@font-face{font-family:'Pretendard';font-weight:45 920;font-style:normal;font-display:swap;src:url('../fonts/PretendardVariable.woff2') format('woff2-variations')}

#logout { cursor: pointer; }

/* NAV 관련 */
#gnb {
    min-height: 100svh;
    flex-basis: 14svw;
    overflow: hidden;
    max-width: 14svw;
    min-width: 14svw;
    background: #fff;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.065);
    padding: 0 30px;
    border-right: solid 1px #e1e1e1;
    z-index: 9;
    display: flex;
    flex-direction: column;
}
#gnb .logo {
    height: 120px;
    width: auto;
    margin: 60px 0 25px;
    float: none;
}
#gnb .logo a {
    width: inherit;
    height: inherit;
}
#gnb .logo img {
    width: inherit;
    height: inherit;
}
/* @media screen and (min-device-pixel-ratio:0) {
    #gnb .logo img {
        height: inherit;
    }
} */
#gnb .gnb_wrap {
    flex-grow: 1;
}
#gnb .gnb-ul li a {
    display: flex;
    padding: 10px 15px;
    font-size: 1rem;
    font-weight: 500;
}
#gnb .btn-box {
    text-align: center;
    padding: 1rem 0rem;
}
#gnb .btn-box a {
    font-weight: 500;
    padding: 0.25rem 0.75rem;
    display: block;
    cursor: pointer;
}

/* 메인페이지 */
#home .content-logo {
    padding: 2rem 10rem;
    display: flex;
    justify-content: center;
    background-color: #14212e;
}
#home .content-logo img {
    width: 400px;
}

/* foot.blade.php */
footer {
    background-color: #333;
}
#ft_copy {
    background-color: rgba(0,0,0,0.2);
    color: rgba(255,255,255,0.25);
    text-shadow: 1px 1px 1px rgba(0,0,0,0.1);
    text-align: center;
    width: 100%;
    padding: 20px 0;
    color: #5b5b5b;
    font-size: 0.92em;
}
/* 푸터 */
#ft_copy p {
  font-size: 1.2rem;
}
#ft_copy p strong {
	padding:0 5px;
	display:inline-block;
}

/* subpage */
#sub_page {
    flex-basis: 86svw;
    overflow: hidden;
}
.sub_title {
  font-size:2rem;
  border-bottom:1px solid #8989;
  margin-bottom: 3rem;
  font-weight: bold;
}
.sub_top_img_wrap {
  width:100%;
  height:200px;
  overflow:hidden;
  box-shadow: 0px 1px 4px #aaa;
  position:relative;
}

.sub_top_img_wrap img {
  object-fit:cover;
  width:100%;
  height:200px;
}

.img_shadow {
  width:100%;
  height:300px;
  position:absolute;
  background:rgba(0,0,0,0.3);
}

.sub_top_img_wrap .sub_title {
  position:absolute;
  left:50%;
  top: 50%;
  color:#fff;
  transform:translate(-50%,-50%);
}
.sub_page_info_wrap {
    width: 100%;
    overflow: hidden;
    padding:30px 100px;
    position:relative;
}
.sub_page_info_wrap h3 {
  font-size: 2rem;
}
.sub_content {
  margin:20px 0 0 0;
}
.sub_page_info_wrap p {
    font-size: 1.25rem;
    font-weight: 500;
}
.sub_page_info_wrap > .tab {
    display: none;
}
.sub_page_info_wrap > .tab[data-tab='1'] {
    display: block;
}
#facility {
    overflow: hidden;
}
.sub_page_info_wrap > .tab > .swiper-wrap {
    height: 500px;
    display: flex;
    align-items: center;
    overflow: hidden;
}
.sub_page_info_wrap > .tab > h3 {
    font-size: 1.75rem;
    font-weight: 800;
    text-align: center;
    border-bottom: 1px solid #000;
    display: flex;
    width: 200px;
    justify-content: center;
    align-items: center;
    margin: 30px auto;
}
.sub_page_info_wrap .helloModify {
    display: flex;
    justify-content: flex-end;
}
.sub_page_info_wrap .modify-area {
    display: none;
}
.sub_page_info_wrap .helloModify button,
.sub_page_info_wrap .modify-area .btn-box button {
    padding: 0.375rem 1.75rem;
    border: 1px solid #dadada;
    border-radius: 4px;
    font-size: 1.125rem;
}
.sub_page_info_wrap .modify-area #update-hello {
    border: 1px solid #dadada;
    border-radius: 4px;
    resize: none;
    width: 100%;
    height: 400px;
    padding: 1rem;
    font-size: 1.125rem;
}
.sub_page_info_wrap .modify-area .btn-box {
    display: flex;
    justify-content: center;
}
.sub_page_info_wrap .modify-area .btn-box button {
    border: 0;
    background-color: var(--s-blue-2);
    color: white;
    box-shadow: 3px 3px 5px -3px var(--s-blue-5);
}
.sub_page_info_wrap .modify-area .btn-box button::after,
.sub_page_info_wrap .modify-area .btn-box button:active {
    background-color: var(--s-blue-4);
    font-weight: bold;
    transform: translate(1px, 1px);
}

.location {
  display:flex;
  flex-direction: column;
}
.table table {
  width:100%;
}

.table table th {
  background:#0059a9;
  color:#fff;
  padding:15px 0;
  font-size:1.3rem;
}

.table table caption {
  font-size:1.3rem;
}


/* 카카오맵 지도관련 CSS */
.map_wrap {float:left; position:relative;overflow:hidden;width:100%;height:400px; z-index:0 !important;}
.radius_border{ border-radius:5px;}
.custom_typecontrol {position: absolute;
    top: 10px;
    right: 5px;
    /* overflow: hidden; */
    /* width: 130px; */
    height: 30px;
    margin: 0;
    padding: 0;
    z-index: 1;
    display: flex;

    flex-direction: column;
    font-family: 'Malgun Gothic', '맑은 고딕', sans-serif;}
.custom_typecontrol span { font-size:0.7rem; display:block;width:65px;height:30px;float:left;text-align:center;line-height:30px;cursor:pointer;}
.custom_typecontrol .btn { background:#fff;background:linear-gradient(#fff,  #e6e6e6);}
.custom_typecontrol .btn:hover {background:#f5f5f5;background:linear-gradient(#f5f5f5,#e3e3e3);}
.custom_typecontrol .btn:active {background:#e6e6e6;background:linear-gradient(#e6e6e6, #fff);}
.custom_typecontrol .selected_btn {border-radius:5px;font-size:0.7rem; color:#fff;background:#425470;background:linear-gradient(#425470, #5b6d8a);}
.custom_typecontrol .selected_btn:hover {color:#fff;}

.custom_zoomcontrol {
    box-shadow: rgb(0 0 0 / 15%) 0px 2px 2px 0px;
    position:absolute;
    top:110px;right:8px;
    width:40px;height:80px;overflow:hidden;z-index:1;background-color:#f5f5f5;}
.custom_zoomcontrol span {
    display:block;width:36px;height:40px;text-align:center;cursor:pointer;
    border-top: 1px solid rgb(226, 226, 226);
    border-right: none;
    border-bottom: none;
    border-left: none;
    border-image: initial;
    width:40px;
    height:40px;
    }
.custom_zoomcontrol span img {width:15px;height:15px;padding:12px 0;border:none;}
.custom_zoomcontrol span:first-child{
    background: url(https://t1.daumcdn.net/mapjsapi/images/2x/control.png) -40px 3px / 124px 264px no-repeat rgb(255, 255, 255);
}
.custom_zoomcontrol span:nth-child(2){
    background: url(https://t1.daumcdn.net/mapjsapi/images/2x/control.png) -40px -29px / 124px 264px no-repeat rgb(255, 255, 255);
}
/* 카카오지도 마커 CSS */
.customoverlay {position: relative;
    bottom: 72px;
    border-radius: 6px;
    border: 1px solid #ccc;
    border-bottom: 2px solid #ddd;
    float: left;
    /* left:8px; */
}
.customoverlay:nth-of-type(n) {border: 0;box-shadow: 0px 1px 2px #888;}
.customoverlay a {display: block;
    text-decoration: none;
    color: #000;
    text-align: center;
    border-radius: 6px;
    font-size: 14px;
    font-weight: bold;
    overflow: hidden;
    background: #d95050;
    background: #007bff url(https://t1.daumcdn.net/localimg/localimages/07/mapapidoc/arrow_white.png) no-repeat right 14px center;
    background: #fff;
}
.customoverlay .title {display: block;
    text-align: center;
    background: #fff;
   /*  margin-right: 35px; */
    padding: 10px 15px;
    font-size: 14px;
    font-weight: bold;}
.customoverlay:after {content:'';position:absolute;margin-left:-12px;left:50%;bottom:-12px;width:22px;height:12px;background:url('https://t1.daumcdn.net/localimg/localimages/07/mapapidoc/vertex_white.png')}

.location_info {
  margin:20px 0 0 0;
  font-size:1.5rem;
}

.location_info ul {
  border-top: 1px solid mediumblue;
}

.location_info ul li {
  text-align:center;
  position:relative;
  padding:10px 0 10px 60px;
  border-bottom:1px solid #ddd;
}

.location_info ul li strong {
  position: absolute;
  left: 0;
  width: 150px;
  text-align: center;
  line-height: 47px;
  top: 0;
  background: #f9f9f9;
  bottom: 0;
}

.location_info ul li span {
  padding:20px 10px;
}

/* 인사말 */
#greeting_input {
  width:100%;
  min-height:400px;
}

/*연습장 */
.exercise_btn_wrap {
  display:flex;
  justify-content:space-between;
  border:1px solid #ddd;
}

.exercise_btn_wrap button {
  width:50%;
  border:none;
  background:#fff;
  border-right:1px solid #ddd;
  padding:15px 0;
  font-size:1.2rem;
}

.exercise_btn_wrap button:last-child {
  border-right:none;
}

.exercise_btn_wrap button.active {
  background:#14212e;
  color:#fff;
}

.exercise_info_wrap > div > h3 {
  text-align: center;
  border-bottom: 1px solid #000;
  display: flex;
  width: 200px;
  justify-content: center;
  align-items: center;
  margin:30px auto;
}

.exercise_info {
  display:none;
}

.exercise_info.active {
  display:block;
}

.exercise_main_text {
  margin:10px 0 0 0;
}

.exercise_main_text img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  display: flex;
  margin: 0 auto;
}

.exercise_ul {
    width: 100%;
  margin:10px 0 0 0;
}

.exercise_ul li {
  display:flex;
}

.exercise_ul strong {
  width: 15%;
  align-items: center;
  display: flex;
  justify-content: center;
  border-bottom:1px solid #ddd;
  background:#f9f9f9;
  font-size:1.2rem;
}

.exercise_ul p {
  border-left:1px solid #ddd;
  border-bottom:1px solid #ddd;
  color:#888;
  padding:15px 5px;
  width:85%;
  font-size: 1.2rem;
  word-break:keep-all;
}

/* 편의시설 */
.convenience_info {
  margin:20px 0 0 0;
}

.convenience_info strong {
  font-size:2rem;
}

.convenience_info p {
  font-size:1.2rem;
  color:#888;
  word-break:keep-all;
}

/* 이미지 슬라이더(슬릭) */
.slick-slider {
  border:1px solid #ddd;
}

.slick-prev {
  position:absolute;
  left:25px;
  top:50%;
  transform:translate(-50%,0);
  z-index:9999;
}

.slick-arrow {
  color:#000;
}

.slick-next {
  position:absolute;
  right:0;
  top:50%;
  transform:translate(-50%,0);
  z-index:99999;
}

.slick-dots {
  display: flex;
  position: absolute;
  bottom: 2px;
  left: 50%;
  transform:translate(-50%,0);
}

.slick-dots li {
  margin:0 2px;
}

.slick-dots button {
  border: none;
  text-indent: -9999px;
  overflow: hidden;
  width: 15px;
  height: 15px;
  background:rgba(0,0,0,0.5);
  border-radius: 15px;
}

.slick-dots li.slick-active button {
  background:#fff;
}

.slick-btn {
  font-size:3rem;
  cursor:pointer;
}

.btn {
  display: inline-block;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  background-color: transparent;
  border: 1px solid transparent;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  border-radius: 0.25rem;
  transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}

.btn-primary {
  color: #fff;
  background-color: #0d6efd;
  border-color: #0d6efd;
}

.btn-secondary {
  color: #fff;
  background-color: #6c757d;
  border-color: #6c757d;
}

.btn-success {
  color: #fff;
  background-color: #198754;
  border-color: #198754;
}

.gt_u_btn {
  position:absolute;
  top:44px;
  left:250px;
  font-size:1rem;
}

.gt_content {
  font-size:1.5rem;
  word-break:keep-all;
}

/* 강사소개 */
.profile_wrap {
  margin:10px 0 0 0;
}

.profile_wrap h3 {
  text-align:center;
  font-size:2rem;
  color:#666;
  width:100%;
  border-bottom:1px solid #dbdbdb;
  font-weight: bold;
  padding: 2rem 0rem 1rem;
}

.profile_wrap table {
  width:100%;
  border-spacing:0;
}

.profile_wrap table img {
  width:100%;
}

.profile_wrap table th {
  background:#14212e;
  color:#fff;
  padding:15px 0;
}

.profile_wrap table th,td {
  text-align:center;
  font-size:1.25rem;
  border-bottom: 1px solid #ddd;
  border-right:1px solid #ddd;
}

.profile_wrap table th:last-child,td:last-child {
  border-right:none;
}

.profile_wrap td {
  color:#666;
}

.profile_wrap table td:nth-child(1) {
  width:15%;
}
.profile_wrap table td:nth-child(2) {
  width:10%;
}
.profile_wrap table td:nth-child(3) {
  width:10%;
}
.profile_wrap table td:nth-child(4) {
  width:10%;
}
.profile_wrap table td:nth-child(5) {
  text-align:left;
  font-size: 1.5rem;
  width:55%;
  padding:0 0 0 10px;
}

.profile_wrap table tr {
  border-top:1px solid #ddd;
  border-bottom:1px solid #ddd;
}



/* 프로그램 안내 */
.program h3 {
  font-size:1.5rem;
  margin:10px 0 0 0;
}

.usage_img_wrap {
  text-align:center;
  padding:0 90px 80px 90px;
}

.program img {
  width:100%;
  margin:25px 0 0 0;
/*   padding:0 40px; */
}

/* 광고문의 */
.advertising_wrap img {
  width: 60%;
  padding: 50px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
}


/* 이용안내 */
.information {
  text-align:center;
}

.information h2 {
  text-align:left;
}

.information img {
  width:100%;
}


.information_wrap {
  background:#ddd;
  padding:10px;
}

.information_table {
  width:100%;
  margin:10px 0 0 0;
}

.information_table th {
  background:#14212e;
  color:#fff;
  font-size:1.3rem;
  padding:15px 0;
}

.information_table td:first-child {
 padding:50px 10px;
 width:15%;
}

.information_table p {
  word-break:keep-all;
}

@media all and (max-width:1150px) {
  .location_info ul li {
    padding:0;
  }

  .location_info ul li strong {
    display:block;
    width:100%;
    position:static;
    border-bottom:1px solid #ddd;
  }

  .location_info ul li span {
    display:block;
  }

  .advertising_wrap img {
    width: 80%;
    padding: 50px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

@media all and (max-width:992px) {
  .usage_img_wrap {
    padding:0;
  }

  .sub_page_info_wrap {
    padding:30px 20px;
  }
  .information img {
    width:100%;
  }

  .exercise_btn_wrap {
    flex-wrap:wrap;
  }

  .exercise_btn_wrap button {
    border-bottom:1px solid #ddd;
  }

  .exercise_btn_wrap button:nth-child(5) {
    border-bottom:none;
  }

  .exercise_btn_wrap button:nth-child(6) {
    border-bottom:none;
  }

  .exercise_ul li {
    flex-wrap:wrap;
  }

  .exercise_ul strong {
    width:100%;
    padding:10px 0;
  }

  .exercise_ul p {
    width:100%;
  }



}

@media all and (max-width:768px) {
/*   .profile_wrap table th:first-child {
    display:none;
  }

  .profile_wrap table td:first-child {
    display:none;
  } */

  .sub_top_img_wrap {
    height:100px;
  }

  .sub_top_img_wrap img {
    height:100px;
  }

	.exercise_main_text img {
		height:300px;
  }

  .information_table p {
    word-break:normal;
  }

  .advertising_wrap img {
    width: 100%;
    padding: 0;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
  }

}

#login {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #14212e;
}
#login label {
    display: inline-block;
    padding: 0.25rem 0rem;
    color: white;
}
#login .login-wrap {
    width: 480px;
}
#login input {
    width: 100%;
    border: 1px solid #dadada;
    padding: 0.75rem 1rem;
    border-radius: 4px;
}
#login .btn-box {
    padding-top: 2rem;
}
#login button {
    width: 100%;
    padding: 1rem 0rem;
}
