body {
    font-family: "Noto Sans JP", sans-serif;
}

.u-desktop {
    display: none;
}

/* リキッドレイアウト対応 */

html {
    font-size: 16px;
}

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

/* Remove default padding */

ul,
ol {
    padding: 0;
}

/* Remove default margin */

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

/* Set core root defaults */

html {
    scroll-behavior: smooth;
}

/* Set core body defaults */

body {
    line-height: 1.5;
    min-height: 100vh;
    text-rendering: optimizeLegibility;
}

/* Remove list styles on ul, ol elements with a class attribute */

ul,
ol {
    list-style: none;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
    -webkit-text-decoration-skip: ink;
    text-decoration-skip-ink: auto;
}

/* Make images easier to work with */

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

/* Natural flow and rhythm in articles by default */

article>*+* {
    margin-top: 1em;
}

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
    font: inherit;
}

/* Blur images when they have no alt attribute */

img:not([alt]) {
    filter: blur(10px);
}

/* フォームリセット */

input,
button,
select,
textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background: transparent;
    border: none;
    border-radius: 0;
    font: inherit;
    outline: none;
}

textarea {
    resize: vertical;
}

input[type=checkbox],
input[type=radio] {
    display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
    cursor: pointer;
}

select::-ms-expand {
    display: none;
}

/* ホバー */

a {
    -webkit-text-decoration: none;
    color: inherit;
    text-decoration: none;
    transition: opacity 0.3s;
}

.about {
    background-image: url("../images/mv/mv-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    position: relative;
    z-index: 1;
}

.about__inner {
    padding: 3.125rem 1.25rem 3.125rem;
}

.about__heading {
    background-image: url("../images/about/about-heading-bg_sp.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: 100% 100%;
    margin-left: auto;
    margin-right: auto;
    max-width: 20rem;
    padding: 1.726875rem 1.71875rem 2.720625rem 1.779375rem;
    position: relative;
    text-align: center;
    z-index: 1;
}

.about__catch {
    display: inline-block;
}

.about__catch img {
    -o-object-fit: contain;
    aspect-ratio: 242/14;
    height: auto;
    max-width: 15.125rem;
    object-fit: contain;
    width: 100%;
}

.about__title {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 160%;
    text-align: center;
}

.about__title span {
    font-size: 1.25rem;
}

.about__img {
    margin-top: -2rem;
    position: relative;
}

.about__img img {
    -o-object-fit: contain;
    aspect-ratio: 335/150;
    border-radius: 0.625rem;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.about__subtitle {
    margin-top: 1.875rem;
}

.about__subtitle img {
    -o-object-fit: contain;
    aspect-ratio: 355/90;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    object-fit: contain;
    width: 100%;
}

.about__lead {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    line-height: 170%;
    margin-top: 1.25rem;
    text-align: center;
}

.about__list {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    margin-top: 1.875rem;
}

.about__item {
    aspect-ratio: 1/1;
    background-image: url("../images/about/about-item-bg.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: 100% 100%;
    max-width: 18.75rem;
    padding: 3.75rem 1.59375rem 4.1875rem;
    text-align: center;
    width: 100%;
}

.about__item-title {
    color: #ffffff;
    display: inline-block;
    font-family: "Darumadrop One", cursive;
    font-size: 2rem;
    font-weight: 300;
    letter-spacing: 0.01em;
    line-height: 100%;
}

.about__item-icon {
    margin-top: 0.9375rem;
}

.about__item-icon img {
    -o-object-fit: contain;
    aspect-ratio: 69/50;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    max-width: 4.3125rem;
    object-fit: contain;
    width: 100%;
}

.about__item-text {
    color: #ffffff;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 170%;
    margin-top: 0.625rem;
}

.about__text {
    margin-left: auto;
    margin-right: auto;
    margin-top: 3rem;
    max-width: 20.9375rem;
}

.about__text span {
    border-bottom: 1px dashed #F48D33;
    color: #222222;
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 250%;
    text-align: center;
}

.about__text span:last-child {
    border-bottom: none;
}

.about__bg-deco-top {
    position: relative;
    top: -0.078125rem;
}

.about__bg-deco-bottom {
    position: relative;
    top: 0.078125rem;
}

.btn-cta {
    background: linear-gradient(90deg, #F89A1E 0%, #EE7615 100%);
    border-radius: 3.125rem;
    color: #ffffff;
    display: inline-block;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 0.9375rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
    padding: 0.625rem 5rem 0.625rem 1.875rem;
    position: relative;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.btn-cta:hover {
    box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.2);
    transform: scale(1.05);
}

.btn-cta:hover::after {
    right: 2.125rem;
}

.btn-cta::after {
    background-image: url("../images/common/icon-arrow-orange.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 0.75rem;
    position: absolute;
    right: 2.25rem;
    top: 50%;
    transform: translateY(-50%);
    transition: right 0.3s ease;
    width: 0.6875rem;
    z-index: 2;
}

.btn-cta::before {
    background-image: url("../images/wakuwaku/wakuwaku-btn-arrow-bg.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 1.5rem;
    position: absolute;
    right: 1.875rem;
    top: 50%;
    transform: translateY(-50%);
    width: 1.5rem;
    z-index: 1;
}

.btn-mail {
    background: #1E9E6F;
    border-radius: 4.0625rem;
    color: #ffffff;
    display: inline-block;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 0.9375rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
    padding: 0.5rem 1.25rem 0.5rem 2.75rem;
    position: relative;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.btn-mail:hover {
    box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.2);
    transform: scale(1.05);
}

.btn-mail::before {
    background-image: url("../images/common/icon-mail.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 0.75rem;
    left: 1.25rem;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 1rem;
    z-index: 1;
}

.faq {
    background-image: url("../images/point/point-02-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    overflow: hidden;
    position: relative;
}

.faq::before {
    background-image: url("../images/faq/faq-bg-cercle_sp.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 23.4375rem;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    width: 23.4375rem;
    z-index: 1;
}

.faq::after {
    background-image: url("../images/faq/faq-bg-leaves.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 4.5625rem;
    pointer-events: none;
    position: absolute;
    right: 1.875rem;
    top: 1.875rem;
    width: 6.5rem;
    z-index: 2;
}

.faq__inner {
    margin-left: auto;
    margin-right: auto;
    max-width: 32.5rem;
    padding: 3.125rem 1.25rem 1.25rem;
    position: relative;
    z-index: 3;
}

.faq__title {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 160%;
    white-space: nowrap;
}

.faq__list {
    margin-top: 1.875rem;
}

.faq__item {
    background-color: #ffffff;
    border-radius: 0.625rem;
    padding: 0.9375rem;
}

.faq__item+.faq__item {
    margin-top: 1.25rem;
}

.faq__item-title {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.9375rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 180%;
    padding-left: 2.1875rem;
    position: relative;
}

.faq__item-title::before {
    background-image: url("../images/faq/faq-question.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 1.5625rem;
    left: 0;
    position: absolute;
    top: 0.125rem;
    width: 1.5625rem;
}

.faq__item-text {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.75rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 180%;
    margin-top: 0.625rem;
    padding-left: 2.1875rem;
    position: relative;
}

.faq__item-text::before {
    background-image: url("../images/faq/faq-answer.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 1.5625rem;
    left: 0;
    position: absolute;
    top: 0.125rem;
    width: 1.5625rem;
}

.faq__photo-list-img {
    -o-object-fit: contain;
    aspect-ratio: 375/260;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.features {
    background-image: url("../images/mv/mv-bg_sp.jpg");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    overflow: hidden;
    position: relative;
    z-index: 1;
}

.features__img1 {
    aspect-ratio: 90/140;
    height: auto;
    left: 0;
    max-width: 5.625rem;
    position: absolute;
    top: 6.75rem;
    width: 100%;
    z-index: 0;
}

.features__img2 {
    aspect-ratio: 120/161;
    bottom: 4rem;
    height: auto;
    max-width: 7.5rem;
    position: absolute;
    right: 0;
    width: 100%;
    z-index: 0;
}

.features__inner.inner {
    padding: 3.125rem 1.25rem 6rem;
}

.features__title {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.125rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 170%;
    text-align: center;
}

.features__title span {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
    text-align: center;
}

.features__title span .orange {
    color: #F48D33;
    display: inline-block;
    font-size: 1.5rem;
}

.features__title .small {
    font-size: 1.5rem;
}

.features__list {
    background-image: url("../images/features/features-list-bg_sp.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 2.25rem;
    padding: 1.875rem 1.25rem;
}

.features__item {
    border-bottom: 1px dashed #F48D33;
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 170%;
    padding: 0.625rem 0.3125rem 0.625rem 1.875rem;
    position: relative;
}

.features__item:first-child {
    border-top: 1px dashed #F48D33;
}

.features__item::before {
    background-image: url("../images/features/features-list-disc.png");
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 0.9375rem;
    left: 0.375rem;
    position: absolute;
    top: 0.75rem;
    width: 0.9375rem;
}

.features__bg-deco {
    position: relative;
    top: 0.078125rem;
}

.fixed-cta {
    bottom: 0;
    display: flex;
    flex-direction: row-reverse;
    left: 0;
    position: fixed;
    width: 100vw;
    z-index: 100;
}

.fixed-cta__btn {
    border-radius: 0.625rem 0.625rem 0 0;
    display: inline-block;
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    width: 50%;
}

.fixed-cta__btn:hover {
    box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.2);
    transform: scale(1.05);
}

.fixed-cta__btn--tel {
    background-color: #ffffff;
    border: 2px solid #F48D33;
    color: #F48D33;
    font-size: 1.25rem;
    padding: 0.25rem 0.625rem 0.625rem 0.625rem;
}

.fixed-cta__btn--tel .fixed-cta__text::before {
    background-image: url("../images/common/icon-tel.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    display: inline-block;
    height: 0.9375rem;
    margin-right: 0.3125rem;
    vertical-align: baseline;
    width: 0.9375rem;
}

.fixed-cta__text {
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 100%;
}

.fixed-cta__time {
    display: block;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    letter-spacing: 0.05em;
    line-height: 100%;
    line-height: 100%;
}

.fixed-cta__btn--mail {
    background-color: #1E9E6F;
    color: #ffffff;
    font-size: 1rem;
    padding: 0.625rem 0.3125rem 0.625rem 0.3125rem;
}

.fixed-cta__btn--mail .fixed-cta__text::before {
    background-image: url("../images/common/icon-mail.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    display: inline-block;
    height: 0.75rem;
    margin-right: 0.3125rem;
    vertical-align: baseline;
    width: 1rem;
}

.footer {
    background-image: url("../images/wakuwaku/wakuwaku-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    position: relative;
}

.footer__inner.inner {
    padding: 1.25rem 1.25rem 0;
}

.footer__heading {
    align-items: flex-end;
    display: flex;
    gap: 0.9375rem;
    justify-content: center;
}

.footer__logo {
    display: inline-block;
    transition: transform 0.3s ease;
}

.footer__logo:hover {
    transform: scale(1.1);
}

.footer__logo img {
    -o-object-fit: contain;
    aspect-ratio: 115/88;
    height: 100%;
    max-width: 7.1875rem;
    object-fit: contain;
    width: 100%;
}

.footer__title-sub {
    color: #ffffff;
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 120%;
}

.footer__title-main {
    color: #ffffff;
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.625rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 120%;
    margin-top: 0.3125rem;
}

.footer__info {
    margin-top: 0.9375rem;
}

.footer__info-text {
    color: #ffffff;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 170%;
    margin-top: 0.9375rem;
    text-align: center;
}

.footer__info-tel {
    align-items: center;
    color: #ffffff;
    display: inline-flex;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 100%;
}

.footer__info-tel::before {
    background-image: url("../images/footer/footer-icon-tel.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    display: inline-block;
    height: 1.5rem;
    margin-right: 0.25rem;
    width: 1.5rem;
    z-index: 1;
}

.footer__info-tel:hover {
    cursor: pointer;
}

.footer__info-time {
    color: #ffffff;
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 170%;
    text-align: center;
}

.footer__right {
    margin-top: 2.5rem;
}

.footer__sns-text {
    color: #ffffff;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
    text-align: center;
}

.footer__sns-list {
    display: flex;
    gap: 0.9375rem;
    justify-content: center;
    margin-top: 0.625rem;
}

.footer__sns-link {
    border-radius: 0.625rem;
    display: block;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.footer__sns-link:hover {
    box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.2);
    transform: scale(1.05);
}

.footer__sns-link img {
    -o-object-fit: contain;
    aspect-ratio: 160/108;
    border-radius: 0.625rem;
    height: 100%;
    max-width: 10rem;
    object-fit: contain;
    width: 100%;
}

.footer__copy.inner {
    padding: 1.25rem 2rem 4.375rem;
}

.footer__copy-text {
    color: #ffffff;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.625rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 170%;
    text-align: center;
}

.inner {
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
    width: 100%;
}

.mv {
    aspect-ratio: 375/994;
    background-image: url("../images/mv/mv-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    height: 100%;
    max-height: 103.125rem;
    overflow: hidden;
    position: relative;
    width: 100%;
}

.mv::before {
    -o-object-fit: contain;
    aspect-ratio: 1/1;
    background-image: url("../images/mv/mv-bg-circle_pc.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: auto;
    object-fit: contain;
    pointer-events: none;
    position: absolute;
    right: -2.875rem;
    top: -1.5rem;
    width: 70%;
    z-index: 1;
}

.mv__logo {
    left: 1.25rem;
    position: absolute;
    top: 1.25rem;
    z-index: 30;
}

.mv__logo a {
    display: block;
    transition: transform 0.3s ease;
}

.mv__logo a:hover {
    transform: scale(1.1);
}

.mv__logo a img {
    -o-object-fit: contain;
    aspect-ratio: 105/80;
    height: auto;
    max-width: 6.5625rem;
    object-fit: contain;
    width: 100%;
}

.mv__bg {
    position: relative;
    right: 0rem;
    top: 0;
    z-index: 10;
}

.mv__bg img {
    -o-object-fit: contain;
    aspect-ratio: 375/640;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.mv__bg::after {
    -o-object-fit: contain;
    aspect-ratio: 309/368;
    background-image: url("../images/mv/mv-bg-circle-bottom_sp.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: -1.25rem;
    content: "";
    height: auto;
    object-fit: contain;
    pointer-events: none;
    position: absolute;
    right: 0;
    width: 82.4%;
    z-index: -1;
}

.mv__catch {
    align-items: flex-start;
    display: flex;
    flex-direction: row;
    gap: 0.3125rem;
    position: absolute;
    right: 1.25rem;
    top: 6.25rem;
    z-index: 20;
}

.mv__catch-left,
.mv__catch-right {
    background-image: url("../images/mv/mv-text-bg.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: 100% 100%;
    color: #ffffff;
    font-size: 1.75rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 115%;
    padding: 1.625rem 0.5rem;
    text-orientation: mixed;
    text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.3);
    writing-mode: vertical-rl;
}

.mv__catch-left {
    margin-top: 1.25rem;
}

.mv__cards {
    align-items: center;
    bottom: 1.5%;
    display: flex;
    flex-direction: column;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: calc(100% - 3.125rem);
    z-index: 20;
}

.mv__card {
    background-color: #ffffff;
    border-radius: 0.3125rem;
    box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.1);
    display: block;
    max-width: 25rem;
    position: relative;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    width: 100%;
}

.mv__card--main {
    aspect-ratio: 335/150;
    margin-top: 1.25rem;
    transform: rotate(5deg);
    z-index: 2;
}

.mv__card--main:hover {
    box-shadow: 0 0.5rem 1.5625rem rgba(0, 0, 0, 0.2);
    transform: rotate(0deg) scale(1.05);
    z-index: 3;
}

.mv__card--cta {
    aspect-ratio: 335/170;
    transform: rotate(-5deg);
    z-index: 1;
}

.mv__card--cta:hover {
    box-shadow: 0 0.5rem 1.5625rem rgba(0, 0, 0, 0.2);
    transform: rotate(0deg) scale(1.05);
    z-index: 3;
}

.mv__card-inner {
    padding: 0.625rem;
}

.mv__badge {
    display: inline-block;
    left: -1.25rem;
    position: absolute;
    top: -1.25rem;
    z-index: 10;
}

.mv__badge img {
    -o-object-fit: contain;
    aspect-ratio: 1/1;
    height: auto;
    max-width: 5rem;
    object-fit: contain;
    width: 100%;
}

.mv__card-heading {
    align-items: center;
    display: flex;
    gap: 0.75rem;
    justify-content: center;
}

.mv__card-img {
    width: 48.5%;
}

.mv__card-img img {
    -o-object-fit: contain;
    border-radius: 0.3125rem;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.mv__card--main .mv__card-img img {
    aspect-ratio: 158/101;
}

.mv__card--cta .mv__card-img img {
    aspect-ratio: 158/101;
}

.mv__card-heading-body {
    text-align: left;
    width: 49%;
}

.mv__card-label {
    color: #F48D33;
    display: inline-block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.625rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 130%;
    margin-bottom: 0.125rem;
    position: relative;
}

.mv__card-label::after {
    background-image: url("../images/mv/mv-card-label-deco.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 1.5625rem;
    position: absolute;
    right: -1.25rem;
    top: 0;
    width: 0.96875rem;
    z-index: 2;
}

.mv__card-title {
    color: #F48D33;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 130%;
}

.mv__card-title span {
    font-size: 1.375rem;
}

.mv__card-title .small {
    font-size: 0.875rem;
}

.mv__card-body {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-top: 0.25rem;
    text-align: center;
}

.mv__card-text {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 170%;
    max-width: 13.75rem;
    text-align: left;
}

.mv__card-btn.u-mobile {
    align-items: center;
    border-radius: 50%;
    display: flex;
    height: 2.5rem;
    justify-content: center;
    position: relative;
    width: 2.5rem;
}

.mv__card--cta .mv__card-btn.u-mobile {
    margin-right: 1.625rem;
}

.mv__card--main .mv__card-btn.u-mobile::before {
    background-image: url("../images/common/icon-cta.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 2.5rem;
    left: 0;
    position: absolute;
    top: 0;
    width: 2.5rem;
    z-index: 1;
}

.mv__card--main .mv__card-btn.u-mobile::after {
    background-image: url("../images/common/icon-arrow-white.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 0.875rem;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 1.1875rem;
    z-index: 2;
}

.mv__card--cta .mv__card-btn.u-mobile {
    background: #1E9E6F;
}

.mv__card--cta .mv__card-btn.u-mobile::after {
    background-image: url("../images/common/icon-mail.svg");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 0.75rem;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 1rem;
}

.mv__card-btn.btn-cta {
    display: none;
}

.mv__card-btn.btn-mail {
    display: none;
}

.mv__card-heading-title {
    color: #1E9E6F;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 130%;
}

.mv__card-heading-title span {
    font-size: 1.375rem;
}

.point-01 {
    background-image: url("../images/mv/mv-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    position: relative;
    z-index: 1;
}

.point-01 .point__inner {
    margin-left: auto;
    margin-right: auto;
    max-width: 38.75rem;
    padding: 3.125rem 1.25rem 3.125rem;
    position: relative;
}

.point__inner {
    margin-left: auto;
    margin-right: auto;
    max-width: 32.5rem;
    padding: 3.125rem 1.25rem 3.125rem;
}

.point__heading {
    text-align: center;
}

.point__label {
    color: #F48D33;
    display: inline-block;
    font-family: "Darumadrop One", cursive;
    font-size: 3rem;
    font-weight: 300;
    line-height: 100%;
}

.point__icon {
    margin-top: 1.25rem;
}

.point__icon img {
    -o-object-fit: contain;
    aspect-ratio: 160/120;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    max-width: 10rem;
    object-fit: contain;
    width: 100%;
}

.point__catch {
    background-color: #F48D33;
    border-radius: 0.625rem;
    color: #ffffff;
    display: block;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
    margin-top: 1.25rem;
    padding: 0.3125rem 1.25rem;
    position: relative;
}

.point__catch::after {
    border-left: 0.625rem solid transparent;
    border-right: 0.625rem solid transparent;
    border-top: 0.75rem solid #F48D33;
    bottom: -0.6875rem;
    content: "";
    height: 0;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: 0;
}

.point__title {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 2.25rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 170%;
    margin-top: 0.8125rem;
}

.point__list {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 1.875rem;
    margin-top: 1.875rem;
}

.point__item {
    max-width: 20.625rem;
}

.point__item-heading {
    position: relative;
    text-align: center;
}

.point__item-img img {
    -o-object-fit: contain;
    aspect-ratio: 1/1;
    border-radius: 50%;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    max-width: 12.5rem;
    object-fit: contain;
    width: 100%;
}

.point__item-catch {
    background-color: #F48D33;
    bottom: -0.3125rem;
    color: #ffffff;
    display: inline-block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    left: 50%;
    letter-spacing: 0.05em;
    line-height: 170%;
    min-width: 15rem;
    padding: 0.25rem 2.5rem;
    position: absolute;
    transform: translateX(-50%);
}

.point__item-body {
    margin-top: 1.25rem;
}

.point__item-title {
    color: #F48D33;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
    text-align: center;
}

.point__item-text {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.9375rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 200%;
    margin-top: 0.625rem;
}

.point__swiper {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-top: 3.4375rem;
    width: 100vw;
}

.point__swiper .swiper-wrapper {
    transition-timing-function: linear;
}

.point__swiper .swiper-slide {
    width: auto;
}

.point__swiper .swiper-slide:nth-child(even) img {
    margin-top: 0.9375rem;
}

.point__swiper .swiper-slide img {
    -o-object-fit: cover;
    aspect-ratio: 250/167;
    border-radius: 0.625rem;
    height: auto;
    object-fit: cover;
    width: 15.625rem;
}

.point-02 {
    background-image: url("../images/point/point-02-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    position: relative;
}

.point-02 .point__inner {
    margin-left: auto;
    margin-right: auto;
    max-width: 38.75rem;
    padding: 3.125rem 1.25rem 3.125rem;
}

.point-02 .point__text {
    background-color: #ffffff;
    border-radius: 1.25rem;
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 200%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 1.875rem;
    min-width: 20.9375rem;
    padding: 1.25rem;
}

.point-02 .point__text p+p {
    margin-top: 1.75rem;
}

.point__swiper--03 {
    margin-top: 3.125rem;
}

.point-03 {
    background-image: url("../images/mv/mv-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    position: relative;
    z-index: 1;
}

.point-03 .point__inner {
    margin-left: auto;
    margin-right: auto;
    max-width: 38.75rem;
    padding: 3.125rem 1.25rem 3.125rem;
}

.point-03 .point__text {
    background-color: #ffffff;
    border-radius: 1.25rem;
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 200%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 1.875rem;
    min-width: 20.9375rem;
    padding: 1.25rem;
}

.point-03 .point__ranking {
    grid-gap: 0.875rem;
    background-image: url("../images/point/point-03-ranking-bg_sp.jpg");
    background-position: center;
    background-repeat: repeat;
    background-size: 100% 100%;
    display: grid;
    gap: 0.875rem;
    grid-template-columns: 1fr;
    left: calc(50% - 50vw);
    margin-top: 7rem;
    padding: 6.5rem 1.25rem 3.75rem;
    position: relative;
    width: 100vw;
}

.point-03 .point__ranking-title {
    background-image: url("../images/point/point-03-ranking-title-bg_sp.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    height: auto;
    left: 50%;
    max-width: 22.1875rem;
    padding: 0.8125rem 0.9375rem 0.75rem 0.9375rem;
    position: absolute;
    text-align: center;
    top: -3.875rem;
    transform: translateX(-50%);
    width: 100%;
}

.point-03 .point__ranking-title h3 {
    color: #ffffff;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 140%;
}

.point-03 .point__ranking-title span {
    display: inline-block;
    font-size: 1.25rem;
    letter-spacing: 0.05em;
    line-height: 140%;
    margin-bottom: 0.625rem;
}

.point-03 .point__ranking-item {
    margin-left: auto;
    margin-right: auto;
    max-width: 32.5rem;
}

.point-03 .point__ranking-item-heading {
    text-align: center;
}

.point-03 .point__ranking-item-label {
    margin-top: 0.625rem;
}

.point-03 .point__ranking-item-label img {
    -o-object-fit: contain;
    aspect-ratio: 28.33/25;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    max-width: 1.770625rem;
    object-fit: contain;
    width: 100%;
}

.point-03 .point__ranking-item-catch {
    color: #F48D33;
    display: inline-block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
}

.point-03 .point__ranking-item-img {
    margin-top: 0.625rem;
    text-align: center;
}

.point-03 .point__ranking-item-img img {
    -o-object-fit: contain;
    aspect-ratio: 335/209;
    border-radius: 0.625rem;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.point-03 .point__ranking-item-text {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 200%;
    margin-top: 0.625rem;
}

.point__bg-deco-bottom {
    position: relative;
    top: -0.078125rem;
}

.point__bg-deco-top {
    position: relative;
    top: 0.078125rem;
}

.points {
    background-image: url("../images/wakuwaku/wakuwaku-bg_sp.jpg");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    position: relative;
}

.points__inner {
    padding: 3.125rem 1.25rem 3.125rem;
}

.points__title {
    color: #ffffff;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 150%;
    text-align: center;
}

.points__title span:not(.number) {
    font-size: 2rem;
}

.points__title span.number {
    font-size: 2.5rem;
}

.points__title span.middle {
    font-size: 1.75rem;
}

.points__list {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 1.875rem;
    margin-top: 3.375rem;
}

.points__item {
    background-image: url(../images/points/points-item-bg.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: 100% 100%;
    min-height: 27.0625rem;
    min-width: 18.75rem;
    padding: 5.1875rem 2.46875rem;
    position: relative;
    text-align: center;
}

.points__item-label {
    background-image: url(../images/points/points-item-label-bg.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    color: #ffffff;
    display: inline-block;
    font-family: "Darumadrop One", cursive;
    font-size: 1.875rem;
    font-weight: 300;
    left: 50%;
    line-height: 100%;
    padding: 1.125rem 0.9375rem 1.4375rem 0.9375rem;
    position: absolute;
    top: -0.625rem;
    transform: translateX(-50%);
}

.points__item-icon img {
    -o-object-fit: contain;
    aspect-ratio: 137/100;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    max-width: 8.5625rem;
    object-fit: contain;
    width: 100%;
}

.points__item-body {
    margin-top: 0.9375rem;
}

.points__item-catch {
    background-color: #F48D33;
    border-radius: 3.125rem;
    color: #ffffff;
    display: inline-block;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
    padding: 0 1.25rem;
}

.points__item-title {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 170%;
}

.points__item-text {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 170%;
    margin-top: 0.625rem;
}

.points__bg-deco-bottom {
    position: relative;
    top: 0.078125rem;
}

.program {
    background-image: url("../images/wakuwaku/wakuwaku-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    position: relative;
}

.program__inner {
    padding: 4.375rem 1.25rem 3.125rem;
}

.program__item {
    background-color: #ffffff;
    border-radius: 0.9375rem;
    margin-left: auto;
    margin-right: auto;
    max-width: 32.5rem;
    padding: 3.125rem 0.9375rem 1.25rem;
    position: relative;
}

.program__item+.program__item {
    margin-top: 6.25rem;
}

.program__item:nth-child(1)::before {
    aspect-ratio: 71/70;
    background-image: url("../images/wakuwaku/wakuwaku-cta-icon1.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    content: "";
    height: auto;
    left: -0.5625rem;
    max-width: 4.4375rem;
    position: absolute;
    top: 3.4375rem;
    width: 100%;
}

.program__item:nth-child(1)::after {
    aspect-ratio: 68/80;
    background-image: url("../images/wakuwaku/wakuwaku-cta-icon2.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    content: "";
    height: auto;
    max-width: 3.625rem;
    position: absolute;
    right: -0.625rem;
    top: 12.6875rem;
    width: 100%;
}

.program__item:nth-child(2)::before {
    aspect-ratio: 54/43;
    background-image: url("../images/program/program-korisu-icon_left.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    content: "";
    height: auto;
    left: 0.625rem;
    max-width: 3.375rem;
    position: absolute;
    top: 13.5rem;
    width: 100%;
}

.program__item:nth-child(2)::after {
    aspect-ratio: 84/75;
    background-image: url("../images/program/program-korisu-icon_right.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    content: "";
    height: auto;
    max-width: 5.25rem;
    position: absolute;
    right: -0.625rem;
    top: 12rem;
    width: 100%;
}

.program__item-target {
    background-image: url("../images/program/program-item-target-bg-green_sp.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    color: #ffffff;
    display: inline-block;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
    height: auto;
    left: 50%;
    letter-spacing: 0.05em;
    line-height: 150%;
    max-width: 19.0625rem;
    padding: 0.5625rem 1.25rem 0.4375rem;
    position: absolute;
    text-align: center;
    top: -2.5rem;
    transform: translateX(-50%);
    width: 100%;
}

.program__item:nth-child(1) .program__item-target {
    top: -2.125rem;
}

.program__item:nth-child(2) .program__item-target {
    background-image: url("../images/program/program-item-target-bg-blue_sp.png");
    top: -3.75rem;
}

.program__item-img img {
    -o-object-fit: cover;
    aspect-ratio: 305/200;
    border-radius: 0.625rem;
    height: auto;
    object-fit: cover;
    width: 100%;
}

.program__item-body {
    margin-top: 1.25rem;
    text-align: center;
}

.program__item-label {
    color: #75968D;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
}

.program__item:nth-child(2) .program__item-label {
    color: #689598;
}

.program__item-title {
    margin-top: 0.3125rem;
}

.program__item-title img {
    -o-object-fit: contain;
    aspect-ratio: 294/45;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    max-width: 18.375rem;
    object-fit: contain;
    width: 100%;
}

.program__item-text {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 200%;
    margin-top: 1.25rem;
    text-align: left;
}

.program__item-btn {
    margin-top: 1.25rem;
}

.recruitment {
    background-image: url("../images/mv/mv-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    overflow: hidden;
    position: relative;
    z-index: 1;
}

.recruitment__inner {
    padding: 0rem 1.25rem 3.125rem;
}

.recruitment__heading {
    text-align: center;
}

.recruitment__title img {
    -o-object-fit: contain;
    aspect-ratio: 335/87;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    max-width: 20.9375rem;
    object-fit: contain;
    width: 100%;
}

.recruitment__text {
    margin-left: auto;
    margin-right: auto;
    margin-top: 1.875rem;
    max-width: 32.5rem;
}

.recruitment__text span {
    border-bottom: 1px dashed #F48D33;
    color: #222222;
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 240%;
    text-align: center;
}

.recruitment__text span:first-child {
    border-top: 1px dashed #F48D33;
}

.recruitment__list {
    background-color: #ffffff;
    border-radius: 0.78125rem;
    margin-left: auto;
    margin-right: auto;
    margin-top: 6.8125rem;
    max-width: 32.5rem;
    padding: 2.5rem 0.9375rem 1.5625rem 1.125rem;
    position: relative;
}

.recruitment__list::before {
    aspect-ratio: 148/70;
    background-image: url("../images/recruitment/recruitment-flag_sp.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: 100% 100%;
    content: "";
    height: auto;
    left: 0;
    max-width: 9.25rem;
    position: absolute;
    top: -5.6%;
    width: 100%;
    z-index: 2;
}

.recruitment__list-title {
    left: 50%;
    position: absolute;
    top: -2.75rem;
    transform: translateX(-50%);
}

.recruitment__list-title img {
    -o-object-fit: contain;
    aspect-ratio: 256/85;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    max-width: 16rem;
    min-width: 16rem;
    object-fit: contain;
    width: 100%;
}

.recruitment__item {
    border-bottom: 1px dashed #CAB589;
}

.recruitment__item:last-child {
    border-bottom: none;
}

.recruitment__item-title {
    color: #F48D33;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 180%;
    padding: 0.625rem 0.3125rem 0rem;
}

.recruitment__item-text {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 180%;
    padding: 0.3125rem 0.3125rem 0.625rem;
}

.recruitment__item-text span:not([class]) {
    font-weight: 700;
}

.recruitment__item-text span.small {
    font-size: 0.75rem;
    white-space: nowrap;
}

.recruitment__item-text--table {
    width: 100%;
}

.recruitment-schedule-wrapper {
    -webkit-overflow-scrolling: touch;
    overflow-x: auto;
    padding: 0.375rem 0.375rem;
}

.recruitment-schedule-table {
    border-collapse: collapse;
    min-width: 40.625rem;
    width: 100%;
}

.recruitment-schedule-table td {
    border: 1px solid #dddddd;
    padding: 0.25rem 0.625rem;
    vertical-align: top;
}

.recruitment-schedule-table td:nth-child(1) {
    white-space: nowrap;
    width: 90px;
}

.recruitment-schedule-table td:nth-child(2) {
    white-space: nowrap;
    width: 51.25%;
}

.recruitment-schedule-table td:nth-child(3) {
    width: 37.5%;
}

.recruitment__schedule-list li {
    display: flex;
}

.recruitment__schedule-list li span {
    flex-shrink: 0;
    width: 6.25rem;
}

.recruitment__schedule-list li+li {
    margin-top: -0.0625rem;
}

.recruitment__schedule-list--date li {
    flex-direction: column;
}

.recruitment__schedule-list--date li span {
    width: auto;
}

.recruitment__schedule-list--time li span {
    width: 6.25rem;
}

.recruitment__item:last-child .recruitment__item-text {
    border-bottom: none;
}

.recruitment__item-contact-btn {
    display: inline-block;
    margin-top: 0.5rem;
}

.recruitment__item-note {
    color: #222222;
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 180%;
    margin-top: 0.625rem;
}

.recruitment__item-tel {
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 180%;
}

.recruitment__item-tel:hover {
    cursor: pointer;
}

.recruitment__item-small {
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 180%;
}

.recruitment__message {
    color: #F48D33;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 150%;
    margin-top: 2.5rem;
    position: relative;
    text-align: center;
}

.recruitment__bg-deco-bottom {
    position: relative;
    top: 0.078125rem;
}

.teachers {
    background-image: url("../images/point/point-02-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    position: relative;
}

.teachers__inner {
    padding: 2.0625rem 1.25rem 4.875rem;
}

.teachers__heading {
    text-align: center;
}

.teachers__catch {
    background-color: #F48D33;
    border-radius: 4.375rem;
    color: #ffffff;
    display: inline-block;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
    margin-top: 1.25rem;
    padding: 0.3125rem 1.875rem;
    position: relative;
}

.teachers__catch::after {
    border-left: 0.625rem solid transparent;
    border-right: 0.625rem solid transparent;
    border-top: 0.75rem solid #F48D33;
    bottom: -0.6875rem;
    content: "";
    height: 0;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: 0;
}

.teachers__title {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.75rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 150%;
    margin-top: 1.25rem;
}

.teachers__list {
    margin-top: 1.875rem;
}

.teachers__item {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    justify-content: center;
}

.teachers__item+.teachers__item {
    margin-top: 1.875rem;
}

.teachers__item-img img {
    -o-object-fit: cover;
    aspect-ratio: 335/245;
    height: auto;
    max-width: 32.5rem;
    object-fit: cover;
    width: 100%;
}

.teachers__item-text {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 200%;
    max-width: 32.5rem;
}

.teachers__item-text span {
    color: #0F8F47;
    font-size: 0.875rem;
    font-weight: 700;
}

.teachers__item-text P+P {
    margin-top: 1.375rem;
}

.teachers__bg-deco-bottom {
    position: relative;
    top: 0.078125rem;
}

.to-top a {
    border-radius: 50%;
    display: none;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.to-top a:hover {
    box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.2);
    transform: scale(1.1);
}

.to-top a img {
    -o-object-fit: contain;
    aspect-ratio: 1/1;
    height: auto;
    max-width: 7.5rem;
    object-fit: contain;
    width: 100%;
}

.is-hidden {
    opacity: 0;
    visibility: hidden;
}

.voice {
    background-image: url("../images/mv/mv-bg_sp.jpg");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    position: relative;
    z-index: 1;
}

.voice__inner {
    padding: 3rem 1.25rem 1.875rem;
}

.voice__heading {
    text-align: center;
}

.voice__catch {
    color: #F48D33;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 0.9375rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 100%;
}

.voice__title {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 160%;
    margin-top: 0.625rem;
}

.voice__list {
    -webkit-overflow-scrolling: touch;
    -ms-overflow-style: none;
    display: flex;
    flex-wrap: nowrap;
    gap: 1.25rem;
    margin-left: calc(-50vw + 50%);
    margin-top: 1.875rem;
    overflow-x: auto;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
    scrollbar-width: none;
    width: 100vw;
}

.voice__list::-webkit-scrollbar {
    display: none;
}

.voice__item-text {
    background-color: #ffffff;
    border-radius: 0.625rem;
    min-height: 14.375rem;
    min-width: 18.75rem;
    padding: 1.25rem 1.25rem 2.1875rem;
    position: relative;
}

.voice__item-text::after {
    border-left: 0.9375rem solid transparent;
    border-right: 0.9375rem solid transparent;
    border-top: 1rem solid #ffffff;
    bottom: -0.9375rem;
    content: "";
    height: 0;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: 0;
}

.voice__item-text p {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 180%;
}

.voice__item-icon {
    -o-object-fit: contain;
    aspect-ratio: 1/1;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    margin-top: 2.1875rem;
    object-fit: contain;
    width: 5rem;
}

.voice__bg-deco-bottom {
    position: relative;
    top: 0.078125rem;
}

.wakuwaku {
    background-image: url("../images/wakuwaku/wakuwaku-bg_sp.jpg");
    background-position: center top;
    background-repeat: repeat;
    background-size: contain;
    position: relative;
}

.wakuwaku__inner.inner {
    padding: 3.125rem 1.25rem;
}

.wakuwaku__heading {
    margin-left: auto;
    margin-right: auto;
    max-width: 800px;
    text-align: center;
}

.wakuwaku__catch {
    background-color: #fff222;
    border-radius: 3.125rem;
    color: #0F8F47;
    display: inline-block;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    line-height: 100%;
    padding: 0.625rem 2.5rem;
    position: relative;
    text-align: center;
}

.wakuwaku__catch::after {
    background-image: url("../images/wakuwaku/wakuwaku-catch-icon.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 1.125rem;
    position: absolute;
    right: 1rem;
    top: -0.625rem;
    width: 1.5625rem;
    z-index: 1;
}

.wakuwaku__title {
    margin-top: -2.25rem;
}

.wakuwaku__title img {
    -o-object-fit: contain;
    aspect-ratio: 320/130;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.wakuwaku__text {
    background-image: url("../images/features/features-list-bg_sp.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    display: block;
    margin-top: 1.25rem;
    padding: 0.9375rem 0.9375rem;
    position: relative;
}

.wakuwaku__text span {
    border-bottom: 1px dashed #F48D33;
    color: #222222;
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 250%;
    text-align: center;
}

.wakuwaku__text span:last-child {
    border-bottom: none;
}

.wakuwaku__text.u-desktop {
    display: none;
}

.wakuwaku__list {
    margin-left: auto;
    margin-right: auto;
    margin-top: 3.125rem;
    width: 100%;
}

.wakuwaku__item {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 0.9375rem;
}

.wakuwaku__item:nth-child(3) {
    gap: 1.75rem;
}

.wakuwaku__item:nth-child(3) .wakuwaku__item-text {
    letter-spacing: 0.05em;
}

.wakuwaku__item+.wakuwaku__item {
    margin-top: 2.8125rem;
}

.wakuwaku__item-body {
    padding-left: 0.125rem;
    padding-right: 0.125rem;
    padding-top: 2.5rem;
    position: relative;
}

.wakuwaku__item-body::after {
    background-image: url("../images/wakuwaku/wakuwaku-label01.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 5rem;
    position: absolute;
    right: 0;
    top: -1rem;
    transform: rotate(10deg);
    width: 7.6875rem;
    z-index: 1;
}

.wakuwaku__item:first-child .wakuwaku__item-body::after {
    top: -1rem;
}

.wakuwaku__item:nth-child(2) .wakuwaku__item-body::after {
    background-image: url("../images/wakuwaku/wakuwaku-label02.png");
    top: -3rem;
}

.wakuwaku__item:nth-child(3) .wakuwaku__item-body::after {
    background-image: url("../images/wakuwaku/wakuwaku-label03.png");
    top: -1.625rem;
}

.wakuwaku__item:nth-child(3) .wakuwaku__item-body {
    padding-top: 0;
}

.wakuwaku__item-catch {
    background-color: #fff222;
    border-radius: 3.125rem;
    color: #0F8F47;
    display: inline-block;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
    padding: 0rem 1.3125rem;
    position: relative;
    text-align: center;
}

.wakuwaku__item-catch::after {
    border-left: 0.5rem solid transparent;
    border-right: 0.5rem solid transparent;
    border-top: 0.625rem solid #fff222;
    bottom: -0.5rem;
    content: "";
    height: 0;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: 0;
}

.wakuwaku__item-title {
    color: #ffffff;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
    margin-top: 0.625rem;
    white-space: nowrap;
}

.wakuwaku__item-text {
    color: #ffffff;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.03em;
    line-height: 180%;
    margin-top: 0.625rem;
}

.wakuwaku__item-img img {
    -o-object-fit: contain;
    aspect-ratio: 335/279;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.wakuwaku__cta {
    margin-top: 3.225rem;
}

.wakuwaku__cta-inner {
    background-image: url("../images/features/features-list-bg_sp.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    padding: 1.25rem;
}

.wakuwaku__cta-contents {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.wakuwaku__cta-img {
    position: relative;
}

.wakuwaku__cta-img::before {
    background-image: url("../images/wakuwaku/wakuwaku-cta-icon1.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 4.375rem;
    left: -1.75rem;
    position: absolute;
    top: -2rem;
    width: 4.4375rem;
}

.wakuwaku__cta-img::after {
    background-image: url("../images/wakuwaku/wakuwaku-cta-icon2.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: -1.875rem;
    content: "";
    height: 5rem;
    position: absolute;
    right: -1rem;
    width: 4.25rem;
}

.wakuwaku__cta-img img {
    -o-object-fit: contain;
    aspect-ratio: 295/200;
    border-radius: 1.875rem;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.wakuwaku__cta-body {
    position: relative;
    text-align: center;
}

.wakuwaku__cta-label {
    color: #75968D;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 170%;
}

.wakuwaku__cta-title {
    margin-top: 0.625rem;
}

.wakuwaku__cta-title img {
    -o-object-fit: contain;
    aspect-ratio: 295/45;
    height: auto;
    object-fit: contain;
    width: 100%;
}

.wakuwaku__cta-text {
    color: #222222;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: 200%;
    margin-top: 0.9375rem;
    text-align: left;
}

.wakuwaku__cta-btn {
    margin-top: 0.9375rem;
    position: relative;
}

@media screen and (min-width: 740px) and (max-width: 767px) {

    .mv {
        max-height: 109.375rem;
    }

}

@media screen and (min-width: 768px) {

    .u-desktop {
        display: block;
    }

    .u-mobile {
        display: none;
    }

    html {
        font-size: 1.4035087719vw;
    }

    .about {
        background-image: url("../images/mv/mv-bg_pc.jpg");
    }

    .about__inner {
        padding: 1.5rem 1.5625rem 6.25rem;
    }

    .about__heading {
        aspect-ratio: 855/264;
        background-image: url("../images/about/about-heading-bg_pc.png");
        background-size: contain;
        left: 4%;
        max-width: 53.4375rem;
        padding: 5rem 9.375rem 5.375rem;
        top: 0.875rem;
    }

    .about__catch img {
        aspect-ratio: 585/28;
        max-width: 31.25rem;
    }

    .about__title {
        font-size: 2.1875rem;
    }

    .about__title span {
        font-size: 2.5rem;
    }

    .about__img {
        margin-left: -1.25rem;
        margin-right: -1.25rem;
        margin-top: -8rem;
    }

    .about__img img {
        aspect-ratio: 1180/400;
        border-radius: 1.875rem;
    }

    .about__subtitle {
        margin-top: 3.125rem;
    }

    .about__subtitle img {
        aspect-ratio: 834/86;
        max-width: 52.125rem;
    }

    .about__lead {
        font-size: 1.25rem;
        letter-spacing: 0.05em;
        margin-top: 0.625rem;
    }

    .about__list {
        display: flex;
        flex-direction: row;
        gap: 0.625rem;
        justify-content: center;
        margin-top: 1.6875rem;
    }

    .about__item {
        max-height: 22.5rem;
        max-width: 22.5rem;
        padding: 3.9375rem 2.625rem 5.21875rem;
    }

    .about__item:nth-child(1),
    .about__item:nth-child(3) {
        margin-top: 3.75rem;
    }

    .about__item-title {
        font-size: 2.625rem;
        letter-spacing: 0.05em;
    }

    .about__item-icon {
        margin-top: 1.25rem;
    }

    .about__item-icon img {
        aspect-ratio: 82/60;
        max-width: 5.125rem;
    }

    .about__item-text {
        font-size: 1rem;
    }

    .about__text {
        margin-top: 2.8rem;
        max-width: 43.75rem;
    }

    .about__text span {
        font-size: 1.125rem;
        line-height: 300%;
    }

    .btn-cta {
        font-size: 1.125rem;
        padding: 0.9375rem 6.25rem 0.9375rem 1.875rem;
    }

    .btn-mail {
        font-size: 1.25rem;
        padding: 0.625rem 1.875rem 0.625rem 3.875rem;
    }

    .btn-mail::before {
        height: 1rem;
        left: 1.875rem;
        width: 1.375rem;
    }

    .faq {
        background-image: url("../images/point/point-02-bg_pc.jpg");
        background-repeat: repeat;
    }

    .faq::before {
        background-image: url("../images/faq/faq-bg-cercle-right_pc.png");
        height: 40rem;
        right: -22.5rem;
        top: -3.125rem;
        width: 40rem;
    }

    .faq::after {
        background-image: url("../images/faq/faq-bg-cercle-left_pc.png");
        height: 40rem;
        left: -22.5rem;
        right: auto;
        top: 3.75rem;
        width: 40rem;
    }

    .faq__inner {
        display: flex;
        gap: 7.125rem;
        max-width: none;
        padding: 6.25rem 1.5625rem 0rem;
    }

    .faq__inner::after {
        background-image: url("../images/faq/faq-bg-leaves.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        bottom: 4.75rem;
        content: "";
        height: 7.625rem;
        left: 4.875rem;
        pointer-events: none;
        position: absolute;
        right: auto;
        top: auto;
        width: 10.875rem;
        z-index: 2;
    }

    .faq__heading {
        width: 18%;
    }

    .faq__title {
        font-size: 2rem;
        padding-left: 0.9375rem;
    }

    .faq__list {
        margin-top: 0rem;
        width: 70%;
    }

    .faq__item {
        border-radius: 1.25rem;
        padding: 1.5625rem;
    }

    .faq__item+.faq__item {
        margin-top: 1.875rem;
    }

    .faq__item-title {
        font-size: 1.125rem;
        padding-left: 3.4375rem;
    }

    .faq__item-title::before {
        height: 2.5rem;
        top: -0.3125rem;
        width: 2.5rem;
    }

    .faq__item-text {
        font-size: 0.875rem;
        margin-top: 1.875rem;
        padding-left: 3.4375rem;
    }

    .faq__item-text::before {
        height: 2.5rem;
        top: -0.3125rem;
        width: 2.5rem;
    }

    .faq__photo-list-img {
        aspect-ratio: 1280/600;
    }

    .features {
        background-image: url("../images/mv/mv-bg_pc.jpg");
    }

    .features__img1 {
        aspect-ratio: 451/533;
        left: -6.875rem;
        max-width: 28.1875rem;
        top: -0.525rem;
        z-index: -1;
    }

    .features__img2 {
        aspect-ratio: 622/690;
        bottom: 9.5rem;
        max-width: 38.875rem;
        right: -10.9375rem;
        z-index: -1;
    }

    .features__inner.inner {
        padding: 6.6875rem 4.375rem 9.375rem;
    }

    .features__title {
        font-size: 1.5rem;
    }

    .features__title span {
        font-size: 1.5rem;
    }

    .features__title span .orange {
        font-size: 2rem;
    }

    .features__title .small {
        font-size: 2rem;
    }

    .features__list {
        background-image: url("../images/features/features-list-bg_pc.png");
        margin-top: 1.875rem;
        max-width: 50rem;
        padding: 3.125rem 5rem;
    }

    .features__item {
        font-size: 1.25rem;
        line-height: 170%;
        padding: 0.9375rem 0.9375rem 0.9375rem 2.9375rem;
    }

    .features__item::before {
        height: 1.25rem;
        left: 0.875rem;
        top: 1.625rem;
        width: 1.25rem;
    }

    .fixed-cta {
        flex-direction: row;
        gap: 0.625rem;
        left: auto;
        max-height: 3.75rem;
        max-width: 29.0625rem;
        right: 1.25rem;
        top: 1.25rem;
        width: 100%;
    }

    .fixed-cta__btn {
        border-radius: 4.0625rem;
    }

    .fixed-cta__btn--tel {
        padding: 0.25rem 1.5625rem 0.625rem;
        width: 44%;
    }

    .fixed-cta__btn--tel .fixed-cta__text::before {
        height: 1rem;
        width: 1rem;
    }

    .fixed-cta__btn--mail {
        font-size: 1.125rem;
        padding: 0.625rem 1.5rem 0.9375rem 1.5rem;
        width: 53.7%;
    }

    .fixed-cta__btn--mail .fixed-cta__text::before {
        height: 1rem;
        width: 1.375rem;
    }

    .footer {
        background-image: url("../images/wakuwaku/wakuwaku-bg_pc.jpg");
        background-repeat: repeat;
    }

    .footer__inner.inner {
        display: flex;
        justify-content: space-between;
        padding: 3.75rem 2.8125rem 0;
    }

    .footer__heading {
        justify-content: flex-start;
    }

    .footer__title-sub {
        font-size: 1rem;
    }

    .footer__title-main {
        font-size: 1.875rem;
        margin-bottom: 0.5rem;
    }

    .footer__info-text {
        font-size: 0.875rem;
        margin-top: 1.425rem;
        text-align: left;
    }

    .footer__info-tel {
        pointer-events: none;
    }

    .footer__info-tel::before {
        height: 1.5rem;
        width: 1.5rem;
    }

    .footer__info-time {
        margin-left: 1.5625rem;
        text-align: left;
    }

    .footer__right {
        margin-top: 0;
    }

    .footer__sns-text {
        font-size: 1.25rem;
    }

    .footer__sns-list {
        gap: 1.25rem;
        margin-top: 1rem;
    }

    .footer__sns-link img {
        aspect-ratio: 250/170;
        max-width: 15.625rem;
    }

    .footer__copy.inner {
        margin-top: 1rem;
        padding: 0 3.125rem 1.25rem;
    }

    .footer__copy-text {
        text-align: left;
    }

    .inner {
        max-width: 1190px;
        padding-left: 25px;
        padding-right: 25px;
    }

    .mv {
        aspect-ratio: 1280/839;
        background-image: url("../images/mv/mv-bg_pc.jpg");
        height: auto;
        max-height: none;
    }

    .mv::before {
        background-image: url("../images/mv/mv-bg-circle_pc.png");
        height: 47.5rem;
        left: -14.375rem;
        right: auto;
        top: -18.75rem;
        width: 47.5rem;
    }

    .mv__logo {
        left: 3.125rem;
        top: 1.875rem;
    }

    .mv__logo a img {
        aspect-ratio: 160/122;
        max-width: 10rem;
    }

    .mv__bg {
        right: -0.625rem;
        top: 0;
    }

    .mv__bg img {
        aspect-ratio: 960/819;
        margin-left: auto;
        width: 76%;
    }

    .mv__bg::after {
        display: none;
    }

    .mv__catch {
        gap: 1.375rem;
        right: 5.625rem;
        top: 7.8125rem;
    }

    .mv__catch-left,
    .mv__catch-right {
        font-size: 2.8125rem;
        letter-spacing: 0.18em;
        padding: 1.875rem 1rem;
    }

    .mv__catch-left {
        margin-top: 1.5625rem;
    }

    .mv__cards {
        align-items: flex-end;
        bottom: 4%;
        flex-direction: row;
        left: 3%;
        max-width: none;
        transform: none;
        width: auto;
    }

    .mv__card {
        border-radius: 0.625rem;
        max-width: 21.875rem;
        width: 100%;
    }

    .mv__card--main {
        aspect-ratio: 350/400;
        margin-left: -2.5rem;
        order: 2;
    }

    .mv__card--cta {
        aspect-ratio: 350/400;
        margin-bottom: 16vw;
        margin-right: -2.5rem;
        order: 1;
    }

    .mv__card-inner {
        padding: 1.5rem 1.25rem 1.625rem;
    }

    .mv__badge {
        left: -1.25rem;
        top: -2.25rem;
    }

    .mv__badge img {
        max-width: 7.5rem;
    }

    .mv__card-heading {
        flex-direction: column;
    }

    .mv__card-img {
        width: 100%;
    }

    .mv__card--main .mv__card-img img {
        aspect-ratio: 310/190;
    }

    .mv__card--cta .mv__card-img img {
        aspect-ratio: 310/156;
    }

    .mv__card-heading-body {
        text-align: center;
        width: 100%;
    }

    .mv__card-label {
        font-size: 0.875rem;
        font-weight: 700;
    }

    .mv__card-label::after {
        display: none;
    }

    .mv__card-label .u-desktop {
        display: inline;
    }

    .mv__card-title {
        font-size: 1.375rem;
    }

    .mv__card-title span {
        font-size: 1.875rem;
    }

    .mv__card-title .small {
        font-size: 1.125rem;
    }

    .mv__card-body {
        flex-direction: column;
        gap: 0.9375rem;
        justify-content: center;
    }

    .mv__card-text {
        font-size: 1rem;
        max-width: none;
        text-align: center;
    }

    .mv__card-btn.u-mobile {
        display: none;
    }

    .mv__card-btn.btn-cta {
        background: #F48D33;
        display: block;
        font-family: "Zen Maru Gothic", sans-serif;
        font-size: 0.875rem;
        padding: 0.625rem 5.4375rem 0.625rem 1.875rem;
    }

    .mv__card-btn.btn-mail {
        display: block;
    }

    .mv__card-heading-title {
        font-size: 1.375rem;
    }

    .mv__card-heading-title span {
        font-size: 1.5rem;
    }

    .point-01 {
        background-image: url("../images/mv/mv-bg_pc.jpg");
    }

    .point-01 .point__inner {
        max-width: none;
        padding: 3.875rem 1.5625rem 2.75rem;
    }

    .point-01 .point__inner::before {
        aspect-ratio: 300/156;
        background-image: url("../images/point/point-01-illust_left.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: 100% 100%;
        content: "";
        height: auto;
        left: calc(50% - min(47vw, 38rem));
        max-width: 18.75rem;
        position: absolute;
        top: 7.1875rem;
        width: 100%;
    }

    .point-01 .point__inner::after {
        aspect-ratio: 300/156;
        background-image: url("../images/point/point-01-illust_right.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: 100% 100%;
        content: "";
        height: auto;
        max-width: 18.75rem;
        position: absolute;
        right: calc(50% - min(47vw, 38rem));
        top: 4.25rem;
        width: 100%;
    }

    .point__inner {
        max-width: none;
        padding: 3.125rem 1.5625rem 6.25rem;
    }

    .point__label {
        font-size: 3.75rem;
    }

    .point__icon img {
        aspect-ratio: 200/150;
        max-width: 12.5rem;
    }

    .point__catch {
        border-radius: 4.375rem;
        display: inline-block;
        font-size: 1.5rem;
        padding: 0.375rem 2.5rem;
    }

    .point__title {
        font-size: 3rem;
        margin-top: 0.625rem;
    }

    .point__list {
        align-items: flex-start;
        flex-direction: row;
        gap: 3.4375rem;
        justify-content: center;
        margin-left: auto;
        margin-right: auto;
        margin-top: 3.125rem;
        max-width: 80rem;
        padding: 0 3.625rem;
    }

    .point__item {
        flex: 1;
        max-width: 28.125rem;
    }

    .point__item-img img {
        max-width: 15.625rem;
    }

    .point__item-catch {
        font-size: 1.25rem;
        max-width: 15rem;
        padding: 0.25rem 2.5rem;
    }

    .point__item-body {
        margin-top: 1.125rem;
    }

    .point__item-title {
        font-size: 1.25rem;
    }

    .point__item-text {
        font-size: 1rem;
    }

    .point__swiper {
        margin-top: 5rem;
    }

    .point__swiper .swiper-slide:nth-child(even) img {
        margin-top: 1.875rem;
    }

    .point__swiper .swiper-slide img {
        aspect-ratio: 300/200;
        width: 18.75rem;
    }

    .point-02 {
        background-image: url("../images/point/point-02-bg_pc.jpg");
        background-repeat: repeat;
    }

    .point-02 .point__inner {
        max-width: none;
        padding: 3.125rem 1.5625rem 5.875rem;
    }

    .point-02 .point__inner::before {
        aspect-ratio: 300/156;
        background-image: url("../images/point/point-02-illust_left.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: 100% 100%;
        content: "";
        height: auto;
        left: calc(50% - min(47vw, 38rem));
        max-width: 18.75rem;
        position: absolute;
        top: 7.875rem;
        width: 100%;
    }

    .point-02 .point__inner::after {
        aspect-ratio: 300/156;
        background-image: url("../images/point/point-02-illust_right.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: 100% 100%;
        content: "";
        height: auto;
        max-width: 18.75rem;
        position: absolute;
        right: calc(50% - min(47vw, 38rem));
        top: 3.125rem;
        width: 100%;
    }

    .point-02 .point__text {
        border-radius: 1.875rem;
        font-size: 1rem;
        max-width: 56.25rem;
        padding: 3.125rem;
    }

    .point-02 .point__text p+p {
        margin-top: 2rem;
    }

    .point__swiper--03 {
        margin-top: 5rem;
    }

    .point-03 {
        background-image: url("../images/mv/mv-bg_pc.jpg");
    }

    .point-03 .point__inner {
        max-width: none;
        padding: 3.125rem 1.5625rem 6.25rem;
    }

    .point-03 .point__inner::before {
        aspect-ratio: 300/156;
        background-image: url("../images/point/point-03-illust_left.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: 100% 100%;
        content: "";
        height: auto;
        left: calc(50% - min(47vw, 38rem));
        max-width: 18.75rem;
        position: absolute;
        top: 14.875rem;
        width: 100%;
    }

    .point-03 .point__inner::after {
        aspect-ratio: 300/156;
        background-image: url("../images/point/point-03-illust_right.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: 100% 100%;
        content: "";
        height: auto;
        max-width: 18.75rem;
        position: absolute;
        right: calc(50% - min(47vw, 38rem));
        top: 10.25rem;
        width: 100%;
    }

    .point-03 .point__text {
        border-radius: 1.875rem;
        font-size: 1rem;
        max-width: 56.25rem;
        padding: 3.125rem;
    }

    .point-03 .point__ranking {
        -moz-column-gap: 1.875rem;
        background-image: url("../images/point/point-03-ranking-bg_pc.jpg");
        border-radius: 1.875rem;
        column-gap: 1.875rem;
        grid-template-columns: repeat(2, 1fr);
        left: 0;
        margin-left: auto;
        margin-right: auto;
        margin-top: 6.875rem;
        max-width: 80rem;
        padding: 5rem 3.125rem 3.75rem;
        row-gap: 1.75rem;
        width: 90%;
    }

    .point-03 .point__ranking-title {
        background-image: url("../images/point/point-03-ranking-title-bg_pc.png");
        left: 51%;
        max-width: 45rem;
        padding: 0.875rem 2.5rem 1rem;
        top: -2.9375rem;
    }

    .point-03 .point__ranking-title h3 {
        font-size: 1rem;
    }

    .point-03 .point__ranking-title span {
        font-size: 1.75rem;
    }

    .point-03 .point__ranking-item {
        max-width: none;
    }

    .point-03 .point__ranking-item:first-of-type {
        grid-gap: 1.25rem 2.5rem;
        align-items: start;
        display: grid;
        gap: 1.25rem 2.5rem;
        grid-column: 1/-1;
        grid-template-areas: "img heading""img text";
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto 1fr;
    }

    .point-03 .point__ranking-item:first-of-type .point__ranking-item-img {
        grid-area: img;
        margin-top: 0;
    }

    .point-03 .point__ranking-item:first-of-type .point__ranking-item-heading {
        align-items: center;
        display: flex;
        gap: 1rem;
        grid-area: heading;
        margin-top: 6.25rem;
    }

    .point-03 .point__ranking-item:first-of-type .point__ranking-item-text {
        align-self: start;
        grid-area: text;
        margin-top: 0;
        text-align: left;
    }

    .point-03 .point__ranking-item:nth-of-type(2),
    .point-03 .point__ranking-item:nth-of-type(3) {
        position: relative;
    }

    .point-03 .point__ranking-item:nth-of-type(2) .point__ranking-item-heading,
    .point-03 .point__ranking-item:nth-of-type(3) .point__ranking-item-heading {
        align-items: center;
        background-color: rgba(255, 255, 255, 0.8);
        display: flex;
        gap: 1rem;
        left: 0;
        padding: 1.125rem 1.875rem;
        position: absolute;
        top: 0;
        z-index: 1;
    }

    .point-03 .point__ranking-item:nth-of-type(2) .point__ranking-item-img,
    .point-03 .point__ranking-item:nth-of-type(3) .point__ranking-item-img {
        margin-top: 0;
    }

    .point-03 .point__ranking-item:nth-of-type(2) .point__ranking-item-text,
    .point-03 .point__ranking-item:nth-of-type(3) .point__ranking-item-text {
        margin-top: 0.3125rem;
    }

    .point-03 .point__ranking-item-label {
        margin-top: 0;
    }

    .point-03 .point__ranking-item-label img {
        aspect-ratio: 34/30;
        max-width: 2.125rem;
    }

    .point-03 .point__ranking-item-catch {
        font-size: 1.25rem;
    }

    .point-03 .point__ranking-item-img {
        margin-top: 1rem;
    }

    .point-03 .point__ranking-item-img img {
        aspect-ratio: 480/300;
        border-radius: 1.25rem;
    }

    .point-03 .point__ranking-item-text {
        font-size: 1rem;
        margin-top: 1.25rem;
    }

    .points {
        background-image: url("../images/wakuwaku/wakuwaku-bg_pc.jpg");
    }

    .points__inner {
        padding: 3.125rem 4.375rem 5.75rem;
    }

    .points__title {
        font-size: 2rem;
    }

    .points__title span:not(.number) {
        font-size: 2.5rem;
    }

    .points__title span.number {
        font-size: 3.125rem;
    }

    .points__title span.middle {
        font-size: 2.5rem;
    }

    .points__list {
        align-items: center;
        flex-direction: row;
        gap: max(1.25rem, min(3vw, 5rem));
        justify-content: center;
    }

    .points__item {
        min-height: 30rem;
        min-width: 21.25rem;
        padding: 4.875rem 1.5rem 4.96875rem;
    }

    .points__item:nth-child(1) {
        margin-bottom: 2.5rem;
        order: 2;
    }

    .points__item:nth-child(2) {
        margin-top: 5rem;
        order: 1;
    }

    .points__item:nth-child(3) {
        margin-top: 5rem;
        order: 3;
    }

    .points__item-label {
        font-size: 2.5rem;
        padding: 1rem 1rem 1.5rem 1rem;
        top: -1.875rem;
    }

    .points__item-icon img {
        aspect-ratio: 165/120;
        max-width: 10.3125rem;
    }

    .points__item-body {
        margin-top: 1.25rem;
    }

    .points__item-catch {
        font-size: 0.875rem;
    }

    .points__item-title {
        font-size: 2rem;
    }

    .points__item-text {
        font-size: 1rem;
    }

    .program {
        background-image: url("../images/wakuwaku/wakuwaku-bg_pc.jpg");
        background-repeat: repeat;
    }

    .program__inner {
        padding: 6.25rem 2.5rem 6.25rem;
    }

    .program__item {
        align-items: center;
        border-radius: 1.875rem;
        display: flex;
        gap: 3.125rem;
        max-width: none;
        padding: 4.375rem;
    }

    .program__item+.program__item {
        margin-top: 5.75rem;
    }

    .program__item:nth-child(2) {
        flex-direction: row-reverse;
    }

    .program__item:nth-child(1)::before {
        aspect-ratio: 99/105;
        left: 2.75rem;
        max-width: 6.1875rem;
        top: 1.875rem;
    }

    .program__item:nth-child(1)::after {
        aspect-ratio: 97/170;
        bottom: 2.375rem;
        max-width: 6.0625rem;
        right: 2.8125rem;
        top: auto;
    }

    .program__item:nth-child(2)::before {
        aspect-ratio: 106/85;
        bottom: auto;
        left: 43%;
        max-width: 6.625rem;
        top: 6.6875rem;
        transform: translateX(-50%);
    }

    .program__item:nth-child(2)::after {
        aspect-ratio: 173/153;
        bottom: 0.75rem;
        max-width: 10.8125rem;
        right: 1.875rem;
        top: auto;
    }

    .program__item-target {
        background-image: url("../images/program/program-item-target-bg-green_pc.png");
        font-size: 1.5rem;
        letter-spacing: 0.1em;
        max-width: 47.75rem;
        padding: 0.75rem 1.875rem 0.75rem;
        top: -1.5625rem;
    }

    .program__item:nth-child(1) .program__item-target {
        top: -1.5625rem;
    }

    .program__item:nth-child(2) .program__item-target {
        background-image: url("../images/program/program-item-target-bg-blue_pc.png");
        top: -1.5625rem;
    }

    .program__item-img {
        width: 46.8%;
    }

    .program__item-img img {
        aspect-ratio: 450/500;
        border-radius: 1.25rem;
    }

    .program__item-body {
        margin-top: 0;
        text-align: left;
        width: 48%;
    }

    .program__item-label {
        font-size: 1.25rem;
    }

    .program__item-title {
        margin-top: 0rem;
    }

    .program__item-title img {
        aspect-ratio: 476/72;
        margin-left: 0;
        max-width: 27.3125rem;
    }

    .program__item:nth-child(2) .program__item-title img {
        aspect-ratio: 476/74;
        margin-left: -4.625rem;
        max-width: 28.75rem;
    }

    .program__item-text {
        font-size: 1rem;
        margin-top: 1.875rem;
    }

    .program__item-btn {
        margin-top: 1.875rem;
    }

    .recruitment {
        background-image: url("../images/mv/mv-bg_pc.jpg");
        margin-top: -6.75rem;
    }

    .recruitment__inner {
        padding: 3.125rem 1.5625rem 6.25rem;
    }

    .recruitment__title img {
        aspect-ratio: 625/137;
        max-width: 39.0625rem;
    }

    .recruitment__text {
        max-width: 50.6875rem;
    }

    .recruitment__text span {
        font-size: 1.125rem;
        line-height: 292%;
    }

    .recruitment__list {
        border-radius: 3.125rem;
        margin-left: 4.0625rem;
        margin-right: 4.0625rem;
        margin-top: 14.6875rem;
        max-width: none;
        padding: 6.25rem 5rem 3.125rem;
    }

    .recruitment__list::before {
        aspect-ratio: 306/146;
        background-image: url("../images/recruitment/recruitment-flag_pc.png");
        left: 2.1875rem;
        max-width: 19.125rem;
        top: -12%;
    }

    .recruitment__list::after {
        aspect-ratio: 97/170;
        background-image: url("../images/wakuwaku/wakuwaku-cta-icon2.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: 100% 100%;
        content: "";
        height: auto;
        max-width: 6.0625rem;
        position: absolute;
        right: 3.75rem;
        top: 0.75rem;
        width: 100%;
        z-index: 2;
    }

    .recruitment__list-title {
        top: -5.75rem;
    }

    .recruitment__list-title img {
        aspect-ratio: 625/183;
        max-width: 39.0625rem;
        min-width: 39.0625rem;
    }

    .recruitment__item {
        align-items: flex-start;
        display: flex;
    }

    .recruitment__item:nth-child(3) {
        flex-direction: column;
    }

    .recruitment__item-title {
        flex-shrink: 0;
        font-size: 1rem;
        padding: 1.25rem;
        width: 12.5rem;
    }

    .recruitment__item-text {
        flex: 1;
        font-size: 1rem;
        padding: 1.25rem;
    }

    .recruitment__item-text span.small {
        font-size: 0.875rem;
    }

    .recruitment__item-text--table {
        padding: 0 1.25rem 1.25rem;
    }

    .recruitment__text--message {
        margin-top: 3.25rem;
    }

    .recruitment__text--message span {
        line-height: 300%;
    }

    .recruitment-schedule-wrapper {
        padding: 0rem 0.375rem;
    }

    .recruitment-schedule-table td {
        padding: 0.2rem 0.625rem;
    }

    .recruitment__schedule-list li+li {
        margin-top: 0rem;
    }

    .recruitment__schedule-list--date li {
        flex-direction: row;
    }

    .recruitment__schedule-list--date li span {
        width: 6.25rem;
    }

    .recruitment__schedule-list--time li span {
        width: 7.5rem;
    }

    .recruitment__item-contact-btn {
        margin-top: 0rem;
    }

    .recruitment__item-note {
        font-size: 1rem;
        margin-top: 0.5rem;
    }

    .recruitment__item-tel {
        display: inline-block;
        font-size: 1.375rem;
        pointer-events: none;
    }

    .recruitment__item-small {
        display: inline-block;
        font-size: 0.875rem;
    }

    .recruitment__message {
        font-size: 2rem;
        margin-top: 5.625rem;
    }

    .recruitment__message::before {
        aspect-ratio: 248/170;
        background-image: url("../images/recruitment/recruitment-img-left.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        content: "";
        height: auto;
        left: calc(50% - min(50vw, 40rem));
        max-width: 20.5rem;
        position: absolute;
        top: -6.375rem;
        width: 100%;
        z-index: 2;
    }

    .recruitment__message::after {
        aspect-ratio: 316/231;
        background-image: url("../images/recruitment/recruitment-img-right.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        content: "";
        height: auto;
        max-width: 19.75rem;
        position: absolute;
        right: calc(50% - min(48vw, 39rem));
        top: -10.125rem;
        width: 100%;
    }

    .teachers {
        background-image: url("../images/point/point-02-bg_pc.jpg");
        background-repeat: repeat;
    }

    .teachers__inner {
        padding: 2rem 1.5625rem 6.25rem;
    }

    .teachers__catch {
        border-radius: 4.375rem;
        font-size: 1.25rem;
        padding: 0.3125rem 2.5rem;
    }

    .teachers__title {
        font-size: 2.5rem;
        margin-top: 1.25rem;
    }

    .teachers__list {
        margin-top: 3.125rem;
        padding-left: 1.25rem;
    }

    .teachers__item {
        flex-direction: row;
        gap: 3.125rem;
    }

    .teachers__item:first-child {
        flex-direction: row-reverse;
    }

    .teachers__item+.teachers__item {
        margin-top: 0.625rem;
    }

    .teachers__item-img {
        width: 46%;
    }

    .teachers__item-img img {
        aspect-ratio: 520/380;
        max-width: 32.5rem;
    }

    .teachers__item-text {
        font-size: 1rem;
        max-width: none;
        width: 49%;
    }

    .teachers__item-text span {
        color: #0F8F47;
        font-size: 1rem;
    }

    .teachers__item-text P+P {
        margin-top: 2rem;
    }

    .to-top {
        bottom: 0.9375rem;
        position: fixed;
        right: 1.25rem;
        z-index: 100;
    }

    .to-top a {
        display: block;
    }

    .voice {
        background-image: url("../images/mv/mv-bg_pc.jpg");
    }

    .voice__inner {
        padding: 5.875rem 1.5625rem 3.125rem;
    }

    .voice__catch {
        font-size: 1.125rem;
    }

    .voice__title {
        font-size: 2rem;
    }

    .voice__list {
        gap: 2.8125rem;
        margin-top: 3.125rem;
        padding-left: 1.5625rem;
        padding-right: 1.5625rem;
    }

    .voice__item-text {
        min-height: 16.875rem;
        min-width: 23.75rem;
        padding: 1.875rem 1.875rem 2.3125rem;
    }

    .voice__item-text p {
        font-size: 1rem;
    }

    .voice__item-icon {
        margin-top: 2.3125rem;
        width: 6.25rem;
    }

    .wakuwaku {
        background-image: url("../images/wakuwaku/wakuwaku-bg_pc.jpg");
    }

    .wakuwaku__inner.inner {
        max-width: 80rem;
        padding: 3.125rem 1.5625rem 6.25rem;
    }

    .wakuwaku__catch {
        font-size: 1.25rem;
    }

    .wakuwaku__catch::after {
        height: 1.375rem;
        right: 0.75rem;
        top: -0.5rem;
        width: 1.875rem;
    }

    .wakuwaku__title {
        margin-top: 1.25rem;
    }

    .wakuwaku__title img {
        aspect-ratio: 760/150;
    }

    .wakuwaku__text {
        background-image: url("../images/features/features-list-bg_pc.png");
        margin-top: 1.875rem;
        padding: 0.625rem 3.125rem;
    }

    .wakuwaku__text::after {
        aspect-ratio: 93/113;
        background-image: url("../images/wakuwaku/wakuwaku-text-icon.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        bottom: -1.75rem;
        content: "";
        height: auto;
        max-width: 8.125rem;
        position: absolute;
        right: calc(50% - min(39vw, 32rem));
        width: 100%;
        z-index: 1;
    }

    .wakuwaku__text span {
        font-size: 1.125rem;
        line-height: 312%;
    }

    .wakuwaku__text.u-desktop {
        display: block;
    }

    .wakuwaku__list {
        margin-left: auto;
        margin-right: auto;
        margin-top: 6.25rem;
        max-width: 80rem;
        width: 100%;
    }

    .wakuwaku__item {
        flex-direction: row;
        gap: 2.5rem;
        justify-content: flex-end;
        margin-right: calc((100% - 100vw) / 2);
    }

    .wakuwaku__item:nth-child(2) {
        flex-direction: row-reverse;
        justify-content: flex-start;
        margin-left: calc((100% - 100vw) / 2);
        margin-right: 0;
    }

    .wakuwaku__item:nth-child(3) {
        gap: 2.5rem;
    }

    .wakuwaku__item-body {
        padding-left: 0;
        padding-right: 0;
        padding-top: 0;
    }

    .wakuwaku__item-body::after {
        height: 7.25rem;
        top: -2rem;
        width: 11.1875rem;
    }

    .wakuwaku__item:first-child .wakuwaku__item-body::after {
        right: 0.375rem;
        top: -5.875rem;
    }

    .wakuwaku__item:nth-child(2) .wakuwaku__item-body::after {
        top: -1.5625rem;
    }

    .wakuwaku__item:nth-child(3) .wakuwaku__item-body::after {
        right: 2.5rem;
        top: -2.5rem;
    }

    .wakuwaku__item-catch {
        font-size: 0.9375rem;
    }

    .wakuwaku__item-title {
        font-size: 1.75rem;
        white-space: normal;
    }

    .wakuwaku__item-text {
        font-size: 1rem;
    }

    .wakuwaku__item-img {
        flex-shrink: 0;
        max-width: 37.5rem;
    }

    .wakuwaku__item-img img {
        aspect-ratio: 600/500;
    }

    .wakuwaku__cta {
        margin-top: 11.25rem;
    }

    .wakuwaku__cta-inner {
        background-image: url("../images/features/features-list-bg_pc.png");
        padding: 2.625rem 3.59375rem 4rem;
    }

    .wakuwaku__cta-contents {
        align-items: center;
        flex-direction: row;
        gap: 3.75rem;
        justify-content: space-between;
    }

    .wakuwaku__cta-img::before {
        content: none;
    }

    .wakuwaku__cta-img::after {
        content: none;
    }

    .wakuwaku__cta-img {
        margin-top: -8rem;
    }

    .wakuwaku__cta-img img {
        aspect-ratio: 450/550;
        max-width: 28.125rem;
    }

    .wakuwaku__cta-body::before {
        background-image: url("../images/wakuwaku/wakuwaku-cta-icon1.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        content: "";
        height: 5.8125rem;
        left: -3.5rem;
        position: absolute;
        top: -4.5rem;
        width: 5.5625rem;
    }

    .wakuwaku__cta-body::after {
        background-image: url("../images/wakuwaku/wakuwaku-cta-icon2.png");
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        bottom: -5.625rem;
        content: "";
        height: 10.9375rem;
        position: absolute;
        right: -2.5rem;
        width: 6.4375rem;
    }

    .wakuwaku__cta-label {
        font-size: 1.25rem;
    }

    .wakuwaku__cta-title {
        margin-top: 0.625rem;
    }

    .wakuwaku__cta-title img {
        aspect-ratio: 480/76;
        max-width: 30rem;
    }

    .wakuwaku__cta-text {
        font-size: 1rem;
        margin-top: 0.375rem;
        text-align: center;
    }

    .wakuwaku__cta-btn {
        margin-top: 1.875rem;
    }

}

@media screen and (min-width: 768px) and (min-width: 1280px) {

    .wakuwaku__item {
        margin-left: 5.625rem;
        margin-right: 0;
    }

    .wakuwaku__item:nth-child(2) {
        margin-left: 0;
        margin-right: 5.625rem;
    }

}

@media (min-width: 1140px) {

    html {
        font-size: 16px;
    }

}

@media (max-width: 375px) {

    html {
        font-size: 4.2666666667vw;
    }

}

/* 251226 EL k.saito 追加 */
@media screen and (max-width: 767px) {
    .to-top {
        bottom: 4rem;
        position: fixed;
        right: -2rem;
        z-index: 100;

        a {
            display: block;

            img {
                -o-object-fit: contain;
                aspect-ratio: 1/1;
                height: auto;
                max-width: 7.5rem;
                object-fit: contain;
                width: 67%;
            }
        }
    }

}

/*# sourceMappingURL=style.css.map */