@font-face {
    font-family: 'playball';
    /* 내가 지어준 폰트 이름 */
    src: url('/fonts/Playball.ttf') format('woff'),
        /* 최신 브라우저용 */
        url('/fonts/Playball.ttf') format('woff');
    /* 구형 브라우저 호환용 */
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "trajan-pro-3", serif;
    font-weight: 600;
    font-style: normal;
}



.font_playball {
    font-family: 'playball';
}

.font_trajan {
    font-family: 'trajan-pro-3';
}

.noto-sans-kr {
    font-family: 'Noto Sans KR', sans-serif;
}

.open-sans {
    font-family: 'Open Sans', sans-serif;
}

.text-red {
    font-size: 2.4rem;
}


/* 기본 Reset */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* 텍스트 가독성 */
body,
input,
textarea,
select,
button {
    /*font-family: Arial, Helvetica, sans-serif;*/
    font-family: 'Noto Sans KR', sans-serif;
    line-height: 1.6;
    /* color: #1c1c1c; */
    background-color: #fff;
}

/* 링크 스타일 */
a {
    text-decoration: none;
    color: inherit;
}

/* 리스트 스타일 제거 */
ul,
ol {
    list-style: none;
}

header {
    margin-bottom: 2rem;
}

section {
    margin-bottom: 8rem;
}

.container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 10px;

}


.gnb {
    position: fixed;
    display: flex;
    top: 0;
    left: 0;
    width: 100%;
    height: 5rem;
    border: 1px solid #ebebeb;
    z-index: 999;
    background: rgba(247, 247, 247, 0.93);
    padding: 0rem 16rem;
}

.nav-close {
    display: none;
}

.nav-open-btn {
    display: none;
}

.logo-wrap {
    width: 16rem;
    height: auto;
    font-size: 24px;
    font-weight: bold;
    color: #333;
    display: flex;
    align-items: center;
    background: url("./img/LOGO.png") no-repeat center;
    background-size: cover;
    position: relative;
    cursor: pointer;
}

.gnb-menu-wrap {
    display: flex;
    gap: 30px;
    align-items: center;
    height: 100%;
    margin-left: auto;
}

.red {
    background-color: #9c1515;
}

.text-red {
    font-size: 2.4rem;
}

.btns {
    padding: 10px 20px;
    /* border-radius: 5px; */
    color: white;
    cursor: pointer;
}

.hero-section-slide-wrap {
    width: 100vw;
    height: 40rem;
    background-color: antiquewhite;
}

.ceo-section {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.text-wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1rem;
}

.swiper-slide {
    display: flex;
    font-size: 2rem;
    height: 100vh;
    color: #333;
}

.img-wrap {
    height: 513px;
    background-size: contain;
    background: url("./img/CEO_INTRO.png") no-repeat center;
    background-size: contain;
}

.slide-1 {
    background: url('./img/메인_픽스1.jpg') no-repeat center;
    background-size: cover;
}

.slide-2 {
    background: url('./img/메인_픽스2..png') no-repeat center;
    background-size: cover;
}

.slide-3 {
    background: url('./img/메인_픽스3.png') no-repeat center;
    background-size: cover;
}

.slide-4 {
    background: url('./img/메인_픽스4.png') no-repeat center;
    background-size: cover;
}

/*.insta-section h2 {*/
/*    color: #9c1515;*/
/*    font-size: 24px;*/
/*    margin-bottom: 30px;*/
/*}*/

.insta-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.1rem;
}

.insta-grid div {
    width: 100%;
    padding-top: 100%;
    /* 1:1 Aspect Ratio */
    background-color: #f0f0f0;
}

.insta-grid-1-pic {
    background: url("./img/인스타 1.png");
    background-size: cover;
}

.insta-grid-2-pic {
    background: url("./img/인스타2.png");
    background-size: cover;
}

.insta-grid-3-pic {
    background: url("./img/인스타 3.png");
    background-size: cover;
}

.text-wrap-v2 {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 1rem;
}

.number-round {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 25px;
    height: 25px;
    border-radius: 100%;
    background-color: #9c1515;
    color: white;
}

.text-wrap-v2 .title {
    display: flex;
    margin-left: 5px;
    align-items: center;
    font-weight: bolder;
}

.text-wrap-v2 .text-area {
    margin-left: 1.9rem;
    letter-spacing: -0.7px;
}

.grid-box {
    width: 100%;
    padding-top: 100%;
    background-color: #f0f0f0;
}

.grid-bg-box {
    display: flex;
    width: 100%;
    height: 352px;
    /* background-size: contain; */
}

.grid-text-box {
    display: flex;
    flex-direction: column;
    /* height: 150px; */
    gap: 2px;
    font-size: 1.2rem;
    margin-top: 1rem;
}

.grid-text-title {
    font-size: 32px;
    margin-bottom: 6px;
}

.grid-text-regular {}

.grid-text-strong {
    font-weight: bolder;
}

.bespoke-beyond-wrap {
    display: grid;
    min-height: 300px;
    gap: 1rem;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    grid-template-rows: 1fr;
    cursor: pointer;
}

.fabric-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.fabric-detail {
    display: flex;
    flex-direction: column;
}

.margin-bottom-20 {
    margin-bottom: 20px;
}

.dress-rental-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr;
    background-color: #f7f7f7;
    justify-content: center;
}

.grid-left {
    display: flex;
    flex-direction: column;
    justify-content: center;
    float: left;
    background-size: contain;
    background-position: center;
    align-items: flex-start;
    padding: 4.2rem 3.5rem 1rem 2rem;
    /*letter-spacing: 1rem;*/
}

.pl-2 {
    padding-left: 7rem;
}

.grid-right {
    display: flex;
    align-content: center;
    justify-content: center;
    height: 697.2px;
    flex-direction: column;
    gap: 1rem;
    padding: 3rem;
    font-size: 1.2rem;
}


.atelier-img {
    background: url("./img/아뜰리에.png");
    background-repeat: no-repeat;
    background-size: cover;
}

.bespoke-img {
    background: url("./img/rectangle_78_a1ffef.png");
    background-repeat: no-repeat;
    background-size: cover;
}

.resizing-img {
    background: url("./img/비스포크.png");
    background-repeat: no-repeat;
    background-size: cover;
}

.bespoke-beyond_1-img {
    background: url("./img/BESPOKE_BEYOND_1.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    height: 449px;
}

.bespoke-beyond_2-img {
    background: url("./img/BESPOKE_BEYOND_2.png");
    background-repeat: no-repeat;
    background-size: cover;
    height: 449px;
}

.bespoke-beyond_3-img {
    background: url("./img/BESPOKE_BEYOND_3.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    height: 449px;
}

.bespoke-beyond_4-img {
    background: url("./img/BESPOKE_BEYOND_4.png");
    background-repeat: no-repeat;
    background-size: cover;
    height: 449px;
}


.british-img {
    background-size: cover;
    background: url("./img/fabric_영국2.png");
    background-repeat: no-repeat;
    background-size: contain;
}

.italian-img {
    background-size: cover;
    background: url("./img/fabric_이태리.png");
    background-repeat: no-repeat;
    background-size: contain;
}

.dress-rental-img {
    background-size: cover;
    background: url("./img/image 28.png");
    background-repeat: no-repeat;
    background-size: 30rem;
    background-position: center;
    background-position-x: 1rem;
}


.map_link_icon::after {
    width: 0;
    height: 0;
    border-left: 4rem solid rgba(0, 0, 0, 0);
    border-right: 4rem solid rgba(0, 0, 0, 0);
    border-top: 8rem solid;
    left: 17rem;
    top: calc(100% - 1rem);
    z-index: 1;
}

.lh-1 {
    line-height: 1rem;
}

.lh-1_2 {
    line-height: 1.2rem;
}

.lh-1_4 {
    line-height: 2.5rem;
}


.lh-2 {
    line-height: 2rem;
}

.in_one_place_section_wrap {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.fts_1_2 {
    font-size: 1.2rem;
}

.hero-section {
    width: 100%;
    height: 100vh;
    z-index: 10;
    margin-top: 5rem;
}

.text-center {
    text-align: center !important;
}

.bottom-grid {
    display: grid;
    margin-top: 40px;
    grid-template-columns: repeat(auto-fit, minmax(200px, 3fr));
    gap: 1rem;
    /*height: 150px;*/
}

.bottom-grid>div {
    background-color: #f0f0f0;
    height: 198px;
    border-radius: 10px;
    border: 2px solid #ececec;
}

footer {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0 3rem;
    border-top: 1px solid #ececec;
    height: 250px;
    gap: 0.6rem;
    padding: 0 15.7rem;
}

.pointer {
    cursor: pointer
}

.footer-title {
    font-size: 1.4rem;
    font-weight: bolder;
}

#italian-fabric-wrap,
#british-fabric-wrap {
    cursor: pointer;
    gap: 4px;
    font-size: 1.2rem;
}

#italian-fabric-wrap-modal {
    display: none;
    position: fixed;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.8);
}

#british-fabric-wrap-modal {
    display: none;
    position: fixed;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.8);
}

.underline-50-gradient {
    background-image: linear-gradient(currentColor, currentColor);
    background-size: 10% 5px;
    background-repeat: no-repeat;
    padding-bottom: 2px;
    background-position: 0 1.6em;
}

.bespoke-beyond_1 {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.bespoke-beyond_2 {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.bespoke-beyond_3 {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.bespoke-beyond_4 {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.in_one_place_container {
    display: flex;
    flex: 1;
    flex-wrap: wrap;
    margin-bottom: 5rem;
}

.in_one_place_text_wrap {
    width: 50%;
    margin-top: 50px;
    margin-bottom: 50px;
    padding-left: 8rem;
}

.greeting-wrap {
    gap: 1rem;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 2fr));
    grid-template-rows: 1fr;
    justify-items: center;
    align-items: center;
}


#map {
    width: 100%;
    height: 600px;
    /* 지도 높이만 변경하면 됨 */
    /* border-radius: 16px; */
    /* 둥근 모서리 */
    overflow: hidden;
    /* 둥근 모서리 안에서 잘리게 */
}


.modal-wrap {
    display: none;
    left: 0;
    top: 0;
    position: fixed;
    width: 100vw;
    height: 100vh;
    background: #333333;
    /* margin-top: 5rem; */
    z-index: 9999;
    overflow: hidden;
    padding: 6rem;
}

.modal-open {}

.modal-close {
    position: absolute;
    width: 50px;
    height: 50px;
    display: block;
    color: white;
    right: 2%;
    top: 0%;
    z-index: 99999;
    font-size: 4rem;
    cursor: pointer;
}


swiper-container {
    width: 100%;
    height: 100%;
}

swiper-slide {
    text-align: center;
    font-size: 18px;
    background: #444;
    display: flex;
    justify-content: center;
    align-items: center;
}

swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fabric-contents-wrap {
    font-family: "trajan-pro-3", serif;
    font-weight: bolder;
    display: grid;
    background: #ebebeb;
    width: 100%;
    height: 100%;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 8rem 1fr;
    padding: 1rem;
    gap: 1rem;
}

.fabric-contents-wrap .fabric-menu {
    display: flex;
    gap: 1rem;
    align-items: center;
    /* padding-left: 1rem; */
    justify-content: flex-start;
    grid-area: fabric-menu;
}

.fabric-contents-wrap .fabric-menu span {
    display: flex;
    padding: 0.6rem 1rem;
    background: #9c1515;
    color: #ebebeb;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.fabric-ssfw {
    grid-area: fabric-ssfw;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 1rem;
    /* padding-left: 1rem; */
}

.fabric-ssfw span {
    display: flex;
    padding: 0.6rem 1rem;
    /* background: #9c1515; */
    color: #1c1c1c;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border: 1px solid #1c1c1c;
    min-width: 5rem;
}

.fabric-contents-wrap .menu {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-content: flex-start;
}

.cloth-pic {
    grid-row: span 2;
    max-width: 46vw;
}

.img-contain img {
    background: #ebebeb;
    object-fit: contain;
}

.british-fabric-inner-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.british-fabric-inner-grid>.inner-grid-1 {
    grid-row: span 2;
    background: url("./img/영국원단_스카발(세로).png") no-repeat center;
    background-size: cover;
}

.british-fabric-inner-grid>.inner-grid-2 {
    background: url("./img/영국원단_스카발(가로1).png") no-repeat center;
    background-size: cover;
}

.british-fabric-inner-grid>.inner-grid-3 {
    background: url("./img/영국원단_스카발(가로2).png") no-repeat center;
    background-size: cover;
}

.italian-fabric-inner-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.italian-fabric-inner-grid>.inner-grid-1 {
    grid-row: span 2;
    background: url("./img/이태리원단_로로피아나(세로).png") no-repeat center;
    background-size: cover;

}

.italian-fabric-inner-grid>.inner-grid-2 {
    background: url("./img/이태리원단_로로피아나(가로1).png") no-repeat center;
    background-size: cover;

}

.italian-fabric-inner-grid>.inner-grid-3 {
    background: url("./img/이태리원단_로로피아나(가로2).png") no-repeat center;
    background-size: cover;

}


@media (min-width: 1400px) {
    .text-wrap {
        padding-left: 12rem;
    }
}

/* 태블릿 (최대 너비 1024px) */
@media (max-width: 1024px) {
    body {
        font-size: 16px;
        background-color: #f5f5f5;
    }

    .container {
        padding: 0 1rem;
    }

    .in_one_place_text_wrap {
        display: flex;
        flex-direction: column;
        width: 100%;
        align-items: center;
    }

    .text-wrap-v2 {
        width: auto;
        /* text-align: center; */
        /* justify-content: center; */
        /* justify-items: center; */
        padding-left: 2rem;
    }

    .in_one_place_section_wrap {
        grid-template-columns: none;
        gap: 3rem;
    }

    .in_one_place_container {
        justify-content: center;
        /* text-align: center; */
    }

    .bespoke-beyond-wrap {
        grid-template-columns: none;
        grid-template-rows: none;
        justify-content: center;
    }

    .bespoke-beyond_1-img {
        width: calc(100vw - 12rem);
        height: 100vh;
        background: url("./img/BESOPOKE_M.png");
        background-repeat: no-repeat;
    }

    .bespoke-beyond_2-img {
        width: calc(100vw - 12rem);
        height: 100vh;
        background: url("./img/COAT_M.png");
    }

    .bespoke-beyond_3-img {
        width: calc(100vw - 12rem);
        height: 100vh;
        background: url("./img/SHOES_M.png");
    }

    .bespoke-beyond_4-img {
        width: calc(100vw - 12rem);
        height: 100vh;
        background: url("./img/JACKET_M.png");
    }

    .fabric-wrap {
        grid-template-columns: none;
    }

    .grid-bg-box {
        padding-top: 50%;
    }

    .dress-rental-wrap {
        grid-template-columns: none;
        grid-template-rows: none;
        padding-top: 1.5rem;
    }

    .pl-2 {
        padding-left: 0;
    }

    .grid-left {
        margin: 0 auto;
    }

    .bottom-grid {
        grid-template-columns: none;
    }

    .grid-wrap {
        grid-template-columns: none;
    }

    footer {
        padding: 0 2rem;
    }

    .gnb {
        position: fixed;
        display: flex;
        top: 0;
        left: 0;
        width: 100%;
        height: 5rem;
        border: 1px solid #ebebeb;
        z-index: 999;
        background: rgba(247, 247, 247, 0.93);
        padding: 0rem 1rem;
    }


}


/* 모바일 (최대 너비 768px) */
@media (max-width: 768px) {
    body {
        font-size: 14px;
        background-color: #eee;
    }

    .text-wrap {
        /* padding-left: 10%; */
    }

    .hero-section {
        width: 100%;
        height: 100vh;
    }

    .swiper-slide {
        height: calc(100vh - 80px);
    }

    .container {
        width: 100%;
    }

    .gnb {
        width: 100vw;
        padding: 0;
        justify-content: space-around;
    }

    .gnb-menu-wrap {
        display: flex;
        position: absolute;
        background: #eeeeeef5;
        width: 80vw;
        height: 100vh;
        color: #1c1c1c;
        align-items: center;
        flex-direction: column;
        padding-top: 5rem;
        right: -100vw;
        transition: 0.3s all;
    }

    .ceo-section {
        grid-template-columns: none;
        text-align: center;
    }

    .insta-grid {
        grid-template-columns: none;
    }

    .bespoke-beyond_1-img {
        width: 100%;
        height: 22rem;
        background-size: contain;
    }

    .bespoke-beyond_2-img {
        width: 100%;
        height: 22rem;
        background-size: contain;
    }

    .bespoke-beyond_3-img {
        width: 100%;
        height: 22rem;
        background-size: contain;
    }

    .bespoke-beyond_4-img {
        width: 100%;
        height: 22rem;
        background-size: contain;
    }

    .british-img,
    .italian-img {
        padding-top: 50%;
        flex: 1;
    }

    .dress-rental-img {
        background-size: cover;
        background-position-x: 0;
    }

    .grid-left {
        padding: 0;
    }

    .fts_1_2 {
        font-size: 0.95rem;
    }

    .margin-bottom-20 {
        text-align: center;
    }

    .grid-right {
        height: 21rem;
    }

    .in_one_place_text_wrap {
        padding-left: 0rem;
        margin-top: 0.3rem;
    }

    .grid-bg-box {

        background-position: center;

        width: 93vw;

        background-repeat: no-repeat;

    }

    .bespoke-beyond_1 {
        gap: 0
    }

    .bespoke-beyond_2 {
        gap: 0
    }

    .bespoke-beyond_3 {
        gap: 0
    }

    .bespoke-beyond_4 {
        gap: 0
    }

    .grid-left {
        align-items: center
    }

    .grid-right,
    .grid-text-regular,
    .grid-text-box {
        font-size: 0.9rem;
        padding: 0rem;
    }

    .grid-text-box {}

    .grid-text-regular {}

    .gnb-menu {
        display: flex;
        justify-content: center;
        align-items: center;
        border: 1px solid #ebebeb;
        width: 80%;
        height: 3rem;
    }

    section {
        margin-bottom: 4rem
    }

    .gnb-menu a {
        display: flex;
        width: 100%;
        height: 2rem;
        align-items: center;
        justify-content: center;
        border: 1px solid #1c1c1c17;
        padding: 1.3rem;
    }

    .btns a {
        border: none;
    }

    .nav-close {
        position: absolute;
        width: 50px;
        height: 50px;
        display: block;
        color: #1c1c1c;
        right: 6%;
        top: -1%;
        z-index: 99999;
        font-size: 4rem;
        cursor: pointer;
    }

    .nav-open-btn {
        display: flex;
        width: 50px;
        height: 100%;
        font-size: 2rem;
        align-items: center;
        justify-content: center;
        position: relative;
        right: 0;
    }

    .slide-1 {
        background: url("./img/mobile_main_01.jpg");
        background-size: cover;
        object-fit: cover;
        background-repeat: no-repeat;
    }

    .slide-2 {
        background: url("./img/mobile_main_02.jpg");
        background-size: cover;
        object-fit: cover;
    }

    .slide-3 {
        background: url("./img/mobile_main_03.png");
        background-size: cover;
        object-fit: cover;
    }

    .grid-text-title {
        /* text-align: center; */
    }

    .modal-wrap {
        padding: 1rem;
    }

    .inner-grid-2 {
        display: none;
    }

    .inner-grid-3 {
        display: none;
    }

    .fabric-contents-wrap {
        grid-template-columns: none;
        grid-template-rows: none;
        overflow: scroll;
    }

    .fabric-contents-wrap .fabric-menu {
        overflow-inline: auto;
        display: -webkit-inline-box;
        width: 80vw;
        gap: 0.6rem;
    }

    .british-fabric-inner-grid {
        grid-template-columns: none;
    }

    .british-fabric-inner-grid>.inner-grid-1 {
        height: 100vh;
    }


    .cloth-pic {
        grid-row: none;
        max-width: 85vw;
    }

    swiper-slide img {
        height: auto;
    }

    swiper-slide {
        background: none;
    }


    .italian-fabric-inner-grid {
        grid-template-columns: none;
    }

    .italian-fabric-inner-grid>.inner-grid-1 {
        height: 100vh;
    }
}

/* 아주 작은 기기 (최대 너비 480px) */
@media (max-width: 480px) {
    body {
        font-size: 12px;
    }


}

@font-face {
    font-family: 'playball';
    /* 내가 지어준 폰트 이름 */
    src: url('/fonts/Playball.ttf') format('woff'),
        /* 최신 브라우저용 */
        url('/fonts/Playball.ttf') format('woff');
    /* 구형 브라우저 호환용 */
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "trajan-pro-3", serif;
    font-weight: 600;
    font-style: normal;
}

.font_playball {
    font-family: 'playball';
}

.font_trajan {
    font-family: 'trajan-pro-3';
}

/* 기본 Reset */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* 텍스트 가독성 */
body {
    /*font-family: Arial, Helvetica, sans-serif;*/
    line-height: 1.6;
    color: #212121;
    background-color: #fff;
}

/* 링크 스타일 */
a {
    text-decoration: none;
    color: inherit;
}

/* 리스트 스타일 제거 */
ul,
ol {
    list-style: none;
}

header {
    margin-bottom: 2rem;
}

section {
    margin-bottom: 8rem;
}

.container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 10px;

}


.gnb {
    position: fixed;
    display: flex;
    top: 0;
    left: 0;
    width: 100%;
    height: 5rem;
    border: 1px solid #ebebeb;
    padding: 0px 20px;
    z-index: 999;
    background: rgba(247, 247, 247, 0.93);
    padding: 0rem 16rem;
}

.nav-close {
    display: none;
}

.nav-open-btn {
    display: none;
}

.logo-wrap {
    width: 16rem;
    height: auto;
    font-size: 24px;
    font-weight: bold;
    color: #333;
    display: flex;
    align-items: center;
    background: url("./img/LOGO.png") no-repeat center;
    background-size: cover;
    position: relative;
    cursor: pointer;
}

.gnb-menu-wrap {
    display: flex;
    gap: 30px;
    align-items: center;
    height: 100%;
    margin-left: auto;
}

.red {
    background-color: #9c1515;
}

.text-red {
    /* color: #9c1515; */
    font-size: 2.4rem;
}

.btns {
    display: flex;
    text-align: center;
    line-height: 1.6rem;
    padding: 7px 20px;
    /* border-radius: 5px; */
    color: white;
    cursor: pointer;
    justify-content: center;
    align-items: center;
}

.hero-section-slide-wrap {
    width: 100vw;
    height: 40rem;
    background-color: antiquewhite;
}

.ceo-section {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.text-wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1rem;
}

.swiper-slide {
    display: flex;
    font-size: 2rem;
    height: calc(100vh - 5rem);
    color: #333;
    justify-content: center;
    align-items: center;
}

.img-wrap {
    height: 513px;
    background-size: contain;
    background: url("./img/CEO_INTRO.png") no-repeat center;
    background-size: contain;
}

.slide-1 {
    background: url('./img/메인_픽스1.jpg') no-repeat center;
    background-size: cover;
}

.slide-2 {
    background: url('./img/메인_픽스2..png') no-repeat center;
    background-size: cover;
}

.slide-3 {
    background: url('./img/메인_픽스3.png') no-repeat center;
    background-size: cover;
}

/*.insta-section h2 {*/
/*    color: #9c1515;*/
/*    font-size: 24px;*/
/*    margin-bottom: 30px;*/
/*}*/

.insta-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.1rem;
}

.insta-grid div {
    width: 100%;
    padding-top: 100%;
    /* 1:1 Aspect Ratio */
    background-color: #f0f0f0;
}

.insta-grid-1-pic {
    background: url("./img/인스타 1.png");
    background-size: cover;
}

.insta-grid-2-pic {
    background: url("./img/인스타2.png");
    background-size: cover;
}

.insta-grid-3-pic {
    background: url("./img/인스타 3.png");
    background-size: cover;
}

.text-wrap-v2 {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 1rem;
}

.number-round {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 25px;
    height: 25px;
    border-radius: 100%;
    background-color: #9c1515;
    color: white;
}

.text-wrap-v2 .title {
    display: flex;
    margin-left: 5px;
    align-items: center;
    font-weight: bolder;
}

.text-wrap-v2 .text-area {
    margin-left: 1.9rem;
    letter-spacing: -0.7px;
}

.grid-box {
    width: 100%;
    padding-top: 100%;
    background-color: #f0f0f0;
}

.grid-bg-box {
    display: flex;
    width: 100%;
    height: 352px;
    /* background-size: contain; */
}

.grid-text-box {
    display: flex;
    flex-direction: column;
    /* height: 150px; */
    gap: 2px;
    font-size: 1.2rem;
    margin-top: 1rem;
}

.grid-text-title {
    font-size: 32px;
    margin-bottom: 6px;
}

.grid-text-regular {}

.grid-text-strong {
    font-weight: bolder;
}

.bespoke-beyond-wrap {
    display: grid;
    min-height: 300px;
    gap: 1rem;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    grid-template-rows: 1fr;
    cursor: pointer;
}

.fabric-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.fabric-detail {
    display: flex;
    flex-direction: column;
}

.margin-bottom-20 {
    margin-bottom: 20px;
}

.dress-rental-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr;
    background-color: #f7f7f7;
    justify-content: center;
}

.grid-left {
    display: flex;
    flex-direction: column;
    justify-content: center;
    float: left;
    background-size: contain;
    background-position: center;
    align-items: flex-start;
    padding: 4.2rem 3.5rem 1rem 2rem;
    /*letter-spacing: 1rem;*/
}

.pl-2 {
    padding-left: 7rem;
}

.grid-right {
    display: flex;
    align-content: center;
    justify-content: center;
    height: 697.2px;
    flex-direction: column;
    gap: 1rem;
    padding: 3rem;
    font-size: 1.2rem;
}


.atelier-img {
    background: url("./img/아뜰리에.png");
    background-repeat: no-repeat;
    background-size: cover;
}

.bespoke-img {
    background: url("./img/rectangle_78_a1ffef.png");
    background-repeat: no-repeat;
    background-size: cover;
}

.resizing-img {
    background: url("./img/비스포크.png");
    background-repeat: no-repeat;
    background-size: cover;
}

.bespoke-beyond_1-img {
    background: url("./img/BESPOKE_BEYOND_1.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    height: 449px;
}

.bespoke-beyond_2-img {
    background: url("./img/BESPOKE_BEYOND_2.png");
    background-repeat: no-repeat;
    background-size: cover;
    height: 449px;
}

.bespoke-beyond_3-img {
    background: url("./img/BESPOKE_BEYOND_3.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    height: 449px;
}

.bespoke-beyond_4-img {
    background: url("./img/BESPOKE_BEYOND_4.png");
    background-repeat: no-repeat;
    background-size: cover;
    height: 449px;
}


.british-img {
    background-size: cover;
    background: url("./img/fabric_영국2.png");
    background-repeat: no-repeat;
    background-size: contain;
}

.italian-img {
    background-size: cover;
    background: url("./img/fabric_이태리.png");
    background-repeat: no-repeat;
    background-size: contain;
}

.dress-rental-img {
    background-size: cover;
    background: url("./img/image 28.png");
    background-repeat: no-repeat;
    background-size: 30rem;
    background-position: center;
    background-position-x: 1rem;
}

.map_link_icon::after {
    width: 0;
    height: 0;
    border-left: 4rem solid rgba(0, 0, 0, 0);
    border-right: 4rem solid rgba(0, 0, 0, 0);
    border-top: 8rem solid;
    left: 17rem;
    top: calc(100% - 1rem);
    z-index: 1;
}

.lh-1 {
    line-height: 1rem;
}

.lh-1_2 {
    line-height: 1.2rem;
}

.lh-1_4 {
    line-height: 2.5rem;
}

sssssssss .lh-2 {
    line-height: 2rem;
}

.in_one_place_section_wrap {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.fts_1_2 {
    font-size: 1.2rem;
}

.hero-section {
    width: 100%;
    height: 100vh;
    z-index: 10;
    margin-top: 5rem;
}

.bottom-grid {
    display: grid;
    margin-top: 40px;
    grid-template-columns: repeat(auto-fit, minmax(200px, 3fr));
    gap: 1rem;
    /*height: 150px;*/
}

.bottom-grid>div {
    background-color: #f0f0f0;
    height: 198px;
    border-radius: 10px;
    border: 2px solid #ececec;
}

footer {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0 3rem;
    border-top: 1px solid #ececec;
    height: 250px;
    gap: 0.6rem;
    padding: 0 15.7rem;
}

.pointer {
    cursor: pointer
}

.footer-title {
    font-size: 1.4rem;
    font-weight: bolder;
}

#italian-fabric-wrap,
#british-fabric-wrap {
    cursor: pointer;
    gap: 4px;
    font-size: 1.2rem;
}

#italian-fabric-wrap-modal {
    display: none;
    position: fixed;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.8);
}

#british-fabric-wrap-modal {
    display: none;
    position: fixed;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.8);
}

.underline-50-gradient {
    background-image: linear-gradient(currentColor, currentColor);
    background-size: 10% 5px;
    background-repeat: no-repeat;
    padding-bottom: 2px;
    background-position: 0 1.6em;
}

.bespoke-beyond_1 {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.bespoke-beyond_2 {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.bespoke-beyond_3 {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.bespoke-beyond_4 {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.in_one_place_container {
    display: flex;
    flex: 1;
    flex-wrap: wrap;
    margin-bottom: 5rem;
}

.in_one_place_text_wrap {
    width: 50%;
    margin-top: 50px;
    margin-bottom: 50px;
    padding-left: 8rem;
}

.greeting-wrap {
    gap: 1rem;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 2fr));
    grid-template-rows: 1fr;
    justify-items: center;
    align-items: center;
}


#map {
    width: 100%;
    height: 600px;
    /* 지도 높이만 변경하면 됨 */
    /* border-radius: 16px; */
    /* 둥근 모서리 */
    overflow: hidden;
    /* 둥근 모서리 안에서 잘리게 */
}


.modal-wrap {
    display: none;
    left: 0;
    top: 0;
    position: fixed;
    width: 100vw;
    height: 100vh;
    background: #333333;
    /* margin-top: 5rem; */
    z-index: 9999;
    overflow: hidden;
    padding: 1rem;
}

.modal-open {}

.modal-close {
    position: absolute;
    width: 50px;
    height: 50px;
    display: block;
    color: black;
    right: 2%;
    top: 0%;
    z-index: 99999;
    font-size: 4rem;
    cursor: pointer;
    -webkit-text-stroke: 0.3px #ebebeb;
}


swiper-container {
    width: 100%;
    height: 100%;
}

swiper-slide {
    text-align: center;
    font-size: 18px;
    background: #444;
    display: flex;
    justify-content: center;
    align-items: center;
}

swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fabric-contents-wrap {
    font-family: "trajan-pro-3", serif;
    font-weight: bolder;
    display: grid;
    background: #ebebeb;
    width: 100%;
    height: 100%;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 8rem 1fr;
    padding: 1rem;
    gap: 1rem;
}

.fabric-contents-wrap .fabric-menu {
    display: flex;
    gap: 1rem;
    align-items: center;
    /* padding-left: 1rem; */
    justify-content: flex-start;
    grid-area: fabric-menu;
}

.fabric-contents-wrap .fabric-menu span {
    display: flex;
    padding: 0.6rem 1rem;
    background: #9c1515;
    color: #ebebeb;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.fabric-ssfw {
    grid-area: fabric-ssfw;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 1rem;
    /* padding-left: 1rem; */
}

.fabric-ssfw span {
    display: flex;
    padding: 0.6rem 1rem;
    /* background: #9c1515; */
    color: #1c1c1c;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border: 1px solid #1c1c1c;
    min-width: 5rem;
}

.fabric-contents-wrap .menu {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-content: flex-start;
}

.cloth-pic {
    grid-row: span 2;
    max-width: 46vw;
}

.img-contain img {
    background: #ebebeb;
    object-fit: contain;
}

.british-fabric-inner-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.british-fabric-inner-grid>.inner-grid-1 {
    grid-row: span 2;
    background: url("./img/영국원단_스카발(세로).png") no-repeat center;
    background-size: cover;
}

.british-fabric-inner-grid>.inner-grid-2 {
    background: url("./img/영국원단_스카발(가로1).png") no-repeat center;
    background-size: cover;
}

.british-fabric-inner-grid>.inner-grid-3 {
    background: url("./img/영국원단_스카발(가로2).png") no-repeat center;
    background-size: cover;
}

.italian-fabric-inner-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.italian-fabric-inner-grid>.inner-grid-1 {
    grid-row: span 2;
    background: url("./img/이태리원단_로로피아나(세로).png") no-repeat center;
    background-size: cover;

}

.italian-fabric-inner-grid>.inner-grid-2 {
    background: url("./img/이태리원단_로로피아나(가로1).png") no-repeat center;
    background-size: cover;

}

.italian-fabric-inner-grid>.inner-grid-3 {
    background: url("./img/이태리원단_로로피아나(가로2).png") no-repeat center;
    background-size: cover;

}

.place-icon {
    background: url("./img/place.png");
    width: 2rem;
    height: 2rem;
    background-size: cover;
    cursor: pointer;
}

.blog-icon {
    background: url("./img/blog.png");
    width: 2rem;
    height: 2rem;
    background-size: cover;
    cursor: pointer;
}

.insta-icon {
    background: url("./img/insta.png");
    width: 2rem;
    height: 2rem;
    background-size: cover;
    cursor: pointer;
}

.swiper-pagination {}

.british-cloth-bg {
    display: none;
}

.italian-cloth-bg {
    display: none;
}

.active {
    display: flex;
}

.selected-fabric {
    color: #9c1515 !important;
    border: #9c1515 1px solid !important;
}

@media (min-width: 1400px) {
    .text-wrap {
        padding-left: 12rem;
    }

    .footer {
        border-top: 1px solid #ececec
    }

}


@media (max-width: 1200px) {
    .gnb {
        padding: 0 1rem;
    }
}


/* 태블릿 (최대 너비 1024px) */
@media (max-width: 1024px) {
    body {
        font-size: 16px;
        background-color: #f5f5f5;
    }

    .container {
        padding: 0 1rem;
    }

    .in_one_place_text_wrap {
        display: flex;
        flex-direction: column;
        width: 100%;
        align-items: center;
    }

    .text-wrap-v2 {
        width: auto;
        /* text-align: center; */
        /* justify-content: center; */
        /* justify-items: center; */
        padding-left: 2rem;
    }

    .in_one_place_section_wrap {
        grid-template-columns: none;
        gap: 3rem;
    }

    .in_one_place_container {
        justify-content: center;
        /* text-align: center; */
    }

    .bespoke-beyond-wrap {
        grid-template-columns: none;
        grid-template-rows: none;
        justify-content: center;
    }

    .bespoke-beyond_1-img {
        width: calc(100vw - 12rem);
        height: 100vh;
        background: url("./img/BESOPOKE_M.png");
        background-repeat: no-repeat;
    }

    .bespoke-beyond_2-img {
        width: calc(100vw - 12rem);
        height: 100vh;
        background: url("./img/COAT_M.png");
    }

    .bespoke-beyond_3-img {
        width: calc(100vw - 12rem);
        height: 100vh;
        background: url("./img/SHOES_M.png");
    }

    .bespoke-beyond_4-img {
        width: calc(100vw - 12rem);
        height: 100vh;
        background: url("./img/JACKET_M.png");
    }

    .fabric-wrap {
        grid-template-columns: none;
    }

    .grid-bg-box {
        padding-top: 50%;
    }

    .dress-rental-wrap {
        grid-template-columns: none;
        grid-template-rows: none;
        padding: 1.5rem;
    }

    .pl-2 {
        padding-left: 0;
    }

    .grid-left {
        margin: 0 auto;
    }

    .bottom-grid {
        grid-template-columns: none;
        font-size: 1rem;
    }

    .grid-wrap {
        grid-template-columns: none;
    }

    footer {
        padding: 0 2rem;
    }

    .gnb {
        padding: 0 1rem;
    }


}


/* 모바일 (최대 너비 768px) */
@media (max-width: 1000px) {


    body {
        font-size: 14px;
        background-color: #eee;
    }

    .text-wrap {
        /* padding-left: 10%; */
    }

    .hero-section {
        width: 100%;
        height: 100vh;
    }

    .swiper-slide {
        display: flex;
        height: calc(100vh - 80px);
        justify-content: center;
    }

    .container {
        width: 100%;
    }

    .gnb {
        width: 100vw;
        padding: 0;
        justify-content: space-around;
    }

    .gnb-menu-wrap {
        display: flex;
        position: absolute;
        background: #eeeeeef5;
        width: 80vw;
        height: 100vh;
        color: #1c1c1c;
        align-items: center;
        flex-direction: column;
        padding-top: 5rem;
        right: -100vw;
        transition: 0.3s all;
    }

    .ceo-section {
        grid-template-columns: none;
        text-align: center;
    }

    .insta-grid {
        grid-template-columns: none;
    }

    .bespoke-beyond_1-img {
        width: 100%;
        height: 22rem;
        background-size: contain;
    }

    .bespoke-beyond_2-img {
        width: 100%;
        height: 22rem;
        background-size: contain;
    }

    .bespoke-beyond_3-img {
        width: 100%;
        height: 22rem;
        background-size: contain;
    }

    .bespoke-beyond_4-img {
        width: 100%;
        height: 22rem;
        background-size: contain;
    }

    .british-img,
    .italian-img {
        padding-top: 50%;
        flex: 1;
    }

    .dress-rental-img {
        background-size: cover;
        background-position-x: 0;
    }

    .grid-left {
        padding: 0;
    }

    .fts_1_2 {
        font-size: 0.95rem;
    }

    .margin-bottom-20 {
        text-align: center;
    }

    .grid-right {
        margin-top: 1rem;
        height: 21rem;
    }

    .in_one_place_text_wrap {
        padding-left: 0rem;
        margin-top: 0.3rem;
    }

    .grid-bg-box {

        background-position: center;

        width: 93vw;

        background-repeat: no-repeat;

    }

    .bespoke-beyond_1 {
        gap: 0
    }

    .bespoke-beyond_2 {
        gap: 0
    }

    .bespoke-beyond_3 {
        gap: 0
    }

    .bespoke-beyond_4 {
        gap: 0
    }

    .grid-left {
        align-items: center
    }

    .grid-right,
    .grid-text-regular,
    .grid-text-box {
        width: 100%;
        font-size: 0.9rem;
        padding: 0rem;
    }

    .grid-text-box {}

    .grid-text-regular {}

    .gnb-menu {
        display: flex;
        justify-content: center;
        align-items: center;
        border: 1px solid #ebebeb;
        width: 80%;
        height: 3rem;
    }

    section {
        margin-bottom: 4rem
    }

    .gnb-menu a {
        display: flex;
        width: 100%;
        height: 2rem;
        align-items: center;
        justify-content: center;
        border: 1px solid #1c1c1c17;
        padding: 1.3rem;
    }

    .btns a {
        border: none;
    }

    .btns>a {
        text-align: center;
    }

    .nav-close {
        position: absolute;
        width: 50px;
        height: 50px;
        display: block;
        color: #1c1c1c;
        right: 6%;
        top: -1%;
        z-index: 99999;
        font-size: 4rem;
        cursor: pointer;
    }

    .nav-open-btn {
        display: flex;
        width: 50px;
        height: 100%;
        font-size: 2rem;
        align-items: center;
        justify-content: center;
        position: relative;
        right: 0;
    }

    .slide-1 {
        background: url("./img/mobile_main_01.jpg");
        background-size: cover;
        object-fit: cover;
        background-repeat: no-repeat;
    }

    .slide-2 {
        background: url("./img/mobile_main_02.jpg");
        background-size: cover;
        object-fit: cover;
    }

    .slide-3 {
        background: url("./img/mobile_main_03.png");
        background-size: cover;
        object-fit: cover;
    }


    .grid-text-title {
        /* display: flex; */
        margin-top: 0.8rem;
        /* justify-content: center; */
        /* align-items: center; */
    }

    .modal-wrap {
        padding: 1rem;
    }

    .inner-grid-2 {
        display: none;
    }

    .inner-grid-3 {
        display: none;
    }

    .fabric-contents-wrap {
        grid-template-columns: none;
        grid-template-rows: none;
        overflow: scroll;
    }

    .fabric-contents-wrap .fabric-menu {
        overflow-inline: auto;
        display: -webkit-inline-box;
        width: 80vw;
        gap: 0.6rem;
    }

    .british-fabric-inner-grid {
        grid-template-columns: none;
    }

    .british-fabric-inner-grid>.inner-grid-1 {
        height: 100vh;
    }


    .cloth-pic {
        grid-row: none;
        max-width: 85vw;
    }

    swiper-slide img {
        height: auto;
    }

    swiper-slide {
        background: none;
    }


    .italian-fabric-inner-grid {
        grid-template-columns: none;
    }

    .italian-fabric-inner-grid>.inner-grid-1 {
        height: 100vh;
    }

    .fabric-contents-wrap {
        grid-template-columns: none;
        grid-template-rows: none;
        overflow: scroll;
    }

    .fabric-contents-wrap .fabric-menu {
        overflow-inline: auto;
        display: -webkit-inline-box;
        width: 80vw;
        gap: 0.6rem;
    }

    .british-fabric-inner-grid {
        grid-template-columns: none;
    }

    .british-fabric-inner-grid>.inner-grid-1 {
        height: 100vh;
    }

    .italian-fabric-inner-grid {
        grid-template-columns: none;
    }

    .italian-fabric-inner-grid>.inner-grid-1 {
        height: 100vh;
    }

    .text-center-m {
        text-align: center;
    }

    .swiper-slide>img {
        width: 100%;
        background-size: cover;
        object-fit: cover;
    }

    .map-section {
        margin-bottom: 0;
    }

    footer {
        border-top: 1px solid #1c1c1c26;
        margin-top: 3rem;
        padding: 0 1rem;
    }

}

/* 아주 작은 기기 (최대 너비 480px) */
@media (max-width: 480px) {
    body {
        font-size: 12px;
    }

    footer {
        border-top: 1px solid #1c1c1c26;
        margin-top: 3rem;
        padding: 0 1rem;
    }


}