@font-face {
    font-family: 'NotoSansKR';
    src: url('/fonts/NotoSansKR-Regular.woff2') format('woff2'),
         url('/fonts/NotoSansKR-Regular.woff') format('woff');
}

@font-face {
    font-family: 'NotoSansJP';
    src: url('/fonts/NotoSansJP-Regular.woff2') format('woff2'),
         url('/fonts/NotoSansJP-Regular.woff') format('woff');
}

@font-face {
    font-family: 'Roboto';
    src: url('/fonts/Roboto-Regular.woff2') format('woff2'),
         url('/fonts/Roboto-Regular.woff') format('woff');
}

html[lang="ko"] body {
    font-family: 'NotoSansKR', sans-serif;
}

html[lang="jp"] body {
    font-family: 'NotoSansJP', sans-serif;
}

html[lang="en"] body {
    font-family: 'NotoSansKR', sans-serif;
}

.text-small {
    font-size: 12px !important;
}

/* Device list status badges */
.device-status-badge {
    background-color: rgba(59, 130, 246, 0.15) !important;
    border: 1px solid rgba(59, 130, 246, 0.35) !important;
    color: #9cc3ff !important;
    font-weight: 600;
    font-size: 11px;
    padding: 3px 8px;
}
.device-status-badge--ok {
    background-color: rgba(59, 130, 246, 0.15) !important;
    border-color: rgba(59, 130, 246, 0.35) !important;
    color: #9cc3ff !important;
}
.device-status-badge--off {
    background-color: rgba(148, 163, 184, 0.12) !important;
    border-color: rgba(148, 163, 184, 0.3) !important;
    color: #cbd5e1 !important;
}
.device-status-badge--inactive {
    background-color: rgba(251, 191, 36, 0.12) !important;
    border-color: rgba(251, 191, 36, 0.35) !important;
    color: #fcd34d !important;
}

/* Device list updated text colors */
.device-text--ok {
    color: #9cc3ff !important;
}
.device-text--off {
    color: rgba(148, 163, 184, 0.9) !important;
}
.device-text--inactive {
    color: rgba(251, 191, 36, 0.9) !important;
}

/* Device list action buttons */
.card-action-btn {
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.03);
    color: rgba(255, 255, 255, 0.75);
    width: 32px;
    height: 32px;
    padding: 0;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
}
.card-action-btn:hover {
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(255, 255, 255, 0.26);
    color: #ffffff;
    transform: translateY(-1px);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.25);
}
.card-action-btn--map {
    border-color: rgba(59, 130, 246, 0.28);
    color: #a7c4ff;
}
.card-action-btn--map:hover {
    background: rgba(59, 130, 246, 0.12);
    border-color: rgba(59, 130, 246, 0.45);
    color: #dbeafe;
}
.card-action-btn--danger {
    border-color: rgba(239, 68, 68, 0.3);
    color: #f8b4b4;
}
.card-action-btn--danger:hover {
    background: rgba(239, 68, 68, 0.12);
    border-color: rgba(239, 68, 68, 0.45);
    color: #fecaca;
}
.card-action-btn--success {
    border-color: rgba(34, 197, 94, 0.3);
    color: #a7f3d0;
}
.card-action-btn--success:hover {
    background: rgba(34, 197, 94, 0.12);
    border-color: rgba(34, 197, 94, 0.45);
    color: #d1fae5;
}

.form-control:disabled {
    background-color: #333333 !important;
    color: #cccccc !important;
}

.hiddenRow {
    padding: 0 !important;
    border: 0 !important;
    margin-top: -5px !important;
}

.spacing0 {
    border-spacing: 0 0px !important;
    -webkit-border-horizontal-spacing: 0px !important;
    -webkit-border-vertical-spacing: 0px !important;
    margin:0px !important;
    background: rgb(41, 44, 48);
}

.spacing1 {
    border-spacing: 0 2px !important;
    -webkit-border-horizontal-spacing: 0px !important;
    -webkit-border-vertical-spacing: 1px !important;
}

.spacing2 {
    border-spacing: 0 2px !important;
    -webkit-border-horizontal-spacing: 0px !important;
    -webkit-border-vertical-spacing: 2px !important;
    background: rgb(41, 44, 48);
}

.info-message {
    color: #54b7c6;
    font-size: 12px;
    display: flex;
    align-items: center;
}

.warning-message {
    color: var(--status-cautionary) !important;
    font-size: 12px;
    display: flex;
    align-items: center;
}

.danger-message {
    color: var(--status-negative) !important;
    font-size: 12px;
    display: flex;
    align-items: center;
}

.info-message i,
.warning-message i,
.danger-message i {
    margin-top: 2px;
    margin-right: .25rem!important;
}

.text-light {
    color:#a2a2a2 !important;
}
.text-secure {
    color:#ff8021 !important;
}
.text-basic {
    color: #d0d0d0 !important;
}

.card-view-status-badge {
    display: flex;
    align-items: center;
    font-size: 14px;
    margin: 0;
    height: 24px;
}

.card-view-delete-button {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 100px;
    color: var(--label-normal);
}

.min-wd-100 {
    min-width: 100px;
}






/***************************/
/* VUNex AI 참고해서 CSS 추가 */
/***************************/
.modal-header {
    background: #007bff;
    color: white;
    border-radius: 0;
}

.modal-header .close {
    color: white;
    opacity: 0.8;
}

.modal-header .close:hover {
    opacity: 1;
}

.modal-title i {
    margin-right: 8px;
}

.modal-body {
    background: var(--background-elevated-normal);
    color: var(--label-normal);
}

.modal-footer {
    background: var(--background-elevated-normal);
    border-top-color: var(--line-normal);
}

/* ✅ SweetAlert2 공통 스타일 */
.swal2-popup {
    background: var(--background-normal-alternative, #0F0F10) !important;
    box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.08);
    border-radius: 6px !important;
    outline: 1px solid var(--line-normal-normal, rgba(112, 115, 124, 0.32));
    outline-offset: -1px;
    padding: 24px !important;
}

.swal2-popup .swal2-title {
    color: var(--label-normal, #F7F7F8) !important;
    font-size: 18px !important;
    font-family: Roboto, Pretendard, sans-serif !important;
    font-weight: 700 !important;
    line-height: 26.01px !important;
    text-align: left !important;
    padding: 0 !important;
    margin: 0 0 8px 0 !important;
    width: 100% !important;
}

.swal2-popup .swal2-html-container {
    color: var(--label-neutral, rgba(194, 196, 200, 0.88)) !important;
    font-size: 15px !important;
    font-family: Roboto, Pretendard, sans-serif !important;
    font-weight: 400 !important;
    line-height: 22.01px !important;
    letter-spacing: 0.14px !important;
    text-align: left !important;
    padding: 0 !important;
    margin: 0 0 24px 0 !important;
    width: 100% !important;
}

.swal2-popup .swal2-actions {
    justify-content: flex-end !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
}

.swal2-popup .swal2-cancel {
    background: transparent !important;
    color: var(--label-normal, #F7F7F8) !important;
    border-radius: 6px !important;
    outline: 1px solid var(--line-normal-normal, rgba(112, 115, 124, 0.32)) !important;
    outline-offset: -1px !important;
    border: none !important;
    padding: 9px 20px !important;
    font-size: 15px !important;
    font-family: Pretendard, sans-serif !important;
    font-weight: 500 !important;
    line-height: 22.01px !important;
    letter-spacing: 0.14px !important;
    min-width: 88px !important;
    margin: 0 !important;
}

.swal2-popup .swal2-cancel:hover {
    background: rgba(247, 247, 248, 0.1) !important;
}

.swal2-popup .swal2-confirm {
    background: var(--primary-normal, #3385FF) !important;
    color: white !important;
    border-radius: 6px !important;
    border: none !important;
    padding: 9px 20px !important;
    font-size: 15px !important;
    font-family: Roboto, Pretendard, sans-serif !important;
    font-weight: 700 !important;
    line-height: 22.01px !important;
    letter-spacing: 0.14px !important;
    min-width: 88px !important;
    margin: 0 !important;
}

.swal2-popup .swal2-confirm:hover {
    background: #2970e6 !important;
}

.swal2-popup .swal2-styled:focus {
    box-shadow: none !important;
}

.swal2-popup .swal2-icon {
    display: none !important;
}


.nav-tabs {
    border-bottom: 1px solid rgba(112, 115, 124, 0.32);
    margin-top: 20px;
    margin-bottom: 0;
}

.nav-tabs .nav-link {
    color: rgba(174, 176, 182, 0.32);
    border: none;
    border-bottom: 1px solid transparent;
    font-weight: 500;
    background: transparent;
    padding: 10px 20px;
    height: 40px;
    display: flex;
    align-items: center;
}

.nav-tabs .nav-link:hover {
    color: var(--primary-normal);
    background: transparent;
    border-bottom: 1px solid transparent;
}

.nav-tabs .nav-link.active,
.nav-tabs .nav-link.active.show {
    color: var(--primary-normal);
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--primary-normal);
    font-weight: 500;
}


.btn:not(.btn-sm, .gf-action-btn, .gf-icon-btn, .gf-pill-btn, .face-rect-color-button, .face-text-color-button) {
    border-radius: 6px !important;
    font-weight: 500 !important;
    min-width: 100px;
}

#main-content {
    padding: 0 !important;
}

@media screen and (max-width: 1200px) {
    .top-navbar>.container-fluid {
        padding: 0 !important;
    }

    .block-header {
        margin-top:50px;
    }
}
