
::-webkit-scrollbar {
display:none;
} 

article,aside,details,figcaption,figure,footer,hgroup,menu,nav,section{display:block}
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,caption,tbody,tfoot,thead,tr,th,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline;}
body{ line-height:1.5; font-family:'Dotum'; font-size:16px; color:#000; background:#fff;-ms-overflow-style: none; } 
audio,canvas,progress,video{display:inline-block;vertical-align:baseline}
audio:not([controls]){display:none;height:0;}
ul,ol,li{list-style:none}
blockquote,q{quotes:none;}
blockquote:before,blockquote:after,q:before,q:after{content:'';content:none;}
fieldset,img{border:0}
hr{height:0;}
small{font-size:80%}
sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}
sup{top:-0.5em}
sub{bottom:-0.25em}
address,caption,em,var{font-style:normal;font-weight:normal}
a{text-decoration:none;cursor:pointer;color: inherit;}
a[href^="tel"]{font-style:normal}
a:hover,a:active,a:focus{text-decoration:none !important;}
b,strong{font-weight:bold}
dfn{font-style:italic}
img{border:0;vertical-align:top}
pre{overflow:auto}
code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}
table{border-spacing:0;border-collapse:collapse}
td,th{padding:0;}
legend, caption{overflow:hidden;text-indent:-9999999px; height:0 !important; width:0 !important;line-height:0 !important;margin:0;padding:0;}
input{vertical-align:middle;margin:0;padding:0;}
input[type="text"],input[type="password"],input[type="email"]{-webkit-appearance:none;appearance:none;border-radius:0;font-family:'Dotum';}
input:checked[type="checkbox"]{-webkit-appearance:checkbox;appearance:checkbox}
button,input[type="button"],input[type="submit"],input[type="reset"],input[type="file"]{border-radius:0;-webkit-appearance:button;appearance:button;font-family:'Dotum';}
button,input,optgroup,select,textarea{margin:0;font:inherit;color:inherit}
button{overflow:visible;border:none;cursor:pointer;margin:0;padding:0;}
a,input,button,select{outline:none}
button,select{text-transform:none}
optgroup{font-weight:bold}
textarea{border:1px solid #bcbcbc;overflow:auto;-webkit-appearance:none;appearance:none;}
input::-ms-clear{display:none;}


body { width: 100%; margin: auto; font-family: 'Noto Sans KR', sans-serif; }

body.main { overflow-y: hidden; }
/* body.sub { overflow-y: hidden; } */

.mo { display: none; }
.pc { display: block; }

/*  */


/*html,a,.btn { cursor: none; }*/
.btn { cursor: pointer; }

#cursor {
    position: fixed;
    z-index: 999999999999999;
    left: 0;
    top: 0;
    pointer-events: none;
    will-change: transform;
}

@media (hover: hover) and (pointer: fine) {
    .cursor__circle {
        display: none;
    width: 25px;
    height: 25px;
    margin-top: -50%;
    margin-left: -50%;
/*    margin-top: 0;
    margin-left: 0;*/
    border-radius: 50%;
    border: solid 1px #004e71;
/*	background-color: #004e71;*/
    transition: opacity 0.3s cubic-bezier(0.25, 1, 0.5, 1),
        background-color 0.3s cubic-bezier(0.25, 1, 0.5, 1),
        border-color 0.3s cubic-bezier(0.25, 1, 0.5, 1),
        width 0.3s cubic-bezier(0.25, 1, 0.5, 1),
        height 0.3s cubic-bezier(0.25, 1, 0.5, 1);
        display: none;
    }

    .cursor_drag { width: 25px; height: 25px; background-color: rgba(0,0,0,0.7); display: flex; justify-content: center; align-items: center; border-radius: 100%; left: 0; top: 0; transform: translate(-50%,-50%); transition: 0.3s; opacity: 0; position: absolute; }
    .cursor_drag p { color: #fff; font-size: 10px; line-height: 100%; font-weight: 500; display: inline-block; position: relative; letter-spacing: 0; }
    .cursor_drag p:before { content:''; width: 5px; height: 5px; border-left: 1px solid #000; border-bottom: 1px solid #000; transform: rotate(45deg); position: absolute; left: -33px; top: 0; bottom: 0; margin: auto; }
    .cursor_drag p:after { content:''; width: 5px; height: 5px; border-right: 1px solid #000; border-bottom: 1px solid #000; transform: rotate(-45deg); position: absolute; right: -33px; top: 0; bottom: 0; margin: auto; }
    
    .cursor_click { width: 25px; height: 25px; background-color: transparent; border: 1px solid #fff; display: flex; justify-content: center; align-items: center; border-radius: 100%; left: 0; top: 0; transform: translate(-50%,-50%); transition: 0.3s; opacity: 0; position: absolute; }
    .cursor_click p { color: #fff; font-size: 10px; line-height: 100%; font-weight: 500; display: inline-block; position: relative; letter-spacing: 0; transform: translateY(-5px); }
    .cursor_click p:before { content:''; width: 5px; height: 5px; border-left: 1px solid #fff; border-bottom: 1px solid #fff; transform: rotate(-45deg); position: absolute; left: 0; right: 0; top: 18px; bottom: 0; margin: auto; }
    
    #cursor{
    width: 70px;
    height: 70px;
    }

    .cursor_skip { width: 4rem; height: 4rem; background-color: #0e0908; display: flex; justify-content: center; align-items: center; border-radius: 100%; left: 0; top: 0; transform: translate(-50%,-50%); transition: transform 0.3s; opacity: 1; position: absolute; display: none; }
    .cursor_skip p { font-family: 'minerva'; color: #fff; font-size: 0.875rem; line-height: 100%; font-weight: 500; display: inline-block; position: relative; letter-spacing: 0; text-transform: uppercase; }
    .cursor_skip:before { content:''; width: 6.375rem; height: 6.375rem; position: absolute; left: -1.1875rem; top: -1.1875rem; background-color: #0e0908; opacity: 0.6; border-radius: 100%; 
    
        animation-name: cursor_skip, cursor_skip2;
        animation-duration: 2.1s, 2.1s;
        animation-delay: 0s, 0s;
        animation-timing-function: ease, ease;
        animation-fill-mode: both, both;
        animation-iteration-count: infinite, infinite;

    }
    .cursor_skip.intro5 { opacity: 0; transition: all 0.3s, opacity 1s 0s; }
    .cursor_skip.drag { opacity: 0; }

    body.main .cursor_skip { display: flex; }

    /* .intro_bg { width: 167.1428%; position: absolute; left: -33%; top: -33%; animation: intro_bg 8s 0s linear infinite; }
    
    @keyframes intro_bg {
        from { transform: rotate(-360deg); }
        to {  }
    } */

    #cursor.arrow .cursor__circle{
    width: 80px;
    height: 80px;
    background-color: transparent;
    border-color: #004e71;
    }

    #cursor.click .cursor__circle{
    width: 80px;
    height: 80px;
    background-color: transparent;
    border-color: transparent;
    }
    #cursor.click .cursor_click { 
    width: 65px;
    height: 65px;
    opacity: 1;
    }

    #cursor.drag .cursor__circle{
    width: 80px;
    height: 80px;
    background-color: transparent;
    border-color: transparent;
    }
    #cursor.drag .cursor_drag { 
    width: 65px;
    height: 65px;
    opacity: 1;
    }

    #cursor.drag2 .cursor__circle{
    width: 80px;
    height: 80px;
    background-color: transparent;
    border-color: transparent;
    }
    #cursor.drag2 .cursor_drag { 
    width: 65px;
    height: 65px;
    opacity: 1;
    }
    #cursor.drag2 .cursor_drag { background-color: transparent; border: 1px solid #fff; }
    #cursor.drag2 .cursor_drag p:before { border-left: 1px solid #fff; border-bottom: 1px solid #fff; }
    #cursor.drag2 .cursor_drag p:after { border-right: 1px solid #fff; border-bottom: 1px solid #fff; }




}



@keyframes cursor_skip {
    0% { transform: scale(0.7); }
    30% { transform: scale(0.7); }
    80% { transform: scale(1); }
    100% { transform: scale(1);  }
}
@keyframes cursor_skip2 {
    0% { opacity: 0; }
    20% { opacity: 0.4; }
    70% { opacity: 0.4; }
    100% { opacity: 0; }
}


/**/

.all_wrap { width: 100%; height: auto; position: relative; left: 0; top: 0; }

.intro_wrap { position: fixed; width: 100%; height: 100%; left: 0; top: 0; z-index: 9999; background-color: #fff; }
.intro_bg { width: 100%; height: 100%; position: absolute; left: 0; top: 0; right: 0; bottom: 0; margin: auto; overflow: hidden; }
.intro_bg:after { content:''; width: 100%; height: 100%; position: absolute; right: 0; top: 0; background-color: #010e4c; }
.intro_line01 { width: 100%; height: 1px; background-color: #010e4c; position: absolute; left: 0; top: 0; }
.intro_line02 { width: 100%; height: 1px; background-color: #010e4c; position: absolute; right: 0; bottom: 0; }
.intro_line03 { width: 1px; height: 100%; background-color: #010e4c; position: absolute; left: 0; top: 0; }
.intro_line04 { width: 1px; height: 100%; background-color: #010e4c; position: absolute; right: 0; bottom: 0; }

.intro_wrap.intro .intro_bg { width: 290px; height: 320px; transition: 1.0s 0s; }
.intro_wrap.intro2 .intro_bg:after { width: 0; transition: 1.0s 0s; }
.intro_wrap.intro2 .intro_line01 { width: 0; transition: 1.2s 0.6s; }
.intro_wrap.intro2 .intro_line02 { width: 0; transition: 1.2s 0.6s; }
.intro_wrap.intro2 .intro_line03 { height: 0; transition: 1.2s 0.6s; }
.intro_wrap.intro2 .intro_line04 { height: 0; transition: 1.2s 0.6s; }

/*  */

.swiper_main { width: 100%; left:0%; height: calc(100vh - 170px); margin: 0; margin-top: 170px; position: relative;}

.main_wrap { width: 84%; margin-left:8%; height: 100%; position: relative; left: 0%; top: 0; z-index: 5; display: flex; justify-content: space-between; align-items: center; overflow: hidden;  }
/* .main_img { width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 1; transform: scale(1.4); transform: scale(1); } */


.main_img { width: 74%; height: 100%; position: relative; overflow: hidden;}
.main_img>div { width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 1; transform: scale(1.4); transform: scale(1); }
.main_wrap.main01 .main_img>div { background: url(../img/main_img.jpg) center no-repeat; background-size: cover; }
.main_wrap.main02 .main_img>div { background: url(../img/main_img2.jpg) center no-repeat; background-size: cover; }
.main_wrap.main03 .main_img>div { background: url(../img/main_img3.jpg) center no-repeat; background-size: cover; }

.main_bg { width: 100%; height: 100%; position: absolute; left: 0; top: 0; background: url(../img/main_bg.png) center no-repeat; background-size: cover; z-index: 8; transform: scale(1); }

.main_txt01 { position: absolute; left: 7%; bottom: 12%; color: #fff; text-align: left; font-family: 'felixti'; z-index: 9; }
.main_txt01 h3 { /*font-size: 160px;*/ font-size: 100px; line-height: 100%; letter-spacing: 0px; /*letter-spacing: -8px; */ opacity: 0; transform: translateX(400px); opacity: 1; transform: translate(0); }
.main_txt01 h1 { font-size: 40px; line-height: 100%; letter-spacing: 60px; opacity: 0; transform: translateX(500px); margin-top: 0px; margin-left: 30px; opacity: 1; transform: translate(0); }

.main_wrap.main02 .main_txt01 { right: 5%; bottom: revert; top: 12%; }


.main_txt02 { position: absolute; right: 10%; top: 25%; text-align: left; font-family: 'mm'; z-index: 9; display: flex; justify-content: center; align-items: flex-start;  }
.main_txt02>div { opacity: 0; transform: translateY(80px); }
.main_txt02 h3 { font-size: 30px; width: 30px; line-height: 100%; margin: 270px 30px 10px 0; font-weight: 800; }
.main_txt02 h3 b { display: block; margin: 5px 0; }
.main_txt02 p { font-size: 17px; line-height:220%; width: 21px; line-height: 100%; margin-left: 14px; font-weight: 500; opacity: 0; transform: translateY(80px); }
.main_txt02 p:nth-child(2) { margin-top: 40px; }
.main_txt02 p b { display: block; line-height: 0%; margin-top: -5px; margin-bottom: 15px; }
.main_txt02 p:last-child b { margin-top: -5px; margin-bottom: 20px; }

.main_txt_box {  position: absolute; right: 7%; top: 14%; color: #fff; text-align: left; z-index: 9; }
.main_txt_box h2 { font-size: 32px; line-height: 128%; font-weight: 600; opacity: 0; transform: translateX(200px); opacity: 1; transform: translate(0);}
.main_txt_box>div { width: 1px; height: 65px; margin-top: 30px; margin-left: 5px; position: relative; }
.main_txt_box>div::after { content: ''; width: 100%; height: 100%; position: absolute; left: 0; top: 0; background-color: #fff; }
.main_txt_box p { font-size: 22px; line-height: 200%; font-weight: 400; margin-top: 30px; opacity: 0; transform: translateX(200px); opacity: 1; transform: translate(0); }

.main_txt_box h3 { font-size: 30px; line-height: 100%; font-weight: 600; margin-top: 45px; opacity: 0; transform: translateX(200px); opacity: 1; transform: translate(0); }
.main_txt_box h4 { font-size: 30px; line-height: 100%; font-weight: 200; margin-top: 20px; opacity: 0; transform: translateX(200px); letter-spacing: 1px; opacity: 1; transform: translate(0); }

/* .main_txt_box2 {  position: absolute; right: 7%; top: 14%; color: #fff; text-align: left; z-index: 9; } */
.main_txt_box2 { width: 26%; min-width:300px; height: 100%; top: 0;/*display: flex; justify-content: center; align-items: center;*/ position: relative; color: #fff; text-align: center; z-index: 9; }
.main_txt_box2.txt_box2-1 { /*background-color: #341a03;*/ background-color: #284033;}
.main_txt_box2.txt_box2-2 { background-color: #061d2b;  }
.main_logo {margin-top:25%;}
.main_txt_box2>div {}
.main_txt_box2 h2 { font-size: 32px; line-height: 128%; font-weight: 600; opacity: 0; transform: translateX(200px); opacity: 1; transform: translate(0); letter-spacing: -3px; margin-top: 30px; color:#eebb1f;}
.main_txt_box2>div>div { width: 1px; height: 25px; margin: auto; margin-top: 17px; position: relative; }
.main_txt_box2>div>div::after { content: ''; width: 100%; height: 100%; position: absolute; left: 0; top: 0; background-color: #fff; }
.main_txt_box2 p { font-size: 30px; line-height: 170%; font-weight: 500; margin-top: 15px; opacity: 0; transform: translateX(200px); opacity: 1; transform: translate(0);  letter-spacing: -3px;}
.main_txt_box2 p span {color:#eebb1f; }
.main_txt_box2 h3 { font-size: 50px; line-height: 100%; font-weight: 600; margin-top: 45px; opacity: 0; transform: translateX(200px); opacity: 1; transform: translate(0);  letter-spacing: -3px;}
.main_txt_box2 h4 {position:absolute; bottom:0; width:100%; height:60px; /*background-color: #c00000;*/ background-color: rgba(225,225,225,0.4); left:0; right:0; margin:0 auto; font-size: 1.53rem; 
line-height: 60px; font-weight: 600; margin-top: 20px; opacity: 0; transform: translateX(200px); letter-spacing: -1px; opacity: 1; transform: translate(0); }
.main_txt_box2 h4 span {color:#eebb1f; font-weight: 600;}

/* .main_wrap.main02 .main_txt_box2 { top: revert; bottom: 14%; text-align: right; } */
/* .main_wrap.main02 .main_txt_box2>div { margin-left: auto; margin-right: 5px; } */


/* .main_wrap.main02 .main_txt_box { top: revert; bottom: 14%; text-align: right; } */
/* .main_wrap.main02 .main_txt_box>div { margin-left: auto; margin-right: 5px; } */

.txt_box2-2 p {padding:20px 0 0 0;}
.txt_box2-2 h2 { font-size: 50px; margin-top: 45px; color:#fff;}
.txt_box2-2 h3 { font-size: 32px; font-weight:400; line-height: 150%; margin-top: 15px; color:#eebb1f;}
/* .txt_box2-2 p { font-size: 32px;  } */

.main_wrap.on .main_img { transform: scale(1); transition: 3s 0s; }
.main_wrap.on .main_bg { transform: scale(12); transition: 3s 0s; }
.main_wrap.on .main_txt_box h2 { opacity: 1; transform: translate(0); transition: 1.8s 0.5s; }
.main_wrap.on .main_txt_box>div::after { height: 100%; transition: 1.8s 1.2s; }
.main_wrap.on .main_txt_box p { opacity: 1; transform: translate(0); transition: 1.8s 1.2s; }
.main_wrap.on .main_txt_box h3 { opacity: 1; transform: translate(0); transition: 1.8s 1.2s; }
.main_wrap.on .main_txt_box h4 { opacity: 1; transform: translate(0); transition: 1.8s 1.2s; }

.main_wrap.on .main_txt01 h3 { opacity: 1; transform: translate(0); transition: 1.8s 0.5s; }
.main_wrap.on .main_txt01 h1 { opacity: 1; transform: translate(0); transition: 1.8s 0.7s; }
.main_wrap.on .main_txt02>div { opacity: 1; transform: translate(0); transition: 1.2s 1.4s; }
.main_wrap.on .main_txt02 p { opacity: 1; transform: translate(0); transition: 1.2s 1.2s; }


.swiper_main .swiper-slide-active .main_img { animation: main_img 3s 0s both; }
.swiper_main .swiper-slide-active .main_txt01 h3 { animation: main_txt 1.8s 0.5s both; }
.swiper_main .swiper-slide-active .main_txt01 h1 { animation: main_txt2 1.8s 0.7s both; }
.swiper_main .swiper-slide-active .main_txt_box h2 { animation: main_txt3 1.8s 0.5s both; }
.swiper_main .swiper-slide-active .main_txt_box>div::after { animation: main_line 1.8s 1.0s both; }
.swiper_main .swiper-slide-active .main_txt_box p { animation: main_txt4 1.8s 1.0s both; }
.swiper_main .swiper-slide-active .main_txt_box h3 { animation: main_txt4 1.8s 1.0s both; }
.swiper_main .swiper-slide-active .main_txt_box h4 { animation: main_txt4 1.8s 1.0s both; }


.main_wrap.on .main_txt_box2 h2 { opacity: 1; transform: translate(0); transition: 1.8s 0.5s; }
.main_wrap.on .main_txt_box2>div::after { height: 100%; transition: 1.8s 1.2s; }
.main_wrap.on .main_txt_box2 p { opacity: 1; transform: translate(0); transition: 1.8s 1.2s; }
.main_wrap.on .main_txt_box2 h3 { opacity: 1; transform: translate(0); transition: 1.8s 1.2s; }
.main_wrap.on .main_txt_box2 h4 { opacity: 1; transform: translate(0); transition: 1.8s 1.2s; }


.swiper_main .swiper-slide-active .main_txt_box2>div::after { animation: main_line 1.8s 1.0s both; }
/*.swiper_main .swiper-slide-active .main_txt_box2 h2 { animation: main_txt3 1.8s 0.5s both; }
.swiper_main .swiper-slide-active .main_txt_box2 p { animation: main_txt4 1.8s 1.0s both; }
.swiper_main .swiper-slide-active .main_txt_box2 h3 { animation: main_txt4 1.8s 1.0s both; }*/
.swiper_main .swiper-slide-active .main_txt_box2 h4 { animation: main_txt4 1.8s 1.0s both; }

.swiper_main .swiper-slide-active .txt_box2-2 .main_logo { animation: main_txt3 1.8s 0.5s both; }
.swiper_main .swiper-slide-active .txt_box2-2 h2 { animation: main_txt3 1.8s 1.0s both; }
.swiper_main .swiper-slide-active .txt_box2-2 h3 { animation: main_txt4 1.8s 1.0s both; }
.swiper_main .swiper-slide-active .txt_box2-2>div>div { animation: main_txt4 1.8s 1.0s both; }
.swiper_main .swiper-slide-active .txt_box2-2 p { animation: main_txt3 1.8s 0.5s both; }

.swiper_main .swiper-slide-active .txt_box2-1 .main_logo { animation: main_txt4 1.8s 0.5s both; }
.swiper_main .swiper-slide-active .txt_box2-1 h2 { animation: main_txt4 1.8s 0.5s both; }
.swiper_main .swiper-slide-active .txt_box2-1 h3 { animation: main_txt3 1.8s 1.0s both; }
.swiper_main .swiper-slide-active .txt_box2-1 p { animation: main_txt4 1.8s 1.0s both; }
.swiper_main .swiper-slide-active .txt_box2-1>div>div { animation: main_txt4 1.8s 1.0s both; }


@keyframes main_img {
    0% { transform: scale(1.4); }
    100% {  }
}
@keyframes main_txt {
    0% { opacity: 0; transform: translateX(400px); }
    100% {  }
}
@keyframes main_txt2 {
    0% { opacity: 0; transform: translateX(400px); }
    100% {  }
}
@keyframes main_txt3 {
    0% { opacity: 0; transform: translateY(50px); }
    100% {  }
}
@keyframes main_txt4 {
    0% { opacity: 0; transform: translateY(60px); }
    100% {  }
}
@keyframes main_line {
    0% { height: 0; }
    100% {  }
}


/*  */

.summary_wrap { width: 100%; height: calc(100vh - 150px); margin-top: 150px; position: relative; left: 0; top: 0; z-index: 5; display: flex; justify-content: center; align-items: center; }
.summary_wrap>div { width: 100%; max-width: 1300px; transform: translateY(-10px); }
.summary_wrap>div>div:last-child { width: 100%; display: flex; justify-content: space-between; align-items: center; margin-top: 45px; }

.summary_tit { text-align: center; animation: summary_op 1.4s 0s both; }
.summary_tit h2 { font-size: 40px; line-height: 100%; }

.summary_img_box { width: 100%; max-width: 689px; height: 521px; margin-top: 0px; position: relative; overflow: hidden; animation: summary_op 1.4s 0s both; }
.summary_img { width: 100%; height: 100%; position: absolute; left: 0; top: 0; background: url(../img/summary.jpg) center no-repeat; background-size: cover; z-index: 2; animation: summary_img 2.5s 0.2s both; }
.summary_img_txt { position: absolute; left: 6%; bottom: -23%; color: #fff; text-align: left; font-family: 'felixti'; z-index: 9; }
.summary_img_txt h4 { font-size: 24px; line-height: 100%; letter-spacing: 54px; animation: summary_img_txt 1.4s 0.8s both; }
.summary_img_txt h1 { font-size: 176px; line-height: 100%; letter-spacing: -10px; animation: summary_img_txt 1.4s 0.95s both; }

.summary_txt_box { width: 100%; max-width: 540px; display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 50px 6%; animation: summary_txt 1.2s 0.45s both; }
.summary_txt_box h2 { width: 100%; font-size: 22px; line-height: 100%; font-weight: 600; margin-bottom: -5px; }
.summary_txt_box>div { width: 47%; }
.summary_txt_box>div:last-child { width: 100%; margin-top: 3.6%; margin-top: 0; }
.summary_txt_box h3 { font-size: 20px; line-height: 100%; font-weight: 600; color: #8a694e; border-bottom: 1px solid #ababab; padding-bottom: 8px; }
.summary_txt_box p { font-size: 14px; line-height: 142%; margin-top: 20px; }

@keyframes summary_op {
    0% { opacity: 0; }
    100% {   }
}
@keyframes summary_img_txt {
    0% { opacity: 0; transform: translateX(250px); }
    100% {   }
}
@keyframes summary_img {
    0% { transform: scale(1.3) translateY(0%); }
    100% {   }
}
@keyframes summary_txt {
    0% { opacity: 0; transform: translateY(60px); }
    100% {   }
}

/**/


.guest_wrap { width: 100%; height:100%;/*height: calc(100vh - 150px);*/ margin-top: 250px; margin-bottom: 50px; position: relative; left: 0; top: 0; z-index: 5; display: flex; justify-content: center; align-items: center;  text-align: center;}
.guest_wrap>div { width: 100%; max-width: 1300px; transform: translateY(-10px); }
.guest_wrap>div>div:last-child { width: 100%; display: flex; justify-content: space-between; align-items: center; margin-top: 45px; }

.guest_tit { text-align: center; animation: summary_op 1.4s 0s both; }
.guest_tit h2 { font-size: 40px; line-height: 100%; }



/*  */

.location_wrap { width: 100%; height: calc(100vh - 150px); margin-top: 150px; position: relative; left: 0; top: 0; z-index: 5; display: flex; justify-content: flex-start; align-items: center; }

.location_img_box { width: 100%; max-width: 1305px; height: 100%; position: relative; overflow: hidden; }
.location_img { width: 100%; height: 100%; position: absolute; left: 0; top: 0; background: url(../img/location_map.jpg) center bottom 10% no-repeat; background-size: cover; z-index: 2; animation: location_img11 2s 0s both; }

.location_txt_box { height: 100%; display: flex; justify-content: flex-start; align-items: center; position: relative; z-index: 9; transform: translateX(-22%); }
.location_txt_box>div { margin-left: 90px; transform: translateY(-10px); transform: translateY(-5px); }
.location_img2 { position: relative; animation: location_txt 1.2s 0.2s both; }
.location_img2>img { cursor: pointer; }
/* .location_txt_box>div>img { transform: translateX(-145px); transform: translateX(0); } */
.location_txt_box h3 { font-size: 24px; line-height: 100%; font-weight: 400; color: #828282; margin-top: 35px; animation: location_txt 1.2s 0.4s both; }
.location_txt_box h1 { font-size: 55px; line-height: 113%; font-weight: 600; color: #010e4c; margin-top: 15px; margin-left: -2px; animation: location_txt 1.2s 0.4s both; }
.location_txt_box h4 { font-size: 20px; line-height: 175%; font-weight: 400; margin-top: 40px; animation: location_txt 1.2s 0.6s both; }
.location_txt_box h2 { font-size: 33px; line-height: 100%; font-weight: 600; margin-top: 46px; }

.location_bt { position: absolute; right: 10px; bottom: -46px; display: flex; justify-content: flex-end; align-items: center; cursor: pointer; }
.location_bt>div { width: 35px; height: 35px; border-radius: 100%; background: #010e4c url(../img/location_icon.png) center top 7px no-repeat; margin-left: 10px; }
.location_bt p { font-size: 18px; line-height: 100%; font-weight: 600; color: #010e4c; }

.location_premium_box { margin-top: 70px; animation: location_txt 1.2s 0.6s both; }
.location_premium_box h2 { font-size: 24px; line-height: 100%; font-weight: 600; margin-bottom: 17px; }
.location_premium_box>div { display: flex; justify-content: space-between; align-items: center; position: relative; }
.location_premium_box>div>img { position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; z-index: 9; }
.location_premium_img>div { position: relative; }
.location_premium_img h6 { position: absolute; right: 10px; bottom: 10px; color: #fff; font-size: 12px; line-height: 100%; text-shadow: 0 0 0.5rem rgba(0, 0, 0, 1),0 0 0.5rem rgba(0, 0, 0, 1); letter-spacing: 0.2px; font-weight: 300; }
.location_premium_box p { width: 50%; font-size: 14px; line-height: 188%; margin-top: 10px; font-weight: 500; }

.location_pop_wrap { width: 100%; height: 100%; position: fixed; left: 0; top: -100%; z-index: 99999999; display: flex; justify-content: center; align-items: center; transition: 0.8s 0s; }
.location_pop_bg_bt { display: block; width: 100%; height: 100%; position: absolute; left: 0; top: 0; cursor: pointer; z-index: 1; }
.location_pop_bg { width: 100%; height: 100%; position: fixed; left: -100%; top: 0; z-index: 99999998; background-color: #000; opacity: 0.8; transition: 0.6s 0.2s; }

.location_pop { width: 75%; max-width: 980px; position: relative; display: flex; justify-content: center; align-items: center; transform: translateY(0px); z-index: 9; }
.location_pop img { width: 100%; }
.location_pop_close { width: 65px; height: 65px; position: absolute; right: -75px; top: 0; cursor: pointer; }
.location_pop_close:after { content:''; width: 1px; height: 100%; position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; background-color: #fff; transform: rotate(45deg); }
.location_pop_close:before { content:''; width: 1px; height: 100%; position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; background-color: #fff; transform: rotate(-45deg); }


.location_pop_wrap.active { top: 0; transition: 0.8s 0.2s; }
.location_pop_bg.active { left: 0; transition: 0.6s 0s; }


@keyframes location_img {
    0% { transform: scale(1.2); }
    100% {   }
}
@keyframes location_txt {
    0% { opacity: 0; transform: translateX(70px); }
    100% {   }
}


/*  */

.brand_wrap { width: 100%; height: calc(100vh - 150px); margin-top: 150px; position: relative; left: 0; top: 0; z-index: 5; display: flex; justify-content: space-between; align-items: center; }
.brand_wrap::before { content: ''; width: 100%; height: 100%; position: absolute; left: 0; top: -50%; z-index: -1; background-color: #000; }
.brand_wrap>div { height: 100%; position: relative; }

.brand_left { width: 33.33%; }
.brand_right { width: 66.67%; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; }

.brand_img_box { position: relative; display: flex; justify-content: center; align-items: center; overflow: hidden; }
.brand_img_box:after { content: ''; width: 0%; height: 110%; position: absolute; top: -5%; background-color: #fff; z-index: 9; }
.brand_img_box.box01 { width: 100%; height: 100%; }
.brand_img_box.box02 { width: 100%; height: 50%; }
.brand_img_box.box03 { width: 50%; height: 50%; justify-content: flex-start; align-items: flex-start; }
.brand_img_box.box04 { width: 50%; height: 50%; justify-content: flex-start; align-items: flex-start; }
.brand_img_box.box01:after { left: -5%; animation: brand_bg 1.7s 0.1s both; }
.brand_img_box.box02:after { right: -5%; animation: brand_bg 1.7s 0.0s both; }
.brand_img_box.box03:after { right: -5%; animation: brand_bg 1.7s 0.2s both; }
.brand_img_box.box04:after { right: -5%; animation: brand_bg 1.7s 0.2s both; }

.brand_img { width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 1; transition: 1.2s; }
.brand_img.img01 { background: url(../img/brand_img01.jpg) center no-repeat; background-size: cover; }
.brand_img.img02 { background: url(../img/brand_img02.jpg) center no-repeat; background-size: cover; }
.brand_img.img03 { background: url(../img/brand_img03.jpg) center no-repeat; background-size: cover; }
.brand_img.img04 { background: url(../img/brand_img04.jpg) center no-repeat; background-size: cover; }

.brand_txt_box { color: #fff; text-align: center; position: relative; z-index: 9; }
.brand_txt_box.box01 { animation: brand_txt 1.2s 0.6s both; }
.brand_txt_box.box02 { animation: brand_txt2 1.2s 0.6s both; }
.brand_txt_box.box03 { color: #000; text-align: left; margin-left: 70px; margin-top: 65px; animation: brand_txt3 1.2s 0.6s both; }
.brand_txt_box.box04 { text-align: left; margin-left: 70px; margin-top: 65px; animation: brand_txt4 1.2s 0.6s both; }
.brand_txt_box h2 { /*font-family: 'mm'; */font-size: 33px; line-height: 120%; font-weight: 300; }
.brand_txt_box h3 { /*font-family: 'mm';*/ font-size: 24px; line-height: 145%; font-weight: 300; }
.brand_txt_box p { font-size: 14px; line-height: 215%; margin-top: 25px; opacity: 0.4; }
.brand_logo { margin-top: 80px; }
.brand_txt_box.box01 p { margin-top: 50px; }
.brand_txt_box.box03 h3 { font-weight: 500; }
.brand_txt_box.box03 p { opacity: 0.7; }

.brand_img_box:hover .brand_img { transform: scale(1.035); }

@keyframes brand_bg {
    0% { width: 110%; }
    100% {   }
}
@keyframes brand_txt {
    0% { opacity: 0; transform: translateY(40px); }
    100% {   }
}
@keyframes brand_txt2 {
    0% { opacity: 0; transform: translateY(-40px); }
    100% {   }
}
@keyframes brand_txt3 {
    0% { opacity: 0; transform: translateX(-40px); }
    100% {   }
}
@keyframes brand_txt4 {
    0% { opacity: 0; transform: translateX(40px); }
    100% {   }
}


/*  */

.contact_wrap { width: 100%; height: calc(100vh - 150px); margin-top: 150px; position: relative; left: 0; top: 0; z-index: 5; display: flex; justify-content: center; align-items: center; }
.contact_wrap>div:last-child { width: 90%; max-width: 1050px; position: relative; z-index: 9; display: flex; justify-content: space-between; align-items: center; }

.contact_bg { width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 1; background: url(../img/contact_bg.jpg) center no-repeat; background-size: cover; animation: contact_bg 9.0s 0s infinite; }

.contact_map { border: 1px solid #000; animation: contact_map 1.2s 0.2s both; }

.contact_txt_box { text-align: left; }
.contact_txt_box h2 { font-size: 40px; line-height: 100%; font-weight: 600; animation: contact_txt 1.2s 0.2s both; }
.contact_txt_box p { font-size: 16px; line-height: 188%; margin-top: 15px; margin-top: 25px; animation: contact_txt 1.2s 0.2s both; }

.contact_bt_box { display: flex; justify-content: flex-start; align-items: center; margin-top: 45px; animation: contact_txt 1.2s 0.2s both; margin-top: 10px; }
.contact_bt_box.box01 { margin-bottom: 25px; }
.contact_bt { display: flex; justify-content: flex-start; align-items: center; margin-right: 17px; }
.contact_bt>div { width: 30px; height: 30px; border-radius: 100%; margin-right: 8px; border: 1px solid #000; box-sizing: border-box; }
.contact_bt>div.naver { background: url(../img/naver.png) center no-repeat; }
.contact_bt>div.kakao { background: #000 url(../img/kakao.png) center no-repeat; }
.contact_bt h5 { font-size: 12px; line-height: 100%; }

.contact_txt_box h3 { font-family: 'Futura PT', sans-serif; font-size: 56px; line-height: 100%; color: #2a2a2a; margin-top: 100px; font-weight: 400; letter-spacing: 2px; margin-bottom: 10px; margin-left: -4px; animation: contact_txt 1.2s 0.55s both; }

@keyframes contact_bg {
	0% { transform: scale(1); }
	50% { transform: scale(1.12); }
	100% { transform: scale(1); }
}
@keyframes contact_map {
    0% { opacity: 0; transform: translateX(-70px); }
    100% {   }
}
@keyframes contact_txt {
    0% { opacity: 0; transform: translateX(70px); }
    100% {   }
}

/*  */

/* .product_wrap { width: 100%; height: calc(100vh - 150px); margin-top: 150px; position: relative; left: 0; top: 0; z-index: 5; display: flex; justify-content: center; align-items: center; } */
/* .product_wrap>div { width: 90%; max-width: 1400px; display: flex; justify-content: space-between; align-items: center; animation: product 1.4s 0.2s both; } */

.product_left { width: 74%; height: 100%; position: relative; }
.product_content { position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; display: flex; justify-content: center; align-items: center; opacity: 1; transition: 0.4s; }
.product_content.active { opacity: 1; }
.product_content p { font-size: 14px; line-height: 180%; opacity: 0.7; font-weight: 500; }

.product_img_box { display: flex; justify-content: center; align-items: center; gap: 0 15px; }
.product_img_box>div { display: flex; justify-content: center; align-items: flex-start; flex-direction: column; gap: 15px 0; }
.product_img { position: relative; }
.product_img.img02 { margin-bottom: 20px; }
.product_img.img02 i { font-size: 14px; line-height: 180%; opacity: 0.7; font-weight: 500;  }

.product_img.img06 { margin-left: 300px; }

.product_content.con01 .product_img_box { flex-wrap: wrap; }
.product_content.con01 p { width: 100%; text-align: center; margin-top: 10px; }
/*.product_content.con02 p { position: absolute; left: 0; bottom: -70px; }*/
.product_content.con03 .product_img_box { align-items: flex-start; flex-direction: column; gap: 15px 0; }
/*.product_content.con03 p { position: absolute; left: 0; bottom: -75px; }*/

.product_img.img02 p { position: absolute; right: 20px; bottom: 75px;  color:#fff; opacity: 1;}
.product_img.img03 p { position: absolute; right: 20px; bottom: 10px;  color:#fff; opacity: 1;}
.product_img.img04 p { position: absolute; right: 20px; bottom: 10px;  color:#fff; opacity: 1;}

.product_img.img05 i { font-size: 14px; line-height: 180%; opacity: 0.7; font-weight: 500;  }
.product_img.img05 p { position: absolute; right: 20px; bottom: 75px;  color:#fff; opacity: 1; }
.product_img.img06 p { position: absolute; right: 20px; bottom: 10px;  color:#fff; opacity: 1; }

.product_img.img07 p { position: absolute; right: 0; bottom: -30px; }
.product_img.img08 p { position: absolute; right: -130px; bottom: -4px; }
.product_img.img09 p { position: absolute; right: 0; bottom: -30px; }

.product_fixed { position: fixed; height: 470px; right: 6%; top: 0; bottom: 0; margin: auto; z-index: 999; }

.product_right { width: 26%; }
.product_right ul { height: 100%; border-left: 1px solid #9e9e9e; padding: 65px 0 70px; }
.product_right ul li { padding: 8px 0 14px; padding-left: 40px; margin-bottom: 45px; position: relative; opacity: 0.3; transition: 0.3s; color: #000; cursor: pointer; }
.product_right ul li:last-child { margin-bottom: 0; }
.product_right ul li:before { content:''; width: 7px; height: 100%; position: absolute; left: -10px; top: 0; bottom: 0; margin: auto; background-color: #010e4c; opacity: 0; transition: 0.3s; }
.product_right ul li h3 { font-size: 23px; line-height: 120%; font-weight: 600; }
.product_right ul li p { font-size: 16px; line-height: 100%; opacity: 0.7; margin-top: 12px; font-weight: 500; }

.product_right ul li.active { opacity: 1; color: #010e4c; }
.product_right ul li.active::before { left: -4px; opacity: 1; }

.product_right ul li:hover { opacity: 1; color: #010e4c; }
.product_right ul li:hover::before { left: -4px; opacity: 1; }

/* @keyframes product {
    0% { opacity: 0; }
    100% {   }
} */


/*  */

.premium_wrap { width: 100%; height: calc(100vh - 150px); margin-top: 150px; position: relative; left: 0; top: 0; z-index: 5; display: flex; justify-content: center; align-items: center; }
.premium_wrap>div { width: 90%; max-width: 1300px; }

.premium_tit { text-align: left; }
.premium_tit h4 { font-size: 22px; line-height: 100%; color: #a0a0a0; font-weight: 300; text-transform: uppercase; letter-spacing: 0; }
.premium_tit h2 { font-size: 40px; line-height: 100%; color: #010e4c; font-weight: 400; margin-top: 10px; }
.premium_tit h2 b { font-weight: 700; }
.premium_tit h2 span { font-size: 22px; }

.premium_img_box { width: 100%; display: flex; justify-content: space-between; align-items: center; margin-top: 32px; }
.premium_img_box>div:first-child { animation: premium_img 1.2s 0.5s both; }
.premium_img_box>div:last-child { animation: premium_img2 1.2s 0.5s both; }
.premium_img { position: relative; }
.premium_img h6 { font-size: 13px; line-height: 100%; color: #fff; position: absolute; right: 12px; bottom: 12px; z-index: 9; text-shadow: 0 0 7px rgba(0,0,0,0.7); letter-spacing: 0; }
.premium_img_box p { font-size: 16px; line-height: 188%; margin-top: 15px; }


.premium_wrap.on .premium_tit { opacity: 1; transform: translate(0); transition: 1.2s 0.2s; }
.premium_wrap.on .premium_img_box>div:first-child { opacity: 1; transform: translate(0); transition: 1.2s 0.7s; }
.premium_wrap.on .premium_img_box>div:last-child { opacity: 1; transform: translate(0); transition: 1.2s 0.7s; }

/*  */

.complex_wrap { width: 100%; height: calc(100vh - 150px); margin-top: 150px; position: relative; left: 0; top: 0; z-index: 5; display: flex; justify-content: center; align-items: center; }
.complex_wrap>div { width: 100%; max-width: 1300px; transform: translateY(-10px); }
.complex_wrap>div>div:last-child { width: 100%; display: flex; justify-content: space-between; align-items: center; margin-top: 45px; }

.complex_img { animation: complex_img 1.4s 0.4s both; }

.complex_chart_box { width: 100%; max-width: 573px; animation: complex_chart 1.4s 0.4s both; }
.complex_wrap ul.tabs2 { width: 100%; margin-bottom: 35px; }
.complex_wrap ul.tabs2 li { margin-left: 0; background: none; border: 1px solid transparent; border-bottom: 1px solid #000; }
.complex_wrap ul.tabs2 li.selected { background: none; border: 1px solid #000; border-bottom: 1px solid transparent; }
.complex_wrap ul.tabs2 li.selected a { color: #000; }


@keyframes complex_img {
    0% { opacity: 0; transform: translateX(-80px); }
    100% {   }
}
@keyframes complex_chart {
    0% { opacity: 0; transform: translateX(80px); }
    100% {   }
}

/*  */

.all_wrap.premium { width: 100%; height: 100vh; overflow: hidden; position: relative; left: 0; top: 0; }

/*  */

.footer { width: 100%; background-color: #000; color: rgba(255,255,255,0.35); text-align: center; position: relative; z-index: 99; padding: 3rem 0 2.875rem; box-sizing: border-box; }
.footer:after { content:''; width: 100%; height: 100vh; position: absolute; left: 0; top: -100vh; display: none; }

.footer_logo {margin-bottom: 2rem;}
.footer ul { width: 50%; margin: auto; display: flex; justify-content: center; align-items: flex-end; flex-wrap: wrap; margin-top: 0.5rem; }
.footer ul li { font-size: 0.75rem; line-height: 100%; font-weight: 5300; padding: 0 0.75rem; position: relative; letter-spacing: 0; }
.footer ul li:after { content:''; width: 1px; height: 0.75rem; position: absolute; right: 0; top: 1px; bottom: 0; margin: auto; background-color: #fff; opacity: 0.3; }
.footer ul li:last-child:after,.footer ul li:nth-child(5):after { display: none; }
/* .footer p { font-size: 0.75rem; line-height: 100%; margin-top: 0.625rem; font-weight: 500; } */
.footer h6 { font-size: 0.75rem; line-height: 100%; margin-top: 0.625rem; font-weight: 300; letter-spacing: 0; }


.top_bt { width: 5rem; height: 5rem; background-color: #e6e6e6; z-index: 99; border-radius: 100%; position: absolute; right: 5%; bottom: 13%; display: flex; justify-content: center; align-items: center; cursor: pointer; transition: 0.5s; display: none; }

/* body.main .top_bt { opacity: 0; }
body.main .top_bt.active { opacity: 1; } */

.footer.end:after { display: block; }


/*body.main .footer { width: 100%; }*/

/*서브*/

.sub_top01 { position: relative; left: 0; top: 0; width: 89.5833%; margin: auto; height: 14.778rem; z-index: 99; margin-top: 6.944rem; overflow: hidden; }
.sub_top02 { position: relative; left: 0; top: 0; width: 89.5833%; margin: auto; height: 14.778rem; z-index: 99; margin-top: 6.944rem; overflow: hidden; }
.sub_top03 { position: relative; left: 0; top: 0; width: 89.5833%; margin: auto; height: 14.778rem; z-index: 99; margin-top: 6.944rem; overflow: hidden; }
.sub_top04 { position: relative; left: 0; top: 0; width: 89.5833%; margin: auto; height: 14.778rem; z-index: 99; margin-top: 6.944rem; overflow: hidden; }
.sub_top05 { position: relative; left: 0; top: 0; width: 89.5833%; margin: auto; height: 14.778rem; z-index: 99; margin-top: 6.944rem; overflow: hidden; }
.sub_top06 { position: relative; left: 0; top: 0; width: 89.5833%; margin: auto; height: 14.778rem; z-index: 99; margin-top: 6.944rem; overflow: hidden; }
/*.sub_top01:after { content:''; width: 100%; height: 100%; position: absolute; left: 0; top: 0; background: url(../img/sub_top.png) center top no-repeat; background-size: cover; z-index: 2; }*/
.sub_top_img { width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 1; }

/* .sub_top01 .sub_top_img { background: url(../img/sub_top01.jpg) center top 10% no-repeat; background-size: cover; animation: sub_top_img 2.5s 0s both; }
.sub_top02 .sub_top_img { background: url(../img/sub_top02.jpg) center top 10% no-repeat; background-size: cover; animation: sub_top_img 2.5s 0s both; }
.sub_top03 .sub_top_img { background: url(../img/sub_top03.jpg) center top 10% no-repeat; background-size: cover; animation: sub_top_img 2.5s 0s both; }
.sub_top04 .sub_top_img { background: url(../img/sub_top04.jpg) center top 10% no-repeat; background-size: cover; animation: sub_top_img 2.5s 0s both; }
.sub_top05 .sub_top_img { background: url(../img/sub_top05.jpg) center top 10% no-repeat; background-size: cover; animation: sub_top_img 2.5s 0s both; }
.sub_top06 .sub_top_img { background: url(../img/sub_top06.jpg) center top 10% no-repeat; background-size: cover; animation: sub_top_img 2.5s 0s both; } */

.sub_top_txt { width: 100%; max-width: 1100px; position: absolute; left: 0; right: 0; top: 48%; margin: auto; z-index: 9; color: #000; text-align: center; animation: sub_top_txt 1.0s 0.2s both; }
.sub_top_txt h2 { font-size: 1.375rem; line-height: 100%; font-weight: 400; letter-spacing: 2.5rem; margin-left: 2.5rem; text-transform: uppercase; animation: sub_top_txt2 1.2s 1.2s both; }


@keyframes sub_img {
    from { background: url(../img/sub_top.jpg) center bottom no-repeat; background-size: cover; }
    to{ }
}
@keyframes sub_top_img {
    from { transform: scale(1.2); }
    to{ }
}
@keyframes sub_top_txt {
    from { opacity: 0; }
    to{ }
}
@keyframes sub_top_txt2 {
    from { letter-spacing: 0.3rem; }
    to{ }
}

#snb_wrap { width: 1100px; height: 40px; position:relative; margin: auto; z-index: 90; border-bottom: 1px solid #000; }
#snb { width: 480px; height: 40px; position: absolute; right: 0; top: 0; display: flex; justify-content: flex-end; align-items: center; }
#snb:after {content:""; display:block; clear:both; }
#snb > li { width: 200px; position:relative; height: 40px; text-align: right; box-sizing: border-box; color: #161616; }
/* #snb > li > a:after { content:''; position: absolute; width: 1px; height: 20px; background-color: #adadad; right: 0; top: 0; bottom: 0; margin: auto; } */
#snb > li > a:after { content:''; position: absolute; width: 7px; height: 7px; border-bottom: 1px solid #666666; border-right: 1px solid #666666; right: 0; top: 0; bottom: 0; margin: auto; transform: rotate(-45deg); }
#snb > li:first-child { width: 60px; }
#snb > li:first-child img { position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; }
#snb > li:nth-child(3) { width: 220px; width: auto; }
#snb > li:nth-child(3) > a:after { display: none; }
#snb > li:first-child + li + li > a { margin-top:1px; }
/*#snb > li:first-child + li + li { border-bottom: 1px solid #e8e8e8; }*/
#snb > li:first-child + .ov {margin-left:0;}
#snb > li:nth-child(2):after { content:''; width: 8px; height: 8px; border-top: 1px solid #666; border-right: 1px solid #666; transform: rotate(45deg); position: absolute; right: 18px; top: 29px; transition:0.3s; }
#snb > li:nth-child(3):after { content:''; width: 8px; height: 8px; border-top: 1px solid #666; border-right: 1px solid #666; transform: rotate(45deg); position: absolute; right: 18px; top: 29px; transition:0.3s; display: none; }
#snb .ov {margin-left:-1px;}
#snb .ov > a { display: block; height: 40px; line-height: 40px; padding: 0 15px; font-size: 14px; min-width: 0.160px; font-weight: 500; }

#snb > li:nth-child(2):hover:after { transform: rotate(135deg); top: 27px; }
#snb > li:nth-child(3):hover:after { transform: rotate(135deg); top: 27px; }

#snb > li:nth-child(2) { display: none; }

#snb .ov ul {position:absolute;left:0;top:100%;min-width:100%;background:#fff; display:none; }
#snb .ov ul li { border:1px solid #c2c2c2;margin-top:-1px; font-weight: 500; }
#snb .ov ul li:first-child {margin-top:0;}
#snb .ov ul li a { display:block;font-size:11.5px; color: #000; padding: 11px 15px; white-space:nowrap; letter-spacing: 0; }
#snb .ov:hover ul {display:block;}
#snb .ov ul li a:hover { background: #ebebeb; color: #000; }

#snb .ov a { text-transform: uppercase; }
/*#snb .ov:last-child a { text-transform: uppercase; }*/

body.full #sub_container { width: 100%; }
#sub_container { width: 90%; position: relative; left: 50%; transform: translateX(-50%); overflow: hidden; background-color: #fff; text-align: center; }
#sub_box { position: relative; width: 100%; margin: auto; text-align: center; padding-bottom: 10.625rem; padding-top: 0px; box-sizing: border-box; margin-top: 13.75rem; }
#sub_tit { width: 100%; margin-top: 0; overflow: hidden; text-align: center; }
#sub_tit h2 { font-size: 3.125rem; color: #000; font-weight: 700; line-height: 100%; letter-spacing: -1px; text-transform: uppercase; }
.sub_line { width: 1px; height: 2.375rem; background-color: #404040; margin: auto; margin-top: 2.1875rem; display: none; }
#sub_tit h5 { font-size: 0.875rem; color: #858585; font-weight: 400; margin-top: 1rem; }
#sub_tit h5 b { color: #222; }
#sub_tit h5 div { display: inline-block; color: #056b5c; }
#sub_tit h5 span { font-size: 0.8125rem; font-family: 'Futura Std'; font-weight: 700; }
.sub_page { margin:0 auto; margin-top: 3.125rem; position: relative; max-width:1100px; left:0; right:0;}

/* body.full #sub_container { width: 100%; }
#sub_container { width: 90%; position: relative; left: 50%; transform: translateX(-50%); overflow: hidden; text-align: center; margin-top: 10.625rem; z-index: 9; }
#sub_box { position: relative; width: 100%; margin: auto; text-align: center; padding-bottom: 10.625rem; padding-top: 0px; box-sizing: border-box; margin-top: 5rem; }
#sub_tit { width: 100%; max-width: 1100px; margin: auto; margin-top: 0; overflow: hidden; text-align: center; text-align: left; }
#sub_tit h2 { font-family: 'define'; font-size: 51px; color: #231815; font-weight: 700; line-height: 100%; letter-spacing: -1px; text-transform: uppercase; padding-bottom: 0.25rem; }
.sub_line { width: 1px; height: 2.375rem; background-color: #404040; margin: auto; margin-top: 2.1875rem; }
#sub_tit h5 { font-size: 0.875rem; color: #858585; font-weight: 400; margin-top: 1rem; }
#sub_tit h5 b { color: #222; }
#sub_tit h5 div { display: inline-block; color: #056b5c; }
#sub_tit h5 span { font-size: 0.8125rem; font-family: 'Futura Std'; font-weight: 700; }
.sub_page { margin:0 auto; margin-top: 3.125rem; position: relative; max-width:1100px; left:0; right:0;} */

.sub_ori { width: 100%; max-width: 1100px; margin: auto; background-color: #f3f3f3; text-align: left; padding: 1.5625rem 1.875rem; box-sizing: border-box; display: flex; justify-content: flex-start; align-items: center; margin: 0 auto 6.25rem; }
.sub_ori>div { width: 3.4375rem; height: 3.4375rem; min-width: 3.4375rem; border-radius: 100%; background: #010e4c url(../sub/ori.png) center no-repeat; margin-right: 1.375rem; }
/* .sub_ori ul {  } */
.sub_ori ul li { font-size: 0.8125rem; line-height: 155%; color: #383838; font-weight: 400; letter-spacing: -0.5px; position: relative; font-weight: 500; }
.sub_ori ul li:before { content:'·'; position: absolute; left: -0.375rem; margin-right: 0.125rem; }

.sub_ori ul.ori2 li { margin-left: 20px; }
.sub_ori ul.ori2 li:first-child { margin-left: 0; font-size: 14px; margin-bottom: 3px; }
.sub_ori ul.ori2 li:first-child:before { display: none; }

.sub_tab_bt { width: 100%; margin-bottom: 20px; }
.sub_tab_bt ul { width: 100%; display: flex; justify-content: space-between; align-items: center; }
.sub_tab_bt ul li { width: 100%; margin-right: 1%; font-size: 18px; line-height: 60px; border: 1px solid #ccc; box-sizing: border-box; }
.sub_tab_bt ul li a { width: 100%; height: 100%; display: block; }
.sub_tab_bt ul li:last-child { margin-right: 0; }
.sub_tab_bt ul li.active { background-color: #000; color: #fff; border: 1px solid #000; }


/**/

.sub_cy_wrap { width: 100%; max-width: 1100px; margin: auto; height: auto; position: relative; padding-bottom: 80px; }
.sub_cy_wrap img { width: 100%; max-width: 1100px; }
.sub_cy_wrap img.half { width: 50%; float: left; }

.sub_page.img { width: 100%; max-width: 1100px; margin: auto; margin-top: 3.125rem; height: auto; position: relative; }
.sub_page.img img { width: 100%; max-width: 1100px; }
.sub_img { margin-bottom: 100px; }
.sub_page.img img.half { width: 50%; float: left; }


ul.tabs2 { width: 100%; display: flex; justify-content: space-between; margin-bottom: 2.188rem; }
ul.tabs2.two { flex-wrap: wrap; }
ul.tabs2 li { width: 100%; color: #222; margin-left: 1%; text-align: center; cursor: pointer; font-size: 15px; height: 45px; line-height: 42px; border: 1px solid #e9eaec; font-weight: 400; background: #e9eaec; box-sizing: border-box; }
ul.tabs2 li a { width: 100%; height: 100%; display: block; }
ul.tabs2 li:nth-child(1) { margin-left: 0; }

ul.tabs2 li.selected, ul.tabs li.selected:hover { color: #fff; background: #4f372b; border: 1px solid #4f372b; }	
ul.tabs2 li.selected a, ul.tabs li.selected a:hover { color: #fff; }
ul.tabs2 li.active { color:#fff; background: #4f372b; border: 1px solid #4f372b; }

#container2 { width: 100%; max-width: 1100px; margin: auto; }

.sub_lounge>img { margin-bottom: 90px; }
.sub_lounge .tabs2 { margin-bottom: 60px; }

.img_ori { position: absolute; right: 1rem; bottom: 0.875rem; color: #fff; font-size: 0.925rem; line-height: 100%; text-shadow: 0 0 0.5rem rgba(0, 0, 0, 1),0 0 0.5rem rgba(0, 0, 0, 1); letter-spacing: 0.2px; font-weight: 300; }

/**/

.sub_pr_wrap { width: 100%; max-width: 1100px; position: relative; }
.sub_pr_top { width: 100%; }
.sub_pr_top>a { width: 100%; display: flex; justify-content: flex-start; align-items: center; box-sizing: border-box; border-bottom: 1px solid #d0c4bf; text-align: left; padding-bottom: 4.125rem; }
.sub_pr_top>a>div { text-align: left; margin-left: 3rem; }
.sub_pr_news { width: 100%; padding: 60px 0 70px; box-sizing: border-box; border-bottom: 1px solid #d0c4bf; text-align: left; }

.sub_pr_top h5 { width: 50%; max-width: 125px; font-size: 13px; line-height: 100%; color: #a2938e; position: relative; font-weight: 500; }
/* .sub_pr_top h5:after { content:''; width: 100%; height: 1px; background-color: #d0c4bf; position: absolute; left: 0; bottom: -20px; } */
.sub_pr_top h2 { font-size: 1.5rem; line-height: 166%; font-weight: 600; margin-top: 2.5rem; }
.sub_pr_top h2 span { position: relative; }
.sub_pr_top h2 span:after { content:''; width: 0%; height: 1px; background-color: #643a2b; position: absolute; left: 0; bottom: 0; transition: 0.4s; display: none; }
.sub_pr_top p { font-size: 0.9375rem; line-height: 200%; opacity: 0.7; margin-top: 2.375rem; height: 200%; text-overflow: ellipsis; overflow: hidden; font-weight: 500; 
    /* display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical;  */
}
.sub_pr_top p span { position: relative; }
.sub_pr_top p span:after { content:''; width: 0%; height: 1px; background-color: #b19c95; position: absolute; left: 0; bottom: -1px; transition: 0.4s; }
.sub_pr_top h6 { font-size: 12px; line-height: 100%; color: #c77b63; margin-top: 4.375rem; font-weight: 500; }

.sub_pr_tit { margin-bottom: 3.125rem; }
.sub_pr_tit h2 { font-size: 28px; line-height: 157%; font-weight: 600; margin-top: 0; }
.sub_pr_tit h6 { display: inline-block; color: #7d7d7d; margin-top: 2.5rem; position: relative; }
.sub_pr_tit h6:after { content:''; width: 100%; height: 1px; background-color: #7d7d7d; position: absolute; left: 0; bottom: -0.5rem; opacity: 0.7; }

.sub_pr_wrap.con .sub_pr_top p { margin-top: 0; }

.sub_pr_bt { width: 230px; height: 55px; margin: auto; margin-top: 130px; font-size: 16px; line-height: 53px; border: 1px solid #000; text-align: center; font-weight: 500; }
.sub_pr_bt>a { width: 100%; height: 100%; display: block; }

.sub_pr_top>a:hover h2 span:after { width: 100%; }
.sub_pr_top>a:hover p span:after { width: 100%; }

.sub_pr_bottom { width: 100%; padding: 60px 0 140px; border-bottom: 1px solid #d0c4bf; display: flex; justify-content: space-between; align-items: center; text-align: left; gap: 3.25rem 5%; flex-wrap:  wrap; }
.sub_pr_thumb { display: block; position: relative; }
/* .sub_pr_thumb:after { content:''; width: 100%; height: 100%; position: absolute; background-color: #000; opacity: 0.7; left: 0; top: 0; transition: 0.5s; opacity: 0; } */
.sub_pr_thumb>h6 { font-size: 10px; color: #fff; position: absolute; display: inline-block; right: 25px; top: 14px; z-index: 9; letter-spacing: 0; padding-right: 12px; opacity: 0; transition: 0.5s; }
.sub_pr_thumb>h6 span { position: relative; }
.sub_pr_thumb>h6 span:before { content:''; width: 100%; height: 1px; background-color: #fff; position: absolute; left: 0; bottom: -1px; }
.sub_pr_thumb>h6:after { content:''; position: absolute; right: 0; top: 2px; bottom: 0; margin: auto; width: 5px; height: 5px; border-bottom: 1px solid #fff; border-right: 1px solid #fff; transform: rotate(-45deg); }

.sub_pr_content { width: 30%; border: 1px solid #ccc; box-sizing: border-box; position: relative; }
.sub_pr_content>a { width: 100%; height: 100%; display: block; padding: 2.625rem 1.875rem 2.5rem; }
.sub_pr_content>a>h3 { font-size: 1rem; line-height: 150%; font-weight: 500; }
.sub_pr_content>a>p { font-size: 0.8125rem; line-height: 153%; opacity: 0.7; margin-top: 1.5rem; font-weight: 500; }
.sub_pr_content>a>h6 { font-size: 0.75rem; line-height: 100%; color: #c77b63; font-weight: 500; margin-top: 3rem; }
.sub_pr_content>a>h3 span { position: relative; }
.sub_pr_content>a>h3 span:after { content:''; width: 0%; height: 1px; background-color: #643a2b; position: absolute; left: 0; bottom: 0; transition: 0.4s; }

.sub_pr_content:after { content:''; width: 0; height: 1px; background-color: #000; position: absolute; left: -1px; top: -1px; transition: 0.4s; }
.sub_pr_content:before { content:''; width: 0; height: 1px; background-color: #000; position: absolute; right: -1px; bottom: -1px; transition: 0.4s; }
.sub_pr_content>a:after { content:''; width: 1px; height: 0; background-color: #000; position: absolute; right: -1px; top: -1px; transition: 0.4s; }
.sub_pr_content>a:before { content:''; width: 1px; height: 0; background-color: #000; position: absolute; left: -1px; bottom: -1px; transition: 0.4s; }

.sub_pr_content:hover:after { width: calc(100% + 2px); }
.sub_pr_content:hover:before { width: calc(100% + 2px); }
.sub_pr_content>a:hover:after { height: calc(100% + 2px); }
.sub_pr_content>a:hover:before { height: calc(100% + 2px); }

.sub_pr_content:hover .sub_pr_thumb:after { opacity: 0.65; }
.sub_pr_content:hover .sub_pr_thumb>h6 { opacity: 1; right: 20px; }
.sub_pr_content:hover h3 span:after { width: 100%; }

/*  */

.sub_over_wrap { width: 100%; max-width: 1100px; margin: auto; height: auto; position: relative; text-align: left; }

.sub_over_top { width: 100%; margin: auto; position: relative; display: flex; justify-content: space-between; align-items: flex-end; }

.swiper_planning { width: 84%; margin: 0; padding: 0; }
.swiper_planning .sub_planning_img { width: 100%; height: 34.125rem; }
.sub_planning_img.img01 { background: url(../sub/planning01.jpg) center no-repeat; background-size: cover; }
.sub_planning_img.img02 { background: url(../sub/planning02.jpg) center no-repeat; background-size: cover; }
.sub_planning_img.img03 { background: url(../sub/planning03.jpg) center no-repeat; background-size: cover; }

.swiper_planning_thumb { width: 14%; margin: 0; padding: 0; }

.swiper_planning_thumb .swiper-wrapper { display: flex; justify-content: space-between; flex-direction: column; }
.swiper_planning_thumb .swiper-slide { height: 100%; height: 5.875rem; cursor: pointer; border: none; overflow: hidden; margin-top: 0.625rem; position: relative; }
.swiper_planning_thumb .sub_planning_img { width: 100%; height: 100%; filter: grayscale(1); }
.swiper_planning_thumb .swiper-slide-thumb-active .sub_planning_img { opacity: 1; filter: grayscale(0); }
.swiper_planning_thumb .swiper-slide-thumb-active:after { content:''; width: 100%; height: 100%; position: absolute; left: 0; top: 0; border: 3px solid #c9c9c9; box-sizing: border-box; }

.swiper-button-next-planning { position: absolute; width: 4.6875rem; height: 2.9375rem; right: -12%; top: 0%; bottom: 0; margin: auto; padding: 0; outline: none; z-index: 99; cursor: pointer; }
.swiper-button-prev-planning { position: absolute; width: 4.6875rem; height: 2.9375rem; left: -12%; top: 0%; bottom: 0; margin: auto; padding: 0; outline: none; z-index: 99; cursor: pointer; }

.sub_over_bottom { width: 100%; margin: auto; position: relative; margin-top: 4.5rem; }
.sub_over_txt_box { margin-top: 35px; display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; margin-bottom: 50px; }
.sub_over_txt_box>div { width: 31%; margin-bottom: 50px; }
.sub_over_txt_box>div h4 { font-size: 1.25rem; line-height: 100%; font-weight: 600; color: #231815; border-bottom: 1px solid #383838; padding-bottom: 18px; }
.sub_over_txt_box>div p { font-size: 0.875rem; line-height: 170%; height: 3rem; margin-top: 18px; opacity: 0.7; font-weight: 500; }


