@charset "utf-8";
/* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */

#skipToContent a {z-index:100000;position:absolute;top:0;left:0;width:1px;height:1px;font-size:0;line-height:0;overflow:hidden}
#skipToContent a:focus,
#skipToContent a:active {width:200px;height:50px;background:#21272e;color:#fff;font-size:14px;font-weight:bold;text-align:center;text-decoration:none;line-height:50px}

.only-desktop-tablet {display:block;}
.only-desktop {display:block;}
.only-tablet-mobile {display: none;}
.only-tablet {display:none;}
.only-mobile {display:none;}

.contain {max-width:1580px; padding-left:30px; padding-right:30px; margin:0 auto;}

/* header */
#header {position:fixed; width:100%;  z-index:100; top: 0;}
#header.active {background:rgba(67,58,51,.5);}
#header .contain {position:relative; display:flex; align-items:center; justify-content:space-between; height:100px; z-index:10; max-width: 1520px;}

#gnb {text-align:center; padding-top: 35px;}
#gnb>ul {display:flex; justify-content:center;}
#gnb>ul>li {position:relative; padding:0 33px;}
#gnb>ul>li>a {position:relative; display:flex; align-items:center; flex-direction: column; justify-content:center; height:65px;color:#fff; font-size:24px; font-weight:600; letter-spacing:-.03em; line-height:1.3em;}
#gnb>ul>li>a:after {content:""; position:absolute; bottom:-1px; left:50%; width:0; height:4px; background:#bc9c15; transition:.2s;}
#gnb>ul>li.active>a:after {width:100%; left:0;}
#gnb .submenu {display:none; position:absolute; left:33px; text-align:center;}
#gnb .submenu>ul {display:flex;}
#gnb .submenu>ul>li:first-child>a {padding-left: 0;}
#gnb .submenu>ul>li>a {display:block; padding:18px 11px; color:#fff; font-size:18px; line-height:1.33em; white-space:nowrap;}
#gnb .submenu>ul>li>a:hover {color:#bc9c15;}
#gnb .submenu>ul>li.active>a {color:#bc9c15;}
.submenu-bg {display:none; position:absolute; width:100%; top: 100px; left:0; background:rgba(67,58,51,.9);}

.language {position: relative; width:auto; height: 100px; padding-top: 35px; display: flex; align-items: center; justify-content: center; z-index:51;}
.language.active .bt-lang:before {transform:rotate(180deg);}
.language .bt-lang {position:relative; display:block; padding-left: 25px;padding-right: 30px; line-height:1.2em; font-size:16px; font-weight:700; color:#fff; width:auto;}
.language .bt-lang:before {content:""; position:absolute; top:50%; margin-top:-6px; right:0; width:12px; height:10px; background: url('../images/common/ico_arrow_bottom.png') 50% 50% no-repeat;}
.language .bt-lang:after {content:""; position:absolute; width:16px; height:16px; background:url("../images/common/ico_lang.png") no-repeat 50% 50%; left:0; top:1px;}
.language .lst {display:none; text-align:center; position:absolute; top: 100px;	left:0; width:100px; border:1px solid #ddd; border-radius:2px; background:#fff; z-index:55; padding:12px 0;}
.language .lst li { text-align:center; }
.language .lst li a {display:block; font-size:16px; font-weight:400; line-height:1.4em; color:#333;text-decoration:none;}
.language .lst li a:hover {color:#00712f;}

/* for mobile */
.btn-m-menu {display:block; position:relative; width:30px; height:26px; margin-top: 35px; overflow:hidden; text-indent:-9999em; z-index:50;}
.btn-m-menu span {position:absolute; top:50%; left:0; width:100%; height:1px; margin-top:-1px; background:#fff;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; left:0; width:100%; height:1px; background:#fff;}
.btn-m-menu span:before {top:-10px;}
.btn-m-menu span:after {bottom:-10px;}

.mobile-navigation {display:block; position:fixed; top:0; right:0; width:100vw; height:100%; overflow:auto; transition:.2s linear; -ms-transform:translateX(100%); transform:translateX(100%); background:#fcf8ee; z-index:150;}
.mobile-navigation .inner {display: flex; align-items: flex-end; justify-content: center; max-width: 1630px; padding: 100px 30px; margin: 0 auto; position: relative;}
.mobile-navigation .img {flex: 1; padding-right: 60px;}
.mobile-navigation .nav-cnt {max-width: 760px; width: 48.5%;}
.mobile-navigation .nav-cnt > ul {display: flex; flex-wrap: wrap; gap: 0 70px; }
.mobile-navigation .nav-cnt > ul > li {margin-bottom: 135px;}
.mobile-navigation .nav-cnt > ul > li > a {font-size: 36px; font-weight: 700; color: #333; margin-bottom: 26px; display: block;}
.mobile-navigation .nav-cnt .submenu li {padding: 10px 0; line-height: 1em;}
.mobile-navigation .nav-cnt .submenu a {font-size: 20px; font-weight: 400;}
.mobile-navigation .nav-cnt .submenu a:hover {color: #998675}
.mobile-navigation .info span {font-size: 16px; font-weight: 600; color: #000; margin-right: 20px;}
.mobile-navigation .close {position:absolute; top:25px; right:18px; width:26px; height:26px; text-indent:-9999em; overflow:hidden;}
.mobile-navigation .close:before,
.mobile-navigation .close:after {content:" "; position:absolute; top:12px; left:0; width:100%; height:3px; background:#000; border-radius:3px;}
.mobile-navigation .close:before {transform:rotate(45deg);}
.mobile-navigation .close:after {transform:rotate(-45deg);}
.mobile-overlay {display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:#000; opacity:0.6; z-index:101;}

html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0);}
html.menu-opened .mobile-overlay {display:block;}

/* main */
.main-visual {position:relative; overflow:hidden; text-align:center; color:#fff;}
.main-visual .item {position:relative; overflow:hidden;}
.main-visual .item img {top:0; left:0; width:100%; height:100%; object-fit:cover; transition:5s; transform:scale(1.1);}
.main-visual .caption {position:absolute;  bottom:50%; left:50%; width:100%; line-height:1.3em; letter-spacing:-.03em; transition:1.4s; transform:translate(-50%, 50%); max-width: 1520px; padding: 0 70px; text-align: left;}
.main-visual .caption h2 {font-size: 50px; font-weight: 700; line-height: 1em; margin-bottom: 27px;}
.main-visual .caption p {font-size: 26px; font-weight: 100; line-height: 1.385em;}
.main-visual .slick-dots {position:absolute; bottom:100px; left:0; width:100%; text-align:center; line-height:0;}
.main-visual .slick-dots li {display:inline-block; margin:0 19px;}
.main-visual .slick-dots li button {display:flex; align-items:center; justify-content:center; width:12px; height:12px; color:#fff; font-size:14px; font-weight:700; background:transparent; transition:.2s; border: none; border-radius:100%; text-indent: -9999em; background-color: #fff;}
.main-visual .slick-dots li.slick-active button {position: relative; background: #43362a;}
.main-visual .slick-dots li.slick-active button:before {position: absolute; content: ''; width: 30px; height: 30px; border-radius: 100%; border: 1px solid #fff; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 51;}
.main-visual .scroll {position:absolute; bottom: 7%; left:50%; transform: translateX(-50%); margin-top:25px; z-index:50; display: flex; flex-direction: column;}
.main-visual .scroll span {font-size: 15px; margin-bottom: 5px; font-weight: 400; letter-spacing: .1em;}
.main-visual .scroll .img {animation:1.5s scrollUpDown linear infinite;}
.main-visual .active .item img {transform:scale(1);}


.point {color: #9b6f5a;}
.point2 {color: #7e6854;}

.main-tit .tag {font-weight: 100; font-size: 20px; letter-spacing: .3em; line-height: 1em;}
.main-tit h2 strong {font-size: 50px; margin-bottom: 15px; display: block;}
.main-tit h2 {font-size: 40px;line-height: 1em;letter-spacing: -.05em; position: relative; color: #333; font-weight: 400;}
.main-tit.large h2 {font-size: 60px; font-weight: 400;}
.section {padding-top: 100px;}

.m-bna:before {position: absolute; content: ''; width: calc(50% - 800px); background: #998675; height: 1px; left: 0; top: 110px;}
.m-bna {padding-bottom: 75px; position: relative;}
.m-bna .contain {display: flex;}
.m-bna .txt {width: 27.5%; padding-right: 70px;}
.m-bna .main-tit .tag {margin-bottom: 85px; position: relative;}
.m-bna .main-tit h2	{height: 225px; position: relative; margin-bottom: 40px;}
.m-bna .main-tit h2:before {position: absolute; content: '&'; font-weight: 600; font-size: 300px; right: 0; top: 0; line-height: 215px; color: #f7f7f7; z-index: -1;}
.m-bna .main-tit strong {transform: translate(-10px,23px); display: inline-block; color: #7c612d; font-size: 80px;}
.m-bna .desc-tit {font-size: 30px; color: #333;}
.m-bna .desc p {margin-top: 25px; font-weight: 400; font-size: 18px; letter-spacing: 0; line-height: 1.333em;}
.m-bna .bna-gallery .imgs {display: flex;}
.m-bna .photo {flex: 1; overflow: hidden;}
.m-bna .item-tit {font-size: 24px; font-weight: 600; color: #000; line-height: 1em; margin-top: 35px; margin-bottom: 65px;}
.m-bna .imgs .img {position: relative;}
.m-bna .imgs .img:before {position: absolute; content: 'Before'; font-size: 24px; color: #fff; left: 35px; bottom: 20px;}
.m-bna .imgs .img:last-child:before {content: 'After';}
.m-bna .submenu {margin-bottom: 50px;}
.m-bna .submenu .tabs {display: flex; justify-content: flex-end;}
.m-bna .submenu .tabs li {font-size: 20px; font-weight: 600; color: #998675; background: #f8ece1; display: flex; align-items: center; justify-content: center; width: 150px; height: 50px;}
.m-bna .submenu .tabs li.active {color: #fff; background: #998675;}
.btn-more {width: fit-content; font-size: 20px; color: #000; letter-spacing: 0;padding: 12px 30px; border: 1px solid #998675;margin-left: auto; display: flex; align-items: center; justify-content: center;}
.m-bna .swiper-pagination {top: auto; bottom: 70px; height: 10px; background: #ddd;}
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {background: #deb024;}
.doctor1-gallery .swiper-pagination {top: auto; bottom: 0; height: 10px; background: #ddd;}
.swiper-button-prev:after, .swiper-button-next:after {color: #fff;}
.m-bna .swiper-button-prev, .m-bna .swiper-button-next {top: 40%;}

.m-special .main-tit {text-align: center; margin-bottom: 85px;}
.m-special .main-cnt .items {display: flex; flex-wrap: wrap; justify-content: center;}
.m-special .main-cnt .item {position: relative; width: 33.3333%;}
.m-special .main-cnt .item .img, .m-special .main-cnt .item .img img {width: 100%;}
.m-special .main-cnt .item .txt{position: absolute; top: 70px; left: 0; width: 100%; text-align: center; color: #fff;}
.m-special .main-cnt .item .txt .tit {font-size: 36px; line-height: 1.3em; position: relative; padding-bottom: 27px;}
.m-special .main-cnt .item .txt .tit:before {position: absolute; content: ''; background: #fff; width: 60px; height: 2px; left: 50%; transform: translateX(-50%); bottom: 0;}
.m-special .main-cnt .item .txt p {font-size: 20px; padding-top: 20px;     letter-spacing: -.025em;}

.m-aftercare {padding-bottom: 100px;background: rgba(153,134,117,0.1);}
.m-aftercare .main-tit {text-align: center; margin-bottom: 75px;}
.m-aftercare .main-tit p {font-size: 20px; color: #998675; line-height: 1.2em; margin-top: 20px;}
.m-aftercare .main-cnt p {margin-top: 75px; font-size: 20px; color: #000; text-align: center; line-height: 1.4em;}

.m-doctors {margin-top: 130px; background: url('../images/main/bg_doctors.jpg') no-repeat top 130px center; background-size: cover; padding-bottom: 80px;}
.m-doctors .txt {background: url('../images/main/bg_world.png') no-repeat top 70px right -22px #998675; color: #fff; max-width: 1520px; margin: 0 auto; padding: 85px 35px 55px 100px; display: flex; align-items: flex-end;}
.m-doctors .txt h2 {font-size: 50px; font-weight: 400; margin-bottom: 25px;}
.m-doctors .txt h2 strong {font-size: 60px;}
.m-doctors .txt .desc {width: 50%;}
.m-doctors .tit {text-align: center; color: #fff; font-size: 46px; letter-spacing: -.05em; padding-top: 65px; padding-bottom: 100px;}
.m-doctors .tit p { font-weight: 100;  line-height: 1em;}
.m-doctors .tit h2 {line-height: 1em; position: relative; width: fit-content; margin: 30px auto 0; padding-left: 65px; font-size: 46px;}
.m-doctors .tit h2:before {position: absolute; content: ''; background: url('../images/main/m_doc_arrow.png') no-repeat center center; background-size: contain; width: 40px; height: 23px; top: 50%; transform: translateY(-50%); left: 0;}
.m-doctors .btn-more {color: #fff; border: 1px solid #fff; width: 180px; height: 50px; padding: 0;}
.m-doctors .doctors-gallery .swiper-wrapper {padding-bottom: 95px;}
.m-doctors .doctors-gallery .item {position: relative; width: fit-content; margin: 0 20px;}
.m-doctors .doctors-gallery .item > a {pointer-events: none;}
.m-doctors .doctors-gallery .name {position: absolute; left: 22px; bottom: 27px; display: flex; gap: 15px; color: #fff; font-size: 24px; font-weight: 500;}
.m-doctors .doctors-gallery .swiper-pagination {top: auto; bottom: 0; background: #ddd; height: 10px; max-width: 1520px; left: 50%; transform: translateX(-50%);}
.m-doctors .doctors-gallery .swiper-button-prev, .m-doctors .doctors-gallery .swiper-button-next {position: absolute; width: 50px; height: 80px; top: 50%; transform: translateY(-50%); overflow: hidden; border: none; font-size: 0; text-indent: -9999em; z-index: 10;}
.m-doctors .doctors-gallery .swiper-button-next {right: 0; background: url('../images/sub/facility_arrow_next.jpg') no-repeat center center; background-size: contain;}
.m-doctors .doctors-gallery .swiper-button-prev {left: 0; background: url('../images/sub/facility_arrow_prev.jpg') no-repeat center center; background-size: contain;}
.m-doctors .doctors-gallery .swiper-button-prev:after, .m-doctors .doctors-gallery .swiper-button-next:after {content: none;}

.m-interior {display: flex; padding-bottom: 200px; width: 100%;}
.m-interior .main-tit {max-width: 1080px; margin: 0 0 40px auto; padding-left: 30px;}
.m-interior .main-tit .tag {font-weight: 400; margin-bottom: 35px;}
.m-interior .main-tit h2 strong {font-size: 60px; font-weight: 600;}
.m-interior .main-tit p {font-size: 20px; font-weight: 400; color: #000; line-height: 1.2em; margin-top: 25px;}
.m-interior .left {flex:1; padding-right: 60px; position: relative;}
.m-interior .left:before {position: absolute; content: ''; width: calc(100% - 1140px); background: #998675; height: 1px; left: 0; top: 9px;}
.m-interior .img, .m-interior .img img {width: 100%;}
.m-interior .photo {width: 50%; min-width: 524px; margin-top: 35px;}
.m-interior .photo p {font-size: 20px; font-weight: 400; color: #000; line-height: 1.2em; margin-top: 25px;}
.m-interior .right {width: 36.458%; display: flex; flex-direction: column; justify-content: space-between;}
.m-interior .btn-more {margin-left: 0; margin-right: auto;}

.m-map {position: relative;}
.m-map iframe {width: 100% !important;}
.m-map .contain {position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 100%;}
.m-map .contain .info {width: 540px; text-align: center; padding: 45px 30px 90px; color: #fff; background: #7e6854; margin-left: auto;}
.m-map .contain .info .tit {font-size: 36px; font-weight: 700; margin-bottom: 25px;}
.m-map .contain .info .item {padding: 22px 0 22px 15px; border-top: 1px solid rgba(255,255,255,.2); display: flex; justify-content: center; gap: 9px;}
.m-map .contain .info .item.loca .item-cnt {font-size: 20px; font-weight: 700;}
.m-map .contain .info .item.tel .item-cnt {text-align: left; font-size: 18px; font-weight: 700;}
.m-map .contain .info .item.time .item-cnt {font-size: 18px;}
.m-map .contain .info .item-cnt {width: fit-content;}
.m-map .contain .info .item .ico {margin-top: 7px;}
.m-map .contain .info > p {font-size: 18px; line-height: 1.333em;}

/* sub */
.sub-visual {position:relative; height:auto; max-height: calc(100vh + 120px); color:#fff; text-align:center; overflow:hidden; background:#333;}
.sub-visual .bg, .sub-visual .bg img {width: 100%;}
.sub-visual .bg {animation:1.5s subvisual linear;}
.sub-visual .inner {position:absolute; top:58%; left:0; width:100%; transform:translateY(-50%);}
.sub-visual h2 {font-size:52px; font-weight:700; line-height:1.3em; letter-spacing:-.03em; text-align: left;}
.sub-visual .scroll-down {position: absolute; bottom: 160px; left: 50%; width: 19px; height: 28px; animation:1.5s scrollUpDown linear infinite;}
.sub-visual .scroll-down img {position: absolute; width: 100%; height: 100%; object-fit: contain; left: 0;}
.sub-visual.none-lnb .inner {padding:0;}
.loaded .sub-visual .bg {transform:scale(1); opacity:1;}

@keyframes subvisual {
 0% {transform: scale(1.05);}
 100% {transform: scale(1);}
}

@keyframes scrollUpDown {
 0% {transform: translateY(0);}
 50% {transform: translateY(20px);}
 100% {transform: translateY(0);}
}

.lnb-wrap {position:relative; transform: translateY(-119px);}
.lnb {margin:0 auto; max-width:1200px;}
.lnb .swiper-container {margin-bottom:-2px;}
.lnb .swiper-wrapper, .sub-tab .swiper-wrapper {transform: translate3d(0px, 0px, 0px);}
.lnb .swiper-wrapper {margin-left: -15px;}
.lnb ul {justify-content:center;}
.lnb ul li {text-align:center; width: max-content; min-width: 80px; background: rgba(126,104,84,.5); }
.lnb ul li:not(:last-child) {border-right: 1px solid  #ddd;}
.lnb ul li a {position: relative; display:flex; flex-direction: column; align-items:flex-start; gap: 5px; justify-content:center; width:300px; height:120px; padding:0 25px; color:#fff; font-size:24px; font-weight:200; line-height:1.2em; letter-spacing:-.02em; word-break:keep-all}
.lnb ul li a .num {font-weight: 700; font-size: 20px;}
.lnb ul li.active {background: #fff;}
.lnb ul li.active a {color: #7e6854;}

.subtab-wrap {padding-bottom: 40px; border-bottom: 3px solid #7e6854;}
.subtab {margin: 0 auto; max-width: 480px;}
.subtab ul {border: 1px solid #ddd; border-right: none;}
.subtab ul li {text-align: center; flex: 1; border-right: 1px solid #ddd;}
.subtab ul li a {display: flex; justify-content: center; align-items: center; width: 100%; height: 60px; color: #333; font-size: 20px; font-weight: 700;}
.subtab ul li.active a {color: #fff; background: #7e6854;}

.sub-title {padding-bottom: 85px;  margin: 0 auto; display: flex; position: relative;}
.sub-title:before {position: absolute; content: ''; width: calc((100% - 1580px) / 2); height: 1px; top: 13px; left: 0; background: #9b6f5a;}
#contArea.wide .sub-title {padding-left: 30px; padding-right: 30px;}
.sub-title > * {flex: 1;}
.sub-title h2 {font-size: 20px; line-height: 1.3em; color: #9b6f5a; letter-spacing: .3em; font-weight: 100; max-width: 1580px; margin: 0 auto; padding: 0 30px;}
.sub-title .doc-tit {margin-bottom: 22px;}

#contArea {max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
#contArea.wide {max-width:100%; padding:0;}

.real-cont {padding-bottom:123px;}

/* footer */
.quick-menu {position: fixed; top: calc(50% - 120px); transform: translateY(-50%); right: 10px; width: 130px; color: #fff;}
.quick-menu > a {display: flex; width: 100%; height: 60px; padding: 3px 12px; align-items: center; word-break:keep-all}
.quick-menu > a > div {width: 100%;}
.quick-menu > a .menu {display: flex; align-items: center;}
.quick-menu > a:nth-child(1) .menu .ico {width: 27px;}
.quick-menu > a .menu .ico {width: 23px; display: flex; align-items: center; justify-content: center;}
.quick-menu > a .menu span {font-size: 15px; font-weight: 700; line-height: 1.2em; flex: 1; text-align: center;}
.quick-menu > a .number {font-weight: 700; font-size: 12px; line-height: 1.2em; margin-top: 3px; display: block;}
.quick-menu > a:nth-child(1) {background: #362f2d;}
.quick-menu > a:nth-child(2) {background: #61b554;}
.quick-menu > a:nth-child(3) {background: #4268b3;}
.quick-menu > a:nth-child(4) {background: linear-gradient(to right, #7a39b3, #cf2f8e);}
.quick-menu > a:nth-child(5) {background: #ee2d23;}
.quick-menu > a:nth-child(6) {background: #00b900;}
.quick-menu > a:nth-child(7) {background: #000;}

#footer {background: #292017; color: #ccc; font-size: 16px; padding: 55px 0;}
#footer .contain {max-width: 1580px;}
address {line-height: 1.5em;}
address span {font-style: normal; margin-right: 18px;}
#footer .copyright {margin-top: 18px;}
#footer .copyright span {font-size: 12px; color: #372c21;}

.scroll-top {position:fixed; bottom:80px; right:60px; width:56px; height:56px; color:#fff; font-size:14px; line-height:1em; text-align:center; display:flex; justify-content:center; align-items:center; flex-direction: column; background: #292017; z-index:80; border: 1px solid rgba(255,255,255,.3); gap: 6px;}
