@charset "utf-8";
html {
	scroll-behavior: smooth;
}

.invisible-style{
  display: none!important;
}

body{
  font-family: 游明朝体, "Yu Mincho", YuMincho serif;
  color: #191919;
  font-size: clamp(0.875rem, 0.792rem + 0.17vw, 1rem);
  line-height: 1.7;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

a {
  text-decoration: none;
  cursor: pointer;
  color: #191919;
}

a:hover {
  text-decoration: none;
  transition: all 0.5s;
}
.link-opacity:hover {
  opacity: 0.5;
}


img {
  max-width: 100%;
  display: block;
  width: 100%;
}

p,
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

u {
  text-decoration: none;
  display: inline-block;
}
strong {
  font-weight: unset;
  display: inline-block;
}


/* 共通パーツ */
.inner {
  max-width: 1920px;
  margin: 0 auto;
}

/* pg-fv */
.pg-fv__inner {
    height: inherit;
}
.pg-fv__container {
    padding-top: 74px;
    background-image: url(https://my-revolution.com/system_panel/uploads/images/pg-fv-bg.png);
    background-size: cover;
    background-position: top left;
    height: clamp(11.25rem, 7.917rem + 6.94vw, 16.25rem);
        position: absolute;
    width: 100%;
    max-width: 1920px;
    top: 0;
}
.pg-fv_title {
      display: flex;
    flex-direction: column;
    align-items: center;
    width: fit-content;
    row-gap: clamp(0.5rem, 0.167rem + 0.69vw, 1rem);
}
.pg-fv-title__sub {
      height: clamp(1.25rem, 0.708rem + 1.13vw, 2.063rem);
    width: auto!important;
}
.pg-fv-title__main {
      line-height: 1;
    font-weight: 600;
    color: #C11B64;
    font-size: clamp(1.75rem, 0.917rem + 1.74vw, 3rem);
}
@media (max-width: 767px) {
  .pg-fv__container {
        background-image: url(https://my-revolution.com/system_panel/uploads/images/pg-fv-bg-sp.png);
    background-size: 100%;
    background-repeat: no-repeat;
    display: flex;
    justify-content: center;
    height: clamp(4.375rem, 0.496rem + 15.92vw, 8.125rem);
  }
  .pg-fv-title__sub {
    height: clamp(0.875rem, -0.03rem + 3.71vw, 1.75rem);
  }
  .pg-fv-title__main {
    font-size: clamp(1.25rem, 0.474rem + 3.18vw, 2rem);
  }
}

/* btn__1 */
.btn__1 {
      display: flex;
    column-gap: 16px;
    align-items: center;
    background-color: #C11B64;
    border-radius: 10px;
    padding: 15px 24px;
   width: fit-content;
  transition: all 0.5s;
}
.btn__2 {
  background-color: #DE5E85;
}
.btn__icon {
      width: clamp(1.5rem, 1.25rem + 0.52vw, 1.875rem);
    height: clamp(1.5rem, 1.25rem + 0.52vw, 1.875rem);
}
.btn__text {
      color: #fff;
    font-weight: 700;
    font-family: "遊ゴシック",sans-serif;
}
.btn__1:hover {
  background-color: #DE5E85;
}
.btn__2:hover {
  background-color: #E288A3;
}


.title1 {
      display: flex;
    flex-direction: column;
    align-items: center;
    row-gap: clamp(1.125rem, 0.875rem + 0.52vw, 1.5rem);
    width: fit-content;
}
.title1__text {
      font-size: clamp(1.75rem, 1.25rem + 1.04vw, 2.5rem);
    font-weight: 600;
    color: #DE5E85;
    line-height: 1;
}
.title1__line {
      border-left: 1px solid #DE5E85;
    height: clamp(1.25rem, 0.833rem + 0.87vw, 1.875rem);
    transform: rotate(45deg);
}

/* cta */
.cta {
      padding-top: 40px;
    padding-bottom: 100px;
}
.cta__inner {
  padding: 0 clamp(1rem, -17.333rem + 38.19vw, 28.5rem);
  padding-right: clamp(8.125rem, -5.458rem + 28.3vw, 28.5rem);
}
.cta__container {
  position: relative;
}
.cta__content {
      position: relative;
    height: clamp(23.75rem, 14.583rem + 19.1vw, 37.5rem);
}
.cta-right__content {
      position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    row-gap: clamp(0.625rem, 0.375rem + 0.52vw, 1rem);
    right: 10%;
    top: 22%;
    z-index: 1;
}

.cta__title {
      position: absolute;
        display: flex;
    flex-direction: column;
    align-items: center;
    right: 6%;
}
.cta-title__sub {
      font-size: 16px;
    font-weight: 500;
    color: #C11B64;
}
.cta-title__main {
  width: clamp(10.625rem, 6.708rem + 8.16vw, 16.5rem);
}
.cta__left {
      position: absolute;
    width: 64%;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}
.cta__right {
      position: absolute;
    width: 64%;
    right: 0;
    bottom: 0;
}
.contact-text__box {
    display: flex;
    flex-direction: column;
    align-items: center;
    row-gap: 16px;
    white-space: nowrap;
}
.contact-text__sub {
      font-size: clamp(1rem, 0.833rem + 0.35vw, 1.25rem);
    font-weight: 500;
    font-family: "遊ゴシック",sans-serif;
    line-height: 1;
}
.contact-text__sub span {
  font-weight: 700;
}
.contact-text-sub__icon {
  width: 131px;
}
.contact-text__box--2 {
      right: unset;
    top: 25px;
    left: clamp(0rem, -6.667rem + 13.89vw, 10rem);
}
.contact-text__sub--2 {
  text-align: center;
}
.cta__img {
  width: clamp(10.625rem, 6.667rem + 8.25vw, 16.563rem);
}
.school__title {
      position: absolute;
    width: fit-content;
    top: -50%;
}
.school-title__bg {
    width: clamp(12.5rem, 8.333rem + 8.68vw, 18.75rem);
    height: auto;
    aspect-ratio: 1/1;
    object-fit: cover;
}
.school-title__content {
      position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.school-title___icon {
  width: clamp(5.875rem, 3.208rem + 5.56vw, 9.875rem);
}
.school-title__text {
      font-size: clamp(1.438rem, 0.729rem + 1.48vw, 2.5rem);
    white-space: nowrap;
    text-align: center;
    color: #fff;
    font-weight: 600;
}
.contact-center__text1 {
      font-size: clamp(1rem, 0.583rem + 0.87vw, 1.625rem);
    font-family: "遊ゴシック",sans-serif;
    font-weight: 700;
    letter-spacing: 0.12em;
    padding-bottom: 32px;
  text-align: center;
}
.contact-center__text1 span {
  font-size: clamp(1.5rem, 0.833rem + 1.39vw, 2.5rem);
}
.btn__text {
  font-size: clamp(0.75rem, 0.375rem + 0.78vw, 1.313rem);
}
.btn__icon {
      width: clamp(1.5rem, 0.833rem + 1.39vw, 2.5rem);
    height: clamp(1.5rem, 0.833rem + 1.39vw, 2.5rem);
}
.contact-center__text2 {
      margin-top: 16px;
    font-weight: 500;
    color: #919191;
    text-decoration: underline;
}
.school-title___icon--2 {
  width: clamp(6.625rem, 4.708rem + 3.99vw, 9.5rem);
}
.school-title__text--black {
      margin-top: 6px;
    font-size: clamp(1.375rem, 0.958rem + 0.87vw, 2rem);
    color: #191919;
}
.cta__right--sp,
.cta__left--sp{
  display: none;
}
.cta-right__content--2 {
      left: 10%;
    right: unset;
    top: 12%;
}

.insta__img {
        position: absolute;
    width: clamp(10rem, 7.833rem + 4.51vw, 13.25rem);
    z-index: 1;
    left: 94%;
    bottom: clamp(0.625rem, -1.042rem + 3.47vw, 3.125rem);
    transition: all 0.5s;
}
.insta__img:hover {
  opacity: 0.7;
}
@media (max-width: 767px) {
  .cta__inner {
    padding-right: 13px;
  }
  .cta__container {
    padding-bottom: 60px;
  }
  .insta__img {
        left: 50%;
    transform: translateX(-50%);
    bottom: 0;
    width: 250px;
  }
  .cta__content {
    height: 796px;
  }
  .cta-right__content {
        right: 50%;
    transform: translateX(50%);
    top: 129px;
    width: max-content;
  }
  .cta__title {
        right: 50%;
    transform: translateX(50%);
  }
  .cta-title__main {
    width: 211px;
  }
  .cta__left {
    display: none;
  }
  .cta__right {
    display: none;
  }
  .cta__right--sp {
    display: block;
        position: absolute;
    width: 356px;
    top: 80px;
    left: 50%;
    transform: translateX(-50%);
  }
  .cta__left--sp {
    display: block;
        position: absolute;
    width: 356px;
    top: 370px;
    left: 50%;
    transform: translateX(-50%);
  }
  .cta__img {
    width: 218px;
  }
  
  .cta-right__content--2 {
        left: 50%;
    right: unset;
    transform: translateX(-50%);
  }
}

/* よくあるご質問　*/
.fq__title {
      font-size: clamp(1.625rem, 1.458rem + 0.35vw, 1.875rem);
    font-weight: 600;
    color: #C11B64;
}
.fq__items {
      margin-top: clamp(1rem, 0.667rem + 0.69vw, 1.5rem);
    display: flex;
    flex-direction: column;
    row-gap: 10px;
}

.f-accordion {
    background-color: #FBD6E8;
    border-radius: 10px;
}
.f-accordion-content {
  display: none;
  position: relative;
}
.f-accordion-header {
  padding: 16px clamp(1.563rem, -2.271rem + 7.99vw, 7.313rem);
    transition: background .3s ease;
    cursor: pointer;
    position: relative;
}
.f-accordion-header__text{
  position: relative;
  padding-right: 30px;
        font-size: clamp(1rem, 0.833rem + 0.35vw, 1.25rem);
    font-weight: 600;
    color: #C11B64;
}
.f-accordion-header__text::before,
.f-accordion-header__text::after {
        position: absolute;
    content: '';
    top: 1px;
    right: 0;
    bottom: 0;
    width: clamp(1rem, 0.833rem + 0.35vw, 1.25rem);
    height: 2px;
    margin: auto;
    background: #C11B64;
}
.f-accordion-header__text::after {
  transform:rotate(-90deg);
  transition:transform 0.3s;
}
.f-accordion-header.active .f-accordion-header__text::after{
  transform:rotate(0deg);
}
.f-accordion-content p{
  position: relative;
    font-weight: 500;
  font-family: "遊ゴシック",sans-serif;
  padding-bottom: 20px;
}
@media (max-width: 767px) {
  .fq__title {
    text-align: center;
  }
}

/* all__btn */
.all__btn {
      width: 120px;
    display: flex;
    justify-content: center;
    font-size: 22px;
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    color: #C11B64;
    padding-bottom: 8px;
    border-bottom: 1px solid #191919;
    transition: all 0.5s;
}
.all__btn:hover {
  border-bottom: 1px solid #C11B64;
}

/* anime */
.anime2 {
  animation-delay: 0.5s;
}
.anime3 {
  animation-delay: 1s;
}
.anime4 {
  animation-delay: 1.5s;
}
.anime5 {
  animation-delay: 2s;
}
.anime6 {
  animation-delay: 2.5s;
}