@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:100,300,400,500,700,900&subset=japanese");
@import url("https://fonts.googleapis.com/css?family=Noto+Serif+JP:100,300,400,500,700,900&subset=japanese");
@import url("https://fonts.googleapis.com/css?family=Unica+One");
@import url("https://fonts.googleapis.com/css?family=Oswald");
a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, embed, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:after, blockquote:before, q:after, q:before {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

*, :after, :before {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  color: #252525;
  background: #fff;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

li {
  list-style: none;
}

a, a:hover {
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
  outline: none;
}

a {
  display: block;
  transition-duration: .4s;
  transition-timing-function: ease;
  transition-delay: auto;
}

a, a:hover {
  transition-property: all;
}

a:hover {
  transition-duration: .2s;
  transition-timing-function: ease;
  transition-delay: auto;
}

img {
  width: 100%;
  vertical-align: bottom;
}

img, video {
  height: auto;
}

video {
  max-width: 100%;
}

hr {
  height: 0;
  border: 0;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #fff;
}

img {
  display: block;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

label {
  font-size: 15px;
}

html {
  font-size: 62.5%;
}

body {
  font-family: Noto Serif JP, Noto Sans JP, -apple-system, BlinkMacSystemFont, Helvetica Neue, Segoe UI, Hiragino Kaku Gothic ProN, Yu Gothic, sans-serif;
  line-height: 1.4;
  font-size: 10px;
  font-size: 1rem;
}

h1 {
  font-size: 36px;
  font-size: 3.6rem;
}

h1, h2 {
  font-weight: 700;
}

h2 {
  font-size: 30px;
  font-size: 3rem;
}

h3 {
  font-size: 23px;
  font-size: 2.3rem;
}

h3, h4 {
  font-weight: 700;
}

h4 {
  font-size: 18px;
  font-size: 1.8rem;
}

h5 {
  font-size: 15px;
  font-size: 1.5rem;
}

h5, h6 {
  font-weight: 700;
}

h6 {
  font-size: 12px;
  font-size: 1.2rem;
}

a, p {
  font-size: 15px;
  font-size: 1.5rem;
  text-shadow: 0 0 0 #252525;
}

@media screen and (max-width:599px) {
  html {
    font-size: 62.5%;
  }
  body {
    line-height: 1.4;
    font-size: 10px;
    font-size: 1rem;
  }
  h1, h2 {
    font-size: 23px;
    font-size: 2.3rem;
  }
  h1, h2, h3 {
    font-weight: 700;
  }
  h3 {
    font-size: 21px;
    font-size: 2.1rem;
  }
  h4 {
    font-size: 15px;
    font-size: 1.5rem;
  }
  h4, h5 {
    font-weight: 700;
  }
  h5 {
    font-size: 12px;
    font-size: 1.2rem;
  }
  h6 {
    font-size: 10px;
    font-size: 1rem;
    font-weight: 700;
  }
  a, p {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

b {
  font-weight: 700;
}

.text-align-center {
  text-align: center;
}

@media screen and (min-width:600px) {
  .is-large-except-mobile {
    font-size: 23px;
  }
}

@keyframes a {
  0% {
    background-position: 100% 50%;
  }
  to {
    background-position: 0 50%;
  }
}

@keyframes b {
  0% {
    background-position: 0 0;
  }
  50% {
    background-position: 100% 100%;
  }
  to {
    background-position: 0 0;
  }
}

@keyframes c {
  0%, 20%, 53%, 80%, to {
    animation-timing-function: cubic-bezier(.215, .61, .355, 1);
    transform: translateZ(0);
  }
  40%, 43% {
    animation-timing-function: cubic-bezier(.755, .05, .855, .06);
    transform: translate3d(0, -30px, 0);
  }
  70% {
    animation-timing-function: cubic-bezier(.755, .05, .855, .06);
    transform: translate3d(0, -15px, 0);
  }
  90% {
    transform: translate3d(0, -4px, 0);
  }
}

.bounce {
  animation-name: c;
  transform-origin: center bottom;
  animation-duration: 3s;
  animation-timing-function: ease;
  animation-iteration-count: infinite;
}

.fadeIn {
  opacity: 0;
  transition: opacity .6s, transform .6s;
  transition-timing-function: cubic-bezier(.47, 0, .745, .715);
  will-change: opacity, transform;
}

.fadeIn.is-inView {
  opacity: 1;
}

.fadeInUp {
  opacity: 0;
  transition: opacity .6s, transform .6s;
  transition-timing-function: cubic-bezier(.47, 0, .745, .715);
  transform: translateY(20px);
  will-change: opacity, transform;
}

.fadeInUp.is-inView {
  opacity: 1;
  transform: translateY(0);
}

.fadeInDown {
  opacity: 0;
  transition: opacity .6s, transform .6s;
  transition-timing-function: cubic-bezier(.47, 0, .745, .715);
  transform: translateY(-20px);
  will-change: opacity, transform;
}

.fadeInDown.is-inView {
  opacity: 1;
  transform: translateY(0);
}

.fadeInRight {
  opacity: 0;
  transition: opacity .6s, transform .6s;
  transition-timing-function: cubic-bezier(.47, 0, .745, .715);
  transform: translateX(20px);
  will-change: opacity, transform;
}

.fadeInRight.is-inView {
  opacity: 1;
  transform: translateX(0);
}

.fadeInLeft {
  opacity: 0;
  transition: opacity .6s, transform .6s;
  transition-timing-function: cubic-bezier(.47, 0, .745, .715);
  transform: translateX(-20px);
  will-change: opacity, transform;
}

.fadeInLeft.is-inView {
  opacity: 1;
  transform: translateX(0);
}

@media screen and (max-width:599px) {
  .fadeIn-mobile {
    opacity: 0;
    transition: opacity .6s, transform .6s;
    transition-timing-function: cubic-bezier(.47, 0, .745, .715);
    will-change: opacity, transform;
  }
  .fadeIn-mobile.is-inView {
    opacity: 1;
  }
  .fadeInUp-mobile {
    opacity: 0;
    transition: opacity .6s, transform .6s;
    transition-timing-function: cubic-bezier(.47, 0, .745, .715);
    transform: translateY(20px);
    will-change: opacity, transform;
  }
  .fadeInUp-mobile.is-inView {
    opacity: 1;
    transform: translateY(0);
  }
  .fadeInDown-mobile {
    opacity: 0;
    transition: opacity .6s, transform .6s;
    transition-timing-function: cubic-bezier(.47, 0, .745, .715);
    transform: translateY(-20px);
    will-change: opacity, transform;
  }
  .fadeInDown-mobile.is-inView {
    opacity: 1;
    transform: translateY(0);
  }
  .fadeInRight-mobile {
    opacity: 0;
    transition: opacity .6s, transform .6s;
    transition-timing-function: cubic-bezier(.47, 0, .745, .715);
    transform: translateX(20px);
    will-change: opacity, transform;
  }
  .fadeInRight-mobile.is-inView {
    opacity: 1;
    transform: translateX(0);
  }
  .fadeInLeft-mobile {
    opacity: 0;
    transition: opacity .6s, transform .6s;
    transition-timing-function: cubic-bezier(.47, 0, .745, .715);
    transform: translateX(-20px);
    will-change: opacity, transform;
  }
  .fadeInLeft-mobile.is-inView {
    opacity: 1;
    transform: translateX(0);
  }
}

.delay100 {
  transition-delay: .1s;
}

.delay200 {
  transition-delay: .2s;
}

.delay300 {
  transition-delay: .3s;
}

.delay400 {
  transition-delay: .4s;
}

.delay500 {
  transition-delay: .5s;
}

.delay600 {
  transition-delay: .6s;
}

.delay700 {
  transition-delay: .7s;
}

.delay800 {
  transition-delay: .8s;
}

.delay900 {
  transition-delay: .9s;
}

.delay1000 {
  transition-delay: 1s;
}

.delay1100 {
  transition-delay: 1.1s;
}

.delay1200 {
  transition-delay: 1.2s;
}

.delay1300 {
  transition-delay: 1.3s;
}

.delay1400 {
  transition-delay: 1.4s;
}

.delay1500 {
  transition-delay: 1.5s;
}

.delay1600 {
  transition-delay: 1.6s;
}

.delay1700 {
  transition-delay: 1.7s;
}

.delay1800 {
  transition-delay: 1.8s;
}

.delay1900 {
  transition-delay: 1.9s;
}

.delay2000 {
  transition-delay: 2s;
}

@media screen and (max-width:599px) {
  .delay100-mobile {
    transition-delay: .1s;
  }
  .delay200¥-mobile {
    transition-delay: .2s;
  }
  .delay300-mobile {
    transition-delay: .3s;
  }
  .delay400-mobile {
    transition-delay: .4s;
  }
  .delay500-mobile {
    transition-delay: .5s;
  }
  .delay600-mobile {
    transition-delay: .6s;
  }
  .delay700-mobile {
    transition-delay: .7s;
  }
  .delay800-mobile {
    transition-delay: .8s;
  }
  .delay900-mobile {
    transition-delay: .9s;
  }
  .delay1000-mobile {
    transition-delay: 1s;
  }
  .delay1100-mobile {
    transition-delay: 1.1s;
  }
  .delay1200-mobile {
    transition-delay: 1.2s;
  }
  .delay1300-mobile {
    transition-delay: 1.3s;
  }
  .delay1400-mobile {
    transition-delay: 1.4s;
  }
  .delay1500-mobile {
    transition-delay: 1.5s;
  }
  .delay1600-mobile {
    transition-delay: 1.6s;
  }
  .delay1700-mobile {
    transition-delay: 1.7s;
  }
  .delay1800-mobile {
    transition-delay: 1.8s;
  }
  .delay1900-mobile {
    transition-delay: 1.9s;
  }
  .delay2000-mobile {
    transition-delay: 2s;
  }
}

.l-col-1 {
  width: 8.33333333%;
}

.l-col-2 {
  width: 16.66666667%;
}

.l-col-3 {
  width: 25%;
}

.l-col-4 {
  width: 33.33333333%;
}

.l-col-5 {
  width: 41.66666667%;
}

.l-col-6 {
  width: 50%;
}

.l-col-7 {
  width: 58.33333333%;
}

.l-col-8 {
  width: 66.66666667%;
}

.l-col-9 {
  width: 75%;
}

.l-col-10 {
  width: 83.33333333%;
}

.l-col-11 {
  width: 91.66666667%;
}

.l-col-12 {
  width: 100%;
}

.l-offset-left-1 {
  margin-left: 8.33333333%;
}

.l-offset-left-2 {
  margin-left: 16.66666667%;
}

.l-offset-left-3 {
  margin-left: 25%;
}

.l-offset-left-4 {
  margin-left: 33.33333333%;
}

.l-offset-left-5 {
  margin-left: 41.66666667%;
}

.l-offset-left-6 {
  margin-left: 50%;
}

.l-offset-left-7 {
  margin-left: 58.33333333%;
}

.l-offset-left-8 {
  margin-left: 66.66666667%;
}

.l-offset-left-9 {
  margin-left: 75%;
}

.l-offset-left-10 {
  margin-left: 83.33333333%;
}

.l-offset-left-11 {
  margin-left: 91.66666667%;
}

.l-offset-left-12 {
  margin-left: 100%;
}

.l-offset-right-1 {
  margin-right: 8.33333333%;
}

.l-offset-right-2 {
  margin-right: 16.66666667%;
}

.l-offset-right-3 {
  margin-right: 25%;
}

.l-offset-right-4 {
  margin-right: 33.33333333%;
}

.l-offset-right-5 {
  margin-right: 41.66666667%;
}

.l-offset-right-6 {
  margin-right: 50%;
}

.l-offset-right-7 {
  margin-right: 58.33333333%;
}

.l-offset-right-8 {
  margin-right: 66.66666667%;
}

.l-offset-right-9 {
  margin-right: 75%;
}

.l-offset-right-10 {
  margin-right: 83.33333333%;
}

.l-offset-right-11 {
  margin-right: 91.66666667%;
}

.l-offset-right-12 {
  margin-right: 100%;
}

.left {
  float: left;
}

.right {
  float: right;
}

[class*=l-full] {
  margin: 0 auto;
  font-size: 0;
}

[class*=l-container] {
  max-width: 1280px;
  margin-right: auto;
  margin-left: auto;
  padding-left: 15px;
  padding-left: calc(constant(safe-area-inset-left) + 15px);
  padding-left: calc(env(safe-area-inset-left) + 15px);
  padding-right: 15px;
  padding-right: calc(constant(safe-area-inset-right) + 15px);
  padding-right: calc(env(safe-area-inset-right) + 15px);
}

[class*=l-row] {
  margin-left: -15px;
  margin-right: -15px;
  font-size: 0;
}

[class*=l-row]:after, [class*=l-row]:before {
  content: "";
  display: block;
  clear: both;
}

[class*=l-row].is-gapless {
  margin-left: 0;
  margin-right: 0;
}

[class*=l-col-] {
  position: relative;
  padding-left: 15px;
  padding-right: 15px;
  display: inline-block;
  vertical-align: top;
  font-size: 1rem;
  word-wrap: break-word;
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
}

.is-gapless>[class*=l-col-] {
  padding-left: 0;
  padding-right: 0;
}

@media screen and (max-width:1300px) {
  [class*=row] {
    margin-left: 0;
    margin-right: 0;
  }
  [class*=col-], [class*=right-col-] {
    float: none;
    width: 100%;
    padding: 0;
  }
  [class*=l-offset-] {
    margin-right: 0;
    margin-left: 0;
  }
}

[class*=flex] {
  display: flex;
}

[class*=flex-wrap] {
  flex-wrap: wrap;
}

[class*=flex-wrap-reverse] {
  flex-wrap: wrap-reverse;
}

[class*=flex-nowrap] {
  flex-wrap: nowrap;
}

[class*=flex-row] {
  flex-direction: row;
}

[class*=flex-row-reverse] {
  flex-direction: row-reverse;
}

[class*=flex-column] {
  flex-direction: column;
}

[class*=flex-column-reverse] {
  flex-direction: column-reverse;
}

[class*=flex-row-wrap] {
  flex-direction: row;
  flex-wrap: wrap;
}

[class*=flex-row-reverse-wrap] {
  flex-direction: row-reverse;
  flex-wrap: wrap;
}

.justify-content-end {
  justify-content: flex-end;
}

.justify-content-center {
  justify-content: center;
}

.justify-content-between {
  justify-content: space-between;
}

.justify-content-around {
  justify-content: space-around;
}

.align-items-start {
  align-items: flex-start;
}

.align-items-end {
  align-items: flex-end;
}

.align-items-center {
  align-items: center;
}

.align-items-baseline {
  align-items: baseline;
}

.align-items-stretch {
  align-items: stretch;
}

.align-self-start {
  align-self: start;
}

.align-self-end {
  align-self: end;
}

.align-self-center {
  align-self: center;
}

.align-self-baseline {
  align-self: baseline;
}

.align-self-stretch {
  align-self: stretch;
}

.align-content-start {
  align-content: start;
}

.align-content-end {
  align-content: end;
}

.align-content-center {
  align-content: center;
}

.align-content-around {
  align-content: around;
}

.align-content-stretch {
  align-content: stretch;
}

.slick-next, .slick-prev {
  position: absolute;
  display: block;
  height: 40px;
  width: 40px;
  line-height: 0;
  font-size: 0;
  cursor: pointer;
  top: 50%;
  transform: translateY(-50%);
  padding: 0;
  border: none;
}

@media screen and (max-width:767px) {
  .slick-next, .slick-prev{
    height: 20px;
    width: 20px;
  }
}

.slick-next, .slick-next:focus, .slick-next:hover, .slick-prev, .slick-prev:focus, .slick-prev:hover {
  background: transparent;
  color: transparent;
  outline: none;
}

.slick-next:focus:before, .slick-next:hover:before, .slick-prev:focus:before, .slick-prev:hover:before {
  opacity: 1;
}

.slick-next.slick-disabled:before, .slick-prev.slick-disabled:before {
  opacity: .25;
}

.slick-next:before, .slick-prev:before {
  font-family: slick;
  font-size: 50px;
  line-height: 1;
  color: #D8758B;
  opacity: .75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media screen and (max-width:767px) {
  .slick-next:before, .slick-prev:before {
    font-size: 20px;
  }
}

.slick-prev {
  left: -25px;
}

[dir=rtl] .slick-prev {
  left: auto;
  right: -25px;
}

.slick-prev:before {
  content: "←";
}

[dir=rtl] .slick-prev:before {
  content: "→";
}

.slick-next {
  right: -25px;
}

[dir=rtl] .slick-next {
  left: -25px;
  right: auto;
}

.slick-next:before {
  content: "→";
}

[dir=rtl] .slick-next:before {
  content: "←";
}

.slick-dotted.slick-slider {
  margin-bottom: 30px;
}

.slick-dots {
  position: absolute;
  bottom: -25px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}

.slick-dots li {
  position: relative;
  display: inline-block;
  margin: 0 5px;
  padding: 0;
}

.slick-dots li, .slick-dots li button {
  height: 20px;
  width: 20px;
  cursor: pointer;
}

.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  outline: none;
  line-height: 0;
  font-size: 0;
  color: transparent;
  padding: 5px;
}

.slick-dots li button:focus, .slick-dots li button:hover {
  outline: none;
}

.slick-dots li button:focus:before, .slick-dots li button:hover:before {
  opacity: 1;
}

.slick-dots li button:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "•";
  width: 20px;
  height: 20px;
  font-family: slick;
  font-size: 6px;
  line-height: 20px;
  text-align: center;
  color: #000;
  opacity: .25;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button:before {
  color: #D8758B;
  opacity: .75;
}

.l-header {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  transition: all .5s ease;
  z-index: 99;
}

@media screen and (max-width:1328px) {
  .l-header {
    position: fixed;
  }
}

.l-header-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all .5s ease;
  border-bottom: 5px solid #D8758B;
}

.l-header-nav.is-active {
  background: #fff;
}

@media screen and (max-width:599px) {
  .l-header-nav.is-active {
    background: none;
  }
}

@media screen and (max-width:1328px) {
  .l-header-nav {
    border-bottom: none;
  }
}

@media screen and (max-width:1328px) {
  .l-header-nav-overlay {
    content: "";
    background: linear-gradient(-90deg, #252525 50%, transparent);
    position: fixed;
    top: 0;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 100vh;
    transform: translateX(100%);
    opacity: 0;
    transition: opacity .5s ease, transform .5s ease, height .5s ease;
    z-index: 99;
  }
  .l-header-nav-overlay.is-active {
    transform: translateX(0);
    opacity: .5;
  }
}

@media screen and (max-width:1328px) {
  .l-header-nav-overlay {
    background: linear-gradient(-90deg, #252525 30%, transparent);
  }
}

@media screen and (max-width:599px) {
  .l-header-nav-overlay {
    background: linear-gradient(-90deg, #252525 60%, transparent);
  }
}

.l-header-nav-toggle {
  position: relative;
  padding: 22.5px 15px;
  position: fixed;
  top: 0;
  right: 0;
  width: 50px;
  display: none;
  z-index: 9999;
  transition: all .5s ease;
}

@media screen and (max-width:1328px) {
  .l-header-nav-toggle {
    display: block;
  }
}

.l-header-nav-toggle-bar, .l-header-nav-toggle:after, .l-header-nav-toggle:before {
  position: absolute;
  content: "";
  display: block;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 20px;
  height: 3px;
  background: #D8758B;
  transition: all .5s ease;
}

.l-header-nav-toggle:before {
  top: 33.33333333%;
}

.l-header-nav-toggle:after {
  top: 66.66666667%;
}

.l-header-nav-toggle-bar {
  top: 50%;
}

.l-header-nav-toggle.is-active {
  background: none;
}

.l-header-nav-toggle.is-active .l-header-nav-toggle-bar, .l-header-nav-toggle.is-active:after, .l-header-nav-toggle.is-active:before {
  background: #D8758B;
  transform-origin: center;
}

.l-header-nav-toggle.is-active:before {
  top: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
}

.l-header-nav-toggle.is-active:after {
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
}

.l-header-nav-toggle.is-active .l-header-nav-toggle-bar {
  top: 50%;
  transform: translate(-200%, -50%);
  opacity: 0;
}

.l-header-nav-list {
  display: flex;
  transition: opacity .5s ease, transform .5s ease, height .5s ease;
  font-family: Noto Sans JP, sans-serif;
}

@media screen and (max-width:1328px) {
  .l-header-nav-list {
    background: #fff;
    position: fixed;
    top: 0;
    bottom: 0;
    right: 0;
    height: 100vh;
    z-index: 999;
    transform: translateX(100%);
    overflow-y: auto;
    flex-direction: column;
    padding-top: 5vh;
    border-left: 5px solid #e73c7e;
  }
  .l-header-nav-list.is-active {
    transform: translateX(0);
  }
}

.l-header-nav-container {
  padding-left: 15px;
  padding-right: 15px;
}

.l-header-nav-row {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  margin-left: -15px;
  margin-right: -15px;
  font-size: 0;
}

@media screen and (max-width:1328px) {
  .l-header-nav-row {
    flex-direction: column;
    margin-left: 0;
    margin-right: 0;
  }
}

.l-header-nav-logo {
  padding: 15px;
  width: auto;
  height: 75px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.l-header-nav-logo:hover {
  opacity: .5;
}

.l-header-nav-logo img {
  display: inline-block;
  height: 100%;
  width: auto;
}

.l-header-nav-logo:active {
  opacity: .1;
}

@media screen and (max-width:1328px) {
  .l-header-nav-logo:active {
    opacity: 1;
  }
}

@media screen and (max-width:1328px) {
  .l-header-nav-logo {
    padding: 5px;
    height: 45px;
    opacity: 1;
  }
}

@media screen and (max-width:1328px) {
  .l-header-nav-logo-area {
    box-sizing: content-box;
    max-height: 45px;
    background: #252525;
    transform: translateY(-100%);
    width: 100%;
    transition: all .5s ease;
    border-bottom: 5px solid #e73c7e;
  }
  .l-header-nav-logo-area.is-active {
    max-height: 45px;
    background: #252525;
    transform: translateY(0);
  }
}

.l-header-nav-title {
  padding: 15px;
  width: auto;
  height: 80px;
  display: none;
}

.l-header-nav-title:hover {
  opacity: .5;
}

.l-header-nav-title img {
  height: 100%;
  width: auto;
}

.l-header-nav-title:active {
  opacity: .1;
}

@media screen and (max-width:1328px) {
  .l-header-nav-title {
    display: flex;
    justify-content: center;
  }
  .l-header-nav-title:active {
    opacity: 1;
  }
}

@media screen and (max-width:1328px) {
  .l-header-nav-items {
    width: 100%;
  }
}

.l-header-nav-item {
  display: inline-block;
  font-weight: 700;
}

@media screen and (max-width:1328px) {
  .l-header-nav-item {
    display: block;
    width: 100%;
  }
}

.l-header-nav-item a {
  position: relative;
  color: #252525;
  margin-top: auto;
  margin-bottom: auto;
  padding: 15px;
  line-height: 1;
  font-weight: 700;
}

@media screen and (max-width:1328px) {
  .l-header-nav-item a {
    margin-top: 15px;
    margin-bottom: 15px;
    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 45px;
    font-size: 18px;
    overflow: hidden;
  }
}

.l-header-nav-item a:hover {
  opacity: .5;
}

@media screen and (max-width:1328px) {
  .l-header-nav-item a:hover {
    opacity: 1;
    background: linear-gradient(90deg, #e73c7e, #fa7268 50%, hsla(0, 0%, 100%, 0) 0, hsla(0, 0%, 100%, 0)) no-repeat;
    background-size: 210%;
    animation: a 1s ease-out 1;
    animation-fill-mode: both;
  }
}

.l-header-nav-item a:active {
  color: #252525;
  opacity: .1;
}

@media screen and (max-width:1328px) {
  .l-header-nav-item a:active {
    color: #fff;
    opacity: 1;
    background: linear-gradient(90deg, #e73c7e, #fa7268 50%, hsla(0, 0%, 100%, 0) 0, hsla(0, 0%, 100%, 0)) no-repeat;
    background-size: 210%;
    animation: a 1s ease-out 1;
    animation-fill-mode: both;
  }
}

@media screen and (max-width:1328px) {
  .l-header-nav-item a:after {
    content: "\f054";
    display: inline-block;
    font-family: Font Awesome\ 5 Free;
    position: absolute;
    font-size: 15px;
    top: 50%;
    right: 15px;
    transform: translateY(-50%);
  }
}

.l-header-nav-icons {
  display: block;
}

.l-header-nav-icon {
  display: inline-block;
}

.l-header-nav-icon a {
  padding: 20px 15px;
  font-size: px;
  line-height: 1;
  position: relative;
  z-index: 1;
}

.l-header-nav-icon a .fa {
  width: 30px;
  text-align: center;
}

.l-header-nav-icon a .fa-envelope {
  font-size: 25px;
  line-height: 35px;
  vertical-align: top;
}

.l-header-nav-icon a .fa-mixcloud {
  font-size: 15px;
  line-height: 20px;
  vertical-align: middle;
}

.l-header-nav-icon a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 45px;
  height: 45px;
  background: none;
  border-radius: 999px;
  z-index: -1;
  transition: all .5s ease;
}

.l-header-nav-icon a:hover {
  opacity: 1;
}

.l-header-nav-icon a:hover:after {
  background: hsla(0, 0%, 100%, .25);
}

.l-header-nav-icon a:active {
  opacity: 1;
}

.l-header-nav-icon a:active:after {
  background: hsla(0, 0%, 100%, 0);
}

.l-header-nav-icon.is-marked a {
  text-shadow: none;
  margin-left: 5px;
  margin-right: 5px;
  color: #e73c7e;
  transition: color .5s ease;
}

.l-header-nav-icon.is-marked a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 45px;
  height: 45px;
  background: none;
  border: 1px solid #e73c7e;
  border-radius: 999px;
  z-index: -1;
  transition: background .5s ease;
}

.l-header-nav-icon.is-marked a:hover {
  color: #fff;
}

.l-header-nav-icon.is-marked a:hover:after {
  background: #e73c7e;
}

.l-header-nav-icon.is-marked a:active {
  opacity: 1;
}

.l-header-nav-icon.is-marked a:active:after {
  background: #e73c7e;
}

.l-header-nav-icon.is-marked.is-active a {
  text-shadow: none;
}

.l-header-nav-icon.is-marked.is-active a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 45px;
  height: 45px;
  background: none;
  border-radius: 999px;
  z-index: -1;
  transition: all .5s ease;
}

.l-header-nav-icon.is-marked.is-active a:hover {
  opacity: 1;
}

.l-header-nav-icon.is-marked.is-active a:hover:after {
  background: #e73c7e;
}

.l-header-nav-icon.is-marked.is-active a:active {
  opacity: 1;
}

.l-header-nav-icon.is-marked.is-active a:active:after {
  background: #e73c7e;
}

.l-header-nav-brand {
  display: inline-block;
}

@media screen and (max-width:1328px) {
  .l-header-nav-brand {
    display: block;
  }
}

.l-header-nav-brand a {
  color: #fff;
  padding: 20px 15px;
  font-size: 20px;
  line-height: 1;
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
  min-width: 230px;
}

.l-header-nav-brand a img {
  max-height: 20px;
  width: auto;
}

.l-header-nav-brand a img:nth-of-type(2n+2) {
  margin-left: 10px;
}

@keyframes d {
  0% {
    transform: rotate(-45deg) translate(0);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  to {
    transform: rotate(-45deg) translate(-20px, 20px);
    opacity: 0;
  }
}

.l-hero {
  position: relative;
  background-color: #252525;
  background-size: 400% 400%;
  animation: b 15s ease infinite;
  overflow: hidden;
}

@media screen and (max-width:599px) {
  .l-hero {
    height: 100vh;
  }
}

.l-hero-beyond2020 {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 100;
  width: 15vmin;
  max-width: 65px;
}

.l-hero-beyond2020 img {
  max-width: 100%;
}

.l-hero-japanendlessdiscovery {
  position: absolute;
  top: 1rem;
  left: calc(1rem + 65px);
  z-index: 100;
  width: 60vmin;
  max-width: 200px;
}

.l-hero-japanendlessdiscovery img {
  max-width: 100%;
}

@media screen and (max-width:599px) {
  .l-hero-japanendlessdiscovery {
    left: 1rem;
    top: calc(1rem + 80px);
    width: 30vmin;
  }
}

.l-hero-inner {
  position: relative;
  overflow: hidden;
  z-index: 2;
}

@media screen and (max-width:1328px) {
  .l-hero-inner {
    padding-top: 0;
  }
}

@media screen and (max-width:599px) {
  .l-hero-inner {
    height: 100vh;
    padding-top: 0;
  }
}

.l-hero-video {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100vh;
  z-index: 3;
}

.l-hero-video:before {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  content: "";
  width: 100%;
  height: 150px;
  background: linear-gradient(180deg, #252525 0, transparent);
  z-index: 2;
}

@media screen and (max-width:1328px) {
  .l-hero-video:before {
    display: none;
  }
}

.l-hero-video iframe {
  position: absolute;
  top: -150px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(200vh + 300px);
  height: calc(100vh + 300px);
  border: none;
  z-index: 1;
}

@media screen and (max-width:599px) {
  .l-hero-video iframe {
    top: -175px;
    height: calc(100vh + 350px);
  }
}

.l-hero-video .ytp-chrome-bottom, .l-hero-video .ytp-chrome-top {
  display: none;
}

.l-hero-bgVideo {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}

.l-hero-bgVideo video {
  max-width: none;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
}

.l-hero-bgVideo video, .l-hero-container {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.l-hero-container {
  z-index: 2;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width:599px) {
  .l-hero-container {
    padding-left: 30px;
    padding-right: 30px;
    width: 100%;
    z-index: 2;
  }
}

.l-hero-logo {
  z-index: 3;
  will-change: opacity, transform;
}

.l-hero-logo, .l-hero-logo img {
  margin-left: auto;
  margin-right: auto;
}

.l-hero-logo img {
  width: auto;
  max-height: 20vh;
}

@media screen and (max-width:1328px) {
  .l-hero-logo img {
    width: auto;
    max-height: 25vh;
  }
}

@media screen and (max-width:599px) {
  .l-hero-logo img {
    width: auto;
    max-height: 20vh;
  }
}

.l-hero-title {
  z-index: 3;
  will-change: opacity, transform;
}

.l-hero-title, .l-hero-title img {
  margin-left: auto;
  margin-right: auto;
}

.l-hero-title img {
  width: auto;
  max-height: 30vh;
}

@media screen and (max-width:1328px) {
  .l-hero-title img {
    width: auto;
    max-height: 40vh;
  }
}

@media screen and (max-width:599px) {
  .l-hero-title img {
    width: 90%;
    height: auto;
  }
}

.l-hero-caption {
  text-align: center;
  line-height: 2;
}

.l-hero-caption p {
  font-size: 18px;
  font-weight: 700;
}

@media screen and (max-width:599px) {
  .l-hero-caption p {
    font-size: 15px;
  }
}

.l-hero-scroll {
  display: block;
  position: absolute;
  bottom: 45px;
  left: 50%;
  z-index: 5;
  transform: translate(-50%, -50%);
  text-decoration: none;
  color: #fff;
  font-family: Oswald;
}

.l-hero-scroll p {
  transform: translateY(100%);
}

.l-hero-scroll span {
  position: absolute;
  top: -40px;
  left: 50%;
  width: 24px;
  height: 24px;
  margin-left: -12px;
  border-left: 3px solid #fff;
  border-bottom: 3px solid #fff;
  transform: rotate(-45deg);
  animation: d 1.5s infinite;
  box-sizing: border-box;
}

@media screen and (max-width:1328px) {
  .l-hero-scroll {
    display: block;
  }
}

.l-hero-info {
  z-index: 2;
}

.l-hero-image {
  max-height: 600px;
  overflow: hidden;
}

@media screen and (max-width:599px) {
  .l-hero-image {
    max-height: 200px;
  }
}

.l-hero-model {
  transform: translate(-50%, -50%);
  z-index: -1;
}

.l-hero-model-1 {
  top: 60%;
  left: 20%;
  min-width: 500px;
  animation: model-1 15s ease infinite;
}

.l-hero-model-2 {
  top: 60%;
  left: 50%;
  min-width: 500px;
  animation: model-2 15s ease infinite;
}

.l-hero-model-3 {
  top: 60%;
  left: 80%;
  min-width: 500px;
  animation: model-3 15s ease infinite;
}

.l-hero-child {
  background-color: #333;
}

.l-hero-child-trackrecord {
  background: url(/assets/img/trackrecord/hero.jpg) 50%/cover;
}

.l-hero-child-sponsorship {
  background-size: 120%;
  background-repeat: no-repeat;
}
@media screen and (max-width:1000px) {
.l-hero-child-sponsorship {
  background-size: cover;
  background-position: center;
}
}

.l-hero-child-request {
  background: url(/assets/img/request/hero.jpg) 50%/cover;
}

.l-hero-child-tickets {
  background: url(/assets/img/tickets/hero.jpg) 50%/cover;
}

.l-hero-child-themesong {
  background: url(/assets/img/themesong/hero.jpg) 50%/cover;
}

.l-hero-child-inner {
  padding-top: 100px;
  padding-bottom: 100px;
  color: #fff;
}

@media screen and (max-width:1328px) {
  .l-hero-child-inner {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

@media screen and (max-width:599px) {
  .l-hero-child-inner {
    padding-top: 45px;
    padding-bottom: 45px;
  }
}

.l-hero-child-title {
  text-align: center;
  color: #fff;
  line-height: 1;
}

.l-breadcrumb {
  background: #fff;
  padding-top: 15px;
  padding-bottom: 15px;
}

.l-breadcrumb ol {
  color: #fa7268;
  font-size: 15px;
  line-height: 1;
}

.l-breadcrumb ol li {
  display: inline-block;
}

.l-breadcrumb ol li a {
  display: inline-block;
  color: #fa7268;
}

.l-breadcrumb ol li:after {
  content: "›";
  display: inline-block;
  margin-left: 5px;
  margin-right: 5px;
}

.l-breadcrumb ol li:last-of-type:after {
  content: none;
  margin-left: 0;
  margin-right: 0;
}

.l-main {
  overflow: hidden;
}

.l-main:before {
  content: "";
  display: block;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  /*background: linear-gradient(90deg, rgba(5, 15, 26, 0), rgba(5, 15, 26, .75) 10%, rgba(5, 15, 26, .75) 90%, rgba(5, 15, 26, 0)), url(../img/bg-fireworks.jpg) no-repeat 50%/cover;*/
}

.l-footer {
  overflow: hidden;
  margin-top: 50px;
}

.l-footer, .l-youtube {
  width: 100%;
  position: relative;
}

.l-youtube {
  padding-top: 56.25%;
}

.l-youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%!important;
  height: 100%!important;
}

.c-section {
  padding-top: 30px;
  padding-bottom: 30px;
}

@media screen and (max-width:599px) {
  .c-section {
    padding-top: 15px;
    padding-bottom: 15px;
  }
}

.c-section-icon {
  width: 100%;
  max-width: 60px;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width:599px) {
  .c-section-icon {
    margin-bottom: 15px;
  }
}

.c-section-title {
  margin-left: auto;
  margin-right: auto;
  padding-top: 30px;
  padding-bottom: 30px;
  text-align: center;
}

@media screen and (max-width:599px) {
  .c-section-title {
    padding: 15px;
  }
}

.c-section-title h2 {
  display: inline-block;
  position: relative;
  line-height: .8;
  color: #252525;
  font-weight: 700;
}

.c-section-title h2:after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 10px;
}

@media screen and (max-width:599px) {
  .c-section-title h2:after {
    height: 7.5px;
  }
}

.c-section-title.is-inView h2:after {
  background: linear-gradient(90deg, #e73c7e, #fa7268 33.33333%, #fff 0, #fff 66.66667%, hsla(0, 0%, 100%, 0) 0);
  background-size: 315%;
  animation: a 1s ease 1;
  animation-fill-mode: both;
}

.c-section-title-txt {
  position: relative;
  display: inline-block;
  z-index: 3;
}

.c-section-title-txt p {
  font-size: 18px;
  padding: 15px;
  background: #252525 no-repeat;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

@media screen and (max-width:599px) {
  .c-section-title-txt p {
    font-size: 14px;
  }
}

.c-section-title-txt.is-inView p {
  background: linear-gradient(90deg, #e73c7e, #fa7268 33.33333%, #fff 0, #fff 66.66667%, #252525 0);
  background-size: 315%;
  animation: bg-slide 1.5s ease 1;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.c-section-title-txt.is-inView:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, hsla(0, 0%, 100%, 0), hsla(0, 0%, 100%, 0) 33.33333%, #e73c7e 0, #fa7268 66.66667%, hsla(0, 0%, 100%, 0) 0, hsla(0, 0%, 100%, 0)) no-repeat;
  background-size: 315%;
  animation: bg-slide 1.5s ease 1;
  z-index: -1;
}

.c-section-row {
  margin-bottom: 60px;
}

.c-section-row:last-of-type {
  margin-bottom: 45px;
}

@media screen and (max-width:599px) {
  .c-section-row {
    margin-bottom: 30px;
  }
  .c-section-row:last-of-type {
    margin-bottom: 0;
  }
}

.c-section-partition {
  display: block;
  content: "";
  border-top: 2px dotted #ccc;
  height: 1px;
  width: 100%;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 60px;
}

@media screen and (max-width:599px) {
  .c-section-partition {
    margin-bottom: 30px;
  }
}

@keyframes e {
  0% {
    left: 15px;
  }
  50% {
    left: 20px;
  }
  to {
    left: 15px;
  }
}

@keyframes f {
  0% {
    right: 15px;
  }
  50% {
    right: 20px;
  }
  to {
    right: 15px;
  }
}

.c-slide {
  position: relative;
  background: hsla(0, 0%, 100%, .1);
}

.c-slide-arrow {
  position: absolute;
  z-index: 4;
  width: 0;
  height: 100%;
  top: 0;
}

.c-slide-arrow:before {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%) rotate(-45deg);
  width: 1.5rem;
  height: 1.5rem;
}

.c-slide-arrow-left {
  left: 0;
}

.c-slide-arrow-left:before {
  left: 15px;
  border-left: 5px solid #fff;
  border-top: 5px solid #fff;
  animation: e 1.5s ease infinite;
}

.c-slide-arrow-right {
  right: 0;
}

.c-slide-arrow-right:before {
  right: 15px;
  border-right: 5px solid #fff;
  border-bottom: 5px solid #fff;
  animation: f 1.5s ease infinite;
}

.c-slide-inner {
  position: relative;
  margin: 4rem auto;
  max-width: 100%;
  padding: 4rem 2rem;
  width: 100%;
  overflow: auto;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

@media screen and (max-width:599px) {
  .c-slide-inner {
    margin: 0 auto;
  }
}

.c-slide-inner img {
  margin: 0 2rem;
}

.c-map {
  overflow: hidden;
  padding-bottom: 30%;
  position: relative;
  height: 0;
}

@media screen and (max-width:599px) {
  .c-map {
    padding-bottom: 50%;
  }
}

.c-map iframe {
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  position: absolute;
}

.c-button {
  position: relative;
  overflow: hidden;
  display: inline-block;
  z-index: 3;
  width: 100%;
  max-width: 290px;
  text-align: center;
  transition: all .5s ease;
  will-change: animation, opacity;
  text-transform: uppercase;
  font-family: Oswald, Noto Sans JP;
  font-weight: 700;
}

@media screen and (max-width:599px) {
  .c-button {
    max-width: 100%;
  }
}

.c-button.is-closed:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .75);
}

.c-button p {
  padding: 20px;
  background: #252525 no-repeat;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 100%;
  font-weight: 700;
}

.c-button p, .c-button p:after {
  opacity: 0;
  will-change: animation, opacity;
}

.c-button p:after {
  content: "\f054";
  display: block;
  font-family: Font Awesome\ 5 Free;
  position: absolute;
  top: 50%;
  right: 15px;
  transform: translateY(-50%);
}

.c-button.has-no-arrow p:after {
  content: none;
}

.c-button i {
  padding: 12.5px;
  background: #252525 no-repeat;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 100%;
  font-weight: 700;
  opacity: 0;
  font-size: 20px;
  will-change: animation, opacity;
}

.c-button.is-inView {
  background: linear-gradient(90deg, #fff, #fff 50%, hsla(0, 0%, 100%, 0) 0, hsla(0, 0%, 100%, 0)) no-repeat;
  background-size: 210%;
  animation: a .66666667s linear 1;
  animation-fill-mode: both;
}

.c-button.is-inView p {
  animation: a .66666667s linear 1;
  animation-fill-mode: both;
  animation-delay: .11111111s;
}

.c-button.is-inView p, .c-button.is-inView p:after {
  background: linear-gradient(90deg, #fff, #fff 33.33333%, #fff 0, #fff 66.66667%, hsla(0, 0%, 100%, 0) 0);
  background-size: 315%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  opacity: 1;
}

.c-button.is-inView p:after {
  animation: a .66666667s linear 1;
  animation-fill-mode: both;
  animation-delay: .6s;
}

.c-button.is-inView:active p, .c-button.is-inView:active p:after, .c-button.is-inView:hover p, .c-button.is-inView:hover p:after {
  background: #252525;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.c-button.is-inView i {
  background: linear-gradient(90deg, #e73c7e, #fa7268 33.33333%, #fff 0, #fff 66.66667%, hsla(0, 0%, 100%, 0) 0);
  background-size: 315%;
  animation: a .66666667s linear 1;
  animation-fill-mode: both;
  animation-delay: .11111111s;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  opacity: 1;
}

.c-button.is-inView:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  background: linear-gradient(90deg, #252525, #252525 50%, hsla(0, 0%, 100%, 0) 0, hsla(0, 0%, 100%, 0)) no-repeat;
  background-size: 210%;
  animation: a .66666667s linear 1;
  animation-fill-mode: both;
  animation-delay: .22222222s;
  z-index: -1;
  overflow: hidden;
}

.c-button.is-inView:active:before, .c-button.is-inView:hover:before {
  background: #fff;
}

.c-button.has-no-hover:active p, .c-button.has-no-hover:hover p {
  background: #fff;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.c-button.has-no-hover:active:before, .c-button.has-no-hover:hover:before {
  background: #252525;
}

.c-button-large p {
  font-size: 23px;
}

.c-button-large p:after {
  font-size: 15px;
}

.c-button-form {
  display: inline-block;
  background: linear-gradient(90deg, #e73c7e, #fa7268);
  padding: 15px;
  color: #fff;
  font-family: Noto Serif JP, serif;
  font-size: 28px;
  border: none;
  width: 300px;
  transition: all .5s ease;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  cursor: pointer;
}

@media screen and (max-width:599px) {
  .c-button-form {
    width: 100%;
    font-size: 18px;
  }
}

.c-button-form:hover {
  color: #252525;
  background: #fff;
}

.c-file {
  padding: 10px 15px 10px 10px;
  margin-right: 10px;
}

.c-file:last-of-type {
  margin-right: 0;
}

.c-file i {
  margin-right: 7.5px;
}

@media screen and (max-width:599px) {
  .c-file {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 15px 15px 15px 40px;
    margin-right: 0;
  }
  .c-file:first-of-type {
    margin-bottom: 15px;
  }
  .c-file i {
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%)
  }
  .c-file span {
    margin-right: 25px;
  }
}

.c-more.is-inView {
  transition: none;
}

.c-more.is-inView, .c-more.is-inView:before {
  background: linear-gradient(90deg, #e73c7e, #fa7268 33.33333%, #fff 0, #fff 66.66667%, hsla(0, 0%, 100%, 0) 0);
  background-size: 315%;
  animation: a .66666667s linear 1;
  animation-fill-mode: both;
  animation-delay: .11111111s;
}

.c-more.is-inView:hover {
  background: #fff;
}

.c-input {
  width: .1px;
  height: .1px;
  opacity: 0;
  overflow: hidden;
  position: absolute;
  z-index: -1;
}

.c-input+label {
  cursor: pointer;
}

.c-input:focus+label {
  outline: 1px dotted #252525;
  outline: 5px auto -webkit-focus-ring-color;
}

.c-submit {
  padding: 10px 15px;
}

.c-company {
  max-width: calc((100% - 45px - 30px) / 2);
}

@media screen and (max-width:599px) {
  .c-company {
    max-width: 100%;
  }
}

.c-tel {
  max-width: calc((100% - 45px - 30px) / 2);
}

.c-tel:after {
  content: "\f095";
  display: block;
  font-family: Font Awesome\ 5 Free;
  position: absolute;
  font-size: 25px;
  top: 55%;
  left: 15px;
  transform: translateY(-50%);
  opacity: 0;
  will-change: animation, opacity;
}

.c-tel.is-inView:after {
  background: linear-gradient(90deg, #e73c7e, #fa7268 33.33333%, #fff 0, #fff 66.66667%, hsla(0, 0%, 100%, 0) 0);
  background-size: 315%;
  animation: a .66666667s linear 1;
  animation-fill-mode: both;
  animation-delay: .6s;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  opacity: 1;
}

@media screen and (max-width:599px) {
  .c-tel {
    max-width: calc(100% - 45px - 15px);
  }
}

.c-icon {
  max-width: 45px;
}

.c-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.c-buttons .c-button {
  width: calc(50% - 15px);
  margin-right: 30px;
}

.c-buttons .c-button:last-of-type {
  margin-right: 0;
}

@media screen and (max-width:599px) {
  .c-buttons .c-button {
    width: 100%;
    margin-right: 0;
  }
}

.c-buttons .c-button-prev p:after {
  content: "\f053";
  left: 15px;
  right: auto;
}

.c-buttons .c-button-next, .c-buttons .c-button-prev {
  max-width: 130px;
}

@media screen and (max-width:599px) {
  .c-buttons .c-button-next, .c-buttons .c-button-prev {
    max-width: 60px;
  }
  .c-buttons .c-button-next p:after, .c-buttons .c-button-prev p:after {
    content: none;
  }
}

@media screen and (max-width:599px) {
  .c-buttons .c-button-center {
    max-width: calc(100% - 120px - 30px);
    margin-left: 15px;
    margin-right: 15px;
  }
  .c-buttons .c-button-center p:after {
    content: none;
  }
}

.c-title {
  position: relative;
  display: inline-block;
  margin-bottom: 15px;
  z-index: 3;
}

.c-title, .c-title h2 {
  will-change: animation, opacity;
}

.c-title h2 {
  padding: 10px 15px;
  font-family: Oswald, Noto Sans JP;
  font-weight: 700;
  background: #252525 no-repeat;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.c-title:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  z-index: -1;
  will-change: animation, opacity;
}

.c-title.is-inView h2 {
  background: linear-gradient(90deg, #252525 33.33333%, #fff 0, #fff 66.66667%, #252525 0);
  background-size: 315%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.c-title.is-inView:before, .c-title.is-inView h2 {
  animation: a 1s ease-out 1;
  animation-fill-mode: both;
}

.c-title.is-inView:before {
  background: linear-gradient(90deg, #fff, #fff 33.33333%, #8a2be2 0, #e22bdf 66.66667%, hsla(0, 0%, 100%, 0) 0, hsla(0, 0%, 100%, 0)) no-repeat;
  background-size: 315%;
}

.c-box {
  position: relative;
  /*max-width: 640px;*/
  margin-left: auto;
  margin-right: auto;
}

.c-box-company {
  border-left: 9px solid #e60012;
  border-radius: 0 22.5px 22.5px 0;
  overflow: hidden;
}

@media screen and (max-width:599px) {
  .c-box-company {
    border-top: 9px solid #e60012;
    border-left: none;
    border-radius: 0 0 22.5px 22.5px;
  }
}

.c-box-company-logo {
  background: none;
  width: 100%;
  padding-top: 200px;
}

@media screen and (max-width:599px) {
  .c-box-company-logo {
    margin-top: -15px;
  }
}

.c-box-company-logo img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 75%;
  height: 75%;
}

@media screen and (max-width:375px) {
  .c-box-company-txt {
    font-size: 4vw;
  }
}

.c-box-toggle {
  position: absolute;
  top: 0;
  right: 0;
  width: 45px;
  height: 45px;
  display: none;
  z-index: 50;
  will-change: transform;
}

@media screen and (max-width:599px) {
  .c-box-toggle {
    display: block;
  }
}

.c-box-toggle:before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  content: "\f067";
  font-family: Font Awesome\ 5 Free;
  font-size: 15px;
  font-weight: 700;
  transition: all .5s ease;
}

.c-box-toggle.is-active:before {
  content: "\f068";
}

.c-box-body {
  padding: 15px;
}

.c-box-body-primary {
  background: none;
}

.c-box-title {
  font-weight: 700;
}

.c-box-title.js-accordion-title {
  line-height: 1;
}

.c-box-title.js-accordion-title.is-active {
  line-height: 1.4;
}

.c-box-txt {
  font-size: 18px;
  text-shadow: 0 0 0 #252525;
}

@media screen and (max-width:767px) {
  .c-box-txt {
    font-size: 15px;
  }
}

.c-box-buttons {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: space-between;
}

.c-frame-video {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;
}

.c-frame-video iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.c-gallery-row {
  margin-left: -4px;
  margin-right: -4px;
  margin-bottom: 26px;
}

@media screen and (max-width:599px) {
  .c-gallery-row {
    margin-bottom: 11px;
  }
}

.c-gallery-col {
  padding-left: 4px;
  padding-right: 4px;
  margin-bottom: 8px;
}

@media screen and (max-width:599px) {
  .c-gallery-col {
    width: 50%;
  }
}

.c-entry-info {
  font-family: Unica One, sans-serif;
  text-transform: uppercase;
  text-align: center;
  position: relative;
}

.c-entry-info:after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 0px);
  height: 20px;
  background: #252525;
  z-index: -1;
  bottom: 15px;
}

@media screen and (max-width:1328px) {
  .c-entry-info:after {
    bottom: 3px;
  }
}

.c-entry-info-start {
  letter-spacing: 5px;
  padding-left: 5px;
  font-size: 72px;
}

@media screen and (max-width:1328px) {
  .c-entry-info-start {
    font-size: 42px;
  }
}

.c-entry-info-day {
  display: block;
  font-size: 120px;
  line-height: 72px;
  letter-spacing: -10px;
}

@media screen and (max-width:1328px) {
  .c-entry-info-day {
    font-size: 64px;
    line-height: 42px;
    letter-spacing: -7px;
  }
}

.c-entry-info-day-inner span {
  letter-spacing: 0;
  font-size: 42px;
  display: inline-block;
  margin-right: -20px;
  margin-left: -10px;
  transform: translateY(-30%) rotate(90deg);
}

@media screen and (max-width:1328px) {
  .c-entry-info-day-inner span {
    font-size: 23px;
    margin-right: -10px;
    margin-left: -5px;
  }
}

.c-entry-info-day-inner small {
  font-size: 64px;
  letter-spacing: -5px;
  position: relative;
}

@media screen and (max-width:1328px) {
  .c-entry-info-day-inner small {
    letter-spacing: -3px;
    font-size: 48px;
  }
}

.c-entry-info-day-inner small i {
  margin-left: 15px;
  margin-right: 15px;
}

@media screen and (max-width:1328px) {
  .c-entry-info-day-inner small i {
    margin-right: 10px;
  }
}

.c-entry-info-day-inner small span {
  font-size: 24px;
  margin-right: -15px;
  margin-left: 0;
  transform: translateY(-20%) rotate(90deg);
}

@media screen and (max-width:1328px) {
  .c-entry-info-day-inner small span {
    font-size: 18px;
  }
}

.c-slick-container {
  max-width: 960px;
  margin-bottom: 100px;
}

@media screen and (max-width:1328px) {
  .c-slick-container {
    padding-left: 45px;
    padding-right: 45px;
    margin-bottom: 50px;
  }
}
@media screen and (max-width:767px) {
  .c-slick-container {
    padding-left: 0;
    padding-right: 0;
  }
}

@media screen and (max-width:1328px) {
  .c-slick-row {
    margin-left: 0;
    margin-right: 0;
  }
}

.c-slick-box {
  padding-left: 15px;
  padding-right: 15px;
}

.c-slick-box.is-round img {
  border-radius: 22.5px;
  overflow: hidden;
}

.c-footer-recruit {
  background: #252525;
  color: #fff;
  width: 100%;
  transition: all .5s ease;
  padding-top: 30px;
  padding-bottom: 30px;
}

@media screen and (max-width:599px) {
  .c-footer-recruit {
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 98;
    transform: translateY(100%);
    padding-top: 15px;
    padding-bottom: 15px;
    padding-bottom: calc(constant(safe-area-inset-bottom) + 15px);
    padding-bottom: calc(env(safe-area-inset-bottom) + 15px);
  }
  .c-footer-recruit.is-active {
    transform: translateY(0);
  }
}

.c-footer-recruit-logo {
  width: auto;
  height: 45px;
}

@media screen and (max-width:599px) {
  .c-footer-recruit-logo {
    display: none;
  }
}

.c-footer-recruit-logo img {
  width: auto;
  height: 100%;
}

.c-footer-recruit-txt {
  font-size: 23px;
  font-weight: 700;
  margin-left: 15px;
  margin-right: 15px;
}

@media screen and (max-width:599px) {
  .c-footer-recruit-txt {
    font-size: 15px;
    margin-left: 0;
  }
}

@media screen and (max-width:1328px) {
  .c-footer-recruit-button {
    width: calc(100% - 112.61px - 207px - 60px);
  }
}

@media screen and (max-width:599px) {
  .c-footer-recruit-button {
    width: 100%;
    max-width: calc(100% - 135px - 15px);
  }
  .c-footer-recruit-button p:after {
    content: none;
  }
}

.c-footer-bottom {
  text-align: center;
  background: #BE3B64;
}

.c-footer-personal {
  text-align: center;
  color: #fff;
  font-size: 15px;
  margin-right: 15px;
}

@media screen and (max-width:599px) {
  .c-footer-personal {
    margin-right: 0;
  }
}

.c-footer-personal a {
  display: inline-block;
  color: #fff;
  font-weight: 700;
}

.c-footer-copyright {
  font-size: 15px;
  color: #fff;
  text-align: center;
}
@media screen and (max-width:767px) {
  .c-footer-copyright {
    font-size: 12px;
  }
}

.c-footer-sns {
  position: fixed;
  bottom: 0;
  right: 10px;
  opacity: 0;
  transition: all 1s ease;
}

.c-footer-sns.is-active {
  opacity: 1;
}

@media screen and (max-width:599px) {
  .c-footer-sns {
    display: none;
  }
}

.c-footer-nav-icon {
  display: inline-block;
}

.c-footer-nav-icon a {
  color: #fff;
  padding: 20px 15px;
  font-size: 20px;
  line-height: 1;
  position: relative;
  z-index: 1;
}

.c-footer-nav-icon a .fa {
  width: 30px;
  text-align: center;
}

.c-footer-nav-icon a .fa-envelope {
  font-size: 25px;
  line-height: 35px;
  vertical-align: top;
}

.c-footer-nav-icon a .fa-mixcloud {
  font-size: 15px;
  line-height: 20px;
  vertical-align: middle;
}

.c-footer-nav-icon a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 45px;
  height: 45px;
  background: none;
  border-radius: 999px;
  z-index: -1;
  transition: all .5s ease;
}

.c-footer-nav-icon a:hover {
  opacity: 1;
}

.c-footer-nav-icon a:hover:after {
  background: hsla(0, 0%, 100%, .25);
}

.c-footer-nav-icon a:active {
  opacity: 1;
}

.c-footer-nav-icon a:active:after {
  background: hsla(0, 0%, 100%, 0);
}

.c-footer-nav-icon.is-marked a {
  color: #252525;
  text-shadow: none;
}

.c-footer-nav-icon.is-marked a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 30px;
  height: 30px;
  background: #fff;
  border-radius: 999px;
  z-index: -1;
  transition: all .5s ease;
}

.c-footer-nav-icon.is-marked a:hover {
  opacity: 1;
}

.c-footer-nav-icon.is-marked a:hover:after {
  background: hsla(0, 0%, 100%, .25);
}

.c-footer-nav-icon.is-marked a:active {
  opacity: 1;
}

.c-footer-nav-icon.is-marked a:active:after {
  background: hsla(0, 0%, 100%, 0)
}

.c-footer-nav-icon.is-marked.is-active a {
  color: #fff;
  text-shadow: none;
}

.c-footer-nav-icon.is-marked.is-active a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 45px;
  height: 45px;
  background: none;
  border-radius: 999px;
  z-index: -1;
  transition: all .5s ease;
}

.c-footer-nav-icon.is-marked.is-active a:hover {
  opacity: 1;
}

.c-footer-nav-icon.is-marked.is-active a:hover:after {
  background: hsla(0, 0%, 100%, .25);
}

.c-footer-nav-icon.is-marked.is-active a:active {
  opacity: 1;
}

.c-footer-nav-icon.is-marked.is-active a:active:after {
  background: hsla(0, 0%, 100%, 0);
}

.c-form-control {
  margin-bottom: 15px;
}

@media screen and (max-width:599px) {
  .c-form-control {
    margin-bottom: 10px;
  }
}

.c-form-control h3, .c-form-control label {
  line-height: 1;
}

.c-form-control h3 {
  font-weight: 400;
  margin-bottom: 10px;
}

.c-form-control input[type=email], .c-form-control input[type=text] {
  width: 100%;
  border: none;
  height: 30px;
  font-size: 15px;
  padding-left: 7.5px;
  padding-right: 7.5px;
}

@media screen and (max-width:599px) {
  .c-form-control input[type=email], .c-form-control input[type=text] {
    height: 32px;
    font-size: 16px;
    padding-left: 8px;
    padding-right: 8px;
  }
}

.c-form-control select[name=age], .c-form-control select[name=interviewDay], .c-form-control select[name=interviewMonth], .c-form-control select[name=interviewTime] {
  font-size: 15px;
  padding-left: 7.5px;
  padding-right: 7.5px;
}

@media screen and (max-width:599px) {
  .c-form-control select[name=age], .c-form-control select[name=interviewDay], .c-form-control select[name=interviewMonth], .c-form-control select[name=interviewTime] {
    font-size: 16px;
    padding-left: 8px;
    padding-right: 8px;
  }
}

.c-form-control textarea {
  width: 100%;
  border: none;
  height: 150px;
  font-size: 15px;
  padding: 3px;
}

@media screen and (max-width:599px) {
  .c-form-control textarea {
    height: 240px;
    font-size: 16px;
    padding: 4px;
  }
}

.c-form-control.category label, .c-form-control.location label {
  margin-right: 10px;
  line-height: 1;
}

.c-form-control.category label:last-child, .c-form-control.location label:last-child {
  margin-right: 0;
}

.c-form-control.category input, .c-form-control.location input {
  height: 15px;
  width: 15px;
  line-height: 1;
}

@media screen and (max-width:599px) {
  .c-form-control.category label {
    line-height: 1.4;
  }
}

.c-form-control span.required {
  margin-left: 10px;
  opacity: .5;
}

.p-top-beyond2020 .l-row-flex-wrap {
  flex-direction: column;
}

.p-top-beyond2020 img {
  max-width: 150px;
  margin-bottom: 30px;
}

.p-top-beyond2020 p {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.p-top-support-col {
  width: 14%;
  margin-top: 15px;
  margin-bottom: 15px;
  padding: 0 10px;
}

.p-top-support-col.l-col-3 {
  width: 18%;
  margin: 15px 10px;
}

@media screen and (max-width:599px) {
  .p-top-support-col {
    width: 25%;
  }
  .p-top-support-col.l-col-3 {
    width: 25%;
    margin: 15px 0;
  }
}

@media screen and (max-width:599px) {
  .p-top-support-col p {
    font-size: 8px;
  }
}

.p-top-about-title h2 {
  color: #fa7268;
  font-size: 23px;
  line-height: 1;
}

.p-top-about-title h2 .small {
  font-size: .75em;
}

.p-top-about-title h2 .large {
  display: inline-block;
  font-size: 30px;
}

@media screen and (max-width:599px) {
  .p-top-about-title h2 {
    font-size: 18px;
  }
  .p-top-about-title h2 small {
    font-size: .75em
  }
  .p-top-about-title h2 span {
    font-size: 23px;
    margin-top: 7.5px;
  }
}

.p-top-about-txt {
  font-size:  18px;
  text-align: center;
}

@media screen and (max-width:599px) {
  .p-top-about-txt {
    font-size:  14px;
    text-align: left;
  }
}

.p-top-about-txt b {
  font-weight: 700;
  text-align: center;
  width: 100%;
  display: block;
  margin-bottom: 5px;
}

.p-top-hanabi-container {
  max-width: 960px;
  padding-top: 15px;
  padding-bottom: 15px;
  background: linear-gradient(180deg, #252525 0, #050f1a);
}

@media screen and (max-width:599px) {
  .p-top-hanabi-row {
    margin-left: -15px;
    margin-right: -15px;
  }
}

.p-top-hanabi-col {
  width: 50%;
}

@media screen and (max-width:599px) {
  .p-top-hanabi-col {
    width: 50%;
    padding-left: 15px;
    padding-right: 15px;
  }
}

.p-top-hanabi-title {
  font-size: 24px;
  text-align: center;
}

@media screen and (max-width:599px) {
  .p-top-hanabi-title {
    font-size: 15px;
  }
}

.p-top-hanabi-txt {
  padding: 15px;
}

.p-top-contact a {
  font-weight: 700;
}

.p-top-contact .l-container p {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.p-top-sns ul li i {
  font-size: 30px;
  color: #fff;
  padding: 20px;
}

@media screen and (max-width:599px) {
  .p-top-instagram [class*=row] {
    margin-left: -5px;
    margin-right: -5px;
  }
  .p-top-instagram [class*=col-] {
    float: none;
    width: 33.33333333%;
    padding-left: 5px;
    padding-right: 5px;
  }
}

.p-top-map img {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.p-top-info {
  padding-top: 30px;
  padding-bottom: 60px;
  background: url(../img/bg-banner.jpg) no-repeat 50%/cover;
}

@media screen and (max-width:599px) {
  .p-top-info {
    padding-top: 5px;
    padding-bottom: 20px;
  }
}

.p-top-info-con {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width:599px) {
  .p-top-info-con {
    width: 100%;
    max-width: 100%;
  }
}

.p-top-info-open {
  max-width: 600px;
  font-size: 58px;
  font-weight: 700;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width:599px) {
  .p-top-info-open {
    font-size: 29px;
  }
}

.p-top-info-days {
  max-width: 600px;
  font-size: 45px;
  font-weight: 700;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width:599px) {
  .p-top-info-days {
    width: 100%;
    text-align: center;
    font-size: 20px;
  }
  .p-top-info-days.u-mb-15{
    margin-bottom: 0;
  }
}

.p-top-info-days em {
  font-size: 80px;
  font-weight: 700;
}

@media screen and (max-width:599px) {
  .p-top-info-days em {
    font-size: 40px;
  }
}

.p-top-info-days span {
  position: relative;
  font-size: 24px;
  font-weight: 700;
  z-index: 1;
  margin-left: 20px;
}

.p-top-info-days-span-01 {
  color: #e73c7e;
}

.p-top-info-days-span-02 {
  color: #4385b9;
}

@media screen and (max-width:599px) {
  .p-top-info-days span {
    font-size: 15px;
    margin-left: 10px;
    margin-right: 10px;
  }
}

.p-top-info-days span:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 40px;
  height: 40px;
  background: #f7f7f7;
  border-radius: 50%;
  z-index: -1;
}

@media screen and (max-width:599px) {
  .p-top-info-days span:before {
    width: 25px;
    height: 25px;
  }
}

.p-top-info-venue {
  font-size: 28px;
  font-weight: 700;
  max-width: 600px;
  min-width: 600px;
  text-align: center;
}

@media screen and (max-width:599px) {
  .p-top-info-venue {
    font-size: 15px;
    min-width: 300px;
    max-width: 100%;
    text-align: center;
  }
}

.p-top-info-venue em {
  font-size: 33.3px;
}

@media screen and (max-width:599px) {
  .p-top-info-venue em {
    font-size: 15px;
  }
}

.p-top-info-venue span {
  border: 2px solid #fff;
  padding: 0 5px;
  margin-right: 10px;
}

@media screen and (max-width:599px) {
  .p-top-info-venue span {
    margin-right: 15px;
  }
}

.p-top-info-venue b {
  display: inline;
  font-size: 18px;
}

@media screen and (max-width:599px) {
  .p-top-info-venue b {
    display: block;
    margin-top: 10px;
    font-size: 15px;
  }
}

.p-top-ticket-jpnight-item {
  margin-bottom: 15px;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 0 15px 30px -10px rgba(0, 0, 0, .5);
  position: relative;
}

.p-top-ticket-jpnight-item:last-of-type {
  margin-bottom: 0;
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-item {
    padding: 10px;
  }
}

.p-top-ticket-jpnight-item.is-closed:before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .75);
  z-index: 3;
}

.p-top-ticket-jpnight-item.is-closed:after {
  position: absolute;
  content: "SOLD OUT";
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 30px;
  font-weight: 700;
  z-index: 4;
}

.p-top-ticket-jpnight-area, .p-top-ticket-jpnight-item {
  display: flex;
  flex-direction: row;
  align-items: center;
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-area, .p-top-ticket-jpnight-item {
    flex-wrap: wrap;
  }
}

.p-top-ticket-jpnight-item {
  line-height: 20px;
  background: linear-gradient(270deg, #5030b7, #af48d1);
}

.p-top-ticket-jpnight-area {
  flex-grow: 1;
  flex-wrap: wrap;
  min-width: 10em;
  width: 50%;
  padding-left: 15px;
  padding-right: 15px;
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-area {
    width: 100%;
  }
}

.p-top-ticket-jpnight-info {
  display: flex;
  flex-grow: 1;
  max-width: calc(100% - 500px);
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-info {
    width: 100%;
    max-width: 100%;
    flex-wrap: wrap;
  }
}

.p-top-ticket-jpnight-iconFrame {
  white-space: nowrap;
  font-weight: 700;
  letter-spacing: .5px;
  min-width: 150px;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-iconFrame {
    min-width: 40px;
    margin-bottom: 15px;
  }
}

.p-top-ticket-jpnight-icon {
  display: block;
  font-size: 40px;
  text-transform: uppercase;
  min-width: 150px;
  max-width: 150px;
  background: #252525;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 15px 0 30px -10px rgba(0, 0, 0, .5);
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-icon {
    font-size: 40px;
    box-shadow: 15px 15px 30px -10px rgba(0, 0, 0, .5);
  }
}

.p-top-ticket-jpnight-icon-txt {
  font-size: 15px;
  margin-left: 15px;
  line-height: 1.5;
  min-width: 125px;
  white-space: pre-wrap;
}

.p-top-ticket-jpnight-icon-txt em {
  font-size: 18px;
  color: #fff;
}

.p-top-ticket-jpnight-month {
  display: block;
  font-size: 18px;
  text-transform: uppercase;
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-month {
    font-size: 15px;
  }
}

.p-top-ticket-jpnight-area, .p-top-ticket-jpnight-description, .p-top-ticket-jpnight-iconFrame {
  box-sizing: border-box;
}

.p-top-ticket-jpnight-area a, .p-top-ticket-jpnight-description a {
  color: #fff;
}

.p-top-ticket-jpnight-description-txt {
  font-size: 15px;
}

.p-top-ticket-jpnight-description-txt a {
  display: inline;
}

.p-top-ticket-jpnight-description-txt a b {
  font-weight: 700;
}

.p-top-ticket-jpnight-price {
  display: flex;
  flex-direction: column;
  font-family: Oswald;
  font-weight: 700;
  margin-right: 15px;
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-price {
    min-width: 60px;
    margin-top: 15px;
    margin-right: 0;
    width: 100%;
  }
}

.p-top-ticket-jpnight-price p {
  padding-left: 15px;
  padding-right: 15px;
}

.p-top-ticket-jpnight-price span {
  font-size: 10px;
}

.p-top-ticket-jpnight-option {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 1rem .5rem 0;
  width: 310px;
  align-items: center;
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-option {
    width: 100%;
    padding: 2rem .5rem 0;
  }
}

.p-top-ticket-jpnight-logo {
  width: 20%;
  margin-right: 1rem;
}

.p-top-ticket-jpnight-caption {
  width: calc(80% - 20px);
  font-weight: 700;
  font-family: Noto Sans JP, sans-serif;
  font-size: 15px;
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-caption {
    font-size: 12px;
  }
}

.p-top-ticket-jpnight-buttons {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 300px;
  flex-wrap: wrap;
}

.p-top-ticket-jpnight-button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 50%;
}

.p-top-ticket-jpnight-button.is-ios {
  padding: 10px;
}

.p-top-ticket-jpnight-button.is-ios a {
  height: 40px;
}

@media screen and (max-width:599px) {
  .p-top-ticket-jpnight-button.is-ios a {
    height: 35px;
  }
}

.p-top-ticket-item {
  margin-bottom: 15px;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 0 15px 30px -10px rgba(0, 0, 0, .5);
  position: relative;
}

.p-top-ticket-item:last-of-type {
  margin-bottom: 0;
}

@media screen and (max-width:599px) {
  .p-top-ticket-item {
    padding: 10px;
  }
}

.p-top-ticket-item.is-closed:before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .75);
  z-index: 3;
}

.p-top-ticket-item.is-closed:after {
  position: absolute;
  content: "SOLD OUT";
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 30px;
  font-weight: 700;
  z-index: 4;
}

.p-top-ticket-area, .p-top-ticket-item {
  display: flex;
  flex-direction: row;
  align-items: center;
}

@media screen and (max-width:599px) {
  .p-top-ticket-area, .p-top-ticket-item {
    flex-wrap: wrap;
  }
}

.p-top-ticket-item {
  line-height: 20px;
  background-image: linear-gradient(315deg, #7f5a83, #0d324d 74%);
}

.p-top-ticket-area {
  flex-grow: 1;
  flex-wrap: wrap;
  min-width: 10em;
  width: 50%;
  padding-left: 15px;
  padding-right: 15px;
}

@media screen and (max-width:599px) {
  .p-top-ticket-area {
    width: 100%;
  }
}

.p-top-ticket-info {
  display: flex;
  flex-grow: 1;
  max-width: calc(100% - 200px);
}

@media screen and (max-width:599px) {
  .p-top-ticket-info {
    width: 100%;
    max-width: 100%;
    flex-wrap: wrap;
  }
}

.p-top-ticket-iconFrame {
  white-space: nowrap;
  font-weight: 700;
  letter-spacing: .5px;
  min-width: 150px;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media screen and (max-width:599px) {
  .p-top-ticket-iconFrame {
    min-width: 40px;
    margin-bottom: 15px;
  }
}

.p-top-ticket-icon {
  display: block;
  font-size: 40px;
  text-transform: uppercase;
  min-width: 150px;
  max-width: 150px;
  background: #252525;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 15px 0 30px -10px rgba(0, 0, 0, .5);
}

@media screen and (max-width:599px) {
  .p-top-ticket-icon {
    font-size: 40px;
    box-shadow: 15px 15px 30px -10px rgba(0, 0, 0, .5);
  }
}

.p-top-ticket-icon-txt {
  font-size: 15px;
  margin-left: 15px;
  line-height: 1.5;
  min-width: 125px;
  white-space: pre-wrap;
}

.p-top-ticket-icon-txt em {
  font-size: 18px;
  color: #fff;
}

.p-top-ticket-month {
  display: block;
  font-size: 18px;
  text-transform: uppercase;
}

@media screen and (max-width:599px) {
  .p-top-ticket-month {
    font-size: 15px;
  }
}

.p-top-ticket-area, .p-top-ticket-description, .p-top-ticket-iconFrame {
  box-sizing: border-box;
}

.p-top-ticket-area a, .p-top-ticket-description a {
  color: #fff;
}

.p-top-ticket-description-txt {
  font-size: 15px;
}

.p-top-ticket-description-txt a {
  display: inline;
}

.p-top-ticket-description-txt a b {
  font-weight: 700;
}

.p-top-ticket-price {
  display: flex;
  flex-direction: column;
  font-family: Oswald;
  font-weight: 700;
  margin-right: 15px;
}

@media screen and (max-width:599px) {
  .p-top-ticket-price {
    min-width: 60px;
    margin-top: 15px;
    margin-right: 0;
    width: 100%;
  }
}

.p-top-ticket-price p {
  padding-left: 15px;
  padding-right: 15px;
}

.p-top-ticket-price span {
  font-size: 10px;
}

.p-top-ticket-button {
  width: auto;
  height: auto;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  outline: none;
  display: inline-block;
  line-height: 28px;
  padding: 10px 25px;
  min-width: 175px;
  margin-top: 10px;
  background-color: #310e68;
  background-image: linear-gradient(316deg, #310e68, #5f0f40 74%);
  box-shadow: 15px 15px 30px -10px rgba(0, 0, 0, .5);
  position: relative;
  border-radius: 15px;
  overflow: hidden;
  border: 3px solid #fff;
}

@media screen and (max-width:599px) {
  .p-top-ticket-button {
    width: 100%;
    box-shadow: 0 15px 30px -10px rgba(0, 0, 0, .5);
  }
}

.p-top-ticket-button:active, .p-top-ticket-button:hover {
  color: #252525;
  background: #fff;
}

@media screen and (max-width:599px) {
  .p-top-photos-row {
    margin-left: -7.5px;
    margin-right: -7.5px;
  }
}

.p-top-photos-col {
  margin-bottom: 30px;
}

@media screen and (max-width:599px) {
  .p-top-photos-col {
    width: 50%;
    padding-left: 7.5px;
    padding-right: 7.5px;
    margin-bottom: 15px;
  }
}

.p-top-photos-history a {
  display: inline-block;
  color: #252525;
  font-weight: 700;
  background: #fff;
  padding: 10px 15px;
  transition: all .5s ease;
  width: 290px;
}

.p-top-photos-history a:active, .p-top-photos-history a:hover {
  background: #e73c7e;
  color: #fff;
}

@media screen and (max-width:599px) {
  .p-top-photos-history a {
    width: calc(100% - 15px);
  }
}

.p-top-QandA-col {
  padding: 15px;
  border-radius: 15px;
  overflow: hidden;
  background-color: #e1e1e1;
  /*background-color: #7f5a83;
  background-image: linear-gradient(315deg, #7f5a83, #0d324d 74%);
  box-shadow: 0 15px 30px -10px rgba(0, 0, 0, .5);*/
  margin-bottom: 30px;
}

@media screen and (max-width:599px) {
  .p-top-QandA-col {
    margin-bottom: 15px;
  }
}

.p-top-QandA-Q {
  display: flex;
  flex-wrap: wrap;
  transition: all .5s ease;
}

.p-top-QandA-Q.is-active {
  margin-bottom: 10px;
}

.p-top-QandA-Q:before {
  content: "Q.";
  display: inline-block;
  width: 20px;
}

.p-top-QandA-Q span {
  width: calc(100% - 20px);
  padding-right: 30px;
}

.p-top-QandA-A {
  display: flex;
  flex-wrap: wrap;
}

.p-top-QandA-A:before {
  content: "A.";
  display: inline-block;
  width: 20px;
}

.p-top-QandA-A span {
  width: calc(100% - 20px);
}

.p-top-access-bg {
  background: url(../img/bg-banner.jpg) no-repeat 50%/cover;
}

@media screen and (max-width:599px) {
  .p-top-access-title-row {
    flex-direction: column;
  }
}

@media screen and (max-width:599px) {
  .p-top-access-title-logo, .p-top-access-title-txt {
    max-width: 150px;
  }
}

.p-top-access-box {
  margin-bottom: 30px;
    text-align: center;
}

.p-top-access-box p {
  font-size: 28px;
  margin-bottom: 10px;
}
@media screen and (max-width:767px) {
  .p-top-access-box p {
    font-size: 16px;
    margin-bottom: 5px;
  }
}

.p-top-access-box dl {
  font-size: 15px;
  width: 100%;
}

.p-top-access-box dt {
  font-size: 15px;
  width: 25%;
}

.p-top-access-box dd {
  font-size: 15px;
  width: 75%;
}

.p-top-attention h3 {
  margin-bottom: 15px;
  line-height: 2;
}

.p-top-attention h3 i {
  margin-right: 5px;
}

.p-request-buttons {
  text-align: center;
}

.p-request-button {
  text-align: center;
  padding: 15px;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 700;
  max-width: 300px;
  margin-left: auto;
  margin-right: auto;
}

.p-request-button-white {
  background: #fff;
  background-size: 315%;
  animation: a .66666667s linear 1;
  animation-fill-mode: both;
  animation-delay: .11111111s;
  transition: none;
}

.p-request-button-white:hover {
  opacity: .5;
}

.p-request-button-white p {
  color: #e73c7e;
  font-size: 15px;
}

.p-request-about-box {
  padding: 15px;
}

.p-request-about .limit {
  text-align: center;
  margin-top: 15px;
  margin-bottom: 15px;
  font-size: 30px;
  font-weight: 700;
}

@media screen and (max-width:599px) {
  .p-request-about .limit {
    font-size: 18px;
  }
}

.p-request-container {
  max-width: 960px;
}

.p-request-table {
  font-family: Noto Sans JP, sans-serif;
}

.p-request-table-row {
  margin: 0;
}

.p-request-table-col {
  padding: 0;
}

@media screen and (max-width:599px) {
  .p-request-table-col {
    margin-bottom: 15px;
  }
}

.p-request-table-header {
  font-size: 18px;
  text-align: center;
  background: #ff435a;
  border: 2px solid #fff;
  border-bottom: none;
  padding: 5px;
}

.p-request-table-body {
  font-size: 18px;
  border: 2px solid #fff;
  padding: 15px;
  height: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.p-request-table-body small {
  font-size: 8px;
}

@media screen and (max-width:599px) {
  .p-request-table-body {
    height: auto;
  }
}

.p-request-method-row {
  margin-bottom: 30px;
}

.p-request-method-row:last-child {
  margin-bottom: 0;
}

.p-request-method-step {
  width: 103px;
  height: 89px;
  background: url(/assets/img/request/step.png) 50% no-repeat;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media screen and (max-width:599px) {
  .p-request-method-step {
    transform: rotate(90deg);
  }
}

@media screen and (max-width:599px) {
  .p-request-method-step div {
    transform: rotate(-90deg) translateY(-7px);
  }
}

.p-request-method-step p {
  font-family: Noto Sans JP, sans-serif;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  transform: translate(-7px);
}

@media screen and (max-width:599px) {
  .p-request-method-step p {
    transform: translate(0);
  }
}

.p-request-method-step h4 {
  font-family: Noto Sans JP, sans-serif;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  font-size: 36px;
  transform: translate(-7px);
}

@media screen and (max-width:599px) {
  .p-request-method-step h4 {
    transform: translate(0);
  }
}

.p-request-method-body {
  background: linear-gradient(270deg, #e73c7e, #fa7268);
  padding: 15px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  font-family: Noto Sans JP, sans-serif;
}

.p-request-method-body img {
  margin-left: auto;
  margin-right: auto;
  max-width: 100px;
}

@media screen and (max-width:599px) {
  .p-request-method-body img {
    max-width: 100px;
    margin-bottom: 15px;
  }
}

.p-request-method-body [class*=l-col] {
  font-size: 15px;
}

.p-request-method-body a {
  color: #ff0;
}

.p-request-method-body small {
  font-size: 8px;
  color: #ff0;
  margin-left: auto;
  margin-right: auto;
}

.p-request-method-body .inline {
  display: inline;
}

.p-tickets-container {
  max-width: 960px;
  padding-left: 30px;
  padding-right: 30px;
}

.p-tickets-detail-img {
  box-shadow: 0 20px 40px rgba(0, 0, 0, .8);
}

.p-tickets-detail-row {
  margin-left: 0;
  margin-right: 0;
}

.p-tickets-detail-box {
  padding: 20px;
}

.p-tickets-detail-box h4 {
  font-size: 30px;
}

@media screen and (max-width:599px) {
  .p-tickets-detail-box h4 {
    font-size: 18px;
  }
}

.p-tickets-detail-box p {
  font-size: 15px;
}

@media screen and (max-width:599px) {
  .p-tickets-detail-box p {
    font-size: 15px;
  }
}

.p-tickets-detail-box-second {
  padding: 30px;
  position: relative;
}

.p-tickets-detail-box-second:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 5px;
  height: calc(100% - 60px);
  transform: translateY(-50%);
  background: linear-gradient(0deg, #e73c7e, #fa7268);
}

.p-tickets-detail-box-second h4 {
  font-size: 25px;
}

@media screen and (max-width:599px) {
  .p-tickets-detail-box-second h4 {
    font-size: 18px;
  }
}

.p-tickets-detail-box-second p {
  font-size: 20px;
}

@media screen and (max-width:599px) {
  .p-tickets-detail-box-second p {
    font-size: 15px;
  }
}

.p-tickets-detail .limit {
  text-align: center;
  margin-top: 15px;
  margin-bottom: 15px;
  font-size: 30px;
  font-weight: 700;
}

@media screen and (max-width:599px) {
  .p-tickets-detail .limit {
    font-size: 18px;
  }
}

.p-tickets-map a {
  margin-left: auto;
  margin-right: auto;
}

.p-tickets-map img {
  max-width: 600px;
}

.p-tickets-form-section-title h2 {
  text-align: center;
  margin-top: 50px;
  margin-bottom: 50px;
}

@media screen and (max-width:599px) {
  .p-tickets-form-section-title h2 {
    margin-top: 30px;
    margin-bottom: 30px;
  }
}

.p-tickets-form-container {
  max-width: 600px;
}

.p-tickets-form-container p {
  font-size: 18px;
  line-height: 2
}

@media screen and (max-width:599px) {
  .p-tickets-form-container p {
    font-size: 15px;
  }
}

.p-tickets-form-container p span {
  color: red;
  margin-right: 10px;
}

.p-tickets-form-container input {
  font-size: 16px;
  width: 100%;
  padding: 5px;
  border: none;
  border-radius: 3px;
}

.p-tickets-form-container-small {
  max-width: 420px;
  position: relative;
}

.p-tickets-form-container-small.is-closed:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .75);
  z-index: 1;
}

.p-tickets-form-container-small.is-closed:after {
  content: "SOLD OUT";
  font-size: 30px;
  font-weight: 700;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}

.p-tickets-form-container-small input {
  display: none;
}

.p-tickets-form-container-small input[type=checkbox]:checked+.checkbox:before {
  opacity: 1;
}

.p-tickets-form-container-small select {
  font-size: 15px;
  color: #252525;
  outline: none;
  text-indent: .01px;
  text-overflow: "";
  background: #fff;
  vertical-align: middle;
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  height: 40px;
  padding: 8px 12px;
  width: 100%;
  border-radius: 3px;
}

.p-tickets-form-container-small select option {
  background-color: #fff;
  color: #252525;
}

.p-tickets-form-container-small select::-ms-expand {
  display: none;
}

.p-tickets-form-container-small select:-moz-focusring {
  color: transparent;
  text-shadow: 0 0 0 #fff;
}

.p-tickets-form-container-small .checkbox {
  box-sizing: border-box;
  transition: background-color .2s linear;
  position: relative;
  display: inline-block;
  padding: 12px 12px 12px 42px;
  border-radius: 8px;
  vertical-align: middle;
  cursor: pointer;
}

.p-tickets-form-container-small .checkbox:after {
  transition: border-color .2s linear;
  position: absolute;
  top: 50%;
  left: 15px;
  display: block;
  margin-top: -8px;
  width: 16px;
  height: 16px;
  border: 2px solid #fff;
  content: "";
}

.p-tickets-form-container-small .checkbox:before {
  transition: opacity .2s linear;
  position: absolute;
  top: 50%;
  left: 21px;
  display: block;
  margin-top: -7px;
  width: 5px;
  height: 9px;
  border-right: 3px solid #fff;
  border-bottom: 3px solid #fff;
  content: "";
  opacity: 0;
  transform: rotate(45deg);
}

.p-tickets-form-container-small .select-wrap {
  position: relative;
}

.p-tickets-form-container-small .select-wrap:before {
  z-index: 1;
  position: absolute;
  right: 15px;
  top: 0;
  content: "\f078";
  font-family: Font Awesome\ 5 Free;
  font-size: 15px;
  font-weight: 700;
  line-height: 43px;
  color: #252525;
  pointer-events: none;
}

.p-tickets-form-container-submit {
  margin-top: 30px;
  margin-bottom: 30px;
  padding-left: 30px;
  padding-right: 30px;
}

.p-tickets-form-container-submit input {
  background: linear-gradient(90deg, #e73c7e, #fa7268);
  padding: 15px;
  color: #fff;
  font-family: Noto Serif JP, serif;
  font-size: 28px;
  border: none;
  width: 300px;
  transition: all .5s ease;
}

@media screen and (max-width:599px) {
  .p-tickets-form-container-submit input {
    width: 100%;
    font-size: 18px;
  }
}

.p-tickets-form-container-submit input:hover {
  color: #252525;
  background: #fff;
}

.p-tickets-form-col {
  width: 100%;
}

@media screen and (max-width:599px) {
  .p-tickets-form-col {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.p-tickets-form-col-small {
  width: 33.3333333333%;
  margin-top: 15px;
}

@media screen and (max-width:599px) {
  .p-tickets-form-col-small {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.p-tickets-attention-box {
  border: 2px solid #fff;
  padding: 15px;
}

.p-work-job [class*=row] {
  margin-top: -75px;
  padding-top: 105px;
}

@media screen and (max-width:599px) {
  .p-work-job [class*=row] {
    margin-top: -45px;
    padding-top: 60px;
  }
}

.p-work-job .c-box {
  background: none;
}

.p-work-result {
  margin-top: -75px;
  padding-top: 105px;
}

@media screen and (max-width:599px) {
  .p-work-result {
    margin-top: -45px;
    padding-top: 60px;
  }
}

@media screen and (max-width:599px) {
  .p-work-result [class*=row] {
    margin-left: -7.5px;
    margin-right: -7.5px;
  }
}

@media screen and (max-width:599px) {
  .p-work-result [class*=col-] {
    width: 50%;
    padding-left: 7.5px;
    padding-right: 7.5px;
  }
}

.p-work-result .c-box {
  margin-bottom: 30px;
}

@media screen and (max-width:599px) {
  .p-work-result .c-box {
    margin-bottom: 15px;
  }
}

.p-work-result .c-box-title {
  text-align: center;
}

@media screen and (max-width:599px) {
  .p-models-list [class*=row] {
    margin-left: -7.5px;
    margin-right: -7.5px;
  }
}

@media screen and (max-width:599px) {
  .p-models-list [class*=col-] {
    width: 50%;
    padding-left: 7.5px;
    padding-right: 7.5px;
  }
}

.p-models-list .c-box {
  margin-bottom: 30px;
}

@media screen and (max-width:599px) {
  .p-models-list .c-box {
    margin-bottom: 15px;
  }
}

.p-models-list .c-box-title {
  text-align: center;
}

.p-models-list .c-box h5 {
  opacity: .5;
}

.p-model-detail-box {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
}

.p-model-detail-box [class*=container] {
  height: 100%;
}

@media screen and (max-width:599px) {
  .p-model-detail-box [class*=container] {
    padding: 15px;
  }
}

.p-model-detail-box [class*=row] {
  height: 100%;
  margin-left: 0;
  margin-right: 0;
}

.p-model-detail-box-title {
  text-align: center;
  width: 100%;
}

.p-model-detail-box h3 {
  font-size: 30px;
  margin-top: 15px;
}

@media screen and (max-width:1328px) {
  .p-model-detail-box h3 {
    font-size: 23px;
  }
}

.p-model-detail-box h4 {
  font-size: 21px;
  opacity: .5;
  margin-bottom: 30px;
}

@media screen and (max-width:1328px) {
  .p-model-detail-box h4 {
    font-size: 18px;
    margin-bottom: 15px;
  }
}

.p-model-detail-box dl dd, .p-model-detail-box dl dt {
  display: inline-block;
  width: calc(50% - 15px);
  font-size: 15px;
  margin-bottom: 15px;
}

.p-model-detail-box dl dt {
  text-align: right;
  margin-left: auto;
  margin-right: 15px;
}

.p-model-detail-box dl dd {
  text-align: left;
  margin-left: 0;
  margin-right: auto;
}

.p-faq-list-box {
  border-radius: 25.5px;
  overflow: hidden;
}

.p-faq-list-box-toggle {
  height: 51px;
}

.p-faq-list-box-toggle:before {
  color: #fff;
}

.p-faq-list-box-question {
  display: flex;
  color: #fff;
  background: #fa7268;
}

.p-faq-list-box-question:before {
  content: "Q.";
  display: inline-block;
  font-size: 15px;
  font-weight: 700;
  margin-right: 10px;
}

@media screen and (max-width:599px) {
  .p-faq-list-box-question:before {
    margin-right: 7.5px;
  }
}

.p-faq-list-box-question h4 {
  font-size: 15px;
  font-weight: 400;
  padding-right: 20px;
}

.p-faq-list-box-answer .c-box-content {
  display: flex;
}

.p-faq-list-box-answer .c-box-content:before {
  content: "A.";
  font-size: 15px;
  font-weight: 700;
  margin-right: 10px;
}

@media screen and (max-width:599px) {
  .p-faq-list-box-answer .c-box-content:before {
    margin-right: 7.5px;
  }
}

.p-faq-list-box-answer .c-box-content p {
  width: calc(100% - 30px);
}

.p-recruit-application [class*=container] {
  padding-left: 30px;
  padding-left: calc(constant(safe-area-inset-left) + 30px);
  padding-left: calc(env(safe-area-inset-left) + 30px);
  padding-right: 30px;
  padding-right: calc(constant(safe-area-inset-right) + 30px);
  padding-right: calc(env(safe-area-inset-right) + 30px);
}

@media screen and (max-width:599px) {
  .p-recruit-application [class*=container] {
    padding-left: 15px;
    padding-right: 15px;
  }
}

@media screen and (max-width:599px) {
  .p-recruit-application [class*=row] {
    margin-left: 0;
    margin-right: 0;
  }
}

.p-recruit-application .c-box-title {
  line-height: 1;
}

.p-recruit-application .c-box-toggle {
  color: #fff;
}

.p-recruit-application [class*=col-]:nth-of-type(odd) .c-box-body:nth-of-type(odd) {
  background-color: #fa7268;
  color: #fff;
}

.p-recruit-application [class*=col-]:nth-of-type(odd) .c-box-body:nth-of-type(2n+2) {
  background-color: #fff;
}

@media screen and (max-width:599px) {
  .p-recruit-application [class*=col-]:nth-of-type(odd) .c-box-body:nth-of-type(2n+2) {
    background-color: hsla(0, 0%, 100%, .75);
  }
}

.p-recruit-application [class*=col-]:nth-of-type(2n+2) .c-box-body:nth-of-type(odd) {
  background-color: #f95b4f;
  color: #fff;
}

@media screen and (max-width:599px) {
  .p-recruit-application [class*=col-]:nth-of-type(2n+2) .c-box-body:nth-of-type(odd) {
    background-color: #fa7268;
  }
}

.p-recruit-application [class*=col-]:nth-of-type(2n+2) .c-box-body:nth-of-type(2n+2) {
  background-color: hsla(0, 0%, 100%, .75);
}

.p-senshu {
  background: #fff;
  color: #252525;
}

.p-senshu .l-row {
  margin-left: 0;
  margin-right: 0;
}

.p-senshu h3 {
  margin-top: 30px;
  margin-bottom: 30px;
  font-size: 23px;
}

.p-sponsorship {
  background: #fff;
  color: #252525;
  margin-bottom: 100px;
}
@media screen and (max-width:767px) {
.p-sponsorship {
  margin-bottom: 50px;
}
}

.p-sponsorship .l-row-flex-wrap {
  padding: 15px;
}

.p-sponsorship-title {
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 15px;
}
@media screen and (max-width:767px) {
  .p-sponsorship-title {
    font-size: 20px;
  }
}

.p-sponsorship-content {
  border: 2px solid #FF7BAC;
  margin-top: 50px;
  margin-left: -15px;
  margin-right: -15px;
}

@media screen and (max-width:599px) {
  .p-sponsorship-content {
    margin-left: 0;
    margin-right: 0;
  }
}

.p-sponsorship-content a {
  color: #252525;
}

@media screen and (max-width:599px) {
  .p-sponsorship-col-2 {
    margin-left: 15px;
    margin-right: 15px;
    width: 16.666666666%;
  }
}

@media screen and (max-width:599px) {
  .p-sponsorship-col-4 {
    margin-left: 15px;
    margin-right: 15px;
    width: 25%;
  }
}

.p-sponsorship-col-title {
  color: #fff;
  background: #242d5f;
  text-align: center;
  padding: 15px;
}

@media screen and (max-width:599px) {
  .p-sponsorship-col-inner h3 {
    font-size: 15px;
    font-weight: 700;
  }
}

.p-themesong-container {
  width: 100%;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
}

.p-themesong-about {
  background: #252525;
  color: #fff;
}

.p-themesong-about h3 {
  font-size: 23px;
  text-align: center;
  margin-top: 30px;
  margin-bottom: 30px;
  padding-left: 15px;
  padding-right: 15px;
}

@media screen and (max-width:599px) {
  .p-themesong-about h3 {
    font-size: 15px;
  }
}

.p-themesong-about p {
  font-size: 15px;
  text-align: center;
}

.p-themesong-about-buttons {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding-top: 15px;
}

.p-themesong-about-button {
  border: 2px solid #fff;
  border-radius: 0;
  padding: 15px;
  text-align: center;
  font-weight: 700;
  background: #252525;
  color: #fff;
  width: 100%;
  max-width: 250px;
  font-family: Oswald, sans-serif;
  font-size: 18px;
  margin-bottom: 30px;
  transition: background .5s ease, color .5s ease;
}

.p-themesong-about-button:last-of-type {
  margin-bottom: 0;
}

@media screen and (max-width:599px) {
  .p-themesong-about-button {
    max-width: 100%;
  }
}

.p-themesong-about-button:hover {
  background: #fff;
  color: #252525;
}

.p-themesong-thanks {
  padding-top: 50px;
  padding-bottom: 50px;
}

.p-themesong-profile {
  background: #252525;
  color: #fff;
}

.p-themesong-profile h2 {
  font-size: 23px;
  font-family: Oswald, sans-serif;
  line-height: 2;
}

.p-themesong-profile h3 {
  font-size: 10px;
  line-height: 2;
  margin-bottom: 15px;
}

.p-themesong-profile h4 {
  font-size: 18px;
  font-family: Oswald, sans-serif;
  line-height: 2;
}

.p-themesong-profile p {
  font-size: 15px;
  margin-bottom: 15px;
}

.is-visible {
  display: block!important;
}

.is-hidden {
  display: none!important;
}

.is-sr-only {
  border: none!important;
  clip: rect(0, 0, 0, 0)!important;
  height: .01em!important;
  overflow: hidden!important;
  padding: 0!important;
  position: absolute!important;
  white-space: nowrap!important;
  width: .01em!important;
}

@media screen and (min-width:1329px) {
  .is-hidden-except-tablet {
    display: none!important;
  }
}

@media screen and (max-width:1328px) {
  .is-hidden-tablet {
    display: none!important;
  }
}

@media screen and (min-width:600px) and (max-width:1328px) {
  .is-hidden-tablet-only {
    display: none!important;
  }
}

@media screen and (min-width:600px) {
  .is-hidden-except-mobile {
    display: none!important;
  }
}

@media screen and (max-width:599px) {
  .is-hidden-mobile {
    display: none!important;
  }
}

.is-invisible {
  visibility: hidden!important;
}

@media screen and (max-width:1328px) {
  .is-invisible-tablet {
    visibility: hidden!important;
  }
}

@media screen and (min-width:600px) and (max-width:1328px) {
  .is-invisible-tablet-only {
    visibility: hidden!important;
  }
}

@media screen and (max-width:599px) {
  .is-invisible-mobile {
    visibility: hidden!important;
  }
}

.u-mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.u-my-auto {
  margin-top: auto;
  margin-bottom: auto;
}

@media screen and (max-width:1328px) {
  .u-mx-auto-tablet {
    margin-left: auto;
    margin-right: auto;
  }
  .u-my-auto-tablet {
    margin-top: auto;
    margin-bottom: auto;
  }
}

@media screen and (max-width:599px) {
  .u-mx-auto-mobile {
    margin-left: auto;
    margin-right: auto;
  }
  .u-my-auto-mobile {
    margin-top: auto;
    margin-bottom: auto;
  }
}

.u-mt-auto {
  margin-top: auto;
}

.u-mt-0 {
  margin-top: 0;
}

.u-mt-5 {
  margin-top: 5px;
}

.u-mt-10 {
  margin-top: 10px;
}

.u-mt-15 {
  margin-top: 15px;
}

.u-mt-20 {
  margin-top: 20px;
}

.u-mt-25 {
  margin-top: 25px;
}

.u-mt-30 {
  margin-top: 30px;
}

.u-mt-35 {
  margin-top: 35px;
}

.u-mt-40 {
  margin-top: 40px;
}

.u-mt-45 {
  margin-top: 45px;
}

.u-mt-50 {
  margin-top: 50px;
}

.u-mt-55 {
  margin-top: 55px;
}

.u-mt-60 {
  margin-top: 60px;
}

.u-mt-65 {
  margin-top: 65px;
}

.u-mt-70 {
  margin-top: 70px;
}

.u-mt-75 {
  margin-top: 75px;
}

.u-mt-80 {
  margin-top: 80px;
}

.u-mt-85 {
  margin-top: 85px;
}

.u-mt-90 {
  margin-top: 90px;
}

.u-mt-95 {
  margin-top: 95px;
}

.u-mt-100 {
  margin-top: 100px;
}

.u-mt-105 {
  margin-top: 105px;
}

.u-mt-110 {
  margin-top: 110px;
}

.u-mt-115 {
  margin-top: 115px;
}

.u-mt-120 {
  margin-top: 120px;
}

.u-mt-125 {
  margin-top: 125px;
}

.u-mt-130 {
  margin-top: 130px;
}

.u-mt-135 {
  margin-top: 135px;
}

.u-mt-140 {
  margin-top: 140px;
}

.u-mt-145 {
  margin-top: 145px;
}

.u-mt-150 {
  margin-top: 150px;
}

.u-mb-auto {
  margin-bottom: auto;
}

.u-mb-0 {
  margin-bottom: 0;
}

.u-mb-5 {
  margin-bottom: 5px;
}

.u-mb-10 {
  margin-bottom: 10px;
}

.u-mb-15 {
  margin-bottom: 15px;
}

.u-mb-20 {
  margin-bottom: 20px;
}

.u-mb-25 {
  margin-bottom: 25px;
}

.u-mb-30 {
  margin-bottom: 30px;
}

.u-mb-35 {
  margin-bottom: 35px;
}

.u-mb-40 {
  margin-bottom: 40px;
}

.u-mb-45 {
  margin-bottom: 45px;
}

.u-mb-50 {
  margin-bottom: 50px;
}

.u-mb-55 {
  margin-bottom: 55px;
}

.u-mb-60 {
  margin-bottom: 60px;
}

.u-mb-65 {
  margin-bottom: 65px;
}

.u-mb-70 {
  margin-bottom: 70px;
}

.u-mb-75 {
  margin-bottom: 75px;
}

.u-mb-80 {
  margin-bottom: 80px;
}

.u-mb-85 {
  margin-bottom: 85px;
}

.u-mb-90 {
  margin-bottom: 90px;
}

.u-mb-95 {
  margin-bottom: 95px;
}

.u-mb-100 {
  margin-bottom: 100px;
}

.u-mb-105 {
  margin-bottom: 105px;
}

.u-mb-110 {
  margin-bottom: 110px;
}

.u-mb-115 {
  margin-bottom: 115px;
}

.u-mb-120 {
  margin-bottom: 120px;
}

.u-mb-125 {
  margin-bottom: 125px;
}

.u-mb-130 {
  margin-bottom: 130px;
}

.u-mb-135 {
  margin-bottom: 135px;
}

.u-mb-140 {
  margin-bottom: 140px;
}

.u-mb-145 {
  margin-bottom: 145px;
}

.u-mb-150 {
  margin-bottom: 150px;
}

@media screen and (max-width:1328px) {
  .u-mt-auto-tablet {
    margin-top: auto;
  }
  .u-mt-0-tablet {
    margin-top: 0;
  }
  .u-mt-5-tablet {
    margin-top: 5px;
  }
  .u-mt-10-tablet {
    margin-top: 10px;
  }
  .u-mt-15-tablet {
    margin-top: 15px;
  }
  .u-mt-20-tablet {
    margin-top: 20px;
  }
  .u-mt-25-tablet {
    margin-top: 25px;
  }
  .u-mt-30-tablet {
    margin-top: 30px;
  }
  .u-mt-35-tablet {
    margin-top: 35px;
  }
  .u-mt-40-tablet {
    margin-top: 40px;
  }
  .u-mt-45-tablet {
    margin-top: 45px;
  }
  .u-mt-50-tablet {
    margin-top: 50px;
  }
  .u-mt-55-tablet {
    margin-top: 55px;
  }
  .u-mt-60-tablet {
    margin-top: 60px;
  }
  .u-mt-65-tablet {
    margin-top: 65px;
  }
  .u-mt-70-tablet {
    margin-top: 70px;
  }
  .u-mt-75-tablet {
    margin-top: 75px;
  }
  .u-mt-80-tablet {
    margin-top: 80px;
  }
  .u-mt-85-tablet {
    margin-top: 85px;
  }
  .u-mt-90-tablet {
    margin-top: 90px;
  }
  .u-mt-95-tablet {
    margin-top: 95px;
  }
  .u-mt-100-tablet {
    margin-top: 100px;
  }
  .u-mt-105-tablet {
    margin-top: 105px;
  }
  .u-mt-110-tablet {
    margin-top: 110px;
  }
  .u-mt-115-tablet {
    margin-top: 115px;
  }
  .u-mt-120-tablet {
    margin-top: 120px;
  }
  .u-mt-125-tablet {
    margin-top: 125px;
  }
  .u-mt-130-tablet {
    margin-top: 130px;
  }
  .u-mt-135-tablet {
    margin-top: 135px;
  }
  .u-mt-140-tablet {
    margin-top: 140px;
  }
  .u-mt-145-tablet {
    margin-top: 145px;
  }
  .u-mt-150-tablet {
    margin-top: 150px;
  }
  .u-mb-auto-tablet {
    margin-bottom: auto;
  }
  .u-mb-0-tablet {
    margin-bottom: 0;
  }
  .u-mb-5-tablet {
    margin-bottom: 5px;
  }
  .u-mb-10-tablet {
    margin-bottom: 10px;
  }
  .u-mb-15-tablet {
    margin-bottom: 15px;
  }
  .u-mb-20-tablet {
    margin-bottom: 20px;
  }
  .u-mb-25-tablet {
    margin-bottom: 25px;
  }
  .u-mb-30-tablet {
    margin-bottom: 30px;
  }
  .u-mb-35-tablet {
    margin-bottom: 35px;
  }
  .u-mb-40-tablet {
    margin-bottom: 40px;
  }
  .u-mb-45-tablet {
    margin-bottom: 45px;
  }
  .u-mb-50-tablet {
    margin-bottom: 50px;
  }
  .u-mb-55-tablet {
    margin-bottom: 55px;
  }
  .u-mb-60-tablet {
    margin-bottom: 60px;
  }
  .u-mb-65-tablet {
    margin-bottom: 65px;
  }
  .u-mb-70-tablet {
    margin-bottom: 70px;
  }
  .u-mb-75-tablet {
    margin-bottom: 75px;
  }
  .u-mb-80-tablet {
    margin-bottom: 80px;
  }
  .u-mb-85-tablet {
    margin-bottom: 85px;
  }
  .u-mb-90-tablet {
    margin-bottom: 90px;
  }
  .u-mb-95-tablet {
    margin-bottom: 95px;
  }
  .u-mb-100-tablet {
    margin-bottom: 100px;
  }
  .u-mb-105-tablet {
    margin-bottom: 105px;
  }
  .u-mb-110-tablet {
    margin-bottom: 110px;
  }
  .u-mb-115-tablet {
    margin-bottom: 115px;
  }
  .u-mb-120-tablet {
    margin-bottom: 120px;
  }
  .u-mb-125-tablet {
    margin-bottom: 125px;
  }
  .u-mb-130-tablet {
    margin-bottom: 130px;
  }
  .u-mb-135-tablet {
    margin-bottom: 135px;
  }
  .u-mb-140-tablet {
    margin-bottom: 140px;
  }
  .u-mb-145-tablet {
    margin-bottom: 145px;
  }
  .u-mb-150-tablet {
    margin-bottom: 150px;
  }
}

@media screen and (max-width:599px) {
  .u-mt-auto-mobile {
    margin-top: auto;
  }
  .u-mt-0-mobile {
    margin-top: 0;
  }
  .u-mt-5-mobile {
    margin-top: 5px;
  }
  .u-mt-10-mobile {
    margin-top: 10px;
  }
  .u-mt-15-mobile {
    margin-top: 15px;
  }
  .u-mt-20-mobile {
    margin-top: 20px;
  }
  .u-mt-25-mobile {
    margin-top: 25px;
  }
  .u-mt-30-mobile {
    margin-top: 30px;
  }
  .u-mt-35-mobile {
    margin-top: 35px;
  }
  .u-mt-40-mobile {
    margin-top: 40px;
  }
  .u-mt-45-mobile {
    margin-top: 45px;
  }
  .u-mt-50-mobile {
    margin-top: 50px;
  }
  .u-mt-55-mobile {
    margin-top: 55px;
  }
  .u-mt-60-mobile {
    margin-top: 60px;
  }
  .u-mt-65-mobile {
    margin-top: 65px;
  }
  .u-mt-70-mobile {
    margin-top: 70px;
  }
  .u-mt-75-mobile {
    margin-top: 75px;
  }
  .u-mt-80-mobile {
    margin-top: 80px;
  }
  .u-mt-85-mobile {
    margin-top: 85px;
  }
  .u-mt-90-mobile {
    margin-top: 90px;
  }
  .u-mt-95-mobile {
    margin-top: 95px;
  }
  .u-mt-100-mobile {
    margin-top: 100px;
  }
  .u-mt-105-mobile {
    margin-top: 105px;
  }
  .u-mt-110-mobile {
    margin-top: 110px;
  }
  .u-mt-115-mobile {
    margin-top: 115px;
  }
  .u-mt-120-mobile {
    margin-top: 120px;
  }
  .u-mt-125-mobile {
    margin-top: 125px;
  }
  .u-mt-130-mobile {
    margin-top: 130px;
  }
  .u-mt-135-mobile {
    margin-top: 135px;
  }
  .u-mt-140-mobile {
    margin-top: 140px;
  }
  .u-mt-145-mobile {
    margin-top: 145px;
  }
  .u-mt-150-mobile {
    margin-top: 150px;
  }
  .u-mb-auto-mobile {
    margin-bottom: auto;
  }
  .u-mb-0-mobile {
    margin-bottom: 0;
  }
  .u-mb-5-mobile {
    margin-bottom: 5px;
  }
  .u-mb-10-mobile {
    margin-bottom: 10px;
  }
  .u-mb-15-mobile {
    margin-bottom: 15px;
  }
  .u-mb-20-mobile {
    margin-bottom: 20px;
  }
  .u-mb-25-mobile {
    margin-bottom: 25px;
  }
  .u-mb-30-mobile {
    margin-bottom: 30px;
  }
  .u-mb-35-mobile {
    margin-bottom: 35px;
  }
  .u-mb-40-mobile {
    margin-bottom: 40px;
  }
  .u-mb-45-mobile {
    margin-bottom: 45px;
  }
  .u-mb-50-mobile {
    margin-bottom: 50px;
  }
  .u-mb-55-mobile {
    margin-bottom: 55px;
  }
  .u-mb-60-mobile {
    margin-bottom: 60px;
  }
  .u-mb-65-mobile {
    margin-bottom: 65px;
  }
  .u-mb-70-mobile {
    margin-bottom: 70px;
  }
  .u-mb-75-mobile {
    margin-bottom: 75px;
  }
  .u-mb-80-mobile {
    margin-bottom: 80px;
  }
  .u-mb-85-mobile {
    margin-bottom: 85px;
  }
  .u-mb-90-mobile {
    margin-bottom: 90px;
  }
  .u-mb-95-mobile {
    margin-bottom: 95px;
  }
  .u-mb-100-mobile {
    margin-bottom: 100px;
  }
  .u-mb-105-mobile {
    margin-bottom: 105px;
  }
  .u-mb-110-mobile {
    margin-bottom: 110px;
  }
  .u-mb-115-mobile {
    margin-bottom: 115px;
  }
  .u-mb-120-mobile {
    margin-bottom: 120px;
  }
  .u-mb-125-mobile {
    margin-bottom: 125px;
  }
  .u-mb-130-mobile {
    margin-bottom: 130px;
  }
  .u-mb-135-mobile {
    margin-bottom: 135px;
  }
  .u-mb-140-mobile {
    margin-bottom: 140px;
  }
  .u-mb-145-mobile {
    margin-bottom: 145px;
  }
  .u-mb-150-mobile {
    margin-bottom: 150px;
  }
}

.u-pt-0 {
  padding-top: 0;
}

.u-pt-5 {
  padding-top: 5px;
}

.u-pt-10 {
  padding-top: 10px;
}

.u-pt-15 {
  padding-top: 15px;
}

.u-pt-20 {
  padding-top: 20px;
}

.u-pt-25 {
  padding-top: 25px;
}

.u-pt-30 {
  padding-top: 30px;
}

.u-pt-35 {
  padding-top: 35px;
}

.u-pt-40 {
  padding-top: 40px;
}

.u-pt-45 {
  padding-top: 45px;
}

.u-pt-50 {
  padding-top: 50px;
}

.u-pt-55 {
  padding-top: 55px;
}

.u-pt-60 {
  padding-top: 60px;
}

.u-pt-65 {
  padding-top: 65px;
}

.u-pt-70 {
  padding-top: 70px;
}

.u-pt-75 {
  padding-top: 75px;
}

.u-pt-80 {
  padding-top: 80px;
}

.u-pt-85 {
  padding-top: 85px;
}

.u-pt-90 {
  padding-top: 90px;
}

.u-pt-95 {
  padding-top: 95px;
}

.u-pt-100 {
  padding-top: 100px;
}

.u-pt-105 {
  padding-top: 105px;
}

.u-pt-110 {
  padding-top: 110px;
}

.u-pt-115 {
  padding-top: 115px;
}

.u-pt-120 {
  padding-top: 120px;
}

.u-pt-125 {
  padding-top: 125px;
}

.u-pt-130 {
  padding-top: 130px;
}

.u-pt-135 {
  padding-top: 135px;
}

.u-pt-140 {
  padding-top: 140px;
}

.u-pt-145 {
  padding-top: 145px;
}

.u-pt-150 {
  padding-top: 150px;
}

.u-pb-0 {
  padding-bottom: 0;
}

.u-pb-5 {
  padding-bottom: 5px;
}

.u-pb-10 {
  padding-bottom: 10px;
}

.u-pb-15 {
  padding-bottom: 15px;
}

.u-pb-20 {
  padding-bottom: 20px;
}

.u-pb-25 {
  padding-bottom: 25px;
}

.u-pb-30 {
  padding-bottom: 30px;
}

.u-pb-35 {
  padding-bottom: 35px;
}

.u-pb-40 {
  padding-bottom: 40px;
}

.u-pb-45 {
  padding-bottom: 45px;
}

.u-pb-50 {
  padding-bottom: 50px;
}

.u-pb-55 {
  padding-bottom: 55px;
}

.u-pb-60 {
  padding-bottom: 60px;
}

.u-pb-65 {
  padding-bottom: 65px;
}

.u-pb-70 {
  padding-bottom: 70px;
}

.u-pb-75 {
  padding-bottom: 75px;
}

.u-pb-80 {
  padding-bottom: 80px;
}

.u-pb-85 {
  padding-bottom: 85px;
}

.u-pb-90 {
  padding-bottom: 90px;
}

.u-pb-95 {
  padding-bottom: 95px;
}

.u-pb-100 {
  padding-bottom: 100px;
}

.u-pb-105 {
  padding-bottom: 105px;
}

.u-pb-110 {
  padding-bottom: 110px;
}

.u-pb-115 {
  padding-bottom: 115px;
}

.u-pb-120 {
  padding-bottom: 120px;
}

.u-pb-125 {
  padding-bottom: 125px;
}

.u-pb-130 {
  padding-bottom: 130px;
}

.u-pb-135 {
  padding-bottom: 135px;
}

.u-pb-140 {
  padding-bottom: 140px;
}

.u-pb-145 {
  padding-bottom: 145px;
}

.u-pb-150 {
  padding-bottom: 150px;
}

@media screen and (max-width:599px) {
  .u-pt-0-mobile {
    padding-top: 0;
  }
  .u-pt-5-mobile {
    padding-top: 5px;
  }
  .u-pt-10-mobile {
    padding-top: 10px;
  }
  .u-pt-15-mobile {
    padding-top: 15px;
  }
  .u-pt-20-mobile {
    padding-top: 20px;
  }
  .u-pt-25-mobile {
    padding-top: 25px;
  }
  .u-pt-30-mobile {
    padding-top: 30px;
  }
  .u-pt-35-mobile {
    padding-top: 35px;
  }
  .u-pt-40-mobile {
    padding-top: 40px;
  }
  .u-pt-45-mobile {
    padding-top: 45px;
  }
  .u-pt-50-mobile {
    padding-top: 50px;
  }
  .u-pt-55-mobile {
    padding-top: 55px;
  }
  .u-pt-60-mobile {
    padding-top: 60px;
  }
  .u-pt-65-mobile {
    padding-top: 65px;
  }
  .u-pt-70-mobile {
    padding-top: 70px;
  }
  .u-pt-75-mobile {
    padding-top: 75px;
  }
  .u-pt-80-mobile {
    padding-top: 80px;
  }
  .u-pt-85-mobile {
    padding-top: 85px;
  }
  .u-pt-90-mobile {
    padding-top: 90px;
  }
  .u-pt-95-mobile {
    padding-top: 95px;
  }
  .u-pt-100-mobile {
    padding-top: 100px;
  }
  .u-pt-105-mobile {
    padding-top: 105px;
  }
  .u-pt-110-mobile {
    padding-top: 110px;
  }
  .u-pt-115-mobile {
    padding-top: 115px;
  }
  .u-pt-120-mobile {
    padding-top: 120px;
  }
  .u-pt-125-mobile {
    padding-top: 125px;
  }
  .u-pt-130-mobile {
    padding-top: 130px;
  }
  .u-pt-135-mobile {
    padding-top: 135px;
  }
  .u-pt-140-mobile {
    padding-top: 140px;
  }
  .u-pt-145-mobile {
    padding-top: 145px;
  }
  .u-pt-150-mobile {
    padding-top: 150px;
  }
  .u-pb-0-mobile {
    padding-bottom: 0;
  }
  .u-pb-5-mobile {
    padding-bottom: 5px;
  }
  .u-pb-10-mobile {
    padding-bottom: 10px;
  }
  .u-pb-15-mobile {
    padding-bottom: 15px;
  }
  .u-pb-20-mobile {
    padding-bottom: 20px;
  }
  .u-pb-25-mobile {
    padding-bottom: 25px;
  }
  .u-pb-30-mobile {
    padding-bottom: 30px;
  }
  .u-pb-35-mobile {
    padding-bottom: 35px;
  }
  .u-pb-40-mobile {
    padding-bottom: 40px;
  }
  .u-pb-45-mobile {
    padding-bottom: 45px;
  }
  .u-pb-50-mobile {
    padding-bottom: 50px;
  }
  .u-pb-55-mobile {
    padding-bottom: 55px;
  }
  .u-pb-60-mobile {
    padding-bottom: 60px;
  }
  .u-pb-65-mobile {
    padding-bottom: 65px;
  }
  .u-pb-70-mobile {
    padding-bottom: 70px;
  }
  .u-pb-75-mobile {
    padding-bottom: 75px;
  }
  .u-pb-80-mobile {
    padding-bottom: 80px;
  }
  .u-pb-85-mobile {
    padding-bottom: 85px;
  }
  .u-pb-90-mobile {
    padding-bottom: 90px;
  }
  .u-pb-95-mobile {
    padding-bottom: 95px;
  }
  .u-pb-100-mobile {
    padding-bottom: 100px;
  }
  .u-pb-105-mobile {
    padding-bottom: 105px;
  }
  .u-pb-110-mobile {
    padding-bottom: 110px;
  }
  .u-pb-115-mobile {
    padding-bottom: 115px;
  }
  .u-pb-120-mobile {
    padding-bottom: 120px;
  }
  .u-pb-125-mobile {
    padding-bottom: 125px;
  }
  .u-pb-130-mobile {
    padding-bottom: 130px;
  }
  .u-pb-135-mobile {
    padding-bottom: 135px;
  }
  .u-pb-140-mobile {
    padding-bottom: 140px;
  }
  .u-pb-145-mobile {
    padding-bottom: 145px;
  }
  .u-pb-150-mobile {
    padding-bottom: 150px;
  }
}

.cloud-founding {
  width: 50%;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width:599px) {
  .cloud-founding {
    width: 100%;
  }
}

.u-font-gradient {
  background: linear-gradient(90deg, #e73c7e, #fa7268);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.is-round {
  border-radius: 22.5px;
  overflow: hidden;
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  -webkit-transform: translateZ(0);
  -moz-transform: translateZ(0);
}

@media screen and (min-width:600px) {
  .is-round-except-mobile {
    border-radius: 22.5px;
    overflow: hidden;
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    -webkit-transform: translateZ(0);
    -moz-transform: translateZ(0);
  }
}

@media screen and (max-width:599px) {
  .is-round-mobile {
    border-radius: 22.5px;
    overflow: hidden;
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    -webkit-transform: translateZ(0);
    -moz-transform: translateZ(0);
  }
}

.is-stripe {
  background-image: linear-gradient(-45deg, hsla(0, 0%, 100%, .9) 25%, #fff 0, #fff 50%, hsla(0, 0%, 100%, .9) 0, hsla(0, 0%, 100%, .9) 75%, #fff 0, #fff);
  background-size: 15px 15px;
  animation: a 15s linear infinite;
}

.is-primary {
  background: #fa7268;
  color: #fff;
}

.is-transparent {
  background: rgba(255, 252, 255, .75);
}

.is-pink {
  background-color: #e899dc;
  background-image: linear-gradient(315deg, #e899dc, #d387ab 74%);
}

.is-white {
  background-color: #fff;
  color: #252525;
}

.js-accordion-body {
  padding-top: 0;
  padding-bottom: 0;
}

.js-accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: all .5s ease;
}