@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Zen+Maru+Gothic:wght@400;500;700&display=swap");
/*! destyle.css v1.0.13 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model
   ========================================================================== */
* {
  box-sizing: border-box;
}

::before,
::after {
  box-sizing: inherit;
}

/* Document
     ========================================================================== */
/**
   * 1. Correct the line height in all browsers.
   * 2. Prevent adjustments of font size after orientation changes in iOS.
   * 3. Remove gray overlay on links for iOS.
   */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  -webkit-tap-highlight-color: transparent;
  /* 3*/
}

/* Sections
     ========================================================================== */
/**
   * Remove the margin in all browsers.
   */
body {
  margin: 0;
}

/**
   * Render the `main` element consistently in IE.
   */
main {
  display: block;
}

/* Vertical rhythm
     ========================================================================== */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings
     ========================================================================== */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0;
}

/* Lists (enumeration)
     ========================================================================== */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Lists (definition)
     ========================================================================== */
dt {
  font-weight: 400;
}

dd {
  margin-left: 0;
}

/* Grouping content
     ========================================================================== */
/**
   * 1. Add the correct box sizing in Firefox.
   * 2. Show the overflow in Edge and IE.
   */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
  border: 0;
  border-top: 1px solid;
  margin: 0;
  clear: both;
  color: inherit;
}

/**
   * 1. Correct the inheritance and scaling of font size in all browsers.
   * 2. Correct the odd `em` font sizing in all browsers.
   */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: inherit;
  /* 2 */
}

address {
  font-style: inherit;
}

/* Text-level semantics
     ========================================================================== */
/**
   * Remove the gray background on active links in IE 10.
   */
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

/**
   * 1. Remove the bottom border in Chrome 57-
   * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
   */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
  /* 2 */
}

/**
   * Add the correct font weight in Chrome, Edge, and Safari.
   */
b,
strong {
  font-weight: bolder;
}

/**
   * 1. Correct the inheritance and scaling of font size in all browsers.
   * 2. Correct the odd `em` font sizing in all browsers.
   */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: inherit;
  /* 2 */
}

/**
   * Add the correct font size in all browsers.
   */
small {
  font-size: 80%;
}

/**
   * Prevent `sub` and `sup` elements from affecting the line height in
   * all browsers.
   */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
     ========================================================================== */
/**
   * Remove the border on images inside links in IE 10.
   */
img {
  border-style: none;
  vertical-align: bottom;
}

embed,
object,
iframe {
  border: 0;
  vertical-align: bottom;
}

/* Forms
     ========================================================================== */
/**
   * Reset form fields to make them styleable
   * 1. Reset radio and checkbox to preserve their look in iOS.
   */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}

[type=checkbox] {
  /* 1 */
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
       appearance: checkbox;
}

[type=radio] {
  /* 1 */
  -webkit-appearance: radio;
  -moz-appearance: radio;
       appearance: radio;
}

/**
   * Show the overflow in IE.
   * 1. Show the overflow in Edge.
   */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
   * Remove the inheritance of text transform in Edge, Firefox, and IE.
   * 1. Remove the inheritance of text transform in Firefox.
   */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
   * Correct the inability to style clickable types in iOS and Safari.
   */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

button[disabled],
[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled] {
  cursor: default;
}

/**
   * Remove the inner border and padding in Firefox.
   */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
   * Restore the focus styles unset by the previous rule.
   */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
   * Remove padding
   */
option {
  padding: 0;
}

/**
   * Reset to invisible
   */
fieldset {
  margin: 0;
  padding: 0;
  border: 0;
  min-width: 0;
}

/**
   * 1. Correct the text wrapping in Edge and IE.
   * 2. Correct the color inheritance from `fieldset` elements in IE.
   * 3. Remove the padding so developers are not caught out when they zero out
   *    `fieldset` elements in all browsers.
   */
legend {
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
   * Add the correct vertical alignment in Chrome, Firefox, and Opera.
   */
progress {
  vertical-align: baseline;
}

/**
   * Remove the default vertical scrollbar in IE 10+.
   */
textarea {
  overflow: auto;
}

/**
   * 1. Remove the padding in IE 10.
   */
[type=checkbox],
[type=radio] {
  padding: 0;
  /* 1 */
}

/**
   * Correct the cursor style of increment and decrement buttons in Chrome.
   */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
   * 1. Correct the outline style in Safari.
   */
[type=search] {
  outline-offset: -2px;
  /* 1 */
}

/**
   * Remove the inner padding in Chrome and Safari on macOS.
   */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
   * 1. Correct the inability to style clickable types in iOS and Safari.
   * 2. Change font properties to `inherit` in Safari.
   */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/**
   * Clickable labels
   */
label[for] {
  cursor: pointer;
}

/* Interactive
     ========================================================================== */
/*
   * Add the correct display in Edge, IE 10+, and Firefox.
   */
details {
  display: block;
}

/*
   * Add the correct display in all browsers.
   */
summary {
  display: list-item;
}

/* Table
     ========================================================================== */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

/* Misc
     ========================================================================== */
/**
   * Add the correct display in IE 10+.
   */
template {
  display: none;
}

/**
   * Add the correct display in IE 10.
   */
[hidden] {
  display: none;
}

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
  scroll-padding-top: 140px;
}
@media screen and (max-width: 767px) {
  html {
    scroll-padding-top: 100px;
  }
}

body {
  position: relative;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  line-height: 1.5;
  color: #2E2C1A;
  font-weight: 400;
  background-color: #ffffff;
  overflow-x: hidden;
}

a {
  color: #2E2C1A;
}

@media screen and (max-width: 767px) {
  button:hover {
    opacity: 1;
  }
}

img {
  width: 100%;
  height: auto;
  display: block;
}

.l-inner {
  max-width: 1120px;
  margin: auto;
  padding: 0 50px;
  box-sizing: content-box;
}
@media screen and (max-width: 767px) {
  .l-inner {
    padding: 0 20px;
  }
}
.l-inner--s {
  max-width: 864px;
  margin: auto;
  padding: 0 50px;
  box-sizing: content-box;
}
@media screen and (max-width: 767px) {
  .l-inner--s {
    padding: 0 20px;
  }
}
.l-inner--m {
  max-width: 1038px;
  margin: auto;
  padding: 0 50px;
  box-sizing: content-box;
}
@media screen and (max-width: 767px) {
  .l-inner--m {
    padding: 0 20px;
  }
}
.l-inner--l {
  max-width: 1072px;
  margin: auto;
  padding: 0 50px;
  box-sizing: content-box;
}
@media screen and (max-width: 767px) {
  .l-inner--l {
    padding: 0 20px;
  }
}

.l-icon-inner {
  max-width: 1100px;
  margin: auto;
  position: relative;
}

/* _footer.scss */
.l-footer {
  background: #eb656b;
  background: linear-gradient(90deg, #eb656b 0%, #ffec5a 100%);
  padding: 30px 0;
}
.l-footer .copyright {
  color: #FFF;
  display: block;
  text-align: center;
  font-size: clamp(1.2rem, 2vw, 1.4rem);
}
.l-footer .copyright-link a {
  text-decoration: underline;
  color: #FFF;
  transition: 0.5s;
}
.l-footer .copyright-link a:hover {
  opacity: 0.7;
  transition: 0.25s;
}

/* _header.scss */
.l-header {
  position: relative;
  display: flex;
  justify-content: center;
  z-index: 99;
}
.l-header__logo {
  width: calc(100vw * 510 / 1920);
  position: absolute;
  top: 20px;
  left: clamp(10px, 2vw, 40px);
  z-index: 1;
  min-width: 180px;
}
.l-header-nav {
  width: 100%;
}
.l-header-nav__main {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px 0;
}
.l-header-nav__item {
  margin-right: clamp(10px, 2vw, 40px);
  font-size: clamp(1.4rem, 1.1vw, 1.6rem);
  font-weight: 700;
}
.l-header-nav__item a {
  transition: 0.5s;
}
.l-header-nav__item a:hover {
  color: #EB656B;
  transition: 0.25s;
}
.l-header-nav__item__img {
  margin-right: clamp(10px, 1vw, 24px);
}
.l-header-nav__item__img img {
  max-width: 200px;
  transition: 0.5s;
}
.l-header-nav__item__img img:hover {
  opacity: 0.5;
  transition: 0.25s;
}
.l-header-nav__item__img:last-child {
  margin-right: 40px;
}
@media screen and (max-width: 1300px) {
  .l-header-nav__main {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0;
    margin-top: 80px;
  }
  .l-header-nav__main:before {
    content: "";
    background-image: url(../img/header-noufescan.svg);
    background-size: cover;
    background-repeat: no-repeat;
    width: 64px;
    height: 62px;
    margin-bottom: 16px;
  }
  .l-header-nav__item {
    padding: 16px 24px;
    margin-right: clamp(10px, 2vw, 40px);
    font-size: clamp(1.4rem, 1.1vw, 1.6rem);
    font-weight: 700;
    border-bottom: 1px solid #e5e4dc;
    width: 100%;
    text-align: center;
  }
}

@media screen and (max-width: 1300px) {
  .l-header-nav--wrapper {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 20;
    width: 100%;
    height: 100vh;
    background-color: #ffffff;
    flex-direction: column;
    align-items: center;
    padding: 25px 20px 0;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.5s, visibility 0.5s;
  }
  .is-open .l-header-nav--wrapper {
    opacity: 1;
    visibility: visible;
  }
}
@media screen and (max-width: 1300px) {
  .l-header-nav--inner {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 20;
    width: 75%;
    max-width: 400px;
    height: 100vh;
    background-color: #FFFCDE;
    flex-direction: column;
    align-items: center;
    padding: 0px 20px 0;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.5s, visibility 0.5s;
    overflow-y: auto;
  }
  .is-open .l-header-nav--inner {
    opacity: 1;
    visibility: visible;
  }
}

.l-header-ham {
  display: none;
  position: fixed;
  z-index: 25;
  top: 0;
  right: 0;
}
.l-header-ham__btn {
  width: 56px;
  height: 64px;
  border-radius: 0 0 0 10px;
  position: relative;
  background-color: #FFFCDE;
}
.l-header-ham__btn::after {
  content: "Menu";
  position: absolute;
  top: 33px;
  left: 50%;
  transform: translateX(-50%);
  color: #EB656B;
  font-size: 1.2rem;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
}
.l-header-ham__btn span {
  display: block;
  width: 24px;
  height: 4px;
  border-radius: 2px;
  position: absolute;
  left: 50%;
  transform: translate(-50%, 0);
  background-color: #EB656B;
  transition: opacity 0.3s, top 0.5s, transform 0.5s;
}
.l-header-ham__btn span:nth-of-type(1) {
  top: 13px;
}
.l-header-ham__btn span:nth-of-type(2) {
  top: 21px;
  opacity: 1;
}
.l-header-ham__btn span:nth-of-type(3) {
  top: 29px;
}
.is-open .l-header-ham__btn:after {
  content: "Close";
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
}
.is-open .l-header-ham__btn span:nth-of-type(1) {
  transform: translateX(-50%) rotate(45deg);
  top: 20px;
  left: 50%;
}
.is-open .l-header-ham__btn span:nth-of-type(2) {
  opacity: 0;
}
.is-open .l-header-ham__btn span:nth-of-type(3) {
  transform: translateX(-50%) rotate(-45deg);
  top: 20px;
  left: 50%;
}
@media screen and (max-width: 1300px) {
  .l-header-ham {
    display: block;
    visibility: hidden;
    opacity: 0;
  }
}

.l-header__nav-sp {
  display: none;
}

@media screen and (max-width: 1300px) {
  .l-header .nav-sp {
    display: none;
  }
  .l-header .l-header__nav-sp {
    display: block;
  }
  .l-header .l-header__nav-sp ul {
    display: flex;
  }
  .l-header .l-header__nav-sp ul li {
    margin-top: 18px;
    margin-right: 10px;
    margin-bottom: 7px;
    width: clamp(80px, 2vw, 198px);
  }
  .l-header .l-header__nav-sp ul li:last-child {
    margin-right: 20px;
  }
}
.l-main {
  overflow-x: hidden;
}
.c-breadcrumb {
  width: 100%;
  height: 60px;
  padding: 0 52px;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .c-breadcrumb {
    padding: 0 27px;
    height: 30px;
  }
}
.c-breadcrumb__list {
  display: flex;
}
.c-breadcrumb__item {
  display: flex;
  align-items: center;
  font-weight: 400px;
}
.c-breadcrumb__item + .c-breadcrumb__item {
  margin-left: 4px;
}
.c-breadcrumb__item + .c-breadcrumb__item::before {
  content: "";
  display: block;
  width: 15px;
  height: 10px;
  background-image: url(../img/common/icon-arrow.svg);
  background-size: 11px auto;
  background-position: center left;
  background-repeat: no-repeat;
  flex-shrink: 0;
}

.c-2columns {
  flex-wrap: wrap;
}
.c-2columns > * {
  width: 50%;
}

.c-hideText {
  position: relative;
}
.c-hideText__txt {
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  width: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
}

@media screen and (max-width: 767px) {
  .c-hideText--sp {
    position: relative;
  }
  .c-hideText--sp__txt {
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    width: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
  }
}

[data-scroll-in=fade-blur] {
  opacity: 0;
  filter: blur(5px);
  transition: opacity 0.3s, filter 0.3s;
}
[data-scroll-in=fade-blur].is-shown {
  opacity: 1;
  filter: blur(0);
}

[data-scroll-in=fade] {
  opacity: 0;
  transition: opacity 0.3s;
}
[data-scroll-in=fade].is-shown {
  opacity: 1;
}

[data-scroll-in=clip-right] {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 0.4s;
}
[data-scroll-in=clip-right].is-shown {
  clip-path: inset(0 0 0 0);
}

[data-scroll-in=clip-down] {
  clip-path: inset(0 0 100% 0);
  transition: clip-path 0.4s;
}
[data-scroll-in=clip-down].is-shown {
  clip-path: inset(0 0 0 0);
}

.c-swing-img {
  max-width: 300px;
  position: absolute;
  transform: rotate(-10deg);
  animation: swing 4s ease-in-out infinite alternate;
  z-index: 20;
}
@media screen and (max-width: 1399px) {
  .c-swing-img {
    max-width: 210px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img {
    max-width: 160px;
  }
}
@media screen and (max-width: 639px) {
  .c-swing-img {
    max-width: 88px;
  }
}
.c-swing-img.--img_01 {
  animation-delay: 1s;
  animation-duration: 4.2s;
}
.c-swing-img.--img_02 {
  animation-delay: 2s;
  animation-duration: 4.4s;
}
.c-swing-img.--img_03 {
  animation-delay: 0s;
  animation-duration: 4.6s;
}
.c-swing-img.--img_04 {
  animation-delay: 1s;
  animation-duration: 4.8s;
}
.c-swing-img.--img_05 {
  animation-delay: 2s;
  animation-duration: 4s;
}
.c-swing-img.--img_06 {
  animation-delay: 0s;
  animation-duration: 4.2s;
}
.c-swing-img.--img_07 {
  animation-delay: 1s;
  animation-duration: 4.4s;
}
.c-swing-img.--img_08 {
  animation-delay: 2s;
  animation-duration: 4.6s;
}
.c-swing-img.--img_09 {
  animation-delay: 0s;
  animation-duration: 4.8s;
}
.c-swing-img.--img_10 {
  animation-delay: 1s;
  animation-duration: 4s;
}
.c-swing-img.--img_11 {
  animation-delay: 2s;
  animation-duration: 4.2s;
}
.c-swing-img.--img_12 {
  animation-delay: 0s;
  animation-duration: 4.4s;
}
.c-swing-img.--img_13 {
  animation-delay: 1s;
  animation-duration: 4.6s;
}
.c-swing-img.--img_14 {
  animation-delay: 2s;
  animation-duration: 4.8s;
}
.c-swing-img.--img_15 {
  animation-delay: 0s;
  animation-duration: 4s;
}
.c-swing-img.--img_16 {
  animation-delay: 1s;
  animation-duration: 4.2s;
}
.c-swing-img.--img_17 {
  animation-delay: 2s;
  animation-duration: 4.4s;
}
.c-swing-img.--img_18 {
  animation-delay: 0s;
  animation-duration: 4.6s;
}
.c-swing-img.--img_19 {
  animation-delay: 1s;
  animation-duration: 4.8s;
}
.c-swing-img.--img_20 {
  animation-delay: 2s;
  animation-duration: 4s;
}
.c-swing-img.--img_21 {
  animation-delay: 0s;
  animation-duration: 4.2s;
}
.c-swing-img.--img_22 {
  animation-delay: 1s;
  animation-duration: 4.4s;
}
.c-swing-img.--img_23 {
  animation-delay: 2s;
  animation-duration: 4.6s;
}
.c-swing-img.--img_24 {
  animation-delay: 0s;
  animation-duration: 4.8s;
}
.c-swing-img.--img_25 {
  animation-delay: 1s;
  animation-duration: 4s;
}
.c-swing-img.--img_26 {
  animation-delay: 2s;
  animation-duration: 4.2s;
}
.c-swing-img.--img_27 {
  animation-delay: 0s;
  animation-duration: 4.4s;
}
.c-swing-img.--img_28 {
  animation-delay: 1s;
  animation-duration: 4.6s;
}
.c-swing-img.--img_29 {
  animation-delay: 2s;
  animation-duration: 4.8s;
}
.c-swing-img.--img_30 {
  animation-delay: 0s;
  animation-duration: 4s;
}
.c-swing-img.--img_31 {
  animation-delay: 1s;
  animation-duration: 4.2s;
}
.c-swing-img.--img_32 {
  animation-delay: 2s;
  animation-duration: 4.4s;
}
.c-swing-img.--img_33 {
  animation-delay: 0s;
  animation-duration: 4.6s;
}
.c-swing-img.--img_34 {
  animation-delay: 1s;
  animation-duration: 4.8s;
}
.c-swing-img.--img_35 {
  animation-delay: 2s;
  animation-duration: 4s;
}
.c-swing-img.--img_36 {
  animation-delay: 0s;
  animation-duration: 4.2s;
}
.c-swing-img.--img_37 {
  animation-delay: 1s;
  animation-duration: 4.4s;
}
.c-swing-img.--img_38 {
  animation-delay: 2s;
  animation-duration: 4.6s;
}
.c-swing-img.--img_39 {
  animation-delay: 0s;
  animation-duration: 4.8s;
}
.c-swing-img.--img_40 {
  animation-delay: 1s;
  animation-duration: 4s;
}
.c-swing-img.--img_41 {
  animation-delay: 2s;
  animation-duration: 4.2s;
}
.c-swing-img.--img_42 {
  animation-delay: 0s;
  animation-duration: 4.4s;
}
.c-swing-img.--img_43 {
  animation-delay: 1s;
  animation-duration: 4.6s;
}
.c-swing-img.--img_44 {
  animation-delay: 2s;
  animation-duration: 4.8s;
}
.c-swing-img.--img_45 {
  animation-delay: 0s;
  animation-duration: 4s;
}
.c-swing-img.--img_46 {
  animation-delay: 1s;
  animation-duration: 4.2s;
}
.c-swing-img.--img_47 {
  animation-delay: 2s;
  animation-duration: 4.4s;
}
.c-swing-img.--img_48 {
  animation-delay: 0s;
  animation-duration: 4.6s;
}
.c-swing-img.--img_49 {
  animation-delay: 1s;
  animation-duration: 4.8s;
}
.c-swing-img.--img_50 {
  animation-delay: 2s;
  animation-duration: 4s;
}
@keyframes swing {
  0% {
    transform: rotate(-10deg);
  }
  100% {
    transform: rotate(10deg);
  }
}
.c-swing-img.--img_01 {
  left: -247px;
  top: 0;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_01 {
    left: -110px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_01 {
    left: -30px;
  }
}
@media screen and (max-width: 639px) {
  .c-swing-img.--img_01 {
    left: -16px;
    top: -70px;
  }
}
.c-swing-img.--img_02 {
  right: -127px;
  top: -208px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_02 {
    right: -127px;
    display: none;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_02 {
    right: -107px;
  }
}
.c-swing-img.--img_03 {
  /* left: -247px; */
  top: -208px;
  right: 0;
  scale: -1 1;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_03 {
    /* left: -110px; */
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_03 {
    /* left: -30px; */
  }
}
@media screen and (max-width: 639px) {
  .c-swing-img.--img_03 {
    /* left: 0; */
    /* top: -108px; */
    top: 0;
  }
}
.c-swing-img.--img_04 {
  /* right: -247px; */
  right: 0;
  bottom: -208px;
  translate: 50% 0;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_04 {
    /* right: -110px; */
    translate: 0 0;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_04 {
    /* right: -30px; */
  }
}
@media screen and (max-width: 639px) {
  .c-swing-img.--img_04 {
    /* right: 16px; */
    /* bottom: -104px; */
    bottom: -164px;
  }
}
.c-swing-img.--img_05 {
  left: -247px;
  top: -208px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_05 {
    left: -110px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_05 {
    left: -30px;
  }
}
@media screen and (max-width: 639px) {
  .c-swing-img.--img_05 {
    left: -5px;
    top: -160px;
  }
}
.c-swing-img.--img_06 {
  right: -247px;
  top: -208px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_06 {
    right: -110px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_06 {
    right: -30px;
    top: -108px;
  }
}
@media screen and (max-width: 639px) {
  .c-swing-img.--img_06 {
    right: -16px;
    top: -80px;
  }
}
.c-swing-img.--img_07 {
  right: -207px;
  top: -208px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_07 {
    right: -107px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_07 {
    right: -107px;
    top: -108px;
  }
}
.c-swing-img.--img_08 {
  left: -137px;
  top: -208px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_08 {
    left: -107px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_08 {
    left: -27px;
    top: -108px;
  }
}
@media screen and (max-width: 639px) {
  .swingDir .c-swing-img {
    width: 88px;
  }
}
.swingDir.even .c-swing-img {
  right: -247px;
}
@media screen and (max-width: 1399px) {
  .swingDir.even .c-swing-img {
    right: -110px;
  }
}
@media screen and (max-width: 1199px) {
  .swingDir.even .c-swing-img {
    right: -30px;
    top: -108px;
  }
}
@media screen and (max-width: 639px) {
  .swingDir.even .c-swing-img {
    right: -32px;
    top: -48px;
  }
}
.swingDir.odd .c-swing-img {
  left: -247px;
}
@media screen and (max-width: 1399px) {
  .swingDir.odd .c-swing-img {
    left: -110px;
  }
}
@media screen and (max-width: 1199px) {
  .swingDir.odd .c-swing-img {
    left: -30px;
    translate: 0 -12%;
  }
}
@media screen and (max-width: 639px) {
  .swingDir.odd .c-swing-img {
    left: -32px;
    top: -64px;
    translate: 0 0;
  }
}
.c-swing-img.--img_09 {
  top: -208px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_09 {
    top: -208px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_09 {
    top: -108px;
  }
}
.c-swing-img.--img_10 {
  top: -100px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_10 {
    top: -100px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_10 {
    top: -50px;
  }
}
.c-swing-img.--img_11 {
  top: -130px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_11 {
    top: -130px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_11 {
    top: -70px;
  }
}
.c-swing-img.--img_12 {
  top: -130px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_12 {
    top: -130px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_12 {
    top: -70px;
  }
}
.c-swing-img.--img_13 {
  top: -100px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_13 {
    top: -100px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_13 {
    top: -50px;
  }
}
.c-swing-img.--img_14 {
  top: -100px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_14 {
    top: -100px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_14 {
    top: -50px;
  }
}
.c-swing-img.--img_15 {
  top: -180px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_15 {
    top: -180px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_15 {
    top: -90px;
  }
}
.c-swing-img.--img_16 {
  top: -120px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_16 {
    top: -120px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_16 {
    top: -60px;
  }
}
.c-swing-img.--img_17 {
  top: -120px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_17 {
    top: -120px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_17 {
    top: -60px;
  }
}
.c-swing-img.--img_18 {
  top: -130px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_18 {
    top: -130px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_18 {
    top: -70px;
  }
}
.c-swing-img.--img_19 {
  left: -247px;
  top: -208px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_19 {
    left: -110px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_19 {
    left: -30px;
    top: -108px;
  }
}
@media screen and (max-width: 639px) {
  .c-swing-img.--img_19 {
    left: -16px;
    top: -108px;
  }
}
.c-swing-img.--img_20 {
  right: -247px;
  top: -208px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_20 {
    right: -110px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_20 {
    right: -30px;
    top: -108px;
  }
}
@media screen and (max-width: 639px) {
  .c-swing-img.--img_20 {
    right: -16px;
    top: -108px;
  }
}
.c-swing-img.--img_21 {
  right: -247px;
  top: -208px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_21 {
    right: -110px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_21 {
    right: -30px;
    top: -108px;
  }
}
@media screen and (max-width: 639px) {
  .c-swing-img.--img_21 {
    right: -16px;
    top: -108px;
  }
}
.c-swing-img.--img_22 {
  right: -127px;
  top: -78px;
}
@media screen and (max-width: 1399px) {
  .c-swing-img.--img_22 {
    right: -107px;
  }
}
@media screen and (max-width: 1199px) {
  .c-swing-img.--img_22 {
    right: -17px;
    top: -38px;
  }
}
@media screen and (max-width: 639px) {
  .c-swing-img.--img_22 {
    right: -16px;
    top: -24px;
  }
}

.h2-style {
  text-align: center;
  line-height: 1.3;
  padding-bottom: clamp(24px, 4vw, 60px);
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
}
.h2-style .\--en {
  display: block;
  font-size: clamp(4rem, 5.4vw, 5rem);
}
.h2-style .\--ja {
  display: inline-block;
  font-size: clamp(1.6rem, 2.7vw, 1.8rem);
  font-weight: 700;
  color: #2E2C1A;
  clip-path: inset(0 100% 0 0);
}
@media screen and (max-width: 979px) {
  .h2-style .\--en {
    font-size: clamp(3rem, 5.4vw, 4rem);
  }
  .h2-style .\--ja {
    font-size: clamp(1.4rem, 2.7vw, 1.6rem);
  }
}

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

.c-align-indent {
  padding-left: 1em;
  text-indent: -1em;
}

.p-concept{
  padding-block: clamp(40px, 10vw, 100px);
  background-color: #fff;
}

.p-concept-wrapper{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2em;
  max-width: 1080px;
  margin-inline: auto;
}
@media screen and (max-width: 1079px) {
  .p-concept-wrapper{
    grid-template-columns: 1fr;
    gap: 2em;
    padding-inline: 10px;
  }
}

.p-volunteer{
  display: grid;
  place-items: center;
}
.p-volunteer a{
  display: grid;
  place-items: center;
  max-width: 1000px;
  width: calc(100% - 20px - 20px);
  margin-block: clamp(6.25rem, 3.963rem + 9.76vw, 12.5rem);
  margin-inline: 20px;
  padding: 2em 4em;
  border: 4px dotted #EB656B;
  border-radius: 8px;
  background-color: #fff;
  color: #EB656B;
  font-size: clamp(1.2rem, 0.793rem + 1.95vw, 2.5rem);
  font-weight: 700;
  letter-spacing: .05em;
  line-height: 1.4;
  text-align: center;
  position: relative;
  transition: 
    border .24s ease-in-out,
    color .24s ease-in-out;
}
@media screen and (max-width: 767px) {
  .p-volunteer a{
    padding: 40px 20px;
  }
}
.p-volunteer a span{
  font-size: clamp(1.25rem, 0.976rem + 1.17vw, 2rem);
}
.p-volunteer a:hover{
  border: 4px dotted #F5C62A;
  color: #F5C62A;
}
.p-volunteer a .c-swing-img.--img_06, .c-swing-img.--img_07{
  top: inherit;
  right: inherit;
  bottom: inherit;
  left: inherit;
}
.p-volunteer a .c-swing-img.--img_06{
  bottom: 0;
  right: 0;
  translate: 25% 50%;
}
.p-volunteer a .c-swing-img.--img_07{
  top: 0;
  left: 0;
  translate: 0 -50%;
}

.p-about {
  background-color: #fff;
  padding-bottom: clamp(40px, 10vw, 100px);
}
.p-about-wapper {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  max-width: 1375px;
  margin: 0 auto 0;
  padding-top: 50px;
}
@media screen and (max-width: 1079px) {
  .p-about-wapper {
    flex-direction: column;
    margin-left: 0;
    margin-top: 0;
    padding: 0 12px;
    padding-top: 11vw;
  }
}
.p-about-inner01 {
  width: 46%;
  margin-right: 25px;
}
@media screen and (max-width: 1079px) {
  .p-about-inner01 {
    width: 100%;
    margin-right: 0;
    margin-bottom: 3vw;
  }
}
.p-about-inner02 {
  margin-right: -85px;
  position: relative;
  z-index: 1;
  width: 56%;
}
.p-about-inner02:before {
  content: "";
  display: inline-block;
  width: 67vw;
  height: 67vw;
  max-width: 950px;
  max-height: 950px;
  border-radius: 50%;
  background: #FFFCDE;
  position: absolute;
  top: 17%;
  right: -20px;
  z-index: -2;
}
@media screen and (max-width: 1079px) {
  .p-about-inner02 {
    width: 100%;
    margin-right: 0;
  }
  .p-about-inner02:before {
    right: auto;
    left: 50%;
    transform: translate(-50%, 0);
    top: -210px;
    width: 130vw;
    height: calc(100% + 330px);
    max-width: inherit;
    max-height: inherit;
  }
}
.p-about__img {
  opacity: 0;
}
.p-about__noufescanBox {
  position: relative;
  max-width: clamp(80px, 8vw, 108px);
  position: relative;
  z-index: 1;
  margin-bottom: clamp(20px, 2.6vw, 40px);
}
@media screen and (max-width: 1079px) {
  .p-about__noufescanBox {
    max-width: clamp(80px, 12vw, 140px);
    margin: 0 auto clamp(20px, 2.6vw, 40px);
    transform: translate(calc(clamp(240px, 40vw, 420px) / -2.5), 0);
  }
}
.p-about__noufescanBox .about-speech {
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  width: 100vw;
  height: 100vw;
  max-width: clamp(240px, 25vw, 340px);
  max-height: clamp(62px, 8vw, 88px);
  position: absolute;
  top: -32px;
  left: 76px;
  z-index: -1;
  transform-origin: 15% 100%;
}
@media screen and (max-width: 1079px) {
  .p-about__noufescanBox .about-speech {
    max-width: clamp(240px, 40vw, 420px);
    max-height: clamp(62px, 28vw, 118px);
    top: -3.5vw;
    left: 88px;
  }
}
@media screen and (max-width: 979px) {
  .p-about__noufescanBox .about-speech {
    top: -3.5vw;
    left: clamp(70px, 8.5vw, 80px);
  }
}
@media screen and (max-width: 767px) {
  .p-about__noufescanBox .about-speech {
    top: clamp(-25px, 8.5vw, -23px);
    left: clamp(60px, 8.5vw, 70px);
  }
}
.p-about__ttl {
  font-size: clamp(2rem, 3vw, 3rem);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: clamp(24px, 2.6vw, 40px);
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1079px) {
  .p-about__ttl {
    text-align: center;
    line-height: 1.66;
  }
}
.p-about__message {
  font-size: clamp(1.6rem, 2vw, 2rem);
  margin-bottom: clamp(40px, 2.6vw, 80px);
  font-weight: 700;
  position: relative;
  z-index: 2;
}
.p-about__message .br {
  display: none;
}
@media screen and (max-width: 1079px) {
  .p-about__message {
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  .p-about__message .br {
    display: block;
  }
}
.p-about__img-box {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 30px;
}
.p-about__img-box:last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 1079px) {
  .p-about__img-box {
    justify-content: center;
  }
}
.p-about__img-box01 {
  align-items: flex-end;
}
.p-about__img-box02 {
  align-items: flex-start;
  margin-bottom: 0;
}
@media screen and (max-width: 1079px) {
  .p-about__img-box02 {
    margin-bottom: 40px;
  }
}
.p-about__img01 {
  max-width: clamp(90px, 13.5vw, 200px);
  margin-right: 30px;
}
@media screen and (max-width: 1079px) {
  .p-about__img01 {
    max-width: clamp(90px, 20vw, 200px);
  }
}
.p-about__img02 {
  max-width: clamp(187px, 27vw, 400px);
}
@media screen and (max-width: 1079px) {
  .p-about__img02 {
    max-width: clamp(187px, 40vw, 400px);
  }
}
.p-about__img03 {
  max-width: clamp(187px, 27vw, 400px);
  margin-right: 30px;
}
@media screen and (max-width: 1079px) {
  .p-about__img03 {
    max-width: clamp(187px, 40vw, 400px);
  }
}
.p-about__img04 {
  max-width: clamp(139px, 20vw, 300px);
}
@media screen and (max-width: 1079px) {
  .p-about__img04 {
    max-width: clamp(139px, 29.6vw, 300px);
  }
}
.p-about__attention {
  font-size: clamp(2rem, 8vw, 3rem);
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  color: #FF3369;
  display: flex;
}
.p-about__attention:before {
  content: "";
  background-image: url(../img/about-attention-decoration_left.svg);
  display: block;
  background-size: contain;
  background-repeat: no-repeat;
  width: clamp(21px, 3.2vw, 29px);
  height: clamp(18px, 2.9vw, 25px);
}
.p-about__attention:after {
  content: "";
  background-image: url(../img/about-attention-decoration_right.svg);
  display: block;
  background-size: contain;
  background-repeat: no-repeat;
  width: clamp(21px, 3.2vw, 29px);
  height: clamp(18px, 2.9vw, 25px);
}
@media screen and (max-width: 1079px) {
  .p-about__attention {
    justify-content: center;
  }
}
.p-about .btn {
  padding: 10px;
}
.p-about .btn a {
  display: block;
  max-width: 400px;
  background: #eb656b;
  background: linear-gradient(90deg, #eb656b 0%, #ffec5a 100%);
  border-radius: 100px;
  width: 100%;
  padding: clamp(23px, 2vw, 32px) clamp(60px, 2vw, 120px) clamp(23px, 2vw, 32px) clamp(50px, 2vw, 120px);
  font-size: clamp(1.4rem, 2vw, 1.6rem);
  font-family: "Zen Maru Gothic", sans-serif;
  color: #fff;
  font-weight: 700;
  margin: auto;
  margin-top: clamp(30px, 2.5vw, 80px);
  position: relative;
  z-index: 2;
  text-align: center;
  transition: 0.25s;
}
.p-about .btn a:after {
  content: "";
  width: 20px;
  height: 20px;
  background-image: url(../img/btn_icon.svg);
  background-size: contain;
  position: absolute;
  z-index: 2;
  top: 50%;
  transform: translateY(-50%);
  right: 60px;
}
.p-about .btn a:hover {
  transition: 0.25s;
  opacity: 0.5;
}
.p-about-detail {
  position: relative;
  max-width: 800px;
  margin: auto;
  padding: 0 10px;
  margin-top: clamp(60px, 10vw, 120px);
}
.p-about-detail__noufeschan {
  width: clamp(70px, 18vw, 150px);
  position: absolute;
  right: calc((clamp(70px, 18vw, 150px)) * -0.25);
  top: -5vw;
}
@media screen and (max-width: 1079px) {
  .p-about-detail__noufeschan {
    top: -8vw;
    right: 0;
  }
}
.p-about dl {
  border: 4px solid #EB656B;
  font-size: clamp(1.4rem, 1.4vw, 2rem);
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .p-about dl {
    border: 2px solid #EB656B;
  }
}
.p-about__table {
  display: flex;
  justify-content: center;
}
.p-about__table + .p-about__table dt {
  border-top: 2px dashed #fff;
}
.p-about__table + .p-about__table dd {
  border-top: 2px dashed #EB656B;
}
.p-about__table dt {
  background-color: #EB656B;
  color: #fff;
  font-weight: 700;
  padding: clamp(20px, 1.4vw, 27px) clamp(16px, 3.4vw, 55px);
  width: 30%;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}
.p-about__table dt .br {
  display: none;
}
@media screen and (max-width: 767px) {
  .p-about__table dt .br {
    display: block;
  }
}
.p-about__table dd {
  font-weight: 700;
  padding: clamp(20px, 1.4vw, 27px) clamp(17px, 1.4vw, 40px);
  width: 70%;
}
.p-about__table dd > p + p{
  margin-block-start: 1em;
}
.p-about__table dd .br {
  display: none;
}
@media screen and (max-width: 767px) {
  .p-about__table dd .br {
    display: block;
  }
}
.p-about__table dd span {
  display: block;
  font-weight: 400;
}
.p-about__table dd span .br {
  display: none;
}
.p-about__table dd span a {
  margin: 0px 10px;
  color: #4da4ce;
}
.p-about__table dd span a.--no-indent {
  margin: 0;
}
.p-about__table dd span a:hover {
  text-decoration: underline;
}
@media screen and (max-width: 767px) {
  .p-about__table dd span .br {
    display: block;
  }
  .p-about__table dd span a {
    margin-left: 0px;
  }
}

.p-career{
  padding-block: clamp(80px, 10vw, 200px);
  background-color: #fff;
}
.p-career-wrapper{
  max-width: 1120px;
  margin-inline: auto;
  position: relative;
}
.p-about__noufescanBox .career-speech {
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  width: 100vw;
  height: 100vw;
  max-width: clamp(240px, 25vw, 340px);
  max-height: clamp(62px, 8vw, 88px);
  position: absolute;
  top: -32px;
  left: 76px;
  z-index: -1;
  transform-origin: 15% 100%;
}
@media screen and (max-width: 1079px) {
  .p-about__noufescanBox .career-speech {
    max-width: clamp(240px, 40vw, 420px);
    max-height: clamp(62px, 28vw, 118px);
    top: -3.5vw;
    left: 88px;
  }
}

.p-about-noufes__map{
  width: fit-content;
}

.p-about-noufes__timetable{
  margin-inline: auto;
  margin-block-start: clamp(9.375rem, 6.074rem + 14.08vw, 18.75rem);
  background-color: #fff;
  position: relative;
  z-index: 20;
}

.p-about-noufes__sponsorship{
  width: fit-content;
  margin-inline: auto;
  margin-block-start: clamp(3.75rem, 2.43rem + 5.63vw, 7.5rem);
  position: relative;
  z-index: 20;
}
@media screen and (max-width: 1079px) {
  .p-about-noufes__sponsorship{
    width: 100%;
    padding-inline: 10px;
  }
}
.p-sponsorship__list.--p-about-noufes{
    margin-block-start: clamp(1rem, 0.648rem + 1.5vw, 2rem);
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}
.p-sponsorship__list.--p-about-noufes > a{
  width: auto;
}

/*
.p-about-theme {
  max-width: 1120px;
  margin: 120px auto 60px;
  padding: 50px;
  position: relative;
  background-image: url(../img/kv-theme-left.webp), url(../img/kv-theme-right.webp);
  background-repeat: no-repeat;
  background-position: 5% 50%, right 5% top 50%;
  background-size: auto 100%;
}
.p-about-theme br.--md {
  display: none;
}
@media screen and (max-width: 979px) {
  .p-about-theme br.--md {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .p-about-theme {
    padding: 20px;
  }
}
@media screen and (max-width: 349px) {
  .p-about-theme {
    background-image: none;
  }
}
.p-about-theme__ttl {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: clamp(1.8rem, 1.8vw, 2.2rem);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: clamp(24px, 2.6vw, 40px);
  position: relative;
  z-index: 2;
  text-align: center;
  color: #FF3369;
}
.p-about-theme__ttl .--large {
  font-size: 1.3636363636em;
  display: block;
}
.p-about-theme__txts {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 0;
  font-weight: 700;
  font-size: clamp(1.6rem, 1.65vw, 2rem);
  line-height: 1.5;
}
.p-about-theme__txts .--pink {
  color: #FF3369;
}
.p-about-theme__txts p + p {
  margin-top: 1em;
}
*/

.circles {
  display: flex;
  justify-content: center;
  max-width: 500px;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1079px) {
  .circles {
    margin: auto;
  }
}
.circles__circle {
  transform: translateX(0%);
  flex-shrink: 0;
  width: 100vw;
  height: 100vw;
  max-width: clamp(210px, 25vw, 340px);
  max-height: clamp(210px, 25vw, 340px);
  border-radius: 50%;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}

.circle-left {
  background: radial-gradient(closest-side, #fff, #fff calc(100% - 3px), #2E2C1A);
  background-size: 100% 100%;
  transform: translateX(-5px);
}
.circle-left__txt {
  position: relative;
  left: 0%;
  font-weight: 700;
  text-align: center;
}
.circle-left__txt span {
  font-size: clamp(1.4rem, 2vw, 2.1rem);
  display: block;
}
.circle-left__txt .small {
  font-size: clamp(1.1rem, 2vw, 1.7rem);
}

.circle-right {
  background: radial-gradient(closest-side, #F7F6F4, #F7F6F4 calc(100% - 3px), #2E2C1A);
  transform: translateX(5px);
}
.circle-right__txt {
  position: relative;
  left: 0%;
  font-weight: 700;
  text-align: center;
}
.circle-right__txt span {
  font-size: clamp(1.4rem, 2vw, 2.1rem);
  display: block;
}

.circle-overwrap {
  background-color: #ffec5a;
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  clip-path: circle(50% at -50% 50%);
}
.circle-overwrap__txt {
  position: relative;
  width: 40%;
  text-align: center;
  left: -50%;
  opacity: 0;
  visibility: hidden;
  font-weight: 700;
  text-align: center;
}
.circle-overwrap__txt span {
  font-size: clamp(1.4rem, 2vw, 2.1rem);
  display: block;
}

.p-access {
  padding-top: clamp(40px, 2vw, 80px);
  padding-bottom: clamp(40px, 2vw, 80px);
  background-color: #fff;
}
.p-access .h2-style {
  color: #EB656B;
}
.p-access-map {
  width: 100%;
}
.p-access-map iframe {
  width: 100%;
  height: 400px;
}
@media screen and (max-width: 767px) {
  .p-access-map iframe {
    height: 350px;
  }
}
.p-access-content {
  max-width: 1100px;
  margin: auto;
  margin-top: 60px;
  margin-bottom: 44px;
  padding: 0 20px;
}
@media screen and (max-width: 979px) {
  .p-access-content {
    margin-top: 20px;
  }
}
.p-access-content__Ttl {
  font-size: clamp(2.2rem, 4vw, 2.4rem);
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  font-weight: 700;
}
@media screen and (max-width: 979px) {
  .p-access-content__Ttl {
    font-size: clamp(1.9rem, 4vw, 2.2rem);
    margin-bottom: 10px;
  }
}
.p-access-content__Ttl:before {
  content: "";
  display: inline-block;
  background-color: #25B367;
  width: 5px;
  height: 36px;
  border-radius: 3px;
  margin-right: 12px;
}
.p-access-content__address {
  font-weight: 700;
  font-size: clamp(1.7rem, 2.4vw, 1.8rem);
  margin-bottom: 40px;
}
@media screen and (max-width: 979px) {
  .p-access-content__address {
    font-size: clamp(1.5rem, 2.4vw, 1.7rem);
    margin-bottom: 20px;
  }
}
.p-access-content__wrapper {
  display: grid;
  grid-template-columns: 4fr 3fr;
  gap: 40px;
}
@media screen and (max-width: 979px) {
  .p-access-content__wrapper {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 767px) {
  .p-access-content__wrapper {
    grid-template-columns: 1fr;
  }
}
.p-access-content__wrapper__box iframe {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .p-access-content__wrapper__box iframe {
    height: 340px;
  }
}
.p-access-content__wrapper__box.--info address {
  display: block;
  /* padding: 2em 0; */
}
@media screen and (max-width: 767px) {
  .p-access-content__wrapper__box.--info address {
    padding-top: 0;
  }
}
.p-access-content__wrapper__box.--info h4 {
  color: #25b367;
  margin-bottom: 2em;
}

.p-access-content__note{
  margin-block-start: 1em;
  padding: 10px 20px;
  border-radius: 10px;
  background-color: #F7F6F4;
}
.p-access-content__note h4.p-access-content__subttl{
  margin-bottom: 0;
}
.p-access-content__note .p-special__venue__list{
  margin-top: .75em;
}

.p-access-methods {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-access-methods {
    grid-template-columns: 1fr;
  }
}
.p-access-methods__ttl {
  font-size: 1.2em;
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 12px;
  align-items: center;
}
.p-access-methods__ttl:before {
  content: "";
  display: block;
  width: 24px;
  height: 32px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.p-access-methods__ttl.--train:before {
  background-image: url(../img/icon-train.svg);
}
.p-access-methods__ttl.--car:before {
  background-image: url(../img/icon-car.svg);
}
.p-access-methods .p-access-content__Ttl {
  font-size: inherit;
  font-weight: inherit;
  margin-top: 32px;
  margin-bottom: 5px;
}
.p-access-methods .p-access-content__Ttl.--yellow::before {
  background-color: #f5c600;
}
.p-access-methods .p-access-content__Ttl.--gray::before {
  background-color: #7c6c83;
}
.p-access-methods__txt {
  margin-top: 30px;
}
.p-access-methods__txt a {
  display: block;
  color: #4DA4CE;
  text-decoration: underline;
}
.p-access-methods .buttonarea{
  display: grid;
  grid-template-columns: auto auto;
  gap: 8px;
  margin-block-start: 1em;
}
@media screen and (max-width: 767px) {
  .p-access-methods .buttonarea{
    grid-template-columns: 1fr;
  }
}
.p-access .venue-btn.--access {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: clamp(1.4rem, 2.34375vw, 1.5rem);
  padding: clamp(14px, 2.34375vw, 17px) 0;
  font-weight: 700;
  text-align: center;
  background-color: #EB656B;
  border-radius: 100px;
  transition: 0.25s;
}
.p-access .venue-btn.--access.--google{
  font-size: 12px;
  max-width: 220px;
}
.p-access .venue-btn.--access:after {
  content: "";
  display: block;
  width: 16px;
  height: 18px;
  background-image: url(../img/btn_icon.svg);
  background-size: contain;
  background-repeat: no-repeat;
  margin-left: 10px;
}
.p-access .venue-btn.--access:hover {
  transition: 0.25s;
  opacity: 0.5;
}

.p-column {
  background-color: #F7F6F4;
  padding-top: 60px;
  padding-bottom: clamp(40px, 10vw, 95px);
}
.p-column__wrapper {
  display: flex;
  margin-bottom: clamp(40px, 10vw, 80px);
  margin-left: 8vw;
}
@media screen and (max-width: 1079px) {
  .p-column__wrapper {
    flex-direction: column;
    margin-left: 0;
  }
}
.p-column__wrapper__ttl {
  margin-right: 40px;
}
.p-column__wrapper__ttl .h2-style {
  color: #25B367;
  position: relative;
  z-index: 0;
  line-height: 1;
  text-align: left;
}
.p-column__wrapper__ttl .h2-style:after {
  content: "";
  display: inline-block;
  background-image: url(../img/infection-ttl_bg.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 120%;
  height: 150%;
  position: absolute;
  top: -24px;
  left: -40px;
  z-index: -1;
}
.p-column__wrapper__ttl .h2-style span {
  margin-top: clamp(10px, 2vw, 27px);
}
.p-column__wrapper__ttl img {
  max-width: clamp(57px, 20vw, 220px);
  transform: rotate(0deg);
}
@media screen and (max-width: 1079px) {
  .p-column__wrapper__ttl {
    margin-right: 0;
  }
  .p-column__wrapper__ttl .h2-style {
    text-align: center;
    margin-bottom: 0;
  }
  .p-column__wrapper__ttl .h2-style:after {
    top: -20px;
    left: 50%;
    transform: translate(-50%, 0);
    width: 15%;
    height: 100%;
    min-width: 150px;
    min-height: 139px;
  }
  .p-column__wrapper__ttl .h2-style .\--en {
    margin-top: 0;
    margin-bottom: 4px;
  }
  .p-column__wrapper__ttl .h2-style .\--ja {
    margin-top: 0;
  }
  .p-column__wrapper__ttl .h2-style .br {
    display: none;
  }
  .p-column__wrapper__ttl .h2-style .mr {
    margin-right: 10px;
  }
  .p-column__wrapper__ttl img {
    max-width: clamp(57px, 18vw, 220px);
    margin: auto;
    margin-bottom: 30px;
    margin-top: -0.5%;
  }
}
@media screen and (max-width: 979px) {
  .p-column__wrapper__ttl .h2-style:after {
    top: -16px;
    width: 13%;
    height: 100%;
    min-width: 125px;
    min-height: 116px;
  }
}
@media screen and (max-width: 767px) {
  .p-column__wrapper__ttl .h2-style:after {
    top: -15px;
    left: 50%;
    width: 15%;
    height: 100%;
    min-width: 120px;
    min-height: 111px;
  }
  .p-column__wrapper__ttl img {
    margin-top: 10px;
  }
}
@media screen and (max-width: 520px) {
  .p-column__wrapper__ttl .h2-style:after {
    min-width: 100px;
    min-height: 93px;
  }
  .p-column__wrapper__ttl img {
    margin-top: 0;
  }
}
.p-column .visit__border {
  border: 4px solid #EB656B;
}
.p-column .venue__border {
  border: 4px solid #25B367;
}
.p-column-content {
  display: inline-block;
  vertical-align: middle;
  border-radius: 36px;
  max-width: 300px;
  background-color: #fff;
}
.p-column-content:last-child {
  margin-right: 35px;
}
@media screen and (max-width: 1079px) {
  .p-column-content {
    min-width: 220px;
  }
  .p-column-content:last-child {
    margin-right: 20px;
  }
}
.p-column-content__img {
  position: relative;
}
.p-column-content__img img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 200px;
}
.p-column-content__img.\--no-image {
  padding: 20px 0;
  background-color: #eee;
}
.p-column-content__img.\--no-image img {
  -o-object-fit: contain;
     object-fit: contain;
  height: 160px;
}
.p-column-content__dsc {
  padding: 15px 25px 40px;
  height: 230px;
}
.p-column-content__dsc h3 {
  font-size: clamp(1.4rem, 3vw, 1.8rem);
  font-weight: 700;
  margin-bottom: 0.5em;
  margin-top: 0.9em;
  max-height: 3em;
  overflow: hidden;
}
.p-column-content__dsc p {
  font-size: clamp(1.4rem, 2vw, 1.4rem);
  max-height: 6em;
  overflow: hidden;
}
.p-column-content__dsc p .font-red {
  color: #EB656B;
}
@media screen and (max-width: 767px) {
  .p-column .visit__border {
    border: 2px solid #EB656B;
  }
  .p-column .venue__border {
    border: 2px solid #25B367;
  }
  .p-column-content {
    max-width: 250px;
  }
  .p-column-content__txt h3 {
    margin-bottom: 17px;
  }
}
.p-column .swiper {
  padding-bottom: clamp(20px, 4vw, 40px);
}
@media screen and (max-width: 1079px) {
  .p-column .swiper {
    margin-left: 20px;
  }
}
.p-column .swiper-horizontal > .swiper-scrollbar,
.p-column .swiper-scrollbar.swiper-scrollbar-horizontal {
  bottom: 0px;
  background-color: #fff;
  cursor: grab;
}
.p-column .swiper-scrollbar-drag {
  background-color: #EB656B;
  cursor: grab;
}

.p-infection-description {
  max-width: 1100px;
  margin: auto;
  padding: 0px 10px;
}
.p-infection-description dl dt {
  background-color: #EB656B;
  color: #fff;
  font-size: clamp(1.5rem, 3vw, 2rem);
  text-align: center;
  border-radius: 16px 16px 0 0;
  padding: clamp(10px, 2vw, 20px) 0;
  font-weight: 700;
}
.p-infection-description dl dd {
  border: 4px solid #EB656B;
  border-top: none;
  border-radius: 0px 0px 16px 16px;
  padding: clamp(24px, 3vw, 40px) clamp(20px, 5vw, 100px);
  background-color: #fff;
}
.p-infection-description dl dd .p-special__venue__list {
  margin-top: 0;
}
.p-infection-description dl dd .p-special__venue__list li + li {
  margin-top: 1.5em;
}
@media screen and (max-width: 767px) {
  .p-infection-description dl dd {
    border: 2px solid #EB656B;
  }
}

.p-infection {
  background-color: #F7F6F4;
  padding-top: 60px;
  padding-bottom: clamp(40px, 10vw, 95px);
}
.p-infection__wrapper {
  display: flex;
  margin-bottom: clamp(40px, 10vw, 80px);
  margin-left: 8vw;
}
@media screen and (max-width: 1079px) {
  .p-infection__wrapper {
    flex-direction: column;
    margin-left: 0;
  }
}
.p-infection__wrapper__ttl {
  margin-right: 40px;
}
.p-infection__wrapper__ttl .h2-style {
  color: #25B367;
  position: relative;
  z-index: 0;
  line-height: 1;
  text-align: left;
}
.p-infection__wrapper__ttl .h2-style:after {
  content: "";
  display: inline-block;
  background-image: url(../img/infection-ttl_bg.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 120%;
  height: 150%;
  position: absolute;
  top: -24px;
  left: -40px;
  z-index: -1;
}
.p-infection__wrapper__ttl .h2-style span {
  margin-top: clamp(10px, 2vw, 27px);
}
.p-infection__wrapper__ttl img {
  max-width: clamp(57px, 20vw, 220px);
  transform: rotate(0deg);
}
@media screen and (max-width: 1079px) {
  .p-infection__wrapper__ttl {
    margin-right: 0;
  }
  .p-infection__wrapper__ttl .h2-style {
    text-align: center;
    margin-bottom: 0;
  }
  .p-infection__wrapper__ttl .h2-style:after {
    top: -20px;
    left: 50%;
    transform: translate(-50%, 0);
    width: 15%;
    height: 100%;
    min-width: 150px;
    min-height: 139px;
  }
  .p-infection__wrapper__ttl .h2-style .\--en {
    margin-top: 0;
    margin-bottom: 4px;
  }
  .p-infection__wrapper__ttl .h2-style .\--ja {
    margin-top: 0;
  }
  .p-infection__wrapper__ttl .h2-style .br {
    display: none;
  }
  .p-infection__wrapper__ttl .h2-style .mr {
    margin-right: 10px;
  }
  .p-infection__wrapper__ttl img {
    max-width: clamp(57px, 18vw, 220px);
    margin: auto;
    margin-bottom: 30px;
    margin-top: -0.5%;
  }
}
@media screen and (max-width: 979px) {
  .p-infection__wrapper__ttl .h2-style:after {
    top: -16px;
    width: 13%;
    height: 100%;
    min-width: 125px;
    min-height: 116px;
  }
}
@media screen and (max-width: 767px) {
  .p-infection__wrapper__ttl .h2-style:after {
    top: -15px;
    left: 50%;
    width: 15%;
    height: 100%;
    min-width: 120px;
    min-height: 111px;
  }
  .p-infection__wrapper__ttl img {
    margin-top: 10px;
  }
}
@media screen and (max-width: 520px) {
  .p-infection__wrapper__ttl .h2-style:after {
    min-width: 100px;
    min-height: 93px;
  }
  .p-infection__wrapper__ttl img {
    margin-top: 0;
  }
}
.p-infection .visit__border {
  border: 4px solid #EB656B;
}
.p-infection .venue__border {
  border: 4px solid #25B367;
}
.p-infection-content {
  padding: 30px 26px;
  display: inline-block;
  vertical-align: middle;
  border-radius: 36px;
  max-width: 300px;
  background-color: #fff;
}
.p-infection-content:last-child {
  margin-right: 35px;
}
@media screen and (max-width: 1079px) {
  .p-infection-content {
    min-width: 220px;
  }
  .p-infection-content:last-child {
    margin-right: 20px;
  }
}
.p-infection-content__img {
  max-width: 250px;
  position: relative;
  margin-bottom: 36px;
}
.p-infection-content__img p {
  font-size: clamp(1.5rem, 2vw, 1.5rem);
  display: inline-block;
  color: #fff;
  font-weight: 700;
  padding: 6px 0px;
  border-radius: 8px;
  position: absolute;
  right: 0;
  transform: translate(0, -50%);
  width: 70px;
  text-align: center;
}
.p-infection-content__img .visit__txt {
  background-color: #EB656B;
}
.p-infection-content__img .venue__txt {
  background-color: #25B367;
}
.p-infection-content__txt {
  max-width: 250px;
  height: 200px;
}
.p-infection-content__txt h3 {
  font-size: clamp(1.4rem, 3vw, 1.8rem);
  font-weight: 700;
  margin-bottom: 20px;
}
.p-infection-content__txt p {
  font-size: clamp(1.4rem, 2vw, 1.4rem);
  max-width: 250px;
}
.p-infection-content__txt p .font-red {
  color: #EB656B;
}
@media screen and (max-width: 767px) {
  .p-infection .visit__border {
    border: 2px solid #EB656B;
  }
  .p-infection .venue__border {
    border: 2px solid #25B367;
  }
  .p-infection-content {
    padding: 20px;
    max-width: 250px;
  }
  .p-infection-content__txt h3 {
    margin-bottom: 17px;
  }
}
.p-infection .swiper {
  padding-bottom: clamp(20px, 4vw, 40px);
}
@media screen and (max-width: 1079px) {
  .p-infection .swiper {
    margin-left: 20px;
  }
}
.p-infection .swiper-horizontal > .swiper-scrollbar,
.p-infection .swiper-scrollbar.swiper-scrollbar-horizontal {
  bottom: 0px;
  background-color: #fff;
  cursor: grab;
}
.p-infection .swiper-scrollbar-drag {
  background-color: #EB656B;
  cursor: grab;
}

.p-infection-description {
  max-width: 1100px;
  margin: auto;
  padding: 0px 10px;
}
.p-infection-description dl dt {
  background-color: #EB656B;
  color: #fff;
  font-size: clamp(1.5rem, 3vw, 2rem);
  text-align: center;
  border-radius: 16px 16px 0 0;
  padding: clamp(10px, 2vw, 20px) 0;
  font-weight: 700;
}
.p-infection-description dl dd {
  border: 4px solid #EB656B;
  border-top: none;
  border-radius: 0px 0px 16px 16px;
  padding: clamp(24px, 3vw, 40px) clamp(20px, 5vw, 100px);
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .p-infection-description dl dd {
    border: 2px solid #EB656B;
  }
}

.p-kv {
  background-color: #fff;
}
.p-kv-image {
  position: relative;
  height: calc(100vh - 40px);
  padding-left: 5%;
}
@media screen and (max-width: 979px) {
  .p-kv-image {
    height: auto;
    aspect-ratio: 16/11;
    padding-left: 2%;
  }
}
@media screen and (max-width: 767px) {
  .p-kv-image {
    padding-left: 0;
    aspect-ratio: unset;
    height: 400px;
  }
}
.p-kv-image img {
  -o-object-fit: contain;
     object-fit: contain;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .p-kv-image img {
    -o-object-fit: cover;
       object-fit: cover;
       object-position: top center;
  }
}


.p-kv-image__ttl {
  position: absolute;
  right: 56px;
  bottom: 32px;
  width: calc(100vw * 606 / 1920);
  min-width: 400px;
  z-index: 20;
}
@media screen and (max-width: 979px) {
  .p-kv-image__ttl {
    right: 0;
    bottom: 20px;
    min-width: 300px;
  }
}
@media screen and (max-width: 767px) {
  .p-kv-image__ttl {
    bottom: 0;
    min-width: 180px;
  }
}
.p-kv-wrapper {
  background: #eb656b;
  background: linear-gradient(177deg, #eb656b 0%, #ffec5a 100%);
  padding: 16px 0;
  margin-left: -10%;
  width: 120%;
}
@media screen and (max-width: 767px) {
  .p-kv-wrapper {
    position: relative;
  }
  .p-kv-wrapper:before {
    content: "";
    display: block;
    background-image: url(../img/kv-decoration-left.svg);
    background-size: contain;
    width: 30vw;
    height: 87vw;
    position: absolute;
    bottom: 0;
    left: -11vw;
  }
  .p-kv-wrapper:after {
    content: "";
    display: block;
    background-image: url(../img/kv-decoration-right.svg);
    background-size: contain;
    width: 30vw;
    height: 87vw;
    position: absolute;
    bottom: 0;
    right: -11vw;
  }
}
.p-kv-wrapper__img .swiper-wrapper {
  transition-timing-function: linear;
}
@media screen and (max-width: 767px) {
  .p-kv-wrapper__img .swiper-slide figure{
    aspect-ratio: 1;
  }
  .p-kv-wrapper__img .swiper-slide figure img{
    border-block-end-width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
.p-kv-wrapper__img img {
  border-radius: 3vw;
}
@media screen and (max-width: 767px) {
  .p-kv-wrapper__img img {
    border: 7px solid #fff;
    border-radius: 5vw;
  }
}
.p-kv-wrapper__copy {
  width: 90%;
  margin: -8vw auto 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  position: relative;
  z-index: 3;
}
.p-kv-wrapper__copy .copy-01 {
  width: 50%;
}
.p-kv-wrapper__copy .copy-02 {
  width: 47%;
}
@media screen and (max-width: 767px) {
  .p-kv-wrapper__copy {
    flex-direction: column;
    width: 82%;
    margin-top: -14vw;
  }
  .p-kv-wrapper__copy .copy-01 {
    width: 100%;
    margin-left: -3%;
    margin-bottom: 18px;
  }
  .p-kv-wrapper__copy .copy-02 {
    width: 100%;
  }
}

.card03 .swiper {
  overflow: visible;
}

.swiper-slide {
  overflow: hidden;
}

.movie-btn {
  position: fixed;
  bottom: 2%;
  right: 10px;
  z-index: 30;
  width: calc(100vw * 312 / 1920);
  min-width: 200px;
}
.movie-btn a{
  rotate: 0deg;
  filter: brightness(1);
  transition: 
    rotate 0.4s ease-in-out,
    filter 0.4s ease-in-out;
}
@media (any-hover: hover) {
  .movie-btn a :hover{
    rotate: 3deg;
    filter: brightness(1.04);
  }
}
@media screen and (max-width: 767px) {
  .movie-btn {
    width: 130px;
    min-width: unset;
   /*  right: auto;
    left: 0; */
  }
}

@keyframes swingPath {
  to {
    stroke-dashoffset: 0;
  }
}
.p-loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #FFFCDE;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999;
}
.p-loader__img {
  max-width: 100px;
  width: 70%;
}

.p-opening {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  background-color: #FFFCDE;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 888;
}
.p-opening__img {
  max-width: 1200px;
  width: 83vw;
}

.tesr {
  width: 100px;
}

.p-special {
  padding-top: clamp(40px, 10vw, 80px);
  padding-bottom: clamp(40px, 10vw, 80px);
  background-color: #fff;
}
.p-special .h2-style {
  color: #EB656B;
  padding-left: 12px;
  padding-right: 12px;
}
.p-special__venue {
  padding: 0 12px;
}
.p-special__venue__ttl {
  text-align: center;
  margin-bottom: clamp(15px, 10vw, 25px);
}
.p-special__venue__ttl h3 {
  font-size: clamp(1.6rem, 2.34375vw, 2.5rem);
  background: linear-gradient(transparent 60%, #fffcde 60%);
  font-family: "Zen Maru Gothic", sans-serif;
  display: inline-block;
  font-weight: 700;
  padding: 0 1.5%;
}
.p-special__venue-inner {
  max-width: 1100px;
  margin: auto;
  padding: 0 50px;
  box-sizing: content-box;
}
@media screen and (max-width: 979px) {
  .p-special__venue-inner {
    padding: 0 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-special__venue-inner {
    padding: 0;
  }
}
.p-special__venue-wrapper {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 64px;
}
@media screen and (max-width: 979px) {
  .p-special__venue-wrapper {
    gap: 20px;
  }
}
.p-special__venue__name {
  line-height: 1.3;
  text-align: center;
  border-radius: 16px;
  margin: auto;
  margin-top: 10px;
  position: relative;
  z-index: 2;
  padding: 6px 0;
  font-weight: 700;
  color: #fff;
}
.p-special__venue__name span {
  display: block;
  font-size: clamp(1.6rem, 2.34375vw, 2.5rem);
}
.p-special__venue__name .small {
  font-size: clamp(1.4rem, 2.34375vw, 2rem);
}
@media screen and (max-width: 600px) {
  .p-special__venue__name {
    border-radius: 8px;
    border: 3px solid #fff;
    min-width: 87%;
    width: -moz-fit-content;
    width: fit-content;
    padding-left: 0.7em;
    padding-right: 0.7em;
  }
}
.p-special .venue-green {
  background-color: #80b399;
}
.p-special .venue-yellow {
  background-color: #E7C563;
}
.p-special .venue-blue {
  background-color: #4da4ce;
}
.p-special .venue-purple {
  background-color: #7C6C83;
}
.p-special__venue__subttl {
  font-size: clamp(1.6rem, 1.6vw, 2rem);
  font-weight: 700;
  margin-top: 2em;
  padding: 0.2em 0 0.2em 1em;
  position: relative;
}
.p-special__venue__subttl::before {
  content: "";
  display: block;
  width: 5px;
  height: 100%;
  background-color: #FF3369;
  position: absolute;
  border-radius: 100px;
  top: 0;
  left: 0;
}
.p-special__venue__list {
  margin-top: 1.5em;
  padding-left: 0.1em;
}
.p-special__venue__list li {
  display: grid;
  grid-template-columns: 1.2em 1fr;
  gap: 0.3em;
}
@media screen and (max-width: 1023px) {
  .p-special__venue__list li {
    font-size: 85%;
  }
}
.p-special__venue__list li::before {
  content: "";
  display: block;
  width: 1.2em;
  height: 1.2em;
  border-radius: 50%;
  border: 1px solid #2E2C1A;
  transform: translateY(0.2em);
}
.p-special__venue__list li + li {
  margin-top: 0.8em;
}
.p-special__venue__thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 2em;
  margin-bottom: 3em;
}
@media screen and (max-width: 767px) {
  .p-special__venue__thumbs {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-top: 1em;
    margin-bottom: 2em;
  }
}
.p-special .venue-btn {
  max-width: 400px;
  margin: auto;
  margin-bottom: clamp(30px, 10vw, 40px);
}
.p-special .venue-btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: clamp(1.4rem, 2.34375vw, 1.5rem);
  padding: clamp(14px, 2.34375vw, 17px) 0;
  font-weight: 700;
  text-align: center;
  background-color: #EB656B;
  border-radius: 100px;
  transition: 0.25s;
}
.p-special .venue-btn a:after {
  content: "";
  display: block;
  width: 16px;
  height: 18px;
  background-image: url(../img/btn_icon.svg);
  background-size: contain;
  background-repeat: no-repeat;
  margin-left: 10px;
}
.p-special .venue-btn a:hover {
  transition: 0.25s;
  opacity: 0.5;
}
@media screen and (max-width: 767px) {
  .p-special .venue-btn {
    max-width: 73.5%;
    margin: auto;
    margin-top: 30px;
    margin-bottom: clamp(30px, 10vw, 40px);
  }
  .p-special .venue-btn a:after {
    width: 14px;
    height: 14px;
    margin-left: 10px;
  }
}
.p-special__wrapper {
  padding: 0 12px;
}
.p-special__container {
  padding: 70px 40px;
  border: 5px solid #EB656B;
  border-radius: 16px;
  max-width: 1100px;
  margin: auto;
}
.p-special__container a {
  color: #4da4ce;
  text-decoration: underline;
}
.p-special__container a:hover {
  filter: brightness(0.8);
}
@media screen and (max-width: 767px) {
  .p-special__container {
    border: 2px solid #EB656B;
    border-radius: 8px;
    padding: 40px 16px;
  }
}
.p-special__content {
  position: relative;
  padding-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-special__content {
    padding-top: 34px;
  }
}
.p-special__content:nth-child(even) .p-special__inner {
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .p-special__content:nth-child(even) .p-special__inner {
    flex-direction: column;
  }
}
.p-special__content .fill-red {
  background-color: #EB656B;
}
.p-special__content .border-red {
  border: 3px solid #EB656B;
}
.p-special__subttl.color-red.--modal {
  color: #EB656B;
}

.p-special__content .p-special__subttl.color-red::before {
  background-color: #EB656B;
}
.p-special__content .p-special__btn.color-red button {
  background-color: #EB656B;
}
.p-special__content .p-special__attention.color-red {
  color: #EB656B;
}
.p-special__content .p-special__attention.color-red.--subttl > span {
  font-size: 1.1111em;
}
.p-special__content .fill-green {
  background-color: #25B367;
}
.p-special__content .border-green {
  border: 3px solid #25B367;
}
.p-special__subttl.color-green.--modal {
  color: #25B367;
}

.p-special__content .p-special__subttl.color-green::before {
  background-color: #25B367;
}
.p-special__content .p-special__btn.color-green button {
  background-color: #25B367;
}
.p-special__content .p-special__attention.color-green {
  color: #25B367;
}
.p-special__content .p-special__attention.color-green.--subttl > span {
  font-size: 1.1111em;
}
.p-special__content .fill-blue {
  background-color: #4DA4CE;
}
.p-special__content .border-blue {
  border: 3px solid #4DA4CE;
}
.p-special__subttl.color-blue.--modal {
  color: #4DA4CE;
}

.p-special__content .p-special__subttl.color-blue::before {
  background-color: #4DA4CE;
}
.p-special__content .p-special__btn.color-blue button {
  background-color: #4DA4CE;
}
.p-special__content .p-special__attention.color-blue {
  color: #4DA4CE;
}
.p-special__content .p-special__attention.color-blue.--subttl > span {
  font-size: 1.1111em;
}
.p-special__content .fill-yellow {
  background-color: #F5C600;
}
.p-special__content .border-yellow {
  border: 3px solid #F5C600;
}
.p-special__subttl.color-yellow.--modal {
  color: #F5C600;
}

.p-special__content .p-special__subttl.color-yellow::before {
  background-color: #F5C600;
}
.p-special__content .p-special__btn.color-yellow button {
  background-color: #F5C600;
}
.p-special__content .p-special__attention.color-yellow {
  color: #F5C600;
}
.p-special__content .p-special__attention.color-yellow.--subttl > span {
  font-size: 1.1111em;
}
.p-special__content .fill-green-2 {
  background-color: #a3d176;
}
.p-special__content .border-green-2 {
  border: 3px solid #a3d176;
}
.p-special__subttl.color-green-2.--modal {
  color: #a3d176;
}

.p-special__content .p-special__subttl.color-green-2::before {
  background-color: #a3d176;
}
.p-special__content .p-special__btn.color-green-2 button {
  background-color: #a3d176;
}
.p-special__content .p-special__attention.color-green-2 {
  color: #a3d176;
}
.p-special__content .p-special__attention.color-green-2.--subttl > span {
  font-size: 1.1111em;
}
.p-special__content .fill-green-3 {
  background-color: #25b367;
}
.p-special__content .border-green-3 {
  border: 3px solid #25b367;
}
.p-special__subttl.color-green-3.--modal {
  color: #25b367;
}

.p-special__content .p-special__subttl.color-green-3::before {
  background-color: #25b367;
}
.p-special__content .p-special__btn.color-green-3 button {
  background-color: #25b367;
}
.p-special__content .p-special__attention.color-green-3 {
  color: #25b367;
}
.p-special__content .p-special__attention.color-green-3.--subttl > span {
  font-size: 1.1111em;
}
.p-special__content .fill-blue-2 {
  background-color: #577DD3;
}
.p-special__content .border-blue-2 {
  border: 3px solid #577DD3;
}
.p-special__subttl.color-blue-2.--modal {
  color: #577DD3;
}

.p-special__content .p-special__subttl.color-blue-2::before {
  background-color: #577DD3;
}
.p-special__content .p-special__btn.color-blue-2 button {
  background-color: #577DD3;
}
.p-special__content .p-special__attention.color-blue-2 {
  color: #577DD3;
}
.p-special__content .p-special__attention.color-blue-2.--subttl > span {
  font-size: 1.1111em;
}
.p-special__content .fill-pink {
  background-color: #f79291;
}
.p-special__content .border-pink {
  border: 3px solid #f79291;
}
.p-special__subttl.color-pink.--modal {
  color: #f79291;
}

.p-special__content .p-special__subttl.color-pink::before {
  background-color: #f79291;
}
.p-special__content .p-special__btn.color-pink button {
  background-color: #f79291;
}
.p-special__content .p-special__attention.color-pink {
  color: #f79291;
}
.p-special__content .p-special__attention.color-pink.--subttl > span {
  font-size: 1.1111em;
}
.p-special__content .fill-pink-2 {
  background-color: #ff3369;
}
.p-special__content .border-pink-2 {
  border: 3px solid #ff3369;
}
.p-special__subttl.color-pink-2.--modal {
  color: #ff3369;
}

.p-special__content .p-special__subttl.color-pink-2::before {
  background-color: #ff3369;
}
.p-special__content .p-special__btn.color-pink-2 button {
  background-color: #ff3369;
}
.p-special__content .p-special__attention.color-pink-2 {
  color: #ff3369;
}
.p-special__content .p-special__attention.color-pink-2.--subttl > span {
  font-size: 1.1111em;
}
.p-special__content .fill-orange {
  background-color: #F69F52;
}
.p-special__content .border-orange {
  border: 3px solid #F69F52;
}
.p-special__subttl.color-orange.--modal {
  color: #F69F52;
}

.p-special__content .p-special__subttl.color-orange::before {
  background-color: #F69F52;
}
.p-special__content .p-special__btn.color-orange button {
  background-color: #F69F52;
}
.p-special__content .p-special__attention.color-orange {
  color: #F69F52;
}
.p-special__content .p-special__attention.color-orange.--subttl > span {
  font-size: 1.1111em;
}
.p-special__content:first-child {
  padding-top: 0;
}
.p-special__content:after {
  content: "";
  background-image: url(../img/special_border.svg);
  background-size: contain;
  background-repeat: repeat-x;
  width: calc(100% + 80px);
  height: 3px;
  display: block;
  position: absolute;
  left: 50%;
  transform: translate(-50%, 0%);
}
@media screen and (max-width: 767px) {
  .p-special__content:after {
    height: 2px;
    width: calc(100% + 32px);
  }
}
.p-special__content:last-child::after {
  display: none;
}
.p-special__content .view-btn {
  max-width: 300px;
  border-radius: 100px;
  transition: 0.25s;
}
.p-special__content .view-btn:hover {
  transition: 0.25s;
  opacity: 0.5;
}
.p-special__content .view-btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: clamp(1.4rem, 2.34375vw, 1.5rem);
  padding: clamp(14px, 2.34375vw, 17px) 0;
  font-weight: 700;
  text-align: center;
}
.p-special__content .view-btn a:after {
  content: "";
  display: block;
  width: 15px;
  height: 15px;
  background-image: url(../img/btn_icon.svg);
  background-size: contain;
  margin-left: 10px;
}
@media screen and (max-width: 767px) {
  .p-special__content .view-btn {
    max-width: 73.5%;
    margin: auto;
    margin-top: 30px;
  }
  .p-special__content .view-btn a:after {
    width: 14px;
    height: 14px;
    margin-left: 10px;
  }
}
@media screen and (max-width: 767px) {
  .p-special__content .view-btn-pc {
    display: none;
  }
}
.p-special__content .view-btn-sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .p-special__content .view-btn-sp {
    display: block;
  }
}
.p-special__content .btn-red {
  background-color: #EB656B;
}
.p-special__content .btn-orange {
  background-color: #F69F52;
}
.p-special__content .btn-yellow {
  background-color: #F5C600;
}
.p-special__content .btn-green {
  background-color: #25B367;
}
.p-special__content .btn-yellow-green {
  background-color: #A3D176;
}
.p-special__inner {
  display: flex;
  justify-content: space-between;
  margin-bottom: 40px;
}
.p-special__inner.--modal {
  display: grid;
  grid-template-columns: 400fr 320fr;
  gap: 7.93%;
}
@media screen and (max-width: 767px) {
  .p-special__inner.--modal {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-special__inner {
    flex-direction: column;
    max-width: 440px;
    margin-bottom: 30px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (max-width: 767px) {
  .p-special .reverse {
    flex-direction: column-reverse;
  }
}
.p-special__box {
  width: 49%;
  position: relative;
}
.p-special__box.--modal {
  width: 100%;
}
.p-special__box .special_img{
  border-radius: 8px;
  overflow: hidden;
}
.p-special__box .special_img img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}
.p-special__box.--modal .special_img{
  border-radius: 8px;
  overflow: hidden;
}
.p-special__box.--modal .special_img img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}
@media screen and (max-width: 767px) {
  .p-special__box {
    width: 100%;
    max-width: 100%;
  }
}
.p-special__box figure {
  width: 100%;
}
.p-special__box .special_img07 {
  max-width: 360px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .p-special__box .special_img07 {
    max-width: clamp(80%, 60vw, 85%);
  }
}
.p-special__box .special_img14 {
  max-width: 400px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .p-special__box .special_img14 {
    max-width: clamp(70%, 60vw, 75%);
  }
}
.p-special__ttl {
  display: flex;
  align-items: flex-end;
  margin-bottom: clamp(26px, 2.34375vw, 30px);
}
.p-special__ttl__img {
  display: flex;
  align-items: flex-end;
}
.p-special__ttl__img.--modal {
  justify-content: center;
  margin: auto;
  margin-bottom: 8px;
}
.p-special__ttl__img .smile {
  width: clamp(46px, 3.4vw, 47px);
  margin-right: 13px;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__img .smile {
    margin-right: 0px;
  }
}
.p-special__ttl__img .speech {
  width: clamp(120px, 12vw, 170px);
  transform-origin: 0% 55%;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__img {
    width: min(100% - 135px, 166px);
  }
  .p-special__ttl__img .smile {
    width: 28%;
  }
  .p-special__ttl__img .speech {
    width: 73%;
  }
}
.p-special__ttl__txt {
  margin-left: 15px;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt {
    margin-left: 10px;
  }
}
.p-special__ttl__txt p {
  font-size: 1.3rem;
  font-weight: 500;
  border-radius: 8px;
  width: 150px;
  text-align: center;
}
.p-special__ttl__txt p:nth-of-type(2) {
  margin-bottom: 5px;
}
@media screen and (max-width: 979px) {
  .p-special__ttl__txt p {
    width: clamp(125px, 17vw, 150px);
  }
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt p {
    font-size: 1.2rem;
    border-radius: 4px;
    width: clamp(80px, 35vw, 125px);
  }
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .small {
    font-size: 1.2rem;
  }
}
.p-special__ttl__txt .venue {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 5px;
  white-space: nowrap;
  min-width: 150px;
  width: -moz-fit-content;
  width: fit-content;
  padding: 2px 0.5em;
  color: #fff;
  text-align: left;
}
.p-special__ttl__txt .venue:before {
  content: "";
  display: inline-block;
  background-size: contain;
  background-image: url(../img/venue-icon.svg);
  background-repeat: no-repeat;
  width: 10px;
  height: 14px;
  margin-right: 6px;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .venue:before {
    margin-right: 4px;
  }
}
.p-special__ttl__txt .price-red {
  border: 3px solid #EB656B;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .price-red {
    border: 2px solid #EB656B;
  }
}
.p-special__ttl__txt .price-green {
  border: 3px solid #25B367;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .price-green {
    border: 2px solid #25B367;
  }
}
.p-special__ttl__txt .price-blue {
  border: 3px solid #4DA4CE;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .price-blue {
    border: 2px solid #4DA4CE;
  }
}
.p-special__ttl__txt .price-blue-02 {
  border: 3px solid #577DD3;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .price-blue-02 {
    border: 2px solid #577DD3;
  }
}
.p-special__ttl__txt .price-orange {
  border: 3px solid #F69F52;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .price-orange {
    border: 2px solid #F69F52;
  }
}
.p-special__ttl__txt .price-yellow-green {
  border: 3px solid #A3D176;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .price-yellow-green {
    border: 2px solid #25B367;
  }
}
.p-special__ttl__txt .price-pink {
  border: 3px solid #FF3369;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .price-pink {
    border: 2px solid #FF3369;
  }
}
.p-special__ttl__txt .price-yellow {
  border: 3px solid #F5C600;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .price-yellow {
    border: 2px solid #F5C600;
  }
}
.p-special__ttl__txt .price-pink02 {
  border: 3px solid #F79291;
}
@media screen and (max-width: 767px) {
  .p-special__ttl__txt .price-pink02 {
    border: 2px solid #F79291;
  }
}
.p-special__time {
  font-size: clamp(1.4rem, 2.6vw, 1.8rem);
  font-weight: 700;
  margin-left: 15px;
  margin-bottom: 8px;
}
@media screen and (max-width: 767px) {
  .p-special__time {
    margin-left: 0;
  }
}
.p-special__time-red {
  color: #EB656B;
}
.p-special__time-green {
  color: #25B367;
}
.p-special__time-blue {
  color: #4DA4CE;
}
.p-special__time-blue-02 {
  color: #577DD3;
}
.p-special__time-blue-02 {
  color: #577DD3;
}
.p-special__time-yellow-green {
  color: #A3D176;
}
.p-special__time-orange {
  color: #F69F52;
}
.p-special__time-pink {
  color: #FF3369;
}
.p-special__time-pink02 {
  color: #F79291;
}
.p-special__time-yellow {
  color: #F5C600;
}
.p-special__subttl {
  font-size: clamp(2rem, 2.6vw, 2.5rem);
  font-weight: 700;
  margin-bottom: clamp(20px, 2.34375vw, 30px);
  flex-shrink: 0;
  line-height: 1.25;
  position: relative;
  padding-left: 0.6em;
}
.p-special__subttl .--small {
  display: block;
  font-size: 0.76em;
}
.p-special__subttl.--modal {
  padding: 0;
  text-align: center;
  margin-bottom: 80px;
}
.p-special__subttl.--modal > span {
  font-size: 2em;
}
.p-special__subttl:not(.--modal):before {
  content: "";
  display: block;
  width: 5px;
  height: 100%;
  margin-right: clamp(7px, 2.34375vw, 10px);
  border-radius: 10px;
  flex-shrink: 0;
  position: absolute;
  top: 0;
  left: 0;
}
.p-special__subttl .small {
  font-size: clamp(1.5rem, 1.7vw, 1.6rem);
  margin-bottom: 0;
}
.p-special__subttl .big {
  font-size: clamp(2rem, 2.6vw, 2.5rem);
  margin-bottom: clamp(20px, 2.34375vw, 30px);
  font-weight: 700;
}
.p-special__attention {
  font-size: clamp(1.4rem, 1.4vw, 2rem);
  color: #EB656B;
  font-weight: 700;
  margin-bottom: 15px;
}
.p-special__txt {
  font-size: clamp(1.5rem, 2vw, 1.6rem);
  line-height: 1.53;
}
.p-special__txt .margin {
  display: block;
  margin: 0.5em 0;
}
@media screen and (max-width: 767px) {
  .p-special__txt {
    margin-bottom: 20px;
    font-size: clamp(1.4rem, 1.4vw, 2rem);
  }
}
.p-special__btn button {
  margin-top: 16px;
  font-size: 15px;
  line-height: 1;
  width: 20.73em;
  height: 3.357em;
  margin-top: 15px;
  border-radius: 1000px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  color: #ffffff;
}
.p-special__btn button .--icon {
  display: block;
  width: 1.333em;
}
@media screen and (max-width: 767px) {
  .p-special__btn button {
    margin-top: -4px;
    margin-bottom: 20px;
    font-size: 14px;
  }
}
.p-special .special-mt-01 {
  margin-top: clamp(20px, 2.34375vw, 30px);
}
.p-special .special-mb-01 {
  margin-bottom: clamp(20px, 2.34375vw, 30px);
}
.p-special .mt30 {
  margin-top: 30px;
}
.p-special .mb0 {
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .p-special .mb0 {
    margin-bottom: 20px;
  }
}
.p-special__detail {
  padding: clamp(24px, 2.34375vw, 30px) clamp(10px, 2.34375vw, 25px);
  background-color: #FFFCDE;
  border-radius: 16px;
}
@media screen and (max-width: 767px) {
  .p-special__detail {
    border-radius: 8px;
    margin-bottom: 20px;
  }
}
.p-special__detail .note {
  font-size: clamp(1.4rem, 2vw, 1.5rem);
  margin-bottom: 14px;
  font-weight: 500;
}
.p-special__detail ol {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
  margin: 0;
  margin: auto;
  border-radius: 16px;
}
.p-special__detail ol li {
  padding-left: 30px;
  position: relative;
  margin-bottom: 24px;
  line-height: 1.6;
}
.p-special__detail ol li:last-child {
  margin-bottom: 0;
}
.p-special__detail ol li .ttl {
  font-size: clamp(1.5rem, 2vw, 1.8rem);
  font-weight: 700;
  margin-bottom: 5px;
}
.p-special__detail ol li .ttl:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  border: 3px solid;
  border-radius: 50%;
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 20px;
  width: 20px;
  color: #4DA4CE;
  font-weight: 700;
  font-size: 69%;
  line-height: 1.6;
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(0, 20%);
  background-color: #fff;
}
.p-special__detail ol li .txt {
  font-size: clamp(1.4rem, 2vw, 1.5rem);
}
.p-special__detail ul li {
  font-size: clamp(1.4rem, 2vw, 1.5rem);
  margin-bottom: 14px;
  font-weight: 500;
}
.p-special__detail ul li:last-child {
  margin-bottom: 0;
}
.p-special__detail dl dt {
  font-size: clamp(1.5rem, 2vw, 1.8rem);
  font-weight: 700;
  padding-left: clamp(20px, 2vw, 40px);
  position: relative;
  margin-bottom: 10px;
}
.p-special__detail dl dt:before {
  content: "";
  display: inline-block;
  background-color: #F69F52;
  width: clamp(12px, 2vw, 14px);
  height: clamp(12px, 2vw, 14px);
  position: absolute;
  left: 0;
  top: 10%;
}
.p-special__detail dl dd {
  font-size: clamp(1.4rem, 2vw, 1.6rem);
  font-weight: 500;
  padding-left: clamp(20px, 2vw, 40px);
  line-height: 1.6;
}
.p-special__banner {
  background-color: #F7F6F4;
  display: flex;
  flex-wrap: wrap;
  padding: clamp(14px, 2.34375vw, 20px) clamp(10px, 2.34375vw, 20px);
  border-radius: 16px;
  gap: clamp(10px, 1.7vw, 20px);
}
.p-special__banner img {
  display: block;
  width: 47.6%;
}
@media screen and (max-width: 767px) {
  .p-special__banner-pc {
    display: none;
  }
}
.p-special__banner-sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .p-special__banner-sp {
    display: flex;
  }
}
.p-special__link {
  margin-top: 24px;
}
.p-special__link a {
  text-decoration: underline;
  display: flex;
  align-items: center;
  transition: 0.5s;
}
.p-special__link a:after {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  background-image: url(../img/btn_icon_black.svg);
  background-repeat: no-repeat;
  background-size: contain;
  margin-left: 8px;
}
.p-special__link a:hover {
  opacity: 0.5;
  transition: 0.25s;
}

.p-special__time-table {
  background-color: #F7F6F4;
  padding-top: clamp(40px, 10vw, 60px);
  padding-bottom: clamp(40px, 10vw, 60px);
  margin-bottom: clamp(40px, 10vw, 60px);
}
.p-special__time-table-temp {
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
}
.p-special__time-table-temp ul li {
  font-size: 1.2em;
  font-weight: 700;
  line-height: 1.8;
}
.p-special__time-table-temp ul li span {
  color: #FF3369;
}
.p-special__time-table-temp ul li span.--break {
  color: inherit;
  padding-left: 1em;
}
.p-special__time-table-temp small {
  display: block;
  color: #a8a797;
  margin-top: 2em;
}
.p-special__time-table-wrapper {
  max-width: 1124px;
  margin: auto;
  padding: 47px 47px 85px;
  background-color: #fff;
  border-radius: 20px;
}
@media screen and (max-width: 767px) {
  .p-special__time-table-wrapper {
    max-width: calc(100% - 40px);
    padding: 40px 16px;
  }
}
.p-special__time-table-inner {
  margin: auto;
}
@media screen and (max-width: 767px) {
  .p-special__time-table-inner {
    overflow: scroll;
  }
}
.p-special__time-table-inner::-webkit-scrollbar {
  height: 8px;
  width: 8px;
  padding: 12px;
}
.p-special__time-table-inner::-webkit-scrollbar-track {
  background: #E5E4DC;
  border-radius: 10px;
  padding: 12px;
}
.p-special__time-table-inner::-webkit-scrollbar-thumb {
  background: #EB656B;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-special__time-table-content {
    max-height: 80vh;
    width: 767px;
    min-width: 767px;
  }
}
.p-special__time-table-time {
  position: sticky;
  top: 0;
  left: auto;
  z-index: 2;
}
.p-special__time-table-box {
  display: flex;
  position: relative;
}
.p-special__time-table-ttl {
  width: 9.9276111686%;
  position: sticky;
  top: 0;
  left: 0;
  z-index: 1;
}
.p-special__time-table-table {
  width: 90.0723888314%;
}
.p-special__time-table__show{
  display: grid;
  place-items: center;
  margin-block: clamp(1.875rem, 1.189rem + 2.93vw, 3.75rem);
  margin-inline: auto;
  padding: 32px 40px;
  width: auto;
  position: relative;
}
.p-special__time-table__show::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 8px;
  border: 4px solid transparent;
  background: linear-gradient(90deg,#EB666B 0%, #FFEB5A 100%) border-box border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0) border-box;
  -webkit-mask-composite: destination-out;
  mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0) border-box;
  mask-composite: exclude;
}
.p-special__time-table__show a{
  display: grid;
  place-items: center;
  color: #EB666B;
  font-size: clamp(1.25rem, 0.793rem + 1.95vw, 2.5rem);
  font-weight: 700;
  z-index: 5;
  transition: color 0.24s ease-in-out;
  text-align: center;
}
.p-special__time-table__show a::before{
  display: block;
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(255,255,255, 0);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
}
.p-special__time-table__show a span{
  font-size: clamp(0.875rem, 0.463rem + 1.76vw, 2rem);
}
.p-special__time-table__show a:hover{
  color: #F69F52;
}

.p-special .coming-soon {
  text-align: center;
  font-size: 32px;
  color: #EB656B;
  font-weight: 700;
}
.p-special__map {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  max-width: 1100px;
  /* margin-block: 200px; */
  margin-inline: auto;
  padding: 48px;
  border: 12px solid #eb656b;
  border-radius: 20px;
}
@media screen and (max-width: 767px) {
  .p-special__map {
    border: 6px solid #eb656b;
    border-radius: 10px;
    margin-bottom: 100px;
    padding-bottom: 20px;
  }
}
.p-special__map > button.--full {
  grid-column: span 2;
}
.p-special__map > button:hover {
  opacity: 0.8;
}
.p-special__map .--btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 175px;
  height: 80px;
  margin: auto;
  background-color: #4da4ce;
  border-radius: 1000px;
  font-size: 20px;
  font-weight: 700;
  gap: 8px;
  color: #fff;
  margin-top: -20px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-special__map .--btn {
    width: 120px;
    height: 44px;
    font-size: 15px;
    margin-top: 0;
  }
}
.p-special__map .--btn .--icon {
  width: 40px;
}
@media screen and (max-width: 767px) {
  .p-special__map .--btn .--icon {
    width: 24px;
  }
}
.p-special__map-btn {
  position: absolute;
  top: -60px;
  right: -60px;
  width: 120px;
  height: 120px;
}
.p-special__map-close {
  position: absolute;
  top: 5%;
  left: 5%;
  width: 90%;
  height: 96px;
  pointer-events: none;
  z-index: 999999999;
  padding-top: 24px;
  padding-right: 24px;
  display: flex;
  justify-content: flex-end;
}
.p-special__map-close button {
  pointer-events: auto;
  width: 56px;
  height: 56px;
  background-color: #fff3cd;
  border-radius: 50%;
  position: relative;
}
.p-special__map-close button:before, .p-special__map-close button:after {
  content: "";
  display: block;
  width: 22.63px;
  height: 4px;
  background-color: #2e2c1a;
  border-radius: 100px;
  position: absolute;
  top: calc(50% - 2px);
  left: calc(50% - 11.315px);
}
.p-special__map-close button:before {
  transform: rotate(45deg);
}
.p-special__map-close button:after {
  transform: rotate(-45deg);
}
.p-special__map-modal {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s, visibility 0.5s;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999999999999;
  width: 100%;
  height: 100%;
  background-color: rgba(235, 101, 107, 0.9);
}
.p-special__map-modal.is-open {
  opacity: 1;
  visibility: visible;
}
.p-special__map-modal .p-special__map-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
.p-special__map-modal .p-special__map-container {
  cursor: default;
  position: absolute;
  top: 5%;
  left: 5%;
  width: 90%;
  max-height: 90%;
  background-color: #fff;
  overflow-y: auto;
  padding-top: 96px;
}
.p-special__map-modal .p-special__map-container img {
  width: 100%;
  height: auto;
}

.p-special__modal {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s, visibility 0.5s;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999999999999;
  width: 100%;
  height: 100%;
  background-color: rgba(235, 101, 107, 0.9);
}
.p-special__modal.is-open {
  opacity: 1;
  visibility: visible;
}
.p-special__modal-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 899px) {
  .p-special__modal-inner {
    width: calc(100% - 20px);
    left: 10px;
  }
}
.p-special__modal-container {
  cursor: default;
  position: absolute;
  width: 100%;
  height: calc(100% - 40px);
  max-width: 880px;
  background-color: #fff;
  border-radius: 20px;
  padding-bottom: 40px;
}
.p-special__modal-contents {
  padding: 0 49px;
  overflow-y: auto;
  height: calc(100dvh - 176px);
}
@media screen and (max-width: 767px) {
  .p-special__modal-contents {
    padding: 0 20px;
  }
}
.p-special__modal-content:not(:nth-child(3)) {
  padding-top: 40px;
  margin-top: 40px;
  border-top: 3px dashed #EB656B;
}
.p-special__modal-close {
  width: 100%;
  height: 96px;
  pointer-events: none;
  z-index: 999999999;
  padding-top: 24px;
  padding-right: 24px;
  display: flex;
  justify-content: flex-end;
}
.p-special__modal-close button {
  pointer-events: auto;
  width: 56px;
  height: 56px;
  background-color: #fff3cd;
  border-radius: 50%;
  position: relative;
}
.p-special__modal-close button:before, .p-special__modal-close button:after {
  content: "";
  display: block;
  width: 22.63px;
  height: 4px;
  background-color: #2e2c1a;
  border-radius: 100px;
  position: absolute;
  top: calc(50% - 2px);
  left: calc(50% - 11.315px);
}
.p-special__modal-close button:before {
  transform: rotate(45deg);
}
.p-special__modal-close button:after {
  transform: rotate(-45deg);
}

.p-sponsorship {
  padding: clamp(55px, 10vw, 80px) 10px clamp(60px, 10vw, 190px);
  background-color: #fff;
}
.p-sponsorship .h2-style {
  color: #EB656B;
}
.p-sponsorship__ttl {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(1.8rem, 2vw, 2.5rem);
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1100px;
  width: 90%;
  margin: auto;
  margin-bottom: clamp(20px, 4vw, 30px);
}
.p-sponsorship__ttl > span {
  flex-shrink: 0;
  white-space: nowrap;
  padding: 0 0.8em;
  min-width: 6em;
  text-align: center;
}
.p-sponsorship__ttl::before, .p-sponsorship__ttl::after {
  content: "";
  display: block;
  width: 100%;
  height: 4px;
  background-color: #FF3369;
  border-radius: 100px;
}
@media screen and (max-width: 767px) {
  .p-sponsorship__ttl::before, .p-sponsorship__ttl::after {
    height: 2px;
  }
}
.p-sponsorship__main {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  max-width: 850px;
  margin: auto;
  margin-bottom: clamp(30px, 4vw, 74px);
}
.p-sponsorship__main a,
.p-sponsorship__main span {
  display: block;
  width: 48%;
}
.p-sponsorship__main a:hover {
  transition: 0.25s;
  opacity: 0.5;
}
@media screen and (max-width: 979px) {
  .p-sponsorship__main {
    max-width: 500px;
  }
}
@media screen and (max-width: 767px) {
  .p-sponsorship__main a,
.p-sponsorship__main span {
    margin-bottom: 12px;
  }
  .p-sponsorship__main a:last-child,
.p-sponsorship__main span:last-child {
    margin-bottom: 0;
  }
}
.p-sponsorship__year, .p-sponsorship__gold, .p-sponsorship__bronze, .p-sponsorship__silver, .p-sponsorship__carrierland, .p-sponsorship__support, .p-sponsorship__personal, .p-sponsorship__sponsor, .p-sponsorship__supporter {
  display: grid;
  max-width: 1100px;
  margin: auto;
  gap: 25px 30px;
}
.p-sponsorship__year{
  grid-template-columns: repeat(3, 1fr);
}
.p-sponsorship__sponsor, .p-sponsorship__carrierland{
  grid-template-columns: repeat(4, 1fr);
}
.p-sponsorship__supporter{
  grid-template-columns: repeat(5, 1fr);
}
.p-sponsorship__year a,
.p-sponsorship__sponsor a,
.p-sponsorship__supporter a,
.p-sponsorship__year span, .p-sponsorship__gold a,
.p-sponsorship__gold span, .p-sponsorship__bronze a,
.p-sponsorship__bronze span, .p-sponsorship__silver a,
.p-sponsorship__silver span, .p-sponsorship__carrierland a,
.p-sponsorship__carrierland span, .p-sponsorship__support a,
.p-sponsorship__support span, .p-sponsorship__personal a,
.p-sponsorship__personal span {
 /*  display: block; */
  border-radius: 8px;
  transition: opacity 0.5s;
}
.p-sponsorship__year a:hover, .p-sponsorship__gold a:hover, .p-sponsorship__bronze a:hover, .p-sponsorship__silver a:hover, .p-sponsorship__carrierland a:hover, .p-sponsorship__support a:hover, .p-sponsorship__personal a:hover, .p-sponsorship__sponsor a:hover,
.p-sponsorship__supporter a:hover {
  transition: opacity 0.25s;
  opacity: 0.5;
}
.p-sponsorship__list {
  margin-bottom: clamp(30px, 4vw, 64px);
}
.p-sponsorship__year a,
.p-sponsorship__year span {
  /* width: 31.5%; */
}
.p-sponsorship__gold, .p-sponsorship__silver, .p-sponsorship__bronze, .p-sponsorship__carrierland, .p-sponsorship__support {
  margin-bottom: clamp(30px, 4vw, 64px);
}
.p-sponsorship__gold a,
.p-sponsorship__gold span, .p-sponsorship__silver a,
.p-sponsorship__silver span, .p-sponsorship__bronze a,
.p-sponsorship__bronze span, .p-sponsorship__carrierland a,
.p-sponsorship__carrierland span, .p-sponsorship__support a,
.p-sponsorship__support span {
  /* width: 22.9%; */
}
.p-sponsorship__personal {
  margin-bottom: clamp(30px, 4vw, 64px);
}
@media screen and (max-width: 979px) {
  .p-sponsorship__personal {
    padding: 0 5px;
    max-width: 500px;
    gap: 10px 10px;
  }
}
.p-sponsorship__personal a,
.p-sponsorship__personal span {
  width: 17.8%;
}
@media screen and (max-width: 979px) {
  .p-sponsorship__personal a,
.p-sponsorship__personal span {
    width: calc((100% - 20px) / 3);
  }
}
@media screen and (max-width: 979px) {
  .p-sponsorship__year, .p-sponsorship__gold, .p-sponsorship__silver, .p-sponsorship__bronze, .p-sponsorship__carrierland, .p-sponsorship__support {
    max-width: 500px;
    gap: 10px 10px;
  }
.p-sponsorship__year a,
.p-sponsorship__year span, .p-sponsorship__gold a,
.p-sponsorship__gold span, .p-sponsorship__silver a,
.p-sponsorship__silver span, .p-sponsorship__bronze a,
.p-sponsorship__bronze span, .p-sponsorship__carrierland a,
.p-sponsorship__carrierland span, .p-sponsorship__support a,
.p-sponsorship__support span {
    /* width: 50%;
    max-width: 220px; */
  }
}
@media screen and (max-width: 767px) {
  .p-sponsorship__main {
    max-width: 230px;
  }
  .p-sponsorship__main a,
.p-sponsorship__main span {
    width: 100%;
  }
  .p-sponsorship__year a,
.p-sponsorship__year span, .p-sponsorship__gold a,
.p-sponsorship__gold span, .p-sponsorship__silver a,
.p-sponsorship__silver span, .p-sponsorship__bronze a,
.p-sponsorship__bronze span, .p-sponsorship__carrierland a,
.p-sponsorship__carrierland span, .p-sponsorship__support a,
.p-sponsorship__support span {
    width: 48%;
  }
}

.p-tw {
  background: linear-gradient(#eb656b 0%, #ffec5a 100%);
  padding: 60px 0 100px;
}
.p-tw__ttl {
  color: #ffffff;
}
.p-tw__ttl .\--ja {
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .p-tw__hash {
    padding: 0 10px;
  }
}
.p-tw__container {
  max-width: 590px;
  margin: auto;
  padding: 0 30px;
  box-sizing: content-box;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-tw__container {
    max-width: 490px;
  }
}
.p-tw__container #hash-list {
  margin-top: 28px;
  max-height: 950px;
  padding: 20px;
  background-color: #ffffff;
  border-radius: 16px;
  overflow-y: scroll;
  -ms-overflow-style: none;
  /* IE and Edge */
  scrollbar-width: none;
  /* Firefox */
}
.p-tw__container #hash-list::-webkit-scrollbar {
  display: none;
}
@media screen and (max-width: 767px) {
  .p-tw__container #hash-list {
    max-height: 357px;
  }
}
.p-tw__container .p-about__noufescanBox {
  position: absolute;
  bottom: -20px;
  right: clamp(-90px, -0.5 * (100vw - 510px) / 2, 10px);
  margin-bottom: 0;
  width: clamp(70px, 20vw, 180px);
  max-width: unset;
  transform: rotateY(180deg);
}

.sp-only {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp-only {
    display: block;
  }
}

.pc-only {
  display: block;
}
@media screen and (max-width: 767px) {
  .pc-only {
    display: none !important;
  }
}

.sp-only-inline {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp-only-inline {
    display: inline;
  }
}

.pc-only-inline {
  display: inline;
}
@media screen and (max-width: 767px) {
  .pc-only-inline {
    display: none !important;
  }
}

.sp-only-flex {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp-only-flex {
    display: flex;
  }
}

.pc-only-flex {
  display: flex;
}
@media screen and (max-width: 767px) {
  .pc-only-flex {
    display: none !important;
  }
}

.mT0 {
  margin-top: 0px;
}

@media screen and (max-width: 979px) {
  .mT20 {
    margin-top: 20px;
  }
}
.mB20 {
  margin-bottom: 20px;
}

.u-pt50 {
  padding-top: 50px;
}

.u-pt85 {
  padding-top: 85px;
}
@media screen and (max-width: 767px) {
  .u-pt85 {
    padding-top: 30px;
  }
}

.u-pt120 {
  padding-top: 120px;
}
@media screen and (max-width: 767px) {
  .u-pt120 {
    padding-top: 30px;
  }
}

.u-pt-half {
  padding-top: 0.6em;
}

.u-fwb {
  font-weight: bold;
}

.u-uppercase {
  text-transform: uppercase;
}

.u-uppercase-none {
  text-transform: none;
}

.u-tc01,
.u-clr-noufes{
  color: #EB656B;
}

.u-tc02,
.u-clr-career{
  color: #F5C62A;
}

.u-tc03{
  color: #4DA4CE;
}

.u-tc04{
  color: #F69F52;
}

.u-tc05{
  color: #D92721;
}

.u-tc06{
  color: #1E7FB8;
}

.u-tc07{
  color: #71B047;
}

.u-fw-b{
  font-weight: 700;
}


.u-trans00{
  opacity: 0;
}

.p-about-noufes__timetable{
  margin-block-start: 0;
  /* padding-top: clamp(40px, 10vw, 60px); */
  padding-bottom: clamp(40px, 10vw, 60px);
  /* background-color: #F7F6F4; */
}

.p-first__timetable-inner{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.p-special__time-table-wrapper{
  max-width: 1100px;
  padding: 0;
}
@media screen and (max-width: 979px) {
  .p-first__timetable-inner{
    grid-template-columns: 1fr;
  }

  .p-special__time-table-inner{
    overflow: hidden;
  }
  .p-special__time-table-wrapper{
    padding: 0 12px;
  }
}

.p-first__timetable-inner > article{
  border: 3px solid;
  border-radius: 10px;
  padding: 16px clamp(1.6rem, 0.755rem + 3.61vw, 4rem);
}
@media screen and (max-width: 979px) {
  .p-first__timetable-inner > article{
    padding: 16px;
  }
}

.p-first__timetable-inner > article.--noufes{
  border-color: #EB656B;
}
.p-first__timetable-inner > article.--career{
  border-color: #F5C62A;
}

.p-first__timetable-inner > article .titlearea{
  display: block;
  width: 100%;
  padding-block-end: 16px;
  border-bottom: 2px dotted;
  filter: brightness(1);
  transition: filter 0.24s ease-in-out;
}
@media (any-hover: hover) {
  .p-first__timetable-inner > article .titlearea:hover{
    filter: brightness(1.15);
  }
}
.p-first__timetable-inner > article.--noufes .titlearea{
  border-color: #EB656B;
}
.p-first__timetable-inner > article.--career .titlearea{
  border-color: #F5C62A;
}

.p-first__timetable-inner > article .timearea{
  padding-block-start: 16px;
}

.p-first__timetable-inner > article .timearea dl{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2em;
  border: none;
}
.p-first__timetable-inner > article .timearea dl:not(:first-of-type){
  margin-block-start: .25em;
}

.p-first__timetable-inner > article .timearea dt{
  white-space: nowrap;
}

.p-first__timetable-inner > article h4,
.p-first__timetable-inner > article dt,
.p-first__timetable-inner > article dd{
  font-size: clamp(1.6rem, 1.459rem + 0.6vw, 2rem);
  font-weight: 700;
}

.p-first__timetable-inner > article h4{
  position: relative;
  left: -.5em;
}

.p-first__timetable-inner > article h4 + p{
  margin-block-start: 4px;
  opacity: .5;
  font-size: clamp(1.4rem, 1.33rem + 0.3vw, 1.6rem);
  font-weight: 700;
}

.p-special__wrapper{
  position: relative;
}
.swingDir.odd .c-swing-img.--noufes{
  top: 0 !important;
  left: 0 !important;
  translate: 10% -50%;
}
.swingDir.even .c-swing-img.--career{
  top: inherit;
  bottom: 0;
  right: 0;
  left: inherit;
  translate: 5px 50%;
}

.p-special__content:first-of-type{
  padding-block-end: 60px;
}
.p-special__content:first-of-type::after{
  bottom: 0;
}

.p-special__content.--noufes > ul,
.p-special__content.--career > ul{
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.p-special__content.--noufes > ul > li,
.p-special__content.--career > ul > li{
  display: grid;
  align-items: center;
  grid-template-columns: 23% 1fr 21%;
  grid-template-rows: repeat(2, auto);
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .p-special__content.--noufes > ul > li,
  .p-special__content.--career > ul > li{
    grid-template-columns: 30% 1fr 21%;
  }
}

.p-special__content.--noufes > ul > li h3,
.p-special__content.--career > ul > li h3{
  grid-area: 1 / 1 / 3 / 2;
}
@media screen and (max-width: 767px) {
  .p-special__content.--noufes > ul > li h3,
  .p-special__content.--career > ul > li h3{
    grid-area: 1 / 1 / 2 / 2;
  }
}

.p-special__content.--noufes > ul > li .cont,
.p-special__content.--career > ul > li .cont{
  grid-area: 1 / 2 / 3 / 3;
}
@media screen and (max-width: 767px) {
  .p-special__content.--noufes > ul > li .cont,
  .p-special__content.--career > ul > li .cont{
    grid-area: 1 / 2 / 2 / 4;
  }
}

.p-special__content.--noufes > ul > li .img,
.p-special__content.--career > ul > li .img{
  grid-area: 1 / 3 / 3 / 4;
}
@media screen and (max-width: 767px) {
  .p-special__content.--noufes > ul > li .img,
  .p-special__content.--career > ul > li .img{
    grid-area: 2 / 1 / 3 / 4;
  }
}


.p-special__content.--noufes > ul > li .cont h4,
.p-special__content.--career > ul > li .cont h4{
  font-size: clamp(2rem, 1.824rem + 0.75vw, 2.5rem);
  line-height: 1.2;
}
.p-special__content.--noufes > ul > li .cont p,
.p-special__content.--career > ul > li .cont p{
  margin-block-start: 1em;
  font-size: clamp(1.4rem, 1.33rem + 0.3vw, 1.6rem);
  line-height: 1.53;
}
@media screen and (max-width: 767px) {
  .p-special__content.--noufes > ul > li .cont p,
  .p-special__content.--career > ul > li .cont p{
    margin-block-start: .5em;
  }
}

.p-kv-image{
  height: auto;
  padding-left: 0;
}
@media screen and (max-width: 979px) {
  .p-kv-image{
    aspect-ratio: auto;
  }
}

/* content stage booth*/
.p-about__noufescanBox.--contentstitle{
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-10%, -80%);
}
@media screen and (max-width: 1079px){
  .p-about__noufescanBox.--contentstitle{
    transform: translate(10%, -80%);
  }
}
.p-special__wrapper.--stage{
  margin-block-start: 0;
  position: relative;
}
@media screen and (max-width: 1079px){
  .p-special__wrapper.--stage{
    margin-block-start: 40px;
  }
}
.p-special__wrapper.--booth{
  margin-block-start: clamp(7.5rem, 4.859rem + 11.27vw, 15rem);
}
.p-special__wrapper.--stage.--day02{
  margin-block-start: clamp(12.5rem, 8.099rem + 18.78vw, 25rem);
  position: relative;
}
.p-special__wrapper.--booth.--day02 .p-special__modal-content,
.p-special__wrapper.--booth.--day02 .p-special__container{
  border-color: #F5C62A;
}
.p-special__wrapper.--booth.--day02 .p-special__container .p-special__content::after{
      background-image: url(../img/special_border-day02.svg);
}
.comingsonn{
  display: grid;
  place-items: center;
  aspect-ratio: 1120/230;
  background-color: #dcdcdc;
  border-radius: 4px;
  color: #fff;
  font-weight: 700;
  text-align: center;
}
.p-special__modal-content .currency{
  display: grid inline;
  place-items: center;
  margin-inline-start: .5em;
  width: 2em;
  translate: 0 25%;
  & img{
    max-width: 100%;
  }
}

.p-stage{
  display: block;
  width: 100%;
  padding-block: clamp(2rem, 1.296rem + 3vw, 4rem);
  border-bottom: 2px dotted;
}
.p-stage.--noufes{
  border-color: #EB656B;
}
.p-stage.--career{
  border-color: #F5C62A;
}
.p-stage h3{
  display: grid;
  grid-template-columns: 4px 1fr;
  gap: .5em;
  margin-block-end: 1em;
  font-size: clamp(1.25rem, 0.986rem + 1.13vw, 2rem);
  font-weight: 700;
  position: relative;
}
.p-stage h3::before{
  display: block;
  content: "";
  width: 4px;
  height: 100%;
  border-radius: 2px;
}
.p-stage.--noufes h3{
  color: #EB656B;
}
.p-stage.--noufes h3::before{
  background-color: #EB656B;
}
.p-stage.--career h3{
  color: #F5C62A;
}
.p-stage.--career h3::before{
  background-color: #F5C62A;
}

.p-stage .col3{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
}
@media screen and (max-width: 767px) {
  .p-stage .col3{
    grid-template-columns: 1fr 1fr;
  }
}
.p-stage .col3 p{
  display: grid;
  place-items: center;
  aspect-ratio: 18/13;
  border-radius: 4px;
  overflow: hidden;
}
.p-stage .col3 p img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.p-stage .col3 h4{
  margin-block-start: 1em;
  font-size: clamp(1rem, 0.824rem + 0.75vw, 1.5rem);
  font-weight: 500;
  text-align: center;
}


/*banner*/
.p-banner-area{
  margin-block-end: clamp(9.375rem, 6.074rem + 14.08vw, 18.75rem);
  background-color: #fff;
  position: relative;
}
.p-banner-area__wrapper{
  width: 100%;
  max-width: 1100px;
  margin-inline: auto;
  padding-inline: 0;
}
@media screen and (max-width: 979px) {
  .p-banner-area__wrapper{
    padding-inline: 12px;
  }
}

.p-banner-area .banner{
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 1120/230;
  filter: brightness(1);
  transition: filter 0.24s ease-in-out;
}
@media (any-hover: hover) {
  .p-banner-area .banner:hover{
    filter: brightness(1.05);
  }
}


/* kv start */
@keyframes shtstra{
  0%{background-position-y:0,100%;}
  50%,100%{background-position-y:0,0%;}
}
@keyframes shtstrb{
  0%,10%{background-position-x:0px,100%;}
  20%,30%{background-position-x:200px,100%;}
  40%,50%{background-position-x:100px,100%;}
  60%,70%{background-position-x:250px,100%;}
  80%,90%{background-position-x:150px,100%;}
}
.shtstr{
  width: 100%;
  height: 100%;
  background-image:
  repeating-linear-gradient(135deg,#000000 0% 49%,#00000000 50%,#000000 51% 100%),
  linear-gradient(#000000 0% 33%,#ffff88 66%,#000000 67% 100%);
  background-size:100% 100%,100% 300%;
  animation:shtstra 1s linear infinite,shtstrb 4s linear infinite;
  position: relative;
}
.swiper-fade .swiper-slide {
  opacity: 0 !important;
  visibility: hidden !important; 
  position: relative;
  background-image: url(../img/kv-noufes-bg.webp);
  background-repeat: no-repeat;
  background-size: auto 100%;
  background-position: top auto;
}
.swiper-fade .swiper-slide .shtstr{
  opacity: 0;
  transition: opacity .5s ease-in;
}
.swiper-fade .swiper-slide .shtstr img{
  opacity: 0;
  transition: opacity 1s 0.8s ease-in;
}
.swiper-fade .swiper-slide.swiper-slide-active {
  opacity: 1 !important;
  visibility: visible !important;
}
.swiper-fade .swiper-slide.swiper-slide-active .shtstr{
  opacity: 1;
}
.swiper-fade .swiper-slide.swiper-slide-active .shtstr img{
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .swiper-slide{
    height: auto;
  }
  .shtstr{
    height: 100%;
    min-height: 100svh;
  }
  .shtstr.--opening{
    height: 100svh;
  }
  .shtstr.--opening img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }
}
/* end kv start */


.u-mt-1em{
  margin-block-start: 1em;
}
.u-mt-5em{
  margin-block-start: 5em;
}


.border-ku{
  border: 3px solid #E55885;
}
.color-ku{
  color: #E55885;
}
.color-ku::before{
  background: #E55885;
}
.color-ku button{
  background: #E55885;
}


.border-neru{
  border: 3px solid #00B6EC;
}
.color-neru{
  color: #00B6EC;
}
.color-neru::before{
  background: #00B6EC;
}
.color-neru button{
  background: #00B6EC;
}


.border-asobu{
  border: 3px solid #EF9725;
}
.color-asobu{
  color: #EF9725;
}
.color-asobu::before{
  background: #EF9725;
}
.color-asobu button{
  background: #EF9725;
}

.p-map{
  margin-block-start: clamp(5rem, 3.182rem + 9.09vw, 10rem);
  & h4{
    font-size: 28px;
    font-weight: 700;
  }
  @media screen and (max-width: 767px) {
    & h4{
      font-size: 20px;
    }
  }
}



/*# sourceMappingURL=maps/style.css.map */
