/* main_visual */
#main_visual { position: relative; height: 920px; max-height: 100vh; 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_text .textbox { z-index: 4; position: absolute; top: 50%; transform: translateY(-50%); width: 100%; text-align: center; }
#main_visual .mv_text .textbox .bar { display: inline-block; margin: 20px 0; width: 35px; height: 2px; background-color: #fff; box-shadow: 2px 0 2px rgba(0, 0, 0, 0.75); }
#main_visual .mv_text .textbox .text1 { display: block; font-weight: 700; font-size: 60px; color: #fff; line-height: 1.3; text-shadow: 2px 0 2px rgba(0, 0, 0, 0.75); }
#main_visual .mv_text .textbox .text1 span { color: #0068b2; }
#main_visual .mv_text .textbox .text2 { font-weight: 500; font-size: 48px; color: #fff; line-height: 1.3; text-shadow: 2px 0 2px rgba(0, 0, 0, 0.75); }
#main_visual .mv_text .textbox .text3 { margin-top: 3px; font-weight: 600; font-size: 26px; color: #fff; line-height: 1.3; letter-spacing: -0.01em; text-shadow: 2px 0 2px rgba(0, 0, 0, 0.75); }
#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; opacity: 0.9; }
#main_visual .mv_slick .con3 .bg { background: url(/image/main/mv_bg3.jpg) no-repeat center/cover; opacity: 0.8; }
#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.2); }

#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: 10px; height: 10px; border-radius: 50%; background-color: #fff; margin: 0 9px; cursor: pointer; }
#main_visual .slick-dots li button { display: none; }
#main_visual .slick-dots li.slick-active { background-color: #005aa6; }

#main_visual .mv_admin { z-index: 10; position: absolute; top: 5px; left: 5px; font-size: 13px; color: #fff; text-shadow: 1px 1px #000; }

@media (max-width: 1535px) {
    #main_visual { height: calc(470px + 22vw); }
    #main_visual .mv_text .contwrap { top: 90px; height: calc(100% - 90px); }
    #main_visual .mv_text .textbox .bar { margin: 15px 0; width: 30px; height: 1px; box-shadow: 1px 0 1px rgba(0, 0, 0, 0.75); }
}
@media (max-width: 1279px) {
    #main_visual { height: calc(350px + 17vw); }
    #main_visual .mv_text .contwrap { top: 80px; height: calc(100% - 80px); }
    #main_visual .mv_text .textbox .bar { margin: 10px 0; width: 20px; }
}
@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 { margin: 0 6px; }
}
@media (max-width: 767px) {
    #main_visual { max-height: calc(100vh - 60px); }
    #main_visual .mv_text .contwrap { top: 60px; height: calc(100% - 60px); }
}

/* main_company */
#main_company { position: relative; overflow: hidden; padding: 100px 0; background: url(/image/main/company_bg.jpg) no-repeat center/cover; background-position: right center; }
#main_company dl { display: flex; flex-wrap: nowrap; }
#main_company dl dt { width: 40%; padding-right: 60px; display: flex; justify-content: right; text-align: right; }
#main_company dl dt img { max-width: initial; width: 730px; height: fit-content; }
#main_company dl dd { width: 60%; }
#main_company dl dd .textbox .text1 { position: relative; display: inline-block; font-family: 'Nanum Myeongjo', serif; font-weight: 800; font-size: 43px; color: #243649; line-height: 1.3; letter-spacing: -0.05em; }
#main_company dl dd .textbox .text1 span { z-index: 2; position: relative; display: inline-block; }
#main_company dl dd .textbox .text1 br { display: none; }
#main_company dl dd .textbox .text1 .talk { z-index: 1; position: absolute; width: 61px; top: -15px; }
#main_company dl dd .textbox .text1 .talk1 { left: -30px; }
#main_company dl dd .textbox .text1 .talk2 { right: -30px; }
#main_company dl dd .textbox .text2 { font-size: 20px; color: #4c4c4c; line-height: 1.5; }
#main_company dl dd .textbox .text3 { margin: 30px 0; font-family: 'Nanum Myeongjo', serif; font-weight: 800; font-size: 28px; color: #243649; letter-spacing: -0.05em; line-height: 1.55; }
#main_company dl dd .textbox .text3 span { display: inline-block; font-size: inherit !important; font-family: inherit !important; }
#main_company dl dd .textbox .text3 span:nth-of-type(2) { margin-left: 10%; }
#main_company dl dd .textbox .text3 span:nth-of-type(3) { margin-left: 5%; }
#main_company dl dd .textbox a { display: inline-block; margin-top: 40px; padding: 13px 50px; text-align: center; font-weight: 500; font-size: 18px; color: #000; border: 2px solid #000; transition: background-color 0.3s; }
#main_company dl dd .textbox a:hover { background-color: rgba(0, 0, 0, 0.2); }
@media (max-width: 1535px) {
    #main_company dl dt { padding-right: calc(30px + 1.7vw); }
    #main_company dl dt img { width: calc(400px + 15vw); }

    #main_company dl dd .textbox .text1 .talk { width: 55px; top: -10px; }
    #main_company dl dd .textbox .text1 .talk1 { left: -30px; }
    #main_company dl dd .textbox .text1 .talk2 { right: -30px; }   
}
@media (max-width: 1279px) {
    #main_company dl dt { padding-right: 30px; }

    #main_company dl dd .textbox .text1 .talk { width: 45px; top: -10px; }
    #main_company dl dd .textbox .text1 .talk1 { left: -20px; }
    #main_company dl dd .textbox .text1 .talk2 { right: -20px; }   
}
@media (max-width: 1023px) {
    #main_company dl { display: block; text-align: center; }
    #main_company dl dt { padding-right: initial; width: 100%; display: block; text-align: center; }
    #main_company dl dt img { width: 100%; max-width: 300px; }
    #main_company dl dd { width: 100%; margin-top: 20px; }
    #main_company dl dd .textbox .text3 span:nth-of-type(2) { margin-left: 30%; }
    #main_company dl dd .textbox .text3 span:nth-of-type(3) { margin-left: 10%; }

    #main_company dl dd .textbox .text1 .talk { width: 35px; top: -5px; }
    #main_company dl dd .textbox .text1 .talk1 { left: -10px; }
    #main_company dl dd .textbox .text1 .talk2 { right: -10px; }
}
@media (max-width: 624px) {
    #main_company dl dd .textbox .text1 br { display: inline-block; }
    #main_company dl dd .textbox .text1 .talk { width: 25px; top: -5px; }
}
@media (max-width: 524px) {
    #main_company dl dd .textbox .text3 span:nth-of-type(2) { margin-left: initial; }
    #main_company dl dd .textbox .text3 span:nth-of-type(3) { margin-left: initial; }
}

/* main_service */
#main_service { position: relative; overflow: hidden; padding: 80px 0 110px; }
#main_service .bg { z-index: 1; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: url(/image/main/service_bg.jpg) no-repeat center/cover; }
#main_service .contwrap { z-index: 2; position: relative; }
#main_service dl { padding-bottom: 50px; display: flex; flex-wrap: nowrap; align-items: center; }
#main_service dl dt { min-width: max-content; margin-right: 40px; font-weight: 700; font-size: 45px; color: #fff; line-height: 1; }
#main_service dl dd { font-size: 16px; color: #aeaeae; line-height: 1.56; }
#main_service .contents { display: flex; flex-wrap: nowrap; justify-content: space-between; }
#main_service .contents > li { width: 31.9230%; }
#main_service .contents > li a { display: block; overflow: hidden; }
#main_service .contents > li a .top { position: relative; padding-bottom: 70.36144578313253%; overflow: hidden; }
#main_service .contents > li a .top img { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: auto; height: auto; min-width: 100%; min-height: 100%; max-width: 120%; transform-origin: center; transition: transform 0.3s; }
#main_service .contents > li a:hover .top img { transform: translate(-50%,-50%) scale(1.1); }
#main_service .contents > li a .bottom { position: relative; padding: 40px 10px; text-align: center; }
#main_service .contents > li:nth-of-type(1) a .bottom { background: url(/image/main/service_bottom1.jpg) no-repeat center/cover; }
#main_service .contents > li:nth-of-type(2) a .bottom { background: url(/image/main/service_bottom2.jpg) no-repeat center/cover; }
#main_service .contents > li:nth-of-type(3) a .bottom { background: url(/image/main/service_bottom3.jpg) no-repeat center/cover; }
#main_service .contents > li a .bottom .textbox .text1 { font-weight: 700; font-size: 22px; color: #000; line-height: 1.38; }
#main_service .contents > li a .bottom .textbox .text2 { font-size: 20px; color: #555; line-height: 1.5; }
#main_service .contents > li a .bottom .arrow1 { z-index: 3; position: absolute; right: 0; top: -26px; width: 52px; }
@media (max-width: 1535px) {
    #main_service dl dt { margin-right: calc(23px + 1vw); }
    #main_service .contents > li a .bottom { padding: 30px 10px; }
    #main_service .contents > li a .bottom .arrow1 { top: -22px; width: 44px; }
}
@media (max-width: 1279px) {
    #main_service .contents > li a .bottom { padding: 20px 10px; }
    #main_service .contents > li a .bottom .arrow1 { top: -19px; width: 38px; }
}
@media (max-width: 1023px) {
    #main_service dl { display: block; }
    #main_service dl dt { margin-right: initial; min-width: initial; }
    #main_service dl dd { margin-top: 10px; }
    #main_service .contents { flex-wrap: wrap; }
    #main_service .contents > li { width: 48%; }
    #main_service .contents > li:nth-of-type(n + 3) { margin-top: 4%; }
    #main_service .contents > li a .bottom { padding: 15px 10px; }
    #main_service .contents > li a .bottom .arrow1 { top: -15px; width: 30px; }
}
@media (max-width: 580px) {
    #main_service .contents > li { width: 100%; }
    #main_service .contents > li:nth-of-type(n + 3) { margin-top: initial; }
    #main_service .contents > li:nth-of-type(n + 2) { margin-top: 25px; }
}

/* main_board */
#main_board { position: relative; overflow: hidden; padding: 80px 0; }
#main_board .contents { display: flex; flex-wrap: nowrap; }
#main_board .contents .left { width: 57%; padding-right: 60px; }
#main_board .contents .right { width: 43%; }

#main_board .contactbox { padding: 40px; background-color: #f1f1f1; }
#main_board .contactbox dl { display: flex; flex-wrap: nowrap; align-items: center; justify-content: center; font-weight: 700; font-size: 36px; color: #005aa6; }
#main_board .contactbox dl * { font-weight: inherit; font-size: inherit; color: inherit; }
#main_board .contactbox dl dt { min-width: max-content; margin-right: 20px; }
#main_board .contactbox dl dt img { width: 60px; }
#main_board .contactbox dl dd { white-space: nowrap; }
#main_board .contactbox .textbox { text-align: center; margin-top: 20px; }
#main_board .contactbox .textbox .text1 { margin-top: 20px; font-weight: 500; font-family: 18px; color: #242424; line-height: 1.2; }
#main_board .contactbox .textbox .text2 { margin-top: 15px; font-size: 16px; color: #626262; line-height: 1.56; }
#main_board .contactbox .textbox .text2 span { color: #e81919; }
#main_board .contactbox .morebtn { margin-top: 25px; display: flex; flex-wrap: nowrap; justify-content: space-between; }
#main_board .contactbox .morebtn a { display: inline-block; width: 48%; padding: 15px 10px; font-weight: 600; font-family: 18px; color: #fff; transition: background-color 0.3s; }
#main_board .contactbox .morebtn a:first-of-type { background-color: #005aa6; }
#main_board .contactbox .morebtn a:last-of-type { background-color: #3a3a3c; }
#main_board .contactbox .morebtn a:first-of-type:hover { background-color: #083256; }
#main_board .contactbox .morebtn a:last-of-type:hover { background-color: #111; }

@media (max-width: 1535px) {
    #main_board .contents .left { padding-right: calc(40px + 1.3vw); }

    #main_board .contactbox { padding: 30px; }
    #main_board .contactbox dl dt { margin-right: 15px; }
    #main_board .contactbox dl dt img { width: calc(30px + 1.7vw); }
    #main_board .contactbox .textbox { margin-top: 17px; }
    #main_board .contactbox .textbox .text1 { margin-top: 17px; }
    #main_board .contactbox .textbox .text2 { margin-top: 13px; }
    #main_board .contactbox .morebtn { margin-top: 20px; }
    #main_board .contactbox .morebtn a { padding: 13px 10px; }
}
@media (max-width: 1279px) {
    #main_board .contents .left { padding-right: calc(30px + 1vw); }

    #main_board .contactbox { padding: 20px; }
    #main_board .contactbox dl dt { margin-right: 10px; }
    #main_board .contactbox dl dt img { width: 45px; }
    #main_board .contactbox .textbox { margin-top: 15px; }
    #main_board .contactbox .textbox .text1 { margin-top: 15px; }
    #main_board .contactbox .textbox .text2 { margin-top: 10px; }
    #main_board .contactbox .morebtn { margin-top: 15px; }
    #main_board .contactbox .morebtn a { padding: 10px; }
}
@media (max-width: 1023px) {
    #main_board .contents { display: block; }
    #main_board .contents .left { padding-right: initial; width: 100%; }
    #main_board .contents .right { width: 100%; margin-top: 25px; }

    #main_board .contactbox { padding: 20px 10px; }
    #main_board .contactbox dl dt { margin-right: 10px; }
    #main_board .contactbox dl dt img { width: 36px; }
    #main_board .contactbox .textbox { margin-top: 10px; }
    #main_board .contactbox .textbox .text1 { margin-top: 10px; }
    #main_board .contactbox .morebtn { margin-top: 10px; }
    #main_board .contactbox .morebtn a { padding: 7px; }
}