/* font */
/* font */
@font-face {
    font-family: 'sebang';
    font-weight: 400;
    src: url(/main/css/font/SEBANG\ Gothic\ OTF.otf);
}
@font-face {
    font-family: 'sebang';
    font-weight: 700;
    src: url(/main/css/font/SEBANG\ Gothic\ OTF\ Bold.otf);
}
@font-face {
    font-family: 'pretendard';
    font-weight: 400;
    src: url(/main/css/font/Pretendard-Regular.otf);
}
@font-face {
    font-family: 'pretendard';
    font-weight: 500;
    src: url(/main/css/font/Pretendard-Medium.otf);
}
@font-face {
    font-family: 'pretendard';
    font-weight: 600;
    src: url(/main/css/font/Pretendard-SemiBold.otf);
}
@font-face {
    font-family: 'pretendard';
    font-weight: 700;
    src: url(/main/css/font/Pretendard-Bold.otf);
}
@font-face {
    font-family: 'pretendard';
    font-weight: 800;
    src: url(/main/css/font/Pretendard-ExtraBold.otf);
}

/* 공통 */
body { position: relative; width: 2160px; height: 3840px; font-family: 'pretendard';}


/* index */
.index_header { height: 320px; line-height: 320px; text-align: center;}
.index_header img { height: 160px;}
.index_img { width: 2160px; height: 3055px; overflow: hidden;}
.index_img img { width: 100%; height: 100%; object-fit: cover;}
.index_footer { position: relative; display: flex; align-items: center; justify-content: center; padding-top: 30px; height: 465px; background: transparent linear-gradient(90deg, #F70767 0%, #A400EA 100%) 0% 0% no-repeat padding-box;  box-sizing: border-box; overflow: hidden;}
.index_footer img { margin-top: -30px; margin-right: 80px; width: 115px;}
.index_footer p { font-size: 60px; color: #fff; line-height: 90px; font-family: 'sebang'; letter-spacing: 1.1px;}
.index_footer p i { position: relative; font-weight: 600;}
.index_footer p i::before { position: absolute; content: ""; left: 50%; top: -20px; transform: translateX(-50%); width: 12px; height: 12px; border-radius: 50%; background-color: #fff; }
.index_footer p b { font-size: 75px;}
    /* 인덱스 푸터 애니메이션 */
.point { position: absolute; width: 200px; height: 200px;}
.point1 { left: -300px; top: 0px;}
.point2 { right: -130px; top: 0px;}
.point > div { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 200px; height: 200px;  border-radius: 50%; background-color: #fff; opacity: 0;}
.circle1 { animation: wave 8s infinite linear;}
.circle2 { animation: wave 8s 2s infinite linear; }
.circle3 { animation: wave 8s 4s infinite linear; }
.circle4 { animation: wave 8s 6s infinite linear; }
@keyframes wave {
    0% { transform: scale(2); opacity: 0.2;}
    100% { transform: scale(6); opacity: 0;}
}


/* main */
.main { position: absolute; left: 0; top: 0; padding-top: 765px; width: 100%; height: 100%; text-align: center; box-sizing: border-box; font-family: 'sebang';}
.main ul { display: flex; justify-content: center; margin-top: 205px;}
.main ul li { margin: 0 30px;}
.main ul li a { display: flex; flex-direction: column; justify-content: space-between; padding: 90px 0 35px; width: 490px; height: 565px; background: #F5F5F5 no-repeat padding-box; box-shadow: inset 7px 7px 20px #FFFFFF96, 5px 3px 15px #00000069; border-radius: 80px; font-size: 50px; color: #fff; box-sizing: border-box; font-weight: 700;}
.main ul li a span { display: block; margin: 0 35px; width: 420px; height: 115px; line-height:115px; background: transparent linear-gradient(97deg, #FA1D58 0%, #A60D35 100%) 0% 0% no-repeat padding-box; border-radius: 129px;}
.main ul li:nth-child(even) span { background: transparent linear-gradient(97deg, #79313F 0%, #5B232E 100%) 0% 0% no-repeat padding-box;}



/* sub 공통 */
.header_logo { display: flex; align-items: center; justify-content: center; height: 285px;}
.header_logo img { height: 160px;}
.header_title { height: 210px; background: transparent linear-gradient(90deg, #F70767 0%, #A400EA 100%) 0% 0% no-repeat padding-box;}
.header_title h1 { color: #fff; font-size: 75px; text-align: center; line-height: 210px; font-weight: 700;}
main { position: relative; height: calc(100% - 495px);}
.container { position: absolute; left: 0; top: 0; width: 100%; height: 100%;}
.snb { position: absolute; right: 0; top: 505px;}
.snb nav ul { width: 200px; height: 690px; background-color: #fff; border-radius: 50px 0 0 50px; box-shadow: 0px 3px 10px #00000066;}
.snb nav li { position: relative; width: 200px; height: 230px;}
.snb nav li~li::before { position: absolute; content: ""; left: 50%; transform: translate(-50%); top: -4px; width: 159px; height: 8px; background: #EEEEEE 0% 0% no-repeat padding-box; box-shadow: inset 0px 3px 6px #00000029; border-radius: 100px;}
.snb nav li a { z-index: 1; position: absolute; left: 0; top: 0; display: flex; flex-direction: column; align-items: center; padding-top: 35px; width: 100%; height: 100%; font-size: 32px; text-align: center; box-sizing: border-box;}
.snb nav li span { display: inline-block; margin-bottom: 20px; width: 100px; height: 100px;}
.snb nav li:nth-child(1) a { border-radius: 50px 0 0 0;}
.snb nav li:nth-child(3) a { border-radius: 0 0 0 50px;}
.snb nav li.active a { background: transparent linear-gradient(173deg, #F44775 0%, #C10D3D 100%) 0% 0% no-repeat padding-box; box-shadow: inset 0px -5px 10px #00000029; color: #fff;}
.snb .btn_back { margin-top: 45px; padding-top: 35px; display: flex; flex-direction: column; align-items: center; width: 200px; height: 204px; background: transparent linear-gradient(180deg, #33C3FF 0%, #00AAF2 100%) 0% 0% no-repeat padding-box; box-shadow: inset 5px -5px 10px #FFFFFF75, 0px 3px 10px #00000066; border-radius: 50px 0px 0px 50px; color: #fff; font-size: 37px; box-sizing: border-box;}
.snb .btn_back span { display: inline-block; width: 80px; height: 80px;}



/* sub 01 - 센터소개 */
.sub_01 .container { padding-top: 225px;}
.sub_01 .video { margin: 0 auto 75px; width: 1600px; height: 900px; background-color: lightgray; box-sizing: border-box;}
.sub_01 .contents { margin: 0 auto; padding: 200px 0 150px; width: 1590px; background: #FFFFFF 0% 0% no-repeat padding-box; box-shadow: 5px 5px 20px #00000052; border-radius: 100px; text-align: center; box-sizing: border-box;}



/* sub 02 - 시설소개 */
.sub_02 .container { padding-top: 175px; box-sizing: border-box; line-height: 1;}
.title { display: flex; align-items: flex-end; margin-left: 190px; padding-left: 20px; padding-bottom: 40px; width: 1665px; border-bottom: 6px solid #6D6D6D; box-sizing: border-box;}
.title h2 { width: 230px; color: #E4174D; background: transparent linear-gradient(180deg, #F1076F 0%, #910B39 100%) 0% 0% no-repeat padding-box; -webkit-background-clip : text; color: transparent; text-align: right;}
.title h2 em { font-size: 200px; font-weight: 600;}
.title h2 i { font-size: 155px; font-weight: 600;}
.title span { margin-left: 48px; margin-bottom: 20px;}
.title span b { font-size: 60px; font-family: 'sebang';}
.title span p { margin-top: 25px; font-size: 35px; color: #898989; font-weight: 500;}
.sub_02 .contents { margin-left: 190px; padding: 80px 25px; width: 1665px; height: 100%; box-sizing: border-box;}
.sub_02 .contents .img_floor { position: absolute; bottom: 0; left: 0; height: 1225px; width: 100%;}
.sub_02 .contents .img_floor img { width: 100%; height: 100%; object-fit: cover; overflow: hidden;}
.sub_02 .contents .slide_list { margin: 0 -25px; display: flex; flex-wrap: wrap; height: 1000px;}
.sub_02 .contents .slide_list li { margin: 0 25px; margin-bottom: 70px;}
.sub_02 .contents .slide_list button { display: flex; flex-direction: column; justify-content: space-between; align-items: center; padding: 24px 22px 20px; width: 366px; height: 430px; background: #FFFFFF 0% 0% no-repeat padding-box; box-shadow: 5px 3px 15px #0000004D; border-radius: 40px; text-align: left;}
.sub_02 .contents .slide_list button .img_zone { margin-bottom: 10px; width: 320px; height: 190px; border: 3px solid #D1D1D1; box-sizing: border-box; overflow: hidden;}
.sub_02 .contents .slide_list button .img_zone img { width: 100%; height: 100%; object-fit: cover;}
.sub_02 .contents .slide_list button .txt_zone { margin-left: 30px; width: 100%; line-height: 1;}
.sub_02 .contents .slide_list button b { display: block; font-size: 35px; font-weight: 700;}
.sub_02 .contents .slide_list button em { margin-top: 11px; display: block; height: 30px; font-size: 29px; color: #787878; text-align: left; font-weight: 600;}
.sub_02 .contents .slide_list span { display: inline-block; width: 100%; height: 65px; line-height: 66px; background: #E4174D 0% 0% no-repeat padding-box; border-radius: 33px; color: #fff; font-size: 32px; text-align: center; font-weight: 500;}
.sub_02 .contents .slide_list span img { margin: 0 0 5px 18px;}
.sub_02 .contents .slide_control { display: flex; align-items: center; justify-content: center;}
.sub_02 .contents .slide_control button { margin: 0 80px; width: 55px; height: 85px;}
.sub_02 .contents .slide_control button:disabled { opacity: 0.3;}
.sub_02 .contents .slide_control ul { display: flex;}
.sub_02 .contents .slide_control ul li button { margin: 0 12px; width: 20px; height: 20px; border-radius: 50%; background-color: #fff;}
.sub_02 .contents .slide_control ul li.active button { background-color: #000;}
    /* 1~8층 탭 */
.tab { z-index: 1; display: flex; align-items: flex-start; position: absolute; left: 0; bottom: 1225px; padding: 45px 200px 0; height: 300px; width: 100%; background-color: #2F2F2F; box-sizing: border-box;}
.tab li { position: relative; margin: 0 30px; }
.tab button { display: flex; flex-direction: column; align-items: center; color: #fff; word-break: keep-all;}
.tab button span { display: inline-block; margin-bottom: 25px; width: 120px; height: 120px; line-height: 120px; background: transparent linear-gradient(180deg, #626262 0%, #424242 100%) 0% 0% no-repeat padding-box; border: 5px solid #858585; border-radius: 28px;}
.tab li.active button span { background: transparent linear-gradient(180deg, #E4174D 0%, #A400EA 100%) 0% 0% no-repeat padding-box; border: 5px solid #FFFFFF;}
.tab li.active::before { position: absolute; content: ""; left: 50%; transform: translateX(-50%); top: -45px; width: 45px; height: 20px; background: url(../images/arrow_btm.png) no-repeat center / 100% auto;}
.tab button span em { font-size: 64px; font-weight: 600; font-family: 'pretendard';}
.tab button span i { font-size: 50px; font-weight: 600; font-family: 'pretendard';}
.tab button u { width: 170px; font-size: 28px; line-height: 36px;}


/* sub 03 - 입주기업소개 */
.sub_03 .container { padding-top: 330px; box-sizing: border-box;}
.sub_03 .cor_list { display: flex; flex-wrap: wrap; margin: 0 auto; margin-top: -25px; width: 1440px;}
.sub_03 .cor_list li { margin: 20px;}
.sub_03 .cor_list button { width: 320px; height: 190px; background: #FFFFFF 0% 0% no-repeat padding-box; box-shadow: 3px 3px 10px #00000073; border-radius: 38px; overflow: hidden;}
.sub_03 .cor_list button img { width: 100%; height: 100%; object-fit: cover;}


/* popup */
.popup { z-index: 2; position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.popup_bg { position: absolute; left: 0; top: 0; width: 100%; height: 100%; background-color: #000; opacity: 0.8;}
.popup_wrap { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); }
.popup_win { width: 1190px; height: 1750px; background-color: #fff; border-radius: 100px; opacity: 1; color: #000;}
.popup_win .popup_img { position: relative; height: 520px; border-radius: 100px 100px 0 0; background-color: lightgray; overflow: hidden;}
.popup_win .popup_img::before { position: absolute; content: ""; width: 100%; height: 100%; background-color: #000; opacity: 0.3;}
.popup_win .popup_img img { width: 100%; height: 100%; object-fit: cover;}
.popup_win h1 { height: 140px; line-height: 140px; background: transparent linear-gradient(90deg, #F70767 0%, #A400EA 100%) 0% 0% no-repeat padding-box; color: #fff; font-family: 'sebang'; font-size: 60px; font-weight: 700; text-align: center;}
.popup_win h2 { position: relative; margin: 115px 135px 50px; font-family: 'sebang'; font-size: 48px; font-weight: 700; color: #E4174D;}
.popup_btn { display: flex; justify-content: center; margin-top: 55px; }
.popup_btn button { display: flex; justify-content: space-between; align-items: center; margin: 0 20px; padding: 0 20px; height: 120px; border-radius: 60px; line-height: 120px; font-size: 45px; font-weight: 700; box-sizing: border-box;}
.popup_btn .btn_prev,
.popup_btn .btn_next { width: 390px; background-color: #E4174D; color: #fff;}
.popup_btn .btn_prev { padding-right: 80px;}
.popup_btn .btn_next { padding-left: 80px;}
.popup_btn .btn_close { padding-left: 55px; width: 270px; background-color: #fff;}
.popup_win span { display: flex; justify-content: space-between; align-items: center; padding: 40px 73px; margin: 0 auto; margin-bottom: 80px; width: 1040px; height: 350px; background: #F8F8F8 0% 0% no-repeat padding-box; border: 3px solid #E4E4E4; box-sizing: border-box;}
.popup_win span .img_zone { width: 320px; height: 190px; border: 3px solid #D1D1D1;}
.popup_win table { width: 540px; font-size: 32px; word-break: keep-all;}
.popup_win table th { padding: 10px 0; width: 145px; font-weight: 800; text-align: left; vertical-align: top;}
.popup_win table td { padding: 10px 0; font-weight: 400; }
.contents_A p,
.contents_C p { margin: 0 100px; padding: 0 25px; height: 440px; font-size: 32px; line-height: 50px; overflow-y: scroll; }
.contents_B ul { padding: 40px 30px; margin: 0 90px; height: 868px; box-sizing: border-box; overflow-y: scroll;}

/* 전체 스크롤바 스타일 */
.scrollbox::-webkit-scrollbar {
    width: 10px; /* 스크롤바 너비 */
    height: 10px; /* 가로 스크롤바 높이 */
}

/* 스크롤바 트랙 */
.scrollbox::-webkit-scrollbar-track {
    background: transparent; /* 트랙 배경색 */
    border-radius: 10px; /* 둥근 모서리 */
}

/* 스크롤바 슬라이더 */
.scrollbox::-webkit-scrollbar-thumb {
    background-color: rgb(180, 180, 180) ;/* 그라데이션 색상 */
    border-radius: 10px; /* 둥근 모서리 */
    border: 2px solid #f0f0f0; /* 외곽선으로 분리 효과 */
}

/* 스크롤바 슬라이더 Hover */
.scrollbox::-webkit-scrollbar-thumb:hover {
    background-color: #000000 ;
}

.contents_B ul li { margin-bottom: 70px; align-items: flex-end; display: flex; justify-content: space-between;}
.contents_B .img_zone { align-self: flex-start; width: 425px; min-height: 425px; background-color: lightgray;}
.contents_B .txt_zone { align-self: flex-start; padding-top: 30px; margin-bottom: 10px; width: 450px; box-sizing: border-box;}
.contents_B .txt_zone b { font-size: 40px; font-weight: 700; line-height: 55px;}
.contents_B .txt_zone p { margin-top: 15px; font-size: 30px; font-weight: 400; line-height: 45px;}
.contents_C table { width: auto;}
.contents_C table th { width: 260px; }
