@charset "utf-8";

main.scroll{
    padding-top: 0 !important;
}

.bg-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: relative;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  overflow: hidden;
}

#page1 h1 {
    font-size: 64px;
    color: #fff;
    font-weight: 700;
    margin-top: 150px;
}

#page1 h5 {
    display: table-cell;
    height: 170px;
    font-size: 20px;
    color: #fff;
    font-weight: 700;
    margin-top: 64px;
    vertical-align: middle;
}

@media screen and (max-width: 1025px) {
    #page1 h1 {
        font-size: 40px;
        margin-top: 80px;
    }
    
    #page1 h5 {
        display: table-cell;
        height: 170px;
        font-size: 20px;
        color: #fff;
        font-weight: 700;
        margin-top: 64px;
        vertical-align: middle;
    }
}

/* ===================================== */
/* 새로운 메인 css */
/* ===================================== */
/* banner-slide */
.banner-slide{
    width: 100%;
    height: 80px;
    background: #fff;
    border-top: 1px solid #EDEDED;
    position: relative;
}
.banner-slide .swiper-container{
    width: 100%;
    max-width: 1440px;
    height: 80px;
    background: #fff;
    margin: 0 auto;
    /*padding-left: 164px;*/
    padding: 0 10px 0 164px;
    overflow: hidden;
}
.banner-slide .swiper-wrapper{
    width: 100%;
    display: flex;
    align-items: center;
    background: #fff;
}
.banner-slide .swiper-slide{
    height: 45px;
    background: transparent;
}
.banner-slide .swiper-slide > a > img{
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.banner-slide .controller{
    position: relative;
    top: -80px;
    left: -164px;
    display: flex;
    align-items: center;
    width: 164px;
    height: 80px;
    z-index: 1;
    background: #fff;
}
.banner-slide .swiper-button-next,
.banner-slide .swiper-button-prev,
.banner-slide .pause,
.banner-slide .play{
    position: relative;
    width: 44px;
    height: 44px;
    border: 1px solid #EDEDED;
    border-radius: 50%;
    background: #fff;
    margin-top: 0;
    top: 0;
}
.banner-slide .swiper-button-prev{
    left: -34px;
}
.banner-slide .swiper-button-next{
    left: 110px;
}
.banner-slide .pause,
.banner-slide .play{left: -28px}

.banner-slide .swiper-button-prev::after,
.banner-slide .swiper-button-next::after{display: none}
.banner-slide .swiper-button-prev::before,
.banner-slide .swiper-button-next::before,
.banner-slide .pause::before,
.banner-slide .play::before{
    content: "";
    background: url("/static/original/images/banner-prev-btn.png");
    background-repeat: no-repeat !important;
    background-position: center center !important;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 24px;
    height: 24px;
}
.banner-slide .swiper-button-next::before{
    background: url("/static/original/images/banner-next-btn.png");
}
.banner-slide .pause::before{
    background: url("/static/original/images/banner-stop-btn.png");
    background-size: 80% 90%;
    margin-left: 1px;
}
.banner-slide .play::before{
    background: url("/static/original/images/banner-play-btn.png");
    background-size: 90% 90%;
    margin-left: 1px;
}
.banner-slide .play{display: none;}

/* mobile */
@media screen and (max-width: 767px) {
    #page1 h1 {
        font-size: 25px;
        margin-top: 80px;
    }
    #page1 h5 {
        display: table-cell;
        height: 170px;
        font-size: 15px;
        color: #fff;
        font-weight: 700;
        margin-top: 64px;
        vertical-align: middle;
    }
    .banner-slide .controller{width: 128px; left: -136px;}
    .banner-slide .swiper-container{padding-left: 136px;}
    .banner-slide .swiper-button-next,
    .banner-slide .swiper-button-prev,
    .banner-slide .pause,
    .banner-slide .play{
        width: 36px;
        height: 36px;
    }
    .banner-slide .swiper-button-prev{left: -26px;}
    .banner-slide .swiper-button-next{left: 90px;}
    .banner-slide .pause,
    .banner-slide .play{left: -22px}
}


/* page2 */
#page2{
    background: url("/static/original/images/bg-pattern-new.png") no-repeat;
    background-position: top center;
    background-size: cover;
    width: 100%;
}
#page2 .wrap{overflow: visible;}
#page2 .wrap > .flex-row{
    display: flex;
    align-items: flex-start;
    gap: 40px;
    padding-bottom:86px;
}
#page2 .wrap > .flex-row .left{
    width: 100%;
    max-width: 800px;
}
#page2 .wrap > .flex-row .right{flex: 1;}

#page2 .title-wrap h2.eng{
    font-family: GmarketSans700;
    font-size: 47px;
    color: #001B45;
}
#page2 .title-wrap h2.eng > strong{
    color: #4251D6;
}
#page2 .title-wrap h3{
    font-family: GmarketSans500;
    font-size: 32px;
    letter-spacing: -1.4px;
    color: #111;
    width: fit-content;
    padding: 10px 0 20px 0;
    margin: 0;
}

#page2 .title-wrap{
    position: relative; z-index: 0;
    padding-left: 150px; min-height: 124px;
}
#page2 .title-wrap img.doctor{
    position: absolute;
    top: -100px;
    left: -110px;
}
#page2 .title-wrap img.quotes{
    position: absolute;
    top: -30px;
    right: 24px;
    z-index: -1;
}

/* 데이터 공개 현황 */
#page2 .wrap > .flex-row .left .card-wrap{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 16px;
    row-gap: 13px;
    border: 1px solid transparent;
    border-radius: 15px;
    border-image: linear-gradient(102.71deg, #C7E4FF 0%, #E5D8FF 100%);
    background-origin: border-box;
    background-clip: content-box, border-box;
    background: linear-gradient(105.16deg, #DFF3FF 12.52%, #EAE9FF 100%);
    padding: 44px 46px 43px 46px;
    position: relative;
    z-index: 1;
    box-shadow: 15px 30px 40px 0 rgba(0, 41, 67, 0.1);
}
#page2 .wrap > .flex-row .left .card-wrap > .cards{
    background: #fff;
    height: 140px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 36px 28px 33px 32px;
}
#page2 .wrap > .flex-row .left .card-wrap > .cards:hover{
    animation: move 1s infinite alternate;
}
#page2 .left .cards p{
    font-family: GmarketSans500;
    font-size: 18px;
    letter-spacing: -0.6px;
    padding-bottom: 10px;
}
#page2 .left .cards span{
    font-font: Pretendard500;
    font-size: 18px;
}
#page2 .left .cards span strong{
    font-family: GmarketSans700;
    font-size: 32px;
    color: #4251D6;
}

/* 홍보 소식 */
#page2 .wrap > .flex-row .right .card-wrap{
    background: #fff;
    border-radius: 15px;
    border: 1px solid #EDEEF0;
    padding: 36px 44px 36px 38px;
    box-shadow: 15px 30px 40px 0 rgba(0, 41, 67, 0.1);
    width: 560px;
}
#page2 .right .title-wrap{
    padding: 0; display: flex; align-items: flex-end;
    justify-content: space-between;
}
#page2 .right .title-wrap button{
    font-family: GmarketSans500;
    font-size: 20px;
    color: #535e7b;
    line-height: 100%;
    padding: 30px 25px;
    background: transparent;
}
#page2 .right .title-wrap button:hover span,
#page2 .right .title-wrap button:focus span,
#page2 .right .title-wrap button:active span{
    color: #444;
}
#page2 .right .title-wrap button:focus{
    outline-offset: -1px;
}
#page2 .right .title-wrap button.active span{
    color: #6033BB;
    text-decoration: underline;
    text-underline-offset: 6px;
}
#page2 .right .title-wrap button.more{
    font-family: Pretendard200;
    font-size: 36px;
    line-height: 100%;
    color: #444;
    padding: 18px 25px 26px 25px;
}
#page2 .right .title-wrap button.more:hover{
    animation: spin 2s infinite linear;
    transition: transform 0.3s ease;
}
@keyframes move {
    0% {
        transform: translateY(0);
    }
    100% {
        transform: translateY(-5px);
    }
}
@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}
@keyframes move-right {
    0% {
        left: 4px;
        margin-left: 6px;
    }
    50% {
        left: 10px;
        margin-left: 8px;
    }
    100% {
        left: 4px;
        margin-left: 6px;
    }
}

/* 공지사항 */
.notice-latest{
    display: flex;
    align-items: center;
    gap: 30px;
    border-bottom: 1px solid #D3DCEC;
    padding-bottom: 17px;
    margin-bottom: 18px;
    min-height: 114px;
}
.notice-latest > .flex-col{
    width: calc(100% - 100px);
}
.card-notice .tit{
    font-family: Pretendard700;
    font-size: 21px;
    line-height: 140%;
    letter-spacing: -1px;
    color: #111;
    word-break: keep-all;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.card-notice .sub{
    font-family: Pretendard400;
    font-size: 16px;
    color: #444444;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    padding-top: 6px;
}
.card-notice .notice-list{
    max-height: 176px;
    overflow: hidden;
}
.card-notice .notice-list > li{
    /*width: 472px;*/
    width: calc(100% - 16px);
    line-height: 180%;
    display: flex;
    align-items: center;
    position: relative;
}
.card-notice .notice-list > li::before{
    content: 'ㆍ';
    color: #C7D3E2;
    font-size: 22px;
    position: relative;
    left: -8px;
}
.card-notice .notice-list > li a{
    font-family: Pretendard500;
    font-size: 17px;
    letter-spacing: -0.3px;
    color: #111111;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: fit-content;
    position: relative;
    left: -4px;
}
.card-notice .notice-list > li a:focus-visible{
    outline-offset: -1px;
}
.icon-new{
    width: 32px; height: 20px;
    position: relative;
}
.icon-new::before{
    content: "";
    width: 18px; height: 18px;
    background: url("/static/original/images/icon-new-circle.png") no-repeat center;
    background-size: contain;
    position: absolute;
}

/* 공개현황 & 홍보소식 : 반응형 레이아웃 */
@media screen and (max-width: 1322px) {
    #page2 .wrap > .flex-row{flex-wrap: wrap;padding-bottom:0;}
    #page2 .wrap > .flex-row .left{max-width: 100% !important;}
    #page2 .wrap > .flex-row .left .card-wrap{
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    }
    #page2 .wrap > .flex-row .left .card-wrap > .cards{
        flex-direction: column-reverse;
        gap: 10px;
        height: 100% !important;
    }
    #page2 .left .cards span{text-align: center;}

    #page2 .wrap > .flex-row .right,
    #page2 .wrap > .flex-row .right .card-wrap{
        width: 100% !important;
    }
    .card-notice .sub{
        min-width: 100%;
    }
}
@media screen and (max-width: 870px) {
    #page2 .wrap > .flex-row .left .card-wrap{
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
    #page2 .wrap > .flex-row .left .card-wrap > .cards{
        flex-direction: row;
    }
    #page2 .left .cards span{text-align: left;}
}
@media screen and (max-width: 767px) {
    #page2 .title-wrap{min-height: 100%;}
    #page2 .title-wrap h3,
    #page3 .title-wrap h3{font-size: 22px !important;}
    #page3 .title-wrap .sub{padding: 10px 0 10px 0;}
    #page2 .title-wrap h2.eng{font-size: 25px;}
    #page2 .title-wrap img.doctor{
        top: -60px; left: -45px; width: 200px;
    }

    #page2 .wrap > .flex-row .left .card-wrap > .cards{
        flex-direction: column-reverse;
    }
    #page2 .left .cards span{text-align: center;}

    #page2 .right .title-wrap button{padding: 26px 10px; font-size: 17px;}
    #page2 .right .title-wrap button.more{padding: 14px 10px 25px 10px; font-size: 30px;}

    .card-notice .tit{font-size: 18px;}
    .card-notice .sub, .card-notice .notice-list > li a{font-size: 15px;}
}
@media screen and (max-width: 500px) {
    #page2 .wrap > .flex-row .left .card-wrap{
        grid-template-columns: repeat(1, minmax(0, 1fr)) !important;
    }
    #page2 .wrap > .flex-row .left .card-wrap > .cards{
        flex-direction: row;
    }
    #page2 .left .cards span{text-align: left;}
}
@media screen and (max-width: 400px) {
    #page2 .wrap > .flex-row .left .card-wrap > .cards{
        flex-direction: column-reverse;
    }
    #page2 .left .cards span{text-align: center;}
}
/* 공개현황 & 홍보소식 : 반응형 레이아웃 - end */


/* 연구자 전용 서비스 */
#page3 .title-wrap{display: flex; align-items: center;
    column-gap: 32px; flex-wrap: wrap;}
#page3 .title-wrap h3{
    font-family: GmarketSans500;
    font-size: 32px;
    letter-spacing: -1.4px;
    color: #111;
    width: fit-content;
    margin-bottom: 0;
    /*padding: 10px 0 20px 0;*/
}
#page3 .title-wrap .sub{
    font-family: Pretendard400;
    font-size: 15px;
    line-height: 120%;
    letter-spacing: -1px;
    color: #555555;
}
#page3 .title-wrap .sub strong{
    font-family: Pretendard600;
}


#page3 .services{
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 34px; row-gap: 42px;
    /*padding: 36px 0 100px 0;*/
    padding: 86px 0 100px 0;
}
#page3 .diagram:hover{
    animation: move 1s infinite alternate;
    /*transition: transform 0.3s ease;*/
}

#page3 .diagram {
    position: relative;
    height: 205px;
}
#page3 .rectangle {
    width: 100%;
    height: 180px;
    background: linear-gradient(107.88deg, #0098F7 37.8%, #0250E2 95.69%);
    border-radius: 20px;
    position: relative;
    z-index: 1;
    padding: 37px 28px 37px 35px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.triangle {
    width: 0;
    height: 0;
    border-left: 75px solid transparent;
    border-top: 25px solid #0260E6;
    position: absolute;
    bottom: 0;
    left: 16px;
    z-index: 0;
}

#page3 .diagram.sec .rectangle {
    background: linear-gradient(107.88deg, #3F53BA 37.8%, #182389 95.69%);
}
#page3 .diagram.sec .triangle{
    border-top: 25px solid #19258B;
}
#page3 .diagram.third .rectangle {
    background: linear-gradient(107.88deg, #7752C1 37.8%, #492989 95.69%);
}
#page3 .diagram.third .triangle{
    border-top: 25px solid #4B2B8C;
}

#page3 .rectangle h5{
    font-family: GmarketSans500;
    font-size: 22px;
    letter-spacing: -0.3px;
    color: #fff;
    width: fit-content;
    padding-bottom: 10px;
    font-weight: 600;
}
#page3 .rectangle p{
    font-family: Pretendard400;
    font-size: 15px;
    letter-spacing: -0.4px;
    line-height: 140%;
    color: #fff;
    width: fit-content;
}

/* 링크 배너(마이크로바이옴 통합시스템) */
.link-banner{
    background: linear-gradient(90.85deg, #EBF2FF 1.06%, #A9C7FF 100%);
    height: 170px;
    border-radius: 20px;
    position: relative;
    font-family: Pretendard400;
    font-size: 16px;
    line-height: 130%;
    color: #3C4765;
    display: flex;
    align-items: center;
    padding: 0 63px;
}
.link-banner h2{
    font-family: GmarketSans500;
    font-size: 30px;
    letter-spacing: -0.4px;
    font-weight: 600;
    color: #1E2B91;
    word-break: keep-all;
    display: flex;
    align-items: flex-start;
}
.link-banner h2 > img{margin-left: 10px;}
.link-banner .flex-col:hover h2 > img{
    animation: move-right 2s ease-in-out infinite;
}

.link-banner .flex-col{position: relative; z-index: 1;}
.link-banner .bg-group{
    position: absolute;
    right: 0;
}
.link-banner img{
    position: relative;
    z-index: 0;
}
.link-banner img.char{
    right: 60px;
    top: 4px;
}
.link-banner img.char-bg{}

@media screen and (max-width: 1130px) {
    #page3 .rectangle img{display: none;}
}
@media screen and (max-width: 820px) {
    #page3 .services{
        grid-template-columns: repeat(1, minmax(0, 1fr));
        row-gap: 20px;
        padding: 10px 0 100px 0;
    }
    #page3 .rectangle img{display: block;}
    #page3 .services .col-span-3{
        grid-column: span 1 / span 1;
    }

    .link-banner{margin-top: 40px; height: 100%; padding: 10px 40px;}
    .link-banner .flex-col{max-width: 300px; gap: 10px;}
    .link-banner img.char-bg{opacity: 0.5;}
}
@media screen and (max-width: 700px) {
    .link-banner{overflow: hidden; font-size: 14px;}
    .link-banner .flex-col{max-width: 100%; gap: 6px;}
    .link-banner h2{font-size: 23px;}
    .link-banner h2 > img{width: 20px; height: 20px; margin-bottom: 4px;}
    .link-banner img.char{display: none;}
}
@media screen and (max-width: 450px) {
    .link-banner .flex-col{max-width: 260px;}
}


/* 메인 슬라이드 */
.swiper {
    width: 100%;
    height: 550px;
}
.swiper-slide {
    text-align: center;
    font-size: 18px;
    background: #ccc;
    display: flex;
    justify-content: center;
    align-items: center;
}
@keyframes scaleAnimation {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.2);
    }
    100% {
        transform: scale(1);
    }
}
.swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1);
    transition: transform 3s ease-in-out;
}
#mainBgSwiper .swiper-slide img{
    animation: scaleAnimation 16s ease-in-out infinite;
    animation-delay: 2s;
}
/*.swiper-slide:hover img,*/
/*.swiper-slide:focus img{*/
/*    transform: scale(1.2);*/
/*    transition: transform 4s ease-in-out;*/
/*}*/

#mainBgSwiper .inner{
    max-width: 1440px;
    width: 100%;
    height: fit-content;
    position: absolute;
    left: 50%;
    transform: translate(-50%, 0);
    z-index: 2;
    padding: 0 20px;
}
#mainBgSwiper .inner.top{
    top: 0;
}
#mainBgSwiper .inner.bottom{
    bottom: 0;
}
#mainBgSwiper .inner-slide{
    max-width: 1440px;
    width: 100%;
    height: 340px;
    position: absolute;
    z-index: 1;
    top: 105px;
    left: 50%;
    transform: translate(-50%, 0);
    padding: 0 20px;
}

.swiper-slide .cont-zone{
    position: relative;
    top: 0;
    left: 0;
    text-align: left;
    opacity: 1;
    transform: translateZ(0);
    will-change: transform;
    transition: transform 1s ease, opacity 0.1s ease;
}

#mainBgSwiper .swiper-pagination{
    width: fit-content !important;
    position: relative !important;
    bottom: 0 !important;
}
.swiper-pagination-bullet {
    width: 10px !important;
    height: 10px !important;
    text-align: center !important;
    line-height: 20px !important;
    font-size: 12px !important;
    color: #000;
    opacity: 1;
    background: rgba(225, 225, 225, 0.3);
    margin: 0 10px !important;
}
.swiper-pagination-bullet-active {
    background: #fff !important;
}

#mainBgSwiper .controls-wrap{
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    position: relative;
    top: 0;
    padding-bottom: 20px;
}
#mainBgSwiper .controls {
    position: relative;
    width: fit-content;
    z-index: 10;
}
#mainBgSwiper .controls button {
    position: relative;
    background: transparent;
    width: 30px; height: 40px;
}
#mainBgSwiper .controls .prev::before,
#mainBgSwiper .controls .next::before,
#mainBgSwiper .controls .stop::before,
#mainBgSwiper .controls .play::before{
    content: "";
    background: url(/static/original/images/banner-prev-btn.png);
    background-repeat: no-repeat !important;
    background-position: center center !important;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 24px;
    height: 24px;
    filter: brightness(0) invert(1);
}
#mainBgSwiper .controls .next::before{
    background: url(/static/original/images/banner-next-btn.png);
}
#mainBgSwiper .controls .stop::before{
    background: url(/static/original/images/banner-stop-btn.png);
    background-size: 80% 90%;
    margin-left: 1px;
}
#mainBgSwiper .controls .play::before{
    background: url(/static/original/images/banner-play-btn.png);
    background-size: 90% 90%;
    margin-left: 1px;
}

.current-slide {
    position: relative;
    width: fit-content;
    top: 0;
    left: 0;
    color: #fff;
    font-size: 20px;
    z-index: 1;
    padding-top: 75px;
    font-family: GmarketSans500;
    font-size: 14px;
    color: rgba(225, 225, 225, 0.9);
    text-shadow: 0px 0px 20px rgba(0, 0, 0, .7);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}
.current-slide > strong{color: #fff;}

.cont-zone .eng{
    font-family: GmarketSans500;
    font-size: 15px;
    color: #A8EFFF;
    padding: 20px 0 25px 0;
}
.cont-zone h1{
    font-family: GmarketSans500;
    font-size: 50px;
    letter-spacing: -1px;
    line-height: 110%;
    color: #fff;
    word-break: keep-all;
    margin-bottom: 30px;
}
.cont-zone h1 > strong{
	display:block;
    font-family: GmarketSans700;
}
.cont-zone h5{
    font-family: Pretendard400;
    font-size: 15px;
    letter-spacing: -0.4px;
    line-height: 150%;
    color: #fff;
    margin-bottom: 30px;
    word-break: keep-all;
}
.cont-zone .more{
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #fff;
    max-width: 300px;
    height: 55px;
    border-radius: 90px;
    padding: 16px 30px;
    font-family: GmarketSans500;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: -0.4px;
    line-height: 100%;
    color: #3E4378;
}
.cont-zone .more::after{
    content: "";
    width: 24px;
    height: 24px;
    background: url("/static/original/images/more-btn-arrow-right.png") no-repeat center;
    background-size: contain;
    position: relative;
    left: 4px;
}
.cont-zone .more:hover::after{
    animation: move-right 1.2s ease-in-out infinite;
}
@media screen and (max-width: 1025px) {
	.cont-zone h1{font-size: 42px;}
}
@media screen and (max-width: 767px) {
    .cont-zone h1{font-size: 36px;}
    .cont-zone h5{font-size: 14px;}
    .cont-zone .eng{font-size: 13px;}
    .cont-zone h1,.cont-zone h5{margin-bottom: 20px;}
    .cont-zone .more{max-width: 180px; height: 45px;}
}

/* ============================================================ */
/* 251204 임혜경 영문 추가  */
.en #page2 .wrap > .flex-row .left{max-width:100%}
.en #page2 .wrap > .flex-row .right{display:none}

@media screen and (max-width: 640px) {
	.en .swiper{height:600px}
}

