/* ─── Variables ─────────────────────────────────────────────────────────────── */
:root {
    --sidebar-width: 268px;
    --sidebar-min-width: 180px;
    --sidebar-max-width: 420px;
    --sidebar-collapsed-width: 60px;
    --topbar-height: 56px;
    --transition: 0.2s ease;
}

/* 深色模式（預設） */
:root,
[data-theme="dark"] {
    --sidebar-bg: #0f172a;
    --sidebar-border: #233450;
    --sidebar-text: #d4deea;
    --sidebar-text-active: #f3f7ff;
    --sidebar-hover-bg: #1f3150;
    --sidebar-active-bg: #2563eb;
    --topbar-bg: #0f172a;
    --topbar-border: #233450;
    --page-bg: #1a2332;
    --card-bg: #ffffff;
    --panel-bg: #172233;
    --panel-bg-soft: #1f3147;
    --panel-border: #2f4156;
    --panel-input-bg: #0f1b2c;
    --panel-text: #e6efff;
}

/* 淺色模式（左側選單採藍色底色，與主內容區的淺色背景區隔） */
[data-theme="light"] {
    --sidebar-bg: #2f6690;
    --sidebar-header-bg: #4f8fc7;
    --sidebar-border: rgba(255, 255, 255, 0.16);
    --sidebar-text: #e6f1fb;
    /* 注意：--sidebar-hover-bg / --sidebar-active-bg / --sidebar-text-active 為共用變數，
       亦供 #bedParamApp、#groupMenusApp 等淺色面板上的清單套用，故維持原淺色數值；
       左側選單實際的滑入／選中樣式改用下方 .nav-link 專屬覆蓋規則。 */
    --sidebar-text-active: #1e40af;
    --sidebar-hover-bg: #f1f5f9;
    --sidebar-active-bg: #dbeafe;
    --navlink-hover-bg: rgba(255, 255, 255, 0.12);
    --navlink-active-bg: #173a5c;
    --topbar-bg: #f8fafc;
    --topbar-border: #e2e8f0;
    --page-bg: #f1f5f9;
    --card-bg: #ffffff;
    --panel-bg: #ffffff;
    --panel-bg-soft: #f8fafc;
    --panel-border: #e2e8f0;
    --panel-input-bg: #ffffff;
    --panel-text: #1e293b;
}

/* ─── Layout ─────────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html, body {
    height: 100%;
    margin: 0;
    padding: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-size: 14px;
    background: var(--page-bg);
    color: var(--panel-text);
    transition: background-color 0.3s, color 0.3s;
}

.app-wrapper {
    display: flex;
    height: 100vh;
    overflow: hidden;
}

/* ─── Sidebar ─────────────────────────────────────────────────────────────────── */
.sidebar {
    position: relative;
    flex-shrink: 0;
    width: var(--sidebar-width);
    min-width: var(--sidebar-width);
    max-width: var(--sidebar-max-width);
    background: var(--sidebar-bg);
    color: var(--sidebar-text);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    transition: width var(--transition), min-width var(--transition);
    z-index: 100;
}

.sidebar.collapsed {
    width: var(--sidebar-collapsed-width);
    min-width: var(--sidebar-collapsed-width);
    max-width: var(--sidebar-collapsed-width);
}

.sidebar-resizer {
    position: absolute;
    top: 0;
    right: 0;
    width: 6px;
    height: 100%;
    cursor: col-resize;
    z-index: 101;
    touch-action: none;
}

.sidebar-resizer:hover,
.sidebar-resizer.is-dragging {
    background: rgba(37, 99, 235, 0.35);
}

.sidebar.collapsed .sidebar-resizer {
    display: none;
    pointer-events: none;
}

body.sidebar-resizing {
    cursor: col-resize !important;
    user-select: none;
}

body.sidebar-resizing .sidebar {
    transition: none;
}

.sidebar-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--sidebar-border);
    min-height: 72px;
    white-space: nowrap;
    overflow: hidden;
}

.brand-icon-wrap {
    width: 42px;
    height: 42px;
    border-radius: 8px;
    background: #2563eb;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.brand-icon {
    width: 28px;
    height: 28px;
    flex-shrink: 0;
}

.brand-texts {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
}

.brand-title {
    font-weight: 700;
    font-size: 22px;
    line-height: 1.15;
    color: #f1f5f9;
    transition: opacity var(--transition);
}

.brand-subtitle {
    margin-top: 2px;
    font-size: 15px;
    color: #94a3b8;
    line-height: 1.25;
    text-align: center;
    transition: opacity var(--transition);
}

.sidebar.collapsed .brand-texts { opacity: 0; width: 0; overflow: hidden; }

.sidebar-user {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--sidebar-border);
    overflow: hidden;
    white-space: nowrap;
}

.user-avatar {
    width: 32px; height: 32px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.user-name { font-size: 15px; color: var(--sidebar-text); transition: opacity var(--transition); }
.sidebar.collapsed .user-name { opacity: 0; width: 0; overflow: hidden; }

/* ─── Nav ─────────────────────────────────────────────────────────────────────── */
.sidebar-nav { flex: 1; padding: 8px 0; }

.nav-list, .nav-sublist { list-style: none; margin: 0; padding: 0; }

.nav-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 11px 16px;
    color: var(--sidebar-text);
    text-decoration: none;
    font-size: 15.5px;
    line-height: 1.35;
    white-space: nowrap;
    overflow: hidden;
    transition: background var(--transition), color var(--transition);
    cursor: pointer;
    border: none;
    background: none;
    width: 100%;
    text-align: left;
}

.nav-link:hover { background: var(--sidebar-hover-bg); color: var(--sidebar-text-active); }
.nav-link.active { background: var(--sidebar-active-bg); color: #fff; }

.nav-icon { width: 20px; text-align: center; flex-shrink: 0; font-size: 16px; }
.nav-label { transition: opacity var(--transition); }
.sidebar.collapsed .nav-label { opacity: 0; width: 0; overflow: hidden; }
.nav-arrow { font-size: 12px; margin-left: auto; transition: transform 0.2s; }
.nav-link[aria-expanded="true"] .nav-arrow { transform: rotate(180deg); }

.nav-sublist .nav-link { padding-left: 46px; font-size: 15px; }
.sidebar.collapsed .nav-sublist { display: none !important; }

/* ─── Main content ─────────────────────────────────────────────────────────────── */
.main-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-width: 0; /* 讓內層 page-body 可出現橫向捲軸，避免寬內容撐破 flex */
    background: var(--page-bg);
}

.top-navbar {
    height: var(--topbar-height);
    background: var(--topbar-bg);
    border-bottom: 1px solid var(--topbar-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    flex-shrink: 0;
    gap: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.18);
}

.page-body {
    flex: 1;
    min-width: 0;
    overflow: auto; /* 橫向／直向超出時統一由此捲動（如整合監控多床橫列） */
    padding: 24px;
    background: var(--page-bg);
}

.top-navbar .breadcrumb-item,
.top-navbar .breadcrumb-item a {
    color: #d4deea;
}

.top-navbar .breadcrumb-item.active {
    color: #f3f7ff;
}

.top-navbar .btn-outline-secondary {
    color: #d4deea;
    border-color: #3a4a66;
    background-color: #1a2a47;
}

.top-navbar .btn-outline-secondary:hover,
.top-navbar .btn-outline-secondary:focus,
.top-navbar .btn-outline-secondary:active {
    color: #ffffff;
    border-color: #4a5c7d;
    background-color: #243757;
}

/* ─── Page header ─────────────────────────────────────────────────────────────── */
.page-header {
    margin-bottom: 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--panel-border);
}

.page-header h4 { margin: 0; font-weight: 600; color: #f3f7ff; font-size: 18px; }
.page-header small { color: #9fb2cc; }

/* ─── Dashboard cards ─────────────────────────────────────────────────────────── */
.dashboard-card {
    background: var(--panel-bg-soft);
    border: 1px solid var(--panel-border);
    border-radius: 10px;
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    transition: box-shadow 0.15s, transform 0.15s;
}

.dashboard-card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.28);
    transform: translateY(-2px);
}

.dashboard-card-icon {
    width: 48px; height: 48px;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    color: #fff;
    font-size: 20px;
    flex-shrink: 0;
}

.dashboard-card-title { font-weight: 600; font-size: 14px; color: #f3f7ff; }
.dashboard-card-sub { font-size: 12px; color: #b7c8de; margin-top: 2px; }

/* ─── Monitoring demo ─────────────────────────────────────────────────────────── */
.monitoring-topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    color: #e8eef8;
}

.monitoring-region-select {
    min-width: 120px;
    background: #213252;
    border: 1px solid #4a5f83;
    color: #e8eef8;
}

.monitoring-region-select:focus {
    border-color: #6f86af;
    box-shadow: none;
}

.monitoring-title {
    color: #f2f7ff;
    font-size: 32px;
    font-weight: 700;
}

.monitoring-message {
    background: #1a2a47;
    border: 1px solid #3b4f71;
    color: #dce7f7;
    padding: 6px 10px;
    border-radius: 6px;
    font-size: 13px;
}

.monitoring-room-card {
    background: #243247;
    border: 1px solid #3a4b66;
    border-radius: 14px;
    padding: 12px;
}

.monitoring-room-header {
    color: #f3f7ff;
    font-size: 30px;
    font-weight: 700;
    margin-bottom: 10px;
}

.monitoring-beds {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.monitoring-bed {
    border: 1px solid #2e4569;
    border-radius: 8px;
    background: #162640;
    color: #e7eefb;
    min-height: 66px;
    padding: 8px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    font-size: 19px;
    font-weight: 600;
}

.monitoring-bed small {
    margin-top: 2px;
    color: #8fa4c6;
    font-size: 13px;
    font-weight: 400;
}

/* ─── System page dark theme ───────────────────────────────────────────────────── */
:where(.page-body, #examServicePlanEditorModal) h1,
:where(.page-body, #examServicePlanEditorModal) h2,
:where(.page-body, #examServicePlanEditorModal) h3,
:where(.page-body, #examServicePlanEditorModal) h4,
:where(.page-body, #examServicePlanEditorModal) h5,
:where(.page-body, #examServicePlanEditorModal) h6,
:where(.page-body, #examServicePlanEditorModal) .form-label,
:where(.page-body, #examServicePlanEditorModal) .col-form-label,
:where(.page-body, #examServicePlanEditorModal) .text-body {
    color: #dbe6f5;
}

:where(.page-body, #examServicePlanEditorModal) .text-muted {
    color: #b7c8de !important;
}

:where(.page-body, #examServicePlanEditorModal) .card {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    color: var(--panel-text);
}

:where(.page-body, #examServicePlanEditorModal) .card-header {
    background: #162235;
    font-weight: 600;
    font-size: 13.5px;
    border-bottom: 1px solid var(--panel-border);
    padding: 10px 16px;
    color: #f3f7ff;
}

:where(.page-body, #examServicePlanEditorModal) .card-body {
    background: var(--panel-bg-soft);
    color: var(--panel-text);
}

/* 系統參數：整合監控開關區塊 — 與卡片主區同色底，勿使用 Bootstrap bg-light */
:where(.page-body, #examServicePlanEditorModal) .system-parameters-monitor-display {
    background-color: var(--panel-bg-soft);
    border-color: var(--panel-border) !important;
}

:where(.page-body, #examServicePlanEditorModal) .table {
    font-size: 13.5px;
    color: var(--panel-text);
    --bs-table-color: var(--panel-text);
    --bs-table-bg: var(--panel-bg-soft);
    --bs-table-striped-bg: #263a53;
    --bs-table-striped-color: var(--panel-text);
    --bs-table-hover-bg: #304866;
    --bs-table-hover-color: #ffffff;
    --bs-table-border-color: var(--panel-border);
}

:where(.page-body, #examServicePlanEditorModal) .table thead th {
    font-weight: 600;
    font-size: 13px;
    vertical-align: middle;
    background: #162235;
    color: #f3f7ff;
    border-color: var(--panel-border);
}

:where(.page-body, #examServicePlanEditorModal) .table td {
    vertical-align: middle;
    border-color: var(--panel-border);
}

:where(.page-body, #examServicePlanEditorModal) .table-light,
:where(.page-body, #examServicePlanEditorModal) .table-light > th,
:where(.page-body, #examServicePlanEditorModal) .table-light > td {
    background-color: #162235 !important;
    color: #f3f7ff !important;
    border-color: var(--panel-border) !important;
}

:where(.page-body, #examServicePlanEditorModal) .table-active,
:where(.page-body, #examServicePlanEditorModal) .table-active > th,
:where(.page-body, #examServicePlanEditorModal) .table-active > td {
    background-color: #304866 !important;
    color: #ffffff !important;
}

:where(.page-body, #examServicePlanEditorModal) .form-control,
:where(.page-body, #examServicePlanEditorModal) textarea {
    background: var(--panel-input-bg);
    border-color: var(--panel-border);
    color: var(--panel-text);
}

/* 注意：.form-select 不能用 background 簡寫，否則會連同 Bootstrap 內建的下拉箭頭圖示一併清掉 */
:where(.page-body, #examServicePlanEditorModal) .form-select {
    --bs-form-select-bg-img: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23dee2e6' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
    background-color: var(--panel-input-bg);
    border-color: var(--panel-border);
    color: var(--panel-text);
}

:where(.page-body, #examServicePlanEditorModal) .form-control::placeholder,
:where(.page-body, #examServicePlanEditorModal) textarea::placeholder {
    color: #8fa4c1;
}

:where(.page-body, #examServicePlanEditorModal) .form-control:focus,
:where(.page-body, #examServicePlanEditorModal) textarea:focus {
    background: var(--panel-input-bg);
    color: #ffffff;
    border-color: #4b6a8f;
    box-shadow: 0 0 0 0.2rem rgba(37, 99, 235, 0.2);
}

:where(.page-body, #examServicePlanEditorModal) .form-select:focus {
    background-color: var(--panel-input-bg);
    color: #ffffff;
    border-color: #4b6a8f;
    box-shadow: 0 0 0 0.2rem rgba(37, 99, 235, 0.2);
}

/* 多選 checkbox 下拉篩選（異常回報等）— 與 form-select 同色 */
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-right: 2rem;
    font-weight: 500;
    text-shadow: none;
    -webkit-font-smoothing: antialiased;
    /* 僅保留 dropdown 箭頭，避免 form-select 內建箭頭重複 */
    background-image: none;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-toggle::after {
    position: absolute;
    right: 0.75rem;
    margin-left: 0;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-menu {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    color: var(--panel-text);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
    padding: 0.35rem 0.35rem 0.45rem;
    overflow: visible;
    min-width: 11.5rem;
    --bs-dropdown-link-color: var(--panel-text);
    --bs-dropdown-link-hover-color: #ffffff;
    --bs-dropdown-link-hover-bg: var(--panel-bg-soft);
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-menu > li {
    list-style: none;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-actions {
    display: flex;
    align-items: stretch;
    gap: 0.35rem;
    padding: 0.15rem 0.35rem 0.45rem;
    margin-bottom: 0.15rem;
    border-bottom: 1px solid var(--panel-border);
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-action-btn {
    flex: 1 1 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.3rem 0.45rem;
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1.2;
    color: #c8daf5;
    background: var(--panel-bg-soft);
    border: 1px solid var(--panel-border);
    border-radius: 0.3rem;
    white-space: nowrap;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-action-btn:hover,
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-action-btn:focus {
    color: #ffffff;
    background: #304866;
    border-color: #4b6a8f;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-action-btn[data-role="select-all"] {
    color: #bfdbfe;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-action-btn[data-role="select-all"]:hover,
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-action-btn[data-role="select-all"]:focus {
    background: rgba(37, 99, 235, 0.35);
    border-color: #3b82f6;
    color: #ffffff;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-action-btn .fa {
    font-size: 0.75rem;
    opacity: 0.9;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-option {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    margin: 0;
    padding: 0.4rem 0.5rem;
    border-radius: 0.25rem;
    cursor: pointer;
    user-select: none;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-option:hover {
    background: var(--panel-bg-soft);
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-option-label {
    color: var(--panel-text);
    font-weight: 500;
    line-height: 1.3;
    flex: 1;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-menu .form-check-input {
    float: none;
    position: static;
    margin: 0;
    flex-shrink: 0;
    background-color: var(--panel-input-bg);
    border-color: #4b6a8f;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-menu .form-check-input:checked {
    background-color: #2563eb;
    border-color: #2563eb;
}
:where(.page-body, #examServicePlanEditorModal) .checkbox-filter-dropdown .checkbox-filter-menu .form-check-input:focus {
    border-color: #4b6a8f;
    box-shadow: 0 0 0 0.2rem rgba(37, 99, 235, 0.25);
}

:where(.page-body, #examServicePlanEditorModal) .input-group-text {
    background: #162235;
    border-color: var(--panel-border);
    color: #8fa4c1;
}

:where(.page-body, #examServicePlanEditorModal) .form-control[readonly] {
    background: var(--panel-input-bg);
    color: var(--panel-text);
    opacity: 0.75;
    cursor: default;
}

:where(.page-body, #examServicePlanEditorModal) .btn-outline-secondary {
    color: #dbe6f5;
    border-color: #4a5f83;
    background: #1f2f47;
}

:where(.page-body, #examServicePlanEditorModal) .btn-outline-secondary:hover {
    color: #fff;
    background: #2a3e5d;
    border-color: #5e769d;
}

/* ─── Breadcrumb ─────────────────────────────────────────────────────────────────── */
.breadcrumb { font-size: 13px; }
.breadcrumb-item + .breadcrumb-item::before { color: #94a3b8; }

/* ─── Sidebar toggle ─────────────────────────────────────────────────────────────── */
.sidebar-toggle-btn { padding: 4px 8px; color: #c8d5e7 !important; text-decoration: none; }
.sidebar-toggle-btn:hover { color: #ffffff !important; }

/* ─── Menu tree ─────────────────────────────────────────────────────────────────── */
.menu-tree-row { display: flex; align-items: center; padding: 4px 0; }
.menu-tree-children { border-left: 2px solid var(--panel-border); margin-left: 8px; padding-left: 8px; }
.parent-row { font-weight: 600; }

/* ─── Dark modals (共用於所有 page-body 內的 modal) ─────────────────────────────── */
:where(.page-body, #examServicePlanEditorModal) .modal-content {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    color: var(--panel-text);
}
:where(.page-body, #examServicePlanEditorModal) .modal-header {
    background: #162235;
    border-bottom-color: var(--panel-border);
}
:where(.page-body, #examServicePlanEditorModal) .modal-title { color: #f3f7ff; }
:where(.page-body, #examServicePlanEditorModal) .modal-header .btn-close { filter: invert(1) grayscale(100%) brightness(200%); }
:where(.page-body, #examServicePlanEditorModal) .modal-body { background: var(--panel-bg-soft); }
:where(.page-body, #examServicePlanEditorModal) .modal-footer {
    background: var(--panel-bg);
    border-top-color: var(--panel-border);
}
:where(.page-body, #examServicePlanEditorModal) .form-check-label { color: var(--panel-text); }
:where(.page-body, #examServicePlanEditorModal) .modal-body .border { border-color: var(--panel-border) !important; }
:where(.page-body, #examServicePlanEditorModal) .modal-body .border { background: var(--panel-input-bg); }

.questionnaire-defaults-dialog {
    width: min(96vw, 72rem);
    max-width: min(96vw, 72rem);
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
}

.questionnaire-defaults-dialog .modal-content {
    height: calc(100dvh - 1rem);
    max-height: calc(100dvh - 1rem);
    overflow: hidden;
}

#questionnaireDefaultValuesForm {
    height: 100%;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

#questionnaireDefaultValuesForm .modal-header,
#questionnaireDefaultValuesForm .modal-footer {
    flex: 0 0 auto;
}

#questionnaireDefaultValuesForm .modal-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: scroll;
    overscroll-behavior: contain;
    scrollbar-width: thin;
    scrollbar-color: #64748b #cbd5e1;
}

#questionnaireDefaultValuesForm .modal-body::-webkit-scrollbar {
    width: 10px;
}

#questionnaireDefaultValuesForm .modal-body::-webkit-scrollbar-track {
    background: #cbd5e1;
}

#questionnaireDefaultValuesForm .modal-body::-webkit-scrollbar-thumb {
    background: #64748b;
    border-radius: 8px;
    border: 2px solid #cbd5e1;
}

.questionnaire-defaults-modal {
    background: #d8dde6 !important;
    color: #111827;
}

.questionnaire-preview-page {
    width: min(100%, 56rem);
    margin: 0 auto;
    padding: 1.5rem 1.75rem;
    background: #ffffff;
    border: 1px solid #b7c0cf;
    color: #111827;
    font-family: "Microsoft JhengHei", "Noto Sans TC", Arial, sans-serif;
    font-size: 0.95rem;
    line-height: 1.65;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.2);
}

.questionnaire-preview-title {
    margin-bottom: 0.75rem;
    color: #111827;
    font-size: 1.15rem;
    font-weight: 700;
    text-align: center;
}

.questionnaire-preview-note {
    margin-bottom: 1rem;
    padding: 0.55rem 0.75rem;
    background: #f8fafc;
    border: 1px solid #d7dee8;
    color: #475569;
}

.questionnaire-preview-section {
    margin: 1rem 0 0.45rem;
    padding: 0.35rem 0.6rem;
    background: #edf2f7;
    border-left: 4px solid #2563eb;
    color: #1e293b;
    font-weight: 700;
}

.questionnaire-default-item {
    padding: 0.55rem 0.25rem 0.65rem;
    border-bottom: 1px solid #e5e7eb;
}

.questionnaire-default-item:last-child {
    border-bottom: none;
}

.questionnaire-default-question {
    display: flex;
    align-items: flex-start;
    gap: 0.35rem;
    margin-bottom: 0.35rem;
    color: #111827;
    font-weight: 600;
}

.questionnaire-default-question-text {
    min-width: 0;
}

.questionnaire-required-mark {
    color: #dc2626;
    font-weight: 700;
}

.questionnaire-default-options {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 1.4rem;
    padding-left: 1.35rem;
}

.questionnaire-default-option {
    min-width: 9rem;
    margin: 0;
    color: #111827;
}

.questionnaire-template-input {
    display: inline-block;
    width: 3.75rem;
    min-width: 3.75rem;
    height: 1.6rem;
    margin: 0 .2rem;
    padding: .1rem .35rem;
    border: 1px solid #64748b;
    border-radius: 2px;
    background: #dbeafe;
    color: #111827;
    line-height: 1.2;
    vertical-align: baseline;
}

.questionnaire-defaults-modal .form-check-label {
    color: #111827;
}

.questionnaire-defaults-modal .form-check-input {
    background-color: #ffffff;
    border-color: #64748b;
}

.questionnaire-defaults-modal .form-check-input:checked {
    background-color: #2563eb;
    border-color: #2563eb;
}

.questionnaire-defaults-modal .form-control {
    max-width: 18rem;
    margin-left: 1.35rem;
    background: #f8fafc !important;
    border-color: #94a3b8 !important;
    color: #111827 !important;
}

.questionnaire-defaults-modal .text-muted {
    color: #64748b !important;
}

/* ─── 檢驗項目表單群組（fieldset／舊系統 GroupBox 外框） ───────────────────────── */
.check-item-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.check-item-form fieldset.check-item-form-group {
    border: 1px solid var(--panel-border);
    border-radius: 0.375rem;
    padding: 0.75rem 1rem 1rem;
    margin: 0;
    min-width: 0;
}
.check-item-form .check-item-form-price-addon {
    margin-bottom: 0;
}
.check-item-form fieldset.check-item-form-group legend {
    float: none;
    width: auto;
    padding: 0 0.5rem;
    margin-bottom: 0.5rem;
    margin-left: -0.25rem;
    font-size: 1.125rem;
    font-weight: 700;
    color: #f3f7ff;
    line-height: 1.35;
    letter-spacing: 0.01em;
}

/* ─── Login page ─────────────────────────────────────────────────────────────────── */
.login-page {
    background: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-wrapper { width: 100%; max-width: 420px; padding: 24px; }

.login-copyright {
    margin: 18px 0 0;
    text-align: center;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.65);
}
[data-theme="light"] .login-copyright { color: rgba(30, 41, 59, 0.55); }

.login-card {
    background: #172233;
    border: 1px solid #2f4156;
    border-radius: 16px;
    padding: 36px 32px;
    box-shadow: 0 24px 64px rgba(0,0,0,0.55);
    color: #e6efff;
}

.login-header {
    text-align: center;
    margin-bottom: 32px;
}

.login-logo {
    width: 84px;
    height: 84px;
    margin-bottom: 18px;
    filter: drop-shadow(0 0 12px rgba(37,99,235,0.5));
}
.login-title { font-size: 28px; font-weight: 700; color: #f3f7ff; margin: 0; }
.login-subtitle { font-size: 16px; color: #7a9ab8; margin-top: 6px; }

/* 表單標籤 */
.login-page .form-label { color: #94a3b8; font-size: 13px; margin-bottom: 5px; font-weight: 500; }

/* 輸入框 */
.login-page .form-control,
.login-page .form-select {
    background: #0f1b2c;
    border-color: #2f4156;
    color: #e6efff;
}
.login-page .form-control::placeholder { color: #4a6480; }
.login-page .form-control:focus,
.login-page .form-select:focus {
    background: #0f1b2c;
    color: #fff;
    border-color: #2563eb;
    box-shadow: 0 0 0 0.2rem rgba(37,99,235,0.25);
}

/* input-group icon */
.login-page .input-group-text {
    background: #162235;
    border-color: #2f4156;
    color: #7a9ab8;
}

/* 語系選擇區 */
.login-lang-box {
    background: #0f1b2c;
    border: 1px solid #2f4156;
    border-radius: 8px;
    padding: 12px 14px;
}
.login-page .btn-outline-secondary {
    color: #c8d8ea;
    border-color: #2f4156;
    background: #162235;
}
.login-page .btn-outline-secondary:hover,
.login-page .btn-outline-secondary:focus {
    background: #1f3147;
    color: #fff;
    border-color: #3f5570;
}
.login-page .dropdown-menu {
    background: #172233;
    border-color: #2f4156;
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.login-page .dropdown-item { color: #c8d8ea; font-size: 14px; }
.login-page .dropdown-item:hover { background: #1f3147; color: #fff; }
.login-page .dropdown-item.active,
.login-page .dropdown-item:active { background: #2563eb; color: #fff; }

/* 錯誤提示 */
.login-page .alert-danger {
    background: #3b1f2b;
    border-color: #7f1d1d;
    color: #fca5a5;
}

/* 驗證碼 */
.captcha-input { width: 140px; flex-shrink: 0; letter-spacing: 3px; font-size: 16px; font-weight: 600; }
.captcha-img-wrap { display: flex; align-items: center; cursor: pointer; }
.captcha-img-wrap img { height: 40px; border-radius: 6px; border: 1px solid #2f4156; }

/* 登入按鈕 */
.btn-login { padding: 11px; font-size: 15px; font-weight: 600; letter-spacing: 0.3px; }

/* ─── Login page（淺色模式） ─────────────────────────────────────────────── */
[data-theme="light"] .login-page {
    background: linear-gradient(135deg, #3fa0e0 0%, #f5fafa 50%, #4fd0b5 100%);
}

[data-theme="light"] .login-card {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    box-shadow: 0 24px 64px rgba(15, 23, 42, 0.12);
    color: #1e293b;
}

[data-theme="light"] .login-logo {
    filter: drop-shadow(0 0 12px rgba(37, 99, 235, 0.25));
}
[data-theme="light"] .login-title { color: #1e293b; }
[data-theme="light"] .login-subtitle { color: #64748b; }

[data-theme="light"] .login-page .form-label { color: #475569; }

[data-theme="light"] .login-page .form-control,
[data-theme="light"] .login-page .form-select {
    background: #f8fafc;
    border-color: #cbd5e1;
    color: #1e293b;
}
[data-theme="light"] .login-page .form-control::placeholder { color: #94a3b8; }
[data-theme="light"] .login-page .form-control:focus,
[data-theme="light"] .login-page .form-select:focus {
    background: #ffffff;
    color: #1e293b;
    border-color: #2563eb;
    box-shadow: 0 0 0 0.2rem rgba(37, 99, 235, 0.15);
}

[data-theme="light"] .login-page .input-group-text {
    background: #f1f5f9;
    border-color: #cbd5e1;
    color: #64748b;
}

[data-theme="light"] .login-lang-box {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}
[data-theme="light"] .login-page .btn-outline-secondary {
    color: #475569;
    border-color: #cbd5e1;
    background: #ffffff;
}
[data-theme="light"] .login-page .btn-outline-secondary:hover,
[data-theme="light"] .login-page .btn-outline-secondary:focus {
    background: #f1f5f9;
    color: #1e293b;
    border-color: #94a3b8;
}
[data-theme="light"] .login-page .dropdown-menu {
    background: #ffffff;
    border-color: #e2e8f0;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
}
[data-theme="light"] .login-page .dropdown-item { color: #334155; }
[data-theme="light"] .login-page .dropdown-item:hover { background: #f1f5f9; color: #1e293b; }
[data-theme="light"] .login-page .dropdown-item.active,
[data-theme="light"] .login-page .dropdown-item:active { background: #2563eb; color: #fff; }

[data-theme="light"] .login-page .alert-danger {
    background: #fef2f2;
    border-color: #fecaca;
    color: #b91c1c;
}

[data-theme="light"] .captcha-img-wrap img { border-color: #cbd5e1; }

/* 登入頁左側插圖（僅淺色模式顯示，呼應體檢／照護流程意象） */
.login-illustration { display: none; }

[data-theme="light"] .login-wrapper { max-width: 900px; padding: 56px 24px; }

[data-theme="light"] .login-card {
    display: flex;
    align-items: stretch;
    padding: 0;
    border-radius: 20px;
    overflow: hidden;
}

[data-theme="light"] .login-illustration {
    display: flex;
    flex: 1 1 44%;
    align-items: center;
    justify-content: center;
    background: linear-gradient(160deg, #eef4fa 0%, #e3edf7 100%);
    padding: 24px 20px;
}

[data-theme="light"] .login-form-panel {
    flex: 1 1 56%;
    padding: 28px 36px 32px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

[data-theme="light"] .login-form-panel .login-header {
    margin-bottom: 18px;
}

[data-theme="light"] .login-form-panel .login-logo {
    width: 56px;
    height: 56px;
    margin-bottom: 10px;
}

[data-theme="light"] .login-form-panel .login-title {
    font-size: 22px;
}

[data-theme="light"] .login-form-panel .login-subtitle {
    font-size: 14px;
    margin-top: 4px;
}

[data-theme="light"] .login-form-panel form .mb-3 {
    margin-bottom: 0.65rem !important;
}

[data-theme="light"] .login-form-panel .login-lang-box {
    padding: 8px 12px;
}

.login-illustration-art {
    position: relative;
    width: 100%;
    max-width: 220px;
    height: 260px;
}

.login-illu-line {
    position: absolute;
    top: 8%;
    bottom: 8%;
    width: 2px;
    background: rgba(47, 102, 144, 0.18);
    border-radius: 2px;
}
.login-illu-line-1 { left: 28%; }
.login-illu-line-2 { left: 58%; top: 4%; bottom: 18%; }
.login-illu-line-3 { left: 82%; top: 18%; bottom: 32%; }

.login-illu-icon {
    position: absolute;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 19px;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.16);
}
.login-illu-icon-lg { width: 64px; height: 64px; font-size: 23px; }
.login-illu-icon-sm { width: 42px; height: 42px; font-size: 15px; }

.login-illu-blue { background: linear-gradient(145deg, #4f8fc7 0%, #2f6690 100%); }
.login-illu-green { background: linear-gradient(145deg, #34a06a 0%, #1e7a4f 100%); }

.login-illu-icon-1 { top: 4%;  left: 14%; }
.login-illu-icon-2 { top: 17%; left: 60%; }
.login-illu-icon-3 { top: 38%; left: 50%; }
.login-illu-icon-4 { top: 56%; left: 8%; }
.login-illu-icon-5 { top: 66%; left: 60%; }
.login-illu-icon-6 { top: 84%; left: 30%; }

@media (max-width: 991.98px) {
    [data-theme="light"] .login-wrapper { max-width: 420px; padding: 24px; }
    [data-theme="light"] .login-card { display: block; padding: 36px 32px; border-radius: 16px; }
    [data-theme="light"] .login-form-panel { padding: 0; }
    [data-theme="light"] .login-illustration { display: none; }
}

/* LINE binding page */
.line-bind-wrapper {
    max-width: 440px;
}

.line-bind-card {
    padding-bottom: 30px;
}

.line-bind-status {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    background: #0f1b2c;
    border: 1px solid #2f4156;
    border-radius: 10px;
    padding: 16px;
    margin-bottom: 18px;
}

.line-bind-status-icon {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 20px;
}

.line-bind-status-ready .line-bind-status-icon {
    background: rgba(37, 99, 235, 0.18);
    color: #93c5fd;
}

.line-bind-status-success .line-bind-status-icon {
    background: rgba(22, 163, 74, 0.18);
    color: #86efac;
}

.line-bind-status-danger .line-bind-status-icon {
    background: rgba(220, 38, 38, 0.18);
    color: #fca5a5;
}

.line-bind-status-title {
    color: #f3f7ff;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.35;
}

.line-bind-status-message {
    color: #b7c8de;
    margin-top: 4px;
    line-height: 1.55;
}

.line-bind-user {
    color: #dbeafe;
    background: #162235;
    border: 1px solid #2f4156;
    border-radius: 8px;
    padding: 8px 10px;
    margin-top: 12px;
    font-size: 13px;
}

/* ─── Institution switcher ─────────────────────────────────────────────────────── */
#institution-switcher-container .dropdown-toggle {
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ─── Modal / form scroll areas (was inline style on Users & Groups) ───────────── */
.scroll-y-max-150 {
    max-height: 150px;
    overflow-y: auto;
}

/* ─── Bed parameter settings tree & sensor cards (from BedSettings.cshtml) ─────── */
#bedParamApp .bed-param-tree-scroll {
    max-height: 75vh;
    overflow-y: auto;
}

#bedParamApp .bed-tree-count {
    font-size: 12px;
}

#bedParamApp .bed-tree-btn {
    display: block;
    width: 100%;
    text-align: left;
    background: var(--panel-bg);
    color: var(--panel-text);
    border: none;
    border-bottom: 1px solid var(--panel-border);
    padding: 8px 12px;
    cursor: pointer;
    font-size: 13.5px;
    font-weight: 500;
    transition: background 0.15s, color 0.15s;
}
#bedParamApp .bed-tree-btn:hover  { background: var(--sidebar-hover-bg); color: var(--sidebar-text-active); }
#bedParamApp .bed-tree-btn.active { background: var(--sidebar-active-bg); color: #fff; }

#bedParamApp .bed-tree-bed {
    display: block;
    width: 100%;
    text-align: left;
    background: var(--panel-input-bg);
    color: var(--panel-text);
    border: none;
    border-bottom: 1px solid var(--panel-border);
    padding: 6px 12px 6px 36px;
    cursor: pointer;
    font-size: 13px;
    transition: background 0.15s, color 0.15s;
}
#bedParamApp .bed-tree-bed:hover  { background: var(--sidebar-hover-bg); color: var(--sidebar-text-active); }
#bedParamApp .bed-tree-bed.active { background: var(--sidebar-active-bg); color: #fff; }

#bedParamApp .sensor-card {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 16px;
}
#bedParamApp .sensor-card .sensor-title { color: #f3f7ff; font-weight: 600; }

/* ─── Bed setting page grid (from BedSetting/Index.cshtml) ─────────────────────── */
.bed-row {
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}

.bed-chip {
    width: 100%;
    min-width: 0;
    min-height: 3.25rem;
    align-items: center;
}

.bed-chip .fa-bed {
    font-size: 1.15rem;
}

.bed-chip .btn {
    font-size: 0.9rem !important;
    padding: 0.2rem 0.35rem;
}

.bed-chip .form-check-input {
    width: 1.1em;
    height: 1.1em;
    margin-top: 0.15em;
}

.zone-drag-handle,
.room-drag-handle {
    cursor: grab;
    user-select: none;
    touch-action: none;
}

.zone-drag-handle:active,
.room-drag-handle:active {
    cursor: grabbing;
}

@media (min-width: 1400px) {
    .bed-row {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }
}

/* ─── Group menu permissions workspace ───────────────────────────────────────── */
#groupMenusApp .group-menu-layout {
    display: grid;
    grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
    gap: 16px;
    align-items: stretch;
}
#groupMenusApp .group-menu-sidebar,
#groupMenusApp .group-menu-workspace {
    min-height: 640px;
}
#groupMenusApp .group-menu-search {
    padding: 12px;
    border-bottom: 1px solid var(--panel-border);
}
#groupMenusApp .group-menu-list {
    max-height: 580px;
    overflow: auto;
}
#groupMenusApp .group-menu-list-item {
    width: 100%;
    min-height: 42px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 8px 12px;
    border: 0;
    border-bottom: 1px solid var(--panel-border);
    background: var(--panel-bg-soft);
    color: var(--panel-text);
    text-align: left;
}
#groupMenusApp .group-menu-list-item:hover {
    background: #263a53;
    color: #ffffff;
}
#groupMenusApp .group-menu-list-item.active {
    background: var(--sidebar-active-bg);
    color: #ffffff;
}
#groupMenusApp .group-menu-list-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
#groupMenusApp .group-menu-toolbar {
    min-height: 58px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}
#groupMenusApp .group-menu-title {
    color: #f3f7ff;
    font-weight: 600;
    line-height: 1.25;
}
#groupMenusApp .group-menu-subtitle {
    margin-top: 3px;
    color: #9fb2cc;
    font-size: 0.8125rem;
    font-weight: 400;
}
#groupMenusApp .group-menu-body {
    padding: 0;
}
#groupMenusApp .group-menu-rolebar,
#groupMenusApp .group-menu-controls {
    display: flex;
    align-items: flex-end;
    gap: 10px;
    flex-wrap: wrap;
    padding: 12px 16px;
    border-bottom: 1px solid var(--panel-border);
}
#groupMenusApp .group-menu-field {
    width: min(320px, 100%);
}
#groupMenusApp .group-menu-role-status {
    min-height: 31px;
    display: flex;
    align-items: center;
    font-size: 0.875rem;
}
#groupMenusApp .group-menu-filter {
    width: min(260px, 100%);
    margin-left: auto;
}
#groupMenusApp .group-menu-table-wrap {
    overflow: auto;
    max-height: 520px;
}
#groupMenusApp .group-menu-table {
    min-width: 760px;
}
#groupMenusApp .group-menu-table thead th {
    position: sticky;
    top: 0;
    z-index: 1;
}
#groupMenusApp .group-menu-menu-col {
    width: 42%;
}
#groupMenusApp .group-menu-parent-row td {
    background: #162235;
    font-weight: 600;
}
#groupMenusApp .group-menu-child-table-row td:first-child {
    padding-left: 32px;
}
#groupMenusApp .group-menu-parent-label,
#groupMenusApp .group-menu-child-label {
    margin: 0;
    display: inline-flex;
    align-items: center;
    min-height: 24px;
}
#groupMenusApp .group-menu-empty,
#groupMenusApp .group-menu-state {
    padding: 20px;
    color: #9fb2cc;
}

@media (max-width: 991.98px) {
    #groupMenusApp .group-menu-layout {
        grid-template-columns: 1fr;
    }
    #groupMenusApp .group-menu-sidebar,
    #groupMenusApp .group-menu-workspace {
        min-height: auto;
    }
    #groupMenusApp .group-menu-list {
        max-height: 240px;
    }
    #groupMenusApp .group-menu-filter {
        margin-left: 0;
    }
}

/* ─── Menu tree table indent (depth via CSS variable from Vue) ─────────────────── */
#menusApp .menu-tree-indent {
    display: inline-block;
    padding-left: calc(var(--menu-depth, 0) * 20 * 1px);
}
#menusApp .menu-drag-col {
    width: 2.25rem;
    text-align: center;
    vertical-align: middle;
}
#menusApp .menu-drag-handle {
    cursor: grab;
    color: #6c757d;
    padding: .15rem .35rem;
    border-radius: .25rem;
    touch-action: none;
}
#menusApp .menu-drag-handle:hover {
    color: #0d6efd;
    background: rgba(13, 110, 253, .08);
}
#menusApp .menu-drag-handle:active {
    cursor: grabbing;
}
#menusApp tr.menu-row-drag-over {
    outline: 2px dashed #0d6efd;
    outline-offset: -2px;
}
#menusApp tr.menu-row-drop-forbidden {
    opacity: .45;
}

/* ─── Responsive ─────────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .sidebar { position: fixed; left: -240px; top: 0; bottom: 0; z-index: 999; transition: left var(--transition); }
    .sidebar.mobile-open { left: 0; }
    .main-content { width: 100%; }
    .monitoring-beds { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .monitoring-title { font-size: 24px; }
    .monitoring-room-header { font-size: 24px; }
}

/* User maintenance */
.user-maintenance {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.user-toolbar {
    display: flex;
    justify-content: flex-end;
}

.user-form-shell,
.user-list-panel {
    background: #f7f7f7;
    border: 1px solid #d7d7d7;
    border-radius: 8px;
    color: #111827;
    overflow: hidden;
}

.user-section-title,
.user-list-title {
    padding: 8px 12px;
    font-weight: 700;
    background: #43b997;
    border-bottom: 1px solid #2f9e80;
    color: #ffffff;
}

.legacy-form-grid {
    display: grid;
    grid-template-columns: 112px minmax(260px, 1fr) 96px minmax(360px, 2fr);
    border-left: 1px solid #d7d7d7;
}

.legacy-label,
.legacy-field {
    min-height: 45px;
    border-right: 1px solid #d7d7d7;
    border-bottom: 1px solid #d7d7d7;
}

.legacy-label {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px 10px;
    background: #f5f5f5;
    color: #111827;
    font-weight: 700;
    white-space: nowrap;
}

.legacy-field {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 8px;
    background: #ffffff;
    color: #111827;
}

.legacy-span {
    grid-column: span 3;
}

.role-label,
.service-label {
    min-height: 96px;
}

.role-box,
.service-box {
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 0;
    padding: 0;
}

.role-check {
    width: 128px;
    min-height: 44px;
    margin: 0;
    padding: 10px 8px 8px 36px;
    border-right: 1px solid #d7d7d7;
    border-bottom: 1px solid #d7d7d7;
}

.service-check {
    width: 180px;
    min-height: 30px;
    margin: 0;
    padding: 5px 8px 3px 36px;
}

.role-primary {
    background: #ecfdf5;
}

.branch-value {
    font-weight: 600;
    color: #111827;
}

.field-60 { max-width: 60px; }
.field-120 { max-width: 120px; }
.field-160 { max-width: 160px; }
.field-220 { max-width: 220px; }
.field-300 { max-width: 300px; }
.field-520 { max-width: 520px; }

.user-maintenance .form-check-label {
    color: #111827;
}

.user-maintenance .table {
    margin-bottom: 0;
    --bs-table-bg: #ffffff;
}

.birth-field,
.contact-address-field {
    flex-wrap: wrap;
}

.disabled-choice-box {
    background: #f8fafc;
}

.disabled-choice-box .form-check-label {
    color: #94a3b8;
}

@media (max-width: 992px) {
    .legacy-form-grid {
        grid-template-columns: 110px minmax(0, 1fr);
    }

    .legacy-span {
        grid-column: span 1;
    }

    .role-check,
    .service-check {
        width: 50%;
    }
}

/* ─── License badge ──────────────────────────────────────────────────────────── */
.license-badge {
    display: inline-block;
    font-size: 0.65rem;
    font-weight: 700;
    line-height: 1;
    padding: 2px 4px;
    border-radius: 3px;
    vertical-align: middle;
    margin-left: 4px;
}

.license-badge.expired {
    background-color: #dc2626;
    color: #fff;
}

.license-badge.expiring {
    background-color: #f59e0b;
    color: #1e1e1e;
}

/* License badge */

/* ─── CheckItem DBGrid（Tabulator）──────────────── */
.check-item-page {
    min-width: 0;
    max-width: 100%;
    width: 100%;
}

.check-item-grid-panel {
    position: relative;
    background: var(--panel-bg-soft);
    border: 1px solid var(--panel-border);
    border-radius: 0.375rem;
    overflow: hidden;
}

.check-item-grid-panel .tabulator {
    background: var(--panel-bg-soft) !important;
    border: none;
    font-size: 0.8125rem;
    color: var(--panel-text) !important;
}

.check-item-grid-panel .tabulator-tableholder,
.check-item-grid-panel .tabulator-tableholder .tabulator-table {
    background-color: var(--panel-bg-soft) !important;
    color: var(--panel-text) !important;
}

.check-item-grid-panel .tabulator-header,
.check-item-grid-panel .tabulator-header .tabulator-col {
    background-color: #162235 !important;
    color: #f3f7ff !important;
    border-color: var(--panel-border) !important;
}

.check-item-grid-panel .tabulator-col {
    border: 1px solid var(--panel-border) !important;
}

.check-item-grid-panel .tabulator-col .tabulator-col-content {
    padding: 0.4rem 0.55rem;
}

.check-item-grid-panel .tabulator-row,
.check-item-grid-panel .tabulator-row.tabulator-row-even {
    background-color: var(--panel-bg-soft) !important;
    border-color: var(--panel-border) !important;
    color: var(--panel-text) !important;
}

.check-item-grid-panel .tabulator-row:hover {
    background-color: #304866 !important;
    color: #ffffff !important;
}

.check-item-grid-panel .tabulator-row.tabulator-selected,
.check-item-grid-panel .tabulator-row.tabulator-selected:hover {
    background-color: #2563eb !important;
    color: #ffffff !important;
}

/* 選取／hover 列上的操作按鈕：避免 outline-primary 與藍底同色 */
.check-item-grid-panel .tabulator-row:hover .tabulator-cell .btn-outline-primary,
.check-item-grid-panel .tabulator-row.tabulator-selected .tabulator-cell .btn-outline-primary {
    color: #eff6ff;
    border-color: rgba(255, 255, 255, 0.9);
    background-color: rgba(255, 255, 255, 0.15);
}

.check-item-grid-panel .tabulator-row:hover .tabulator-cell .btn-outline-primary:hover,
.check-item-grid-panel .tabulator-row.tabulator-selected .tabulator-cell .btn-outline-primary:hover {
    color: #1e40af;
    background-color: #fff;
    border-color: #fff;
}

.check-item-grid-panel .tabulator-row:hover .tabulator-cell .btn-outline-danger,
.check-item-grid-panel .tabulator-row.tabulator-selected .tabulator-cell .btn-outline-danger {
    color: #fecaca;
    border-color: #fca5a5;
    background-color: rgba(255, 255, 255, 0.08);
}

.check-item-grid-panel .tabulator-row:hover .tabulator-cell .btn-outline-danger:hover,
.check-item-grid-panel .tabulator-row.tabulator-selected .tabulator-cell .btn-outline-danger:hover {
    color: #fff;
    background-color: #dc3545;
    border-color: #dc3545;
}

.check-item-grid-panel .tabulator-cell {
    padding: 0.35rem 0.55rem;
    display: flex;
    align-items: center;
    background-color: transparent !important;
    border: 1px solid var(--panel-border) !important;
}

.check-item-grid-panel .tabulator-frozen-left,
.check-item-grid-panel .tabulator-frozen-right {
    border-color: var(--panel-border) !important;
}

.check-item-grid-panel .tabulator-placeholder-contents,
.check-item-grid-panel .tabulator-placeholder-contents span {
    color: #8fa4c1 !important;
}

.check-item-grid-panel .tabulator-tableholder::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

.check-item-grid-panel .tabulator-tableholder::-webkit-scrollbar-track {
    background: var(--panel-input-bg);
}

.check-item-grid-panel .tabulator-tableholder::-webkit-scrollbar-thumb {
    background: var(--panel-border);
    border-radius: 3px;
}

.check-item-grid-panel .tabulator-tableholder::-webkit-scrollbar-thumb:hover {
    background: #4b6a8f;
}

.check-item-grid-loading {
    position: absolute;
    inset: 0;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(15, 27, 44, 0.6);
    color: var(--panel-text);
}

.check-item-grid-pager {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
    padding: 0.5rem 0.75rem;
    border-top: 1px solid var(--panel-border);
    background: var(--panel-bg);
    color: var(--panel-text);
    font-size: 0.8125rem;
}

.check-item-grid-pager .page-input {
    width: 4rem;
}

.index-grid-pager {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--panel-border);
    border-radius: 0.375rem;
    background: var(--panel-bg);
    color: var(--panel-text);
    font-size: 0.8125rem;
}

.index-grid-pager .page-input {
    width: 4rem;
}

.index-grid-pager .page-size-select {
    width: auto;
}

.check-item-actions-card .card-body {
    min-height: 100%;
}

.check-item-phrase-item-list,
.check-item-phrase-grid-panel {
    max-height: min(52vh, 28rem);
    overflow: auto;
    background: var(--panel-bg, #fff);
}

.check-item-phrase-manage tbody tr[role="button"] {
    cursor: pointer;
}

.check-item-sort-list {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    background: var(--panel-bg, #fff);
}

/* 排序設定 Modal：高度約螢幕 3/4，表格區自動填滿 */
#sortManageModal .modal-dialog.check-item-sort-modal-dialog {
    height: 75vh;
    max-height: 75vh;
}

#sortManageModal .modal-dialog.check-item-sort-modal-dialog .modal-content {
    height: 100%;
    display: flex;
    flex-direction: column;
}

#sortManageModal .modal-dialog.check-item-sort-modal-dialog .modal-body {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.check-item-sort-drag-col {
    width: 2.25rem;
    text-align: center;
    vertical-align: middle;
}

.check-item-sort-drag-handle {
    cursor: grab;
    color: #6c757d;
    padding: .15rem .35rem;
    border-radius: .25rem;
    touch-action: none;
    display: inline-flex;
}

.check-item-sort-drag-handle:hover {
    color: #0d6efd;
    background: rgba(13, 110, 253, .08);
}

.check-item-sort-drag-handle:active {
    cursor: grabbing;
}

#sortManageModal tr.check-item-sort-row {
    cursor: pointer;
}

#sortManageModal tr.check-item-sort-row-drag-over {
    outline: 2px dashed #0d6efd;
    outline-offset: -2px;
}

/* 排序設定 Modal：深色標題列內的頁籤（覆寫 Bootstrap 預設黑字） */
#sortManageModal .modal-header .nav-tabs .nav-link {
    color: #c8d5e7;
    border: 1px solid transparent;
    border-bottom: none;
    margin-bottom: -1px;
    background: transparent;
}

#sortManageModal .modal-header .nav-tabs .nav-link:hover {
    color: #f3f7ff;
    border-color: var(--panel-border);
    background: #1f2f47;
}

#sortManageModal .modal-header .nav-tabs .nav-link.active {
    color: #f3f7ff;
    background-color: var(--panel-bg-soft);
    border-color: var(--panel-border) var(--panel-border) var(--panel-bg-soft);
    font-weight: 600;
}

/* 體檢專案編輯 Modal：標題列固定白底，頁籤文字改用固定深淺灰階，
   避免淡色模式下被全域 .nav-link（側邊欄用，色淺）覆寫導致看不清 */
#projectModal .nav-tabs .nav-link {
    color: #6c757d;
}
#projectModal .nav-tabs .nav-link:hover {
    color: #343a40;
}
#projectModal .nav-tabs .nav-link.active {
    color: #1e293b;
    font-weight: 600;
}

/* 項目群組 Modal：加寬加高，群組名稱單行顯示 */
#groupManageModal .modal-dialog.check-item-group-modal-dialog {
    width: min(96vw, 90rem);
    max-width: min(96vw, 90rem);
    height: 75vh;
    max-height: 75vh;
}

#groupManageModal .modal-dialog.check-item-group-modal-dialog .modal-content {
    height: 100%;
    display: flex;
    flex-direction: column;
}

#groupManageModal .modal-dialog.check-item-group-modal-dialog .modal-body {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.check-item-group-list {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}

.check-item-group-table .check-item-group-col-seq {
    width: 3.5rem;
    white-space: nowrap;
}

.check-item-group-table .check-item-group-col-name {
    width: 1%;
    min-width: 14rem;
    white-space: nowrap;
}

.check-item-group-table .check-item-group-col-codes {
    word-break: break-all;
}

.check-item-group-table .check-item-group-col-actions {
    width: 7rem;
    white-space: nowrap;
}

/* 體檢方案設定編輯 Modal（modal-xl 疊加，支援巢狀於專案編輯視窗） */
#examServicePlanEditorModal .modal-dialog.exam-service-plan-editor-dialog {
    max-width: 1140px;
    width: 96vw;
    height: min(94vh, calc(100vh - 2.5rem));
    max-height: min(94vh, calc(100vh - 2.5rem));
}

#examServicePlanEditorModal .modal-dialog.exam-service-plan-editor-dialog .modal-content {
    height: 100%;
    display: flex;
    flex-direction: column;
}

#examServicePlanEditorModal .modal-dialog.exam-service-plan-editor-dialog .modal-content > .exam-service-plan-editor-shell {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
}

#examServicePlanEditorModal .modal-dialog.exam-service-plan-editor-dialog .modal-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}

.exam-plan-editor-layout {
    min-height: 520px;
}

#examServicePlanEditorModal .col-lg-8.d-flex.flex-column {
    min-height: 0;
}

#examServicePlanEditorModal .exam-plan-shell.flex-grow-1 {
    flex: 1 1 auto;
    min-height: 0;
}

#examServicePlanEditorModal .exam-plan-shell .exam-plan-workspace {
    min-height: 300px;
}

#examServicePlanEditorModal .exam-plan-items-table-wrap {
    max-height: min(38vh, 360px);
}

#examServicePlanEditorModal .exam-plan-option-groups-card {
    flex-shrink: 0;
}

.exam-plan-option-groups-body {
    overflow: hidden;
}

.exam-plan-option-groups-table-wrap {
    height: 11rem;
    max-height: 11rem;
    overflow: auto;
    background: var(--panel-bg-soft);
}

.exam-plan-option-groups-table {
    --bs-table-color: var(--panel-text);
    --bs-table-bg: var(--panel-bg-soft);
    --bs-table-striped-bg: #263a53;
    --bs-table-striped-color: var(--panel-text);
    --bs-table-hover-bg: #304866;
    --bs-table-hover-color: #ffffff;
    --bs-table-border-color: var(--panel-border);
    color: var(--panel-text);
    margin-bottom: 0;
}

.exam-plan-option-groups-table thead th {
    background-color: #162235 !important;
    color: #f3f7ff !important;
    border-color: var(--panel-border) !important;
    white-space: nowrap;
    vertical-align: middle;
}

.exam-plan-option-groups-table tbody td {
    border-color: var(--panel-border);
    color: var(--panel-text);
    vertical-align: middle;
}

.exam-plan-option-groups-table .form-control-sm {
    min-width: 0;
}

.exam-plan-option-groups-table .exam-plan-col-group-no {
    width: 3.5rem;
}

.exam-plan-option-groups-table .exam-plan-col-select-limit {
    width: 5.5rem;
}

.exam-plan-option-groups-table .exam-plan-col-group-actions {
    width: 3.25rem;
}

.exam-plan-package-summary {
    background: var(--panel-bg-soft);
    border-color: var(--panel-border) !important;
    color: var(--panel-text);
}

.exam-plan-manual-add-input {
    width: 8.5rem;
}

.exam-plan-package-count strong {
    font-variant-numeric: tabular-nums;
}

.exam-plan-page {
    min-width: 0;
}

/* 左側方案清單：選取列（比照檢查類別 active，提高對比） */
#examServicePlanEditorModal .exam-plan-project-plans-table tbody tr.exam-plan-plan-row {
    cursor: pointer;
}

#examServicePlanEditorModal .exam-plan-project-plans-table tbody tr.exam-plan-plan-row:not(.exam-plan-plan-row-selected):hover > td {
    background-color: #304866 !important;
    color: #ffffff !important;
}

#examServicePlanEditorModal .exam-plan-project-plans-table tbody tr.exam-plan-plan-row-selected > td {
    background-color: #304866 !important;
    color: #ffffff !important;
    border-color: var(--panel-border) !important;
    font-weight: 600;
}

#examServicePlanEditorModal .exam-plan-project-plans-table tbody tr.exam-plan-plan-row-selected > td:first-child {
    box-shadow: inset 4px 0 0 0 #3b82f6;
}

[data-theme="light"] #examServicePlanEditorModal .exam-plan-project-plans-table tbody tr.exam-plan-plan-row:not(.exam-plan-plan-row-selected):hover > td {
    background-color: #eff6ff !important;
    color: #1e40af !important;
}

[data-theme="light"] #examServicePlanEditorModal .exam-plan-project-plans-table tbody tr.exam-plan-plan-row-selected > td {
    background-color: #2563eb !important;
    color: #ffffff !important;
    border-color: #93c5fd !important;
    font-weight: 600;
}

[data-theme="light"] #examServicePlanEditorModal .exam-plan-project-plans-table tbody tr.exam-plan-plan-row-selected > td:first-child {
    box-shadow: inset 4px 0 0 0 #1d4ed8;
}

.exam-plan-charge-type-fieldset legend {
    font-size: inherit;
    float: none;
    width: auto;
    margin-bottom: 0;
}

.exam-plan-shell.card {
    background: var(--panel-bg);
    border-color: var(--panel-border);
    color: var(--panel-text);
}

.exam-plan-shell .card-body {
    background: var(--panel-bg);
}

.exam-plan-shell .exam-plan-workspace {
    display: grid;
    grid-template-columns: minmax(200px, 260px) minmax(0, 1fr);
    min-height: 420px;
    background: var(--panel-bg);
}

.exam-plan-category-nav {
    background: var(--panel-bg-soft);
    border-color: var(--panel-border) !important;
}

.exam-plan-category-nav-header {
    background: var(--panel-bg-soft);
    border-color: var(--panel-border) !important;
    color: var(--panel-text);
}

.exam-plan-category-list {
    max-height: 360px;
    overflow: auto;
    background: var(--panel-bg-soft);
}

.exam-plan-category-list .list-group-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    border-left: 3px solid transparent;
    background-color: var(--panel-bg-soft);
    border-color: var(--panel-border);
    color: var(--panel-text);
}

.exam-plan-category-list .list-group-item:hover,
.exam-plan-category-list .list-group-item:focus {
    background-color: #304866;
    color: #ffffff;
}

.exam-plan-category-list .list-group-item.active {
    background-color: #304866;
    border-color: var(--panel-border);
    border-left-color: var(--bs-primary);
    color: #ffffff;
    font-weight: 600;
}

.exam-plan-category-list .badge {
    background-color: #263a53 !important;
    color: var(--panel-text) !important;
}

.exam-plan-items-panel {
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
    position: relative;
    background: var(--panel-bg-soft);
}

.exam-plan-items-sort-row {
    background: var(--panel-bg-soft);
    border-color: var(--panel-border) !important;
    color: var(--panel-text);
}

.exam-plan-items-sort-label {
    flex-shrink: 0;
    white-space: nowrap;
}

.exam-plan-items-sort-select {
    width: auto;
    min-width: 12rem;
    max-width: 18rem;
}

.exam-plan-items-sort-hint {
    min-width: 0;
}

.exam-plan-category-list .list-group-item.disabled,
.exam-plan-category-list .list-group-item:disabled {
    opacity: 0.55;
    pointer-events: none;
    cursor: not-allowed;
}

.exam-plan-items-toolbar {
    flex-wrap: nowrap;
    background: var(--panel-bg-soft);
    border-color: var(--panel-border) !important;
    color: var(--panel-text);
}

.exam-plan-items-toolbar-actions {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
}

.exam-plan-items-search {
    width: 12rem;
    min-width: 8rem;
    max-width: 16rem;
}

.exam-plan-items-toolbar .text-muted {
    color: #a8bdd4 !important;
}

.exam-plan-items-table-wrap {
    flex: 1 1 auto;
    min-height: 0;
    max-height: calc(75vh - 16rem);
    overflow: auto;
    background: var(--panel-bg-soft);
}

.exam-plan-items-table {
    --bs-table-color: var(--panel-text);
    --bs-table-bg: var(--panel-bg-soft);
    --bs-table-striped-bg: #263a53;
    --bs-table-striped-color: var(--panel-text);
    --bs-table-hover-bg: #304866;
    --bs-table-hover-color: #ffffff;
    --bs-table-border-color: var(--panel-border);
    color: var(--panel-text);
}

.exam-plan-items-table thead th {
    background-color: #162235 !important;
    color: #f3f7ff !important;
    border-color: var(--panel-border) !important;
}

.exam-plan-items-table tbody td {
    border-color: var(--panel-border);
    color: var(--panel-text);
}

.exam-plan-items-table tbody tr.table-active > td {
    background-color: #304866 !important;
    color: #ffffff !important;
}

.exam-plan-items-table tbody tr.table-active > td:first-child {
    box-shadow: inset 3px 0 0 #2563eb;
}

.exam-plan-items-table tbody tr.exam-plan-row-selectable {
    cursor: pointer;
    user-select: none;
}

.exam-plan-items-table tbody tr.exam-plan-row-selectable:not(.table-active):hover > td {
    background-color: rgba(48, 72, 102, 0.45);
}

.exam-plan-selection-bar {
    background: color-mix(in srgb, #2563eb 15%, var(--panel-bg-soft));
    border-color: color-mix(in srgb, #2563eb 35%, var(--panel-border)) !important;
    flex-shrink: 0;
}

.exam-plan-items-table .text-muted {
    color: #a8bdd4 !important;
}

.exam-plan-group-card {
    background: var(--panel-bg-soft);
    border-color: var(--panel-border) !important;
    color: var(--panel-text);
}

.exam-plan-page .card.shadow-sm:not(.exam-plan-shell) {
    background: var(--panel-bg);
    border-color: var(--panel-border);
    color: var(--panel-text);
}

.exam-plan-page .card-header {
    background: var(--panel-bg-soft);
    border-color: var(--panel-border);
    color: var(--panel-text);
}

.exam-plan-context-menu,
.exam-plan-page .exam-plan-dropdown-menu {
    --bs-dropdown-bg: var(--panel-bg);
    --bs-dropdown-border-color: var(--panel-border);
    --bs-dropdown-link-color: var(--panel-text);
    --bs-dropdown-link-hover-color: var(--panel-text);
    --bs-dropdown-link-hover-bg: var(--panel-bg-soft);
    --bs-dropdown-link-active-color: var(--panel-text);
    --bs-dropdown-link-active-bg: var(--panel-bg-soft);
    --bs-dropdown-link-disabled-color: color-mix(in srgb, var(--panel-text) 55%, transparent);
    background-color: var(--panel-bg) !important;
    border: 1px solid var(--panel-border) !important;
    color: var(--panel-text) !important;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
    z-index: 1030 !important;
}

[data-theme="dark"] .exam-plan-context-menu,
[data-theme="dark"] .exam-plan-page .exam-plan-dropdown-menu {
    --bs-dropdown-link-hover-color: #ffffff;
    --bs-dropdown-link-hover-bg: #304866;
    --bs-dropdown-link-active-color: #ffffff;
    --bs-dropdown-link-active-bg: #2563eb;
    --bs-dropdown-link-disabled-color: #7a92ab;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
}

[data-theme="light"] .exam-plan-context-menu,
[data-theme="light"] .exam-plan-page .exam-plan-dropdown-menu {
    --bs-dropdown-link-hover-color: #0f172a;
    --bs-dropdown-link-hover-bg: #e2e8f0;
    --bs-dropdown-link-active-color: #0f172a;
    --bs-dropdown-link-active-bg: #dbeafe;
    --bs-dropdown-link-disabled-color: #94a3b8;
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
}

.exam-plan-context-menu {
    position: absolute;
    z-index: 1050;
    min-width: 14rem;
    max-width: 22rem;
    padding: 0.35rem 0;
}

.exam-plan-context-menu .dropdown-header,
.exam-plan-page .exam-plan-dropdown-menu .dropdown-header {
    color: color-mix(in srgb, var(--panel-text) 72%, transparent) !important;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    padding: 0.35rem 1rem 0.25rem;
}

.exam-plan-context-menu .dropdown-item,
.exam-plan-page .exam-plan-dropdown-menu .dropdown-item {
    width: 100%;
    text-align: left;
    border: none;
    background: transparent;
    padding: 0.45rem 1rem;
    font-size: 0.875rem;
    line-height: 1.35;
    color: var(--panel-text) !important;
}

.exam-plan-context-menu .dropdown-item:hover:not(:disabled),
.exam-plan-context-menu .dropdown-item:focus:not(:disabled),
.exam-plan-page .exam-plan-dropdown-menu .dropdown-item:hover,
.exam-plan-page .exam-plan-dropdown-menu .dropdown-item:focus {
    background-color: var(--bs-dropdown-link-hover-bg) !important;
    color: var(--bs-dropdown-link-hover-color) !important;
}

.exam-plan-context-menu .dropdown-item:disabled,
.exam-plan-page .exam-plan-dropdown-menu .dropdown-item:disabled {
    color: var(--bs-dropdown-link-disabled-color) !important;
    opacity: 1;
}

.exam-plan-context-menu .dropdown-divider,
.exam-plan-page .exam-plan-dropdown-menu .dropdown-divider {
    border-color: var(--panel-border);
    opacity: 1;
    margin: 0.25rem 0;
}

.exam-plan-context-menu-hint,
.exam-plan-page .exam-plan-dropdown-menu .dropdown-item-text {
    color: color-mix(in srgb, var(--panel-text) 72%, transparent) !important;
    font-size: 0.8125rem;
}

.exam-plan-items-table .exam-plan-col-fixed {
    width: 2.75rem;
}

.exam-plan-items-table thead .exam-plan-col-fixed .form-check-input {
    margin: 0;
}

.exam-plan-items-table .exam-plan-col-select,
.exam-plan-items-table .exam-plan-col-optional {
    width: 3.5rem;
}

.exam-plan-optional-square {
    display: inline-block;
    width: 1rem;
    height: 1rem;
    border: 2px solid #6b8aad;
    border-radius: 0.15rem;
    background: transparent;
    vertical-align: middle;
}

.exam-plan-optional-square.is-on {
    background: var(--bs-primary);
    border-color: var(--bs-primary);
}

@media (max-width: 991.98px) {
    .exam-plan-shell .exam-plan-workspace {
        grid-template-columns: 1fr;
    }

    .exam-plan-category-nav {
        border-end: none !important;
        border-bottom: 1px solid var(--panel-border);
    }

    .exam-plan-category-list {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        overflow-x: auto;
        max-height: none;
    }

    .exam-plan-category-list .list-group-item {
        flex: 0 0 auto;
        white-space: nowrap;
    }
}

/* ─── 淺色模式元件覆蓋 ────────────────────────────────────────────────────────── */

/* ── 全站 Bootstrap 表格（最高優先，蓋掉所有 table-dark / table-light / 寫死深色） ── */
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) thead th,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) thead td {
    background-color: #f1f5f9 !important;
    color: #1e293b !important;
    border-color: #e2e8f0 !important;
}
/* sticky-top 表頭保持同色 */
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) thead.sticky-top th {
    background-color: #f1f5f9 !important;
    color: #1e293b !important;
}
/* Bootstrap table-dark 整體轉換 */
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .table-dark {
    --bs-table-color: #1e293b;
    --bs-table-bg: #f1f5f9;
    --bs-table-border-color: #e2e8f0;
    --bs-table-striped-color: #1e293b;
    --bs-table-striped-bg: #f8fafc;
    --bs-table-active-color: #1e293b;
    --bs-table-active-bg: #e2e8f0;
    --bs-table-hover-color: #1e40af;
    --bs-table-hover-bg: #eff6ff;
}
/* Bootstrap 一般表格 */
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .table {
    --bs-table-color: #1e293b;
    --bs-table-bg: #ffffff;
    --bs-table-border-color: #e2e8f0;
    --bs-table-striped-color: #1e293b;
    --bs-table-striped-bg: #f8fafc;
    --bs-table-hover-color: #1e40af;
    --bs-table-hover-bg: #eff6ff;
    color: #1e293b;
}
/* table-hover 列 hover（!important 蓋掉 Bootstrap --bs-table-hover-color:#fff） */
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .table-hover > tbody > tr:hover > td,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .table-hover > tbody > tr:hover > th {
    color: #1e40af !important;
    background-color: #eff6ff !important;
}
/* table-primary 已選列 */
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) tbody tr.table-primary > td,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) tbody tr.table-primary > th {
    background-color: #dbeafe !important;
    color: #1e40af !important;
    border-color: #e2e8f0 !important;
}
/* table-active 已選列（場次管理等 dbgrid 列選取） */
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .table-active,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .table-active > th,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .table-active > td {
    background-color: #dbeafe !important;
    color: #1e40af !important;
    border-color: #e2e8f0 !important;
}

/* 側邊欄（藍色底色） */
[data-theme="light"] .sidebar-brand,
[data-theme="light"] .sidebar-user {
    background: var(--sidebar-header-bg);
}
[data-theme="light"] .brand-title { color: #ffffff; }
[data-theme="light"] .brand-subtitle { color: #e6f1fb; }
[data-theme="light"] .sidebar-toggle-btn { color: #374151 !important; }
[data-theme="light"] .sidebar-toggle-btn:hover { color: #1e40af !important; }
[data-theme="light"] .sidebar .nav-link:hover { background: var(--navlink-hover-bg); color: #ffffff; }
[data-theme="light"] .sidebar .nav-link.active { background: var(--navlink-active-bg); color: #ffffff; }
[data-theme="light"] .sidebar .nav-link.active .nav-icon { color: #ffffff; }
[data-theme="light"] .nav-sublist { background: rgba(0, 0, 0, 0.08); }
[data-theme="light"] .sidebar { box-shadow: 2px 0 8px rgba(0, 0, 0, 0.12); }

/* 頂部導覽列 */
[data-theme="light"] .top-navbar .breadcrumb-item,
[data-theme="light"] .top-navbar .breadcrumb-item a {
    color: #374151;
}
[data-theme="light"] .top-navbar .breadcrumb-item.active {
    color: #111827;
}
[data-theme="light"] .top-navbar .btn-outline-secondary {
    color: #374151;
    border-color: #d1d5db;
    background-color: #f9fafb;
}
[data-theme="light"] .top-navbar .btn-outline-secondary:hover,
[data-theme="light"] .top-navbar .btn-outline-secondary:focus,
[data-theme="light"] .top-navbar .btn-outline-secondary:active {
    color: #111827;
    border-color: #9ca3af;
    background-color: #f3f4f6;
}
[data-theme="light"] .top-navbar .btn-link {
    color: #374151;
}
[data-theme="light"] .top-navbar .dropdown-menu {
    background: #ffffff;
    border-color: #e5e7eb;
}
[data-theme="light"] .top-navbar .dropdown-item {
    color: #374151;
}
[data-theme="light"] .top-navbar .dropdown-item:hover {
    background-color: #f3f4f6;
}
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .card-header {
    background: #f1f5f9;
    color: #1e293b;
    border-bottom-color: #e2e8f0;
}
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .form-control:focus,
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) textarea:focus {
    color: #1e293b;
    border-color: #3b82f6;
    box-shadow: 0 0 0 0.2rem rgba(59, 130, 246, 0.2);
}
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .form-select:focus {
    color: #1e293b;
    border-color: #3b82f6;
    box-shadow: 0 0 0 0.2rem rgba(59, 130, 246, 0.2);
}
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .form-select {
    --bs-form-select-bg-img: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .form-control::placeholder,
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) textarea::placeholder {
    color: #9ca3af;
}
[data-theme="light"] .page-header h4,
[data-theme="light"] .page-header h5 {
    color: #1e293b;
}
[data-theme="light"] .text-muted {
    color: #6b7280 !important;
}

/* page-body 通用按鈕 */
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .btn-outline-secondary {
    color: #374151;
    border-color: #d1d5db;
    background: #ffffff;
}
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .btn-outline-secondary:hover,
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .btn-outline-secondary:focus,
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .btn-outline-secondary:active {
    color: #1e293b;
    border-color: #9ca3af;
    background: #f3f4f6;
}

/* input-group-text */
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .input-group-text {
    background: #f1f5f9;
    border-color: #e2e8f0;
    color: #64748b;
}

/* Tabulator 表頭與列 */
[data-theme="light"] .check-item-grid-panel .tabulator-header,
[data-theme="light"] .check-item-grid-panel .tabulator-header .tabulator-col {
    background-color: #f1f5f9 !important;
    color: #1e293b !important;
    border-color: #e2e8f0 !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator {
    background: #ffffff !important;
    border-color: #e2e8f0 !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator-tableholder,
[data-theme="light"] .check-item-grid-panel .tabulator-tableholder .tabulator-table {
    background-color: #ffffff !important;
    color: #1e293b !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator-row,
[data-theme="light"] .check-item-grid-panel .tabulator-row.tabulator-row-even {
    background-color: #ffffff !important;
    border-color: #f1f5f9 !important;
    color: #1e293b !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator-row:hover {
    background-color: #eff6ff !important;
    color: #1e40af !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator-row.tabulator-selected,
[data-theme="light"] .check-item-grid-panel .tabulator-row.tabulator-selected:hover {
    background-color: #dbeafe !important;
    color: #1e40af !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator-placeholder-contents,
[data-theme="light"] .check-item-grid-panel .tabulator-placeholder-contents span {
    color: #6b7280 !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator-tableholder::-webkit-scrollbar-track {
    background: #f1f5f9;
}
[data-theme="light"] .check-item-grid-panel .tabulator-tableholder::-webkit-scrollbar-thumb {
    background: #d1d5db;
}

/* Modal */
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .modal-header {
    background: #f1f5f9;
    border-bottom-color: #e2e8f0;
}
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .modal-title {
    color: #1e293b;
}
[data-theme="light"] :where(.page-body, #examServicePlanEditorModal) .modal-header .btn-close {
    filter: none;
}

/* Fieldset legend */
[data-theme="light"] .check-item-form fieldset.check-item-form-group legend {
    color: #1e293b;
}

/* Breadcrumb separator */
[data-theme="light"] .breadcrumb-item + .breadcrumb-item::before {
    color: #9ca3af;
}

/* checkbox-filter-dropdown */
[data-theme="light"] :where(.page-body) .checkbox-filter-dropdown .checkbox-filter-menu .form-check-input {
    background-color: #ffffff;
    border-color: #d1d5db;
}

/* 分頁按鈕（Tabulator Bootstrap 5 pagination） */
[data-theme="light"] .check-item-grid-panel .tabulator-footer,
[data-theme="light"] .check-item-grid-panel .tabulator-paginator {
    background: #ffffff !important;
    border-top-color: #e2e8f0 !important;
    color: #374151 !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator-page,
[data-theme="light"] .check-item-grid-panel .tabulator-page-size {
    color: #374151 !important;
    background-color: #ffffff !important;
    border-color: #d1d5db !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator-page:hover:not([disabled]),
[data-theme="light"] .check-item-grid-panel .tabulator-page-size:hover {
    background-color: #f1f5f9 !important;
    color: #1e293b !important;
    border-color: #9ca3af !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator-page.active {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
    color: #ffffff !important;
}
[data-theme="light"] .check-item-grid-panel .tabulator-page[disabled] {
    color: #d1d5db !important;
    background-color: #f9fafb !important;
}

/* ── 全站 form-label / col-form-label（深色模式寫死 #dbe6f5，淺色必須覆蓋） ── */
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .form-label,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .col-form-label,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) h3,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) h4,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) h5,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) h6 {
    color: #1e293b !important;
}
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .form-control,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) .form-select,
[data-theme="light"] :where(.page-body, .modal-body, .modal-content) textarea {
    color: #1e293b;
    background-color: #ffffff;
    border-color: #d1d5db;
}

/* ── 醫院及比對值管理：面板 header 與年份清單 ── */
[data-theme="light"] .hcv-panel-header {
    background: #f1f5f9 !important;
    color: #1e293b !important;
    border-bottom-color: #e2e8f0 !important;
}
[data-theme="light"] .hcv-year-link {
    color: #374151 !important;
    border-bottom-color: #e2e8f0 !important;
}
[data-theme="light"] .hcv-year-link:hover,
[data-theme="light"] .hcv-year-link:focus {
    background: #eff6ff !important;
    color: #1e40af !important;
}
[data-theme="light"] .hcv-year-list {
    background: #ffffff;
}

/* ── 全站 modal-dialog-scrollable 卷軸修正 ────────────────────────────────
   問題根因：.modal-content 和 .modal-header/body/footer 之間插了 <form>，
   破壞 Bootstrap 的 flex 高度鏈，導致 .modal-body 無限展開不卷動。
   同時對 .modal-content 與其直接子 <form> 都加上 flex column + max-height。 */
.modal-dialog-scrollable .modal-content,
.modal-dialog-scrollable .modal-content > form {
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - var(--bs-modal-margin, 0.5rem) * 2);
    overflow: hidden;
}
.modal-dialog-scrollable .modal-body {
    overflow-y: auto;
    flex: 1 1 auto;
    min-height: 0;
}

/* ── 體檢方案設定編輯 Modal：淺色模式覆蓋 ── */
[data-theme="light"] .exam-plan-category-list .badge {
    background-color: #e2e8f0 !important;
    color: #374151 !important;
}
[data-theme="light"] .exam-plan-category-list .list-group-item {
    background-color: #ffffff;
    color: #1e293b;
    border-color: #e2e8f0;
}
[data-theme="light"] .exam-plan-category-list .list-group-item:hover,
[data-theme="light"] .exam-plan-category-list .list-group-item:focus {
    background-color: #eff6ff;
    color: #1e40af;
}
[data-theme="light"] .exam-plan-category-list .list-group-item.active {
    background-color: #dbeafe;
    border-color: #bfdbfe;
    color: #1e40af;
}
[data-theme="light"] .exam-plan-option-groups-table thead th,
[data-theme="light"] .exam-plan-items-table thead th {
    background-color: #f1f5f9 !important;
    color: #1e293b !important;
}
[data-theme="light"] .exam-plan-items-table tbody tr.table-active > td {
    background-color: #dbeafe !important;
    color: #1e40af !important;
}
[data-theme="light"] .exam-plan-items-toolbar .text-muted {
    color: #6b7280 !important;
}
[data-theme="light"] .exam-plan-option-groups-table {
    --bs-table-bg: #ffffff;
    --bs-table-color: #1e293b;
    --bs-table-border-color: #e2e8f0;
}
[data-theme="light"] .exam-plan-items-table {
    --bs-table-bg: #ffffff;
    --bs-table-color: #1e293b;
    --bs-table-border-color: #e2e8f0;
}
[data-theme="light"] .exam-plan-option-groups-table tbody td,
[data-theme="light"] .exam-plan-items-table tbody td {
    color: #1e293b;
    border-color: #e2e8f0;
}
[data-theme="light"] .exam-plan-items-sort-row,
[data-theme="light"] .exam-plan-items-toolbar {
    background: #f8fafc;
    border-color: #e2e8f0 !important;
}
[data-theme="light"] .exam-plan-package-summary {
    background: #f8fafc;
    border-color: #e2e8f0 !important;
}
[data-theme="light"] .exam-plan-category-nav-header {
    background: #f8fafc;
    border-color: #e2e8f0 !important;
}
