@charset "UTF-8";
:root {
  --color-black: #000;
  --color-black-02: #1a1a1a;
  --color-white: #fff;
  --color-gray: #f1f1f1;
  --color-gray-02: #ccc;
  --color-deep-red: #c33;
  --color-red: #e45457;
  --color-red-02: #c03;
  --color-red-03: #c66;
  --color-red-04: #e35457;
  --color-light-tone-red: #e35457;
  --color-rose: #d96a5f;
  --color-pink: #c99;
  --color-pink-02: #d98098;
  --color-pink-03: #ed768c;
  --color-yellow: #fc0;
  --color-green: #9c3;
  --color-green-02: #993;
  --color-green-03: #cbdd72;
  --color-blue: #369;
  --color-light-blue: #63b3ce;
  --color-light-blue-02: #6cc;
  --color-brown: #a05933;
  --color-brown-02: #936030;
  --color-light-brown: #efd2ae;
  --color-orange: #e39b2d;
  --color-orange-02: #f60;
  --color-orange-03: #e29a2e;
  --color-orange-04: #f9c200;
  --weight-medium: 500;
  --weight-bold: 700;
  --base-transition-duration: 0.36s;
  --base-fade-duration: 0.16s;
  --base-hover-alpha: 0.7;
}

/* ------------------------
  reset
------------------------ */
html,
body {
  height: 100%;
}

.soy-campaign:where(*) *,
.soy-campaign:where(*) *::after,
.soy-campaign:where(*) *::before {
  box-sizing: border-box;
}
.soy-campaign:where(*) * {
  margin: 0;
  padding: 0;
  font-size: inherit;
  line-height: inherit;
}
.soy-campaign:where(*) pre,
.soy-campaign:where(*) textarea {
  overflow: auto;
}
.soy-campaign:where(*) template {
  display: none;
}
.soy-campaign:where(*) details,
.soy-campaign:where(*) main,
.soy-campaign:where(*) summary {
  display: block;
}
.soy-campaign:where(*) input[type=number] {
  width: auto;
}
.soy-campaign:where(*) input[type=search] {
  -webkit-appearance: textfield;
}
.soy-campaign:where(*) input[type=search]::-webkit-search-cancel-button,
.soy-campaign:where(*) input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}
.soy-campaign:where(*) progress {
  display: inline-block;
}
.soy-campaign:where(*) small {
  font-size: 75%;
}
.soy-campaign:where(*) sub,
.soy-campaign:where(*) sup {
  position: relative;
  vertical-align: baseline;
  font-size: 75%;
  line-height: 0;
}
.soy-campaign:where(*) sup {
  top: -0.5em;
}
.soy-campaign:where(*) sub {
  bottom: -0.25em;
}
.soy-campaign:where(*) textarea {
  resize: vertical;
}
.soy-campaign:where(*) audio,
.soy-campaign:where(*) canvas,
.soy-campaign:where(*) iframe,
.soy-campaign:where(*) img,
.soy-campaign:where(*) svg,
.soy-campaign:where(*) video {
  vertical-align: middle;
}
.soy-campaign:where(*) audio:not([controls]) {
  display: none;
}
.soy-campaign:where(*) img {
  border: 0;
  max-width: 100%;
  height: auto;
}
.soy-campaign:where(*) button,
.soy-campaign:where(*) input,
.soy-campaign:where(*) select,
.soy-campaign:where(*) textarea {
  min-height: 1.5em;
  color: inherit;
  font-family: inherit;
  font-weight: inherit;
  font-style: inherit;
}
.soy-campaign:where(*) button {
  overflow: visible;
}
.soy-campaign:where(*) button,
.soy-campaign:where(*) select {
  text-transform: none;
}
.soy-campaign:where(*) input {
  line-height: normal;
}
.soy-campaign:where(*) button,
.soy-campaign:where(*) html input[type=button],
.soy-campaign:where(*) input[type=reset],
.soy-campaign:where(*) input[type=submit] {
  border-style: none;
  cursor: pointer;
  background-color: transparent;

  -webkit-appearance: button;
}
.soy-campaign:where(*) button[disabled],
.soy-campaign:where(*) html input[disabled] {
  cursor: default;
}
.soy-campaign:where(*) button::-moz-focus-inner,
.soy-campaign:where(*) input::-moz-focus-inner {
  padding: 0;
  border: 0;
}
.soy-campaign:where(*) code,
.soy-campaign:where(*) kbd,
.soy-campaign:where(*) pre,
.soy-campaign:where(*) samp {
  font-family: monospace;
}
.soy-campaign:where(*) ol,
.soy-campaign:where(*) ul {
  list-style: none;
}
.soy-campaign:where(*) select {
     -moz-appearance: none;
  -webkit-appearance: none;
}
.soy-campaign:where(*) table {
  border-spacing: 0;
  border-collapse: collapse;
}
.soy-campaign:where(*) fieldset {
  border: 0;
}

/* ------------------------
  utilities Classes
------------------------ */
.u-hidden {
  display: none !important;
  visibility: hidden;
}

.u-hidden-visible {
  opacity: 0;
  pointer-events: none;
}

@media (max-width: 767.98px) {
  .u-hidden-sm {
    display: none !important;
    visibility: hidden;
  }
}

.u-hidden-up-sm {
  display: none !important;
  visibility: hidden;
}

@media (max-width: 767.98px) {
  .u-hidden-down-sm {
    display: none !important;
    visibility: hidden;
  }
}

@media (min-width: 768px) and (max-width: 1279.98px) {
  .u-hidden-md {
    display: none !important;
    visibility: hidden;
  }
}

@media (min-width: 768px) {
  .u-hidden-up-md {
    display: none !important;
    visibility: hidden;
  }
}

@media (max-width: 1279.98px) {
  .u-hidden-down-md {
    display: none !important;
    visibility: hidden;
  }
}

@media (min-width: 1280px) {
  .u-hidden-lg {
    display: none !important;
    visibility: hidden;
  }
}

@media (min-width: 1280px) {
  .u-hidden-up-lg {
    display: none !important;
    visibility: hidden;
  }
}

.u-hidden-down-lg {
  display: none !important;
  visibility: hidden;
}

.u-visuallyhidden {
  overflow: hidden;
  clip: rect(0 0 0 0);
  position: absolute;
  margin: -1px;
  padding: 0;
  border: 0;
  width: 1px;
  height: 1px;
}

.u-visuallyhidden.focusable:active,
.u-visuallyhidden.focusable:focus {
  overflow: visible;
  clip: auto;
  position: static;
  margin: 0;
  width: auto;
  height: auto;
}

.u-invisible {
  visibility: hidden;
}

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

/* ------------------------
  Print Styles
------------------------ */
@media print {
  *,
  *::before,
  *::after {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }

  a,
  a:visited {
    text-decoration: underline;
  }

  tr,
  img {
    page-break-inside: avoid;
  }

  img {
    max-width: 100% !important;
  }

  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3;
  }

  h2,
  h3 {
    page-break-after: avoid;
  }
}
/* Magnific Popup CSS */
.mfp-bg {
  overflow: hidden;
  opacity: 0.9;
  position: fixed;
  z-index: 1042;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
}
.is-special .mfp-bg,
.is-adventurer .mfp-bg {
  background-color: #2c210e;
}
@media (max-width: 767.98px) {
  .is-special .mfp-bg,
  .is-adventurer .mfp-bg {
    opacity: 0.8;
  }
}
@media (min-width: 768px) {
  .mfp-bg {
    min-width: 1000px;
  }
  .is-special .mfp-bg,
  .is-adventurer .mfp-bg {
    opacity: 0.5;
  }
}

.mfp-wrap {
  position: fixed;
  z-index: 1043;
  top: 0;
  left: 0;
  outline: none !important;
  width: 100%;
  height: 100%;

  -webkit-backface-visibility: hidden;
}
.mfp-wrap::-webkit-scrollbar {
  width: 5px;
}
.mfp-wrap::-webkit-scrollbar-thumb {
  border-radius: 5px;
  background-color: #646464;
}
.mfp-wrap::-webkit-scrollbar-track {
  background-color: #323232;
}

.mfp-container {
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
}
.mfp-container::before {
  content: "";
  display: inline-block;
  height: 100%;
  vertical-align: middle;
}

#bangaihen .mfp-container {
  padding-top: 0;
}

.mfp-align-top .mfp-container::before {
  display: none;
}

.mfp-content {
  display: inline-block;
  position: relative;
  z-index: 1045;
  margin: 0 auto;
  text-align: left;
  vertical-align: middle;
}
@media (max-width: 767.98px) {
  .mfp-content {
    max-width: vw(614, 750);
  }
  .is-adventurer .mfp-content {
    padding-top: 29.3333333333vw;
    padding-bottom: 13.3333333333vw;
    max-width: 80vw;
  }
  .is-special .mfp-content {
    padding-top: 29.3333333333vw;
    padding-bottom: 13.3333333333vw;
    max-width: 88.5333333333vw;
  }
}
@media (min-width: 768px) {
  .mfp-content {
    max-width: vw(1320, 1920);
  }
  .is-special .mfp-content,
  .is-adventurer .mfp-content {
    max-width: max(1274px,99.56077vw);
  }
}

.mfp-inline-holder .mfp-content,
.mfp-ajax-holder .mfp-content {
  width: 100%;
  cursor: auto;
}

.mfp-ajax-cur {
  cursor: progress;
}

.mfp-close,
.mfp-arrow,
.mfp-preloader,
.mfp-counter {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.mfp-zoom-out-cur,
.mfp-zoom-out-cur .mfp-image-holder .mfp-close {
  cursor:         zoom-out;
}

.mfp-zoom {
  cursor: pointer;
  cursor:         zoom-in;
}

.mfp-auto-cursor .mfp-content {
  cursor: auto;
}

.mfp-loading.mfp-figure {
  display: none;
}

.mfp-hide {
  display: none !important;
}

.mfp-preloader {
  position: absolute;
  z-index: 1044;
  top: 50%;
  right: 8px;
  left: 8px;
  margin-top: -0.8em;
  width: auto;
  text-align: center;
  color: #ccc;
}
.mfp-preloader a {
  color: #ccc;
}
.mfp-preloader a:hover {
  color: #fff;
}

.mfp-s-ready .mfp-preloader {
  display: none;
}

.mfp-s-error .mfp-content {
  display: none;
}

button.mfp-close,
button.mfp-arrow {
  display: block;
  overflow: visible;
  z-index: 1046;
  padding: 0;
  border: 0;
  outline: none;
  cursor: pointer;
  background: transparent;
  box-shadow: none;

  -webkit-appearance: none;
  touch-action: manipulation;
}
button::-moz-focus-inner {
  padding: 0;
  border: 0;
}

button.mfp-close {
  opacity: 0.65;
  opacity: 1;
  position: absolute;
  top: 0;
  right: 0;
  background-size: contain;
}
button.mfp-close:hover,
button.mfp-close:focus {
  opacity: 1;
}

.mfp-counter {
  position: absolute;
  top: 0;
  right: 0;
  white-space: nowrap;
  color: #ccc;
  font-size: 12px;
  line-height: 18px;
}

.mfp-arrow {
  top: 50%;
  background: url(/daphne/assets/img/icon_next.png) center no-repeat !important;
  background-size: contain !important;
}
@media (max-width: 767.98px) {
  .mfp-arrow {
    position: fixed;
    margin-top: -4.6666666667vw;
    width: 5.0666666667vw;
    height: 9.3333333333vw;
  }
}
@media (min-width: 768px) {
  .mfp-arrow {
    position: absolute;
    margin-top: min(-2.56222vw, -33px);
    width: max(35px,2.78185vw);
    height: max(65px,5.12446vw);
  }
}

.mfp-arrow-left {
  transform: scaleX(-1);
}
@media (max-width: 767.98px) {
  .mfp-arrow-left {
    left: 2.2666666667vw;
  }
}
@media (min-width: 768px) {
  .mfp-arrow-left {
    left: max(189px,14.78771vw);
  }
}

@media (max-width: 767.98px) {
  .mfp-arrow-right {
    right: 2.2666666667vw;
  }
}
@media (min-width: 768px) {
  .mfp-arrow-right {
    right: max(189px,14.78771vw);
  }
}

.mfp-iframe-holder {
  padding-top: 0;
  padding-bottom: 0;
}
.mfp-iframe-holder .mfp-content {
  width: 100%;
  line-height: 0;
}
.mfp-iframe-scaler {
  padding-top: 56.25%;
  width: 100%;
  height: 0;
}
.mfp-iframe-scaler iframe {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  border: none;
  width: 100%;
  height: 100%;
  background: #000;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
}

/* Main image in popup */
img.mfp-img {
  display: block;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 40px 0 40px;
  width: auto;
  max-width: 100%;
  height: auto;
  line-height: 0;
}

/* The shadow behind the image */
.mfp-figure {
  line-height: 0;
}
.mfp-figure::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  top: 40px;
  right: 0;
  bottom: 40px;
  left: 0;
  width: auto;
  height: auto;
  background: #444;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
}
.mfp-figure small {
  display: block;
  color: #bdbdbd;
  font-size: 12px;
  line-height: 14px;
}
.mfp-figure figure {
  margin: 0;
}

.mfp-bottom-bar {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: -36px;
  width: 100%;
  cursor: auto;
}

.mfp-title {
  padding-right: 36px;
  text-align: left;
  word-wrap: break-word;
  color: #f3f3f3;
  line-height: 18px;
}

.mfp-image-holder .mfp-content {
  max-width: 100%;
}

.mfp-gallery .mfp-image-holder .mfp-figure {
  cursor: pointer;
}

@media screen and (max-width: 768px) and (orientation: landscape), screen and (max-height: 300px) {
  /**
   * Remove all paddings around the image on small screen
   */
  .mfp-img-mobile .mfp-image-holder {
    padding-right: 0;
    padding-left: 0;
  }
  .mfp-img-mobile img.mfp-img {
    padding: 0;
  }
  .mfp-img-mobile .mfp-figure::after {
    top: 0;
    bottom: 0;
  }
  .mfp-img-mobile .mfp-figure small {
    display: inline;
    margin-left: 5px;
  }
  .mfp-img-mobile .mfp-bottom-bar {
    box-sizing: border-box;
    position: fixed;
    top: auto;
    bottom: 0;
    margin: 0;
    padding: 3px 5px;
    background: rgba(0, 0, 0, 0.6);
  }
  .mfp-img-mobile .mfp-bottom-bar:empty {
    padding: 0;
  }
  .mfp-img-mobile .mfp-counter {
    top: 3px;
    right: 5px;
  }
  .mfp-img-mobile .mfp-close {
    position: fixed;
    top: 0;
    right: 0;
    padding: 0;
    width: 35px;
    height: 35px;
    background: rgba(0, 0, 0, 0.6);
    text-align: center;
    line-height: 35px;
  }
}
@media all and (max-width: 768px) {
  .mfp-container {
    padding-right: 0;
    padding-left: 0;
  }
}
.mfp-fade {
  /* overlay at start */
  /* content at start */
}
.mfp-fade.mfp-bg {
  opacity: 0;
  transition: all 0.25s ease-out;
  /* overlay animate in */
  /* overlay animate out */
}
.mfp-fade.mfp-bg.mfp-ready {
  opacity: 0.9;
}
@media (max-width: 767.98px) {
  .is-special .mfp-fade.mfp-bg.mfp-ready,
  .is-adventurer .mfp-fade.mfp-bg.mfp-ready {
    opacity: 0.8;
  }
}
@media (min-width: 768px) {
  .is-special .mfp-fade.mfp-bg.mfp-ready,
  .is-adventurer .mfp-fade.mfp-bg.mfp-ready {
    opacity: 0.5;
  }
}
.mfp-fade.mfp-bg.mfp-removing {
  opacity: 0;
}
.mfp-fade.mfp-wrap {
  /* content animate it */
  /* content animate out */
}
.mfp-fade.mfp-wrap .mfp-container {
  opacity: 0;
  transition: all 0.25s ease-out;
}
.mfp-fade.mfp-wrap.mfp-ready .mfp-container {
  opacity: 1;
}
.mfp-fade.mfp-wrap.mfp-removing .mfp-container {
  opacity: 0;
}

@-webkit-keyframes rotate_360 {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes rotate_360 {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@-webkit-keyframes scaleAnimation {
  0% {
    transform: scale(1);
  }
  45% {
    transform: scale(1.14);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes scaleAnimation {
  0% {
    transform: scale(1);
  }
  45% {
    transform: scale(1.14);
  }
  100% {
    transform: scale(1);
  }
}
.kv-ctn {
  display: grid;
  position: relative;
}
.kv-ctn > .poster {
  position: absolute;
  margin: auto;
  transition: opacity 0.2s cubic-bezier(0, 0, 0.58, 1);

  inset: 0;
}
.kv-ctn > .poster > img {
  width: 100%;
  height: 100% !important;

  -o-object-fit: cover;

     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.kv-ctn > .poster.-play {
  opacity: 0;
}
.kv-ctn > .video {
  pointer-events: none;
}
.kv-ctn.-play > .poster {
  opacity: 0;
}

.lead-ctn {
  position: relative;
  background: url(../../assets/images/lead/bg_sm.jpg) no-repeat top/cover;
}
.lead-ctn :root {
  --color-black: #000;
  --color-black-02: #1a1a1a;
  --color-white: #fff;
  --color-gray: #f1f1f1;
  --color-gray-02: #ccc;
  --color-deep-red: #c33;
  --color-red: #e45457;
  --color-red-02: #c03;
  --color-red-03: #c66;
  --color-red-04: #e35457;
  --color-light-tone-red: #e35457;
  --color-rose: #d96a5f;
  --color-pink: #c99;
  --color-pink-02: #d98098;
  --color-pink-03: #ed768c;
  --color-yellow: #fc0;
  --color-green: #9c3;
  --color-green-02: #993;
  --color-green-03: #cbdd72;
  --color-blue: #369;
  --color-light-blue: #63b3ce;
  --color-light-blue-02: #6cc;
  --color-brown: #a05933;
  --color-brown-02: #936030;
  --color-light-brown: #efd2ae;
  --color-orange: #e39b2d;
  --color-orange-02: #f60;
  --color-orange-03: #e29a2e;
  --color-orange-04: #f9c200;
  --weight-medium: 500;
  --weight-bold: 700;
  --base-transition-duration: 0.36s;
  --base-fade-duration: 0.16s;
  --base-hover-alpha: 0.7;
}
.lead-ctn .txt-box > .txt {
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  letter-spacing: 0.05em;
  color: var(--color-white);
  font-size: 3.2vw;
  font-weight: bold;
  line-height: 1.75;
}
@media (min-width: 768px) {
  .lead-ctn .txt-box > .txt {
    font-size: max(18px, 1.317715959vw);
    line-height: 1.8888888889;
  }
}
.lead-ctn .txt-box > .txt + .txt {
  margin-top: 5.0666666667vw;
}
@media (min-width: 768px) {
  .lead-ctn .txt-box > .txt + .txt {
    margin-top: max(34px, 2.4890190337vw);
  }
}
.lead-ctn .txt-box:not(.-anim) > .txt {
  opacity: 0;

  translate: 0 8vw;
}
@media (min-width: 768px) {
  .lead-ctn .txt-box:not(.-anim) > .txt {
    translate: 0 max(30px, 2.196193265vw);
  }
}
@media (min-width: 768px) {
  .lead-ctn {
    background-image: url(../../assets/images/lead/bg_lg.jpg);
  }
}
@media (min-width: 768px) {
  .lead-ctn > .txt-box {
    translate: max(308px, 22.5475841874vw);
  }
}
.lead-ctn > .annotation {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(calc(-50% + 29.8666666667vw), calc(-50% + 42.1333333333vw));
  color: var(--color-white);
  font-size: 2.4vw;
}
@media (min-width: 768px) {
  .lead-ctn > .annotation {
    transform: translate(calc(-50% + max(372px, 27.2327964861vw)), calc(-50% + max(145px, 10.6149341142vw)));
    font-size: max(9px, 0.6588579795vw);
  }
}

.point-ctn {
  position: relative;
  z-index: 1;
  background-color: var(--color-gray);
}
.point-ctn :root {
  --color-black: #000;
  --color-black-02: #1a1a1a;
  --color-white: #fff;
  --color-gray: #f1f1f1;
  --color-gray-02: #ccc;
  --color-deep-red: #c33;
  --color-red: #e45457;
  --color-red-02: #c03;
  --color-red-03: #c66;
  --color-red-04: #e35457;
  --color-light-tone-red: #e35457;
  --color-rose: #d96a5f;
  --color-pink: #c99;
  --color-pink-02: #d98098;
  --color-pink-03: #ed768c;
  --color-yellow: #fc0;
  --color-green: #9c3;
  --color-green-02: #993;
  --color-green-03: #cbdd72;
  --color-blue: #369;
  --color-light-blue: #63b3ce;
  --color-light-blue-02: #6cc;
  --color-brown: #a05933;
  --color-brown-02: #936030;
  --color-light-brown: #efd2ae;
  --color-orange: #e39b2d;
  --color-orange-02: #f60;
  --color-orange-03: #e29a2e;
  --color-orange-04: #f9c200;
  --weight-medium: 500;
  --weight-bold: 700;
  --base-transition-duration: 0.36s;
  --base-fade-duration: 0.16s;
  --base-hover-alpha: 0.7;
}
.point-ctn .card-box {
  display: grid;
  justify-content: center;

  grid-gap: 3.2vw;
}
@media (min-width: 768px) {
  .point-ctn .card-box {
    grid-template-columns: repeat(3, 1fr);
    grid-gap: max(40px, 2.9282576867vw);
  }
}
@media (max-width: 767.98px) {
  .point-ctn .card-box > .card-item {
    padding-bottom: 7.4666666667vw;
    width: 74.6666666667vw;
  }
}
.point-ctn .card-btn {
  display: grid;
  position: relative;
  border: 1px solid var(--color-red-02);
  border-radius: 50vw;
  transition: opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);

  place-content: center;
}
@media (any-hover: hover) {
  .point-ctn .card-btn:hover {
    opacity: var(--base-hover-alpha);
  }
}
.point-ctn .card-btn > .txt {
  display: block;
  width: 14.9333333333vw;
  font-size: 0;

  margin-inline: auto;
}
@media (min-width: 768px) {
  .point-ctn .card-btn > .txt {
    width: max(60px, 4.39238653vw);
  }
}
.point-ctn .card-btn > .card-arrow {
  position: absolute;
  top: calc(50% - 0.2666666667vw);
  right: 3.7333333333vw;
  width: 4.2666666667vw;
  transform: translateY(-50%);
}
@media (min-width: 768px) {
  .point-ctn .card-btn > .card-arrow {
    top: calc(50% - max(2px, 0.1464128843vw));
    right: max(14px, 1.0248901903vw);
    width: max(16px, 1.1713030747vw);
  }
}
.point-ctn .card-item {
  position: relative;
  z-index: 1;
  border-radius: 2.1333333333vw;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  background-color: var(--color-white);
}
@media (min-width: 768px) {
  .point-ctn .card-item {
    border-radius: max(8px, 0.5856515373vw);
    width: auto;

    -webkit-padding-after: max(58px, 4.2459736457vw);

            padding-block-end: max(58px, 4.2459736457vw);
  }
}
@media (min-width: 768px) {
  .point-ctn .card-item.-second {
    transition-delay: 0.1s;
  }
}
@media (min-width: 768px) {
  .point-ctn .card-item.-third {
    transition-delay: 0.2s;
  }
}
.point-ctn .card-item > .index {
  position: absolute;
  top: 5.6vw;
  right: 4.8vw;
  width: 9.8666666667vw;
}
@media (min-width: 768px) {
  .point-ctn .card-item > .index {
    top: min(-1.8301610542vw, -25px);
    right: max(8px, 0.5856515373vw);
    width: max(56px, 4.0995607613vw);
  }
}
.point-ctn .card-item > .card-btn {
  margin: 3.2vw auto 0;
  width: 53.0666666667vw;
  height: 12vw;
}
@media (min-width: 768px) {
  .point-ctn .card-item > .card-btn {
    margin-top: max(20px, 1.4641288433vw);
    padding: 0 max(13px, 0.9516837482vw);
    width: max(200px, 14.6412884334vw);
    height: max(40px, 2.9282576867vw);
  }
}
.point-ctn .card-item:not(.-anim) {
  opacity: 0;

  translate: 0 8vw;
}
@media (min-width: 768px) {
  .point-ctn .card-item:not(.-anim) {
    translate: 0 max(30px, 2.196193265vw);
  }
}
.point-ctn .card-arrow {
  display: grid;
}
.point-ctn .card-arrow > svg {
  stroke: var(--color-red-02);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
}
.point-ctn .card_caption .txt {
  display: block;
  text-align: center;
  font-size: 5.6vw;
  font-weight: var(--weight-bold);
}
@media (min-width: 768px) {
  .point-ctn .card_caption .txt {
    margin-top: max(3px, 0.2196193265vw);
    font-size: max(28px, 2.0497803807vw);
  }
}
.point-ctn .card_caption .desc {
  display: block;
  text-align: center;
  letter-spacing: 0.05em;
  font-size: 3.2vw;
  font-weight: var(--weight-medium);
  line-height: 1.75;

  -webkit-margin-before: 1.0666666667vw;

          margin-block-start: 1.0666666667vw;
}
@media (min-width: 768px) {
  .point-ctn .card_caption .desc {
    font-size: max(14px, 1.0248901903vw);

    -webkit-margin-before: max(4px, 0.2928257687vw);

            margin-block-start: max(4px, 0.2928257687vw);
  }
}
.point-ctn .cta-arrow {
  display: grid;
}
.point-ctn .cta-arrow > svg {
  stroke: var(--color-white);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
}
.point-ctn .cta-btn {
  display: grid;
  position: relative;
  border-radius: 50vw;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  background-color: var(--color-red-02);

  place-content: center;
}
@media (any-hover: hover) {
  .point-ctn .cta-btn:hover {
    opacity: var(--base-hover-alpha);
  }
}
.point-ctn .cta-btn > .txt {
  width: 46.6666666667vw;
  font-size: 0;
}
@media (min-width: 768px) {
  .point-ctn .cta-btn > .txt {
    width: max(232px, 16.9838945827vw);
  }
}
.point-ctn .cta-btn > .txt img {
  transform: rotate(0.0001deg);
}
.point-ctn .cta-btn > .cta-arrow {
  position: absolute;
  top: calc(50% - 0.8vw);
  right: 4vw;
  width: 4.2666666667vw;
  transform: translateY(-50%);
}
@media (min-width: 768px) {
  .point-ctn .cta-btn > .cta-arrow {
    top: calc(50% - max(2px, 0.1464128843vw));
    right: max(28px, 2.0497803807vw);
    width: max(32px, 2.3426061493vw);
  }
}
.point-ctn .cta-btn:not(.-anim) {
  opacity: 0;

  translate: 0 8vw;
}
@media (min-width: 768px) {
  .point-ctn .cta-btn:not(.-anim) {
    translate: 0 max(30px, 2.196193265vw);
  }
}
@media (min-width: 768px) {
  .point-ctn .sec-ttl {
    display: flex;
    flex-direction: row-reverse;
    justify-content: end;

    gap: max(10px, 0.7320644217vw);
  }
}
.point-ctn .sec-ttl > .ttl {
  width: 42.2666666667vw;
}
@media (max-width: 767.98px) {
  .point-ctn .sec-ttl > .ttl {
    margin-left: auto;
  }
}
@media (min-width: 768px) {
  .point-ctn .sec-ttl > .ttl {
    width: max(274px, 20.0585651537vw);
  }
}
.point-ctn .sec-ttl > .ttlsub {
  text-align: center;
  letter-spacing: 0.05em;
  font-size: 3.2vw;
  font-weight: bold;
}
@media (max-width: 767.98px) {
  .point-ctn .sec-ttl > .ttlsub {
    margin-top: 4.2666666667vw;
  }
}
@media (min-width: 768px) {
  .point-ctn .sec-ttl > .ttlsub {
    padding-top: max(10px, 0.7320644217vw);
    font-size: max(16px, 1.1713030747vw);
  }
}
.point-ctn > .panel {
  position: absolute;
  z-index: -1;
  top: 20vw;
  left: 50%;
  width: 90.6666666667vw;
  height: 48vw;
  transform: translateX(-50%);
  background-color: var(--color-blue);
}
@media (min-width: 768px) {
  .point-ctn > .panel {
    top: max(155px, 11.3469985359vw);
    width: max(1200px, 87.8477306003vw);
    height: max(500px, 36.6032210835vw);
  }
}
@media (min-width: 768px) {
  .point-ctn > .sec-ttl {
    margin: 0 auto;
    width: max(1200px, 87.8477306003vw);

    translate: max(2px, 0.1464128843vw);
  }
}
@media (max-width: 767.98px) {
  .point-ctn > .card-box {
    padding-top: 2.4vw;
  }
}
@media (min-width: 768px) {
  .point-ctn > .card-box {
    margin-top: max(58px, 4.2459736457vw);
    width: max(960px, 70.2781844802vw);

    margin-inline: auto;
  }
}
.point-ctn > .cta-btn {
  margin: 5.8666666667vw auto 0;
  width: 74.6666666667vw;
  height: 19.7333333333vw;
}
@media (min-width: 768px) {
  .point-ctn > .cta-btn {
    margin-top: max(30px, 2.196193265vw);
    width: max(600px, 43.9238653001vw);
    height: max(100px, 7.3206442167vw);
  }
}

.campaign-ctn {
  position: relative;
  z-index: 1;
  background: url(../../assets/images/campaign/bg_sm.png) repeat top/cover;
}
.campaign-ctn :root {
  --color-black: #000;
  --color-black-02: #1a1a1a;
  --color-white: #fff;
  --color-gray: #f1f1f1;
  --color-gray-02: #ccc;
  --color-deep-red: #c33;
  --color-red: #e45457;
  --color-red-02: #c03;
  --color-red-03: #c66;
  --color-red-04: #e35457;
  --color-light-tone-red: #e35457;
  --color-rose: #d96a5f;
  --color-pink: #c99;
  --color-pink-02: #d98098;
  --color-pink-03: #ed768c;
  --color-yellow: #fc0;
  --color-green: #9c3;
  --color-green-02: #993;
  --color-green-03: #cbdd72;
  --color-blue: #369;
  --color-light-blue: #63b3ce;
  --color-light-blue-02: #6cc;
  --color-brown: #a05933;
  --color-brown-02: #936030;
  --color-light-brown: #efd2ae;
  --color-orange: #e39b2d;
  --color-orange-02: #f60;
  --color-orange-03: #e29a2e;
  --color-orange-04: #f9c200;
  --weight-medium: 500;
  --weight-bold: 700;
  --base-transition-duration: 0.36s;
  --base-fade-duration: 0.16s;
  --base-hover-alpha: 0.7;
}
.campaign-ctn .bar-box {
  position: relative;
  z-index: 1;
}
.campaign-ctn .bar-box > .pkg {
  width: 49.6vw;

  translate: 5.3333333333vw;
}
@media (min-width: 768px) {
  .campaign-ctn .bar-box > .pkg {
    margin: 0 auto;
    width: max(468px, 34.2606149341vw);

    translate: min(-7.027818448vw, -96px);
  }
}
.campaign-ctn .bar-box > .bar {
  position: absolute;
  z-index: -1;
  top: 2.9333333333vw;
  left: 30.9333333333vw;
  width: 49.2vw;
}
@media (min-width: 768px) {
  .campaign-ctn .bar-box > .bar {
    top: max(29px, 2.1229868228vw);
    left: max(490px, 35.8711566618vw);
    width: max(444px, 32.5036603221vw);
  }
}
.campaign-ctn .campaign-box {
  position: relative;
  background: url(../../assets/images/campaign/contents_bg_sm.png) no-repeat center/contain;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-box {
    background-image: url(../../assets/images/campaign/contents_bg_lg.png);
  }
}
.campaign-ctn .campaign-box > .campaign-ttl {
  padding-top: 12.2666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-box > .campaign-ttl {
    padding-top: max(102px, 7.467057101vw);
  }
}
.campaign-ctn .campaign-box > .bar-box {
  margin-top: 4.8vw;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-box > .bar-box {
    margin-top: max(52px, 3.8067349927vw);

    translate: min(-1.317715959vw, -18px);
  }
}
.campaign-ctn .campaign-box > .present-box {
  margin-top: 1.6vw;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-box > .present-box {
    margin-top: min(-0.439238653vw, -6px);

    translate: min(-2.196193265vw, -30px);
  }
}
.campaign-ctn .campaign-box > .w-chance {
  margin-top: 8.2666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-box > .w-chance {
    margin-top: min(-1.9033674963vw, -26px);
  }
}
.campaign-ctn .campaign-box > .txt {
  margin-top: 6.4vw;
  text-align: center;
  font-size: 3.2vw;
  font-weight: bold;
  line-height: 1.6666666667;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-box > .txt {
    margin-top: max(34px, 2.4890190337vw);
    font-size: max(14px, 1.0248901903vw);
    line-height: 1.8571428571;
  }
}
.campaign-ctn .campaign-box > .campaign-btn {
  margin: 4.2666666667vw auto 0;
  width: 74.6666666667vw;
  height: 19.7333333333vw;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-box > .campaign-btn {
    margin: max(20px, 1.4641288433vw) auto 0;
    width: max(600px, 43.9238653001vw);
    height: max(100px, 7.3206442167vw);
  }
}
.campaign-ctn .campaign-box > .line-box {
  margin: 4.2666666667vw auto 0;
  padding: 5.8666666667vw 4.8vw 7.4666666667vw;
  width: 74.6666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-box > .line-box {
    margin: max(24px, 1.756954612vw) auto 0;
    padding: max(22px, 1.6105417277vw) 0 max(15px, 1.0980966325vw);
    width: max(670px, 49.0483162518vw);
  }
}
.campaign-ctn .campaign-box > .campaign-txt {
  margin-top: 20.8vw;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-box > .campaign-txt {
    margin-top: max(146px, 10.6881405564vw);
  }
}
.campaign-ctn .campaign-box > .annotation {
  position: absolute;
  right: 5.3333333333vw;
  bottom: -24.5333333333vw;
  font-size: 2.4vw;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-box > .annotation {
    right: min(-10.6149341142vw, -145px);
    bottom: min(-8.4919472914vw, -116px);
    font-size: max(9px, 0.6588579795vw);
  }
}
.campaign-ctn .campaign-btn {
  display: grid;
  position: relative;
  border-radius: 50vw;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  background-color: var(--color-red-02);
  color: var(--color-white);

  place-items: center;
}
@media (any-hover: hover) {
  .campaign-ctn .campaign-btn:hover {
    opacity: var(--base-hover-alpha);
  }
}
.campaign-ctn .campaign-btn > .txt {
  letter-spacing: 0.05em;
  color: var(--color-white);
  font-size: 4vw;
  font-weight: var(--weight-bold);
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-btn > .txt {
    font-size: max(20px, 1.4641288433vw);
  }
}
.campaign-ctn .campaign-btn > .arrow {
  position: absolute;
  top: 50%;
  right: 4.5333333333vw;
  width: 4.8vw;
  transform: translateY(calc(-50% - 0.5333333333vw));
  font-size: 0;

  fill: none;
  stroke: var(--color-white);
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-btn > .arrow {
    right: max(30px, 2.196193265vw);
    width: max(32px, 2.3426061493vw);
    transform: translateY(calc(-50% - max(3px, 0.2196193265vw)));
  }
}
.campaign-ctn .campaign-ttl {
  position: relative;
}
.campaign-ctn .campaign-ttl > .ttl {
  margin: 0 auto;
  width: 76.9333333333vw;
  transform-origin: 50% 60%;
}
@media (max-width: 767.98px) {
  .campaign-ctn .campaign-ttl > .ttl {
    translate: 0.5333333333vw;
  }
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-ttl > .ttl {
    width: max(794px, 58.1259150805vw);
  }
}
.campaign-ctn .campaign-txt > .txt {
  text-align: center;
  color: #2c130a;
  font-size: 3.2vw;
  font-weight: bold;
  line-height: 1.6666666667;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-txt > .txt {
    font-size: max(20px, 1.4641288433vw);
    line-height: 1.5;
  }
}
.campaign-ctn .campaign-txt > .txt > .ttl {
  display: block;
}
.campaign-ctn .campaign-txt > .txt + .txt {
  margin-top: 2.6666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-txt > .txt + .txt {
    margin-top: max(16px, 1.1713030747vw);
  }
}
.campaign-ctn .campaign-txt > .img {
  margin: 1.3333333333vw auto 0;
  width: 70.2666666667vw;

  translate: 0.5333333333vw;
}
@media (min-width: 768px) {
  .campaign-ctn .campaign-txt > .img {
    margin: max(16px, 1.1713030747vw) auto 0;
    width: max(676px, 49.4875549048vw);

    translate: max(4px, 0.2928257687vw);
  }
}
.campaign-ctn .chance-head {
  background-color: var(--color-gray);
}
.campaign-ctn .chance-head > .txt {
  width: 16.8vw;
}
@media (min-width: 768px) {
  .campaign-ctn .chance-head > .txt {
    width: max(126px, 9.224011713vw);

    translate: min(-0.2928257687vw, -4px);
  }
}
.campaign-ctn .chance-txt {
  border-radius: 2.1333333333vw;
  background-color: var(--color-gray);
}
@media (min-width: 768px) {
  .campaign-ctn .chance-txt {
    border-radius: max(16px, 1.1713030747vw);
  }
}
.campaign-ctn .chance-txt > .txt {
  text-align: center;
  letter-spacing: 0.02em;
  font-size: 3.2vw;
  font-weight: bold;
  line-height: 1.5;
}
@media (min-width: 768px) {
  .campaign-ctn .chance-txt > .txt {
    font-size: max(24px, 1.756954612vw);
    line-height: 1.4;
  }
}
.campaign-ctn .chance-txt > .txt > .lg {
  display: block;
  font-size: 4.2666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .chance-txt > .txt > .lg {
    font-size: max(32px, 2.3426061493vw);
  }
}
.campaign-ctn .close-box > .panel {
  position: absolute;
  z-index: 4;
  top: 22.6666666667vw;
  left: 50%;
  width: 85.3333333333vw;

  translate: -50%;
}
@media (min-width: 768px) {
  .campaign-ctn .close-box > .panel {
    top: max(148px, 10.8345534407vw);
    width: max(800px, 58.5651537335vw);
  }
}
.campaign-ctn .close-box > .bg {
  position: absolute;
  z-index: 3;
  top: 0;
  width: 100%;
  height: 966.9333333333vw;
  background-color: color-mix(in srgb, var(--color-black-02), transparent 15%);
}
@media (min-width: 768px) {
  .campaign-ctn .close-box > .bg {
    height: max(3374px, 246.9985358712vw);
  }
}
.campaign-ctn .contact-block {
  position: relative;
}
.campaign-ctn .contact-block > .panel {
  position: absolute;
  z-index: -1;
  top: 5.8666666667vw;
  left: 0;
  width: 100%;
  height: 48vw;
  background-color: var(--color-red-04);

  -webkit-clip-path: polygon(0 0, 36.5% 0, 36.5% 10%, 100% 10%, 100% 100%, 0 100%);

          clip-path: polygon(0 0, 36.5% 0, 36.5% 10%, 100% 10%, 100% 100%, 0 100%);
}
@media (min-width: 768px) {
  .campaign-ctn .contact-block > .panel {
    top: max(50px, 3.6603221083vw);
    height: max(400px, 29.2825768668vw);

    -webkit-clip-path: polygon(0 0, 65.5% 0, 65.5% 9%, 100% 9%, 100% 100%, 0 100%);

            clip-path: polygon(0 0, 65.5% 0, 65.5% 9%, 100% 9%, 100% 100%, 0 100%);
  }
}
.campaign-ctn .contact-block > .ttl {
  margin-left: auto;
  width: 58vw;
}
@media (min-width: 768px) {
  .campaign-ctn .contact-block > .ttl {
    width: max(410px, 30.0146412884vw);
  }
}
.campaign-ctn .contact-block > .contact-body {
  margin: 5.3333333333vw auto 0;
  padding: 8.5333333333vw 0 9.6vw;
  width: 74.6666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .contact-block > .contact-body {
    margin: max(28px, 2.0497803807vw) auto 0;
    padding: max(52px, 3.8067349927vw) 0 max(38px, 2.7818448023vw);
    width: max(800px, 58.5651537335vw);
  }
}
.campaign-ctn .contact-body {
  position: relative;
  border-radius: 1.3333333333vw;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  background-color: var(--color-white);
}
@media (min-width: 768px) {
  .campaign-ctn .contact-body {
    border-radius: max(10px, 0.7320644217vw);
  }
}
.campaign-ctn .contact-body > .ttl {
  text-align: center;
  font-size: 4vw;
  font-weight: var(--weight-bold);
}
@media (min-width: 768px) {
  .campaign-ctn .contact-body > .ttl {
    font-size: max(24px, 1.756954612vw);
  }
}
.campaign-ctn .contact-body > .cp {
  margin-top: 5.8666666667vw;
  text-align: center;
  font-size: 4vw;
  font-weight: bold;
  line-height: 1.4;
}
@media (min-width: 768px) {
  .campaign-ctn .contact-body > .cp {
    margin-top: max(25px, 1.8301610542vw);
    letter-spacing: 0.05em;
    font-size: max(20px, 1.4641288433vw);
    line-height: 1.2;
  }
}
.campaign-ctn .contact-body > .txt {
  margin-top: 7.2vw;
  text-align: center;
  font-size: 3.2vw;
  font-weight: 900;
  line-height: 1.3333333333;
}
@media (min-width: 768px) {
  .campaign-ctn .contact-body > .txt {
    margin-top: max(23px, 1.6837481698vw);
    font-size: max(16px, 1.1713030747vw);
    line-height: 1.5;
  }
}
.campaign-ctn .contact-body > .txt.-sm {
  font-size: 2.6666666667vw;
  line-height: 1.65;
}
@media (max-width: 767.98px) {
  .campaign-ctn .contact-body > .txt.-sm {
    margin-top: 0 !important;
  }
}
@media (min-width: 768px) {
  .campaign-ctn .contact-body > .txt.-sm {
    font-size: max(12px, 0.878477306vw);
    line-height: 2;
  }
}
.campaign-ctn .contact-body > .txt + .txt {
  margin-top: 3.4666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .contact-body > .txt + .txt {
    margin-top: 0;
  }
}
@media (min-width: 768px) {
  .campaign-ctn .contact-body > .txt .promise {
    display: inline-block;

    margin-inline: max(10px, 0.7320644217vw);
  }
}
.campaign-ctn .contact-body .term {
  margin: 4.8vw auto 0;
  padding: 3.2vw 3.7333333333vw;
  width: 62.9333333333vw;
  background-color: var(--color-gray);
  letter-spacing: 0.05em;
  font-size: 2.6666666667vw;
  line-height: 1.75;
}
@media (min-width: 768px) {
  .campaign-ctn .contact-body .term {
    margin-top: max(32px, 2.3426061493vw);
    padding: max(20px, 1.4641288433vw) max(32px, 2.3426061493vw);
    width: max(700px, 51.2445095168vw);
    font-size: max(11px, 0.8052708638vw);
    line-height: 1.7272727273;
  }
}
.campaign-ctn .contact-body:not(.-anim) {
  opacity: 0;

  translate: 0 8vw;
}
@media (min-width: 768px) {
  .campaign-ctn .contact-body:not(.-anim) {
    translate: 0 max(30px, 2.196193265vw);
  }
}
.campaign-ctn .contact-box > .contact-block {
  margin: 0 auto;
  width: 90.6666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .contact-box > .contact-block {
    width: max(1200px, 87.8477306003vw);
  }
}
.campaign-ctn .line-box {
  background-color: var(--color-gray);
}
@media (min-width: 768px) {
  .campaign-ctn .line-box {
    text-align: center;
  }
}
.campaign-ctn .line-box > .txt {
  display: flex;
  letter-spacing: 0.05em;
  font-size: 2.6666666667vw;
  line-height: 1.75;
}
@media (min-width: 768px) {
  .campaign-ctn .line-box > .txt {
    justify-content: center;
    font-size: max(11px, 0.8052708638vw);
    line-height: 1.7272727273;
  }
}
.campaign-ctn .line-box > .txt::before {
  content: "※";
}
.campaign-ctn .line-box > .btn {
  display: block;
  margin-top: 2.6666666667vw;
  cursor: pointer;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  text-decoration: underline;
  font-size: 2.9333333333vw;
}
@media (min-width: 768px) {
  .campaign-ctn .line-box > .btn {
    margin: max(6px, 0.439238653vw) auto 0;
    font-size: max(14px, 1.0248901903vw);
  }
}
@media (any-hover: hover) {
  .campaign-ctn .line-box > .btn:hover {
    opacity: var(--base-hover-alpha);
  }
}
.campaign-ctn .list-box {
  background-color: var(--color-white);
}
.campaign-ctn .list-box > .step-list {
  translate: 0 -8vw;
}
@media (min-width: 768px) {
  .campaign-ctn .list-box > .step-list {
    translate: 0 min(-4.39238653vw, -60px);
  }
}
.campaign-ctn .list-ttl {
  display: flex;
  justify-content: center;
  position: relative;
}
.campaign-ctn .list-ttl > .ttl {
  display: flex;
  letter-spacing: 0.05em;
  font-size: 5.6vw;
  font-weight: bold;

  gap: 4.8vw;
}
@media (min-width: 768px) {
  .campaign-ctn .list-ttl > .ttl {
    font-size: max(30px, 2.196193265vw);

    gap: max(32px, 2.3426061493vw);
  }
}
.campaign-ctn .list-ttl > .ttl::before,
.campaign-ctn .list-ttl > .ttl::after {
  content: "";
  width: 0.5333333333vw;
  height: 6.6666666667vw;
  transition: bottom;
  background-color: var(--color-black);
}
@media (min-width: 768px) {
  .campaign-ctn .list-ttl > .ttl::before,
  .campaign-ctn .list-ttl > .ttl::after {
    width: max(2px, 0.1464128843vw);
    height: max(34px, 2.4890190337vw);
  }
}
.campaign-ctn .list-ttl > .ttl::before {
  rotate: -24deg;
}
.campaign-ctn .list-ttl > .ttl::after {
  rotate: 24deg;
}
.campaign-ctn .list-ttl > .bg {
  position: absolute;
  z-index: -1;
  top: 2.6666666667vw;
  left: 50%;
  width: 46vw;
  transform: translateX(-50%);
}
@media (min-width: 768px) {
  .campaign-ctn .list-ttl > .bg {
    top: max(12px, 0.878477306vw);
    width: max(255px, 18.6676427526vw);
  }
}
.campaign-ctn .modal-btn {
  display: block;
  position: relative;
  border: 2px solid var(--color-black);
  cursor: pointer;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  background-color: var(--color-white);
}
@media (any-hover: hover) {
  .campaign-ctn .modal-btn:hover {
    opacity: var(--base-hover-alpha);
  }
}
.campaign-ctn .modal-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 4.2666666667vw;
  width: 4vw;
  background: url(../../assets/images/common/icon_info.svg) no-repeat center/contain;

  translate: 0% -50%;
  aspect-ratio: 1;
}
@media (min-width: 768px) {
  .campaign-ctn .modal-btn::after {
    right: max(52px, 3.8067349927vw);
    width: max(26px, 1.9033674963vw);
  }
}
.campaign-ctn .modal-btn > .txt {
  text-align: center;
  letter-spacing: 0.05em;
  font-size: 4vw;
  font-weight: var(--weight-bold);
  line-height: 1;
}
@media (min-width: 768px) {
  .campaign-ctn .modal-btn > .txt {
    font-size: max(24px, 1.756954612vw);
  }
}
.campaign-ctn .modal-btn:not(.-anim) {
  opacity: 0;

  translate: 0 8vw;
}
@media (min-width: 768px) {
  .campaign-ctn .modal-btn:not(.-anim) {
    translate: 0 max(30px, 2.196193265vw);
  }
}
.campaign-ctn .present-box {
  display: grid;
  justify-content: center;
  position: relative;

  gap: 16vw;
}
@media (min-width: 768px) {
  .campaign-ctn .present-box {
    margin-top: max(10px, 0.7320644217vw);

    grid-template-columns: max(443px, 32.4304538799vw) max(368px, 26.9399707174vw);
    gap: max(106px, 7.7598828697vw);
  }
}
.campaign-ctn .present-box::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 66.6666666667vw;
  height: 1px;
  transform: translate(-50%, -50%);
  background-color: #300;
}
@media (min-width: 768px) {
  .campaign-ctn .present-box::before {
    width: 1px;
    height: max(288px, 21.0834553441vw);
    transform: translate(calc(-50% + max(30px, 2.196193265vw)), calc(-50% - max(12px, 0.878477306vw)));
  }
}
@media (max-width: 767.98px) {
  .campaign-ctn .present-txt.-first > .txt {
    margin: 0 auto;
    width: 66.9333333333vw;

    translate: -2.1333333333vw;
  }
}
@media (max-width: 767.98px) {
  .campaign-ctn .present-txt.-second > .txt {
    margin: 0 auto;
    width: 56.1333333333vw;
  }
}
.campaign-ctn .present-txt > .winners-box {
  margin-top: 4vw;
}
@media (min-width: 768px) {
  .campaign-ctn .present-txt > .winners-box {
    margin-top: max(26px, 1.9033674963vw);
  }
}
@media (min-width: 768px) {
  .campaign-ctn .present-txt > .winners-box.-first {
    translate: max(20px, 1.4641288433vw);
  }
}
.campaign-ctn .share-box {
  overflow: hidden;
  border-radius: 1.3333333333vw;
  background-color: #f6e4cc;
}
@media (min-width: 768px) {
  .campaign-ctn .share-box {
    display: grid;
    justify-content: center;

    grid-template-areas: "phone ttl" "phone txt";
  }
}
.campaign-ctn .share-box > .ttl {
  color: var(--color-orange-02);
  font-size: 4.8vw;
  font-weight: bold;
  line-height: 1.3888888889;
}
@media (max-width: 767.98px) {
  .campaign-ctn .share-box > .ttl {
    text-align: center;
  }
}
@media (min-width: 768px) {
  .campaign-ctn .share-box > .ttl {
    align-self: flex-end;
    margin-top: min(-0.3660322108vw, -5px);
    font-size: max(30px, 2.196193265vw);
    line-height: 1;

    grid-area: ttl;
  }
}
.campaign-ctn .share-box > .share-txt {
  margin-top: 3.2vw;
}
@media (min-width: 768px) {
  .campaign-ctn .share-box > .share-txt {
    margin-top: max(10px, 0.7320644217vw);
    transition-delay: 0.14s;

    grid-area: txt;
  }
}
.campaign-ctn .share-box > .phone {
  margin: 1.6vw auto 0;
  width: 40.9333333333vw;
}
@media (max-width: 767.98px) {
  .campaign-ctn .share-box > .phone {
    translate: 1.0666666667vw 0;
  }
}
@media (min-width: 768px) {
  .campaign-ctn .share-box > .phone {
    margin: 0 0 0 min(-1.1713030747vw, -16px);
    width: max(199px, 14.5680819912vw);

    grid-area: phone;
  }
}
.campaign-ctn .share-list > .list {
  font-size: 3.2vw;
  font-weight: bold;
  line-height: 1.75;
}
.campaign-ctn .share-list > .list::before {
  content: "※";
}
@media (min-width: 768px) {
  .campaign-ctn .share-list > .list {
    display: flex;
    font-size: max(14px, 1.0248901903vw);
    line-height: 1.7142857143;
  }
}
@media (max-width: 767.98px) {
  .campaign-ctn .share-txt {
    text-align: center;
  }
}
.campaign-ctn .share-txt > .txt {
  font-size: 3.2vw;
  font-weight: bold;
  line-height: 1.75;
}
@media (min-width: 768px) {
  .campaign-ctn .share-txt > .txt {
    font-size: max(14px, 1.0248901903vw);
    line-height: 1.7142857143;
  }
}
.campaign-ctn .step-list {
  display: grid;
  position: relative;

  gap: 6.4vw;
}
@media (min-width: 768px) {
  .campaign-ctn .step-list {
    justify-content: center;

    grid-template-columns: repeat(4, max(248px, 18.1551976574vw));
    gap: max(20px, 1.4641288433vw);
  }
}
@media (min-width: 768px) {
  .campaign-ctn .list-item:nth-of-type(1) {
    transition-delay: 0.1s;
  }
}
@media (min-width: 768px) {
  .campaign-ctn .list-item:nth-of-type(2) {
    transition-delay: 0.2s;
  }
}
@media (min-width: 768px) {
  .campaign-ctn .list-item:nth-of-type(3) {
    transition-delay: 0.3s;
  }
}
@media (min-width: 768px) {
  .campaign-ctn .list-item:nth-of-type(4) {
    transition-delay: 0.4s;
  }
}
@media (min-width: 768px) {
  .campaign-ctn .list-item.-first > .txt.-sm {
    margin-top: max(10px, 0.7320644217vw);
  }
}
@media (max-width: 767.98px) {
  .campaign-ctn .list-item > .img {
    margin: 0 auto;
    width: 54vw;
  }
}
.campaign-ctn .list-item > .txt {
  margin-top: 1.0666666667vw;
  text-align: center;
  color: var(--color-orange-02);
  font-size: 4vw;
  font-weight: bold;
}
@media (min-width: 768px) {
  .campaign-ctn .list-item > .txt {
    margin-top: max(22px, 1.6105417277vw);
    font-size: max(20px, 1.4641288433vw);
    line-height: 1.5;
  }
}
.campaign-ctn .list-item > .txt.-sm {
  margin-top: 0;
  text-align: center;
  color: var(--color-black);
  font-size: 3.2vw;
  line-height: 1.75;
}
@media (min-width: 768px) {
  .campaign-ctn .list-item > .txt.-sm {
    margin-top: max(16px, 1.1713030747vw);
    font-size: max(14px, 1.0248901903vw);
    line-height: 1.7142857143;
  }
}
.campaign-ctn .w-chance > .chance-head {
  display: flex;
  justify-content: center;
  margin: 0 auto;
  padding-top: 4.2666666667vw;
  border-radius: 50vw;
  width: 22.4vw;

  aspect-ratio: 1;
}
@media (min-width: 768px) {
  .campaign-ctn .w-chance > .chance-head {
    padding-top: max(32px, 2.3426061493vw);
    width: max(168px, 12.298682284vw);
  }
}
.campaign-ctn .w-chance > .chance-txt {
  margin: -11.7333333333vw auto 0;
  padding: 4.2666666667vw 0 2.9333333333vw;
  width: 74.6666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .w-chance > .chance-txt {
    margin: min(-6.4421669107vw, -88px) auto 0;
    padding: max(30px, 2.196193265vw) 0 max(20px, 1.4641288433vw);
    width: max(670px, 49.0483162518vw);
  }
}
.campaign-ctn .winners-box {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  position: relative;
  z-index: 1;

  gap: 1.0666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .winners-box {
    gap: max(6px, 0.439238653vw);
  }
}
.campaign-ctn .winners-box > .num {
  transform-origin: 50% 100%;
}
.campaign-ctn .winners-box > .num.-five {
  width: 5.7333333333vw;
}
@media (min-width: 768px) {
  .campaign-ctn .winners-box > .num.-five {
    width: max(37px, 2.7086383602vw);
  }
}
.campaign-ctn .winners-box > .num.-fifty {
  width: 12.6666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn .winners-box > .num.-fifty {
    width: max(82px, 6.0029282577vw);
  }
}
.campaign-ctn .winners-box > .people {
  width: 11.2vw;
}
@media (min-width: 768px) {
  .campaign-ctn .winners-box > .people {
    width: max(72px, 5.270863836vw);
  }
}
.campaign-ctn .winners-box > .line {
  position: absolute;
  z-index: -1;
  bottom: -1.3333333333vw;
  left: 50%;
  width: 27.4666666667vw;
  height: 2.9333333333vw;
  transform-origin: 0% 50%;
  background-color: #fadead;

  translate: -50%;
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
}
@media (min-width: 768px) {
  .campaign-ctn .winners-box > .line {
    bottom: min(-0.7320644217vw, -10px);
    width: max(178px, 13.0307467057vw);
    height: max(20px, 1.4641288433vw);
  }
}
@media (min-width: 768px) {
  .campaign-ctn {
    background: url(../../assets/images/campaign/bg_lg.png) repeat top/cover;
  }
}
.campaign-ctn > .ttl {
  position: absolute;
  z-index: 5;
  top: 0;
  width: 68.6666666667vw;
  background-color: var(--color-gray);

  translate: -0.2666666667vw -50%;
}
@media (min-width: 768px) {
  .campaign-ctn > .ttl {
    width: max(550px, 40.2635431918vw);

    translate: 0 -50%;
  }
}
.campaign-ctn > .campaign-box {
  margin: 0 auto;
  width: 85.3333333333vw;
  height: 475.4666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn > .campaign-box {
    width: max(1116px, 81.6983894583vw);
    height: max(2290px, 167.6427525622vw);
  }
}
.campaign-ctn > .list-ttl {
  margin-top: 10.6666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn > .list-ttl {
    margin-top: max(108px, 7.906295754vw);
  }
}
.campaign-ctn > .list-box {
  margin: 14.4vw auto 0;
  padding-bottom: 62.9333333333vw;
  width: 90.6666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn > .list-box {
    margin: max(106px, 7.7598828697vw) auto 0;
    padding-bottom: max(128px, 9.3704245974vw);
    width: max(1200px, 87.8477306003vw);
  }
}
.campaign-ctn > .share-box {
  margin: -60.2666666667vw auto 0;
  padding: 6.9333333333vw 0 0;
  width: 82.6666666667vw;
}
@media (min-width: 768px) {
  .campaign-ctn > .share-box {
    margin: min(-11.7130307467vw, -160px) auto 0;
    padding: max(9px, 0.6588579795vw) 0 0;
    width: max(1000px, 73.2064421669vw);
  }
}
.campaign-ctn > .campaign-btn {
  margin: 7.4666666667vw auto 0;
  width: 74.6666666667vw;
  height: 19.7333333333vw;
}
@media (min-width: 768px) {
  .campaign-ctn > .campaign-btn {
    margin: max(26px, 1.9033674963vw) auto 0;
    width: max(600px, 43.9238653001vw);
    height: max(100px, 7.3206442167vw);
  }
}
.campaign-ctn > .modal-btn {
  margin: 4.8vw auto 0;
  width: 74.6666666667vw;
  height: 19.2vw;
}
@media (min-width: 768px) {
  .campaign-ctn > .modal-btn {
    margin-top: max(26px, 1.9033674963vw);
    width: max(800px, 58.5651537335vw);
    height: max(122px, 8.9311859444vw);
  }
}
.campaign-ctn > .contact-box {
  margin-top: 16vw;
}
@media (min-width: 768px) {
  .campaign-ctn > .contact-box {
    margin-top: max(75px, 5.4904831625vw);
  }
}
.campaign-ctn > .gradient {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1.3333333333vw;
  background: linear-gradient(90deg, var(--color-gray-02) 0%, var(--color-gray-02) calc(100% / var(--maxNum) * 1), var(--color-red-04) calc(100% / var(--maxNum) * 1), var(--color-red-04) calc(100% / var(--maxNum) * 2), var(--color-pink-02) calc(100% / var(--maxNum) * 2), var(--color-pink-02) calc(100% / var(--maxNum) * 3), var(--color-blue) calc(100% / var(--maxNum) * 3), var(--color-blue) calc(100% / var(--maxNum) * 4), var(--color-green-02) calc(100% / var(--maxNum) * 4), var(--color-green-02) calc(100% / var(--maxNum) * 5), var(--color-brown) calc(100% / var(--maxNum) * 5), var(--color-brown) calc(100% / var(--maxNum) * 6), var(--color-light-blue-02) calc(100% / var(--maxNum) * 6), var(--color-light-blue-02) 100%);

  --maxNum: 7;
}
@media (min-width: 768px) {
  .campaign-ctn > .gradient {
    height: max(6px, 0.439238653vw);
    background: linear-gradient(90deg, var(--color-gray-02) 0%, var(--color-gray-02) calc(100% / var(--maxNum) * 1), var(--color-red-04) calc(100% / var(--maxNum) * 1), var(--color-red-04) calc(100% / var(--maxNum) * 2), var(--color-pink-02) calc(100% / var(--maxNum) * 2), var(--color-pink-02) calc(100% / var(--maxNum) * 3), var(--color-blue) calc(100% / var(--maxNum) * 3), var(--color-blue) calc(100% / var(--maxNum) * 4), var(--color-green-02) calc(100% / var(--maxNum) * 4), var(--color-green-02) calc(100% / var(--maxNum) * 5), var(--color-brown) calc(100% / var(--maxNum) * 5), var(--color-brown) calc(100% / var(--maxNum) * 6), var(--color-light-blue-02) calc(100% / var(--maxNum) * 6), var(--color-light-blue-02) calc(100% / var(--maxNum) * 7), var(--color-gray-02) calc(100% / var(--maxNum) * 7), var(--color-gray-02) calc(100% / var(--maxNum) * 8), var(--color-red-04) calc(100% / var(--maxNum) * 8), var(--color-red-04) calc(100% / var(--maxNum) * 9), var(--color-pink-02) calc(100% / var(--maxNum) * 9), var(--color-pink-02) calc(100% / var(--maxNum) * 10), var(--color-blue) calc(100% / var(--maxNum) * 10), var(--color-blue) calc(100% / var(--maxNum) * 11), var(--color-green-02) calc(100% / var(--maxNum) * 11), var(--color-green-02) calc(100% / var(--maxNum) * 12), var(--color-brown) calc(100% / var(--maxNum) * 12), var(--color-brown) calc(100% / var(--maxNum) * 13), var(--color-light-blue-02) calc(100% / var(--maxNum) * 13), var(--color-light-blue-02) 100%);

    --maxNum: 14;
  }
}

.about-ctn {
  position: relative;
  background-color: var(--color-light-blue);
}
.about-ctn > .ttl {
  margin-left: auto;
  width: 83.4666666667vw;
  background-color: var(--color-white);

  translate: 0.5333333333vw -7.2vw;
}
@media (min-width: 768px) {
  .about-ctn > .ttl {
    width: max(599px, 43.850658858vw);

    translate: max(3px, 0.2196193265vw) min(-3.6603221083vw, -50px);
  }
}
.about-ctn > .txt {
  opacity: 0;
  margin: 4.2666666667vw 0 0 10.1333333333vw;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  letter-spacing: 0.05em;
  color: var(--color-white);
  font-size: 3.2vw;
  font-weight: bold;
  line-height: 1.7083333333;

  translate: 0 8vw;
}
@media (min-width: 768px) {
  .about-ctn > .txt {
    margin: max(36px, 2.635431918vw) 0 0 max(180px, 13.17715959vw);
    letter-spacing: 0.08em;
    font-size: max(18px, 1.317715959vw);
    line-height: 1.8888888889;

    translate: 0 max(30px, 2.196193265vw);
  }
}
.about-ctn > .txt + .txt {
  margin-top: 5.8666666667vw;
}
@media (min-width: 768px) {
  .about-ctn > .txt + .txt {
    margin-top: max(34px, 2.4890190337vw);
  }
}
.about-ctn > .txt.-anim,
.about-ctn > .txt.-anim + .txt {
  opacity: 1;

  translate: 0;
}
.about-ctn > .annotation {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(calc(-50% + 27.7333333333vw), calc(-50% + 68.8vw));
  letter-spacing: 0.05em;
  color: var(--color-white);
  font-size: 2.1333333333vw;
}
.about-ctn > .soyjoy {
  width: 72.5333333333vw;
}
@media (max-width: 767.98px) {
  .about-ctn > .soyjoy {
    margin: 3.2vw auto 0;

    translate: -0.2666666667vw;
  }
}
@media (min-width: 768px) {
  .about-ctn > .soyjoy {
    position: absolute;
    top: 50%;
    left: 50%;
    width: max(394px, 28.8433382138vw);
    transform: translate(calc(-50% + max(238px, 17.4231332357vw)), calc(-50% + max(18px, 1.317715959vw)));
  }
}
.about-ctn > .deco.-first {
  position: absolute;
  bottom: -10.9333333333vw;
  left: -30.1333333333vw;
  width: 49.6vw;
}
@media (min-width: 768px) {
  .about-ctn > .deco.-first {
    bottom: max(20px, 1.4641288433vw);
    left: min(-13.9092240117vw, -190px);
    width: max(390px, 28.5505124451vw);
  }
}
.about-ctn > .deco.-second {
  position: absolute;
  top: 28vw;
  right: -31.4666666667vw;
  width: 46.5333333333vw;
}
@media (min-width: 768px) {
  .about-ctn > .deco.-second {
    top: max(36px, 2.635431918vw);
    right: min(-17.0571010249vw, -233px);
    width: max(420px, 30.7467057101vw);
  }
}

.scene-ctn :root {
  --color-black: #000;
  --color-black-02: #1a1a1a;
  --color-white: #fff;
  --color-gray: #f1f1f1;
  --color-gray-02: #ccc;
  --color-deep-red: #c33;
  --color-red: #e45457;
  --color-red-02: #c03;
  --color-red-03: #c66;
  --color-red-04: #e35457;
  --color-light-tone-red: #e35457;
  --color-rose: #d96a5f;
  --color-pink: #c99;
  --color-pink-02: #d98098;
  --color-pink-03: #ed768c;
  --color-yellow: #fc0;
  --color-green: #9c3;
  --color-green-02: #993;
  --color-green-03: #cbdd72;
  --color-blue: #369;
  --color-light-blue: #63b3ce;
  --color-light-blue-02: #6cc;
  --color-brown: #a05933;
  --color-brown-02: #936030;
  --color-light-brown: #efd2ae;
  --color-orange: #e39b2d;
  --color-orange-02: #f60;
  --color-orange-03: #e29a2e;
  --color-orange-04: #f9c200;
  --weight-medium: 500;
  --weight-bold: 700;
  --base-transition-duration: 0.36s;
  --base-fade-duration: 0.16s;
  --base-hover-alpha: 0.7;
}
.scene-ctn .foot-txt {
  display: grid;
  transform: rotate(0.0001deg);
  background-color: var(--color-red-02);

  place-content: center;
}
.scene-ctn .foot-txt > .txt {
  margin: 0 auto;
  width: 74.4vw;
}
@media (min-width: 768px) {
  .scene-ctn .foot-txt > .txt {
    width: max(1136px, 83.1625183016vw);
  }
}
.scene-ctn .gradient-pagination {
  display: grid;

  grid-template-columns: repeat(7, 1fr);
}
.scene-ctn .gradient-pagination .pagination {
  cursor: pointer;
  transition: opacity 0.2s;
  transform-origin: 50% 100%;
}
.scene-ctn .gradient-pagination .pagination:nth-of-type(1) {
  background-color: #d1c9bb;
}
@media (any-hover: hover) {
  .scene-ctn .gradient-pagination .pagination:hover {
    opacity: var(--base-hover-alpha);
  }
}
.scene-ctn .gradient-pagination .pagination {
  cursor: pointer;
  transition: opacity 0.2s;
  transform-origin: 50% 100%;
}
.scene-ctn .gradient-pagination .pagination:nth-of-type(2) {
  background-color: #e35457;
}
@media (any-hover: hover) {
  .scene-ctn .gradient-pagination .pagination:hover {
    opacity: var(--base-hover-alpha);
  }
}
.scene-ctn .gradient-pagination .pagination {
  cursor: pointer;
  transition: opacity 0.2s;
  transform-origin: 50% 100%;
}
.scene-ctn .gradient-pagination .pagination:nth-of-type(3) {
  background-color: #d98098;
}
@media (any-hover: hover) {
  .scene-ctn .gradient-pagination .pagination:hover {
    opacity: var(--base-hover-alpha);
  }
}
.scene-ctn .gradient-pagination .pagination {
  cursor: pointer;
  transition: opacity 0.2s;
  transform-origin: 50% 100%;
}
.scene-ctn .gradient-pagination .pagination:nth-of-type(4) {
  background-color: #4171b2;
}
@media (any-hover: hover) {
  .scene-ctn .gradient-pagination .pagination:hover {
    opacity: var(--base-hover-alpha);
  }
}
.scene-ctn .gradient-pagination .pagination {
  cursor: pointer;
  transition: opacity 0.2s;
  transform-origin: 50% 100%;
}
.scene-ctn .gradient-pagination .pagination:nth-of-type(5) {
  background-color: #abae29;
}
@media (any-hover: hover) {
  .scene-ctn .gradient-pagination .pagination:hover {
    opacity: var(--base-hover-alpha);
  }
}
.scene-ctn .gradient-pagination .pagination {
  cursor: pointer;
  transition: opacity 0.2s;
  transform-origin: 50% 100%;
}
.scene-ctn .gradient-pagination .pagination:nth-of-type(6) {
  background-color: #a05933;
}
@media (any-hover: hover) {
  .scene-ctn .gradient-pagination .pagination:hover {
    opacity: var(--base-hover-alpha);
  }
}
.scene-ctn .gradient-pagination .pagination {
  cursor: pointer;
  transition: opacity 0.2s;
  transform-origin: 50% 100%;
}
.scene-ctn .gradient-pagination .pagination:nth-of-type(7) {
  background-color: #63b3ce;
}
@media (any-hover: hover) {
  .scene-ctn .gradient-pagination .pagination:hover {
    opacity: var(--base-hover-alpha);
  }
}
.scene-ctn [data-current="0"] .gradient-pagination > .pagination:nth-of-type(1) {
  transform: scaleY(1.6);
}
.scene-ctn [data-current="1"] .gradient-pagination > .pagination:nth-of-type(2) {
  transform: scaleY(1.6);
}
.scene-ctn [data-current="2"] .gradient-pagination > .pagination:nth-of-type(3) {
  transform: scaleY(1.6);
}
.scene-ctn [data-current="3"] .gradient-pagination > .pagination:nth-of-type(4) {
  transform: scaleY(1.6);
}
.scene-ctn [data-current="4"] .gradient-pagination > .pagination:nth-of-type(5) {
  transform: scaleY(1.6);
}
.scene-ctn [data-current="5"] .gradient-pagination > .pagination:nth-of-type(6) {
  transform: scaleY(1.6);
}
.scene-ctn [data-current="6"] .gradient-pagination > .pagination:nth-of-type(7) {
  transform: scaleY(1.6);
}
.scene-ctn .sec-ttl {
  position: relative;
  z-index: 1;
}
.scene-ctn .sec-ttl > .ttl {
  width: 40.5333333333vw;
}
@media (min-width: 768px) {
  .scene-ctn .sec-ttl > .ttl {
    width: max(292px, 21.3762811127vw);
    background-color: var(--color-white);
  }
}
@media (min-width: 768px) {
  .scene-ctn .sec-ttl > .sub_ttl {
    position: absolute;
    top: max(12px, 0.878477306vw);
    left: max(307px, 22.4743777452vw);
    letter-spacing: 0.05em;
    font-size: max(16px, 1.1713030747vw);
    font-weight: bold;
  }
}
.scene-ctn .scene-arrows {
  display: flex;
  justify-content: space-between;
  pointer-events: none;
}
.scene-ctn .scene-arrows > .arrow {
  width: 9.3333333333vw;
  height: 9.3333333333vw;
  transition: opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  pointer-events: all;
}
@media (any-hover: hover) {
  .scene-ctn .scene-arrows > .arrow:hover {
    opacity: var(--base-hover-alpha);
  }
}
@media (min-width: 768px) {
  .scene-ctn .scene-arrows > .arrow {
    width: max(50px, 3.6603221083vw);
    height: max(50px, 3.6603221083vw);
  }
}
.scene-ctn .scene-arrows > .arrow.-prev {
  background: url(../../assets/images/common/slider_arrow_prev.svg) no-repeat center/contain;
}
.scene-ctn .scene-arrows > .arrow.-next {
  background: url(../../assets/images/common/slider_arrow_next.svg) no-repeat center/contain;
}
.scene-ctn .scene-arrows > .arrow svg {
  display: none;
}
.scene-ctn .scene-box {
  position: relative;
  background-color: var(--color-gray);
}
@media (min-width: 768px) {
  .scene-ctn .scene-box {
    display: grid;
    width: max(1200px, 87.8477306003vw);

    grid-template-columns: repeat(2, 1fr);
    grid-template-areas: "area1 area2" "area3 area3";
    -webkit-margin-before: min(-2.635431918vw, -36px);
            margin-block-start: min(-2.635431918vw, -36px);
  }
}
.scene-ctn .scene-box > .slider-txt {
  margin: 9.0666666667vw 8vw 0;
  padding-bottom: 12.8vw;
}
@media (min-width: 768px) {
  .scene-ctn .scene-box > .slider-txt {
    margin: max(104px, 7.6134699854vw) 0 0 max(56px, 4.0995607613vw);
    padding-bottom: 0;
  }
}
.scene-ctn .scene-box > .gradient-pagination {
  position: absolute;
  bottom: 7.2vw;
  left: 50%;
  width: 74.6666666667vw;
  height: 0.8vw;
}
@media (max-width: 767.98px) {
  .scene-ctn .scene-box > .gradient-pagination {
    transform: translateX(-50%);
  }
}
@media (min-width: 768px) {
  .scene-ctn .scene-box > .gradient-pagination {
    bottom: max(52px, 3.8067349927vw);
    left: max(56px, 4.0995607613vw);
    width: max(490px, 35.8711566618vw);
    height: max(6px, 0.439238653vw);
  }
}
@media (min-width: 768px) {
  .scene-ctn .scene-slider {
    position: unset;
  }
}
.scene-ctn .scene-slider .slide {
  cursor: pointer;
}
.scene-ctn .scene-slider > .scene-arrows {
  position: absolute;
  bottom: -65.8666666667vw;
  left: calc(50% + 26.6666666667vw);
  width: 22.9333333333vw;
  transform: translate(-50%, 0);
}
@media (min-width: 768px) {
  .scene-ctn .scene-slider > .scene-arrows {
    bottom: min(-13.17715959vw, -180px);
    left: max(64px, 4.6852122987vw);
    width: max(116px, 8.4919472914vw);
  }
}
.scene-ctn .slider-txt {
  position: relative;
}
@media (min-width: 768px) {
  .scene-ctn .slider-txt {
    margin: max(103px, 7.5402635432vw) max(58px, 4.2459736457vw) 0 max(52px, 3.8067349927vw);

    grid-area: area1;
    -webkit-padding-after: 0;
            padding-block-end: 0;
  }
}
.scene-ctn .slider-txt > .txt-box {
  position: absolute;
  top: 0;
  left: 0;
}
.scene-ctn .txt-box {
  opacity: 0;
  transition: opacity 0.48s cubic-bezier(0.23, 1, 0.32, 1);
}
.scene-ctn .txt-box > .ttl {
  font-size: 4.8vw;
  font-weight: var(--weight-bold);
}
@media (min-width: 768px) {
  .scene-ctn .txt-box > .ttl {
    font-size: max(30px, 2.196193265vw);
  }
}
.scene-ctn .txt-box > .txt {
  font-size: 2.9333333333vw;
  font-weight: var(--weight-bold);
  line-height: 1.7272727273;

  -webkit-margin-before: 0.5333333333vw;

          margin-block-start: 0.5333333333vw;
}
@media (min-width: 768px) {
  .scene-ctn .txt-box > .txt {
    font-size: max(14px, 1.0248901903vw);
    line-height: 1.7857142857;

    -webkit-margin-before: max(10px, 0.7320644217vw);

            margin-block-start: max(10px, 0.7320644217vw);
  }
}
.scene-ctn [data-current="0"] .txt-box:nth-of-type(1) {
  opacity: 1;
  position: relative;
}
.scene-ctn [data-current="1"] .txt-box:nth-of-type(2) {
  opacity: 1;
  position: relative;
}
.scene-ctn [data-current="2"] .txt-box:nth-of-type(3) {
  opacity: 1;
  position: relative;
}
.scene-ctn [data-current="3"] .txt-box:nth-of-type(4) {
  opacity: 1;
  position: relative;
}
.scene-ctn [data-current="4"] .txt-box:nth-of-type(5) {
  opacity: 1;
  position: relative;
}
.scene-ctn [data-current="5"] .txt-box:nth-of-type(6) {
  opacity: 1;
  position: relative;
}
.scene-ctn [data-current="6"] .txt-box:nth-of-type(7) {
  opacity: 1;
  position: relative;
}
@media (max-width: 767.98px) {
  .scene-ctn > .sec-ttl {
    translate: -0.2666666667vw;
  }
}
.scene-ctn > .scene-box {
  margin-top: -4.2666666667vw;
}
@media (min-width: 768px) {
  .scene-ctn > .scene-box {
    margin-top: min(-2.635431918vw, -36px);
  }
}
.scene-ctn > .foot-txt {
  height: 10.6666666667vw;
}
@media (min-width: 768px) {
  .scene-ctn > .foot-txt {
    padding-top: max(10px, 0.7320644217vw);
    height: max(100px, 7.3206442167vw);
  }
}

.choitashi-ctn :root {
  --color-black: #000;
  --color-black-02: #1a1a1a;
  --color-white: #fff;
  --color-gray: #f1f1f1;
  --color-gray-02: #ccc;
  --color-deep-red: #c33;
  --color-red: #e45457;
  --color-red-02: #c03;
  --color-red-03: #c66;
  --color-red-04: #e35457;
  --color-light-tone-red: #e35457;
  --color-rose: #d96a5f;
  --color-pink: #c99;
  --color-pink-02: #d98098;
  --color-pink-03: #ed768c;
  --color-yellow: #fc0;
  --color-green: #9c3;
  --color-green-02: #993;
  --color-green-03: #cbdd72;
  --color-blue: #369;
  --color-light-blue: #63b3ce;
  --color-light-blue-02: #6cc;
  --color-brown: #a05933;
  --color-brown-02: #936030;
  --color-light-brown: #efd2ae;
  --color-orange: #e39b2d;
  --color-orange-02: #f60;
  --color-orange-03: #e29a2e;
  --color-orange-04: #f9c200;
  --weight-medium: 500;
  --weight-bold: 700;
  --base-transition-duration: 0.36s;
  --base-fade-duration: 0.16s;
  --base-hover-alpha: 0.7;
}
.choitashi-ctn .choitashi-box {
  position: relative;
  background-color: var(--color-light-blue);
}
.choitashi-ctn .choitashi-box > .txt {
  opacity: 0;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  letter-spacing: 0.08em;
  color: var(--color-white);
  font-size: 3.7333333333vw;
  font-weight: bold;
  line-height: 1.9285714286;

  translate: 0 8vw;
}
@media (max-width: 767.98px) {
  .choitashi-ctn .choitashi-box > .txt {
    text-align: center;
  }
}
@media (min-width: 768px) {
  .choitashi-ctn .choitashi-box > .txt {
    letter-spacing: 0.07em;
    font-size: max(22px, 1.6105417277vw);
    line-height: 1.9090909091;

    translate: 0 max(30px, 2.196193265vw);
  }
}
.choitashi-ctn .choitashi-box > .txt + .txt {
  margin-top: 7.2vw;
}
@media (min-width: 768px) {
  .choitashi-ctn .choitashi-box > .txt + .txt {
    margin-top: max(42px, 3.074670571vw);
  }
}
.choitashi-ctn .choitashi-box > .txt.-anim {
  opacity: 1;

  translate: 0;
}
.choitashi-ctn .choitashi-box > .txt.-anim + .txt {
  opacity: 1;

  translate: 0;
}
.choitashi-ctn .choitashi-box > .txt.-anim ~ .annotation {
  opacity: 1;
}
.choitashi-ctn .choitashi-box > .annotation {
  opacity: 0;
  position: absolute;
  top: 50%;
  left: 50%;
  transition: opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  transform: translate(calc(-50% + 29.8666666667vw), calc(-50% + 8vw));
  letter-spacing: 0.05em;
  color: var(--color-white);
  font-size: 2.1333333333vw;
}
@media (min-width: 768px) {
  .choitashi-ctn .choitashi-box > .annotation {
    transform: translate(calc(-50% + max(450px, 32.9428989751vw)), calc(-50% + max(190px, 13.9092240117vw)));
    font-size: max(9px, 0.6588579795vw);
  }
}
.choitashi-ctn .choitashi-box > .deco.-first {
  position: absolute;
  bottom: -10.6666666667vw;
  left: 0;
  width: 108.8vw;
}
@media (min-width: 768px) {
  .choitashi-ctn .choitashi-box > .deco.-first {
    bottom: max(13px, 0.9516837482vw);
    left: max(54px, 3.953147877vw);
    width: max(472px, 34.5534407028vw);
  }
}
@media (min-width: 768px) {
  .choitashi-ctn .choitashi-box > .deco.-second {
    position: absolute;
    right: min(-4.39238653vw, -60px);
    bottom: min(-0.6588579795vw, -9px);
    width: max(202px, 14.7877013177vw);
  }
}
.choitashi-ctn > .ttl {
  position: relative;
  z-index: 1;
  margin-left: auto;
  width: 70.6666666667vw;
  background-color: var(--color-white);

  translate: 0.4vw;
}
@media (min-width: 768px) {
  .choitashi-ctn > .ttl {
    width: max(508px, 37.1888726208vw);

    translate: max(2px, 0.1464128843vw);
  }
}
.choitashi-ctn > .choitashi-box {
  padding: 15.2vw 0 66.6666666667vw;

  translate: 0 -4.8vw;
}
@media (max-width: 767.98px) {
  .choitashi-ctn > .choitashi-box {
    margin: 0 auto;
    width: 90.6666666667vw;
  }
}
@media (min-width: 768px) {
  .choitashi-ctn > .choitashi-box {
    padding: max(130px, 9.5168374817vw) 0 max(106px, 7.7598828697vw) max(598px, 43.7774524158vw);

    translate: 0 min(-2.635431918vw, -36px);
  }
}

.movie-ctn {
  position: relative;
}
.movie-ctn :root {
  --color-black: #000;
  --color-black-02: #1a1a1a;
  --color-white: #fff;
  --color-gray: #f1f1f1;
  --color-gray-02: #ccc;
  --color-deep-red: #c33;
  --color-red: #e45457;
  --color-red-02: #c03;
  --color-red-03: #c66;
  --color-red-04: #e35457;
  --color-light-tone-red: #e35457;
  --color-rose: #d96a5f;
  --color-pink: #c99;
  --color-pink-02: #d98098;
  --color-pink-03: #ed768c;
  --color-yellow: #fc0;
  --color-green: #9c3;
  --color-green-02: #993;
  --color-green-03: #cbdd72;
  --color-blue: #369;
  --color-light-blue: #63b3ce;
  --color-light-blue-02: #6cc;
  --color-brown: #a05933;
  --color-brown-02: #936030;
  --color-light-brown: #efd2ae;
  --color-orange: #e39b2d;
  --color-orange-02: #f60;
  --color-orange-03: #e29a2e;
  --color-orange-04: #f9c200;
  --weight-medium: 500;
  --weight-bold: 700;
  --base-transition-duration: 0.36s;
  --base-fade-duration: 0.16s;
  --base-hover-alpha: 0.7;
}
.movie-ctn .movie-arrows {
  display: flex;
  justify-content: space-between;
  pointer-events: none;
}
.movie-ctn .movie-arrows > .arrow {
  width: 9.3333333333vw;
  height: 9.3333333333vw;
  transition: opacity 0.2s;
  pointer-events: all;
}
.movie-ctn .movie-arrows > .arrow svg {
  display: none;
}
@media (any-hover: hover) {
  .movie-ctn .movie-arrows > .arrow:hover {
    opacity: var(--base-hover-alpha);
  }
}
.movie-ctn .movie-arrows > .arrow.-prev {
  background: url(../../assets/images/common/slider_arrow_prev.svg) no-repeat center/contain;
}
.movie-ctn .movie-arrows > .arrow.-next {
  background: url(../../assets/images/common/slider_arrow_next.svg) no-repeat center/contain;
}
.movie-ctn .movie-pagination li {
  width: 4vw;

  aspect-ratio: 1;
}
@media (min-width: 768px) {
  .movie-ctn .movie-pagination li {
    width: max(30px, 2.196193265vw);
  }
}
.movie-ctn .movie-pagination li:nth-of-type(1) button {
  background-image: url(../../assets/images/common/pagination_num_1.svg);
  background-position: center;
  background-size: 2.6666666667vw 2.6666666667vw;
}
@media (min-width: 768px) {
  .movie-ctn .movie-pagination li:nth-of-type(1) button {
    background-size: max(20px, 1.4641288433vw) max(20px, 1.4641288433vw);
  }
}
.movie-ctn .movie-pagination li:nth-of-type(2) button {
  background-image: url(../../assets/images/common/pagination_num_2.svg);
  background-position: center;
  background-size: 2.6666666667vw 2.6666666667vw;
}
@media (min-width: 768px) {
  .movie-ctn .movie-pagination li:nth-of-type(2) button {
    background-size: max(20px, 1.4641288433vw) max(20px, 1.4641288433vw);
  }
}
.movie-ctn .movie-pagination li:nth-of-type(3) button {
  background-image: url(../../assets/images/common/pagination_num_3.svg);
  background-position: center;
  background-size: 2.6666666667vw 2.6666666667vw;
}
@media (min-width: 768px) {
  .movie-ctn .movie-pagination li:nth-of-type(3) button {
    background-size: max(20px, 1.4641288433vw) max(20px, 1.4641288433vw);
  }
}
.movie-ctn .movie-pagination li:nth-of-type(4) button {
  background-image: url(../../assets/images/common/pagination_num_4.svg);
  background-position: center;
  background-size: 2.6666666667vw 2.6666666667vw;
}
@media (min-width: 768px) {
  .movie-ctn .movie-pagination li:nth-of-type(4) button {
    background-size: max(20px, 1.4641288433vw) max(20px, 1.4641288433vw);
  }
}
.movie-ctn .movie-pagination li:nth-of-type(5) button {
  background-image: url(../../assets/images/common/pagination_num_5.svg);
  background-position: center;
  background-size: 2.6666666667vw 2.6666666667vw;
}
@media (min-width: 768px) {
  .movie-ctn .movie-pagination li:nth-of-type(5) button {
    background-size: max(20px, 1.4641288433vw) max(20px, 1.4641288433vw);
  }
}
.movie-ctn .movie-pagination li + li {
  position: relative;
  z-index: 1;
}
.movie-ctn .movie-pagination li + li::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -2.4vw;
  width: 1.6vw;
  height: 2.4vw;
  transform: translateY(-50%);
  background: url(../../assets/images/common/pagination_slash.svg) no-repeat center/contain;
}
@media (min-width: 768px) {
  .movie-ctn .movie-pagination li + li::before {
    left: min(-1.2445095168vw, -17px);
    width: max(12px, 0.878477306vw);
    height: max(18px, 1.317715959vw);
  }
}
.movie-ctn .movie-pagination button {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  min-height: unset;
  transition: opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
}
@media (any-hover: hover) {
  .movie-ctn .movie-pagination button:hover {
    opacity: var(--base-hover-alpha);
  }
}
.movie-ctn .movie-pagination button::after {
  content: "";
  display: block;
  opacity: 0.001;
  position: absolute;
  bottom: -0.2666666667vw;
  left: 50%;
  width: 2.6666666667vw;
  height: 0.5333333333vw;
  transition: opacity;
  transform: translateX(-50%);
  background-color: var(--color-red-02);
}
@media (min-width: 768px) {
  .movie-ctn .movie-pagination button::after {
    bottom: min(-0.1464128843vw, -2px);
    width: max(22px, 1.6105417277vw);
    height: max(3px, 0.2196193265vw);
  }
}
.movie-ctn .movie-pagination button.is-active::after {
  opacity: 1;
}
.movie-ctn .movie-slider > .movie-track {
  padding-top: 11.7333333333vw;
}
@media (min-width: 768px) {
  .movie-ctn .movie-slider > .movie-track {
    padding-top: max(38px, 2.7818448023vw);
  }
}
@media (max-width: 767.98px) {
  .movie-ctn .movie-slider > .movie-arrows {
    position: absolute;
    bottom: -2.6666666667vw;
    left: 50%;
    width: 74.6666666667vw;

    translate: -50% 0;
  }
}
@media (min-width: 768px) {
  .movie-ctn .movie-slider > .movie-arrows {
    display: none;
  }
}
.movie-ctn .movie-slider > .movie-pagination {
  gap: 2.6666666667vw;
}
@media (max-width: 767.98px) {
  .movie-ctn .movie-slider > .movie-pagination {
    margin-top: 7.4666666667vw;
  }
}
@media (min-width: 768px) {
  .movie-ctn .movie-slider > .movie-pagination {
    position: absolute;
    z-index: 1;
    bottom: min(-0.1464128843vw, -2px);
    left: max(104px, 7.6134699854vw);

    gap: max(19px, 1.3909224012vw);
  }
}
.movie-ctn .movie-slider > .movie-play {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 18.6666666667vw;
  transform: translate(calc(-50% + 25.0666666667vw), calc(-50% + 11.7333333333vw));
  pointer-events: none;
}
@media (min-width: 768px) {
  .movie-ctn .movie-slider > .movie-play {
    width: max(140px, 10.2489019034vw);
    transform: translate(calc(-50% + max(378px, 27.6720351391vw)), calc(-50% + max(222px, 16.2518301611vw)));
  }
}
.movie-ctn .movie-slider > .movie-play .st0 {
  fill: #fac300;
}
.movie-ctn .movie-slider > .movie-play .play_circle {
  transform-origin: 50% 50%;
  -webkit-animation: rotate_360 20s linear infinite;
          animation: rotate_360 20s linear infinite;
}
.movie-ctn .movie-track .slide-box {
  width: 74.6666666667vw;
}
@media (min-width: 768px) {
  .movie-ctn .movie-track .slide-box {
    width: max(960px, 70.2781844802vw);
  }
}
.movie-ctn .sec-ttl > .ttl {
  width: 39.2vw;
}
@media (min-width: 768px) {
  .movie-ctn .sec-ttl > .ttl {
    background-color: var(--color-white);
  }
}
@media (max-width: 767.98px) {
  .movie-ctn .sec-ttl > .ttl {
    margin-left: 4.8vw;
  }
}
@media (min-width: 768px) {
  .movie-ctn .sec-ttl > .ttl {
    width: max(281px, 20.5710102489vw);
  }
}
.movie-ctn .slide-box.is-active .desc {
  opacity: 1;
}
@media (max-width: 767.98px) {
  .movie-ctn .slide-box:nth-of-type(1) .desc {
    position: relative;
    left: -1.8666666667vw;
    white-space: nowrap;
  }
}
@media (max-width: 767.98px) {
  .movie-ctn .slide-box:nth-of-type(2) .desc {
    position: relative;
    left: -2.6666666667vw;
    white-space: nowrap;
  }
}
.movie-ctn .slide-img {
  overflow: hidden;
  position: relative;
  border-radius: 1.6vw;
}
@media (min-width: 768px) {
  .movie-ctn .slide-img {
    border-radius: max(12px, 0.878477306vw);
  }
}
.movie-ctn .slide-img > .img {
  transition: scale 0.54s cubic-bezier(0.23, 1, 0.32, 1);
}
@media (any-hover: hover) {
  .movie-ctn .slide-img:hover > .img {
    transition-duration: 0.64s;

    scale: 1.04;
  }
}
.movie-ctn .slide-link {
  display: block;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
}
.movie-ctn .slide-box:nth-of-type(2) .slide-link {
  transition-delay: 0.12s;
}
.movie-ctn .slide-link > .desc {
  margin-top: 2.1333333333vw;
  text-align: center;
  letter-spacing: 0.05em;
  color: var(--color-black);
  font-size: 2.9333333333vw;
  font-weight: bold;
}
@media (min-width: 768px) {
  .movie-ctn .slide-link > .desc {
    margin-top: max(14px, 1.0248901903vw);
    font-size: max(18px, 1.317715959vw);
  }
}
.movie-ctn .slide-link:not(.-anim) {
  opacity: 0;

  translate: 0 8vw;
}
@media (min-width: 768px) {
  .movie-ctn .slide-link:not(.-anim) {
    translate: 0 max(30px, 2.196193265vw);
  }
}
.movie-ctn > .sec-ttl {
  translate: -0.4vw;
}
@media (min-width: 768px) {
  .movie-ctn > .sec-ttl {
    margin: 0 auto;
    width: max(1200px, 87.8477306003vw);

    translate: min(-0.0732064422vw, -1px);
  }
}
.movie-ctn > .panel {
  position: absolute;
  z-index: -1;
  top: 7.2vw;
  left: 50%;
  width: 90.6666666667vw;
  height: 48vw;
  transform: translateX(-50%);
  background-color: var(--color-orange-04);
}
@media (min-width: 768px) {
  .movie-ctn > .panel {
    top: max(50px, 3.6603221083vw);
    width: max(1200px, 87.8477306003vw);
    height: max(500px, 36.6032210835vw);
  }
}
.profile-ctn {
  position: relative;
}
.profile-ctn :root {
  --color-black: #000;
  --color-black-02: #1a1a1a;
  --color-white: #fff;
  --color-gray: #f1f1f1;
  --color-gray-02: #ccc;
  --color-deep-red: #c33;
  --color-red: #e45457;
  --color-red-02: #c03;
  --color-red-03: #c66;
  --color-red-04: #e35457;
  --color-light-tone-red: #e35457;
  --color-rose: #d96a5f;
  --color-pink: #c99;
  --color-pink-02: #d98098;
  --color-pink-03: #ed768c;
  --color-yellow: #fc0;
  --color-green: #9c3;
  --color-green-02: #993;
  --color-green-03: #cbdd72;
  --color-blue: #369;
  --color-light-blue: #63b3ce;
  --color-light-blue-02: #6cc;
  --color-brown: #a05933;
  --color-brown-02: #936030;
  --color-light-brown: #efd2ae;
  --color-orange: #e39b2d;
  --color-orange-02: #f60;
  --color-orange-03: #e29a2e;
  --color-orange-04: #f9c200;
  --weight-medium: 500;
  --weight-bold: 700;
  --base-transition-duration: 0.36s;
  --base-fade-duration: 0.16s;
  --base-hover-alpha: 0.7;
}
.profile-ctn .btn-box {
  display: grid;
  position: relative;
  border-radius: 50vw;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  background-color: var(--color-red-02);

  place-content: center;
}
@media (any-hover: hover) {
  .profile-ctn .btn-box:hover {
    opacity: var(--base-hover-alpha);
  }
}
.profile-ctn .btn-box > .txt {
  letter-spacing: 0.05em;
  color: var(--color-white);
  font-size: 4.2666666667vw;
  font-weight: var(--weight-bold);

  translate: -5.3333333333vw;
}
@media (min-width: 768px) {
  .profile-ctn .btn-box > .txt {
    letter-spacing: 0.05em;
    font-size: max(22px, 1.6105417277vw);

    translate: max(5px, 0.3660322108vw);
  }
}
.profile-ctn .btn-box > .arrow {
  position: absolute;
  top: 50%;
  right: 7.4666666667vw;
  width: 6.6666666667vw;
  transform: translateY(-50%);
  font-size: 0;

  fill: none;
  stroke: var(--color-white);
}
@media (min-width: 768px) {
  .profile-ctn .btn-box > .arrow {
    right: max(30px, 2.196193265vw);
    width: max(32px, 2.3426061493vw);
    transform: translateY(calc(-50% - max(3px, 0.2196193265vw)));
  }
}
.profile-ctn .btn-box:not(.-anim) {
  opacity: 0;

  translate: 0 8vw;
}
@media (min-width: 768px) {
  .profile-ctn .btn-box:not(.-anim) {
    translate: 0 max(30px, 2.196193265vw);
  }
}
.profile-ctn .profile-box {
  border-radius: 1.3333333333vw;
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
  background-color: var(--color-white);
}
@media (max-width: 767.98px) {
  .profile-ctn .profile-box {
    filter: drop-shadow(0 0 0.5333333333vw rgba(0, 0, 0, 0.2));
  }
}
@media (min-width: 768px) {
  .profile-ctn .profile-box.-nimura {
    display: grid;
    border-radius: max(10px, 0.7320644217vw);

    gap: max(22px, 1.6105417277vw) max(52px, 3.8067349927vw);
    grid-template-areas: "profileImg name" "profileImg desc" "profileImg .";
  }
}
.profile-ctn .profile-box.-nimura > .name {
  margin: 5.0666666667vw auto 0;
  width: 51.8666666667vw;
  transform: rotate(0.0001deg);

  translate: -1.0666666667vw;
}
@media (min-width: 768px) {
  .profile-ctn .profile-box.-nimura > .name {
    margin: max(38px, 2.7818448023vw) 0 0;
    width: max(302px, 22.1083455344vw);

    translate: 0;
    grid-area: name;
  }
}
.profile-ctn .profile-box > .img {
  width: 52.2666666667vw;

  margin-inline: auto;
}
@media (min-width: 768px) {
  .profile-ctn .profile-box > .img {
    flex-shrink: 0;
    width: max(236px, 17.2767203514vw);

    margin-inline: 0;
    grid-area: profileImg;
  }
}
.profile-ctn .profile-box > .desc {
  font-size: 2.9333333333vw;
  font-weight: var(--weight-medium);
  line-height: 1.7272727273;
}
@media (min-width: 768px) {
  .profile-ctn .profile-box > .desc {
    font-size: max(14px, 1.0248901903vw);
    line-height: 1.8571428571;

    grid-area: desc;
  }
}
.profile-ctn .splide-track {
  transition: translate var(--base-transition-duration) cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity var(--base-fade-duration) cubic-bezier(0, 0, 0.58, 1);
}
.profile-ctn .splide-track:not(.-anim) {
  opacity: 0;

  translate: 0 8vw;
}
@media (min-width: 768px) {
  .profile-ctn .splide-track:not(.-anim) {
    translate: 0 max(30px, 2.196193265vw);
  }
}
.profile-ctn > .ttl {
  margin-left: auto;
  width: 51.7333333333vw;
  background-color: var(--color-white);
}
@media (max-width: 767.98px) {
  .profile-ctn > .ttl {
    translate: 0.4vw;
  }
}
@media (min-width: 768px) {
  .profile-ctn > .ttl {
    width: max(376px, 27.5256222548vw);

    translate: max(2px, 0.1464128843vw);
  }
}
.profile-ctn > .panel {
  position: absolute;
  z-index: -1;
  top: 7.2vw;
  left: 0;
  width: 100%;
  height: 48vw;
  background-color: var(--color-orange-03);
}
@media (min-width: 768px) {
  .profile-ctn > .panel {
    top: max(50px, 3.6603221083vw);
    height: max(500px, 36.6032210835vw);
  }
}
.profile-ctn > .profile-box {
  margin: 12.2666666667vw auto 0;
  padding: 8.2666666667vw 6.1333333333vw 10.6666666667vw;
  width: 74.6666666667vw;
}
@media (max-width: 767.98px) {
  .profile-ctn > .profile-box {
    transform: translateZ(0);
  }
}
@media (min-width: 768px) {
  .profile-ctn > .profile-box {
    margin: max(34px, 2.4890190337vw) auto 0;
    padding: max(39px, 2.8550512445vw) max(52px, 3.8067349927vw);
    width: max(960px, 70.2781844802vw);
    height: 100%;
  }
}
.profile-ctn > .btn-box {
  margin: 26.6666666667vw auto 0;
  width: 89.6vw;
  height: 19.7333333333vw;
}
@media (min-width: 768px) {
  .profile-ctn > .btn-box {
    margin: max(156px, 11.420204978vw) auto max(84px, 6.149341142vw);
    width: max(600px, 43.9238653001vw);
    height: max(100px, 7.3206442167vw);
  }
}

@media (min-width: 768px) {
  .ec-wrap > h2 {
    padding-bottom: 51px;
  }
}
.ec-wrap img {
  width: auto;
  height: auto;
}
.ec-wrap > .box-ec {
  margin: 6px;
}
@media (min-width: 768px) {
  .ec-wrap > .box-ec {
    margin: 0 auto;
  }
}
.ec-wrap .box-ec .list-ec {
  -webkit-padding-before: 0;
          padding-block-start: 0;
}

.floating-box {
  display: block;
  transition: opacity var(--base-fade-duration) cubic-bezier(0.23, 1, 0.32, 1), visibility var(--base-fade-duration) cubic-bezier(0.23, 1, 0.32, 1);
}
@media (any-hover: hover) {
  .floating-box:hover {
    opacity: var(--base-hover-alpha);
  }
}
body[data-current="1"] .floating-box.-first {
  visibility: hidden;
  opacity: 0;
}

.soy-campaign_inner {
  margin-right: auto;
  margin-left: auto;
  padding-right: max(40px,3.14788vw);
  padding-left: max(40px,3.14788vw);
  max-width: max(1199px,93.70425vw);
}
@media screen and (max-width: 767px) {
  .soy-campaign_inner {
    padding-right: 0;
    padding-left: 0;
    max-width: none;
  }
}

.contact-modal {
  position: relative;
  padding-top: max(70px, 5.1244509517vw);
  max-width: max(1055px, 77.2327964861vw);
  pointer-events: none;

  margin-inline: auto;
}
@media (max-width: 767.98px) {
  .contact-modal {
    padding-top: 16vw;
  }
}
.contact-modal .contact-modal_lineheight {
  display: block;
  padding-top: 1em;
}
.contact-modal .contact-modal_close {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  right: min(-2.196193265vw, -30px);
  width: max(64px, 4.6852122987vw);
  height: max(64px, 4.6852122987vw);
  cursor: pointer;
  transition: opacity 0.3s cubic-bezier(0.47, 0, 0.745, 0.715);
  transform: translateX(-100%);
  pointer-events: auto;
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_close {
    top: 2.6666666667vw;
    right: -5.6vw;
    width: 10.6666666667vw;
    height: 10.6666666667vw;
    transform: translateX(-40%);
  }
}
.contact-modal .contact-modal_close::before,
.contact-modal .contact-modal_close::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 1px;
  height: 100%;
  transform-origin: center;
  background-color: #fff;
}
.contact-modal .contact-modal_close::before {
  transform: rotate(45deg);
}
.contact-modal .contact-modal_close::after {
  transform: rotate(-45deg);
}
@media (any-hover: hover) {
  .contact-modal .contact-modal_close:hover {
    opacity: var(--base-hover-alpha);
    transition: opacity 0.2s cubic-bezier(0.47, 0, 0.745, 0.715);
  }
}
.contact-modal#contact-modal01 .contact-modal_inner {
  border: max(4px, 0.2928257687vw) solid var(--color-light-tone-red);
}
.contact-modal#contact-modal02 .contact-modal_inner {
  border: max(4px, 0.2928257687vw) solid #cb7064;
}
.contact-modal .contact-modal_inner {
  padding: max(52px, 3.8067349927vw) max(82px, 6.0029282577vw);
  background-color: #fff;
  pointer-events: auto;
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_inner {
    padding: 6.6666666667vw 8.5333333333vw;
    border-width: 1.0666666667vw;
  }
}
.contact-modal .contact-modal_title {
  text-align: center;
  font-size: max(24px, 1.756954612vw);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_title {
    font-size: 4.8vw;
  }
}
.contact-modal .contact-modal_lead {
  letter-spacing: 0.08em;
  font-size: max(14px, 1.0248901903vw);
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_lead {
    font-size: 3.2vw;
  }
}
.contact-modal .contact-modal_textarea {
  overflow-y: scroll;
  margin-top: max(26px, 1.9033674963vw);
  padding: max(37px, 2.7086383602vw) max(45px, 3.2942898975vw);
  max-height: calc(65vh - max(70px, 5.1244509517vw));
  background-color: #f0f0f0;
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_textarea {
    margin-top: 4vw;
    padding: 7.4666666667vw 5.3333333333vw;
    max-height: calc(60vh - 16vw);
  }
}
.contact-modal .contact-modal_heading {
  position: relative;
  letter-spacing: 0.1em;
  font-size: max(14px, 1.0248901903vw);
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_heading {
    font-size: 3.7333333333vw;
  }
}
.contact-modal .contact-modal_heading:not(:first-child) {
  margin-top: max(22px, 1.6105417277vw);
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_heading:not(:first-child) {
    margin-top: 5.8666666667vw;
  }
}
.contact-modal .contact-modal_heading::before {
  content: "";
  display: inline-block;
  margin-right: max(7px, 0.5124450952vw);
  width: 0.8em;
  height: 0.8em;
  background-color: #000;
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_heading::before {
    margin-right: 1.8666666667vw;
  }
}
.contact-modal .contact-modal_text {
  margin-top: max(10px, 0.7320644217vw);
  font-size: max(12px, 0.878477306vw);
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_text {
    margin-top: 2.6666666667vw;
    font-size: 3.2vw;
  }
}
.contact-modal .contact-modal_text a {
  position: relative;
  transition: opacity 0.18s cubic-bezier(0.47, 0, 0.745, 0.715);
  text-decoration: none;
  word-wrap: break-word;
  color: #c70025;
}
@media (max-width: 767.98px) {
  .contact-modal .contact-modal_text a {
    text-decoration: underline;
  }
}
@media (min-width: 768px) {
  .contact-modal .contact-modal_text a {
    display: inline-block;
  }
}
@media (min-width: 768px) {
  .contact-modal .contact-modal_text a::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    height: 1px;
    transition: transform 0.18s cubic-bezier(0.23, 1, 0.32, 1);
    background-color: #c70025;
  }
}
@media (any-hover: hover) {
  .contact-modal .contact-modal_text a:hover {
    opacity: var(--base-hover-alpha);
    transition: opacity 0.2s cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  .contact-modal .contact-modal_text a:hover::after {
    transition: transform 0.2s cubic-bezier(0.23, 1, 0.32, 1);
    transform: scaleX(0);
  }
}
.contact-modal .contact-modal_text_caption {
  display: block;
  margin-top: max(5px, 0.3660322108vw);
  padding-left: 1em;
  text-indent: -1em;
  font-size: max(10px, 0.7320644217vw);
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_text_caption {
    margin-top: 1.3333333333vw;
    font-size: 2.6666666667vw;
  }
}
.contact-modal .contact-modal_text_caption + .contact-modal_text_caption {
  margin-top: 1px;
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_text_caption + .contact-modal_text_caption {
    margin-top: 1px;
  }
}
.contact-modal .contact-modal_list {
  margin-top: max(10px, 0.7320644217vw);
  font-size: max(12px, 0.878477306vw);
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_list {
    margin-top: 2.6666666667vw;
    font-size: 3.2vw;
  }
}
.contact-modal .contact-modal_list li {
  position: relative;
  padding-left: max(20px, 1.4641288433vw);
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_list li {
    padding-left: 4vw;
  }
}
.contact-modal .contact-modal_list li::after {
  content: "";
  position: absolute;
  top: 0.7em;
  left: max(2px, 0.1464128843vw);
  border-radius: 50%;
  width: max(3px, 0.2196193265vw);
  height: max(3px, 0.2196193265vw);
  background-color: #000;
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_list li::after {
    left: 1.0666666667vw;
    width: 0.8vw;
    height: 0.8vw;
  }
}
.contact-modal .contact-modal_list li + li {
  margin-top: max(3px, 0.2196193265vw);
}
@media screen and (max-width: 767px) {
  .contact-modal .contact-modal_list li + li {
    margin-top: 0.4vw;
  }
}
.contact-modal .contact-modal_list li .contact-modal_text_caption {
  margin-top: 0;
}

.mfp-content:has(.line-modal-inner) {
  padding: 8vw 0;
}
@media (min-width: 768px) {
  .mfp-content:has(.line-modal-inner) {
    padding: max(30px, 2.196193265vw) 0;
  }
}

.line-modal-inner {
  padding-top: 17.6vw;
  width: 85.3333333333vw;
  height: 165.0666666667vw;
  background: url(../../assets/images/line-modal/bg_sm.png) no-repeat center/cover;
}
@media (min-width: 768px) {
  .line-modal-inner {
    padding-top: max(115px, 8.4187408492vw);
    width: max(799px, 58.4919472914vw);
    height: max(500px, 36.6032210835vw);
    background: url(../../assets/images/line-modal/bg_lg.png) no-repeat center/cover;
  }
}
.line-modal-inner .contact-modal_close::before,
.line-modal-inner .contact-modal_close::after {
  background-color: #000;
}
@media (max-width: 767.98px) {
  .line-modal-inner .ttl {
    margin: 0 auto;
    width: 55.4666666667vw;
  }
}
@media (min-width: 768px) {
  .line-modal-inner .ttl {
    margin-left: max(142px, 10.3953147877vw);
    width: max(286px, 20.9370424597vw);
  }
}
.line-modal-inner .txt {
  margin-top: 6.1333333333vw;
  text-align: center;
  letter-spacing: 0.07em;
  font-size: 3.2vw;
  font-weight: bold;
  line-height: 1.6666666667;
}
@media (min-width: 768px) {
  .line-modal-inner .txt {
    margin-top: max(41px, 3.0014641288vw);
    margin-left: min(-16.6910688141vw, -228px);
    letter-spacing: normal;
    font-size: max(17px, 1.2445095168vw);
    line-height: 1.6470588235;
  }
}
@media (max-width: 767.98px) {
  .line-modal-inner .img {
    margin: 5.8666666667vw auto 0;
    width: 48vw;
  }
}
@media (min-width: 768px) {
  .line-modal-inner .img {
    position: absolute;
    top: max(79px, 5.7833089312vw);
    right: max(128px, 9.3704245974vw);
    width: max(484px, 35.4319180088vw);
  }
}
.line-modal-inner .contact-modal_close {
  top: 6.9333333333vw;
  right: 1.8666666667vw;
  width: 5.8666666667vw;
  height: 5.8666666667vw;
}
@media (min-width: 768px) {
  .line-modal-inner .contact-modal_close {
    top: max(32px, 2.3426061493vw);
    right: min(-0.9516837482vw, -13px);
    width: max(44px, 3.2210834553vw);
    height: max(44px, 3.2210834553vw);
  }
}
.line-modal-inner .contact-modal_close::before,
.line-modal-inner .contact-modal_close::after {
  width: 2px;
}
.line-modal-inner .contact-modal_close .close-txt {
  position: absolute;
  top: 6.4vw;
  right: 2.1333333333vw;
  width: 1.4666666667vw;
}
@media (min-width: 768px) {
  .line-modal-inner .contact-modal_close .close-txt {
    top: max(51px, 3.7335285505vw);
    right: max(18px, 1.317715959vw);
    width: max(9px, 0.6588579795vw);
  }
}
.line-modal-inner img {
  width: 100%;
  max-width: 100%;
  height: auto;
}

/* --------------------------------
  libraries
-------------------------------- */
.mfp-container {
  padding: 0 max(14px, 1.0248901903vw);
}
@media screen and (max-width: 767px) {
  .mfp-container {
    padding: 0 4.8vw;
  }
}

@media screen and (max-width: 767px) {
  .mfp-iframe-holder {
    padding: 0 6.4vw;
  }
}
.mfp-iframe-holder .mfp-content {
  margin-top: max(75px, 5.4904831625vw);
  max-width: 1132px;
}
@media screen and (max-width: 767px) {
  .mfp-iframe-holder .mfp-content {
    margin-top: 10.6666666667vw;
  }
}
.mfp-iframe-holder .mfp-content:has(.youtube-tate-inner) {
  max-width: 100%;

  aspect-ratio: 654/1104;
}
@media (min-width: 768px) {
  .mfp-iframe-holder .mfp-content:has(.youtube-tate-inner) {
    margin-top: max(40px, 2.9282576867vw);
    max-width: max(338px, 24.7437774524vw);

    aspect-ratio: 330/557;
  }
}
.mfp-iframe-holder .mfp-iframe-inner {
  position: relative;
  padding: max(30px, 2.196193265vw) max(60px, 4.39238653vw);
  border: max(4px, 0.2928257687vw) solid #edae30;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .mfp-iframe-holder .mfp-iframe-inner {
    padding: 10.6666666667vw 2.6666666667vw;
  }
}
.mfp-iframe-holder .youtube-tate-inner {
  padding: 4.2666666667vw 5.3333333333vw;
  border: 0.5333333333vw solid #c70025;
  height: 100%;
}
@media (min-width: 768px) {
  .mfp-iframe-holder .youtube-tate-inner {
    padding: max(20px, 1.4641288433vw);
    border-width: max(2px, 0.1464128843vw);
  }
}
.mfp-iframe-holder .youtube-tate-inner .mfp-iframe-scaler {
  padding-top: unset;
  height: 100%;

  aspect-ratio: 9/16;
}
.mfp-iframe-holder .mfp-iframe-scaler {
  position: relative;
}
.mfp-iframe-holder .movie-modal_close {
  top: -10.6666666667vw;
  right: 0;
  width: 8vw;
  height: 8vw;
}
@media (min-width: 768px) {
  .mfp-iframe-holder .movie-modal_close {
    top: min(-5.4904831625vw, -75px);
    width: max(65px, 4.7584187408vw);
    height: max(65px, 4.7584187408vw);
  }
}
.mfp-iframe-holder .movie-modal_close::before,
.mfp-iframe-holder .movie-modal_close::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: max(3px, 0.2196193265vw);
  height: max(75px, 5.4904831625vw);
  transform: translate(-50%, -50%) rotate(-45deg);
  background-color: #edae30;
}
@media screen and (max-width: 767px) {
  .mfp-iframe-holder .movie-modal_close::before,
  .mfp-iframe-holder .movie-modal_close::after {
    width: 1.0666666667vw;
    height: 10.6666666667vw;
  }
}
.mfp-iframe-holder .movie-modal_close::after {
  transform: translate(-50%, -50%) rotate(45deg);
}
.mfp-iframe-holder .youtube-tate-movie_close {
  top: 0;
  width: 10.6666666667vw;
  height: 10.6666666667vw;
  transform: translateY(-100%);
  background-color: #c70025;
}
@media (min-width: 768px) {
  .mfp-iframe-holder .youtube-tate-movie_close {
    width: max(40px, 2.9282576867vw);
    height: max(40px, 2.9282576867vw);
    transform: translateY(calc(-100% + max(1px, 0.0732064422vw)));
  }
}
.mfp-iframe-holder .youtube-tate-movie_close::before,
.mfp-iframe-holder .youtube-tate-movie_close::after {
  width: max(2px, 0.1464128843vw);
  height: max(34px, 2.4890190337vw);
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .mfp-iframe-holder .youtube-tate-movie_close::before,
  .mfp-iframe-holder .youtube-tate-movie_close::after {
    width: 0.5333333333vw;
    height: 9.6vw;
  }
}

button.mfp-close {
  top: min(-3.2942898975vw, -45px);
  right: min(-3.2942898975vw, -45px);
  width: max(45px, 3.2942898975vw);
  height: max(45px, 3.2942898975vw);
}

[data-simplebar] {
  overflow-y: scroll;

  -ms-overflow-style: none;
  scrollbar-width: none;
}
[data-simplebar]::-webkit-scrollbar {
  display: none;
}

.simplebar-scrollbar::before {
  border-radius: 0;
  background: #979797;
}

.simplebar-scrollbar.simplebar-visible::before {
  opacity: 1;
}

.simplebar-track {
  background-color: transparent;
}

/*
* top.css
*
*/
/* --------------------------------
  globals
-------------------------------- */
html {
  margin-right: 0 !important;
}

body {
  position: relative;
}

.u-ff-kosugi {
  font-family: Kosugi !important;
}

.u-ws-nowrap {
  white-space: nowrap !important;
}

.u-fs-nowrap {
  display: inline-block;
}

.main-ctn {
  overflow: hidden;
  transition: opacity 0.3s;
  font-family: "Noto Sans CJK JP", "Noto Sans JP", sans-serif;
}
.main-ctn > .lead-ctn {
  padding: 55.4666666667vw 12.8vw 15.4666666667vw;
}
@media (min-width: 768px) {
  .main-ctn > .lead-ctn {
    padding: max(70px, 5.1244509517vw) 0 max(65px, 4.7584187408vw);
  }
}
.main-ctn > .point-ctn {
  padding: 12.8vw 0 16vw;
}
@media (min-width: 768px) {
  .main-ctn > .point-ctn {
    padding: max(106px, 7.7598828697vw) 0 max(84px, 6.149341142vw);
  }
}
.main-ctn > #campaign {
  padding-bottom: 9.6vw;
  background-color: var(--color-gray);
}
@media (min-width: 768px) {
  .main-ctn > #campaign {
    padding-bottom: max(84px, 6.149341142vw);
  }
}
.main-ctn > .campaign-ctn {
  padding: 19.2vw 0 30.6666666667vw;
}
@media (min-width: 768px) {
  .main-ctn > .campaign-ctn {
    padding: max(140px, 10.2489019034vw) 0 max(130px, 9.5168374817vw);
  }
}
.main-ctn > .about-ctn {
  margin: 24vw auto 0;
  padding-bottom: 17.0666666667vw;
  width: 90.6666666667vw;
}
@media (min-width: 768px) {
  .main-ctn > .about-ctn {
    margin: max(156px, 11.420204978vw) auto 0;
    padding-bottom: max(146px, 10.6881405564vw);
    width: max(1200px, 87.8477306003vw);
  }
}
.main-ctn > .scene-ctn {
  margin: 0 auto;
  padding-top: 17.3333333333vw;
  width: 90.6666666667vw;
}
@media (min-width: 768px) {
  .main-ctn > .scene-ctn {
    padding-top: max(106px, 7.7598828697vw);
    width: max(1200px, 87.8477306003vw);
  }
}
.main-ctn > .choitashi-ctn {
  margin: 31.4666666667vw auto 0;
  width: 90.6666666667vw;
}
@media (min-width: 768px) {
  .main-ctn > .choitashi-ctn {
    margin: max(140px, 10.2489019034vw) auto 0;
    width: max(1200px, 87.8477306003vw);
  }
}
.main-ctn > .movie-ctn {
  margin-top: 17.3333333333vw;
}
@media (min-width: 768px) {
  .main-ctn > .movie-ctn {
    margin-top: max(72px, 5.270863836vw);
  }
}
.main-ctn > .profile-ctn {
  margin: 21.3333333333vw auto 0;
  width: 90.6666666667vw;
}
@media (min-width: 768px) {
  .main-ctn > .profile-ctn {
    margin: max(112px, 8.1991215227vw) auto 0;
    width: max(1200px, 87.8477306003vw);
  }
}
.main-ctn > .ec-wrap {
  margin: 44px auto 48px;
}
@media (min-width: 768px) {
  .main-ctn > .ec-wrap {
    margin-bottom: 80px;
  }
}
.main-ctn > .floating-box {
  position: fixed;
  z-index: 1;
}
.main-ctn > .floating-box.-first {
  right: 3.2vw;
  bottom: 2.6666666667vw;
  width: 21.3333333333vw;
}
@media (min-width: 768px) {
  .main-ctn > .floating-box.-first {
    right: max(22px, 1.6105417277vw);
    bottom: max(20px, 1.4641288433vw);
    width: max(160px, 11.7130307467vw);
  }
}
.main-ctn .soy-campaign-footer {
  margin-top: 1.3333333333vw;
}
@media screen and (max-width: 767px) {
  .main-ctn .u-hidden-sm {
    display: none !important;
    visibility: hidden;
  }
}
@media screen and (min-width: 768px) {
  .main-ctn .u-hidden-lg {
    display: none !important;
    visibility: hidden;
  }
}
.main-ctn > *:not(.ec-wrap) {
  font-feature-settings: "palt";
}
.main-ctn > *:not(.ec-wrap) img,
.main-ctn > *:not(.ec-wrap) video {
  width: 100%;
  height: auto;
}
.main-ctn > *:not(.ec-wrap) h2 {
  padding: 0;
  font-size: 0;
}