@charset "utf-8";

@media (max-width: 1800px) {
    /* header */
    #header .contain { padding-left: 30px; padding-right: 30px;}
    .btn-menu { right: 30px !important;} 

    /* main */
    .sec1-sb { height: 360px;}
    .sec2 .btbox { max-width: 100%; padding-left: 30px; padding-right: 30px; z-index: 1;}
    .sec2-swiper-button-next, .sec2-swiper-button-prev {width: 30px; height: 30px; background-size: 8px;}
    .sec2-swiper-button-prev { left: 15px;}
    .sec2-swiper-button-next { right: 15px;}
} 

@media (max-width: 1400px) {
    /* header */
    .sitelogo img { height: 40px;}
    #gnb>ul>li {padding:0 45px;} 
    #gnb>ul>li>a  { font-size: 16px;}
    #gnb .submenu>ul {padding:16px 5px;}
    #gnb .submenu>ul>li>a {font-size: 14px; padding: 6px 0;}
    .hd-sns a { width: 28px; height: 28px;}

    /* footer */
    #footer { padding: 25px 0;}
    .ft-logo a img { height: 34px;}
    .ft-text { margin: 15px 0 5px;}
    .ft-text span { font-size: 13px; padding-right: 15px; }
    .ft-right a { font-size: 13px;}
    .ft-right a:last-child { padding-left: 15px; }
    .cpr span { font-size: 13px;}
    .cpr a { font-size: 12px; padding-left: 10px;}

    /* visual */
    .main-visual .item { height: 750px;}
    .main-visual .caption h2 { font-size: 36px; margin-bottom: 15px;}
    .main-visual .caption p { font-size: 16px; margin-bottom: 15px;}

    /* main */
    .sec1 { padding: 60px 0; height: 75vh;}
    .sec1 .tit { font-size: 26px; }
    .sec1-list { margin-top: 60px;}
    .sec1-list li a { justify-content: space-between;}
    .sec1-list li .list-tit { font-size: 19px; margin-bottom: 10px;}
    .sec1-list li .txt{ font-size: 14px; font-weight: 400;}
    .sec1-list li .circle { width: 30px; height: 30px; background-size: 8px; margin-left: 0; margin-right: 50px;}
    .sec1-list li::after { right: 25px; height: 30px;}
    .sec1-sb { height: 260px;}
    .sec2 { padding: 60px 0;}
    .sec2 .main-tit { font-size: 30px; margin-bottom: 15px;}
    .sec2 .main-txt { font-size: 16px;}
    .sec2-box { margin-top: 35px;}
    .sec2-swiper-slide { border-radius: 5px;}
    .sec2-swiper-slide a { padding: 20px; }
    .sec2-swiper-slide .thumb { border-radius: 5px;}
    .sec2-swiper-slide .textbox { padding-left: 25px;}
    .sec2-swiper-slide .textbox strong { font-size: 14px; margin-bottom: 10px;}
    .sec2-swiper-slide .textbox .tit { font-size: 20px; margin-bottom: 14px;}
    .sec2-swiper-slide .textbox .txt { font-size: 14px;}
    .sec2-more{ font-size: 13px; margin-top: 30px;}
}
@media (max-width: 1200px) {
    /* sub */
    .sub-visual { height: 280px;}
    .sub-visual h2 { font-size: 30px; margin-top: 0;}
    .sub-visual p { font-size: 14px;}
    .real-cont { padding-bottom: 60px;}
    .real-cont2 { padding-bottom: 0; } 
    .sub-title { padding: 60px 0 40px;}
    .sub-title h1 { font-size: 24px;}
    .sub-title h1::before { width: 13px; height: 13px; margin-bottom: 10px;}
    .lnb { border-radius: 0; overflow: unset;}
    .lnb ul li { overflow: unset;}
    .lnb ul li a {height:50px; font-size:15px;}
    .lnb ul li::after { height: 15px;}
    .lnb ul li.active a { border-radius: 0;}

    /* 인사말 */
    .gt-img { border-radius: 10px 0 10px 0; margin-bottom: 30px;}
    .gt-left strong { font-size: 13px; margin-bottom: 10px;}
    .gt-left h2 { font-size: 22px;}
    .gt-right p { font-size: 14px; margin-bottom: 15px;}
    .gt-right strong { font-size: 15px; margin-top: 30px;}

    /* 사업종목 및 경영이념 */
    .mn-list { gap: 8px;}
    .mn-list li { width: calc(100%/4 - 6px); border-radius: 5px; padding: 15px;}
    .mn-list li img { width: 45px;}
    .mn-list li .txt { font-size: 14px;}

    /* 회사연혁 */
    .hst { padding-top: 30px;}
    .hst-left h2{ font-size: 22px; margin-bottom: 12px;}
    .hst-left h2 span { font-size: 26px;}
    .hst-left p{ font-size: 16px; margin-bottom: 30px;}
    .hst-left img { height: 120px;}
    .group { margin-bottom: 40px;}
    .group .year { font-size: 22px; margin-bottom: 18px;}
    .group .year::before { width: 20px; left: -23px;}
    .hst-right { margin-left: 0; padding-left: 35px;}
    .group::before { width: 15px; height: 15px; background-size: contain; left: -42px; top:4px;}
    .group .list li { margin-bottom: 10px;}
    .group .list li .month{ font-size: 14px;}
    .group .list li .txt { font-size: 14px; padding-left: 10px; margin-left: 25px;}
    .group .list li .txt::before { width: 4px; height: 4px; top: 6px;}

    /* 협력업체 */
    .pt-list { gap: 35px 10px;}
    .pt-list li { width: calc(100%/5 - 8px);}
    .pt-list li .txt { font-size: 15px; margin-top: 12px;}
    .pt-list li .thumb:after { border-radius: 5px;}
    .pt-list li .thumb { border-radius: 5px;}

    /* sub2 공통 */
    .sub2-box { margin-bottom: 50px;}
    .subtit { font-size: 20px; margin-bottom: 10px; padding-left: 23px;}
    .subtit span { font-size: 16px;}
    .subtit::before { width: 15px; height: 15px; background-size: contain; top: 4px;}
    .sub2-txtbox { padding-left: 23px;}
    .sub2-txt { font-size: 14px; font-weight: 400;}
    .sub2-list { gap: 10px; margin-top: 15px;}
    .sub2-list li { border-radius: 5px;}
    .sub2-graybox { margin-top: 15px; border-radius: 5px; padding: 20px 15px;}
    .sub2-graybox strong { font-size: 14px; margin-bottom: 10px;}
    .sub2-graybox .num { font-size: 14px; top: 4px;}
    .sub2-graybox p { font-size: 14px; font-weight: 400;}
    .sub2-tbl-wrap { margin-top: 20px;}
    .sub2-tbl tr td { padding: 10px 5px; padding-left: 10px; font-size: 14px; font-weight: 400;}

    /* 기타 제작 품목 */
    .etc-list { gap: 30px 9px;}
    .etc-list li { width: calc(100%/3 - 6px);}
    .etc-list li .thumb{ border-radius: 5px; margin-bottom: 15px;}
    .etc-list li .thumb:after{ border-radius: 5px;}
    .etc-list li .txt { font-size: 15px;}

    /* 갤러리 */
    .gallery-list { padding: 20px 0 0 0;}
}
/* Landscape tablet */
@media (max-width: 1024px) {
	body, input, textarea, select, button, table {font-size:15px;}	

    /* header */
    #gnb {display: none;}
    #header { height: 80px; }
    #header .contain { height: 100%;}
    #header .contain:after {content: none;}
    .sitelogo img { height: 35px;}
    .btn-m-menu {display: block; }
    .btn-menu { display: none;}
    .mobile-navigation {display:block;}

    /* footer */
    #footer .contain { display: block; text-align: center;}
    .ft-right {text-align: center;} 
    .ft-right { margin-top: 6px;}
    .cpr { margin-top: 5px;}

    /* visual */
    .main-visual .item { height: 520px;}
    .main-visual .caption h2 { font-size: 28px;}

    /* 매장위치 */
    .root_daum_roughmap .wrap_map {height:300px !important;}
	.directions .address-info .addr {font-size:20px;}
	.directions .contact-info dl {padding:20px 0;}
	.directions .contact-info dt {padding-left:20px; width:140px;}

	/* board */
	.input {padding:5px 14px; height:40px;}
	textarea.input {padding:12px 14px;}

    .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-list2 table tbody td {font-size:14px;}
    .board-list table tbody td.subject { padding-left: 10px;}
    .board-list .label { font-size: 12px; line-height: 1em; padding: 5px 8px;}

    .form-agree {margin:50px 0 0;}
	.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-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 { margin: 0 -5px;}
    .gallery-list ul li { width: 33.333%; padding: 0 5px; margin-bottom: 30px;}
    .gallery-list ul li .thumb { border-radius: 5px;}
    .gallery-list ul li .tit { font-size: 15px;}

    .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;}

    .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 ;}
} 

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

    /* main */
    .sec1-list { display: block; margin-top: 30px;}
    .sec1-list li{ width: 100%; margin-bottom: 30px;}
    .sec1-list li:last-child { margin-bottom: 0;}
    .sec1-list li .circle { margin-right: 0;}
    .sec1-list li::after { display: none;}
    .sec1-sb { height: 180px;}

    /* 사업종목 및 경영이념 */
    .mn-list { gap: 8px; flex-wrap: wrap;}
    .mn-list li { width: calc(100%/2 - 4px);}

    /* 협력업체 */
    .pt-list li { width: calc(100%/4 - 8px);}
}

/* 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;}

    /* header */
    #header { height: 60px !important; border-bottom: none;}
    #header .contain { padding-left: 15px; padding-right: 15px;}
    .sitelogo a img{ height: 30px;}
	.mobile-navigation .home {height:60px;}
	.mobile-navigation .close {top:17px;}
    .list-icon { right: 15px; width: 22px; height: 22px; margin-top: -11px;}

	#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;}
    .list-icon span:before { top: -8px;}
    .list-icon span::after { bottom: -8px;}

    .root_daum_roughmap .wrap_map {height:250px !important;}

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

    /* visual */
    .main-visual .item { height: 320px;}
    .main-visual .contain{ padding-left: 15px; padding-right: 15px;}
    .main-visual .caption { top: 35%;}
    .main-visual .caption p { font-size: 14px;}
    .main-visual .caption h2 { font-size: 20px;}

    /* main */
    .sec1 { padding:40px 0; height: 60vh;}
    .sec1 .tit { font-size: 20px; }
    .sec1-list li { margin-bottom: 25px;}
    .sec1-list li .list-tit { font-size: 16px; margin-bottom: 5px;}
    .sec1-sb{ height: 110px;}
    .sec2 { padding: 40px 0;}
    .sec2 .main-tit{ font-size: 24px;}
    .sec2 .main-txt{ font-size: 14px;}
    .sec2-swiper-slide a { display: block; padding: 15px;}
    .sec2-swiper-slide .thumb { width: 100%;}
    .sec2-swiper-slide .textbox{ padding-left: 0; width: 100%; padding-top: 20px;}
    .sec2-swiper-slide .textbox .tit { font-size: 18px;}
    .sec2-swiper-slide .textbox .txt { -webkit-line-clamp:2;}
    .sec2-more { margin-top: 15px;}

	/* sub */
    .sub-visual { height: 180px;}
    .sub-visual h2 { font-size: 22px;}
    .real-cont { padding-bottom: 40px;}
    .real-cont2 { padding-bottom: 0; } 
    .sub-title { padding: 40px 0 20px;}
    .sub-title h1 { font-size: 20px;}
    .lnb-wrap { margin-top: 0;}
    .lnb ul li a {height:45px; font-size:14px; white-space: nowrap;}

    /* 인사말 */
    .gt-img { border-radius: 5px 0 5px 0;}
    .gt-box { display: flex; flex-wrap: wrap;}
    .gt-box>div { width: 100%; }
    .gt-left h2 { font-size: 20px; margin-bottom: 20px;}

    /* 회사연혁 */
    .hst { display: block; padding-top: 20px;}
    .hst-left {width: 100%; } 
    .hst-left p { margin-bottom: 15px;}
    .hst-left img { height: 70px;}
    .hst-right { width: 100%; margin-top: 25px;}
    .group .year { font-size: 19px;}

    /* 협력업체 */
    .pt-list li { width: calc(100%/3 - 7px);}
    .pt-list li .txt { font-size: 14px;}

    /* 매장위치 */
    .root_daum_roughmap .wrap_map {height:250px !important;}	
	.directions {margin-top:30px;}
	.directions .address-info .addr {font-size:18px;}
	.directions .address-info {margin-bottom:20px;}
	.directions .contact-info dl {padding:16px 0;}
	.directions .contact-info dt {padding-left:5px; width:110px;}
	.directions .contact-info dt svg {margin-right:10px;}

    /* sub2 공통 */
    .sub2-box { margin-bottom: 40px;}
    .subtit { font-size: 17px; margin-bottom: 10px; padding-left: 18px;}
    .subtit span { font-size: 15px;}
    .subtit::before { width: 12px; height: 12px; background-size: contain; top: 4px;}
    .sub2-txtbox { padding-left: 0;}
    .sub2-txt br { display: none;}
    .sub2-list { flex-wrap: wrap;}
    .sub2-list li{ width: 100%; flex: none;}
    .sub2-list li img { width: 100%;}
    .sub2-fx { display: flex; gap: 10px; flex-wrap: wrap;}
    .sub2-fx>div { width: 100%;}
    .sub2-normal { padding: 0;}
    .sub2-tbl-wrap { overflow: auto;}
    .sub2-tbl { width: 640px;}

    /* 기타제작품목 */
    .etc-list li { width: calc(100%/2 - 5px);}

	/* 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;}

	.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-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%;}

	.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 tbody {display:block;}
	.board-form table tr {display:block; padding:12px 0;}
	.board-form table th {display:block; border:0; text-align:left; padding:0; margin-bottom:7px; font-size:14px; background:none;}
	.board-form table td {display:block; border:0; padding:0;}
	.board-form + .buttons {margin-top:30px;}
    .jun-board table { border: none;}

	.form-agree {margin:30px 0 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 22px; font-size:16px; line-height:48px;}
	.btn-pack.comment {width:80px; height:32px; font-size:14px;}

	.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%;}

    .board-form .input { width:100% !important;}

    .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) {
    /* main */
    .sec1 .tit br { display: none;}

    /* 사업종목 및 경영이념 */
    .mn-list li { width: 100%;}

    /* 협력업체 */
    .pt-list {gap: 35px 6px;}
    .pt-list li { width: calc(100%/2 - 3px);}
}