﻿@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;}


.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;}

colgroup {color: #4E4498;}


/* layout */
#wrap {display: flex; flex-direction: column; min-height: 100vh;}
#header {background-color:#fff; 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 60px; border-radius: 30px  0 30px 30px;  display: inline-flex; height: 50px; width: 260px; justify-content: center; align-items: center;}
.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;}



/*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: 1480px; 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:20px; position: relative; display: flex; height: 100%; align-items: center; cursor: pointer; 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;  transition: 0.4s;}
#header .gnb > li:hover > a {color:#4E4498; border-bottom: 2px solid #4E4498;}
#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-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: 30px 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;} */

#mlayout .mtxt { margin-left: 430px;}
#mlayout .mtxt > span {font-family: TTWanjudaedunsancheB; font-size: 2.4rem;}
#mlayout .mtxt> p {font-size: 1.2rem; padding-top: 6px;}
#mainbox {display: flex; flex-wrap: wrap; justify-content: space-between; margin-top: 30px;}
.minner{background: url(../images/sub_bg.svg) no-repeat; background-size: 400px; height: 128px; margin-top: 140px;}
.mbox { padding: 0 20px;}
.mbox > h2 {margin-bottom: 14px;}
.mwrap01 {width: calc(40% - 20px);}
.mwrap02 {width: 35%;}
.mwrap03 {width: 25%; position: relative;}
.mnotice {margin-bottom: 20px;}
.mnotice > li {padding: 14px 0;border-bottom: 1px solid #3E3E3E; position: relative; cursor: pointer; width: 100%;}
.mnotice > li:hover {background-color: #EBF2FF;}
.mnotice > li > a { font-size: 1.1rem;}
.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: 0; color: #444A98; font-size: 1rem; }
.mguide { width: 100%; margin-top: 10px; display: flex;}
.mguide > li {padding: 5px 0; width: calc(55%/2);}
.mguide > li:nth-child(1) { width: 45%;}
.mguide > li > span {width: 60px; font-weight: 600; display: flex; align-items: center;}
.mguide > li > p {padding-top: 10px;}
.mtime {font-weight: 800; font-size: 1.6rem;}
.mday {color: red;}
.mday > span {font-size: 0.8rem; display: block;}

.mpopuptxt {position: absolute; top: 0; right: 0; display: flex; flex-direction: column; align-items: flex-start;}
.mpopuptxt > h2 {writing-mode: vertical-rl; float: right;}
.popupbtns {display: flex; flex-direction: column;}
.mpopup { width: 93%;  background-color: #3E3E3E; border-radius: 5px; overflow: hidden; position: relative;}
.slider {position: relative; width: 93%; overflow: hidden; border-radius: 5px; height: 420px; background-color: #00B818;}
.slides {display: flex; transition: transform 0.5s ease; width: 100%; height: 100%;}
.slide {min-width: 100%; height: 100%; display: flex;}
.slide img {max-width: 100%; max-height: 100%; object-fit: cover;}
.slidebtns {}
.mpopupbtns > button{position: relative; top: 0; left: 0; display: block; width: 30px; height: 20px; margin: 10px 0;}
#next{background: #fff url(../images/bg_selectArrow.svg) no-repeat center center; }
#prev{background: #fff url(../images/bg_selectArrow.svg) no-repeat center center; transform: scaleY(-1);}
.mQuick {display: grid; grid-template-columns: 1fr 1fr; gap: 20px;}
.mQuick > li {width: 100%; border: 1px solid #3E3E3E;  border-radius: 5px; height: 180px; display: flex; justify-content: center; font-size: 1.15rem; align-items: flex-end; cursor: pointer;}
.mQuick > li a {height: 100%; width: 100%; display: flex; align-items: flex-end; justify-content: center; padding-bottom: 30px;}/*20241011*/
.mQuick > li:hover > a {color: #444A98;}
.mQuick > li:nth-child(1) {background: url(../images/m01.png) no-repeat top 30px center;}
.mQuick > li:nth-child(2) {background: url(../images/m02.png) no-repeat top 30px center;}
.mQuick > li:nth-child(3) {background: url(../images/m03.png) no-repeat top 30px center;}
.mQuick > li:nth-child(4) {background: url(../images/m04.png) no-repeat top 30px center;}
.mQuick > li:nth-child(1):hover {background: url(../images/m01_c.png) no-repeat top 30px center;}
.mQuick > li:nth-child(2):hover {background: url(../images/m02_c.png) no-repeat top 30px center;}
.mQuick > li:nth-child(3):hover {background: url(../images/m03_c.png) no-repeat top 30px center;}
.mQuick > li:nth-child(4):hover {background: url(../images/m04_c.png) no-repeat top 30px center;}


/*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.2rem; 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;}



/*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: 54%; left: 40px;}
.subtitle_wrap > span {font-family: TTWanjudaedunsancheB; font-size: 2.4rem;}
.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 > p {text-align: center; 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;}


/*예약하기*/
.gallery{display: flex; flex-wrap: wrap; width: 100%;} 
.gallery_box{ width: 40%; height: 300px; border-radius: 10px; background-color: #363636;}
.gallery_info{width: 60%; padding-left: 20px;}
.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;}
.gallery_scale li span::before { position: absolute; content:''; top:42%; width: 3px; height: 3px; border-radius: 50%; background-color: #363636; left: 0;}
.gallery_txt{ padding-top: 10px; line-height: 24px;}
.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;}


/*달력 시간*/
.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; 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:flex; padding: 20px 12px;font-size:1.2rem; font-weight:500;}
.bordlist {border: 1px solid #C4C4C4; border-left: 0; border-right: 0; padding: 12px;}
.bordlist dl{display: flex;}

.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;}
.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;}

.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;}
.paging a {display: flex; align-items: center; justify-content: center; min-width: 18px; margin: 0 5px; height: 20px;}
.paging .active { width:20px; color: #fff; background-color: #667788; border-radius: 50%; display: flex; justify-content: center;}


/*테이블*/
.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; padding: 20px; margin: 0 auto;}
.step > ul { display: flex; justify-content: center;}
.step > ul > li {text-align: center; width: 90px; padding: 5px;  margin: 0 20px;}
.step > ul > li img {width: 100%; height: auto; padding-bottom: 10px;}

.signup {width: 100%;}
.signup table {width: 100%;}
.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_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:60px; text-align:center;}
.register_select > div{display:inline-block; zoom:1; *display:inline; width:calc(50% - 20px); vertical-align: top; margin: 0 10px; box-sizing:border-box;}
.regiseter_select_wrap {width: calc(33.333% - 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:86%; 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;}





/*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;}

.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: 78px; text-align: right;}
.time_set > label:nth-of-type(2){width: 50px;}
.time_set > input{width: 35%; margin-right: 10px;}

.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;}
.file_box >span {padding-left: 10px;}
.file_box > input {width: 100%; border: none;}

.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; width: 110px; 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; }


/*레이아웃 팝업*/
.laypopup { 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 {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;}

/* 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}



/*반응형*/
@media (max-width: 1450px) {
  #side_layout{display: none;}
  #content{max-width: 1480px;}
  #header .gnb > li {font-size: 1.5vw; padding: 3px 1.12vw 0;}
  #header .user {font-size: 1.2vw;}
  .mwrap01 {width: 35%;}
  .mwrap02 {width: 35%;}
  .mwrap03 {width: 30%;}
  .slider{height: 413px;}
  .mtime {font-size: 1.4vw;}
  .mday {font-size: 1rem;}
  .mguide > li:nth-child(1) {width: 36%;}
  .mguide > li {width: calc(64%/2);}
  .mQuick {gap: 10px;}
  .mQuick > li > a {font-size: 1rem;}
  .intro_select > div {width: calc(50% - 140px); margin: 0 20px;}
  .intro_txt {padding: 24px;}
  .intro_txt > p {font-size: .94rem;}
}

@media (max-width: 1024px) {
  #header .gnb {display: none;}
  #header .user{display: none;}
  .mbox { padding: 0 20px; margin: 20px 0;}
  .mwrap01 {width: 100%;}
  .mwrap02 {width: calc(54% - 10px);}
  .mwrap03 {width: 46%; margin-bottom: 100px;}
  .mtime {font-size: 3.2vw;}
  .mday {font-size: 1rem;}
  .bnr_list > li {flex: 1 1 calc(50% - 32px); /* 화면 너비가 좁아지면 두 개씩 줄 바꿈 */}
  .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 > input{width: 36%}
  .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;}


}

@media (max-width: 768px) {
  #mlayout .mtxt {display: none;}

  .slider {width: 90%; float: left; height: 600px;}

  .minner{background: url(../images/sub_bg.svg) no-repeat center center; background-size: 500px; height: 164px; margin-top: 140px;}
  .mbox {margin: 40px 0;}
  .mwrap01 {width: 100%;}
  .mwrap02 {width: 100%;}
  .mwrap03 {width: 100%; margin-bottom: 140px;}
  .mtime {font-size: 3.6vw;}
  .mpopuptxt {right: 14px;}
  .subtitle{background: none;}
  .subtitle_wrap {padding-right: 26px;}
  .bnr_list > li {flex: 1 1 calc(100% - 32px); /* 화면 너비가 좁아지면 두 개씩 줄 바꿈 */}
  .subtitle_wrap > span {font-size: 2rem;}
  .subtitle_wrap > p {font-size: 1rem;}
  .gallery_box{width: 100%;}
  .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),
  .remove-table th:nth-child(3), .remove-table td:nth-child(3) {display: table-cell;}
  .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 > li {font-size: 0.9rem; margin: 0 10px 10px;}
  .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;}
} 

@media (max-width: 540px) {
  #mlayout .mtxt{display: none;}
  
  .slider {width: 90%; height: 420px; float: left;}
  .minner{background-size: auto; height: 124px; margin-top: 140px;}
  .mbox {margin: 24px 0;}
  .mtime {font-size: 5.4vw;}
  .mday > span {display: block; padding: 0;} 
  .mQuick > li > a {font-size: 3.6vw;}
  .mguide {display: block;}
  .mguide > li {display: flex; width: 100% !important; padding: 8px;}
  .mguide > li:last-child > span {display: flex; align-items: flex-start;}
  .mguide > li > p {padding: 0;}
  .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%;}
  #content_login{padding: 20px 14px 40px;}
  .step {padding: 5px;}
  .step > ul > li {font-size: 0.7rem; margin: 0; width: 70px;}
  
  .signup_wrap::before {top: 110px;}
  .siagnid{width:calc(100% - 90px) !important;}
  .siagnadd{width: 120px !important;}
  .gallery_scale {display: block;}
  .gallery_scale > li:last-child {padding: 0px 30px 10px 10px;}
  .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;}
  .gallery_box{height: 210px;}
  .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: 14px;}
  .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 {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;}
  .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;}
  .period > input {width: calc(50% - 30px);}
  .sch_sel > select {width: 30%;}
  .sch_sel > input {width: 40%;};
  .sch_sel > button {width: 20%;}
}