/* ─── Variables ─────────────────────────────────────────────────────────────── */
:root {
    --sidebar-width: 240px;
    --sidebar-collapsed-width: 60px;
    --sidebar-bg: #0f172a;
    --sidebar-border: #233450;
    --sidebar-text: #d4deea;
    --sidebar-text-active: #f3f7ff;
    --sidebar-hover-bg: #1f3150;
    --sidebar-active-bg: #2563eb;
    --topbar-height: 56px;
    --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;
    --transition: 0.2s ease;
}

/* ─── 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: #334155;
}

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

/* ─── Sidebar ─────────────────────────────────────────────────────────────────── */
.sidebar {
    width: var(--sidebar-width);
    min-width: var(--sidebar-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);
}

.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: 20px;
    line-height: 1.1;
    color: #f1f5f9;
    transition: opacity var(--transition);
}

.brand-subtitle {
    margin-top: 2px;
    font-size: 14px;
    color: #94a3b8;
    line-height: 1.2;
    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: 13px; 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: 9px 14px;
    color: var(--sidebar-text);
    text-decoration: none;
    font-size: 13.5px;
    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: 18px; text-align: center; flex-shrink: 0; font-size: 14px; }
.nav-label { transition: opacity var(--transition); }
.sidebar.collapsed .nav-label { opacity: 0; width: 0; overflow: hidden; }
.nav-arrow { font-size: 11px; margin-left: auto; transition: transform 0.2s; }
.nav-link[aria-expanded="true"] .nav-arrow { transform: rotate(180deg); }

.nav-sublist .nav-link { padding-left: 42px; font-size: 13px; }
.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 ───────────────────────────────────────────────────── */
.page-body h1,
.page-body h2,
.page-body h3,
.page-body h4,
.page-body h5,
.page-body h6,
.page-body .form-label,
.page-body .col-form-label,
.page-body .text-body {
    color: #dbe6f5;
}

.page-body .text-muted {
    color: #b7c8de !important;
}

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

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

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

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

.page-body .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);
}

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

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

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

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

.page-body .form-control:focus,
.page-body .form-select:focus,
.page-body 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);
}

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

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

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

.page-body .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) ─────────────────────────────── */
.page-body .modal-content {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    color: var(--panel-text);
}
.page-body .modal-header {
    background: #162235;
    border-bottom-color: var(--panel-border);
}
.page-body .modal-title { color: #f3f7ff; }
.page-body .modal-header .btn-close { filter: invert(1) grayscale(100%) brightness(200%); }
.page-body .modal-body { background: var(--panel-bg-soft); }
.page-body .modal-footer {
    background: var(--panel-bg);
    border-top-color: var(--panel-border);
}
.page-body .form-check-label { color: var(--panel-text); }
.page-body .modal-body .border { border-color: var(--panel-border) !important; }
.page-body .modal-body .border { background: var(--panel-input-bg); }

/* ─── 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-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: 64px;
    height: 64px;
    margin-bottom: 14px;
    filter: drop-shadow(0 0 12px rgba(37,99,235,0.5));
}
.login-title { font-size: 20px; font-weight: 700; color: #f3f7ff; margin: 0; }
.login-subtitle { font-size: 13px; color: #7a9ab8; margin-top: 4px; }

/* 表單標籤 */
.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; }

/* 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 menus list (from GroupMenus/Index.cshtml) ─────────────────────────── */
#groupMenusApp .list-group-item {
    background: var(--panel-bg-soft);
    color: var(--panel-text);
    border-color: var(--panel-border);
}
#groupMenusApp .list-group-item:hover {
    background: #263a53;
    color: #ffffff;
}
#groupMenusApp .list-group-item.active {
    background: var(--sidebar-active-bg);
    border-color: var(--sidebar-active-bg);
    color: #ffffff;
}

/* ─── 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);
}

/* ─── 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%;
    }
}
