@font-face {
    font-family:'Freesentation';
    font-style:normal;
    font-weight:100;
    src:local('Freesentation'),
        url(../../../fonts/Freesentation-1Thin.ttf) format('truetype');
}
@font-face {
    font-family:'Freesentation';
    font-style:normal;
    font-weight:200;
    src:local('Freesentation'),
        url(../../../fonts/Freesentation-2ExtraLight.ttf) format('truetype');
}
@font-face {
    font-family:'Freesentation';
    font-style:normal;
    font-weight:300;
    src:local('Freesentation'),
        url(../../../fonts/Freesentation-3Light.ttf) format('truetype');
}
@font-face {
    font-family:'Freesentation';
    font-style:normal;
    font-weight:400;
    src:local('Freesentation'),
        url(../../../fonts/Freesentation-4Regular.ttf) format('truetype');
}
@font-face {
    font-family:'Freesentation';
    font-style:normal;
    font-weight:500;
    src:local('Freesentation'),
        url(../../../fonts/Freesentation-5Medium.ttf) format('truetype');
}
@font-face {
    font-family:'Freesentation';
    font-style:normal;
    font-weight:600;
    src:local('Freesentation'),
        url(../../../fonts/Freesentation-6SemiBold.ttf) format('truetype');
}
@font-face {
    font-family:'Freesentation';
    font-style:normal;
    font-weight:700;
    src:local('Freesentation'),
        url(../../../fonts/Freesentation-7Bold.ttf) format('truetype');
}
@font-face {
    font-family:'Freesentation';
    font-style:normal;
    font-weight:800;
    src:local('Freesentation'),
        url(../../../fonts/Freesentation-8ExtraBold.ttf) format('truetype');
}
@font-face {
    font-family:'Freesentation';
    font-style:normal;
    font-weight:900;
    src:local('Freesentation'),
        url(../../../fonts/Freesentation-9Black.ttf) format('truetype');
}

@font-face {
    font-family:'NanumSquareAc';
    font-style:normal;
    font-weight:300;
    src:local('NanumSquareAc'),
        url(../../../fonts/NanumSquare_acL.ttf) format('truetype');
}
@font-face {
    font-family:'NanumSquareAc';
    font-style:normal;
    font-weight:400;
    src:local('NanumSquareAc'),
        url(../../../fonts/NanumSquare_acR.ttf) format('truetype');
}
@font-face {
    font-family:'NanumSquareAc';
    font-style:normal;
    font-weight:700;
    src:local('NanumSquareAc'),
        url(../../../fonts/NanumSquare_acB.ttf) format('truetype');
}
@font-face {
    font-family:'NanumSquareAc';
    font-style:normal;
    font-weight:800;
    src:local('NanumSquareAc'),
        url(../../../fonts/NanumSquare_acEB.ttf) format('truetype');
}




img { max-width:100%; }
.wrap { width: 1200px; margin: 0 auto; }

@media screen and (max-width:1240px) {
    .wrap { width: auto; padding: 0 20px; }
}
@media screen and (max-width:1024px) {
    .wrap { padding: 0 15px; }
}
@media screen and (max-width:768px) {
    .wrap { padding: 0 10px; }
}
@media screen and (max-width:640px) {
    .wrap { padding: 0 5px; }
}






#main {  }
#main section { background-repeat: no-repeat; background-size: cover; padding: 120px 0; box-sizing: border-box; }
#main section .title { color: #000; text-align: center; font-family: 'NanumSquareAc'; font-size: 40px; font-weight: 800; margin: 0 0 80px; }
#main section .bullet { width: 20px; height: 2px; background: #000; }

@media screen and (max-width:1240px) {
    #main section { padding: 110px 0; }
    #main section .title { font-size: 36px; margin: 0 0 72px; }
    #main section .bullet { width: 18px; }
}
@media screen and (max-width:1024px) {
    #main section { padding: 100px 0; }
    #main section .title { font-size: 32px; margin: 0 0 64px; }
    #main section .bullet { width: 16px; }
}
@media screen and (max-width:768px) {
    #main section { padding: 90px 0; }
    #main section .title { font-size: 28px; margin: 0 0 56px; }
    #main section .bullet { width: 14px; }
}
@media screen and (max-width:640px) {
    #main section { padding: 80px 0; }
    #main section .title { font-size: 24px; margin: 0 0 48px; }
    #main section .bullet { width: 12px; }
}



#main .visual { height: 1000px; flex-shrink: 0; background-image: url('../../../img/main/visual.png'); position: relative; }
#main .visual h2 { position: absolute; top: 50%; left: 0; right: 0; width: 100%; transform: translate(0, -50%); color: #ffffff; text-align: center; font-family: 'NanumSquareAc'; font-size: 50px; font-weight: 300; line-height: 128%; }
#main .visual h2 span { color: #16B7FF; font-weight: 800; }
#main .visual h2 strong { font-weight: 800; }
#main .visual div { position: absolute; left: 50%; bottom: 60px; transform: translate(-50%, 0); text-align: center; }
#main .visual div span { color: #ffffff; font-family: 'Freesentation'; font-size: 16px; font-weight: 500; display:block; animation: floatUpDown 1.5s ease-in-out infinite; }
#main .visual div svg { width: 30px; height:30px; flex-shrink: 0; display: inline-block; }
@keyframes floatUpDown {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-20px);
    }
}

@media screen and (max-width:1240px) {
    #main .visual { height: 900px; }
    #main .visual h2 { font-size: 45px; }
    #main .visual div { bottom: 54px; }
    #main .visual div span { font-size: 15px; }
    #main .visual div svg { width: 27px; height:27px; }
}
@media screen and (max-width:1024px) {
    #main .visual { height: 800px; }
    #main .visual h2 { font-size: 40px; }
    #main .visual div { bottom: 48px; }
    #main .visual div span { font-size: 14px; }
    #main .visual div svg { width: 24px; height:24px; }
}
@media screen and (max-width:768px) {
    #main .visual { height: 700px; }
    #main .visual h2 { font-size: 35px; }
    #main .visual div { bottom: 42px; }
    #main .visual div span { font-size: 13px; }
    #main .visual div svg { width: 21px; height:21px; }
}
@media screen and (max-width:640px) {
    #main .visual { height: 600px; }
    #main .visual h2 { font-size: 36px; }
    #main .visual div span { font-size: 12px; }
    #main .visual div svg { width: 18px; height:18px; }
}



#main .introduction { background-image: url('../../../img/main/bg_introduction.png'); }
#main .introduction .text { color: #000; text-align: center; font-family: 'Freesentation'; font-size: 24px; font-weight: 300; line-height: 133.333%; }
#main .introduction .text strong { color: #16B7FF; font-weight: 600; }
#main .introduction .text span { font-weight: 600; }
#main .introduction .image { text-align:center; margin:120px 0 0; }

@media screen and (max-width:1240px) {
    #main .introduction .text { font-size: 22px; }
    #main .introduction .image { margin:108px 0 0; }
    #main .introduction .image img { width: 61.333vw }
}
@media screen and (max-width:1024px) {
    #main .introduction .text { font-size: 20px; }
    #main .introduction .image { margin:96px 0 0; }
}
@media screen and (max-width:768px) {
    #main .introduction .text { font-size: 18px; }
    #main .introduction .image { margin:84px 0 0; }
}
@media screen and (max-width:640px) {
    #main .introduction .text { font-size: 16px; }
    #main .introduction .image { margin:72px 0 0; }
}



#main .business { background-image: url('../../../img/main/bg_business.png'); overflow: hidden; background-color: #f8f8f8; }
#main .business .list { font-size:0; margin: 160px 0 0; }
#main .business .list dl { width:510px; display: inline-block; vertical-align: top; padding: 0 80px 0 0; }
#main .business .list dl dt { color: #000; font-family: 'NanumSquareAc'; font-size: 60px; font-weight: 800; }
#main .business .list dl dd { margin: 30px 0 0; }
#main .business .list dl dd .tit { color: #000; font-family: 'Freesentation'; font-size: 24px; font-weight: 300; line-height: 125%; }
#main .business .list dl dd .tit span { color: #16B7FF; }
#main .business .list dl dd .tit strong { color: #000; font-weight: 600; }
#main .business .list dl dd .bullet { margin:20px 0 16px; }
#main .business .list dl dd .con { color: #333; font-family: 'Freesentation'; font-size: 14px; font-weight: 300; line-height: 200%; }
#main .business .list .slide { display: inline-block; width: calc(100% - 510px); vertical-align: top; position: relative; min-height: 438px; }
#main .business .list .slide .slide-inner { position: absolute; top: 0; left: 0; }
#main .business .list .slide ul {  }
#main .business .list .slide ul li { width: 390px; margin: 0 30px 0 0; }
#main .business .list .slide ul li .img { border-radius: 10px; }
#main .business .list .slide ul li .box { margin: 20px 0 0; padding: 16px; border-radius: 10px; background-color: #ececec; color: #333; font-family: 'Freesentation'; font-size: 14px; font-style: normal; font-weight: 400; line-height: 200%; min-height: 200px; }

@media screen and (max-width:1240px) {
    #main .business .list { margin: 144px 0 0; }
    #main .business .list dl { width: 460px; padding: 0 72px 0 0; }
    #main .business .list dl dt { font-size: 52px; }
    #main .business .list dl dd { margin: 27px 0 0; }
    #main .business .list dl dd .tit { font-size: 22px; }
    #main .business .list dl dd .bullet { margin:18px 0 14px; }
    #main .business .list dl dd .con { font-size: 13px; }
    #main .business .list .slide { width: calc(100% - 460px); min-height: 401px; }
    #main .business .list .slide ul li { width: 350px; margin: 0 27px 0 0; }
    #main .business .list .slide ul li .img { border-radius: 9px; }
    #main .business .list .slide ul li .box { margin: 18px 0 0; padding: 15px; border-radius: 9px; font-size: 13px; min-height: 186px; }
}
@media screen and (max-width:1024px) {
    #main .business .list { margin: 128px 0 0; }
    #main .business .list dl { width: 410px; padding: 0 64px 0 0; }
    #main .business .list dl dt { font-size: 44px; }
    #main .business .list dl dd { margin: 24px 0 0; }
    #main .business .list dl dd .tit { font-size: 20px; }
    #main .business .list dl dd .bullet { margin:16px 0 12px; }
    #main .business .list dl dd .con { font-size: 12px; }
    #main .business .list .slide { width: calc(100% - 410px); min-height: 326px; }
    #main .business .list .slide ul li { width: 310px; margin: 0 24px 0 0; }
    #main .business .list .slide ul li .img { border-radius: 8px; }
    #main .business .list .slide ul li .box { margin: 16px 0 0; padding: 14px; border-radius: 8px; font-size: 12px; min-height: 172px; }
}
@media screen and (max-width:768px) {
    #main .business .list { margin: 112px 0 0; }
    #main .business .list dl { width: 360px; padding: 0 56px 0 0; }
    #main .business .list dl dt { font-size: 36px; }
    #main .business .list dl dd { margin: 21px 0 0; }
    #main .business .list dl dd .tit { font-size: 18px; }
    #main .business .list dl dd .bullet { margin:14px 0 10px; }
    #main .business .list dl dd .con { font-size: 11px; }
    #main .business .list .slide { width: calc(100% - 360px); min-height: 324px; }
    #main .business .list .slide ul li { width: 270px; margin: 0 21px 0 0; }
    #main .business .list .slide ul li .img { border-radius: 7px; }
    #main .business .list .slide ul li .box { margin: 14px 0 0; padding: 13px; border-radius: 7px; font-size: 11px; min-height: 158px; }
}
@media screen and (max-width:640px) {
    #main .business .list { margin: 96px 0 0; }
    #main .business .list dl { width: auto; padding: 0; }
    #main .business .list dl dt { font-size: 28px; }
    #main .business .list dl dd { margin: 18px 0 0; }
    #main .business .list dl dd .tit { font-size: 16px; }
    #main .business .list dl dd .bullet { margin:12px 0 8px; }
    #main .business .list dl dd .con { font-size: 10px; }
    #main .business .list .slide { width: 100%; min-height: 285px; margin: 24px 0 0; }
    #main .business .list .slide .slide-inner { position: static; top: auto; left: auto; min-width: 100%; }
    #main .business .list .slide ul li { width: 230px; margin: 0 18px 0 0; }
    #main .business .list .slide ul li .img { border-radius: 6px; }
    #main .business .list .slide ul li .box { margin: 12px 0 0; padding: 12px; border-radius: 6px; font-size: 10px; min-height: 144px; }
}



#main .location {  }
#main .location .map { overflow: hidden; margin: -1%; }
#main .location .map li { float: left; width: 48%; margin: 1%; }
#main .location .map li .text {  }
#main .location .map li .text .bullet { margin:0 0 20px; }
#main .location .map li .text p { color: #000; font-family: 'Freesentation'; font-size: 20px; font-style: normal; font-weight: 600; line-height: 150%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#main .location .map li .text span { color: #16B7FF; }
#main .location .map li .image { margin: 50px 0 0; border-radius: 20px; }

@media screen and (max-width:1240px) {
    #main .location .map li .text .bullet { margin:0 0 18px; }
    #main .location .map li .text p { font-size: 18px; }
    #main .location .map li .image { margin: 40px 0 0; border-radius: 18px; }
}
@media screen and (max-width:1024px) {
    #main .location .map li .text .bullet { margin:0 0 16px; }
    #main .location .map li .text p { font-size: 16px; }
    #main .location .map li .image { margin: 30px 0 0; border-radius: 16px; }
}
@media screen and (max-width:768px) {
    #main .location .map li .text .bullet { margin:0 0 14px; }
    #main .location .map li .text p { font-size: 14px; }
    #main .location .map li .image { margin: 20px 0 0; border-radius: 14px; }
}
@media screen and (max-width:640px) {
    #main .location .map { margin: 0; }
    #main .location .map li { float: none; width: auto; margin: 30px 0 0; }
    #main .location .map li:first-child { margin:0 }
    #main .location .map li .text .bullet { margin:0 0 12px; }
    #main .location .map li .text p { font-size: 12px; }
    #main .location .map li .image { margin: 10px 0 0; border-radius: 12px; }
}



#main .contact { background-image: url('../../../img/main/bg_contact.png'); background-color: #f8f8f8; }
#main .contact .box { padding: 40px 60px; border-radius: 30px; border: 1px solid #D9D9D9; background-color: rgba(255, 255, 255, 0.6); }
#main .contact .box form {  }
#main .contact .box form h5 { color: #000; text-align: center; font-family: 'Freesentation'; font-size: 24px; font-style: normal; font-weight: 300; line-height: 133.333%; text-align: center; }
#main .contact .box form h5 span { font-weight: 600; color: #16B7FF; }
#main .contact .box form .f { margin: 20px 0 0; }
#main .contact .box form .f ul { overflow: hidden; margin: -2%; }
#main .contact .box form .f ul li { float: left; width: 46%; margin: 2%; }
#main .contact .box form .f .i { margin: 40px 0 0; }
#main .contact .box form .f .i label { color: #000; font-family: 'Freesentation'; font-size: 16px; font-style: normal; font-weight: 600; margin: 0 0 12px; display: inline-block; }

#main .contact .box form .f .i textarea ,
#main .contact .box form .f .i input { width: 100%; color: #333; font-family: 'Freesentation'; font-size: 20px; font-style: normal; font-weight: 300; }
#main .contact .box form .f .i input { height: 55px; border:none; border-bottom: 1px solid #000; }
#main .contact .box form .f .i textarea { border-radius: 5px; border: 1px solid #000; height: 307px; padding: 12px 8px; vertical-align: top; resize: none; }

#main .contact .box form .f .a { position: relative; margin: 20px 0 0; }
#main .contact .box form .f .a label { color: #000; font-family: 'Freesentation'; font-size: 16px; font-style: normal; font-weight: 600; }
#main .contact .box form .f .a a { display: inline-block; width: 4%; position: relative; }
#main .contact .box form .f .a a:after { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%) rotate(45deg); content: ''; width: 9px; height: 9px; border-top: 2px solid #222f40; border-right: 2px solid #222f40; }
#main .contact .box form .f .a input { appearance: none; position: absolute; top: 50%; right: 0; transform: translate(0, -50%); padding: 0; margin: 0; width: 20px; height: 20px; border: 2px solid #c6c6c6; }
#main .contact .box form .f .a input:checked { appearance:auto; }

#main .contact .box form .f .b { text-align: center; margin:40px 0 0; }
#main .contact .box form .f .b button { border-radius: 5px; border: 1px solid #000; padding: 8px 60px; color: #000; font-family: 'Freesentation'; font-size: 20px; font-style: normal; font-weight: 400; line-height: 160%; background-color: #fff; }

@media screen and (max-width:1240px) {
    #main .contact .box { padding: 36px 54px; border-radius: 27px; }
    #main .contact .box form h5 { font-size: 22px; }
    #main .contact .box form .f { margin: 18px 0 0; }
    #main .contact .box form .f .i { margin: 36px 0 0; }
    #main .contact .box form .f .i label { font-size: 15px; margin: 0 0 11px; }

    #main .contact .box form .f .i textarea ,
    #main .contact .box form .f .i input { font-size: 18px; }
    #main .contact .box form .f .i input { height: 50px; }
    #main .contact .box form .f .i textarea { border-radius: 4px; height: 278px; padding: 11px 7px; }

    #main .contact .box form .f .a { margin: 18px 0 0; }
    #main .contact .box form .f .a label { font-size: 15px; }
    #main .contact .box form .f .a a:after { width: 8px; height: 8px; }
    #main .contact .box form .f .a input { width: 18px; height: 18px; }

    #main .contact .box form .f .b { margin:36px 0 0; }
    #main .contact .box form .f .b button { border-radius: 4px; padding: 7px 54px; font-size: 18px; }
}
@media screen and (max-width:1024px) {
    #main .contact .box { padding: 32px 48px; border-radius: 24px; }
    #main .contact .box form h5 { font-size: 20px; }
    #main .contact .box form .f { margin: 16px 0 0; }
    #main .contact .box form .f .i { margin: 32px 0 0; }
    #main .contact .box form .f .i label { font-size: 14px; margin: 0 0 10px; }

    #main .contact .box form .f .i textarea ,
    #main .contact .box form .f .i input { font-size: 16px; }
    #main .contact .box form .f .i input { height: 45px; }
    #main .contact .box form .f .i textarea { border-radius: 4px; height: 251px; padding: 10px 6px; }

    #main .contact .box form .f .a { margin: 16px 0 0; }
    #main .contact .box form .f .a label { font-size: 14px; }
    #main .contact .box form .f .a a:after { width: 8px; height: 8px; }
    #main .contact .box form .f .a input { width: 16px; height: 16px; }

    #main .contact .box form .f .b { margin:32px 0 0; }
    #main .contact .box form .f .b button { border-radius: 4px; padding: 7px 48px; font-size: 16px; }
}
@media screen and (max-width:768px) {
    #main .contact .box { padding: 28px 42px; border-radius: 21px; }
    #main .contact .box form h5 { font-size: 18px; }
    #main .contact .box form .f { margin: 14px 0 0; }
    #main .contact .box form .f .i { margin: 28px 0 0; }
    #main .contact .box form .f .i label { font-size: 13px; margin: 0 0 9px; }

    #main .contact .box form .f .i textarea ,
    #main .contact .box form .f .i input { font-size: 14px; }
    #main .contact .box form .f .i input { height: 40px; }
    #main .contact .box form .f .i textarea { border-radius: 3px; height: 224px; padding: 9px 5px; }

    #main .contact .box form .f .a { margin: 14px 0 0; }
    #main .contact .box form .f .a label { font-size: 13px; }
    #main .contact .box form .f .a a:after { width: 7px; height: 7px; }
    #main .contact .box form .f .a input { width: 14px; height: 14px; }

    #main .contact .box form .f .b { margin:28px 0 0; }
    #main .contact .box form .f .b button { border-radius: 3px; padding: 6px 42px; font-size: 14px; }
}
@media screen and (max-width:640px) {
    #main .contact .box { padding: 24px 36px; border-radius: 18px; }
    #main .contact .box form h5 { font-size: 16px; }
    #main .contact .box form .f { margin: 12px 0 0; }
    #main .contact .box form .f ul { margin: 0; }
    #main .contact .box form .f ul li { float: none; width: auto; margin: 0; }
    #main .contact .box form .f .i { margin: 24px 0 0; }
    #main .contact .box form .f .i label { font-size: 12px; margin: 0 0 8px; }

    #main .contact .box form .f .i textarea ,
    #main .contact .box form .f .i input { font-size: 12px; }
    #main .contact .box form .f .i input { height: 35px; }
    #main .contact .box form .f .i textarea { border-radius: 3px; height: 197px; padding: 8px 4px; }

    #main .contact .box form .f .a { margin: 12px 0 0; }
    #main .contact .box form .f .a label { font-size: 12px; }
    #main .contact .box form .f .a a:after { width: 7px; height: 7px; }
    #main .contact .box form .f .a input { width: 12px; height: 12px; }

    #main .contact .box form .f .b { margin:24px 0 0; }
    #main .contact .box form .f .b button { border-radius: 3px; padding: 6px 36px; font-size: 12px; }
}



.popup { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.4); z-index: 1001; }
.popup .box { position: fixed; top: 50%; left: 50%; max-width: 90%; width: 640px; transform: translate(-50%, -50%); max-height:90%; background-color: #ffffff; border-radius: 10px; }
.popup .box > div { position: relative; padding: 40px 30px; }
.popup .box div .tit { font-size: 18px; font-weight: 700; color: #2a2a2a; position: relative; }
.popup .box div a { display: block; position: absolute; top: 10px; right: 5px; width: 40px; height: 40px; }
.popup .box div a:after { display: block; content: "\00d7"; font-size: 35px; color: #999999; }
.popup .box div p { margin: 30px 0 0; font-size: 15px; color: #2a2a2a; max-height: 40vh; overflow-y: scroll; -ms-overflow-style :none; font-weight: 400; line-height:145%; }
.popup .box div p::-webkit-scrollbar { display: none; }

@media screen and (max-width:1240px) {
    .popup .box { border-radius: 9px; }
    .popup .box > div { padding: 36px 27px; }
    .popup .box div .tit { font-size: 17px; }
    .popup .box div a { top: 9px; right: 4px; width: 36px; height: 36px; }
    .popup .box div a:after { font-size: 32px; }
    .popup .box div p { margin: 27px 0 0; font-size: 14px; }
}
@media screen and (max-width:1024px) {
    .popup .box { border-radius: 8px; }
    .popup .box > div { padding: 32px 24px; }
    .popup .box div .tit { font-size: 16px; }
    .popup .box div a { top: 8px; right: 4px; width: 32px; height: 32px; }
    .popup .box div a:after { font-size: 29px; }
    .popup .box div p { margin: 24px 0 0; font-size: 13px; }
}
@media screen and (max-width:768px) {
    .popup .box { border-radius: 7px; }
    .popup .box > div { padding: 28px 21px; }
    .popup .box div .tit { font-size: 15px; }
    .popup .box div a { top: 7px; right: 3px; width: 28px; height: 28px; }
    .popup .box div a:after { font-size: 26px; }
    .popup .box div p { margin: 21px 0 0; font-size: 12px; }
}
@media screen and (max-width:640px) {
    .popup .box { border-radius: 6px; }
    .popup .box > div { padding: 24px 18px; }
    .popup .box div .tit { font-size: 14px; }
    .popup .box div a { top: 6px; right: 3px; width: 24px; height: 24px; }
    .popup .box div a:after { font-size: 23px; }
    .popup .box div p { margin: 18px 0 0; font-size: 11px; }
}