@charset "utf-8";
/*
 * Name     : sub.css
 * Version  : 1.1.3
 * Author   : onepixel studio
 * Date     : 2023-10-20
 * Table of contents
 * ------------------------------------------------------
 * 01) Hero
 * 02) Common
 * 03) About
 * 04) Business
 * 05) Product
 * 06) FAQ
 * 07) Inquiry
 * 08) Popup
 * 09) Terms
 * 10) Media queries
 */

/* *********************************************
 * Hero
 ******************************************** */
.hero {position: relative; height: 450px; overflow: hidden}
.hero .hero-bg {position: absolute; top: 0; left: 0; bottom: 0; right: 0; margin-bottom: 0; background-color: var(--main); background-size: cover; background-position: center; background-repeat: no-repeat; transform: scale(1.15); transition: transform 5s; z-index: 5}
.hero.--load .hero-bg {transform: scale(1)}
.hero .caption {position: relative; display: flex; width: 100%; height: 100%; padding-top: 40px; text-align: center; align-items: center; z-index: 10}
.hero .caption h2 {font-size: 36px; font-weight: 600; color: var(--white-100); letter-spacing: -0.02em; line-height: 1.1;}

/* *********************************************
 * Common
 ******************************************** */
.breadcrumb-navbar {position: relative; height: 60px; background-color: rgba(0,0,0,.5); transform: translateY(-60px); z-index: 10}
.breadcrumb-navbar .container-xl {height: 100%}
.breadcrumb-navbar .navbar-wrapper {display: flex; height: 100%; flex-wrap: wrap}
.breadcrumb-navbar .navbar-wrapper > li {flex-basis: 0; flex-grow: 1; max-width: 100%}
.breadcrumb-navbar .navbar-wrapper > li > a {position: relative; display: flex; width: 100%; height: 100%; font-size: 18px; font-weight: 600; color: var(--white-100); letter-spacing: -0.02em; align-items: center; justify-content: center}
.breadcrumb-navbar .navbar-wrapper > li > a.active {font-weight: 700; color: var(--main); background-color: var(--white-100)}
.breadcrumb-navbar .navbar-wrapper > li + li > a::before {content: ''; position: absolute; top: 50%; left: 0; width: 1px; height: 20px; background-color: rgba(255,255,255,.2); transform: translateY(-50%)}
.section {padding-top: 20px; padding-bottom: 120px;}
.section .section-main-heading {text-align: center; margin-bottom: 40px}
.section .section-main-heading h2 {font-size: 42px; font-weight: 700; color: var(--main); letter-spacing: -0.02em; line-height: 1.1}
.section .section-main-heading p {font-size: 18px; color: var(--main); letter-spacing: -0.02em; line-height: 1.5; margin-top: 16px}
.section .section-sub-heading {text-align: center; margin-bottom: 64px}
.section .section-sub-heading .en-heading {font-size: 20px; font-weight: 800; color: var(--primary); line-height: 1.1; margin-bottom: 20px}
.section .section-sub-heading h3 {font-size: 30px; font-weight: 700; color: var(--main); letter-spacing: -0.02em; line-height: 1.32}
.section .section-sub-heading h3.mb24{margin-bottom: 24px;}
.section .section-sub-heading p {font-size: 18px; font-weight: 500; color: var(--gray-400); letter-spacing: -0.02em}
.sub-bottom-banner {height: 300px;width: 100%; text-align: center; display: none;}
.sub-bottom-banner span {font-size: 32px;color: var(--white-100);font-weight: 600;display: block;width: 100%;padding-top: 65px;line-height: 1.6;}
.sub-bottom-banner button.sbb-btn {font-weight: 500;background-color: var(--main);height: 48px;border-radius: 24px;padding: 12px 30px;font-size: 16px;font-weight: 500;font-stretch: normal;font-style: normal;line-height: normal;letter-spacing: normal;border: none;text-align: left;color: var(--white-100);transition: 0.3s ease;margin-top: 20px;}
.sub-bottom-banner button.sbb-btn:hover {background: var(--white-100);color: var(--main);}
.sub-bottom-banner.page1 {background: url("../images/sub/sub_bottom_banner.jpg")no-repeat center;}
.sub-bottom-banner.page2 {background: url("../images/sub/sub_bottom_banner.jpg")no-repeat center;}
.sub-bottom-banner.page3 {background: url("../images/sub/sub_bottom_banner.jpg")no-repeat center;}
.sub-bottom-banner.page4 {background: url("../images/sub/sub_bottom_banner.jpg")no-repeat center;}
.sub-bottom-banner.page5 {background: url("../images/sub/sub_bottom_banner.jpg")no-repeat center;}
a.button-more-arrow .icon::before {background-color: var(--primary);}

/* *********************************************
 * About
 ******************************************** */
/* 회사소개 */
.about-overview {padding-bottom: 140px}
.about-overview .row-overview .col-img img {display: block; width: 100%}
.about-overview .row-overview .col-content .en-heading {font-size: 20px; font-weight: 700; color: var(--primary); letter-spacing: 0.02em; margin-bottom: 20px}
.about-overview .row-overview .col-content h3 {font-size: 28px; font-weight: 700; color: var(--main); letter-spacing: -0.02em; line-height: 1.36; margin-bottom: 10px}
.about-overview .row-overview .col-content p {font-size: 17px; color: var(--gray-400); letter-spacing: -0.02em; line-height: 1.56}
.about-overview .row-overview .col-content .company-info {margin-top: 48px}
.about-overview .row-overview .col-content .company-info li {padding: 16px 20px; border-bottom: 2px solid #e9e9e9}
.about-overview .row-overview .col-content .company-info li dl {font-size: 0}
.about-overview .row-overview .col-content .company-info li dl dt, .about-overview .row-overview .col-content .company-info li dl dd {display: inline-block; font-size: 18px; letter-spacing: -0.02em; line-height: 1.5; vertical-align: top}
.about-overview .row-overview .col-content .company-info li dl dt {font-weight: 600; color: var(--gray-300); width: 110px}
.about-overview .row-overview .col-content .company-info li dl dd {font-weight: 600; color: var(--main); text-align: right; width: calc(100% - 110px)}

.about-core-value .section-sub-heading {position: relative; margin-bottom: 0; padding-bottom: 75px}
.about-core-value .section-sub-heading::after {content: 'Motivation from Pleasure'; position: absolute; bottom: 0; left: 0; right: 0; font-size: 90px; font-weight: 900; color: var(--gray-200); line-height: 0.5; text-align: center; opacity: .1}
.about-core-value .row-core .col-core-item figure {margin-bottom: 0}
.about-core-value .row-core .col-core-item figure img {display: block; width: 100%}
.about-core-value .row-core .col-core-item figure figcaption {position: relative; margin-top: -40px; margin-right: 80px; padding: 32px 24px; background-color: var(--white-100); z-index: 5}
.about-core-value .row-core .col-core-item figure figcaption .col-title {width: 80px}
.about-core-value .row-core .col-core-item figure figcaption .col-title h5 {font-size: 14px; font-weight: 700; color: var(--primary)}
.about-core-value .row-core .col-core-item figure figcaption .col-content h4 {font-size: 20px; font-weight: 600; color: var(--main); letter-spacing: -0.02em; line-height: 1.3; margin-bottom: 14px}
.about-core-value .row-core .col-core-item figure figcaption .col-content p {color: var(--gray-400); letter-spacing: -0.02em; line-height: 1.56}

/* CEO 인사말 */
.greeting-type-01 .col-img img {display: block; width: 100%}
.greeting-type-01 .col-text h3 {font-size: 28px; font-weight: 600; color: var(--main); letter-spacing: -0.02rem; margin-bottom: 24px}
.greeting-type-01 .col-text p {color: var(--main); letter-spacing: -0.02em; line-height: 1.6}
.greeting-type-01 .col-text p + p {margin-top: 16px}
.greeting-type-01 .col-text p .ceo-name {font-size: 24px; font-weight: 700; color: var(--main); letter-spacing: 0.03em}
.greeting-type-02 .cover-img {margin-bottom: 48px}
.greeting-type-02 .cover-img img {display: block; width: 100%}
.greeting-type-02 .col-text p {color: var(--main); letter-spacing: -0.02em; line-height: 1.8}
.greeting-type-02 .col-text p + p {margin-top: 16px}
.greeting-type-02 .col-text p .ceo-name {font-size: 24px; font-weight: 700; color: var(--main); letter-spacing: 0.03em}

/* 연혁 */
.history .history-cover {margin-bottom: 24px; padding: 100px 0; background-size: cover; background-position: center; background-repeat: no-repeat}
.history .history-cover h3 {font-size: 36px; font-weight: 600; color: var(--white-100); letter-spacing: -0.02em; line-height: 1.16; margin-bottom: 20px; text-align: center;}
.history .history-cover p {font-size: 18px; font-weight: 400; color: rgba(255,255,255,.8); letter-spacing: -0.02em; line-height: 1.55; text-align: center;}
.history .history-item {padding: 32px;}
.history .history-item + .history-item {border-top: 1px solid #e9e9e9}
.history .history-item .col-year h4 {font-size: 32px; font-weight: 700; color: var(--main); letter-spacing: 0.02em}
.history .history-item .col-content > ul > li {font-size: 0}
.history .history-item .col-content > ul > li + li {margin-top: 10px}
.history .history-item .col-content > ul > li > b, .history .history-item .col-content > ul > li > p {display: inline-block; font-size: 18px; letter-spacing: -0.02em; line-height: 1.56; vertical-align: top}
.history .history-item .col-content > ul > li > b {display: block; font-weight: 700; color: var(--gray-300); margin-bottom: 6px;}
.history .history-item .col-content > ul > li > p {font-weight: 500; color: var(--gray-400)}
.history .history-item .col-img > img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* 오시는 길 */
.location .map-container {position: relative; margin-bottom: 64px; padding-bottom: 56.25%; overflow: hidden}
.location .map-container > iframe {position: absolute; display: block; top: 0; left: 0; width: 100% !important; height: 100% !important}
.location .location-info {padding-left: 64px; padding-right: 64px}
.location .location-info .info-heading {font-size: 16px; font-weight: 600; color: var(--main); letter-spacing: -0.02em}
.location .location-info p {color: var(--gray-300); letter-spacing: -0.02em; line-height: 1.8}

/* *********************************************
 * Business
 ******************************************** */
/* 사업소개 */
.business-overview {padding-left: 20px; padding-right: 20px}
.business-overview .overview-container {max-width: 1800px; margin: auto}
.business-overview .overview-heading {font-size: 32px; font-weight: 600; color: var(--main); letter-spacing: -0.02em; line-height: 1.36; margin-bottom: 64px; text-align: center;}
.business-overview .overview-cover {position: relative; height: 290px; background-image: url(../images/sub/about_bg.jpg); background-size: cover; background-repeat: no-repeat; background-position: center}
.business-overview .overview-cover .typo-box {position: absolute; width: 100%; bottom: 0; right: 0; padding: 50px; background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgb(0 0 0 / 70%)); z-index: 10; text-align: center;}
.business-overview .overview-cover .typo-box p {font-size: 18px; font-weight: 500; color: var(--white-100); letter-spacing: -0.02em; line-height: 1.64}
.business-overview .row-overview .col-item .item-inner {height: 100%; padding: 32px; border: 1px solid #dee2e6; text-align: center;}
.business-overview .row-overview .col-item .item-inner .item-header {margin-bottom: 10px}
.business-overview .row-overview .col-item .item-inner .item-header h3 {font-size: 22px; font-weight: 700; color: var(--main); letter-spacing: -0.02em}
.business-overview .row-overview .col-item .item-inner .item-header .icon {display: inline-flex; width: 90px; height: 90px; font-size: 48px; color: var(--primary); align-items: center; justify-content: center; margin-bottom: 20px;}
.business-overview .row-overview .col-item .item-inner p {font-size: 17px; color: var(--gray-400); letter-spacing: -0.02em; line-height: 1.8}
.business-strength .row-strength + .row-strength {margin-top: 64px}
.business-strength .row-strength .col-img img {display: block; width: 100%}
.business-strength .row-strength .col-info .heading {position: relative; margin-bottom: 24px; z-index: 5}
.business-strength .row-strength .col-info .heading h4 {font-size: 22px; font-weight: 700; color: var(--main); line-height: 1.1}
.business-strength .row-strength .col-info .heading .num {position: absolute; bottom: 0; left: 0; display: block; font-size: 90px; font-weight: 900; color: var(--gray-200); line-height: 0.8; opacity: 0.09; z-index: -1}
.business-strength .row-strength .col-info p {color: var(--gray-400); letter-spacing: -0.02em; line-height: 1.75; font-size: 18px;}
.business-field .row-field .col-field .field-card {height: 100%; border: 1px solid #dee2e6}
.business-field .row-field .col-field .field-card figure {margin-bottom: 0}
.business-field .row-field .col-field .field-card figure img {display: block; width: 100%}
.business-field .row-field .col-field .field-card .content {padding: 60px 40px 40px}
.business-field .row-field .col-field .field-card .content .heading {position: relative; margin-bottom: 20px; z-index: 5}
.business-field .row-field .col-field .field-card .content .heading h4 {font-size: 22px; font-weight: 700; color: var(--main); letter-spacing: -0.02em}
.business-field .row-field .col-field .field-card .content .heading .num {position: absolute; bottom: 0; left: 0; font-size: 90px; font-weight: 900; color: var(--gray-200); line-height: 0.85; opacity: 0.09; z-index: -1}
.business-field .row-field .col-field .field-card .content p {font-size: 17px; color: var(--gray-400); letter-spacing: -0.02em; line-height: 1.8}
.business-detail {}
.business-detail .row-detail .col-img img {display: block; width: 100%}
.business-detail .row-detail .col-text {display: flex; background-color: #f3f5fb; align-items: center; position: relative;}
.business-detail .row-detail .col-text::before {content:''; position:absolute; display:block; top:11px; right:-3px; width:30px; height:1px; background-color: #6693fb; opacity:0.5; transform:rotate(-45deg)}
.business-detail .row-detail .col-text .text-inner {width: 100%; padding-left: 64px; padding-right: 20px}
.business-detail .row-detail .col-text .text-inner h4 {font-size: 22px; font-weight: 700; color: var(--main); letter-spacing: -0.02em; line-height: 1.3; margin-bottom: 16px}
.business-detail .row-detail .col-text .text-inner p {font-size: 17px; font-weight: 500; color: var(--gray-300); letter-spacing: -0.02em; line-height: 1.8}
.business-detail .row-detail .col-text .text-inner .button-more-arrow {color: var(--main); margin-top: 48px}
.business-detail .row-detail .col-text .text-inner .button-more-arrow .icon {color: var(--white-100)}
.business-detail .row-detail + .row-detail {margin-top: 32px}

/* *********************************************
 * Product
 ******************************************** */
/* 페이지 타입 */
.product-list-page .product-type-heading {font-size: 19px; font-weight: 600; color: var(--main); letter-spacing: -0.02em; margin-bottom: 20px}
.product-list-page .masonry-group .grid-sizer, .product-list-page .masonry-group .gallery-item {width: calc(25% - 20px)}
.product-list-page .gallery-item {margin-bottom: 40px}
.product-list-page .gallery-item a {display: block; height: 100%}
.product-list-page .gallery-item figure {position: relative; overflow: hidden}
.product-list-page .gallery-item figure img {display: block; width: 100%; transition: transform .5s}
.product-list-page .gallery-item a:hover figure img {transform: scale(1.1)}
.product-list-page .gallery-item .category {display: block; font-size: 14px; font-weight: 600; color: var(--primary); margin-bottom: 4px}
.product-list-page .gallery-item h5 {font-size: 19px; font-weight: 600; color: var(--main); letter-spacing: -0.02em; line-height: 1.48}
.product-list-page .gallery-item p {color: var(--gray-300); letter-spacing: -0.02em; line-height: 1.64; margin-top: 16px}
.product-list-page .gallery-item .gallery-card {height: 100%; background-color: var(--white-100); overflow: hidden}
.product-list-page .gallery-item .gallery-card.bordered {border: 1px solid #e9e9e9}
.product-list-page .gallery-item .gallery-card.rounded {border-radius: 20px !important}
.product-list-page .gallery-item .gallery-card figure {margin-bottom: 0}
.product-list-page .gallery-item .gallery-card .card-content {padding: 28px}
.product-list-page .video-item {margin-bottom: 60px}
.product-list-page .video-item a {display: block; height: 100%}
.product-list-page .video-item figure {position: relative; margin-bottom: 24px; overflow: hidden}
/* .product-list-page .video-item figure::before {content: ''; position: absolute; display: block; bottom: 0; left: 0; right: 0; height: 50%; background-image: linear-gradient(to top, rgba(0,0,0,.56), transparent); z-index: 1; transition: height .3s ease-in-out} */
.product-list-page .video-item figure img {display: block; width: 100%; transition: transform .5s}
.product-list-page .video-item figure .play-icon {position: absolute; display: inline-flex; top: 50%; left: 50%; width: 80px; height: 80px; font-size: 50px; color: var(--white-100); line-height: 1; border-radius: 50%; background-color: rgba(33,33,33,.6); backdrop-filter: blur(3px); align-items: center; justify-content: center; transform: translate(-50%,-50%); transition: background-color .3s; z-index: 2}
/* .product-list-page .video-item figure figcaption {position: absolute; bottom: 0; left: 0; right: 0; padding: 28px 32px; z-index: 10} */
.product-list-page .video-item .info h4 {font-size: 21px; font-weight: 600; color: var(--main); letter-spacing: -0.02em}
.product-list-page .video-item .info p {font-weight: 500; color: var(--gray-300); letter-spacing: -0.02em; margin-top: 10px}
.product-list-page .video-item a:hover figure img {transform: scale(1.1)}
/* .product-list-page .video-item a:hover figure::before {height: 80%} */
.product-list-page .video-item a:hover figure .play-icon {background-color: rgba(0,0,0,.6)}

/* magnific popup */
.mfp-with-zoom .mfp-container, .mfp-with-zoom.mfp-bg {opacity: 0; -webkit-backface-visibility: hidden; transition: all 0.3s ease-out}
.mfp-with-zoom.mfp-ready .mfp-container {opacity: 1}
.mfp-with-zoom.mfp-ready.mfp-bg {opacity: .8}
.mfp-with-zoom.mfp-removing .mfp-container, .mfp-with-zoom.mfp-removing.mfp-bg {opacity: 0}
.mfp-bottom-bar {margin-top: -24px}
.mfp-arrow:before {display: none}
.mfp-arrow:after {content: ''; display: block; top: 50%; left: 50%; width: 52px; height: 30px; margin: -15px 0 0 -26px !important; padding: 0;  border: 0 !important; background-size: 100%; background-position: center; background-repeat: no-repeat}
.mfp-arrow-left:after {background-image: url(../images/sub/long_arrow_left.svg)}
.mfp-arrow-right:after {background-image: url(../images/sub/long_arrow_right.svg)}

/* *********************************************
 * FAQ
 ******************************************** */
.accordion {border-bottom: 1px solid #e5e5e5}
.accordion>.card {border: 0; border-radius: 0 !important}
.accordion>.card>.card-header {margin-bottom: 0; padding: 20px 24px; border-top: 1px solid #e5e5e5; border-bottom: 0; background-color: var(--white-100)}
.accordion .card-header .btn-link {position: relative; font-size: 20px; font-weight: 600; color: var(--main); letter-spacing: -0.02em; text-decoration: none; height: auto; padding: 0;width:100%;text-align: left;}
.accordion .card-header .btn-link::before, .accordion .card-header .btn-link::after {content: ''; position: absolute; display: block; top: 50%; background-color: var(--main); transform: translateY(-50%)}
.accordion .card-header .btn-link::before {top: 50%; right: 0; width: 20px; height: 1px}
.accordion .card-header .btn-link::after {top: 50%; right: 10px; width: 1px; height: 20px}
.accordion .card-header .btn-link[aria-expanded='true']::after {display: none}
.accordion .card-body {padding: 0 28px 28px}
.accordion .card-body p {font-size: 17px; color: var(--gray-300); letter-spacing: -0.02em; line-height: 1.8}

/* *********************************************
 * Inquiry
 ******************************************** */
.inquiry-form .table-form {display: block; width: 100%}
.inquiry-form .table-form > tbody {display: flex; margin-left: -1.5rem; margin-right: -1.5rem; flex-wrap: wrap}
.inquiry-form .table-form > tbody > tr {height: auto !important; margin-bottom: 32px; max-width: 50%; flex: 0 0 50%; padding-left: 1.5rem; padding-right: 1.5rem}
.inquiry-form .table-form > tbody > tr:nth-child(5), .inquiry-form .table-form > tbody > tr:nth-child(6) {max-width: 100%; flex: 0 0 100%}
.inquiry-form .table-form > tbody > tr > td {display: block; width: 100% !important; font-family: inherit !important; font-size: 0; text-align: left !important}
.inquiry-form .table-form > tbody > tr > td br {display: none}
.inquiry-form .table-form > tbody > tr:not([height]) {display: none}
.inquiry-form .table-form .formmail_title_bgcolor {font-size: 16px; font-weight: 600; color: var(--main); letter-spacing: -0.02em; line-height: 1.1; margin-bottom: 12px; background-color: transparent}
.inquiry-form .table-form .formmail_title_bgcolor font {font-family: inherit !important; font-size: inherit !important}
.inquiry-form .table-form input[type='text'], .inquiry-form .table-form input[type='password'], .inquiry-form .table-form select, .inquiry-form .table-form textarea {display: block; width: 100%; height: 56px; padding: 0 16px; font-family: inherit !important; font-size: 16px; font-weight: 500; color: var(--gray-300); letter-spacing: -0.02em; border: 1px solid transparent; background-color: var(--white-200); outline: 0; transition: color .3s, border-color .3s, background-color .3s}
.inquiry-form .table-form input[type='text']:focus, .inquiry-form .table-form input[type='password']:focus, .inquiry-form .table-form select:focus, .inquiry-form .table-form textarea:focus {color: var(--main); border-color: var(--main); background-color: var(--white-100)}
.inquiry-form .table-form select {cursor: pointer; padding-right: 28px; background-image: url(../images/common/select_dropdown_arrow.svg); background-position: right 16px center; background-size: 16px 16px; background-repeat: no-repeat}
.inquiry-form .table-form textarea {padding: 16px; height: auto !important; min-height: 210px}
.inquiry-form .submit-button {padding-top: 40px}
.inquiry-form .submit-button .button-submit {display: block; width: 100%; height: 64px; font-size: 20px; font-weight: 600; color: var(--white-100); letter-spacing: -0.02em; padding: 0; border: 0; background-color: var(--main); outline: 0; transition: background-color .3s}
.inquiry-form .submit-button .button-submit:hover {background-color: var(--main)}
#privacyModal .term-content p {color: var(--gray-300); letter-spacing: -0.02em; line-height: 1.8}
#privacyModal .term-content p + p {margin-top: 16px}

/* *********************************************
 * 아이디/비밀번호 찾기 Popup
 ******************************************** */
.popup-wrapper .popup-header {display: flex; height: 4rem; padding: 0 1.75rem; border-bottom: 1px solid #000; align-items: center; justify-content: space-between}
.popup-wrapper .popup-header h1 {font-size: 1.25rem; font-weight: 700; color: #000; letter-spacing: -0.03em}
.popup-wrapper .popup-header .button-close {display: flex; width: 4rem; height: 4rem; font-size: 1.5rem; color: #FFFFFF; margin: 0 -1.75rem 0 auto; align-items: center; justify-content: center; border: 0; background-color: #000}
.popup-wrapper .popup-content {padding: 1.75rem 1.75rem 2.25rem}
.popup-wrapper .popup-content p {color: #000; letter-spacing: -0.02em; line-height: 1.5} 
.popup-wrapper .popup-content p strong {font-weight: 700; color: #000} 
.popup-wrapper .popup-content p .warning-text {font-weight: 600; color: #e03131} 
.popup-wrapper .popup-content p .info-text {font-weight: 600; color: #f59f00} 
.popup-wrapper .popup-content p .success-text {font-weight: 600; color: #099268} 
.popup-wrapper .popup-content .info-summary {border-top: 1px solid #333}
.popup-wrapper .popup-content .info-summary li {display: flex; padding: 1.25rem 0; border-bottom: 1px solid #e9e9e9; flex-wrap: wrap}
.popup-wrapper .popup-content .info-summary li > b, .popup-wrapper .popup-content .info-summary li > p {font-size: 1rem; letter-spacing: -0.02em; line-height: 1.6}
.popup-wrapper .popup-content .info-summary li > b {width: 5rem; font-weight: 700; color: #000}
.popup-wrapper .popup-content .info-summary li > p {flex-basis: 0; max-width: 100%; color: #666}
.popup-wrapper .popup-content .bottom-buttons {padding-top: 3rem}

/* *********************************************
 * Terms
 ******************************************** */
.terms-section .terms-container h3 {font-size: 1.25rem; font-weight: 700; color: var(--main); line-height: 1.5; letter-spacing: -0.03rem; margin-bottom: 1.5rem}
.terms-section .terms-container h4 {font-size: 1.125rem; font-weight: 700; color: var(--main); letter-spacing: -0.03em; margin-bottom: 0.625rem}
.terms-section .terms-container h5 {font-size: 1.0625rem; font-weight: 600; color: var(--main); letter-spacing: -0.03em; margin-bottom: 0.375rem}
.terms-section .terms-container p {color: var(--main); letter-spacing: -0.03em; line-height: 1.75; margin-bottom: 1.125rem}
.terms-section .terms-container .item-list > li {position: relative; color: var(--main); letter-spacing: -0.03em; line-height: 1.75; padding-left: 0.875rem}
.terms-section .terms-container .item-list > li::before {content: '-'; position: absolute; top: 0; left: 0; color: #ccc}
.terms-section .terms-container .bullet-list > li {position: relative; color: var(--main); letter-spacing: -0.03em; line-height: 1.75; padding-left: 1.25rem}
.terms-section .terms-container .bullet-list > li::before {content: ''; position: absolute; top: 0.625rem; left: 0; width: 0.625rem; height: 0.625rem; border: 2px solid #ccc; border-radius: 50%}
.terms-section .terms-container .order-list {counter-reset: terms}
.terms-section .terms-container .order-list > li {position: relative; color: var(--main); letter-spacing: -0.03em; line-height: 1.75; padding-left: 1.125rem}
.terms-section .terms-container .order-list > li + li {margin-top: 0.25rem}
.terms-section .terms-container .order-list > li b {font-weight: 600; color: var(--main)}
.terms-section .terms-container .order-list > li::before {content: counter(terms)'.'; position: absolute; left: 0; counter-increment: terms}
.terms-section .terms-container .order-list-ko > li {position: relative; color: var(--main); letter-spacing: -0.03em; line-height: 1.75; padding-left: 1.5rem}
.terms-section .terms-container .order-list-ko > li > span:first-child {position: absolute; left: 0}
.terms-section .terms-container .order-list-ko > li > span:first-child:after {content: '.'}
.terms-section .terms-container .order-list-bracket {counter-reset: bracket}
.terms-section .terms-container .order-list-bracket > li {position: relative; color: var(--main); letter-spacing: -0.03em; line-height: 1.75; padding-left: 1.5rem}
.terms-section .terms-container .order-list-bracket > li::before {content: '('counter(bracket)')'; position: absolute; left: 0; counter-increment: bracket}


/* *********************************************
 * 메종드컨셉 추가
 ******************************************** */
.tabs {list-style-type: none; margin-bottom: 64px; text-align: center;}
.tabs li { display: inline-flex; font-size: 16px; font-weight: 500; color: var(--gray-200); height: 48px; padding: 0 20px; border: 1px solid var(--gray-100); border-radius: 24px; background-color: transparent; align-items: center; justify-content: center; outline: 0; transition: color .3s, border-color .3s, background-color .3s; margin-left: 12px; cursor: pointer;}
.tabs li:first-child{margin-left: 0;}
.tabs li.active { font-weight: 700; color: var(--white-100); border-color: var(--main); background-color: var(--main);}
.tab-content {display: none;}
.tab-content.active {display: block;}

.business-overview .row-overview {margin-bottom: 64px;}
.about-designer { display: flex; align-items: stretch; background: var(--white-200); flex-direction: row-reverse; justify-content: space-between; margin: 64px 0;}
.about-designer-img img {width: 100%; height: 100%; object-fit: cover; display: block; padding-left: 12px;}
.about-designer-txt {flex: 2; padding: 60px; display: flex; flex-direction: column; justify-content: center;}
.about-designer-txt h3 span{font-size: 17px; font-weight: 500; color: var(--gray-300); padding-left: 5px;}
.about-designer-txt p:nth-of-type(1){opacity: 0.2; font-weight: 700;}
.about-designer-txt p:nth-of-type(2){margin-top: 20px;}
.section .about-designer .section-sub-heading {text-align: left; margin-bottom: 0;} 

.lucciguide_img {text-align: center;}
.lucciguide_img > img {max-width: 1100px; width: 100%;}
.lucciguide_img .pc {display:inline;}
.lucciguide_img .mo {display: none;}
.lucciguide {font-size: 18px; text-align: center;}
.lucciguide .lucciguide_txt {margin-top: 64px;}
.lucciguide .lucciguide_txt h3 {text-align: left; font-size: 22px; font-weight: 700; color: var(--main); line-height: 1.1;}
.lucciguide .lucciguide_txt p {text-align: left; padding-top: 4px; padding-bottom: 12px; color: var(--gray-400);}
.table-bordered>tbody>tr>td, .table-bordered>tbody>tr>th, .table-bordered>tfoot>tr>td, .table-bordered>tfoot>tr>th, .table-bordered>thead>tr>td, .table-bordered>thead>tr>th {vertical-align: middle;}
span.blue {font-size: 16px; color: var(--primary);}
.instagram-widget{margin-top: 40px;}
.lucciguide_subtxt {margin-top: 40px; font-size: 17px; color: var(--gray-400);}
.Installguide {margin-top: 64px;}
.Installguide .Installguide-item {font-size: 18px;}
.Installguide .Installguide-item .row {border-bottom: 1px solid var(--gray-100); padding: 40px 0;}
.Installguide .Installguide-item .row:first-child { border-top: 1px solid var(--gray-100);}
.Installguide .Installguide-item .col-num h4 {font-size: 32px; font-weight: 700; color: var(--main); letter-spacing: -0.03em; padding-left: 30px; position: relative;}
.Installguide .Installguide-item .col-num h4 span {position: absolute; left: 0;}
.Installguide .Installguide-item .col-Installinfo {}
.Installguide .Installguide-item .col-Installinfo li {}
.Installguide .Installguide-item .col-Installinfo li .sm_txt { font-size: 15px; font-weight: 400; color: var(--gray-300);}
.Installguide .Installguide-item .col-Installinfo li b {font-size: 20px; padding-bottom: 4px; display: block;}
.Installguide .Installguide-item .col-Installinfo li b.mt {margin-top: 20px;}
.Installguide .Installguide-item .col-Installinfo li p{position: relative; padding-left: 16px;}
.Installguide .Installguide-item .col-Installinfo li p::before {content: "• "; color: var(--primary); position: absolute; left: 0;}
.Install_endtxt {margin-top: 40px; text-align: center;}
.pairinguide {max-width: 1100px; margin: 0 auto;}
.pairinguide .col-field {margin-bottom: 2rem;}
.pairinguide .col-field:nth-child(n+3) {margin-bottom: 0;}
.serviceguide {}
.serviceguide .row {row-gap: 1.5rem; }
.serviceguide .col-service {display: flex; width: 50%;}
.serviceguide .col-service .service-box {
  flex: 1;
  height: auto;
  display: flex;
  flex-direction: column; 
}
.serviceguide .col-service .service-box {position: relative; padding: 40px; height: 100%; background-color: #f3f5fb;}
.serviceguide .col-service .service-box::before {content:''; position:absolute; display:block; top:11px; right:-3px; width:30px; height:1px; background-color: #6693fb; opacity:0.5; transform:rotate(-45deg)}
.serviceguide .col-service .service-box .heading {}
.serviceguide .col-service .service-box .heading h4 {font-size: 22px; font-weight: 700; color: var(--main); letter-spacing: -0.02em;}
.serviceguide .col-service .service-box p {font-size: 17px; color: var(--gray-400); letter-spacing: -0.02em; line-height: 1.8}
.service-info {background-color: var(--white-200); padding: 50px; margin-top: 60px; border-radius: 20px;}
.service-info h3 {text-align: center; font-size: 30px; font-weight: 700; color: var(--main); letter-spacing: -0.02em; line-height: 1.32;}
.service-info > p {text-align: center;  font-size: 18px; font-weight: 500; color: var(--gray-400); letter-spacing: -0.02em; margin: 24px 0;}
.service-table {border-bottom: 1px solid #d1d1d1; padding: 24px 0; font-size: 18px; color: var(--gray-400);}
.service-table:last-of-type{border-bottom: none;}
.service-table h4 {font-size: 20px;  font-weight: 700;  letter-spacing: -0.02em; margin-bottom: 4px;}
.service-table .col-content p {position: relative; padding-left: 16px;}
.service-table .col-content p::before {content: "• "; color: var(--primary); position: absolute; left: 0;}
.service-info-box {background: #fff; padding: 60px 80px; border-radius: 14px;}
.service-info-box .service-table {border-bottom: none; padding: 0;}
.service-info-box .service-table h4{text-align: center; margin-bottom: 40px;}
.service-info-box .service-table span.blue{margin-top: 40px; display: block;}
.serviceguide .history-item ul:nth-of-type(n+2) {margin-top: 40px;}
.serviceguide .history .history-item .col-content > ul > li > b {color: var(--gray-400);}
.serviceguide .history .history-item .col-content ul li p {position: relative; padding-left: 16px; display: block;}
.serviceguide .history .history-item .col-content ul li p::before {content: "• "; color: var(--primary); position: absolute; left: 0;}
.costguide .row{align-items: center;}
.accordion .card-body p strong{color: var(--gray-400); display: block; opacity: 0.85;}
.affiliated{margin-top: 60px;}
.affiliated ul{display: grid; grid-template-columns: repeat(5, 1fr); gap: 50px 0; justify-items: center; padding: 40px; margin-top: 20px; background: var(--white-200); border-radius: 20px;}
.affiliated ul li{opacity: 0.65; max-width: 240px;}
.affiliated ul li:hover{opacity: 1;}
.affiliated ul li img{}
.affiliated h3 i{font-size: 24px;}
.luccibtn{
  background-color: var(--primary);
  color: #fff;
  padding: 2px 8px;
  display: inline-block;
  margin-bottom: 4px;
  font-size: 15px;
  margin-left: 4px;
}
.lucci_caption{
  color: var(--gray-200);
  font-size: 14px;
  margin-top: 8px;
}

/* 루씨에어맵 */
:root{
  --accent:#0d6efd;
  --hover-fill:rgba(30,120,255,0.12);
  --hover-stroke:rgba(30,120,255,0.9);
}
.lucciairmap{
    display:flex;
    flex-direction: row;
    gap:50px;
    align-items: center;
}
.map-wrap{
    flex:0 0 clamp(320px, 25vw, 450px);
    width:clamp(320px, 25vw, 450px);
    min-width:0;
    box-sizing:border-box;
}
.map-card{width:100%;}
.lucciairmap .map-card { position: relative;}
.lucciairmap .map-card .map-markers{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.lucciairmap .map-card .map-markers .marker{
  position:absolute;
  left:0; top:0;
  transform:translate(-50%,-100%);
  color:var(--primary);
  font-size:18px;
  line-height:1;
}

.lucciairmap .map-card svg{
  width:100% !important;
  height:auto !important;
  max-width:100%;
  display:block;
}
.lucciairmap .map-card svg #map [id]{
  cursor:pointer;
  outline:none;
  stroke:#9ebadb;
  stroke-width:2;
  transition:fill .12s ease, stroke .12s ease, stroke-width .12s ease;
}
.lucciairmap .map-card svg #map [id]:hover,
.lucciairmap .map-card svg #map [id]:focus-visible{
  fill:var(--hover-fill);
  stroke:var(--hover-stroke);
  stroke-width:2;
  stroke-linejoin:round;
  stroke-linecap:round;
  paint-order:stroke fill;
  vector-effect:non-scaling-stroke;
}

.lucciairmap .map-card svg #map-outline{
  pointer-events:none;
}
.map-caption{
  margin-top:10px;
  font-size:17px;
  color: var(--main);
  display:flex;
  align-items:center;
  gap:6px;
}
.map-caption i{opacity:.85;}

.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);align-items:center;justify-content:center;z-index:9999;}
.modal.open{display:flex;}
.modal-box{background:#fff;padding:20px;border-radius:10px;width:92%;max-width:540px;box-shadow:0 12px 40px rgba(2,6,23,0.2);position:relative;}
.modal-box h2{margin:0 0 8px;font-size:18px;}
.close-btn{position:absolute;right:12px;top:12px;background:#eee;border:0;padding:6px 10px;border-radius:6px;cursor:pointer;}
ul.providers{margin:8px 0 0;padding-left:18px;}
.tooltip{position:fixed;padding:6px 10px;background:#111;color:#fff;border-radius:6px;font-size:13px;pointer-events:none;transform:translate(-50%,-120%);display:none;z-index:10000;white-space:nowrap}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}



  
/* *********************************************
 * Media queries
 *************1******************************* */
@media (min-width: 768px) {
    .business-strength .row-strength .col-info.text-md-end .heading .num {left: auto; right: 0}
}

@media (max-width: 991px) {
    .hero .caption h2 {font-size: 32px}

    .breadcrumb-navbar .navbar-wrapper > li > a {font-size: 16px}
    .section {padding-top: 0px; padding-bottom: 100px}
    .section .section-main-heading h2 {font-size: 36px}
    .section .section-sub-heading .en-heading {font-size: 18px}
    .section .section-sub-heading h3 {font-size: 26px}

    .about-overview .row-overview .col-content {margin-top: 48px}
    .about-overview .row-overview .col-content .en-heading {font-size: 18px}
    .about-overview .row-overview .col-content h3 {font-size: 24px; line-height: 1.32}
    .about-overview .row-overview .col-content .company-info {margin-top: 36px}
    .about-overview .row-overview .col-content .company-info li dl dt, .about-overview .row-overview .col-content .company-info li dl dd {font-size: 16px}
    .about-core-value .section-sub-heading::after {bottom: 10px; font-size: 72px}
    .about-core-value .row-core .col-core-item figure figcaption .col-content h4 {font-size: 18px}

    .greeting-type-01 .col-text {margin-top: 48px}
    .greeting-type-01 .col-text h3 {font-size: 26px}

    .history .history-cover h3 {font-size: 32px}
    .history .history-cover p {font-size: 18px}
    .history .history-item {padding: 40px 28px}
    .history .history-item .col-year h4 {font-size: 28px}

    .location .location-info {padding-left: 32px; padding-right: 32px}

    .business-overview .overview-heading {font-size: 28px; margin-bottom: 48px}
    .business-overview .overview-cover {margin-bottom: 60px}
    .business-overview .row-overview .col-item .item-inner {padding: 28px}
    .business-overview .row-overview .col-item .item-inner .item-header h3 {font-size: 19px}
    .business-overview .row-overview .col-item .item-inner .item-header .icon {width: 80px; height: 80px; font-size: 36px}
    .business-strength .row-strength .col-info .heading .num {font-size: 78px}

    .business-field .row-field .col-field .field-card .content {padding: 44px 28px 28px}
    .business-field .row-field .col-field .field-card .content .heading h4 {font-size: 20px}
    .business-field .row-field .col-field .field-card .content .heading .num {font-size: 72px}
    .business-detail .row-detail .col-text .text-inner {padding-left: 40px}
    .business-detail .row-detail .col-text .text-inner h4 {font-size: 20px}
    .business-detail .row-detail .col-text .text-inner p {font-size: 16px}
    .business-detail .row-detail .col-text .text-inner .button-more-arrow {margin-top: 36px}

    .product-list-page .masonry-group .grid-sizer, .product-list-page .masonry-group .gallery-item {width: calc(33.333334% - 20px)}
    .product-list-page .gallery-item h5 {font-size: 18px}
    .product-list-page .video-item figure {margin-bottom: 20px}
    .product-list-page .video-item .info h4 {font-size: 18px}

    .accordion>.card>.card-header {padding: 24px}
    .accordion .card-header .btn-link {font-size: 19px}
    .accordion .card-body {padding: 0 24px 24px}

    .sub-bottom-banner {height: 240px;}
    .sub-bottom-banner span {font-size: 26px;padding-top: 45px;}
    .Installguide .Installguide-item .col-num h4{font-size: 28px; line-height: 1.2;}
    .service-info h3 {font-size: 26px;}
    .map-wrap {flex: 0 0 clamp(320px, 35vw, 450px); width: clamp(320px, 35vw, 450px);}
    .serviceguide .col-service .service-box {padding: 30px;}
    .affiliated ul{grid-template-columns: repeat(4, 1fr);}
    .affiliated h3 i{font-size: 20px;}
    .luccibtn {font-size: 14px;}
}

@media (max-width: 860px) {
    .history .history-item .col-content > ul > li > p > br{display: none;}
}

@media (max-width: 767px) {
    .hero {height: 350px}
    .hero .caption {padding-top: 90px;}
    .hero .caption h2 {font-size: 30px}

    .breadcrumb-navbar .container-xl {padding-left: 0; padding-right: 0}
    .breadcrumb-navbar {border-bottom: 1px solid #e9e9e9; background-color: var(--white-100); transform: translateY(0)}
    .breadcrumb-navbar .navbar-wrapper {display: none}
    .breadcrumb-navbar .dropdown-wrapper {height: 100%}
    .breadcrumb-navbar .dropdown {height: 100%}
    .breadcrumb-navbar .dropdown .button-dropdown {position: relative; display: flex; font-size: 16px; color: var(--main); letter-spacing: -0.02em; width: 100%; height: 100%; margin-left: -1px; padding: 0 24px; border-left: 1px solid #e9e9e9; align-items: center}
    .breadcrumb-navbar .dropdown .button-dropdown::after {content: '\F282'; position: absolute; top: 50%; right: 24px; font-family: 'bootstrap-icons'; font-size: 13px; margin-top: -9px; transition: transform .3s}
    .breadcrumb-navbar .dropdown .button-dropdown[aria-expanded='true']::after {transform: rotate(180deg)}
    .breadcrumb-navbar .dropdown:nth-child(3) .button-dropdown {color: var(--white-100); background-color: var(--primary)}
    .breadcrumb-navbar .dropdown:nth-child(3) .button-dropdown::after {color: var(--white-100)}
    .breadcrumb-navbar .dropdown .dropdown-menu {right: 0; margin: 0; padding: 0; border: none; border-radius: 0; box-shadow: 2px 4px 16px rgba(0,0,0,.19);width:100%}
    .breadcrumb-navbar .dropdown .dropdown-menu.show {transform: translate3d(0,59px,0) !important}
    .breadcrumb-navbar .dropdown .dropdown-item {font-size: 15px; color: var(--main); letter-spacing: -0.02em; padding: 16px 24px; transition: color .25s, background-color .25s}
    .breadcrumb-navbar .dropdown .dropdown-item + .dropdown-item {border-top: 1px solid #eaeaea}
    .breadcrumb-navbar .dropdown .dropdown-item:focus, .breadcrumb-navbar .dropdown .dropdown-item:hover, .breadcrumb-navbar .dropdown .dropdown-item.active, .breadcrumb-navbar .dropdown .dropdown-item:active {color: var(--white-100); background-color: var(--primary)}

    .section {padding-top: 40px; padding-bottom: 80px}
    .section .section-main-heading {margin-bottom: 40px}
    .section .section-main-heading h2 {font-size: 32px}
    .section .section-main-heading p {font-size: 16px}
    .section .section-sub-heading {margin-bottom: 48px}
    .section .section-sub-heading .en-heading {font-size: 16px; margin-bottom: 16px}
    .section .section-sub-heading h3 {font-size: 22px}
    .section .section-sub-heading p {font-size: 15px; padding: 0 10px;}
    .section .section-sub-heading p br{display: none;}
    .about-overview .row-overview .col-content {margin-top: 32px}
    .about-overview .row-overview .col-content .en-heading {font-size: 16px; margin-bottom: 16px}
    .about-overview .row-overview .col-content h3 {font-size: 21px}
    .about-overview .row-overview .col-content p {font-size: 15px}
    .about-overview .row-overview .col-content .company-info {margin-top: 28px}
    .about-overview .row-overview .col-content .company-info li dl dt {width: 80px}
    .about-overview .row-overview .col-content .company-info li {padding: 12px 16px}
    .about-overview .row-overview .col-content .company-info li dl dt, .about-overview .row-overview .col-content .company-info li dl dd {font-size: 14px}
    .about-overview .row-overview .col-content .company-info li dl dd {width: calc(100% - 80px)}

    .about-core-value .section-sub-heading::after {bottom: 0; font-size: 8vw; line-height: 0.9}
    .about-core-value .row-core .col-core-item + .col-core-item {margin-top: 28px}
    .about-core-value .row-core .col-core-item figure figcaption {margin-top: -32px; margin-right: 64px; padding: 24px 20px}
    .about-core-value .row-core .col-core-item figure figcaption .col-title {margin-bottom: 8px}
    .about-core-value .row-core .col-core-item figure figcaption .col-title h5 {font-size: 12px}
    .about-core-value .row-core .col-core-item figure figcaption .col-content h4 {font-size: 16px}
    .about-core-value .row-core .col-core-item figure figcaption .col-content p {font-size: 14px}

    .greeting-type-01 .col-text {margin-top: 32px}
    .greeting-type-01 .col-text h3 {font-size: 22px}
    .greeting-type-01 .col-text p .ceo-name {font-size: 22px}
    .greeting-type-02 .cover-img {margin-bottom: 32px}
    .greeting-type-02 .col-text p .ceo-name {font-size: 22px}

    .history .history-cover {padding: 100px 0}
    .history .history-cover h3 {font-size: 26px; margin-bottom: 16px}
    .history .history-cover p {font-size: 16px}
    .history .history-item {padding: 32px 24px}
    .history .history-item .col-year h4 {font-size: 22px}
    .history .history-item .col-content > ul > li > b, .history .history-item .col-content > ul > li > p {font-size: 17px}

    .location .map-container {margin-bottom: 32px}
    .location .location-info {padding-left: 16px; padding-right: 16px}
    .location .location-info .col-info + .col-info {margin-top: 28px}
    .location .location-info .info-heading {font-size: 14px}

    .business-overview .overview-heading {font-size: 22px; margin-bottom: 36px}
    .business-overview .overview-cover {height: 300px; margin-bottom: 48px}
    .business-overview .overview-cover .typo-box {padding: 28px}
    .business-overview .overview-cover .typo-box p {font-size: 16px}
    .business-overview .row-overview .col-item + .col-item {margin-top: 24px}
    .business-overview .row-overview .col-item .item-inner {padding: 24px; position: relative;}
    .business-overview .row-overview .col-item .item-inner .item-header{display: flex;}
    .business-overview .row-overview .col-item .item-inner .item-header h3 {font-size: 17px}
    .business-overview .row-overview .col-item .item-inner .item-header .icon {width: 80px; height: 80px; font-size: 32px; position: absolute; top: 50%; right: 20px; transform: translate(0, -50%);}
    .business-overview .row-overview .col-item .item-inner p {font-size: 15px; text-align: left; padding-right: 90px;}
    .business-strength .row-strength .col-info {margin-top: 60px}
    .business-strength .row-strength .col-info .heading {margin-bottom: 16px}
    .business-strength .row-strength .col-info .heading h4 {font-size: 19px}
    .business-strength .row-strength .col-info .heading .num {font-size: 64px}
    .business-strength .row-strength + .row-strength {margin-top: 48px}

    .business-field .row-field .col-field .field-card .content {padding: 36px 24px 24px}
    .business-field .row-field .col-field .field-card .content .heading {margin-bottom: 12px}
    .business-field .row-field .col-field .field-card .content .heading h4 {font-size: 18px}
    .business-field .row-field .col-field .field-card .content .heading .num {font-size: 56px}
    .business-field .row-field .col-field .field-card .content p {font-size: 15px}

    .business-detail .row-detail .col-text .text-inner {padding-top: 28px; padding-left: 24px; padding-right: 24px; padding-bottom: 28px}
    .business-detail .row-detail .col-text .text-inner h4 {font-size: 18px}
    .business-detail .row-detail .col-text .text-inner p {font-size: 15px}
    .business-detail .row-detail .col-text .text-inner .button-more-arrow {margin-top: 28px}

    .product-list-page .masonry-group .grid-sizer, .product-list-page .masonry-group .gallery-item {width: calc(50% - 20px)}
    .product-list-page .product-type-heading {font-size: 17px}
    .product-list-page .gallery-item .gallery-card .card-content {padding: 24px}
    .product-list-page .gallery-item figure {margin-bottom: 10px}
    .product-list-page .gallery-item .category {font-size: 12px}
    .product-list-page .gallery-item h5 {font-size: 16px}
    .product-list-page .video-item {margin-bottom: 48px}
    .product-list-page .video-item figure {margin-bottom: 16px}
    .product-list-page .video-item figure .play-icon {width: 56px; height: 56px; font-size: 32px}
    .product-list-page .video-item .info h4 {font-size: 17px}
    .product-list-page .video-item .info p {margin-top: 6px}

    .accordion>.card>.card-header {padding: 20px 24px}
    .accordion .card-header .btn-link {font-size: 17px; padding-right: 48px}
    .accordion .card-header .btn-link::before {width: 16px}
    .accordion .card-header .btn-link::after {right: 8px; height: 16px}
    .accordion .card-body p {font-size: 14px}

    .inquiry-form .table-form > tbody {margin-left: -12px; margin-right: -12px}
    .inquiry-form .table-form > tbody > tr {padding-left: 12px; padding-right: 12px}
    .inquiry-form .table-form .formmail_title_bgcolor {font-size: 14px}
    .inquiry-form .table-form input[type='text'], .inquiry-form .table-form input[type='password'], .inquiry-form .table-form select, .inquiry-form .table-form textarea {font-size: 14px}
    .inquiry-form .submit-button .button-submit {height: 60px; font-size: 18px}

    .tabs {margin-bottom: 58px;}
    .tabs li{font-size: 14px; height: 42px; padding: 0 16px; margin-left: 8px;}
    span.blue{font-size: 15px;}
    .section .about-designer .section-sub-heading h3 {padding: 0 10px;}
    .about-designer-txt {padding: 24px 14px;}
    .lucciguide{font-size: 16px;}
    .lucciguide_subtxt{font-size: 15px;}
    .lucciguide_img .pc{display: none;}
    .lucciguide_img .mo{display: inline;}
    .Installguide .Installguide-item .col-num h4{font-size: 22px;}
    .Installguide .Installguide-item{font-size: 17px;}
    .Installguide .Installguide-item .col-Installinfo li b{font-size: 18px;}
    .pairinguide .col-field{margin-bottom: 1rem;}
    .business-detail .no-gutters .col-img{padding: 0;}
    .affiliated ul{grid-template-columns: repeat(3, 1fr); gap: 40px 0;}
    .affiliated ul li{font-size: 15px;}
    .affiliated h3 i{font-size: 18px;}
    .luccibtn {font-size: 13px; padding: 0px 6px;}
  
    .lucciairmap {flex-direction: column;}

}

@media (max-width: 575px) {
    .history .history-item {padding: 24px 0}
    .history .history-item .col-year {margin-bottom: 20px}
    .history .history-item .col-content > ul > li > b, .history .history-item .col-content > ul > li > p {font-size: 16px}

    .business-field .row-field .col-field + .col-field {margin-top: 28px}

    .product-list-page .masonry-group .grid-sizer, .product-list-page .masonry-group .gallery-item {width: 100%}
    .product-list-page .gallery-item {margin-bottom: 32px}
    .product-list-page .video-item {margin-bottom: 32px}

    .inquiry-form .table-form > tbody > tr {flex: 0 0 100%; max-width: 100%; margin-bottom: 24px}
    .inquiry-form .submit-button {padding-top: 24px}

    .sub-bottom-banner {height: 220px;}
    .sub-bottom-banner span {font-size: 20px;}

    /* 메종드컨셉추가 */
    .section {padding-bottom: 40px;}
    .business-overview .row-overview .col-item .item-inner .item-header {flex-direction: column;}
    .business-overview .row-overview .col-item .item-inner .item-header .icon {position: static;  transform: none;}
    .business-overview .row-overview .col-item .item-inner p {text-align: center; padding-right: 0;}
    .business-overview .overview-cover .typo-box p br{display: none;}
    .history .history-item .col-img{margin-top: 20px;} 
    .about-designer{flex-direction: column;}
    .about-designer-img img {padding-left: 0; max-height: 300px; object-position: top center;}
    .lucciguide{font-size: 15px;}
    .lucciguide .table-bordered{font-size: 14px;}
    .lucciguide_subtxt{font-size: 13px;}
    .table>:not(caption)>*>* {padding: 0;}
    .lucciguide .lucciguide_txt {margin-top: 40px;}
    .lucciguide_subtxt{margin-top: 20px;}
    .Installguide{margin-top: 40px;}
    .Installguide .Installguide-item .row{padding: 30px 0;}
    .Installguide .Installguide-item{font-size: 16px;}
    .Installguide .Installguide-item .col-num h4{padding-left: 20px; margin-bottom: 10px;}
    .Install_endtxt{margin-top: 20px;}
    .pairinguide .col-field{margin-bottom: 0;}
    .serviceguide .col-service .service-box {padding: 30px;}
    .serviceguide .col-service .service-box p {font-size: 15px;}
    .serviceguide .col-service .service-box .heading h4{font-size: 19px;}
    .service-info h3 {font-size: 22px;}
    .service-info > p {font-size: 15px;}
    .service-table {font-size: 15px; padding: 12px 0;}
    .service-table h4 {font-size: 18px;}
    .service-info {padding: 30px; margin-top: 30px;}
    .service-info-box {padding: 20px 20px;}
    .service-info-box .service-table h4 {margin-bottom: 20px;}
    .service-info-box .service-table span.blue{margin-top: 20px;}
    .serviceguide .history .history-item .col-img{margin-top: 0px;}
    .affiliated ul{grid-template-columns: repeat(2, 1fr); gap: 20px 0;}
    .map-wrap {flex: 0 0 clamp(250px, 35vw, 450px); width: clamp(250px, 35vw, 450px);}
}

@media (max-width: 480px) {
    .serviceguide .col-service {width: 100%;}
}