/* 여기까지 small*/
/* @media (max-width: 767px) {
} */
/* 991px 까지가 모바일 UI */
@media (max-width: 991px) {
    
    .mb-job-rq-detail-style {
        width: 100% !important;
        margin-top: 0 !important;
    }
    .calendar-cd-mobile-height {
        height: 420px !important;
    }
    .size1cd-mobile-height {
        height: 150px !important;
    }
    .name-cd-mobile-height {
        height: 200px !important;
    }
    .dsbd-mobile-height {
        height: 300px !important;
    }
    .donut-cd-mobile-height {
        height: 400px !important;
    }
    .export-btn-mobile-mg {
        margin-right: 10px;
    }
    /* .tracker-detail-col-custom {
        overflow-y: auto !important;
    } */
    .padding-custom-mb {
        padding-bottom: 30px !important;
    }
    .mobile-yauto-row-custom {
        margin-top: 10px !important;
        padding-right: 70px !important;
        /* margin-left: -50px !important; */
    }
    .mobile-row-custom {
        overflow-y: auto;
        overflow-x: hidden;
        margin-left: -20px !important;
        margin-right: -20px !important;
    }
    .mobile-height-auto {
        height: auto !important;
    }

    .mobile-card-body-custom {
        height: auto !important;
        overflow: visible !important;
        padding-inline: 30px !important;
        margin-left: 30px !important;
        margin-right: -60px !important;
        /* overflow-y: auto;
        padding-top: 0;
        padding-left: 30px !important;
        overflow-x: hidden; */
    }
    .under-remocon-area-mb-mg {
        margin-top: 20px !important;
    }
    .map-ratio {
        aspect-ratio: 5/3 !important;
    }

    .mobile-td-wd {
        width: 10% !important;
    }
    .chart-mg-zr {
        margin-left: 10px !important;
    }
    .mb-wd-auto {
        width: auto !important;
    }
    .mobile-search-row-height {
        height: 20% !important;
    }
    .mobile-table-row-height {
        height: 80% !important;
    }
    .event-card-mobile-mg {
        margin-left: -10px !important;
        margin-right: -10px !important;
    }
    .stp-event-mg {
        margin-left: -30px !important;
        margin-right: -30px !important;
    }
    .basicRow-mobile-mg {
        margin-left: -20px !important;
        margin-right: -20px !important;
    }
    .stp-event-tab-width {
        width: 100% !important;
    }
    .y-auto-row-mg {
        margin-right: -35px !important;
    }

    .date-input-width {
        width: 300px;
    }
    .chart-area-mg {
        margin-left: -47px !important;
        margin-right: -47px !important;
    }

    .chart-area-scroll {
        width: 400px !important;
        overflow-x: auto;
        overflow-y: hidden;
    }
    .cd-pd {
        padding-inline: 0 !important;
    }
    .mb-row {
        margin-left: -25px !important;
        margin-right: -27px !important;
    }

    .basic-row-mg {
        margin-top: -12px !important;
    }
    .id-row-margin {
        margin-top: -1px !important;
    }
    .map-card-row {
        margin-top: -15px !important;
    }
    .list-col-custom-for-list-page {
        height: 100vh;
        overflow-x: hidden !important;
        overflow-y: hidden !important;
        padding-inline: 2px;
        display: flex;
        flex-direction: column;
        border-bottom: 2px solid rgba(205, 205, 205, 0.2);
    }

    .detail-col-custom-for-list-page {
        height: 100vh;
        overflow-x: hidden !important;
        overflow-y: auto !important;
    }
    .arrow-height {
        height: 15px;
    }
    .hr-custom {
        display: none;
    }
    /* 기존 클래스 커스텀 */
    .content-custom {
        background-color: var(--bg-color);
        padding: 12px !important;
        overflow-y: auto;
        overflow-x: auto;
    }
    .cardbody-custom {
        margin-top: -15px;
        margin-left: -3px !important;
        margin-right: -3px !important;
    }
    /*/ 기존 클래스 커스텀 */

    .page-comment-custom {
        color: var(--least-important-color) !important;
        font-weight: 500 !important;
        display: none;
    }
    .navbar-light {
        /* background-color: var(--mobile-menubar-color); */
        /* border-bottom: 2px solid rgba(205, 205, 205, 0.2); */
    }
    .map-height-mobile {
        height: 200px !important;
    }
    .wtable-height-custom {
        height: 250px !important;
    }
    .vertical-line {
        border-right: 0px solid rgba(0, 0, 0, 0.2) !important;
    }
    /* 카드 커스텀 */
    .mini-card-custom {
        border-bottom: 1px solid rgba(28, 27, 27, 0.2) !important;
        max-width: none !important;
        border: none;
        border-radius: 0;
        padding-bottom: 10px;
        background-color: #ffffff !important;
        box-shadow: none;
    }
    .main-card-custom {
        max-width: none !important;
        border: none;
        background-color: #ebebeb !important;
        box-shadow: none;
        border-radius: 10px !important;
    }
    /* .donut-card-custom {
        padding: 0 !important;
        padding-left: -10px !important;
        margin-left: -20px;
        margin-right: -20px;
    } */
    /* /카드 커스텀 */
}
.tracker-detail-col-custom {
    overflow-y: hidden !important;
}
.map-card-row {
    margin-top: -40px;
}

.arrow-height {
    height: 17px;
    margin-top: 5px !important;
}
.tab-col-custom {
    overflow-x: auto !important; /* 가로 스크롤 활성화 */
    overflow-y: hidden !important; /* 세로 스크롤 비활성화 (필요 시) */
    white-space: nowrap !important; /* 콘텐츠가 줄 바꿈되지 않고 한 줄로 이어지도록 설정 */
}
/* 기존 클래스 커스텀 */
.content {
    background-color: var(--bg-color);
    padding-inline: 20px;
    padding-top: 30px;
    overflow-y: auto;
    overflow-x: auto;
}

/*/ 기존 클래스 커스텀 */
.content-custom {
    background-color: var(--bg-color);
    padding-inline: 20px;
    padding-top: 15px;
    overflow-y: auto;
    overflow-x: auto;
}

.container-custom {
    padding: 0;
}

.cardbody-custom {
    margin-left: 10px;
    margin-right: 20px;
}
.wtable-height-custom {
    height: 420px !important;
}
.page-comment-custom {
    color: var(--least-important-color) !important;
    font-weight: 500 !important;
}

/*최종 탭 커스텀*/
/* 탭 전체 컨테이너 */
.custom-tab-group3 {
    background-color: #fff; /* 배경 흰색 */
    border: 1px solid #e9ecef; /* 아주 연한 테두리 */
    border-radius: 15px !important; /* 전체적으로 둥근 모서리 */
    padding: 5px; /* 내부 버튼과의 간격 */
    display: flex;
    align-items: center;
}

/* 기본 버튼 스타일 (미선택 상태) */
.custom-tab3 {
    color: #adb5bd !important; /* 연한 회색 글자 (uncheck) */
    background-color: transparent !important; /* 배경 투명 */
    border: none !important; /* 테두리 제거 */
    border-radius: 10px !important;
    
    font-weight: 600;
    transition: all 0.3s ease;
    flex: 1; /* 가로 너비 균등 분배 */
    text-align: center;
}

/* 선택된 상태 스타일 (Checked) */
.custom-tab-group3 .btn-check:checked + .custom-tab3 {
    background-color: #eef4ff !important; /* 연한 블루 배경 (tab-color) */
    color: #4385f5 !important; /* 진한 블루 글자 (check) */
    font-weight: bold;
    /* 이미지처럼 그림자 효과를 주려면 아래 추가 */
    box-shadow: 0 2px 4px rgba(0,0,0,0.05); 
}

/* 호버 스타일 (선택되지 않은 버튼에 마우스 올렸을 때) */
.custom-tab3:hover {
    background-color: #f8f9fa !important;
    color: #6c757d !important;
}

/* 부트스트랩 기본 파란 테두리(포커스) 제거 */
.btn-check:focus + .btn-primary, .btn-primary:focus {
    box-shadow: none !important;
}
/* /최종 탭 커스텀 */

/* 카드 커스텀 */
.main-card-custom {
    max-width: none !important;
    border: none;
    background-color: #ffffff !important;
    box-shadow: none;
    border-radius: 5px;
    padding: 10px;
}
.mainB-card-custom {
    position: relative !important; /* 부모 요소에 상대 위치를 설정 */
    max-width: none !important;
    border: none !important;
    /* background-color: #EFF9FC!important; */
    background-color: var(--content-card-background-color) !important; /* 변수로 변경 */
    border-radius: 5px !important;
    padding: 15px !important;
    /* padding-top: 15px;
    padding-left: 15px;
    padding-bottom: 0px; */
    box-shadow: 2px 2px 4px rgba(87, 81, 81, 0.3) !important;
}
.mainW-card-custom {
    max-width: none !important;
    border: none;
    background-color: #ffffff !important;
    box-shadow: none !important;
    border-radius: 5px;
    padding: 10px;
}
.mini-card-custom {
    max-width: none !important;
    border: none;
    background-color: #ffffff !important;
    box-shadow: none;
}
.sd-inner-card-custom {
    max-width: none !important;
    border: none;
    background-color: #ffffff !important;
    box-shadow: none;
    border-radius: 5px;
    margin-left: 8px;
    margin-right: 8px;
    margin-top: 3px;
}
.sd-inner-card-header-custom {
    background-color: transparent;
    border: none;

    font-size: 18px !important;
    color: var(--title-font-color) !important;
    font-weight: bold;
}
/*/ 카드 커스텀 */

/* 목록 및 상태 페이지 스크롤 위한 커스텀 */
.content-custom-for-list-page {
    background-color: var(--bg-color);
    width: 100%;
    padding: 0;
    overflow-x: hidden;
}

.list-col-custom-for-list-page {
    height: 100%;
    overflow-x: hidden !important;
    overflow-y: hidden !important;
    padding-inline: 2px;
    display: flex;
    flex-direction: column;
}

.detail-col-custom-for-list-page {
    height: 100%;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    background-color: #ffffff;
}

.list-row-custom-for-list-page {
    flex: 0 0 auto;
}

.list-row-rest-custom-for-list-page {
    flex: 1 1 auto;
    overflow: hidden;
}

.scroll-list-box {
    overflow-y: auto;
    overflow-x: hidden;
    height: 100%;
    width: 100%;
    background-color: white;
}

.num-box {
    color: white;
    background-color: var(--button-color);
    border: none;
    border-radius: 15px;
    padding-inline: 10px;
    padding-top: 5px;
    padding-bottom: 5px;
}

.lightgray-background {
    background-color: var(--text-box-color) !important;
    border-radius: 10px;
    
    transition: background-color 0.2s ease; /* 부드러운 전환 효과 */
}
.list-tr-custom:hover .lightgray-background {
    background-color: var(--deeper-text-box-color) !important; /* 더 진한 색상으로 설정 */
}
.lightgray-background.highlighted {
    background-color: var(--deeper-text-box-color) !important; /* 더 진한 색상으로 설정 */
}
/* tr 요소가 hover 되었을 때의 스타일 */
.list-tr-custom {
    cursor: pointer; /* 마우스를 가져다 댔을 때 손가락 모양 활성화 */
    transition: background-color 0.2s ease; /* 배경색 변경에 부드러운 전환 효과 추가 */
}
.list-tr-custom:hover {
    background-color: var(--row-selected-color) !important;
}
.list-tr-custom.tr-selected {
    background-color: var(--row-selected-color) !important;
}

/*/ 목록 및 상태 페이지 스크롤 위한 커스텀 */

/* tr요소 커스텀 */
.tr-custom {
    cursor: pointer; /* 마우스를 가져다 댔을 때 손가락 모양 활성화 */
    transition: background-color 0.2s ease; /* 배경색 변경에 부드러운 전환 효과 추가 */
}

/* tr 요소가 hover 되었을 때의 스타일 */
.tr-custom:hover {
    background-color: #f0f0f0 !important; /* 원하는 어두운 색상으로 변경 (여기서는 연한 회색 예시) */
}

.td-custom {
    background-color: transparent !important;
}
.td-custom.cctv-tr-selected {
    border-right: 3px solid rgb(228, 145, 67) !important;
    /* background-color: red !important; */
}
/* /tr요소 커스텀 */
.p-background {
    background-color: var(--text-box-color);
    border-radius: 10px;
    padding-inline: 15px;
    padding-top: 5px;
    padding-bottom: 5px;
}
.br-custom {
    margin-top: 10px;
    margin-left: 20px;
    margin-right: 80px;
}

/* 삼각형 오버레이 */
/* .triangle-button {
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-bottom: 15px solid #626262;
    position: fixed; 
    z-index: 1000;
    top: 10%;
    left: 90%;
    transform: translate(-50%, -50%); 
} */

.up-down-btn {
    position: fixed;
    top: 10%;
    left: 85% !important;
    z-index: 1000;

    cursor: pointer;
    transition: all 0.3s ease;
}

/* Hover 시 더 진한 색상으로 변경 */
.triangle-button:hover {
    border-bottom-color: rgba(98, 98, 98, 1);
}

.date-input-width {
    width: 420px;
}
.yauto-custom {
    color: var(--font-color) !important;
    margin-right: 5px;
}

.secondRow-hr-custom {
    margin-left: 5px;
    margin-right: 45px !important;
}

.monitoring-container-pd {
    padding: 0;
}
.nanum-bold_box {
    font-size: 14px !important;
    font-family: 'NanumSquare' !important;
}
.nanum-bold {
   font-family: 'NanumSquareBold' !important;
}
.nanum-event {
   font-size: 16px !important;
    font-family: 'NanumSquareRegular' !important;
}

.nanum-bold_ex {
    font-family: 'NanumSquareBold' !important;
}
.nanum-extra-bold {
    font-size: 18px !important;
    font-family: 'NanumSquareExtraBold' !important;
}
.nanum-extra-bold-e {
    font-size: 17px !important;
    font-family: 'NanumSquareExtraBold' !important;
}


.nanum-extra-bold_e {
     font-size: 40px !important;
        color: #2E66D5;
    font-family: 'NanumSquareExtraBold' !important;
}
.nanum-extra-bold-occ {
     font-size: 60px !important;
        color: #2E66D5;
    font-family: 'NanumSquareExtraBold' !important;
}

.nanum-extra-bold_mo {
    font-size: 30px !important;
    font-family: 'NanumSquareExtraBold' !important;
}
.nanum-extra-bold-weather {
    font-size: 40px !important;
    font-family: 'NanumSquareExtraBold' !important;
}
.nanum-regular-occ {
    font-size: 15px !important;
    font-family: 'NanumSquareRegular' !important;
}

.nanum-regular-name {
    font-size: 17px !important;
    font-family: 'NanumSquareRegular' !important;
    color: #5A677B;
}
.nanum-regular-sub {
    font-size: 18px !important;
    color: #696767;
    font-family: 'NanumSquareRegular' !important;
}
.nanum-regular-subsub {
    font-size: 16px !important;
    color: #696767;
    font-family: 'NanumSquareRegular' !important;
}
.nanum-regular-data {
    font-size: 16px !important;
    color: #696767;
    font-family: 'NanumSquareRegular' !important;
}
.nanum-regular-gas {
    font-size: 13px !important;
    color: #555454;
    font-family: 'NanumSquareRegular' !important;
}
.nanum-regular-event {
    font-size: 13px !important;
    color: #8694A9;
    font-family: 'NanumSquareRegular' !important;
}
.nanum-bold-occ {
  font-size: 18px !important;
    color: #555454;
    font-family: 'NanumSquareBold' !important;
}
.nanum-bold-occupancy {
  font-size: 16px !important;
    color: #555454;
    font-family: 'NanumSquareRegular' !important;
}
.nanum-bold-occTitle {
  font-size: 21px !important;
    
    font-family: 'NanumSquareExtraBold' !important;
}

.mobile-monitor-list {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background: rgba(218, 218, 218, 0.8); /* 반투명 배경 */
    z-index: 1000;
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    padding: 10px; /* 내부 여백 */
    box-shadow: 0 -4px 10px rgba(178, 178, 178, 0.5); /* 그림자 효과 */
}
.overlay-monitor-container {
    display: flex;
    gap: 10px;
}

.mobile-card-custom {
    flex: 0 0 auto; /* 가로로만 확장되도록 설정 */
    width: 250px; /* 카드 고정 너비 */
    height: 90px; /* 카드 고정 높이 */
    background: white; /* 카드 배경색 */
    border-radius: 8px; /* 카드 모서리 둥글게 */
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); /* 카드 그림자 */
    display: flex;
    align-items: center; /* 수직 가운데 정렬 */
}

.object-card-custom {
    border: 1px solid #ddd;
    border-radius: 10px;
    background-color: #fff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
    padding: 1rem;
    margin-bottom: 1rem;
}
.break-word-custom {
    word-break: break-word;
    white-space: normal;
}
.main-row {
    overflow: hidden;
}

/* 버튼 커스텀 최종 */
.checkbutton-custom {
    border-radius: 10px !important;
    border: none;
    background-color: var(--button-color);
    --bs-btn-color: #ffffff; /*버튼 안의 글짜 색상*/
    /* --bs-btn-bg: #326abc; */
    --bs-btn-border-color: var(--button-color);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--button-hover-color);
    --bs-btn-hover-border-color: var(--button-color);
    --bs-btn-focus-shadow-rgb: 88, 145, 226;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--button-color);
    --bs-btn-active-border-color: var(--button-color);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: var(--button-disable-color);
    --bs-btn-disabled-border-color: var(--button-hover-color);
    /* background-image: linear-gradient(45deg, #326abc, #1e3e6e); */
}

.checkbutton-custom:hover {
    background-color: var(--button-hover-color);
    color: #ffffff;
}

.rvs-checkbutton-custom {
    border-radius: 10px !important;
    border: 2px solid var(--button-color); /* 테두리 색상 적용 */
    background-color: #ffffff; /* 배경 흰색 */
    color: var(--button-color); /* 글자색을 --button-color로 */

    --bs-btn-color: var(--button-color);
    --bs-btn-bg: #ffffff;
    --bs-btn-border-color: var(--button-color);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--button-hover-color);
    --bs-btn-hover-border-color: var(--button-hover-color);
    --bs-btn-focus-shadow-rgb: 88, 145, 226;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--button-color);
    --bs-btn-active-border-color: var(--button-color);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: var(--button-disable-color);
    --bs-btn-disabled-border-color: var(--button-hover-color);
}
.rvs-checkbutton-custom:hover {
    background-color: var(--button-hover-color);
    color: #ffffff;
}

.modifybutton-custom {
    border-radius: 10px !important;
    border: none;
    background-color: var(--mbutton-color);
    --bs-btn-color: #ffffff; /*버튼 안의 글짜 색상*/
    /* --bs-btn-bg: #326abc; */
    --bs-btn-border-color: var(--mbutton-color);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--mbutton-hover-color);
    --bs-btn-hover-border-color: var(--mbutton-color);
    --bs-btn-focus-shadow-rgb: 88, 145, 226;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--mbutton-color);
    --bs-btn-active-border-color: var(--mbutton-color);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: var(--button-disable-color);
    --bs-btn-disabled-border-color: var(--mbutton-hover-color);
    /* background-image: linear-gradient(45deg, #326abc, #1e3e6e); */
}

.modifybutton-custom:hover {
    background-color: var(--mbutton-hover-color);
    color: #ffffff;
}

.deletebutton-custom {
    border-radius: 10px !important;
    border: none;
    background-color: var(--dbutton-color);
    --bs-btn-color: #ffffff; /*버튼 안의 글짜 색상*/
    /* --bs-btn-bg: #326abc; */
    --bs-btn-border-color: var(--dbutton-color);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--dbutton-hover-color);
    --bs-btn-hover-border-color: var(--dbutton-color);
    --bs-btn-focus-shadow-rgb: 88, 145, 226;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--dbutton-color);
    --bs-btn-active-border-color: var(--dbutton-color);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: var(--button-disable-color);
    --bs-btn-disabled-border-color: var(--dbutton-hover-color);
    /* background-image: linear-gradient(45deg, #326abc, #1e3e6e); */
}

.deletebutton-custom:hover {
    background-color: var(--dbutton-hover-color);
    color: #ffffff;
}
/* /버튼 커스텀 최종 */

.settingbox-custom {
    background-color: var(--text-box-color);
    border-radius: 10px;
    padding-top: 10px;
    padding-bottom: 3px;
}

.pageBtn-custom.selected {
    background: var(--point-color) !important;
    color: #ffffff !important;
}
.text-ellipsis {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
/* h5player */
.h5-play-wrap {
    position: relative;
    overflow: hidden;

    width: 100%;
    aspect-ratio: 5 / 3;

    background-color: transparent;
}
.video_loading {
    position: absolute;
    top: 0;
    left: 0;
    color: #fff;
}
.radio-img {
    width: 30px;
    height: 30px;
    cursor: pointer;
    border: 2px solid transparent; /* 기본 테두리 */
    border-radius: 8px;
    transition: transform 0.2s, border-color 0.2s;
}

.map-img {
    width: 30px;
    height: 30px;
    cursor: pointer;
    border: 2px solid transparent; /* 기본 테두리 */
    border-radius: 8px;
    transition: transform 0.2s, border-color 0.2s;
}

/* 리모컨 관련 커스텀 */
.cross-container {
    background-color: var(--remocon-bg-color);
}
.inner-cross-container {
    background-color: var(--remocon-btn-color);
    display: grid;
    grid-template-rows: 1fr auto 1fr;
    grid-template-columns: 1fr auto 1fr;
    /* grid-template-columns: repeat(3, 1fr);   grid-template-rows: repeat(3, 1fr);  */
    position: relative;
}

.cross-item {
    position: relative;
    background-color: var(--remocon-bg-color);
    display: flex;
    justify-content: center;
    align-items: center;
}

/* 위치별 스타일 */
.cross-item.LeftUp {
    grid-row: 1;
    grid-column: 1;
    border-bottom-right-radius: 8px !important; /* 오른쪽 아래 모서리 둥글게 */
}

.cross-item.Up {
    grid-row: 1;
    grid-column: 2;
}

.cross-item.RightUp {
    grid-row: 1;
    grid-column: 3;
    border-bottom-left-radius: 8px !important; /* 오른쪽 아래 모서리 둥글게 */
}

.cross-item.Left {
    grid-row: 2;
    grid-column: 1;
}

.cross-item.Right {
    grid-row: 2;
    grid-column: 3;
}

.cross-item.LeftDown {
    grid-row: 3;
    grid-column: 1;
    border-top-right-radius: 8px !important; /* 오른쪽 아래 모서리 둥글게 */
}

.cross-item.Down {
    grid-row: 3;
    grid-column: 2;
}

.cross-item.RightDown {
    grid-row: 3;
    grid-column: 3;
    border-top-left-radius: 8px !important; /* 오른쪽 아래 모서리 둥글게 */
}

/* 중앙 버튼 스타일 */
.cross-item.center {
    grid-row: 2;
    grid-column: 2;
    background-color: transparent;
    border: transparent;
    /* background-color: var(--remocon-btn-color) !important; */
    /* background-color:red; */
}
.circle-btn {
    display: block;
    width: 70% !important;
    aspect-ratio: 1;
    background-color: var(--remocon-btn-color);
    border: 2px solid var(--remocon-border-color);
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.3s, transform 0.2s;
}
.circle-tri {
}
/* 호버 시 효과 */
.circle-btn:hover {
    /* background-color: #aaa; */
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.3); /* 그림자 강화 */
}

/* 클릭 시 효과 */
.circle-btn:active {
    transform: scale(0.95); /* 클릭 시 버튼 약간 축소 */
    /* background-color: #888; */
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.3); /* 그림자 강화 */
}

/* 리모컨 가운데 버튼 */
.center-circle-btn {
    display: block;
    background-color: white;
    border: 2px solid var(--remocon-border-color);
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.3s, transform 0.2s;
}
.center-circle-btn:hover {
    /* background-color: #faf8f8; */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3); /* 그림자 강화 */
}

.center-circle-btn:active {
    transform: scale(0.95); /* 클릭 시 버튼 약간 축소 */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3); /* 그림자 강화 */
    /* background-color: #faf8f8; */
}
/* /리모컨 가운데 버튼 */
.cross-box {
    display: flex;
    background-color: var(--remocon-btn-color);
    /* background-color: red; */
    justify-content: center !important;
    align-items: center !important;
}
.cross-box.Up {
    width: 100%;
    height: 80%;
    position: absolute;
    bottom: 0;
    border-radius: 8px 8px 0 0 !important;
}
.cross-box.Left {
    height: 100%;
    width: 80%;
    position: absolute;
    right: 0;
    border-radius: 8px 0 0 8px !important;
}
.cross-box.Right {
    height: 100%;
    width: 80%;
    position: absolute;
    left: 0;
    border-radius: 0 8px 8px 0 !important;
}
.cross-box.Down {
    width: 100%;
    height: 80%;
    position: absolute;
    top: 0;
    border-radius: 0 0 8px 8px !important;
}
/* 기본 스타일 */

.tri-btn {
    background-color: transparent;
    border: transparent;
}

/* 위쪽 삼각형 */
.tri-btn.top {
    margin-bottom: 30px;
}

/* 아래쪽 삼각형 */
.tri-btn.bottom {
    margin-top: 30px;
}

/* 왼쪽 삼각형 */
.tri-btn.left {
    margin-right: 30px;
}

/* 오른쪽 삼각형 */
.tri-btn.right {
    margin-left: 30px;
}
.remocon-container {
    background-color: var(--remocon-bg-color);
    border: 2px solid var(--remocon-border-color);
    box-shadow: 0 7px 5px rgba(0, 0, 0, 0.2);
    overflow-y: hidden;
    border-radius: 30px;
    aspect-ratio: 1 / 2;
}
/* .tri-btn:hover {
    border-color: #888;
} */
.under-remocon-area {
    margin-left: 12px;
    margin-right: 12px;
}
.rac-btn {
    display: inline-block; /* 인라인 블록으로 설정 */
    width: 100%;
    height: auto;
    padding: 10px 20px; /* 내부 여백 설정 */
    background-color: var(--remocon-btn-color); /* 버튼 배경색 (파란색) */
    border: 2px solid var(--remocon-border-color);
    border-radius: 8px; /* 살짝 둥근 모서리 */
    /* box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2); */
    cursor: pointer; /* 클릭 가능한 포인터 */
    transition: all 0.3s ease; /* 부드러운 애니메이션 효과 */
}

/* 호버 시 효과 */
.rac-btn:hover {
    /* background-color: #0056b3; 배경색 어둡게 변경 */
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.3); /* 그림자 강화 */
}

/* 클릭 시 효과 */
.rac-btn:active {
    /* background-color: #003f7f;  */
    transform: scale(0.98); /* 약간 축소 */
}

.option-btn {
    display: inline-block; /* 인라인 블록으로 설정 */
    /* width: 100%; */
    height: 100%;
    padding: 5px 5px;
    background-color: var(--remocon-btn-color);
    border: 2px solid var(--remocon-border-color);
    border-radius: 5px;
    cursor: pointer;
    transition: all 0.3s ease;
}

/* 호버 시 효과 */
.option-btn:hover {
    /* background-color: #0056b3; 배경색 어둡게 변경 */
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.3); /* 그림자 강화 */
}

/* 클릭 시 효과 */
.option-btn:active {
    /* background-color: #003f7f;  */
    transform: scale(0.98); /* 약간 축소 */
}
.map-ratio {
    aspect-ratio: 5/9;
}
.dsbd-card-custom {
    border-radius: 10px !important;
    max-width: none !important;
    border: solid 1px #E7EAF1;
    background-color: #ffffff;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0) !important;
    /* box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.2);  */
}
.dsbd-card-header-custom {
    border-radius: 10px;
    background-color: transparent;
    border: none;
    color: var(--important-font-color);
    font-family: 'NanumSquareBold';
}
.thead-dark-custom th {
    background-color: #EEF2F6; /* Bootstrap dark */
    color: var(--important-font-color);
}
/* 커스텀 파일 업로드 버튼 */
.custom-original-file-input {
    display: none;
}
.custom-file-upload {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 12px;
    background-color: #f5f5f5;
    border: solid 1px #dcd8d8;
    color: rgb(91, 86, 86);
    border-top-left-radius: 3px;
    border-bottom-left-radius: 3px;
    cursor: pointer;
    text-align: center;
    white-space: nowrap;
}
.file-name-display {
    padding-left: 8px;
    display: flex;
    align-items: center;
    flex: 1;
    border-top-right-radius: 3px;
    border-bottom-right-radius: 3px;
    border-top-left-radius: 0px !important;
    border-bottom-left-radius: 0px !important;
    white-space: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    background-color: #ffffff !important;
    height: 100% !important;
    border: 1px solid #dcd8d8;
    border-left: none;
}

.thin-horizon-scrollbar {
    scrollbar-width: thin;
    scrollbar-color: #c1c1c1 transparent;
}
.thin-horizon-scrollbar::-webkit-scrollbar {
    height: 5px; /* 1px 대신 6px 권장 */
}
/* WebKit (Chrome/Edge/Safari) */
.thin-horizon-scrollbar::-webkit-scrollbar {
    height: 6px; /* 1px 대신 6px 권장 */
}
.thin-horizon-scrollbar::-webkit-scrollbar-track {
    background: transparent;
}
.thin-horizon-scrollbar::-webkit-scrollbar-thumb {
    background: #c1c1c1;
    border-radius: 9999px;
}
.file-upload-wrapper {
    width: 100% !important;
    /* height: 100%; */
    height: 35px;
    display: flex;
    align-items: center;
}
.file-pill {
    background-color: #f1eeee;
    border-radius: 999px;
    height: 80%;
}
/* /커스텀 파일 업로드 버튼 */

.select-disabled-custom:disabled {
    appearance: none; /* 최신 브라우저용 */
    -webkit-appearance: none; /* Safari, Chrome */
    -moz-appearance: none; /* Firefox */

    background-image: none !important; /* 화살표 이미지 제거 */
    background-color: #e9ecef; /* 비활성화된 느낌 유지 (선택사항) */
    color: #6c757d; /* 텍스트 색도 비활성 스타일로 */
}
.calendar-event {
    position: absolute;
    background: rgb(241, 124, 124, 0.7);
    width: 5px;
    height: 5px;
    border-radius: 150px;
    bottom: 5px;
    left: calc(50% - 2px);
    content: ' ';
    display: block;
}

.truncate-multiline {
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: break-word;
    white-space: normal;
}
.map-marker-label {
    font-size: 13px;
    font-weight: 800; /* 글자가 굵어야 외곽선 안에서 선명하게 보입니다 */
    color: #434B5E;
    white-space: nowrap;
    margin-top: -5px;

    /* 1. 텍스트 렌더링 품질 최적화 (깨짐 방지 핵심) */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;

    /* 2. 외곽선 효과: text-shadow 대신 stroke 사용 (더 깔끔함) */
  

    /* 3. 그림자 효과: 외곽선 밖으로 부드럽게 퍼지도록 설정 */
    filter: drop-shadow(0px 1px 1px rgba(0, 0, 0, 0.3));

    /* 선택 불가 및 클릭 무시 */
    user-select: none;
    pointer-events: none;
}
.clickable-card {
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.clickable-card:hover {
    transform: scale(1.02);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
}
.clickable-card:active {
    transform: scale(0.99);
}
.no-scroll {
    overflow-x: hidden !important;
    overflow-y: hidden !important;
}
.option-group {
    display: flex;
    gap: 16px;
    margin: 20px 0;
}

.option-card {
    color: var(--least-important-color);
    flex: 1;
    border: 2px solid #ddd;
    border-radius: 12px;
    padding: 10px;
    text-align: center;
    cursor: pointer;
    font-size: 16px;
    font-family: system-ui;
    transition: all 0.2s ease-in-out;
}

.option-card:hover {
    /* border-color: #888; */
    background: #f9f9f9;
}

.option-card input {
    display: none;
    /* 기본 라디오 버튼 숨김 */
}

.option-card input:checked + span {
    font-family: 'NanumSquareExtraBold' !important;
    color: var(--point-color);
}

.option-card input:checked ~ .option-card {
    color: var(--point-color);
    border: 2px solid var(--point-color) !important;
}
.readonly-input {
    background-color: #f5f5f5;
    color: #999;
}

.disabled-btn {
    opacity: 0.2;
    pointer-events: none;
    cursor: not-allowed;
}

.deleted-user {
    color: #cec6c6;
    text-decoration: line-through;
}
.compLocation {
    display: block;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.wct-page {
    page-break-after: always;
}
.stp-status-filter {
  align-items: center;
}

.stp-filter-btn {
  border: 1px solid #ddd;
  background: #fff;
  border-radius: 8px;
  padding: 6px 14px;
  font-size: 14px;
  cursor: pointer;
  font-family: NanumSquareRegular;
}

.stp-filter-btn.active {
  background: #afacac;
  color: #fff;
}

.stp-filter-btn[data-status="none"] { color: #2563eb; }
.stp-filter-btn[data-status="request"] { color: #ef4444; }
.stp-filter-btn[data-status="result"] { color: #22c55e; }

.stp-status-badge {
  padding: 4px 10px;
  border-radius: 6px;
    font-family: 'NanumSquare';
   font-weight: normal !important;
}

.status-none { color: #2563eb; }
.status-request { color: #ef4444; }
.status-result { color: #22c55e; }

.table-scroll-wrap {
  max-height: 350px;
  overflow-y: auto;    /* 세로 스크롤 담당 */
}
.x72, .pdf-wrap {
  white-space: normal !important;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
}