@charset "utf-8";

@media (max-width: 1700px) {
	#header {padding:0 var(--space-container);}
}

@media (max-width: 1460px) {
	.fix-inquiry .tel {flex: 0;}
	.fix-inquiry .tel span {white-space: nowrap;}
	.fix-inquiry .input-wrap {flex: 1 1 auto;}
	.fix-inquiry .input-wrap .input {width: 25%; flex: 1 1 auto;}
	.fix-inquiry .input-wrap #memo {width: 40%; flex: 2 1 auto;}
	.fix-inquiry .form-agree .check {flex-direction: column;}
	.fix-inquiry .form-agree .check a {margin-left: 0; margin-top: 5px;}
	.fix-inquiry .buttons .btn {height: 50px; padding: 0 var(--space-30);}
}

@media (max-width: 1280px) {
	#gnb {display:none;}
	.btn-m-menu {display:block;}
	.mobile-navigation {display:block;}
	#header .h-tel {margin-left: auto; margin-right: 20px; width: 160px; height: 38px; font-size: 14px;}
	#header .h-tel .icon {width: 18px; height: 18px;}

	.main-visual-wrap .scroll-wrap {right: 0;}

	.foot-txt-wrap {flex-direction: column-reverse;}
	.foot-links {margin-left: 0;}

	.project-list ul {margin:0 -15px;}
	.project-list ul li {width:50%; padding:0 15px; margin-bottom: 40px;}
}

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

	/* header */

	/* main */
	.main-inquiry .list-wrap {width: 60%;}
	.main-inquiry .inquiry-wrap {width: calc(40% - 20px);}

	.main-cases .contain {padding: 0;}
	.main-cases .tab ul {padding: 0 var(--space-20);}
	.main-cases .slick-list {padding-left: var(--space-20); padding-right: var(--space-20);}
	.main-cases .slick-slide {width: 33.334vw;}


	/* footer */


	/* sub */

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


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

	.cases .board-search .search form {width: 100%; gap: 5px;}
	.performance-list .wrap {margin:0 -10px -20px;}
	.performance-list .item {padding:0 10px; margin-bottom: 30px;}
	.performance-list .cnt .tit {font-size:16px; margin-bottom:15px;}
	.performance-list .cnt ul li {margin-bottom:5px;}
	
	.performance-image {width:350px;}
	.performance-info .tit {font-size:20px;}
	
	.review .board-search .search {gap: 5px;}

	/* member */
	.agree-wrap .agree-tit {font-size:18px;}


	.fix-inquiry-toggle {display: block;}
	.fix-inquiry-toggle .tel {font-size: 16px;}
	.fix-inquiry {padding-top: 0; display: none;}
	.fix-inquiry.active {display: block;}
	.fix-inquiry .contain {flex-direction: column; gap: 10px;}
	.fix-inquiry .tel {margin-right: 0; font-size: 16px; display: none;}
	.fix-inquiry .input-wrap {flex: none; margin-right: 0; width: 100%; flex-direction: column; gap: 5px;}
	.fix-inquiry .input-wrap .input {width: 100%; flex: none;}
	.fix-inquiry .input-wrap .input[name="memo"] {width: 100%; flex: none;}
	.fix-inquiry .form-agree .check {flex-direction: row;}
	.fix-inquiry .form-agree .check a {margin-left: 10px; margin-top: 0;}
	.fix-inquiry .buttons {width: 100%;}
	.fix-inquiry .buttons .btn {width: 100%; flex: none; margin-left: 0; height: 40px;}


} 

/* 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 .item {height:75vw;}

	.main-visual-wrap .scroll-wrap {display:none;}

	.main-inquiry .cont {flex-direction: column; gap: 40px;}
	.main-inquiry .list-wrap {width: 100%;}
	.main-inquiry .inquiry-wrap {width: 100%;}
	.main-inquiry .inquiry-wrap .items {flex-direction: column;}
	.main-inquiry .inquiry-wrap .captcha-wrap {flex-direction: row;}
	.main-inquiry .inquiry-wrap .captcha {width: auto;}
	.main-inquiry .inquiry-wrap .form-agree {margin: 20px 0;}
	.main-inquiry .inquiry-wrap .form-agree .check {flex-direction: column; gap: 10px;}
	.main-inquiry .inquiry-wrap .form-agree .checkbox label:before {margin-right: 9px;}


	/* footer */
	#footer .contain {flex-direction: column;}
	.foot-info-wrap {width: 100%;}
	.foot-info .unit-wrap {flex-direction: column; gap: 8px;}
	.foot-info .unit {padding: 0; justify-content: flex-start;}
	.foot-info .unit::after {content: none;}
	.foot-copy {flex-direction: column; gap: 8px;}
	.foot-copy span {padding: 0; justify-content: flex-start;}
	.foot-copy span::after {content: none;}

	/* sub */

	/* content */
	

	/* 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: 767px) {
	body, input, textarea, select, button, table {font-size:15px;}
	.only-desktop-tablet {display:none;}
	.only-tablet {display:none;}
	.only-mobile {display:block;}

	/* header */
	#header .h-tel {width: 38px;}
	#header .h-tel .icon {margin-right: 0;}
	#header .h-tel .tit {display: none;}
	#header .h-tel .tel {display: none;}


	/* main */
	.main-visual,
	.main-visual .item {height:100vw;}
	.main-visual .caption { gap:10px;}
	.main-visual .caption .t1 {font-size:26px;}
	.main-visual .caption .t2 {font-size:13px;}
	.main-visual .slick-dots {bottom:44px;}
	.main-visual .slick-dots li button {width:30px; height:30px; font-size:11px;}
	.main-visual .mv-bottom {font-size:12px;}

	.main-about .contain {flex-direction:column;}
	.main-about .img-wrap {width:100%;}
	.main-about .txt-wrap {max-width:100%;}
	.main-overview .items {grid-template-columns: repeat(2, 30%); justify-content: center; gap: 40px 20px;}
	.main-overview .item::after {content: none;}
	.main-overview .item .icon {width: 40px; height: 40px;}

	.main-cases .tab ul {flex-wrap: wrap; padding: 0 20px;}
	.main-cases .tab ul li {flex:1 0 auto;}
	.main-cases .slick-slide {width: 100vw; padding: 0 20px;}
	.main-cases .slick-slide .item {box-shadow: 2px 2px 8px 0 rgba(0, 0, 0, 0.25); aspect-ratio: auto;}
	.main-cases .slick-slide a {height: 56vw; max-height: 230px;}
	.main-cases .slick-slide .txt-wrap {max-height: 220px; height: calc((1.5em * 2) + (1.75em * 2) + 1.7em + 50px);}
	.main-cases .slick-slide .txt-wrap .tit {display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; white-space: normal;}

	.main-inquiry .list {height: 61px;}
	.main-inquiry .list-wrap .list {height: 61px;}



	/* footer */

	/* sub */
	.sub-visual {height:240px; padding:50px 0;}
	.sub-visual .title p {width:80%; margin:8px auto 0;}

	.lnb-wrap {padding:0;}
	.lnb {border-radius:0;}
	.lnb ul li {flex:1 0 auto; width:auto;}
	.lnb ul li a {padding:0 15px; font-size:14px; white-space:nowrap;}

	.sub-title {padding:60px 0 30px;}

	/* content */
	.greetings .sec1 {flex-direction: column;}
	.greetings .sec2 .vision {grid-template-columns:repeat(1, 1fr);}
	.greetings .sec2 .vision .item {aspect-ratio: auto;}
	.greetings .sec2 .vision .item .icon {margin-top: 20px;}

	.license .list {grid-template-columns:repeat(2, 1fr); gap: var(--space-40);}

	.field .feat-grid {grid-template-columns: repeat(1, 1fr); grid-template-rows: repeat(4, 1fr);}
	.field .feat-grid .box {display: flex; flex-direction: column;}
	.field .feat-grid .txt {margin: auto 0;}
	.field .time-grid {grid-template-columns: repeat(1, 1fr); grid-template-rows: repeat(3, 1fr);}
	.field .time-grid .icon {margin-top: auto;}
	.field .major-grid {grid-template-columns: repeat(1, 1fr);}
	.field .major-grid .box {display: flex; flex-direction: column;}
	.field .major-grid .desc {margin: auto 0;}
	.field .major-grid.type2 {grid-template-rows: auto;}
	.field .major-grid.type2 .box {flex-direction: column; gap: 10px;}
	.field .major-grid.type2 .tit {flex: none;}
	.field .major-grid.type2 .dot-list {width: 100%;}
	.field .major-grid .dot-list li {padding-left: 12px;}
	.field .major-grid .dot-list li::before {width: 4px; height: 4px; top: 7px;}
	.field .step-list li {width: calc(50% - (var(--space-30) / 2)); display: flex; flex-direction: column;}
	.field .step-list li .info {flex: 1;}

	.partner {grid-template-columns: repeat(2, 1fr); gap: 20px 15px;}
	
	/* 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;}

	.prj-tab ul li a {font-size:15px;}

	.performance-list .wrap {margin:0;}
	.performance-list .item {width:100%; padding:0; margin-bottom:20px;}
	.performance-list .item:last-child {margin-bottom:0;}
	
	.performance-detail .top {flex-direction: column;}
	.performance-image {width:100%; margin-bottom:20px;}
	.performance-info {width:100%;}
	.performance-info .tit-wrap .title {font-size: 20px;}
	.performance-info .info li .lbl {width:80px;}

	.review .board-search .search {width: 100%;}

	/* member */
	.login-tab {border-bottom-width:2px; margin-bottom:35px;}
	.login-tab ul {padding:0 1px;}
	.login-tab ul li {border-width:2px; margin:0 -1px;}
	.login-tab ul li a {font-size:16px; line-height:46px;}
	.login-content .group .input {height:48px; font-size:14px;}

	.sns-login .tit {margin-bottom:20px;}
	.sns-login .tit span {padding:0 20px;}
	.sns-login a {margin:0 8px}
	.sns-login img {width:44px;}

	.agree-wrap {margin-bottom:35px;}
	.agree-wrap .group {margin-top:30px;}
	.agree-wrap .agree-tit {font-size:16px;}
	.agree-wrap .agree-tit .checkbox label:before {background-image:url("../images/member/checkbox_x2.png"); background-size:11px auto;}
	.agree-wrap .agree-tit .checkbox input:checked + label:before {background-image:url("../images/member/checkbox_on_x2.png");}
	.agree-wrap .agree-box {margin-top:7px; max-height:130px; padding:10px 13px;}
	.agree-wrap .agree-box .terms-wrap {line-height:1.4em; word-break:break-all;}

	.terms-wrap .policy-contact {display:block; padding:0 15px;}
	.terms-wrap .policy-contact dl {border-left:0; padding:20px 5px; border-top:1px solid #e5e5e5;}
	.terms-wrap .policy-contact dl:first-child {border-top:0;}

	.join-form table tbody {display:block;}
	.join-form table tr {display:block; padding:12px 0;}
	.join-form table th {display:block; border:0; text-align:left; padding:0; margin-bottom:7px; font-size:16px; background:none;}
	.join-form table td {display:block; border:0; padding:0;}
	.join-form + .buttons {margin-top:30px;}
	.join-form .help-text {display:block; clear:both; padding-top:6px; margin-left:0; font-size:14px; line-height:1.5em;}
	.join-form #user_id {float:left; width:calc(100% - 90px) !important;}
	.join-form #user_id + .btn-pack {width:90px; text-align:center;}
	.join-form #user_pw,
	.join-form #user_pw2,
	.join-form #user_name {width:100% !important;}

	.join-complete .tit {font-size:22px; margin-bottom:20px;}
	.join-complete .txt {font-size:16px;}
	.join-complete .icon {width:110px; height:110px; background-size:48px;}

	.find-tab {border-bottom-width:2px; margin-bottom:35px;}
	.find-tab ul {padding:0 1px;}
	.find-tab ul li {border-width:2px; margin:0 -1px;}
	.find-tab ul li a {font-size:16px; line-height:46px;}
	.find-content .group .input {height:48px; font-size:14px;}
	.find-result {padding:30px 15px; font-size:16px;}
	.find-result h4 {font-size:19px;}
	.find-result .name {font-size:24px;}

	.member-leave .txt {margin-bottom:27px;}
	.member-leave .txt .tit {font-size:18px;}
	.member-leave .form {margin-bottom:35px; padding:35px 25px; font-size:15px;}
	.member-leave .form .group .label-tt {width:80px;}

} 


/* Landscape phones and down */
@media (max-width: 320px) {
	.lnb ul li a {font-size: .89em;}

} 