@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: "Yu Gothic", "Hiragino Kaku Gothic ProN", "Meiryo", sans-serif;
  background: #f3ef7f;
}

.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: 1080px) {
  button.hamburger,
  nav#mobileMenu {
    display: none;
  }
}
h2 {
  text-align: center;
}

div.inner {
  margin: auto;
}

a.button {
  position: relative;
  text-align: center;
  background: #b9d42f;
  border: solid 1px #b9d42f;
  border-radius: 99px;
  display: block;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  margin: auto;
  padding: 20px 0;
}
a.button:after {
  content: "";
  width: 6px;
  height: 6px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  position: absolute;
  top: 9px;
  right: 14px;
}
@media (hover: hover) and (pointer: fine) {
  a.button:hover {
    border: solid 1px #c7dd59;
    -webkit-box-shadow: 0 0 10px #96ac24;
            box-shadow: 0 0 10px #96ac24;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    background: #c7dd59;
  }
}

[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: 50px;
  background: none;
  border: none;
  cursor: pointer;
  position: sticky;
  left: calc(100vw - 4.5em);
  bottom: 15px;
  z-index: 99;
}

main {
  max-width: 1980px;
  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, 860px);
  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: #b188bc;
  position: relative;
  z-index: 99;
}
header.header div.inner {
  max-width: 1980px;
  overflow: initial;
  margin: auto;
  padding: 40px;
}
header.header h1 {
  max-width: clamp(200px, 40vw, 860px);
  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 {
  background: #b188bc;
}
footer div.inner {
  max-width: 1980px;
  font-weight: bold;
  padding: 30px;
}
footer p#copyright {
  width: 100%;
  font-size: 20px;
  text-align: right;
}

nav#gNavi ul,
nav#fNavi ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}
nav#gNavi ul li,
nav#fNavi ul li {
  width: clamp(50px, 11vw, 170px);
}
nav#gNavi ul img,
nav#fNavi ul img {
  max-width: 80px;
  width: 100%;
  margin-bottom: 5px;
}
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;
}
@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 span,
nav#fNavi ul span {
  font-size: 18px;
}
nav#gNavi ul li:first-child,
nav#fNavi ul li:first-child {
  width: clamp(50px, 7vw, 130px);
}
nav#gNavi ul li:first-child img,
nav#fNavi ul li:first-child img {
  max-width: 90px;
}
nav#gNavi ul li:nth-child(2),
nav#fNavi ul li:nth-child(2) {
  width: clamp(50px, 6.5vw, 120px);
}
nav#gNavi ul li:nth-child(3) img,
nav#fNavi ul li:nth-child(3) img {
  max-width: 150px;
}
nav#gNavi ul li:last-child,
nav#fNavi ul li:last-child {
  width: clamp(50px, 10vw, 130px);
  padding-left: clamp(5px, 10vw, 14px);
}
nav#gNavi ul li:last-child img,
nav#fNavi ul li:last-child img {
  max-width: 130px;
}

section#stage {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  margin-bottom: 80px;
}
section#stage div {
  width: 25%;
  height: clamp(100px, 42vw, 800px);
  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;
}
section#stage div#st_minty {
  background: #53d2cb;
}
section#stage div#st_yelly {
  background: #ffed1a;
}
section#stage div#st_yelly img {
  margin-right: 8%;
}
section#stage div#st_lully {
  background: #2eb1ec;
}
section#stage div#st_larry {
  background: #eb5b2d;
}
section#stage div img {
  max-height: 600px;
}
section#stage p {
  font-weight: bold;
  position: absolute;
  bottom: 15px;
  right: 20px;
}

section#concept {
  margin-bottom: 80px;
}
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 50px 0;
}
section#concept div.inner figure {
  text-align: center;
}
section#concept div.inner figure img {
  max-width: clamp(200px, 80vw, 1000px);
}

section.topics {
  margin-bottom: clamp(30px, 10vw, 100px);
}
section.topics h2 {
  margin-bottom: 80px;
}
section.topics h2 img {
  max-width: 420px;
  width: 32vw;
}
section.topics div#topics-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 50px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 35px;
}
section.topics div#topics-inner article figure {
  max-width: 300px;
  margin-bottom: 20px;
}
section.topics div#topics-inner article p {
  width: 70%;
  font-size: 14px;
  text-align: center;
  line-height: 1;
  background: #fff;
  border: solid 1px #a2a28b;
  border-radius: 99px;
  margin: auto;
  padding: 5px 0;
}
@media (hover: hover) and (pointer: fine) {
  section.topics div#topics-inner article figure, section.topics div#topics-inner article p {
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  section.topics div#topics-inner article:hover figure, section.topics div#topics-inner article:hover p {
    -webkit-box-shadow: 0 0 10px #cfc92b;
            box-shadow: 0 0 10px #cfc92b;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  section.topics div#topics-inner article:hover p {
    border: solid 1px #cfc92b;
  }
  section.topics div#topics-inner article:hover p:after {
    -webkit-transition: 0.3s;
    transition: 0.3s;
    right: 10px;
  }
}
section.topics a.button {
  width: 250px;
}
section.topics a.button:after {
  width: 10px;
  height: 10px;
  top: 27px;
  right: 20px;
}
@media (hover: hover) and (pointer: fine) {
  section.topics a.button:hover:after {
    -webkit-transition: 0.3s;
    transition: 0.3s;
    right: 15px;
  }
}

section#character-introduction h2 {
  margin-bottom: clamp(10px, 10vw, 50px);
}
section#character-introduction h2 img {
  width: clamp(200px, 58vw, 720px);
}
section#character-introduction div.character {
  margin-bottom: 30px;
}
section#character-introduction div.character figure {
  text-align: center;
}
section#character-introduction div.character figure img {
  max-height: clamp(200px, 90vw, 600px);
}
section#character-introduction div.character h3 {
  font-size: clamp(10px, 4vw, 18px);
  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;
}
section#character-introduction div.character h3 img {
  max-width: clamp(50px, 30vw, 200px);
}
section#character-introduction div.character div {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 16px;
  text-align: center;
  line-height: 2;
}
section#character-introduction div.character div.chara-details {
  padding: 30px 0 50px 0;
}

section#instagram {
  margin-bottom: 100px;
}
section#instagram h2 {
  margin-bottom: clamp(10px, 10vw, 50px);
}
section#instagram h2 img {
  width: clamp(200px, 40vw, 550px);
}
section#instagram article figure {
  max-width: 300px;
  margin-bottom: 20px;
}
section#instagram article p {
  width: 70%;
  font-size: 14px;
  text-align: center;
  line-height: 1;
  background: #fff;
  border: solid 1px #a2a28b;
  border-radius: 99px;
  margin: auto;
  padding: 5px 0;
}
@media (hover: hover) and (pointer: fine) {
  section#instagram article figure, section#instagram article p {
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  section#instagram article:hover figure, section#instagram article:hover p {
    -webkit-box-shadow: 0 0 10px #cfc92b;
            box-shadow: 0 0 10px #cfc92b;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  section#instagram article:hover p {
    border: solid 1px #cfc92b;
  }
  section#instagram article:hover p:after {
    -webkit-transition: 0.3s;
    transition: 0.3s;
    right: 10px;
  }
}
section#instagram article {
  max-width: 500px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: auto;
}
section#instagram article figure {
  max-width: 500px;
}
section#instagram article p {
  padding: 12px 0;
}

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

section#contact {
  margin-bottom: 100px;
}
section#contact h2 {
  margin-bottom: 40px;
}
section#contact h2 img {
  max-width: 280px;
}
section#contact a.button {
  max-width: 600px;
  font-size: 22px;
  font-weight: bold;
  line-height: 1;
  padding: 30px 0;
}
section#contact a.button:after {
  width: 20px;
  height: 20px;
  top: 32px;
  right: 60px;
}
@media (hover: hover) and (pointer: fine) {
  section#contact a.button:hover:after {
    right: 50px;
  }
}

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: 10px 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(20px, 9vw, 80px);
}
section.subpage.topics div#subpageTopics-inner {
  max-width: 1000px;
  margin: auto;
}
section.subpage.topics div#subpageTopics-inner article:not(:last-of-type) {
  margin-bottom: 40px;
}
section.subpage.topics div#subpageTopics-inner article header {
  margin-bottom: 30px;
}
section.subpage.topics div#subpageTopics-inner article header time {
  font-size: 80%;
}
section.subpage.topics div#subpageTopics-inner article header h3 {
  font-size: 140%;
}
section.subpage.topics div#subpageTopics-inner article section.article-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}
section.subpage.topics div#subpageTopics-inner article section.article-inner div.artcile-text {
  width: 60%;
}
section.subpage.topics div#subpageTopics-inner article section.article-inner div.artcile-text h4 {
  margin-bottom: 20px;
}
section.subpage.topics div#subpageTopics-inner article section.article-inner div.artcile-text h5 {
  font-size: 80%;
  text-align: center;
  border: solid 1px #000;
  margin-bottom: 10px;
  padding: 5px;
}
section.subpage.topics div#subpageTopics-inner article section.article-inner div.artcile-text h6 {
  font-size: 80%;
  text-align: center;
  border: solid 1px #000;
  margin: 10px 0;
  padding: 5px;
}
section.subpage.topics div#subpageTopics-inner article section.article-inner div.article-figure {
  width: 40%;
}
section.subpage.topics div#subpageTopics-inner article section.article-inner div.article-figure figure:not(:last-child) {
  margin-bottom: 20px;
}
section.subpage.topics div#subpageTopics-inner article section.article-inner div.article-figure figure img {
  border: solid 1px #a2a28b;
}
@media (hover: hover) and (pointer: fine) {
  section.subpage.topics div#subpageTopics-inner article section.article-inner div.article-figure figure img {
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  section.subpage.topics div#subpageTopics-inner article section.article-inner div.article-figure figure:hover img {
    -webkit-box-shadow: 0 0 10px #cfc92b;
            box-shadow: 0 0 10px #cfc92b;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
}
section.subpage.topics div#subpageTopics-inner p.border-heart {
  text-align: center;
  margin: 40px 0 0 0;
}
section.subpage.topics div#subpageTopics-inner p.border-heart img {
  max-width: 100%;
}

@media (max-width: 1980px) {
  section#stage {
    margin-bottom: 5vw;
  }
  section#stage div img {
    max-height: 34vw;
  }
}
@media (max-width: 1080px) {
  .pc {
    display: none;
  }
}
@media screen and (max-width: 1080px) and (max-width: 768px) {
  .pc-768 {
    display: none;
  }
}
@media screen and (max-width: 1080px) and (max-width: 480px) {
  .pc-480 {
    display: none;
  }
}
@media screen and (max-width: 1080px) and (max-width: 360px) {
  .pc-360 {
    display: none;
  }
}
@media (max-width: 1080px) {
  .sp {
    display: initial;
  }
}
@media screen and (max-width: 1080px) and (max-width: 1080px) {
  .sp-1080 {
    display: initial;
  }
}
@media screen and (max-width: 1080px) and (max-width: 768px) {
  .sp-768 {
    display: initial;
  }
}
@media screen and (max-width: 1080px) and (max-width: 680px) {
  .sp-680 {
    display: initial;
  }
}
@media screen and (max-width: 1080px) and (max-width: 480px) {
  .sp-480 {
    display: initial;
  }
}
@media screen and (max-width: 1080px) and (max-width: 360px) {
  .sp-360 {
    display: initial;
  }
}
@media (max-width: 1080px) {
  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: 1080px) and (max-width: 1980px) {
  header.header div.inner {
    padding: 15px;
  }
  header.header h1 {
    width: 300px;
  }
  header.header h1 a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  header.header nav#gNavi {
    display: none;
  }
}
@media (max-width: 1080px) {
  footer div.inner {
    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 {
    margin: auto;
  }
  footer nav#fNavi {
    display: none;
  }
  footer p#copyright {
    font-size: clamp(10px, 3vw, 16px);
    text-align: center;
  }
}
@media screen and (max-width: 1080px) and (max-width: 480px) {
  footer div.inner {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media (max-width: 1080px) {
  .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 2px #231815;
    border-radius: 99px;
    background: #00d2c5;
    -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: 68px 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 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: 16px 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: 1080px) and (prefers-reduced-motion: reduce) {
  .mobile-menu {
    -webkit-transition: none;
    transition: none;
  }
  .hamburger span {
    -webkit-transition: none;
    transition: none;
  }
}
@media (max-width: 1080px) {
  section#stage {
    /*
    margin-bottom:5vw;
    //box
    div{
      img{
        //max-height:40vw;
        max-height:34vw;
      }
    }
    // /box
    */
  }
}
@media screen and (max-width: 1080px) and (max-width: 1080px) {
  section#stage {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-bottom: 8vw;
    /*
    //box
    div{
      width:50%;
      height: 50vw;
    }
    // /box
    */
  }
  section#stage p {
    font-size: clamp(10px, 2vw, 16px);
    right: 1vw;
    bottom: -2em;
  }
}
@media (max-width: 1080px) {
  section#concept {
    margin-bottom: 10vw;
  }
}
@media screen and (max-width: 1080px) 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: 1080px) {
  section#topics div#topics-inner {
    gap: 15px;
  }
}
@media screen and (max-width: 1080px) and (max-width: 480px) {
  section#topics h2 {
    margin-bottom: 10vw;
  }
  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: 210px;
    width: 60%;
  }
}
@media screen and (max-width: 1080px) and (max-width: 600px) {
  section#character-introduction div.chara-details div {
    text-align: justify;
  }
  section#character-introduction div.chara-details div br[class*=sp] {
    display: none;
  }
}
@media (max-width: 1080px) {
  section#contact {
    margin-bottom: 10vw;
  }
  section#contact h2 {
    margin-bottom: 7vw;
  }
  section#contact h2 img {
    max-width: 490px;
    width: 49vw;
  }
  section#contact a.button {
    max-width: 700px;
    width: 80%;
    font-size: clamp(16px, 4vw, 22px);
    padding: 7vw 0;
  }
  section#contact a.button:after {
    width: 20px;
    height: 20px;
    top: 4vw;
    right: 5vw;
  }
}
@media screen and (max-width: 1080px) and (max-width: 480px) {
  section#contact a.button:after {
    width: 3vw;
    height: 3vw;
    top: 4.7vw;
    right: 5vw;
  }
}
@media (max-width: 1080px) {
  section.subpage.topics article h3 {
    font-size: 130% !important;
    line-height: 1.3;
  }
  section.subpage.topics article section.article-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  section.subpage.topics article section.article-inner div.artcile-text,
  section.subpage.topics article section.article-inner div.article-figure {
    width: 100% !important;
  }
  section.subpage.topics article section.article-inner div.article-figure figure {
    padding: 0 15%;
  }
  section.subpage.topics p.border-heart img {
    width: 80vw;
  }
}