@media screen and (max-width:767px) {
    .pc {
        display: none !important;
    }

    .sp {
        display: block !important;
    }

    .wrapper {
        width: 82%;
    }

    body,
    p {
        font-size: 14px;
    }

    .modal-cookie {
        padding: 20px;
    }

    .modal-flex {
        justify-content: space-between;
        align-items: flex-end;
        flex-direction: column;
        font-size: 14px;
    }

    .modal-flex p {
        font-size: 12px;
    }

    a.cookie-close-btn {
        padding: 5px 30px;
        background-color: #D9A8B2;
        border-radius: 10px;
        border: 1px solid #D9A8B2;
        transition: all .5s ease;
    }

    /*--------------------------------------------------------------
# header
--------------------------------------------------------------*/

    .top-header {
        left: 5vw;
    }

    .logo {
        width: 200px;
    }

    .kv-img {
        height: 90svh;
    }

    .menu-wrap.sp {
        left: auto;
        bottom: auto;
    }

    .menu-wrap.sp .menu::before {
        background: #fff;
    }

    .menu-wrap {
        display: flex !important;
        position: fixed;
        top: 0;
        right: -100%;
        left: 0;
        /* 初期状態では画面の外に隠れている */
        width: 100vw;
        height: 100dvh;
        background-color: #D29EAA;
        color: #fff;
        transition: right 0.5s ease;
        /* スライドインのアニメーション */
        padding: 20px;
        box-sizing: border-box;
        z-index: 999;
    }

    .menu-wrap.open {
        right: 0;
    }

    /* ボタンのスタイル */
    .hamburger {
        position: fixed;
        top: 18px;
        right: 20px;
        width: 35px;
        cursor: pointer;
        z-index: 20;
    }

    .hamburger-logo {
        position: absolute;
        bottom: 12vh;
        left: 9vw;
		max-width: 72vw;
        width: 300px;
    }

    .hamburger span {
        display: block;
        height: 2px;
        width: 100%;
        background-color: #3B4043;
        margin: 13px 0;
        transition: 0.4s;
        border-radius: 999px;
    }

    .hamburger.active span {
        background-color: #fff;
    }

    /* バツ印に変化するスタイル */
    .hamburger.active span:nth-child(1) {
        transform: rotate(45deg) translate(11px, 11px);
    }

    .hamburger.active span:nth-child(2) {
        opacity: 0;
    }

    .hamburger.active span:nth-child(3) {
        transform: rotate(-45deg) translate(10px, -10px);
    }

    .menu,
    .menu-wrap.sp li {
        font-size: 20px;
        filter: none;
    }

    .menu-wrap.sp li {
        margin-bottom: 25px;
        margin-left: 26px;
    }

    .menu-wrap.sp li:nth-child(5) {
        margin-bottom: 25px;
    }

    .menu-wrap.sp li:last-child {
        margin-bottom: 0;
    }

    .rl-text.menu {
        margin: 17vh 0 22vh 9vw;
    }

    .menu-wrap.sp ul {
        margin-top: 17vh;
    }

    .menu-wrap.sp .address-wrap {
        position: absolute;
        bottom: 0;
        left: 0;
    }

    .menu-wrap.sp .sns-wrap a:first-child {
        margin-right: 5px;
    }

    .address-wrap {
        height: 10svh;
        padding: 0 15px;
    }

    .address-content {
        justify-content: space-between;
        font-size: min(3.2vw, 14px);
        align-items: flex-end;
    }

    .address {
        align-items: center;
        letter-spacing: 2px;
        width: 70%;
    }

    .address img {
        height: 14px;
    }

    .address-content .sns-wrap {
        width: 20%;
    }

    .address-content .sns-wrap img {
        height: min(5.87vw, 33px);
    }

    .address-content .sns-wrap a:first-child {
        margin-right: 10px;
    }

    /*--------------------------------------------------------------
# concept-slider
--------------------------------------------------------------*/

    .concept-section {
        margin-bottom: 38vw;
    }

    .text-concept {
        padding-bottom: 0.5em;
    }

    .concept-content h2 {
        font-size: min(5.64vw, 26px);
        margin-top: 0.5em;
    }

    .concept-logo {
        margin-top: 30vw;
    }

    .concept-logo img {
        width: 84vw;
    }

    /*--------------------------------------------------------------
# about
--------------------------------------------------------------*/
    .about-section {
        margin-bottom: 0;
    }

    .top .wrapper {
        width: 85vw;
        margin: 0 auto;
    }

    .top .gallery-section .wrapper,
    .top .media-section .wrapper {
        width: 90vw;
    }

    /*  .about_01-img {
        width: 91vw;
        translate: -6%;
    }

    .about-02 {
        flex-direction: column;
    }
 */

    .about_01-img {
        margin-right: -5%;
        width: 70%;
    }

    .flex-about-img {
        gap: 20px;
        margin-top: 110px;
    }

    .about_05-img,
    .about_06-img,
    .about_07-img {
        width: 28%;
    }

    .about_05-img {
        margin-top: -30%;
        margin-bottom: 30%;
    }

    .about_06-img {
        margin-top: -15%;
        margin-bottom: 15%;
    }

    .about-02 {
        flex-direction: column;
        align-items: center;
    }

    .about_02-img-wrap {
        text-align: center;
        width: 100%;
    }

    .about_02-img {
        width: 85%;
        margin-top: 0;
        margin-right: 0;
        margin-left: 0;
    }

    .about_08-img {
        width: 50%;
        margin-top: 14%;
        margin-right: 5%;
    }

    .about-content {
        width: 100%;
        padding: 0;
        justify-content: center;
        flex-direction: column;
        margin: 0 0 90px
    }

    .about-content .side-title {
        margin-bottom: 1em;
    }

    .text-content {
        margin-left: 0;
    }

    main .rl-text {
        writing-mode: horizontal-tb;
    }

    span.pink-title {
        font-size: 16px;
    }

    .about-content span.pink-title,
    .school-content span.pink-title {
        font-weight: 700;
    }

    .pink-title::before {
        width: 3em;
        height: 1px;
        margin-bottom: 0.3em;
        margin-right: 1em;
    }

    .section-title {
        margin: 1em 0;
        font-size: 20px;
    }

    .more-btn {
        padding: 10px 56px;
    }

    .about-content .more-btn {
        position: relative;
        margin: 0;
    }

    .btn-wrap {
        text-align: center;
        margin-top: 40px;
    }

    .section-text {
        line-height: 2;
    }

    /*  .about_02-img {
        translate: 3%;
        width: 60vw;
    }

    .about-03 {
        flex-direction: column;
        margin: 95px 0 0;
    }

    .about_03-img {
        translate: 30%;
        width: 82.5vw;
        margin-bottom: 120px;
    }

    .about_04-img {
        translate: -15%;
        width: 82vw;
    } */


    /*--------------------------------------------------------------
# school
--------------------------------------------------------------*/
    .school-section {
        margin-bottom: 140px;
    }

    .school-content .side-title {
        margin-bottom: 1em;
    }

    .school-01 {
        flex-direction: column;
        gap: 0;
    }

    .school_01-img {
        width: 100%;
        margin-top: 100px;
        aspect-ratio: 3 / 2;
    }

    .school-content {
        flex-direction: column;
        width: 100%;
        margin: 40px 0 74px;
    }

    .flex-school-img {
        flex-direction: column;
        translate: -9vw;
        margin-top: 0;
    }

    .school_03-img {
        margin-left: 24%;
    }

    .school_05-img {
        margin-top: 16%;
        margin-right: 0%;
        margin-left: 6%;
        width: 50%;
    }

    .school-content .more-btn {
        position: relative;
    }

    /*  .school_01-img {
        translate: -16%;
        width: 59vw;
    }

    .school_02-img-wrap {
        translate: 9.25% 0%;
        margin-top: 60px;
    }

    .school_02-img {
        translate: -8%;
        width: 51.2vw;
    }
 */


    /*--------------------------------------------------------------
# gallery
--------------------------------------------------------------*/
    .gallery-section {
        padding: 80px 0;
    }

    .section-title {
        margin: 0 0 16px;
    }

    .gallery-section .pink-title {
        margin-bottom: 0;
    }

    .gallery-section ul {
        margin: 50px 0;
    }

    .gallery-content {
        width: 49%;
        margin-bottom: 6px;
    }

    /*--------------------------------------------------------------
# media
--------------------------------------------------------------*/
    .media-section {
        padding: 80px 0;
    }

    .media-section .side-title {
        position: relative;
    }

    .media-section .pink-title {
        display: block;
        margin-bottom: 0;
    }

    .media-section .pink-title::before,
    .news-section .pink-title::before {
        display: none;
    }

    .media-section .side-title,
    .news-section .side-title {
        transform: none;
        left: 0;
        text-align: center;
    }

    .media-section h2 {
        font-size: 20px;
        font-family: "FOT-TsukuMinPro-D", sans-serif;
        font-weight: 600;
        text-align: center;
        margin-bottom: 40px;
        opacity: 0;
    }

    .media-section ul {
        gap: 2%;
    }

    .media-content-wrap {
        width: 100%;
        flex-wrap: wrap;
        translate: none;
    }

    .media-content {
        width: 49%;
        margin-bottom: 30px;
    }

    .media-text-wrap {
        padding: 0;
    }

    .media-section .date {
        font-size: 12px;
        margin: 6px 6px 6px 0;
    }

    .media-text {
        font-size: 12px;
        margin-left: 0;
    }

    .media-section .more-btn,
    .news-section .more-btn.sp {
        display: block;
        width: 210px;
        margin: 50px auto 0;
    }

    .media-section .more-btn {
        margin: 30px auto 0;
    }

    .media-icon {
        margin-left: 0;
    }

    /*--------------------------------------------------------------
# news
--------------------------------------------------------------*/
    .news-section {
        padding: 80px 0;
    }


    .news-section .side-title {
        position: relative;
    }

    .news-content-wrap {
        flex-direction: column;
    }

    .news-section ul {
        width: 100%;
    }

    .news-section ul a {
        flex-direction: column;
        padding: 20px 0;
    }

    .news-section .date {
        margin-bottom: 0.5em;
        font-size: 12px;
    }

    .post-pagination-wrapper .pagination {
        gap: 10px;
    }

    .post-pagination-wrapper .pagination li a,
    .post-pagination-wrapper .pagination li span {
        padding: 6px 5px;
    }

    /*--------------------------------------------------------------
# contact
--------------------------------------------------------------*/
    .contact-section {
        padding: 94px 0;
    }

    .contact-section .wrapper {
        width: 90vw;
    }

    .contact-content {
        padding: 30px 10px;
    }

    .contact-section .text-concept {
        font-size: 12px;
        width: 70%;
    }

    .contact-section h2 {
        font-size: 20px;
        margin: 0.5em;
    }

    .contact-content p {
        font-size: 12px;
    }

    .contact-section .more-btn {
        font-size: 14px;
    }

    .top-btn {
        right: 5px;
    }

    .footer-area .top-btn .more-btn {
        font-size: 14px;
        padding: 1.5em;
    }

    /*--------------------------------------------------------------
# footer
--------------------------------------------------------------*/
    .footer-area {
        padding: 20px 9%;
    }

    .footer-content {
        text-align: left;
    }

    .footer-text {
        font-size: 14px;
    }

    .footer-nav-flex {
        display: flex;
        gap: 30px;
    }

    .footer-nav {
        flex-direction: column;
        font-size: 15px;
        gap: 1em;
        margin-bottom: 30px;
    }

    .footer-nav.top {
        padding-left: 1em;
        border-left: 1px solid #fff;
    }

    .footer-nav.bottom.sp {
        display: block;
    }

    .footer-nav.bottom li {
        font-size: 12px;
        margin-bottom: 15px;
    }

    .footer-nav.bottom li:last-child {
        margin-bottom: 0;
    }

    .footer-area .sns-wrap {
        text-align: center;
        margin: 0 0 30px;
        /* position: absolute;
        bottom: 18%;
        right: 0; */
        /* gap: 20px; */
    }

    .footer-area .sns-wrap img {
        height: 25px;
    }

    .copy-right {
        position: relative;
        font-size: 12px;
        transform: none;
        right: auto;
    }

    .footer-logo {
        width: 206px;
        margin: 30px 0;
    }


    /*--------------------------------------------------------------
# 404
--------------------------------------------------------------*/
    .error-404 .wrapper {
        padding: 100px 0;
    }

    .not-found {
        font-size: 30px;
    }

    .error-404 p {
        font-size: 14px;
    }




    /*--------------------------------------------------------------
# observer-animation
--------------------------------------------------------------*/
    .about_08-img.is-show {
        animation: fadeIN-right 2s forwards;
    }

    .about_02-img.is-show,
    .school_05-img.is-show {
        animation: fadeIN-left 2s forwards;
    }

    .media-animation-wrap.is-show,
    .news-content-wrap.is-show {
        animation-delay: 0s;
    }



}