@charset "UTF-8";
a:link, a:visited {
  color: #000;
  text-decoration: none;
}
* {
  margin: 0;
  padding: 0;
}

ul {
  list-style-type: none;
  padding: 0;
}

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

* html body {
  overflow-y: auto;
}

* + html body {
  overflow-y: auto;
}

body {
  overflow-y: scroll;
}

.wp-block-group {
  margin-bottom: 0 !important;
}

html {
  -webkit-overflow-scrolling: touch;
}

input, textarea {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

img {
  vertical-align: bottom;
  border: 0;
  max-width: 100%;
  height: auto;
  width: auto;
  image-rendering: auto;
}

body {
  font-family: "Hiragino Sans", -apple-system, BlinkMacSystemFont, "Noto Sans JP", sans-serif;
  font-size: clamp(12px, 4vw, 20px);
  font-style: normal;
  background: #fffcdb;
  -webkit-text-size-adjust: 100%;
}

.pc, .pc-768, .pc-480, .pc-360 {
  display: initial;
}

.sp, .sp-1080, .sp-768, .sp-680, .sp-480, .sp-360 {
  display: none;
}

@media screen and (min-width: 1280px) {
  .pc-contents {
    display: initial;
  }
  .sp-contents {
    display: none;
  }
}
@media screen and (max-width: 1280px) {
  .pc-contents {
    display: none;
  }
  .sp-contents {
    display: initial;
  }
}
@media screen and (min-width: 1280px) {
  button.hamburger,
  nav#mobileMenu {
    display: none;
  }
}
h2 {
  text-align: center;
}

div.inner {
  margin: auto;
}

a.button {
  position: relative;
}
a.button:after {
  content: "";
  width: clamp(12px, 3vw, 24px);
  height: 24px;
  background: url(../images/common/icon_arrow_white01.svg) no-repeat;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  position: absolute;
  top: 9px;
  right: 14px;
}
a.button {
  font-size: clamp(12px, 5vw, 30px);
  font-weight: bold;
  color: #fff;
  text-align: center;
  background: #8fd3f5;
  border-radius: 99px;
  display: block;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  margin: auto;
  padding: clamp(10px, 3vw, 20px) 0;
}
@media (hover: hover) and (pointer: fine) {
  a.button:hover {
    -webkit-box-shadow: 0 0 10px rgb(96.1803278689, 192.606557377, 240.8196721311);
            box-shadow: 0 0 10px rgb(96.1803278689, 192.606557377, 240.8196721311);
    -webkit-transition: 0.3s;
    transition: 0.3s;
    background: rgb(189.8196721311, 229.393442623, 249.1803278689);
  }
}

[data-aos=fade-up] {
  -webkit-transform: translateY(20px);
          transform: translateY(20px); /* デフォルトは大体100px前後 */
}

[data-aos=fade-up].aos-animate {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

button.pagetop {
  width: 50px;
  height: 65px;
  background: none;
  border: none;
  cursor: pointer;
  position: sticky;
  left: calc(100vw - 5.5em);
  bottom: 15px;
  z-index: 99;
  margin-top: -65px;
}

main {
  margin: auto;
}

header.header div.inner,
footer div.inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}
header.header figure#fLogo,
footer figure#fLogo {
  max-width: clamp(200px, 40vw, 300px);
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header.header figure#fLogo a, header.header figure#fLogo img,
footer figure#fLogo a,
footer figure#fLogo img {
  width: 100%;
}
@media (hover: hover) and (pointer: fine) {
  header.header figure#fLogo a img,
  footer figure#fLogo a img {
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
  }
  header.header figure#fLogo a:hover img,
  footer figure#fLogo a:hover img {
    -webkit-transform: scale(1.05, 1.05);
            transform: scale(1.05, 1.05);
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
  }
}

header.header {
  background: #8fd3f5;
  position: relative;
  z-index: 99;
}
header.header div.inner {
  max-width: 1280px;
  overflow: initial;
  margin: auto;
  padding: 40px;
}
header.header h1 {
  max-width: clamp(200px, 40vw, 300px);
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header.header h1 a, header.header h1 img {
  width: 100%;
}
@media (hover: hover) and (pointer: fine) {
  header.header h1 a img {
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
  }
  header.header h1 a:hover img {
    -webkit-transform: scale(1.05, 1.05);
            transform: scale(1.05, 1.05);
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
  }
}

footer div.inner {
  max-width: 1280px;
  font-weight: bold;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  padding: 30px 0 50px 0;
}

div#copyright {
  width: 100%;
  font-size: clamp(12px, 4vw, 24px);
  font-weight: bold;
  text-align: center;
  background: #8fd3f5;
  padding: clamp(10px, 5vw, 30px) 0;
}
@media screen and (-webkit-min-device-pixel-ratio: 2) and (max-width: 430px) {
  div#copyright {
    font-family: "M PLUS Rounded 1c", "Hiragino Sans", -apple-system, BlinkMacSystemFont, "Noto Sans JP", sans-serif;
  }
}

nav#gNavi ul,
nav#fNavi ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
}
nav#gNavi ul li,
nav#fNavi ul li {
  width: clamp(50px, 11vw, 120px);
}
nav#gNavi ul img,
nav#fNavi ul img {
  max-width: 120px;
  width: 100%;
  max-height: 130px;
}
@-moz-document url-prefix() {
  nav#gNavi ul img,
  nav#fNavi ul img {
    width: 100px;
  }
}
@media (hover: hover) and (pointer: fine) {
  nav#gNavi ul a p,
  nav#fNavi ul a p {
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
  }
  nav#gNavi ul a:hover p,
  nav#fNavi ul a:hover p {
    -webkit-transform: scale(1.15, 1.15);
            transform: scale(1.15, 1.15);
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
  }
}
nav#gNavi ul a,
nav#fNavi ul a {
  height: 100%;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 10px;
}
nav#gNavi ul p,
nav#fNavi ul p {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
nav#gNavi ul span,
nav#fNavi ul span {
  font-size: clamp(12px, 3vw, 22px);
}
nav#gNavi ul li:first-child,
nav#fNavi ul li:first-child {
  width: clamp(50px, 10vw, 130px);
}
nav#gNavi ul li:first-child P,
nav#fNavi ul li:first-child P {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
nav#gNavi ul li:nth-child(2) img,
nav#fNavi ul li:nth-child(2) img {
  max-width: 75px;
}
nav#gNavi ul li:nth-child(3) img,
nav#fNavi ul li:nth-child(3) img {
  max-width: 86px;
}
nav#gNavi ul li:nth-child(4),
nav#fNavi ul li:nth-child(4) {
  width: clamp(50px, 11vw, 150px);
}
nav#gNavi ul li:nth-child(4) img,
nav#fNavi ul li:nth-child(4) img {
  max-width: 142px;
}
nav#gNavi ul li:nth-child(5) P,
nav#fNavi ul li:nth-child(5) P {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
nav#gNavi ul li:nth-child(5) img,
nav#fNavi ul li:nth-child(5) img {
  max-width: 84px;
}
nav#gNavi ul li:last-child,
nav#fNavi ul li:last-child {
  width: clamp(50px, 10vw, 130px);
}
nav#gNavi ul li:last-child p,
nav#fNavi ul li:last-child p {
  padding-top: 20px;
}
section#stage {
  padding: clamp(10px, 5vw, 50px) 0 clamp(10px, 20vw, 50px) 0;
}
section#stage .splide__pagination {
  gap: 5px;
  bottom: clamp(-110px, -16vw, -40px);
}
section#stage .splide__pagination li button {
  width: clamp(10px, 4vw, 25px);
  height: clamp(10px, 4vw, 25px);
  background: #3b8ae3;
  opacity: 0.3;
}
section#stage .splide__pagination li button.is-active {
  opacity: 1;
}

section#concept {
  margin-bottom: 100px;
}
section#concept h2 img {
  max-width: clamp(200px, 60vw, 800px);
}
section#concept div.inner div {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 16px;
  text-align: center;
  line-height: 2;
  padding: 30px 0 80px 0;
}
section#concept div.inner figure {
  text-align: center;
}
section#concept div.inner figure img {
  max-width: clamp(200px, 80vw, 1000px);
}

section.topics {
  max-width: 1280px;
  margin: auto auto clamp(30px, 10vw, 100px) auto;
}
section.topics h2 {
  margin-bottom: clamp(20px, 5vw, 80px);
}
section.topics h2 img {
  width: clamp(100px, 50vw, 600px);
}
section.topics div#topics-inner article {
  width: 33.3333333333%;
}
section.topics div#topics-inner article figure {
  margin-bottom: 30px;
}
section.topics div#topics-inner article p {
  width: 55%;
  font-size: clamp(14px, 3vw, 36px);
  font-weight: bold;
  line-height: 1;
  position: relative;
  margin: auto;
  padding: 5px 0;
}
section.topics div#topics-inner article p:after {
  content: "";
  width: clamp(10px, 1.5vw, 20px);
  height: 27px;
  background: url(../images/common/icon_arrow01.svg) no-repeat;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  position: absolute;
  right: 0;
  top: 30%;
}
@media (hover: hover) and (pointer: fine) {
  section.topics div#topics-inner article:not(section.topics div#topics-inner article.noimage) figure, section.topics div#topics-inner article:not(section.topics div#topics-inner article.noimage) p, section.topics div#topics-inner article:not(section.topics div#topics-inner article.noimage) img {
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  section.topics div#topics-inner article:not(section.topics div#topics-inner article.noimage):hover figure, section.topics div#topics-inner article:not(section.topics div#topics-inner article.noimage):hover p, section.topics div#topics-inner article:not(section.topics div#topics-inner article.noimage):hover img {
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  section.topics div#topics-inner article:not(section.topics div#topics-inner article.noimage):hover img {
    -webkit-box-shadow: 0 0 10px #8fd3f5;
            box-shadow: 0 0 10px #8fd3f5;
  }
  section.topics div#topics-inner article:not(section.topics div#topics-inner article.noimage):hover p:after {
    -webkit-transition: 0.3s;
    transition: 0.3s;
    right: 10px;
  }
}
section.topics div#topics-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 60px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: clamp(20px, 8vw, 95px);
}
section.topics div#topics-inner h3 {
  display: none;
}
section.topics a.button {
  max-width: 450px;
  width: 80%;
}
section.topics a.button:after {
  top: 35%;
  right: 8%;
}
@media (hover: hover) and (pointer: fine) {
  section.topics a.button:hover:after {
    -webkit-transition: 0.3s;
    transition: 0.3s;
    right: 10%;
  }
}

section#story {
  max-width: 1280px;
  margin: auto auto clamp(30px, 10vw, 100px) auto;
}
section#story h2 {
  margin-bottom: clamp(30px, 10vw, 80px);
}
section#story h2 img {
  width: clamp(100px, 60vw, 620px);
}
section#story section.story_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 50px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
section#story section.story_box:nth-of-type(even) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
section#story section.story_box:not(:last-of-type) {
  margin-bottom: clamp(20px, 5vw, 60px);
}
section#story section.story_box figure {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 40%;
          flex: 1 0 40%;
  text-align: center;
}
section#story section.story_box figure img {
  max-width: 600px;
  width: 100%;
}
section#story section.story_box dl {
  max-width: 600px;
  -webkit-box-flex: 0;
      -ms-flex: 0 1 60%;
          flex: 0 1 60%;
  line-height: 1.6;
}
section#story section.story_box dl dt, section#story section.story_box dl dd {
  font-weight: bold;
}
section#story section.story_box dl dt {
  font-size: clamp(12px, 7vw, 45px);
  margin-bottom: 30px;
}
section#story section.story_box dl dd {
  font-size: clamp(12px, 10vw, 20px);
}
section#story section.story_box.dream {
  gap: 30px;
}
section#story section.story_box.dream figure {
  -webkit-box-flex: 0;
      -ms-flex: 0 1 50%;
          flex: 0 1 50%;
}
section#story section.story_box.dream figure img {
  max-width: 100%;
}
section#story section.story_box.dream dl {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 50%;
          flex: 1 0 50%;
}

section#profile {
  background: #c8e7e9;
  margin-bottom: clamp(30px, 10vw, 100px);
  padding: clamp(30px, 7vw, 100px) 0;
}
section#profile div.inner {
  max-width: 1280px;
  margin: auto;
}
section#profile h2 {
  margin-bottom: clamp(10px, 10vw, 120px);
}
section#profile h2 img {
  width: clamp(200px, 70vw, 720px);
}
section#profile section#profile-story_sp {
  display: none;
}
section#profile div.character {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 0 30px 30px 0;
  margin-bottom: 30px;
}
section#profile div.character figure {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 40%;
          flex: 1 0 40%;
  text-align: center;
}
section#profile div.character figure img {
  max-height: clamp(200px, 60vw, 450px);
}
section#profile div.character h3 {
  font-size: clamp(10px, 5vw, 30px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 40px;
}
section#profile div.character h3 img {
  max-width: clamp(50px, 50vw, 340px);
}
section#profile div.character div.chara-details {
  -webkit-box-flex: 0;
      -ms-flex: 0 1 60%;
          flex: 0 1 60%;
  font-size: 16px;
  line-height: 1.5;
  padding: 50px 30px 50px 0;
}
section#profile div.character div.chara-details dl dt {
  font-size: clamp(16px, 6vw, 36px);
  font-weight: bold;
  text-align: center;
  line-height: 1.2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 40px;
}
section#profile div.character div.chara-details dl dd {
  font-size: clamp(12px, 4vw, 20px);
  text-align: justify;
}
section#profile div.character div.chara-details dl dd h4 {
  font-size: clamp(16px, 5vw, 26px);
  font-weight: bold;
  margin-bottom: 20px;
}
section#profile div.character div.chara-details dl dd p {
  font-size: clamp(16px, 5vw, 22px);
  font-weight: bold;
  margin-bottom: 20px;
}
section#profile div.character.pokori {
  background: -webkit-gradient(linear, left top, right top, color-stop(30%, #c8e7e9), to(#f9d0c3));
  background: linear-gradient(to right, #c8e7e9 30%, #f9d0c3 100%);
}
section#profile div.character.damsook {
  background: -webkit-gradient(linear, left top, right top, color-stop(30%, #c8e7e9), to(#feebbe));
  background: linear-gradient(to right, #c8e7e9 30%, #feebbe 100%);
}
section#profile div.character.damsook h3 img {
  max-width: clamp(50px, 50vw, 480px);
}
section#profile div.character.buddy {
  background: -webkit-gradient(linear, left top, right top, color-stop(30%, #c8e7e9), to(#fadce9));
  background: linear-gradient(to right, #c8e7e9 30%, #fadce9 100%);
}
section#profile div.character.buddy h3 img {
  max-width: clamp(50px, 50vw, 360px);
}
section#profile div.character.lunzy {
  background: -webkit-gradient(linear, left top, right top, color-stop(30%, #c8e7e9), to(#edf2c5));
  background: linear-gradient(to right, #c8e7e9 30%, #edf2c5 100%);
}
section#profile div.character.lunzy h3 img {
  max-width: clamp(50px, 50vw, 360px);
}
section#profile div.character.dumbool {
  background: -webkit-gradient(linear, left top, right top, color-stop(30%, #c8e7e9), to(#e7d5e8));
  background: linear-gradient(to right, #c8e7e9 30%, #e7d5e8 100%);
}
section#profile div.character.dumbool h3 img {
  max-width: clamp(50px, 65vw, 500px);
}

section#creator {
  margin-bottom: clamp(30px, 15vw, 200px);
}
section#creator div.inner {
  max-width: 1280px;
  margin: auto;
}
section#creator h2 {
  margin-bottom: clamp(30px, 10vw, 100px);
}
section#creator h2 img {
  width: 100%;
}
section#creator div.creator_wrap {
  background: #2f875f;
  position: relative;
  padding: 120px 50px 180px 50px;
}
section#creator div.creator_wrap div.inner_free {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 50px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
section#creator div.creator_wrap div#photo, section#creator div.creator_wrap dl {
  width: 50%;
}
section#creator div.creator_wrap div {
  position: relative;
}
section#creator div.creator_wrap div figure {
  text-align: center;
  position: relative;
  z-index: 5;
  padding-top: 30px;
}
section#creator div.creator_wrap div figure img {
  width: 100%;
}
section#creator div.creator_wrap div p {
  position: absolute;
  top: -12%;
  right: -3%;
}
section#creator div.creator_wrap dl dt, section#creator div.creator_wrap dl dd {
  color: #fff;
}
section#creator div.creator_wrap dl dt {
  font-size: 36px;
  font-weight: bold;
  margin-bottom: 30px;
}
section#creator div.creator_wrap dl dd {
  font-size: clamp(12px, 10vw, 22px);
  text-align: justify;
}
section#creator div.creator_wrap p#img-bottom {
  width: 100%;
  position: absolute;
  bottom: -20%;
  left: 0;
  z-index: 10;
}
section#creator div.creator_wrap p#img-bottom img {
  width: 100%;
}

section#instagram {
  margin-bottom: clamp(30px, 10vw, 100px);
}
section#instagram div.inner {
  overflow: hidden;
}
section#instagram h2 {
  margin-bottom: clamp(30px, 10vw, 80px);
}
section#instagram h2 img {
  max-width: 1280px;
  width: 100%;
}
section#instagram div.instagram-inner {
  padding: 0 12%;
}
section#instagram article {
  width: 33.3333333333%;
}
section#instagram article figure {
  margin-bottom: 30px;
}
section#instagram article p {
  width: 55%;
  font-size: clamp(14px, 3vw, 36px);
  font-weight: bold;
  line-height: 1;
  position: relative;
  margin: auto;
  padding: 5px 0;
}
section#instagram article p:after {
  content: "";
  width: clamp(10px, 1.5vw, 20px);
  height: 27px;
  background: url(../images/common/icon_arrow01.svg) no-repeat;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  position: absolute;
  right: 0;
  top: 30%;
}
@media (hover: hover) and (pointer: fine) {
  section#instagram article:not(section#instagram article.noimage) figure, section#instagram article:not(section#instagram article.noimage) p, section#instagram article:not(section#instagram article.noimage) img {
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  section#instagram article:not(section#instagram article.noimage):hover figure, section#instagram article:not(section#instagram article.noimage):hover p, section#instagram article:not(section#instagram article.noimage):hover img {
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  section#instagram article:not(section#instagram article.noimage):hover img {
    -webkit-box-shadow: 0 0 10px #8fd3f5;
            box-shadow: 0 0 10px #8fd3f5;
  }
  section#instagram article:not(section#instagram article.noimage):hover p:after {
    -webkit-transition: 0.3s;
    transition: 0.3s;
    right: 10px;
  }
}
section#instagram article {
  max-width: 600px;
  width: 100%;
  margin: auto;
}
section#instagram article figure {
  margin-bottom: clamp(20px, 5vw, 50px);
}
section#instagram article figure img {
  width: 100%;
}
section#instagram article a:after {
  display: none;
}

section.comingsoon div.inner {
  font-size: clamp(10px, 8vw, 50px);
  text-align: center;
  padding: 30px 0;
}

section#contact {
  margin-bottom: 100px;
}
section#contact div.inner {
  overflow: hidden;
}
section#contact h2 {
  margin-bottom: clamp(30px, 10vw, 30px);
}
section#contact h2 img {
  max-width: 1280px;
  width: 100%;
}
section#contact div {
  font-size: clamp(10px, 5vw, 40px);
  font-weight: bold;
  text-align: center;
  margin-bottom: clamp(30px, 10vw, 70px);
}
section#contact a.button {
  max-width: 600px;
  font-weight: bold;
  border: none;
  padding: clamp(10px, 3vw, 20px) 0;
}
section#contact a.button:after {
  display: none;
}

section.comingsoon {
  margin-bottom: 60px;
}
section.comingsoon div.inner p {
  text-align: center;
  margin-bottom: 40px;
}
section.comingsoon div.inner a.button {
  width: 250px;
  padding: clamp(10px, 3vw, 20px) 0;
}
section.comingsoon div.inner a.button:after {
  width: 10px;
  height: 10px;
  top: 17px;
  right: 15px;
}

section.subpage.topics {
  margin-bottom: 30px;
  padding: clamp(10px, 5vw, 70px) 0;
}
section.subpage.topics div.inner {
  padding-bottom: 0;
}
section.subpage.topics h2 {
  margin-bottom: clamp(1px, 2vw, 80px);
}
section.subpage.topics div#subpageTopics-inner {
  max-width: 1280px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 25px;
  margin: auto;
}
section.subpage.topics div#subpageTopics-inner article {
  width: 48%;
  margin-bottom: 30px;
  padding-top: 30px;
}
section.subpage.topics div#subpageTopics-inner article figure {
  margin-bottom: 30px;
}
section.subpage.topics div#subpageTopics-inner article div {
  font-size: clamp(12px, 2vw, 22px);
  font-weight: bold;
}
section.subpage.topics div#subpageTopics-inner p.border-line {
  width: 100%;
  height: 3px;
  text-align: center;
  background: #fff;
  border-radius: 99px;
  border: solid 2px #59a0d0;
  margin: 40px 0;
}
section.subpage.topics.article-page div.inner_article-page h2 {
  font-size: clamp(12px, 5vw, 40px);
  text-align: center;
  margin: clamp(1px, 5vw, 60px) 0;
}
section.subpage.topics.article-page div.inner_article-page figure {
  text-align: center;
  margin-bottom: 30px;
}
section.subpage.topics.article-page div.inner_article-page figure img {
  max-width: 600px;
  width: 100%;
}
section.subpage.topics.article-page div.inner_article-page h3 {
  max-width: 600px;
  font-size: clamp(12px, 5vw, 30px);
  margin: auto auto 30px auto;
}
section.subpage.topics.article-page div.inner_article-page div {
  max-width: 600px;
  line-height: 1.6;
  margin: auto auto 30px auto;
}
section.subpage.topics.article-page div.inner_article-page div a {
  color: #e5004f;
  text-decoration: underline;
}
section.subpage.topics.article-page div.inner_article-page dl {
  max-width: 600px;
  margin: auto auto 30px auto;
}
section.subpage.topics.article-page div.inner_article-page dl dt, section.subpage.topics.article-page div.inner_article-page dl dd {
  margin-bottom: 20px;
}
section.subpage.topics.article-page div.inner_article-page dl dt {
  font-size: clamp(12px, 4vw, 18px);
  font-weight: bold;
  text-align: center;
  border: solid 1px #000;
  padding: 5px;
}
section.subpage.topics.article-page div.inner_article-page dl dd {
  font-size: clamp(12px, 5vw, 20px);
}

section#topics-list_button {
  margin: clamp(20px, 5vw, 40px) 0;
}
section#topics-list_button a.button {
  max-width: 600px;
  font-weight: bold;
  border: none;
  padding: clamp(10px, 3vw, 20px) 0;
}
section#topics-list_button a.button:after {
  display: none;
}

@media (max-width: 1280px) {
  body {
    font-family: "Hiragino Sans", -apple-system, BlinkMacSystemFont, "Noto Sans JP", sans-serif;
    font-weight: 400;
    font-synthesis: none;
    -webkit-text-size-adjust: 100%;
  }
  strong, b {
    font-weight: 700;
  }
  section#charactar_header {
    margin-bottom: 5vw;
  }
  section#charactar_header div img {
    max-height: 34vw;
  }
  .pc {
    display: none !important;
  }
}
@media screen and (max-width: 1280px) and (max-width: 768px) {
  .pc-768 {
    display: none;
  }
}
@media screen and (max-width: 1280px) and (max-width: 480px) {
  .pc-480 {
    display: none;
  }
}
@media screen and (max-width: 1280px) and (max-width: 360px) {
  .pc-360 {
    display: none;
  }
}
@media (max-width: 1280px) {
  .sp {
    display: initial;
  }
}
@media screen and (max-width: 1280px) and (max-width: 1080px) {
  .sp-1080 {
    display: initial;
  }
}
@media screen and (max-width: 1280px) and (max-width: 768px) {
  .sp-768 {
    display: initial;
  }
}
@media screen and (max-width: 1280px) and (max-width: 680px) {
  .sp-680 {
    display: initial;
  }
}
@media screen and (max-width: 1280px) and (max-width: 480px) {
  .sp-480 {
    display: initial;
  }
}
@media screen and (max-width: 1280px) and (max-width: 360px) {
  .sp-360 {
    display: initial;
  }
}
@media (max-width: 1280px) {
  button.pagetop {
    left: calc(100vw - 4.5em);
  }
  @supports (-webkit-touch-callout: none) {
    button.pagetop {
      left: calc(100vw - 5.5em);
    }
  }
  button {
    -webkit-tap-highlight-color: transparent;
  }
  div.inner {
    overflow: hidden;
    padding-top: 10px !important;
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media screen and (max-width: 1280px) and (max-width: 1280px) {
  header.header div.inner {
    padding: 15px;
  }
  header.header h1 {
    width: 85px;
  }
  header.header h1 a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-top: 2px;
  }
  header.header nav#gNavi {
    display: none;
  }
}
@media (max-width: 1280px) {
  footer div.inner {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 20px 15px !important;
  }
  footer div.inner:first-of-type {
    padding-bottom: 0 !important;
  }
  footer div.inner:last-of-type {
    padding-top: 10px !important;
  }
  footer figure#fLogo {
    max-width: clamp(50px, 60vw, 300px);
    padding-bottom: 20px;
  }
  footer nav#fNavi {
    display: none;
  }
  footer p#copyright {
    font-size: clamp(10px, 3vw, 16px);
    text-align: center;
  }
  .hamburger {
    width: 44px;
    height: 32px;
    display: -ms-grid;
    display: grid;
    place-items: center;
    border: 0;
    background: transparent;
    position: relative;
    z-index: 99;
    -webkit-tap-highlight-color: transparent;
    outline: none;
    margin-top: 5px;
  }
  .hamburger span {
    display: block;
    width: 35px;
    height: 3px;
    border: solid 3px #59a0d0;
    border-radius: 99px;
    background: #fff;
    -webkit-transition: opacity 0.2s, -webkit-transform 0.25s;
    transition: opacity 0.2s, -webkit-transform 0.25s;
    transition: transform 0.25s, opacity 0.2s;
    transition: transform 0.25s, opacity 0.2s, -webkit-transform 0.25s;
  }
  .hamburger span:nth-child(2) {
    -webkit-transform-origin: center;
            transform-origin: center;
  }
  .hamburger[aria-expanded=true] span:nth-child(1) {
    -webkit-transform: translateY(11px) rotate(45deg);
            transform: translateY(11px) rotate(45deg);
  }
  .hamburger[aria-expanded=true] span:nth-child(2) {
    opacity: 0;
  }
  .hamburger[aria-expanded=true] span:nth-child(3) {
    -webkit-transform: translateY(-10px) rotate(-45deg);
            transform: translateY(-10px) rotate(-45deg);
  }
  .mobile-menu {
    position: fixed;
    inset: 0 0 auto 0;
    background: #fff;
    -webkit-box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    -webkit-transform: translateY(-16px);
            transform: translateY(-16px);
    opacity: 0;
    pointer-events: none;
    -webkit-transition: opacity 0.25s ease, -webkit-transform 0.25s ease;
    transition: opacity 0.25s ease, -webkit-transform 0.25s ease;
    transition: transform 0.25s ease, opacity 0.25s ease;
    transition: transform 0.25s ease, opacity 0.25s ease, -webkit-transform 0.25s ease;
    padding: 62px 16px 3px;
    z-index: 40;
  }
  .mobile-menu.open {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }
  .mobile-menu.open ul li:nth-child(1) a {
    -webkit-animation-delay: 0.1s;
            animation-delay: 0.1s;
  }
  .mobile-menu.open ul li:nth-child(2) a {
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
  .mobile-menu.open ul li:nth-child(3) a {
    -webkit-animation-delay: 0.3s;
            animation-delay: 0.3s;
  }
  .mobile-menu.open ul li:nth-child(4) a {
    -webkit-animation-delay: 0.4s;
            animation-delay: 0.4s;
  }
  .mobile-menu.open ul li:nth-child(5) a {
    -webkit-animation-delay: 0.5s;
            animation-delay: 0.5s;
  }
  .mobile-menu.open ul li:nth-child(6) a {
    -webkit-animation-delay: 0.6s;
            animation-delay: 0.6s;
  }
  .mobile-menu.open ul li a {
    -webkit-animation: sNavi_ani 0.3s ease-in-out forwards;
            animation: sNavi_ani 0.3s ease-in-out forwards;
  }
  @-webkit-keyframes sNavi_ani {
    0% {
      padding-left: 50px;
    }
    100% {
      opacity: 1;
      padding-left: 0;
    }
  }
  @keyframes sNavi_ani {
    0% {
      padding-left: 50px;
    }
    100% {
      opacity: 1;
      padding-left: 0;
    }
  }
  .mobile-menu ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .mobile-menu ul li:not(:last-child) {
    border-bottom: 1px solid #eee;
  }
  .mobile-menu ul li a {
    color: #111;
    text-decoration: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 20px;
    opacity: 0;
    padding: 10px 4px;
  }
  .mobile-menu ul li a p {
    width: 50px;
    text-align: center;
  }
  .mobile-menu ul li a img {
    width: 40px;
    height: 50px;
  }
  .mobile-menu ul li:nth-child(3) img, .mobile-menu ul li:last-child img {
    width: 50px;
  }
  body.menu-open {
    overflow: hidden;
  }
}
@media (max-width: 1280px) and (prefers-reduced-motion: reduce) {
  .mobile-menu {
    -webkit-transition: none;
    transition: none;
  }
  .hamburger span {
    -webkit-transition: none;
    transition: none;
  }
}
@media screen and (max-width: 1280px) and (max-width: 680px) {
  section#stage {
    padding: clamp(10px, 5vw, 50px) 0 clamp(10px, 5vw, 30px) 0;
  }
}
@media (max-width: 1280px) {
  section#concept {
    margin-bottom: 10vw;
  }
}
@media screen and (max-width: 1280px) and (max-width: 600px) {
  section#concept div.inner div {
    text-align: justify;
    padding-bottom: 8vw;
  }
  section#concept div.inner div br[class*=sp] {
    display: none;
  }
}
@media (max-width: 1280px) {
  section#topics div#topics-inner {
    gap: 15px;
  }
  section#topics div#topics-inner article {
    max-width: 600px;
    width: 100%;
  }
  section#topics div#topics-inner article:not(section#topics div#topics-inner article:first-of-type) {
    display: none;
  }
  section#topics div#topics-inner article h3 {
    font-size: clamp(12px, 10vw, 20px);
    display: initial;
  }
  section#topics div#topics-inner article p {
    display: none;
  }
}
@media screen and (max-width: 1280px) and (max-width: 480px) {
  section#topics div#topics-inner {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 8vw;
    padding: 0 12%;
  }
  section#topics div#topics-inner article {
    width: 100%;
  }
  section#topics div#topics-inner article p {
    max-width: 150px;
    width: 50%;
    font-size: clamp(14px, 6vw, 26px);
  }
}
@media (max-width: 1280px) {
  section#story {
    display: none;
    /*
    //box
    section.story_box{
      flex-direction: column variables.$imp;
      gap:clamp(10px,5vw,30px);
      figure,dl{
        width:100%;
      }
      figure{
        img{
          max-width:600px variables.$imp;
          width: 80%;
        }
      }
      dl{
        dt{
          text-align: center;
        }
        dd{
          //font-size: initial;
          text-align: justify;
        }
      }
    }
    // /box
    */
  }
  section#profile {
    background: none;
  }
  section#profile section#profile-story_sp {
    display: initial;
  }
  section#profile section#profile-story_sp div.inner_free {
    line-height: 1.6;
    margin-bottom: clamp(40px, 8vw, 60px);
  }
  section#profile section#profile-story_sp figure {
    text-align: center;
    margin-bottom: clamp(40px, 5vw, 50px);
    padding: 0 12%;
  }
  section#profile section#profile-story_sp figure img {
    max-width: 600px;
    width: 100%;
  }
  section#profile div.character {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    border-radius: 0 0 20px 20px;
    padding-top: clamp(10px, 8vw, 50px);
  }
  section#profile div.character:last-of-type {
    margin-bottom: 0;
  }
  section#profile div.character div.chara-details {
    padding: clamp(10px, 5vw, 50px) 15px;
  }
  section#profile div.character div.chara-details h3 {
    margin-bottom: clamp(10px, 4vw, 40px);
  }
  section#profile div.character div.chara-details h3 img {
    margin-bottom: clamp(6px, 2vw, 10px);
  }
  section#profile div.character div.chara-details dl dt {
    margin-bottom: clamp(20px, 10vw, 40px);
  }
  section#profile div.character div.chara-details dl dd h4 {
    text-align: center;
  }
  section#profile div.character.pokori {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #fffcdb), to(#f9d0c3));
    background: linear-gradient(to bottom, #fffcdb 50%, #f9d0c3 100%);
  }
  section#profile div.character.damsook {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #fffcdb), to(#feebbe));
    background: linear-gradient(to bottom, #fffcdb 50%, #feebbe 100%);
  }
  section#profile div.character.damsook h3 img {
    max-width: clamp(50px, 50vw, 480px);
  }
  section#profile div.character.buddy {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #fffcdb), to(#fadce9));
    background: linear-gradient(to bottom, #fffcdb 50%, #fadce9 100%);
  }
  section#profile div.character.buddy h3 img {
    max-width: clamp(50px, 50vw, 360px);
  }
  section#profile div.character.lunzy {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #fffcdb), to(#edf2c5));
    background: linear-gradient(to bottom, #fffcdb 50%, #edf2c5 100%);
  }
  section#profile div.character.lunzy h3 img {
    max-width: clamp(50px, 50vw, 360px);
  }
  section#profile div.character.dumbool {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #fffcdb), to(#e7d5e8));
    background: linear-gradient(to bottom, #fffcdb 50%, #e7d5e8 100%);
  }
  section#profile div.character.dumbool h3 img {
    max-width: clamp(50px, 65vw, 500px);
  }
  section#creator div.inner {
    overflow: initial;
  }
  section#creator div.creator_wrap {
    padding: clamp(50px, 15vw, 120px) 15px 30vw 15px;
  }
  section#creator div.creator_wrap div.inner_free {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: clamp(10px, 5vw, 30px);
  }
  section#creator div.creator_wrap div.inner_free div#photo {
    max-width: 570px;
    width: 100%;
  }
  section#creator div.creator_wrap div.inner_free div#photo figure img {
    width: 90%;
  }
  section#creator div.creator_wrap div.inner_free div#photo p {
    width: clamp(100px, 44vw, 276px);
  }
  section#creator div.creator_wrap div.inner_free dl {
    width: 100%;
  }
  section#creator div.creator_wrap div.inner_free dl dt {
    font-size: clamp(16px, 12vw, 56px);
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: clamp(10px, 8vw, 40px);
  }
  section#creator div.creator_wrap div.inner_free dl dt span {
    font-size: clamp(12px, 4vw, 24px);
  }
  section#creator div.creator_wrap div.inner_free dl dd {
    font-size: clamp(16px, 4vw, 20px);
    line-height: 1.6;
  }
  section#creator div.creator_wrap p#img-bottom {
    bottom: -13vw;
  }
  section#contact {
    margin-bottom: 10vw;
  }
  section#contact h2 {
    margin-bottom: 7vw;
  }
  section#contact a.button {
    max-width: 700px;
    width: 80%;
    padding: clamp(10px, 3vw, 20px) 0;
    /*
    &:after{
      width:20px;
      height:20px;
      top:4vw;
      right:5vw;
    }
    */
  }
}
@media screen and (max-width: 1280px) and (max-width: 480px) {
  section#contact a.button:after {
    width: 3vw;
    height: 3vw;
    top: 4.7vw;
    right: 5vw;
  }
}
@media (max-width: 1280px) {
  section.subpage.topics div#subpageTopics-inner {
    gap: initial;
  }
  section.subpage.topics article div {
    font-size: clamp(12px, 4vw, 22px) !important;
  }
  section.subpage.topics p.border-heart img {
    width: 80vw;
  }
}