@charset "utf-8";

@media (max-width: 1600px) {
	/* main-visual */
	.main-visual .item {height: 53vw;}
	.main-visual .absol {bottom: 30px;}
	.main-visual .caption {bottom: 24%; left: 7%;}
	.main-visual .caption .logo {height: 55px;}
	.main-visual .caption .logo img {height: 100%;}
	.main-visual .slick-dots li button {width: 80px;}

	/* footer */
	#footer .foot-info {gap: 50px;}
}

@media (max-width: 1200px) {
    .slide-wrap {max-width: 450px;}
}

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

	/* header */
    #gnb {display:none;}
    .btn-m-menu {display:flex;}
	.btn-m-menu span {background: #fff;}
	#header.active .btn-m-menu span {background: #242424;}

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

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

	/* footer */
	#footer .ft-contact-info {gap: 0 10px;}

	/* sub */
	.path-wrap {bottom: 30px;}
	.path-wrap .home a {width: 50px; height: 50px;}
	.path-wrap .part {min-width: 200px;}
	.path-wrap .part ul {top: 50px;}
	.path-wrap .part > a {height: 50px;}

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

    /* 제품소개 */
    .prod-top-menu {grid-template-columns: repeat(3, 1fr);}
    /* 상세페이지 */
    .slide-wrap {max-width: 400px;}

	/* 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 */
	.sitelogo a, .ft-logo-wrap {width: calc(224px / 1.3); height: calc(48px / 1.3);}
	
	/* main */
	/* main-visual */
	.main-visual .caption .logo {height: 50px;}
	.main-visual .caption p {font-size: 16px;}
	.main-visual .slide-btn {width: 30px; height: 30px;}
	.main-visual .slick-dots li {margin: 0 4px;}
	.main-visual .slick-dots li button {width: 50px;}

	/* main section */
	.main-contact .more {width: 135px; height: 50px;}

	.main-product .list .img {flex: 0 0 50%;}
	.main-product .list .info {flex: 0 0 50%; padding: 15px;}
	.main-product .list .btn {width: 33px; height: 33px; border-radius: 8px;}
	.main-product .list .name p {font-size: 18px;}

	.main-contact .cont {flex-direction: column;}
	.main-contact .inquiry {max-width: 100%;}
	.notice-box .more {margin-top: 15px;}
	
	/* footer */	
	#footer .foot-info {flex-direction: column; gap: 20px;}
	#footer .ft-cont {flex-direction: row; align-items: flex-end;}
	
	/* sub */

	/* 공통 */
	
	/* content */
	/* 회사개요 */
	.overview .list .icon {width: 50px; height: 50px;}

	/* 제품소개 */
    .product-nav { position: fixed; left: 0; width: 100%; height: 100vh; top: 0; transform: translateX(-100%); transition: transform 0.3s ease-in-out; z-index: 999; padding: 80px 20px 20px;}
    .product-nav.active {transform: translateX(0);}
	.m-category {display: flex !important; align-items: center; justify-content: center; position: fixed; top: 55%; right: 0px; width: 40px; height: 40px; background: #DCE9F1; border-radius: 6px; border: none; padding: 0; z-index: 101; transform: translateY(-50%);}
    .product-nav.active .m-category { display: none;}
	.product-navmenu { width: 100%; z-index: 1; height: 100vh; padding: 60px 20px 20px; overflow: auto; background: #fff;}
	body.category-opened {overflow: hidden;}
	.product-nav .close {display: block; position: absolute; top: 20px; right: 20px; width: 20px; height: 20px; background: transparent; border: none;}
	.product-nav .close span {position: absolute; left: 0; top: 50%; width: 100%; height: 2px; background: #222;}
	.product-nav .close span:first-child {transform: translateY(-50%) rotate(45deg);}
	.product-nav .close span:last-child {transform: translateY(-50%) rotate(-45deg);}
    .prod-list-wrap { width: 100%;}


	/* 상세페이지 */
    .product-view .head {flex-direction: column; gap: 20px;}
    .slide-wrap {max-width: 520px; width: 100%; margin: 0 auto;}

	/* 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 #header {position: sticky; background: #fff;}
	#main .btn-m-menu span {background: #222;}
	.sitelogo a, .ft-logo-wrap {width: calc(224px / 1.5); height: calc(48px / 1.5);}

	/* main */
	/* main-visual */
	.main-visual .item {height: 53vw;}
	.main-visual .caption .logo {height: 40px;}
	.main-visual .caption h2 {font-size: 20px;}
	.main-visual .caption p {font-size: 14px;}
	.main-visual .absol {bottom: 10px;}
	.main-visual .slick-dots li button {width: 40px; height: 2px;}

	/* main section */
	.main-product .list {grid-template-columns: repeat(1, 1fr); gap: 10px;}
	.main-product .list .img {flex: unset;}
	.main-product .list .info {flex:1}
	.main-contact .inquiry {padding: 20px;}
	.main-contact .info .label {width: 55px;}
	.main-contact .sub-tel {padding: 10px;}
	.main-contact .notice-box .list li {flex-direction: column; align-items: flex-start; padding: 14px 0;}
	.main-contact .notice-box .list .date {margin-left: auto;}

    /* 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 .copyright > span:after {display: none;}
	#footer .icon-wrap {position: absolute; top: 40px; right: 30px; width: 45px; height: 45px;}

	/* sub */
	.sub-visual h2 {font-size: 28px;}
	.path-wrap {bottom: 5px; padding: 0;}
	.path-wrap .inner {gap: 4px; justify-content: flex-start;}
	.path-wrap .home a {width: 40px; height: 40px; background-size: 15px;}
	.path-wrap .part {min-width: calc(100% /2 - 25px)}
	.path-wrap .part ul {padding: 15px;}
	.path-wrap .part > a {height: 40px; padding: 0 10px; font-size: 14px;}
	.path-wrap .part > a:after {right: 10px;}
	

	/* 공통 */
	
	/* content */
	/* 인사말 */
	.greeting .head {flex-direction: column; align-items: start;}
	.greeting .logo {margin-left: auto; width: 170px;}
	.greeting .intro {font-size: 22px;}

	/* 회사개요 */
	.overview .list {grid-template-columns: repeat(2, 1fr); gap: 10px;}
	.overview .list .icon {width: 45px; height: 45px;}
	.overview .list .tit {font-size: 16px;}

	/* 취급메이커 */
	.maker .item-list {grid-template-columns: repeat(2, 1fr); gap: 10px;}
	.maker .item-list .list {border-radius: 6px;}

	/* 찾아오시는 길 */
	.root_daum_roughmap .wrap_map {height: 250px !important;}
	.location-section .lct-info {padding: 10px;}
	.location-section .lct-info dl {align-items: start;}
	.location-section .lct-info dd::before {display: none;}
	.location-section .lct-info .lct-tit {width: 40px;}

    /* 제품소개 */
    .prod-search-wrap {flex-direction: column; align-items: start; gap: 20px}
    .prod-search-wrap form {width: 100%;}
    .prod-search-wrap .search {width: 100%; height: 40px;}
    .prod-top-menu {grid-template-columns: repeat(2, 1fr);}
    .prod-list ul {margin: 0 -10px;}
    .prod-list ul li {width: 50%; padding:0 10px;}
    .prod-list ul li .tit {font-size: 18px;}

	/* 상세페이지 */
    .pd-btn.swiper-button-next, .pd-btn.swiper-button-prev {width: 30px; height: 30px;}
    .product-view .head .tit {font-size: 20px;}


	/* 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 .slick-dots li button {width: 25px;}
	#footer .ft-wrap {flex-direction: column; gap: 10px;}
	.main-product .list li a {gap: 4px; height: unset;}
	.main-product .list .img,
	.main-product .list .info {flex: 0 1 50%; min-width: 0; aspect-ratio: unset;}
} 