@charset "UTF-8";

/*버튼 컬러*/
.p_color{color: #4E4498;}
.bp_bcolor{background-color: #4E4498;}
.p_bcolor{background-color: #98398D;}
.pk_bcolor{background-color: #E83F7F;}
.pp_bcolor{background-color: #761C97;}
.b_bcolor {background-color: #0CAEFF;}
.g_bcolor {background-color: #00A75F;}
.pb_bcolor {background-color: #444A98; width: 230px !important;}

.set01 {border-bottom: 0 !important; margin-bottom: 0;}
.set02 {border-bottom: 1px solid #3E3E3E;}
.set03  {color: #049c9c; font-weight: 600;}
.set04 {background-color: #D5D5D5 !important;}
.set05 {width: 150px;}
.set06 {padding-top: 0 !important;}
.set07 {background-color: #707070 !important;}
.set08 {overflow-y: hidden;}
.set09 {font-size: 0.85rem; margin-top: 110px !important;}
.set10 {display: flex; align-items: center;}
.set11 {color: #2a2f41;}
.set12 {border-top: 3px solid #363636;}
.set13 {border: 1px solid #707070;}

colgroup {color: #4E4498;}


/* layout */
#wrap {display: flex; flex-direction: column; min-height: 100vh;}
#header {background-color:#fff; top:0; position: fixed; width: 100%; z-index: 99; box-shadow: -2px 0 5px rgba(0, 0, 0, 0.2);}
#footer {position: relative; background-color: #343849; width: 100%; bottom: 0; left: 0; }
#container { width: 100%; position: relative; padding-bottom: 68px; flex: 1;}
#subvisual {width: 100%; position: relative; background-color: #D2E0FF; height: 280px; margin-bottom: 36px;}
#layout {width:100%; max-width: 1480px; position: relative; margin:0 auto; padding: 0 26px;}
#side_layout {width: 280px; position: relative; float: left;}
#content { width: 100%; max-width: 1080px; float: right; position: relative;}
#content_login { width: 100%; max-width: 1480px; position: relative; background-color: #f7f7f7; border-radius: 10px; padding: 20px 30px 40px;}
#content_login  h2 {color:#4545A2; height: 40px; padding: 0 10px; line-height: 40px;}



/*button*/
.text_center{text-align: center; font-size: 1.2rem;}
.btn_intro{color: #fff !important; padding: 14px 50px; border-radius: 30px  0 30px 30px;  display: inline-flex; height: 50px; width: 260px; justify-content: flex-start; align-items: center; position: relative;}
.btn_intro::after {position: absolute; content: ''; width: 30px; height: 16px; right: 20px; background: url(../images/arrow_w.svg) no-repeat;}
.btn_lg{border: 1px solid #445566; background-color: #fff; border-radius: 10px; padding: 14px 30px; font-size: 0.86rem;}
.btn_g{background: #445566; border-radius: 10px; padding: 14px 30px; color: #fff; font-size: 0.86rem;}
.btn_lg02{border: 1px solid #667788; background-color: #fff; border-radius: 10px; padding: 14px 30px; font-size: 0.86rem;}
.btn_g02{background: #667788; border-radius: 10px; padding: 14px 30px; color: #fff; font-size: 1rem;}

.serch_button{background-color: #3E3E3E; border-radius: 6px; color: #fff; padding: 6px;}
.gb_button{background-color:#667788; color: #fff; border-radius: 6px; padding: 6px 16px;}
.gb_button > a:link {color: #fff;}
.gl_button{background-color: #fff; color: #3E3E3E;  border:1px solid #667788; border-radius: 6px; padding: 6px 16px;}
.tb_button {height: 40px; padding: 0 10px; line-height: 40px;}
.register{float: right;}
.register > button{padding: 10px; background-color: #667788; color: #fff; border-radius: 6px;}
.rental_btn{color: #fff; border-radius: 6px; padding: 6px; width: 80px;}

.round_button {border: 2px solid #444A98; border-radius: 30px 0px 30px 30px; background-color: transparent; cursor: pointer; margin-top: 20px;}
.round_button > a {padding: 8px 30px; display: block; position: relative; width: 180px;}
.round_button > a > span {color: #444A98; font-weight: 600; margin-right: 4px;}
.movebtn::after {position: absolute; content: ''; background: url(../images/right_up.svg)no-repeat; width: 18px; height: 18px;}

/*intro*/
.intro {display: flex; justify-content: center; padding-top: 80px;}
.introbg::before {content:''; position: absolute; left: 0; top:0; width: 100%; height: 100%; z-index: -1; background: url(../images/introbg.jpg) no-repeat; background-size: cover; opacity: 0.3;}
.intro > h1 {width: 200px;}
.intro_select {font-size:0; margin-top:60px; text-align:center;}
.intro_select > div {display: inline-block; width: calc(50% - 260px); margin: 0 50px; box-sizing: border-box;}
.intro_select_section{background-color: #fff; border-radius: 10px;}
.intro_select_section > a {cursor: pointer; display: block; overflow: hidden; border-radius: 10px; box-shadow: 0 2px 14px 0 rgba(0, 0, 0, 0.3);}
.intro_card {position: relative; overflow: hidden;}
.intro_card::before {content: ''; display: block; padding-bottom: 60%;}
.introi{position: absolute; left: 0; top: 0; width: 100%; height: 100%; object-fit: cover; }
.intro_txt { padding: 32px; background-color: #fff;}
.intro_txt > h3 {text-align: left; height: 56px; line-height: 56px;}
.intro_txt > p {overflow: hidden; height: 20px; font-size: 16px; line-height: 16px; margin: 12px 0;  display: -webkit-box; -webkit-line-clamp: 2;}
.intro_txt > strong {display: flex; align-items: center; justify-content: flex-end; height: 30px; font-size: 20px; font-weight: 700; line-height: 20px; text-align: right; margin-top: 20px; color:#4E4498;}
.intro_txt_g {color: #00824D !important;}
.arrow_g::after {background: url(../images/intro_arrow02.svg) no-repeat !important;}
.intro_txt > strong::after {content: ''; width: 30px; height: 16px; display: inline-block; margin-left: 14px; background: url(../images/intro_arrow01.svg) no-repeat;}




/* header */
#header .cont {position: relative; width: 100%; max-width: 1600px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; height: 96px; box-sizing: border-box; padding: 0 26px;}
#header .gnb {position: relative; top: 0; height: 100%; display: inline-flex; justify-content: center; align-items: center; text-align: center; font-family: SCDream;}
#header .gnb > li {font-size:18px; position: relative; display: flex; height: 100%; align-items: center; padding: 3px 1.62vw 0;}
#header .gnb > li + li::before {position: absolute; content: ''; width: 4px; height: 4px; top: 50%; background-color: #363636; border-radius: 100%; left: 0;}
#header .gnb > li > a {font-weight: 500; padding-bottom: 2px; background-size: 0 2px;  transition: background-size 0.5s; display: block;}
#header .gnb > li > a:hover  {background-size: 100% 2px; background-image: linear-gradient(#444A98, #444A98); background-repeat: no-repeat; background-position: left 0 bottom 0;}
#header .user{position: relative; color: #666666;}

#header .user > ul {display: flex;}
#header .user >ul > li > a{margin-left: 20px;position: relative;}
#header .user >ul > li > a::before{content: '';position: absolute;display:block;left:-10px;top:50%;width:1px;height:14px;transform: translateY(-50%);background-color: #e6e6e6;}
#header .user >ul > li:first-child > a{color:#056bbd ; cursor: pointer;}
#header .user >ul > li:first-child > a::before{display: none;}

/*모바일 메뉴 버튼*/
.open-btn{display:none; position:relative; width: 38px; height: 38px; background-color: #3E3E3E; border-radius: 50%; cursor: pointer;}
.open-btn span{display:block; width: 60%; height: 2px; background: rgba(255,255,225,1); color:transparent; position: absolute; top:48%; left: 20%; transition: 0.5s;}
.open-btn span:before,
.open-btn span:after{content:''; position: absolute; left:0; top:0; width:100%; height: 2px; background: rgba(255,255,255,1); transition: 0.5s;}
.open-btn span:before{top:-8px;}
.open-btn span:after{top:8px;}
.close-btn {display:block; position:relative; width: 30px; height: 30px; cursor: pointer; margin-left: auto;}
.close-btn span:before,
.close-btn span:after{content:''; position: absolute; left:0; top:0; width:100%; height: 2px; background: rgba(255,255,255,1);}
.close-btn span:before{top:50%; transform: rotate(45deg);}
.close-btn span:after{top:50%; transform: rotate(-45deg);}




/*모바일 메뉴 배경*/
.no-scroll {overflow: hidden;}
.m_aside_bg{left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.6); opacity: 0; transition: 0.4s; z-index: 999;}
.m_aside_bg.on {opacity: 1; position: fixed;}
.menu-slide {position: fixed; top: 0; right: 0; width: 300px; height: 100%; background-color: #fff;
box-shadow: -2px 0 5px rgba(0, 0, 0, 0.2); transform: translateX(100%); /* 화면 오른쪽 밖으로 숨김 */ transition: transform 0.3s ease; overflow-y: auto; visibility: hidden; opacity: 0; z-index: 1000;}
.menu-slide.on {transform: translateX(0); visibility: visible; opacity: 1; /* 메뉴가 화면 안으로 슬라이드 */}
.menu_top {background-color: #444A98; height: 80px; display: flex; align-items: center; padding: 20px;}
.menu_top > .user > span {color:#fff; cursor: pointer;}
.menu_top > .user > a {color:#fff; cursor: pointer; margin-left: 15px; font-weight: 900;}

/* 메뉴 항목 */
.menu-slide > ul > li {border-bottom: 1px solid #3E3E3E; cursor: pointer;}
.menu-slide > ul > li > a {font-size: 1.2rem; font-family: SCDream; padding: 20px; height: auto; display: flex;  background: url(../images/bg_side02.svg) no-repeat center right 20px; background-size: 26px;}

.m-depth2 { display: none; background-color: #EBF2FF;}
.m-depth2.open { display: block;}
.m-depth2 > li {border-top: 1px solid #3E3E3E;}
.m-depth2 > li > a {padding: 14px 20px; display: flex; height: auto; font-size: 1.1rem;  background: url(../images/bg_side01.svg) no-repeat center right 20px; background-size: 24px;}
.m-depth2 > li:hover > a{background: url(../images/bg_side01_on.svg) no-repeat center right 20px; background-size: 26px;}
.m-depth3 { display: none; background-color: #fff; border-top: 1px solid #3E3E3E; padding: 10px 0;}
.m-depth3 > li { margin: 0 20px; border-bottom: 1px dotted #4E4498; cursor: pointer;}
.m-depth3 > li > a {padding: 10px 20px; height: auto; display: flex; background: url(../images/bg_side03.svg) no-repeat center right 20px; background-size: 12px;}
.m-depth3 > li:last-child { border-bottom: none;}

.m-depth3.open {  display: block;}


/*footer*/
.sub_footer {background: url(../images/wave.svg) no-repeat center bottom;}
.footer-inner {max-width: 1480px; margin: 0 auto; padding: 20px 26px; color: #fff; text-align: center; line-height: 24px;}
.footer-inner > p { margin-top: 16px;}



/*main*/
#mcontainer { width: 100%; height: calc(100% - 210px); position: relative; flex: 1; display: flex; align-items: center;}
#mlayout{position: relative; width: 100%; height: 80%;  max-width: 1480px; min-height: 800px; margin: 0 auto; padding: 0 20px;}
/* .m_inner {width: 100%; height: 100%; position: absolute; background: url(../images/sub_bg.svg) no-repeat top 140px left 20px; background-size: 400px; padding: 0 20px;} */

#mainbox {display: flex; flex-wrap: wrap; justify-content: space-between; margin-top: 30px;}
.minner{padding-top: 7%;}
.mbox { padding: 0 15px;}
.mbox > h2 {margin-bottom: 14px;}
.mwrap01 {width: calc(792px); position:relative; display:flex; justify-content:flex-end; flex-direction:column;}
.mwrap02 {width: calc(100% - 792px);}
.mwrap03 {width: 27%; position: relative;}
.mnotice {width: 100%;}
.mwrap01_top {border-radius: 16px; box-shadow: 0 2px 28px #0d648a33, 0 10px 10px #0d648a33; display: flex; flex-direction: column; align-items: center; position: relative; padding: 20px 32px; height: 230px;}
.mwrap01_top::before {position: absolute; content: ''; background: url(../images/sub_bg_m.svg)no-repeat center; top: -180px; width: 100%; height: 180px;}

.notitit {width: 100%; padding-bottom: 10px; display: flex; justify-content: space-between;}
.notitit > a {background: url(../images/more.svg)no-repeat center center; font-size: 0; width: 30px; height: 30px; display: block; border-radius:50%; box-shadow: 0 2px 10px #0d648a33, 0px 0px #0d648a33; position: relative; background-size: 15px;}


.mwrap01_bottom {position: relative; width: 100%; padding-top: 24px;}
.mnotice > li { border-bottom: 1px dashed #9E9E9E; position: relative; cursor: pointer; width: 100%;}
.mnotice > li:hover {background-color: #EBF2FF;}
.mnotice > li:hover strong {font-weight: 600;}
.mnotice > li:last-child{border-bottom: none;}
.mnotice > li > a { font-size: 1.1rem; padding: 12px 10px; display: block;}
.mnotice > li > a > strong { display: inline-block; width: calc(100% - 100px); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mnotice > li > a > span { position:absolute; top: 14px; right: 10px; color: #444A98; font-size: 1rem; }
.mguidebox { width: 100%; margin-top: 10px; display: flex; justify-content: space-between; gap: 24px;}
.mguidebox > li {width: 230px; height: 146px; display: flex; justify-content: center; flex-direction: column; border-radius: 10px; padding: 24px 16px; position: relative; overflow: hidden;}
.mguidebox > li:nth-child(1) {background: #C6EBFF; color: #444A98;}
.mguidebox > li:nth-child(1)::before {position: absolute; content: ''; background: url(../images/mg01.png)no-repeat; width: 120px; height: 120px; top: -50px; left: -50px; background-size: 100%;}
.mguidebox > li:nth-child(2) {background: #FFF5C5; color: #761C97;}
.mguidebox > li:nth-child(2)::before {position: absolute; content: ''; background: url(../images/mg02.png)no-repeat; width: 120px; height: 120px; top: -50px; left: -50px; background-size: 100%;}
.mguidebox > li:nth-child(3) {background: #FFC8ED; color: #E83F7F;}
.mguidebox > li:nth-child(3)::before {position: absolute; content: ''; background: url(../images/mg03.png)no-repeat; width: 120px; height: 120px; top: -50px; left: -50px; background-size: 100%;}

.mguidebox > li > div {height: 100%;}
.mguidebox > li > div > em { display: block; text-align: right; font-size: 20px; padding-bottom: 18px; font-weight: 600;}

.mguidelist {color: rgba(0,0,0);}
.mguidelist > dl {display: flex; margin-top: 10px;}
.mguidelist > dl > dd {padding-left: 12px;}

.mpopupcont {border-radius: 16px; box-shadow: 0 2px 28px #0d648a33, 0 10px 10px #0d648a33; display: flex; flex-direction: column; align-items: center; position: relative; padding: 14px; margin-bottom: 50px;}
.mpopuptxt {display: flex; justify-content: space-between; width: 100%; padding: 2px 0px 16px 0px;}
.popupbtns {display: flex; flex-direction: column;}
.mpopup { width: 93%;  background-color: #3E3E3E; border-radius: 5px; overflow: hidden; position: relative;}
.slider {position: relative; width: 100%; overflow: hidden; border-radius: 5px; margin: 0 auto; z-index: 1;}
.slides {position: relative; width: 100%; z-index: 1; display: flex; padding: 0; margin: 0; box-sizing: content-box; transition: transform 1s ease-in-out;}
.slide {flex-shrink: 0; position: relative; width: 100%;}
/* .slide > a {display: block; width: 100%; height: 100%; position: relative; overflow: hidden;} */
/* .slide > img {width: 100%; height: 100%; object-fit: cover; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); display: block; max-width: none; max-height: none;} */
.slide > div {display:block; padding-bottom:56.3%; position:relative; overflow:hidden;}
.slide > div > img {  width: 100%; height: 100%; position: absolute; left: 0; top: 0;}

.mpopupbtns {display: flex; gap: 14px; position: relative;}
.mpopupbtns > button{width: 30px; height: 30px; border-radius: 50%; box-shadow: 0 2px 10px #0d648a33, 0px 0px #0d648a33; color: transparent; position: relative; background-color: rgb(255, 255, 255);}
.mprev::before {position: absolute; content: ''; background: url(../images/bg_selectArrow.svg)no-repeat; left: 50%; top: 50%; transform: translate(-50%, -50%) rotate(90deg); width: 12px; height: 12px;}
.mnext::before {position: absolute; content: ''; background: url(../images/bg_selectArrow.svg)no-repeat; left: 50%; top: 50%; transform: translate(-50%, -50%) rotate(-90deg); width: 12px; height: 12px;}
.mstop::before {position: absolute; content: ''; background: url(../images/bg_player_stop.svg)no-repeat; left: 50%; top: 50%; transform: translate(-50%, -50%);  width: 12px; height: 12px;}
.mstart::before {position: absolute; content: ''; background: url(../images/bg_player_start.svg)no-repeat; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 12px; height: 12px;}
.mstart {display: none;}

.mQuick {display: flex; align-items: center; width: 100%; padding: 30px 0px 20px 0px;}
.mQuick > h2 {color: #444A98; font-size: 30px; text-align: center;}
.mQuicklist {display: flex; justify-content: space-between; align-items: center; width: 100%; padding-left:20px;}
.mQuicklist > li {display: flex; justify-content: center; width: 130px; align-items: flex-end;}
.mQuicklist > li a {display: flex; position: relative; flex-direction: column; gap: 8px; align-items: center; font-weight: 500;}
.mQuicklist > li a em {padding-left: 5px;}
.mQuicklist > li:hover > a {color: #444A98; font-weight: 600;}
.mQuicklist > li a img {width: 100px;}

/*팝업 문구*/
.file_btn > div {color:#C92525}

/*aside*/
#side_layout > h1 { background-color:#444A98; height: 140px; display: flex; justify-content: center; align-items: center; border-radius: 16px 16px 0 0; color: #fff; font-family: TTWanjudaedunsancheB; font-size: 1.6rem;}
.depth2_cont > ul {border: 1px solid #727272; border-radius: 16px; background-color: #fff; position: relative; width: 100%; top: -15px; padding: 24px 28px;}
.depth2_cont > ul > li {border-bottom: 1px solid #727272;}
.depth2_cont > ul > li:last-child {border-bottom: 0;}

.depth2_cont > ul > li.on {border-bottom: 1px solid #4E4498;}
.depth2_cont > ul > li.on:last-child {border-bottom: 0;}

.depth2_cont > ul > li.on > a {color: #4E4498; font-weight: 700; background: url(../images/bg_side01_on.svg) no-repeat center right 20px; background-size: 24px;}
.depth2_cont > ul > li > a { height: 60px; display: flex; align-items: center; padding-left: 10px; cursor: pointer; font-size: 1.1rem; background: url(../images/bg_side01.svg) no-repeat center right 20px; background-size: 24px;}
/*.depth2_cont > ul > li:hover a {color: #fff; background-color: #363636;}*/
.depth3_cont{display: none; background-color: #fff; border-top: 0;}
.depth3_cont > li {padding: 0 12px;}
.depth3_cont > li > a {height: auto; display: flex; padding: 14px 0; border-bottom: 1px dotted #BEBEBE; background: url(../images/bg_side03.svg) no-repeat center right 14px; background-size: 10px;}
.depth3_cont > li:last-child> a {border-bottom: 0;}
.depth3_cont.on {display: block; }
.depth3_cont > li.on > a {color:#4E4498; font-weight: 600; background: url(../images/bg_side03_on.svg) no-repeat center right 14px; background-size: 10px;}


/*.selected {background-color: #3E3E3E !important;}*/


.title_wrap {display: flex; align-items: flex-end; border-bottom: 1px solid #707070; height: 60px; padding-bottom: 10px; margin-bottom: 35px;}
.title_wrap > h2 {font-size: 1.6rem;}
.location_wrap {margin-left: auto;}
.location_wrap > ul {display: inline-flex; align-items: center; position: relative;}
.location_wrap > ul > li {padding: 0 0.4vw 0;}
.location_wrap > ul > li + li::before {content: ''; border-top: 4px solid transparent; border-bottom: 4px solid transparent; border-left: 6px solid #C7C7C7; position: relative; display: inline-block; width: 10px;}

/*tab*/
.tab_list {display: flex; border: 1px solid #444A98;}
.tab_list > li {width: calc(100%/2); text-align: center; }
.tab_list > li > a {display: block; height: 46px; line-height: 46px;}
.tab_list > li > a.on {background-color: #444A98; color: #fff; font-weight: 600;}
.tab02 {display: none;}

/*content*/
.subtitle{position: relative; width:100%; max-width: 1480px; height: 100%; margin: 0 auto; background: url(../images/sub_bg.svg) no-repeat bottom 12px right 20px; background-size: 500px;}
.subtitle_wrap {position: absolute; top: 58%; left: 40px;}
.subtitle_wrap > span {font-family: TTWanjudaedunsancheB; font-size: 3rem;}
.subtitle_wrap > p {font-size: 1.2rem; padding-top: 6px; }

/*소개*/
.sub_banner {position: relative; max-width: auto; height: 300px; background: url(../images/banner.png) no-repeat center center; background-size: cover; border-radius: 10px;}
.sub_inner {text-align: center;}
.sub_inner > p {margin-top: 20px; line-height: 1.6;}
.bnr_list{display: flex; flex-wrap:wrap; margin: 64px 0;}
.bnr_list > li {flex:1 1 calc(33.333% - 32px); height: 400px; display: flex; align-items: center; justify-content: center; box-sizing: border-box;}
.bnr_list > li > p { position: relative; top: 42px; line-height: 1.6; text-align: center;}
.bnr_list > li:nth-child(1) { background: url(../images/section01.png) no-repeat center center;}
.bnr_list > li:nth-child(2) { background: url(../images/section02.png) no-repeat center center;}
.bnr_list > li:nth-child(3) { background: url(../images/section03.png) no-repeat center center;}

.banner {overflow: hidden; position: relative; border-radius: 10px;}
.banner::before {content: ''; display: block; padding-bottom: 40%;}
.banner > img {position: absolute; top: 0; left: 0; width: 100%; height: 100%;}

.inner_wrap {display: flex; flex-wrap: wrap;}
.img_inner {width: calc(420px); float: left; padding: 0; border: 0; padding-right: 28px;}
.sub_img {overflow: hidden; position: relative; border-radius: 12px;}
.sub_img::before {content: ''; display: block; padding-bottom: 64%;}
.sub_img > img {position: absolute; top: 0; left: 0; width: 100%; height: 100%;}
.sub_txt {width: calc(100% - 420px); float: right;}
.sub_txt > h2 {font-weight: 500; margin-bottom: 20px;}
.sub_txt > em {padding-top: 18px; display: block; font-weight: 600; padding-bottom: 4px;}
.service_txt > p {padding:2px 0px 2px 14px;  position: relative; }
.service_txt > p::before {content: '-'; position: absolute; width: 10px; height: 10px; left: 0;}


.info_list {display: flex; flex-wrap: wrap;}
.info_list > li {width: 100%; margin: 20px 0;}

.pro_inner > p {line-height: 1.4;}
.pro_inner > h3 {color: #444A98; font-weight: 600; margin: 24px 0px; font-size: 26px;}

.vision {width: 100%; position: relative; display: flex; flex-direction: column; padding-bottom: 140px;}
.vision_tit {width: 470px; margin: 0 auto; text-align: center; position: relative;}
.vision_tit::after {position: absolute; content: ''; background: url(../images/obj01.svg) no-repeat; width: 54px; height: 52px; top: -3px; left: -46px;}
.vision_tit::before {position: absolute; content: ''; background: url(../images/obj02.svg) no-repeat; width: 74px; height: 72px; top: -18px; right: -76px;}


.vision p {font-size: 30px; color: #444A98; font-weight: 700; position: relative;}
.vision p::after { position: absolute; content: '';  bottom: -4px; left: 0px; width: 100%; height: 14px; background-color: #D2E0FF; z-index: -1;}
.vision_list {display: flex; flex-wrap: wrap; justify-content: center; width: 100%; margin-top: 50px;}
.vision_list > li {width: calc(100% / 5 - 20px); display: inline-block; margin: 0 -15px;}
.vision_list > li > div { border-radius: 50%; padding-top: 100%; position: relative; background-size: 30%;}
.vision_box01 > div {border: 1px solid #3D1193; background: url(../images/str11.png)  center center no-repeat;}
.vision_box01 > div > div::before,
.vision_box01 > div > div::after {background: #3D1193;}
.vision_box02 > div {border: 1px solid #6C2489; background: url(../images/str02.png)  center center no-repeat;}
.vision_box02 > div > div::before,
.vision_box02 > div > div::after {background: #6C2489;}
.vision_box03 > div {border: 1px solid #E83F7F; background: url(../images/str10.png) center center no-repeat;}
.vision_box03 > div > div::before,
.vision_box03 > div > div::after {background: #E83F7F;}
.vision_box04 > div {border: 1px solid #12B9E0; background: url(../images/str05.png)  center center no-repeat;}
.vision_box04 > div > div::before,
.vision_box04 > div > div::after {background: #12B9E0;}
.vision_box05 > div {border: 1px solid #14DBDB; background: url(../images/str03.png)  center center no-repeat;}
.vision_box05 > div > div::before,
.vision_box05 > div > div::after {background: #14DBDB;}

.vision_list > li > div > div {position: absolute; width: 100%;}
.vision_list > li > div > div::after {position: absolute; display: block; content: ''; width: 10px; height: 10px; position: absolute; border-radius: 50%; left: 50%; transform: translateX(-50%); bottom: 30px;}
.vision_list > li:nth-child(even) > div > div::before {height: 80px;}
.vision_list > li:nth-child(even) > div > div > span {top: 55px;}
.vision_list > li > div > div::before {position: absolute; display: block; content: ''; width: 1px; height: 110px; left: 50%; transform: translateX(-50%); top: -32px;}
.vision_list > li > div > div > span {position: absolute; display: block; left: 50%; transform: translateX(-50%); top: 85px; color: #444A98; font-size: 18px; font-weight: 500; width: 100%; text-align: center;}


.strategy {width: 100%;}
.strategy_cont {width: 100%; position: absolute;}
.strategy_cont::before {content: ''; display: block; padding-bottom: 40%;}
.strategy_cont > img {position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover;}

.strategy_bg {width: calc(100% - 48px); margin-bottom: 40px; overflow: hidden; position: relative; border-radius: 120px; top: 0;}
.strategy_bg::before {content: ''; display: block; padding-bottom: 21%;}
.strategy_bg > img {position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover;}

.strategy_list {display: flex; flex-wrap: wrap; font-size: 14px; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 100%; justify-content: center; gap: 40px;}
.strategy_box01 {background: rgba(0, 0, 0, 0.10) url(../images/visionW01.svg)  center top 36% no-repeat;}
.strategy_box02 {background: rgba(0, 0, 0, 0.10) url(../images/visionW02.svg)  center top 30% no-repeat;}
.strategy_box03 {background: rgba(0, 0, 0, 0.10) url(../images/visionW03.svg)  center top 30% no-repeat;}
.strategy_box04 {background: rgba(0, 0, 0, 0.10) url(../images/visionW04.svg)  center top 30% no-repeat;}
.strategy_box05 {background: rgba(0, 0, 0, 0.10) url(../images/visionW05.svg)  center top 30% no-repeat;}

.strategy_list > li > div {backdrop-filter: blur(6px); border-radius: 50%; display: flex; flex-direction: column; justify-content: center; align-items: center; border: 1px solid #fff; padding-top: 100%; position: relative; background-size: 48%;}
.strategy_list > li > div > img {width: 35%;}
.strategy_list > li > div > span {padding-top: 20px; color: #fff;}

.strategy_list > li {width: calc(100% / 5 - 60px); display: inline;}
.strategy_list > li > div > div { position: absolute; bottom: 15%; color: #fff;}


.str02_wrap{width: 100%; display: flex; flex-wrap: wrap;justify-content: center; align-items: center; position: relative; padding-top: 70px;}
.str02_cont {display: flex; width: calc(100% - 48px); gap: 40px;}
.str02_cont > div {background-color: #fff; border: 1px solid #4E4498; border-radius: 130px; width: 100%; display: flex; align-items: center; box-shadow: 2px 0 5px rgba(78, 68, 152, 0.2);}
.str02_list {padding: 40px 66px; width: 100%;}
.str02_list > li {padding: 3px 10px; position: relative; color: #4E4498;}
.str02_list > li::before {position: absolute; content: ''; width: 3px; height: 3px; border-radius: 50%; background-color: #363636; left: 0; top: 12px;}

.str03_cont {width: 100%;}
.str03_cont > h3 { text-align: center; color: #444A98; margin-top: 40px; font-size: 21px;}
.str03_list { display: flex; flex-wrap: wrap; gap: 20px 12px; justify-content: space-between; margin-top: 30px;}
.str03_list > li { width: calc(100% / 3 - 12px); border: 1px solid #727272; border-radius: 12px; height: 160px; font-size: 14px; box-shadow: 2px 0 5px rgba(0, 0, 0, 0.2);}


.str03_list > li > div { padding: 20px;}
.str03_box > span {display: block; border-bottom: 1px solid #b0b0b0; padding-bottom: 10px; color: #444A98; font-weight: 500; font-size: 18px;}
.str03_box > span > img {width: 28px; margin-right: 10px;}
.str03_box > div {padding: 12px 6px;}
.str03_box > div > p {padding: 0px 10px 10px; position: relative;}

.str03_list > li:nth-child(2), .str03_list > li:nth-child(5),.str03_list > li:nth-child(8) {background:#4B4F60; color: #fff;}
.str03_list > li:nth-child(2) span, .str03_list > li:nth-child(5) span, .str03_list > li:nth-child(8) span {color: #fff !important;}

.str03_list > li p::before {position: absolute; content: ''; width: 3px; height: 3px; border-radius: 50%; background-color: #363636; left: 0; top: 7px;}
.str03_list > li:nth-child(2) p::before, .str03_list > li:nth-child(5) p::before, .str03_list > li:nth-child(8) p::before {position: absolute; content: ''; width: 3px; height: 3px; border-radius: 50%; background-color: #b1b1b1; left: 0; top: 7px;}

.details_box > li > span {display: block; background:#445566; color: #fff; text-align: center; border-radius: 8px 8px 0px 0px; padding: 10px 0px;}
.details_box > li > div {border: 1px solid #BEBEBE; height: 130px; border-radius: 0px 0px 8px 8px; padding: 10px; margin-bottom: 24px; text-align: center; display: flex; flex-wrap: wrap; justify-content: center; align-items: center;}
.details_box > li > div > p {padding-bottom: 10px;}

.strategy_inner{background-color: #fff; border-radius: 10px; width: calc(33.333% - 14px); box-shadow: 0 2px 14px 0 rgba(0, 0, 0, 0.3);}
.strategy_inner > div {cursor: pointer; display: block; overflow: hidden; border-radius: 10px; }
.strategy_card {position: relative; overflow: hidden;}
.strategy_card::before {content: ''; display: block; padding-bottom: 60%;}
.strategy_txt { padding: 18px 21px 24px; background-color: #fff; border-radius: 0 0 10px 10px; height: 180px; }
.strategy_txt > em {text-align: left; font-size: 21px; display: inline-block; padding-bottom: 16px;}
.strategy_txt > ul > li {position: relative; padding: 0px 0px 6px 10px;}
.strategy_txt > ul > li::before { position: absolute; content:''; top:35%; width: 3px; height: 3px; border-radius: 50%; background-color: #363636; left: 0;}
.strategy_txt > p { font-size: 16px; line-height: 16px; margin: 12px 0;  display: -webkit-box; -webkit-line-clamp: 2;}


.class_wrap{width: 100%; display: flex; flex-wrap: wrap;justify-content: center; align-items: center; position: relative; padding-top: 10px;}
.class_list {display: flex; flex-wrap: wrap; font-size: 14px; width: 100%; justify-content: space-between; gap: 40px;}
.class_box01 {background: url(../images/class01.png)  center center no-repeat;}
.class_box02 {background: url(../images/class03.png)  center center no-repeat;}
.class_box03 {background: url(../images/class04.png)  center center no-repeat;}
.class_box04 {background: url(../images/class05.png)  center center no-repeat;}
.class_box05 {background: url(../images/class02.png)  center center no-repeat;}
.class_box06 {background: url(../images/class07.png)  center center no-repeat;}
.class_box07 {background: url(../images/class08.png)  center center no-repeat;}
.class_box08 {background: url(../images/class09.png)  center center no-repeat;}
.class_box09 {background: url(../images/class10.png)  center center no-repeat;}
.class_box10 {background: url(../images/class06.png)  center center no-repeat;}
.classC {border-radius: 50%; display: flex; flex-direction: column; justify-content: center; align-items: center; border: 2px solid #4D668F; padding-top: 100%; position: relative; background-size: 78%;}
.class_list > li > div > img {width: 35%;}
.class_list > li > div > span {padding: 20px 0; display: block; text-align: center; font-size: 18px; font-weight: 500; padding-bottom: 10px;}

.class_list > li {width: calc(100% / 5 - 60px); display: inline;}



.build {width: calc(100%); background-color: #444A98; border-radius: 12px 0px 12px 0px; text-align: center; padding: 36px 0; margin-top: 54px;}
.build > h3 {color: #fff;}
.build_list { display: flex; flex-wrap:wrap; gap: 24px; width: 94%; margin: 0 auto; padding-top: 32px;}
.build_inner{background-color: #fff; border-radius: 10px; width: calc(50% - 15px); position: relative;}
.build_inner > div {cursor: pointer; display: block; overflow: hidden; border-radius: 10px;}

.build_card {position: relative; overflow: hidden;}
.build_card::before {content: ''; display: block; padding-bottom: 34%;}
.build_inner > div > span {position: absolute; color: #fff; top: 50%; display: table; width: 100%;}


.target_list{display: flex; flex-wrap:wrap; margin: 64px 0;}
.target_list > li {flex:1 1 calc(25% - 32px); height: 300px; display: flex; align-items: center; justify-content: center; box-sizing: border-box; flex-direction: column; padding-top: 68px;}
.target_list > li > p { position: relative; line-height: 1.6; text-align: center;}
.target_list > li:nth-child(1) { background: url(../images/target01.svg) no-repeat center center;}
.target_list > li:nth-child(2) { background: url(../images/target02.svg) no-repeat center center;}
.target_list > li:nth-child(3) { background: url(../images/target03.svg) no-repeat center center;}
.target_list > li:nth-child(4) { background: url(../images/target04.svg) no-repeat center center;}
.target_list > li > em { display: block; font-size: 21px; font-weight: 500;}
.target_list > li:nth-child(1) > em {color: #3D1193;}
.target_list > li:nth-child(2) > em {color: #E83F7F;}
.target_list > li:nth-child(3) > em {color: #6C2489;}
.target_list > li:nth-child(4) > em {color: #12B9E0;}

/*스마트서비스*/
.content_map_wrap {display: table; width: 100%;}
.content_map_wrap > div {display: table-cell; vertical-align: top; }
.content_map_title {width: calc(300px); background: #444A98; color: #fff; border-radius: 12px 0 0 12px; border: 1px solid #444a98;}
.map_title_wrap {padding: 0px 20px; display: flex; flex-direction: column; justify-content: center; height: 110px; }
.map_title_wrap > h3 {color: #fff; font-size: 25px; padding-bottom: 8px;}
.map_list {height: 374px; overflow-y: auto; background-color: #F2F6FF; border-radius: 0px 0px 0px 10px;}
.map_list > ul {color: #343849;}
.map_list > ul > li {padding: 0px 20px; cursor: pointer; display: flex;}
.map_list > ul > li:last-of-type > div {border: none;}
.map_list > ul > li.on {background-color: #D2E0FF;}


.scroll::-webkit-scrollbar{width: 15px;}
.scroll::-webkit-scrollbar-thumb{background-color: #6C2489;/* 스크롤바 둥글게 설정    */border-radius: 15px; border: 4px solid #F2F6FF; }
.scroll::-webkit-scrollbar-track{background-color: transparent;}


.map_list_section {padding:20px 0px 20px 22px; position: relative; width: 100%; border-bottom: 1px solid #445566;}
.map_list_section::before {position: absolute; content: ''; background: url(../images/address.svg) no-repeat; width: 20px; height: 20px; left: 0;}
.map_list_section.on::before {position: absolute; content: ''; background: url(../images/addressOn.svg) no-repeat; width: 20px; height: 20px; left: 0;}

.map_list_section > em {display: block; padding-bottom: 8px; font-size: 18px; font-weight: 500; position: relative;}
.map_list_section > em::after {position: absolute; content: ''; background: url(../images/intro_arrow01.svg) no-repeat; width: 24px; height: 12px; top: 4px; margin-left: 10px; display: none;}
.map_list_section.on > em::after {display: inline;}

/*.map_item.active .map_list_section > em::after {visibility: visible;}*/

.content_map_wrap .content_map .mapbox {width: 100%; height: 486px; background: #000; border-radius: 0 12px 12px 0;}
.content_map {position: relative;}


/*홍보동영상*/
.video_wrap {display: flex; flex-direction: column; align-items: center;}
.video_tit {text-align: center; margin-bottom: 20px; position: relative;}
.video_tit::after {position: absolute; content: ''; background: url(../images/dot02.svg) no-repeat; width: 54px; height: 52px; top: -8px; right: -56px;}
.video_tit::before {position: absolute; content: ''; background: url(../images/dot01.svg) no-repeat; width: 54px; height: 52px; bottom: -8px; left: -74px;}
.video_tit > h3 {font-size: 26px; font-weight: 500;}
.video_tit > h3 > span {width: 8px; height: 8px; border-radius: 50%; display: inline-block; background:#F23113; text-indent: -9999px; vertical-align: bottom; margin: 4px;}
.video_tit > h2 {font-size: 31px; color: #444A98;}

.video_container {background: #fff; border-radius: 28px; box-shadow: 0 2px 28px #0d648a33, 0 10px 10px #0d648a33; display: flex; align-items: center; height: 100%; width: 100%; position: relative; justify-content: center;}

.video_frame {border: unset; border-radius: 18px; height: 100%; width: 100%; margin: 15px; display: flex; align-items: center; justify-content: center; overflow: hidden; cursor: pointer;}
.video_frame > video {height: 100%; width: 100%; object-fit: cover;}




/*예약하기*/
.gallery{display: flex; flex-wrap: wrap; width: 100%;}
.gallery_box{ width: calc(486px); float: left; padding: 0; border: 0; padding-right: 28px;}
.gallery_info{width: calc(100% - 486px); float: right;}
.phrase {color: #F23113; font-weight: 500; padding-top: 16px; display: block;}
.gallery_scale {display: flex; border-bottom: 1px solid #707070;}
.gallery_scale > li {padding: 10px 30px 10px 10px; position: relative;}
.gallery_scale li span {padding-right: 10px; font-weight: 500;}
.gallery_scale li span::before { position: absolute; content:''; top:42%; width: 3px; height: 3px; border-radius: 50%; background-color: #363636; left: 0;}
.gallery_scale li em {padding-right: 20px;}
.gallery_txt{ padding-top: 10px; line-height: 24px; position: relative;}
.gallery_txt li {padding-left: 12px;}
.gallery_txt li::before {position: absolute; content: '-'; left: 0;}
.guide_txt{border:6px solid #707070; padding: 26px 10px; margin: 36px 0; border-image: url(../images/line.png) 9 round; background: url(../images/clock.svg) no-repeat left 16px center; background-size: 40px;}
.guide_txt > p {padding: 0 58px;}
.select_wrap{ display: flex; border-top: 3px solid #363636; width: 100%;  justify-content: space-between; flex-wrap: wrap; margin-bottom: 50px;}
.select_contc{max-width: 100%; flex: 1 1 calc(100%); border-bottom: 3px solid #363636; padding-bottom: 24px;}
.select_contl, .select_contr{width: calc(50% - 20px); max-width: calc(50% - 20px);}
.prev, .next { cursor: pointer;}
.prev {background: url(../images/prev.svg) no-repeat center center; width: 20px; height: 20px;}
.next {background: url(../images/next.svg) no-repeat center center; width: 20px; height: 20px;}
.people_wrap {display:none;}
.people_wrap.active {display:flex;}
.select_tit {display: flex; align-items: center; height: 60px; justify-content: center; border-bottom: 1px solid #363636;}
.select_tit span {color: #049c9c; font-size: 1.2rem; font-weight: 700;}
.calendar_txt {overflow: hidden; position: absolute; padding: 0; display: block; clip: rect(0,0,0,0);}
.radiobx_wrap{margin-bottom: 30px;}

/*스마트서비스*/
.service01 {background: url(../images/service01.svg) no-repeat left 16px center; background-size: 40px;}
.service02 {background: url(../images/service02.svg) no-repeat left 16px center; background-size: 40px;}
.service03 {background: url(../images/service03.svg) no-repeat left 16px center; background-size: 40px;}
.service04 {background: url(../images/service04.svg) no-repeat left 16px center; background-size: 40px;}
.service05 {background: url(../images/service05.svg) no-repeat left 16px center; background-size: 40px;}
.service06 {background: url(../images/service06.svg) no-repeat left 16px center; background-size: 40px;}
.service07 {background: url(../images/service07.svg) no-repeat left 16px center; background-size: 40px;}
.service08 {background: url(../images/service08.svg) no-repeat left 16px center; background-size: 40px;}



/*달력 시간*/
.calendar_tbl, .time_tbl{width: 100%;}
.calendar_tbl th, .time_tbl th{border-bottom: 1px solid #C9C9C9;}
.calendar_tbl th, .calendar_tbl td, .time_tbl th {height: 60px; text-align: center; padding: 10px 0; font-size: 1.2rem;}
.time_tbl td {font-size: 1rem; text-align: center; height: 50px;}
.calendar_info {position: relative; border-top: 1px solid #C9C9C9; border-bottom: 1px solid #C9C9C9; padding: 18px 0; margin-top: 26px;}
.circle_p::before {content:''; display: inline-block; position: absolute; width: 20px; height: 20px; left: 0; background-color: #4E4498; border-radius: 50%;}
.circle_g::before {content:''; display: inline-block; position: absolute; width: 20px; height: 20px; left: 90px; background-color: #667788; border-radius: 50%;}
.circle_p, .circle_g {padding:0 30px;}

.past-date {color: #c4c4c4; cursor:  default !important;/* 지난 날짜의 색상 */}
.calendar_tbl th, .calendar_tbl td {cursor: pointer; /* 날짜 커서*/}
.calendar_tbl td.on {background:url(../images/circle_on.svg) no-repeat center center; background-size: 40px; color: #fff; /*날짜 선택*/}
.chkbx input:disabled + .checkmark { background-color: #f0f0f0; cursor: not-allowed; /* 비활성화 상태 */
}

.signup_wrap {width: 100%; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; text-align: center; min-height: 300px;}
.signup_wrap::before {content: ''; position: absolute; top: 130px; background: url(../images/check.svg); width: 100px; height: 100px;}
.signup_loginwrap::before {content: ''; position: absolute; top: 300px; background: url(../images/check.svg) no-repeat; width: 100px; height: 100px;}
.signup_txt {position: relative; padding-top: 110px;}
.signup_txt > strong {font-size: 1.45rem;}
.signup_txt > p { margin-top:20px; padding: 10px 40px; background-color:#F5F5F5; border-radius: 30px;}

.select_list{position: relative;}
.select_list > li {padding-left: 10px; margin: 8px 0; position: relative; display: flex;}
.select_list > li::before { position: absolute; content:''; top:42%; width: 3px; height: 3px; border-radius: 50%; background-color: #363636;}
.select_list > li >span{width: 100px; padding-left: 10px;}
.select_list > li > em {padding-left: 20px;}
.number{display: flex;}
.number> p {width: 15%;}
.number> ul {margin-left: 20px; width: calc(100% - 15%);}
.number> ul > li {margin-bottom: 8px;}
.number> ul > li > input {width: 100%;}
.search_box {width: 100%; display: flex; align-items: center; justify-content: center; margin-bottom: 16px;}
.search_box > input {width: calc(100% - 60px); margin-right: 10px;}
.search_box > button {width: 60px;}

.id_list {width: 100%; max-height: 240px; overflow-y: auto;}
.id_list ul li {padding: 10px 10px 10px 0px;}
.id_list ul li button { width: 60px; float: right; padding: 4px; border-radius: 6px; border: 1px solid #3E3E3E; background-color: #fff;}
.id_list ul li button:hover{background-color: #3E3E3E; color: #fff;}

.study_tbl > table {width: 100%; border-top: 1px solid #3E3E3E;}
.study_tbl > table > tbody > tr {height: 48px; border-bottom: 1px solid #C4C4C4;}
.study_tbl > table > tbody > tr > th,
.study_tbl > table > tbody > tr > td {border-bottom: 1px solid #C4C4C4;}
.study_tbl > table > tbody > tr > th {background-color: #F6F7F8; border-right: 1px solid #C4C4C4;}
.study_tbl > table > tbody > tr > td {padding: 20px;}

.total_wrap {display: flex; align-items: flex-end; justify-content: space-between; padding: 26px 0 10px 0; border-bottom: 1px solid #3E3E3E;}
.sch_box {margin-left: auto; }
.sch_box > select {height: 40px; width: 100px; cursor: pointer;}
.period > input {height: 40px; cursor: pointer;}
.inputbox {display: flex; gap: 6px; justify-content: center; align-items: center; border-radius: 8px; padding: 20px 10px; border: 2px solid #bec9cf; margin-bottom: 10px; position: relative;}
.inputbox::after {position: absolute; content: ''; height: 30px; width:100%; top: -2px; left: -2px; border-radius: 8px 8px 0 0; border-right: 2px solid #444A98; border-left: 2px solid #444A98; border-top: 2px solid #444A98;}
.sch_sel > select, .sch_sel > input {height: 40px;}
.sch_sel > button {background-color: #3E3E3E; border-radius: 6px; color: #fff; padding: 10px; width: 60px;}

/* 공지사항 */
.bord {width:100%; border-top:1px solid #667788; border-bottom: 1px solid #C4C4C4;}
.bord > h4{ display:block; padding: 20px 12px;font-size:1.2rem; font-weight:500;
word-wrap: break-word;
white-space: -moz-pre-wrap;
white-space: pre-wrap;
}
.bordlist {border: 1px solid #C4C4C4; border-left: 0; border-right: 0; padding: 12px;}
.bordlist dl{display: flex; width: 100%;}
.bordlist dl > dd {padding-right:10px}

.question > span {word-wrap: break-word;white-space: -moz-pre-wrap;white-space: pre-wrap;}
.answer > p {word-wrap: break-word;white-space: -moz-pre-wrap;white-space: pre-wrap;}

.filelist {background-color: #F6F7F8; border-bottom: 1px solid #C4C4C4; padding: 12px;}
.filelist ul > li {display: flex; align-items: center;}
.filelist ul > li > img {width: 30px; margin-right: 5px;}
.btnlist {margin-top: 20px; display: flex;}
.btnlist_left > button { padding: 10px; background-color: #fff; border: 1px solid #3E3E3E; border-radius: 6px; width: 68px;}
.btnlist_right{margin-left: auto;}
.btnlist_right > button {padding: 10px; background-color: #3E3E3E; border: 1px solid #3E3E3E; border-radius: 6px; width: 68px; color: #fff;}
.readh{min-height:200px; padding:12px;}
.readh > pre { word-break:break-all; overflow-wrap:break-word; white-space:pre-wrap;}

.text-right {margin-bottom: 14px;}
.text-right > div{display: flex; margin: 14px 0;}
.text-right > span {color: #919191;}
.text-right > p {margin-bottom: 10px;}
.text-btn {margin-left: auto;}
.text-btn > a {cursor: pointer; margin-left: 10px;}
.commentwrite{display: flex;}
.commentwrite > div {flex-grow: 1; border: 1px solid #c4c4c4; border-right: none; height: 80px; position: relative;}
.form-control {width: 100%; height: 100%; padding: 14px; border: none; resize: none;}
.commentwrite > button {width: 100px; background-color: #3E3E3E; color: #fff;}

/*자주 묻는 질문*/
.qa_wrap > ul > li{padding-bottom: 20px;}
.question{background: url(../images/question.svg) no-repeat center left 20px; background-size: 40px; border: 1px solid #B5B5B5; border-radius: 5px; padding: 24px 20px 24px 68px; cursor: pointer;}
.answer{background: url(../images/answer.svg) no-repeat center left 20px; background-size: 40px; border: 1px solid #B5B5B5; border-top: 0; border-radius: 0 0 5px 5px; padding: 24px 20px 24px 68px; display: none;}


/*영상 리스트*/
.vod_wrap {width: 100%;}
.vod_cont {display: flex; flex-wrap: wrap; margin-top: 30px;}
.vod_box {flex: 1 1 calc(33.333% - 20px); margin: 10px; padding: 10px; box-sizing: border-box; cursor: pointer;}
.vod_img {position: relative; display: flex; height: 210px; background-color: #3E3E3E; border-radius: 12px;}
.vod_txt {margin: 16px 0; display: flex;flex-direction: column; justify-content: space-between;}
.vod_txt span {font-size: 1.2rem; font-weight: 600;}
.vod_txt span, .vod_txt p {padding: 5px 0;}

.paging {display: flex; align-items: center; justify-content: center; margin: 20px 0; gap: 5px;}
.paging a {display: flex;align-items: center;justify-content: center;cursor: pointer;min-width: 18px;}
.paging .active { width:25px; height: 25px; color: #fff; background-color: #667788; border-radius: 50%; display: flex; justify-content: center;}
.board {width: 25px; height: 25px; border: 1px solid #667788; border-radius: 50%;}
.board  > img {width: 10px;}


/*테이블*/
.tblist {width:100%;border-top:1px solid #667788;}
.tblist table{width:100%;}
.tblist th {padding:12px; color:#000;font-weight:500; border-right:1px solid #dbdbdb; border-bottom:1px solid #dbdbdb; background-color:#F6F7F8;line-height: 1.3;}
.tblist td {padding:8px; color:#333; text-align:center; border-right:1px solid #dbdbdb; border-bottom:1px solid #dbdbdb;word-break: keep-all;}
.tblist th:last-child,
.tblist td:last-child{border-right:none}
.tblist .chkbx {padding-left: 18px;}

.totalbx > span  {color:#C92525; font-weight: 600;}
.sch_box > button {background-color: #3E3E3E; border-radius: 6px; color: #fff; padding: 10px; width: 60px;}
.sch_box > input {height: 40px; width: 210px;}


/*아이디 비밀번호 찾기*/
.find_wrap > ul {display: flex; padding-bottom: 10px;}
.find_wrap > ul > li { height: 40px;}
.find_wrap > ul > li > h2 {cursor: pointer; font-size: 1.14rem;}
.tab-content {display: none;}
.tab-content.active {display: block;}
.tab-active {color: #fff !important; background-color: #444A98; border-radius: 10px;}


/*회원정보수정*/
.joinlist {width: 100%;}
.joinlist table {width: 100%;}
.joinlist th {text-align: left; padding: 30px 20px;}
.joinlist td > input {width: 60%;}



/*회원가입*/
.step{ border-radius: 10px; display: flex; justify-content: center;}
.step > ul { display: flex; justify-content: center; gap: 20px;}
.step > ul > li {text-align: center; width: 90px; padding: 5px;}
.step > ul > li img {width: 100%; height: auto; padding-bottom: 10px;}

.signup {width: 100%;}
.signup table { margin : 0 auto;}
.signup th {text-align: left; padding: 30px 20px;}
.signup td {padding: 20px 0;}
.signup td > input {width: 250px;}
.phonebx > input {width: 140px;}
.phonebx > select {width: 140px;}
.mailbx > input {width: 140px;}
.mailbx > select {width: 180px;}
.sign_btn {background-color: #3E3E3E; display: inline-block; padding: 6px 10px; margin-left: 10px; border-radius: 4px;}
.sign_btn > a {color: #fff;}
.address > input{width: 445px; display: block; margin: 10px 0;}

.register_txt{border: 6px solid #707070; padding: 26px 10px; border-image: url(../images/line.png) 9 round; background: #fff; display: flex; justify-content: center; flex-wrap: wrap;}
.register_txt > em {font-weight: 600; color: #444A98;}

/*이용약관*/

.register_bullet{color:#000; font-size:1.3rem; font-weight:700; position:relative;}
/*.register_bullet:before{display:block; content:''; width:7px; height:7px; background:#24b0a6; position:absolute; left:0; top:10px;}*/

.agree_wrap > div{margin-top:80px;}
.agree_txt{background-color: #fff; border-radius:10px; padding:30px;  box-sizing:border-box; margin-top:15px; height:300px; overflow-y:scroll; font-size: 0.9rem;}
.agree_txt h2{color:#000; font-weight:400; font-size:17px; margin-top:30px;}
.agree_txt p{font-size:15px; line-height:25px; margin-top:10px; color:#000;}
.register_title1{color:#000; font-size:24px; font-weight:500; line-height:24px;}
.agree_check{margin-top:20px; font-size:18px; font-weight:500; color:#000;}
.agree_check strong{color:#f00;}
.agree_check > *{display:inline-block; line-height:18px;}
.agree_check > div{margin-left:30px;}
.agree_check input{vertical-align:top; margin-top:2px;}
.agree_btn_wrap{margin-bottom:40px; font-size:18px; color:#000; padding-top:40px; text-align:center;}
.agree_btn{margin-top:130px;font-size:0; padding-bottom:120px; text-align:center;}
.agree_btn a{display:inline-block; color:#fff; font-size:18px; font-weight:500; text-align:center; width:163px; height:48px; line-height:48px; font-size:18px; margin:0 12px;}

.overflow_x_scroll{width: 100%; overflow-x: auto;}
.register_box{display: flex; flex-wrap: wrap;}
.register_select{font-size:0; margin-top:20px; text-align:center;}
.register_select > div{display:inline-block; zoom:1; width:calc(50% - 20px); vertical-align: top; margin: 0 10px; box-sizing:border-box;}
.regiseter_select_wrap {width: calc(50% - 20px) !important;}
.register_bg {background:url(../images/phone.png)no-repeat top 40px center;}
.register_bg02 {background:url(../images/ipin.png)no-repeat top 40px center;}
.register_select_section{background-color: #fff; border-radius:10px; padding:40px 20px;  min-height: 300px; display: flex; flex-direction: column; justify-content: space-between; align-items: center;}
.register_select_section h3{background:#fff; border:1px solid #bec9cf; height:68px; line-height:68px; color:#000; font-size:1.4rem; text-align:center; width: 86%;}
.register_select_section h4{color:#2a2f41; font-size:20px; font-weight:600; text-align:center; margin:30px 0;}
.register_select_section p{font-size:15px; text-align:center; color:#000; margin-bottom:30px; word-break:keep-all;}

.register_select_section a{display:block; color:#fff; background:#2a2f41; font-size:18px; font-weight:500; text-align:center; height:48px; line-height:48px; width:43%; border-radius: 30px; position: relative;}
.register_select_section a span{width: 24px; display: inline-block; position: absolute; left: 30px; top: -2px;}

.register_naver {background: #00B818 !important;}
.register_kakao {background: #F9E000 !important;}


.privacy_table{width:100%; border-top:2px solid #444A98;}
.privacy_table th, .privacy_table td{border-left:1px solid #ddd; padding:20px; vertical-align:top;  text-align:center; vertical-align:middle;}
.privacy_table th:first-child, .privacy_table td:first-child{border-left:0;}
.privacy_table th{background:#f5f5f5; font-weight:500;}
.privacy_table td{border-bottom:1px solid #ddd;}

.pravicy_site_wrap{font-size:0; margin:0 -10px;margin-top:20px;}
.pravicy_site_wrap > div{display:inline-block; zoom:1; width:50%; font-size:16px; padding:0 10px; box-sizing:border-box;}
.pravicy_site_wrap > div > div{padding:35px; border:1px solid #ddd;}


.checkwrap_bg {
	background-color: #fff;
	padding: 8px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 50%;
}

.checkwrap{
	width: 100%;
	height: 100%;
	border: 2px solid #BDBDBD;
	padding: 20px;
	background-color: #fff;
	text-align: center;
}
.checkwrap_bg_wrap{
	justify-content: center;
	display: flex;
}



/*login */
.loginfrom {max-width: 550px; margin: 0 auto;}
.loginfrom > ul > li {margin-bottom: 12px; position: relative;}
.loginfrom input {width: 100%; padding: 0 15px; height: 46px;}
.loginbtn {background-color: #4545A2; width: 100%; display: block; text-align: center; height: 50px; border-radius: 4px; line-height: 50px; color:#fff !important;}
.loginbtn_l {background-color: #fff; border: 1px solid #4545A2; width: 100%; display: block; text-align: center; height: 50px; border-radius: 4px; line-height: 50px; }
.btnbx {display: flex; align-items: center;}
.btnbx a{font-size: 14px; color: #919191; margin-left: auto;}

.login_top{text-align: center; padding-bottom: 14px;}
.login_top > h2 {font-size: 1.7rem; padding-bottom: 4px;}
.login_bt{text-align: center;}
.login_bt > ul {display: flex; justify-content: center;}
.login_bt > ul > li {width: 50px; height: 50px; background-color: #2a2f41; border-radius: 50%; margin: 20px 10px; display: flex; justify-content: center; align-items: center;}
.login_bt > ul > li img {width: 35px; height: auto;}


.txtinfo{margin-left: 8px; color: #B5B5B5; font-size: 12px;}
.passinfo{margin-top: 8px; color: red; font-size: 12px;display: block;}



/*공지등록*/
.layer_wrap {display: flex; flex-direction: column; padding: 20px 0; border-bottom: 1px solid #C1C1C1;}
.layer_wrap > label {margin-bottom: 10px; cursor: default;}
.layer_set {display: flex; flex-direction: column; padding-bottom: 20px;}

.time_wrap { display: flex; align-items: center; justify-content: center;}
.time_set {display: flex; width: 100%; align-items: center; justify-content: center;}
.time_set > label{padding:0 10px; width:12%; text-align:center;}
.time_set > label:nth-of-type(2){width: 50px;}
.time_set > input{width:calc(100% - 320px); margin-right: 10px;}
.time_wrap {
	.form_group {
		display: flex;
		align-items: center;
		flex: auto;
		column-gap: 5px;
		width: 100%;
	}
	.form_date {
		flex: auto;
	}
	.form_time {
		width: 90px;
	}
	.txt_unit {
		display: flex;
		padding-right: 5px;;
	}
	&:has(.form_group) {
		label {
			min-width: 100px;
		}
	}
}

.layer2_wrap {display: flex; padding: 20px 0; border-bottom: 1px solid #C1C1C1; justify-content: center;}


.px_wrap {width:100%; display: flex; flex-direction: column; justify-content: center;}
.px_wrap > label {margin-bottom: 10px; cursor: default; }
.px_box {display: flex; align-items: center;}
.px_box > input {width: 35%; margin: 0 5px;}
.px_box > span {font-size: 0.8rem; color: #707070; padding-left: 10px;}

input#file{display:none}
.file_btn {display: flex;}
.file_btn > label {padding: 10px 20px; text-align: center; color:#fff; background-color: #3E3E3E; border-radius: 5px; cursor: pointer; }
.file_btn > button {padding: 10px 20px; background-color: #fff; border: 1px solid #3E3E3E; border-radius: 5px; margin-left: 10px;}
.file_box {border: 1px solid #bec9cf; border-radius: 5px; width: 100%; margin-top: 10px; padding: 20px; flex-direction: column;}
.file_box >span { padding-left:10px;  overflow:hidden; text-overflow:ellipsis; display:block;}
.file_box > input {width: 100%; border: none;}
.file_btnD {padding: 10px 20px; background-color: #fff; border: 1px solid #3E3E3E; border-radius: 5px; margin-left: auto;}
.file_box {border: 1px solid #bec9cf; border-radius: 5px; width: 100%; margin-top: 10px; padding: 20px; display: flex; align-items: center;}

.subject-options {display: flex; flex-wrap: wrap; gap: 10px;}
.radio-set {flex: 1 1 90px; display: flex; align-items: center;}

/* 언어 펼침 languages*/
#gn3 > a {cursor: pointer; padding: 0 23px; color: #444A98;}
#gn3c{display: none; z-index:999; position:absolute; top:34px; background-color: #fff; border: 1px solid #919191; border-radius: 6px; padding: 10px; right: 0;
box-shadow: -2px 0 5px rgba(0, 0, 0, 0.2);}
#gn3c.on{display:block; }
#gn3c ul{}
#gn3c li{display:block;text-align:left; height: 30px; line-height: 30px;}
#gn3c li > a{border-bottom:1px solid rgba(255,255,255, .1); padding:7px 10px; margin-left:0; box-sizing:border-box; padding:0; display: block;}
#gn3c li>a img{display:block;}
#gn3c li>a:hover,
#gn3c li>a:focus{
border-bottom: 1px solid #444A98;
}

/*좌석 예약*/
.select_time {text-align: center; margin-bottom: 30px;}
.select_time > a{display: inline-block; margin: 0 4px; padding: 8px; border: 1px solid #445566; border-radius: 5px; font-size: 0.9rem; text-align: center; cursor: pointer; box-sizing: content-box; width: 60px;}
.select_time > a:hover {border:1px solid #4E4498;}
.select_time > a.on {background-color: #444A98; color: #fff;}

.seat_info{display: flex;}
.seat_info > ul{display: flex; margin-left: auto; margin-bottom: 10px;}
.seat_info > ul > li {display: flex; align-items: center; margin-right: 14px;}
.seat_info > ul > li:nth-of-type(4) {margin-right: 0;}
.seat_info > ul > li > span {display:block; width:20px; height: 20px; padding-right: 4px; margin-right: 4px; border-radius: 2px;}
.seat_info > ul > li:nth-of-type(1) > span { background-color:#fff; border:1px solid #3E3E3E;}
.seat_info > ul > li:nth-of-type(2) > span { background-color: #919191;}
.seat_info > ul > li:nth-of-type(3) > span { background-color: #FFCF0C;}
.seat_info > ul > li:nth-of-type(4) > span { background-color: #444A98;}

.seat_time{display: inline-block; margin-right: 5px;}
.seat_time > span {display: inline-block; padding-left: 8px;}
.seat_time > span > b{display: table-caption; font-size: 0.9rem; line-height: 120%; letter-spacing: -1px; font-weight: 400;}
.seat_time > span > span {display: inline-block; min-width: 28px; height: 30px; background-color: #fff; border:1px solid #3E3E3E; border-radius: 2px; cursor: pointer;}
.seat_time > span.on > span.notavail {background-color: #919191; cursor:default;}
.seat_time > span.on > span.reserved  {background-color: #444A98; cursor:default;}
.seat_time > span.on > span.selected {background-color: #FFCF0C; }

.seat_cont {display: flex; flex-direction: column; width: 100%; justify-content: center; align-items: center; gap:46px;}
.seat_box{ width: calc(540px); padding: 0; border: 0;}

/*레이아웃 팝업*/
.laypopup, .member-sch { position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.5); display: none;}
.laypopup .laypopup_wrap,
.member-sch .member-sch_wrap {position: relative; left: 50%; top: 50%; transform: translate(-50%, -50%); width: auto; height: auto; background-color: #fff; border-radius: 10px; max-width: 500px;}
.laypopup_tit{ width: 100%; padding: 15px 20px; background-color: #4E4498; border-radius: 10px 10px 0 0; font-size: 20px; letter-spacing: -0.05em; font-weight: 600; box-sizing: border-box; display: flex; align-items: center;}
.laypopup_tit > h2 {color: #fff; font-size: 21px;}
.laypopup_tit > span {display: inline-block; width: 30px; height: 30px; background: url(../images/close.svg) no-repeat; cursor: pointer; margin-left: auto;}
.laypopup_box {padding: 20px 0; border-bottom: 1px solid #c1c1c1; justify-content: space-around;}
.laypopup_cont {padding: 20px;}
.timepopup_wrap >.time_set > select {width: 70px; margin-left: 8px;}
.timepopup_wrap >.time_set {margin-top: 10px;}
.text_left {text-align: right; font-size: 18px;}
.text_left > button {width: 80px; height: 40px; font-size: 14px; border-radius: 8px; color: #fff;}
.laypopup_btn {background-color: #fff; color: #445566 !important; border: 1px solid #445566;}
.laypopup_registBtn {background-color: #445566;color:#fff;border:0;width: 150px; height: 50px;font-size: 2rem;border-radius: 15px;cursor: pointer;}
.lay_sel > select {height: 40px; width: 25%;}
.lay_sel > input {height: 40px; width: 52%;}
.lay_sel > button {height: 40px; width: 20%; font-size: 1rem; color: #fff; border-radius: 6px;}

/* body에 class .popup_open를 붙이면 활성화됨. */
.popup{ position: fixed; left: 0; top: 0; width: 100%; height: 100%; z-index: 999999; display: none; }
body.popup_open .popup{ display: block; }
.popup .popup-wrap{ position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: auto; height: auto; border-radius: 10px; background-color: #fff; border-radius: 10px; z-index: 2;max-width: 100%;}
.popup .popup-title { width: 100%; padding: 15px 20px; background-color: #4E4498; border-radius: 10px 10px 0 0; color: #fff; font-size: 20px; letter-spacing: -0.05em; font-weight: 600; box-sizing: border-box; }
.popup .popup-content{ width: 100%; height: auto; padding: 20px; box-sizing: border-box; min-width: 400px;}

.popup .popup-wrap .popup-content .text-box p{ font-size: 20px; letter-spacing: -0.05em; line-height: 30px; font-weight: 400; margin-bottom: 30px; word-break: keep-all; text-align: center;}
.popup .popup-wrap .popup-content .text-box strong{ display: block; color: #4E4498; font-size: 20px; font-weight: 600; margin-bottom: 20px; }
.popup .popup-wrap .popup-content .popup-btn ul{ display: flex; justify-content: center; }

.popup .popup-wrap .popup-content .popup-btn ul li{ width: 100px; height: auto;  margin-right: 20px; box-sizing: border-box; }
.popup .popup-wrap .popup-content .popup-btn ul li:last-child{margin-right: 0;}
/*버튼 역순 정렬*/
.popup .popup-wrap .popup-content .popup-btn ul.button-reverse li{margin-right: 0;order: 2}
.popup .popup-wrap .popup-content .popup-btn ul.button-reverse li:last-child{margin-right: 20px;order: 1; width: 230px;}
.popup .popup-wrap .popup-content .popup-btn ul.button-reverse li:first-child a{color: #445566; border: 1px solid #445566; background-color: #fff;}

.popup .popup-wrap .popup-content .popup-btn ul li a{ display: block; width: 100%; height: 100%; padding: 12px 0; text-align: center; font-size: 18px; letter-spacing: -0.05em; font-weight: 500; box-sizing: border-box; border-radius: 10px; background-color: #445566; color: #fff;}


/* 인풋박스 스타일 */
.popup .popup-wrap .popup-content .input-box{width: 100%; height: auto; margin-bottom: 30px;}
.popup .popup-wrap .popup-content input{ width: 100%; height: 6rem; border: 1px solid #c8c8c8; border-radius: 5px; box-sizing: border-box; font-size: 2rem; color: #4d4d4d;padding-left: 1rem;}


/* *********** 뒷배경 검정색 딤 처리 박스 *********** */
body.popup_open .dimmed{width: 100%; height: 100%; position: fixed; left: 0; top: 0; background: rgba(0,0,0,0.5); overflow: hidden; z-index: 1;}
/* body 태그에 연결할 클래스 */
body.popup_open{overflow: hidden}

/*ERROR*/
.error {position: absolute; top: 0; left: 0; width: 100%; height: 100%; text-align: center;}
.error_section { margin-top: 30px; width: 100%; height: 580px; background: #fff; vertical-align: middle; position: relative; display: flex; flex-direction: column; justify-content: flex-end;}
.error_section::before {content:''; position: absolute; left: 0; top:0; width: 100%; height: 100%; background: url(../images/sambang_error.png) no-repeat center;}
.error_tit{font-size: 2rem; color: #444A98; font-weight: 600;}
.error_txt{font-size: 1.4rem; padding-top: 10px;}
.error_button {display: flex; justify-content: center; padding-top: 14px; gap: 20px;}
.error_button > li {position: relative;}
.error_button > li > a {border: 1px solid #445566; border-radius: 8px; width: 140px; height: 40px; line-height: 40px; display: block; cursor: pointer;}
.error_button > li > a:hover {background-color: #445566; color: #fff;}






/*반응형*/
@media (max-width: 1440px) {
#side_layout{display: none;}
#content{max-width: 1480px;}
#header .gnb > li {font-size: 1.27vw; padding: 3px 1.12vw 0;}
#header .user {font-size: 1.2vw;}
#header .cont > h1 > a > img {width: 160px;}
.mwrap01 {width: 55%;}
.mwrap02 {width: 45%;}
.minner {padding-top:170px; padding-botoom:50px;}
.mpopupcont {margin-bottom: 18px;}
.mguidebox > li {padding:18px 10px;}
.mguidebox > li:nth-child(1)::before {background-size: 84%;}
.mguidebox > li:nth-child(2)::before {background-size: 84%;}
.mguidebox > li:nth-child(3)::before {background-size: 84%;}
.mguidebox > li > div > em {padding: 10px 0px;}
.mQuick {flex-wrap: wrap; padding: 10px 0px 20px 0px; gap: 20px;}
.mQuicklist {padding-left: 0;}
.intro_select > div {width: calc(50% - 140px); margin: 0 20px;}
.intro_txt {padding: 24px;}
.intro_txt > p {font-size: .94rem;}

}

@media (max-width: 1440px) {
#header .gnb {display: none;}
#header .user{display: none;}
.mbox { padding: 0 20px; margin: 20px 0;}
.mwrap01 {width: 100%;}
.mwrap02 {width: 100%; display: flex; padding: 40px 20px 90px 20px;}
.minner {padding-top: 260px;}

.mguidebox > li:nth-child(1)::before {background-size: 100%;}
.mguidebox > li:nth-child(2)::before {background-size: 100%;}
.mguidebox > li:nth-child(3)::before {background-size: 100%;}
.mguidebox > li {padding:24px;}
.mpopupcont {width: calc(100% - 240px);}
.mQuick {flex-direction: column; width: 220px; margin-left: 20px; align-items: center; justify-content:center; gap: 10px;}
.mQuicklist {flex-direction: column; gap: 10px; align-items: center;}
.mQuicklist > li {display: flex; justify-content: center; align-items: flex-end;}

.bnr_list > li {flex: 1 1 calc(50% - 32px); /* 화면 너비가 좁아지면 두 개씩 줄 바꿈 */}
.target_list > li {flex: 1 1 calc(50% - 32px); margin-top: 16px; }
.select_contl, .select_contr{width: 100%; max-width: 100%; float: none;}
.select_contr{border-top: 3px solid #363636; margin-top: 34px;}
.open-btn{display: block;}
.vod_box {flex: 1 1 calc(50% - 20px);}
.scroll_wrap {overflow:hidden;}
.tbscroll{overflow-x:scroll;}
.tbscroll table {width: 100%; min-width: 1080px;}
.joinlist td > input {width: 80%;}
.time_wrap{flex-direction: column;}
.time_set:nth-of-type(1){margin-bottom: 6px;}
.time_set:nth-of-type(2){margin-top: 6px;}
.register_box > .regiseter_select_wrap {flex: 1 1 calc(50% - 20px) !important;}
.register_box .regiseter_select_wrap:last-of-type > .register_select_section{width: calc(50% - 10px); margin: 0 auto; margin-top: 18px;}
.register_select_section a,
.register_select_section h3 {width: calc(100% - 30px);}

.txtinfo{display: block; margin-top: 5px;}
.intro_select {margin-top: 30px;}
.intro_select > div {width: 50%; margin: 0 20px; margin-top: 40px;}
.intro_txt {padding: 26px;}

.strategy_inner{width: 100%;}
.str02_cont {flex-wrap: wrap;}
.str03_list > li {width: calc(50% - 20px);}
.str03_list > li:nth-child(even) p::before {position: absolute; content: ''; width: 3px; height: 3px; border-radius: 50%; background-color: #b1b1b1; left: 0; top: 7px;}
.str03_list > li:nth-child(even) {background:#4B4F60; color: #fff;}
.str03_list > li:nth-child(even) span {color: #fff !important;}
.str03_list > li:nth-child(5) {background: none; color: #000;}
.str03_list > li:nth-child(5) span {color: #444A98 !important;}

.strategy_list {gap: 30px;}
.strategy_list > li {width: calc(100% / 5 - 40px);}

.vision_tit {width: 410px;}
.vision p {font-size: 26px;}
.vision_list > li {width: calc(100% / 5);}

.class_list {justify-content: space-around; gap: 60px 10px;}
.class_list > li {width: calc(100% / 4 - 20px);}

}

@media (max-width: 768px) {


.mbox {margin: 40px 0;}
.minner {padding-top: 230px;}
.mwrap01 {width: 100%;}
.mwrap01_bottom {padding-top: 34px; gap: 10px; display: flex; flex-direction: column;}
.mwrap02 {width: 100%; display: inline; padding: 0px 20px 80px 20px;}
.mpopupcont {width: 100%;}
.mQuick {width: 100%; align-items: center; justify-content: flex-start; flex-direction:row; margin-left: 0; padding-top: 50px;}
.mguidebox{flex-direction: column;}
.mguidebox > li {width: 100%;}
.mQuicklist{flex-direction: row; gap: 10px;}
.subtitle{background: none;}
.subtitle_wrap {padding-right: 26px;}
.bnr_list > li {flex: 1 1 calc(100% - 32px); /* 화면 너비가 좁아지면 두 개씩 줄 바꿈 */}
.target_list > li {flex: 1 1 calc(100% - 32px); }
.subtitle_wrap > span {font-size: 2rem;}
.subtitle_wrap > p {font-size: 1rem;}
.gallery_box{width: 100%; padding-right: 0;}
.gallery_info{width: 100%; padding: 20px 0 0 0;}
.location_wrap{display: none;}
.signup_txt > p {font-size: 0.86rem;}
.vod_box {flex: 1 1 calc(100% - 20px); padding: 10px 0;}

.remove-table th, .remove-table td {display: none;}
.remove-table th:nth-child(2), .remove-table td:nth-child(2) {display: table-cell; width: 80%;}
.remove-table th:nth-child(3), .remove-table td:nth-child(3) {display: table-cell; width: 20%;}

.remove-table th:nth-child(1), .remove-table td:nth-child(1),
.remove-table th:nth-child(4), .remove-table td:nth-child(4),
.remove-table th:nth-child(5), .remove-table td:nth-child(5) {display: none;}

.remove-table col:nth-child(1),
.remove-table col:nth-child(4),
.remove-table col:nth-child(5) {display: none;}

.remove-table td:nth-child(3),
.remove-table th:nth-child(3) {border-right: none;}
.px_box > span {display: none;}


.phonebx > input {width: calc(33.333% - 10px);}
.phonebx > select {width: calc(100%/3.3333);}
.mailbx > input {width: calc(50% - 10.5px);}
.mailbx > select {width: 100%; margin-top: 10px;}
.address > input {width: 100%;}

.step > ul {gap: 12px;}
.step > ul > li {font-size: 0.9rem; width: 60px; margin: 0; font-size: 12px;}
.agree_check > div {margin-left:0; text-align:right; padding-top:4px; display: block;}
.overflow_x_scroll {width: 100%; overflow-x: auto;}
.privacy_table{width:640px;}
.privacy_table th, .privacy_table td{padding:10px; font-size:14px;}
.pravicy_site_wrap > div {display: block; width: auto;}
.pravicy_site_wrap > div > div {margin-top: 20px; padding: 15px;}

.register_select{margin-top:20px;}
.register_select > div{display:block; width:auto;}
.register_select > div + div{margin-top:20px;}
.register_select_section{background-color: #fff; border-radius:10px; padding:40px 30px;  min-height: 300px; display: flex; flex-direction: column; justify-content: space-between;}
.regiseter_select_wrap {width: auto !important;}
.register_box > .regiseter_select_wrap {flex: 1 1 calc(100% - 20px) !important;}
.register_box .regiseter_select_wrap:last-of-type > .register_select_section{width: auto; margin: auto;}
.register_select_section h3{height: 45px; line-height: 45px; font-size: 16px; }
.register_select_section p{ font-size: 14px; margin-top:15px; word-break: keep-all;}
.register_select_section p br{display:none;}
.register_select_section h3,
.register_select_section a{width: 100%;}
.footer-inner {font-size: 0.9rem;}
.sub_footer {background: none;}
.select_time {text-align: left;}
.intro_select {margin: auto;}
.intro_select > div { width: 65%; margin-top: 40px;}
.intro_txt {padding: 18px;}
.intro_txt > p {font-size: .87rem;}
.inputbox {flex-direction: column;}

.img_inner {width: 100%; padding-right: 0px;}
.sub_txt {width: 100%; }
.sub_txt > em {padding-top: 10px;}
.sub_txt > h2 {padding: 12px 0;}

.pro_video_inner{width: 100%;}
.build_inner{width: 100%;}
.build_list {width: 90%;}

.content_map_wrap, .content_map_wrap > div {display: block; width: auto;}
.content_map_title {border-radius: 12px; margin-bottom: 40px;}
.content_map_wrap .content_map .mapbox {border-radius: 12px;}
.str03_list > li {width: calc(100%);}

.strategy_bg{border-radius: 250px;}
.strategy_bg::before{padding-bottom: 72%;}
.strategy_list {gap: 20px 20px;}
.strategy_list > li {width:calc(100% / 3 - 48px);}

.vision {padding-bottom: 90px;}
.vision_tit {width: 220px;}
.vision_list > li {width: calc(100% / 3); margin-bottom: 26px;}
.vision_list > li > div > div::before {display: none;}
.vision_list > li > div > div::after {display: none;}
.vision_list > li > div > div > span {top: 10px;}
.vision_list > li:nth-child(even) > div > div > span {top: 10px;}

.class_list {justify-content: space-around; gap: 50px 10px;}
.class_list > li {width: calc(50% - 20px);}
#previewImg {width:100%}
.map_list{border-radius:0px 0px 12px 12px;}

.checkwrap_bg {width: 100%;}

.seat_cont {flex-wrap: wrap; justify-content: center;}
.seat_box{width: 100%;}

.period{width:100%; display:flex; justify-content:center; align-items:center; gap:7px}
.period > input {width:140px;}

}

@media (max-width: 540px) {
.mwrap02 {padding: 0px 20px 60px 20px;}
.mQuick {gap: 20px;}
.mQuicklist {flex-direction: column; gap: 20px;}
.mQuicklist > li {width: 100%; box-shadow: 0 2px 28px #0d648a33, 0 10px 10px #0d648a33; border-radius: 10px; padding: 12px 32px;}
.mQuicklist > li a {width: 100%; justify-content: space-between; flex-direction: row;}
.mQuicklist > li a img {width: 100px;}
.mQuicklist > li a em {text-align: center; width: calc(100% - 100px); font-size: 18 px;}
.sub_banner{height: 210px;}
.location_wrap{display: none;}
.signup_txt > p {font-size: 0.86rem;}
.sch_box > input {width: 160px;}
.joinlist td > input {width: 100%;}
.time_set > input{width: 25%}
.signup tbody tr {display: flex; flex-direction: column;}
.signup tbody tr th {order: 1; width: 100%; padding: 28px 0;}
.signup tbody tr td {order: 2; width: 100%;}
.signup td{padding: 0;}
.signup td > input {width: 100%;}
.signup table {width:100%;}
#content_login{padding: 20px 14px 40px;}

.step {padding: 5px; display: flex; justify-content: centerr; width: 100%;}
.step > ul {flex-wrap: wrap; width: calc(100% - 20px); gap: 8px 30px;}
.step > ul > li {font-size: 0.7rem; margin: 0; width: 60px;}

.signup_wrap::before {top: 110px;}
.siagnid{width:calc(100% - 90px) !important;}
.siagnadd{width: 120px !important;}
.gallery_scale {display: block;}
.agree_check {font-size: 14px;}
.title_wrap > h2{font-size: 1.4rem;}
.intro {padding-top: 50px;}
.intro > h1 {width: 160px;}
.intro_select > div {width: 90%; margin: auto; margin-top: 40px;}
.intro_txt {padding: 12px;}
.intro_txt > p {font-size: 0.8rem;}
.intro_txt > strong {font-size: 1.1rem;}
.intro_txt > strong::after {margin-left: 10px;}
.register_bullet {font-size: 1.1rem;}
.register_select_section {padding:20px; min-height: 240px;}
.register_select_section h4 {font-size: 18px; margin: 0;}
.register_select_section a {font-size: 14px; height: 40px; line-height: 40px;}
.register_select_section a span {width: 18px;}
.register_select_section p {margin:0; position: relative;}
.signup_loginwrap::before {width: 80px; height: 80px; top: 230px;}
.bnr_list > li {background-size: 280px;}
.footer-inner {font-size: 0.7rem; line-height: 12px;}
.bnr_list > li {background-size: 280px !important; height: 350px;}
.sub_inner > p {font-size: 0.9rem;}
.btn_intro {font-size: 1rem;}
.agree_txt{height:250px; padding: 10px;}
.pravicy_site_wrap > div > div {font-size: 12px;}
.gallery_info {font-size: 0.88rem;}
.select_contl, .select_contr, .select_contc{font-size: 14px;}
.calendar_tbl th, .calendar_tbl td, .time_tbl th, .time_tbl td {font-size: 0.8rem;}
.guide_txt > p {padding: 0 0 0 58px; font-size: 14px;}
.question {font-size: 14px;}
.tblist th, .tblist td {font-size: 0.78rem;}
.total_wrap {font-size: 14px;}
.vod_txt span, .vod_txt p {padding: 2px 0;}
.vod_txt p {font-size: 14px;}
.study_tbl > table > tbody > tr > th {padding: 12px;}
.chk-set {flex: 1 1 90px; display: flex; align-items: center;}
.seat_info > ul > li > p {font-size: 0.8rem;}
.btnlist {flex-wrap: wrap;}
.btnlist_right {margin-top: 14px;}
.select_time > a {margin-bottom: 10px;}
.laypopup .laypopup_wrap,
.member-sch .member-sch_wrap {width: 80%;}
.timepopup_wrap >.time_set {display: block;}
.timepopup_wrap >.time_set > label {display: block; text-align: left; padding: 0; margin-bottom: 2px; font-size: 14px;}
.timepopup_wrap >.time_set > input {width: 30%; margin: 0;}

.time_set {flex-direction:column;}
.time_set > label {text-align:left; width:100%; font-siae:12px; padding:8px 0px;}
.time_set > input {width:100%; margin-right:10px;}
.period {flex-direction:column;width:100% ;}
.period > label{width:100%;padding-left:10px;}
.sch_box {display:flex;gap:6px;justify-content: end;margin-left: auto;}
.sch_sel > input { width : calc (100% - 80px);}

.popup .popup-wrap {max-width: 90%;}
.popup .popup-content {min-width: 310px;}
.period {display: flex; align-items: center; justify-content: center; gap: 3px;}
.sch_sel {display: flex; justify-content: center; gap: 5px; width:100%; margin-top:10px;}
.period > input {width: calc(100% - 10px);}
.sch_sel > select {width: 100px;}
.sch_sel > input {width:calc(100% - 180px);};
.sch_sel > button {width: 20%;}
.lay_sel > select {width: 30%;}
.lay_sel > input {width: 45%;}
.lay_sel > button {width: 20%;}
.lay_sel > select, .lay_sel > input, .lay_sel > button {font-size: .75rem;}
.error_section {height: 500px;}
.error_section::before {top: -30px;}

.pro_inner > p {font-size: 14px;}
.pro_video_txt {padding: 15px 18px 24px;}
.pro_video_txt > p {font-size: 14px;}

.vison_inner {width: 70%;}
.vision em {font-size: 21px;}
.vision p {font-size: 14px;}

.tab_list > li > a {font-size: 12px;}

.sub_txt {font-size: 14px;}
.sub_txt > h2 {font-size: 18px;}

.content_map_wrap > div {height: 360px;}
.map_list {height: 248px;}
.content_map_wrap .content_map .mapbox {height: 360px;}

.map_title_wrap > h3 {font-size: 21px;}
.map_list > ul > li {padding: 14px 0;}
.map_list_section  {font-size: 14px;}
.map_list_section > em {font-size: 16px;}


.strategy > h3 {font-size: 18px;}
.strategy_txt {font-size: 14px; padding: 14px 14px 24px;}
.strategy_txt > em {font-size: 18px;}

.video_tit::before {width: 44px; bottom: -28px; left: -31px;}
.video_tit::after {width: 44px; top: 4px; right: -24px;}
.video_tit > h3 {font-size: 21px;}
.video_tit > h2 {font-size: 24px;}
.video_frame {margin: 8px;}
.video_container {margin-top: 20px;}

.str02_cont {width: calc(100% - 10px);}
.str02_list {padding:70px 44px; font-size: 14px;}

.strategy_list {gap: 20px 30px;}
.strategy_list > li {width: calc(100% / 2 - 34px);}
.strategy_bg::before {padding-bottom: 200%;}
.strategy_cont::before {padding-bottom: 120%;}
.strategy_list > li > div > div{font-size: 10px;}

.vision {padding-bottom: 40px;}
.vision p {font-size: 21px;}
.vision_tit {width: 165px;}
.vision_tit::before {width: 54px; right: -54px;}
.vision_tit::after {width: 44px; top: 7px;}
.vision_list > li {width: calc(100% / 3 - -16px); margin-bottom: 46px;}

#checkplus {display:block; text-align:center}

.bordlist dl{display: inline-block; width: 100%;}
.bordlist  dl > dt {float: left; width: 50px;}
.bordlist  dl > dd {float: right; width: calc(100% - 56px);}

.banner::before {padding-bottom: 50%;}

.checkwrap_bg {width: 100%;}
}