/* 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 { height: 100%; }
#main_visual .mv_text .textbox { z-index: 2;  position: relative; top: 55%; transform: translateY(-50%); text-align: center; }
#main_visual .mv_text .textbox p { text-shadow: 2px 0 2px rgba(0, 0, 0, 0.7); }
#main_visual .mv_text .textbox .text1 {  font-weight: 700; font-size: 51px; color: #fff; line-height: 1.3; }
#main_visual .mv_text .textbox .text2 { font-size: 44px; color: #fff; line-height: 1.45; }
#main_visual .mv_text .textbox .text3 { font-size: 36px; color: #fff; line-height: 1.45; }
#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.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 { width: 12px; height: 12px; border-radius: 50%; background-color: #fff; margin: 0 6px; cursor: pointer; }
#main_visual .slick-dots li button { display: none; }
#main_visual .slick-dots li.slick-active { background-color: #26225f; }
@media (max-width: 1535px) {
    #main_visual { height: calc(470px + 22vw); }
}
@media (max-width: 1279px) {
    #main_visual { height: calc(350px + 17vw); }
}
@media (max-width: 1023px) {
    #main_visual { height: calc(300px + 15vw); }
    #main_visual .slick-dots { bottom: 20px; }
    #main_visual .slick-dots li { width: 10px; height: 10px; }
}

/* main_about */
#main_about { padding: 110px 0; overflow: hidden; background: url(/image/main/about_bg.jpg) no-repeat center/cover; }
#main_about .contents1 { display: flex; flex-wrap: nowrap; }
#main_about .contents1 li { position: relative; width: 50%; }
#main_about .contents1 li:first-of-type { padding-right: 5%; }
#main_about .contents1 li .textbox .text1 { font-weight: 700; font-size: 42px; color: #26225f; letter-spacing: -0.01em; line-height: 1.3; }
#main_about .contents1 li .textbox .text1 br { display: none; }
#main_about .contents1 li .textbox .text2 { margin-top: 20px; font-weight: 500; font-size: 22px; color: #000; letter-spacing: -0.01em; line-height: 1.33; }
#main_about .contents1 li .textbox .text2 br { display: none; }
#main_about .contents1 li .textbox .text3 { margin-top: 25px; font-size: 18px; color: #7a7a7a; letter-spacing: -0.01em; line-height: 1.55; }
#main_about .contents1 li .textbox a { display: inline-block; margin-top: 35px; padding: 14px 65px; text-align: center; font-weight: 700; font-size: 18px; color: #fff; background-color: #26225f; transition: background-color 0.3s; }
#main_about .contents1 li .textbox a:hover { background-color: #1e1c37; }
@media (max-width: 767px) {
    #main_about { background-position-x: 100%; }
    #main_about .contents1 { display: block; }
    #main_about .contents1 li { width: 100%; text-align: center; }
    #main_about .contents1 li:first-of-type { margin-bottom: 20px; padding-right: initial; }
    #main_about .contents1 li img { width: 100%; max-width: 300px; }
    #main_about .contents1 li .textbox .text1 br { display: inline-block; }
    #main_about .contents1 li .textbox .text2 br { display: inline-block; }
}

/* main_business */
#main_business { padding: 80px 0; overflow: hidden; }
#main_business .cwrap { position: relative; max-width: 1380px; margin-left: auto; margin-right: auto; }
#main_business .textbox { text-align: center; }
#main_business .textbox .text1 { font-weight: 700; font-size: 40px; color: #000; }
#main_business .textbox .text2 { margin-top: 20px; font-size: 20px; color: #000; line-height: 1.45; }
#main_business .contents1 { margin-top: 45px; }
#main_business .contents1 ul { display: flex; flex-wrap: nowrap; justify-content: space-between; }
#main_business .contents1 ul li { width: 24%; overflow: hidden; }
#main_business .contents1 ul li .cont { position: relative; display: block; }
#main_business .contents1 ul li:nth-of-type(2n) .cont { margin-top: 50px; }
#main_business .contents1 ul li .cont .img1 { width: 100%; transform-origin: center; transition: transform 0.3s; }
#main_business .contents1 ul li:hover .cont .img1 { transform: scale(1.1); }
#main_business .contents1 ul li .cont .frame { z-index: 1; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
#main_business .contents1 ul li .cont .frame .desc1 { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 100%; text-align: center; font-weight: 700; font-size: 30px; color: #fff; }
#main_business .contents1 ul li .cont .frame .desc1::after { display: block; content: ''; position: absolute; left: 50%; transform: translateX(-50%); top: -25px; width: 40px; height: 3px; background-color: #fff; }
#main_business .contents1 ul li .cont .frame a { position: absolute; left: 50%; transform: translateX(-50%); bottom: 65px; display: inline-flex; flex-wrap: nowrap; align-items: center; padding: 9px 30px; font-size: 16px; color: #fff; background-color: transparent; border: 2px solid #fff; transition: background-color 0.3s, border 0.3s; }
#main_business .contents1 ul li .cont .frame a span { display: inline-block; margin-right: 7px; }
#main_business .contents1 ul li .cont .frame a img { display: inline-block; width: 14px; }
#main_business .contents1 ul li .cont .frame a:hover { background-color: #26225f; border: 2px solid #26225f; }
@media (max-width: 1480px) {
    #main_business .cwrap { width: calc(100% - 100px); }
    #main_business .contents1 ul li .cont .frame .desc1::after { top: -20px; width: 30px; }
    #main_business .contents1 ul li .cont .frame a { bottom: 50px; padding: 8px 26px; }
}
@media (max-width: 1230px) {
    #main_business .cwrap { width: calc(100% - 80px); }
    #main_business .contents1 ul li:nth-of-type(2n) .cont { margin-top: 40px; }
    #main_business .contents1 ul li .cont .frame .desc1::after { top: -15px; width: 25px; }
    #main_business .contents1 ul li .cont .frame a { bottom: 40px; padding: 7px 23px; }
}
@media (max-width: 1023px) {
    #main_business .cwrap { width: calc(100% - 60px); }
    #main_business .contents1 ul { flex-wrap: wrap; }
    #main_business .contents1 ul li { width: 48%; }
    #main_business .contents1 ul li:nth-of-type(n + 3) { margin-top: 4%; }
    #main_business .contents1 ul li:nth-of-type(2n) .cont { margin-top: initial; }
    #main_business .contents1 ul li .cont .frame .desc1::after { height: 2px; }
    #main_business .contents1 ul li .cont .frame a { bottom: 30px; }
}
@media (max-width: 767px) {
    #main_business .cwrap { width: calc(100% - 40px); }
}
@media (max-width: 524px) {
    #main_business .contents1 ul li .cont .frame a { bottom: 20px; padding: 6px 20px; }
}
@media (max-width: 424px) {
    #main_business .contents1 ul li { width: 100%; padding: 50px 15px 40px; }
    #main_business .contents1 ul li:nth-of-type(n + 3) { margin-top: initial; }
    #main_business .contents1 ul li:nth-of-type(n + 2) { margin-top: calc(15px + 1vw); }
    #main_business .contents1 ul li:nth-of-type(1) { background: url(/image/main/business_img1.jpg) no-repeat center/cover; }
    #main_business .contents1 ul li:nth-of-type(2) { background: url(/image/main/business_img2.jpg) no-repeat center/cover; }
    #main_business .contents1 ul li:nth-of-type(3) { background: url(/image/main/business_img3.jpg) no-repeat center/cover; }
    #main_business .contents1 ul li:nth-of-type(4) { background: url(/image/main/business_img4.jpg) no-repeat center/cover; }
    #main_business .contents1 ul li .img1 { display: none; }
    #main_business .contents1 ul li .cont .frame { position: relative; }
    #main_business .contents1 ul li .cont .frame .desc1 { position: relative; top: initial; transform: translateX(-50%); }
    #main_business .contents1 ul li .cont .frame a { position: relative; bottom: initial; margin-top: 20px; border: 1px solid #fff; }
    #main_business .contents1 ul li .cont .frame a:hover { border: 1px solid #26225f; }
}

/* main_inquiry */
#main_inquiry { position: relative; padding: 130px 0; overflow: hidden; background: url(/image/main/inquiry_bg.jpg) no-repeat center/cover; }
#main_inquiry .frame { z-index: 1; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.6); } 
#main_inquiry .textbox { z-index: 2; position: relative; text-align: center; }
#main_inquiry .textbox .text1 { font-weight: 700; font-size: 40px; color: #fff; }
#main_inquiry .textbox .text2 { margin-top: 20px; font-size: 20px; color: #fff; line-height: 1.45; }
#main_inquiry .textbox .morebtn { margin-top: 45px; text-align: center; }
#main_inquiry .textbox .morebtn a { display: inline-block; padding: 14px 65px; text-align: center; font-weight: 700; font-size: 18px; color: #fff; background-color: #26225f; transition: background-color 0.3s; }
#main_inquiry .textbox .morebtn a:hover { background-color: #1e1c37; }