@charset "utf-8";
@media (max-width: 1400px) {
    body, input, textarea, select, button, table {font-size:14px; font-weight: 400; }	

    :root{
		--font-size52 : 34px;
		--font-size48 : 32px;
		--font-size40 : 28px;
		--font-size36 : 24px;
		--font-size34 : 23px;
		--font-size32 : 22px;
		--font-size30 : 21px;
		--font-size28 : 20px;
		--font-size26 : 19px;
		--font-size24 : 18px;
		--font-size22 : 17px;
		--font-size20 : 16px;
		--font-size18 : 15px;
	}

    /* header */
    .sitelogo img { height: 45px; }
	#gnb>ul>li { padding: 0 22px;}
    #gnb>ul>li>a { font-size: 16px; }
	.hd-tel { padding-left: 34px; padding-right: 15px; }
	.hd-tel::before { left: 12px; width: 15px; height: 15px; }
    .language .toggle-button { font-size: 13px; }
    .language .toggle-button .ico { width: 20px; }
    .language .toggle-button .chevron { width: 9px; }

    /* footer */
	#footer { padding: 25px 0;}
	.ft-logo img { height: 38px; }
	.ft-text span { padding-right: 20px; margin-bottom: 4px; font-size: 13px; }
	.ft-text span strong { padding-right: 7px; }
	.cpr span { font-size: 12px; }
	.policy a { padding-right: 16px; }
	.policy a::after { display: none; }
	.scroll-top { position: fixed; width: 40px; height: 40px; right: 15px; bottom: 15px; top: auto; z-index: 99; transform: none; box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.16); }
	.quick { transform: none; top: auto; bottom: 60px; right: 15px; }
	.quick a { width: 40px; height: 40px; margin-bottom: 5px; }
    .quick a:first-child { font-size: 12px; font-weight: 400; }

    /* visual */
	.main-visual { height: 750px; }
    .main-visual .item { height: 750px; }
	.main-visual .caption .info .main-subtit { font-size: 12px;  }
	.main-visual .caption .info h2 { font-size: 42px; margin: 15px 0;}
	.main-visual .caption .info p { margin-bottom: 25px; }
	.main-visual .caption .links { gap: 5px; }
	.main-visual .caption .links a { padding: 0 15px; height: 38px; gap: 6px; }
	.main-visual .caption .img { width: 50%; margin-right: 0; }
	.main-visual .vs-pagination { bottom: 20px; gap: 10px; }
	.main-visual .roll-btn { font-size: 15px; gap: 5px; }
	.main-visual .roll-btn .bar { font-size: 11px; position: relative; top: -1px; }

	/* main 공통 */
	.main-pd { padding: 90px 0;}
	.main-subtit { font-size: 12px; margin-bottom: 14px; padding-left: 26px; padding-right: 22px; }
	.main-subtit::before { width: 20px; top: 8px; }
	.main-subtit::after { width: 20px; top: 8px; }
	.main-tit { margin-bottom: 30px; }

	/* main */
	.sec1 .img { padding-right: 30px; }
	.sec1 .info h3 { margin: 20px 0;}
	.sec1 .info p { margin-bottom: 40px; }
	.sec1 .info ul { gap: 30px; }
	.sec1 .info ul li { width: calc(100%/2 - 15px);}
	.sec2-wrap .item a { padding: 25px 10px;}
	.sec2-wrap .item .icon { width: 50px; height: 50px; }
	.sec2-wrap .item .tt { margin: 15px 0 12px;}
	.sec3-titbox { margin-bottom: 30px; }
	.sec3-view { width: 36px; height: 36px; background-size: 24px; }
	.sec3 .op { margin-top: 50px;}
	.sec3 .op img { border-radius: 5px; }

	/* 파트너사 공통 */
	.op-wrap { gap: 15px; }
	.op-wrap .item { width: 200px; }

	/* sub */
	.sub-visual { height: 380px; }
	.sub-visual h4 { margin-bottom: 10px;  }
	.sub-visual h2 { font-size: 42px;}
	.sub-title { padding: 30px 0;}
	.real-cont { padding-bottom: 90px;}
	.real-cont2 { padding-bottom: 0; }

	/* 공통 */
	.sub-subtit { font-size: 12px; margin-bottom: 10px; padding-left: 24px; }
	.sub-subtit::before { width: 18px; top: 11px; }
	.sub-pd { padding: 60px 0;}

	/* 회사소개 */
	.company .img { padding-right: 30px; }
	.company .info h3 { margin: 20px 0;}
	.company .info .txt p { margin-bottom: 15px; }
	.company .info .sign strong { padding-right: 8px; }
	.company .info .sign h5 { line-height: 1.66em; display: inline-block; }

	/* 주요 서비스 */
	.sv-tab-wrap { position: sticky; top: 100px; width: 100%; background: #fff; z-index: 99; border-bottom: 1px solid #ddd; border-top: 1px solid #ddd;}
	.sv-tab-wrap ul { display: flex; padding: 0; border-radius: 0; width: 100%; border: none; }
	.sv-tab-wrap ul li { flex: 1;}
	.sv-tab-wrap ul li a { width: auto; height: 40px; border-radius: 0; line-height: 2em; }
	.sv-flex .info { padding-left: 25px; }
	.sv-flex .info h3 { margin: 15px 0;}
	.sv-flex .info p { margin-bottom: 20px; }
	.sv-flex .info .fz::before { top: 10px; }
	.sv-flex .info ul { margin-bottom: 30px; }
	.sv-flex .info ul li { padding: 12px 0; }
	.sv-flex .info ul li span { padding-left: 22px; }
	.sv-flex .info ul li span::before { width: 16px; height: 16px; top: 4px; }
	.sv-flex .info .btns { gap: 10px; }
	.sv-flex .info .btns a { width: calc(100%/2 - 5px); height: 48px; gap: 6px;}
	.sv-flex.rv { flex-direction: row-reverse;}
	.sv-flex.rv .info { padding-left: 0; padding-right: 25px; }

	/* 차량 안내 */
	.car-flex { margin-bottom: 50px; }
	.car-flex .image { padding-right: 30px; }
	.pd-thumb-swiper { margin-top: 10px; }
	.car-flex .info { padding-left: 0; }
	.car-flex .info .ctr { font-size: 12px; padding: 2px 7px;}
	.car-flex .info .subtit { margin: 15px 0 10px;}
	.car-flex .info p { margin-bottom: 20px; }
	.car-flex .info .fz::before { top: 10px; }
	.car-flex .info ul { margin-bottom: 30px; }
	.car-flex .info ul li { padding: 12px 0;}
	.car-flex .info ul li .tt { padding-left: 0; width: 90px; }
	.car-flex .info ul li .hash { gap: 5px; }
	.car-flex .info ul li .hash span { font-size: 12px; padding: 2px 6px 0;}
	.car-flex .info .btns { gap: 10px; }
	.car-flex .info .btns a { width: calc(100%/2 - 5px); height: 48px; gap: 6px;}

	/* 리뷰 */
	.review-list { padding-top: 12px; gap: 12px; }
	.review-item a { padding: 15px; }
	.review-item .ctr { padding: 3px 10px;}
	.review-item .tit { margin: 13px 0;}
	.review-item .info { padding-top: 10px; margin-top: 10px; }
	.review-item .name { padding-right: 16px; }
	.review-item .name::after { right: 7px; height: 10px; }

	/* 예약 문의 */
	.ct-form { gap: 35px 10px;}
	.ct-form dl { width: calc(100%/2 - 5px); }
	.ct-form dt { font-size: 16px; margin-bottom: 10px; }
	.ct-form dd .input { height: 44px; }
	.captcha-wrap { height: 44px; }
}
/* Landscape tablet */
@media (max-width: 1024px) {
	/* header */
	#header { width: 100%; top: 0; height: 80px; border-radius: 0; }
	#gnb {display: none;}
	#header .contain:after {content: none;}
	.list-icon { display: inline-block; }

    /* footer */
    #footer .contain { display: block; text-align: center; }
	.ft-text { margin-bottom: 15px; }
	.ft-right { text-align: center; }
	.policy { margin-bottom: 15px; }
	.cpr { margin-top: 15px; }
    
    /* visual */
    .main-visual { height: 520px; }
    .main-visual .item { height: 520px; }
	.main-visual .caption .info { flex: 1 1 auto; min-width: 0; width: 1%; top: 0; z-index: 1; }
	.main-visual .caption .info h2 { font-size: 32px; }
	.main-visual .caption .img { position: absolute; right: 0; width: 400px; top: 50%; transform: translateY(-50%); display: flex; align-items: center;}
	.main-visual .caption .img>div { padding-bottom: 0; }
	.main-visual .caption .img img { left: auto; transform: none; right: 0; position: relative; top: auto;}

	/* 주요 서비스 */
	.sv-tab-wrap { top: 80px; }

	/* board */
	.input {padding:5px 14px; height:40px;}
	textarea.input {padding:12px 14px;}
    .status-search .info dl dd.fx .item .ui-datepicker-trigger { height: 40px; width: 40px; }

	/* 검색 */
	.board-search .search input.input {width:240px;}

    .board-list colgroup col {width:auto !important;}
    .board-list table thead th {font-size:15px;}
	.board-list table tbody td {font-size:15px;}
    .board-list table tbody td.subject { padding-left: 10px;}
    .board-list .label { font-size: 12px; line-height: 1em; padding: 5px 8px;}
    .board-list .down { width: 14px; height: 18px; background-size: contain;}

    .form-agree { margin: 30px 0 0 0;}
	.form-agree h3 {font-size:16px; margin-bottom: 12px;}
	.form-agree .scroll-box {font-size:12px; max-height:110px; overflow:auto;}
	.form-agree .check {margin-top:12px; font-size:14px;}

    .board-form table th { font-size: 14px; }
    .board-form table td { font-size: 14px; padding: 15px }
	.board-form .item-fx .item.fx { gap: 10px 15px;}
	.board-form .item-fx .item.fx .input { max-width:70px;}
    .board-form .input { height: 40px; }
    .captcha-wrap { height: 44px; }

	.board-white table {font-size:15px;}

	.board-form table {font-size:15px !important;}

	.files-upload-text .upfiles-alt {font-size:14px;}

	.board-view-tit {padding:14px 6px;}
	.board-view-tit h3 {font-size:18px;}
	.board-view-info {padding:13px 6px; font-size:13px;}
	.board-view-cnt {padding:15px 6px 40px;}

	.gallery-list ul li .abbox { padding: 15px; }
	.gallery-list ul li .abbox .tt { margin-bottom: 4px; }
	.gallery-list ul li .abbox .en-tt { font-size: 12px; }
	.gallery-list ul li .abbox .more { width: 60px; height: 60px; }

    .faq .tit {font-size:15px;}
	.faq .tit a {padding:9px 60px 9px 12px;}
	.faq .tit a:after {top:14px;}
	.faq .q {flex:0 0 32px; width:32px; height:32px; font-size:16px; line-height:32px;}
	.faq .cnt {padding:18px 25px 18px 60px; font-size: 14px; }

    .calendar-head { border-radius: 0; padding: 15px 0;}
    .calendar-head h3 {font-size:20px; margin:0 30px;}
	.calendar table th {font-size:15px;}
	.calendar table td {height:110px; font-size:14px;}
	.calendar ul li:before {top:7px;}

	.board-prev-next {font-size:14px;}

	.btn-pack.medium {height:40px; padding:0 16px; font-size:15px; line-height:38px;}
	.btn-pack.large {min-width:140px; height:50px; font-size:18px; line-height:48px;}
    .btn-pack.zip-bt { height: 44px; font-size: 14px; line-height: 42px; min-width: 100px ;}

	.store-search {padding:22px 5%;}
	.store-search .map-area {width:280px;}
	.store-search .map-img .local {padding:0 10px; font-size:13px; line-height:22px;}
    
    .news-list .thumb {width:200px;}
	.news-list .tit {font-size:17px;}
	.news-list .txt {font-size:14px;}
	.news-list .date {font-size:13px;}
} 

/* portrait tablet */
@media (max-width: 900px) {	
	.only-desktop {display:none;}
	.only-tablet {display:block;}

	/* main */
	.sec2-wrap .item { width: calc(100%/2);}

	/* 주요 서비스 */
	.sv-flex { flex-wrap: wrap; gap: 30px 0;}
	.sv-flex .img { width: 100%; }
	.sv-flex .img img { width: 100%; }
	.sv-flex .info { width: 100%; padding-left: 0; }
	.sv-flex .info ul li { width: 100%; }
	.sv-flex .info .btns { gap: 0; }
	.sv-flex .info .btns a { width: calc(100%/2);}
	.sv-flex .info .btns a img { height: 18px; }
	.sv-flex.rv { flex-direction: row;}
	.sv-flex.rv .info { padding-left: 0; padding-right: 0; }

	/* 차량 안내 */
	.car-flex { flex-wrap: wrap; gap: 30px 0;}
	.car-flex>div { width: 100%; }
	.car-flex .image { padding-right: 0; }
	.car-flex .info .btns { gap: 0; }
	.car-flex .info .btns a { width: calc(100%/2);}
	.car-flex .info .btns a img { height: 18px; }

	/* 리뷰 */
	.review-list { padding-top: 10px; gap: 10px; grid-template-columns:repeat(2, 1fr);}
}

/* Landscape phone */
@media (max-width: 640px) {
	body, input, textarea, select, button, table {font-size:14px;}
	.only-desktop-tablet {display:none;}
	.only-tablet {display:none;}
	.only-mobile {display:block;}

	:root{
		--font-size52 : 26px;
		--font-size48 : 25px;
		--font-size40 : 23px;
		--font-size36 : 22px;
		--font-size34 : 20px;
		--font-size32 : 20px;
		--font-size30 : 20px;
		--font-size28 : 19px;
		--font-size26 : 18px;
		--font-size24 : 17px;
		--font-size22 : 16px;
		--font-size20 : 15px;
		--font-size18 : 14px;
	}

    /* header */
    #header { height: 60px; }
    #header .contain { padding-left: 15px; padding-right: 15px;}
    .sitelogo img { height: 36px; }
    .hd-tel { text-indent: -9999em; padding: 10px; width: 32px; height: 32px; border-radius: 44px; }
    .hd-tel::before { left: 8px; width: 15px; height: 15px; }

	#contArea {padding-left: 15px; padding-right: 15px;}
	.contain {padding-left: 15px; padding-right: 15px;}
    .contain2 { padding-left: 15px; padding-right: 15px;}
	.real-cont {min-height: 200px; padding-bottom: 40px;}

	/* footer */
    #footer .contain { padding-left: 15px; padding-right: 15px; }

    /* visual */
    .main-visual { height: 320px; }
    .main-visual .item { height: 320px; }
	.main-visual .caption { bottom: auto; top: 50%; transform: translateY(-50%);}
	.main-visual .caption .info { z-index: 1; }
	.main-visual .caption .info h2 { font-size: 24px; margin-bottom: 15px; }
	.main-visual .caption .info p { margin-bottom: 0; }
	.main-visual .caption .info p br { display: none; }
	.main-visual .caption .links { display: none; }
	.main-visual .caption .img { width: 260px; }
	.main-visual .vs-pagination { bottom: 15px; }

	/* main 공통 */
	.main-pd { padding: 50px 0;}

	/* main */
	.sec1 .contain { display: block; }
	.sec1 .contain>div { width: 100%; }
	.sec1 .img { padding-right: 0; margin-bottom: 30px; }
	.sec2-wrap .item br { display: none; }
	.sec3 .op { margin-top: 40px; }

	/* 파트너사 공통 */
	.op-wrap { gap: 15px; }
	.op-wrap .item { width: 160px; }

	/* sub */
	.sub-visual { height: 240px; }
	.sub-visual h2 { font-size: 30px;}
	.sub-title { padding: 20px 0;}
	.real-cont { padding-bottom: 50px;}
	.real-cont2 { padding-bottom: 0; }

	/* 공통 */
	.sub-pd { padding: 40px 0;}

	/* 회사소개 */
	.company { flex-wrap: wrap;}
	.company>div { width: 100%; }
	.company .img { padding-right: 0; margin-bottom: 25px; }
	.company .info p br { display: none; }

	/* 주요 서비스 */
	.sv-tab-wrap { border-bottom: none; top: 60px; }
	.sv-tab-wrap ul { flex-wrap: wrap;}
	.sv-tab-wrap ul li { flex: none; width: calc(100%/4); border-right: 1px solid #ddd; border-bottom: 1px solid #ddd;}
	.sv-tab-wrap ul li:nth-child(4n) { border-right: none;}

	/* 리뷰 */
	.review-list { padding-top: 10px; gap: 10px; grid-template-columns:repeat(1, 1fr);}

	/* 예약 문의 */
	.ct-form dl { width: 100%; } 

	/* board */
	.input {font-size:14px; padding:0 10px; height:38px;}
	select.input {padding-right:26px; background-image:url("/images/bbs/select_x2.png"); background-position:right 8px center; background-size:12px auto;}
	textarea.input {padding:7px 10px;}

	.board-search {display:flex; flex-direction:column; margin-bottom:10px;}
	.board-search .total-page {order:3; float:none; font-size:13px;}
	.board-search .cate {float:none; order:1; margin-left:0; margin-bottom:5px;}
	.board-search .cate .input {display:block; width:100%;}
	.board-search .search {float:none; order:2; display:flex;}
	.board-search .search .input {flex:1 1 auto; min-width:0; width:1%;}

	.radiobox input:checked + label:before {background-image:url("/images/bbs/radiobox_x2.png"); background-size:8px auto;}
	.checkbox input:checked + label:before {background-image:url("/images/bbs/checkbox_x2.png"); background-size:11px auto;}

	.board-list {display:none;}
	.board-list-m {display:block;}

	.board-white table {display:block; border-top:0; border-bottom:0; font-size:14px;}
	
	.board-white table tbody {display:block;}
	.board-white table tr {display:block; padding:12px 0;}
	.board-white table th {display:block; border:0; text-align:left; padding:0; margin-bottom:7px; font-size:16px; background:none;}
	.board-white table td {display:block; border:0; padding:0;}
	.board-white .editor {padding:0; margin-top:-12px;}
	.board-white .item {margin:3px 12px 3px 0;}
	.board-white #user_name {max-width:100% !important;}
	.board-white + .buttons {margin-top:30px;}

	.board-form table { border-bottom: none; }
	.board-form table tbody {display:block;}
    .board-form table colgroup col {width: 100% !important; margin-bottom: 10px;}
	.board-form table tr {display:block; }
	.board-form table th {display:block; border:0; text-align:left; padding:0; font-size:15px; background:none; height: auto; margin-top: 24px; margin-bottom: 5px; }
    .board-form table th.pd { padding-top: 24px;}

	.file-fx { display: block; }
	.files-upload { width: 100%; }
	.file-fx .resume-btn { margin-top: 10px; }

	.board-form table td {display:block; border:0; padding:0;}
	.board-form + .buttons {margin-top:30px;}
    .board-form input#past_8, input#technic_9, input#sample_type_5, input#cell_type_5, input#blood_1 { width: 200px !important;}
    .clr-txt { font-size: 13px;}
    .clr-span { padding-left: 0;}
    .board-form tr th.bg { background: transparent;}
    .board-form tr td.fw { text-align: left; margin-bottom: 10px; font-size: 14px; color: #00316d;}
    .board-form .sel-fx select { width: 100%; }
    .board-form .input { font-size: 14px; }
    .board-form .item-pd { padding: 0; }

	.form-agree { margin-bottom: 30px; }
	.form-agree h3 {font-size:16px;}
	.form-agree .scroll-box {font-size:12px; max-height:110px; overflow:auto;}
	.form-agree .check {margin-top:12px; font-size:14px;}

	.board-view-tit h3 {font-size:17px;}
	.board-view-info {font-size:12px;}

	.board-prev-next dl {padding:10px 6px;}
	.board-prev-next dt {width:70px}

	.calendar-head h3 {font-size:18px; margin:0 17px;}
	.calendar-head .cal-btn {width:34px; height:34px; background-size:9px auto;}
	.calendar-head .cal-prev {background-image:url("/images/bbs/cal_prev_x2.png");}
	.calendar-head .cal-next {background-image:url("/images/bbs/cal_next_x2.png");}
	.calendar table th {padding:6px 4px; font-size:14px;}
	.calendar table td {height:60px; padding:5px 4px; font-size:12px;}
	.calendar ul li {padding-left:0; margin-bottom:6px;}
	.calendar ul li:before {display:none;}
	.calendar .cal-date {font-size:10px; margin-bottom:8px;}

	.buttons {margin:15px 0;}

	.btn-pack.small {height:26px; padding:0 8px; font-size:11px; line-height:24px;}
	.btn-pack.medium {height:38px; padding:0 14px; font-size:14px; line-height:36px;}
	.btn-pack.large {min-width:120px; height:42px; padding:0 18px; font-size:15px; line-height:40px;}
	.btn-pack.xlarge {min-width:120px; height:50px; padding:0 12px; font-size:14px; line-height:48px;}
	.btn-pack.comment {width:80px; height:32px; font-size:14px;}

    .btn-pack.ctbt { min-width: 120px; height: 42px; font-size: 15px; line-height: 40px;}

	.paginate {margin-top:20px;}
	.paginate a,  
	.paginate strong{margin:0 1px;width:30px;height:30px;font-size:14px;line-height:30px;}  
	.paginate a.direction {margin:0; background-size:11px;}
	.paginate a.direction.first {background-image:url("/images/bbs/btn_first_x2.png");}
	.paginate a.direction.prev {background-image:url("/images/bbs/btn_prev_x2.png"); margin-right:14px;}
	.paginate a.direction.next {background-image:url("/images/bbs/btn_next_x2.png"); margin-left:14px;}
	.paginate a.direction.last {background-image:url("/images/bbs/btn_last_x2.png");}

	.comment-area {margin-top:37px;}
	.comment-total {font-size:14px; margin-bottom:12px;}
	.comment-write {position:relative; padding:10px;}
	.comment-write .byte {position:absolute; bottom:15px; left:12px; font-size:12px;}
	.comment-write .write {display:block;}
	.comment-write .write textarea {display:block; width:100%; height:65px; margin-right:0;}
	.comment-write .write .btn {text-align:right; margin-top:6px;}
	.comment-item {padding:17px 4px;}
	.comment-item.comment-reply {padding-left:25px; background-image:url("/images/bbs/icon_reply_x2.png"); background-position:3px 18px; background-size:auto 13px;}
	.comment-info {font-size:14px;}
	.comment-info .name {margin-right:5px;}

	.faq .tit a {padding:7px 0 7px 5px;}
	.faq .tit a:after {display:none;}
	.faq .q {flex:0 0 26px; width:26px; height:26px; font-size:15px; line-height:26px; margin-right:10px;}
	.faq .cnt {padding:12px 12px 12px 15px;}
    
	.comment-info .date {font-size:11px;}
	.comment-ctr {font-size:12px;}
	.comment-ctr .bar {vertical-align:middle; margin:-.2em 4px 0;}
	.comment-txt {font-size:14px;}
	.comment-link {font-size:13px;}
	.comment-input {padding:10px;}
	.comment-input textarea {height:48px;}

	.board-password {padding:30px 20px;} 

    .form-agree .scroll-box { padding: 15px;}

	.gallery-list ul li { width: 50%; }

    .product-list ul li { width: 50%;}

	.store-search {padding:0; border-radius: 0; }
	.store-search .search-area h3 {font-size:16px; padding:15px 25px; margin-bottom:20px; background:#f4f4f4;}
	.store-search .search-area dl {display:block; padding:0 15px; margin:20px 0;}
	.store-search .search-area dl dt {width:auto; margin-bottom:6px; font-size:15px;}
	.store-search .search-area dl dd {width:auto;}
	.store-search .search-area input.input {width:calc(100% - 74px); margin-right:4px;}
	.store-search .search-area select.input {width:calc(50% - 39px); margin-right:4px;}
	.store-search .search-area .btn-pack.medium {width:70px;}

    .news-list ul li {padding:17px 0;}
	.news-list .thumb {width:38%; margin-right:14px;}
	.news-list .tit {font-size:15px; max-height:2.8em; white-space:normal; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;}
	.news-list .txt {font-size:13px; margin-top:3px; max-height:3em; -webkit-line-clamp:2;}
	.news-list .date {display:none;}
} 
@media (max-width: 420px) {

}