@charset "UTF-8";

/*!header-----------------------------------------------------------------------*/
.pc-header-nav {
    display: none;
}

/*!全体ハンバーガー*/
/* overlay-styles.css */
.hamburger-overlay {
    position: fixed;
    top: 0px;
    right: 5px;
    z-index: 1000;
    width: 48px;
    height: 48px;
    border: none;
    background: transparent;
    cursor: pointer;
}

.hamburger-overlay-line {
    position: absolute;
    left: 11px;
    width: 26px;
    height: 2px;
    background-color: #333;
    transition: all .6s;
}

.hamburger-overlay-line:nth-of-type(1) {
    top: 14px;
}

.hamburger-overlay-line:nth-of-type(2) {
    top: 23px;
}

.hamburger-overlay-line:nth-of-type(3) {
    top: 32px;
}

.hamburger-overlay.active .hamburger-overlay-line {
    background-color: #333;
}

.hamburger-overlay.active .hamburger-overlay-line:nth-of-type(1) {
    transform: translateY(9px) rotate(-45deg);
}

.hamburger-overlay.active .hamburger-overlay-line:nth-of-type(2) {
    opacity: 0;
}

.hamburger-overlay.active .hamburger-overlay-line:nth-of-type(3) {
    transform: translateY(-9px) rotate(45deg);
}

.sp-nav-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: #EBC3EB;
    visibility: hidden;
    opacity: 0;
    transition: all .6s;
    z-index: 900;
}

.sp-nav-overlay.active {
    visibility: visible;
    opacity: 1;
}

.sp-nav-overlay-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    text-align: center;
}

.sp-nav-overlay-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.sp-nav-overlay-item {
    opacity: 0;
    transform: translateY(20px);
    transition: all .6s;
}

.sp-nav-overlay.active .sp-nav-overlay-item {
    opacity: 1;
    transform: translateY(0);
}

.sp-nav-overlay.active .sp-nav-overlay-item:nth-child(1) {
    transition-delay: 0.1s;
}

.sp-nav-overlay.active .sp-nav-overlay-item:nth-child(2) {
    transition-delay: 0.2s;
}

.sp-nav-overlay.active .sp-nav-overlay-item:nth-child(3) {
    transition-delay: 0.3s;
}

.sp-nav-overlay.active .sp-nav-overlay-item:nth-child(4) {
    transition-delay: 0.4s;
}

.sp-nav-overlay.active .sp-nav-overlay-item:nth-child(5) {
    transition-delay: 0.5s;
}

.sp-nav-overlay.active .sp-nav-overlay-item:nth-child(6) {
    transition-delay: 0.6s;
    margin-bottom: 20px;
}

.sp-nav-overlay.active .sp-nav-overlay-item:nth-child(7) {
    transition-delay: 0.7s;
}

.sp-nav-overlay-link {
    display: inline-block;
    margin-bottom: 15px;
    color: #333;
    font-size: 16px;
    text-decoration: none;
    transition: color .3s;
}

.sp-nav-overlay-link:hover {
    color: #eeb5ee;
}

.sp-nav-item-bold {
    font-weight: 800;
    font-size: 25px;
}

.sp-header-btn {
    background: linear-gradient(90deg, #EBC3EB, #fff);
    border: solid 2px #B986AE;
    border-radius: 30px;
    position: relative;
    transition: all 1s ease-out;
    text-align: center;
    width: 100%;
    max-width: 250px;
    margin: auto;
    margin-bottom: 30px;
    cursor: pointer;
    padding: 15px 0;
}

.sp-header-btn a {
    display: block;
    color: #333;
    text-decoration: none;
    font-size: 16px;
    font-weight: bold;
    position: relative;
    margin-bottom: 0;
}

.sp-header-btn::before {
    background: linear-gradient(90deg, #fff, #EBC3EB);
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transition: all 1s ease-out;
    width: 100%;
    border-radius: 30px;
}

.sp-header-btn:hover::before {
    opacity: 0;
}




/*!main----------------------------------------------------------------------------------------*/



/*!section-fa-view--------------------*/

.hidden-area {
    overflow: hidden;
}

.fa-view {
    padding-top: 0;
}

.fa-view-womans {
    position: relative;
}

.fa-view-img img {
    position: absolute;
    object-fit: contain;
}

/*!ピンク*/
.fa-view-img img:nth-child(1) {
    width: 40%;
    /* right: 50px; */
    /* bottom: 50px; */
    transform: translateX(120%) translateY(-120%);
    z-index: 3;
}

/*!パープル*/
.fa-view-img img:nth-child(2) {
    width: 64%;
    transform: translateX(74%) translateY(-165%);
    z-index: 1;
}

/*!ブルー*/
.fa-view-img img:nth-child(3) {
    width: 95%;
    /* left: -40px; */
    /* bottom: 0; */
    transform: translateX(-10%) translateY(-100%);
    z-index: 2;
}

/*!テーマフェードイン*/
.mj img {
    opacity: 0;
    transition: opacity 1s ease-in-out;
}

.visually-hidden {
    position: absolute;
    visibility: hidden;
}


/*!section-concept--------------------*/
.concept {
    padding-top: 0;
}

.section-title-concept {
    padding-top: 80px;
}

.concept-slide {
    overflow: hidden;
}

.concept-slide ul {
    display: flex;
    margin: 0;
    padding: 0;
    width: max-content;
}

.concept-slide ul li {
    list-style: none;
    width: calc(100vw / 4 - 10px);
    /* 写真の枚数にあわせる */
}

.concept-slide img {
    display: block;
    width: 100%;
}

.concept-text {
    margin-bottom: 80px;
}

.concept-text h3 {
    margin: 0;
    margin-bottom: 30px;
}


.concept-catch-item {
    border-left: 2px solid #C73C86;
    font-size: 16px;
    padding-left: 10px;
}

.concept-text p {
    text-align: justify;
    line-height: 1.4;
}


.concept-top-border {
    border-top: solid 1px #C73C86;
    margin-top: 10px;
}

.concept-bottom-border {
    border-top: solid 1px #C73C86;
    margin-bottom: 10px;
}

/*!section-theme--------------------*/


.theme {
    background-image: url(../img/theme-sp3.webp);
    background-size: cover;
    background-repeat: no-repeat;
    height: 820px;
    background-position: center top;
    position: relative;
    filter: brightness(110%);
    /* 150%にすると明るくなります (100%が標準) */
}

.theme::after {
    position: absolute;
    content: '';
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    box-shadow: inset 0px -10px 10px rgb(255, 255, 255);
}

.theme-text {
    padding: 10px;
    background-color: #ffffffaa;
    width: 100%;
    max-width: 370px;
    margin: auto;
    text-align: justify;
    line-height: 1.5;
}


.theme-text h3 {
    text-align: center;
    font-size: 32px;
}

.theme-text rt {
    font-size: 14px;
}

.global-color {
    color: #0053B7;
}

.local-color {
    color: #f55c00;
}

.theme-img {
    position: relative;
    height: 420px;
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
}

.theme-img img {
    position: absolute;
    object-fit: contain;
    /* filter: blur(10px); */
    /* ぼかし効果 */
    /* 下半分だけ表示 */
}


.theme-img img:nth-child(1) {
    width: 40%;
    right: 10%;
    bottom: -.1%;
    z-index: 3;
}

.theme-img img:nth-child(2) {
    width: 53%;
    left: 10%;
    bottom: 0%;
    z-index: 2;
}

.theme-img img:nth-child(3) {
    width: 30%;
    left: 40%;
    bottom: 40%;
    z-index: 1;
}

/*!テーマフェードイン*/
.mv img {
    opacity: 0;
    transition: opacity .5s ease-in-out;
}


/*!section-overview--------------------*/

.overview {
    margin-bottom: 50px;
}

.overview-sub-title h4 {
    font-size: 20px;
}

.big-border {
    border: 1px solid #833688;
    margin-top: 20px;
}

.overview-sub-title {
    background-color: #833688;
    color: #fff;
    text-align: center;
    padding: 1px 0;
}

.overview-sub-title p {
    font-size: 20px;
}

.overview-text-center {
    text-align: center;
    margin: 20px;
}

/* 全体ボックス */
.highlight.big-border {
    margin: 40px 0;
    background: #fff;
    padding: 0;
}

/* 見出し「ハイライト」 */
.overview-sub-title {
    background: #833688;
    padding: 15px 0;
    text-align: center;
    color: #fff;
}

.overview-sub-title h4 {
    font-size: 20px;
    margin: 0;
}

/* 各figureブロック */
.figure-1st,
.figure-2nd {
    margin: 40px 20px;
}

.highlight-figure img {
    border: solid 1px #833688;
    padding: 5px;
}

/* キャプション部分 */
.highlight-figcaption {
    margin-top: 20px;
    /* width: 40%; */
}

/* 小見出しの装飾（左の赤いラインなど）*/
.highlight-figcaption h4 {
    font-size: 18px;
    margin-bottom: 10px;
    padding-left: 10px;
    border-left: 4px solid #C73C86;
    /* line-height: 1.4; */
    margin-left: 0;
    text-align: justify;
}

.highlight-h4-first-span {
    font-size: 12px;
    vertical-align: top;
}

/* 段落 */
.highlight-figcaption p {
    font-size: 14px;
    line-height: 1.75;
    white-space: pre-line;
    text-align: justify;
}


.application {
    padding: 0 20px 20px 20px;
    line-height: 1.75;
}

.application-title {
    text-align: center;
    font-weight: 600;
    background: linear-gradient(90deg, #c73c86 21%, #833688 91%);
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* .application-caption {
    text-align: justify;
    line-height: 2;
} */

/* .application-color {
    color: #f00;
    font-weight: 600;
    border-bottom: 2px double #3c3c3c;
} */

.application-list {
    list-style: disc;
    padding-left: 1.5em;
    line-height: 1.8;
    font-size: 14px;
    text-align: justify;
    margin-bottom: 30px;
}

.application-list li {
    margin-bottom: 15px;
    /* ← li同士の間隔を広げる */
}

.application-list .important {
    color: #e60000;
    /* 赤文字 */


}

.important a {
    text-decoration: none;
    color: #e60000;
    border-bottom: 2px double #e60000;
}

.schedule-content {
    /* width: 100%; */
    max-width: 100%;
    margin: 20px;

}

.schedule-item {
    margin: 30px 0;
    position: relative;
    list-style: none;
}

.schedule-contents-list-item li:first-child>br {
    display: none;
}


.schedule-item>p:first-of-type {
    font-size: 20px;
    font-weight: 600;
    position: relative;
    display: inline-block;
    padding-top: 10px;
    margin-left: 20px;
}

.schedule-item>p:first-of-type::before {
    content: "◆";
    color: #7d2c89;
    font-size: 1rem;
    position: absolute;
    bottom: 1px;
    transform: translateX(-120%);
}

/* 時間部分 */


.schedule-item p:first-child {
    margin-bottom: 10px;
}

.schedule-item p:nth-of-type(2) {
    font-size: 16px;
    line-height: 1.4;
    padding-left: 40px;
}

.schedule-item span {
    font-size: 12px;
    line-height: 1.4;
}

.schedule-item p:nth-of-type(3) {
    margin-top: 8px;
    font-size: 16px;
    padding-left: 40px;
}

/* #st {
    font-size: 16px;
    letter-spacing: 3px;
    padding-left: 2.5px;
} */

.st {
    letter-spacing: 3px;
    padding-left: 2.5px;
}

.schedule-content .schedule-item P>span {
    font-size: 16px;
}

.schedule-contents-list {
    padding-left: 30px;
    list-style: none;

}

/*  */

.schedule-contents-list p {
    font-size: 16px;
    border-bottom: 2px solid #000;
    width: 70px;
    margin-bottom: 10px;
    margin-left: 4%;
    padding-bottom: 2px;
    text-align: center;
}

.schedule-contents-list-item {
    font-size: 0.8rem;
    border: 1px solid #000;
    border-top: none;
    border-bottom: none;
    list-style: none;
    padding: 10px 0 10px 4%;
}

.schedule-contents-list-item li {
    text-indent: -4rem;
    padding-left: 4rem;
    line-height: 1.3;
}

.schedule-contents-list-item:last-child li {
    margin-bottom: 10px;
}

.schedule-contents-list-item li:nth-child(7) {
    margin-bottom: 0;
}

/* .schedule-contents-list-item li:nth-child(1){
    margin-bottom: 0;
}

.schedule-contents-list-item li:nth-child(5){
    margin-bottom: 0;
} */


/*  */

.map-name {
    font-size: 16px;
    margin-bottom: 20px;
    line-height: 1.5;
}

.side-star {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 5px;
    font-size: 16px;
    font-weight: bold;
}

.side-star::before,
.side-star::after {
    content: "◆";
    color: #7d2c89;
    font-size: 1rem;
}

.side-star::after {
    transform: translateX(50%) translateY(10%);
}

.side-star::before {
    transform: translateX(-50%) translateY(10%);
}


.btn {
    background: linear-gradient(90deg, #EBC3EB, #fff);
    border: solid 2px #B986AE;
    border-radius: 30px;
    position: relative;
    transition: all 1s ease-out;
    text-align: center;
    width: 100%;
    max-width: 250px;
    margin: auto;
    padding: 20px 0;
    margin-bottom: 30px;
    cursor: pointer;
}

.btn a {
    display: block;
    color: #333;
    text-decoration: none;
    font-size: 16px;
    font-weight: bold;
}

.btn a {
    position: relative;
}

.btn::before {
    background: linear-gradient(90deg, #fff, #EBC3EB);
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transition: all 1s ease-out;
    width: 100%;
    border-radius: 30px;
}

.btn:hover::before {
    opacity: 0;
}

.google-map-img {
    width: 90%;
    max-height: 300px;
    margin: auto;
}

.google-map {
    max-height: 250px;
}

/*!カーテンスライド部分*/

.animation {
    position: relative;
    overflow: hidden;
}

.animation::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(90deg, #B986AE 0%, #B986AE 100%);
    transform: translatex(-100%);
}

@keyframes showMask {
    0% {
        transform: translateX(-100%);
    }

    45%,
    50% {
        transform: translate(0%);
    }

    100% {
        transform: translateX(100%);
    }
}

.animation.show::before {
    animation: showMask 1.5s forwards;
}

.animation .photo-inner {
    opacity: 0;
}

@keyframes showElements {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

.animation.show .photo-inner {
    animation: showElements .01s .6s forwards;
}

/*!縦スライド*/
.side-scrolling-area {
    display: none;
}

.press-box-text p {
    font-size: 18px;
    font-style: normal;
}




/*!section-live--------------------*/
.live-title {
    text-align: center;
    font-size: 25px;
    margin-bottom: 30px;
    position: relative;
}

.live-title::before {
    content: "\\";
    position: absolute;
    transform: translateX(-200%);
    top: 0px;
    font-size: 50px;
}

.live-title::after {
    content: "/";
    position: absolute;
    transform: translateX(200%);
    top: 0px;
    font-size: 50px;
}

.live-img {
    width: 100%;
    /* max-width: 350px; */
    margin: auto;
    margin-bottom: 30px;
}

.live-img img {
    width: 100%;
    border: solid 1px #833688;
    padding: 5px;
}

.live-text-caption {
    font-size: 14px;
    line-height: 1.4;
    text-align: center;
    width: 100%;
    max-width: 320px;
    margin: auto;
    margin-bottom: 30px;
}

.live-date {
    text-align: center;
    margin-bottom: 30px;
    font-size: 16px;
    font-weight: bold;
    align-items: baseline;
    position: relative;
}

.live-date::before,
.live-date::after {
    content: "◆";
    color: #7d2c89;
    font-size: 1rem;
    position: absolute;
}

.live-date::after {
    transform: translateX(50%) translateY(25%);
}

.live-date::before {
    transform: translateX(-150%) translateY(25%);
}

.live-text {
    margin-bottom: 50px;
}

.instagram-btn {
    border-radius: 60px;
    background: linear-gradient(90deg, #ecbf81, #d3928d, #b987c5, #ab9ace);
}

.instagram-btn::before {
    border-radius: 60px;
    background: linear-gradient(90deg, #ab9ace, #b987c5, #d3928d, #ecbf81);
}

.instagram-btn a {
    color: #fff;
}

.live-title span {
    background: linear-gradient(90deg, #7659af, #b987c5, #d3928d, #dea14a);
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 700;
}

.live-date span {
    background: linear-gradient(90deg, #7659af, #b987c5, #d3928d, #dea14a);
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/*!section-comment--------------------*/
.comment {
    background-image: url(../img/comment-back.webp);
    background-repeat: no-repeat;
    background-position: center;
    background-color: rgba(255, 255, 255, 0.8);
    background-blend-mode: lighten;
    padding-bottom: 50px;
}

.comment-div {
    border: 1px solid #833688;
    width: 100%;
    margin: auto;
}

.comment-figure {
    margin: 20px;
}

.comment-img {
    width: 100%;
    max-width: 250px;
    margin: auto;
    margin-bottom: 20px;
}

.comment-img img {
    width: 100%;
}

.commenter-name {
    text-align: center;
    font-weight: bold;
    margin-bottom: 30px;
}

.commenter-name-text {
    /* font-size: 20px; */
    border-bottom: #333 1px solid;
    /* padding: 0 10px 3px; */
}

.comment-figcaption {
    width: 100%;
    max-width: 350px;
    margin: auto;
    line-height: 1.5;
}

.comment-figcaption p:nth-child(2) {
    font-size: 16px;
    line-break: loose;
    text-align: justify;
    line-height: 1.5;
}

.comment-discipline {
    font-size: 12px;
}

/*!footer----------------------------------------------------------------------------------------*/

footer {
    background-image: url(../img/footer-back.webp);
    background-size: cover;
    background-repeat: no-repeat;
    padding: 50px 0 80px;
}

.footer-address {
    width: 100%;
    max-width: 300px;
    margin: auto;
}

.footer-address img {
    width: 100%;
    max-width: 300px;
    margin: auto;
    margin-bottom: 5px;
}

.school-department {
    font-family: sans-serif;
    font-weight: bold;
    margin-bottom: 30px;
}

.child-school-department {
    font-size: 11px;
}

address p {
    font-size: 14px;
    width: 100%;
    max-width: 300px;
    /* margin: auto; */
    margin-bottom: 20px;
}

.sns-link-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px;
}

.sns-link-icon a+a {
    padding-left: 30px;
}

.sns-link-icon img {
    width: 100%;
    max-width: 50px;
    margin: auto;
}

small {
    text-align: center;
}

small p {
    font-size: 10px;
}

/*!btn-scroll-hidden-footer*/
.fixed-content {
    position: fixed;
    bottom: 5px;
    right: 5px;
    pointer-event: all;
    z-index: 899;
    /* 重要 */
}

.fixed-content a {
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    max-width: 150px;
}

.btn-wrap a:nth-child(2) {
    background: #041b68;
}

.hidden {
    animation: scrollIn .5s ease-in-out forwards;
    pointer-event: none;
}

@keyframes scrollIn {
    from {
        right: 10px;
    }

    to {
        right: -200px;
    }
}

.visible {
    animation: scrollOut .5s ease-in-out forwards;
    pointer-event: all;
}

@keyframes scrollOut {
    from {
        right: -160px;
    }

    to {
        right: 10px;
    }
}