@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Afacad:ital,wght@0,400..700;1,400..700&family=Shippori+Mincho:wght@400;500;600;700&family=Zen+Kaku+Gothic+Antique&display=swap');

html {
    font-size: 62.5%;
    background: linear-gradient(90deg,#FFF 0%, #A0D8EA 100%);
    background-attachment: fixed;
    background: #A0D8EA;
}
body {
    background-color: #FFF;
    font-family: "Zen Kaku Gothic Antique", sans-serif;
    font-size: 16px;
    font-size: 1.6rem;
    color: #000;
}

img {
    width: 100%;
    vertical-align: bottom;
}

.pc {
    display: block;
}
.sp {
    display: none;
}
@media print, screen and (max-width: 768px) {
    .pc {
        display: none;
    }
    .sp {
        display: block;
    }
}

/* ==============================
  ヘッダー　（FV)
============================== */
header {
    position: relative;
    overflow: hidden;
}

header .fv-wrapper {
    position: relative;
}
/* ロゴ */
header h2 {
    position: absolute;
    top: 5.9%;
    left: 3.5%;
    width: 16.19%;
    z-index: 5;
}
/* タイトル */
header h1 {
    position: absolute;
    top: 29%;
    left:18%;
    width: 43%;
    z-index: 5;
}
header h1 img {
    transition: clip-path 2s ease-out;

    clip-path: inset(0 100% 0 0);
    will-change: clip-path;
}
header h1.is-active img {
    clip-path: inset(0 0 0 0);
}

header h1 picture:first-of-type img {
    transition-delay: 0.5s;
}
header h1 picture:nth-of-type(2) img {
    transition-delay: 1.2s;
}
header h1 img.pc {
    transition-delay: 2.6s;
}

header .fv-text-wrapper {
    position: absolute;
    bottom: 15.3%;
    left: 13.85%;
    width: max-content;
    z-index: 1;
}
header .fv-text {
    background-image: url(../images/fv-text-bg.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    font-family: 'Shippori Mincho', serif;
    font-size: min(4.14rem, 2.16vw);
    font-weight: 600;
    letter-spacing: 0.1em;
    width: 18.2em;
    height: 2.53em;
    display: flex;
    justify-content: center;
    align-items: center;
}
header .fv-text p.date-text {
    background: linear-gradient(90deg, #A0D8EA 0%, #A878B1 100%);
     color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;

    transition: clip-path 1s ease-out;

    transition-delay: 0.6s;
    clip-path: inset(0 100% 0 0);
}
header .fv-text.is-active p.date-text {
    clip-path: inset(0 0 0 0);
}
header .fv-text-wrapper p.sub {
    color: #585656;
    font-size: min(1.97rem, 1.02vw);
    text-align: right;
    margin-top: 0.3em;
    margin-right: 4.81em;
}

header .fv-photo {
    width: 100%;
    z-index: -1;
    transition: opacity 0.8s ease;
    opacity: 0;
}
header .fv-photo.is-active {
    opacity: 1;
}

header .fv-bg-wrapper {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    opacity: 0.7;
    pointer-events: none;
    filter: blur(5px);
    transition: filter 1s ease-out;
    transition-delay: 0.8s;
}
header .fv-bg-wrapper.is-active {
    filter: blur(0);
}
header .fv-bg-wrapper .fv-bg-box {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}
header .fv-bg-wrapper .fv-bg-box.fv-bg-left {
    top: 9.7%;
    left: 0;
    right: auto;
    width: 38.07%;
}
header .fv-bg-wrapper .fv-bg-box.fv-bg-right {
    top: 29.3%;
    right: 0;
    left: auto;
    width: 53.3%;
}
header .fv-bg-wrapper .fv-bg-box.fv-bg-sp {
    display: none;
}

@media print, screen and (max-width: 768px) {
    /* ロゴ */
    header h2 {
        position: absolute;
        top: 5.1vw;
        left: 5.3vw;
        width: 35.2vw;
    }
    /* タイトル */
    header h1 {
        position: absolute;
        top: 13.9vw;
        right: 0;
        left:auto;
        width: 41.3vw;
        display: flex;
        flex-direction:row-reverse;
    }
    header h1 img {
        clip-path: inset(0 0 100% 0);
    }
    header h1 picture:first-of-type img {
        transition-delay: 0s;
    }
    header h1 picture:last-of-type img {
        transition-delay: 1s;
    }

    header .fv-text-wrapper {
        position: absolute;
        bottom: 14.4vw;
        left: -0.1vw;
        width: 102.1vw;
        z-index: 1;
    }
    header .fv-text {
        font-size: 5.6vw;
        width: 100%;
        height: 2.61em;
    }
    header .fv-text-wrapper p.sub {
        font-size: 2.6vw;
    }


    header .fv-bg-wrapper .fv-bg-box.fv-bg-left,
    header .fv-bg-wrapper .fv-bg-box.fv-bg-right {
        display: none;
    }
    header .fv-bg-wrapper .fv-bg-box.fv-bg-sp {
        display: block;
        top: 54.8vw;
        left: 0;
        right: 0;
        width: 100%;
    }
}


/* ==============================
  first-content
============================== */
.first-content {
    position: relative;
    display: flex;
    justify-content: flex-start;
    margin-top: -4.2%;
    padding-right: 10.6%;
    padding-bottom: 7.55%;
    padding-left: 17.8%;
    width: 71.56%;
}
.first-content .header-photo {
    position: relative;
    width: 46.9%;
}
.first-content .header-photo img {
    filter: blur(5px);
    transition: filter 1s ease-out;
}
.first-content .header-photo img:first-of-type {
    position: relative;
    width: 54.8%;
    margin-top: 6.8%;
    z-index: 1;
    transition-delay: 0s;
}
.first-content .header-photo img:last-of-type {
    width: 72.5%;
    position: absolute;
    top: auto;
    right: 0;
    bottom: 3.4%;
    z-index: 0;
    transition-delay: 0.2s;
}
.first-content .header-photo.is-active img {
    filter: blur(0);
}

.first-content .header-text {
    width: 44.3%;
    margin-left: 8.7%;
}
.first-content .header-text h3 {
    font-family: 'Shippori Mincho', serif;
    font-size: min(2.8rem, 1.34vw);
    color: #A878B1;
    line-height: 2.3;
    letter-spacing: 0.15em;
}
.first-content .header-text p {
    font-size: min(1.8rem, 0.93vw);
    line-height: 3;
    letter-spacing: 0.2em;
    color: #585656;
    margin-top: 3em;
}

@media print, screen and (max-width: 768px) {
    .first-content {
        flex-direction: column-reverse;
        margin-top: 0;
        padding-right: 0;
        padding-bottom: 41.6vw;
        padding-left: 0;
        width: 100%;
        position: relative;
        z-index: 2;
    }
    .first-content .header-photo {
        width: 94.8vw;
        margin: 12.3vw 0 0 auto;
    }
    .first-content .header-photo img:first-of-type {
        width: 45.4vw;
        margin-top: 0;
    }
    .first-content .header-photo img:last-of-type {
        width: 58vw;
        position: absolute;
        top: 14.2vw;
        right: 0;
        bottom: auto;
    }

    .first-content .header-text {
        width: 100%;
        margin-left: 0;
        text-align: center;
    }
    .first-content .header-text h3 {
        font-size: 4.5vw;
        line-height: 2.05;
    }
    .first-content .header-text p {
        font-size: 3.2vw;
        line-height: 2.9;
        letter-spacing: 0;
        margin-top: 2.5em;
    }
}

main {
    position: relative;
    background: linear-gradient(to right, #A0D8EA 3.6%, #CD9BD7 97.23%);
    padding: 0 0 6.5%;
    overflow: hidden;
}
main .main-bg-wrapper {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}
main .main-bg-wrapper .main-bg-box {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 0.8;
}
main .main-bg-wrapper .main-bg-box.main-bg-01 {
    top: -7.6vw;
    left: 0;
    width: 97.9%;
}
main .main-bg-wrapper .main-bg-box.main-bg-02 {
    top: auto;
    left: 0;
    bottom: 27.2vw;
    width: 99.7%;
}
main .main-bg-wrapper .main-bg-box.main-bg-03-sp,
main .main-bg-wrapper .main-bg-box.main-bg-04-sp {
    display: none;
}

section {
    position: relative;
    z-index: 1;
}
section h2 {
    font-family: "Afacad", sans-serif;
    font-size: min(4rem, 2.08vw);
    text-align: center;
    letter-spacing: 0.3em;
    color: #585656;
    width: 100%;
}
section h2::after {
    content: "";
    display: block;
    width: 1.55em;
    height: 1px;
    background: #585656;
    margin: 0.625em auto 0;

}
section h2 span.jp {
    display: block;
    font-size: min(1.4rem, 0.72vw);
    letter-spacing: 0.25em;
    margin-top: 0.71em;
}
section h2 + p {
    font-size: min(1.6rem, 0.83vw);
    text-align: center;
    width: 100%;
    margin-top: 1.5%;
    letter-spacing: 0.2em;
    color: #585656;
}
@media print, screen and (max-width: 768px) {
    main {
        padding: 0 0 25.8vw;
    }
    main .main-bg-wrapper {
        position: absolute;
        top: 0;
        right: 0;
        width: 100%;
        height: 100%;
        z-index: 0;
    }
    main .main-bg-wrapper .main-bg-box {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
    }
    main .main-bg-wrapper .main-bg-box.main-bg-01 {
        top: -2.9vw;
        right: 0;
        left: auto;
        width: 94.6vw;
    }
    main .main-bg-wrapper .main-bg-box.main-bg-02 {
        top: 173.9vw;
        left: 0;
        width: 100%;
    }
    main .main-bg-wrapper .main-bg-box.main-bg-03-sp {
        display: block;
        top: 1106.9vw;
        left: 0;
        width: 79.3vw;
    }
    main .main-bg-wrapper .main-bg-box.main-bg-04-sp {
        display: block;
        top: auto;
        bottom: 741.9vw;
        left: 0;
        width: 100%;
    }

    section {
        position: relative;
        z-index: 1;
    }
    section h2 {
        font-size: 8.6vw;
        color: #585656;
    }
    section h2::after {
        width: 16.6vw;
        margin: 0.68em auto 0;

    }
    section h2 span.jp {
        font-size: 3.2vw;
        margin-top: 0.21em;
    }
    section h2 + p {
        font-size: 3.7vw;
        margin-top: 6.4vw;
        line-height: 1.78;
    }
}

/* ==============================
  features
============================== */
#features {
    padding: 3.5% 0;
}
#features h2 {
    color: #FFF;
}
#features h2::after {
    background: #FFF;
}
#features h2 + p {
    color: #FFF;
    margin-top: 1.31em;
}

#features .three-box {
    display: flex;
    justify-content: center;
    margin-top: 3.17%;
}
#features .three-box .box {
    position: relative;
    background-color: #FFF;
    width: 20.1%;
    padding: 3.125% 1.9% 3.4% 2.1%;
    font-size: min(1.6rem, 0.83vw);
    box-sizing: border-box;
    background-image: url(../images/three-box-bg-head.png), url(../images/three-box-bg-foot.png);
    background-repeat: no-repeat;
    background-position: top right, bottom left;
    background-size: 100% auto;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#features .three-box .box.is-active {
    transform: translateY(0);
    opacity: 1;
}
#features .three-box .box + .box {
    margin-left: 2.29%;
}
#features .three-box .box .num {
    position: absolute;
    top: 1.11em;
    left: 1.05em;
    border: 1px solid transparent;
    border-radius: 50%;

    background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(180deg, #A0D8EA 0%, #A878B1 100%) border-box;
    width: 3.94em;
    height: 3.94em;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: min(2.2rem, 1.14vw);
}
#features .three-box .box .num span {
    font-family: "Afacad", sans-serif;
    background: linear-gradient(180deg, #A0D8EA 0%, #A878B1 100%);
    color: transparent;
   -webkit-background-clip: text;
   background-clip: text;
   -webkit-text-fill-color: transparent;
   text-fill-color: transparent;
}
#features .three-box .box h5 {
    font-family: "Shippori Mincho", serif;
    font-size: min(2rem, 1.04vw);
    line-height: 1.75;
    margin-top: 2em;
}
#features .three-box .box p {
    font-size: min(1.6rem, 0.83vw);
    line-height: 2.18;
    margin-top: 1em;
}

@media (min-width: 768px) {
    #features .three-box .box:first-of-type {
        transition-delay: 0s;
    }
    #features .three-box .box:nth-of-type(2) {
        transition-delay: 0.2s;
    }
    #features .three-box .box:last-of-type {
        transition-delay: 0.4s;
    }
}

@media print, screen and (max-width: 768px) {
    #features {
        padding: 16.6vw 0 27.1vw;
    }
    #features h2 + p {
        margin-top: 6.4vw;
    }

    #features .three-box {
        flex-direction: column;
        margin-top: 9.1vw;
    }
    #features .three-box .box {
        width: 89.2vw;
        margin: 0 auto;
        padding: 13.9vw 9.4vw 15vw 9.4vw;
        font-size:3.2vw;
        background-image: url(../images/three-box-bg-head-sp.png), url(../images/three-box-bg-foot-sp.png);
    }
    #features .three-box .box:last-of-type {
        background-position: top left, bottom -1px right;
    }
    #features .three-box .box + .box {
        margin-left: auto;
        margin-top: 9.1vw;
    }
    #features .three-box .box .num {
        position: absolute;
        top: 5.6vw;
        left: 5.3vw;
        width: 17.7vw;
        height: 17.7vw;
        font-size: 4.3vw;
    }
    #features .three-box .box h5 {
        font-size: 4.8vw;
        line-height: 1.6;
        margin-top: 9.1vw;
    }
    #features .three-box .box p {
        font-size: 3.2vw;
        line-height: 2.08;
        margin-top: 3.7vw;
    }
}

/* ==============================
  Course
============================== */
#course h2 + p {
    margin-top: 1.3%;
}

#course .course-box-wrapper {
    position: relative;
    width: 82.18%;
    margin: 0 0 0 auto;
    font-size: min(1.6rem, 0.83vw);
}
#course .course-box-wrapper::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #FFF;
    border-radius: 8.75em 0 0 8.75em;


    transition: all 0.5s ease;
    transform: translateX(30%);
    opacity: 0;
}
#course .course-box-wrapper.is-active::before {
    transform: translateX(0);
    opacity: 1;
}

#course .course-box-wrapper.course-01 {
    padding: 5.4% 0 7.7%;
}
#course .course-box-wrapper.course-02 {
    margin-top: 0.7%;
    padding: 8% 0 7.8%;
}
#course .course-box-wrapper .inner {
    position: relative;
    width: 65.5%;
    margin: 0 25.3% 0 9.1%;
    z-index: 1;
}


#course .course-box-wrapper .square {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #CD9BD7;
    color: #FFF;
    font-family: "Shippori Mincho", serif;
    font-size: min(1.8rem, 0.93vw);
    height: 2.9em;
    width: 19.9em;
    margin: 0 auto;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#course .course-box-wrapper .square.is-active {
    transform: translateY(0);
    opacity: 1;
}
#course .course-box-wrapper .square.purple {
    margin-top: 6.8%;
    background-color: #CD9BD7;
}
#course .course-box-wrapper .square.blue {
    background-color: #8FB9E3;
}
#course .course-box-wrapper .square::after {
    content: "";
    display: block;
    border: 1px solid #FFF;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: 3px;
}


/* 詳細 */
#course .course-about-wrapper {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 3.2%;
}
/* 左 */
#course .course-about-wrapper .course-about {
    position: relative;
    width: 46.8%;
}
#course .course-about-wrapper .course-about .photo {
    width: 86.3%;
    position: relative;
    z-index: 2;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#course .course-about-wrapper .course-about p {
    position: absolute;
    right: 0;
    bottom: 0;
    font-size: min(1.6rem, 0.83vw);
    color: #585656;
    line-height: 2.18;
    width: 80.9%;
    padding: 5.93em 2.4em 2.6em 3em;
    box-sizing: border-box;
    z-index: 1;
    background-image: url(../images/course-about-head-purple.png), url(../images/course-about-foot-purple.png), url(../images/course-about-body-purple.png);
    background-repeat: no-repeat, no-repeat, repeat-y;
    background-position: top right, bottom left, left center;
    background-size: 100% auto, 100% auto, contain;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#course .course-02 .course-about-wrapper .course-about p {
    background-image: url(../images/course-about-head-blue.png), url(../images/course-about-foot-blue.png), url(../images/course-about-body-blue.png);
}

#course .course-about-wrapper .course-about .photo.is-active,
#course .course-about-wrapper .course-about p.is-active {
    transform: translateY(0);
    opacity: 1;
}

/* 右 */
#course .course-about-wrapper .course-detail {
    width: 47.1%;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#course .course-about-wrapper .course-detail.is-active {
    transform: translateY(0);
    opacity: 1;
}

#course .course-detail .list-wrapper  {
    border: 1.2px solid transparent;
    background: linear-gradient(#FFFFFF, #FFFFFF) padding-box, linear-gradient(90deg, #8CD6EE 0%, #F2A7CC 100%) border-box;
}

#course .course-detail .list-wrapper h6 {
    background: linear-gradient(270deg, #F2A7CC 0%, #8CD6EE 95.19%);
    text-align: center;
    color: #FFF;
    font-family: "Shippori Mincho", serif;
    font-size: min(1.8rem, 0.93vw);
    line-height: 1.875;
    padding: 0.55em 0;
}
#course .course-detail .list-wrapper .list-box {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: min(1.6rem, 0.83vw);
    color: #585656;
    padding: 1.68em 0 1.81em;
}
#course .course-detail .list-wrapper .list-box + .list-box {
    border-top: 1px solid transparent;
}
#course .course-detail .list-wrapper .list-box + .list-box::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background: linear-gradient(90deg, #8CD6EE 0%, #F2A7CC 100%);
}
#course .course-detail .list-wrapper .list-item {
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1.875;
    width: 50%;
}
#course .course-detail .list-wrapper .item01 img {
    width: 2.29em;
    margin-right: 1.01em;
}
#course .course-detail .list-wrapper .item02 img {
    width: 3.76em;
    margin-right: 0.79em;
}
#course .course-detail .list-wrapper .item03 img {
    width: 3.97em;
    margin-right: 1.02em;
}

#course .course-detail .list-wrapper .list-text {
    width: 50%;
}
#course .course-detail .list-wrapper .list-text p {
    font-size: min(1.4rem, 0.72vw);
    line-height: 1.78;
    border-left: 1px solid #BEBFDD;
    padding: 0 2em 0 2.28em;
    min-height: 7.14em;
    display: flex;
    align-items: center;
}


@media (min-width: 768px) {
    #course .course-box-wrapper .square {
        transition-delay: 0s;
    }
    #course .course-about-wrapper .course-about .photo {
        transition-delay: 0.2s;
    }
    #course .course-about-wrapper .course-about p {
        transition-delay: 0.4s;
    }
    #course .course-about-wrapper .course-detail {
        transition-delay: 0.6s;
    }
}

@media print, screen and (max-width: 768px) {
    #course h2 + p {
        margin-top: 9.4vw;
    }

    #course .course-box-wrapper {
        width: 95.4vw;
        font-size: 3.7vw;
    }
    #course .course-box-wrapper::before {
        border-radius: 29.5vw 0 0 29.5vw;
    }

    #course .course-box-wrapper.course-01 {
        padding: 19.3vw 0 15.8vw;
    }
    #course .course-box-wrapper.course-02 {
        margin-top: 3.4vw;
        padding: 17.2vw 0 20.9vw;
    }
    #course .course-box-wrapper .inner {
        width: 83.8vw;
        margin: 0 6.1vw 0 5.3vw;
    }


    #course .course-box-wrapper .square {
        font-size: 4.3vw;
        height: 3.06em;
        width: 14.68em;
        margin: 0 0 0 auto;
        position: relative;
        z-index: 1;
    }
    #course .course-box-wrapper .square.purple {
        margin-top: 13.4vw;
    }
    #course .course-box-wrapper .square.blue {
        width: 16.43em;
    }

    /* 詳細 */
    #course .course-about-wrapper {
        flex-direction: column;
        margin-top: -2.6vw;
        position: relative;
        z-index: 0;
    }
    /* 左 */
    #course .course-about-wrapper .course-about {
        width: 100%;
        padding-bottom: 65.3vw;
    }
    #course .course-02   .course-about-wrapper .course-about {
        padding-bottom: 46.2vw;
    }
    #course .course-about-wrapper .course-about .photo {
        width: 78.4vw;
    }
    #course .course-about-wrapper .course-about p {
        position: absolute;
        top: 41.6vw;
        right: 0;
        bottom: auto;
        font-size: 3.2vw;
        line-height: 2.08;
        width: 77.6vw;
        padding: 19.6vw 5.3vw 5.3vw 6.1vw;
        background-image: url(../images/course-about-head-purple-sp.png), url(../images/course-about-foot-purple-sp.png), url(../images/course-about-body-purple-sp.png);
    }
    #course .course-02 .course-about-wrapper .course-about p {
        background-image: url(../images/course-about-head-blue-sp.png), url(../images/course-about-foot-blue-sp.png), url(../images/course-about-body-blue-sp.png);
    }

    /* 右 */
    #course .course-about-wrapper .course-detail {
        width: 100%;
    }

    #course .course-detail .list-wrapper  {
        background: linear-gradient(#FFFFFF, #FFFFFF) padding-box, linear-gradient(360deg, #F2A7CC 0%, #8CD6EE 95.19%) border-box;
        display: flex;
        width: 72vw;
        margin-left: 5.9vw;
    }

    #course .course-detail .list-wrapper h6 {
        background: linear-gradient(360deg, #F2A7CC 0%, #8CD6EE 95.19%);
        font-size: 4.2vw;
        -webkit-writing-mode: vertical-lr;
        writing-mode: vertical-lr;
        letter-spacing: 0.5em;
        padding: 0 0.5em;
        width: calc(4.2vw + 1em);
    }
    #course .course-detail .list-wrapper .list-box-wrapper {
        width: 53.2vw;
        margin: 0 auto;
    }
    #course .course-detail .list-wrapper .list-box {
        flex-direction: column;
        font-size: 3.7vw;
        padding: 8vw 0 5.1vw;
    }
    #course .course-detail .list-wrapper .list-box + .list-box::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 1px;
        background: #8CD6EE;
    }
    #course .course-detail .list-wrapper .list-box:last-of-type:before {
        background: #A878B1;
    }
    #course .course-detail .list-wrapper .list-item {
        justify-content: flex-start;
        line-height: 1.42;
        width: 100%;
    }
    #course .course-detail .list-wrapper .item01 img {
        width: 8.3vw;
        margin: 0 6.1vw 0 4.3vw;
    }
    #course .course-detail .list-wrapper .item02 img {
        width: 13.6vw;
        margin: 0 3.5vw 0 1.6vw;
    }
    #course .course-detail .list-wrapper .item03 img {
        width: 14.4vw;
        margin: 0 3.02vw 0 1.3vw;
    }

    #course .course-detail .list-wrapper .list-text {
        width: 100%;
        margin-top: 3.7vw;
    }
    #course .course-detail .list-wrapper .list-text p {
        font-size: 3.2vw;
        line-height: 2.08;
        border-left: none;
        padding: 0 1.8vw;
        min-height: auto;
    }

}

/* ==============================
  Career
============================== */
#career {
    position: relative;
    width: 95%;
    margin: 3.64% auto 0 0;
    font-size: min(1.6rem, 0.83vw);
    padding: 6.7% 0 8.6%;
}
#career::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #FFF;
    border-radius: 0 8.75em 8.75em 0;

    transition: all 0.5s ease;
    transform: translateX(-30%);
    opacity: 0;
}
#career.is-active::before {
    transform: translateX(0);
    opacity: 1;
}
#career .inner {
    position: relative;
    width: 54.38%;
    margin: 0 auto 0 25.9%;
    z-index: 1;
}
#career .inner h2::after {
    display: none;
}

#career .record-wrapper {
    display: flex;
    justify-content: space-between;
    margin-top: 7.6%;
}
#career .record-wrapper .rate {
    width: max-content;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#career .record-wrapper .rate.is-active {
    transform: translateY(0);
    opacity: 1;
}

#career .record-wrapper .rate h3 {
    position: relative;
    font-size: min(2.5rem, 1.3vw);
    font-weight: 700;
    letter-spacing: 1em;
    background: linear-gradient(90deg, #A0D8EA 0%, #CD9BD7 100%);
    color: transparent;
   -webkit-background-clip: text;
   background-clip: text;
   -webkit-text-fill-color: transparent;
   text-fill-color: transparent;
    text-align: center;
    text-indent: 1em;
    padding: 0.32em 0;
}
#career .record-wrapper .rate h3::before,
#career .record-wrapper .rate h3::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, #A0D8EA 0%, #CD9BD7 100%);
}
#career .record-wrapper .rate h3::after {
    top: auto;
    bottom: 0;
}

#career .record-wrapper .rate .rate-number {
    font-family: "Afacad", sans-serif;
    font-size: min(12.5rem, 6.51vw);
    font-weight: 700;
    line-height: 1;
    text-align: center;
    background: linear-gradient(90deg, #A0D8EA 0%, #CD9BD7 100%);
    color: transparent;
   -webkit-background-clip: text;
   background-clip: text;
   -webkit-text-fill-color: transparent;
   text-fill-color: transparent;
   padding: 0.25em 0;
}
#career .record-wrapper .rate .rate-number span {
    font-size: min(6.5rem, 3.38vw);
}

#career .record-wrapper .rate p {
    text-align: center;
    font-size: min(1.2rem, 0.62vw);
    line-height: 1.83;
    color: #585656;
}

#career .record-wrapper .record {
    width: 49.8%;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#career .record-wrapper .record.is-active {
    transform: translateY(0);
    opacity: 1;
}
#career .record-wrapper .record h3 {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: min(25.5rem, 1.32vw);
    color: #FFF;
    line-height: 1;
}
#career .record-wrapper .record h3 span {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 1.81em;
    height: 1.81em;
    background: linear-gradient(135deg, #A0D8EA 0%, #D3A2D9 100%);
    border-radius: 0.31em;
}
#career .record-wrapper .record h3 span + span {
    margin-left: 0.12em;
}
#career .record-wrapper .record p {
    font-size: min(1.6rem, 0.83vw);
    line-height: 1.875;
    color: #585656;
    margin-top: 2.48em;
}
#career .record-wrapper .record p span {
    color: #A878B1;
}

/* 就職先 */
#career .occupation-wrapper {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    margin-top: 14.1%;
}
#career .occupation-wrapper .box {
    position: relative;
    border: 1px solid transparent;
    background: linear-gradient(#FFFFFF, #FFFFFF) padding-box, linear-gradient(180deg, #A0D8EA 0%, #D3A2D9 100%) border-box;
    position: relative;
    width: 31.45%;
    min-height: 30vw;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#career .occupation-wrapper .box.is-active {
    transform: translateY(0);
    opacity: 1;
}
#career .occupation-wrapper .box h5 {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    margin: 0 auto;
    transform: translateY(-50%);

    border: 1px solid transparent;
    border-radius: 50%;

    background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(180deg, #A0D8EA 0%, #A878B1 100%) border-box;
    width: 6.27em;
    height: 6.27em;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: "Afacad", sans-serif;
    font-size: min(1.8rem, 0.93vw);
    letter-spacing: 0.3em;
}
#career .occupation-wrapper .box h5 span {
    font-family: "Afacad", sans-serif;
    background: linear-gradient(180deg, #A0D8EA 0%, #A878B1 100%);
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    margin-left: 0.3em;
}

#career .occupation-wrapper .box h5 + p {
    font-size: min(1.6rem, 0.83vw);
    line-height: 1.875;
    letter-spacing: 0.1em;
    text-align: center;
    color: #585656;
    margin-top: 4.625em;
    padding-bottom: 1.06em;
    border-bottom: 1px solid #D0DBEE;
}
#career .occupation-wrapper .box .box-content {
    padding: 0 0 9.6% 6.4%;
}
#career .occupation-wrapper .box h6 {
    position: relative;
    font-family: "Afacad", sans-serif;
    font-size: min(1.4rem, 0.72vw);
    letter-spacing: 0.1em;
    background: linear-gradient(180deg, #A0D8EA 0%, #A878B1 100%);
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    border-left: 3px solid transparent;
    padding-left: 1em;
    margin: 1.5em 0 1em;
}
#career .occupation-wrapper .box h6::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 1.14em;
    height: 3px;
    background: linear-gradient(90deg, #A0D8EA 0%, #A878B1 100%);
    transform-origin: 0 100%;
    transform: rotate(90deg);
}
#career .occupation-wrapper .box .box-content .list-box p {
    display: inline-block;
    text-indent: -1rem;
    padding-left: 1rem;
    margin-right: 1em;
}
#career .occupation-wrapper .box .box-content .list-box p.break {
    line-height: 1.58;
    padding-top: 0.5em;
}
#career .occupation-wrapper .box p {
    font-size: min(1.2rem, 0.625vw);
    line-height: 2;
    color: #585656;
}
#career .occupation-wrapper .box p span {
    color:#A878B1;
}

#career .occupation-wrapper .box p.sub {
    font-family: "Afacad", sans-serif;
    font-size: min(1.4rem, 0.72vw);
    color:#A878B1;
    padding: 1em 0 0.5em;
    line-height: 1.2;
    letter-spacing: 0.1em;
}
#career .occupation-wrapper .box p.sub span {
    font-size: min(1.2rem, 0.624vw);
}

#career .occupation-wrapper .box .sub-box {
    margin-top: 4%;
    width: 94.19%;
    box-sizing: border-box;
    padding: 7.8% 0;
    background-image: url(../images/occupation-sub_box-bg.png?20260309);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    font-family: "Afacad", sans-serif;
}
#career .occupation-wrapper .box .sub-box h6 {
    font-size: min(1.5rem, 0.78vw);
    line-height: 2.3;
    letter-spacing: 0.1em;
    border: none;
    padding-left: 0;
    background: none;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    margin: 0;
}
#career .occupation-wrapper .box .sub-box h6::before {
    display: none;
}
#career .occupation-wrapper .box .sub-box h6 span {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: max-content;
    height: 1.81em;
    background: linear-gradient(135deg, #A0D8EA 0%, #D3A2D9 100%);
    border-radius: 0.31em;
    color: #FFF;
    font-size: min(1.6rem, 0.83vw);
    -webkit-text-fill-color: initial;
    text-fill-color: initial;
    padding: 0 0.5em;
    line-height: 1;
}
#career .occupation-wrapper .box .sub-box h6 span + span {
    margin-left: 0.4em;
}
#career .occupation-wrapper .box .sub-box h6 span.gradation {
    font-size: min(1.5rem, 0.78vw);
    line-height: 2.3;
    letter-spacing: 0.1em;
    background: linear-gradient(180deg, #A0D8EA 0%, #CD9BD7 100%);
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    border: none;
    margin:0.1em 0 0;
    padding: 0;
    text-align: center;
}

#career .occupation-wrapper .box .sub-box h5 {
    position: relative;
    border: none;
    border-radius: 0;
    color: #B8A7D9;
    font-size: min(2.4rem, 1.25vw);
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: 0.1em;
    width: 100%;
    height: auto;
    background: none;
    transform: none;
    margin: 2.8% 0 1.4%;
    display: block;
    text-align: center;
}
#career .occupation-wrapper .box .sub-box p {
    font-size: min(1.2rem, 0.62vw);
    line-height: 2.08;
    letter-spacing: 0.1em;
    border: none;
    margin-top: 0;
    padding: 0;
}

#career .occupation-wrapper p.attention {
    width: 96.7%;
    margin: 1.5em auto;
    font-size: min(1.2rem, 0.625vw);
    line-height: 1.83;
    color: #585656;

    position: absolute;
    bottom: 3vw;
    width: 62.5%;
    right: 1.5em;
}

@media (min-width: 768px) {
    #career .record-wrapper .rate {
        transition-delay: 0s;
    }
    #career .record-wrapper .record {
        transition-delay: 0.2s;
    }
    #career .occupation-wrapper .box:first-of-type {
        transition-delay: 0s;
    }
    #career .occupation-wrapper .box:nth-of-type(2) {
        transition-delay: 0.2s;
    }
    #career .occupation-wrapper .box:last-of-type {
        transition-delay: 0.4s;
    }
}
@media print, screen and (max-width: 768px) {
    #career {
        width: 94.8vw;
        margin: 30.3vw auto 0 0;
        font-size: 4.6vw;
        padding: 19.3vw 0 18.2vw;
    }
    #career::before {
        border-radius: 0 29.5vw 29.5vw 0;
    }
    #career .inner {
        width: 83.8vw;
        margin: 0 auto 0 5.3vw;
    }

    #career .record-wrapper {
        flex-direction: column;
        margin-top: 10.4vw;
    }
    #career .record-wrapper .rate {
        width: max-content;
        margin: 0 auto;
    }

    #career .record-wrapper .rate h3 {
        font-size: 3.7vw;
        padding: 2.4vw 0;
    }

    #career .record-wrapper .rate .rate-number {
        font-size: 20.4vw;
       padding: 4vw 0;
    }
    #career .record-wrapper .rate .rate-number span {
        font-size: 12vw;
    }

    #career .record-wrapper .rate p {
        font-size: 2.6vw;
        line-height: 2;
    }

    #career .record-wrapper .record {
        width: 75.2vw;
        margin: 14.2vw auto 0;
    }
    #career .record-wrapper .record h3 {
        font-size: 4.3vw;
    }
    #career .record-wrapper .record h3 span {
        width: 7.79vw;
        height: 7.79vw;
        border-radius: 1.3vw;
    }
    #career .record-wrapper .record h3 span + span {
        margin-left: 0.5vw;
    }
    #career .record-wrapper .record p {
        font-size: 3.2vw;
        line-height: 2.08;
        margin-top: 3.49vw;
    }

    /* 就職先 */
    #career .occupation-wrapper {
        flex-direction: column;
        margin-top: 26.8vw;
    }
    #career .occupation-wrapper .box {
        width: 100%;
    }
    #career .occupation-wrapper .box + .box {
        margin-top: 26.6vw;
    }
    #career .occupation-wrapper .box:first-of-type {
        order: 1;
    }
    #career .occupation-wrapper .box:nth-of-type(2) {
        order: 3;
        margin-top: 21.5vw;
    }
    #career .occupation-wrapper .box:last-of-type {
        order: 4;
    }
    #career .occupation-wrapper .box h5 {
        width: 30.3vw;
        height: 30.3vw;
        font-size: 4.83vw;
    }

    #career .occupation-wrapper .box h5 + p {
        font-size: 4.3vw;
        line-height: 1.56;
        margin-top: 19.8vw;
        padding-bottom: 5.3vw;
    }
    #career .occupation-wrapper .box .box-content {
        padding: 0 0 8.6vw 5.3vw;
    }
    #career .occupation-wrapper .box h6 {
        font-size: 3.7vw;
    }
    #career .occupation-wrapper .box .box-content .list-box p {
        margin-right: 1.5vw;
    }
    #career .occupation-wrapper .box p {
        font-size: 3.2vw;
        line-height: 2.08;
    }

    #career .occupation-wrapper .box p.sub {
        font-size: 3.7vw;
    }
    #career .occupation-wrapper .box p.sub span {
        font-size: 3.2vw;
    }

    #career .occupation-wrapper .box .sub-box {
        width: 67.2vw;
        padding: 6.5vw 0 6vw;
        margin: 6.7vw 0 0 3.2vw;
        background-image: url(../images/occupation-sub_box-bg-sp.png?20260309);
    }
    #career .occupation-wrapper .box .sub-box h6 {
        font-size: 4.5vw;
        line-height: 2.05;
    }
    #career .occupation-wrapper .box .sub-box h6 span {
        font-size:4vw;
        padding: 0 1.25em;
    }
    #career .occupation-wrapper .box .sub-box h6 span + span {
        margin-left: 0.93em;
    }
    #career .occupation-wrapper .box .sub-box h6 span:last-of-type {
        margin-left: 0;
    }
    #career .occupation-wrapper .box .sub-box h6 span.gradation {
        font-size: 4.5vw;
        line-height: 2.05;
        margin:0.1em 0 0;
    }

    #career .occupation-wrapper .box .sub-box h5 {
        font-size: 6.4vw;
        margin: 4.8vw 0 4.8vw;
    }
    #career .occupation-wrapper .box .sub-box p {
        font-size: 3.2vw;
    }

    #career .occupation-wrapper p.attention {
        order: 4;
        position: relative;
        bottom: 0;
        right: 0;
        width: 73.1vw;
        margin: 5.3vw auto 0;
        font-size: 2.6vw;
        line-height: 2.2;
    }
}


/* ==============================
  voice_instagram
============================== */
#voice_instagram {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 6.5% 0 0;
}
#voice_instagram h2 {
    color: #FFF;
}
#voice_instagram h2::after {
    display: none;
}
#voice_instagram h2 span.jp {
    font-size: min(1.6rem, 0.83vw);
}
#voice_instagram .voice-wrapper {
    width: 32%;
}
#voice_instagram .voice-wrapper h2 {
    margin-bottom: 0.625em;
}

#voice_instagram .voice-wrapper .voice-box {
    position: relative;
    background-color: #FFF;
    width: 100%;
    box-sizing: border-box;
    padding: 5.5% 6% 5.4% 20%;
    border: 1px solid transparent;
    background: linear-gradient(#FFFFFF, #FFFFFF) padding-box, linear-gradient(90deg, #D3A2D9 0%, #A0D8EA 100%) border-box;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#voice_instagram .voice-wrapper .voice-box.is-active {
    transform: translateY(0);
    opacity: 1;
}
#voice_instagram .voice-wrapper .voice-box:nth-of-type(2n) {
    padding:5.5% 20% 5.5% 6%;
}
#voice_instagram .voice-wrapper .voice-box::before,
#voice_instagram .voice-wrapper .voice-box::after {
    content: "";
    position: absolute;
    width: 1.055em;
    height: 1.055em;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;

    pointer-events: none;
}
#voice_instagram .voice-wrapper .voice-box .voice-bg {
    position: absolute;
    top:-2%;
    left: 0;
    width: 100%;
    z-index: 0;
}

#voice_instagram .voice-wrapper .voice-box + .voice-box {
    margin-top: 2.2%;
}
#voice_instagram .voice-wrapper .voice-box .photo {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto 0;
    width: 21.9%;
    transform: translateX(-16.2%);
}
#voice_instagram .voice-wrapper .voice-box:nth-of-type(2n) .photo {
    right: 0;
    left: auto;
    transform: translateX(16.2%);
}
#voice_instagram .voice-wrapper .voice-box .photo img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto 0;
}

#voice_instagram .voice-wrapper .voice-box p {
    font-size: min(1.6rem, 0.83vw);
    line-height: 1.875;
    color: #585656;
    position: relative;
    z-index: 1;
}


#voice_instagram .instagram-wrapper {
    width: 24.8%;
    margin-left: 7.6%;
}
#voice_instagram .instagram-wrapper h2 img {
    display: block;
    width: 9.2%;
    margin: 0.5em auto;
}
#voice_instagram .instagram-wrapper h2 span.jp span.pc {
    display: inline;
}

#voice_instagram .instagram-wrapper .instagram-box {
    margin-top: 8.5%;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#voice_instagram .instagram-wrapper .instagram-box.is-active {
    transform: translateY(0);
    opacity: 1;
}
#voice_instagram .instagram-wrapper .instagram-box + .instagram-box {
    margin-top: 6%;
}


@media (min-width: 768px) {
    #voice_instagram .voice-wrapper .voice-box {
        transition-delay: 0s;
    }
    #voice_instagram .voice-wrapper .voice-box:nth-of-type(2) {
        transition-delay: 0.2s;
    }
    #voice_instagram .voice-wrapper .voice-box:nth-of-type(3) {
        transition-delay: 0.4s;
    }
    #voice_instagram .voice-wrapper .voice-box:last-of-type {
        transition-delay: 0.6s;
    }
    #voice_instagram .instagram-wrapper .instagram-box:first-of-type {
        transition-delay: 0s;
    }
    #voice_instagram .instagram-wrapper .instagram-box:nth-of-type(2) {
        transition-delay: 0.2s;
    }
}
@media print, screen and (max-width: 768px) {
    #voice_instagram {
        flex-direction: column;
        padding: 13.9vw 0 0;
    }
    #voice_instagram h2 span.jp {
        font-size: 3.2vw;
    }
    #voice_instagram .voice-wrapper {
        width: 83.8vw;
        margin: 0 auto;
    }
    #voice_instagram .voice-wrapper h2 {
        margin-bottom: 11.5vw;
    }

    #voice_instagram .voice-wrapper .voice-box {
        width: 83.8vw;
        padding: 8vw 4.5vw 6.7vw 29.5vw;
        border: 1px solid transparent;
    }
    #voice_instagram .voice-wrapper .voice-box::before,
    #voice_instagram .voice-wrapper .voice-box::after {
        width: 0.875em;
        height: 0.875em;
    }

    #voice_instagram .voice-wrapper .voice-box:nth-of-type(2n) {
        padding: 8vw 29vw 6.7vw 5.9vw;
    }
    #voice_instagram .voice-wrapper .voice-box:nth-of-type(odd) {
        left: 2.688vw;
    }
    #voice_instagram .voice-wrapper .voice-box:nth-of-type(even) {
        right: 2.688vw;
    }
    #voice_instagram .voice-wrapper .voice-box .voice-bg {
        position: absolute;
        top:-2%;
        left: 0;
        width: 100%;
    }

    #voice_instagram .voice-wrapper .voice-box + .voice-box {
        margin-top: 9.13vw;
    }
    #voice_instagram .voice-wrapper .voice-box .photo {
        width: 30.1vw;
        transform: translateX(-19.6%);
    }
    #voice_instagram .voice-wrapper .voice-box:nth-of-type(2n) .photo {
        transform: translateX(19.6%);
    }

    #voice_instagram .voice-wrapper .voice-box p {
        font-size: 3.2vw;
        line-height: 1.91;
    }


    #voice_instagram .instagram-wrapper {
        width: 89.2vw;
        margin: 15.8vw auto 0;
    }
    #voice_instagram .instagram-wrapper h2 img {
        width: 9.6vw;
        margin: 0 auto 1.4vw;
    }

    #voice_instagram .instagram-wrapper .instagram-box {
        margin-top: 2.4vw;
    }
    #voice_instagram .instagram-wrapper .instagram-box + .instagram-box {
        margin-top: 2.9vw;
    }

}

/* ==============================
  DATA
============================== */
#data {
    position: relative;
    width: 64.5%;
    margin: 8.9% auto 0;
    font-size: min(1.6rem, 0.83vw);
    padding: 3.9% 0 6%;
}
#data::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #FFF;
    border-radius: 8.75em;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#data.is-active::before {
    transform: translateY(0);
    opacity: 1;
}
#data h2,
#data h2 + p {
    position: relative;
    z-index: 1;
}
#data .data-wrapper {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    flex-wrap: wrap;
    margin-top: 4.6%;

    position: relative;
    z-index: 1;
}

#data .data-wrapper .box {
    width: 25.1%;

    transition: all 0.5s ease;
    transform: translateY(30%);
    opacity: 0;
}
#data .data-wrapper .box.is-active {
    transform: translateY(0);
    opacity: 1;
}
#data .data-wrapper .box.data-01 {
    width: 28.8%;
}
#data .data-wrapper .box.data-02 {
    width: 27.2%;
    margin-left: 4.1%;
}
#data .data-wrapper .box.data-03 {
    width: 26.3%;
    margin-left: 3.4%;
}
#data .data-wrapper .box.data-04 {
    width: 25.1%;
}
#data .data-wrapper .box.data-05 {
    width: 25.2%;
    margin: 2.4% 0 0 6.6%;
}
#data .data-wrapper .box img {
    position: relative;
    z-index: 1;
}

#data .data-wrapper .box .fukidashi {
    position: relative;
    z-index: 0;
    background-image: url(../images/data-fukidashi.png);
    background-repeat: no-repeat;
    background-size: contain;
    font-size: min(1.3rem, 0.68vw);
    text-align: center;
    line-height: 1.38;
    font-weight: 700;
    width: 24em;
    height: 5.07em;
    box-sizing: border-box;
    padding: 1.23em 0 0;
    transform: translateY(-30.3%);
}
#data .data-wrapper .box p {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    background: linear-gradient(90deg, #A0D8EA 0%, #CD9BD7 96.21%);
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
}
#data .data-wrapper .box.data-01 .fukidashi {
    margin: 0 0.46em 0 auto;
}
#data .data-wrapper .box.data-02 .fukidashi {
    margin: 0 0.66em 0 auto;
}
#data .data-wrapper .box.data-03 .fukidashi {
    margin: 0 -0.59em 0 auto;
}
#data .data-wrapper .box.data-04 .fukidashi {
    background-image: url(../images/data-fukidashi-02.png);
    width: 26.1em;
    height: 5.53em;
    margin: 0 -1.76em 0 auto;
}
#data .data-wrapper .box.data-05 .fukidashi {
    background-image: url(../images/data-fukidashi-02.png);
    width: 26.4em;
    height: 5.53em;
    margin: 0 -1.84em 0 auto;
}

#data p.attention {
    width: 100%;
    text-align: center;
    font-size: min(1.2rem, 0.625vw);
    color: #585656;
    margin-top: 3.2%;
    z-index: 1;
}

@media (min-width: 768px) {
    #data .data-wrapper .box {
        transition-delay: 0s;
    }
    #data .data-wrapper .box:nth-of-type(2) {
        transition-delay: 0.2s;
    }
    #data .data-wrapper .box:nth-of-type(3) {
        transition-delay: 0.4s;
    }
    #data .data-wrapper .box:nth-of-type(4) {
        transition-delay: 0.6s;
    }
    #data .data-wrapper .box:nth-of-type(5) {
        transition-delay: 0.8s;
    }
}

@media print, screen and (max-width: 768px) {
    #data {
        width: 100%;
        margin: 16.9vw auto 0;
        font-size: 4.3vw;
        padding: 15.5vw 0 15vw;
    }
    #data::before {
        border-radius: 24.1vw;
    }
    #data .data-wrapper {
        flex-direction: column;
        align-items: flex-start;
        margin-top: 12vw;
    }

    #data .data-wrapper .box {
        width: 100%;
    }
    #data .data-wrapper .box.data-01 {
        width: 90.7vw;
    }
    #data .data-wrapper .box.data-02 {
        width: 84.8vw;
        margin: 11.8vw auto 0 6.4vw;
    }
    #data .data-wrapper .box.data-03 {
        width: 83vw;
        margin: 8.8vw auto 0 5.1vw;
    }
    #data .data-wrapper .box.data-04 {
        width: 75.8vw;
        margin: 11.2vw auto 0 10.7vw;
    }
    #data .data-wrapper .box.data-05 {
        width: 75.3vw;
        margin: 10.4vw auto 0 11vw;
    }

    #data .data-wrapper .box .fukidashi {
        position: relative;
        z-index: 0;
        background-image: url(../images/data-fukidashi-sp.png);
        background-size: 100% 99%;
        font-size: 3.4vw;
        transform: translateY(-28.7%);
    }
    #data .data-wrapper .box p {
        display: flex;
        align-items: center;
        justify-content: center;
        height: 100%;
        background: linear-gradient(90deg, #A0D8EA 0%, #CD9BD7 96.21%);
        color: transparent;
        -webkit-background-clip: text;
        background-clip: text;
        -webkit-text-fill-color: transparent;
        text-fill-color: transparent;
    }
    #data .data-wrapper .box.data-01 .fukidashi {
        margin: 0 0 0 9.1vw;
    }
    #data .data-wrapper .box.data-02 .fukidashi {
        margin: 0 0 0 2.6vw;
    }
    #data .data-wrapper .box.data-03 .fukidashi {
        margin: 0 0 0 3.2vw ;
    }
    #data .data-wrapper .box.data-04 .fukidashi {
        background-image: url(../images/data-fukidashi-sp.png);
        width: 24em;
        height: 5.07em;
        margin: 0 0 0 -1.6vw;
    }
    #data .data-wrapper .box.data-05 .fukidashi {
        background-image: url(../images/data-fukidashi-sp.png);
        width: 24em;
        height: 5.07em;
        margin: 0 0 0 -1.8vw;
    }

    #data p.attention {
        font-size: 3.2vw;
        margin-top: 10.7vw;
        line-height: 1.6;
    }
}

/* ==============================
  access
============================== */
#access {
    padding: 8.2% 0 5.1%;
}
#access h2::after {
    display: none;
}
#access h2 span.jp {
    font-size: min(1.8rem, 0.93vw);
}

#access .access-wrapper {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: wrap;
    margin-top: 6.5%;
}
#access .access-wrapper .google-map {
    width: 40.8%;
}
#access .access-wrapper .google-map .map-wrapper iframe  {
    width: 100%;
    height: 100%;
    aspect-ratio: 784 / 451;
}

#access .access-wrapper .google-map p {
    font-size: min(2rem, 1.04vw);
    font-weight: bold;
    margin-top: 4.7%;
    color: #585656;
}

#access .access-wrapper .access-text {
    width: max-content;
    margin-left: 2.2%;
    color: #585656;
}
#access .access-wrapper .access-text h5 {
    position: relative;
    font-family: "Afacad", sans-serif;
    font-size: min(1.6rem, 0.83vw);
    background: linear-gradient(180deg, #A0D8EA 0%, #A878B1 100%);
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    padding-left: 1em;
    margin-bottom: 0.4em;
}
#access .access-wrapper .access-text h5::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 1.14em;
    height: 3px;
    background: linear-gradient(90deg, #A0D8EA 0%, #A878B1 100%);
    transform-origin: 0 100%;
    transform: rotate(90deg);
}
#access .access-wrapper .access-text p {
    font-size: min(1.4rem, 0.72vw);
    line-height: 1.87;
}
#access .access-wrapper .access-text p + p {
    border-top: 1px dotted #A878B1;
    margin-top: 0.6em;
    padding-top: 1em;
}

#access .access-wrapper .access-text p + h5 {
    border-top: 1px solid #A878B1;
    margin-top: 0.8em;
    padding-top: 0.63em;
}
#access .access-wrapper .access-text p + h5::before {
    top: 0.63em;
}

#access .access-wrapper .access-text .btn-more {
    font-size: min(1.6rem, 0.83vw);
    margin-top: 3.625em;
}
#access .access-wrapper .access-text .btn-more a {
    display: block;
    color: #FFF;
    letter-spacing: 0.25em;
    width: 14.31em;
    text-align: center;
    margin: 0 auto;
    background: linear-gradient(90deg, #A0D8EA 0%, #CD9BD7 100%);
    text-decoration: none;
    border-radius: 1.875em;
    padding: 1.125em 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
#access .access-wrapper .access-text .btn-more a img {
    width: 0.87125em;
    margin-top: 0.2em;
    margin-left: 0.5em;
}

@media print, screen and (max-width: 768px) {
    #access {
        padding: 17.4vw 0 16.3vw;
    }
    #access h2 {
        text-align: left;
        padding-left: 5.3vw;
        box-sizing: border-box;
    }
    #access h2 span.jp {
        font-size: 3.7vw;
    }

    #access .access-wrapper {
        flex-direction: column;
        width: 89.5vw;
        margin: 5.3vw auto 0;
    }
    #access .access-wrapper .google-map {
        width: 100%;
    }
    #access .access-wrapper .google-map .map-wrapper iframe  {
        aspect-ratio: 333 / 179;
    }

    #access .access-wrapper .google-map p {
        font-size: 3.2vw;
        margin-top: 5.3vw;
        line-height: 1.6;
    }

    #access .access-wrapper .access-text {
        width: 100%;
        margin-left: 0;
    }
    #access .access-wrapper .access-text h5 {
        font-size: 3.2vw;
        margin-top: 7.796vw;
    }
    #access .access-wrapper .access-text p {
        font-size: 2.6vw;
        line-height: 2;
    }
    #access .access-wrapper .access-text p + p {
        margin-top: 1.6em;
        padding-top: 1.6em;
    }

    #access .access-wrapper .access-text p + h5 {
        margin-top: 1.2em;
        padding-top: 1.2em;
    }
    #access .access-wrapper .access-text p + h5::before {
        top: 1.2em;
    }

    #access .access-wrapper .access-text .btn-more {
        font-size: 4.3vw;
        margin-top: 8.6vw;
    }
    #access .access-wrapper .access-text .btn-more a {
        width: 61.5vw;
        border-radius: 8vw;
        padding:5.1vw 0;
    }
    #access .access-wrapper .access-text .btn-more a img {
        width: 3.4vw;
    }
}

/* ==============================
  Footer
============================== */
footer .banner-wrapper {
    display: flex;
    justify-content: space-between;
    width: 75%;
    margin: 0 auto 5%;
}
footer .banner-wrapper .banner-box {
    width: 24.375%;
}

footer .about-wrapper {
    background-color: #A0D8EA;
}
footer .about-wrapper .inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 69.63%;
    margin: 0 auto;
    padding: 1.56% 0;
}
footer .about-wrapper .inner h1 {
    width: 21.7%;
}
footer .about-wrapper .inner p {
    color: #FFF;
    font-size:min(1.1rem, 0.57vw);

}

@media print, screen and (max-width: 768px) {
    footer .banner-wrapper {
        flex-direction: column;
        width: 89.2vw;
        margin: 0 auto 12.9vw;
    }
    footer .banner-wrapper .banner-box {
        width: 100%;
    }
    footer .banner-wrapper .banner-box + .banner-box {
        margin-top: 2.6vw;
    }

    footer .about-wrapper .inner {
        flex-direction: column;
        width: 100%;
        padding: 8.8vw 0 6.9vw;
    }
    footer .about-wrapper .inner h1 {
        width: 62.3vw;
    }
    footer .about-wrapper .inner p {
        margin-top: 4.3vw;
        font-size: 2.9vw;
        text-align: center;
        line-height: 1.5;
    }

}
