@charset "utf-8"; 
@import url(bootstrap.min.css); 
@import url(bootstrap-icons.min.css); 
@import url(font.css); 
@import url(common.css); 
@import url(layout.css); 
@import url(bbs.css); 

:root { 
--font-play: 'Play', sans-serif; 
--font-noto: 'Noto Sans KR', sans-serif;
 } 
/* common */
h3.content-title{color:#222529; font-size:38px; font-weight:500; letter-spacing:-0.6px; text-align: center; margin-bottom: 80px; display: block; width: 100%;}
h5.h5-style1{font-weight:600; font-size:30px; color:#222; margin-top: 30px; text-align: left;}
.border01{padding-bottom:15px; margin-bottom:30px; border-bottom:1px dashed #ccc;}
h5.h5-style2 {border-top: 2px solid #7f7f7f; position: relative; padding: 35px 0 35px 87px; font-size: 27px; font-weight: 600; color: #222; letter-spacing: -0.25px; line-height: 1.3;}
h5.h5-style2:before {content: ""; position: absolute; top: 50%; margin-top: -15px; left: 40px; width: 36px;  height: 31px; background: url(/assets/img/title-icon.png) center/contain no-repeat;}

.gray-box {padding: 50px 40px; background-color: #f5f7f9; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;}
.gray-box .p1 {position: relative; padding: 0 10px; font-size: 17.5px; font-weight: 400; color: #333; letter-spacing: 0; line-height: 2.05; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;}
.gray-box .p1:before {content: ""; position: absolute; top: 15px; left: 0; width: 3px; height: 3px; background-color: #000;}
.gray-box .p1 span{font-size: 15px; color: #214399;}

@media (max-width: 1020px) { 
h3.content-title{color:#222529; font-size:18px; font-weight:500; letter-spacing:-0.6px; text-align: center; margin-bottom: 30px; display: block; width: 100%;}
h5.h5-style1{font-weight:400; font-size:22px; color:#222; margin-top: 30px; text-align: left;}
.border01{padding-bottom:15px; margin-bottom:30px; border-bottom:1px dashed #ccc;}
h5.h5-style2 {border-top: 2px solid #7f7f7f; position: relative; padding: 25px 0 25px 67px; font-size: 22px; font-weight: 600; color: #222; letter-spacing: -0.25px; line-height: 1.3;}
h5.h5-style2:before {content: ""; position: absolute; top: 50%; margin-top: -17px; left: 20px; width: 32px;  height: 31px; background: url(/assets/img/title-icon.png) center/contain no-repeat;}

.gray-box {padding: 30px 20px; background-color: #f5f7f9; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;}
.gray-box .p1 {position: relative; padding: 0 10px; font-size: 16px; font-weight: 400; color: #333; letter-spacing: 0; line-height: 2.05; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;}
.gray-box .p1:before {content: ""; position: absolute; top: 15px; left: 0; width: 3px; height: 3px; background-color: #000;}
.gray-box .p1 span{font-size: 14px; color: #214399;}
    
}



.table1 {width: 100%; border-collapse: collapse; position: relative; border-left: 2px solid #fff !important; border-right: 2px solid #fff !important;}
.table1 thead{position: relative;}
.table1 caption, .table1 legend {position: absolute; margin: -1px; padding: 0; width: 1px; height: 1px; border: 0; clip: rect(0, 0, 0, 0); overflow: hidden;}

.table1 th {padding: 20px 5px;  border-top: 1px solid #111; border-width:1px 0 0 1px; text-align: center; background: #f6f6f6;}
.table1 th.first-child {}
.table1 td {padding: 25px;border:1px solid #ddd;border-width:0 0 1px 1px;text-align: center;vertical-align: middle !important;}
.table1 td ul { text-align: left;  margin: 0 0 0 20px;}
.table1 td ul li{list-style: circle; text-align: left !important;}
.table1 td.lt{ text-align: left;}
.table1 strong {font-weight: 700;}
.table1 label {overflow: hidden; position: absolute; width: 0; height: 0; font: 0/0 san-serif; visibility: hidden;}
.table1 td a:hover {color: #005fcb; text-decoration: underline;}
.table1 tr:hover td {background-color: #f9f9f9;}


.table2 { clear:both; margin:0; padding:0; width:100%; border-collapse:collapse; border-top:#004795 2px solid; border-left:2px solid #fff; border-right:2px solid #fff; border-bottom:2px solid #ccc; }
.table2 th { border:1px #d7d7d7 solid; padding:18px 0; background:#f6f6f6; text-align:center; color:#004795; font-weight: 500; }
.table2 td { border:1px #d7d7d7 solid; padding:15px 15px; text-align:center; letter-spacing:-0.5px; }
.table2 td.lt { text-align:left; }
.table2 td li{ text-align:left;}

@media (max-width: 1020px) { 
    .table1 th, .table1 td{white-space: nowrap;}
}

.tabs3 { border:none; display:black; position:relative; z-index:910;}
.tabs3 li { float:left; margin-right:5px; margin-bottom: 5px}
.tabs3 li a { display:table; font-size:15px; font-weight:400; padding:12px; color:#2fb8bb; border:1px solid #2fb8bb !important; text-align:center; line-height:1.5; margin-left:-1px; border-radius:15px; width: 120px; }
.tabs3 li a.active, .tabs3 li a.active:hover, .tabs3 li a.active:focus { display:table; background:#2fb8bb; border:1px solid ##2fb8bb; color:#fff !important; }
.tabs3 li a p{ display:table-cell; vertical-align:middle;}

@media (max-width: 768px){
.tabs3 li { display:block; float:left; width:33%; margin-top:-1px; max-height:50px; overflow:hidden; margin-right:0;}
.tabs3 li a {display:table; width:100%; font-size:12.5px; min-height:50px; border-radius:0;  padding:4px 3px; margin-bottom:0 !important; border-left:0 !important; border-right:0 !important; border-top:1px solid #e3e3e3 !important; border-bottom:1px solid #e3e3e3 !important;}
}


.ul-table2 { margin:0; padding:0; list-style:none; border-top:2px solid #000; display:block; overflow:hidden; }
.ul-table2>li { margin:0; padding:20px 30px; width:50%; display:block; float:left; border-bottom:1px solid #d7d7d7; height:260px; position:relative; }
.ul-table2>li .img { position:absolute; left:35px; top:40px; }
.ul-table2>li .text { padding:50px 0 0 180px; }
.ul-table2>li .text h4 { color:#c10319; font-weight: 700; }
.ul-table2>li .text p { font-size: 18px;}
.ul-table2>li .text p strong {color: #064396;}
.ul-table2>li:nth-child(odd) { border-right:1px solid #d7d7d7; }
@media (max-width: 991px) {
.ul-table2>li { width:100%; float:none; height:auto; min-height:240px; }
.ul-table2>li:nth-child(odd) { border-right:0; }
}
@media (max-width: 421px) {
.ul-table2>li .img { display:none; }
.ul-table2>li .text { padding:0; }
.ul-table2>li { width:100%; float:none; height:auto; min-height:auto; }
}
/* --- 기존 스타일 유지 --- */
.visual { position: relative; overflow: hidden; height: 100vh; background: #000; } 
.visual .txt { position: absolute; left:50%; top: 50%; width: 100%; max-width: 1600px; text-align: left; z-index: 10; transform:translate(-50%, -80%); } 
.visual .txt h3 { font-size: 65px; font-weight: 700; color: #fff; line-height: 1.5; } 
.visual .txt p { margin: 40px 0 0;  font-size: 35px; font-weight: 700; color: #e20610; font-family: var(--font-play); } 

.mouse-box { position: absolute; bottom: 50px; left: 50%; width: 50px; transform: translateX(-50%); height: 50px; z-index: 10; } 
.mouse-box .mouse { margin: 0 auto; height: 44px; width: 30px; border-radius: 22px; border: 2px solid #fff; position: relative; } 
.mouse-box .mouse .wheel { height: 8px; width: 2px; display: block; margin: 8px auto; background-color: #fff; -webkit-animation: mouse-wheel 0.8s linear infinite; animation: mouse-wheel 0.8s linear infinite; position: relative } 

@keyframes mouse-wheel { 0% { top: 1px } 25% { top: 2px } 50% { top: 3px } 75% { top: 2px } 100% { top: 1px } } 

.visual-swiper { height: 100vh; overflow: hidden; position: relative; z-index: 1; } 
.visual-swiper .swiper-slide { height: 100%; position: relative; overflow: hidden; background: #000; }

/* --- 유튜브 배경 꽉 채우기 추가 (핵심) --- */
.video-wrap {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  pointer-events: none; /* 영상 위 요소 클릭 방해 금지 */
}

/* 16:9 비율 유지하며 배경 꽉 채우기 */
.video-wrap iframe {
  position: absolute;
  top: 50%; left: 50%;
  width: 100vw;
  height: 56.25vw; /* 9/16 비율 */
  min-height: 100vh;
  min-width: 177.77vh; /* 16/9 비율 */
  transform: translate(-50%, -50%);
}

/* 영상이 너무 밝아 글씨가 안 보일 경우를 위한 어두운 투명막 */
.video-wrap::after {
  content: '';
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0, 0, 0, 0.2); 
  z-index: 2;
}

@media (max-width: 1020px) { 
  .visual .txt { padding: 0 20px; }
  .visual .txt h3 { font-size: 28px; } 
  .visual .txt p { font-size: 14px; display: none;}
  .mouse-box .mouse { height: 26px; width: 16px; border-radius: 8px; } 
  .mouse-box .mouse .wheel { height: 5px; width: 2px; display: block; margin: 3px auto; } 
}

.notice-quick{ height: 632px; padding: 80px 0; background: #fff;}
.notice {position:relative; padding-right:40px;}
.notice h3 { display:block; font-size:30px; font-weight:700; padding:0; margin-bottom:20px; color:#1f1f1f; margin-top: 0;}	
.notice ul { margin:0; padding:0; }
.notice ul li {padding:20px 0; margin:0; }
.notice ul li a{ margin:0; padding:0; line-height:150%;  font-weight:500; color:#1f1f1f;}
.notice ul li a span.date { color:#939393; display:block; font-size:14px; }
.notice ul li:first-child { border-bottom:1px dashed #d8d8d8; padding-bottom:20px;}
.notice ul li:first-child a{ font-size:22px;}
.notice ul li:first-child a span.date{ font-size:15px;}
.notice a.more { display:block; position:absolute; right:40px; top:0; }
.notice a.more i { font-size: 30px;}	
 
.quick{ width: 100%; }
.quick h3 { display:block; font-family: var(--font-play); font-size:30px; font-weight:700; padding:0; margin-bottom:20px; color:#1f1f1f; margin-top: 0;}	
.quick ul{display: flex; flex-flow:row wrap; margin: 0; padding: 0;}
.quick ul li{flex-basis: 25%; text-align: center; list-style: none; padding: 0 20px 40px 0}
.quick ul li a{display: block; text-align: center; padding:40px 0 40px; text-align:center; overflow:hidden;}
.quick ul li a:hover i{transform: translateY(-10%); -webkit-transition-duration: 0.4s; /* Safari */  transition-duration: 0.4s;  cursor: pointer;}
.quick ul li a i{ display: inline-block; width: 100px; -webkit-transition-duration: 0.4s; /* Safari */  transition-duration: 0.4s;  cursor: pointer;}
.quick ul li a p{padding: 0; margin-top: 10px; margin-bottom: 0; font-size: 20px;}
.quick ul li a:hover p{color: #a12c35;}
.quick ul li a p br{display: none;}

.news { position:relative; padding-left:40px; } 
.news h3 { display:block; font-size:30px; font-weight:700; padding:0; margin-bottom:20px; color:#1f1f1f; margin-top: 0; } 
.news p { margin: 55px 0 0; font-size: 24px; font-weight: 400; } 
.news .swiper-arrow { margin: 60px 0 60px; display: flex; color: #000; } 
.news .swiper-arrow .arrow { margin: 0 8px; } 
.news .swiper-arrow .swiper-button-disabled { opacity: 0.3; } 
.news .item {} 
.news a { display: block; border-radius: 25px; border: 1px solid #ddd; overflow: hidden; margin-top: 20px;} 
.news .bg-img { height: 380px; } 

.news .info-head { padding: 15px 20px; display: flex; align-items: center; justify-content: space-between; } 
.news .info-head h4 { font-size: 18px; font-weight: 500; line-height: 1.5; } 

.news a.more { display:block; position:absolute; right:20px; top:0; border: none; margin: 0 !important; }
.news a.more i { font-size: 30px;}

@media (max-width: 1020px) {
.notice-quick{margin:0; padding:30px 0; height: auto;}	
.notice {position:relative; padding:0 ; margin:0;}
.notice h3 { font-size:20px; margin-bottom: 10px;}
.notice ul li:first-child a{ font-size:20px;}
.notice a.more { display:block; position:absolute; right:0; top:0; margin: 0; padding: 0; line-height: 0;}
.notice a.more i { font-size: 25px; vertical-align: top; margin: 0; padding: 0;}    
.notice ul li a span.date { padding-top: 10px; }

.news { position:relative; padding-left:0; }     
.news h3 { font-size:20px; margin-bottom: 10px;}  
.quick{ width: 100%; padding-left: 0; margin-top: 35px;  }    
.quick ul{display: flex; flex-flow:row wrap; margin: 0; padding: 0;}
.quick ul li{flex-basis: 50%; text-align: center; list-style: none; padding: 0 10px 20px 0; }
.quick ul li a{display: flex; flex-direction: column; text-align: center; padding:20px 0 20px;text-align:center;background:#f2f6f8;border-radius:20px;box-shadow:rgba(0,0,0,.08) 4px 4px 3px;overflow:hidden;}
.quick ul li a i{ display: block; width: 50px; align-self: center;}
.quick ul li a p{padding: 0; margin-top: 10px; margin-bottom: 0; font-size: 15px;}
.quick ul li a p br{display: block;}


}

.main-banner {width:100%;position:relative; border-radius:10px;}
.main-banner a {display:block; position: relative; width:100%;height:100%;  box-sizing:border-box;padding:40px 0 40px 50px;overflow:hidden; transition:all .3s ease;z-index:1;}
.main-banner a:before {display:block;content:'';position:absolute;top:0;right:74px;width:250px;height:168px; z-index:-1;}
.main-banner a .txt1 {display:block;font-weight:500;color:#666;}
.main-banner a .txt2 {display:block;font-weight:700;color:#333333;font-size:1.333em;padding-top:4px;transition:all .3s ease;}
.main-banner a .txt3 {display:block;font-weight:500;color:#666666;font-size:0.889em;padding-top:2px;}
.main-banner a:hover .txt2 {color:#203C92;text-decoration:underline;}
.b1 {background:#fde2e6; }
.b1 a:before {background:#fde2e6; background:url(/assets/img/bg-banner1.png) no-repeat right bottom; }
.b2 {background:#caf0fc;}
.b2 a:before {background:#caf0fc; background:url(/assets/img/bg-banner2.png) no-repeat right bottom;}
@media all and (max-width:1299px) {
	.main-banner a {padding:20px 0 0 40px;}
}
@media all and (max-width:999px) {
	.main-banner {padding-top:0;}
	.main-banner a {position:relative;top:auto;left:auto;height:auto;padding:20px 0 20px 20px;}
}
@media all and (max-width:599px) {
	.main-banner a:before {top:50%;margin-top:-90px;right:-40px;transform:scale(0.65);}
}


.main-partner { background: url("/assets/img/bg-partner.jpg")no-repeat center; height: 500px; display: flex; flex-wrap: nowrap; align-items: center; justify-content: center; color: #fff; margin-top: 50px;}
.main-partner h2 small { display: block;}
.main-partner h2 { font-weight: 500; font-size: 45px; line-height: 1.5; margin-left: 750px;}
.main-partner .btn_group a { margin: 0 10px 0 0; font-weight: 400; color: #fff; border: 1.5px solid rgba(255, 255, 255, 0.7); padding: 15px 33px; transition-duration: .4s; }
.main-partner .btn_group a.btn_down:hover { background: #FFFFFF; color: #0E2071 }
.main-partner .btn_group a.btn_link { color: #fff; font-weight: 500; }
.main-partner .btn_group a.btn_link:hover { background: #FFFFFF; color: #0E2071; }
.main-partner .btn_group a::after { display: none; }
@media (max-width: 1020px) { 
.main-partner { background: url("/assets/img/bg-partner.jpg")no-repeat center; background-size:cover; height: 300px; display: flex; flex-wrap: nowrap; align-items: center; justify-content: center; color: #fff; }
.main-partner h2 { font-weight: 500; font-size: 20px; line-height: 1.5; margin-bottom: 30px; margin-left: 0; text-align: center;}
.main-partner .btn_group a { margin: 0 10px 0 0; font-weight: 400; font-size: 14px; color: #fff; border: 1.5px solid rgba(255, 255, 255, 0.7); padding: 7px 23px; transition-duration: .4s; }
.main-partner .btn_group a.btn_down:hover { background: #FFFFFF; color: #0E2071 }
.main-partner .btn_group a.btn_link { color: #fff; font-weight: 500; }
.main-partner .btn_group a.btn_link:hover { background: #FFFFFF; color: #0E2071; }
.main-partner .btn_group a::after { display: none; }
}

.banner-swiper .swiper-slide{ width: 200px;}

/* 팝업레이어 */
#hd_pop {z-index:5800;position:relative;margin:0 auto;height:0; text-align:left;}
#hd_pop h2 {position:absolute;font-size:0;line-height:0;overflow:hidden}
.hd_pops {position:absolute;border:1px solid #e9e9e9;background:#fff;}
.hd_pops .ul-10 { margin:0; padding:0; list-style:none; }
.hd_pops .ul-10 li { margin:0; padding:0 0 5px 17px; position:relative; text-align:left; font-size:15px; }
.hd_pops .ul-10 li:before { content:''; position:absolute; left:5px; top:14px; width:4px; height:4px; background-color:#bd4146; }
.hd_pops .ul-10 li strong { font-weight:400; color:#bd4146; display:block; padding-right:10px; font-size:16px; }
.hd_pops img{max-width:100%}
.hd_pops_con { padding:12px;}
.hd_pops_con h4{ font-size:17px;}
.hd_pops_con h5{ font-size:16px; color:#d62925; border-bottom:1px dotted #d62925; border-top:1px dotted #d62925; padding:10px 0;}
.hd_pops_footer {padding: 0;background:#000;color:#fff;text-align:left;position:relative;}
.hd_pops_footer:after {display:block;visibility:hidden;clear:both;content:""}
.hd_pops_footer button {padding: 10px;border:0;color:#fff;  font-size:13px;}
.hd_pops_footer .hd_pops_reject{background:#000;text-align:left;}
.hd_pops_footer .hd_pops_close{background:#393939;position:absolute;top:0;right:0}

@media (max-width: 991px) {
.hd_pops { left: 50% !important;  margin-left: -150px !important;}
.hd_pops_con { width: 300px !important; height: 343px !important;}	
.hd_pops img{width:300px;}	
	#hd_pops_6{top: 60px !important;}
	#hd_pops_7{top: 110px !important;}
	#hd_pops_8{top: 160px !important;}
	#hd_pops_9{top: 160px !important;}
	
}

/* 사이트맵 */
.sitemap{display: flex; flex-wrap: wrap;}
.sitemap ul{list-style: none; padding:30px; margin: 0;  flex-basis: 350px; flex-grow: 0;}
.sitemap ul li{}
.sitemap ul li a{display: block; padding: 15px 0; position: relative; }
.sitemap ul li a::before{content: '-'; opacity: 0; position: absolute; left: 0; top: 15px;}
.sitemap ul li a:hover{ padding-left: 12px;}
.sitemap ul li a:hover::before{opacity: 1;  left: 0;}
.sitemap ul li a br{display: none;}
.sitemap ul li.title{padding: 25px 0; margin-bottom: 15px; border-top: 1px solid #111; border-bottom: 1px solid #ddd; font-size: 20px; color: cadetblue;}

/* 개인정보보호방침 */

.privacy .privacy-box{padding: 50px 40px; background-color: #f5f7f9; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; display: flex;  align-items: center;}
.privacy i{ font-size: 45px; flex-shrink: 0; width: 150px; text-align: center;}
.privacy .privacy-box p{margin-bottom: 0 !important; flex-grow: 1;}
.privacy h3{ font-size: 16px; margin-bottom: 10px; font-weight: 600;}
.privacy p{ margin-bottom: 30px; line-height: 2;}
.privacy .inner-p { margin-left: 16px;}
@media (max-width: 1020px) { 
.privacy .privacy-box{padding: 20px 10px; flex-wrap: wrap;}
.privacy i{ font-size: 45px; flex-grow: 1; flex-shrink: 0; width: 100%;}
}


/* 페이지 */
.greeting h4{font-family: var(--font-play); text-transform: uppercase; color: #00AC99; margin: 150px 0 20px 0; letter-spacing: 5px;}
.greeting h5{font-size: 36px; line-height: 1.5; font-weight: 500;}
.greeting p{font-size: 17px; line-height: 2.5; margin-top: 30px;}
@media (max-width: 1020px) { 
.greeting h4{font-family: var(--font-play); text-transform: uppercase; color: #00AC99; margin: 0 0 20px 0; letter-spacing: 5px; font-size: 13px;  text-align: center}
.greeting h5{font-size: 25px; line-height: 1.5; font-weight: 500; text-align: center;}
.greeting p{font-size: 15px; line-height: 2; margin-top: 30px;}
.greeting p br{display: none;}
}
.photo-swiper-row2 {overflow: hidden !important; margin-bottom: 30px;}
.photo-swiper-row2 .item { overflow: hidden; } 
.photo-swiper-row2 .bg-img { height: 400px; } 
.photo-swiper-row2 .bg-img h4 { color: #fff; font-size:35px; position: absolute; bottom: 45px; right: 45px; } 

.photo-swiper-row3 {overflow: hidden !important; margin-bottom: 30px;}
.photo-swiper-row3 .item { overflow: hidden; } 
.photo-swiper-row3 .bg-img { height: 300px; } 
.photo-swiper-row3 .bg-img h4 { color: #fff; font-size:35px; position: absolute; bottom: 45px; right: 45px; } 
@media (max-width: 1020px) { 
.photo-swiper-row2 .bg-img { height: 220px; } 
.photo-swiper-row3 .bg-img { height: 220px; } 
}

.info1 { background:#fff no-repeat 40px 40px; min-height:270px; padding:30px 50px 30px 300px; margin-bottom: 50px; border-radius: 25px; border: 2px solid #f1f1f1;}
.info1 h3 { position:relative; height:80px; color: #0a8b8e; }
.info1 h3:before { content:''; position:absolute; left:0; top:60px; width:40px; height:1px; background-color:#999; }
.info1 p {line-height: 200%; }
.info1 p strong { color: #004AA3; font-size: 17px;}

@media (max-width: 767px) {
	
.info1 { background-image:none !important; min-height:270px; padding:15px; margin-bottom: 50px;}
.info1 h3 { position:relative; height:80px; color: #0a8b8e; }
.info1 h3:before { content:''; position:absolute; left:0; top:60px; width:40px; height:1px; background-color:#999; }
.info1 p { }	
}