



.inner {
    width: calc(100% - 100px);
    height: 100%;
    margin: 0 auto;
    padding: 0 50px;
}

.dim {
    display: none;
    position: fixed;
    z-index: 99;
    width: 100vw;
    height: 100vh;
    background: rgba(000,000,000,.5);
}

.dim.on {
    display: block;
}

/***** sns-btn *****/
.sns-btn {
    right: 50px;
}

/***** web-header *****/
.web-header {
    display: none;
}

/***** tb-header *****/
.tb-header {
    display: block;
    padding: 15px 0;
}

.tb-header {
    position: absolute;
    top: 0;
    z-index: 99;
    width: 100%;
    border-bottom: 1px solid rgba(255,255,255,.2);
    transition: .2s;
}

.tb-header.scroll {
    position: fixed;
    z-index: 9999;
    background: #fff;
    border-bottom: 1px solid #ddd;
}

.tb-header .inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0;
}

.tb-header .logo a {
    display: block;
    width: 170px;
    height: 50px;
    background: url(../images/logo.png)no-repeat 0 0;
    background-size: 170px auto;
}

.tb-header.scroll .logo a {
    background: url(../images/logo_color.png)no-repeat 0 0;
    background-size: 170px auto;
}

.tb-header .menu > ul {
    display: none;
    position: absolute;
    top: 81px;
    right: 0;
    z-index: 9;
    width: 0;
    height: calc(100vh - 81px);
    background: #fff;
}

.tb-header .menu > ul.on {
    display: block;
    width: 450px;
    animation: slideIn 0.2s ease;
}

@keyframes slideIn {
    from {
      transform: translateX(100%);
    }
    to {
      transform: translateX(0);
    }
}

.tb-header .menu > ul > li {
    position: relative;
    padding: 30px 50px 25px;
}

.tb-header .menu > ul > li ~ li {
    border-top: 1px solid #aaa;
}

.tb-header .menu > ul > li > a {
}

.tb-header .menu .open-btn {
    position: absolute;
    top: 34px;
    right: 50px;
    width: 16px;
    height: 16px;
    display: inline-block;
    background: url(../images/open_btn.png)no-repeat 0 0;
    background-size: 16px 16px;
    cursor: pointer;
}

.tb-header .menu .open-btn.on {
    background: url(../images/close_btn.png)no-repeat 0 0;
    background-size: 16px 16px;
}

.tb-header .menu .sub-menu {
    display: none;
    padding: 20px 0 0 0;
}

.tb-header .menu .sub-menu li a {
    display: block;
    padding: 20px 0;
}

.tb-header .menu .sub-menu li ~ li {
    border-top: 1px solid #ddd;
}

.gnb-btn {
    display: block;
    position: absolute;
    top: 50%;
    right: 50px;
    transform: translateY(-50%);
    z-index: 100;
    width: 23px;
    height: 21px;
    background: url(../images/gnb_btn.png)no-repeat 0 0;
    cursor: pointer;
}

.gnb-btn.scroll {
    background: url(../images/gnb_btn_black.png)no-repeat 0 0;
}

.gnb-btn.close {
    background: url(../images/gnb_btn_close_black.png)no-repeat 0 0;
}

.gnb-btn.scroll.close {
    background: url(../images/gnb_btn_close_black.png)no-repeat 0 0;
}

/***** main *****/
.main-visual .slide .title {
    font-size: 60px;
}

.main-visual .slide .text {
    font-size: 22px;
}

/***** intro *****/
.section {
    padding: 100px 0;
}

.section .text-wrap .title {
    font-size: 40px;
}

.intro {
    display: block;
}

.intro .intro-img {
    width: 100%;
    background: url(../images/intro_img.png)no-repeat 0 0;
    background-size: 100% auto;
    background-position: right;
}

.intro .text-wrap {
    margin: 50px 0 0 0;
    padding: 0 50px;
}

.intro .title:before {
    width: 1px;
    height: 200px;
    margin: -200px 0 30px 20px;
}

.intro .text {
    width: 100%;
}

/***** bg-logo *****/
.bg-logo {
    top: 1900px;
    background-size: 50% auto;
}

/***** intro2 *****/
.intro2 .text-box {
    display: flex;
    justify-content: space-between;
    margin: 60px 0 0 0;
}

.intro2 .text-box .box {
    width: calc(100% / 3 - 60px);
    padding: 30px 25px 40px;
    background: #f9f9f9;
    border-radius: 10px;
}

.intro2 .text-box .box:hover {
    outline: 1px solid #3f63fc;
}

.intro2 .text-box .box .title {
    font-size: 22px;
}

.intro2 .text-box .box .text {
    margin: 30px 0 0 0;
    opacity: .8;
}

/***** banner *****/
.banner {
    padding: 150px 0;
}

/***** point *****/


/***** 센터소개 *****/
.center .tabcont1 .introduction .inner {
    width: 100%;
    padding: 0;
}

.center .tabcont1 .introduction .text {
    width: 100% !important;
}

.center .tabcont1 .introduction {
    background: url(../images/center_bg_img.png)no-repeat right bottom;
    background-size: 60% auto;
    margin: 0 50px 0;
    padding: 150px 0;
}

.center .tabcont3 .value img {
    width: 100%;
}

/***** 전문가 소개 *****/
.rehabilitation .card-top .inner {
    display: block;
}
    
.rehabilitation .card-top .text .name {
    display: none;
}
    
.rehabilitation .card-top .text {
    width: 100%;
    margin: 40px 0 0 0;
}
    
.rehabilitation .card-top .card-img img.pc {
    display: none;
}
    
.rehabilitation .card-top .card-img img.mb {
    display: block;
    width: 100%;
}

.rehabilitation .card-wrap {
    padding: 50px 0 0 0;
}

.rehabilitation .card-wrap .inner {
    display: block;
}

.rehabilitation .card-wrap .card {
    width: 100%;
}

.rehabilitation .card-wrap .card ~ .card {
    margin: 50px 0 0 0;
}

.rehabilitation .card-wrap .card .img img {
    width: 100%;
}

.rehabilitation .card-wrap .card .text .career {
    display: flex;
}

.rehabilitation .card-wrap .card .text .career .txt {
    width: 100%;
    padding: 30px 0 20px 0;
    border-bottom: 1px solid rgba(000,000,000,.1);
    color: #555;
}

.rehabilitation .card-wrap .card .text .career .txt span {
    display: block;
    margin: 0 0 20px 0;
    color: #3f63fc;
    font-size: 22px;
}

.rehabilitation .card-wrap .card .text .other {
    display: flex;
    padding: 20px 0 0 0;
    color: #555;
}

.rehabilitation .card-wrap .card .text .other div {
    width: 100%;
}
    
.center .tabcont1 .introduction .text {
    width: 100%;
    margin: 0 0 400px 0;
}

/***** 재활 프로그램 *****/
.program .program-img .img {
    width: calc(100% / 2 - 15px);
    margin: 0 0 30px 0;
}

.program .more-wrap .text-wrap .text {
    width: 100%;
}

/***** 이용안내 *****/
.use-guide .tabcont1 .guide {
    width: 100%;
}

.use-guide .tabcont1 .guide img {
    width: 100%;
}

.use-guide .tabcont2 .map .map-wrap .map-img img {
    width: 100%;
}

.use-guide .tabcont2 .map .map-wrap > div {
    width: calc(100% / 2 - 30px);
}

/***** footer *****/
footer {
    font-size: 14px;
}

footer .top ul li {
    margin: 0 0 0 50px;
}

footer .contact ul li {
    margin: 0 20px 0 0;
}















































