@charset 'UTF-8';

:root {
  --white: #fff;
  --yellow: #fbff00;
  --blue: #0072fb;
  --lightblue: #45ffff;
  --main-width: 100vw;
}

* {
  -webkit-tap-highlight-color: transparent;
}

html, body {
  position: relative;
  height: 100%;
}

html {
  font-size: 10px;
  scroll-behavior: smooth;
}

body {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: calc(var(--main-width) * (4.8 / 100));
  font-style: normal;
  font-weight: 700;
  font-feature-settings: "palt";
  font-optical-sizing: auto;
  line-height: 1.6;
  color: var(--blue);
  letter-spacing: 0.04em;
}

body::before, body::after {
  position: fixed;
  left: 0;
  display: block;
  width: 100vw;
  height: 50%;
  content: '';
}

body::before {
  top: -49.9999%;
  background: #ebffff;
}

body::after {
  bottom: -50%;
  background: var(--yellow);
}

h2 {
  margin-bottom: 2em;
}

p {
  margin: 1.5em 0;
}

a {
  color: var(--black);
  text-decoration: none;
}

.full {
  width: 100%;
  height: auto;
}

.benesse-logo {
  position: absolute;
  top: 2vw;
  left: 3vw;
  z-index: 99999;
  width: calc(var(--main-width) * (20.267 / 100));
  aspect-ratio: 260 / 62;
}

main {
  overflow-x: hidden;
}

.sidebar-left, .sidebar-right {
  display: none;
}

.page-header-container {
  position: fixed;
  z-index: 99990;
  width: var(--main-width);
}

.page-header {
  display: grid;
  place-items: center center;
  padding: calc(var(--main-width) * (2 / 100)) 0;
  background: #fffd;
}

img[src*="/title.png"] {
  width: calc(var(--main-width) * (36.267 / 100));
  height: auto;
}

.kv-container {
  position: relative;
  height: 100dvh;
  overflow: hidden;
}

.kv {
  height: 100%;
  margin-top: -4%;
  background: var(--lightblue);
}

.kv-buttons-container {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}

.kv-marquee {
  position: relative;
  overflow: hidden;
  white-space: nowrap;
}

.kv-marquee-inner {
  display: inline-block;
}

.kv-face {
  display: inline-block;
  height: auto;
  padding: 1rem 1.5rem;
}

.kv-face01 {
  width: calc(var(--main-width) * (64.8 / 100));
}

.kv-face02 {
  width: calc(var(--main-width) * (72.267 / 100));
}

.kv-face03 {
  width: calc(var(--main-width) * (64.8 / 100));
}

.kv-face04 {
  width: calc(var(--main-width) * (65.067 / 100));
}

.kv-face05 {
  width: calc(var(--main-width) * (64.8 / 100));
}

.kv-face06 {
  width: calc(var(--main-width) * (65.067 / 100));
}

.kv-face07 {
  width: calc(var(--main-width) * (72 / 100));
}

.kv-face08 {
  width: calc(var(--main-width) * (65.067 / 100));
}

.kv-buttons {
  display: flex;
  gap: 0.6rem;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 2% 0;
  background: #fffd;
}

img[src*="campaign.png"] {
  width: 17.3rem;
  height: auto;
}

img[src*="/instagram.png"] {
  width: 17rem;
  height: auto;
}

.section-inner {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  width: 100%;
}

.section1 {
  position: relative;
}

.section1-inner {
  left: calc(50% - var(--main-width) / 2);
  width: var(--main-width);
  text-align: center;
  background: var(--yellow);
}

.section1-text1 {
  padding-top: calc(var(--main-width) * (20.266 / 100));
  padding-bottom: calc(var(--main-width) * (25.599 / 100));
}

.section1-text1 h2 {
  font-size: calc(var(--main-width) * (8 / 100));
  font-weight: 700;
}

.card-container {
  perspective: calc(var(--main-width) * (666.667 / 100));
}

.card {
  position: relative;
  margin: auto;
  transition: transform 0.2s;
  transform-style: preserve-3d;
}

.card-front, .card-back {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
}

.card-back {
  transform: rotateY(180deg)
}

.card-image {
  width: 100%;
  height: 100%;
}

.card01 {
  transform: rotate(5deg);
}

.card01 .card {
  width: calc(var(--main-width) * (73.333 / 100));
  aspect-ratio: 550 / 636;
}

.card02 {
  margin-top: calc(var(--main-width) * (13 / 100));
  transform: rotate(9deg);
}

.card02 .card {
  width: calc(var(--main-width) * (68 / 100));
  aspect-ratio: 510 / 636;
}

.card03 {
  margin-top: calc(var(--main-width) * (13 / 100));
  transform: rotate(0deg);
}

.card03 .card {
  width: calc(var(--main-width) * (74.667 / 100));
  aspect-ratio: 560 / 686;
}

.card04 {
  margin-top: calc(var(--main-width) * (13 / 100));
  transform: rotate(-5deg);
}

.card04 .card {
  width: calc(var(--main-width) * (81.333 / 100));
  aspect-ratio: 610 / 608;
}

.card05 {
  margin-top: calc(var(--main-width) * (10 / 100));
  transform: rotate(5deg);
}

.card05 .card {
  width: calc(var(--main-width) * (78.4 / 100));
  aspect-ratio: 588 / 638;
}

.card06 {
  margin-top: calc(var(--main-width) * (13 / 100));
  transform: rotate(0deg);
}

.card06 .card {
  width: calc(var(--main-width) * (79.467 / 100));
  aspect-ratio: 596 / 630;
}

.card07 {
  margin-top: 0;
  margin-left: calc(var(--main-width) * (10 / 100));
  transform: rotate(28deg);
}

.card07 .card {
  width: calc(var(--main-width) * (89.067 / 100));
  aspect-ratio: 668 / 726;
}

.card08 {
  margin-top: calc(var(--main-width) * (18 / 100));
  transform: rotate(-5deg);
}

.card08 .card {
  width: calc(var(--main-width) * (81.067 / 100));
  aspect-ratio: 608 / 690;
}

.scrollarrow-container {
  position: relative;
  padding-bottom: calc(var(--main-width) * (20 / 100));
  margin-top: calc(var(--main-width) * (14 / 100));
}

img[src*="/scrollarrow.svg"] {
  position: absolute;
  top: 0;
  left: 50%;
  width: calc(var(--main-width) * (3.733 / 100));
  height: auto;
  transform: translate(-50%, 0);
  animation: slide-bottom-alternate 1s ease-in 0s infinite alternate none;
}

img[src*="/scrolltext.svg"] {
  position: absolute;
  top: 0;
  left: calc(50% + var(--main-width) * (5.333 / 100));
  width: calc(var(--main-width) * (1.892 / 100));
  height: auto;
  transform: translate(-50%, 60%);
}

.section2 {
  position: relative;
}

.section2.scrolllock::before {
  position: absolute;
  top: -100dvh;
  left: 0;
  z-index: 100;
  display: block;
  width: 100%;
  height: 100dvh;
  content: '';
}

.section2-inner {
  padding-top: calc(var(--main-width) * (63.467 / 100));
  background: var(--white) top center / var(--main-width) auto url('../asobo-bg01.svg') no-repeat;
}

.section2-content01 {
  text-align: center;
}

img[src*="/asobo-img01.png"] {
  position: relative;
  z-index: 40;
  width: calc(var(--main-width) * (91.733 / 100));
  height: auto;
}

.section2-content01-text {
  position: relative;
  margin-top: calc(var(--main-width) * (-7 / 100));
}

.section2-content01-text p {
  position: relative;
  z-index: 30;
}

.section2-content01-text-bg {
  position: absolute;
  top: calc(var(--main-width) * (-14 / 100));
  left: 0;
  z-index: 20;
  width: var(--main-width);
  aspect-ratio: 1;
  background: var(--lightblue);
  border-radius: 50%;
}

.section2-content02 {
  position: relative;
  z-index: 10;
  padding-top: calc(var(--main-width) * (60 / 100));
  margin-top: calc(var(--main-width) * (-50 / 100));
  text-align: center;
  background: top center / var(--main-width) auto url('../asobo-bg02.png');
}

.op0 {
  opacity: 0;
}

.zoom-forward {
  animation: zoom 500ms linear forwards;
}

.zoom-reverse {
  animation: zoom 400ms linear reverse forwards;
}

.zoom2-forward {
  animation: zoom2 800ms linear forwards;
}

.zoom2-reverse {
  animation: zoom2 400ms linear reverse forwards;
}

img[src*="/kouza.png"] {
  display: block;
  width: calc(var(--main-width) * (84.533 / 100));
  height: auto;
  margin: calc(var(--main-width) * (8.533 / 100)) auto calc(var(--main-width) * (35 / 100) / 2);
}

.trial {
  width: 100%;
  height: calc(var(--main-width) * (35 / 100) / 2);
}

img[src*="/asobo-txt01.png"] {
  width: calc(var(--main-width) * (68.8 / 100));
  height: auto;
}

/*
.rainbow-container {
  position: relative;
  width: calc(var(--main-width) * (90.133 / 100));
  aspect-ratio: 338 / 551;
  margin: calc(var(--main-width) * (68.267 / 100)) auto 0;
}

.rainbow-frame {
  width: 100%;
  height: 100%;
  padding: calc(var(--main-width) * (8 / 100)) calc(var(--main-width) * (5.067 / 100));
  background: center / 100% auto url('../asobo-frm01.svg') no-repeat;
}
*/

.rainbow-container {
  position: relative;
  width: calc(var(--main-width) * (90.133 / 100));
  aspect-ratio: 338 / 430;
  margin: calc(var(--main-width) * (68.267 / 100)) auto 0;
}

.rainbow-frame {
  width: 100%;
  height: 100%;
  padding: calc(var(--main-width) * (8 / 100)) calc(var(--main-width) * (5.067 / 100));
  background: center / 100% auto url('../asobo-frm01b.svg') no-repeat;
}

.rainbow-text {
  position: absolute;
  top: calc(var(--main-width) * (-23 / 100));
  right: 0;
  width: calc(var(--main-width) * (64 / 100));
  aspect-ratio: 480 / 166;
}

.tags-container {
  margin-top: calc(var(--main-width) * (6.667 / 100));
}

.puppet-container + .tags-container {
  margin-top: calc(var(--main-width) * (24 / 100));
}

.tags {
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--main-width) * (2 / 100));
  justify-content: center;
}

.tag {
  padding: calc(var(--main-width) * (0.533 / 100)) calc(var(--main-width) * (3.2 / 100));
  font-size: calc(var(--main-width) * (4.2 / 100));
  color: var(--white);
  background: #833513;
  border-radius: 5vw;
}

.taparea-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  aspect-ratio: 586 / 632;
}

.taparea {
  position: absolute;
  cursor: pointer;
}

.taparea1 {
  top: calc(var(--main-width) * (75 / 100));
  left: calc(var(--main-width) * (5 / 100));
  width: calc(var(--main-width) * (10 / 100));
  height: calc(var(--main-width) * (12 / 100));
}

.taparea2 {
  top: calc(var(--main-width) * (79 / 100));
  left: calc(var(--main-width) * (28 / 100));
  width: calc(var(--main-width) * (10 / 100));
  height: calc(var(--main-width) * (12 / 100));
}

.taparea3 {
  top: calc(var(--main-width) * (61 / 100));
  left: calc(var(--main-width) * (46 / 100));
  width: calc(var(--main-width) * (10 / 100));
  height: calc(var(--main-width) * (11 / 100));
}

.taparea4 {
  top: calc(var(--main-width) * (51 / 100));
  left: calc(var(--main-width) * (63 / 100));
  width: calc(var(--main-width) * (11 / 100));
  height: calc(var(--main-width) * (12 / 100));
}

.taparea5 {
  top: calc(var(--main-width) * (72 / 100));
  left: calc(var(--main-width) * (70 / 100));
  width: calc(var(--main-width) * (10 / 100));
  height: calc(var(--main-width) * (12 / 100));
}

.rainbow-balloon {
  width: calc(var(--main-width) * (70.667 / 100));
  aspect-ratio: 265 / 194;
  margin: calc(var(--main-width) * (-6.5 / 100)) auto 0;
  background: center / 100% auto url('../asobo-frm02.svg') no-repeat;
}

.rainbow-balloon-img-container {
  display: grid;
  place-items: center center;
  width: 100%;
  height: 100%;
  padding: calc(var(--main-width) * (8 / 100)) calc(var(--main-width) * (3 / 100)) calc(var(--main-width) * (3 / 100));
  background: center calc(var(--main-width) * (21 / 100)) / calc(var(--main-width) * (35.2 / 100)) auto url('../asobo-txt03.png') no-repeat;
}

img[src*="/asobo-txt03.png"] {
  width: calc(var(--main-width) * (35.2 / 100));
  height: auto;
}

.taparea-container:has(.taparea1:hover) + .rainbow-balloon > .rainbow-balloon-img-container {
  background: center calc(var(--main-width) * (12 / 100)) / calc(var(--main-width) * (52 / 100)) auto url('../_dummy-gif-animation.png') no-repeat;
}

.taparea-container:has(.taparea2:hover) + .rainbow-balloon > .rainbow-balloon-img-container {
  background: center calc(var(--main-width) * (12 / 100)) / calc(var(--main-width) * (52 / 100)) auto url('../_dummy-gif-animation.png') no-repeat;
}

.taparea-container:has(.taparea3:hover) + .rainbow-balloon > .rainbow-balloon-img-container {
  background: center calc(var(--main-width) * (12 / 100)) / calc(var(--main-width) * (52 / 100)) auto url('../_dummy-gif-animation.png') no-repeat;
}

.taparea-container:has(.taparea4:hover) + .rainbow-balloon > .rainbow-balloon-img-container {
  background: center calc(var(--main-width) * (12 / 100)) / calc(var(--main-width) * (52 / 100)) auto url('../_dummy-gif-animation.png') no-repeat;
}

.taparea-container:has(.taparea5:hover) + .rainbow-balloon > .rainbow-balloon-img-container {
  background: center calc(var(--main-width) * (12 / 100)) / calc(var(--main-width) * (52 / 100)) auto url('../_dummy-gif-animation.png') no-repeat;
}

.puppet-container {
  position: relative;
  width: calc(var(--main-width) * (90.133 / 100));
  aspect-ratio: 676 / 986;
  margin: calc(var(--main-width) * (56 / 100)) auto 0;
}

.puppet-text1 {
  position: absolute;
  top: calc(var(--main-width) * (-20 / 100));
  left: calc(var(--main-width) * (-1 / 100));
  width: calc(var(--main-width) * (62.4 / 100));
  height: auto;
}

.puppet-frame1 {
  width: 100%;
  height: 100%;
  background: center / 100% auto url('../asobo-frm03.png') no-repeat;
}

.puppet-frame2 {
  position: absolute;
  bottom: calc(var(--main-width) * (-17 / 100));
  left: calc(var(--main-width) * (8 / 100));
  width: calc(var(--main-width) * (46.4 / 100));
  height: calc(var(--main-width) * (46.4 / 100));
  background: var(--white);
  border: calc(var(--main-width) * (0.7 / 100)) solid #fb019e;
  border-radius: 50%;
}

.puppet-text2 {
  position: absolute;
  top: var(--main-width);
  left: calc(var(--main-width) * (-2.7 / 100));
  z-index: 10;
  width: calc(var(--main-width) * (72.267 / 100));
  height: auto;
}

.puppet-animation1-wrap {
  position: relative;
  top: calc(var(--main-width) * (1.3 / 100));
  width: 100%;
  height: 100%;
  clip-path: url("#puppet-animation1-mask");
}

.puppet-animation1 {
  position: relative;
  top: calc(var(--main-width) * (42 / 100));
  left: calc(var(--main-width) * (-2 / 100));
  width: calc(var(--main-width) * (64 / 100));
  height: auto;
}

.puppet-animation1-mask {
  transform: scale(0.00297, 0.00199); /* stylelint-disable-line number-max-precision */
}

.puppet-animation2-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  clip-path: circle(50%);
}

.puppet-animation2 {
  position: absolute;
  top: calc(var(--main-width) * (11 / 100));
  left: calc(var(--main-width) * (3 / 100));
  width: 90%;
  height: auto;
}

.startset-container {
  position: relative;
  width: calc(var(--main-width) * (88.533 / 100));
  height: auto;
  margin: calc(var(--main-width) * (20 / 100)) auto 0;
}

img[src*="/asobo-banner-arrow.svg"] {
  position: absolute;
  top: calc(var(--main-width) * (40 / 100));
  left: calc(var(--main-width) * (32 / 100));
  width: calc(var(--main-width) * (9.6 / 100));
  height: calc(var(--main-width) * (10.667 / 100));
  animation: asobo-banner-arrow 600ms ease-in infinite;
}

.section2-end {
  height: calc(var(--main-width) * (31.733 / 100));
  background: center bottom / calc(var(--main-width) * (27.2 / 100)) auto url('../yellow-border.svg') repeat-x;
}

.shape-container {
  position: absolute;
}

.shape {
  animation: shape 2000ms ease-in-out alternate infinite;
}

.shape01 {
  top: calc(var(--main-width) * (150 / 100));
  left: calc(var(--main-width) * (-14 / 100));
  width: calc(var(--main-width) * (44.533 / 100));
  aspect-ratio: 334 / 288;
}

.shape02 {
  top: calc(var(--main-width) * (250 / 100));
  left: calc(var(--main-width) * (-14 / 100));
  width: calc(var(--main-width) * (49.333 / 100));
  aspect-ratio: 370 / 342;
}

.shape02 .shape {
  animation-duration: 2500ms;
}

.shape03 {
  top: calc(var(--main-width) * (212 / 100));
  right: calc(var(--main-width) * (-13 / 100));
  width: calc(var(--main-width) * (49.333 / 100));
  aspect-ratio: 370 / 342;
}

.shape03 .shape {
  animation-duration: 1800ms;
}

.shape04 {
  /* top: calc(var(--main-width) * (428 / 100)); */
  top: calc(var(--main-width) * (400 / 100));
  right: calc(var(--main-width) * (-19 / 100));
  width: calc(var(--main-width) * (50.667 / 100));
  aspect-ratio: 380 / 310;
}

.shape05 {
  /* top: calc(var(--main-width) * (475 / 100)); */
  top: calc(var(--main-width) * (458 / 100));
  left: calc(var(--main-width) * (-20 / 100));
  width: calc(var(--main-width) * (51.467 / 100));
  aspect-ratio: 386 / 266;
}

.shape05 .shape {
  animation-duration: 1300ms;
}

.shape06 {
  /* top: calc(var(--main-width) * (580 / 100)); */
  top: calc(var(--main-width) * (570 / 100));
  right: calc(var(--main-width) * (-35 / 100));
  width: calc(var(--main-width) * (59.2 / 100));
  aspect-ratio: 444 / 444;
}

.shape06 .shape {
  animation-duration: 2200ms;
}

.section3 {
  position: relative;
}

.section3-inner {
  padding-top: calc(var(--main-width) * (8 / 100));
  padding-bottom: calc(var(--main-width) * (13.333 / 100));
  text-align: center;
  background: var(--yellow);
}

main img[src*="banner-campaign.png"] {
  width: calc(var(--main-width) * (93.733 / 100));
  height: auto;
}

main img[src*="/banner-news.png"] {
  width: calc(var(--main-width) * (77.6 / 100));
  height: auto;
  margin-top: calc(var(--main-width) * (7.467 / 100));
}

main img[src*="/banner-instagram.png"] {
  width: calc(var(--main-width) * (84.8 / 100));
  height: auto;
  margin-top: calc(var(--main-width) * (10.667 / 100));
}

.banner1, .banner1 img, .banner2, .banner2 img {
  position: relative;
  display: inline-block;
}

.banner1:hover {
  animation: banner2 600ms ease 0s forwards;
}

.banner2:hover {
  animation: banner2 600ms ease 0s forwards;
}

@media screen and (width >= 650px) {
  body {
    background: var(--yellow) center top / 100px auto url('../body-bg.svg') repeat-x fixed;
    border-top: 1px solid var(--white);
  }

  body::before {
    top: calc(-49.9999% + 60px);
    background: var(--white);
  }

  .benesse-logo {
    position: fixed;
    top: 15px;
    left: 20px;
    width: calc(var(--main-width) * (34.667 / 100));
  }

  .layout {
    position: relative;
    width: 100%;
    max-width: 1200px;
    margin: auto;
  }

  .main-top {
    position: fixed;
    top: 60px;
    left: 50%;
    z-index: 99999;
    box-sizing: content-box;
    width: 375px;
    height: 60px;
    border: 4px solid #002cc1;
    border-bottom: none;
    border-top-left-radius: 40px;
    border-top-right-radius: 40px;
    transform: translateX(-50%);
  }

  .main-mask {
    position: fixed;
    top: 0;
    left: 50%;
    z-index: 99999;
    width: 385px;
    height: 100px;
    background: center top / 100% auto url("../main-mask650.svg") no-repeat;
    transform: translateX(-50%);
  }

  main {
    box-sizing: content-box;
    width: 375px;
    padding-top: 60px;
    margin: auto;
    overflow: hidden;
    background: var(--yellow);
    border-right: 4px solid #002cc1;
    border-left: 4px solid #002cc1;
  }

  .page-header-container {
    top: 60px;
  }

  .kv-container {
    height: calc(100dvh - 60px);
  }
}

@media screen and (width >= 1100px) {
  .page-header-container {
    display: none;
  }

  .sidebar-left, .sidebar-right {
    position: fixed;
    top: 60px;
    display: block;
    width: calc((100vw - 383px) / 2);
    min-width: 300px;
    height: calc(100% - 60px);
  }

  .sidebar-left {
    left: 0;
    padding-right: 40px;
    text-align: right;
  }

  .sidebar-right {
    right: 0;
    padding-left: 40px;
  }

  .sidebar-pos {
    position: relative;
    display: inline-block;
  }

  .sidebar-inner {
    display: flex;
    flex-direction: column;
    gap: 20px;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    max-height: calc(100% - 20px);
  }

  .sidebar-right .sidebar-inner {
    gap: 70px;
    justify-content: center;
  }

  .sidebar-inner img.full {
    width: auto;
    max-height: 190px;
  }

  .sidebar-inner img[src*="/title-big.png"].full {
    width: auto;
    max-height: 160px;
  }

  .sidebar-menu {
    font-size: 14px;
    font-weight: 400;
    list-style: decimal-leading-zero;
  }

  .sidebar-menu li:not(:first-child) {
    margin-top: 1.5em;
  }

  .sidebar-menu a {
    font-size: 18px;
    font-weight: 700;
  }

  .sidebar-right img[src*="/banner-news.png"].full {
    width: 233px;
    height: auto;
  }

  .section2-end {
  height: calc(var(--main-width) * (10 / 100));
  background: none;
  }

  .section3 {
    display: none;
  }
}

@media screen and (width >= 650px) and (height >= 750px) {
  .main-top {
    top: 80px;
  }

  .main-mask {
    height: 120px;
    background-image: url("../main-mask750.svg");
  }

  main {
    padding-top: 80px;
  }

  .page-header-container {
    top: 80px;
  }

  .kv-container {
    height: calc(100dvh - 80px);
  }

  .sidebar-left, .sidebar-right {
    top: 80px;
    height: calc(100% - 80px);
  }

  .sidebar-inner img.full {
    width: auto;
    max-height: 210px;
  }

  .sidebar-inner img[src*="/title-big.png"].full {
    width: auto;
    max-height: 180px;
  }
}

@media screen and (width >= 650px) and (height >= 850px) {
  .main-top {
    top: 100px;
  }

  .main-mask {
    height: 140px;
    background-image: url("../main-mask850.svg");
  }

  main {
    padding-top: 100px;
  }

  .page-header-container {
    top: 100px;
  }

  .kv-container {
    height: calc(100dvh - 100px);
  }

  .sidebar-left, .sidebar-right {
    top: 100px;
    height: calc(100% - 100px);
  }

  .sidebar-inner img.full {
    width: auto;
    max-height: 230px;
  }

  .sidebar-inner img[src*="/title-big.png"].full {
    width: auto;
    max-height: 200px;
  }
}

@media screen and (width >= 650px) and (height >= 950px) {
  .main-top {
    top: 120px;
  }

  .main-mask {
    height: 160px;
    background-image: url("../main-mask950.svg");
  }

  main {
    padding-top: 120px;
  }

  .page-header-container {
    top: 120px;
  }

  .kv-container {
    height: calc(100dvh - 120px);
  }

  .sidebar-left, .sidebar-right {
    top: 120px;
    height: calc(100% - 120px);
  }

  .sidebar-inner img.full {
    width: auto;
    max-height: 250px;
  }
}

@media screen and (width >= 650px) and (height >= 1050px) {
  .main-top {
    top: 140px;
  }

  .main-mask {
    height: 180px;
    background-image: url("../main-mask1050.svg");
  }

  main {
    padding-top: 140px;
  }

  .page-header-container {
    top: 140px;
  }

  .kv-container {
    height: calc(100dvh - 140px);
  }

  .sidebar-left, .sidebar-right {
    top: 140px;
    height: calc(100% - 140px);
  }
}

@keyframes slide-bottom-alternate {
  0% {
    transform: translateY(0);
  }

  100% {
    transform: translateY(calc(var(--main-width) * (6 / 100)));
  }
}

@keyframes zoom {
  0% {
    opacity: 0;
    transform: matrix3d(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
  }

  3.1% { transform: matrix3d(.3, 0, 0, 0, 0, .3, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }

  63.26% {
    opacity: 1;
    transform: matrix3d(1.1, 0, 0, 0, 0, 1.1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
  }

  100% {
    opacity: 1;
    transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
  }
}

@keyframes zoom2 {
  0% {
    opacity: 0;
    transform: matrix3d(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
  }

  3.1% {
    opacity: 1;
    transform: matrix3d(.382, 0, 0, 0, 0, .241, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
  }

  4.7% { transform: matrix3d(.593, 0, 0, 0, 0, .411, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  6.21% { transform: matrix3d(.773, 0, 0, 0, 0, .579, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  9.31% { transform: matrix3d(1.044, 0, 0, 0, 0, .898, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  9.41% { transform: matrix3d(1.05, 0, 0, 0, 0, .907, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  12.41% { transform: matrix3d(1.16, 0, 0, 0, 0, 1.115, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  14.11% { transform: matrix3d(1.173, 0, 0, 0, 0, 1.184, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  18.72% { transform: matrix3d(1.119, 0, 0, 0, 0, 1.231, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  20.12% { transform: matrix3d(1.095, 0, 0, 0, 0, 1.218, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  24.32% { transform: matrix3d(1.037, 0, 0, 0, 0, 1.148, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  27.73% { transform: matrix3d(1.011, 0, 0, 0, 0, 1.082, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  29.93% { transform: matrix3d(1.001, 0, 0, 0, 0, 1.044, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  35.54% { transform: matrix3d(.991, 0, 0, 0, 0, .978, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  41.04% { transform: matrix3d(.99, 0, 0, 0, 0, .961, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  43.14% { transform: matrix3d(.99, 0, 0, 0, 0, .963, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  52.15% { transform: matrix3d(.998, 0, 0, 0, 0, .991, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  58.56% { transform: matrix3d(1.001, 0, 0, 0, 0, 1.005, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  63.26% { transform: matrix3d(1.002, 0, 0, 0, 0, 1.007, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);}
  73.97% { transform: matrix3d(1.001, 0, 0, 0, 0, 1.002, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  85.49% { transform: matrix3d(1, 0, 0, 0, 0, .999, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }
  89.39% { transform: matrix3d(1, 0, 0, 0, 0, .999, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); }

  100% {
    opacity: 1;
    transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
  }
}

@keyframes asobo-banner-arrow {
  0% { transform: translateX(0); }
  100% { transform: translateX(calc(var(--main-width) * (3 / 100))); }
}

@keyframes shape {
  0% { transform: rotateZ(0); }
  100% { transform: rotateZ(20deg); }
}

@keyframes banner1 {
  0%, 100% { transform: translateX(0); }
  10%, 30%, 50%, 70% { transform: translateX(calc(var(--main-width) * (-1.5 / 100))); }
  20%, 40%, 60% { transform: translateX(calc(var(--main-width) * (1.5 / 100))); }
  80% { transform: translateX(calc(var(--main-width) * (0.5 / 100))); }
  90% { transform: translateX(calc(var(--main-width) * (-0.5 / 100)));}
}

@keyframes banner2 {
  0%, 100% { transform: translateY(0); }
  70% { transform: translateY(calc(var(--main-width) * (-1.5 / 100))); }
  20% { transform: translateY(calc(var(--main-width) * (1.5 / 100))); }
  80% { transform: translateY(calc(var(--main-width) * (0.5 / 100))); }
  90% { transform: translateY(calc(var(--main-width) * (-0.5 / 100)));}
}
