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;
  text-rendering: optimizeLegibility
}

html,
body {
  -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
}

/* PCでは改行を無効にする */
.sp-br {
  display: none;
}

/* 画面幅が576px以下の時（スマホ）だけ改行を有効にする */
@media screen and (max-width: 576px) {
  .sp-br {
    display: inline;
  }
}

@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: 700
}

small {
  font-size: .875em
}

span {
  font-style: inherit;
  font-weight: inherit
}

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 {
  margin: 70px auto 0px auto;
  width: 63%;
  -webkit-transition: .3s ease;
  transition: .3s ease
}

.content__inner {
  width: 100%;
  max-width: 1310px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px
}

.content__inner2 {
  width: 100%;
  max-width: 1190px;
  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: 1220px;
    padding-left: 30px;
    padding-right: 30px
  }
}

#footer {
  padding-top: clamp(100px, 18vw, 180px);
  padding-bottom: clamp(100px, 18vw, 180px);
  background-color: #4fa8d7
}

.footer__inner {
  width: 100%;
  max-width: 1310px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
  text-align: center
}

.footer__logo {
  width: 100%;
  max-width: 580px;
  margin: 0px auto
}

.footer__logo img {
  width: 100%;
  height: auto;
  vertical-align: top
}

.footer__snsList {
  padding-top: clamp(26px, 3.5vw, 35px);
  margin: 0px auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 37px
}

.footer__snsList li,
.footer__snsList a {
  width: 60px;
  height: 60px;
  display: block
}

@media(hover: hover)and (pointer: fine) {

  .footer__snsList li,
  .footer__snsList a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .footer__snsList li:hover,
  .footer__snsList a:hover {
    opacity: .8
  }
}

.footer__snsInsta a {
  background: url(../img/common/icon_insta_blue.svg) center center/cover no-repeat
}

.footer__snsX a {
  background: url(../img/common/icon_x_blue.svg) center center/cover no-repeat
}

.footer__snsFB a {
  background: url(../img/common/icon_fb_blue.svg) center center/cover no-repeat
}

.footer__title {
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  padding-bottom: .5em;
  margin-top: 1.8em
}

.footer__normalText {
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  color: #fff
}

.footer__hostText {
  font-size: clamp(1.5rem, 3.2vw, 2rem);
  line-height: 1.4;
  color: #fff
}

.footer__banner {
  width: 100%;
  max-width: 580px;
  margin: 0 auto;
  margin-top: clamp(50px, 8vw, 80px)
}

.footer__banner img {
  width: 100%;
  height: auto;
  vertical-align: top
}

@media(hover: hover)and (pointer: fine) {
  .footer__banner a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .footer__banner a:hover {
    opacity: .8
  }
}

.footer__suppleText {
  font-size: clamp(0.875rem, 1.6vw, 1rem);
  color: #fff;
  margin-top: 2em
}

.footer__copyText {
  font-size: clamp(0.875rem, 1.6vw, 1rem);
  color: #fff;
  margin-top: 2em;
  margin-bottom: 5em
}

.c-navToggle {
  z-index: 800;
  position: fixed;
  right: 0px;
  top: 0px;
  width: 60px;
  height: 60px;
  cursor: pointer;
  border-radius: 0px;
  background-color: #df7791;
  -webkit-transition: .3s ease;
  transition: .3s ease
}

.c-navToggle__icon {
  position: absolute;
  top: 15px;
  left: 13px
}

.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
}

body.is-gNavOpen .c-navToggle {
  background-color: rgba(0, 0, 0, 0)
}

body.is-gNavOpen .c-navToggle__icon span:nth-child(1) {
  top: 12px;
  -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: 12px;
  -webkit-transform: rotate(-315deg);
  transform: rotate(-315deg)
}

.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: 600;
  width: 100%;
  height: 100vh;
  height: 100lvh;
  background: rgba(0, 0, 0, .8);
  opacity: 0
}

body.is-gNavOpen .c-overlay {
  opacity: 1;
  visibility: visible
}

.c-bgLogoGray {
  background: url(../img/common/bk_logo_gray.svg) top center/min(33%, 530px) auto repeat;
  background-color: #fff
}

.c-bgLogoBlue {
  background: url(../img/common/bk_logo_blue.svg) top center/min(33%, 530px) auto repeat;
  background-color: #4fa8d7
}

.c-mvParallax {
  position: relative
}

.c-mvParallax__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  clip-path: inset(0);
  z-index: -1
}

.c-mvParallax__bg::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: url(../img/common/bg_mv.webp) center/cover no-repeat
}

.c-title {
  text-align: center;
  color: #4fa8d7;
  font-size: clamp(2.125rem, 4.6vw, 2.875rem);
  line-height: 1.4
}

.c-title.-colorWhite {
  color: #fff
}

.c-title.-colorBlack {
  color: #333
}

.c-lead.-styleA {
  text-align: center;
  line-height: 1.6;
  font-size: clamp(1.5rem, 3.2vw, 2rem);
  line-height: 1.4;
  margin-top: 1.5em
}

.c-lead.-styleB {
  text-align: left;
  line-height: 1.6;
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  margin-top: 1.5em;
  text-align: center
}

.c-lead.-styleB span {
  display: inline-block;
  font-weight: bold;
}

.c-lead.-styleB1 {
  text-align: left;
  line-height: 1.6;
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  margin-top: 1.5em
}

.c-lead.-styleC {
  line-height: 1.6;
  font-size: clamp(1.5rem, 3.2vw, 2rem);
  line-height: 1.4;
  text-align: center;
  background-color: #f2efef;
  padding: .7em 1em
}

.c-hostText {
  text-align: center;
  line-height: 1.6;
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  margin-top: 1em;
  padding-left: 15px;
  padding-right: 15px
}

@media screen and (min-width: 576px) {
  .c-hostText {
    font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
    line-height: 1.6
  }
}

.c-ticketList {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: clamp(20px, 3vw, 33px) clamp(20px, 3vw, 33px)
}

.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-color: #ba1934;
  display: block;
  padding: .1em;
  border-radius: 8px;
  color: #fff;
  text-decoration: none;
  height: 100%
}

@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
  }
}

.c-ticketList__name {
  font-size: clamp(1.5rem, 3.2vw, 2rem);
  line-height: 1.4;
  display: block;
  margin-top: 1em
}

.c-ticketList__code {
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  display: block;
  /*margin-top: .5em*/
}

.c-ticketList__code1 {
  font-size: clamp(1rem, 1.5vw, 1rem);
  line-height: 1.6;
  display: block;
}

.c-ticketList__btn {
  font-size: clamp(1.5rem, 3.2vw, 2rem);
  line-height: 1.4;
  display: block;
  margin-top: .8em;
  padding: .8em 0;
  background-image: repeating-linear-gradient(to right, #FFF 0, #FFF 2px, transparent 2px, transparent 10px);
  background-position: left top;
  background-size: auto 2px;
  background-repeat: repeat-x
}

@media screen and (min-width: 576px) {
  .c-ticketList {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media screen and (min-width:1216px) {
  .c-ticketList {
    grid-template-columns: repeat(4, 1fr)
  }
}

.c-ticketList__notes {
  text-align: center;
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6
}

.c-snsList {
  margin: 0px auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 37px
}

.c-snsList li,
.c-snsList a {
  width: 60px;
  height: 60px;
  display: block
}

@media(hover: hover)and (pointer: fine) {

  .c-snsList li,
  .c-snsList a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .c-snsList li:hover,
  .c-snsList a:hover {
    opacity: .8
  }
}

.c-snsList__insta a {
  background: url(../img/common/icon_insta.svg) center center/cover no-repeat
}

.c-snsList__x a {
  background: url(../img/common/icon_x.svg) center center/cover no-repeat
}

.c-snsList__fb a {
  background: url(../img/common/icon_fb.svg) center center/cover no-repeat
}


.c-btn.-styleA {
  font-size: clamp(1.375rem, 3vw, 1.875rem);
  line-height: 1.4;
  position: relative;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  width: 100%;
  max-width: 510px;
  display: block
}

.c-btn.-styleA a {
  background-color: #df7791;
  width: 100%;
  display: inline-block;
  color: #fff;
  padding: .7em .5em;
  border-radius: 8px;
  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.375rem, 3vw, 1.875rem);
  line-height: 1.4;
  position: relative;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  width: 100%;
  max-width: 510px;
  display: block
}

.c-btn.-styleB a {
  background-color: #fff;
  width: 100%;
  display: inline-block;
  color: #4fa8d7;
  padding: .7em 10%;
  border-radius: 8px;
  text-decoration: none;
  background: #fff url(../img/common/icon_arrow_right_blue.svg) right 8% center/clamp(18px, 2.2vw, 22px) auto no-repeat
}

@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.-access {
  display: inline-block;
  margin: .2em 0
}

.c-btn.-access a {
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  background-color: #e5000f;
  text-decoration: none;
  color: #fff;
  border-radius: 8px;
  padding: .5em;
  margin: .3em 0
}

@media(hover: hover)and (pointer: fine) {
  .c-btn.-access a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .c-btn.-access a:hover {
    opacity: .8
  }
}

.c-pagetop {
  position: fixed;
  right: 15px;
  bottom: clamp(80px, 14vw, 80px);
  display: none;
  z-index: 500;
  width: clamp(80px, 12vw, 120px)
}

.c-pagetop img {
  width: 100%;
  height: auto;
  vertical-align: top
}

@media(hover: hover)and (pointer: fine) {
  .c-pagetop a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .c-pagetop a:hover {
    opacity: .8
  }
}

@media screen and (min-width: 576px) {
  .c-pagetop {
    bottom: clamp(100px, 14vw, 100px)
  }
}

@media screen and (min-width: 1024px) {
  .c-pagetop {
    bottom: clamp(100px, 14vw, 100px)
  }
}	

@media screen and (min-width: 1440px) {
  .c-pagetop {
    bottom: clamp(100px, 14vw, 120px)
  }
}

.p-globalNav {
  position: fixed;
  top: 0;
  right: 0;
  width: 90%;
  max-width: 440px;
  -webkit-transition: -webkit-transform .3s ease;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  background-color: rgba(223, 119, 145, .85);
  z-index: 700;
  -webkit-transform: translateX(100%);
  transform: translateX(100%);
  overflow-y: auto;
  height: 100dvh;
  -webkit-overflow-scrolling: touch
}

.p-globalNav::-webkit-scrollbar {
  width: 3px
}

.p-globalNav::-webkit-scrollbar-thumb {
  background: hsla(0, 0%, 100%, .8);
  border-radius: 5px
}

.p-globalNav::-webkit-scrollbar-track {
  border: none;
  border-radius: 5px;
  background: rgba(0, 0, 0, .2)
}

body.is-gNavOpen .p-globalNav {
  -webkit-transform: translateX(0);
  transform: translateX(0)
}

.p-globalNav__inner {
  max-width: 1280px;
  margin: 0px auto;
  color: #fff
}

.p-globalNav__inner a {
  color: #fff
}

.p-globalNav__menuList {
  margin-top: 60px;
  text-align: center;
  border-top: 1px solid #fff
}

.p-globalNav__menuList li {
  font-size: 1.0625rem;
  line-height: 1.7;
  border-bottom: 1px solid #fff
}

.p-globalNav__menuList a {
  display: block;
  text-decoration: none;
  padding: 1em
}

@media(hover: hover)and (pointer: fine) {
  .p-globalNav__menuList a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .p-globalNav__menuList a:hover {
    opacity: .8
  }
}

.p-globalNav__snsList {
  margin: 25px 0px 50px 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 25px
}

.p-globalNav__snsList li,
.p-globalNav__snsList a {
  width: 28px;
  height: 28px;
  display: block
}

@media(hover: hover)and (pointer: fine) {
  .p-globalNav__snsList a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .p-globalNav__snsList a:hover {
    opacity: .8
  }
}

.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__snsFB a {
  background: url(../img/common/icon_fb_white.svg) center center/cover no-repeat
}

.p-fixBottomNav {
  background-color: #4bd5b4;
  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: 500
}

.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.8125rem, 1.5vw, 1.875rem);
  line-height: 1.4;
  font-weight: 800;
  color: #4fa8d7;
  margin: 0 8px	
}

.p-fixBottomNav ul li a {
  background-color: #fff;
  display: block;
  padding: .5em .2em;
  border-radius: 8px;
  text-decoration: none;
  color: #51bdaf
}

@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, 3.5vw, 35px) clamp(20px, 3.5vw, 35px)
  }

  .p-fixBottomNav ul li {
    font-weight: 600
  }
}

@media screen and (min-width: 1024px) {
  .p-fixBottomNav ul {
    gap: clamp(20px, 3.5vw, 35px) clamp(30px, 6vw, 60px)
  }

  .p-fixBottomNav ul li {
    font-size: clamp(1.125rem, 1.5vw, 1.875rem)
  }
}

.p-mainVisual {
  position: relative;
  aspect-ratio: 1/1;
  background: url(../img/common/mv_sp.webp) center/cover no-repeat
}

@media screen and (min-width: 768px) {
  .p-mainVisual {
    margin-right: 60px;
    aspect-ratio: 16/9;
    background: url(../img/common/mv_pc.webp) center/cover no-repeat
  }
}

.p-newsScrollBox {
  width: 100%
}

.p-newsScrollBox__inner {
  width: 100%;
  margin: 0 auto;
  height: 420px;
  padding: 20px;
  background: #fff;
  border: 1px solid #c9c9c9
}

.p-newsScrollBox__inner .simplebar-scrollbar {
  background-color: #4fa8d7 !important;
  border-radius: 13px
}

.p-newsScrollBox__inner .simplebar-scrollbar::before {
  background-color: rgba(0, 0, 0, 0) !important
}

.p-newsScrollBox__inner .simplebar-track {
  background-color: #ccc
}

.p-newsScrollBox__inner li {
  display: grid;
  grid-template-columns: 1fr;
  line-height: 1.6;
  background-image: repeating-linear-gradient(to right, #6E6E6E 0, #6E6E6E 2px, transparent 2px, transparent 10px);
  background-position: left bottom;
  background-size: auto 2px;
  background-repeat: repeat-x
}

.p-newsScrollBox__inner li:last-child {
  background-image: none
}

.p-newsScrollBox__date {
  margin: 0;
  padding: 2em 0 0 0;
  font-size: clamp(1rem, 1.7vw, 1.0625rem)
}

.p-newsScrollBox__date span {
  background-color: #848484;
  color: #fff;
  display: block;
  padding: .4em .2em;
  text-align: center;
  width: 120px
}

.p-newsScrollBox__text {
  font-size: clamp(1rem, 1.7vw, 1.0625rem);
  margin: 0;
  padding: 1em 0 2em 0
}

@media screen and (min-width: 768px) {
  .p-newsScrollBox__inner {
    padding: 30px 40px
  }

  .p-newsScrollBox__inner li {
    grid-template-columns: 160px 1fr;
    gap: clamp(20px, 3.5vw, 35px) clamp(15px, 2.5vw, 25px)
  }

  .p-newsScrollBox__date {
    padding: 2em 0
  }

  .p-newsScrollBox__text {
    padding: 2em 0
  }
}

.p-aboutBox {
  background-color: #4fa8d7;
  padding: clamp(30px, 7.5vw, 75px) clamp(20px, 6vw, 60px)
}

.p-aboutBox__intro {
  color: #fff;
  margin-top: 2em;
  padding-bottom: 1em;
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  line-height: 1.8
}

.p-aboutBox__point {
  font-size: clamp(1.375rem, 2.8vw, 1.75rem);
  color: #fff;
  margin-top: 1.5em;
  line-height: 1.4
}

span.marker {
    background-image: repeating-linear-gradient(-45deg, #4bd5b4 0, #4bd5b4 3px, transparent 3px, transparent 6px);
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 100% 50%;
}

.p-aboutBox__pointLead {
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  line-height: 1.8;
  margin-top: .5em
}

.p-castBox {
  width: 100%;
  max-width: 1310px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px
}

.p-castBox__titleWrap {
  background-color: hsla(0, 0%, 100%, .9);
  padding: clamp(30px, 6vw, 60px) clamp(20px, 3vw, 30px)
}

.p-castBox__list {
  display: grid;
  gap: clamp(50px, 8vw, 80px);
  grid-template-columns: 1fr
}

.p-castBox__list li {
  background-color: #ffffffe0
}

.p-castBox__list a {
  text-decoration: none
}

@media(hover: hover)and (pointer: fine) {
  .p-castBox__list a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .p-castBox__list a:hover {
    opacity: .8
  }
}

@media screen and (min-width: 576px) {
  .p-castBox__list {
    gap: clamp(20px, 3.5vw, 35px);
    grid-template-columns: repeat(2, 1fr)
  }
}

@media screen and (min-width: 1024px) {
  .p-castBox__list {
    grid-template-columns: repeat(3, 1fr)
  }
}

.p-castBox__listInner {
  padding-left: clamp(15px, 3vw, 30px);
  padding-right: clamp(15px, 3vw, 30px);
  padding-bottom: 2em
}

.p-castBox__photo {
  position: relative;
  padding: clamp(15px, 1.5vw, 15px);
  padding-bottom: 0px
}

.p-castBox__photo img {
  aspect-ratio: 4/3;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: auto;
  vertical-align: top
}

.p-castBox__photo::after {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 12px solid rgba(0, 0, 0, 0);
  border-right: 12px solid rgba(0, 0, 0, 0);
  border-bottom: 20px solid #fff
}

.p-castBox__name {
  text-align: center;
  font-size: clamp(1.5rem, 3.2vw, 2rem);
  color: #4fa8d7;
  line-height: 1.4;
  margin-top: 1em
}

.p-castBox__program {
  text-align: center;
  font-size: clamp(1.25rem, 2.6vw, 1.625rem);
  line-height: 1.4;
  margin-top: 1em
}

.p-castBox__direction {
  text-align: center;
  font-size: clamp(0.9375rem, 1.5vw, 1.25rem);
  line-height: 1.5;
  margin-top: 1em
}

span.marker1 {
    background: linear-gradient(transparent 50%, #f9df4a 50%);
}


.p-castBox__direction1 {
  text-align: center;
  font-size: clamp(0.9375rem, 1.5vw, 1.25rem);
  line-height: 1.5;
  margin-top: 1em;
  background: linear-gradient(transparent 50%, #f9df4a 50%);	  
}

.p-castBox__direction2 {
  text-align: center;
  font-size: clamp(0.9375rem, 1.5vw, 1.25rem);
  line-height: 1.5;
  margin-top: 1em
}

.p-castBox__direction3 {
  text-align: center;
  font-size: clamp(0.9375rem, 1.5vw, 1.25rem);
  line-height: 1.5;
  margin-top: 0;
  background: linear-gradient(transparent 50%, #f9df4a 50%);	  
}

.p-castBox__btn {
  background: #4bd5b4;
  background: linear-gradient(135deg, rgb(75, 213, 180) 0%, rgb(79, 168, 215) 100%);
  color: #fff;
  border-radius: 8px;
  text-align: center;
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  max-width: 320px;
  padding: .3em .5em;
  margin: 2em auto 0 auto
}

.p-scheduleBox__timetable {
  margin-left: auto;
  margin-right: auto
}

.p-scheduleBox__timetable img {
  width: 100%;
  height: auto;
  vertical-align: top
}

.p-scheduleBox__timetable.-yoko {
  max-width: 1160px
}

.p-scheduleBox__timetable.-tate {
  max-width: 800px
}

.p-scheduleBox__notesList {
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6
}

.p-scheduleBox__notesList>li {
  padding-left: 1.2em;
  text-indent: -1.2em
}

.p-scheduleBox__notesList>li::before {
  content: "※ "
}

.p-guestBox__name {
  margin-top: 1em;
  font-size: clamp(1.4375rem, 3vw, 1.875rem);
  color: #fff
}

.p-guestBox__notes {
  margin-top: 1em;
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  text-align: center
}

.p-notesBox {
  background-color: #f2efef
}

.p-notesBox__list>li {
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  padding-left: 1.2em;
  text-indent: -1.2em
}

.p-notesBox__list>li::before {
  content: "※ "
}

.p-notesBox__list>li ul {
  margin-left: 1em
}

.p-notesBox__list>li ul li {
  padding-left: 1.2em;
  text-indent: -1.2em
}

.p-notesBox__list>li ul li::before {
  content: "・ "
}

.p-accessBox__photoMap {
  display: grid;
  grid-template-columns: repeat(1, 1fr)
}

.p-accessBox__photoMap img {
  width: 100%;
  height: auto;
  vertical-align: top
}

.p-accessBox__photo {
  aspect-ratio: 3/2;
  overflow: hidden;
  position: relative
}

.p-accessBox__photo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block
}

.p-accessBox__map {
  position: relative;
  aspect-ratio: 8/5
}

.p-accessBox__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0
}

iframe {
  width: 100%;
  height: 300px; /* スマホでの高さ */
}

@media screen and (min-width: 576px) {
  iframe {
    height: 450px; /* PCでの高さ */
  }
}

@media screen and (min-width: 768px) {
  .p-accessBox__photoMap {
    grid-template-columns: repeat(2, 1fr)
  }

  .p-accessBox__map {
    aspect-ratio: auto;
    width: 100%;
    height: 100%
  }

  .p-accessBox__map iframe {
    position: static;
    width: 100%;
    height: 100%
  }
}

.p-modalWrap {
  display: none
}

.p-modalCast {
  background-color: #fff
}

.p-modalCast__mainVisual {
  position: relative
}

.p-modalCast__mainVisual img {
  aspect-ratio: 16/9;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: auto;
  vertical-align: top
}

.p-modalCast__mainVisual::after {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 12px solid rgba(0, 0, 0, 0);
  border-right: 12px solid rgba(0, 0, 0, 0);
  border-bottom: 20px solid #fff
}

.p-modalCast__photo {
  margin: 0px auto;
  max-width: 540px;
  margin-top: clamp(40px, 6vw, 60px)
}

.p-modalCast__photo img {
  width: 100%;
  height: auto;
  vertical-align: top
}

.p-modalCast__photo.-yoko {
  max-width: 540px
}

.p-modalCast__photo.-tate {
  max-width: 420px
}

.p-modalCast__inner {
  padding-left: clamp(15px, 6vw, 60px);
  padding-right: clamp(15px, 6vw, 60px);
  padding-bottom: clamp(30px, 6vw, 60px)
}

.p-modalCast__name {
  text-align: center;
  font-size: clamp(1.5rem, 3.2vw, 2rem);
  line-height: 1.4;
  color: #4fa8d7;
  margin-top: 1.2em
}

.p-modalCast__name2 {
  text-align: center;
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  color: #4fa8d7;
  margin-top: 1.2em
}

.p-modalCast__lead {
  text-align: center;
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  margin-top: .3em
}

.p-modalCast__title {
  font-weight: 900;
  color: #4fa8d7;
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  text-align: center;
  background-color: #f2efef;
  margin-top: 2.5em
}

.p-modalCast__storyText {
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  margin-top: 1em;
  line-height: 1.8
}

.p-modalCast__detailList {
  display: grid;
  grid-template-columns: 1fr;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: start;
  line-height: 1.6;
  margin-top: 2.5em;
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7
}

.p-modalCast__detailList dt {
  font-weight: 900;
  color: #fff;
  background-color: #4fa8d7;
  text-align: center;
  width: 120px
}

.p-modalCast__detailList dd {
  color: #4fa8d7;
  padding: .5em 0 1em 0
}

@media screen and (min-width: 480px) {
  .p-modalCast__detailList {
    grid-template-columns: 120px 1fr;
    gap: clamp(15px, 2.5vw, 25px) clamp(20px, 3.5vw, 35px)
  }

  .p-modalCast__detailList dt {
    width: auto
  }

  .p-modalCast__detailList dd {
    padding: 0
  }
}

.p-modalCast__profileText {
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  margin-top: 1em;
  line-height: 1.8
}

.p-modalCast__profileText1 {
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  margin-top: 1em;
  line-height: 1.8;
  text-align: center	  
}

.p-modalCast__btnTicket {
  text-align: center;
  font-size: clamp(1.125rem, 2.3vw, 1.4375rem);
  line-height: 1.6;
  margin-top: clamp(35px, 5vw, 50px);
  line-height: 1.4
}

.p-modalCast__btnTicket span {
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  line-height: 1.4;
  display: block
}

.p-modalCast__btnTicket a {
  background-color: #df7791;
  color: #fff;
  display: block;
  text-decoration: none;
  border-radius: 8px;
  padding: .6em
}

@media(hover: hover)and (pointer: fine) {
  .p-modalCast__btnTicket a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .p-modalCast__btnTicket a:hover {
    opacity: .8
  }
}

.p-modalCast__btnList {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  width: 100%;
  max-width: 400px;
  margin-top: clamp(30px, 4vw, 40px);
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7
}

.p-modalCast__btnList li {
  padding-bottom: clamp(15px, 2.2vw, 22px)
}

.p-modalCast__btnList a {
  text-decoration: none;
  border-radius: 8px;
  background: #4bd5b4;
  background: linear-gradient(135deg, rgb(75, 213, 180) 0%, rgb(79, 168, 215) 100%);
  color: #fff;
  border-radius: 8px;
  display: block;
  width: 100%;
  padding: .3em
}

@media(hover: hover)and (pointer: fine) {
  .p-modalCast__btnList a {
    -webkit-transition: opacity .3s ease;
    transition: opacity .3s ease
  }

  .p-modalCast__btnList a:hover {
    opacity: .8
  }
}

.p-modalCast__btnList a span {
  padding-top: .3em;
  padding-bottom: .3em;
  display: inline-block
}

.p-modalCast__btnX {
  background: url(../img/common/icon_x_white.svg) left center/23px auto no-repeat;
  padding-left: 35px;
  padding-right: 35px
}

.p-modalCast__btnInsta {
  background: url(../img/common/icon_insta_white.svg) left center/25px auto no-repeat;
  padding-left: 38px;
  padding-right: 38px
}

.p-modalCast__btnYoutube {
  background: url(../img/common/icon_youtube_white.svg) left center/31px auto no-repeat;
  padding-left: 50px;
  padding-right: 50px
}

.p-modalCast__btnTiktok {
  background: url(../img/common/icon_tiktok_white.svg) left center/18px auto no-repeat;
  padding-left: 50px;
  padding-right: 50px
}

.p-modalGuest__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(15px, 3vw, 30px)
}

.p-modalGuest__list li {
  background-color: #fff;
  display: grid;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: start;
  grid-template-columns: clamp(120px, 25vw, 250px) 1fr
}

@media screen and (min-width: 1024px) {
  .p-modalGuest__list {
    grid-template-columns: repeat(2, 1fr)
  }

  .p-modalGuest__list li {
    grid-template-columns: 250px 1fr
  }
}

.p-modalGuest__profile {
  padding: clamp(10px, 2vw, 20px)
}

.p-modalGuest__post {
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7
}

.p-modalGuest__name {
  font-size: clamp(1.5rem, 3.2vw, 2rem);
  line-height: 1.4;
  color: #4fa8d7
}

.p-modalGuest__position {
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7
}

.p-modalGuest__title {
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  color: #4fa8d7;
  background-color: #f2efef;
  padding: .1em .3em;
  margin-top: .5em
}

.p-modalGuest__date {
  font-size: clamp(0.9375rem, 1.7vw, 1.0625rem);
  line-height: 1.7;
  margin-top: .5em
}

.p-modalGuest__photo {
  position: relative
}

.p-modalGuest__photo img {
  aspect-ratio: 1/1;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: auto;
  vertical-align: top
}

.p-modalGuest__photo::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 6px solid rgba(0, 0, 0, 0);
  border-bottom: 6px solid rgba(0, 0, 0, 0);
  border-right: 10px solid #fff
}

@media screen and (min-width: 576px) {
  .p-modalGuest__photo::after {
    border-top: 12px solid rgba(0, 0, 0, 0);
    border-bottom: 12px solid rgba(0, 0, 0, 0);
    border-right: 20px solid #fff
  }
}

.modaal-inner-wrapper {
  padding-right: 15px !important;
  padding-left: 15px !important
}

.modaal-container {
  background: rgba(0, 0, 0, 0) !important
}

.modaal-content-container {
  padding: 0px !important
}

.modaal-close {
  background-color: rgba(0, 0, 0, .5) !important
}

.modaal-close:focus,
.modaal-close:hover {
  background: #000 !important;
  background-color: #000 !important
}

.modaal-close:after,
.modaal-close:before {
  background: #fff !important
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before {
  background: #fff !important
}

.u-mt-XL {
  margin-top: clamp(100px, 18vw, 180px)
}

.u-mb-XL {
  margin-bottom: clamp(100px, 18vw, 180px)
}

.u-mtb-XL {
  margin-top: clamp(100px, 18vw, 180px);
  margin-bottom: clamp(100px, 18vw, 180px)
}

.u-m-XL {
  margin: clamp(100px, 18vw, 180px)
}

.u-pt-XL {
  padding-top: clamp(100px, 18vw, 180px)
}

.u-pb-XL {
  padding-bottom: clamp(100px, 18vw, 180px)
}

.u-ptb-XL {
  padding-top: clamp(100px, 18vw, 180px);
  padding-bottom: clamp(100px, 18vw, 180px)
}

.u-p-XL {
  padding: clamp(100px, 18vw, 180px)
}

.u-mt-L {
  margin-top: clamp(70px, 11vw, 110px)
}

.u-mb-L {
  margin-bottom: clamp(70px, 11vw, 110px)
}

.u-mtb-L {
  margin-top: clamp(70px, 11vw, 110px);
  margin-bottom: clamp(70px, 11vw, 110px)
}

.u-m-L {
  margin: clamp(70px, 11vw, 110px)
}

.u-pt-L {
  padding-top: clamp(70px, 11vw, 110px)
}

.u-pb-L {
  padding-bottom: clamp(70px, 11vw, 110px)
}

.u-ptb-L {
  padding-top: clamp(70px, 11vw, 110px);
  padding-bottom: clamp(70px, 11vw, 110px)
}

.u-p-L {
  padding: clamp(70px, 11vw, 110px)
}

.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);
  text-align: left
}

.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, 15vw, 150px)
}

.u-gap-XXL-XXL {
  gap: clamp(80px, 15vw, 150px) clamp(80px, 15vw, 150px)
}

.u-gap-XXL-XL {
  gap: clamp(80px, 15vw, 150px) clamp(50px, 10vw, 100px)
}

.u-gap-XXL-L {
  gap: clamp(80px, 15vw, 150px) clamp(40px, 8vw, 80px)
}

.u-gap-XXL-M {
  gap: clamp(80px, 15vw, 150px) clamp(30px, 6vw, 60px)
}

.u-gap-XXL-S {
  gap: clamp(80px, 15vw, 150px) clamp(20px, 3.5vw, 35px)
}

.u-gap-XXL-XS {
  gap: clamp(80px, 15vw, 150px) clamp(15px, 2.5vw, 25px)
}

.u-gap-XL {
  gap: clamp(50px, 10vw, 100px)
}

.u-gap-XL-XXL {
  gap: clamp(50px, 10vw, 100px) clamp(80px, 15vw, 150px)
}

.u-gap-XL-XL {
  gap: clamp(50px, 10vw, 100px) clamp(50px, 10vw, 100px)
}

.u-gap-XL-L {
  gap: clamp(50px, 10vw, 100px) clamp(40px, 8vw, 80px)
}

.u-gap-XL-M {
  gap: clamp(50px, 10vw, 100px) clamp(30px, 6vw, 60px)
}

.u-gap-XL-S {
  gap: clamp(50px, 10vw, 100px) clamp(20px, 3.5vw, 35px)
}

.u-gap-XL-XS {
  gap: clamp(50px, 10vw, 100px) clamp(15px, 2.5vw, 25px)
}

.u-gap-L {
  gap: clamp(40px, 8vw, 80px)
}

.u-gap-L-XXL {
  gap: clamp(40px, 8vw, 80px) clamp(80px, 15vw, 150px)
}

.u-gap-L-XL {
  gap: clamp(40px, 8vw, 80px) clamp(50px, 10vw, 100px)
}

.u-gap-L-L {
  gap: clamp(40px, 8vw, 80px) clamp(40px, 8vw, 80px)
}

.u-gap-L-M {
  gap: clamp(40px, 8vw, 80px) clamp(30px, 6vw, 60px)
}

.u-gap-L-S {
  gap: clamp(40px, 8vw, 80px) clamp(20px, 3.5vw, 35px)
}

.u-gap-L-XS {
  gap: clamp(40px, 8vw, 80px) clamp(15px, 2.5vw, 25px)
}

.u-gap-M {
  gap: clamp(30px, 6vw, 60px)
}

.u-gap-M-XXL {
  gap: clamp(30px, 6vw, 60px) clamp(80px, 15vw, 150px)
}

.u-gap-M-XL {
  gap: clamp(30px, 6vw, 60px) clamp(50px, 10vw, 100px)
}

.u-gap-M-L {
  gap: clamp(30px, 6vw, 60px) clamp(40px, 8vw, 80px)
}

.u-gap-M-M {
  gap: clamp(30px, 6vw, 60px) clamp(30px, 6vw, 60px)
}

.u-gap-M-S {
  gap: clamp(30px, 6vw, 60px) clamp(20px, 3.5vw, 35px)
}

.u-gap-M-XS {
  gap: clamp(30px, 6vw, 60px) clamp(15px, 2.5vw, 25px)
}

.u-gap-S {
  gap: clamp(20px, 3.5vw, 35px)
}

.u-gap-S-XXL {
  gap: clamp(20px, 3.5vw, 35px) clamp(80px, 15vw, 150px)
}

.u-gap-S-XL {
  gap: clamp(20px, 3.5vw, 35px) clamp(50px, 10vw, 100px)
}

.u-gap-S-L {
  gap: clamp(20px, 3.5vw, 35px) clamp(40px, 8vw, 80px)
}

.u-gap-S-M {
  gap: clamp(20px, 3.5vw, 35px) clamp(30px, 6vw, 60px)
}

.u-gap-S-S {
  gap: clamp(20px, 3.5vw, 35px) clamp(20px, 3.5vw, 35px)
}

.u-gap-S-XS {
  gap: clamp(20px, 3.5vw, 35px) clamp(15px, 2.5vw, 25px)
}

.u-gap-XS {
  gap: clamp(15px, 2.5vw, 25px)
}

.u-gap-XS-XXL {
  gap: clamp(15px, 2.5vw, 25px) clamp(80px, 15vw, 150px)
}

.u-gap-XS-XL {
  gap: clamp(15px, 2.5vw, 25px) clamp(50px, 10vw, 100px)
}

.u-gap-XS-L {
  gap: clamp(15px, 2.5vw, 25px) clamp(40px, 8vw, 80px)
}

.u-gap-XS-M {
  gap: clamp(15px, 2.5vw, 25px) clamp(30px, 6vw, 60px)
}

.u-gap-XS-S {
  gap: clamp(15px, 2.5vw, 25px) clamp(20px, 3.5vw, 35px)
}

.u-gap-XS-XS {
  gap: clamp(15px, 2.5vw, 25px) clamp(15px, 2.5vw, 25px)
}

.u-inlineText {
  display: inline-block
}