@charset "UTF-8";

:root {

    --inner: 1600;

    /* space */
    --space-5 : clamp(5px, calc(5 / var(--inner) * 100vw), 5px);
    --space-6 : clamp(5px, calc(6 / var(--inner) * 100vw), 6px);
    --space-7 : clamp(5px, calc(7 / var(--inner) * 100vw), 7px);
    --space-8 : clamp(5px, calc(8 / var(--inner) * 100vw), 8px);
    --space-9 : clamp(5px, calc(9 / var(--inner) * 100vw), 9px);
    --space-10 : clamp(5px, calc(10 / var(--inner) * 100vw), 10px);
    --space-12 : clamp(5px, calc(12 / var(--inner) * 100vw), 12px);
    --space-13 : clamp(5px, calc(13 / var(--inner) * 100vw), 13px);
    --space-14 : clamp(5px, calc(14 / var(--inner) * 100vw), 14px);
    --space-15 : clamp(5px, calc(15 / var(--inner) * 100vw), 15px);
    --space-17 : clamp(5px, calc(17 / var(--inner) * 100vw), 17px);
    --space-18 : clamp(5px, calc(18 / var(--inner) * 100vw), 18px);
    --space-19 : clamp(5px, calc(19 / var(--inner) * 100vw), 19px);
    --space-20 : clamp(5px, calc(20 / var(--inner) * 100vw), 20px);
    --space-25 : clamp(15px, calc(25 / var(--inner) * 100vw), 25px);   
    --space-30 : clamp(15px, calc(30 / var(--inner) * 100vw), 30px);
    --space-35 : clamp(15px, calc(35 / var(--inner) * 100vw), 35px);
    --space-40 : clamp(15px, calc(40 / var(--inner) * 100vw), 40px);
    --space-45 : clamp(15px, calc(45 / var(--inner) * 100vw), 45px);
    --space-50 : clamp(15px, calc(50 / var(--inner) * 100vw), 50px);
    --space-55 : clamp(15px, calc(50 / var(--inner) * 100vw), 55px);
    --space-60 : clamp(20px, calc(60 / var(--inner) * 100vw), 60px);
    --space-65 : clamp(20px, calc(65 / var(--inner) * 100vw), 65px);
    --space-70 : clamp(20px, calc(70 / var(--inner) * 100vw), 70px);
    --space-75 : clamp(20px, calc(75 / var(--inner) * 100vw), 75px);
    --space-80 : clamp(20px, calc(80 / var(--inner) * 100vw), 80px);
    --space-85 : clamp(20px, calc(85 / var(--inner) * 100vw), 85px);
    --space-90 : clamp(20px, calc(90 / var(--inner) * 100vw), 90px);
    --space-95 : clamp(20px, calc(95 / var(--inner) * 100vw), 95px);
    --space-100 : clamp(40px, calc(100 / var(--inner) * 100vw), 100px);
    --space-110 : clamp(40px, calc(110 / var(--inner) * 100vw), 110px);
    --space-120 : clamp(40px, calc(120 / var(--inner) * 100vw), 120px);
    --space-125 : clamp(40px, calc(125 / var(--inner) * 100vw), 125px);
    --space-130 : clamp(40px, calc(130 / var(--inner) * 100vw), 130px);
    --space-140 : clamp(40px, calc(140 / var(--inner) * 100vw), 140px);
    --space-150 : clamp(60px, calc(150 / var(--inner) * 100vw), 150px);
    --space-155 : clamp(60px, calc(150 / var(--inner) * 100vw), 155px);
    --space-160 : clamp(60px, calc(160 / var(--inner) * 100vw), 160px);
    --space-165 : clamp(60px, calc(165 / var(--inner) * 100vw), 165px);
    --space-170 : clamp(60px, calc(170 / var(--inner) * 100vw), 170px);
    --space-175 : clamp(60px, calc(175 / var(--inner) * 100vw), 175px);
    --space-180 : clamp(60px, calc(180 / var(--inner) * 100vw), 180px);
    --space-200 : clamp(60px, calc(200 / var(--inner) * 100vw), 200px);
    --space-230 : clamp(60px, calc(230 / var(--inner) * 100vw), 230px);
    --space-250 : clamp(60px, calc(250 / var(--inner) * 100vw), 250px);
    --space-300 : clamp(60px, calc(300 / var(--inner) * 100vw), 300px);

    /* font-size */
    --font-12 : clamp(10px, calc(12 / var(--inner) * 100vw), 12px);
    --font-13 : clamp(10px, calc(13 / var(--inner) * 100vw), 13px);
    --font-14 : clamp(10px, calc(14 / var(--inner) * 100vw), 14px);
    --font-15 : clamp(10px, calc(15 / var(--inner) * 100vw), 15px);
    --font-16 : clamp(14px, calc(16 / var(--inner) * 100vw), 16px);
    --font-17 : clamp(14px, calc(17 / var(--inner) * 100vw), 17px);
    --font-18 : clamp(14px, calc(18 / var(--inner) * 100vw), 18px);
    --font-20 : clamp(14px, calc(20 / var(--inner) * 100vw), 20px);
    --font-22 : clamp(18px, calc(22 / var(--inner) * 100vw), 22px);
    --font-23 : clamp(18px, calc(23 / var(--inner) * 100vw), 23px);
    --font-24 : clamp(18px, calc(24 / var(--inner) * 100vw), 24px);
    --font-25 : clamp(18px, calc(25 / var(--inner) * 100vw), 25px);
    --font-26 : clamp(18px, calc(26 / var(--inner) * 100vw), 26px);
    --font-28 : clamp(18px, calc(28 / var(--inner) * 100vw), 28px);
    --font-30 : clamp(20px, calc(30 / var(--inner) * 100vw), 30px);
    --font-32 : clamp(20px, calc(32 / var(--inner) * 100vw), 32px);
    --font-33 : clamp(20px, calc(33 / var(--inner) * 100vw), 33px);
    --font-35 : clamp(20px, calc(33 / var(--inner) * 100vw), 35px);
    --font-36 : clamp(20px, calc(36 / var(--inner) * 100vw), 36px);
    --font-40 : clamp(20px, calc(40 / var(--inner) * 100vw), 40px);
    --font-45 : clamp(20px, calc(45 / var(--inner) * 100vw), 45px);
    --font-46 : clamp(20px, calc(46 / var(--inner) * 100vw), 46px);
    --font-48 : clamp(20px, calc(48 / var(--inner) * 100vw), 48px);
    --font-50 : clamp(20px, calc(50 / var(--inner) * 100vw), 50px);
    --font-55 : clamp(20px, calc(55 / var(--inner) * 100vw), 55px);
    --font-60 : clamp(25px, calc(60 / var(--inner) * 100vw), 60px);
    --font-68 : clamp(25px, calc(68 / var(--inner) * 100vw), 68px);
    --font-70 : clamp(25px, calc(70 / var(--inner) * 100vw), 70px);
    --font-73 : clamp(25px, calc(75 / var(--inner) * 100vw), 75px);
    --font-75 : clamp(25px, calc(75 / var(--inner) * 100vw), 75px);
    --font-80 : clamp(30px, calc(80 / var(--inner) * 100vw), 80px);
    --font-88 : clamp(40px, calc(88 / var(--inner) * 100vw), 88px);
    --font-128 : clamp(50px, calc(128 / var(--inner) * 100vw), 128px);

    --fw-light: 400;
    --fw-normal: 500; 
    --fw-medium: 600;
    --fw-semibold: 700;
    --fw-bold: 800;
    --fw-black: 900;

    --fm-suit: "SUIT", sans-serif;
    --fm-en: "Cormorant Garamond", serif;

    --flex-box: flex;

    --color-basic: #222222;
    --color-white: #FFFFFF;
    --color-gray: #e1e1e1;
    --color-gray-f8f8f8: #F8F8F8;

    --border: 1px solid var(--color-basic);
    --border-gray: 1px solid var(--color-gray);
    --border-white: 1px solid var(--color-white);

    --border-radius: 100000000px;
    --radius-6 : 6px;
    --radius-8 : 8px;
    --radius-10 : 10px;
    --radius-12 : clamp(6px, calc(12 / var(--inner) * 100vw), 12px);
    --radius-14 : clamp(8px, calc(14 / var(--inner) * 100vw), 14px);
    --radius-15 : clamp(8px, calc(15 / var(--inner) * 100vw), 15px);
    --radius-16 : clamp(8px, calc(16 / var(--inner) * 100vw), 16px);
    --radius-20 : clamp(10px, calc(20 / var(--inner) * 100vw), 20px);
    --radius-24 : clamp(12px, calc(24 / var(--inner) * 100vw), 24px);
    --radius-30 : clamp(15px, calc(30 / var(--inner) * 100vw), 30px);
    --radius-32 : clamp(16px, calc(32 / var(--inner) * 100vw), 32px);
    --radius-40 : clamp(20px, calc(40 / var(--inner) * 100vw), 40px);
    --radius-50 : clamp(25px, calc(50 / var(--inner) * 100vw), 50px);

    --transition: all 0.3s;
    
    --bc-space: clamp(30px, calc(50 / var(--inner) * 100vw), 50px);
}
html {
    scroll-behavior: smooth;
    min-width: 280px;
    overflow-x: hidden;
    -webkit-text-size-adjust: none;
    -moz-text-size-adjust: none;
    -ms-text-size-adjust: none;
    -o-text-size-adjust: none;
    color: var(--color-basic);
    font-size: var(--font-18);
    font-family: var(--fm-suit);
}
body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
address, code, em, img, select,
small, strong, sub, sup, var, button,
b, i, dl, dt, dd, ol, ul, li,
fieldset, form, label, legend, input, textarea,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary, mark, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-weight:inherit;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-size: inherit;
    font-family: inherit;
    color: inherit;
    word-break: keep-all;
}   
*, *:before, *:after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
a,
a:active,
a:hover,
a:visited {
    text-decoration: none;
}
a,
button {
    outline: none;
    -webkit-transition: var(--transition);
    transition: var(--transition);
    color:inherit;
    font-size:inherit;
}
/* a:hover {
    color: var(--color-primary);
} */
svg * {
    -webkit-transition: 0.05s ease-in-out;
    transition: 0.05s ease-in-out;
}
iframe,
img,
table {
    border: 0;
}
button,
img,
input,
select,
textarea {
    vertical-align: middle;
}
li,
ol,
ul {
    list-style: none;
}
/* p,
pre,
li {
    line-height: 1.4;
} */
pre {
    white-space: pre-line;
}
td,
tr {
    vertical-align: middle;
}
address,
em,
optgroup {
    font-style: normal;
}
img {
    width:100%
}
caption {
    position: static;
    width: 0;
    height: 0;
    font-size: 0;
    line-height: 0;
    overflow: hidden;
    visibility: hidden;
}
::-moz-selection {
    color:var(--color-white);
    background:var(--color-basic)
}
::-webkit-selection {
    color:var(--color-white);
    background:var(--color-basic)
}
::selection {
    color:var(--color-white);
    background:var(--color-basic)
}

svg {
    height: auto;
}
@media all and (max-width: 1200px) {
    html {
        font-size: var(--font-18);
    }
}
@media all and (max-width: 1000px) {
    html {
        font-size: var(--font-17);
    }
    body.en {
        font-size: var(--font-16);
    }
}
@media all and (max-width:640px) {
    html {
        font-size: var(--font-16);
    }
    pre {
        white-space: normal;
    }
}
@media all and (max-width:414px) {
    h4 br {
        display: none;
    }
}
@media all and (max-width:320px) {
    html {
        font-size: var(--font-13);
    }
}

/* 인풋 기본 스타일 제거 */
textarea,
input,
select,
button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    -webkit-border-radius: 0;
    border-radius: 0;
    border: 0;
    line-height: normal;
}

/* input type number 에서 화살표 제거 */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
button:focus,
input:focus,
select:focus,
textarea:focus {
    outline: none;
}
select::-ms-expand {
    display: none;
}
textarea {
    width: 100%;
    background: none;
    resize: none;
}
button {
    border: 0;
    background: none;
    cursor: pointer;
}
select {
    cursor: pointer;
    background-color: var(--color-white);
    outline: none;
    overflow: hidden;
    width: 100%;
}

/* placeholder css 적용하기 */
input::placeholder,
textarea::placeholder {
    color: var(--color-dark);
    opacity: 1;
}
input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
    color: var(--color-dark);
}
input:-ms-input-placeholder,
textarea:-ms-input-placeholder {
    color: var(--color-dark);
}
input:-mos-input-placeholder,
textarea:-mos-input-placeholder {
    color: var(--color-dark);
}

/* placeholder 포커스시 감추기*/
input:focus::-webkit-input-placeholder,
textarea:focus::-webkit-input-placeholder {
    color: transparent;
}
input:focus:-moz-placeholder,
textarea:focus:-moz-placeholder {
    color: transparent;
}
input:focus::-moz-placeholder,
textarea:focus::-moz-placeholder {
    color: transparent;
}
input:focus:-ms-input-placeholder,
textarea:focus:-ms-input-placeholder {
    color: transparent;
}

/* 색상&배경 */
.color-primary {
    color: var(--color-primary);
}
.color-primary-light {
    color: var(--color-primary-light);
}
.color-green-light {
    color: var(--color-green-light);
}
.color-white {
    color: var(--color-white)
}
.bg-primary {
    background-color: var(--color-primary);
}

/* 폰트 속성 */
.fm-en {
    font-family: var(--fm-en);
}
.fw-thin {
    font-weight: var(--fw-thin);
}
.fw-light {
    font-weight: var(--fw-light);
}
.fw-normal {
    font-weight: var(--fw-normal);
}
.fw-medium {
    font-weight: var(--fw-medium);
}
.fw-semibold {
    font-weight: var(--fw-semibold);
}
.fw-bold {
    font-weight: var(--fw-bold);
}
.fw-black {
    font-weight: var(--fw-black);
}

/* 폰트 사이즈 */
.font80 {
    font-size: var(--font-80);
}
.font75 {
    font-size: var(--font-75);
}
.font73 {
    font-size: var(--font-73);
}
.font70 {
    font-size: var(--font-70);
}
.font68 {
    font-size: var(--font-68);
}
.font65 {
    font-size: var(--font-65);
}
.font60 {
    font-size: var(--font-60);
}
.font55 {
    font-size: var(--font-55);
}
.font50 {
    font-size: var(--font-50);
}
.font45 {
    font-size: var(--font-45);
}
.font40 {
    font-size: var(--font-40);
}
.font36 {
    font-size: var(--font-36);
}
.font35 {
    font-size: var(--font-35);
}
.font32 {
    font-size: var(--font-32);
}
.font30 {
    font-size: var(--font-30);
}
.font25 {
    font-size: var(--font-25);
}
.font22 {
    font-size: var(--font-22);
}
.font20 {
    font-size: var(--font-20);
}
.font18 {
    font-size: var(--font-18);
}
.font17 {
    font-size: var(--font-17);
}
.font16 {
    font-size: var(--font-16);
}
.font15 {
    font-size: var(--font-15);
}
.font14 {
    font-size: var(--font-14);
}
.font13 {
    font-size: var(--font-13);
}
.font12 {
    font-size: var(--font-12);
}

/* Padding & Margin  */
.p0 {
    padding: 0 !important;
}
.pt0 {
    padding-top: 0 !important;
}
.pr0 {
    padding-right: 0 !important;
}
.pb0 {
    padding-bottom: 0 !important;
}
.pl0 {
    padding-left: 0 !important;
}
.m0 {
    margin-top: 0 !important;
}
.mt0 {
    margin-top: 0 !important;
}
.mr0 {
    margin-right: 0 !important;
}
.mb0 {
    margin-bottom: 0 !important;
}
.ml0 {
    margin-left: 0 !important;
}

.mt150 {
    margin-top: var(--space-150);
}
.mt130 {
    margin-top: var(--space-130);
}
.mt100 {
    margin-top: var(--space-100);
}
.mt90 {
    margin-top: var(--space-90);
}
.mt80 {
    margin-top: var(--space-80);
}
.mt70 {
    margin-top: var(--space-70);
}
.mt65 {
    margin-top: var(--space-65);
}
.mt60 {
    margin-top: var(--space-60);
}
.mt50 {
    margin-top: var(--space-50);
}
.mt45 {
    margin-top: var(--space-45);
}
.mt40 {
    margin-top: var(--space-40);
}
.mt35 {
    margin-top: var(--space-35);
}
.mt30 {
    margin-top: var(--space-30);
}
.mt25 {
    margin-top: var(--space-25);
}
.mt20 {
    margin-top: var(--space-20);
}
.mt15 {
    margin-top: var(--space-15);
}
.mt12 {
    margin-top: var(--space-12);
}
.mt10 {
    margin-top: var(--space-10);
}
.mb250 {
    margin-bottom: var(--space-250);
}
.mb180 {
    margin-bottom: var(--space-180);
}
.mb160 {
    margin-bottom: var(--space-160);
}
.mb150 {
    margin-bottom: var(--space-150);
}
.mb140 {
    margin-bottom: var(--space-140);
}
.mb130 {
    margin-bottom: var(--space-130);
}
.mb120 {
    margin-bottom: var(--space-120);
}
.mb120 {
    margin-bottom: var(--space-110);
}
.mb100 {
    margin-bottom: var(--space-100);
}
.mb90 {
    margin-bottom: var(--space-90);
}
.mb80 {
    margin-bottom: var(--space-80);
}
.mb70 {
    margin-bottom: var(--space-70);
}
.mb60 {
    margin-bottom: var(--space-60);
}
.mb50 {
    margin-bottom: var(--space-50);
}
.mb45 {
    margin-bottom: var(--space-40);
}
.mb40 {
    margin-bottom: var(--space-40);
}
.mb30 {
    margin-bottom: var(--space-30);
}
.mb25 {
    margin-bottom: var(--space-25);
}
.mb20 {
    margin-bottom: var(--space-20);
}
.mb17 {
    margin-bottom: var(--space-17);
}
.mb15 {
    margin-bottom: var(--space-15);
}
.mb12 {
    margin-bottom: var(--space-12);
}
.mb10 {
    margin-bottom: var(--space-10);
}
.ml20 {
    margin-left: var(--space-20);
}
.ptpb200 {
    padding-top: var(--space-200);
    padding-bottom: var(--space-200);
}
.ptpb180 {
    padding-top: var(--space-180);
    padding-bottom: var(--space-180);
}
.ptpb150 {
    padding-top: var(--space-150);
    padding-bottom: var(--space-150);
}
.ptpb130 {
    padding-top: var(--space-130);
    padding-bottom: var(--space-130);
}
.ptpb120 {
    padding-top: var(--space-120);
    padding-bottom: var(--space-120);
}
.ptpb100 {
    padding-top: var(--space-100);
    padding-bottom: var(--space-100);
}
.ptpb80 {
    padding-top: var(--space-80);
    padding-bottom: var(--space-80);
}
.ptpb70 {
    padding-top: var(--space-70);
    padding-bottom: var(--space-70);
}
.ptpb60 {
    padding-top: var(--space-60);
    padding-bottom: var(--space-60);
}
.ptpb50 {
    padding-top: var(--space-50);
    padding-bottom: var(--space-50);
}
.ptpb35 {
    padding-top: var(--space-35);
    padding-bottom: var(--space-35);
}
.ptpb30 {
    padding-top: var(--space-30);
    padding-bottom: var(--space-30);
}
.ptpb25 {
    padding-top: var(--space-25);
    padding-bottom: var(--space-25);
}
.pt250 {
    padding-top: var(--space-250);
}
.pt180 {
    padding-top: var(--space-180);
}
.pt150 {
    padding-top: var(--space-150);
}
.pt140 {
    padding-top: var(--space-140);
}
.pt90 {
    padding-top: var(--space-90);
}
.pt80 {
    padding-top: var(--space-80);
}
.pt65 {
    padding-top: var(--space-65);
}
.pt50 {
    padding-top: var(--space-50);
}
.pt40 {
    padding-top: var(--space-40);
}
.pt35 {
    padding-top: var(--space-35);
}
.pt30 {
    padding-top: var(--space-30);
}
.pt25 {
    padding-top: var(--space-25);
}
.pb250 {
    padding-bottom: var(--space-250);
}
.pb60 {
    padding-bottom: var(--space-60);
}
.pb50 {
    padding-bottom: var(--space-50);
}
.pb40 {
    padding-bottom: var(--space-40);
}
.pb35 {
    padding-bottom: var(--space-35);
}
.pb30 {
    padding-bottom: var(--space-30);
}
.pb25 {
    padding-bottom: var(--space-25);
}
.pb20 {
    padding-bottom: var(--space-20);
}
.pb17 {
    padding-bottom: var(--space-17);
}
.plpr110 {
    padding-left: var(--space-110);
    padding-right: var(--space-110);
}
.plpr80 {
    padding-left: var(--space-80);
    padding-right: var(--space-80);
}
.plpr60 {
    padding-left: var(--space-60);
    padding-right: var(--space-60);
}
.plpr50 {
    padding-left: var(--space-50);
    padding-right: var(--space-50);
}
.plpr45 {
    padding-left: var(--space-45);
    padding-right: var(--space-45);
}
.plpr40 {
    padding-left: var(--space-40);
    padding-right: var(--space-40);
}
.plpr35 {
    padding-left: var(--space-35);
    padding-right: var(--space-35);
}
.plpr30 {
    padding-left: var(--space-30);
    padding-right: var(--space-30);
}
.plpr20 {
    padding-left: var(--space-20);
    padding-right: var(--space-20);
}
    /* @media all and (max-width: 1200px) {
        .plpr80,
        .plpr60,
        .plpr50,
        .plpr45,
        .plpr40,
        .plpr35,
        .plpr25,
        .plpr30,
        .plpr20 {
            padding-left: 20px;
            padding-right: 20px;
        }
    }
    @media all and (max-width: 1000px) {
        .plpr80,
        .plpr60,
        .plpr50,
        .plpr45,
        .plpr40,
        .plpr35,
        .plpr25,
        .plpr30,
        .plpr20 {
            padding-left: 15px;
            padding-right: 15px;
        }
    } */

/* Display */
.dpb {
    display: block;
}
.dpi {
    display: inline;
}
.dpib {
    display: inline-block;
}

/* Alaign */
.tac {
    text-align: center;
}
.tal {
    text-align: left;
}
.tar {
    text-align: right;
}

/* Absolute align */
.xyalign {
    position: absolute;
    top: 50%;
    left: 50%;
    -moz-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
}
.yalign {
    position: absolute;
    top: 50%;
    -moz-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.xalign {
    position: absolute;
    left: 50%;
    -moz-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

/* Border */
.b0 {
    border: 0 !important;
}
.bt0 {
    border-top: 0 !important;
}
.bl0 {
    border-left: 0 !important;
}
.br0 {
    border-right: 0 !important;
}
.bb0 {
    border-bottom: 0 !important;
}

/* display */
.dp-flex {
    display: flex;
}
.dp-inflex {
    display: inline-flex;
}
.fl-basic {
    display: flex;
    align-items: center;
}
.jc-start {
    justify-content: flex-start;
}
.jc-center {
    justify-content: center;
}
.jc-sb {
    justify-content: space-between;
}
.jc-sa {
    justify-content: space-around;
}
.jc-se {
    justify-content: space-evenly;
}
.jc-end {
    justify-content: flex-end
}
.al-center {
    align-items: center;
}
.aI-start {
    align-items: flex-start;
}
.al-end {
    align-items: flex-end;
}
.fl-wrap {
    flex-wrap: wrap;
}
.fl-column {
    flex-direction: column;
}

/* Grid */
.grid {
    display: grid;
}
.grid-inline {
    display: inline-grid;
}
.grid2 {
    grid-template-columns: repeat(2, 1fr);
}
.grid3 {
    grid-template-columns: repeat(3, 1fr);
}
.grid4 {
    grid-template-columns: repeat(4, 1fr);
}
.grid5 {
    grid-template-columns: repeat(5, 1fr);
}
.grid6 {
    grid-template-columns: repeat(6, 1fr);
}
.grid7 {
    grid-template-columns: repeat(7, 1fr);
}
.grid8 {
    grid-template-columns: repeat(8, 1fr);
}
.gap-c80 {
    column-gap: vvar(--space-80);
}
.gap-c60 {
    column-gap: var(--space-60);
}
.gap-c50 {
    column-gap: var(--space-50);
}
.gap-c40 {
    column-gap: var(--space-40);
}
.gap-c30 {
    column-gap: var(--space-30);
}
.gap-c20 {
    column-gap: var(--space-20);
}
.gap-r80 {
    row-gap: var(--space-80);
}
.gap-r60 {
    row-gap: var(--space-60);
}
.gap-r50 {
    row-gap: var(--space-50);
}
.gap-r40 {
    row-gap: var(--space-40);
}
.gap-r30 {
    row-gap: var(--space-30);
}
.gap-r20 {
    row-gap: var(--space-20);
}
.gap80 {
    gap: var(--space-80)
}
.gap60 {
    gap: var(--space-60)
}
.gap40 {
    gap: var(--space-40)
}
.gap30 {
    gap: var(--space-30)
}
.gap20 {
    gap: var(--space-20)
}

/* box-shadow */
.shadow {
    -webkit-box-shadow: 0px 0px 40px 0px rgba(0,0,0,0.1);
    -moz-box-shadow: 0px 0px 40px 0px rgba(0,0,0,0.1);
    box-shadow: 0px 0px 40px 0px rgba(0,0,0,0.1);
}

/* 말줄임 */
.dot {
    text-overflow: ellipsis;
    white-space: nowrap;
    word-wrap: normal;
    overflow: hidden;
}
.ellipsis1 {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    word-break: normal;
}
.ellipsis2 {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    word-break: normal;
}
.ellipsis3 {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    word-break: normal;
}
.ellipsis4 {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    word-break: normal;
}

/* 효과 */
.effect1 {
    transition: all 0.2s linear;
    -webkit-transition: all 0.2s linear;
    -ms-transition: all 0.2s linear;
    -o-transition: all 0.2s linear;
    -moz-transition: all 0.2s linear;
}
.ready {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    height: 200px;
    font-weight: var(--fw-light);
    font-size: var(--font-16)
}

.pc {
    display: block;
}
.tablet1024,
.tablet768,
.mobile {
    display: none;
}
.reverse {
    display: none;
}
.onlyblock {
    display: block;
}
    @media all and (max-width:1200px) {
        .tablet1024 {
            display: block;
        }
        .reverse1024 {
            display: none;
        }
        .onlyblock {
            display: block;
        }
    }
    @media all and (max-width:1000px) {
        .tablet768 {
            display: block;
        }
        .reverse768 {
            display: none;
        }
        .onlyblock {
            display: block;
        }
    }
    @media all and (max-width:640px) {
        .pc {
            display: none;
        }
        .mobile,
        .reverse {
            display: block;
        }
        .mobileReverse {
            display: none !important;
        }
        .onlyblock {
            display: block;
        }
    }

/* 개인정보처리방침 */
.privacy h3 {
    font-weight: var(--fw-bold);
    padding: var(--space-40) 0 0;
    color: var(--color-dark);
}
.privacy h4 {
    margin-top:var(--space-20)
}
.en .privacy h3 {
    font-size: var(--font-16);
}
.privacy p,
.privacy th,
.privacy td,
.privacy li {
    color: var(--color-dark);
    line-height: 1.5;
    font-size: var(--font-15);
    font-weight: var(--fw-normal)
}
.privacy a {
    font-size: inherit;
    color: inherit;
    font-weight: inherit;
}
.privacy ul,
.privacy ol {
    margin-top: var(--space-10);
}
.privacy li > ol,
.privacy li > ul {
    margin-top: var(--space-5);
    margin-bottom: var(--space-10);
}
.privacy li {
    position: relative;
    margin-bottom: var(--space-5);
}
.privacy p {
    margin-top: var(--space-10);
}
.privacy .brace-list > li {
    padding-left: var(--space-20);
}
.privacy .line-list > li {
    padding-left: var(--space-10);
}
.privacy .hangul-list > li {
    padding-left: var(--space-20);
}
.privacy .number-list > li {
    padding-left: var(--space-20);
}
.privacy .brace-list > li::before,
.privacy .line-list > li::before,
.privacy .hangul-list > li::before,
.privacy .number-list > li::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    line-height: 1.4;
    font-size: inherit;
}
.privacy .hangul-list > li::before,
.privacy .number-list > li::before {
    line-height: 1.5;
}
.privacy .brace-list > li:nth-child(1)::before {
    content: "⑴";
}
.privacy .brace-list > li:nth-child(2)::before {
    content: "⑵";
}
.privacy .brace-list > li:nth-child(3)::before {
    content: "⑶";
}
.privacy .brace-list > li:nth-child(4)::before {
    content: "⑷";
}
.privacy .brace-list > li:nth-child(5)::before {
    content: "⑸";
}
.privacy .line-list > li::before {
    content: "-";
}
.privacy .hangul-list > li:nth-child(1)::before {
    content:"가.";
}
.privacy .hangul-list > li:nth-child(2)::before {
    content: "나.";
}
.privacy .hangul-list > li:nth-child(3)::before {
    content: "다.";
}
.privacy .hangul-list > li:nth-child(4)::before {
    content: "라.";
}
.privacy .hangul-list > li:nth-child(5)::before {
    content: "마.";
}
.privacy .number-list > li:nth-child(1)::before {
    content:"1.";
}
.privacy .number-list > li:nth-child(2)::before {
    content: "2.";
}
.privacy .number-list > li:nth-child(3)::before {
    content: "3.";
}
.privacy .number-list > li:nth-child(4)::before {
    content: "4.";
}
.privacy .number-list > li:nth-child(5)::before {
    content: "5.";
}
.privacy .table {
    margin:  var(--space-15) 0;
    border: var(--border);
    border-width: 1px 1px 0 1px;
}
.privacy .table td,
.privacy .table th {
    border-bottom: var(--border);
    text-align: left;
    padding: var(--space-5) var(--space-10);
}
.privacy .table td:first-child,
.privacy .table th:first-child {
    border-right: var(--border);
}
.privacy .table th {
    background-color: var(--color-gray);
}
    /* 이용약관 미디어쿼리 */
    @media all and (max-width:640px) {
        .privacy h3 {
            font-size: var(--font-16);
            padding: var(--space-30) 0 0
        }
        .privacy p,
        .privacy th,
        .privacy td,
        .privacy li,
        .privacy .brace-list > li::before, 
        .privacy .line-list > li::before,
        .privacy .hangul-list > li::before ,
        .privacy .number-list > li::before {
            font-size: var(--font-15)
        }
        .en .privacy p,
        .en .privacy th,
        .en .privacy td,
        .en .privacy li,
        .en .privacy .brace-list > li::before, 
        .en .privacy .line-list > li::before,
        .en .privacy .hangul-list > li::before ,
        .en .privacy .number-list > li::before {
            font-size: var(--font-14)
        }
    }
    
/* 네비게이션 영역 */
.breadcrumbs {
    height: var(--bc-space);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(30px); 
    border-radius: var(--border-radius);
    z-index: 20;
    overflow: visible;
    margin-top: auto;
    margin-bottom: var(--space-60);
    position: relative;
}
.breadcrumbs .home {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--bc-space);
    height: var(--bc-space);
    border-radius: 50%;
    background-color: var(--color-primary);
}
.breadcrumbs .home:hover {
    background-color: var(--color-hover);
}
.breadcrumbs .home img {
    width: clamp(8px, calc(12 / var(--inner) * 100vw), 12px);
}
.breadcrumb > li > a {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-16);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
}
.breadcrumbs .crumbs {
    position: relative;
    z-index: 5;
    padding-left: calc(var(--bc-space) + var(--space-20));
    padding-right: var(--space-30);
}
.breadcrumbs .crumbs.open {
    z-index: 30;
}
.breadcrumbs .crumbs-title {
    display: flex;
    align-items: center;
    height: 100%;
    cursor: pointer;
}
.breadcrumbs .crumbs-title strong {
    font-size: var(--font-16);
    color: var(--color-white);
    text-transform: uppercase;
}
.breadcrumbs .crumbs-title span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.breadcrumbs .crumbs-title span img {
    width: 8px;
    margin-left: var(--space-15)
}
    /* 네비게이션 > 드롭다운 메뉴 */
.breadcrumbs .dropdown {
    width: 100%;
    position: absolute;
    z-index: 100;
    left: 50%;
    top: var(--bc-space);
    transform: translateX(-50%);
    box-shadow: none;
}
.breadcrumbs .dropdown > li {
    visibility: hidden;
    height: 0;
    padding-top: 0;
    padding-bottom: 0;
    margin: 0;
    overflow: hidden;
    font-size: var(--font-14);
    cursor: pointer;
    white-space: nowrap;
    transition:
        0.3s height cubic-bezier(0.73, 0.32, 0.34, 1.5),
        0.3s padding cubic-bezier(0.73, 0.32, 0.34, 1.5),
        0.3s margin cubic-bezier(0.73, 0.32, 0.34, 1.5),
        0.3s 0.1s;
}
.breadcrumbs .crumbs.open .dropdown {
    pointer-events: auto;
    box-shadow: 0 3px 10px rgba(0,0,0,0.03), 0 3px 10px rgba(0,0,0,0.08);
}
.breadcrumbs .crumbs.open .dropdown > li {
    visibility: visible;
    height: clamp(30px, calc(40 / var(--inner) * 100vw), 40px);
}
.breadcrumbs .dropdown > li > a {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    font-size: var(--font-15);
    padding: 0 var(--space-10);
    background-color: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(30px);
}
.breadcrumbs .dropdown > li.on > a,
.breadcrumbs .dropdown > li:hover > a {
    background: var(--color-primary);
}
.breadcrumbs .dropdown > li.on > a,
.breadcrumbs .dropdown > li > a:hover {
    font-weight: var(--fw-bold);
    color: var(--color-white);
}
    /* PC: hover */
    @media all and (min-width: 1025px) {
        .breadcrumbs .crumbs:hover {
            z-index: 30;
        }
        .breadcrumbs .crumbs:hover .dropdown {
            box-shadow: 0 3px 10px rgba(0,0,0,0.03), 0 3px 10px rgba(0,0,0,0.08);
        }
        .breadcrumbs .crumbs:hover .dropdown > li {
            visibility: visible;
            height: clamp(30px, calc(40 / var(--inner) * 100vw), 40px);
        }
    }
    /* 모바일: click */
    @media all and (max-width: 1024px) {
        .breadcrumbs .crumbs.open {
            z-index: 30;
        }
        .breadcrumbs .crumbs.open .dropdown {
            box-shadow: 0 3px 10px rgba(0,0,0,0.03), 0 3px 10px rgba(0,0,0,0.08);
        }
        .breadcrumbs .crumbs.open .dropdown > li {
            visibility: visible;
            height: clamp(30px, calc(40 / var(--inner) * 100vw), 40px);
        }
    }

/* 카카오 지도 */
.root_daum_roughmap {
    width:100% !important;
    height: 100% !important;
}
.root_daum_roughmap .wrap_map {
    height: 100% !important;
}
.root_daum_roughmap .border1,
.root_daum_roughmap .border2,
.root_daum_roughmap .border3,
.root_daum_roughmap .border4 {
    display: none !important;
}