html {
  scroll-behavior: smooth;
}

.cocoasupport, .cocoasupport::after, .cocoasupport *, .cocoasupport *::after {
  all: unset;
}
@media (max-width: 640px) {
  .cocoasupport, .cocoasupport img {
    font-size: 5.1282051282vw;
  }
}
@media (min-width: 641px) {
  .cocoasupport, .cocoasupport img {
    font-size: 1.7985611511vw;
  }
}
@media (min-width: 1112px) {
  .cocoasupport, .cocoasupport img {
    font-size: 20px;
  }
}
.cocoasupport {
  --black: #000;
  color: var(--black);
  line-height: 1.5;
  font-family: "Hiragino Kaku Gothic Pro", "Meiryo", sans-serif;
  display: grid;
}
body:not(.loaded) .cocoasupport {
  opacity: 0;
}

body.loaded .cocoasupport {
  opacity: 1;
  transition: 800ms;
}

.cocoasupport img {
  max-width: 100%;
  vertical-align: bottom;
}
.cocoasupport button,
.cocoasupport label,
.cocoasupport a {
  cursor: pointer;
}

.c-loading {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
body.loaded .c-loading {
  display: none;
}

.c-loading.finish {
  opacity: 0;
  transition: opacity 400ms;
}

.p-top {
  display: grid;
  justify-items: center;
  background: url(../images/bg_arc_1.png) no-repeat center bottom/100% 3em, url(../images/top_bg.png) repeat center top/13.25em;
  padding-bottom: 5em;
}
@media (max-width: 640px) {
  .p-top {
    grid-row-gap: 1em;
  }
}
.p-top__title {
  display: grid;
}
@media (max-width: 640px) {
  .p-top__title {
    grid-row-gap: 1em;
    justify-items: center;
    padding: 1em 0;
  }
}
@media (min-width: 641px) {
  .p-top__title {
    grid-auto-flow: column;
    align-items: center;
    justify-content: center;
    padding: 2em 0;
  }
}
@media (max-width: 640px) {
  .p-top__title h1 {
    order: 1;
  }
}
@media (max-width: 640px) {
  .p-top__title h1 img {
    width: 16.8em;
  }
}
@media (min-width: 641px) {
  .p-top__title h1 img {
    width: 31.2em;
  }
}
@media (max-width: 640px) {
  .p-top__title .mv {
    width: 15em;
  }
}
@media (min-width: 641px) {
  .p-top__title .mv {
    width: 23.4em;
  }
}
body:not(.loaded) .p-top__title .mv {
  opacity: 0;
}

body.loaded .p-top__title .mv {
  transition: opacity 1200ms 400ms;
}

.p-top__about {
  display: grid;
  box-sizing: border-box;
  background: white;
}
@media (max-width: 640px) {
  .p-top__about {
    grid-row-gap: 1em;
    width: 17.5em;
    border-radius: 1.2em;
    padding: 1.2em;
  }
}
@media (min-width: 641px) {
  .p-top__about {
    grid-template-areas: "logo q" "logo a";
    width: 46em;
    border-radius: 2em;
    padding: 2em;
  }
  .p-top__about .logo {
    grid-area: logo;
  }
  .p-top__about .q {
    grid-area: q;
  }
  .p-top__about .a {
    grid-area: a;
  }
}
@media (max-width: 640px) {
  .p-top__about .q {
    position: relative;
    display: flex;
  }
  .p-top__about .q::after {
    position: absolute;
    content: "";
    background: url(../images/about_image.png) no-repeat center center/contain;
    aspect-ratio: 127/172;
    right: 0;
    bottom: 0;
    transform: translate(0, 0.5em);
    width: 4em;
  }
}
@media (max-width: 640px) {
  .p-top__about .q img {
    width: 9.9em;
  }
}
@media (min-width: 641px) {
  .p-top__about .q img {
    width: 32.1em;
  }
}
.p-top__about .a {
  display: grid;
  box-sizing: border-box;
}
@media (max-width: 640px) {
  .p-top__about .a {
    grid-template-columns: max-content 1fr;
    grid-column-gap: 0.8em;
  }
}
@media (min-width: 641px) {
  .p-top__about .a {
    grid-auto-flow: column;
    position: relative;
    padding-top: 1em;
  }
}
.p-top__about .a::before {
  content: "";
  background: url(../images/about_a.png) no-repeat center center/contain;
  aspect-ratio: 35/39;
}
@media (max-width: 640px) {
  .p-top__about .a::before {
    width: 1.6em;
  }
}
@media (min-width: 641px) {
  .p-top__about .a::before {
    width: 1.8em;
    margin-inline: 0.6em 1em;
  }
}
.p-top__about .a p {
  color: #956134;
  font-weight: bold;
}
@media (max-width: 640px) {
  .p-top__about .a p {
    font-size: 0.65em;
  }
}
@media (min-width: 641px) {
  .p-top__about .a p {
    font-size: 0.8em;
  }
}
@media (min-width: 641px) {
  .p-top__about .a::after {
    content: "";
    background: url(../images/about_image.png) no-repeat center center/contain;
    aspect-ratio: 127/172;
    order: 1;
    width: 6.35em;
    margin-top: -1em;
    margin-left: 0.5em;
  }
}
@media (max-width: 640px) {
  .p-top__about .logo {
    justify-self: center;
  }
}
@media (max-width: 640px) {
  .p-top__about .logo img {
    width: 7.4em;
  }
}
@media (min-width: 641px) {
  .p-top__about .logo img {
    width: 10.6em;
  }
}

.p-quiz {
  display: grid;
  justify-items: center;
}
@media (min-width: 641px) {
  .p-quiz {
    padding-top: 1em;
  }
}
.p-quiz .inner {
  position: relative;
  display: grid;
  justify-self: center;
  justify-items: center;
  box-sizing: border-box;
  box-shadow: 0.3em 0.3em 0 0 #ffd1d4;
  border: 0.3em solid white;
  border-radius: 1.5em;
  background: #fdeff5 url(../images/quiz_bg.png) repeat center top/37em;
}
@media (max-width: 640px) {
  .p-quiz .inner {
    width: 17.5em;
    padding: 0 1em 1em;
  }
}
@media (min-width: 641px) {
  .p-quiz .inner {
    width: 33em;
    padding-bottom: 1em;
  }
}
.p-quiz .inner::before {
  content: "";
  position: absolute;
  left: 100%;
  bottom: 100%;
  width: 3.2em;
  aspect-ratio: 64/49;
  background: url(../images/quiz_chara_bird.png) no-repeat center center/contain;
}
@media (max-width: 640px) {
  .p-quiz .inner::before {
    transform: translate(-125%, 50%);
  }
}
@media (min-width: 641px) {
  .p-quiz .inner::before {
    transform: translate(-50%, 50%);
  }
}
.p-quiz .inner .title {
  margin-top: -1em;
  margin-bottom: 1.5em;
}
@media (min-width: 641px) {
  .p-quiz .inner .title {
    width: 24.2em;
  }
}
.p-quiz .inner .choice {
  display: grid;
  margin: 1em auto 1.5em;
}
@media (max-width: 640px) {
  .p-quiz .inner .choice {
    grid-row-gap: 1.2em;
  }
}
@media (min-width: 641px) {
  .p-quiz .inner .choice {
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    grid-column-gap: 0.6em;
  }
}
.p-quiz .inner .choice .btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  height: 2.6em;
  border: #ffd1d4 solid 0.2em;
  border-radius: 1.3em;
  padding: 0 1em;
  background: white;
  cursor: pointer;
  transition: 200ms;
}
.p-quiz .inner .choice .btn img {
  width: auto;
  height: 1.6em;
  transition: 200ms;
}
.p-quiz .inner .choice .btn[disabled] {
  cursor: default;
}
.p-quiz .inner .choice .btn[disabled] img {
  opacity: 50%;
}
.p-quiz .inner .choice .btn.correct {
  background: #fff700;
}
.p-quiz .inner .choice .btn.correct img {
  opacity: 1;
}
.p-quiz .inner .choice .btn.selected::before {
  position: absolute;
  left: 0%;
  bottom: calc(100% - 0.2em);
  width: 100%;
  height: 1.3em;
  background: no-repeat center center/contain;
  transition: opacity 200ms;
}
.p-quiz .inner .choice .btn.selected:not(.selected)::before {
  opacity: 0;
}
.p-quiz .inner .choice .btn.selected.selected::before {
  content: "";
}
.p-quiz .inner .choice .btn.selected:not(.correct)::before {
  background-image: url(../images/quiz_select_incorrect.png);
}
.p-quiz .inner .choice .btn.selected.correct {
  z-index: 1;
}
.p-quiz .inner .choice .btn.selected.correct::before {
  background-image: url(../images/quiz_select_correct.png);
}
.p-quiz .inner .choice .btn.selected.correct::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 10em;
  aspect-ratio: 1;
  transform: translate(-50%, -50%);
  background: url(../images/quiz_select_maru.png) no-repeat center center/contain;
  transition: opacity 400ms 100ms;
}
.p-quiz .inner .answer {
  display: grid;
  overflow: hidden;
}
.p-quiz .inner .answer:not(.open) {
  height: 0 !important;
  opacity: 0;
}
.p-quiz .inner .answer.open {
  transition: height 600ms, opacity 400ms 600ms;
}
@media (max-width: 640px) {
  .p-quiz .inner .answer {
    grid-template-areas: "caption caption" "text image" "ojisan ojisan";
    grid-gap: 0.6em;
    align-items: center;
    justify-items: center;
    background: white;
    border-radius: 1em;
    padding: 1em;
  }
}
@media (min-width: 641px) {
  .p-quiz .inner .answer {
    position: relative;
    grid-template-areas: "image . ojisan" "image caption ojisan" "image text ojisan" "image . ojisan";
    grid-gap: 0.5em 1em;
    align-items: center;
    padding: 0 0.5em 0 1em;
  }
  .p-quiz .inner .answer::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    width: calc(100% - 11em);
    height: calc(100% - 4em);
    transform: translate(4em, -50%);
    background: white;
  }
  .p-quiz .inner .answer > *, .p-quiz .inner .answer::after {
    position: relative;
  }
}
.p-quiz .inner .answer::after {
  grid-area: ojisan;
  content: "";
  width: 10.75em;
  aspect-ratio: 215/209;
  background: url(../images/quiz_ojisan.png) no-repeat center center/contain;
}
.p-quiz .inner .answer .caption {
  grid-area: caption;
}
.p-quiz .inner .answer .caption img {
  width: 9.8em;
}
.p-quiz .inner .answer .image {
  grid-area: image;
}
.p-quiz .inner .answer .image img {
  width: 7.4em;
}
.p-quiz .inner .answer .text {
  grid-area: text;
  font-size: 0.8em;
}
.p-activities {
  --color1: #1eaa39;
  --color2: #f7b52c;
  --color3: #62afe2;
  --color4: #ed85a0;
  display: grid;
  grid-row-gap: 2em;
  justify-items: center;
  background: url(../images/bg_arc_2.png) no-repeat center top, url(../images/bg_arc_1.png) no-repeat center bottom, url(../images/bg_paper.jpg) repeat center center;
  overflow-x: hidden;
}
@media (max-width: 640px) {
  .p-activities {
    padding: 4em 0;
    background-size: 100% 1.6em, 100% 1.6em, 15em;
  }
}
@media (min-width: 641px) {
  .p-activities {
    padding: 6em 0;
    background-size: 100% 3em, 100% 3em, 20em;
  }
}
@media (max-width: 640px) {
  .p-activities .title img {
    width: 16.8em;
  }
}
@media (min-width: 641px) {
  .p-activities .title img {
    width: 37.4em;
  }
}
.p-activities .contents {
  display: grid;
  grid-row-gap: 2em;
}
@media (max-width: 640px) {
  .p-activities .contents {
    width: 17em;
  }
}
@media (min-width: 641px) {
  .p-activities .contents {
    width: 51.2em;
  }
}
.p-activities .contents-item {
  position: relative;
  display: grid;
  border: 0.2em solid;
  border-radius: 2em;
  background: white no-repeat;
}
@media (max-width: 640px) {
  .p-activities .contents-item[data-id="1"] {
    background-image: linear-gradient(10deg, white 75%, transparent 75%), url(../images/activities_column_bg_1.png);
    background-position: left top 0.5em, left top;
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="1"] {
    background-image: linear-gradient(255deg, white 75%, transparent 75%), url(../images/activities_column_bg_1.png);
    background-position: left top, center center;
  }
}
.p-activities .contents-item[data-id="1"] {
  border-color: var(--color1);
}

@media (max-width: 640px) {
  .p-activities .contents-item[data-id="2"] {
    background-image: linear-gradient(-10deg, white 75%, transparent 75%), url(../images/activities_column_bg_1.png);
    background-position: left top 0.5em, left top;
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="2"] {
    background-image: linear-gradient(-255deg, white 75%, transparent 75%), url(../images/activities_column_bg_1.png);
    background-position: left top, center center;
  }
}
.p-activities .contents-item[data-id="2"] {
  border-color: var(--color1);
}

@media (max-width: 640px) {
  .p-activities .contents-item[data-id="3"] {
    background-image: linear-gradient(10deg, white 75%, transparent 75%), url(../images/activities_column_bg_2.png);
    background-position: left top 0.5em, left top;
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="3"] {
    background-image: linear-gradient(255deg, white 75%, transparent 75%), url(../images/activities_column_bg_2.png);
    background-position: left top, center center;
  }
}
.p-activities .contents-item[data-id="3"] {
  border-color: var(--color2);
}

@media (max-width: 640px) {
  .p-activities .contents-item[data-id="4"] {
    background-image: linear-gradient(-10deg, white 75%, transparent 75%), url(../images/activities_column_bg_2.png);
    background-position: left top 0.5em, left top;
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="4"] {
    background-image: linear-gradient(-255deg, white 75%, transparent 75%), url(../images/activities_column_bg_2.png);
    background-position: left top, center center;
  }
}
.p-activities .contents-item[data-id="4"] {
  border-color: var(--color2);
}

@media (max-width: 640px) {
  .p-activities .contents-item[data-id="5"] {
    background-image: linear-gradient(10deg, white 75%, transparent 75%), url(../images/activities_column_bg_3.png);
    background-position: left top 0.5em, left top;
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="5"] {
    background-image: linear-gradient(255deg, white 75%, transparent 75%), url(../images/activities_column_bg_3.png);
    background-position: left top, center center;
  }
}
.p-activities .contents-item[data-id="5"] {
  border-color: var(--color3);
}

@media (max-width: 640px) {
  .p-activities .contents-item[data-id="6"] {
    background-image: linear-gradient(-10deg, white 75%, transparent 75%), url(../images/activities_column_bg_3.png);
    background-position: left top 0.5em, left top;
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="6"] {
    background-image: linear-gradient(-255deg, white 75%, transparent 75%), url(../images/activities_column_bg_3.png);
    background-position: left top, center center;
  }
}
.p-activities .contents-item[data-id="6"] {
  border-color: var(--color3);
}

@media (max-width: 640px) {
  .p-activities .contents-item[data-id="7"] {
    background-image: linear-gradient(10deg, white 75%, transparent 75%), url(../images/activities_column_bg_4.png);
    background-position: left top 0.5em, left top;
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="7"] {
    background-image: linear-gradient(255deg, white 75%, transparent 75%), url(../images/activities_column_bg_4.png);
    background-position: left top, center center;
  }
}
.p-activities .contents-item[data-id="7"] {
  border-color: var(--color4);
}

@media (max-width: 640px) {
  .p-activities .contents-item[data-id="8"] {
    background-image: linear-gradient(-10deg, white 75%, transparent 75%), url(../images/activities_column_bg_4.png);
    background-position: left top 0.5em, left top;
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="8"] {
    background-image: linear-gradient(-255deg, white 75%, transparent 75%), url(../images/activities_column_bg_4.png);
    background-position: left top, center center;
  }
}
.p-activities .contents-item[data-id="8"] {
  border-color: var(--color4);
}

@media (max-width: 640px) {
  .p-activities .contents-item {
    justify-items: center;
    grid-row-gap: 1em;
    padding: 1em;
    background-size: 100% 100%, 300% auto;
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item {
    grid-gap: 0.5em 1em;
    grid-auto-rows: max-content 1fr;
    background-size: 101% auto;
    padding: 1em;
  }
  .p-activities .contents-item:nth-of-type(odd) {
    grid-template-areas: "image cap click" "image body click";
    padding-left: 2.4em;
  }
  .p-activities .contents-item:nth-of-type(even) {
    grid-template-areas: "click cap image" "click body image";
    padding-right: 2.4em;
  }
  .p-activities .contents-item .image {
    grid-area: image;
  }
  .p-activities .contents-item .cap {
    grid-area: cap;
  }
  .p-activities .contents-item .click {
    grid-area: click;
  }
}
.p-activities .contents-item::before {
  position: absolute;
  z-index: 1;
  top: 0;
  content: "";
  background: no-repeat center center/contain;
  animation-duration: 2s;
  animation-timing-function: steps(1);
  animation-iteration-count: infinite;
  transform-origin: 50% 40%;
}
.p-activities .contents-item[data-id="2"]::before {
  transform-origin: 50% 70%;
}

.p-activities .contents-item[data-id="8"]::before {
  transform-origin: 50% 70%;
}

@media (max-width: 640px) {
  .p-activities .contents-item::before {
    font-size: 80%;
  }
}
.p-activities .contents-item[data-id="1"]::before {
  animation-name: ojikero1;
  left: 0;
}
@keyframes ojikero1 {
  0% {
    transform: translate(-25%, -20%) rotate(-10deg);
  }
  50% {
    transform: translate(-25%, -20%) rotate(10deg);
  }
}

.p-activities .contents-item[data-id="2"]::before {
  animation-name: ojikero2;
  left: 100%;
}
@keyframes ojikero2 {
  0% {
    transform: translate(-75%, -50%) rotate(20deg);
  }
  50% {
    transform: translate(-75%, -50%) rotate(40deg);
  }
}

.p-activities .contents-item[data-id="3"]::before {
  animation-name: ojikero3;
  left: 0;
}
@keyframes ojikero3 {
  0% {
    transform: translate(-25%, -20%) rotate(-10deg);
  }
  50% {
    transform: translate(-25%, -20%) rotate(10deg);
  }
}

.p-activities .contents-item[data-id="4"]::before {
  animation-name: ojikero4;
  left: 100%;
}
@keyframes ojikero4 {
  0% {
    transform: translate(-75%, -20%) rotate(10deg);
  }
  50% {
    transform: translate(-75%, -20%) rotate(-10deg);
  }
}

.p-activities .contents-item[data-id="5"]::before {
  animation-name: ojikero5;
  left: 0;
}
@keyframes ojikero5 {
  0% {
    transform: translate(-25%, -20%) rotate(-10deg);
  }
  50% {
    transform: translate(-25%, -20%) rotate(10deg);
  }
}

.p-activities .contents-item[data-id="6"]::before {
  animation-name: ojikero6;
  left: 100%;
}
@keyframes ojikero6 {
  0% {
    transform: translate(-75%, -20%) rotate(10deg);
  }
  50% {
    transform: translate(-75%, -20%) rotate(-10deg);
  }
}

.p-activities .contents-item[data-id="7"]::before {
  animation-name: ojikero7;
  left: 0;
}
@keyframes ojikero7 {
  0% {
    transform: translate(-25%, -20%) rotate(-10deg);
  }
  50% {
    transform: translate(-25%, -20%) rotate(10deg);
  }
}

.p-activities .contents-item[data-id="8"]::before {
  animation-name: ojikero8;
  left: 100%;
}
@keyframes ojikero8 {
  0% {
    transform: translate(-75%, -50%) rotate(20deg);
  }
  50% {
    transform: translate(-75%, -50%) rotate(40deg);
  }
}

.p-activities .contents-item[data-id="1"]::before {
  background-image: url(../images/activities_ojisan_1.png);
  width: 6.1em;
  aspect-ratio: 122/119;
}

.p-activities .contents-item[data-id="2"]::before {
  background-image: url(../images/activities_kerota_1.png);
  width: 4.65em;
  aspect-ratio: 93/89;
}

.p-activities .contents-item[data-id="3"]::before {
  background-image: url(../images/activities_ojisan_2.png);
  width: 6.25em;
  aspect-ratio: 125/116;
}

.p-activities .contents-item[data-id="4"]::before {
  background-image: url(../images/activities_ojisan_3.png);
  width: 6.25em;
  aspect-ratio: 125/118;
}

.p-activities .contents-item[data-id="5"]::before {
  background-image: url(../images/activities_ojisan_4.png);
  width: 6.1em;
  aspect-ratio: 122/121;
}

.p-activities .contents-item[data-id="6"]::before {
  background-image: url(../images/activities_ojisan_5.png);
  width: 6.35em;
  aspect-ratio: 127/119;
}

.p-activities .contents-item[data-id="7"]::before {
  background-image: url(../images/activities_ojisan_6.png);
  width: 6.5em;
  aspect-ratio: 130/120;
}

.p-activities .contents-item[data-id="8"]::before {
  background-image: url(../images/activities_kerota_2.png);
  width: 4.55em;
  aspect-ratio: 91/91;
}

.p-activities .contents-item::after {
  position: absolute;
  z-index: 0;
  content: "";
  left: 0;
  bottom: 100%;
  width: 100%;
  height: 2.2em;
  background: no-repeat center bottom/1.5em 100%;
}
.p-activities .contents-item[data-group="1"]::after {
  background-image: linear-gradient(var(--color1), var(--color1));
}

.p-activities .contents-item[data-group="2"]::after {
  background-image: linear-gradient(var(--color2), var(--color2));
}

.p-activities .contents-item[data-group="3"]::after {
  background-image: linear-gradient(var(--color3), var(--color3));
}

.p-activities .contents-item[data-group="4"]::after {
  background-image: linear-gradient(var(--color4), var(--color4));
}

.p-activities .contents-item .image {
  position: relative;
}
@media (min-width: 641px) {
  .p-activities .contents-item .image {
    width: 14.2em;
  }
  .p-activities .contents-item[data-id="1"] .image {
    width: 14.2em;
  }
  .p-activities .contents-item[data-id="2"] .image {
    width: 13.1em;
  }
  .p-activities .contents-item[data-id="3"] .image {
    width: 14.8em;
  }
  .p-activities .contents-item[data-id="4"] .image {
    width: 15.6em;
  }
  .p-activities .contents-item[data-id="5"] .image {
    width: 14.1em;
  }
  .p-activities .contents-item[data-id="6"] .image {
    width: 15.2em;
  }
  .p-activities .contents-item[data-id="7"] .image {
    width: 13em;
  }
  .p-activities .contents-item[data-id="8"] .image {
    width: 15.3em;
  }
}
.p-activities .contents-item .image::after {
  position: absolute;
  content: "";
  background: no-repeat center center/contain;
}
.p-activities .contents-item[data-id="5"] .image::after {
  left: 100%;
  top: 100%;
  width: 3.2em;
  aspect-ratio: 64/76;
  transform: translate(-2.3em, -2.4em);
  background-image: url(../images/activities_kamegoro_1.png);
}

@media (min-width: 641px) {
  .p-activities .contents-item .caption {
    height: 1.6em;
  }
}
.p-activities .contents-item .body {
  display: block;
  position: relative;
}
.p-activities .contents-item .body p {
  display: block;
  font-size: 0.8em;
  line-height: 1.6;
}
.p-activities .contents-item .body::before, .p-activities .contents-item .body::after {
  background: no-repeat center center/contain;
}
@media (max-width: 640px) {
  .p-activities .contents-item .body::before, .p-activities .contents-item .body::after {
    font-size: 75%;
  }
}
.p-activities .contents-item[data-id="2"] .body::before {
  content: "";
  width: 4.65em;
  aspect-ratio: 93/128;
  background-image: url(../images/activities_mimi_1.png);
}
@media (max-width: 640px) {
  .p-activities .contents-item[data-id="2"] .body::before {
    position: absolute;
    left: 0;
    bottom: 100%;
    transform: translate(-2em, -4em) scale(0.9);
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="2"] .body::before {
    float: right;
    margin-left: 1em;
    transform: translateY(2em);
  }
}

.p-activities .contents-item[data-id="3"] .body::before {
  position: absolute;
  content: "";
  right: 0;
  bottom: 100%;
  transform: translateY(-1em);
  width: 3.2em;
  aspect-ratio: 64/54;
  background-image: url(../images/activities_tori_1.png);
}

.p-activities .contents-item[data-id="4"] .body::before {
  position: absolute;
  content: "";
  left: 0;
  width: 4.25em;
  aspect-ratio: 85/48;
  background-image: url(../images/activities_moguro_1.png);
}
@media (max-width: 640px) {
  .p-activities .contents-item[data-id="4"] .body::before {
    position: absolute;
    bottom: 100%;
    transform: translate(0, -0.5em);
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="4"] .body::before {
    top: 100%;
  }
}

.p-activities .contents-item[data-id="6"] .body::before {
  content: "";
  width: 4.65em;
  aspect-ratio: 93/112;
  background-image: url(../images/activities_kerota_3.png);
}
@media (max-width: 640px) {
  .p-activities .contents-item[data-id="6"] .body::before {
    position: absolute;
    left: 0;
    bottom: 100%;
    transform: translate(-1em, -2em);
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="6"] .body::before {
    float: right;
    margin-left: 1em;
    transform: translateY(4em);
  }
}

.p-activities .contents-item[data-id="8"] .body::before {
  content: "";
  width: 6.8em;
  aspect-ratio: 136/158;
  background-image: url(../images/activities_pongoro_1.png);
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="8"] .body::before {
    float: left;
    margin-right: 1em;
    transform: translateY(3.5em);
  }
}

.p-activities .contents-item[data-id="8"] .body::after {
  position: absolute;
  content: "";
  bottom: 100%;
  width: 3.05em;
  aspect-ratio: 61/53;
  background-image: url(../images/activities_tori_2.png);
}
@media (max-width: 640px) {
  .p-activities .contents-item[data-id="8"] .body::after {
    left: 0;
    transform: translate(-2em, -0.4em) scaleX(-1);
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item[data-id="8"] .body::after {
    right: 0;
    transform: translateY(-1.4em);
  }
}

@media (min-width: 641px) {
  .p-activities .contents-item .click {
    align-self: center;
  }
}
.p-activities .contents-item .click button {
  display: grid;
}
@media (max-width: 640px) {
  .p-activities .contents-item .click button {
    width: 7.4em;
    aspect-ratio: 148/72;
  }
}
@media (min-width: 641px) {
  .p-activities .contents-item .click button {
    width: 3.8em;
    aspect-ratio: 76/121;
  }
}
.p-activities .contents-item .click button span {
  grid-column: 1;
  grid-row: 1;
}
.p-activities .contents-item .click button:not(.read) .on, .p-activities .contents-item .click button.read .off {
  visibility: hidden;
}
.p-activities .contents-item .click button:not(.read) .on {
  transform: scale(1.1);
}
.p-activities .contents-item .click button.read .on {
  transform: scale(1);
  transition: transform 400ms;
}
.p-activities .meijiLink {
  display: grid;
  grid-row-gap: 0.2em;
  justify-items: center;
  background: white;
  border: 0.1em solid #e6cba6;
  border-radius: 1.5em;
}
@media (max-width: 640px) {
  .p-activities .meijiLink {
    margin-top: 1em;
    padding: 1em 1.5em;
    font-size: 80%;
  }
}
@media (min-width: 641px) {
  .p-activities .meijiLink {
    margin-top: 2em;
    padding: 1em 3em;
  }
}
.p-activities .meijiLink h3 {
  color: #ff0000;
  font-size: 1em;
  font-weight: bold;
}
.p-activities .meijiLink p {
  font-size: 0.8em;
  text-align: center;
}
.p-activities .meijiLink a {
  color: #0088ff;
  font-size: 0.8em;
  text-decoration: underline;
}

.p-process {
  margin: 3em auto;
  justify-self: center;
}
@media (max-width: 640px) {
  .p-process {
    width: 18em;
  }
}
@media (min-width: 641px) {
  .p-process {
    width: 53.5em;
  }
}

.p-app {
  justify-self: stretch;
  display: grid;
  justify-content: center;
  background: #c3d600;
  padding: 2em 0;
}
.p-app .inner {
  position: relative;
}
@media (max-width: 640px) {
  .p-app .inner {
    width: 18em;
  }
}
@media (min-width: 641px) {
  .p-app .inner {
    width: 39.5em;
  }
}
.p-app .inner .download {
  display: grid;
  position: absolute;
}
@media (max-width: 640px) {
  .p-app .inner .download {
    left: 0;
    bottom: 0;
    width: 100%;
  }
}
@media (min-width: 641px) {
  .p-app .inner .download {
    left: 26.25em;
    top: 5.3em;
    width: 11.85em;
  }
}
.p-app .inner .download {
  /*

  @include sp {
  	grid-template-columns: 89fr 100fr;
  	grid-column-gap: 0.8em;
  	align-items: center;
  	left: px(22);
  	top: px(390);
  	width: px(314);
  }

  @include pc {
  	justify-items: center;
  	grid-row-gap: 0.5em;
  	left: px(570);
  	top: px(129);
  	width: px(148);
  	.apple {
  		width: 89%;
  	}
  }
  */
}

.p-foot {
  justify-self: center;
  margin: 4em auto;
}
.p-foot .totop img {
  width: 8.8em;
}
