@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Marck+Script'); /* font-family: 'Marck Script', cursive; */
@import url('https://fonts.googleapis.com/css?family=Cagliostro'); /* font-family: 'Cagliostro', sans-serif; */
@import url('https://fonts.googleapis.com/css?family=Josefin+Sans:400,700'); /* font-family: 'Josefin Sans', sans-serif; */
@import url('https://fonts.googleapis.com/css?family=Barlow:400,600'); /* font-family: 'Barlow', sans-serif; */
@import url('https://fonts.googleapis.com/css?family=Courgette'); /* font-family: 'Courgette', cursive; */
@import url('https://fonts.googleapis.com/css?family=Chonburi'); /* font-family: 'Chonburi', cursive; */
@import url('https://fonts.googleapis.com/css?family=Cormorant+SC:300,400,500,600'); /* font-family: 'Cormorant SC', serif; */

/* subLayout */
/*html { overflow-x:hidden; }*/
img { max-width: 100%;}

#contents {position:relative;  opacity:0; filter: alpha(opacity=0;); z-index:5;}
#contents:after, #contents_layer:after {content: "";display:block; clear:both;}
#contents_layer {position:relative; opacity:0; filter: alpha(opacity=0;); z-index:5; }
.subCon { position:relative; }
.subCon:after {content:"";display:block;clear:both;}


.subArea { position:relative; padding-bottom:1px; z-index:2;}
.topArea, .topArea02 { position:relative; overflow:hidden; z-index:1;}
.subTypo { position:absolute; right:0; bottom:0; color:#fff; text-align:right;  z-index:3;}
.subTypo .subTypo01 { font-size:1em; line-height:1.8em;  padding-right:0.3em; }
.subTypo .subTypo02 {font-size:5.5vw; line-height:.71em; opacity:0.5; filter: alpha(opacity=50;);}
.subTypo_02 { left:auto; right:10%;}

.subCon01 { width:100%; margin:0 auto; padding: 0;}
.subCon02 { width:96%; max-width:1520px; margin:0 auto;}
.subCon03 { width:96%; max-width:1440px; margin:0 auto;}

.subCon.topArea .lightslider li img {
    filter: brightness(0.7);
}
/* toparea 타이틀 */
.top-title {
    position: absolute;
    top: 50%; left: 50%;
    z-index: 2;
    transform: translate(-50%, -50%);
    font-family: 'pret-sb';
    font-size: 57px;
    letter-spacing: 0.05em;
    line-height: 1.5;
    color: #fff;
}


/* toparea에 포함된 탭 메뉴*/
.toparea-menu {
    position: absolute;
    z-index: 1;
    bottom: 35px;
    left: 0;
    width: 100%;
    display: flex;
    justify-content: center;
    gap: 25px;
}
.toparea-menu li {
    width: 170px;
    text-align: center;
    border: 1px solid #fff;
    border-radius: 50px;
}
.toparea-menu li.this, .toparea-menu li:hover {
    border: 1px solid transparent;
    background: var(--main-green);
}
.toparea-menu li a {
    display: block;
    height: 100%;
    padding: 15px 0;
    color: #fff;
    font-size: 27px;
    letter-spacing: 0.05em;
}
@media(max-width:1024px){
    .toparea-menu {
        bottom: 28px;
        gap: 15px;
    }
    .toparea-menu li {
        width: 92px;
    }
    .toparea-menu li a {
        font-size: 15px;
    }
}
@media(max-width:768px){
    .top-title {
        font-size: 31px;
        width: 100%;
        text-align: center;
    }
}


.subNav { padding:1.2% 1%; text-align:right; border-bottom:1px solid #e5e5e5; }
.subNav ul li { display:inline-block; margin:0 5px; font-size:1.2em; line-height:1.5em; color:#000; vertical-align:middle; }
.subNav ul li.line {opacity:0.3;}
.subNav ul li.block768 { margin:0 0 3px!important;}
.subNav li a { font-size:1.07em; line-height:1.8em; color:#000; vertical-align:middle; -webkit-transition: all 0.3s ease-in-out; -moz-transition: all 0.3s ease-in-out;
-ms-transition: all 0.3s ease-in-out; -o-transition: all 0.3s ease-in-out; transition: all 0.3s ease-in-out; }
.subNav li a:hover, .subNav li a:focus { text-decoration:underline;}
.subNav li.this a, .tourNav li a.this { font-family: 'pret-sb'; color: var(--main-green);}
.subTitle { margin-bottom:5%; font-size:1em; font-weight:400; text-align:center;}
.subTitle .title01 { position:relative; display:inline-block; font-family: "source-han-serif-korean", 'Jeju Myeongjo',serif; font-size:1.4em; line-height:1.5em; font-weight:200;  letter-spacing:0.05em; padding-left:0.05em; color:#81786f; text-transform:uppercase;}
.subTitle .title01:after { content:"";display:block; width:20px; height:1px; margin:1.2em auto; background:#81786f;}
.subTitle .title02 { display:block; font-family: "source-han-serif-korean", 'Jeju Myeongjo',serif;  font-size:2.4em; line-height:1.2em;  color:#553f3f; text-transform:uppercase; }
.room .subTitle .title02 span { font-family:'Noto Sans KR', serif; font-size:0.85em; font-weight:300; letter-spacing:0em; }
.subTitle .title03 { display:block; font-family: 'Hi Melody', 'Gaegu', cursive; font-size:2.0em; line-height:1.8em; color:#333; margin-top:0.4em; opacity:0.5; filter: alpha(opacity=50;); }

.penTypo { padding:6% 0; text-align:center; font-family:'GothamThin'; font-size:10px; line-height:1.5em; color:#000; text-transform:uppercase; letter-spacing:0.1em; }

@media  (max-width: 1480px){
}


@media  (max-width: 1280px){


}




@media  (max-width: 1024px){

.subTypo {}
.subTypo .subTypo01 { font-size:0.8em; }
.subTypo .subTypo02 { font-size:8.5vw; }
.subNav { padding:2%; margin-bottom:5%; text-align:center;}
.subNav ul li {  margin:0 3px; font-size:1em; }
.subTitle { margin-bottom:8%;}
.subTitle .title01 {font-size:1.3em;}
.subTitle .title01:after { margin:0.8em auto;}
.subTitle .title02 { font-size:1.8em;}
.subTitle .title03 { font-size:1.6em;}

}


@media  (max-width: 768px){
/* .subCon01 { padding: 0 20px;} */
.subTitle .title01 {font-size:1.1em; letter-spacing:-0.05em;}
.subTitle .title01:after { width:15px; margin:0.8em auto;}
.subTitle .title02 { font-size:1.6em;}
.subTitle .title03 { font-size:1.6em; margin-top:0;}
}


@media  (max-width: 560px){
.subNav { padding:2% 1%;}
.subNav ul li { margin:0 0;letter-spacing:0em;  }
.subNav li.line { margin:0 -2px;}
.penTypo { font-size:8px;}

.subTitle .title01 {font-size:1em; letter-spacing:-0.05em;}
.subTitle .title01:after { width:12px; margin:0.8em auto;}
.subTitle .title02 { font-size:1.4em;}
.subTitle .title03 { font-size:1.35em; margin-top:0;}
}

@media  (max-width: 480px){
.subTypo .subTypo02 { font-size:10.5vw; }


}



@media  (max-width: 380px){

}

.cont-inner {
    margin: 0 auto;
    max-width: 1450px;
}

/* 인사말 */
.about-first-wrap {
    position: relative;
}
.first-bg01, .first-bg02 {
    display: block;
    position: absolute;
}
.first-bg01 {
    top: 0;
    left: 0;
    max-width: 406px;
    width: 20vw;
}
.first-bg02 {
    bottom: 0;
    right: 0;
    max-width: 436px;
    width: 21vw;
}
.about-first {
    margin: 70px auto 0;
    max-width: 768px;
    height: 90vh;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    text-align: center;

}
.about-first h2 {
    margin-bottom: 50px;
}
.about-first p {
    margin-bottom: 40px;
}

@media(max-width:1200px){
    .first-bg01, .first-bg02 { display: none;}
    .about-first { 
        max-width: 74.5vw;
        height: auto;
    }
}

@media(max-width:768px){
    .about-first { justify-content: flex-start;}
    .about-cont .common-title { 
        margin-bottom: 16px;
        text-align: center;
    }
    
}




.about-cont .sec01 {
    display: flex;
    align-items: center;
    gap: 132px; 
    padding: 100px 0;
}

.about-cont .sec01 .imgbox {
   
}

.about-cont .sec01 .imgbox img {
    width: 28.125vw;
    max-width: 540px;
    height: auto;
    display: block;
}

.about-cont .common-title {
   text-align: left;
}
.coach-cont {
    display: flex;
    gap: 21px;
    margin-top: 30px;
}
/* 강사 약력 제목 */
.coach-cont .small-title {
    width: 126px;
    height: 45px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--main-green);
    color: #fff;
    border-radius: 50px;
    font-size: 25px;
    font-family: 'pret-b';
}
/* 약력 리스트 */
.coach-cont li {
    font-size: 18px;
    line-height: 2.2;
    margin-left: 3em;
    padding-right: 2em;
}
.coach-cont li::before {
    content: 'ㆍ ';
    margin-left: -1.2em;

}
@media (max-width:1200px){
    .about-cont .sec01 {
        gap: 50px;
    }
    .about-cont .sec01 .imgbox img {
        width: 38vw;
        max-width: 540px;
    }
    /* 강사 약력 제목 */
    .coach-cont {
        flex-direction: column;
    }
    .coach-cont .small-title {
        width: 126px;
        height: 45px;
        font-size: 22px;
    }
    /* 약력 리스트 */
    .coach-cont li {
        font-size: 14px;
    }
}

@media(max-width:768px) {
    .about-cont .sec01 {
        flex-direction: column;
        padding: 100px 0;
    }
    .about-cont .sec01 .imgbox img {
        margin: 0 auto;
        width: 86vw;
    }
    .about-cont .sec01 .common-title {
        text-align: center;
    }
    .about-cont .common-title {
        text-align: center;
    }
    .coach-cont {
        gap: 26px;
        align-items: center;
        margin-top: 18px;
    }
}


/* 갤러리 사진모음 */
.gallery .top {
    position: relative;
    display: flex;
    justify-content: center;
}
.gallery .gal-text {
    position: absolute;
    bottom: 50px;
    right: 70px;
    color: #fff;
    font-size: 20px;
    line-height: 1.9;
}
.gallery .center {
    display: flex;
    justify-content: center;
    gap: 2vw;
    padding: 0 13.23vw;
    margin-top: 1.8vw;
}
.gallery .center .left {
    display: flex;
    flex-direction: column;
    gap: 2vw;
    width: 31.25vw;
    max-width: 600px;
}
.gallery .center .right {
    width: 40.1vw;
    max-width: 770px;
}
.gallery .bottom {
    display: flex;
    justify-content: center;
    padding: 0 13.23vw;
    margin-top: 1.8vw;
}

@media (max-width:768px) {
    .gallery .gal-text {
        bottom: 22px;
        right: 22px;
        font-size: 14px;
        line-height: 1.7;
        text-align: right;
    }
    .gallery .center {
        flex-direction: column;
        padding: 0;
        gap: 3vw;
    }
    .gallery .center .left {
        flex-direction: row;
        width: 48.5vw;
        gap: 3vw;
    }
    .gallery .center .right {
        position: relative;
        width: 100vw;
    }
    .gallery .bottom {
        width: 100vw;
        padding: 0;
    }
}