@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New&display=swap');

body {
    color: #fff;
    height: 100%;
    margin: 0;
    padding: 0;
    background: #003448;
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-weight: 400;
    font-style: normal;
    text-align: center;
}
h1, h2, h3 {
    margin: 0 auto;
}
ul, li {
    list-style: none;
    margin: 0;
    padding: 0;
}
img {
    width: 100%;
}
p {
    margin: 0;
}
a {
    text-decoration: none;
    color: #fff;
}

.top-warp_pc {
    display: none;
}
.sp {
    display: block;
}

.all-warp {
    background: #E8D8BA;
    background: linear-gradient(0deg, #c3b291 0%, rgba(0, 80, 96, 1) 40%, rgba(0, 52, 72, 1) 80%);
    position: relative;
}
.pagelink {
    padding-top: 10vw;
    margin-top: -10vw;
    display: block;
}
@media screen and ( min-width: 760px ) {
    .sp {
        display: none;
    }

    .top-warp {
        content: "";
        background-image: url(../img/pc-bg.png);
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
        width: 100%;
        background-attachment: fixed;
    }
    .pagelink {
        padding-top: 8vw;
        margin-top: -8vw;
    }
}
@media screen and ( min-width: 1024px ) and (min-height: 660px) {
    .top-warp_pc {
        display: block;
    }
}

/**** top-warp_pc-left ****/
.top-warp_pc .top-warp_pc-left {
    position: fixed;
    top: 0;
    left: 0;
    width: calc((100vw - 470px) / 2);
    height: 100dvh;
    z-index: 0;
    overflow-y: hidden;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    padding: 0 2% 0;
    box-sizing: border-box;
}
.top-warp_pc-left .pc-info_main {
    align-self: flex-end;
}
.top-warp_pc-left .pc-info_title {
    width: min(283px, 90%);
    margin: 0 auto 4%;
}
.top-warp_pc-left .pc-info_date {
    width: min(267px, 90%);
    margin: 5% auto;
}
.top-warp_pc-left .pc-info_sub {
    border-top: 1px dotted #fff;
    width: min(330px, 90%);
    margin-top: 0;
    text-align: left;
    align-self: start;
}
.top-warp_pc-left .pis_box {
    margin-top: 10%;
}
.top-warp_pc-left .pis_box .pis_title {
    display: block;
    margin: 0;
    font-size: 86%;
    font-weight: 600;
    border: 1px solid #fff;
    text-align: center;
    letter-spacing: 3px;
    width: min(110px, 90%);
    border-radius: 100px;
    padding: 2px 0 2px 6px;
    box-sizing: border-box;
}
.top-warp_pc-left .pis_box .pis_text {
    margin: 7px 0 0 7px;
    font-size: min(86%, 1vw);
    font-weight: 600;
    line-height: 1.7;
    letter-spacing: 1px;
}
.top-warp_pc-left .pis_box .pis_text .note {
    font-size: 90%;
    display: block;
    font-weight: 500;
}
.top-warp_pc-left .pis_box .pis_tel {
    margin: 2px 0 0 6px;
    font-size: min(158%, 1.67vw);
    font-weight: 900;
    letter-spacing: 2px;
}
.top-warp_pc-left .pis_box .pis_tel::before {
    content: "";
    background: url(../img/pc-tel_icon.png) no-repeat;
    background-size: 15px;
    width: 20px;
    height: 20px;
    display: inline-block;
    margin-bottom: -2px;
}
.top-warp_pc-left .pis_box .pis_tel .note {
    font-size: 48%;
    font-weight: 600;
    letter-spacing: 1px;
    margin-left: -5px;
}

.top-warp_pc .top-warp_pc-right {
    position: fixed;
    top: 0;
    right: 0;
    /* width: max(100px, calc(100vw - 470px - (470 / 1410 * 100vw))); */
    width: calc((100vw - 470px) / 2);
    height: 100%;
    padding-bottom: 45px;
    padding-left: 30px;
    padding-right: 20px;
    display: block;
    justify-items: center;
    padding-top: calc(240 / 768 * 100dvh);
    overflow-y: auto;
    box-sizing: border-box;
    z-index: 999;
}
.top-warp_pc-right .pc-nav {
    text-align: left;
    width: min(275px, 60%);
    margin-right: auto;
    margin-left: 20px;
}
.top-warp_pc-right .pc-nav .pn-link {
    margin-bottom: 2vw;
}
.top-warp_pc-right .pc-nav .pn-link:last-of-type {
    margin-bottom: 0;
}

.top-warp_pc-right .pc-nav .pn-link a {
    font-size: min(90%, 1.3vw);
    letter-spacing: 1px;
    padding-left: 0;
    position: relative;
    transition: 0.15s;
    padding-left: 0px;
}
.top-warp_pc-right .pc-nav .pn-link a::before {
    content: "";
    background: url(../img/pc-menu_icon.png) no-repeat;
    background-size: 11px;
    width: 20px;
    height: 11px;
    display: inline-block;
}
.top-warp_pc-right .pc-nav .pn-link a::after {
    content: "";
    height: 1px;
    width: 0px;
    background: rgb(255 255 255 / 80%);
    display: block;
    position: absolute;
    top: 50%;
}
.top-warp_pc-right .pc-nav .pn-link a:hover {
    padding-left: 30px;
}
.top-warp_pc-right .pc-nav .pn-link a:hover::after {
    width: 20px;
}
.top-warp_pc-right .pc-nav .pn-link.is-active a {
    padding-left: 30px;
}
.top-warp_pc-right .pc-nav .pn-link.is-active a::after {
    width: 20px;
}
.top-warp_pc-right .pc-btn_yado {
    margin-top: 10%;
}
.top-warp_pc-right .pc-btn_yado a {
    border: 1px solid #fff;
    display: block;
    width: min(275px, 90%);
    box-sizing: border-box;
    border-radius: 100px;
    padding: 14px 17px 14px;
    line-height: 0;
    background: rgb(255 255 255 / 20%);
    transition: 0.15s;
}
.top-warp_pc-right .pc-btn_yado a:hover {
    background: rgb(255 255 255 / 0);
}
.top-warp_pc-right .pc-btn_plan a {
    display: block;
    line-height: 0;
    transition: 0.15s;
    position: absolute;
    bottom: 5%;
    right: 10%;
    width: min(118px, 50%);
}
.top-warp_pc-right .pc-btn_plan a:hover {
    bottom: 4%;
}

/***** .top-warp_main *****/
.top-warp_main {
    position: relative;
    max-width: 470px;
    width: 100%;
    /* margin: 0 max(100px, calc(100vw - 470px - (470 / 1410 * 100vw))) 0 auto; */
    margin-top: 0;
    margin-left: auto;
    margin-right: auto;
    z-index: 2;
    overflow: hidden;
    background: linear-gradient(0deg, #c3b291 0%, rgba(0, 80, 96, 1) 40%, rgba(0, 52, 72, 1) 80%);
}
.top-warp_main .top-main {
    margin-top: 9px;
}
.top-warp_main .main-warp {
    border: 2px solid #c5a786;
    border-bottom: none;
    max-width: 454px;
    width: 95%;
    margin: auto;
    background: rgb(0 52 72 / 70%);
    background: linear-gradient(0deg, rgba(0, 52, 72, 0) 1.3%, rgba(0, 52, 72, 0.7) 1.3%);
}
/*.top-warp_main .main-warp img {
    width: 105.2%;
    margin-left: -2.3%;
}*/
@media screen and ( min-width: 760px ) {
    .top-warp_main .top-main {
        margin-top: 45px;
    }
}

/***** main-fv_area *****/
.top-warp_main .main-fv_area {
    position: relative;
    background: url(../img/main-fvbg.png) no-repeat;
    background-size: 100%;
    width: 102.5%;
    height: 100%;
    margin-top: -17px;
    margin-left: -10px;
}
.top-warp_main .mf-title {
    width: min(440px, 97%);
    margin: auto;
    padding-top: 19.5%;
    padding-left: 10px;
}
.top-warp_main .mf-info {
    width: min(418px, 92%);
    margin: auto;
    padding-top: 10%;
    padding-bottom: 22%;
    padding-left: 10px;
}
.top-warp_main .fv_plan-bnr.is-hidden {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}
.top-warp_main .fv_plan-bnr a {
    display: block;
    width: min(118px, 26%);
    position: fixed;
    bottom: 0vh;
    right: 0.5%;
    z-index: 10;
}
.top-warp_main .fv_plan-bnr a img {
    width: 100%;
    margin: auto;
}

#info-link.pagelink {
    padding-top: 20vw;
    margin-top: -20vw;
}
@media screen and ( min-width: 760px ) {
    .top-warp_main .main-fv_area {
        width: 102.24%;
        margin-top: -20px;
    }
    .top-warp_main .fv_plan-bnr a {
        width: min(118px, 26%);
        position: absolute;
        bottom: -7%;
        right: -1.5%;
        transition: 0.15s;
    }
    .top-warp_main .fv_plan-bnr a:hover {
        bottom: -8%;
    }
}

/***** shop_area *****/
.top-warp_main .shop_area .sa-title {
    width: min(400px, 88%);
    position: relative;
}
.top-warp_main .shop_area .sa-title::after {
    content: "";
    display: block;
    background: url(../img/shop-read_titlebg.png) no-repeat;
    background-size: contain;
    padding-top: 25.75%;
    padding-right: 71.75%;
    position: absolute;
    top: 69%;
    right: -9%;
}
.top-warp_main .shop_area .sa-point {
    margin-top: 7%;
}
.top-warp_main .shop_area .point-link a {
    display: block;
    width: min(145px, 35%);
    margin: 7px 5% 0 auto;
    background: #fff;
    border: 1px solid #e7d8b9;
    border-radius: 100px;
    box-sizing: border-box;
    color: #003448;
    font-size: min(14px, 3.1vw);
    font-weight: bold;
    padding: 4px 5px 5px;
    text-align: center;
    position: relative;
    transition: 0.15s;
}
.top-warp_main .shop_area .point-link a::after {
    content: "";
    background: url(../img/btn_arrow-b.png) no-repeat;
    background-size: contain;
    width: 4px;
    height: 7px;
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.top-warp_main .shop_area .point-link a:hover {
    background: #e7d8b9;
}
.top-warp_main .shop_area .sap-01 .point01 {
    width: min(370px, 80%);
    margin-left: 5.5%;
}
.top-warp_main .shop_area .sap-02 {
    position: relative;
}
.top-warp_main .shop_area .sap-02::before {
    content: "";
    display: block;
    background: url(../img/shop-point02bg.png) no-repeat;
    background-size: contain;
    padding-top: 42.556%;
    padding-left: 34.27%;
    position: absolute;
    top: -25%;
    left: -2.5%;
}
.top-warp_main .shop_area .sap-02 .point02 {
    width: min(278px, 60%);
    margin: 5% 3% 0 auto;
}
.top-warp_main .shop_area .sap-02 .point-link a {
    margin-top: -2%;
}
.top-warp_main .shop_area .sap-cash {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 90%;
    margin: 8% auto;
}
.top-warp_main .shop_area .sap-cash .sapc-title {
    background: #e7d8b9;
    width: 22.75%;
    font-size: min(13px, 2.5vw);
    font-weight: bold;
    color: #040000;
    border-radius: 100px;
    box-sizing: border-box;
    padding: 2px 5px;
}
.top-warp_main .shop_area .sap-cash .sapc-text {
    width: 90%;
    text-align: left;
    font-size: min(12px, 2.6vw);
    font-weight: 500;
    margin-left: 10px;
    letter-spacing: 0.5px;
    line-height: 1.2;
}
.top-warp_main .shop_area .sap-cash .sapc-text .note {
    font-size: 85%;
    margin-left: 6px;
}

.top-warp_main .sa-menu .sam-title {
    width: min(305px, 70%);
    margin: auto auto 0 5%;
}
.top-warp_main .sa-menu .menu01 {
    width: min(450px, 102%);
    margin-left: 2.5%;
    margin-top: -4%;
}
.top-warp_main .sa-menu .menu02 {
    width: min(443px, 100%);
    margin-left: -11px;
    margin-top: -8%;
}

.top-warp_main .shop_area .sa-bottom {
    width: 105.9%;
    margin-left: -3%;
}

@media screen and ( min-width: 760px ) {
    .top-warp_main .shop_area .sa-title {
        width: min(400px, 95%);
    }
    .top-warp_main .shop_area .sap-01 .point01 {
        width: min(370px, 95%);
    }
    .top-warp_main .shop_area .sap-02 .point02 {
        width: min(278px, 70%);
    }
    .top-warp_main .shop_area .sap-cash {
        width: 90%;
    }
    .top-warp_main .sa-menu .sam-title {
        width: min(305px, 80%);
    }
}


/***** .access *****/
.top-warp_main .access {
    position: relative;
}
.top-warp_main .access::before {
    content: "";
    display: block;
    background: url(../img/access-bg.png) no-repeat;
    background-size: contain;
    padding-top: 75%;
    padding-left: 105.265%;
    position: absolute;
    top: -4%;
    left: -2%;
}
.top-warp_main .access .main-access {
    width: min(273px, 60%);
    margin: 4% 4% 0 auto;
}

.top-warp_main .access_info {
    max-width: 400px;
    width: 90%;
    margin: 23% auto 0;
    text-align: left;
}
.top-warp_main .access_info .ai-list {
    position: relative;
}
.top-warp_main .access_info .ai-list:first-of-type {
    width: 60%;
}
.top-warp_main .access_info .ai-list .ai-title {
    color: #040000;
    background: #e4d5b8;
    font-size: 90%;
    font-weight: bold;
    letter-spacing: 1px;
    width: 150px;
    padding: 3px 10px;
    box-sizing: border-box;
    border-radius: 100px;
    text-align: center;
    margin: 0;
}
.top-warp_main .access_info .ai-list .ai-link {
    position: absolute;
    top: 2px;
    right: 60px;
    width: 120px;
}
.top-warp_main .access_info .ai-list .ai-link img {
    width: 100%;
    margin: auto;
}
.top-warp_main .access_info .ai-list .ai-text {
    margin: 6px 0 25px 10px;
    letter-spacing: 1px;
    font-size: 90%;
}
.top-warp_main .access_info .ai-list .ai-text .note {
    display: block;
    font-size: 80%;
}
.top-warp_main .ai-slide {
    margin: 40px auto;
}
.top-warp_main .ai-map iframe {
    width: 100%;
}

@media screen and ( min-width: 760px ) {
    .top-warp_main .access .main-access {
        width: min(273px, 80%);
    }
    .top-warp_main .access_info .ai-list:first-of-type {
        width: 100%;
    }
    .top-warp_main .access_info .ai-list .ai-text {
        font-size: 16px;
    }
    .top-warp_main .access_info .ai-list .ai-link {
        right: 114px;
    }
    .top-warp_main .access_info .ai-list .ai-link a {
        transition: 0.15s;
    }
    .top-warp_main .access_info .ai-list .ai-link a:hover {
        opacity: 0.8;
    }
}

.top-warp_main .event img {
    width: 100%;
    margin: auto;
}
.top-warp_main .event .e-list {
    width: 95%;
    border: 10px solid #c5a786;
    padding: 34px 5px 22px;
    box-sizing: border-box;
    border-image-source: url(../img/event-bg.png);
    border-image-slice: 100 fill;
    border-image-width: 100px;
    border-image-repeat: round;
    color: #040000;
    margin: 17% auto 0;
    position: relative;
}
.top-warp_main .event .e-list::before {
    content: "";
    display: block;
    background: url(../img/event-bg_sub.png) no-repeat;
    background-size: cover;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}
.top-warp_main .event .event-title {
    position: absolute;
    top: -40px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    width: min(328px, 80%);
    margin: auto;
}
.top-warp_main .event .et-sub {
    width: min(344px, 95%);
    margin: auto;
}
.top-warp_main .event .el-content {
    margin-top: 9%;
}
.top-warp_main .event .elc-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
}
.top-warp_main .event .elc-info {
    width: 49.03%;
    margin-right: 3%;
    font-size: min(16px, 90%);
}
.top-warp_main .event .elc-info.right {
    margin-right: 0;
    margin-left: 3%;
}
.top-warp_main .event .elc-title {
    margin: 0;
}
.top-warp_main .event .elc-text {
    margin: 5px 0 10px;
    font-size: 92%;
    text-align: justify;
    line-height: 1.5;
    font-weight: 500;
}
.top-warp_main .event .elc-img {
    width: min(185px, 50%);
}
.top-warp_main .event .e-btn a {
    display: block;
    background: #003448;
    width: min(227px, 90%);
    margin: 10px auto 0;
    padding: 10px;
    box-sizing: border-box;
    border: 2px solid #003448;
    border-radius: 100px;
    font-weight: bold;
    letter-spacing: 0.5px;
    transition: 0.15s;
    position: relative;
    font-size: min(16px, 90%);
}
.top-warp_main .event .e-btn a::after {
    content: "";
    background: url(../img/btn_arrow.png) no-repeat;
    background-size: contain;
    width: 4px;
    height: 7px;
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.top-warp_main .event .e-btn a:hover {
    background: rgb(0 52 72 / 50%);
}
.top-warp_main .event .event-timetable {
    width: 90%;
    margin: 10% auto;
}
.top-warp_main .event .et-title {
    width: min(360px, 90%);
    margin: 0 0 5%;
}
.top-warp_main .et-bottom img {
    width: 100%;
    margin: auto;
}
@media screen and ( min-width: 760px ) {
    .top-warp_main .event .e-list {
        padding: 34px 10px 22px;
    }
    .top-warp_main .event .event-title {
        top: -47px;
    }
    .top-warp_main .event .elc-info {
        font-size: 16px;
    }
}


/**** course-warp ****/
.course-warp {
    border: 2px solid #c5a786;
    border-top: none;
    border-bottom: none;
    max-width: 454px;
    width: 95%;
    margin: auto;
    background: rgb(255 255 255 / 70%); 
    background-image: url(../img/course-bg.png);
    background-repeat: no-repeat;
}
.course-warp .cw-box {
    width: 90%;
    margin: auto;
}
.course-warp .course-title {
    width: min(270px, 70%);
    margin: -4% 0 6%;
}
.course-warp .course-bnr {
    margin: 0 auto 3%;
    transition: 0.15s;
}
.course-warp .course-bnr:hover {
    opacity: 0.8;
}
.course-warp .c-btn a {
    display: block;
    background: #003448;
    width: min(310px, 90%);
    margin: 8% auto;
    padding: 10px;
    box-sizing: border-box;
    border: 2px solid #003448;
    border-radius: 100px;
    font-weight: bold;
    letter-spacing: 0.5px;
    transition: 0.15s;
    position: relative;
}
.course-warp .c-btn a::after {
    content: "";
    background: url(../img/btn_map.png) no-repeat;
    background-size: contain;
    width: 13px;
    height: 15px;
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.course-warp .c-btn a:hover {
    background: rgb(0 52 72 / 50%);
}
.course-warp .c-bottom {
    line-height: 0;
}
@media screen and ( min-width: 760px ) {
    .course-warp .course-bnr {
        width: 90%;
    }
}

/**** plan-warp ****/
.plan-warp {
    border: 2px solid #c5a786;
    border-top: none;
    border-bottom: none;
    max-width: 454px;
    width: 95%;
    margin: auto;
    position: relative;
    padding-top: 35%;
    background: rgb(197 167 134 / 60%);
    background: linear-gradient(0deg, rgb(197 167 134 / 0%) 5.5%, rgba(197, 167, 134, 0.6) 5.5%);
}
.plan-warp .plan-title {
    width: min(425px, 97%);
    margin: 0;
    position: absolute;
    top: -35px;
    left: -11px;
}
.plan-warp .pl-title {
    width: min(208px, 70%);
}
.plan-warp .pl-box {
    width: 95%;
    border: 10px solid #c5a786;
    padding: 25px 10px 10px;
    box-sizing: border-box;
    border-image-source: url(../img/plan-yado_bg.png);
    border-image-slice: 100 fill;
    border-image-width: 100px;
    border-image-repeat: round;
    color: #003448;
    margin: -5% auto 0;
    display: flex;
    flex-wrap: wrap;
}
.plan-warp .plb-content {
    width: 48%;
    text-align: left;
    font-size: min(13px, 68%);
    margin-bottom: 14px;
    border-bottom: 2px dotted;
    padding-bottom: 6px;
    font-weight: 600;
    display: flex;
    align-items: center;
}
.plan-warp .plb-content:nth-child(2n) {
    margin-left: 4%;
}
.plan-warp .plb-content.sm {
    font-size: min(12px, 65%);
}
.plan-warp .plb-content a {
    color: #003448;
    display: block;
    width: 100%;
    position: relative;
    transition: 0.15s;
}
.plan-warp .plb-content a .note {
    display: block;
    font-size: 80%;
    margin-top: -3px;
}
.plan-warp .plb-content a::after {
    content: "";
    display: block;
    background: url(../img/btn_arrow-b.png) no-repeat;
    background-size: cover;
    width: 4px;
    height: 7px;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.plan-warp .pl-slide {
    margin: 20px auto 40px;
}
.plan-warp .p-bottom {
    position: relative;
    z-index: 2;
}

#plan-link.pagelink {
    padding-top: 50vw;
    margin-top: -50vw;
}
@media screen and ( min-width: 760px ) {
    .plan-warp .plb-content {
        font-size: 13px;
    }
    .plan-warp .plb-content.sm {
        font-size: 12px;
    }
    .plan-warp {
        background: linear-gradient(0deg, rgb(197 167 134 / 0%) 6.5%, rgba(197, 167, 134, 0.6) 6.5%);
    }
    .plan-warp .plb-content a:hover {
        opacity: 0.6;
    }
    #plan-link.pagelink {
        padding-top: 15vw;
        margin-top: -15vw;
    }
}

/**** map-warp ****/
.map-warp {
    border: 2px solid #c5a786;
    border-top: none;
    border-bottom: none;
    max-width: 454px;
    width: 95%;
    margin: -16% auto 0;
    overflow: hidden;
    height: 40vh;
    position: relative;
}
.map-warp iframe {
    width: 100%;
    height: calc(50vh + 300px);
    margin-top: -150px;
    position: relative;
    z-index: 1;
    filter: grayscale(100%) sepia(25%);
}
@media screen and ( min-width: 760px ) {
    .map-warp::before {
        content: "";
        width: 100%;
        height: 40vh;
        position: absolute;
        top: 0;
        left: 0;
        background: #c5a786;
        mix-blend-mode: hue;
    }
}  

.top-warp_main .slider li {
    margin: 0 4px;
    position: relative;
}
.top-warp_main .slider li img {
    width: 100%;
    margin: auto;
    border: 2px solid #c5a786;
    border-radius: 10px;
}
.top-warp_main .slider li .name {
    position: absolute;
    bottom: 7px;
    right: 7px;
    font-weight: 600;
    font-size: 10px;
    text-shadow: 0 0 3px black;
}
@media screen and ( min-width: 760px ) {
    .top-warp_main .slider li .name {
        font-size: 12px;
    }
}

/**** sp-foot ****/
.sp-foot {
    position: relative;
}
.sp-foot .top-tb {
    position: absolute;
    top: -120px;
    right: 0;
}
.sp-foot .top-tb span {
    display: block;
    width: 43px;
    margin: auto;
    position: relative;
    top: 38px;
    z-index: 2;
}
.sp-foot .top-tb a {
    background: #003448;
    padding: 10px 15px;
    font-weight: bold;
    font-size: 110%;
    position: relative;
    z-index: 2;
    border-radius: 26px 26px 0 0;
}
.sp-foot .sf-nav {
    background: #003448;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 16px 8px;
}
.sp-foot .sf-nav .f-logo {
    width: min(87.83px,20%);
}
.sp-foot .sf-nav .sfn-link {
    width: 53%;
    margin: 0 5px;
    display: flex;
    flex-wrap: wrap;
    display: none;
}
.sp-foot .sf-nav .sfnl-content {
    width: 30.5%;
    margin-left: 6px;
    font-size: 10px;
    letter-spacing: -0.5px;
    text-align: left;
    margin-bottom: 3px;
}
.sp-foot .sf-nav .sfnl-content a {
    position: relative;
    padding-left: 12px;
}
.sp-foot .sf-nav .sfnl-content a::before {
    content: "";
    background: url(../img/pc-menu_icon.png) no-repeat;
    background-size: cover;
    display: block;
    width: 11px;
    height: 11px;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
.sp-foot .sf-nav .f-tel {
    width: min(128px, 30%);
}
.sp-foot .sf-c {
    background: #e7d8b9;
    color: #003448;
    font-size: 10px;
    letter-spacing: 1px;
    padding: 5px;
}

/**** sp-head ****/
.sp-head .sp-btn_yado {
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    width: min(119px, 50%);
    box-sizing: border-box;
    padding: 13px 16px 9px 9px;
    border-radius: 0 40px 50px 0;
}
.sp-head .sp-btn_yado a {
    display: block;
    width: 80%;
    margin: auto;
    position: relative;
    z-index: 1;
}
.sp-head .sp-menu-btn {
    position: fixed;
    z-index: 5;
    top: 10px;
    right: 14px;
    width: min(93px, 40%);
    display: flex;
    align-items: center;
    background: #fff;
    border: 2px solid #e7d8b9;
    border-radius: 100px;
    box-sizing: border-box;
    padding: 2px 8px 0px;
    font-weight: bold;
    font-size: 12px;
    color: #003448;
}
.sp-head .sp-menu-btn .menu-icon {
    width: 17px;
    margin: 6px;
}
.sp-menu {
    position: fixed;
    inset: 0;
    z-index: 1000;
    pointer-events: none;
}
.sp-menu__backdrop {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.5);
    opacity: 0; transition: opacity .25s ease;
    z-index: 0;
}
.sp-menu__inner {
    position: absolute;
    inset: 0;
    background: #f6f1eb;
    transform: translateY(-2%);
    opacity: 0;
    transition: transform .25s ease, opacity .25s ease;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    padding: 64px 24px 24px;
    z-index: 1;
}
.sp-menu__close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 50px;
    height: 50px;
    border: none;
    background: none;
}
.sp-menu__list { 
    list-style: none;
    padding: 0;
    margin: 15px 0 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    position: relative;
}
.sp-menu__list li {
    width: 49.5%;
    background: #003448;
    border-radius: 5px;
    margin-bottom: 4px;
}
.sp-menu__list a {
    display: block;
    padding: 18px 6px 18px 32px;
    text-decoration: none;
    color: #ffffff;
    font-size: 14px;
    text-align: left;
    font-weight: bold;
    position: relative;
}
.sp-menu__list a::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 10px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    background: url(../img/pc-menu_icon.png) no-repeat;
    background-size: cover;
    width: 15px;
    height: 15px;
}
.sp-menu__list .sp-menu_img {
    background: none;
    border-radius: 0;
    margin-bottom: 0;
    position: absolute;
    bottom: -12vw;
    right: 5vw;
    width: 32%;
}
.sp-menu_cash {
    border: 1px solid #003448;
    border-radius: 5px;
    box-sizing: border-box;
    background: #f6f1eb;
    color: #003448;
    text-align: left;
    padding: 10px;
}
.sp-menu_cash .smc_title {
    margin: 0;
    background: #003448;
    color: #fff;
    font-size: 80%;
    padding: 2px 14px 4px;
    letter-spacing: 1px;
    display: inline-block;
    border-radius: 100px;
}
.sp-menu_cash .smc_text {
    font-size: 88%;
    font-weight: bold;
    margin: 5px 0 3px 10px;
}
.sp-menu_cash .smc_text .note {
    display: block;
    font-size: 90%;
}
.sp-menu_contact {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 5px;
}
.sp-menu_contact .smc_box {
    width: 49%;
    border: 1px solid #003448;
    border-radius: 5px;
    box-sizing: border-box;
    background: #f6f1eb;
    text-align: left;
    padding: 8px 10px 8px;
}
.sp-menu_contact .smc_title {
    margin: 0;
    background: #003448;
    color: #fff;
    font-size: 80%;
    padding: 2px 14px 4px;
    letter-spacing: 1px;
    display: inline-block;
    border-radius: 100px;
}
.sp-menu_contact .smc_tel {
    color: #003448;
    margin: 7px 0 0px 8px;
}
.sp-menu_contact .smc_box.-link {
    background: #003448;
    padding: 11px 6px 0 13px;
}
.sp-menu_contact .smc_box.-link a {
    display: block;
}


/* 開いた状態 */
.sp-menu.is-open { 
    pointer-events: auto;
}
.sp-menu.is-open .sp-menu__backdrop {
    opacity: 1;
}
.sp-menu.is-open .sp-menu__inner { 
    transform: translateY(0); opacity: 1;
}
/* スクロールロック */
body.is-locked { overflow: hidden; touch-action: none; }

/* 動きを減らすユーザー配慮 */
@media (prefers-reduced-motion: reduce){
  .sp-menu__inner, .sp-menu__backdrop { transition: none; }
}

/***** animation *****/
.fadein { 
    opacity:0;
    transform: translateY(20px);
    transition: all 0.8s ease;
}
 
.fadein.is-animated { 
    opacity:1;
    transform: none;
}

/**** close ****/
.mf-info {
    position: relative;
}
.mf-info .close {
    position: absolute;
    top: -54px;
    left: -26px;
    width: 120%;
}

@media screen and ( min-width: 760px ) {
    .mf-info .close {
        top: -63px;
        left: -35px;
        width: 122%;
    }
}