html,body,p,ol,ul,li,dl,dt,dd,blockquote,figure,fieldset,legend,textarea,pre,iframe,hr,h1,h2,h3,h4,h5,h6 {
  margin: 0;
  padding: 0
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%
}

ul {
  list-style: none
}

button,
input,
select,
textarea {
  margin: 0
}

html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}

*,
*::before,
*::after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit
}

img,
video {
  height: auto;
  max-width: 100%
}

iframe {
  border: 0
}

table {
  border-collapse: collapse;
  border-spacing: 0
}

td,
th {
  padding: 0
}

td:not([align]),
th:not([align]) {
  text-align: inherit
}

html {
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  min-width: 300px;
  overflow-x: hidden;
  overflow-y: scroll;
  text-rendering: optimizeLegibility;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%
}

article,
aside,
figure,
footer,
header,
hgroup,
section {
  display: block
}

a {
  cursor: pointer;
  text-decoration: none
}

hr {
  background-color: #f5f5f5;
  border: none;
  display: block;
  height: 2px;
  margin: 1.5rem 0
}

img {
  height: auto;
  max-width: 100%;
  vertical-align: top
}

input[type=checkbox],
input[type=radio] {
  vertical-align: baseline
}

fieldset {
  border: none
}

table td,
table th {
  vertical-align: top
}

table td:not([align]),
table th:not([align]) {
  text-align: inherit
}

@media screen and (max-width: 1023.9px) {
  .is-hidden-touch {
    display: none !important
  }
}

html,
body {
  height: 100% !important;
  -webkit-text-size-adjust: 100%;
  font-family: "M PLUS 1", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  color: #333;
  font-optical-sizing: auto
}

html {
  font-size: 16px
}

body {
  font-size: 1em;
  line-height: 1.8;
  font-weight: 500
}

small {
  font-size: .875em
}

span {
  font-style: inherit;
  font-weight: inherit;
  display: inline-block;
  /*font-weight: 400;
  font-size: 1.2em;*/
}

strong {
  font-weight: 700
}

a:link {
  color: inherit;
  text-decoration: underline
}

a:visited {
  color: inherit;
  text-decoration: underline
}

a:hover {
  color: inherit;
  text-decoration: none
}

#header {
  width: 100%
}

.header__inner {
  width: 100%;
  margin: 0px auto;
  position: relative
}

.header__logo {
  position: fixed;
  left: 10px;
  top: 10px;
  width: 120px;
  z-index: 1300;
  -webkit-transition: .3s ease;
  transition: .3s ease
}

.header__logo {
  display: block
}

body.is-gNavOpen .header__logo {
  display: none
}

.header__logo.-navOpen {
  display: none
}

body.is-gNavOpen .header__logo.-navOpen {
  display: block
}

@media screen and (min-width: 768px) {
  .header__logo {
    left: 30px;
    top: 30px;
    width: 200px
  }
}

.header__logoBgBand {
  position: fixed;
  top: 0;
  left: 0;
  width: calc(100% - 15px);
  height: 80px;
  background-color: #333;
  z-index: 1200;
  -webkit-transform: translateY(-100%);
  transform: translateY(-100%);
  -webkit-transition: .3s ease;
  transition: .3s ease
}

body.is-gNavOpen .header__logoBgBand {
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

@media screen and (min-width: 768px) {
  .header {
    height: 130px
  }
}

#content {
  background-color: #fff
}

.content__inner {
  width: 100%;
  max-width: 1310px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
  padding-top: clamp(60px, 10vw, 100px);
  padding-bottom: clamp(80px, 12vw, 120px)
}

.content__inner2 {
  width: 100%;
  max-width: 1150px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px
}

@media screen and (min-width: 1024px) {
  .content__inner {
    max-width: 1340px;
    padding-left: 30px;
    padding-right: 30px
  }

  .content__inner2 {
    max-width: 1180px;
    padding-left: 30px;
    padding-right: 30px
  }
}

#footer {
  background-image: repeating-linear-gradient(90deg, #F0F0F0 0, #F0F0F0 40px, #FFF 40px, #FFF 80px);
  background-size: 80px 100%;
  background-position: center center;
  padding-top: clamp(40px, 6vw, 60px);
  padding-bottom: clamp(150px, 20vw, 200px)
}

@media screen and (min-width: 576px) {
  #footer {
    background-image: repeating-linear-gradient(90deg, #F0F0F0 0, #F0F0F0 50px, #FFF 50px, #FFF 100px);
    background-size: 100px 100%
  }
}

#footer p {
  text-align: center;
  font-weight: 700;
  font-size: clamp(0.875rem, 1.6vw, 1rem);
  margin: 0 0 1em 0
}

#footer p strong {
  font-weight: 900;
  font-size: clamp(1rem, 1.8vw, 1.125rem)
}

#footer p span {
  display: inline-block
}

.footer__inner {
  width: 100%;
  max-width: 1310px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
  text-align: center
}

.footer__title {
  font-size: clamp(1.125rem, 2vw, 1.25rem);
  font-weight: 900;
  padding-top: clamp(25px, 4vw, 40px);
  padding-bottom: .2em;
  color: red;
  letter-spacing: .1em
}

.footer__snsList {
  padding-top: clamp(15px, 2vw, 20px);
  padding-bottom: clamp(15px, 2vw, 20px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 30px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.footer__snsList li,
.footer__snsList a {
  width: 60px;
  height: 60px;
  display: block
}

.footer__snsInsta a {
  background: url(../img/common/icon_insta_black.svg) center center/cover no-repeat
}

.footer__snsX a {
  background: url(../img/common/icon_x_black.svg) center center/cover no-repeat
}

@media screen and (min-width: 1024px) {
  .footer__inner {
    max-width: 1340px;
    padding-left: 30px;
    padding-right: 30px
  }
}

.c-navToggle {
  z-index: 1400;
  position: fixed;
  right: 0px;
  top: 0px;
  width: 66px;
  height: 66px;
  cursor: pointer;
  border-radius: 0px;
  background-color: #333;
  -webkit-transition: .3s ease;
  transition: .3s ease
}

.c-navToggle__icon {
  position: absolute;
  top: 18px;
  left: 16px
}

.c-navToggle__icon span {
  display: block;
  position: absolute;
  height: 4px;
  width: 34px;
  background: #fff;
  border-radius: 3px;
  -webkit-transition: .3s ease;
  transition: .3s ease
}

.c-navToggle__icon span:nth-child(1) {
  top: 0px
}

.c-navToggle__icon span:nth-child(2) {
  top: 12px
}

.c-navToggle__icon span:nth-child(3) {
  top: 24px
}

@media screen and (min-width: 768px) {
  .c-navToggle {
    width: 88px;
    height: 88px
  }

  .c-navToggle__icon {
    top: 25px;
    left: 21px
  }

  .c-navToggle__icon span {
    height: 5px;
    width: 45px;
    border-radius: 3px
  }

  .c-navToggle__icon span:nth-child(1) {
    top: 0px
  }

  .c-navToggle__icon span:nth-child(2) {
    top: 15px
  }

  .c-navToggle__icon span:nth-child(3) {
    top: 30px
  }
}

body.is-gNavOpen .c-navToggle__icon span:nth-child(1) {
  top: 13px;
  -webkit-transform: rotate(315deg);
  transform: rotate(315deg)
}

body.is-gNavOpen .c-navToggle__icon span:nth-child(2) {
  width: 0;
  left: 50%
}

body.is-gNavOpen .c-navToggle__icon span:nth-child(3) {
  top: 13px;
  -webkit-transform: rotate(-315deg);
  transform: rotate(-315deg)
}

@media screen and (min-width: 768px) {
  body.is-gNavOpen .c-navToggle__icon span:nth-child(1) {
    top: 15px;
    -webkit-transform: rotate(315deg);
    transform: rotate(315deg)
  }

  body.is-gNavOpen .c-navToggle__icon span:nth-child(3) {
    top: 15px
  }
}

.c-overlay {
  -webkit-transition: opacity .3s ease, visibility .3s ease;
  transition: opacity .3s ease, visibility .3s ease;
  visibility: hidden;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  width: 100%;
  height: 100vh;
  height: 100lvh;
  background: rgba(0, 0, 0, .3);
  opacity: 0
}

body.is-gNavOpen .c-overlay {
  opacity: 1;
  visibility: visible
}

.c-bgStripe {
  background-image: repeating-linear-gradient(90deg, #F0F0F0 0, #F0F0F0 40px, #FFF 40px, #FFF 80px);
  background-size: 80px 100%;
  background-position: center center
}

@media screen and (min-width: 576px) {
  .c-bgStripe {
    background-image: repeating-linear-gradient(90deg, #F0F0F0 0, #F0F0F0 50px, #FFF 50px, #FFF 100px);
    background-size: 100px 100%
  }
}

.c-bgYellow {
  background-color: #ffffb5
}

.c-bgPink {
  background-color: #ffe6f9
}

.c-title {
  font-weight: 900;
  text-align: center;
  color: #2a47a8
}

.c-title.-styleA {
  font-size: clamp(2.375rem, 5vw, 3.125rem);
  line-height: 1.4;
  background: url(../img/common/icon_star_yellow.svg) center 0/clamp(25px, 3.5vw, 35px) no-repeat;
  padding-top: .8em;
  letter-spacing: .1em
}

.c-title.-styleA.-fontEn {
  font-size: clamp(2.5rem, 5.5vw, 3.4375rem);
  letter-spacing: 0em
}

.c-title.-styleB {
  font-size: clamp(1.875rem, 3.2vw, 2.625rem);
  line-height: 1.4;
  letter-spacing: .1em
}

.c-title.-fontEn {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  letter-spacing: 0em
}

.c-title.-colorBlack {
  color: #333
}

.c-pageTitle {
  text-align: center;
  background-image: repeating-linear-gradient(90deg, #F0F0F0 0, #F0F0F0 40px, #FFF 40px, #FFF 80px);
  background-size: 80px 100%;
  background-position: center center;
  padding-bottom: clamp(50px, 8vw, 80px);
  padding-top: clamp(40px, 6vw, 60px);
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px
}

@media screen and (min-width: 576px) {
  .c-pageTitle {
    background-image: repeating-linear-gradient(90deg, #F0F0F0 0, #F0F0F0 50px, #FFF 50px, #FFF 100px);
    background-size: 100px 100%
  }
}

@media screen and (min-width: 1024px) {
  .c-pageTitle {
    padding-left: 30px;
    padding-right: 30px
  }
}

.c-pageTitle__mainTitle {
  font-size: clamp(2.25rem, 5vw, 3.125rem);
  line-height: 1.4;
  font-weight: 900;
  letter-spacing: .1em;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto
}

.c-pageTitle__mainTitle span {
  display: inline-block
}

.c-pageTitle__eventTitle {
  font-size: clamp(1.875rem, 4.2vw, 2.625rem);
  line-height: 1.4;
  font-weight: 900;
  letter-spacing: .1em;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  color: #2a47a8
}

.c-pageTitle__eventTitle span {
  display: inline-block
}

.c-pageTitle__subTitle {
  color: #2a47a8;
  background: url(../img/common/icon_star_yellow.svg) center 0/clamp(25px, 3.5vw, 35px) no-repeat;
  padding-top: 1.5em;
  margin-top: .5em;
  font-size: clamp(1.625rem, 3.4vw, 2.125rem);
  line-height: 1.4;
  font-weight: 900;
  letter-spacing: .1em;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto
}

.c-pageTitle__subTitle.-colorBlack {
  color: #333
}

.c-pageTitle__subTitle span {
  display: inline-block
}

.c-pageTitle__lead {
  max-width: 960px;
  margin: 0px auto;
  color: #2a47a8;
  font-size: clamp(1.125rem, 2.4vw, 1.5rem);
  line-height: 1.4;
  font-weight: 700;
  padding-top: .8em;
  text-align: center
}

.c-pageTitle__lead span {
  display: inline-block
}

.c-lead.-styleA {
  color: #2a47a8;
  text-align: center;
  line-height: 1.6;
  font-weight: 600
}

.c-lead.-styleB {
  text-align: left;
  line-height: 1.6;
  font-size: clamp(1.125rem, 2.4vw, 1.5rem);
  line-height: 1.6;
  font-weight: 600
}

.c-ticketList {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: clamp(20px, 3vw, 30px) clamp(20px, 3vw, 30px)
}

.c-ticketList li {
  text-align: center;
  font-size: clamp(1.1875rem, 2.5vw, 1.5625rem);
  line-height: 1.4;
  font-weight: 700
}

.c-ticketList li a {
  background: red;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#FF0000), to(#CB0010));
  background-image: linear-gradient(#FF0000, #CB0010);
  display: block;
  padding: .8em .2em;
  border-radius: 50px;
  color: #fff;
  text-decoration: none
}

@media(hover: hover)and (pointer: fine) {
  .c-ticketList li a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .c-ticketList li a:hover {
    opacity: .8
  }
}

@media screen and (min-width: 576px) {
  .c-ticketList {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media screen and (min-width: 1024px) {
  .c-ticketList {
    grid-template-columns: repeat(4, 1fr)
  }

  .c-ticketList li {
    font-size: clamp(1.125rem, 2.4vw, 1.875rem)
  }
}

.c-statusList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: clamp(5px, 1.5vw, 15px)
}

.c-statusList__icon {
  white-space: nowrap;
  background-color: #333;
  color: #fff;
  font-size: clamp(0.875rem, 2vw, 1.25rem);
  font-weight: 700;
  line-height: 1.4;
  padding: .3em .5em
}

.c-statusList__icon.-borderless {
  background-color: #ff5b22
}

.c-statusList__icon.-subtitles {
  background-color: #919090
}

.c-statusList__icon.-stream {
  background-color: red
}

.c-btn.-styleA {
  font-size: clamp(1.125rem, 2vw, 1.25rem);
  font-weight: 700;
  position: relative;
  margin: 0px auto;
  text-align: center;
  width: 100%;
  max-width: 430px;
  display: block
}

.c-btn.-styleA a {
  background: red;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#FF0000), to(#CB0010));
  background-image: linear-gradient(#3f6bfe, #182962);
  width: 100%;
  display: inline-block;
  color: #fff;
  padding: 1.3em 1em;
  border-radius: 50px;
  text-decoration: none
}

@media(hover: hover)and (pointer: fine) {
  .c-btn.-styleA a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .c-btn.-styleA a:hover {
    opacity: .8
  }
}

.c-btn.-styleB {
  font-size: clamp(1.75rem, 5vw, 3.125rem);
  font-weight: 900;
  position: relative;
  margin: 0px auto;
  text-align: center;
  width: 100%;
  display: block
}

.c-btn.-styleB a {
  background: red;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#FF0000), to(#CB0010));
  background-image: linear-gradient(#FF0000, #CB0010);
  width: 100%;
  display: inline-block;
  color: #fff;
  padding: .8em .5em;
  line-height: 1.2;
  text-decoration: none
}

@media(hover: hover)and (pointer: fine) {
  .c-btn.-styleB a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .c-btn.-styleB a:hover {
    opacity: .8
  }
}

.c-btn.-styleB a span {
  display: inline-block
}

.p-globalNav {
  position: fixed;
  top: -3px;
  left: 0;
  width: 100%;
  background-color: #333;
  z-index: 1100;
  -webkit-transform: translateY(-100%);
  transform: translateY(-100%);
  -webkit-transition: -webkit-transform .3s ease;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  overflow-y: auto;
  max-height: 100dvh;
  -webkit-overflow-scrolling: touch
}

.p-globalNav::-webkit-scrollbar {
  width: 3px
}

.p-globalNav::-webkit-scrollbar-thumb {
  background: hsla(0, 0%, 100%, .4);
  border-radius: 5px
}

.p-globalNav::-webkit-scrollbar-track {
  border: none;
  border-radius: 5px;
  background: hsla(0, 0%, 100%, .2)
}

body.is-gNavOpen .p-globalNav {
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

.p-globalNav a {
  text-decoration: none
}

@media(hover: hover)and (pointer: fine) {
  .p-globalNav a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .p-globalNav a:hover {
    opacity: .8
  }
}

.p-globalNav__inner {
  position: relative;
  width: 100%;
  margin: 0px auto;
  padding: 0px 15px;
  display: grid;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: start;
  grid-template-columns: repeat(1, 1fr);
  padding: 120px 50px 110px 50px
}

.p-globalNav__menuWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column
}

.p-globalNav__snsLangWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column
}

@media screen and (min-width: 576px) {
  .p-globalNav__inner {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media screen and (min-width: 768px) {
  .p-globalNav__inner {
    padding: 180px 50px 100px 50px
  }

  .p-globalNav__menuWrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row
  }

  .p-globalNav__menuWrap>*:nth-child(1) {
    -webkit-box-flex: 5;
    -ms-flex: 5;
    flex: 5;
    padding-right: 1em
  }

  .p-globalNav__menuWrap>*:nth-child(2) {
    -webkit-box-flex: 6;
    -ms-flex: 6;
    flex: 6;
    padding-right: 1em
  }

  .p-globalNav__snsLangWrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row
  }

  .p-globalNav__snsLangWrap>*:nth-child(1) {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1
  }

  .p-globalNav__snsLangWrap>*:nth-child(2) {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1
  }
}

@media screen and (min-width: 1024px) {
  .p-globalNav__inner {
    max-width: 1280px;
    padding: 180px 80px 100px 80px
  }
}

.p-globalNav__inner {
  color: #fff
}

.p-globalNav__inner a {
  color: #fff
}

.p-globalNav__inner a.-impLink {
  color: #fdfd00
}

.p-globalNav__menuList>li {
  font-size: 1.25rem;
  line-height: 1.4;
  font-weight: 700;
  padding-bottom: 25px
}

.p-globalNav__menuList>li>ul {
  padding-top: 15px
}

.p-globalNav__menuList>li>ul>li {
  font-size: 1.125rem;
  line-height: 1.4;
  font-weight: 700;
  padding-bottom: 15px
}

.p-globalNav__menuList>li>ul>li a {
  display: block;
  background: url(../img/common/icon_arrow_right_white.svg) left 2px/20px no-repeat;
  padding-left: 30px
}

.p-globalNav__snsTitle {
  font-size: 1.25rem;
  line-height: 1.4;
  font-weight: 700
}

.p-globalNav__snsList {
  padding: 25px 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 35px
}

.p-globalNav__snsList li,
.p-globalNav__snsList a {
  width: 40px;
  height: 40px;
  display: block
}

.p-globalNav__snsInsta a {
  background: url(../img/common/icon_insta_white.svg) center center/cover no-repeat
}

.p-globalNav__snsX a {
  background: url(../img/common/icon_x_white.svg) center center/cover no-repeat
}

.p-globalNav__languageInner {
  border: 1px solid #fff;
  width: 180px;
  padding: 20px 40px
}

.p-globalNav__languageTitle {
  font-size: 1.125rem;
  line-height: 1.4;
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 900
}

.p-globalNav__languageList {
  padding-top: 30px
}

.p-globalNav__languageList>li {
  font-size: 1rem;
  line-height: 1.4;
  font-weight: 700;
  padding-bottom: 10px
}

.p-globalNav__languageList>li a {
  display: block;
  background: url(../img/common/icon_arrow_right_white.svg) left 2px/20px no-repeat;
  padding-left: 30px
}

.p-fixBottomNav {
  background-color: #e70012;
  padding: 15px 10px;
  position: fixed;
  bottom: 0px;
  width: 100%;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  -webkit-transition: -webkit-transform .3s ease;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  z-index: 800
}

.p-fixBottomNav ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 5px;
  margin: 0px auto;
  max-width: 1280px
}

.p-fixBottomNav ul li {
  text-align: center;
  font-size: clamp(0.625rem, 3vw, 1.875rem);
  line-height: 1.4;
  font-weight: 800;
  color: #2a47a8
}

.p-fixBottomNav ul li a {
  background-color: #fff;
  display: block;
  padding: .5em .2em;
  border-radius: 50px;
  text-decoration: none
}

@media(hover: hover)and (pointer: fine) {
  .p-fixBottomNav ul li a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .p-fixBottomNav ul li a:hover {
    opacity: .8
  }
}

body.is-scrollDown .p-fixBottomNav {
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

@media screen and (min-width: 576px) {
  .p-fixBottomNav {
    padding: 20px 1.5vw
  }

  .p-fixBottomNav ul {
    gap: clamp(20px, 3vw, 40px) clamp(20px, 3vw, 40px)
  }

  .p-fixBottomNav ul li {
    font-weight: 800
  }
}

@media screen and (min-width: 1024px) {
  .p-fixBottomNav ul {
    gap: clamp(20px, 3vw, 40px) clamp(30px, 5vw, 60px)
  }

  .p-fixBottomNav ul li {
    font-size: clamp(1.125rem, 3vw, 1.875rem)
  }
}

.p-locationList>li {
  padding-top: clamp(60px, 10vw, 100px)
}

.p-locationList__name {
  font-size: clamp(2.25rem, 5vw, 3.125rem);
  line-height: 1.3;
  font-weight: 900;
  text-align: center;
  color: #2a47a8;
  letter-spacing: .1em
}

.p-locationList__name span {
  display: inline-block
}

.p-locationList__date {
  font-weight: 700;
  margin-top: .4em;
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: clamp(1.5rem, 3.4vw, 2.125rem);
  line-height: 1.2;
  text-align: center
}

.p-locationList__caption {
  font-size: clamp(0.875rem, 1.6vw, 1rem);
  padding-top: .5em
}

.p-locationList__program {
  font-size: clamp(1.1875rem, 2.6vw, 1.625rem);
  font-weight: 900;
  line-height: 1.4
}

.p-locationList__photoMap {
  margin-top: clamp(15px, 2vw, 20px);
  margin-bottom: clamp(15px, 2vw, 20px);
  display: grid;
  grid-template-columns: repeat(1, 1fr)
}

.p-locationList__photoMap img {
  width: 100%;
  height: auto;
  vertical-align: top
}

.p-locationList__photo {
  aspect-ratio: 3/2;
  overflow: hidden;
  position: relative
}

.p-locationList__photo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block
}

.p-locationList__map {
  position: relative;
  aspect-ratio: 16/9
}

.p-locationList__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0
}

.p-locationList .c-btn {
  margin-top: clamp(25px, 4vw, 40px)
}

@media screen and (min-width: 768px) {
  .p-locationList__photoMap {
    grid-template-columns: repeat(2, 1fr)
  }

  .p-locationList__photoMap.-photoOnly {
    max-width: 50%;
    grid-template-columns: repeat(1, 1fr);
    margin-left: auto;
    margin-right: auto
  }

  .p-locationList__map {
    aspect-ratio: auto;
    width: 100%;
    height: 100%
  }

  .p-locationList__map iframe {
    position: static;
    width: 100%;
    height: 100%
  }
}

.p-mainVisual__photo {
  overflow: hidden;
  position: relative;
  height: clamp(300px, 40vw, 600px)
}

.p-mainVisual__photo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center center;
  object-position: center center;
  display: block
}

.p-mainVisual__photo.-hankyuSunhiroba img {
  -o-object-position: center 90%;
  object-position: center 90%
}

.p-mainVisual__photo.-logoView {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}

.p-mainVisual__photo.-logoView img {
  width: 80%;
  max-width: 360px;
  height: auto;
  margin: 0 auto;
  display: block;
  -webkit-transform: translateY(15%);
  transform: translateY(15%)
}

@media screen and (min-width: 768px) {
  .p-mainVisual__photo.-logoView img {
    width: 50%;
    max-width: 800px;
    -webkit-transform: translateY(8%);
    transform: translateY(8%)
  }
}

.p-scheduleList {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(30px, 5vw, 60px) clamp(20px, 3vw, 40px)
}

.p-scheduleList .c-btn {
  margin-top: 2em;
  max-width: none
}

.p-scheduleList .c-statusList {
  margin-top: 2em
}

.p-scheduleList>li {
  background-color: #fff
}

.p-scheduleList__date {
  background-color: #2a47a8;
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: clamp(1.75rem, 3.8vw, 2.375rem);
  line-height: 1.2;
  text-align: center;
  padding: .2em .2em .3em .3em;
  font-weight: 700
}

.p-scheduleList__inner {
  padding: clamp(15px, 3vw, 30px);
  border-top: 10px solid #ffe6f9
}

.p-scheduleList__photo {
  aspect-ratio: 16/9;
  overflow: hidden;
  position: relative
}

.p-scheduleList__photo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block
}

.p-scheduleList__photo.-sizeAuto {
  aspect-ratio: auto;
  overflow: visible;
  width: 100%;
  height: auto
}

.p-scheduleList__photo.-sizeAuto img {
  width: 100%;
  height: auto;
  vertical-align: top;
  -o-object-fit: initial;
  object-fit: initial
}

.p-scheduleList__title {
  font-size: clamp(1.25rem, 2.4vw, 1.5rem);
  font-weight: 900;
  line-height: 1.3;
  color: #2a47a8;
  margin-top: .8em
}

.p-scheduleList__time {
  display: grid;
  gap: 0px 5px;
  font-size: clamp(1.125rem, 2vw, 1.25rem);
  font-weight: 700;
  border-top: 3px dotted #707070;
  line-height: 1.4;
  margin-top: 1.3em
}

.p-scheduleList__time>dt {
  padding: .5em 0 0 0
}

.p-scheduleList__time>dd {
  padding: .5em 0 0 0
}

.p-scheduleList__price {
  display: grid;
  grid-template-columns: 3.5em auto;
  gap: 10px 5px;
  font-size: clamp(1.125rem, 2vw, 1.25rem);
  font-weight: 700;
  border-top: 3px dotted #707070;
  line-height: 1.4;
  margin-top: 1em
}

.p-scheduleList__price>dt {
  padding: .5em 0 0 0
}

.p-scheduleList__price>dd {
  padding: .5em 0 0 0
}

.p-scheduleList__price>dd span {
  display: inline-block;
  /*white-space: nowrap;*/
  font-weight: 400;	
}

.p-scheduleList__price>dd span small {
  font-size: 0.8em;
}

.p-scheduleList__desc {
  margin-top: 1em;
  border-top: 3px dotted #707070;
  font-size: clamp(0.875rem, 1.6vw, 1rem);
  font-weight: 500;
  padding: .5em 0
}

.p-scheduleList__desc p {
  margin: 1em 0
}

.p-scheduleList__ticket {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 2vw, 20px) clamp(20px, 2.5vw, 25px);
  margin-top: 3em
}

.p-scheduleList__ticket>li {
  text-align: center;
  font-size: 1rem;
  line-height: 1.7;
  line-height: 1.4;
  font-weight: 700
}

.p-scheduleList__ticket>li a {
  background: red;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#FF0000), to(#CB0010));
  background-image: linear-gradient(#FF0000, #CB0010);
  display: block;
  padding: .8em .2em;
  border-radius: 50px;
  color: #fff;
  text-decoration: none
}

@media(hover: hover)and (pointer: fine) {
  .p-scheduleList__ticket>li a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .p-scheduleList__ticket>li a:hover {
    opacity: .8
  }
}

@media screen and (min-width: 576px) {
  .p-scheduleList__ticket {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media screen and (min-width: 1024px) {
  .p-scheduleList__ticket {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media screen and (min-width: 768px) {
  .p-scheduleList {
    grid-template-columns: repeat(2, 1fr)
  }
}

.p-scheduleList2 {
  margin-top: 10px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px
}

.p-scheduleList2 .c-statusList {
  margin-top: 2em
}

.p-scheduleList2__date {
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: clamp(1.75rem, 3.8vw, 2.375rem);
  line-height: 1.2;
  text-align: center;
  padding: .2em .2em .3em .3em;
  font-weight: 700;
  background-color: #2a47a8
}

.p-scheduleList2>li {
  padding: clamp(15px, 3vw, 30px);
  background-color: #fff;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(15px, 3vw, 30px)
}

.p-scheduleList2__photo {
  aspect-ratio: 16/9;
  overflow: hidden;
  position: relative
}

.p-scheduleList2__photo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block
}

.p-scheduleList2__photo.-sizeAuto {
  aspect-ratio: auto;
  overflow: visible;
  width: 100%;
  height: auto
}

.p-scheduleList2__photo.-sizeAuto img {
  width: 100%;
  height: auto;
  vertical-align: top;
  -o-object-fit: initial;
  object-fit: initial
}

.p-scheduleList2__title {
  font-size: clamp(1.875rem, 4vw, 2.5rem);
  font-weight: 900;
  line-height: 1.3;
  color: #2a47a8;
  margin-top: .3em
}

.p-scheduleList2__time {
  display: grid;
  grid-template-columns: 3.5em auto;
  gap: 10px 5px;
  font-size: clamp(1.125rem, 2vw, 1.25rem);
  font-weight: 700;
  border-top: 3px dotted #707070;
  border-bottom: 3px dotted #707070;
  line-height: 1.4;
  margin-top: 1.4em
}

.p-scheduleList2__time dt {
  padding: .5em 0
}

.p-scheduleList2__time dd {
  padding: .5em 0
}

.p-scheduleList2__timeTableTitle {
  margin-top: 1.5em
}

.p-scheduleList2__timeTable {
  display: grid;
  grid-template-columns: 100px auto;
  gap: 5px 5px;
  font-weight: 500;
  line-height: 1.4;
  margin-top: .3em
}

.p-scheduleList2__timeTable dt {
  font-size: 0.875rem;
  line-height: 1.7
}

.p-scheduleList2__lead {
  font-size: clamp(1.1875rem, 2.4vw, 1.5rem);
  line-height: 1.5;
  font-weight: 700;
  margin-top: .8em
}

@media screen and (min-width: 768px) {
  .p-scheduleList2>li {
    grid-template-columns: repeat(2, 1fr)
  }
}

.p-impNewsBox {
  background-color: #333;
  color: #fff
}

.p-impNewsBox__inner {
  width: 100%;
  max-width: 1310px;
  margin-left: auto;
  margin-right: auto;
  padding: 30px 15px
}

.p-impNewsBox__title {
  font-size: clamp(1.5rem, 3.2vw, 2rem);
  font-weight: 900
}

.p-impNewsBox__text {
  padding-top: .5em
}

@media screen and (min-width: 1024px) {
  .p-impNewsBox__inner {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 20px;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: start;
    padding: 60px 15px
  }
}

.p-newScroolBox__inner {
  width: 100%;
  margin: 0 auto;
  height: 330px;
  padding: 20px;
  background: #fff;
  border-radius: 10px 0px 0px 10px
}

.p-newScroolBox__inner .simplebar-scrollbar {
  background-color: gray !important;
  border-radius: 13px
}

.p-newScroolBox__inner .simplebar-scrollbar::before {
  background-color: rgba(0, 0, 0, 0) !important
}

.p-newScroolBox__inner .simplebar-track {
  background-color: #fff
}

.p-newScroolBox__inner dl {
  display: grid;
  grid-template-columns: 1fr;
  line-height: 1.6
}

.p-newScroolBox__inner dl dt {
  font-weight: 900
}

.p-newScroolBox__inner dl dd {
  margin: 0;
  font-weight: 700;
  padding-bottom: 2em;
  padding-top: .2em
}

@media screen and (min-width: 768px) {
  .p-newScroolBox__inner {
    padding: 40px;
    border-radius: 30px 0px 0px 30px
  }

  .p-newScroolBox__inner dl {
    grid-template-columns: 120px 1fr;
    gap: clamp(20px, 3vw, 40px) clamp(10px, 1vw, 20px)
  }

  .p-newScroolBox__inner dl dd {
    padding: 0px
  }
}

.p-accessBox__map {
  margin-top: clamp(25px, 4vw, 40px);
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 48%
}

.p-accessBox__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.p-accessBox__info {
  text-align: center;
  font-weight: 500
}

.p-accessBox__info .c-title {
  margin: 1.5em 0 .5em 0
}

.p-accessBox__info p {
  margin: 1em 0
}

.p-accessBox__info p span {
  display: inline-block
}

.p-leafletBox__img {
  width: 100%;
  max-width: 850px;
  margin: 30px auto
}

.p-leafletBox__text {
  text-align: center;
  font-weight: 700;
  padding: 1em 0
}

.p-eventBox__lead {
  text-align: center;
  font-size: clamp(1.125rem, 2.4vw, 1.5rem);
  font-weight: bold
}

.p-eventBox__infoList {
  margin-top: clamp(25px, 4vw, 40px);
  display: grid;
  grid-template-columns: 1fr
}

.p-eventBox__infoList>dt {
  text-align: center;
  color: #fff;
  font-weight: 700;
  background-color: #2a47a8;
  padding: 1em .5em;
  font-size: clamp(1.125rem, 2.4vw, 1.5rem);
  line-height: 1.5
}

.p-eventBox__infoList>dd {
  background-color: #fff;
  font-size: clamp(1.125rem, 2.4vw, 1.5rem);
  line-height: 1.5;
  padding: 1em 1em 1.5em 1em
}

.p-eventBox__infoList>dd p {
  font-size: clamp(0.875rem, 1.6vw, 1rem);
  margin-top: .5em;
  font-weight: 500
}

.p-eventBox__infoList .c-statusList {
  padding-bottom: .5em
}

@media screen and (min-width: 768px) {
  .p-eventBox__infoList {
    grid-template-columns: clamp(160px, 20vw, 200px) 1fr;
    gap: 15px 0
  }

  .p-eventBox__infoList>dd {
    padding: 1em
  }
}

.p-eventBox__castName {
  margin-top: clamp(50px, 8vw, 80px);
  font-size: clamp(1rem, 2.2vw, 1.375rem);
  font-weight: 700;
  line-height: 1.5
}

.p-eventBox__castPhotoList {
  margin-top: clamp(25px, 4vw, 40px);
  display: grid;
  grid-template-columns: repeat(2, 1fr)
}

.p-eventBox__castPhotoList>li {
  aspect-ratio: 1/1;
  overflow: hidden;
  position: relative
}

.p-eventBox__castPhotoList img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block
}

@media screen and (min-width: 480px) {
  .p-eventBox__castPhotoList {
    grid-template-columns: repeat(3, 1fr)
  }
}

@media screen and (min-width: 768px) {
  .p-eventBox__castPhotoList {
    grid-template-columns: repeat(5, 1fr)
  }
}

.p-eventTicket__info {
  margin-top: clamp(25px, 4vw, 40px)
}

.p-eventTicket__price {
  text-align: center;
  margin-bottom: .3em;
  font-size: clamp(1.375rem, 2.8vw, 1.75rem);
  line-height: 1.5
}

.p-eventTicket__price span {
  display: inline-block;
  padding: 0 .5em
}

.p-eventTicket p {
  text-align: center;
  line-height: 1.5
}

.p-eventTicket .c-ticketList {
  margin-top: clamp(25px, 4vw, 40px)
}

.p-cautionBox {
  padding-top: clamp(40px, 6vw, 60px)
}

.p-cautionBox__title {
  font-weight: 700;
  margin-top: clamp(40px, 6vw, 60px)
}

.p-cautionBox__list>li {
  padding-left: 1.2em;
  text-indent: -1.2em
}

.p-cautionBox__list>li::before {
  content: "※ "
}

.p-cautionBox__list>li ul {
  margin-left: 1em
}

.p-cautionBox__list>li ul li {
  padding-left: 1.2em;
  text-indent: -1.2em
}

.p-cautionBox__list>li ul li::before {
  content: "・ "
}

.p-homeMainVisual {
  position: relative;
  width: 100%
}

.p-homeMainVisual__logoWrap {
  width: 90%;
  max-width: 960px;
  padding-bottom: clamp(200px, 26vw, 260px);
  margin: 0px auto;
  margin: 100px auto 50px auto;
  position: relative
}

.p-homeMainVisual__logo {
  width: 100%;
  height: auto;
  vertical-align: top
}

.p-homeMainVisual__ticket {
  max-width: 220px;
  width: clamp(160px, 22vw, 220px);
  height: auto;
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  bottom: 0px
}

.p-homeMainVisual__ticket img {
  width: 80%;
  height: auto;
  vertical-align: top
}

@media(hover: hover)and (pointer: fine) {
  .p-homeMainVisual__ticket a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .p-homeMainVisual__ticket a:hover {
    opacity: .8
  }
}

.p-homeMainVisual__snsList {
  position: absolute;
  right: 10px;
  bottom: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 20px
}

.p-homeMainVisual__snsList li,
.p-homeMainVisual__snsList a {
  width: 40px;
  height: 40px;
  display: block
}

@media(hover: hover)and (pointer: fine) {

  .p-homeMainVisual__snsList li,
  .p-homeMainVisual__snsList a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .p-homeMainVisual__snsList li:hover,
  .p-homeMainVisual__snsList a:hover {
    opacity: .8
  }
}

.p-homeMainVisual__snsInsta a {
  background: url(../img/common/icon_insta_black.svg) center center/cover no-repeat
}

.p-homeMainVisual__snsX a {
  background: url(../img/common/icon_x_black.svg) center center/cover no-repeat
}

@media screen and (min-width: 768px) {
  .p-homeMainVisual__snsList {
    top: 55%;
    bottom: auto;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    gap: 25px
  }

  .p-homeMainVisual__snsList li,
  .p-homeMainVisual__snsList a {
    width: 60px;
    height: 60px
  }
}

@media screen and (min-width: 1024px) {
  .p-homeMainVisual__logoWrap {
    padding-bottom: 100px;
    margin: 150px auto 150px auto
  }

  .p-homeMainVisual__ticket {
    left: 0;
    bottom: -50px;
    -webkit-transform: translateX(-15%);
    transform: translateX(-15%)
  }
}

@media screen and (min-width:1216px) {
  .p-homeMainVisual__ticket {
    bottom: -30px
  }
}

.p-homeIntroBox__lead {
  font-size: clamp(2.625rem, 6.5vw, 4.0625rem);
  line-height: 1.2;
  font-weight: 900;
  text-align: center;
  color: #2a47a8
}

.p-homeIntroBox__lead span {
  display: inline-block
}

.p-homeIntroBox__title {
  font-size: clamp(1rem, 2.4vw, 1.5rem);
  font-weight: 700;
  text-align: center
}

.p-homeIntroBox__title span {
  display: inline-block
}

.p-homeOutlineDateBox {
  background-color: #fff;
  border-radius: 10px;
  margin-top: clamp(60px, 10vw, 100px);
  padding-top: clamp(25px, 4vw, 40px);
  padding-bottom: clamp(25px, 4vw, 40px);
  padding-left: 15px;
  padding-right: 15px;
  text-align: center
}

.p-homeOutlineDateBox__date {
  font-weight: 700;
  margin-top: .5em;
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: clamp(1.125rem, 3.4vw, 2.125rem);
  line-height: 1.2
}

.p-homeOutlineDateBox__date span {
  font-size: clamp(1.625rem, 5vw, 3.125rem);
  line-height: 1.2
}

.p-homeOutlineDateBox__supText {
  font-size: clamp(0.875rem, 1.6vw, 1rem);
  font-weight: 700;
  margin: 1.5em 0 .5em 0
}

@media screen and (min-width: 480px) {
  .p-homeOutlineDateBox__date {
    font-size: clamp(1.5625rem, 3.4vw, 2.125rem)
  }

  .p-homeOutlineDateBox__date span {
    font-size: clamp(2.25rem, 5vw, 3.125rem)
  }
}

@media screen and (min-width: 768px) {
  .p-homeOutlineDateBox {
    border-radius: 30px
  }
}

.p-recruitOverview {
  background-color: #fff;
  border-radius: 10px;
  padding: clamp(25px, 5vw, 50px);
  padding-top: 0px
}

.p-recruitOverview__title {
  font-size: clamp(1.875rem, 4.2vw, 2.625rem);
  color: #2a47a8;
  line-height: 1.4;
  font-weight: 900;
  letter-spacing: .1em;
  text-align: center;
  padding-top: clamp(25px, 5vw, 50px)
}

.p-recruitOverview__date {
  margin-top: .2em;
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: clamp(1.125rem, 3.4vw, 2.125rem);
  line-height: 1.2;
  text-align: center;
  font-weight: 700
}

.p-recruitOverview__date span {
  font-size: clamp(1.625rem, 5vw, 3.125rem)
}

.p-recruitOverview__text {
  margin-top: .5em
}

@media screen and (min-width: 768px) {
  .p-recruitOverview {
    border-radius: 30px
  }
}

.p-recruitList {
  margin-top: 10px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px
}

.p-recruitList__mainTitle {
  background-color: #2a47a8;
  color: #fff;
  font-size: clamp(1.75rem, 3.8vw, 2.375rem);
  line-height: 1.4;
  text-align: center;
  padding: .2em .2em .4em .3em;
  font-weight: 700;
  margin-top: clamp(50px, 8vw, 80px)
}

.p-recruitList li {
  padding: clamp(15px, 3vw, 30px);
  background-color: #fff;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(15px, 3vw, 30px)
}

.p-recruitList__photo {
  aspect-ratio: 3/2;
  overflow: hidden;
  position: relative
}

.p-recruitList__photo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block
}

.p-recruitList__photo.-sizeAuto {
  aspect-ratio: auto;
  overflow: visible;
  width: 100%;
  height: auto
}

.p-recruitList__photo.-sizeAuto img {
  width: 100%;
  height: auto;
  vertical-align: top;
  -o-object-fit: initial;
  object-fit: initial
}

.p-recruitList__title {
  font-size: clamp(1.875rem, 4vw, 2.5rem);
  font-weight: 900;
  line-height: 1.3;
  color: #2a47a8
}

.p-recruitList__lead {
  font-size: clamp(1.125rem, 2.4vw, 1.5rem);
  font-weight: 700;
  border-top: 3px dotted #707070;
  border-bottom: 3px dotted #707070;
  line-height: 1.4;
  margin-top: 1.2em;
  padding: .8em 0
}

.p-recruitList p {
  margin-top: 1.2em
}

@media screen and (min-width: 768px) {
  .p-recruitList li {
    grid-template-columns: repeat(2, 1fr)
  }
}

.u-mt-XL {
  margin-top: clamp(80px, 12vw, 120px)
}

.u-mb-XL {
  margin-bottom: clamp(80px, 12vw, 120px)
}

.u-mtb-XL {
  margin-top: clamp(80px, 12vw, 120px);
  margin-bottom: clamp(80px, 12vw, 120px)
}

.u-m-XL {
  margin: clamp(80px, 12vw, 120px)
}

.u-pt-XL {
  padding-top: clamp(80px, 12vw, 120px)
}

.u-pb-XL {
  padding-bottom: clamp(80px, 12vw, 120px)
}

.u-ptb-XL {
  padding-top: clamp(80px, 12vw, 120px);
  padding-bottom: clamp(80px, 12vw, 120px)
}

.u-p-XL {
  padding: clamp(80px, 12vw, 120px)
}

.u-mt-L {
  margin-top: clamp(60px, 10vw, 100px)
}

.u-mb-L {
  margin-bottom: clamp(60px, 10vw, 100px)
}

.u-mtb-L {
  margin-top: clamp(60px, 10vw, 100px);
  margin-bottom: clamp(60px, 10vw, 100px)
}

.u-m-L {
  margin: clamp(60px, 10vw, 100px)
}

.u-pt-L {
  padding-top: clamp(60px, 10vw, 100px)
}

.u-pb-L {
  padding-bottom: clamp(60px, 10vw, 100px)
}

.u-ptb-L {
  padding-top: clamp(60px, 10vw, 100px);
  padding-bottom: clamp(60px, 10vw, 100px)
}

.u-p-L {
  padding: clamp(60px, 10vw, 100px)
}

.u-mt-M {
  margin-top: clamp(50px, 8vw, 80px)
}

.u-mb-M {
  margin-bottom: clamp(50px, 8vw, 80px)
}

.u-mtb-M {
  margin-top: clamp(50px, 8vw, 80px);
  margin-bottom: clamp(50px, 8vw, 80px)
}

.u-m-M {
  margin: clamp(50px, 8vw, 80px)
}

.u-pt-M {
  padding-top: clamp(50px, 8vw, 80px)
}

.u-pb-M {
  padding-bottom: clamp(50px, 8vw, 80px)
}

.u-ptb-M {
  padding-top: clamp(50px, 8vw, 80px);
  padding-bottom: clamp(50px, 8vw, 80px)
}

.u-p-M {
  padding: clamp(50px, 8vw, 80px)
}

.u-mt-S {
  margin-top: clamp(40px, 6vw, 60px)
}

.u-mb-S {
  margin-bottom: clamp(40px, 6vw, 60px)
}

.u-mtb-S {
  margin-top: clamp(40px, 6vw, 60px);
  margin-bottom: clamp(40px, 6vw, 60px)
}

.u-m-S {
  margin: clamp(40px, 6vw, 60px)
}

.u-pt-S {
  padding-top: clamp(40px, 6vw, 60px)
}

.u-pb-S {
  padding-bottom: clamp(40px, 6vw, 60px)
}

.u-ptb-S {
  padding-top: clamp(40px, 6vw, 60px);
  padding-bottom: clamp(40px, 6vw, 60px)
}

.u-p-S {
  padding: clamp(40px, 6vw, 60px)
}

.u-mt-XS {
  margin-top: clamp(25px, 4vw, 40px)
}

.u-mb-XS {
  margin-bottom: clamp(25px, 4vw, 40px)
}

.u-mtb-XS {
  margin-top: clamp(25px, 4vw, 40px);
  margin-bottom: clamp(25px, 4vw, 40px)
}

.u-m-XS {
  margin: clamp(25px, 4vw, 40px)
}

.u-pt-XS {
  padding-top: clamp(25px, 4vw, 40px)
}

.u-pb-XS {
  padding-bottom: clamp(25px, 4vw, 40px)
}

.u-ptb-XS {
  padding-top: clamp(25px, 4vw, 40px);
  padding-bottom: clamp(25px, 4vw, 40px)
}

.u-p-XS {
  padding: clamp(25px, 4vw, 40px)
}

.u-mt-XXS {
  margin-top: clamp(15px, 2vw, 20px)
}

.u-mb-XXS {
  margin-bottom: clamp(15px, 2vw, 20px)
}

.u-mtb-XXS {
  margin-top: clamp(15px, 2vw, 20px);
  margin-bottom: clamp(15px, 2vw, 20px)
}

.u-m-XXS {
  margin: clamp(15px, 2vw, 20px)
}

.u-pt-XXS {
  padding-top: clamp(15px, 2vw, 20px)
}

.u-pb-XXS {
  padding-bottom: clamp(15px, 2vw, 20px)
}

.u-ptb-XXS {
  padding-top: clamp(15px, 2vw, 20px);
  padding-bottom: clamp(15px, 2vw, 20px)
}

.u-p-XXS {
  padding: clamp(15px, 2vw, 20px)
}

.u-pt-none {
  padding-top: 0 !important
}

.u-pb-none {
  padding-bottom: 0 !important
}

.u-ptb-none {
  padding-top: 0 !important;
  padding-bottom: 0 !important
}

.u-p-none {
  padding: 0 !important
}

.u-mt-none {
  margin-top: 0 !important
}

.u-mb-none {
  margin-bottom: 0 !important
}

.u-mtb-none {
  margin-top: 0 !important;
  margin-bottom: 0 !important
}

.u-m-none {
  margin: 0 !important
}

.u-gap-XXL {
  gap: clamp(80px, 13vw, 150px)
}

.u-gap-XXL-XXL {
  gap: clamp(80px, 13vw, 150px) clamp(80px, 13vw, 150px)
}

.u-gap-XXL-XL {
  gap: clamp(80px, 13vw, 150px) clamp(50px, 9vw, 100px)
}

.u-gap-XXL-L {
  gap: clamp(80px, 13vw, 150px) clamp(40px, 7vw, 80px)
}

.u-gap-XXL-M {
  gap: clamp(80px, 13vw, 150px) clamp(30px, 5vw, 60px)
}

.u-gap-XXL-S {
  gap: clamp(80px, 13vw, 150px) clamp(20px, 3vw, 40px)
}

.u-gap-XXL-XS {
  gap: clamp(80px, 13vw, 150px) clamp(10px, 1vw, 20px)
}

.u-gap-XL {
  gap: clamp(50px, 9vw, 100px)
}

.u-gap-XL-XXL {
  gap: clamp(50px, 9vw, 100px) clamp(80px, 13vw, 150px)
}

.u-gap-XL-XL {
  gap: clamp(50px, 9vw, 100px) clamp(50px, 9vw, 100px)
}

.u-gap-XL-L {
  gap: clamp(50px, 9vw, 100px) clamp(40px, 7vw, 80px)
}

.u-gap-XL-M {
  gap: clamp(50px, 9vw, 100px) clamp(30px, 5vw, 60px)
}

.u-gap-XL-S {
  gap: clamp(50px, 9vw, 100px) clamp(20px, 3vw, 40px)
}

.u-gap-XL-XS {
  gap: clamp(50px, 9vw, 100px) clamp(10px, 1vw, 20px)
}

.u-gap-L {
  gap: clamp(40px, 7vw, 80px)
}

.u-gap-L-XXL {
  gap: clamp(40px, 7vw, 80px) clamp(80px, 13vw, 150px)
}

.u-gap-L-XL {
  gap: clamp(40px, 7vw, 80px) clamp(50px, 9vw, 100px)
}

.u-gap-L-L {
  gap: clamp(40px, 7vw, 80px) clamp(40px, 7vw, 80px)
}

.u-gap-L-M {
  gap: clamp(40px, 7vw, 80px) clamp(30px, 5vw, 60px)
}

.u-gap-L-S {
  gap: clamp(40px, 7vw, 80px) clamp(20px, 3vw, 40px)
}

.u-gap-L-XS {
  gap: clamp(40px, 7vw, 80px) clamp(10px, 1vw, 20px)
}

.u-gap-M {
  gap: clamp(30px, 5vw, 60px)
}

.u-gap-M-XXL {
  gap: clamp(30px, 5vw, 60px) clamp(80px, 13vw, 150px)
}

.u-gap-M-XL {
  gap: clamp(30px, 5vw, 60px) clamp(50px, 9vw, 100px)
}

.u-gap-M-L {
  gap: clamp(30px, 5vw, 60px) clamp(40px, 7vw, 80px)
}

.u-gap-M-M {
  gap: clamp(30px, 5vw, 60px) clamp(30px, 5vw, 60px)
}

.u-gap-M-S {
  gap: clamp(30px, 5vw, 60px) clamp(20px, 3vw, 40px)
}

.u-gap-M-XS {
  gap: clamp(30px, 5vw, 60px) clamp(10px, 1vw, 20px)
}

.u-gap-S {
  gap: clamp(20px, 3vw, 40px)
}

.u-gap-S-XXL {
  gap: clamp(20px, 3vw, 40px) clamp(80px, 13vw, 150px)
}

.u-gap-S-XL {
  gap: clamp(20px, 3vw, 40px) clamp(50px, 9vw, 100px)
}

.u-gap-S-L {
  gap: clamp(20px, 3vw, 40px) clamp(40px, 7vw, 80px)
}

.u-gap-S-M {
  gap: clamp(20px, 3vw, 40px) clamp(30px, 5vw, 60px)
}

.u-gap-S-S {
  gap: clamp(20px, 3vw, 40px) clamp(20px, 3vw, 40px)
}

.u-gap-S-XS {
  gap: clamp(20px, 3vw, 40px) clamp(10px, 1vw, 20px)
}

.u-gap-XS {
  gap: clamp(10px, 1vw, 20px)
}

.u-gap-XS-XXL {
  gap: clamp(10px, 1vw, 20px) clamp(80px, 13vw, 150px)
}

.u-gap-XS-XL {
  gap: clamp(10px, 1vw, 20px) clamp(50px, 9vw, 100px)
}

.u-gap-XS-L {
  gap: clamp(10px, 1vw, 20px) clamp(40px, 7vw, 80px)
}

.u-gap-XS-M {
  gap: clamp(10px, 1vw, 20px) clamp(30px, 5vw, 60px)
}

.u-gap-XS-S {
  gap: clamp(10px, 1vw, 20px) clamp(20px, 3vw, 40px)
}

.u-gap-XS-XS {
  gap: clamp(10px, 1vw, 20px) clamp(10px, 1vw, 20px)
}