/* main_visual */
#main_visual { position: relative; /* height: 800px; */ height: 41.6146vw; /* 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_bg1.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.4); }

#main_visual .slick-dots { z-index: 10; position: absolute; left: 50%; transform: translateX(-50%); bottom: 30px; display: flex; flex-wrap: nowrap; }
#main_visual .slick-dots li { position: relative; width: 15px; height: 15px; border-radius: 50%; background-color: #616161; margin: 0 6px; cursor: pointer; }
#main_visual .slick-dots li button { display: none; }
#main_visual .slick-dots li.slick-active { background-color: #fff; }
@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: 20px; }
    #main_visual .slick-dots li { width: 12px; height: 12px; }
}
@media (max-width: 767px) {
    #main_visual { height: 141.4602vw; }
    #main_visual .mv_slick .con1 .bg { background: url(/image/main/mo_mv_bg1.jpg) no-repeat center/cover; }
    #main_visual .mv_slick .con2 .bg { background: url(/image/main/mo_mv_bg1.jpg) no-repeat center/cover; }
}


/* main common */
.main_tit { padding-bottom: 30px; font-weight: 700; font-size: 40px; color: #000; }


/* maincompany */
#maincompany { position: relative; padding: 100px 0; overflow: hidden; }
#maincompany .contents1 { display: flex; flex-wrap: nowrap; justify-content: space-between; }
#maincompany .contents1 > li { width: 31%; }
#maincompany .contents1 > li > a { position: relative; display: block; aspect-ratio: 1/1; display: flex; align-items: center; justify-content: center; text-align: center; box-shadow: 0 0 10px rgba(206, 206, 206, 0.8); border-radius: 15px; }
#maincompany .contents1 > li > a .imgbox img { display: inline-block; width: 180px; transform-origin: center; transition: transform 0.3s; }
#maincompany .contents1 > li > a:hover .imgbox img { transform: rotateY(180deg); }
#maincompany .contents1 > li > a .imgbox p { margin-top: 15px; text-align: center; font-weight: 500; font-size: 30px; color: #000; line-height: 1.16; }
#maincompany .contents1 > li > a .info { z-index: 1; position: absolute; display: flex; align-items: center; justify-content: center; font-size: 18px; color: #fff; line-height: 1.6; top: -18px; width: 85px; height: 36px; text-align: center; font-size: 18px; color: #fff; background-color: #003686; border-radius: 100px; }
@media (max-width: 1535px) {
    #maincompany .contents1 > li > a .imgbox img { width: calc(90px + 5vw); }
    #maincompany .contents1 > li > a .info { top: -15px; width: 70px; height: 30px; }
}
@media (max-width: 1279px) {
    #maincompany .contents1 > li > a { border-radius: 13px; }
    #maincompany .contents1 > li > a .imgbox img { width: calc(70px + 4vw); }
}
@media (max-width: 1023px) {
    #maincompany .contents1 > li > a { box-shadow: 0 0 6px rgba(206, 206, 206, 0.8); border-radius: 11px; }
    #maincompany .contents1 > li > a .info { top: -13px; width: 60px; height: 26px; }
}
@media (max-width: 767px) {
    #maincompany .contents1 { display: block; }
    #maincompany .contents1 > li { width: 100%; }
    #maincompany .contents1 > li:nth-of-type(n + 2) { margin-top: 40px; }
    #maincompany .contents1 > li > a { padding: 40px 10px 20px; aspect-ratio: initial; border-radius: 10px; }
    #maincompany .contents1 > li > a .imgbox img { width: 100px; }
}

/* maingallery */
#maingallery { position: relative; padding: 90px 0; overflow: hidden; background: url(/image/main/gall_bg.jpg) no-repeat center/cover; }
#maingallery .morebtn { margin-top: 30px; text-align: center; }
#maingallery .morebtn a { display: inline-block; padding: 11px 40px; font-weight: 600; font-size: 18px; color: #121212; border: 1px solid #404040; border-radius: 100px; transition: background-color 0.3s; }
#maingallery .morebtn a:hover { background-color: rgba(0, 0, 0, 0.1); }

#maingallery .gallwrap .gallul { position: relative; margin: -10px; }
#maingallery .gallwrap .gallul .gallli { padding: 10px; }
#maingallery .gallwrap .gallul .gallli .galla { display: block; }
#maingallery .gallwrap .gallul .gallli .galla .imgbox { position: relative; padding-bottom: 70%; border-radius: 20px; overflow: hidden; }
#maingallery .gallwrap .gallul .gallli .galla .imgbox img { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: auto; height: auto; min-width: 100%; min-height: 100%; max-width: 110%; }
#maingallery .gallwrap .gallul .gallli .galla .txtbox { margin-top: 15px; text-align: center; font-weight: 600; font-size: 20px; color: #000; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* mainlocation */
#mainlocation { display: none !important; position: relative; padding: 85px 0; overflow: hidden; }
#mainlocation .contents1 { display: flex; flex-wrap: nowrap; background-color: #f7f7f7; border: 1px solid #e4e4e4; }
#mainlocation .contents1 > dt { width: 60%; }
#mainlocation .contents1 > dt .mapcont { height: 500px; }
#mainlocation .contents1 > dt .mapcont .root_daum_roughmap { width: 100%; height: 100%; }
#mainlocation .contents1 > dt .mapcont .root_daum_roughmap .wrap_map { width: 100%; height: calc(100% - 32px); }
#mainlocation .contents1 > dd { width: 40%; padding: 0 30px; }
#mainlocation .contents1 > dd .scrbox { position: relative; top: 50%; transform: translateY(-50%); font-size: 18px; color: #616161; line-height: 1.38; }
#mainlocation .contents1 > dd .scrbox * { font-size: inherit; color: inherit; line-height: inherit; }
#mainlocation .contents1 > dd .scrbox dl { display: flex; flex-wrap: nowrap; }
#mainlocation .contents1 > dd .scrbox dl:nth-of-type(n + 2) { margin-top: 28px; }
#mainlocation .contents1 > dd .scrbox dl dt { min-width: max-content; margin-right: 17px; }
#mainlocation .contents1 > dd .scrbox dl dt img { width: 70px; }
#mainlocation .contents1 > dd .scrbox .scr1 { font-weight: 500; color: #003686; }
@media (max-width: 1535px) {
    #mainlocation .contents1 > dt .mapcont { height: calc(300px + 13vw); }
    #mainlocation .contents1 > dd { padding: 0 25px; }
    #mainlocation .contents1 > dd .scrbox dl:nth-of-type(n + 2) { margin-top: 24px; }
    #mainlocation .contents1 > dd .scrbox dl dt { margin-right: 15px; }
    #mainlocation .contents1 > dd .scrbox dl dt img { width: calc(40px + 1.8vw); }
}
@media (max-width: 1279px) {
    #mainlocation .contents1 > dt { width: 55%; }
    #mainlocation .contents1 > dd { width: 45%; padding: 0 20px; }
    #mainlocation .contents1 > dd .scrbox dl:nth-of-type(n + 2) { margin-top: 20px; }
    #mainlocation .contents1 > dd .scrbox dl dt { margin-right: 13px; }
}
@media (max-width: 1023px) {
    #mainlocation .contents1 { display: block; }
    #mainlocation .contents1 > dt { width: 100%; }
    #mainlocation .contents1 > dt .mapcont { height: calc(200px + 10vw); }
    #mainlocation .contents1 > dd { padding: 15px; width: 100%; }
    #mainlocation .contents1 > dd .scrbox { top: initial; transform: translateY(0); }
    #mainlocation .contents1 > dd .scrbox dl dt { margin-right: 11px; }
    #mainlocation .contents1 > dd .scrbox dl dt img { width: 40px; }
}