@import url("https://fastly.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css");
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.2/css/all.min.css');
@import url("https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200");

:lang(ko) {
    word-break: keep-all;
}
:root {
    /* 기본컬러 */
    --gray-100: #F2F2F2;
    --gray-200: #D9D9D9;
    --gray-300: #cccccc;
    --gray-400: #999999;
    --gray-500: #666666;
    --gray-600: #444444;
    --gray-700: #1F1F1F;

    --white: #ffffff;
    --red: #E31818;
    --blue: #326BFF;
    --dark: #232323;

    /* 키컬러 */
    --primary: #F99634;
    --primary-gradient: #F99634, #FF6A00;
    
    /* 배경컬러 */
    --primary-bg: #F5EFE9;
    /* --primary-bg-light: #f9963412; */
    --primary-bg-light: #FAF6F0;
    --bg: var(--white);
    --bg-white: var(--white);
    --bg-dark: var(--dark);
    
    /* 상태컬러 */
    --success: #1C9F62;
    --error: #FF0000;
    --checked: var(--primary);
    
    /* 멤버십컬러*/
    --pro-bg: #F4F0FA;
    --pro-gradient: #3490F9, #F934BE;

    /* 티어컬러*/
    --tier-bronze: #AD5630;
    --tier-silver: #9E9E9E;
    --tier-gold: #E3AE34;
    --tier-platinum: #60B5C5;
    --tier-diamond: #4DA3FF;
    --tier-master: #8B5CF6;
    --tier-grandmaster: #DC2626;
    --tier-challenger: #FF6A00;


    /* 설정컬러 */
    --tag: #3384E2;
    --shadow: 0 4px 20px 0 rgba(0, 0, 0, 0.08);
    --dark-line: var(--gray-200);
    --dimd: var(--black-700);

    --white-50: rgba(255, 255, 255, .05);
    --white-100: rgba(255, 255, 255, .1);
    --white-200: rgba(255, 255, 255, .2);
    --white-300: rgba(255, 255, 255, .3);
    --white-400: rgba(255, 255, 255, .4);
    --white-500: rgba(255, 255, 255, .5);
    --white-600: rgba(255, 255, 255, .6);
    --white-700: rgba(255, 255, 255, .7);
    --white-800: rgba(255, 255, 255, .8);
    --white-900: rgba(255, 255, 255, .9);

    --black-50: rgba(0, 0, 0 , .05);
    --black-100: rgba(0, 0, 0 , .1);
    --black-200: rgba(0, 0, 0 , .2);
    --black-300: rgba(0, 0, 0 , .3);
    --black-400: rgba(0, 0, 0 , .4);
    --black-500: rgba(0, 0, 0 , .5);
    --black-600: rgba(0, 0, 0 , .6);
    --black-700: rgba(0, 0, 0 , .7);
    --black-800: rgba(0, 0, 0 , .8);
    --black-900: rgba(0, 0, 0 , .9);

    

    --radius-lg: 20px;
    --radius-md: 16px;
    --radius-sm: 10px;
    --radius-xs: 6px;
    --border-radius: var(--radius-lg);
    --page-gap: 180px;
    --sec-gap: 150px;
    --gap: 20px; 
    --content-gap: 40px;

    --container-sm: 1000px;
    --container-md: 1240px; 
    --container-lg: 1600px;

    --font-family: "Pretendard Variable", Pretendard, -apple-system, sans-serif;

    --ft12: 0.75rem; 
    --ft13: 0.8125rem; 
    --ft14: 0.875rem;
    --ft15: 0.938rem;
    --ft16: 1rem;
    --ft18: 1.125rem;
    --ft20: 1.25rem;
    --ft22: 1.375rem;
    --ft24: 1.5rem;
    --ft26: 1.625rem;
    --ft28: 1.75rem;
    --ft30: 1.875rem;
    --ft32: 2rem;
    --ft35: 2.188rem;
    --ft36: 2.25rem;
    --ft40: 2.5rem;
    --ft45: 2.813rem;
    --ft48: 3rem;
    --ft50: 3.125rem;
    --ft56: 3.5rem;
    --ft60: 3.75rem;
    --ft70: 4.375rem;
    --ft80: 5rem;
    --ft100: 6.25rem;
    --ft150: 9.375rem;
    

    --thin: 100;
    --extra-light:200;
    --light: 300;
    --normal: 400;
    --medium: 500;
    --semi-bold: 600;
    --bold: 700;
    --extra-bold: 800;
    --black: 900;

    --swiper-pagination-bullet-size: 6px;
    --swiper-pagination-bullet-inactive-color: var(--gray-700);
    
}
body.dark {
    /* 기본컬러 */
   
    /* --gray-100: #3a342f; */
    --gray-100: #47433e;
    --gray-200: #615c57;
    --gray-300: #726e6a;
    --gray-400: #8d8983;
    --gray-500: #b8b2ad;
    --gray-600: #d3cdc7;
    --gray-700: #f5f2f0;

    --dark: #ffffff;
    --red: #E31818;
    --blue: #326BFF;
    --white: #232323;

    /* 키컬러 */
    --primary: #F99634;
    --primary-gradient: #F99634, #FF6A00;
    
    /* 배경컬러 */
    --primary-bg: #3b2e22;
    --primary-bg-light: #3f3329;
    --bg: #302B28;
    --bg-white: var(--dark);
    --bg-dark: var(--white);
    
    /* 멤버십컬러*/
    --pro-bg: #443C4E;
    --pro-gradient: #3490F9, #F934BE;
    --premium-gradient: #F99634, #FF6A00;


    /* 상태컬러 */
    --success: #22C55E;
    --error: #FF4D4F;
    --checked: var(--primary);

    /* 설정컬러 */
    --shadow: 0 4px 20px rgba(0, 0, 0, 0.45);
    --dark-line: var(--gray-200);
    --dimd: var(--black-400);

    --black-50: rgba(255, 255, 255, .05);
    --black-100: rgba(255, 255, 255, .1);
    --black-200: rgba(255, 255, 255, .2);
    --black-300: rgba(255, 255, 255, .3);
    --black-400: rgba(255, 255, 255, .4);
    --black-500: rgba(255, 255, 255, .5);
    --black-600: rgba(255, 255, 255, .6);
    --black-700: rgba(255, 255, 255, .7);
    --black-800: rgba(255, 255, 255, .8);
    --black-900: rgba(255, 255, 255, .9);
    

    --white-50: rgba(35, 35, 35, .05);
    --white-100: rgba(35, 35, 35, .1);
    --white-200: rgba(35, 35, 35, .2);
    --white-300: rgba(35, 35, 35, .3);
    --white-400: rgba(35, 35, 35, .4);
    --white-500: rgba(35, 35, 35, .5);
    --white-600: rgba(35, 35, 35, .6);
    --white-700: rgba(35, 35, 35, .7);
    --white-800: rgba(35, 35, 35, .8);
    --white-900: rgba(35, 35, 35, .9);

    --swiper-pagination-bullet-inactive-color: var(--gray-700);
    
}

.material-symbols-outlined,
.material-symbols-rounded {
    user-select: none;
    font-variation-settings:
        'FILL' 0,
        'wght' 400,
        'GRAD' 0,
        'opsz' 24, 
        'color' var(--gray-600),
}
.material-symbols-outlined.xsm,
.material-symbols-rounded.xsm {
    font-variation-settings:
        'FILL' 0,
        'wght' 400,
        'GRAD' 0,
        'opsz' 14,
}

.margin_btm {margin-bottom: 16px;}
.overflow {overflow: hidden;}

.ellipsis {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ellipsis.line2 {
    white-space: wrap;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}
.ellipsis.line3 {
    white-space: wrap;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}
.ellipsis.line4 {
    white-space: wrap;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
}

/* scrollbar */
::selection {
    background-color: var(--primary);
    color: white;
}
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
::-webkit-scrollbar-thumb {
    background-color: var(--gray-400);
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
    background-color: var(--primary);
}
* {
    margin: 0;
    padding: 0;
    line-height: 1.4;
    box-sizing: border-box;
    color: var(--gray-600);
    font-family: var(--font-family);
    font-style: normal;
}
html,
body {
    font-size: 16px;
}
body {
    width: 100%;
    font-weight: 400;
    letter-spacing: -1;
    color: var(--gray-600);
    background: var(--bg);
}
img {
    display: block;
    margin: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    user-select: none;
}
a {
    text-decoration: none;
    color: inherit;
    width: 100%; height: 100%;
    display: block;
}
ul,
ol,
li {
    margin: 0;
    list-style: none;
}

i.icon {
    display: block;
}

h1,
.h1_title {
    color: var(--gray-600);
    font-weight: var(--semi-bold);
    font-size: var(--ft100);
    line-height: 1.2;
    white-space: pre-line;
}
h2 {
    font-size: var(--ft40);
    font-weight: var(--semi-bold);
    color: var(--gray-600);
    /* line-height: 1.4; */
    white-space: pre-line;
}

h3 {
    font-size: var(--ft32);
    color: var(--gray-600);
    /* line-height: 1.2; */
    white-space: pre-line;
}

h4 {
    font-size: var(--ft24);
    color: var(--gray-600);
}

h5 {
    font-size: var(--ft20);
    color: var(--gray-600);
}

p {
    font-size: var(--ft16);
    color: var(--gray-600);
    white-space: pre-line;
}
span {
    color: inherit;
}
strong {
    font-weight: normal;
    color: var(--primary);
}

/* layout */
.wrap {
    width: 100%;
    margin: 0 auto;
    position: relative;
    /* overflow: hidden; */
}
section {
    width: 100%;
    position: relative;
}
footer {
    width: 100%;
    overflow: hidden;
}
.page {
    overflow: hidden;
    margin: 0 auto;
}
.page.pagemb {
    margin-bottom: 180px;
}
.container,
.container_sm,
.container_lg,
.container_md {
    width: 100%;
    margin: 0 auto;
    position: relative;
}
.container {
    max-width: calc(100% - 40px);
}
.container_sm {
    max-width: var(--container-sm);
}
.container_md {
    max-width: var(--container-md);
}
.container_lg {
    max-width: var(--container-lg);
}
/* font */
.text-center {
    text-align: center;
}
.text-right {
    text-align: right;
}
/* layout */
.grid {
    width: 100%;
    display: grid;
    gap: var(--grid-gap);
}
.grid.col-2 {
    grid-template-columns: repeat(2, 1fr);
}
.grid.col-3 {
    grid-template-columns: repeat(3, 1fr);
}
.grid.col-4 {
    grid-template-columns: repeat(4, 1fr);
}
.grid.col-5 {
    grid-template-columns: repeat(5, 1fr);
}
.align-end {
    align-items: flex-end;
}
.align-start {
    align-items: flex-start;
}
.align-center {
    align-items: center;
}
.align-strech {
    align-items: stretch;
}
.justify-end {
    justify-content: flex-end;
}
.justify-start {
    justify-content: flex-start;
}
.justify-between {
    justify-content: space-between;
}
.justify-strech {
    justify-content: stretch;
}
.justify-center {
    justify-content: center;
}
.unique_ft {
    font-family: var(--unique-ft);
}
.underline {
    text-decoration: underline;
}
.icon_lg {
    font-size: 40px;
}

/* button */
button {
    border-radius: 10px;
    outline: none;
    border: 0;
    font-family: inherit;
    background: unset;
    cursor: pointer;
}


/* select, input, textarea */
select,
input,
input[type="text"],
input[type="number"],
input[type="password"],
textarea {
    border-radius: 0;
    padding: 0;
    border: 0;
    height: var(--input-height);
    background: none;
    font-family: inherit;
    font-size: 16px;
    resize: vertical;
}
select:focus,
input:focus,
input[type="text"]:focus,
input[type="number"]:focus,
input[type="password"]:focus,
textarea:focus {
    outline: none;
    /* outline: 1px solid var(--primary); */
}

input[type="search"] {
    -webkit-appearance: textfield; 
}
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button {
    display: none; 
}
select {
    appearance: none;
    padding-right: 34px;
    background: url('/images/arrow_drop_down.svg') no-repeat 94% 50%/20px auto;
}
select.white {
    background: url('/images/arrow_drop_down_white.svg') no-repeat 94% 50%/20px auto;
}
select option:hover {
    background-color: var(--primary);
}
select.under_line {
    background-position: 100% 50%;
}

input::placeholder,
textarea::placeholder {
    color: var(--gray-400);
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    appearance: none;
    display: none;
}
.search__box {
    position: relative;
}
.search__input {
    padding-right: 44px !important;
}
.search__btn {
    position: absolute;
    cursor: pointer;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    pointer-events: auto;
    display: flex;
    align-items: center;
    justify-content: center;
}
.search__btn .icon {
    transition: .3s ease;
    transform-origin: center;
}
.check_box {
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
}
input[type="checkbox"],
input[type="radio"] {
    display: none;    
}
.checkbox_group label,
.radio_group label {
    display: block;
    position: relative;
    cursor: pointer;
}
.checkbox_group label > span,
.radio_group label > span {
    display: block;
    width: 16px;
    height: 16px;
    border: 1px solid var(--gray-500);
    border-radius: 50%;
    background-color: white;
    position: relative;
    transition: border .3s ease;
}
.checkbox_group label > span::after,
.radio_group label > span::after {
    content: '';
    display: block;
    width: 6px;
    height: 6px;
    background-color: var(--gray-500);
    border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0);
    transition: transform .3s ease;
}
.checkbox_group input:checked ~  label > span::after,
.radio_group input:checked ~  label > span::after {
    transform: translate(-50%, -50%) scale(1);
}

/* pagination */
.pagination {
    margin-top: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.pagination .pagination_btn {
    width: 32px;
    height: 32px;
}
.pagination .pagination_btn a {
    display: flex;
    justify-content: center;
    align-items: center;
}
.pagination ul {
    display: flex;
    gap: 10px;
    padding: 0 10px;
}
.pagination ul li {
    width: 30px;
    height: 30px;
    border-radius: var(--radius-sm);
}
.pagination ul li a {
    font-size: var(--ft16);
    color: var(--gray-500);
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}
.pagination i {
    font-size: var(--ft14);
    color: var(--gray-500);
}
.pagination span {
    font-size: var(--ft18);
    color: var(--gray-500);
}
.pagination ul li:hover,
.pagination ul li.page_click {
    background-color: var(--primary);
}
.pagination ul li:hover a,
.pagination ul li.page_click a {
    color: white;
}


/* table */
table {
    border-collapse: collapse;
}
.table {
    width: 100%;
}

/* datepicker */
.ui-datepicker {
    display: none;
    background-color: var(--white);
    border-radius: var(--radius-md);
    margin-top: 10px;
    margin-left: 0px;
    margin-right: 0px;
    padding: 12px;
    padding-bottom: 10px;
    width: 300px;
    box-shadow: 10px 10px 40px rgba(0, 0, 0, 0.1);
}
.ui-widget.ui-widget-content {
    border-color: var(--dark-line);
}
.ui-datepicker-header {
    height: 45px;
    border: none;
    border-radius: var(--radius-md);
    background-color: var(--gray-100);
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
    width: 20px;
    height: 20px;
    background-color: var(--white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
}
.ui-datepicker .ui-datepicker-prev {
    left: 10px;
}
.ui-datepicker .ui-datepicker-next {
    right: 10px;
}
.ui-datepicker .ui-icon {
    text-indent: 0;
}
.ui-datepicker .ui-datepicker-prev .ui-icon,
.ui-datepicker .ui-datepicker-next .ui-icon {
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    margin: 0;
    opacity: .5;
    transition: opacity .4s ease;
}
.ui-datepicker .ui-datepicker-prev .ui-icon {
    background: url('/images/icon/prev.svg') no-repeat center / contain;
}
.ui-datepicker .ui-datepicker-next .ui-icon {
    background: url('/images/icon/next.svg') no-repeat center / contain;
}
.ui-datepicker .ui-datepicker-prev:hover,
.ui-datepicker .ui-datepicker-next:hover {
    border: none;
}
.ui-datepicker .ui-datepicker-prev:hover .ui-icon,
.ui-datepicker .ui-datepicker-next:hover .ui-icon  {
    opacity: 1;
}
/* .ui-datepicker .ui-datepicker-prev i,
.ui-datepicker .ui-datepicker-next i {
    width: 100%;
    height: 100%;
    font-size: 12px;
    color: var(--gray-500);
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: .5;
    transition: opacity .4s ease;
}
.ui-datepicker .ui-datepicker-prev:hover,
.ui-datepicker .ui-datepicker-next:hover {
    border: none;
}
.ui-datepicker .ui-datepicker-prev:hover i,
.ui-datepicker .ui-datepicker-next:hover i {
    opacity: 1;
} */

.ui-datepicker .ui-datepicker-title {
    margin: 0 0em;
    line-height: 16px;
    text-align: center;
    font-size: 14px;
    padding: 0px;
    font-weight: bold;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
}
.ui-datepicker select {
    padding-right: 24px;
    background: url(/images/arrow_drop_down.svg) no-repeat 94% 50% / 14px auto;
    color: var(--gray-600);
}
.ui-datepicker select.ui-datepicker-year {
    width: 80px;
}
.ui-datepicker select.ui-datepicker-month {
    width: 60px;
}
#datepicker:focus>.ui-datepicker {
    display: block;
}



.ui-state-disabled {
    cursor: auto;
    color: hsla(0, 0%, 80%, 1);
}

.ui-datepicker table {
    margin-top: 10px;
}
.ui-state-default {
    border: none !important;
    border-radius: 6px;
}
.ui-datepicker-calendar>thead>tr>th {
    padding: 5px;
    font-size: var(--ft12);
    font-weight: 400;
}
.ui-datepicker-calendar>tbody>tr>td {
    cursor: pointer;
    padding: 4px;
    font-size: 12px;
    font-weight: 100;
    text-align: center;
    aspect-ratio: 1 / 1;
}
.ui-datepicker-calendar>tbody>tr>td>a {
    background-color: var(--gray-100) !important;
    font-size: var(--ft13) !important;
    font-weight: bold !important;
    color: var(--gray-600) !important;
    text-decoration: none;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ui-state-active,
.ui-widget-content .ui-state-active,
.ui-widget-header .ui-state-active,
a.ui-button:active,
.ui-button:active,
.ui-button.ui-state-active:hover {
    color: white !important;
    background-color: var(--primary) !important;
}

.ui-state-hover {
    background-color: var(--light-hover);
}

.ui-state-highlight,
.ui-widget-content .ui-state-highlight,
.ui-widget-header .ui-state-highlight {
    border: none;
    background-color: var(--gray-300) !important;
}

.inp {
    padding: 10px 10px;
    background-color: #f1f1f1;
    border-radius: 4px;
    border: 0px;
}

.ui-state-active {
    background: #ff3307;
}

.inp:focus {
    outline: none;
    background-color: #eee;
}

@media all and (max-width: 1800px) {
    .container_lg,
    .container_md {
        padding: 0 60px;
    }
}

@media all and (max-width: 1400px) {
    :root {
        --sec-gap : 140px;
    }
}

@media all and (max-width: 1280px) {
    .container_sm {
        padding: 0 40px;
    }
}

@media all and (max-width: 1200px) {
    :root {
        --page-gap: 140px;
    }
    html {
        font-size: 15px;
    }

    .container_lg,
    .container_md {
        padding: 0 40px;
    }
}
@media all and (max-width: 768px) {
    :root {
        --radius-lg: 12px;
        --radius-md: 10px;
        --radius-sm: 8px;
        --radius-xs: 6px;

        --sec-gap : 80px;
        --page-gap: 100px;
    }
    html, body {
        font-size: 14px;
    }

    select, 
    input, 
    input[type="text"], 
    input[type="number"], 
    input[type="password"], 
    textarea {
        transform: scale(0.875);
        transform-origin: left;
    }

    .container_lg,
    .container_md,
    .container_sm {
        padding: 0 16px;
    }
    .pagination {
        margin-top: 50px;
    }
    .container {
        max-width: calc(100% - 20px);
    }

    .pagination .pagination_btn {
        width: 28px;
        height: 28px;
    }
    .pagination ul li {
        width: 28px;
        height: 28px;
    }
}

/* hover */
@media (hover:hover) {
    /* input, select, textarea */
    input[type="text"]:hover,
    input[type="number"]:hover,
    input[type="password"]:hover,
    textarea:hover,
    select:hover {
        background-color: none;
        /* background-color: var(--input-hover); */
    }
    input[type="text"].out_line:hover,
    input[type="number"].out_line:hover,
    input[type="password"].out_line:hover,
    textarea.out_line:hover,
    select.out_line:hover {
        background-color: transparent;
        border-color: var(--gray-400);
    }
    .search__btn:hover .icon {
        transform: rotateZ(-15deg);
    }
    
    
    /* pagination */
    .pagination li:hover {
        background-color: var(--btn-hover);
    }

    /* table */
    .table__item:hover {
        background-image: var(--list-hover);
    }
    
    
}

@font-face {
    font-family: 'Material Icons';
    font-style: normal;
    font-weight: 400;
    src: url(https://example.com/MaterialIcons-Regular.eot); /* For IE6-8 */
    src: local('Material Icons'),
      local('MaterialIcons-Regular'),
      url(https://example.com/MaterialIcons-Regular.woff2) format('woff2'),
      url(https://example.com/MaterialIcons-Regular.woff) format('woff'),
      url(https://example.com/MaterialIcons-Regular.ttf) format('truetype');
}

.material-symbols-outlined {
  font-variation-settings:
  'FILL' 0,
  'wght' 400,
  'GRAD' 0,
  'opsz' 24
}

.material-icons {
font-family: 'Material Icons';
font-weight: normal;
font-style: normal;
font-size: 24px;  /* Preferred icon size */
display: inline-block;
line-height: 1;
text-transform: none;
letter-spacing: normal;
word-wrap: normal;
white-space: nowrap;
direction: ltr;

/* Support for all WebKit browsers. */
-webkit-font-smoothing: antialiased;
/* Support for Safari and Chrome. */
text-rendering: optimizeLegibility;

/* Support for Firefox. */
-moz-osx-font-smoothing: grayscale;

/* Support for IE. */
font-feature-settings: 'liga';
}
.sr_only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
}