@charset "utf-8";


@font-face {
    font-family: 'TheJamsil5Bold';
    src: url('https://cdn.jsdelivr.net/gh/fontbee/font@main/LOTTE/TheJamsil5Bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: 'TheJamsil4Medium';
    src: url('https://cdn.jsdelivr.net/gh/fontbee/font@main/LOTTE/TheJamsil2Light.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
}


html,
body {
    height: 100%;
    min-height: 100vh;
    min-height: 100dvh;
    overscroll-behavior: none;
}

#wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    min-height: 100vh;
    min-height: 100dvh;
}

.content {
    max-width: 390px;
    width: 100%;
    height: 800px;
    border: 1px solid #1D1D19;
    position: relative;
}

.section {
    padding: 40px 20px;
}

.flex {
    display: flex;
    flex-wrap: wrap;
}

/* cover */
.cover_section {
    align-items: center;
    justify-content: center;
    height: 100%;
    background: #1D1D19;
}


/* main */
.section_wrapper {
    height: calc(100% - 60px - 73.5px);
    background: #EFEFF1;
    overflow-y: auto;
    position: relative;
}

.p_18 {
    color: #000;
    /* font-family: Pretendard; */
    font-size: 18px;
    font-style: normal;
    line-height: 150%;
}

.w500 {
    font-weight: 500 !important;
}

.p_12 {
    color: #000;
    /* font-family: Pretendard; */
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
}

.c888 {
    color: #888 !important;
}

.selected_box {
    flex-direction: column;
    gap: 20px;
    padding: 20px;
    align-items: center;
    justify-content: center;
    /* border-radius: 12px; */
    /* background: linear-gradient(180deg, #EEEDEC 0%, #E6E5E4 100%); */

    border-radius: 24px;
    background: #E8E8EB;

    cursor: pointer;
    width: 100%;
}

.selected_tit {
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 30px;
}

.selected_tit.flex p {
    width: calc(100% - 55.94px - 30px);
    overflow: hidden !important;
    white-space: normal !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 1 !important;
    line-clamp: 1 !important;
    -webkit-box-orient:
        vertical !important;
    word-break: break-word;

}

.p_14 {
    color: #000;
    /* font-family: Pretendard; */
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
}

.select_badge {
    border-radius: 6px;
    background: #F4F3F2;
    color: #666;
    /* font-family: Pretendard; */
    font-size: 10px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    padding: 4px 10px;
}

.location_date_box {
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.location_icon_box,
.date_icon_box {
    align-items: center;
    gap: 5px;
}

.p_10 {
    color: #000;
    /* font-family: Pretendard; */
    font-size: 10px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}

.c666 {
    color: #666;
}

.mt12 {
    margin-top: 12px;
}

.black_list {
    align-items: stretch;
    gap: 10px;
    row-gap: 12px;
}

.black_list li {
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(29, 29, 25, 0.80) 0%, #1D1D19 100%);
    align-items: center;
    gap: 5px;
    cursor: pointer;
    color: #FFF;
    /* font-family: Pretendard; */
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0;
    padding: 22px;
    width: calc(50% - 5px);
}


@media all and (max-width:1100px) {
    html,
    body {
        height: 100%;
        min-height: 100vh;
        min-height: 100dvh;
        background: #F4F3F2;
    }

    #wrap {
        align-items: flex-start;
        min-height: 100vh;
        min-height: 100dvh;
        height: auto;
        background: #F4F3F2;
    }

    .content {
        max-width: unset;
        width: 100%;
        height: auto;
        min-height: 100vh;
        min-height: 100dvh;
        border: unset;
        background: #F4F3F2;
    }

    .section_wrapper {
        height: auto;
        min-height: calc(100vh - 60px - 73.5px);
        min-height: calc(100dvh - 60px - 73.5px);
        background: #F4F3F2;
        overflow-y: visible;
        -webkit-overflow-scrolling: auto;
        padding: 60px 0 73.5px 0;
    }

    /* 로그인 페이지: 헤더/푸터 없으므로 패딩 제거 */
    body.login .section_wrapper {
        min-height: 100vh;
        min-height: 100dvh;
        padding: 0;
        background: #EFEFF1;
    }

    body.login .content,
    body.login #wrap,
    body.login {
        background: #EFEFF1;
    }

}

/* 태블릿(iPad 등) 전용: 미디어 쿼리 범위를 벗어나는 iPad Pro 13"(1032px) 대응 */
html.is-tablet,
body.is-tablet {
    height: 100%;
    min-height: 100vh;
    min-height: 100dvh;
    background: #F4F3F2;
}

html.is-tablet #wrap,
body.is-tablet #wrap {
    display: block;
    align-items: stretch;
    justify-content: stretch;
    min-height: 100vh;
    min-height: 100dvh;
    height: auto;
    width: 100%;
    max-width: unset;
    background: #F4F3F2;
}

html.is-tablet .content,
body.is-tablet .content {
    max-width: unset;
    width: 100%;
    height: auto;
    min-height: 100vh;
    min-height: 100dvh;
    border: unset;
    background: #F4F3F2;
}

html.is-tablet .section_wrapper,
body.is-tablet .section_wrapper {
    height: auto;
    min-height: calc(100vh - 60px - 73.5px);
    min-height: calc(100dvh - 60px - 73.5px);
    background: #F4F3F2;
    overflow-y: visible;
    -webkit-overflow-scrolling: auto;
    padding: 60px 0 73.5px 0;
}

body.is-tablet.login .section_wrapper {
    min-height: 100vh;
    min-height: 100dvh;
    padding: 0;
    background: #EFEFF1;
}

body.is-tablet.login .content,
body.is-tablet.login #wrap,
body.is-tablet.login {
    background: #EFEFF1;
}


.location_icon_box.main {
    gap: 30px;
}



/* 20251224 추가 */

/* CSS */
.main_quick {
    width: 100%;
    padding: 8px 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    box-sizing: border-box;
}

/* 상단 그리드 */
.main_quick .top_grid {
    display: flex;
    gap: 8px;
}

/* Hub 박스 */
.main_quick .hub_box {
    flex: 1;
    padding: 16px;
    background: #F6F6F6;
    border-radius: 24px;
    border: 0.5px solid rgba(255, 255, 255, 0.60);
    background: #F6F6F6;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.main_quick .hub_box h3 {
    color: #161614;
    font-family: "TheJamsil5Bold";
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
    /* 27px */
    /* 27px */
    margin: 0;
}

.main_quick .hub_list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.main_quick .hub_item {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
}

.main_quick .hub_item .icon_wrap {
    width: 35px;
    height: 35px;
    background: #EDEDED;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.main_quick .hub_item span {
    flex: 1;
    color: #161614;
    font-family: "TheJamsil4Medium";
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
}

.main_quick .hub_item .arrow {
    width: 4px;
    height: 8px;
}

/* 오른쪽 컬럼 */
.main_quick .right_col {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* 프로젝트 */
.main_quick .project_box {
    height: 163.5px;
    aspect-ratio: 1 / 1;
    padding: 12px 16px;
    border-radius: 24px;
    border: 1px solid rgba(255, 255, 255, 0.60);
    background: #D7FF01;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.main_quick .project_box.empty {
    background: #F6F6F6;
    align-items: center;
    justify-content: center;
}

.main_quick .project_box.empty p {
    color: #888888;
    font-size: 14px;
    font-family: 'Pretendard', sans-serif;
    margin: 0;
}

.main_quick .project_box .tag {
    color: #161614;
    font-family: "TheJamsil4Medium";

    opacity: 0.6;
    font-size: 10px;
    font-style: normal;
    font-weight: 300;
    line-height: normal;
    margin: 0;
}

.main_quick .project_box h4 {
    color: #161614;
    font-family: "TheJamsil5Bold";
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 20px;
    /* 142.857% */
    margin: 0;

    overflow: hidden !important;
    white-space: normal !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    line-clamp: 3 !important;
    -webkit-box-orient:
        vertical !important;
    word-break: break-word;
}

.main_quick .project_box .info_wrap {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.main_quick .project_box .info {
    display: flex;
    align-items: center;
    gap: 5px;
    opacity: 0.6;
}

.main_quick .project_box .info img {
    width: 10px;
    height: 10px;
}

.main_quick .project_box .info span {
    color: #161614;
    font-family: "TheJamsil4Medium";
    font-size: 10px;
    font-style: normal;
    font-weight: 300;
    line-height: normal;
}

/* QR */
.main_quick .qr_box {
    flex: 1;
    padding: 16px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.40);
    background: #363636;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-decoration: none;
    height: 60px;
}

.main_quick .qr_box img {
    width: 20px;
    height: 20px;
}

.main_quick .qr_box span {
    color: #FFF;
    font-family: "TheJamsil5Bold";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}

/* 안전교육 */
.main_quick .certificate {
    padding: 16px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.40);
    background: #363636;
    display: flex;
    justify-content: space-between;
    align-items: center;
    /* margin-bottom: -10px; */
}

.main_quick .certificate .cert_info {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.main_quick .certificate h4 {
    color: #FFF;
    font-family: "TheJamsil5Bold";
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    margin: 0;
}

.main_quick .certificate .dates {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.main_quick .certificate .dates p {
    color: #AAA;
    font-family: "TheJamsil4Medium";
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    margin: 0;
}

.main_quick .certificate .dates a {
    color: #D3FB00;
}

.main_quick .certificate .dday {
    color: #D7FF01;
    font-family: "TheJamsil5Bold";
    font-size: 28px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
}

/* 빠른메뉴 */
.main_quick .quick_grid {
    display: flex;
    gap: 10px;
}

.main_quick .quick_card {
    flex: 1;
    height: 105px;
    padding: 10px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.60);
    background: #363636;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-end;
    text-decoration: none;
}

.main_quick .quick_card .badge {
    width: 30px;
    height: 30px;
    background: #D3FB00;
    border-radius: 50%;
    box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
}

.main_quick .quick_card .badge img {
    width: 6px;
    height: 6px;
}

.main_quick .quick_card .icon {
    align-self: flex-start;
}

.main_quick .quick_card .icon img {
    width: 20px;
    height: 20px;
}

.main_quick .quick_card h5 {
    /* align-self: flex-start; */
    color: #FFF;
    font-family: "TheJamsil5Bold";
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    text-align: center;
    margin: 0 auto;
}

/* 메뉴 */
.main_quick .menu_wrap {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.main_quick .menu_item {
    padding: 16px;
 border-radius: 16px;
border: 1px solid rgba(255, 255, 255, 0.60);
background: #F6F6F6;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-decoration: none;
}

.main_quick .menu_item span {
color: #161614;
font-family: "TheJamsil5Bold";
font-size: 14px;
font-style: normal;
font-weight: 400;
line-height: normal;
}

.main_quick .menu_item .badge {
    width: 30px;
    height: 30px;
background: #363636;
    border-radius: 50%;
    box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
}

/* .main_quick .menu_item .badge img {
    width: 6px;
    height: 6px;
} */

/* 반응형 */
/* @media (max-width: 768px) {
    .main_quick .top_grid {
        flex-direction: column;
    }

    .main_quick .quick_grid {
        flex-direction: column;
    }

    .main_quick .quick_card {
        height: 80px;
    }
} */

/* 20260121 추가 - 새로운 메인 레이아웃 */
.main_content_wrapper {
    align-self: stretch;
    width: 100%;
    /* padding: 8px 20px; */
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* 프로젝트 카드 */
.project_card {
    align-self: stretch;
    height: 90px;
    padding: 16px;
    background: #D7FF01;
    overflow: hidden;
    border-radius: 16px;
    outline: 1px rgba(255, 255, 255, 0.60) solid;
    outline-offset: -1px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    gap: 6px;
}

.project_card.empty {
    justify-content: center;
}

.project_card_title {
    align-self: stretch;
    color: #161614;
    font-size: 18px;
    font-family: 'The Jamsil OTF', 'TheJamsil5Bold', sans-serif;
    font-weight: 500;
    line-height: 20px;
    word-wrap: break-word;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
}

.project_card_title.empty {
    font-size: 16px;
    font-weight: 400;
    text-align: center;
}

.project_card_info_row {
    align-self: stretch;
    display: inline-flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 4px;
}

.project_card_info_item {
    opacity: 0.60;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 5px;
}

.project_card_info_item .icon {
    width: 12px;
    height: 12px;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.project_card_info_item .icon img,
.project_card_info_item .icon svg {
    width: 100%;
    height: 100%;
}

.project_card_info_item .text {
    color: #161614;
    font-size: 10px;
    font-family: 'The Jamsil OTF', 'TheJamsil4Medium', sans-serif;
    font-weight: 400;
    word-wrap: break-word;
}

/* 안전교육 수료증 카드 */
.safety_cert_card {
    align-self: stretch;
    padding: 16px;
    background: #363636;
    overflow: hidden;
    border-radius: 16px;
    outline: 1px rgba(255, 255, 255, 0.40) solid;
    outline-offset: -1px;
    display: flex;
    flex-direction: column;
}

.safety_cert_header {
    align-self: stretch;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}

.safety_cert_header h4 {
    color: white;
    font-size: 18px;
    font-family: 'The Jamsil OTF', 'TheJamsil4Medium', sans-serif;
    font-weight: bold;
    word-wrap: break-word;
    margin: 0;
}

.safety_cert_content {
    align-self: stretch;
    display: flex;
    flex-direction: column;
}

.safety_cert_expire {
    align-self: stretch;
    padding-top: 8px;
    padding-bottom: 8px;
    border-bottom: 1px rgba(199, 199, 199, 0.30) solid;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.safety_cert_expire_row {
    align-self: stretch;
    display: inline-flex;
    justify-content: space-between;
    align-items: center;
}

.safety_cert_expire_text {
    color: #D6D6D6;
    font-size: 14px;
    font-family: 'The Jamsil OTF', 'TheJamsil4Medium', sans-serif;
    font-weight: 400;
    word-wrap: break-word;
}

.safety_cert_dday {
    text-align: right;
    color: #D7FF01;
    font-size: 28px;
    font-family: 'The Jamsil OTF', 'TheJamsil5Bold', sans-serif;
    font-weight: 700;
    word-wrap: break-word;
}

/* 퀵 메뉴 행 */
.quick_menu_row {
    align-self: stretch;
    display: inline-flex;
    justify-content: space-between;
    align-items: center;
}

.quick_menu_item {
    flex: 1;
    height: 90px;
    padding: 10px;
    background: #363636;
    overflow: hidden;
    display: inline-flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-end;
    text-decoration: none;
}

.quick_menu_item:not(:last-child) {
    border-right: 1px #626262 solid;
}

.quick_menu_item .icon_badge {
    width: 30px;
    height: 30px;
    box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.10);
    border-radius: 26px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.quick_menu_item .icon_badge_inner {
    width: 20px;
    height: 20px;
    position: relative;
    background: #D7FF01;
    overflow: hidden;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.quick_menu_item .icon_badge_inner svg {
    width: 7px;
    height: 10px;
}

.quick_menu_item .label {
    align-self: stretch;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 8px;
}

.quick_menu_item .label span {
    color: white;
    font-size: 16px;
    font-family: 'The Jamsil OTF', 'TheJamsil4Medium', sans-serif;
    font-weight: bold;
    word-wrap: break-word;
}

/* 공지사항 카드 */
.notice_card {
    align-self: stretch;
    position: relative;
    background: white;
    overflow: hidden;
    border-radius: 16px;
}

.notice_card_inner {
    align-self: stretch;
    display: flex;
    flex-direction: column;
}

.notice_header {
    align-self: stretch;
    padding: 16px;
    background: #363636;
    overflow: hidden;
    border-top-left-radius: 16px;
    border-top-right-radius: 16px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

.notice_header h5 {
    color: white;
    font-size: 14px;
    font-family: 'The Jamsil OTF', 'TheJamsil5Bold', sans-serif;
    font-weight: bold;
    word-wrap: break-word;
    margin: 0;
}

.notice_item {
    align-self: stretch;
    padding: 16px;
    background: #F6F6F6;
    border-bottom: 1px rgba(199, 199, 199, 0.30) solid;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    gap: 8px;
    text-decoration: none;
}

.notice_item_author {
    color: #888888;
    font-size: 12px;
    font-family: 'The Jamsil OTF', 'TheJamsil5Bold', sans-serif;
    font-weight: bold;
    word-wrap: break-word;
}

.notice_item_content {
    align-self: stretch;
    display: inline-flex;
    justify-content: space-between;
    align-items: center;
}

.notice_item_title {
    color: #888888;
    font-size: 14px;
    font-family: 'The Jamsil OTF', 'TheJamsil5Bold', sans-serif;
    font-weight: bold;
    word-wrap: break-word;
}

.notice_item_date {
    color: #888888;
    font-size: 12px;
    font-family: 'The Jamsil OTF', 'TheJamsil5Bold', sans-serif;
    font-weight: bold;
    word-wrap: break-word;
}