@charset "utf-8";

/***************************************************************************
*
* INDEX STYLE
*
***************************************************************************/

/* main */
#main {
    position: relative;
    background-color: #000;
}
#main .mainArrow {
    position: absolute;
    bottom: 261px;
    left: 50%;
    transform: translateX(-50%);
}
#main .mainArrow a {
    display: block;
    width: 18px;
    animation: arrow 5s ease infinite;
}
#main .mainArrow a img {
    aspect-ratio: 18/8;
}
@keyframes arrow {
    5% {
        transform: translateY(0);
    }
    10% {
        transform: translateY(0);
    }
    60% {
        transform: translateY(20px);
    }
    100% {
        transform: translateY(0);
    }
}
#main .mainWrap .mainBox {
    position: relative;
    width: 100%;
}
#main .mainWrap .mainBox .mainPhoto {
    width: 100%;
}
#main .mainWrap .mainBox .mainPhoto img {
    width: 100%;
    height: 100vh;
}
#main .mainWrap .slick-slide.mainBox:first-child .mainInfo {
    top: 46.1%;
}
#main .mainWrap .mainBox .mainInfo {
    position: absolute;
    top: 48.6%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}
#main .mainWrap .mainBox .mainInfo .mainLogo {
    display: inline-block;
    width: 111px;
    margin-bottom: 26px;
}
#main .mainWrap .mainBox .mainInfo .mainLogo img {
    width: 100%;
    aspect-ratio: 1/1;
}
#main .mainWrap .mainBox .mainInfo .mainSlogan {
    width: 443px;
    margin: 0 auto 18px;
}
#main .mainWrap .mainBox .mainInfo .mainSlogan img {
    width: 100%;
    aspect-ratio: 443/47;
}
#main .mainWrap .mainBox .mainInfo .mainSub {
    font-size: 21px;
    color: #fff;
    line-height: 1.5;
    letter-spacing: 2.3px;
}
#main .mainWrap .slick-slide.mainBox:first-child .mainInfo .mainSub {
    font-size: 15px;
    letter-spacing: 1.6px;
}
#main .mainWrap .mainBox .mainNumber {
    position: absolute;
    bottom: 129px;
    left: 50.1%;
    transform: translateX(-50%);
    font-size: 15px;
    color: #fff;
    letter-spacing: 3px;
}
#main .mainWrap .slick-dots {
    bottom: 102px;
}
#main .mainWrap .slick-dots li {
    width: 77px;
    height: 1px;
    pointer-events: none;
}
#main .mainWrap .slick-dots li button {
    width: 100%;
    height: 100%;
    padding: 0;
    background-color: #fff;
}
#main .mainWrap .slick-dots li button:before {
    content: none;
}
#main .mainWrap .slick-dots li.slick-active button {
    background-color: #A0A0F2;
}
#main .mainWrap.slick-dotted.slick-slider {
    margin-bottom: 0;
}
#main .mainWrap.slick-initialized .slick-slide {
    line-height: 0  ;
}
/* main */

/* areaAboutM7 */
.areaAboutM7 {
    padding-top: 74px;
}
.areaAboutM7 .aboutM7Title {
    position: relative;
    text-align: center;
    font-size: 23px;
    font-weight: bold;
    color: #623562;
    margin-bottom: 91px;
}
.areaAboutM7 .aboutM7Title::before {
    content: "";
    position: absolute;
    bottom: -13px;
    left: 50%;
    transform: translateX(-50%);
    width: 80px;
    aspect-ratio: 80/3;
    background: url(../images//index/icon-line-tilte-about.svg)no-repeat top left/100%;
}
.areaAboutM7 .aboutM7Video {
    display: block;
    text-align: center;
    margin-bottom: 95px;
}
.areaAboutM7 .aboutM7Video iframe {
    width: 660px;
    aspect-ratio: 660/405;
    margin: 0 auto;
}
.areaAboutM7 .aboutM7Intro {
    position: relative;
    background: url(../images/index/area-about-m7-photo-01.webp)no-repeat center center/cover;
    padding: 186px 0 178px;
}
.areaAboutM7 .aboutM7Intro .m7IntroList {
    display: flex;
    flex-wrap: wrap;
    width: calc(100% - 60px);
    max-width: 1340px;
    margin: 0 auto;
}
.areaAboutM7 .aboutM7Intro .m7IntroList li {
    width: calc(100%/3 - 27px);
    text-align: center;
}
.areaAboutM7 .aboutM7Intro .m7IntroList li:not(:last-child) {
    margin-right: 40px;
}
.areaAboutM7 .aboutM7Intro .m7IntroList li .introPhoto {
    width: 100%;
    margin-bottom: 41px;
}
.areaAboutM7 .aboutM7Intro .m7IntroList li .introPhoto img {
    width: 100%;
    aspect-ratio: 420/229;
}
.areaAboutM7 .aboutM7Intro .m7IntroList li .introSub {
    font-size: 18px;
    color: #fff;
    letter-spacing: 2px;
}
.areaAboutM7 .aboutM7Service {
    background-color: #F5F5F5;
    padding: 153px 0 128px;
}
.areaAboutM7 .aboutM7Service .serviceList {
    display: flex;
    flex-wrap: wrap;
    width: calc(100% - 60px);
    max-width: 1340px;
    margin: 0 auto;
}
.areaAboutM7 .aboutM7Service .serviceList li {
    width: calc(100%/3 - 27px);
}
.areaAboutM7 .aboutM7Service .serviceList li:not(:last-child) {
    margin-right: 40px;
}
.areaAboutM7 .aboutM7Service .serviceList li .servicePhoto {
    width: 100%;
    margin-bottom: 33px;
}
.areaAboutM7 .aboutM7Service .serviceList li .servicePhoto img {
    width: 100%;
    aspect-ratio: 420/274;
}
.areaAboutM7 .aboutM7Service .serviceList li .serviceName {
    text-align: center;
    font-size: 23px;
    line-height: 1.6;
    margin-bottom: 21px;
}
.areaAboutM7 .aboutM7Service .serviceList li .serviceSub {
    font-size: 15px;
    line-height: 2;
    text-align: justify;
}
/* areaAboutM7 */

/* areaMeals */
.areaMeals {
    padding-top: 71px;
    margin-bottom: 194px;
}
.areaMeals .areaTitle {
    margin-bottom: 50px;
}
.areaMeals .mealsWrap {
    text-align: center;
}
.areaMeals .mealsWrap .mealsBox:not(:last-child) {
    position: relative;
    margin-bottom: 118px;
}
.areaMeals .mealsWrap .mealsBox:not(:last-child)::before {
    content: "";
    position: absolute;
    bottom: -60px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 720px;
    height: 1px;
    background-color: #B2B2B2;
    z-index: 1;
}
.areaMeals .mealsWrap .mealsBox .mealsChef {
    width: 257px;
    margin: 0 auto 10px;
}
.areaMeals .mealsWrap .mealsBox .mealsChef img{
    width: 100%;
    aspect-ratio: 257/25;
}
.areaMeals .mealsWrap .mealsBox .mealsDish {
    font-size: 42px;
    font-weight: bold;
    color: #623562;
    margin-bottom: 43px;
}
.areaMeals .mealsWrap .mealsBox .mealsPhoto {
    width: 100%;
    max-width: 720px;
    margin: 0 auto 71px;
}
.areaMeals .mealsWrap .mealsBox .mealsPhoto img {
    width: 100%;
    aspect-ratio: 720/523;
    object-fit: cover;
    object-position: center;
}
.areaMeals .mealsWrap .mealsBox .mealsDetail .mealsNote {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 24px;
}
.areaMeals .mealsWrap .mealsBox .mealsSub {
    font-size: 15px;
    line-height: 2.35;
}
.areaMeals .mealsWrap .mealsBox .mealsSub .subNote {
    display: inline-block;
    margin: 10px 0;
}
.areaMeals .mealsWrap .mealsBox .mealsSub .noto {
    font-family: "Noto Sans JP", sans-serif;
}
.areaMeals .mealsWrap .mealsBox .mealsDetail:not(:last-child) {
    margin-bottom: 20px;
}
.areaMeals .mealsWrap .mealsBox .mealsDetail h3 {
    font-size: 24px;
    line-height: 2.35;
    font-family: "Shippori Mincho", serif;
    letter-spacing: -1.1px;
    margin-bottom: 24px;
}
.areaMeals .mealsWrap .mealsBox .mealsDetail p {
    font-size: 15px;
    line-height: 2.35;
    margin-bottom: 20px;
}
/* areaMeals */

/* areaPlan */
.areaPlan {
    background-color: #F2EDE5;
    padding: 57px 0 99px;
}
.areaPlan .areaTitle{
    margin-bottom: 67px;
}
.areaPlan .planSub {
    font-size: 15px;
    font-weight: 400;
    margin-bottom: 20px;
}
.areaPlan .planNote {
    font-size: 15px;
    font-weight: 400;
    color: #FF0000;
    margin-bottom: 20px;
}
.areaPlan .planWrap .planBox{
    background-color: #fff;
    border-radius: 7px;
    padding: 53px 0 83px;
    box-shadow: 0 0 6px rgba(0,0,0,0.13);
}
.areaPlan .planWrap .planBox:not(:last-child) {
    margin-bottom: 70px;
}
.areaPlan .planWrap .planBox .planChef {
    width: 341px;
    margin: 0 auto 5px;
}
.areaPlan .planWrap .planBox .planChef img {
    width: 100%;
    aspect-ratio: 341/34;
}
.areaPlan .planWrap .planBox .planDish {
    text-align: center;
    font-size: 45px;
    font-weight: bold;
    color: #623562;
    /* margin-bottom: 17px; */
    margin: 20px 60px 40px;
    line-height: 120%;
}
.areaPlan .planWrap .planBox .planPhoto {
    width: 100%;
    margin-bottom: 37px;
}
.areaPlan .planWrap .planBox .planPhoto img {
    width: 100%;
    aspect-ratio: 880/300;
    object-fit: cover;
    object-position: center;
}
.areaPlan .planWrap .planBox .flanDetail {
    width: 100%;
    max-width: 660px;
    margin: 0 auto 34px;
}
.areaPlan .planWrap .planBox .flanDetail .flanDetailSub {
    font-size: 15px;
    margin-bottom: 28px;
    line-height: 2;
}
.areaPlan .planWrap .planBox .flanDetail .detailList li {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    font-size: 18px;
    padding: 13px 21px 12px;
    border-bottom: 1px solid rgba(212, 212, 212,0.7);
}
.areaPlan .planWrap .planBox .flanDetail .detailList li:first-child {
    border-top: 1px solid rgba(212, 212, 212,0.7);
}
.areaPlan .planWrap .planBox .flanDetail .detailList li .detailName {
    width: 100px;
    font-weight: bold;
    color: #623562;
}
.areaPlan .planWrap .planBox .flanDetail .detailList li .detailSub {
    width: calc(100% - 128px);
    line-height: 1.7;
}
.areaPlan .planWrap .planBox .flanTable {
    width: 100%;
    max-width: 560px;
    margin: 0 auto;
}
.areaPlan .planWrap .planBox .flanTable .tableDate {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 18px;
}
.areaPlan .planWrap .planBox .flanTable .tableDate .dateSub {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 77px;
    text-align: center;
    font-size: 18px;
    font-weight: bold;
    color: #fff;
    padding: 8px 12px;
    background: #9084FF;
    border-radius: 6px 0 0 6px;
}
.areaPlan .planWrap .planBox .flanTable .tableDate .dateSelect {
    width: calc(100% - 77px);
    font-family: "Noto Sans JP", sans-serif;
    font-size: 18px;
    border: 1px solid #9084FF;
    border-radius: 0 6px 6px 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding: 15px 35px 15px 27px;
    background: url(../images/index/icon-triangle.svg)no-repeat right 13px center/17px;
    cursor: pointer;
    color: #000000;
}
.areaPlan .planWrap .planBox .flanTable .tableStatus {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    font-size: 18px;
    font-weight: bold;
    background-color: #FFEDED;
    padding: 15px 14px 15px 18px;
    margin-bottom: 23px;
}
.areaPlan .planWrap .planBox .flanTable .tableStatus .statusText {
    width: calc(100% - 110px);
    color: #FF0000;
}
.areaPlan .planWrap .planBox .flanTable .tableStatus .statusNote {
    width: 99px;
    text-align: center;
    color: #FFFFFF;
    padding: 4px 5px 5px;
    background-color: #FF0000;
    line-height: 1.2;
}
.areaPlan .planWrap .planBox .flanTable .tableNote {
    font-size: 13px;
    color: #FF0000;
    margin-bottom: 36px;
    letter-spacing: 0.1px;
}
.areaPlan .planWrap .planBox .flanTable .tableTicket {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 34px;
}
.areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    width: calc(50% - 13px);
    background-color: #F5F5F5;
    padding: 13px 16px 15px;
}
.areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketPerson {
    width: 60px;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    margin-right: 10px;
    margin-top: -4px;
}
.areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketPerson .note {
    display: block;
    font-size: 10px;
    font-weight: 400;
}
.areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketControl {
    width: 152px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}
.areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketControl button {
    width: 50px;
    aspect-ratio: 1/1;
    border: 1px solid rgba(144,132,255,0.5);
    border-radius: 50%;
    background: url(../images/index/icon-minus-purple.svg)no-repeat center center/14px;
    color: transparent;
}
.areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketControl button.btnPlus {
    border-color: #9084ff;
    background-color: #9084ff;
    background-image: url(../images/index/icon-plus-white.svg);
    background-size: 19px;
}
.areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketControl .ticketCount {
    display: inline-block;
    width: 40px;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    margin: 0 6px;
}
.areaPlan .planWrap .planBox .flanTable .tableTotal {
    text-align: center;
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 37px;
}
.areaPlan .planWrap .planBox .flanTable .tableTotal .totalPeople {
    display: inline-block;
    font-size: 34px;
    letter-spacing: 2px;
    margin-right: 3px;
    margin-left: 4px;
}
.areaPlan .planWrap .planBox .flanTable .tableTotal .totalPeople .unit {
    font-size: 24px;
}
.areaPlan .planWrap .planBox .flanTable .tableTotal .totalPrice {
    font-size: 35px;
    letter-spacing: 2px;
}
.areaPlan .planWrap .planBox .flanTable .tableTotal .totalPrice .unit {
    font-size: 25px;
}
.areaPlan .planWrap .planBox .flanTable .tableBtn {
    width: 100%;
    max-width: 561px;
    margin: 0 auto;
}
.areaPlan .planWrap .planBox .flanTable .tableBtn button {
    display: block;
    width: 100%;
    text-align: center;
    font-size: 18px;
    font-weight: bold;
    font-family: "Noto Sans JP", sans-serif;
    color: #fff;
    border-radius: 50px;
    padding: 12px 10px;
    background: #9084FF;
    border: 2px solid #9084FF;
}
.areaPlan .planWrap .planBox .flanTable .tableBtn button.unactive {
    pointer-events: none;
    background: #333;
    border-color: #333;
    opacity: 0.5;
}
/* areaPlan */

/* areaReview */
.areaReview {
    padding: 87px 0 88px;
}
.areaReview .areaTitle {
    margin-bottom: 64px;
}
.areaReview .reviewList .reviewBox {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    background-color: #F5F5F5;
    border-radius: 7px;
    box-shadow: 0 0 6px rgba(0,0,0,0.13);
    padding: 30px 33px;
}
.areaReview .reviewList .reviewBox:not(:last-child) {
    margin-bottom: 31px;
}
.areaReview .reviewList .reviewBox .reviewAvatar {
    width: 110px;
    aspect-ratio: 1/1;
    margin-right: 15px;
}
.areaReview .reviewList .reviewBox .reviewAvatar img {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background-color: #fff;
    object-fit: cover;
    object-position: center;
}
.areaReview .reviewList .reviewBox .reviewInfo {
    width: 93px;
    margin-right: 33px;
    margin-bottom: 3px;
}
.areaReview .reviewList .reviewBox .reviewInfo p {
    font-size: 15px;
    margin-left: 3px;
}
.areaReview .reviewList .reviewBox .reviewInfo .infoName {
    font-weight: bold;
    margin-bottom: -3px;
}
.areaReview .reviewList .reviewBox .reviewInfo .infoLive {
    margin-bottom: 6px;
}
.areaReview .reviewList .reviewBox .reviewInfo .reviewRate {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.areaReview .reviewList .reviewBox .reviewInfo .reviewRate li {
    position: relative;
    width: 15px;
}
.areaReview .reviewList .reviewBox .reviewInfo .reviewRate li img {
    width: 100%;
    aspect-ratio: 1/1;
}
.areaReview .reviewList .reviewBox .reviewInfo .reviewRate li .yellow {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
}
.areaReview .reviewList .reviewBox .reviewInfo .reviewRate li.active .grey {
    opacity: 0;
}
.areaReview .reviewList .reviewBox .reviewInfo .reviewRate li.active .yellow {
    opacity: 1;
}
.areaReview .reviewList .reviewBox .reviewSub {
    width: calc(100% - 251px);
    font-size: 15px;
    letter-spacing: -0.4px;
    line-height: 2;
}
.areaReview .reviewList .reviewBox .reviewSub .bg {
    display: inline;
    background-color: #FFFF00;
    white-space: break-spaces;
    -webkit-box-decoration-break: clone;
    border-radius: 5px;
    padding: 1px 0;
}
/* areaReview */

/* areaFaq */
.areaFaq {
    background-color: #F5F5F5;
    padding: 73px 0 52px;
    margin-bottom: 109px;
}
.areaFaq .areaTitle {
    padding: 6px 10px 10px;
    margin-bottom: 63px;
}
.areaFaq .faqWrap .faqBox:not(:last-child) {
    margin-bottom: 51px;
}
.areaFaq .faqWrap .faqBox .faqQuest {
    position: relative;
    font-size: 15px;
    font-weight: bold;
    background-color: #DEDEDE;
    padding: 4px 10px 5px 23px;
    margin-bottom: 23px;
}
.areaFaq .faqWrap .faqBox .faqQuest::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 13px;
    height: 100%;
    background-color: #623562;
}
.areaFaq .faqWrap .faqBox .faqAnswer {
    width: 100%;
}
.areaFaq .faqWrap .faqBox .faqAnswer .answerSub:not(:last-child) {
    margin-bottom: 10px;
}
.areaFaq .faqWrap .faqBox .faqAnswer li {
    font-size: 15px;
    letter-spacing: 0.2px;
}
.areaFaq .faqWrap .faqBox .faqAnswer li:not(:last-child) {
    margin-bottom: 7px;
}
/* areaFaq */

/* areaMap */
.areaMap {
    padding-top: 52px;
    margin-bottom: 60px;
}
.areaMap .mapWrap {
    margin-bottom: 49px;
}
.areaMap .mapWrap .areaTitle {
    margin-bottom: 62px;
}
.areaMap .mapWrap .mapDetail {
    width: 100%;
    max-width: 660px;
    margin: 0 auto 35px;
}
.areaMap .mapWrap .mapDetail iframe {
    width: 100%;
    aspect-ratio: 660/431;
}
.areaMap .mapWrap .mapBtn{
    width: 284px;
    margin: 0 auto;
}
.areaMap .mapWrap .mapBtn a {
    position: relative;
    display: block;
    width: 100%;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 0.5px;
    background-color: #F5F5F5;
    border-radius: 40px;
    padding: 7px 10px;
}
.areaMap .mapWrap .mapBtn a::before {
    content: "";
    position: absolute;
    top: 46%;
    left: 55px;
    transform: translateY(-50%);
    width: 40px;
    aspect-ratio: 39/33;
    background: url(../images/index/icon-map.svg)no-repeat top left/100%;
}
.areaMap .mapWrap .mapBtn a .sub {
    padding-left: 56px;
}
.areaMap .mapInstruct {
    background: #F5F5F5;
    padding: 81px 0 63px;
}
.areaMap .mapInstruct .instructWrap .instructBox {
    width: 100%;
    max-width: 660px;
    margin: 0 auto;
}
.areaMap .mapInstruct .instructWrap .instructBox:not(:last-child) {
    margin-bottom: 61px;
}
.areaMap .mapInstruct .instructWrap .instructBox:first-child {
    margin-bottom: 56px;
}
.areaMap .mapInstruct .instructWrap .instructBox .instructTitle {
    text-align: center;
    font-size: 18px;
    font-weight: bold;
    border-top: 1px solid #BFBFBF;
    border-bottom: 1px solid #BFBFBF;
    padding: 11px 0 12px;
    margin-bottom: 40px;
}
.areaMap .mapInstruct .instructWrap .instructBox:first-child .instructTitle {
    margin-bottom: 15px;
}
.areaMap .mapInstruct .instructWrap .instructBox .instructSub {
    font-size: 15px;
    line-height: 2.35;
    margin-left: 5px;
}
.areaMap .mapInstruct .instructWrap .instructBox .instructVideo {
    width: 100%;
}
.areaMap .mapInstruct .instructWrap .instructBox .instructVideo iframe {
    width: 100%;
    aspect-ratio: 660/407;
}
.areaMap .mapInstruct .instructWrap .instructBox .instructBoxPhoto {
    display: none;
    margin-top: 30px;
}
.areaMap .mapInstruct .instructWrap .instructBox .instructBoxPhoto .boxPhoto:not(:last-child) {
    margin-bottom: 30px;
}
.areaMap .mapInstruct .instructWrap .instructBox .intructPhoto {
    width: 100%;
    margin-bottom: 27px;
}
.areaMap .mapInstruct .instructWrap .instructBox .intructPhoto img {
    width: 100%;
}
.areaMap .mapInstruct .instructWrap.instructWrapHidden {
    display: none;
}
.areaMap .mapInstruct .instructMore {
    position: relative;
    display: block;
    width: 350px;
    text-align: center;
    font-size: 15px;
    border: 1px solid #BFBFBF;
    border-radius: 8px;
    padding: 11px 10px 12px 8px;
    letter-spacing: -0.5px;
    margin: 44px auto 0;
    cursor: pointer;
}
.areaMap .mapInstruct .instructMore::before {
    content: "";
    position: absolute;
    top: 52%;
    left: 11px;
    transform: translateY(-50%);
    width: 15px;
    aspect-ratio: 15/10;
    background: url(../images/index/icon-triangle.svg)no-repeat top left/100%;
    transition: all .3s;
}
.areaMap .mapInstruct .instructMore .close {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    opacity: 0;
}
.areaMap .mapInstruct .instructMore.show .open {
    color: transparent;
}
.areaMap .mapInstruct .instructMore.show .close {
    opacity: 1;
}
.areaMap .mapInstruct .instructMore.show::before {
    transform: translateY(-50%) rotate(180deg);
}
/* areaMap */

/* areaContactUs */
.areaContactUs {
    margin-bottom: 72px;
}
.areaContactUs .contactUsWrap {
    width: 100%;
    max-width: 652px;
    background-color: #F5F5F5;
    border-radius: 29px;
    padding: 26px 45px 46px;
    margin: 0 auto 68px;
}
.areaContactUs .contactUsWrap .contactUsTitle {
    text-align: center;
    font-size: 23px;
    font-weight: bold;
    color: #623562;
    margin-bottom: 40px;
}
.areaContactUs .contactUsWrap .contactUsSub {
    font-size: 15px;
    margin-bottom: 13px;
    line-height: 2;
}
.areaContactUs .contactUsWrap .contactUsNote {
    font-size: 15px;
    margin-bottom: 43px;
    line-height: 1.95;
}
.areaContactUs .contactUsWrap .contactUsBtn {
    width: 273px;
    margin: 0 auto;
}
.areaContactUs .contactUsWrap .contactUsBtn a {
    display: block;
    width: 100%;
    text-align: center;
    font-size: 18px;
    font-weight: bold;
    color: #fff;
    background-color: #303030;
    border-radius: 50px;
    padding: 7px 5px 6px;
    border: 2px solid #303030;
}
.areaContactUs .contactUsNetwork {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.areaContactUs .contactUsNetwork li:not(:last-child) {
    margin-right: 28px;
}
.areaContactUs .contactUsNetwork li a {
    position: relative;
}
.areaContactUs .contactUsNetwork li img {
    height: 44px;
}
.areaContactUs .contactUsNetwork li .purple {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
}
/* areaContactUs */

@media(max-width:1120px) and (min-width: 769px) {
    .areaAboutM7 .aboutM7Intro {
        padding: 150px 0;
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList li {
        width: calc(100% / 3 - 16px);
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList li:not(:last-child) {
        margin-right: 24px;
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList li .introPhoto {
        margin-bottom: 20px;
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList li .introSub {
        font-size: 16px;
    }
    .areaAboutM7 .aboutM7Service {
        padding: 120px 0 100px;
    }
    .areaAboutM7 .aboutM7Service .serviceList li {
        width: calc(100% / 3 - 16px);
    }
    .areaAboutM7 .aboutM7Service .serviceList li:not(:last-child) {
        margin-right: 24px;
    }
}
@media(max-width:1055px) and (min-width: 769px) {
    .areaAboutM7 .aboutM7Service .serviceList li .serviceName {
        font-size: 21px;
    }
    .areaAboutM7 .aboutM7Service .serviceList li .serviceSub {
        font-size: 14px;
    }
}
@media(max-width: 950px) and (min-width: 769px) {
    .areaAboutM7 .aboutM7Service .serviceList li .serviceName br {
        display: none;
    }
}
@media(max-width: 890px) and (min-width: 769px) {
    .areaAboutM7 .aboutM7Service .serviceList li .serviceName {
        font-size: 18px;
    }
}
@media(max-width: 790px) and (min-width: 769px) {
    .areaAboutM7 .aboutM7Service .serviceList li .serviceName {
        font-size: 17px;
    }
}
@media(min-width: 769px) {
    .areaPlan .planWrap .planBox .flanTable .tableBtn button:hover {
        background-color: #fff;
        color: #9084FF;
    }
    .areaMap .mapWrap .mapBtn a:hover {
        background-color: #303030;
        color: #fff;
    }
    .areaMap .mapWrap .mapBtn a:hover::before {
        background-image: url(../images/index/icon-map-white.svg);
    }
    .areaMap .mapInstruct .instructMore:hover {
        background-color: #303030;
        border-color: #303030;
        color: #fff;
    }
    .areaMap .mapInstruct .instructMore:hover:before {
        background-image: url(../images/index/icon-triangle-white.svg);
    }
    .areaContactUs .contactUsWrap .contactUsBtn a:hover {
        background-color: #fff;
        color: #303030;
    }
    .areaContactUs .contactUsNetwork li a:hover .basic {
        opacity: 1;
    }
    .areaContactUs .contactUsNetwork li a:hover .purple {
        opacity: 1;
    }
    .areaMeals .mealsWrap .mealsBox .mealsDetail.detailSpecial .mealsSub {
        font-size: 18px;
        line-height: 1.5;
    }
    .areaMeals .mealsWrap .mealsBox .mealsDetail.detailSpecial .mealsNote {
        margin-bottom: 15px;
    }
    .areaMeals .mealsWrap .mealsBox .mealsSub .noto {
        font-size: 15px;
    }
}
@media(max-width: 768px) {

    #main {
        position: relative;
    }
    #main .mainArrow {
        bottom: 35%;
    }
    #main .mainWrap .mainBox .mainPhoto img {
        width: 100%;
        height: 100vh;
        object-fit: cover;
        object-position: center;
    }
    #main .mainWrap .slick-slide .mainBox .mainInfo {
        top: 46.7%;
        width: 80%;
    }
    #main .mainWrap .mainBox .mainInfo .mainLogo {
        display: block;
        width: clamp(86px, 23vw, 100px);
        margin: 0 auto 25px;
    }
    #main .mainWrap .mainBox .mainInfo .mainSlogan {
        position: relative;
        display: inline-block;
        width: clamp(200px, 53vw, 270px);
        margin: 0 auto 30px;
    }
    #main .mainWrap .mainBox .mainInfo .mainSlogan::before {
        content: "";
        position: absolute;
        bottom: -22px;
        left: 50%;
        transform: translateX(-50%);
        width: clamp(315px,80vw,400px);
        aspect-ratio: 315 / 53;
        background: url(../images/index/main-photo-06.webp) no-repeat top left / 100%;
    }
    #main .mainWrap .mainBox .mainInfo {
        top: 46.8%;
    }
    #main .mainWrap .slick-slide.mainBox:first-child .mainInfo {
        top: 42.5%;
    }
    #main .mainWrap .slick-slide.mainBox:first-child .mainInfo .mainSub {
        font-size: clamp(14px, 3.7vw, 18px);
    }
    #main .mainWrap .mainBox .mainInfo .mainSub {
        width: 90vw;
        font-size: clamp(14px, 3.7vw, 18px);
        line-height: 2;
    }
    #main .mainWrap .mainBox .mainNumber {
        bottom: clamp(135px,32vw,220px);
        left: 50.5%;
        font-size: clamp(10px,2.6vw,14px);
    }
    #main .mainWrap .slick-dots li {
        width: 71px;
    }
    #main .mainWrap .slick-dots {
        bottom: clamp(112px,29vw,190px);
    }
    #main .mainMenuAnchor {
        position: absolute;
        bottom: 10px;
        left: 50%;
        transform: translateX(-50%);
        width: 95%;
    }
    #main .mainMenuAnchor .menuAnchor {
        display: flex;
        flex-wrap: wrap;
    }
    #main .mainMenuAnchor .menuAnchor li {
        width: calc(100% / 3 - 1%);
        margin: 3px 0 2px;
    }
    #main .mainMenuAnchor .menuAnchor li:not(:nth-child(3n)) {
        margin-right: 1.5%;
    }
    #main .mainMenuAnchor .menuAnchor li a {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        background-color: #000000;
        border: 1px solid rgba(255,255,255,0.6);
        padding: 8px 5px;
    }
    #main .mainMenuAnchor .menuAnchor li a .icon {
        width: clamp(43px,11vw,50px);
    }
    #main .mainMenuAnchor .menuAnchor li a .icon img {
        display: block;
        width: 100%;
        max-width: clamp(24px,6vw,45px);
        margin: 0 auto;
    }
    #main .mainMenuAnchor .menuAnchor li a .name {
        width: calc(100% - clamp(29px,8vw,35px));
        text-align: center;
        font-size: clamp(12px, 3.1vw, 15px);
        color: #fff;
        margin-left: -15px;
    }

    .areaAboutM7 {
        padding-top: 9.8vw;
    }
    .areaAboutM7 .aboutM7Video {
        margin-bottom: 8.6vw;
    }
    .areaAboutM7 .aboutM7Video iframe {
        width: 100%;
        aspect-ratio: 660/407;
    }
    .areaAboutM7 .aboutM7Title {
        font-size: clamp(22px,5.8vw,28px);
        letter-spacing: -1px;
        margin-bottom: 12vw;
    }
    .areaAboutM7 .aboutM7Title::before {
        bottom: -10px;
        left: 50%;
        width: 69px;
    }
    .areaAboutM7 .aboutM7Intro {
        padding: 17.5vw 11vw 13.1vw;
        background-image: url(../images/index/area-about-m7-photo-01-sp.webp);
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList {
        width: 100%;
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList li {
        width: 100%;
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList li:not(:last-child) {
        margin: 0 0 13.3vw;
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList li .introPhoto {
        margin-bottom: 8.2vw;
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList li .introPhoto img {
        aspect-ratio: 270/117;
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList li .introSub {
        position: relative;
        width: 100%;
        text-align: left;
        font-size: clamp(15px,4vw,20px);
        padding-left: 5.8vw;
        letter-spacing: 1.4px;
    }
    .areaAboutM7 .aboutM7Intro .m7IntroList li .introSub::before {
        content: "";
        position: absolute;
        top: -5.4vw;
        left: -0.5vw;
        width: 100%;
        aspect-ratio: 270/49;
        background: url(../images/index/area-about-m7-photo-08.webp)no-repeat top left/100%;
    }
    .areaAboutM7 .aboutM7Service {
        padding: 0 0 7vw;
    }
    .areaAboutM7 .aboutM7Service .serviceList {
        width: 100%;
    }
    .areaAboutM7 .aboutM7Service .serviceList li {
        width: 100%;
    }
    .areaAboutM7 .aboutM7Service .serviceList li:not(:last-child) {
        margin: 0 0 11vw;
    }
    .areaAboutM7 .aboutM7Service .serviceList li .servicePhoto {
        margin-bottom: 7.1vw;
    }
    .areaAboutM7 .aboutM7Service .serviceList li .servicePhoto img {
        aspect-ratio: 375 / 213;
    }
    .areaAboutM7 .aboutM7Service .serviceList li .serviceName {
        font-size: clamp(18px, 4.8vw, 24px);
        line-height: 1.8;
        margin-bottom: 3.3vw;
    }
    .areaAboutM7 .aboutM7Service .serviceList li .serviceSub {
        font-size: clamp(15px, 4vw, 20px);
        width: 77%;
        margin: 0 auto;
        letter-spacing: -0.7px;
        line-height: 2.35;
    }

    .areaMeals {
        padding-top: 5vw;
        margin-bottom: clamp(34px,9vw,50px);
    }
    .areaMeals .areaTitle {
        margin-bottom: clamp(39px, 10vw, 50px);
    }
    .areaMeals .mealsWrap .mealsBox:not(:last-child) {
        margin-bottom: 86px;
    }
    .areaMeals .mealsWrap .mealsBox:not(:last-child)::before {
        bottom: -47px;
        width: 84%;
    }
    .areaMeals .mealsWrap .mealsBox .mealsChef {
        width: clamp(182px, 47vw, 300px);
        margin-bottom: clamp(4px,1.2vw,10px);
    }
    .areaMeals .mealsWrap .mealsBox .mealsDish {
        font-size: clamp(31px,7.2vw,40px);
        margin-bottom: clamp(28px,7vw,40px);
    }
    .areaMeals .mealsWrap .mealsBox .mealsPhoto {
        width: 108.6%;
        margin: 0 0 clamp(30px,8vw,40px) -4.3%;
    }
    .areaMeals .mealsWrap .mealsBox .mealsPhoto img {
        aspect-ratio: 372/271;
    }
    .areaMeals .mealsWrap .mealsBox .mealsDetail .mealsNote {
        text-align: center;
        line-height: 1.4;
        font-size: clamp(17px, 4.4vw, 23px);
        margin-bottom: clamp(23px,5.5vw,35px);
    }
    .areaMeals .mealsWrap .mealsBox .mealsNote br {
        display: none;
    }
    .areaMeals .mealsWrap .mealsBox .mealsSub {
        font-size: clamp(15px,4vw,20px);
        text-align: justify;
        line-height: 2.34;
        padding: 0 8%;
    }
    .areaMeals .mealsWrap .mealsBox .mealsSub .subNote {
        line-height: 2;
    }
    .areaMeals .mealsWrap .mealsBox .mealsSub .space {
        display: inline-block;
        margin-left: clamp(15px,4vw,19px);
    }
    .areaMeals .mealsWrap .mealsBox .mealsDetail h3 {
        font-size: clamp(17px, 4.4vw, 23px)!important;
        line-height: 1.4;
        padding: 0 8%;
        margin-bottom: clamp(23px, 5.5vw, 35px);
    }
    .areaMeals .mealsWrap .mealsBox .mealsDetail p {
        font-size: clamp(15px,4vw,20px)!important;
        text-align: justify;
        line-height: 2.34;
        padding: 0 8%;
        margin-bottom: 20px;
    }
    .areaMeals .mealsWrap .mealsBox .mealsDetail p span {
        font-size: clamp(15px,4vw,20px)!important;
    }
    .areaPlan {
        padding: 36px 0 42px;
    }
    .areaPlan .inner {
        padding: 0 5.3%;
    }
    .areaPlan .areaTitle {
        width: 105.8%;
        margin-left: -2.9%;
        margin-bottom: 6.5vw;
    }

    .areaPlan .planSub {
        font-size: clamp(15px, 4vw, 20px);
        margin-bottom: clamp(20px, 5vw, 30px);
        line-height: 2;
        letter-spacing: -0.5px;
    }
    .areaPlan .planNote {
        font-size: clamp(15px, 4vw, 20px);
        margin-bottom: clamp(29px, 7vw, 40px);
        line-height: 2;
        letter-spacing: -0.5px;
    }
    .areaPlan .planWrap .planBox {
        padding: 23px 0 31px;
    }
    .areaPlan .planWrap .planBox:not(:last-child) {
        margin-bottom: 34px;
    }
    .areaPlan .planWrap .planBox .planChef {
        width: clamp(174px,46vw,300px);
        margin-bottom: -2px;
    }
    .areaPlan .planWrap .planBox .planDish {
        font-size: clamp(24px,6.4vw,30px);
        margin-bottom: clamp(12px,3vw,20px);
    }
    .areaPlan .planWrap .planBox .planPhoto {
        margin-bottom: 0;
    }
    .areaPlan .planWrap .planBox .planPhoto img {
        aspect-ratio: 355/195;
    }
    .areaPlan .planWrap .planBox .flanDetail {
        max-width: none;
        margin-bottom: clamp(17px,3.2vw,25px);
    }
    .areaPlan .planWrap .planBox .flanDetail .flanDetailSub {
        font-size: clamp(13px, 3.4vw, 16px);
        padding: clamp(11px, 3vw, 20px) clamp(26px, 7vw, 40px);
        margin: 0;
        letter-spacing: -1px;
        line-height: 1.95;
    }
    .areaPlan .planWrap .planBox .flanDetail .detailList li {
        align-items: center;
        font-size: clamp(14px, 3.7vw, 18px);
        padding: clamp(3px,0.8vw,10px) clamp(19px,5.1vw,40px);
    }
    .areaPlan .planWrap .planBox .flanDetail .detailList li .detailName {
        width: 25%;
        line-height: 1.9;
    }
    .areaPlan .planWrap .planBox .flanDetail .detailList li .detailSub {
        width: 70.4%;
        letter-spacing: 1px;
        line-height: 1.9;
    }
    .areaPlan .planWrap .planBox .flanTable {
        max-width: none;
        padding: 0 clamp(9px,1.5vw,15px);
    }
    .areaPlan .planWrap .planBox .flanTable .tableDate .dateSub {
        width: 15.5%;
        font-size: clamp(13px,3.4vw,16px);
        padding: 5px 5px;
    }
    .areaPlan .planWrap .planBox .flanTable .tableDate .dateSelect {
        width: 84.5%;
        font-size: clamp(13px,3.4vw,16px);
        padding: 8px 25px 8px 17px;
        background-position: right 7px center;
    }
    .areaPlan .planWrap .planBox .flanTable .tableDate {
        margin-bottom: clamp(17px,3.2vw,25px);
    }
    .areaPlan .planWrap .planBox .flanTable .tableStatus {
        font-size: clamp(15px,4vw,20px);
        padding: 7px 11px 6px;
        margin-bottom: clamp(17px,3.2vw,25px);
    }
    .areaPlan .planWrap .planBox .flanTable .tableStatus .statusText {
        width: 70%;
        letter-spacing: 0.9px;
        /* text-align: right; */
        margin-right: 5%;
    }
    .areaPlan .planWrap .planBox .flanTable .tableStatus .statusNote {
        width: 22%;
        max-width: 100px;
        font-size: clamp(13px,3.4vw,16px);
        padding: 2px 5px 3px;
    }
    .areaPlan .planWrap .planBox .flanTable .tableNote {
        font-size: clamp(13px,3.4vw,16px);
        line-height: 1.2;
        margin-left: 10px;
        margin-bottom: 19px;
    }
    .areaPlan .planWrap .planBox .flanTable .tableTicket {
        justify-content: center;
        gap: 8px;
        margin-bottom: 13px;
    }
    .areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox {
        width: 285px;
        padding: 13px 17px 14px;
    }
    .areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketPerson {
        width: calc(100% - 170px);
        font-size: clamp(20px,5.2vw,26px);
    }
    .areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketPerson .note {
        font-size: clamp(10px,2.6vw,14px);
    }
    .areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketControl {
        width: 147px;
    }
    .areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketControl button {
        width: 48px;
    }
    .areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox .ticketControl .ticketCount {
        width: 35px;
        font-size: clamp(20px,5.2vw,26px);
    }
    .areaPlan .planWrap .planBox .flanTable .tableTotal {
        font-size: clamp(13px,3.4vw,16px);
        margin-bottom: 15px;
    }
    .areaPlan .planWrap .planBox .flanTable .tableTotal .totalPeople {
        font-size: clamp(20px,5.2vw,26px);
    }
    .areaPlan .planWrap .planBox .flanTable .tableTotal .totalPeople .unit {
        font-size: clamp(14px, 3.7vw, 18px);
    }
    .areaPlan .planWrap .planBox .flanTable .tableTotal .totalPrice {
        font-size: clamp(20px,5.2vw,26px);
    }
    .areaPlan .planWrap .planBox .flanTable .tableTotal .totalPrice .unit {
        font-size: clamp(14px, 3.7vw, 18px);
    }
    .areaPlan .planWrap .planBox .flanTable .tableBtn {
        width: 89%;
        max-width: 350px;
    }
    .areaPlan .planWrap .planBox .flanTable .tableBtn button {
        font-size: clamp(18px, 4.8vw, 24px);
    }

    .areaReview {
        padding: clamp(21px,4vw,35px) 0 clamp(29px,4vw,35px);
    }
    .areaReview .areaTitle {
        margin-bottom: clamp(32px, 6vw, 40px);
    }
    .areaReview .reviewList {
        width: 96.7%;
        margin: 0 auto;
    }
    .areaReview .reviewList .reviewBox {
        padding: 22px 22px 23px;
    }
    .areaReview .reviewList .reviewBox:not(:last-child) {
        margin-bottom: 6.7vw;
    }
    .areaReview .reviewList .reviewBox .reviewAvatar {
        width: 94px;
        margin-right: 16px;
    }
    .areaReview .reviewList .reviewBox .reviewInfo {
        width: calc(100% - 110px);
        margin: -7px 0 0;
    }
    .areaReview .reviewList .reviewBox .reviewInfo p {
        font-size: clamp(15px,4vw,20px);
        margin-left: 0;
    }
    .areaReview .reviewList .reviewBox .reviewInfo .reviewRate {
        width: 148px;
    }
    .areaReview .reviewList .reviewBox .reviewInfo .reviewRate li {
        width: 24px;
    }
    .areaReview .reviewList .reviewBox .reviewSub {
        width: 100%;
        font-size: clamp(15px,4vw,20px);
        margin-top: 18px;
    }
    .areaFaq {
        padding: clamp(18px,4vw,35px) 0 clamp(27px,4vw,35px);
        margin-bottom: 0;
    }
    .areaFaq .areaTitle {
        margin-bottom:clamp(41px,10vw,50px);
    }
    .areaFaq .faqWrap {
        width: 102.8%;
        margin-left: -1.4%;
    }
    .areaFaq .faqWrap .faqBox:not(:last-child) {
        margin-bottom: clamp(37px, 9vw, 45px);
    }
    .areaFaq .faqWrap .faqBox .faqAnswer li {
        font-size: clamp(15px,4vw,20px);
    }
    .areaMap {
        padding-top: 16px;
        margin-bottom: 51px;
    }
    .areaMap .mapWrap {
        margin-bottom: clamp(20px,5.3vw,40px);
    }
    .areaMap .mapWrap .areaTitle {
        margin-bottom: clamp(25px, 7vw, 40px);
    }
    .areaMap .mapWrap .mapDetail {
        width: 103%;
        max-width: none;
        margin: 0 0 14px -1.5%;
    }
    .areaMap .mapWrap .mapDetail iframe {
        aspect-ratio: 355/232;
    }
    .areaMap .mapWrap .mapBtn {
        width: 270px;
    }
    .areaMap .mapWrap .mapBtn a {
        font-size: clamp(14px, 3.7vw, 18px);
        letter-spacing: 0.5px;
        padding: clamp(6px,1.5vw,15px) 10px;
    }
    .areaMap .mapWrap .mapBtn a .sub {
        padding-left: 28px;
    }
    .areaMap .mapWrap .mapBtn a::before {
        left: clamp(27px,5vw,35px);
        width: clamp(27px,5vw,35px);
        aspect-ratio: 27/23;
    }
    .areaMap .mapInstruct {
        background-color: transparent;
        padding: 0;
    }
    .areaMap .mapInstruct .inner {
        padding: 0 3%;
    }
    .areaMap .mapInstruct .instructWrap .instructBox:not(:last-child) {
        margin-bottom: clamp(25px,6vw,40px);
    }
    .areaMap .mapInstruct .instructWrap .instructBox:first-child {
        margin-bottom: clamp(44px,10vw,55px);
    }
    .areaMap .mapInstruct .instructWrap .instructBox:first-child .instructTitle {
        margin-bottom: clamp(20px,5vw,40px);
    }
    .areaMap .mapInstruct .instructWrap .instructBox .instructTitle{
        font-size: clamp(16px, 4.2vw, 22px);
        margin-bottom: clamp(29px,7vw,40px);
        padding: 13px 0;
    }
    .areaMap .mapInstruct .instructWrap .instructBox .instructSub {
        font-size: clamp(15px,4vw,20px);
        letter-spacing: -0.5px;
        line-height: 1.68;
        margin-left: 4px;
    }
    .areaMap .mapInstruct .instructWrap .instructBox .instructVideo{
        width: 100.8%;
        margin-left: -0.4%;
    }
    .areaMap .mapInstruct .instructWrap .instructBox .instructVideo iframe {
        aspect-ratio: 355/219;
    }
    .areaMap .mapInstruct .instructWrap .instructBox .intructPhoto {
        width: 99.8%;
        margin: 0 auto 14px;
    }
    .areaMap .mapInstruct .instructMore {
        margin-top: clamp(21px,5vw,30px);
    }
    .areaMap .mapInstruct .instructWrap .instructBox .instructBoxPhoto {
        margin-top: clamp(25px, 6vw, 40px);
    }
    .areaContactUs {
        margin-bottom: 87px;
    }
    .areaContactUs .contactUsWrap {
        padding: 28px 24px 29px;
        margin-bottom: 57px;
    }
    .areaContactUs .contactUsWrap .contactUsTitle {
        font-size: clamp(23px,6vw,29px);
        margin-bottom: 15px;
    }
    .areaContactUs .contactUsWrap .contactUsSub {
        font-size: clamp(15px,4vw,20px);
        line-height: 1.52;
        letter-spacing: -0.2px;
        margin-bottom: 18px;
    }
    .areaContactUs .contactUsWrap .contactUsNote {
        font-size: clamp(15px,4vw,20px);
        line-height: 1.52;
        margin-bottom: 39px;
    }
    .areaContactUs .contactUsWrap .contactUsBtn {
        width: 270px;
    }
    .areaContactUs .contactUsWrap .contactUsBtn a {
        font-size: clamp(18px, 4.8vw, 24px);
        padding: 9px 5px;
    }


    @media (orientation:landscape) {
        #main .mainWrap .mainBox .mainPhoto img {
            height: auto;
        }
    }
}

@media(max-width: 430px) {
    .areaMap .mapWrap .mapBtn {
        width: 183px;
    }
    .areaMeals .mealsWrap .mealsBox .mealsNote br {
        display: block;
    }
    .areaContactUs .contactUsWrap .contactUsBtn {
        width: 235px;
    }
    .areaPlan .planWrap .planBox .flanTable .tableTicket .ticketBox {
        width: 258px;
    }
}
@media(max-width: 360px) {
    .areaAboutM7 .aboutM7Intro {
        padding: 17.5vw 9vw 13.1vw;
    }
}

@media(max-height: 780px) and (min-width: 769px){

    #main .mainArrow {
        bottom: 170px;
    }
}
