@charset "utf-8";

@media (max-width: 1800px) {
	#gnb .submenu {left: 50%; transform: translateX(-50%);}
}

@media (max-width: 1600px) {

	/* header */
	#gnb .submenu>ul {flex-direction: column; gap: 0; border-radius: 24px;}
	
	/* footer */
	#footer .foot-info {gap: 50px;}

	/* sub */
	.greeting .head .logo {width: 380px;}
	.greeting .list {gap: 60px;}
	.greeting .list .tit {font-size: 20px;}
	.greeting .list .item {gap: 10px;}
	.greeting .line-wrap .line {top: 57px;}

	/* process */
	.process .tit-area {width: 300px;}
}

@media (max-width: 1400px) { 
    /* main-visual */
	.main-visual {height: 53vw;}
	.main-visual .slick-slide {height: 53vw;}
    .main-visual .item iframe {height: 53vw;}
    .sub-visual {height: 53vw;}
}

/* Landscape tablet */
@media (max-width: 1024px) {
	body, input, textarea, select, button, table {font-size:15px;}

	/* header */
    #gnb {display:none;}
    .btn-m-menu {display:flex;}

	/* main */
	/* main-visual */
	.main-visual .caption h2 {width: 300px;}
	.main-visual .caption p {font-size: 17px; margin-bottom: 0;}
	.main-visual .slick-dots li button {width: 60px; height: 3px;}

	/* main-content */
	/* 공통 */
	.com-btn {height: 55px;}

	.stack-cards__item {min-height:440px;}
	
	.prj-txt .tit {font-size: 40px;}
	.main-contact {min-height: 850px;}

	/* footer */
	.ft-logo-wrap {width: 250px;}
	#footer .ft-contact-info {gap: 0 10px;}
	.scroll-top {width: 50px; height: 50px;}

	/* sub */
	.lnb ul li {height: 60px;}
    .sub-visual .cell {bottom: 100px;}

	/* content */
	/* 회사소개 */
	.greeting .head .logo {width: 280px;}

	/* 연혁 */
	.history .item h3 {width: 250px;}
	.history .item-box {padding: 17px 0 100px 80px;}
	.history .item-box:before {left: -3px; width: 38px; height: 38px; border-width: 11px;}

	/* process */
	.process .tit-area {width: 200px; margin-top: 36px;}
	.process .cols {gap: 20px;}
	.process .card {flex:0 0 calc(50% - 10px);}

	/* certification */
	.certification .list {grid-template-columns: repeat(4, 1fr);}

	/* 찾아오시는 길 */
	.root_daum_roughmap .wrap_map {height: 320px !important;}

	/* product */
	.prod-list ul li .tit {font-size: 18px;}
	.prod-list ul li .tit:before {top: 11px; width: 6px; height: 6px;}

	/* 상세페이지 */
	.prod-view {align-items: flex-start;}
    .project-btn-wrap .swiper-button-prev, .project-btn-wrap .swiper-button-next {width: 50px; height: 50px;}
    .project-pagination.swiper-pagination {max-width: 72px;}

	/* news */
	.news-img-list ul li .tit {font-size:15px;}

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

    .simple-list .link-item {padding:24px 0;}
    .simple-list .link-item .num {max-width:80px; font-size:16px;}
    .simple-list .link-item .num .notice {width:48px; height:48px;}
    .simple-list .link-item .cnt .tit {font-size:18px;}
    .simple-list .link-item .cnt .info {margin-top:12px; font-size:13px;}
    .simple-list .link-item .arrow {max-width:80px; font-size:24px;}

	.gallery-list ul li .tit {font-size:15px;}

	.card-list {gap:32px;}
	.card-list .link-item .info .tit {font-size:18px;}
	.card-list .link-item .info .txt {font-size:15px;}
	.card-list .link-item .info .date {font-size:13px;}

	.news-list .thumb {width:200px;}
	.news-list .tit {font-size:17px;}
	.news-list .txt {font-size:14px;}
	.news-list .date {font-size:13px;}

	.event-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 h3 {font-size:28px; margin:0 30px;}
	.calendar-head .cal-btn {width:40px; height:40px;}
	.calendar table th {font-size:15px;}
	.calendar table td {height:110px; font-size:14px;}
	.calendar ul li:before {top:7px;}

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

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

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

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

	.product-list ul li {width:25%;}
	.product-list ul li .tit {font-size:15px;}
	.product-image {width:350px;}
	.product-info .tit {font-size:25px;}

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

	.result-group .gall li {width:25%;}

} 

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

	
	/* main */
	/* main-visual */
	.main-visual .caption .logo {height: 50px;}
	.main-visual .caption p {font-size: 16px;}

	/* main section */
	/* main-project */
	.main-container .product .cards {min-height: 600px;}

	/* main-news */
	.main-news .list {margin: 0 -10px;}
	.main-news .list .item {padding: 0 10px;}
	.main-contact .tit-wrap .tit {font-size: 145px;}
	.main-contact .tit-wrap .logo {width: 490px;}

	/* main-contact */
	.main-contact {min-height: 800px;}

	/* footer */	
	#footer .foot-info {flex-direction: column; gap: 20px;}
	#footer .ft-cont {flex-direction: row; align-items: flex-end;}
	.ft-logo-wrap {width: 180px;}
	#footer .ft-contact-info > dl {align-items: flex-start;}
	
	/* sub */
	.sub-visual .cell {bottom: 60px;}
    .sub-visual h2 {font-size: 100px;}
	.lnb-wrap {margin-top: 0;}
	.lnb {border-radius: 0;}
	.lnb ul li {border-radius: 0; height: 60px;}

	/* 공통 */
	
	/* content */
	/* 회사소개 */
	.greeting .head {flex-direction: column; gap: 40px;}
	.greeting .list {gap: 30px;}
	.greeting .list .tit {font-size: 18px;}
	.greeting .list .dot {width: 25px;}
	.greeting .line-wrap .line {top: 51px;}
	
	/* 연혁 */
	.history .item h3 {width: 180px;}
	.history .item-box {padding: 9px 0 100px 60px;}
	.history .item-box:before {top: 13px; left: 4px; width: 24px; height: 24px; border-width: 6px;}

	/* process */
	.process {flex-direction: column; gap: 40px;}
	.process .card {min-height: 310px;}
	.process .card .num {padding: 0 16px;}
	.process .cols {justify-content: center;}

	/* certification */
	.certification .list {grid-template-columns: repeat(3, 1fr); gap: 20px;}

	/* 오시는 길 */
	.lct-info dl {align-items: flex-start;}
	.lct-info dl dt span {width: 110px;}

	/* project */
	.project-list ul {margin: 0 -10px;}
	.project-list ul li {padding: 0 10px; margin-bottom: 20px;}
	.project-list ul li .txt-box {gap: 10px; padding: 10px;}
	.project-list ul li .txt-box .arrow {width: 40px; height: 40px;}
	.project-list ul li a:hover .txt-box .desc {margin-top: 10px;}

	/* product */
	.prod-list ul {margin: 0 -10px;}
	.prod-list ul li {width: 33.33%; padding: 0 10px; margin-bottom: 20px;}

	/* 상세페이지 */
	.prod-view {flex-direction: column; gap: 40px;}
	.prod-view-img {width: 100%; max-width: 640px; margin: 0 auto;}
	.prod-view .head {padding-bottom: 26px; margin-bottom: 26px;}
	.prod-view .info {width: 100%;}
    .project-btn-wrap .swiper-button-prev, .project-btn-wrap .swiper-button-next {width: 40px; height: 40px; background-size: 7px;}
    .project-pagination.swiper-pagination {max-width: 62px;}

	/* catalogs */
	.catalogs .list {grid-template-columns: repeat(3, 1fr);}

	/* news */
	.news-img-list ul {margin: 0 -10px;}
	.news-img-list ul li {width: 33.33333333%; padding:0 10px;}

	/* board */	
	.gallery-list ul {margin:0 -10px;}
	.gallery-list ul li {width:33.33333333%; padding:0 10px;}

	.card-list {gap:32px 20px;}

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

	.store-search {padding:30px; margin-bottom:30px;}
	.store-search .map-area {display:none;}
	.store-search .search-area h3 {text-align:center; margin-bottom:30px;}
	
} 

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

	#contArea {padding-bottom: 100px;}

	/* header */

	/* main */
	/* main-visual */
    .main-visual {height: 70vw;}
    .main-visual .slick-slide {height: 70vw;}
    .main-visual .item iframe {height: 70vw;}
	.main-visual .caption {bottom: 10%;}
	.main-visual .caption h2 {width: 180px; margin-bottom: 10px;}
	.main-visual .caption p {font-size: 14px;}
	
	/* main section */
	.com-btn {height: 45px;}
    
	/* main project */
	.stack-cards__item {min-height:350px; border-radius: 24px;}
    .main-container .product .card .prj-txt {top: 14px; left: 14px; right: 14px; bottom: 14px;}
    .prj-txt .tag {font-size: 18px;}
    .prj-txt .date {font-size: 15px;}
    
	/* main-news */
	.main-news .tit-wrap {flex-direction: column; gap: 20px;}
	.main-news .tit-area .logo {width: 231px;}
	.main-news .tit-area .tit {font-size: 69px; margin-top: 5px;}
	.main-news .list .item {width: 50%; margin-bottom: 30px;}
    
	/* main-contact */
	.main-contact .tit-wrap .tit {font-size: 106px; margin-top: 9px;}
	.main-contact .tit-wrap .logo {width: 350px;}
	
    /* footer */
	#footer .ft-cont {flex-direction: column; align-items: flex-start; gap: 10px;}
	#footer .ft-privacy {gap: 20px;}
	#footer .ft-contact-info {margin-bottom: 0;}
	#footer .ft-contact-info > dl {justify-content: start; width: 100%; margin-bottom: 5px;}
	#footer .copyright  {margin-top: 10px;}
	#footer .copyright > span {width: 100%; line-height: 1.25em;}
	#footer .ft-cont2 {flex-direction: column; align-items: flex-start;}
	#footer .top-wrap {flex-direction: row-reverse; justify-content: space-between; width: 100%;}
	.scroll-top {width: 30px; height: 30px;}
    
	/* sub */
    .sub-visual {height: 70vw;}
	.sub-visual .cell {bottom: 20px;}
	.sub-visual .box {margin-bottom: 0;}
	.sub-visual h2 {font-size: 75px;}
	.lnb ul li {height: 50px;}
    .lnb ul li a {white-space: nowrap; padding: 0 15px;}
	
	/* 공통 */
	
	/* content */
	/* 회사소개 */
	.greeting .list {flex-wrap: wrap; gap: 30px 50px; justify-content: center; padding: 0 20px;}
	.greeting .line-wrap {margin-top: 80px;}
	.greeting .line-wrap .line {top: 52px;}
	.greeting .line-wrap .line2 {top: 147px;}
	.greeting .line-wrap.on .line2 {transition-delay: 1.6s;}
	
	/* 연혁 */
	.history {padding-top: 20px;}
	.history .item {flex-direction: column;}
	.history .item h3 {width: 100%;margin-bottom: 20px;}
	.history .item-box {width: 100%; padding: 2px 0 60px 20px;}
	.history .item-box:after {display: none;}
	.history .item-box:before {display: none;}

	/* process */
	.process .cols {gap: 10px;}
	.process .card {flex:0 0 calc(50% - 5px);}
	.process .card .tit {font-size: 18px;}

	/* certification */
	.certification .list {grid-template-columns: repeat(2, 1fr); gap: 20px 10px;}

	/* 찾아오시는 길 */
	.root_daum_roughmap .wrap_map {height: 250px !important;}
	.location-section .lct-info dl {flex-direction: column; gap: 10px;}

	/* project */
	.project-list ul {margin: 0 -20px;}
	.project-list ul li {width: 100%; padding: 0 20px;}
	.project-list ul li .txt-box {padding: 20px;}

    .project-list ul li a .thumb:after {opacity: 0 !important;}
	.project-list ul li a .txt-box .desc { opacity: 0 !important; max-height: 0 !important; margin-top: 0 !important;}
	.project-list ul li a .txt-box .arrow {opacity: 0 !important;}

	/* 상세페이지 */
	.view-visual-box {flex-direction: column; align-items: flex-start; gap: 20px;}
	.view-visual-box .btn-wrap {display: flex; align-items: center; justify-content: flex-end; width: 100%;}
    .project-btn-wrap .swiper-button-prev, .project-btn-wrap .swiper-button-next {width: 35px; height: 35px; background-size: 6px;}

	/* product */
	.prod-list ul {margin: 0 -7px;}
	.prod-list ul li {width: 50%; padding: 0 7px; margin-bottom: 27px;}

	/* catalogs */
	.catalogs .list {grid-template-columns: repeat(2, 1fr);}
	.catalogs .download:after {width: 20px; height: 20px;}

	/* news */
	.news-img-list {padding-top:15px;}
	.news-img-list ul {margin:0 -7px;}
	.news-img-list ul li {width:50%; padding:0 7px; margin-bottom:27px;}
	.news-img-list ul li .thumb {margin-bottom:10px;}
	.news-img-list ul li .tit {font-size:14px;}
	.news-img-list ul li .date {font-size:12px; margin-top:4px;}

	/* board */
	.input {font-size:14px; padding:0 10px; height:38px;}
	select.input {padding-right:26px; 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%;}

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

    .simple-list .link-item {padding:16px 0;}
    .simple-list .link-item .num {max-width:50px; font-size:14px;}
    .simple-list .link-item .num .notice {width:40px; height:40px; font-size:12px;}
    .simple-list .link-item .cnt .tit {font-size:15px;}
    .simple-list .link-item .cnt .info {gap:5px 16px; margin-top:8px; font-size:12px;}
    .simple-list .link-item .arrow {display:none;}

	.gallery-list {padding-top:15px;}
	.gallery-list ul {margin:0 -7px;}
	.gallery-list ul li {width:50%; padding:0 7px; margin-bottom:27px;}
	.gallery-list ul li .thumb {margin-bottom:10px;}
	.gallery-list ul li .tit {font-size:14px;}
	.gallery-list ul li .date {font-size:12px; margin-top:4px;}

	.card-list {grid-template-columns:repeat(2, 1fr); gap:24px 16px; margin-bottom:32px;}
	.card-list .link-item {border-radius:10px;}
	.card-list .link-item .info {padding:12px;}
	.card-list .link-item .info .tit {font-size:15px;}
	.card-list .link-item .info .txt {margin-top:10px; font-size:13px;}
	.card-list .link-item .info .date {margin-top:10px; font-size:12px;}

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

	.event-list {padding-top:20px;}
	.event-list ul li {width:100%; margin-bottom:32px;}
	.event-list ul li .thumb {margin-bottom:10px;}
	.event-list ul li .tit {font-size:15px;}
	.event-list ul li .date {font-size:12px; margin-top:4px;}

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

	.calendar-head {margin-bottom:15px;}
	.calendar-head h3 {font-size:20px; 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;}

	.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:16px; background:none;}
	.board-form table td {display:block; border:0; padding:0;}
	.board-form + .buttons {margin-top:30px;}

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

	.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;}
	.paginate a.direction.prev {margin-right:14px;}
	.paginate a.direction.next {margin-left:14px;}

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

	.product-list ul {margin:0 -7px;}
	.product-list ul li {width:50%; padding:0 7px; margin-bottom:27px;}
	.product-list ul li .thumb {margin-bottom:10px;}
	.product-list ul li .tit {font-size:14px;}
	.product-summary {display:block;}
	.product-image {width:100%; margin-bottom:20px;}
	.product-info {width:100%;}
	.product-info .tit {font-size:22px; padding-bottom:14px; margin-bottom:14px;}
	.product-detail {padding-bottom:25px; margin-bottom:25px;}
	.product-detail .tit {font-size:17px; padding-bottom:10px; margin-bottom:14px;}

	.store-search {padding: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;}

	.result-top {font-size:18px;}
	.result-group .gall {margin:0 -7px;}
	.result-group .gall li {width:50%; padding:0 7px;}
	.result-group dl dt {font-size:15px;}
	.result-group dl dd {font-size:13px;}
	.result-group dl dd.date {font-size:12px;}

} 

@media (max-width: 420px) {
	.main-visual .caption h2 {width: 150px;}
	.main-news .tit-area .tit {font-size: 50px; margin-top: 3px;}
	.main-news .tit-area .logo {width: 167px;}
	.main-contact .tit-wrap .tit {font-size: 85px; margin-top: 0;}
	.main-contact .tit-wrap .logo {width: 300px;}

    .sub-visual h2 {font-size: 55px;}
    .sub-visual .box {font-size: 13px;}
    .sub-visual .box .icon {width: 12px; height: 12px;}
    .sub-visual .box .depth:before {width: 3px; height: 3px; margin: 0 8px;}

    .prj-txt .tit {font-size: 30px;}

	.greeting .list {gap: 20px;}
	.greeting .list .tit {font-size: 15px;}
	.greeting .list .dot {width: 20px;}
	.greeting .line-wrap .line {top: 44px;}
	.greeting .line-wrap .line2 {top: 123px;}	

	.process .cols {flex-direction: column; align-items: center; width: 100%;}
	.process .card {flex:0 0 100%; width: 100%;}
	.process .card:nth-of-type(even) {top: 0;}
} 