/* main common */
.main_tit1 { text-align: center; padding-bottom: 70px; font-family: "Playfair Display";  font-weight: 800; font-size: 40px; color: #3c3c3c; line-height: 1.3; }

/* main_visual */
#main_visual { position: relative; height: 100vh; /* height: 980px; max-height: calc(100vh - 100px); */ overflow: hidden; }
#main_visual .mv_wrap { position: relative; height: 100%; }
#main_visual .mv_text { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
#main_visual .mv_text .contwrap { top: 100px; height: calc(100% - 100px); }
#main_visual .mv_slick { z-index: 1; position: relative; height: 100%; }
#main_visual .mv_slick .slick-list, #main_visual .mv_slick .slick-track, #main_visual .mv_slick .slick-slide, #main_visual .mv_slick .slick-slide > div { height: 100%; }
#main_visual .mv_slick .con { position: relative; height: 100%; }
#main_visual .mv_slick .con .bg { z-index: 1; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
#main_visual .mv_slick .slick-current .bg { animation: mv_bg forwards linear 3s; }
@keyframes mv_bg { 
    0% { transform: scale(1.1); }
    100% { transform: scale(1); }
}
#main_visual .mv_slick .con1 .bg { background: url(/image/main/mv_bg1.jpg) no-repeat center/cover; }
#main_visual .mv_slick .con2 .bg { background: url(/image/main/mv_bg2.jpg) no-repeat center/cover; }
#main_visual .mv_slick .con3 .bg { background: url(/image/main/mv_bg3.jpg) no-repeat center/cover; }
#main_visual .mv_slick .con .frame { z-index: 2; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.5); }

#main_visual .slick-dots { z-index: 10; position: absolute; left: 50%; transform: translateX(-50%); bottom: 20px; display: flex; flex-wrap: nowrap; }
#main_visual .slick-dots li { position: relative; width: 24px; height: 24px; border-radius: 50%; background-color: transparent; border: 2px solid transparent; margin: 0 6px; cursor: pointer; }
#main_visual .slick-dots li::after { display: block; content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 8px; height: 8px; background-color: #fff; border-radius: 50%; }
#main_visual .slick-dots li button { display: none; }
#main_visual .slick-dots li.slick-active { border: 2px solid #fff; }

#main_visual .mv_text .textbox { z-index: 4; position: relative; top: 50%; transform: translateY(-50%); text-align: left; }
#main_visual .mv_text .textbox .text1 { 
    background: linear-gradient(to right, #fff, #d1b19e, #d1b19e);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-family: "Playfair Display";
    font-weight: 800; font-size: 80px; line-height: 1.3;
    filter: drop-shadow(2px 2px 2px rgba(0, 0, 0, 0.75));
}
#main_visual .mv_text .textbox .text2 { font-weight: 300; font-size: 27px; color: #fff; text-shadow: 2px 0 2px rgba(0, 0, 0, 0.75); line-height: 1.3; }
#main_visual .mv_text .textbox .text3 { margin-top: 5px; font-size: 50px; color: #fff; text-shadow: 2px 0 2px rgba(0, 0, 0, 0.75); line-height: 1.3; }
#main_visual .mv_text .textbox .text3 span { display: inline-block; margin-left: 10px; font-size: 24px; color: #fff; }
#main_visual .mv_text .textbox a { position: relative; display: inline-block; margin-top: 33px; padding: 20px 35px; text-align: center; border: 2px solid #c5a590; border-radius: 100px; overflow: hidden; }
#main_visual .mv_text .textbox a span { z-index: 2; position: relative; display: inline-block; font-size: 20px; color: #c8a38d; transition: color 0.3s; }
#main_visual .mv_text .textbox a::after { display: block; content: ''; z-index: 1; position: absolute; top: -2%; left: -1%; width: 0; height: 104%; background-color: #c5a590; transition: width 0.3s; }
#main_visual .mv_text .textbox a:hover::after { width: 102%; }
#main_visual .mv_text .textbox a:hover span { color: #fff; }

#main_visual .videowrap { position: relative; height: 100%; }
#main_visual .videowrap video { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: auto; height: auto; min-width: 100%; min-height: 100%; max-width: 300%; }

@media (max-width: 1535px) {
    /* #main_visual { height: calc(470px + 22vw); max-height: calc(100vh - 90px); } */
    #main_visual .mv_text .contwrap { top: 90px; height: calc(100% - 90px); }
}
@media (max-width: 1279px) {
    /* #main_visual { height: calc(350px + 17vw); max-height: calc(100vh - 80px); } */
    #main_visual .mv_text .contwrap { top: 80px; height: calc(100% - 80px); }
}
@media (max-width: 1023px) {
    /* #main_visual { height: calc(300px + 15vw); max-height: calc(100vh - 70px); } */
    #main_visual .mv_text .contwrap { top: 70px; height: calc(100% - 70px); }

    #main_visual .slick-dots { bottom: 10px; }
    #main_visual .slick-dots li { width: 20px; height: 20px; }
    #main_visual .slick-dots li::after { width: 6px; height: 6px; }
}
@media (max-width: 767px) {
    #main_visual { height: calc(300px + 12vw); max-height: calc(100vh - 60px); }
    #main_visual .mv_text .contwrap { top: 60px; height: calc(100% - 60px); }

    #main_visual .videowrap video { max-width: 200%; }
}

/* main_company */
#main_company { position: relative; overflow: hidden; padding: 180px 0; background: url(/image/main/company_bg.jpg) no-repeat center/cover; }
#main_company .textbox { text-align: center; }
#main_company .textbox .text1 { font-size: 22px; color: #666; line-height: 1.36; }
#main_company .textbox .text2 { margin-top: 3px; font-size: 35px; color: #b0873a; line-height: 1.25; }
#main_company .textbox .text3 { margin-top: 60px; }
#main_company .textbox .text3 a { position: relative; display: inline-block; padding: 16px 70px; text-align: center; border-radius: 100px; border: 2px solid #b0873a; transition: background-color 0.3s; overflow: hidden; }
#main_company .textbox .text3 a::after { display: block; content: ''; z-index: 1; position: absolute; top: -2%; left: -1%; width: 0; height: 104%; background-color: #b0873a; transition: width 0.3s; }
#main_company .textbox .text3 a:hover::after { width: 102%; }
#main_company .textbox .text3 a span { z-index: 2; position: relative; display: inline-block; font-weight: 500; font-size: 18px; color: #b0873a; transition: color 0.3s; }
#main_company .textbox .text3 a:hover span { color: #fff; }
@media (max-width: 767px) {
    #main_company { background-position-x: 20%; }
}

/* main_offers */
#main_offers { position: relative; overflow: hidden; padding: 110px 0; }
#main_offers .ctwrap { position: relative; max-width: 1490px; margin-left: auto; margin-right: auto; }
#main_offers .contents { display: flex; flex-wrap: nowrap; justify-content: space-between; font-size: 20px; color: #232222; line-height: 1.25; }
#main_offers .contents * { font-size: inherit; color: inherit; line-height: inherit; }
#main_offers .contents > li { width: 23.5%; background-color: #ece7e4; }
#main_offers .contents > li .textbox { padding: 25px 8px; text-align: center; }
#main_offers .contents > li .imgbox img { width: 100%; }
@media (max-width: 1610px) {
    #main_offers .ctwrap { width: calc(100% - 120px); }
    #main_offers .contents > li .textbox { padding: 20px 7px; }
}
@media (max-width: 1230px) {
    #main_offers .ctwrap { width: calc(100% - 100px); }
    #main_offers .contents > li .textbox { padding: 15px 6px; }
}
@media (max-width: 1023px) {
    #main_offers .ctwrap { width: calc(100% - 80px); }
    #main_offers .contents { flex-wrap: wrap; }
    #main_offers .contents > li { width: 48%; }
    #main_offers .contents > li:nth-of-type(n + 3) { margin-top: 4%; }
}
@media (max-width: 767px) {
    #main_offers .ctwrap { width: calc(100% - 60px); }
}
@media (max-width: 460px) {
    #main_offers .ctwrap { width: calc(100% - 40px); }
}
@media (max-width: 424px) {
    #main_offers .contents { display: block; }
    #main_offers .contents > li { width: 100%; }
    #main_offers .contents > li:nth-of-type(n + 3) { margin-top: initial; }
    #main_offers .contents > li:nth-of-type(n + 2) { margin-top: 20px; }
}

/* main_ddi */
#main_ddi { position: relative; overflow: hidden; padding: 140px 0 100px; }
#main_ddi .bg { z-index: 1; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: url(/image/main/ddi_bg.jpg) no-repeat center/cover; background-attachment: fixed; }
#main_ddi .frame { z-index: 2; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.7); }
#main_ddi .textbox { z-index: 3; position: relative; text-align: center; }
#main_ddi .textbox .text1 { font-weight: 600; font-size: 35px; color: #fff; line-height: 1.42; }
#main_ddi .textbox .text2 { font-size: 22px; color: #fff; line-height: 1.59; }
@media (max-width: 767px) {
    #main_ddi .textbox .text2 br { display: none; }
}

/* #main_location */
#main_location { position: relative; overflow: hidden; padding: 100px 0; }
#main_location .contents { display: flex; flex-wrap: nowrap; justify-content: space-between; }
#main_location .contents > li { width: 47.6%; }
#main_location .contents > li .mapcont { position: relative; height: 420px; border-radius: 5px; overflow: hidden; }
#main_location .contents > li .mapcont iframe { width: 100%; height: 100%; }
#main_location .contents > li .mapdesc { margin-top: 18px; font-size: 18px; color: #727272; line-height: 1.38; }
#main_location .contents > li .mapdesc b { display: block; color: #000; }
#main_location .contents > li .mapdesc .br1 { display: none; }
@media (max-width: 1535px) {
    #main_location .contents > li .mapcont { height: calc(300px + 8.1vw); }
}
@media (max-width: 1023px) {
    #main_location .contents { display: block; }
    #main_location .contents > li { width: 100%; }
    #main_location .contents > li:nth-of-type(n + 2) { margin-top: 30px; }
    #main_location .contents > li .mapcont { height: calc(200px + 5vw); }
}
@media (max-width: 424px) {
    #main_location .contents > li .mapdesc .br1 { display: inline-block; }
}

/* inquiryWrap */
.inquiryWrap { position: relative; }
.inquiryWrap .formcont { position: relative; }
.inquiryWrap .formcont form { width: 100%; }
.inquiryWrap .formcont form .customWrap { position: relative; font-size: 16px; color: #828282; line-height: 1.4; }
.inquiryWrap .formcont form .customWrap * { font-size: inherit; color: inherit; line-height: inherit; }
.inquiryWrap .formcont form .customWrap .inputWrap { margin-bottom: 10px; }
.inquiryWrap .formcont form .customWrap .inputWrap:last-of-type { margin-bottom: 0; }
.inquiryWrap .formcont form .customWrap .inputWrap .inputText { display: block; padding: 13px 20px; width: 100%; background-color: #f3f3f3; border-radius: 10px; border: none !important; box-shadow: none !important; outline: none !important; }
.inquiryWrap .formcont form .customWrap .inputWrap textarea { display: block; padding: 13px 20px; width: 100%; max-width: 100%; background-color: #f3f3f3; border-radius: 10px; border: none !important; box-shadow: none !important; outline: none !important; }
.inquiryWrap .formcont form .inquirymore { margin-top: 15px; display: flex; flex-wrap: nowrap; align-items: center; font-size: 18px; color: #fff; line-height: 1; }
.inquiryWrap .formcont form .inquirymore * { font-size: inherit; color: inherit; line-height: inherit; }
.inquiryWrap .formcont form .inquirymore a, .inquiryWrap .formcont form .inquirymore button { padding: 14px 0; width: 180px; border-radius: 10px; text-align: center; border: none !important; box-shadow: none !important; outline: none !important; transition: background-color 0.3s; }
.inquiryWrap .formcont form .inquirymore .sendbtn { background-color: #d5bcad; }
.inquiryWrap .formcont form .inquirymore .sendbtn:hover { background-color: #a27c66; }
@media (max-width: 1535px) {
    .inquiryWrap .formcont form .customWrap .inputWrap .inputText,
    .inquiryWrap .formcont form .customWrap .inputWrap textarea
    { padding: 11px 17px; border-radius: 9px; }
    .inquiryWrap .formcont form .inquirymore a, 
    .inquiryWrap .formcont form .inquirymore button 
    { padding: 13px 0; width: 150px; border-radius: 9px; }
}
@media (max-width: 1279px) {
    .inquiryWrap .formcont form .customWrap .inputWrap .inputText,
    .inquiryWrap .formcont form .customWrap .inputWrap textarea
    { padding: 10px 15px; border-radius: 8px; }
    .inquiryWrap .formcont form .inquirymore a, 
    .inquiryWrap .formcont form .inquirymore button 
    { padding: 12px 0; width: 130px; border-radius: 8px; }
}
@media (max-width: 1023px) {
    .inquiryWrap .formcont form .customWrap .inputWrap .inputText,
    .inquiryWrap .formcont form .customWrap .inputWrap textarea
    { padding: 9px 13px; border-radius: 7px; }
    .inquiryWrap .formcont form .inquirymore a, 
    .inquiryWrap .formcont form .inquirymore button 
    { padding: 11px 0; width: 100px; border-radius: 7px; }
}

.inquiryadm { display: inline-block; margin-bottom: 10px; }

/* main_contact */
#main_contact { position: relative; overflow: hidden; padding: 95px 0 65px; background-color: #f1eeec; }
#main_contact .contents { display: flex; flex-wrap: nowrap; justify-content: space-between; }
#main_contact .contents > li { width: 44%; }
#main_contact .contents > li strong { display: block; padding-bottom: 60px; font-family: "Playfair Display";  font-weight: 800; font-size: 40px; color: #3c3c3c; }
@media (max-width: 1023px) {
    #main_contact .contents > li:first-of-type { width: 60%; }
    #main_contact .contents > li:last-of-type { width: 39%; }
}
@media (max-width: 767px) {
    #main_contact .contents { display: block; }
    #main_contact .contents > li:first-of-type { width: 100%; }
    #main_contact .contents > li:last-of-type { width: 100%; margin-top: 30px; }
}

#main_contact .cont1 { display: flex; flex-wrap: nowrap; }
#main_contact .cont1 .left { min-width: max-content; margin-right: 50px; }
#main_contact .cont1 .left img { width: 100px; }
#main_contact .cont1 .right { width: 100%; font-size: 18px; line-height: 1; }
#main_contact .cont1 .right * { font-size: inherit; line-height: inherit; }
#main_contact .cont1 .right p { display: flex; flex-wrap: nowrap; align-items: center; width: 100%; }
#main_contact .cont1 .right p:nth-of-type(n + 2) { margin-top: 20px; }
#main_contact .cont1 .right p b { display: inline-block; width: 135px; min-width: 135px; font-weight: 500; color: #b59887; letter-spacing: -0.01em; }
#main_contact .cont1 .right p span { display: inline-block; width: 100%; color: #5e5e5e; letter-spacing: -0.01em; }
@media (max-width: 1535px) {
    #main_contact .cont1 .left { margin-right: calc(30px + 1.3vw); }
    #main_contact .cont1 .left img { width: calc(60px + 2.6vw); }
    #main_contact .cont1 .right p:nth-of-type(n + 2) { margin-top: 17px; }
    #main_contact .cont1 .right p b { width: 120px; min-width: 120px; }
}
@media (max-width: 1279px) {
    #main_contact .cont1 .right p:nth-of-type(n + 2) { margin-top: 15px; }
    #main_contact .cont1 .right p b { width: 110px; min-width: 110px; }
}
@media (max-width: 1023px) {
    #main_contact .cont1 .left { margin-right: 20px; }
    #main_contact .cont1 .right p:nth-of-type(n + 2) { margin-top: 13px; }
    #main_contact .cont1 .right p b { width: 110px; min-width: 110px; }
}
@media (max-width: 380px) {
    #main_contact .cont1 { display: block; }
    #main_contact .cont1 .left { min-width: initial; margin-right: initial; }
    #main_contact .cont1 .left img { width: 60px; }
    #main_contact .cont1 .right { margin-top: 20px; }
    #main_contact .cont1 .right p b { width: 90px; min-width: 90px; }
}

#main_contact .cont2 { display: block; font-size: 18px; color: #636363; line-height: 1; }
#main_contact .cont2:nth-of-type(n + 2) { margin-top: 20px; }
#main_contact .cont2 * { font-size: inherit; color: inherit; line-height: inherit; }
#main_contact .cont2 a { display: inline-block; }
#main_contact .cont2 dl { display: flex; flex-wrap: nowrap; align-items: center; }
#main_contact .cont2 dl dt { min-width: max-content; margin-right: 11px; }
#main_contact .cont2 dl dt img { width: 60px; }
#main_contact .cont2 dl dd { position: relative; white-space: nowrap; }
#main_contact .cont2 dl dd::after { display: block; content: ''; position: absolute; bottom: -6px; left: 0; width: 0; height: 1px; background-color: #636363; transform-origin: left; transition: width 0.3s; }
#main_contact .cont2 a:hover dl dd::after { width: 100%; }
@media (max-width: 1535px) {
    #main_contact .cont2:nth-of-type(n + 2) { margin-top: 17px; }
    #main_contact .cont2 dl dt { margin-right: 10px; }
    #main_contact .cont2 dl dt img { width: calc(40px + 1.3vw); }
}
@media (max-width: 1279px) {
    #main_contact .cont2:nth-of-type(n + 2) { margin-top: 15px; }
}