@charset "UTF-8";
/*
_function.scss ファイル
それぞれ( )内にpxでの数値を入れるとrem, pxに変換
*/
body {
  color: #222222;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 0.9375rem;
  font-style: normal;
  font-weight: 400;
  line-height: 210%;
  background: #222222;
}

img {
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
}

@media screen and (max-width: 1439px) and (min-width: 768px) {
  html {
    font-size: calc(1600 / 1440 * 1vw);
  }
}
@media screen and (max-width: 767px) and (min-width: 390px) {
  html {
    font-size: calc(1500 / 390 * 1vw);
  }
}

.l-inner {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  max-width: 650px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) {
  .l-inner {
    max-width: 700px;
  }
}
@media screen and (min-width: 900px) {
  .l-inner {
    max-width: 850px;
    padding-left: 0;
    padding-right: 0;
  }
}
@media screen and (min-width: 1200px) {
  .l-inner {
    max-width: 62.5rem;
  }
}

.c-button__header {
  color: #ebebeb;
  font-weight: 700;
  line-height: 0.9375rem;
  border-radius: 1.875rem;
  background: #222222;
  padding: 0.6875rem 1.875rem 0.75rem 1.875rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
@media screen and (min-width: 1200px) {
  .c-button__header {
    padding: 0.6875rem 2.5625rem 0.75rem 2.625rem;
  }
}
.c-button__header:hover {
  opacity: 0.7;
}

.c-button__more {
  background: #222222;
  color: #ebebeb;
  border-radius: 1.875rem;
  border: 0.0625rem solid #ebebeb;
  padding: 1.0625rem 5.375rem 1.125rem 5.4375rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-weight: 700;
  line-height: 0.9375rem;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.c-button__more:hover {
  opacity: 0.7;
}

.c-button__more-p {
  background: #9f28fb;
  color: #ebebeb;
  border-radius: 1.875rem;
  border: none;
  padding: 0.625rem 3.9375rem 0.625rem 4rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
@media screen and (min-width: 768px) {
  .c-button__more-p {
    padding: 0.5625rem 3.9375rem 0.625rem 4rem;
  }
}
.c-button__more-p:hover {
  opacity: 0.7;
}

.c-button__works {
  background: #9f28fb;
  color: #ebebeb;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1rem;
  padding: 1rem 1.625rem 1rem 4.125rem;
  border-radius: 1.5625rem;
  width: 15.625rem;
  position: relative;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.c-button__works::after {
  content: "";
  position: absolute;
  background: url(../img/icon-arrow.svg);
  background-size: cover;
  width: 0.8125rem;
  height: 0.625rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 1.625rem;
}
.c-button__works:hover {
  opacity: 0.7;
}

.c-button__tag-sp {
  background: transparent;
  color: #ebebeb;
  font-size: 1rem;
  font-weight: 700;
  line-height: 0.875rem;
  padding: 0.8125rem 2.5rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border: 0.0625rem solid #ebebeb;
  border-radius: 1.25rem;
  -webkit-transition: background 0.5s;
  transition: background 0.5s;
}

.c-button__detail-sp {
  background: transparent;
  color: #ebebeb;
  font-size: 1rem;
  font-weight: 700;
  line-height: 0.875rem;
  padding: 0.8125rem 1.5625rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  border: 0.0625rem solid #ebebeb;
  border-radius: 1.25rem;
  margin-inline: auto;
  text-wrap: nowrap;
}

.c-button__tag-pc {
  padding: 0.8125rem 2.5rem;
  color: #ebebeb;
  background: #727272;
  border-radius: 1.25rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1rem;
  font-weight: 700;
  line-height: 0.875rem;
}

.c-button__detail-pc {
  border-radius: 1.25rem;
  background: #727272;
  padding: 0.8125rem 1.5625rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1rem;
  font-weight: 700;
  line-height: 0.875rem;
}

.c-button__decision {
  background: #9f28fb;
  padding: 0.8125rem 4.125rem 0.8125rem 2.5rem;
  color: #ebebeb;
  border-radius: 1.25rem;
  width: 10.625rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 0.875rem;
  position: relative;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.c-button__decision::after {
  content: "";
  position: absolute;
  background: url(../img/icon-search.svg);
  background-size: cover;
  width: 0.875rem;
  height: 0.875rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 2.5rem;
}
.c-button__decision:hover {
  opacity: 0.7;
}

.c-tag {
  color: #ebebeb;
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 0.8125rem;
  padding: 0.4375rem 0.75rem;
  border-radius: 1.21875rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.c-tag__p {
  background-color: #ef6bab;
}

.c-tag__m {
  background-color: #9f28fb;
}

.c-tag__b {
  background-color: #569bff;
}

.c-tag__g {
  background-color: #21be69;
}

.c-tag__o {
  background-color: #ee933e;
}

.c-color-p {
  color: #ef6bab;
}

.c-color-m {
  color: #9f28fb;
}

.c-color-b {
  color: #569bff;
}

.c-color-g {
  color: #21be69;
}

.c-color-o {
  color: #ee933e;
}

.c-heart {
  background-image: url(../img/icon-heart.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 1.5625rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
@media screen and (min-width: 768px) {
  .c-heart {
    margin-top: 0.125rem;
  }
}
.c-heart.heart__pink {
  background-image: url(../img/icon-heart-pink.svg);
}
.c-heart:hover {
  opacity: 0.8;
}

.p-top__wrapper {
  background-image: url(../img/bg-fv-sp.png);
  background-size: cover;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-top__wrapper {
    background-image: url(../img/bg-fv-pc.png);
  }
}

.p-header {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 60;
  -webkit-transition: background-color 0.4s ease-in;
  transition: background-color 0.4s ease-in;
}

/* スクロールしたらヘッダーメニューのフォントカラー変更 */
.p-header.headerColorScroll {
  background-color: rgba(100, 100, 100, 0.7);
  -webkit-transition: background-color 0.4s ease-out;
  transition: background-color 0.4s ease-out;
}

.p-header__logo.headerColorScroll {
  background: url(../img/logo-sp-w.svg);
  background-size: cover;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
@media screen and (min-width: 768px) {
  .p-header__logo.headerColorScroll {
    background: url(../img/logo-g.png);
    background-size: cover;
  }
}

.p-header__nav.headerColorScroll {
  color: #ebebeb;
  -webkit-transition: color 0.4s ease-out;
  transition: color 0.4s ease-out;
}

@media screen and (min-width: 900px) {
  .p-header__link.headerColorScroll {
    font-weight: 700;
    line-height: 0.9375rem;
    /* 下線のスタイル */
  }
  .p-header__link.headerColorScroll::after {
    background-color: #ffffff; /* 下線の色 */
  }
}

.p-header__button.headerColorScroll {
  color: #222222;
  background-color: #ebebeb;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

.p-header__bar.headerColorScroll {
  background: #ebebeb;
  -webkit-transition: top 0.3s linear, background 0.4s ease-out, -webkit-transform 0.3s linear;
  transition: top 0.3s linear, background 0.4s ease-out, -webkit-transform 0.3s linear;
  transition: transform 0.3s linear, top 0.3s linear, background 0.4s ease-out;
  transition: transform 0.3s linear, top 0.3s linear, background 0.4s ease-out, -webkit-transform 0.3s linear;
}

.p-header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-header__inner {
    padding-top: 1.3125rem;
    padding-bottom: 1.3125rem;
  }
}

.p-header__logo {
  width: 1.98925rem;
  height: 1.488125rem;
  background: url(../img/logo-sp.svg);
  background-size: cover;
}
@media screen and (min-width: 768px) {
  .p-header__logo {
    width: 14.0625rem;
    height: 1.5709375rem;
    background: url(../img/logo-pc.png);
    background-size: cover;
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }
  .p-header__logo:hover {
    opacity: 0.8;
  }
}

.p-header__nav {
  display: none;
}
@media screen and (min-width: 900px) {
  .p-header__nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1.875rem;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -webkit-transition: color 0.4s ease-in;
    transition: color 0.4s ease-in;
  }
}

@media screen and (min-width: 900px) {
  .p-header__link {
    font-weight: 700;
    line-height: 0.9375rem;
    display: inline-block;
    position: relative;
    text-decoration: none;
    /* 下線のスタイル */
    /* リンクにホバーした際の下線の表示 */
  }
  .p-header__link::after {
    background-color: #222222; /* 下線の色 */
    bottom: -0.3125rem; /* 要素の下端からの距離 */
    content: ""; /* 要素に内容を追加 */
    height: 1px; /* 下線の高さ */
    left: 0; /* 要素の左端からの距離 */
    position: absolute; /* 絶対位置指定 */
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1); /* 下線を横方向に0倍、縦方向に1倍に変形（非表示） */
    -webkit-transform-origin: center top;
            transform-origin: center top; /* 変形の原点を中央上に指定 */
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s; /* 変形をアニメーション化 */
    width: 100%; /* 要素の幅 */
  }
  .p-header__link:hover::after {
    -webkit-transform: scale(1, 2);
            transform: scale(1, 2); /* 下線を横方向に1倍、縦方向に1倍に変形（表示） */
  }
}

@media screen and (min-width: 900px) {
  .p-header__button {
    margin-left: 0.125rem;
  }
}

.p-header__open {
  width: 3rem;
  height: 1.5625rem;
  position: relative;
  z-index: 51;
  margin-left: auto;
}
@media screen and (min-width: 900px) {
  .p-header__open {
    display: none;
  }
}
.p-header__open.is-checked .p-header__bar:nth-of-type(2) {
  display: none;
}
.p-header__open.is-checked .p-header__bar:nth-of-type(1) {
  top: 0.625rem;
  -webkit-transform: rotate(30deg);
          transform: rotate(30deg);
  background: #ebebeb;
}
.p-header__open.is-checked .p-header__bar:nth-of-type(3) {
  top: 0.625rem;
  -webkit-transform: rotate(-30deg);
          transform: rotate(-30deg);
  background: #ebebeb;
}

.p-header__bar {
  position: absolute;
  top: 0;
  left: 0;
  width: 3rem;
  height: 0.0625rem;
  background: #222222;
  -webkit-transition: top 0.3s linear, background 0.4s ease-in, -webkit-transform 0.3s linear;
  transition: top 0.3s linear, background 0.4s ease-in, -webkit-transform 0.3s linear;
  transition: transform 0.3s linear, top 0.3s linear, background 0.4s ease-in;
  transition: transform 0.3s linear, top 0.3s linear, background 0.4s ease-in, -webkit-transform 0.3s linear;
}
.p-header__bar:nth-of-type(1) {
  top: 0;
}
.p-header__bar:nth-of-type(2) {
  top: 0.78125rem;
}
.p-header__bar:nth-of-type(3) {
  top: 1.5625rem;
}

.p-header__content {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  right: 0;
  background: rgba(34, 34, 34, 0.9);
  z-index: 50;
  padding: 92px 30px 57px 34px;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: -webkit-transform 0.3s linear;
  transition: -webkit-transform 0.3s linear;
  transition: transform 0.3s linear;
  transition: transform 0.3s linear, -webkit-transform 0.3s linear;
}
@media screen and (min-width: 600px) {
  .p-header__content {
    width: 500px;
  }
}
@media screen and (min-width: 768px) {
  .p-header__content {
    width: 350px;
  }
}
.p-header__content.is-checked {
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

.p-header__content-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
}
@media screen and (min-width: 600px) {
  .p-header__content-menu {
    gap: 20px;
    font-size: 23px;
  }
}
@media screen and (min-width: 768px) {
  .p-header__content-menu {
    gap: 2rem;
    font-size: 0.9375rem;
  }
}

.p-header__content-link {
  color: #ebebeb;
}

.p-fv {
  padding-top: 5.1875rem;
  padding-bottom: 12.9375rem;
}
@media screen and (min-width: 768px) {
  .p-fv {
    padding-top: 10.1875rem;
    padding-bottom: 21.25rem;
  }
}

.p-fv__title-top {
  color: #ffffff;
  font-size: 0.875rem;
  font-weight: 900;
  line-height: 0.875rem;
}
@media screen and (min-width: 768px) {
  .p-fv__title-top {
    font-size: 1.625rem;
    line-height: 100%;
  }
}

.p-fv__title {
  margin-top: 1rem;
  width: 18.25rem;
}
@media screen and (min-width: 768px) {
  .p-fv__title {
    margin-top: 1.75rem;
    width: 38.125rem;
  }
}

.p-title__sub {
  margin-top: 1.25rem;
  color: #ffffff;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 165%;
}
@media screen and (min-width: 768px) {
  .p-title__sub {
    margin-top: 2.75rem;
    font-size: 1rem;
  }
}

.p-title__sub-inline {
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 165%;
}
@media screen and (min-width: 768px) {
  .p-title__sub-inline {
    font-size: 1rem;
  }
}

.p-fv__swiper {
  margin-top: -10.5rem;
}
@media screen and (min-width: 768px) {
  .p-fv__swiper {
    margin-top: -14.1875rem;
  }
}

/* スライドの動き等速 */
.p-fv__swiper-wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}

.p-fv__swiper-slide {
  background: #ebebeb;
  border-radius: 1.5625rem;
  padding: 1.875rem 1.1875rem 1.625rem;
  max-width: 19.5rem;
}
.p-fv__swiper-slide:hover .p-fv-slide__img img {
  -webkit-filter: brightness(0.8);
          filter: brightness(0.8);
}
.p-fv__swiper-slide:hover .p-fv-slide__img p {
  opacity: 1;
}

.p-fv-slide__tags {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.3125rem;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.p-fv-slide__img {
  margin-top: 1rem;
  width: 100%;
  height: auto;
  position: relative;
}
.p-fv-slide__img img {
  -webkit-transition: -webkit-filter 0.3s;
  transition: -webkit-filter 0.3s;
  transition: filter 0.3s;
  transition: filter 0.3s, -webkit-filter 0.3s;
}
.p-fv-slide__img p {
  color: #ebebeb;
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  bottom: 0.625rem;
  left: 0.625rem;
  line-height: 150%;
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

.p-fv-slide__title-wrapper {
  margin-top: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (min-width: 768px) {
  .p-fv-slide__title-wrapper {
    margin-top: 1.125rem;
  }
}

.p-fv-slide__title-main {
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 120%;
}

.p-fv-slide__title-sub {
  margin-top: 0.5rem;
  color: #6b6b6b;
  font-weight: 400;
  line-height: 120%;
}

.p-fv-slide__members {
  margin-top: 0.8125rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.25rem;
}
@media screen and (min-width: 768px) {
  .p-fv-slide__members {
    margin-top: 0.75rem;
  }
}

.p-fv-slide__member {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 0.25rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .p-fv-slide__member {
    gap: 0.1875rem;
  }
}

.p-fv-slide__member-img {
  width: 1.875rem;
  height: 1.875rem;
}

.p-fv-slide__member-name {
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 120%;
}
@media screen and (min-width: 768px) {
  .p-fv-slide__member-name {
    padding-top: 0.375rem;
  }
}

.p-fv-slide__text {
  margin-top: 0.625rem;
  color: #6b6b6b;
  line-height: 165%;
}
@media screen and (min-width: 768px) {
  .p-fv-slide__text {
    margin-top: 1rem;
  }
}

.p-fv-slide__button {
  margin-top: 1.6875rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (min-width: 768px) {
  .p-fv-slide__button {
    margin-top: 1.875rem;
  }
}

.p-fv-slide__button-more {
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 0.875rem;
  padding-bottom: 0.3125rem;
  border-bottom: 0.0625rem solid #222222;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.p-fv-slide__button-more:hover {
  opacity: 0.7;
}

.p-fv-slide__button-watch {
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 0.875rem;
  padding-bottom: 0.3125rem;
  border-bottom: 0.0625rem solid #222222;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.p-fv-slide__button-watch:hover {
  opacity: 0.7;
}
.p-fv-slide__button-watch .arrow-naname img {
  width: 0.5625rem;
  height: 0.5625rem;
  margin-top: -0.5rem;
}

.swiper-horizontal {
  padding-bottom: 2.8125rem;
}
@media screen and (min-width: 768px) {
  .swiper-horizontal {
    padding-bottom: 4.5rem;
  }
}

/* プログレスバーの位置を下に移動 */
.swiper-horizontal > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal {
  bottom: 0;
  top: auto;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 12.5rem;
}
@media screen and (min-width: 768px) {
  .swiper-horizontal > .swiper-pagination-progressbar,
  .swiper-pagination-progressbar.swiper-pagination-horizontal {
    width: 25rem;
  }
}

/* プログレスバーの高さ変更 */
.swiper-horizontal > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal {
  height: 0.125rem;
}

/* プログレスバーの背景色変更 */
.swiper-pagination-progressbar {
  background-color: #ffffff;
}

/* プログレスバーの色変更 */
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background-color: #9f28fb;
}

.p-about {
  position: relative;
  margin-top: -6.1875rem;
  padding-top: 6.8125rem;
}
@media screen and (min-width: 768px) {
  .p-about {
    margin-top: -15rem;
    padding-top: 15.625rem;
  }
}
.p-about::before {
  content: "";
  position: absolute;
  background: -webkit-gradient(linear, left bottom, left top, color-stop(14.58%, #222), color-stop(84.9%, rgba(34, 34, 34, 0)));
  background: linear-gradient(0deg, #222 14.58%, rgba(34, 34, 34, 0) 84.9%);
  width: 100%;
  height: 6.8125rem;
  top: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  .p-about::before {
    height: 15.625rem;
  }
}

.p-about__inner {
  padding-top: 5.125rem;
  padding-bottom: 5rem;
  padding-left: 2.4375rem;
  padding-right: 2.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.0625rem;
}
@media screen and (min-width: 900px) {
  .p-about__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 2.5rem;
    padding-top: 7.9375rem;
    padding-bottom: 11.6875rem;
  }
}
@media screen and (min-width: 1200px) {
  .p-about__inner {
    gap: 6.375rem;
    padding-left: 4.625rem;
    padding-right: 4.0625rem;
  }
}

.p-about__title {
  width: 11.25rem;
  height: auto;
}
@media screen and (min-width: 768px) {
  .p-about__title {
    width: clamp(17.8125rem, 24.0295138889vw, 21.6265625rem);
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}
@media screen and (min-width: 1200px) {
  .p-about__title {
    width: 21.6265625rem;
  }
}

.p-about__text {
  color: #ebebeb;
  font-weight: 700;
  line-height: 195%;
  font-size: 0.875rem;
}
@media screen and (min-width: 900px) {
  .p-about__text {
    margin-top: 15.125rem;
    font-size: 1.125rem;
    line-height: 210%;
  }
}
.p-about__text + .p-about__text {
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-about__text + .p-about__text {
    margin-top: 1.1875rem;
  }
}

.p-works {
  padding-bottom: 4.1875rem;
}
@media screen and (min-width: 768px) {
  .p-works {
    padding-bottom: 9rem;
  }
}

.p-works__title {
  margin: 0 auto;
  width: 5.3125rem;
  height: 1.3125rem;
}
@media screen and (min-width: 768px) {
  .p-works__title {
    width: 6.125rem;
    height: 1.5rem;
  }
}

.p-works__title-en {
  display: block;
}

.p-works__title-ja {
  display: block;
  margin-top: 0.625rem;
  font-size: 0.75rem;
  text-align: center;
  color: #ebebeb;
  font-weight: 700;
  line-height: 0.9375rem;
}
@media screen and (min-width: 768px) {
  .p-works__title-ja {
    margin-top: 0.8125rem;
    font-size: 0.875rem;
  }
}

.sp-filter {
  overflow: hidden;
  margin-top: 5rem;
}
@media screen and (min-width: 768px) {
  .sp-filter {
    display: none;
  }
}

.sp-list,
.sp-list__detail {
  padding-top: 5.25rem;
  padding-bottom: 5.25rem;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 60;
  background: rgba(34, 34, 34, 0.9);
  -webkit-transform: translateX(120%);
          transform: translateX(120%);
  -webkit-transition: -webkit-transform 0.5s ease-in-out;
  transition: -webkit-transform 0.5s ease-in-out;
  transition: transform 0.5s ease-in-out;
  transition: transform 0.5s ease-in-out, -webkit-transform 0.5s ease-in-out;
}
.sp-list.is-checked,
.sp-list__detail.is-checked {
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

.sp-list-button {
  position: absolute;
  top: 1.25rem;
  right: 1.6875rem;
  width: 2.5rem;
}

.sp-list li.is-active {
  border-color: transparent;
}
.sp-list li.is-active[data-filter=all] {
  background: #9f28fb;
}
.sp-list li.is-active[data-filter=cat1] {
  background: #ef6bab;
}
.sp-list li.is-active[data-filter=cat2] {
  background: #569bff;
}
.sp-list li.is-active[data-filter=cat3] {
  background: #21be69;
}
.sp-list li.is-active[data-filter=cat4] {
  background: #ee933e;
}

.sp-tag {
  margin-left: auto;
  margin-right: auto;
}
.sp-tag + .sp-tag {
  margin-top: 2rem;
}

.sp-list__detail {
  padding: 7.5rem 1.4375rem 12.5rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
}

.sp-fileter__button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1.25rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}

.card-hidden {
  display: none;
}
@media screen and (min-width: 768px) {
  .card-hidden {
    display: block;
  }
}

.filter-pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .filter-pc {
    display: block;
    margin-top: 6.25rem;
  }
}

.filter-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1.25rem;
}

.filter-list li {
  background: transparent;
  border: 0.0625rem solid #ebebeb;
  cursor: pointer;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.filter-list li:hover {
  opacity: 0.7;
}

.filter-list li span {
  font-size: 1rem;
  font-weight: 700;
  line-height: 0.875rem;
}

.filter-list li.is-active {
  border-color: transparent;
}
.filter-list li.is-active[data-filter=all] {
  background: #9f28fb;
}
.filter-list li.is-active[data-filter=cat1] {
  background: #ef6bab;
}
.filter-list li.is-active[data-filter=cat2] {
  background: #569bff;
}
.filter-list li.is-active[data-filter=cat3] {
  background: #21be69;
}
.filter-list li.is-active[data-filter=cat4] {
  background: #ee933e;
}

.filter-list__middle li,
.filter-list__bottom li {
  padding: 0.8125rem 1.5625rem;
  margin-top: 1.5625rem;
}

.filter-list__middle li.is-active,
.filter-list__bottom li.is-active,
.detail-tag.is-active {
  border-color: transparent;
  background: #727272;
}

.filter-button {
  display: block;
  margin-top: 4.1875rem;
  margin-left: auto;
  margin-right: auto;
}

.filter-item {
  margin-top: 3.125rem;
  -webkit-column-count: 1;
     -moz-column-count: 1;
          column-count: 1;
  -webkit-column-gap: 1.25rem;
     -moz-column-gap: 1.25rem;
          column-gap: 1.25rem;
  margin-bottom: 2.8125rem;
}
@media screen and (min-width: 768px) {
  .filter-item {
    margin-top: 6rem;
    -webkit-column-count: 3;
       -moz-column-count: 3;
            column-count: 3;
    -webkit-column-gap: 2rem;
       -moz-column-gap: 2rem;
            column-gap: 2rem;
    width: 62.5rem;
    margin-inline: auto;
    margin-bottom: 9.0625rem;
    -webkit-column-width: 19.5rem;
       -moz-column-width: 19.5rem;
            column-width: 19.5rem;
  }
}

.filter-item li {
  margin-bottom: 1.6875rem;
  border: 0.125rem solid #fff;
  background: #eee;
  -webkit-column-break-inside: avoid;
     -moz-column-break-inside: avoid;
          break-inside: avoid;
  max-width: 19.5rem;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .filter-item li {
    max-width: 19.5rem;
    margin-inline: 0;
    margin-bottom: 2.0625rem;
    grid-template-columns: repeat(3, auto);
    -ah-column-rule-align: before;
  }
}

.p-works__button {
  display: block;
  margin-top: 1.0625rem;
  margin-inline: auto;
}

.p-course {
  background: url(../img/bg-about-gradation-sp.png), url(../img/bg-about-mark-sp.png), #ebebeb;
  background-size: cover, cover;
  background-position: center, center;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-course {
    background: url(../img/bg-about-gradation.png), url(../img/bg-about-mark.png), #ebebeb;
  }
}

.p-course__inner {
  padding-top: 3.125rem;
  padding-bottom: 4.25rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-course__inner {
    padding-top: 5.5rem;
    padding-bottom: 9.25rem;
  }
}

.p-course__title-sub {
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 165%;
}
@media screen and (min-width: 768px) {
  .p-course__title-sub {
    font-size: 0.9375rem;
    line-height: 0.9375rem;
  }
}

.p-course__title {
  margin-top: 0.625rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.75rem;
}
@media screen and (min-width: 768px) {
  .p-course__title {
    margin-top: 1.625rem;
    gap: 1.1875rem;
  }
}
.p-course__title img {
  width: 11.8125rem;
  height: 2.4375rem;
}
@media screen and (min-width: 768px) {
  .p-course__title img {
    width: 19.125rem;
    height: 3.9375rem;
  }
}

.p-course__title-text {
  font-size: 1rem;
  font-weight: 900;
  line-height: 165%;
  padding-top: 0.6875rem;
  margin-left: -0.3125rem;
}
@media screen and (min-width: 768px) {
  .p-course__title-text {
    font-size: 1.125rem;
    padding-top: 1.875rem;
  }
}

.p-course__text {
  margin-top: 1.375rem;
  font-weight: 700;
  line-height: 165%;
}
@media screen and (min-width: 768px) {
  .p-course__text {
    font-size: 1.125rem;
  }
}

.p-course__contents {
  margin-top: 2.25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.875rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 900px) {
  .p-course__contents {
    margin-top: 3.125rem;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 2.1875rem;
  }
}

.p-course__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center; /* 横方向は中央寄せ */
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 15rem;
  border-radius: 0.625rem;
  background: #fff;
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 165%;
}
@media screen and (min-width: 1200px) {
  .p-course__content {
    width: 16.25rem;
    font-size: 0.9375rem;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }
}

.p-course__menu {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-course__menu {
    margin-top: 5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 2.1875rem;
  }
}

@media screen and (min-width: 768px) {
  .p-course__menu-title {
    width: 8.4375rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    font-size: 0.9375rem;
    font-weight: 700;
    line-height: 210%;
    text-align: left;
    padding-top: 0.6875rem;
    border-top: 0.0625rem solid #6b6b6b;
  }
}

@media screen and (min-width: 768px) {
  .menu-standard,
  .menu-advance {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 2.25rem;
    width: 30rem;
    padding-top: 0.6875rem;
    border-top: 0.0625rem solid #6b6b6b;
    padding-bottom: 2.5rem;
  }
}

@media screen and (min-width: 768px) {
  .menu-standard__title,
  .menu-advance__title {
    font-size: 0.9375rem;
    font-weight: 700;
    line-height: 210%;
    width: 9rem;
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
    position: relative;
  }
  .menu-standard__title::before,
  .menu-advance__title::before {
    content: "";
    position: absolute;
    width: 0.375rem;
    height: 0.375rem;
    border-radius: 50%;
    background: #9f28fb;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    left: -0.125rem;
  }
}

@media screen and (min-width: 768px) {
  .menu-standard__courses,
  .menu-advance__courses {
    text-align: left;
    line-height: 1.9375rem;
  }
}

@media screen and (min-width: 768px) {
  .menu-standard__course,
  .menu-advance__course {
    padding-left: 0.75rem;
    position: relative;
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }
  .menu-standard__course::before,
  .menu-advance__course::before {
    content: "–";
    position: absolute;
    color: #9f28fb;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    left: 0;
  }
  .menu-standard__course:hover,
  .menu-advance__course:hover {
    opacity: 0.7;
    cursor: pointer;
  }
}

.p-course__button {
  margin-top: 3.5rem;
  margin-inline: auto;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .p-course__button {
    margin-top: 2rem;
  }
}

.p-footer__inner {
  color: #ffffff;
  padding-left: 2.0625rem;
  padding-right: 2.0625rem;
}
@media screen and (min-width: 768px) {
  .p-footer__inner {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
}

.p-footer__wrapper {
  padding-top: 3.125rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.6875rem;
}
@media screen and (min-width: 768px) {
  .p-footer__wrapper {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 0;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__top {
    margin-top: -0.6875rem;
  }
}

.p-footer__top__logo {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-footer__top__logo {
    width: 17.5rem;
  }
}

.p-footer__top__icons {
  margin-top: 1.875rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.5rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 768px) {
  .p-footer__top__icons {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: start;
    margin-top: 1.5625rem;
    gap: 1.4375rem;
  }
}
.p-footer__top__icons img {
  width: 2.75rem;
  height: 2.75rem;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
@media screen and (min-width: 768px) {
  .p-footer__top__icons img {
    width: 2.1875rem;
    height: 2.1875rem;
  }
}
.p-footer__top__icons img:hover {
  opacity: 0.7;
}

@media screen and (min-width: 768px) {
  .p-footer__bottom {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 0rem 4.25rem;
    -webkit-box-pack: left;
        -ms-flex-pack: left;
            justify-content: left;
    width: 29.625rem;
  }
}

.p-footer__bottom-ul {
  line-height: 0.875rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1.5rem 2rem;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-left: 0.1875rem;
  padding-right: 0.1875rem;
}
@media screen and (min-width: 600px) {
  .p-footer__bottom-ul {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    font-size: 0.75rem;
    max-width: 536px;
    padding: 0;
    gap: 1.5rem 1.375rem;
  }
}

.p-footer__bottom-li {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  font-size: 0.75rem;
}
@media screen and (min-width: 768px) {
  .p-footer__bottom-li {
    font-size: 0.875rem;
  }
}
.p-footer__bottom-li:hover {
  opacity: 0.7;
}

@media screen and (min-width: 768px) {
  .p-footer__bottom-ul {
    display: contents; /* ul要素自体を非表示にし、直接子要素を親要素の位置に配置 */
  }
}

/* リストアイテムの順番を変更 */
@media screen and (min-width: 768px) {
  .p-footer__bottom-li:nth-child(1) {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__bottom-li:nth-child(2) {
    -webkit-box-ordinal-group: 6;
        -ms-flex-order: 5;
            order: 5;
    margin-left: 2.6875rem;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__bottom-li:nth-child(3) {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__bottom-li:nth-child(4) {
    -webkit-box-ordinal-group: 5;
        -ms-flex-order: 4;
            order: 4;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__bottom-li:nth-child(5) {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
}

.p-footer__bottom-text {
  margin-top: 3.75rem;
  font-size: 0.75rem;
  line-height: 165%;
}
@media screen and (min-width: 768px) {
  .p-footer__bottom-text {
    margin-top: 2.625rem;
    font-size: 0.8125rem;
    width: 29.75rem;
    margin-left: auto;
  }
}

.p-footer__copyright {
  margin-top: 1.5625rem;
  display: block;
  color: #ffffff;
  font-size: 0.8125rem;
  text-align: center;
  padding-bottom: 2.625rem;
  line-height: 0.875rem;
}
@media screen and (min-width: 768px) {
  .p-footer__copyright {
    margin-top: 2.3125rem;
  }
}

.u-hidden-pc {
  display: inline-block;
  font-weight: 700;
}
@media screen and (min-width: 900px) {
  .u-hidden-pc {
    display: none;
  }
}

.u-hidden-sp {
  display: none;
}
@media screen and (min-width: 900px) {
  .u-hidden-sp {
    display: inline-block;
    font-weight: 700;
  }
}