@charset "utf-8";
/*기본 정의*/
body, header, div, a, span, p, h1, h2, h3, h5, h6, ul, li, img{
    margin: 0;
    padding: 0;
    line-height: 1.5em;
}
body{
    font-family: 'Noto Sans KR', sans-serif;
}
body,p,h1,h2,h3,h4,h5,h6,ul,ol,li,dl,dt,dd,table,th,td,form,fieldset,legend,input,textarea,button{margin:0;padding:0}
::selection { background: #5d336e;; color: #fff; text-shadow: none; }
a{text-decoration: none; color: #000;}
a:link {text-decoration: none;}
a:visited {text-decoration: none;}
a:hover {text-decoration: none;}
h2{font-size: 3rem}
h3{font-size: 2.5rem}
h5{font-size: 1.5rem}
h6{font-size: 1.25rem}

.headline--title{
    padding-top: 30px;
    text-align: center;
    font-weight: 300;
}
.margin--first{
    margin: 0 !important;
}
.about, .banner, .business, .range-effect, .news, footer{
    position: relative;
    z-index: 1;
}


/*GNB 영역*/
header{
    width: 100%;
    height: 100px;
    min-width: 1180px;
    display: block;
    border-bottom: 1px solid #fff;
    position: absolute;
    z-index: 10;
    transition: all 0.2s;
}
header.fix{
    position: fixed;
    z-index: 100;
    width: 100%;
    height: 100px;
    min-width: 1180px;
    background: #fff;
    border-bottom: 1px solid #bbb;
    box-shadow: 0 2px 8px 4px rgba(0,0,0,0.1);
    color: #000;
}

.header-wrap{
    position: absolute;
    width: 1180px;
    height: 100px;
    left: 50%;
    top: 0;
    margin-left: -590px;
    z-index: 100;
}
.header--logo > a{
    width: 177px;
    height: 63px;
    float: left;
    margin-top: 19px;
}
.header--logo img{
    width: 100%;
    height: auto;
}
.header--list{
    float: right;
    display: inline-block;
}
.header--list > li{
    float: left;
    font-weight: 400;
    font-size: 1rem;
    line-height: 100px;
    list-style: none;
    margin-right: 60px;
}
.header--list > li > a{
    color: #fff;
    transition: color 0.3s;
}
.fix  li  a{
    color: #555;
}
.header--list > li > a:hover{
    color: #600b63;
}
span {
    position: relative;
}
span::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background-color: #600b63;
    transform-origin: bottom right;
    transform: scaleX(0);
    transition: transform 0.5s ease;
}
span.menu-on::before{
    transform-origin: bottom left;
    transform: scaleX(1);
    height: 2px;
}

/*메인 영역*/
.main{
    width: 100%;
    height: 100vh;
    min-width: 1180px;
    min-height: 768px;
    position: relative;
    background-size: auto 100%;
}
.main{
    width: 100%;
    min-width: 1180px;
    height: 100vh;
    overflow: hidden;
}
.main--bg__dim{
    position: fixed;
    width: 100%;
    height: 100vh;
    background-color: #000;
    opacity: 0;
}
.main--bg > img{
    position: fixed;
    z-index: 0;
    width: 100%;
    min-width: 1180px;
    height: auto;
}
.main--bg.resizing > img{
    width: auto;
    height: 100%;
    right: 0;
}
.main--wrap{
    color: #fff;
    position: relative;
    padding-top: 100px;
    width: 800px;
    left: 50%;
    margin-left: -500px;
}
.main--line{
    width: 620px;
    height: 1px;
    position: absolute;
    z-index: 20;
    margin-left: 100px;
    transform-origin: left;
    -webkit-transform: rotate(90deg);
    -moz-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    -o-transform: rotate(90deg);
    transform: rotate(90deg);
}
.main--line__line{
    width: 100%;
    height: 1px;
    background-color: #ffffff;
    -webkit-transition: width 0.4s;
    -moz-transition: width 0.4s;
    -ms-transition: width 0.4s;
    -o-transition: width 0.4s;
    transition: width 0.3s;
    transition-delay: 0.2s;
}
.main--wrap.move .main--line__line{
    width: 0;
}
.main--line__arrow{
    width: 132px;
    height: 29px;
    background: url("../images/icon-arrow-main.png") no-repeat;
    position: absolute;
    right: 0;
    top: -14px;
    -webkit-transition: opacity 0.2s;
    -moz-transition: opacity 0.2s;
    -ms-transition: opacity 0.2s;
    -o-transition: opacity 0.2s;
    transition: opacity 0.2s;
    transition-delay: 0.48s;
}
.move .main--line__arrow{
    transition-delay: 0s;
}
.main--wrap.move .main--line__arrow{
    opacity: 0;
}
.main--line__arrow > span{
    margin-left: 24px;
    margin-top: 20px;
    display: inline-block;
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg);
}
.main--title{
    position: absolute;
    z-index: 20;
    top: 280px;
    margin-left: 200px;
}
.main--title > h3, .main--title > h1, .main--title > h5{
    -webkit-transition: opacity 0.3s;
    -moz-transition: opacity 0.3s;
    -ms-transition: opacity 0.3s;
    -o-transition: opacity 0.3s;
    transition: opacity 0.3s;
}
.main--title > h3{
    margin-bottom: 20px;
    font-weight: 400;
    line-height: 1;
    transition-delay: 0.1s;

}
.main--title > h1{
    font-size: 5rem;
    font-weight: 500;
    margin-bottom: 32px;
    line-height: 1;
    transition-delay: 0.15s;
}
.main--title > h5{
    font-weight: 300;
    line-height: 1.5em;
    transition-delay: 0.2s;
}
.main--wrap.move .main--title h3, .main--wrap.move .main--title h1, .main--wrap.move .main--title h5{
    opacity: 0
}


/*회사소개 영역*/
.about{
    width: 100%;
    height: 660px;
    min-width: 1180px;
    position: relative;
    overflow: hidden;
	background: url("../images/news-bg.png");
}
.about--wrap{
    width: 100%;
    height: 560px;
    overflow: hidden;
    margin: auto;
}
/*.about--white-box__top{
    width: 100%;
    height: 100px;
    background-color: #fff;
    position: relative;
    z-index: 5;
}*/
.about--white-box__mid{
    width: 1180px;
    margin: auto;
    height: 560px;
}
.about--text{
    width: 380px;
    height: 560px;
    padding: 140px 0 0 60px;
    background-color: #fff;
    position: absolute;
    z-index: 5;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
.about--white-box__bottom{
    width: 100%;
    height: 100px;
    background-color: #fff;
    position: relative;
    z-index: 5;
}
.about--box__dim > div{
    width: 1180px;
    height: 560px;
    position: absolute;
    z-index: 4;
}
.about--box__dim-left{
    background: -moz-linear-gradient(left,  rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.6) 90%, rgba(0,0,0,0.8) 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(left,  rgba(0,0,0,0.4) 0%,rgba(0,0,0,0.6) 90%,rgba(0,0,0,0.8) 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right,  rgba(0,0,0,0.4) 0%,rgba(0,0,0,0.6) 90%,rgba(0,0,0,0.8) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#66000000', endColorstr='#cc000000',GradientType=1 ); /* IE6-9 */
    margin-left: -1180px;
}
.about--box__dim-right{
    background: -moz-linear-gradient(left,  rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.6) 10%, rgba(0,0,0,0.4) 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(left,  rgba(0,0,0,0.8) 0%,rgba(0,0,0,0.6) 10%,rgba(0,0,0,0.4) 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right,  rgba(0,0,0,0.8) 0%,rgba(0,0,0,0.6) 10%,rgba(0,0,0,0.4) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#cc000000', endColorstr='#66000000',GradientType=1 ); /* IE6-9 */
    margin-left: 1180px;
}
.about--img__slider{
    width: 3540px;
    height: 560px;
    margin-left: -1180px;
}
.about--img__slider > div > img{
    width: 1180px;
    height: 560px;
}
.about--text > h3{
    color: #600b63;
    margin-bottom: 40px;
}
.about--text > h6{
    font-weight: 400;
}
.about--white-box__bottom{
    background-color: #000;
    width: 100%;
    height: 100px;
    position: relative;
}
/*배너 영역*/
.banner{
    width: 100%;
    min-width: 1180px;
    height: 300px;
    background: url("../images/img-banner.png") no-repeat;
    background-size: cover;
}
.banner--wrap{
    text-align: center;
    color: #fff;
    padding-top: 80px;
}
.banner--wrap > h3{
    margin-bottom: 16px;
}
.banner--wrap > h6{
    font-weight: 300;
}

/*사업안내 영역*/
.business{
    width: 100%;
    height: 720px;
    min-width: 1180px;
    background: url("../images/img-business-bc.png") center;
    display: inline-block;
}
.business--wrap{
    width: 1140px;
    height: 100%;
    margin: auto;
}
.headline--title{
    font-weight: 400;
    text-align: center;
    margin-bottom: 28px;
    color: #4a4a4a;
}
.business--list__list{
    width: 360px;
    height: 504px;
    display: inline-block;
    float: left;
    margin-left: 30px;
    background: #fff;
    -webkit-box-shadow: 0 15px 20px 0 rgba(0, 0, 0, 0.15);
    -moz-box-shadow:  0 15px 20px 0 rgba(0, 0, 0, 0.15);
    box-shadow:  0 15px 20px 0 rgba(0, 0, 0, 0.15);
    transition: all 0.3s cubic-bezier(.25,.8,.25,1);
}

.business--list__list:hover {
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
    margin-top: -8px;
    animation-name: depth;
    animation-duration: 0.25s;
    border-bottom: 8px solid #aaa;
    box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22);
}
@keyframes depth {
    0%   {margin-top: -2px; border-bottom: 2px solid #fff;}
    25%  {margin-top: -3px; border-bottom: 3px solid #eee;}
    50%  {margin-top: -4px; border-bottom: 4px solid #ccc;}
    100% {margin-top: -5px; border-bottom: 5px solid #aaa;}
}
.business--list__list:first-child{
    margin-left: 0;
}
.business--list__img{
    width: 100%;
    height: 324px;
}
.business--list__text{
    width: 100%;
    height: 180px;
    padding: 28px 48px 0 20px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
}
.business--list__text > h6{
    margin-bottom: 12px;
    font-weight: 400;
}
.business--list__text > p{
    font-size: 0.9rem;
}
.business--list__more{
    position: absolute;
    bottom: 20px;
    right: 28px;
}
.business--list__more:after{
    content: '';
    width: 15px;
    height: 5px;
    background: url("../images/icon-arrow-busi.png");
    display: inline-block;
    margin: 0 0 5px 6px;
}
/*분야 및 효능*/
.range-effect{
    width: 100%;
    height: 870px;
    background-color: #faf5f8;
    position: relative;
    display: inline-block;
    min-width: 1180px;
}
.range--wrap{
    width: 1020px;
    height: 396px;
    margin: auto;
}
.range--list{
    width: 280px;
    height: 260px;
    float: left;
    margin-left: 90px;
}
.range--list:first-child{
    margin-left: 0;
}
.range--list__img{
    width: 100px;
    height: 88px;
    margin: auto auto 8px;
}
.range--text__span{
    font-size: 1.125rem;
    font-weight: 400;
    text-align: center;
    display: block;
    margin-bottom: 16px;
}
.range--text__p{
    font-weight: 300;
}

.effect--wrap{
    width: 980px;
    /*height: 400px;*/
    background-color: #fff;
    -webkit-box-shadow: 0 10px 15px rgba(0, 0, 0, 0.15);
    -moz-box-shadow:  0 10px 15px rgba(0, 0, 0, 0.15);
    box-shadow:  0 10px 15px rgba(0, 0, 0, 0.15);
    position: absolute;
    /*bottom: -20px;*/
    left: 50%;
    margin-left: -510px;
    padding: 0 20px;
}
.effect--list{
    width: 280px;
    height: 80px;
    float: left;
    margin-left: 70px;
    margin-bottom: 48px;
}
.effect--list__img{
    float:left;
}
.effect--list__img{
    width: 60px;
    height: 60px;
    padding: 10px;
    margin-right: 20px;
}
.effect--text__span{
    font-size: 1.125rem;
    font-weight: 500;
}

/*공지 및 뉴스 영역*/
.news{
    width: 100%;
    min-width: 1180px;
    height: 1470px;
    background: url("../images/news-bg.png");
}
.news--wrap{
    width: 1020px;
    margin: auto;
    /*padding-top: 5px;*/
}
.news--title{
    width: 100%;
    height: 130px;
}
.news--title__a{
    float: right;
    display: inline-block;
}
.news--title__a:after{
    content: '';
    background: url("../images/icon-arrow-news.png") no-repeat;
    width: 8px;
    height: 15px;
    display: inline-block;
    margin: 0 8px -2px 6px;
}
.news--list__top, .news--list__bottom{
    width: 100%;
    height: 620px;
    margin-bottom: 30px;
}
.news--list{
    width: 320px;
    height: 620px;
    float: left;
    margin-left: 30px;
}
.news--list__img{
    width: 100%;
    height: 300px;
    overflow: hidden;
}
.news--list__img img{
    max-width: 100%;
    -webkit-transition: all 0.6s;
    -moz-transition: all 0.6s;
    -ms-transition: all 0.6s;
    -o-transition: all 0.6s;
    transition: all 0.6s;
}
.news--list:hover .news--list__img img{
    -webkit-transform: scale(1.1) rotate(0.02deg);
    -moz-transform: scale(1.1) rotate(0.02deg);
    -ms-transform: scale(1.1) rotate(0.02deg);
    -o-transform: scale(1.1) rotate(0.02deg);
    transform: scale(1.1) rotate(0.02deg);
}
.news--list__text{
    height: 260px;
    padding: 30px;
    background-color: #fff;
}
.news--list__textCut{
    height: 220px;
    overflow: hidden;
    position: relative;
}
.news--list__textCut:after{
    content: '';
    width: 100%;
    height: 48px;
    position: absolute;
    bottom: 0;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.02) 1%, white 80%, white 100%);
}
.news--list__textCut > h6{
    font-weight: 300;
}
.news--list__textCut > p{
    margin-top: 8px;
    color: #968c87;
}
.news--list__span{
    font-size: 0.75rem;
    color: #808080;
}
.news--list__p{
    color: #572f62;
    font-weight: 400;
}

/*footer 영역*/
footer{
    width: 100%;
    height: 200px;
    padding-top: 56px;
    background-color: #fff;
}
.footer--wrap{
    width: 1180px;
    height: 100%;
    margin: auto;
}
.footer__img{
    width: 200px;
    height: 71px;
    margin-top: 28px;
    float: left;
}
.footer--wrap__text{
    width: 800px;
    height: 140px;
    float: left;
    margin-left: 100px;
}
.footer--wrap__left , .footer--wrap__right{
    float: left;
    margin: 0;
}
.footer--wrap__left{
    width: 600px;
    height: 140px;
}
.footer--wrap__right{
    width: 200px;
    height: 140px;
}
.footer--text__list2{
    width: 200px;
}
.footer--text__title{
    float: left;
    font-weight: 500;
    color: #000;
    margin-bottom: 4px;
}
.footer--text__list1, .footer--text__list2 {
    float: left;
}
.footer--text__list1 > li, .footer--text__list2 > li{
    display: inline-block;
    list-style: none;
    font-size: 0.75rem;
    width: 280px;
}
.footer--text__list2 > li {
	line-height: 1.5rem;
}