/* ======================================================================
   APP_VSG_webapp - Global CSS  |  Design system "Thiết kế Mobile app"
   - Token design + biến --app-* dùng trong CSS isolation.
   - Lớp override .mud-* toàn cục giữ TỐI THIỂU (theme-first — xem DESIGN.md §3).
   - Hex màu chỉ được phép ở đây và Layout/AppTheme.cs.
   ====================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@300;400;500;600;700;800&display=swap');

/* ──────────────────────────────────────────────────────────────────────
   DESIGN TOKENS — nguồn gốc: design system "Thiết kế Mobile app".
   Thang màu navy doanh nghiệp #0A4174, nền slate, chữ Be Vietnam Pro.
   Các biến `--app-*` bên dưới ánh xạ sang token này nên mọi *.razor.css
   hiện có không phải đổi tên biến — chỉ đổi giá trị (restyle thuần).
   ────────────────────────────────────────────────────────────────────── */
:root {
    /* Primitive — thang xanh navy (7 anchor brand, nội suy 50→900) */
    --blue-50:  #EAF3F8;
    --blue-100: #BDD8E9;
    --blue-200: #9DC8E1;
    --blue-300: #7BBDE8;
    --blue-400: #6EA2B3;
    --blue-500: #4E8EA2;
    --blue-600: #49769F;
    --blue-700: #0A4174;
    --blue-800: #062E54;
    --blue-900: #001D39;

    /* Primitive — neutral slate */
    --slate-0:   #FFFFFF;
    --slate-25:  #FAFBFC;
    --slate-50:  #F4F6F8;
    --slate-100: #ECEFF3;
    --slate-200: #DEE3EA;
    --slate-300: #C4CBD6;
    --slate-400: #98A2B3;
    --slate-500: #6B7280;
    --slate-600: #4B5563;
    --slate-700: #344054;
    --slate-800: #1F2937;
    --slate-900: #0F172A;

    /* Semantic — thương hiệu */
    --brand:         var(--blue-700);
    --brand-hover:   var(--blue-800);
    --brand-pressed: var(--blue-900);
    --brand-soft:    var(--blue-50);
    --brand-accent:  var(--blue-500);
    --brand-on:      #FFFFFF;

    /* Semantic — bề mặt */
    --bg-app:     var(--slate-50);
    --bg-surface: var(--slate-0);
    --bg-sunken:  var(--slate-100);

    /* Semantic — chữ */
    --fg-1: var(--slate-900);
    --fg-2: var(--slate-700);
    --fg-3: var(--slate-500);
    --fg-4: var(--slate-400);

    /* Semantic — viền */
    --border-1:      var(--slate-200);
    --border-2:      var(--slate-300);
    --border-strong: var(--slate-400);

    /* Semantic — trạng thái */
    --success-500: #16A34A;
    --warning-500: #F59E0B;
    --error-500:   #EF4444;
    --info-500:    #0EA5E9;

    /* Type — Be Vietnam Pro */
    --font-sans: "Be Vietnam Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

    /* Alias: nhiều file lỡ dùng spelling Anh "--mud-palette-background-grey",
       nhưng MudBlazor 9.x CHỈ sinh "--mud-palette-background-gray" (Mỹ) → biến
       không resolve, nền rơi về transparent. Định nghĩa alias 1 chỗ để mọi file
       dùng "-grey" render đúng nền xám (thay vì mất nền). */
    --mud-palette-background-grey: var(--mud-palette-background-gray);

    --fs-display: 32px;
    --fs-h1:      26px;
    --fs-h2:      22px;
    --fs-h3:      18px;
    --fs-body:    15px;
    --fs-body-sm: 14px;
    --fs-caption: 12px;
    --fs-tiny:    11px;

    /* Spacing — 4 / 8 / 12 / 16 / 24 (+ mở rộng) */
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 24px;
    --space-6: 32px;
    --space-7: 48px;
    --space-8: 64px;

    /* Bo góc */
    --radius-xs:     4px;
    --radius-sm:     8px;
    --radius-input:  12px;
    --radius-button: 12px;
    --radius-card:   16px;
    --radius-pill:   999px;

    /* Đổ bóng — nhẹ, flat modern */
    --shadow-xs:   0 1px 2px rgba(15, 23, 42, 0.04);
    --shadow-sm:   0 1px 2px rgba(15, 23, 42, 0.06), 0 1px 3px rgba(15, 23, 42, 0.04);
    --shadow-card: 0 2px 6px rgba(15, 23, 42, 0.05), 0 1px 2px rgba(15, 23, 42, 0.04);
    --shadow-pop:  0 8px 24px rgba(15, 23, 42, 0.10), 0 2px 6px rgba(15, 23, 42, 0.04);

    /* Chuyển động */
    --ease-out:    cubic-bezier(.16, 1, .3, 1);
    --ease-in-out: cubic-bezier(.4, 0, .2, 1);
    --dur-fast: 120ms;
    --dur-base: 200ms;
    --dur-slow: 320ms;

    /* ──────────────────────────────────────────────────────────────────
       Tokens app-level (khớp AppTheme.Default) — ánh xạ sang design token
       ở trên. Giữ nguyên TÊN biến để *.razor.css hiện có không vỡ.
       ────────────────────────────────────────────────────────────────── */
    --app-bg: var(--bg-app);
    --app-surface: var(--bg-surface);
    --app-primary: var(--brand);
    --app-primary-lighten: var(--brand-soft);
    --app-secondary: var(--brand-accent);

    --app-text-primary: var(--fg-1);
    --app-text-secondary: var(--fg-3);

    --app-divider: var(--border-1);
    --app-divider-strong: var(--border-2);

    /* Status colors (đồng bộ với AppTheme.Default) */
    --app-success: var(--success-500);
    --app-error: var(--error-500);
    --app-warning: var(--warning-500);
    --app-info: var(--info-500);

    /* Info banner — nền nhạt + text đậm + viền soft. Khớp design source
       LoginScreen/ForgotPasswordScreen.jsx (var --status-info-bg + --info-600). */
    --app-info-bg:     rgba(2, 132, 199, 0.08);   /* sky-600 8% — soft, không chói */
    --app-info-fg:     #075985;                    /* sky-800 — text đậm dễ đọc */
    --app-info-border: rgba(2, 132, 199, 0.18);

    /* Success banner — đồng bộ pattern soft */
    --app-success-bg:  rgba(34, 197, 94, 0.10);
    --app-success-fg:  #15803D;

    /* Step indicator (Soft UI) */
    --app-step-idle-bg: var(--slate-100);
    --app-step-idle-text: var(--fg-4);
    --app-step-idle-border: var(--border-1);

    /* Avatar people pair — warm (requester) vs cool (assignee). Dùng cho ticket
       detail panel + bất kỳ chỗ nào cần phân biệt người gửi/người xử lý. */
    --app-avatar-warm-from: #F4A584;
    --app-avatar-warm-to:   #E0795C;
    --app-avatar-cool-from: #4A7FB8;
    --app-avatar-cool-to:   var(--brand);   /* navy primary */

    /* SLA chip palette — design v2 dùng coral/orange (không amber) cho warn vì
       màu cảnh báo SLA trong context ticket nghiêng về hot/urgent tone. */
    --app-sla-warn-text:   #C2410C;          /* orange-800 — đậm dễ đọc */
    --app-sla-warn-bg:     rgba(251, 146, 60, 0.16);  /* orange-400 16% */
    --app-sla-warn-border: rgba(251, 146, 60, 0.40);
    --app-sla-err-text:    #B91C1C;          /* red-700 */
    --app-sla-err-bg:      rgba(239, 68, 68, 0.14);
    --app-sla-err-border:  rgba(239, 68, 68, 0.38);
    --app-sla-ok-text:     #15803D;          /* green-700 */
    --app-sla-ok-bg:       rgba(22, 163, 74, 0.12);
    --app-sla-ok-border:   rgba(22, 163, 74, 0.32);

    /* Shadow */
    --app-shadow-soft: 0 18px 45px rgba(15, 23, 42, 0.08);
    --app-shadow-card: var(--shadow-card);
    /* Card auth (login/forgot) — khớp shadow trong LoginScreen.jsx của design source */
    --app-shadow-card-strong: 0 12px 32px -8px rgba(10, 65, 116, 0.20), 0 4px 12px -4px rgba(10, 65, 116, 0.08);
    --app-shadow-logo: 0 4px 12px -4px rgba(10, 65, 116, 0.15);
    --app-shadow-btn-primary: 0 4px 16px rgba(10, 65, 116, 0.28);
    --app-shadow-btn-primary-hover: 0 6px 20px rgba(10, 65, 116, 0.38);
    --app-shadow-step-active: 0 2px 8px rgba(10, 65, 116, 0.35);
    --app-shadow-appbar: 0 1px 8px rgba(15, 23, 42, 0.06);
    --app-shadow-drawer: 2px 0 16px rgba(15, 23, 42, 0.06);
    --app-shadow-overlay-card: 0 8px 32px rgba(15, 23, 42, 0.10);

    /* Vòng focus cho input/control (theo design system) */
    --app-focus-ring: 0 0 0 3px rgba(10, 65, 116, 0.12);

    /* Gradient header card auth — khớp design source (nhẹ, neutral, không brand-soft) */
    --app-auth-header-gradient: linear-gradient(180deg, #F4F8FB 0%, var(--bg-surface) 100%);
    /* Nền trang auth — radial ellipse phía trên, đúng design source */
    --app-auth-bg-gradient: radial-gradient(ellipse at top, #EAF3F8 0%, var(--bg-app) 60%);
}

/* Reset + base */
html,
body {
    min-height: 100%;
    margin: 0;
    background: var(--app-bg);
    font-family: var(--font-sans);
    color: var(--app-text-primary);
}

body {
    overflow-x: hidden;
}

/* ======================================================================
   LỚP THEME TOÀN CỤC — tinh chỉnh component MudBlazor cho khớp design
   system mà MudTheme (Layout/AppTheme.cs) không biểu đạt được.
   GIỮ TỐI THIỂU: màu / chữ / bo góc / đổ bóng đã nằm trong AppTheme.cs;
   khối này chỉ cho phần MudTheme không vươn tới. Mọi giá trị lấy từ
   biến --app-* định nghĩa ở :root — không hardcode hex.
   ====================================================================== */

/* Nút primary (filled) — thêm shadow navy mềm theo design system.
   Selector 2-class để thắng .mud-elevation-* mặc định của MudBlazor
   (app.css nạp TRƯỚC MudBlazor.min.css nên cần specificity cao hơn). */
.mud-button-root.mud-button-filled-primary {
    box-shadow: var(--app-shadow-btn-primary);
}
.mud-button-root.mud-button-filled-primary:hover {
    box-shadow: var(--app-shadow-btn-primary-hover);
}
.mud-button-root.mud-button-filled-primary:active {
    box-shadow: var(--app-shadow-btn-primary);
}

/* ======================================================================
   MudSwitch — pill style toàn cục khớp design system "Thiết kế Mobile app".
   MudBlazor default đã pill-ish nhưng track opacity nhẹ, on-state không đủ
   đậm. Override mỏng để track full opacity + thumb trắng có shadow, on-state
   tô brand navy đậm khớp design v2 (vd "Nhật ký hệ thống" toggle ở Ticket).
   ====================================================================== */

/* Track — bo pill 999px, full opacity, slate khi off. */
.mud-switch .mud-switch-track {
    border-radius: 999px !important;
    opacity: 1 !important;
    background-color: var(--slate-300) !important;
    transition: background-color 180ms var(--ease-out);
}

/* On state cho mọi màu — đè màu theo color variant. Primary = brand navy. */
.mud-switch.mud-switch-color-primary .mud-switch-base.mud-checked ~ .mud-switch-track,
.mud-switch.mud-switch-color-primary .mud-switch-base.mud-checked + .mud-switch-track {
    background-color: var(--mud-palette-primary) !important;
}
.mud-switch.mud-switch-color-success .mud-switch-base.mud-checked ~ .mud-switch-track,
.mud-switch.mud-switch-color-success .mud-switch-base.mud-checked + .mud-switch-track {
    background-color: var(--mud-palette-success) !important;
}
.mud-switch.mud-switch-color-error .mud-switch-base.mud-checked ~ .mud-switch-track,
.mud-switch.mud-switch-color-error .mud-switch-base.mud-checked + .mud-switch-track {
    background-color: var(--mud-palette-error) !important;
}

/* Thumb — tròn trắng nhỏ có shadow để nổi trên track. */
.mud-switch .mud-switch-thumb {
    background-color: #fff !important;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.20),
                0 1px 1px rgba(15, 23, 42, 0.08) !important;
}

/* Disabled state — track xám nhạt + thumb hơi mờ. */
.mud-switch.mud-disabled .mud-switch-track {
    background-color: var(--slate-200) !important;
}
.mud-switch.mud-disabled .mud-switch-thumb {
    background-color: var(--slate-100) !important;
}

/* Label bên cạnh switch — font weight tự nhiên, khoảng cách 8px. */
.mud-switch .mud-switch-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--mud-palette-text-primary);
    margin-left: 4px;
}

/* Helper utility classes (chỉ dùng khi MudBlazor không cung cấp tương đương) */
.app-soft-card {
    border-radius: 20px;
    background: var(--app-surface);
    box-shadow: var(--app-shadow-card);
}

.app-page-title {
    font-weight: 700;
    letter-spacing: -0.02em;
}

.app-muted-text {
    color: var(--app-text-secondary);
}

/* Validation message (Blazor mặc định bôi đỏ rất chói — tinh chỉnh nhẹ) */
.validation-message {
    color: var(--mud-palette-error, #ef4444);
    font-size: 12px;
    margin-top: 4px;
}

/* ======================================================================
   RESPONSIVE GRID — utility class lấy nguyên từ design source
   (`ui_kits/web/web.css`). Dùng thay vì raw `grid-template-columns: 1fr 1fr`
   để mọi page tự stack ở mobile/tablet theo breakpoint chuẩn. Xem DESIGN.md §20.

   Breakpoints chuẩn: 1280 / 1024 / 720 / 520.
   ====================================================================== */

.r-grid       { display: grid; }
.r-grid-2     { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.r-grid-3     { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.r-grid-4     { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); }
.r-grid-5     { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); }
.r-grid-6     { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); }

/* Lưới chuyên biệt — main + sidebar 360px */
.r-grid-main-side  { display: grid; grid-template-columns: minmax(0, 1fr) 360px; }
/* List + detail (chat / ticket) */
.r-grid-tickets    { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr); }
/* Org structure — cây 1.6fr + chi tiết 1fr */
.r-grid-org        { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr); }
/* Attendance chart — 2fr + 1fr */
.r-grid-att-chart  { display: grid; grid-template-columns: minmax(0, 2fr) minmax(0, 1fr); }
/* Asset edit — nav 200px + form */
.r-grid-asset-edit { display: grid; grid-template-columns: 200px minmax(0, 1fr); }
/* Dashboard 3 widget */
.r-grid-dash-3     { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); }
/* Account info — sidebar 320px + form */
.r-grid-account    { display: grid; grid-template-columns: 320px minmax(0, 1fr); }

@media (max-width: 1280px) {
    .r-grid-6 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .r-grid-5 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 1100px) {
    .r-grid-account { grid-template-columns: minmax(0, 1fr); }
}

@media (max-width: 1024px) {
    .r-grid-main-side,
    .r-grid-tickets,
    .r-grid-org,
    .r-grid-att-chart  { grid-template-columns: minmax(0, 1fr); }
    .r-grid-6          { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .r-grid-5          { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .r-grid-4          { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .r-grid-dash-3     { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 720px) {
    .r-grid-6,
    .r-grid-5,
    .r-grid-4,
    .r-grid-3,
    .r-grid-dash-3     { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .r-grid-asset-edit { grid-template-columns: 1fr; }
}

@media (max-width: 520px) {
    .r-grid-6,
    .r-grid-5,
    .r-grid-4,
    .r-grid-3,
    .r-grid-2,
    .r-grid-dash-3     { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────────────────────────────────
   Dialog + Tabs utility classes
   Áp ở global scope (không scoped) → dùng được trên `<MudDialog>`,
   `<MudTabs>` và component MudBlazor khác mà không cần wrapper div
   (tránh hạn chế CSS isolation với component invocation).
   ───────────────────────────────────────────────────────────────────── */

/* Header section có viền dưới — dùng trong <TitleContent> của MudDialog
   để tách rõ tiêu đề dialog với nội dung phía dưới. */
.app-dialog-section-divider {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--app-divider);
}

/* Dialog có chiều cao cố định vừa màn hình — dùng cho dialog có form dài
   (vd Edit nhân viên 7 tab). Kết quả:
     - Dialog wrapper height fixed = 90vh (dưới breakpoint mobile dùng full).
     - Title (TitleContent) + Actions (DialogActions) sticky top/bottom.
     - DialogContent FLEX 1 + scroll Y riêng → user scroll content,
       không phải scroll cả dialog (footer luôn nhìn thấy).
   Áp dụng: DialogOptions { Class = "app-dialog-fixed-height" }. */
.app-dialog-fixed-height {
    height: 90vh;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
}

.app-dialog-fixed-height .mud-dialog-content {
    flex: 1 1 auto;
    overflow-y: auto;
    /* min-height:0 BẮT BUỘC cho flex child có overflow — không có thì content
       không shrink được và overflow tràn ngoài dialog. */
    min-height: 0;
}

.app-dialog-fixed-height .mud-dialog-actions {
    flex: 0 0 auto;
    border-top: 1px solid var(--app-divider);
    background: var(--mud-palette-surface);
}

/* Mobile (<= 600px) — dialog full-screen để tận dụng không gian. */
@media (max-width: 600px) {
    .app-dialog-fixed-height {
        height: 100vh;
        max-height: 100vh;
        max-width: 100vw;
        margin: 0;
        border-radius: 0;
    }
}

/* Tab strip có nét đứt phía dưới + spacing tách header và content.
   Áp Class="app-tabs-dashed" trực tiếp lên `<MudTabs>` — MudTabs render
   div root có class này → descendant selector match được mud-tabs-tabbar. */
.app-tabs-dashed .mud-tabs-tabbar {
    border-bottom: 1px dashed var(--app-divider);
    margin-top: 5px;
}

/* Khoảng cách giữa nét đứt và nội dung tab.
   Đặt margin-top trên panels (sibling của tabbar) — margin-bottom của tabbar
   bị collapse trong flex column container của MudTabs. */
.app-tabs-dashed .mud-tabs-panels {
    margin-top: 8px;
}

/* ======================================================================
   Chat NMM dialog — wrapper bỏ padding/title MudDialog mặc định để render
   layout custom (header/quick/fields/search/list/foot) theo Claude design.
   Áp DialogOptions { Class = "chat-nmm-dialog" } cho ChatGroupCreateDialog
   và ChatDirectStartDialog. Style chi tiết section nằm trong từng .razor.css.
   Global ở đây CHỈ override MudDialog skeleton (padding=0, max-width=560,
   height auto, content scroll). DESIGN.md §5.1: rule fix CSS không apply
   trên Mud component root → phải global. */
.chat-nmm-dialog {
    width: 100%;
    max-width: 560px;
    max-height: min(92vh, 760px);
}
.chat-nmm-dialog .mud-dialog-title {
    display: none;
}
.chat-nmm-dialog .mud-dialog-content {
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    max-height: min(92vh, 760px);
}
.chat-nmm-dialog .mud-dialog-actions {
    display: none;
}
@media (max-width: 600px) {
    .chat-nmm-dialog {
        max-width: calc(100vw - 24px);
        max-height: 92vh;
    }
}

/* ======================================================================
   Notification popover — phải đặt ở GLOBAL (không trong .razor.css) vì
   MudPopover render qua portal ra ngoài DOM tree component → CSS isolation
   không reach được. Class .notification-popover được apply qua
   <MudMenu PopoverClass="notification-popover">.

   Layout: header + scroll list + footer trong .notification-popover-content
   (1 scroll container DUY NHẤT là .notification-scroll giữa).

   KHÔNG dùng .notification-popover (outer) để control height — MudBlazor v9
   wrap thêm layer nội bộ làm cascading flex/overflow phức tạp. Thay vào đó
   set height + overflow trực tiếp trên div .notification-popover-content
   (do component tự render — đảm bảo control 100%).
   ====================================================================== */

.notification-popover-content {
    width: 408px;                      /* đủ rộng cho cụm action header + tab không chật */
    height: 520px;                     /* fixed height — không phụ thuộc parent */
    display: flex;
    flex-direction: column;
    overflow: hidden;                  /* chặn scroll cấp này — cho .notification-scroll lo */
}

.notification-popover-content .notification-scroll {
    flex: 1 1 auto;
    min-height: 0;                     /* cho phép flex child overflow */
    overflow-y: auto;                  /* SCROLL DUY NHẤT */
    overscroll-behavior: contain;
}

.notification-popover-content .notification-scroll::-webkit-scrollbar {
    width: 6px;
}
.notification-popover-content .notification-scroll::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 3px;
}
.notification-popover-content .notification-scroll::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.35);
}

/* Empty state — full (popover rỗng) + mini (tab lọc rỗng). Bám NotifMenu.notif-empty. */
.notification-empty {
    flex: 1 1 auto;                    /* canh giữa khoảng trống giữa header và footer */
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 40px 16px;
    text-align: center;
}
.notification-empty .notif-empty-circle {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-pill);
    background: var(--slate-100);
    color: var(--fg-3);
    display: flex;
    align-items: center;
    justify-content: center;
}
.notification-empty .notif-empty-title { font-weight: 600; color: var(--fg-1); }
.notification-empty .notif-empty-sub   { font-size: var(--fs-caption); color: var(--fg-3); }
.notification-empty.notif-empty--mini  { padding: 28px 16px; }

/* ── Header: tiêu đề + pill "N mới" + cụm action (đánh dấu đã đọc / cài đặt / đóng) ── */
.notification-popover-content .notif-head {
    padding: 12px 12px 0 12px;
    border-bottom: 1px solid var(--app-divider);
    flex: 0 0 auto;
}
.notification-popover-content .notif-head-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
.notification-popover-content .notif-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--fs-h3);
    font-weight: 700;
    color: var(--fg-1);
}
.notification-popover-content .notif-count {
    font-size: var(--fs-caption);
    font-weight: 600;
    color: var(--brand);
    background: var(--brand-soft);
    padding: 2px 8px;
    border-radius: var(--radius-pill);
    line-height: 1.6;
}
.notification-popover-content .notif-head-actions {
    display: flex;
    align-items: center;
    gap: 2px;
}
/* nút "Đánh dấu đã đọc" — kiểu link gọn, không in hoa */
.notification-popover-content .notif-link.mud-button-root {
    text-transform: none;
    font-size: var(--fs-caption);
    font-weight: 600;
    min-width: 0;
    padding: 2px 8px;
}

/* ── Tab lọc: Tất cả / Chưa đọc / Nhắc đến ── */
.notification-popover-content .notif-tabs {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 8px;
}
.notification-popover-content .notif-tab {
    appearance: none;
    background: none;
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 10px;
    font-family: var(--font-sans);
    font-size: var(--fs-body-sm);
    font-weight: 500;
    color: var(--fg-3);
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
}
.notification-popover-content .notif-tab:hover:not(:disabled) { color: var(--fg-1); }
.notification-popover-content .notif-tab.active {
    color: var(--brand);
    font-weight: 600;
    border-bottom-color: var(--brand);
}
.notification-popover-content .notif-tab:disabled { opacity: .45; cursor: default; }
.notification-popover-content .notif-tab .t-count {
    font-size: var(--fs-tiny);
    font-weight: 600;
    background: var(--slate-100);
    color: var(--fg-3);
    padding: 1px 6px;
    border-radius: var(--radius-pill);
    line-height: 1.5;
}
.notification-popover-content .notif-tab.active .t-count {
    background: var(--brand-soft);
    color: var(--brand);
}

/* ── Dòng noti: icon-tone trái | meta | chấm chưa đọc phải ── */
.notification-popover-content .notif-row {
    cursor: pointer;
    border-bottom: 1px solid var(--app-divider);
    outline: none;
}
.notification-popover-content .notif-row:last-child { border-bottom: none; }
.notification-popover-content .notif-row:hover { background: var(--slate-50); }
.notification-popover-content .notif-row.unread { background: var(--brand-soft); }
.notification-popover-content .notif-row.unread:hover { background: var(--blue-100); }
.notification-popover-content .notif-row:focus-visible { box-shadow: inset 0 0 0 2px var(--brand-accent); }
.notification-popover-content .notif-row-inner {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px;
    width: 100%;
}
.notification-popover-content .notif-row-icon {
    flex: 0 0 auto;
    width: 32px;
    height: 32px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
}
.notification-popover-content .notif-row-icon .mud-icon-root {
    font-size: 18px;
    width: 18px;
    height: 18px;
}
/* Tone — nền tint + màu icon. Khớp NotifRow.toneMap. (hex chỉ được phép trong app.css) */
.notification-popover-content .notif-row-icon.tone-brand   { background: var(--brand-soft);     color: var(--brand); }
.notification-popover-content .notif-row-icon.tone-success { background: rgba(22, 163, 74, .12); color: #15803D; }
.notification-popover-content .notif-row-icon.tone-warning { background: rgba(245, 158, 11, .16);color: #B45309; }
.notification-popover-content .notif-row-icon.tone-error   { background: rgba(239, 68, 68, .12); color: #B91C1C; }
.notification-popover-content .notif-row-icon.tone-info    { background: rgba(14, 165, 233, .12);color: #075985; }
.notification-popover-content .notif-row-icon.tone-neutral { background: var(--slate-100);       color: var(--fg-2); }

.notification-popover-content .notif-row-meta {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.notification-popover-content .notif-row-title {
    font-size: var(--fs-body-sm);
    font-weight: 500;
    color: var(--fg-1);
    line-height: 1.35;
}
.notification-popover-content .notif-row-title .notif-code {
    font-family: var(--font-mono);
    font-weight: 600;
    font-size: 0.92em;
}
.notification-popover-content .notif-row-body {
    font-size: var(--fs-caption);
    color: var(--fg-3);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.notification-popover-content .notif-row-time {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: var(--fs-tiny);
    color: var(--fg-4);
    margin-top: 2px;
}
.notification-popover-content .notif-mention-tag {
    font-size: var(--fs-tiny);
    font-weight: 600;
    color: var(--info-500);
    background: rgba(14, 165, 233, .12);
    padding: 1px 6px;
    border-radius: var(--radius-pill);
}
.notification-popover-content .notif-row-dot {
    flex: 0 0 auto;
    width: 8px;
    height: 8px;
    margin-top: 6px;
    border-radius: var(--radius-pill);
    background: var(--brand-accent);
}

/* ── Footer ── */
.notification-popover-content .notif-foot {
    flex: 0 0 auto;
    border-top: 1px solid var(--app-divider);
    padding: 4px;
}
.notification-popover-content .notif-foot .mud-button-root {
    text-transform: none;
    font-weight: 600;
}

.notification-loading-row,
.notification-end-row,
.notification-loadmore-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
}
.notification-end-row {
    border-top: 1px solid var(--app-divider);
}
.notification-loading-row {
    background: var(--app-primary-lighten);
    border-top: 1px solid var(--app-divider);
}
.notification-loadmore-row {
    border-top: 1px dashed var(--app-divider);
}

/* Sentinel — invisible spacer ở cuối list cho IntersectionObserver detect.
   Cần height > 0 để IO observe được; rootMargin 100px (set ở JS) làm fire sớm. */
.notification-popover-content .notification-sentinel {
    height: 1px;
    width: 100%;
    margin: 0;
    padding: 0;
}

/* ======================================================================
   Tem QR tài sản — TaiSanLabelDialog (modal trong trang /tai-san).
   Card tem + quy tắc in. Đặt global vì @media print phải ẩn shell ngoài
   phạm vi CSS isolation của component.
   ====================================================================== */
.ts-label-sheet {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.ts-asset-label {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 240px;
    padding: 8px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 4px;
    box-sizing: border-box;
}

.ts-asset-label-qr {
    width: 72px;
    height: 72px;
    flex: 0 0 72px;
}

.ts-asset-label-text {
    min-width: 0;
}

.ts-asset-label-ma {
    font-weight: 700;
    font-size: 13px;
    word-break: break-all;
}

.ts-asset-label-ten {
    font-size: 11px;
    color: var(--mud-palette-text-secondary);
}

/* Khi dialog in tem mở (.ts-label-sheet có trong DOM): chỉ in vùng tem.
   Ẩn shell chính (.mud-layout) + scrim (.mud-overlay); cho dialog chảy
   theo flow tĩnh để in được nhiều trang. */
@media print {
    body:has(.ts-label-sheet) .mud-layout,
    body:has(.ts-label-sheet) .mud-overlay {
        display: none !important;
    }

    body:has(.ts-label-sheet) .mud-dialog-container,
    body:has(.ts-label-sheet) .mud-dialog {
        position: static !important;
        max-width: none !important;
        max-height: none !important;
        height: auto !important;
        overflow: visible !important;
        box-shadow: none !important;
        margin: 0 !important;
    }

    .ts-no-print {
        display: none !important;
    }
}

/* ─── Gallery ảnh tài sản (AssetImageGallery) ─── */
.ts-img-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: flex-start;
}

.ts-img-tile {
    position: relative;
    width: 110px;
    height: 110px;
    flex: 0 0 auto;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--mud-palette-lines-default);
    background: var(--mud-palette-background-grey);
}

    .ts-img-tile .ts-img-clickable {
        display: block;
        width: 100%;
        height: 100%;
        cursor: pointer;
    }

    .ts-img-tile img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

.ts-img-remove {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    padding: 4px;
    background: rgba(0, 0, 0, 0.32);
    opacity: 0;
    transition: opacity .15s ease;
    pointer-events: none;
}

.ts-img-tile:hover .ts-img-remove,
.ts-img-remove--show {
    opacity: 1;
}

    .ts-img-remove .mud-button-root {
        pointer-events: auto;
    }

.ts-img-avatar-badge {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    text-align: center;
    font-size: 10px;
    line-height: 1.7;
    background: rgba(0, 0, 0, 0.6);
    color: #fff;
    pointer-events: none;
}

.ts-img-add-upload {
    width: 110px;
    height: 110px;
    flex: 0 0 auto;
    position: relative;
}

.ts-img-add {
    width: 110px;
    height: 110px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    border: 1.5px dashed var(--mud-palette-primary);
    border-radius: 10px;
    color: var(--mud-palette-primary);
    cursor: pointer;
    transition: background .15s ease, border-color .15s ease;
}

    .ts-img-add:hover,
    .ts-img-add--drag {
        background: var(--mud-palette-primary-hover);
        border-style: solid;
    }

/* Hàng select + nút "+ Tạo" trong form tài sản */
.ts-field-with-add {
    display: flex;
    gap: 6px;
    align-items: flex-start;
}

/* Modal xem ảnh tài sản (AssetImageViewerDialog) */
.ts-img-viewer-stage {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--mud-palette-dark);
    border-radius: 10px;
    min-height: 320px;
    max-height: 70vh;
    overflow: hidden;
}

.ts-img-viewer-img {
    max-width: 100%;
    max-height: 70vh;
    object-fit: contain;
    display: block;
}

.ts-img-viewer-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0.85;
}

    .ts-img-viewer-nav:first-of-type { left: 12px; }
    .ts-img-viewer-nav:last-of-type  { right: 12px; }

.ts-img-viewer-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 8px;
    gap: 12px;
}

/* Avatar tài sản ở header dialog chi tiết */
.ts-asset-avatar {
    width: 104px;
    height: 104px;
    object-fit: cover;
    border-radius: 14px;
    border: 1px solid var(--mud-palette-lines-default);
}

/* Ảnh đại diện trong từng dòng danh sách tài sản */
.ts-list-avatar {
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
    object-fit: cover;
    border-radius: 8px;
    border: 1px solid var(--mud-palette-lines-default);
}

.ts-list-avatar--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--mud-palette-background-grey);
    color: var(--mud-palette-text-disabled);
}

/* Thẻ thống kê click được — trang danh sách tài sản */
.ts-stat-card {
    transition: border-color .15s, box-shadow .15s, background .15s;
}

    .ts-stat-card:hover {
        border-color: var(--mud-palette-primary) !important;
    }

    .ts-stat-card--active {
        border-color: var(--mud-palette-primary) !important;
        background: var(--mud-palette-primary-hover);
        box-shadow: 0 0 0 1px var(--mud-palette-primary) inset;
    }

/* Lưới preview import tài sản — dòng có lỗi tô nền đỏ nhạt */
.ts-import-row-err td {
    background: var(--mud-palette-error-hover, #fdecea);
}

/* Bộ lọc đơn vị dạng cây (OrgTreeFilter) */
.ts-org-filter-btn {
    height: 38px;
    text-transform: none;
}

.ts-org-filter-label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ts-org-tree-body {
    max-height: 50vh;
    overflow: auto;
}


/* ============================================================
 * Module Đào tạo (E-learning)
 * ============================================================ */

.dao-tao-dept-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    flex-shrink: 0;
    vertical-align: middle;
    margin-right: 6px;
}

.dao-tao-stat-card {
    transition: border-color 0.2s ease;
    min-height: 60px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-radius: 10px !important;
}

.dao-tao-stat-card:hover {
    border-color: var(--mud-palette-primary-hover);
}

.dao-tao-stat-label {
    font-size: 10px !important;
    font-weight: 600 !important;
    color: var(--mud-palette-text-secondary) !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    line-height: 1.3;
}

.dao-tao-stat-val {
    font-size: 20px;
    font-weight: 700;
    color: var(--mud-palette-text-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1.1;
    letter-spacing: -0.01em;
}

.dao-tao-stat-val-success { color: var(--mud-palette-success); }
.dao-tao-stat-val-error   { color: var(--mud-palette-error); }
.dao-tao-stat-val-warning { color: var(--mud-palette-warning); }

.dao-tao-stat-denom {
    font-size: 13px;
    color: var(--mud-palette-success);
    font-weight: 600;
    opacity: 0.55;
    margin-left: 2px;
}

/* Khi giá trị chính KHÔNG có màu success, denominator giữ tone trung tính. */
.dao-tao-stat-val:not(.dao-tao-stat-val-success) .dao-tao-stat-denom {
    color: var(--mud-palette-text-secondary);
    opacity: 0.85;
}

/* Variant "rich" — có thêm dòng sub-text giải thích metric (dùng cho TheoDoiKetQua).
   Cao hơn variant gọn (90 vs 60) để chứa được sub-text mà không bị chật. */
.dao-tao-stat-card-rich {
    min-height: 90px !important;
    gap: 4px !important;
}

.dao-tao-stat-card-rich .dao-tao-stat-val {
    font-size: 26px;
}

.dao-tao-stat-sub {
    font-size: 11px !important;
    color: var(--mud-palette-text-secondary) !important;
    line-height: 1.3;
    margin-top: 2px;
}

/* Course info banner — dùng cho /dao-tao/theo-doi-ket-qua. Bao bằng accent border-left thay vì full bg. */
.dao-tao-course-banner {
    border-left: 3px solid var(--mud-palette-primary) !important;
    background: var(--mud-palette-surface);
}

/* Grid 2 cột trong banner: trái = meta khóa học (flex 1), phải = pill filter trạng thái (auto). */
.dao-tao-course-banner-grid {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}

.dao-tao-course-banner-info {
    flex: 1 1 auto;
    min-width: 0;
}

.dao-tao-course-banner-filter {
    flex: 0 0 auto;
    max-width: 55%;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 10px;
}

/* Hàng filter: ô tìm nhân viên + dropdown lọc trạng thái cạnh nhau (wrap khi hẹp). */
.dao-tao-banner-filter-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    width: 100%;
}

/* Wrapper ô tìm — giữ flex sizing Ở ĐÂY (không lên root MudTextField, tránh field bị kéo cao). */
.dao-tao-banner-search {
    flex: 1 1 180px;
    min-width: 160px;
    max-width: 240px;
}

/* Thống kê nhanh khóa đang chọn — hàng chip nhỏ dưới dropdown lọc (Hoàn thành/Đang học/Chưa đạt). */
.dao-tao-banner-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: flex-end;
}
.dao-tao-banner-stat {
    display: inline-flex;
    align-items: baseline;
    gap: 5px;
    padding: 4px 10px;
    background: var(--mud-palette-background-grey, #f4f4f8);
    border-radius: 8px;
    font-size: 12px;
    white-space: nowrap;
}
.dao-tao-banner-stat-label { color: var(--mud-palette-text-secondary); }
.dao-tao-banner-stat-val { font-weight: 700; }

/* Pills bên trong filter col: cho phép wrap nhiều dòng nếu width hẹp. */
.dao-tao-course-banner-filter .dao-tao-state-pills {
    justify-content: flex-end;
}

/* Responsive: dưới 1100px stack dọc lại (pill xuống dưới meta) — tránh bóp meta khóa quá hẹp. */
@media (max-width: 1100px) {
    .dao-tao-course-banner-grid {
        flex-direction: column;
    }
    .dao-tao-course-banner-filter {
        max-width: 100%;
        align-items: flex-start;
    }
    .dao-tao-course-banner-filter .dao-tao-banner-stats {
        justify-content: flex-start;
    }
}

.dao-tao-course-banner-ma {
    font-family: 'JetBrains Mono', monospace;
    font-size: 13px;
    font-weight: 700;
    color: var(--mud-palette-primary);
    background: var(--brand-soft);
    padding: 2px 8px;
    border-radius: 6px;
    letter-spacing: 0.02em;
}

/* Dropdown filter trạng thái (legacy — QuanLyKhoaHoc vẫn dùng MudMenu). */
.dao-tao-state-menu {
    min-width: 260px;
}

/* ── Pill segmented filter trạng thái (TheoDoiKetQua) — inline, click thẳng, không dropdown.
   Container nền xám nhạt bo tròn; pill active là pillow trắng có shadow. ── */
.dao-tao-state-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    padding: 4px;
    background: var(--mud-palette-background-grey, #f4f4f8);
    border-radius: 999px;
    align-items: center;
}

.dao-tao-state-pill {
    appearance: none;
    border: 0;
    background: transparent;
    padding: 6px 14px;
    border-radius: 999px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    line-height: 1;
    color: var(--mud-palette-text-secondary);
    transition: background 120ms ease, color 120ms ease, box-shadow 120ms ease;
    font-family: inherit;
}

.dao-tao-state-pill:hover {
    background: rgba(0, 0, 0, 0.04);
    color: var(--mud-palette-text-primary);
}

.dao-tao-state-pill.active {
    background: var(--mud-palette-surface, #fff);
    color: var(--mud-palette-text-primary);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
    font-weight: 600;
}

.dao-tao-state-pill-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 7px;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.06);
    color: var(--mud-palette-text-secondary);
    font-size: 11px;
    font-weight: 600;
}

/* Count tone theo state khi pill KHÔNG active (tô nhẹ background theo color). */
.dao-tao-state-pill-success .dao-tao-state-pill-count {
    background: rgba(46, 125, 50, 0.12);
    color: var(--mud-palette-success-darken);
}
.dao-tao-state-pill-info .dao-tao-state-pill-count {
    background: rgba(2, 136, 209, 0.12);
    color: var(--mud-palette-info-darken);
}
.dao-tao-state-pill-warning .dao-tao-state-pill-count {
    background: rgba(237, 108, 2, 0.12);
    color: var(--mud-palette-warning-darken);
}
.dao-tao-state-pill-error .dao-tao-state-pill-count {
    background: rgba(211, 47, 47, 0.12);
    color: var(--mud-palette-error-darken);
}

/* Pill active: count chuyển sang nền màu đậm chữ trắng. */
.dao-tao-state-pill.active.dao-tao-state-pill-success .dao-tao-state-pill-count {
    background: var(--mud-palette-success); color: #fff;
}
.dao-tao-state-pill.active.dao-tao-state-pill-info .dao-tao-state-pill-count {
    background: var(--mud-palette-info); color: #fff;
}
.dao-tao-state-pill.active.dao-tao-state-pill-warning .dao-tao-state-pill-count {
    background: var(--mud-palette-warning); color: #fff;
}
.dao-tao-state-pill.active.dao-tao-state-pill-error .dao-tao-state-pill-count {
    background: var(--mud-palette-error); color: #fff;
}
.dao-tao-state-pill.active.dao-tao-state-pill-default .dao-tao-state-pill-count {
    background: var(--mud-palette-primary); color: #fff;
}

/* ── Bảng theo dõi 3 cột (TheoDoiKetQua) — cell xếp dọc label/value ──
   Mỗi row trong cell: label cố định 80px (xám in hoa nhỏ) | value flex-grow.
   Padding row cao hơn default vì cell có 3-4 dòng. */
.dao-tao-tracking-table td {
    vertical-align: top;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
}

.dao-tao-cell-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    line-height: 1.5;
    min-height: 22px;
}

.dao-tao-cell-label {
    flex: 0 0 80px;
    color: var(--mud-palette-text-secondary);
    font-size: 10.5px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
}

.dao-tao-cell-value {
    color: var(--mud-palette-text-primary);
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-width: 0;
    flex: 1;
}

/* Nút mã chứng nhận trong cell — hành xử như link, mở dialog xem cert. */
.dao-tao-cert-link {
    appearance: none;
    background: transparent;
    border: 0;
    padding: 2px 6px;
    border-radius: 4px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--mud-palette-primary);
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    font-weight: 600;
    transition: background 120ms ease;
}

.dao-tao-cert-link:hover {
    background: var(--mud-palette-primary-hover, rgba(25, 118, 210, 0.08));
    text-decoration: underline;
}

.dao-tao-state-menu-count {
    font-size: 11px;
    font-weight: 600;
    background: var(--slate-200);
    color: var(--fg-3);
    padding: 1px 7px;
    border-radius: 999px;
    font-variant-numeric: tabular-nums;
}

/* --- Khóa học của tôi · Filter bar segmented pills (khớp el-segmented design source) ---
   Specificity tăng (chain class) để THẮNG cascade vs MudBlazor button reset
   (global "button {padding:0;border:0;background:rgba(0,0,0,0);...}"). */
.dao-tao-filter-bar {
    row-gap: 8px;
}

.dao-tao-seg {
    display: inline-flex;
    background: var(--slate-100);
    padding: 4px;
    border-radius: 10px;
    gap: 2px;
}

.dao-tao-seg .dao-tao-seg-btn,
button.dao-tao-seg-btn {
    appearance: none;
    border: 0 !important;
    background: transparent;
    font-family: inherit;
    font-size: 13px;
    font-weight: 500;
    color: var(--mud-palette-text-secondary);
    cursor: pointer;
    padding: 6px 12px !important;
    border-radius: 8px !important;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: background 140ms, color 140ms, box-shadow 140ms;
    white-space: nowrap;
    line-height: 1.4;
}

.dao-tao-seg .dao-tao-seg-btn:hover,
button.dao-tao-seg-btn:hover {
    color: var(--mud-palette-text-primary);
    background: rgba(0, 0, 0, 0.03);
}

.dao-tao-seg .dao-tao-seg-btn.active,
button.dao-tao-seg-btn.active {
    background: var(--mud-palette-surface) !important;
    color: var(--mud-palette-primary) !important;
    font-weight: 600;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.dao-tao-seg-btn .dao-tao-seg-count {
    font-size: 11px;
    font-weight: 600;
    background: var(--slate-200);
    color: var(--fg-3);
    padding: 1px 7px;
    border-radius: 999px;
    font-variant-numeric: tabular-nums;
    line-height: 1.6;
    margin-left: 4px;
}

.dao-tao-seg-btn.active .dao-tao-seg-count {
    background: var(--brand-soft);
    color: var(--mud-palette-primary);
}

/* Tone count badge theo state — áp dụng cả khi pill chưa active để user nhận biết
   "đã hoàn thành" (xanh) / "hết hạn" (đỏ) ngay. Active state KHÔNG override tone
   (đè ngoài cùng → vẫn ưu tiên tone state để giữ nhận diện màu). */
.dao-tao-seg-count-success {
    background: rgba(76, 175, 80, 0.18) !important;
    color: var(--mud-palette-success) !important;
}

.dao-tao-seg-count-error {
    background: rgba(244, 67, 54, 0.16) !important;
    color: var(--mud-palette-error) !important;
}

/* --- Left nav filter --- */
.dao-tao-left-nav {
    width: 248px;
    min-width: 232px;
    background: var(--mud-palette-surface);
    border-right: 1px solid var(--mud-palette-lines-default);
    display: flex;
    flex-direction: column;
}

.dao-tao-nav-search {
    padding: 12px 12px 8px;
    flex-shrink: 0;
    border-bottom: 1px solid var(--mud-palette-lines-default);
}

.dao-tao-nav-body {
    flex: 1 1 auto;
    overflow-y: auto;
    min-height: 0;
    padding: 6px 0;
}

.dao-tao-nav-section {
    padding: 6px 0 8px;
    border-bottom: 1px solid var(--mud-palette-lines-default);
}

.dao-tao-nav-section:last-child {
    border-bottom: none;
}

.dao-tao-nav-title {
    display: flex;
    align-items: center;
    gap: 6px;
    width: 100%;
    padding: 8px 14px 4px;
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--mud-palette-text-secondary);
}

.dao-tao-nav-title:hover {
    background: var(--mud-palette-action-default-hover);
}

.dao-tao-nav-title > span:first-child {
    flex: 1;
    text-align: left;
}

.dao-tao-nav-hint {
    font-size: 10px;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    color: var(--mud-palette-text-disabled);
}

.dao-tao-nav-chevron {
    transition: transform 0.18s ease;
}

.dao-tao-nav-items {
    display: flex;
    flex-direction: column;
    padding: 2px 8px 4px;
}

.dao-tao-nav-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 7px 10px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    color: var(--mud-palette-text-primary);
    user-select: none;
    transition: background 0.12s ease;
    position: relative;
}

.dao-tao-nav-item:hover {
    background: var(--mud-palette-action-default-hover);
}

.dao-tao-nav-item.is-active {
    background: var(--mud-palette-primary-hover);
    color: var(--mud-palette-primary-darken);
    font-weight: 600;
}

.dao-tao-nav-item.is-active::before {
    content: "";
    position: absolute;
    left: 0;
    top: 6px;
    bottom: 6px;
    width: 3px;
    background: var(--mud-palette-primary);
    border-radius: 0 2px 2px 0;
}

.dao-tao-nav-item.is-sub {
    margin-left: 16px;
    font-size: 12.5px;
}

.dao-tao-nav-item-body {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
}

.dao-tao-nav-item-count {
    margin-left: auto;
    background: var(--mud-palette-action-disabled-background);
    color: var(--mud-palette-text-secondary);
    padding: 1px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    min-width: 24px;
    text-align: center;
}

/* Count chip CÓ dữ liệu (SL > 0) — tô màu thương hiệu để nổi bật khi sort theo SL desc; SL=0 giữ xám. */
.dao-tao-nav-item-count.has-data {
    background: var(--brand-soft);
    color: var(--brand);
}

/* Active luôn thắng (specificity 3 class > 2 class của .has-data). */
.dao-tao-nav-item.is-active .dao-tao-nav-item-count {
    background: var(--mud-palette-primary);
    color: white;
}

.dao-tao-nav-item-code {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    color: var(--mud-palette-text-disabled);
    margin-right: 6px;
    flex-shrink: 0;
}

/* Chấm trạng thái khóa học trong left nav (TheoDoiKetQua) — báo mở/đóng/nháp/hết hạn. */
.dao-tao-course-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-right: 8px;
    flex-shrink: 0;
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.6);
}

.dao-tao-nav-item-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}

/* Nav item dạng STACK (TheoDoiKetQua) — dùng chung: khóa học (tiêu đề/mã) + phòng ban (tên/công ty·chi nhánh).
   .dao-tao-course-meta = cột wrapper · .dao-tao-course-title = dòng chính · sub = mã (mono) hoặc scope (thường). */
.dao-tao-course-meta {
    display: flex;
    flex-direction: column;
    min-width: 0;
    flex: 1;
    gap: 1px;
    line-height: 1.25;
}
.dao-tao-course-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 13px;
    color: var(--mud-palette-text-primary);
}
.dao-tao-course-code {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10.5px;
    color: var(--mud-palette-text-disabled);
}
/* Sub-line chữ thường (vd "công ty · chi nhánh" dưới tên phòng ban). */
.dao-tao-nav-sub {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 11px;
    color: var(--mud-palette-text-disabled);
}

.dao-tao-nav-item-co {
    background: var(--mud-palette-primary-hover);
    color: var(--mud-palette-primary-darken);
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 4px;
    font-size: 10px;
    margin-right: 6px;
    flex-shrink: 0;
}

.dao-tao-nav-reset {
    flex-shrink: 0;
    margin: 6px 12px;
}

/* --- Layout shell with left nav ---
   Chiều cao: fit viewport trừ header app + page header + paddings (~200px).
   Override qua CSS var `--dao-tao-layout-offset` ở page level nếu page có toolbar khác cỡ.
   Dùng `dvh` để tránh nhảy khi mobile browser ẩn/hiện URL bar (fallback `vh` cho browser cũ). */
.dao-tao-layout {
    display: flex;
    gap: 16px;
    align-items: stretch;
    --dao-tao-layout-offset: 200px;
    height: calc(100vh - var(--dao-tao-layout-offset));
    height: calc(100dvh - var(--dao-tao-layout-offset));
    min-height: 420px;
}

.dao-tao-layout-content {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
    overflow: hidden;
}

.dao-tao-layout-content > .dao-tao-content-scroll {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* MudPaper bao MudTable — fill toàn bộ vùng scroll, để table tự scroll bên trong. */
.dao-tao-table-paper {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* Override MudTable internal container để header sticky hoạt động:
   container có overflow auto + chiều cao flex 1 → thead sticky neo theo container. */
.dao-tao-table-paper .mud-table {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

.dao-tao-table-paper .mud-table-container {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}

/* Đảm bảo sticky thead có background đặc (không transparent — tránh thấy xuyên row khi scroll). */
.dao-tao-table-paper .mud-table thead.mud-table-sticky-header th {
    background: var(--mud-palette-surface);
    z-index: 2;
}

/* Pagination bar sticky bottom — sibling của content-scroll, đứng yên khi table scroll. */
.dao-tao-pagination-bar {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 8px 12px;
    background: var(--mud-palette-surface);
    border-top: 1px solid var(--mud-palette-lines-default);
}

@media (max-width: 1100px) {
    .dao-tao-layout {
        flex-direction: column;
        height: auto;
    }
    .dao-tao-left-nav {
        width: 100%;
        max-height: 360px;
    }
}

/* ── Mobile <600px: optimize trang /dao-tao/khoa-hoc-cua-toi ──
   - Description ẩn (utility .app-hide-xs).
   - Filter pills horizontal scroll thay vì wrap/squeeze.
   - Card stats vẫn 2 cột vì font 12px đã đủ nhỏ. */
.app-hide-xs { /* default visible */ }

@media (max-width: 600px) {
    .app-hide-xs { display: none !important; }

    /* Pills filter: nếu nhiều/dài → cho scroll ngang thay vì wrap lung tung.
       webkit-overflow-scrolling cho smooth iOS. */
    .dao-tao-seg {
        overflow-x: auto;
        max-width: 100%;
        -webkit-overflow-scrolling: touch;
    }
    .dao-tao-seg::-webkit-scrollbar { height: 4px; }

    /* Pill button mobile: shrink padding + font, label vẫn rõ */
    .dao-tao-seg .dao-tao-seg-btn,
    button.dao-tao-seg-btn {
        padding: 5px 9px !important;
        font-size: 12.5px;
    }
    .dao-tao-seg-btn .dao-tao-seg-count {
        font-size: 10.5px;
        padding: 1px 6px;
    }

    /* Filter bar paper padding nhỏ */
    .dao-tao-filter-bar {
        padding: 6px !important;
    }
}

/* ── Mobile <768px: optimize nhóm trang quản lý khóa học ──
   Header buttons wrap gọn, nav left thấp hơn, pagination + toolbar collapse 1 cột. */
@media (max-width: 768px) {
    /* Nav left collapse hơn để không chiếm hết viewport mobile */
    .dao-tao-left-nav {
        max-height: 240px;
    }

    /* Pagination bar: stack column khi mobile để không bị crowded */
    .dao-tao-pagination-bar {
        flex-direction: column;
        gap: 8px;
        align-items: stretch;
        text-align: center;
    }

    /* Stat cards mobile: padding nhỏ + font giảm cho fit 1 cột MudGrid */
    .dao-tao-stat-card {
        padding: 10px !important;
    }
    .dao-tao-stat-val {
        font-size: 22px !important;
    }

    /* Section title trong form dialog: smaller padding mobile */
    .dao-tao-form-section-title {
        flex-wrap: wrap;
    }
    .dao-tao-form-section-title .dao-tao-form-section-hint {
        margin-left: 0;
        width: 100%;
        margin-top: 2px;
    }
}

/* --- Toggle card "Bắt buộc" cho modal --- */
/* Section title cho form blocks (Step 1 dialog tạo khóa học).
   Icon nhỏ + label primary color + hint dưới subtle. Underline border tạo group visual. */
.dao-tao-form-section-title {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 8px 0 8px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--mud-palette-lines-default);
    color: var(--mud-palette-primary);
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.dao-tao-form-section-title .dao-tao-form-section-hint {
    margin-left: auto;
    color: var(--mud-palette-text-secondary);
    font-size: 11px;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
}

.dao-tao-toggle-card {
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 12px;
    padding: 14px 16px;
    transition: all 0.2s ease;
    cursor: pointer;
}

/* Compact variant: padding nhỏ, single row — dùng cho field secondary trong form dày field. */
.dao-tao-toggle-card.dao-tao-toggle-card-compact {
    padding: 8px 12px;
    border-radius: 8px;
}

.dao-tao-toggle-card:hover {
    border-color: var(--mud-palette-primary-hover);
}

.dao-tao-toggle-card.is-on {
    border-color: var(--mud-palette-primary);
    background: var(--mud-palette-primary-hover);
}

/* Summary card cuối Step 4 — "Sẵn sàng tạo khóa học" với 3 stat grid. Khớp design el-summary-card. */
.dao-tao-summary-card {
    background: linear-gradient(135deg, rgba(76, 175, 80, 0.04), transparent 60%);
    border-color: var(--mud-palette-success) !important;
}

.dao-tao-summary-stat {
    text-align: center;
    padding: 8px 4px;
}

.dao-tao-summary-stat-label {
    font-size: 11px;
    color: var(--mud-palette-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
}

.dao-tao-summary-stat-val {
    font-size: 24px;
    font-weight: 700;
    color: var(--mud-palette-text-primary);
    margin-top: 4px;
    font-variant-numeric: tabular-nums;
}

.dao-tao-summary-stat-unit {
    font-size: 13px;
    color: var(--mud-palette-text-secondary);
    font-weight: 400;
}

/* ════════════════════════════════════════════════════════════════════════
   Step 4 — radio pills + chip row PB. Khớp design el-radio-pill + el-chip.
   ════════════════════════════════════════════════════════════════════════ */

.dao-tao-radio-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.dao-tao-radio-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 999px;
    background: var(--mud-palette-surface);
    cursor: pointer;
    font-size: 13px;
    color: var(--mud-palette-text-primary);
    transition: all 0.15s;
    user-select: none;
}

.dao-tao-radio-pill:hover {
    border-color: var(--mud-palette-primary);
}

.dao-tao-radio-pill-dot {
    width: 14px;
    height: 14px;
    border-radius: 999px;
    border: 2px solid var(--mud-palette-lines-default);
    background: var(--mud-palette-surface);
    flex-shrink: 0;
    transition: all 0.15s;
}

.dao-tao-radio-pill.checked {
    border-color: var(--mud-palette-primary);
    background: var(--mud-palette-primary-hover);
    color: var(--mud-palette-primary);
    font-weight: 600;
}

.dao-tao-radio-pill.checked .dao-tao-radio-pill-dot {
    border-color: var(--mud-palette-primary);
    background: var(--mud-palette-primary);
    box-shadow: inset 0 0 0 2px white;
}

/* Chip row + chip PB + "+ Thêm phòng ban" dashed button. */
.dao-tao-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.dao-tao-chip-pb {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12.5px;
    font-weight: 500;
    padding: 4px 6px 4px 10px;
    border-radius: 999px;
    background: var(--mud-palette-action-default-hover);
    color: var(--mud-palette-text-primary);
    border: 1px solid transparent;
}

.dao-tao-chip-pb-count {
    opacity: 0.7;
    font-size: 11px;
    margin-left: -2px;
}

.dao-tao-chip-pb-x {
    appearance: none;
    border: 0;
    background: transparent;
    width: 20px;
    height: 20px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--mud-palette-text-secondary);
    cursor: pointer;
    padding: 0;
    margin-left: 2px;
}

.dao-tao-chip-pb-x:hover {
    background: var(--mud-palette-lines-default);
    color: var(--mud-palette-text-primary);
}

.dao-tao-chip-pb-add {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    appearance: none;
    background: transparent;
    border: 1px dashed var(--mud-palette-lines-default);
    color: var(--mud-palette-text-secondary);
    cursor: pointer;
    padding: 4px 12px;
    border-radius: 999px;
    font-size: 12.5px;
    font-weight: 500;
    font-family: inherit;
    transition: all 0.15s;
}

.dao-tao-chip-pb-add:hover {
    color: var(--mud-palette-primary);
    border-color: var(--mud-palette-primary);
}

/* --- Drawer preview --- */
.dao-tao-preview-drawer {
    width: 520px;
    max-width: 92vw;
    display: flex;
    flex-direction: column;
    overflow: hidden;          /* panel KHÔNG tự cuộn — body con cuộn, head/foot đứng yên */
}

@media (max-width: 600px) {
    .dao-tao-preview-drawer {
        width: 100vw;
    }
}

/* Layout cuộn: header + footer cố định, chỉ vùng body cuộn (flex column + min-height:0). */
.dao-tao-preview-root {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
}

.dao-tao-preview-head {
    flex-shrink: 0;
}

.dao-tao-preview-body {
    flex: 1 1 auto;
    overflow-y: auto;
    min-height: 0;
}

.dao-tao-preview-foot {
    flex-shrink: 0;
}

.dao-tao-preview-head {
    background: linear-gradient(180deg, var(--mud-palette-primary-hover) 0%, var(--mud-palette-surface) 100%);
    padding: 18px 20px 16px;
}

.dao-tao-preview-section {
    padding: 14px 20px;
    border-top: 1px solid var(--mud-palette-lines-default);
}

.dao-tao-preview-section-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--mud-palette-text-secondary);
    margin-bottom: 8px;
}

/* Stats 2×2 — mỗi stat là card xám bo tròn (khớp design ảnh mẫu). */
.dao-tao-preview-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.dao-tao-preview-stat {
    background: var(--mud-palette-background-grey, #f4f4f8);
    border-radius: 10px;
    padding: 12px 14px;
}

.dao-tao-preview-stat-label {
    font-size: 10.5px;
    color: var(--mud-palette-text-secondary);
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
}

.dao-tao-preview-stat-val {
    font-size: 22px;
    font-weight: 700;
    color: var(--mud-palette-text-primary);
    line-height: 1.1;
}

/* Progress block — card xám lớn, label + % cùng row trên, bar full width dưới. */
.dao-tao-preview-progress {
    background: var(--mud-palette-background-grey, #f4f4f8);
    border-radius: 10px;
    padding: 12px 14px;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    gap: 8px 10px;
    align-items: center;
}

.dao-tao-preview-progress-label {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
    font-size: 10.5px;
    color: var(--mud-palette-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
}

.dao-tao-preview-progress-val {
    grid-column: 2 / 3;
    grid-row: 1 / 2;
    font-size: 14px;
    font-weight: 700;
    color: var(--mud-palette-primary);
    text-align: right;
}

.dao-tao-preview-progress-bar {
    grid-column: 1 / 3;
    grid-row: 2 / 3;
    height: 8px;
    background: var(--mud-palette-action-default-hover, rgba(0,0,0,0.08));
    border-radius: 999px;
    overflow: hidden;
}

.dao-tao-preview-progress-fill {
    height: 100%;
    background: var(--mud-palette-primary);
    border-radius: 999px;
    transition: width 240ms ease;
}

/* Description — blockquote style với border-left primary + nền xanh nhạt. */
.dao-tao-preview-desc {
    background: var(--mud-palette-primary-hover, rgba(25,118,210,0.06));
    border-left: 3px solid var(--mud-palette-primary);
    border-radius: 6px;
    padding: 10px 14px;
    font-size: 13px;
    color: var(--mud-palette-text-primary);
    line-height: 1.55;
}

/* Rows cấu hình — label trái, value bold phải, dotted separator dưới. */
.dao-tao-preview-rows {
    display: flex;
    flex-direction: column;
}

.dao-tao-preview-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 8px 0;
    border-bottom: 1px dashed var(--mud-palette-lines-default);
    font-size: 13px;
}

.dao-tao-preview-row:last-child {
    border-bottom: none;
}

.dao-tao-preview-row-label {
    color: var(--mud-palette-text-secondary);
}

.dao-tao-preview-row-val {
    color: var(--mud-palette-text-primary);
    font-weight: 600;
    text-align: right;
}

/* Section title — count badge tròn xám. */
.dao-tao-preview-section-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 18px;
    padding: 0 6px;
    border-radius: 999px;
    background: var(--mud-palette-action-default-hover);
    color: var(--mud-palette-text-secondary);
    font-size: 10.5px;
    font-weight: 700;
    margin-left: 6px;
    vertical-align: middle;
}

/* Tài liệu row — số STT trong avatar tròn xám + icon + name + meta. */
.dao-tao-preview-mat-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 0;
}

.dao-tao-preview-mat-num {
    flex: 0 0 28px;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--mud-palette-action-default-hover);
    color: var(--mud-palette-text-secondary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
}

.dao-tao-preview-mat-body {
    flex: 1 1 auto;
    min-width: 0;
}

.dao-tao-preview-mat-name {
    font-size: 13px;
    color: var(--mud-palette-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.3;
}

.dao-tao-preview-mat-meta {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 2px;
    font-size: 11px;
    color: var(--mud-palette-text-secondary);
}

.dao-tao-preview-mat-type {
    display: inline-flex;
    align-items: center;
    padding: 1px 6px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* Footer — flex row 2 đầu (Đóng trái, action group phải). */
.dao-tao-preview-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding-top: 12px;
    border-top: 1px solid var(--mud-palette-lines-default);
}

/* Drawer chi tiết — chips phân công + list câu hỏi (xem chi tiết khóa học). */
.dao-tao-preview-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.dao-tao-preview-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 999px;
    font-size: 12.5px;
    background: var(--mud-palette-action-default-hover);
}

.dao-tao-preview-q {
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 8px;
    padding: 10px 12px;
}

.dao-tao-preview-q-head {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
}

.dao-tao-preview-q-num {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--mud-palette-text-secondary);
}

.dao-tao-preview-q-diem {
    font-size: 12px;
    font-weight: 700;
    color: var(--mud-palette-primary);
    white-space: nowrap;
}

.dao-tao-preview-q-noidung {
    font-size: 13.5px;
    font-weight: 500;
    margin-bottom: 6px;
}

.dao-tao-preview-q-opts {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.dao-tao-preview-q-opt {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    padding: 4px 8px;
    border-radius: 6px;
}

.dao-tao-preview-q-opt.correct {
    background: var(--mud-palette-success-hover, rgba(46, 160, 67, 0.10));
    color: var(--mud-palette-success-darken);
    font-weight: 500;
}

/* Timeline dọc 4 bước (Thông tin → Tài liệu → Bài kiểm tra → Phân công) trong drawer chi tiết. */
.dao-tao-tl {
    display: flex;
    flex-direction: column;
}

.dao-tao-tl-item {
    display: grid;
    grid-template-columns: 30px 1fr;
    gap: 14px;
    position: relative;
    padding-bottom: 20px;
}

/* Đường nối dọc giữa các marker (ẩn ở bước cuối). */
.dao-tao-tl-item:not(.dao-tao-tl-last)::before {
    content: '';
    position: absolute;
    left: 14px;
    top: 32px;
    bottom: 0;
    width: 2px;
    background: var(--mud-palette-lines-default);
}

.dao-tao-tl-marker {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--mud-palette-primary);
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    flex-shrink: 0;
    z-index: 1;
}

.dao-tao-tl-body {
    min-width: 0;
    padding-top: 3px;
}

.dao-tao-tl-title {
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 700;
    font-size: 14px;
    margin-bottom: 10px;
    color: var(--mud-palette-text-primary);
}

.dao-tao-tl-bank {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 12px;
    border: 1px dashed var(--mud-palette-lines-default);
    border-radius: 8px;
    background: var(--mud-palette-action-default-hover);
}

.dao-tao-card {
    height: 100%;                 /* fill grid item → các card cùng hàng cao bằng nhau */
    display: flex;
    flex-direction: column;
    transition: box-shadow 0.2s ease, transform 0.18s ease;
}

/* MudCardContent giãn đầy chiều cao để foot (CTA) ghim đáy đồng đều giữa các card. */
.dao-tao-card > .mud-card-content {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

.dao-tao-card:hover {
    box-shadow: 0 2px 12px rgba(15, 23, 42, 0.07);
    transform: translateY(-1px);
}

.dao-tao-card-title {
    font-weight: 600;
    color: var(--mud-palette-text-primary);
    margin-bottom: 4px;
}

.dao-tao-card-title:hover {
    color: var(--mud-palette-primary);
}

.dao-tao-card-desc {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Card 4-stat container — gom vào "ô" background subtle (khớp design el-cc-stats). */
.dao-tao-card-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 14px;
    padding: 10px 12px;
    background: var(--mud-palette-action-default-hover);
    border-radius: 10px;
}

.dao-tao-card-stat {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-size: 12px;
    min-width: 0;
}

.dao-tao-card-stat > .mud-icon-root {
    color: var(--mud-palette-text-secondary);
    margin-top: 2px;
    flex-shrink: 0;
}

.dao-tao-card-stat-label {
    color: var(--mud-palette-text-secondary);
    font-size: 11px;
    line-height: 1.3;
}

.dao-tao-card-stat-val {
    color: var(--mud-palette-text-primary);
    font-weight: 600;
    font-size: 12.5px;
    line-height: 1.35;
    white-space: nowrap;   /* để text-overflow:ellipsis HOẠT ĐỘNG (thiếu nowrap → ngày dài wrap 2 dòng) */
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Progress row — bar + label cùng dòng (khớp design el-cc-progress-row). */
.dao-tao-card-progress {
    display: flex;
    align-items: center;
    gap: 12px;
}

.dao-tao-card-progress-bar {
    flex: 1;
    min-width: 0;
    height: 6px !important;
    border-radius: 999px;
}

.dao-tao-card-progress-label {
    white-space: nowrap;
    flex-shrink: 0;
    font-size: 12px !important;
}

/* Foot — border-top + space-between (khớp design el-cc-foot).
   Mobile: cho wrap để best-score + CTA xuống dòng riêng (CTA button mỗi nút full width). */
.dao-tao-card-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-top: 10px;
    margin-top: auto;             /* ghim foot xuống đáy card (kết hợp flex .dao-tao-card) */
    border-top: 1px solid var(--mud-palette-lines-default);
    flex-wrap: wrap;
}

@media (max-width: 600px) {
    /* Foot mobile: best score row 1, CTA stack row 2 full width. */
    .dao-tao-card-foot > .mud-stack {
        width: 100%;
    }
    .dao-tao-card-foot > .mud-stack > .mud-button-root {
        flex: 1 1 0;
    }
    .dao-tao-card-foot > .mud-button-root {
        width: 100%;
    }
}

.dao-tao-state-chip {
    font-weight: 600 !important;
}

/* --- Cards grid view cho Quản lý KH --- */
.dao-tao-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 12px;
}

.dao-tao-admin-card {
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 12px;
    padding: 16px;
    background: var(--mud-palette-surface);
    cursor: pointer;
    transition: all 0.18s ease;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.dao-tao-admin-card:hover {
    border-color: var(--mud-palette-primary);
    box-shadow: 0 4px 16px rgba(10, 65, 116, 0.08);
    transform: translateY(-1px);
}

.dao-tao-admin-card.is-preview {
    border-color: var(--mud-palette-primary);
    box-shadow: 0 0 0 1px var(--mud-palette-primary) inset;
}

/* Row menu khóa học — match design ELCourseMenu (ElearningScreen.admin.jsx + ElearningScreen.css).
   Spec design: container 240px, item padding 8px 10px, icon 14px, font 13px, divider 4px margin.
   Override MudMenu/MudList default (Mud item padding lớn hơn, icon Medium=24px). */
.dao-tao-row-menu {
    min-width: 240px;
    padding: 4px;
    border-radius: 10px;
}

.dao-tao-row-menu-header {
    padding: 8px 10px 10px;
    border-bottom: 1px solid var(--mud-palette-lines-default);
    margin-bottom: 4px;
    pointer-events: none;
    max-width: 240px;
}

.dao-tao-row-menu-ma {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    color: var(--mud-palette-text-secondary);
    letter-spacing: 0.3px;
}

.dao-tao-row-menu-title {
    font-weight: 600;
    font-size: 13px;
    color: var(--mud-palette-text-primary);
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Item: Mud 9.4 dùng .mud-menu-item (KHÔNG phải mud-list-item).
   Default Mud: padding 8px 12px, icon-color action-disabled !important, icon-size ~22px.
   Override: padding 8px 10px, font 13px, icon 14px, color text-disabled (slate-400 nhạt hơn). */
.dao-tao-row-menu .mud-menu-list {
    padding: 4px;
    min-width: 240px;
}

.dao-tao-row-menu .mud-menu-item {
    padding: 8px 10px;
    border-radius: 6px;
    min-height: auto;
}

.dao-tao-row-menu .mud-menu-item-text {
    flex: 1 1 auto;
    margin: 0;
    font-size: 13px;
}

.dao-tao-row-menu .mud-menu-item-text .mud-typography {
    font-size: 13px;
}

/* Icon 14px (Mud default ~22px) + màu disabled nhạt (#94A3B8 ~ design --fg-4). */
.dao-tao-row-menu .mud-menu-item-icon {
    margin-inline-end: 10px;
    color: var(--mud-palette-text-disabled) !important;
}

.dao-tao-row-menu .mud-menu-item-icon .mud-icon-root,
.dao-tao-row-menu .mud-menu-item-icon svg.mud-svg-icon {
    font-size: 14px !important;
    width: 14px !important;
    height: 14px !important;
}

/* Danger variant: text + icon đỏ + hover tint nhẹ. */
.dao-tao-row-menu .mud-menu-item.is-danger {
    color: var(--mud-palette-error);
}

.dao-tao-row-menu .mud-menu-item.is-danger .mud-menu-item-icon {
    color: var(--mud-palette-error) !important;
}

.dao-tao-row-menu .mud-menu-item.is-danger:hover {
    background-color: rgba(244, 67, 54, 0.08);
}

.dao-tao-row-menu .mud-divider {
    margin: 4px 0;
}

/* ════════════════════════════════════════════════════════════════════════
   Bảng "Quản lý khóa học" — cell compact, ép 1 dòng + ellipsis cho Phạm vi/Hiệu lực
   để row đều chiều cao, không bị bất đối xứng do wrap text dài.
   ════════════════════════════════════════════════════════════════════════ */

.dao-tao-admin-table .mud-table-cell {
    padding-top: 8px;
    padding-bottom: 8px;
    vertical-align: middle;
}

/* Bảng đủ rộng để KHÔNG bóp cột "Tên khóa học" (10 cột). Hẹp hơn → .mud-table-container (overflow:auto)
   tự scroll NGANG, thay vì wrap tiêu đề dọc từng từ. Reset ở mobile <600px (MudTable stack). */
.dao-tao-admin-table table {
    min-width: 980px;
}

/* Tiêu đề khóa — ƯU TIÊN hiển thị: đậm + tối đa 2 dòng (clamp), title attr giữ tên đầy đủ khi hover. */
.dao-tao-admin-title {
    font-weight: 600;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.3;
    word-break: break-word;
}

/* Cell 1 dòng + ellipsis. Title attr giữ thông tin đầy đủ khi hover. */
.dao-tao-cell-truncate {
    display: block;
    max-width: 220px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Cell 1 dòng không wrap (dùng cho khoảng ngày). */
.dao-tao-cell-nowrap {
    white-space: nowrap;
}

/* Progress bar mini cho cột Tiến độ: bar mảnh 4px + caption 1 dòng. */
.dao-tao-cell-progress {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 120px;
    max-width: 180px;
}

.dao-tao-cell-progress-bar {
    height: 4px !important;
    border-radius: 2px;
}

.dao-tao-cell-progress-text {
    font-size: 12px;
    color: var(--mud-palette-text-secondary);
    white-space: nowrap;
}

/* Mobile <600px: bỏ truncate (DataLabel stack layout đã đủ chỗ). */
@media (max-width: 600px) {
    .dao-tao-cell-truncate {
        max-width: none;
        white-space: normal;
    }
    .dao-tao-cell-progress {
        min-width: 0;
        max-width: none;
    }
    /* MudTable chuyển stack (DataLabel) — bỏ min-width bảng + bỏ clamp tiêu đề (hiện full). */
    .dao-tao-admin-table table {
        min-width: 0;
    }
    .dao-tao-admin-title {
        -webkit-line-clamp: initial;
        display: block;
    }
}

/* ════════════════════════════════════════════════════════════════════════
   Block "Danh sách câu hỏi" trong dialog Tạo khóa học · Step 3 — khớp design
   ELQuestionListBlock (ElearningScreen.admin.jsx + ElearningScreen.css).
   ════════════════════════════════════════════════════════════════════════ */

.dao-tao-qb {
    overflow: hidden;
    display: flex;
    flex-direction: column;
    background: var(--mud-palette-surface);
}

.dao-tao-qb-head {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--mud-palette-lines-default);
    flex-wrap: wrap;
}

.dao-tao-qb-toolbar {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--mud-palette-lines-default);
    flex-wrap: wrap;
}

.dao-tao-qb-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    background: var(--mud-palette-action-default-hover);
    padding: 4px;
    border-radius: 10px;
}

.dao-tao-qb-chip {
    appearance: none;
    border: 0;
    background: transparent;
    font-family: inherit;
    font-size: 13px;
    font-weight: 500;
    color: var(--mud-palette-text-secondary);
    cursor: pointer;
    padding: 6px 12px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: all 140ms;
}

.dao-tao-qb-chip:hover {
    color: var(--mud-palette-text-primary);
}

.dao-tao-qb-chip.active {
    background: var(--mud-palette-surface);
    color: var(--mud-palette-primary);
    font-weight: 600;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.dao-tao-qb-chip-count {
    font-size: 11px;
    font-weight: 600;
    background: var(--mud-palette-lines-default);
    color: var(--mud-palette-text-secondary);
    padding: 1px 7px;
    border-radius: 999px;
    min-width: 20px;
    text-align: center;
}

.dao-tao-qb-chip.active .dao-tao-qb-chip-count {
    background: var(--mud-palette-primary-hover);
    color: var(--mud-palette-primary);
}

.dao-tao-qb-body {
    padding: 12px 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: 460px;
    overflow-y: auto;
    flex: 1;
    min-height: 0;
}

.dao-tao-qb-row {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 14px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 10px;
    background: var(--mud-palette-surface);
    transition: border-color 0.15s, box-shadow 0.15s;
}

.dao-tao-qb-row:hover {
    border-color: var(--mud-palette-primary);
    box-shadow: 0 1px 4px rgba(10, 65, 116, 0.06);
}

.dao-tao-qb-num {
    min-width: 56px;
    font-size: 11px;
    font-weight: 700;
    color: var(--mud-palette-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding-top: 4px;
}

.dao-tao-qb-body-col {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.dao-tao-qb-answers {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.dao-tao-qb-answer-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: rgba(76, 175, 80, 0.08);
    border: 1px solid rgba(76, 175, 80, 0.4);
    color: var(--mud-palette-success);
    border-radius: 6px;
    font-size: 12.5px;
    line-height: 1.4;
}

.dao-tao-qb-answer-chip > .mud-icon-root {
    color: var(--mud-palette-success);
}

.dao-tao-qb-empty {
    padding: 48px 16px;
    text-align: center;
    border: 1px dashed var(--mud-palette-lines-default);
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* Fullscreen overlay — list mở rộng full viewport, scrim phủ background. */
.dao-tao-qb-scrim {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.5);
    z-index: 1400;
    cursor: pointer;
}

.dao-tao-qb.is-fullscreen {
    position: fixed;
    top: 24px;
    left: 24px;
    right: 24px;
    bottom: 24px;
    z-index: 1500;
    max-height: calc(100vh - 48px);
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.3);
    border-radius: 12px;
}

.dao-tao-qb.is-fullscreen .dao-tao-qb-body {
    max-height: none;
    flex: 1;
}

/* Mobile <600px: fullscreen ngân hàng câu hỏi phủ KÍN mép (bỏ inset 24px chật) + bỏ cột số cứng 56px. */
@media (max-width: 600px) {
    .dao-tao-qb.is-fullscreen {
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        max-height: 100vh;
        border-radius: 0;
    }
    .dao-tao-qb-num {
        min-width: auto;
    }
    .dao-tao-qb-row {
        gap: 8px;
    }
}

/* Stepper 4 bước (dialog Tạo khóa) — mobile <600px: ẩn label chữ (giữ vòng số + connector) để KHÔNG
   tràn ngang (MudStack Row không wrap, 4 label đầy đủ vượt bề rộng ~360px). Reset connector về giữa avatar. */
@media (max-width: 600px) {
    .dao-tao-stepper-label {
        display: none;
    }
    .dao-tao-stepper-conn {
        margin-bottom: 0 !important;
        min-width: 12px !important;
    }
}

/* ════════════════════════════════════════════════════════════════════════
   User flow "Vào học" — 5 màn (Detail / Viewer / TestIntro / KetQua / ChungNhan).
   Pattern khớp _design_source/.../ElearningScreen.flow.jsx + .test.jsx (variant modern).
   ════════════════════════════════════════════════════════════════════════ */

/* ── Detail page — 2-col grid (main + sticky side) ── */
.dao-tao-detail-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 16px;
    align-items: start;
}

.dao-tao-detail-main {
    min-width: 0;
}

.dao-tao-detail-side {
    position: sticky;
    top: 84px;
}

.dao-tao-side-card {
    background: var(--mud-palette-surface);
}

.dao-tao-side-rows {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.dao-tao-side-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding-bottom: 8px;
    border-bottom: 1px dashed var(--mud-palette-lines-default);
    font-size: 13px;
}

.dao-tao-side-row:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.dao-tao-side-label {
    color: var(--mud-palette-text-secondary);
    font-size: 12px;
}

.dao-tao-side-val {
    color: var(--mud-palette-text-primary);
    font-weight: 500;
    text-align: right;
}

/* ── Material row card trong Detail ── */
.dao-tao-mat-row {
    transition: border-color 0.18s, background 0.18s;
}

.dao-tao-mat-row.is-confirmed {
    background: rgba(76, 175, 80, 0.04);
    border-color: var(--mud-palette-success);
}

.dao-tao-mat-num {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--mud-palette-primary-hover);
    color: var(--mud-palette-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 13px;
    flex-shrink: 0;
}

/* ── Test panel trong Detail ── */
.dao-tao-test-panel {
    transition: border-color 0.18s, box-shadow 0.18s;
}

.dao-tao-test-panel.is-ready {
    border-color: var(--mud-palette-primary);
    box-shadow: 0 4px 14px rgba(10, 65, 116, 0.08);
}

/* Stat tile cho test panel: icon nhỏ + label uppercase + số to.
   Số đứng giữa để mắt scan nhanh; unit nhạt hơn để không cướp attention. */
.dao-tao-test-stat {
    background: var(--mud-palette-surface);
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 8px;
    padding: 10px 12px;
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.dao-tao-test-stat-head {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--mud-palette-text-secondary);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.dao-tao-test-stat-val {
    font-size: 22px;
    font-weight: 700;
    color: var(--mud-palette-text-primary);
    line-height: 1.2;
}

.dao-tao-test-stat-unit {
    font-size: 13px;
    font-weight: 500;
    color: var(--mud-palette-text-secondary);
    margin-left: 2px;
}

/* ── Viewer page — 2-col grid (side list + main canvas) ── */
.dao-tao-viewer-grid {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 16px;
    /* Tận dụng tối đa chiều cao màn hình: lấp đầy viewport (trừ app bar + breadcrumb/title). */
    height: calc(100vh - 170px);
    min-height: 480px;
}

.dao-tao-viewer-side {
    background: var(--mud-palette-surface);
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 200px);
    position: sticky;
    top: 84px;
}

/* Side head — button toggle (mobile) hoặc tiêu đề tĩnh (desktop).
   `appearance:none` reset native button. Display flex để icon + title + count + chevron căn hàng. */
.dao-tao-viewer-side-head {
    appearance: none;
    border: 0;
    background: transparent;
    width: 100%;
    text-align: left;
    cursor: default; /* desktop: không toggle nên cursor mặc định */
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 14px;
    font-family: inherit;
    font-weight: 600;
    font-size: 13px;
    border-bottom: 1px solid var(--mud-palette-lines-default);
    color: var(--mud-palette-text-primary);
}

.dao-tao-viewer-side-head-title {
    flex: 1;
    min-width: 0;
}

.dao-tao-viewer-side-head-count {
    font-size: 11px;
    font-weight: 700;
    background: var(--mud-palette-action-default-hover);
    color: var(--mud-palette-text-secondary);
    padding: 2px 8px;
    border-radius: 999px;
    min-width: 22px;
    text-align: center;
}

/* Chevron: desktop ẩn (list luôn show), mobile hiện. */
.dao-tao-viewer-side-chevron {
    display: none;
}

.dao-tao-viewer-side-list {
    flex: 1;
    overflow-y: auto;
    padding: 4px;
}

.dao-tao-viewer-side-item {
    appearance: none;
    border: 0;
    background: transparent;
    width: 100%;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 6px;
    text-align: left;
    cursor: pointer;
    color: var(--mud-palette-text-primary);
    font-family: inherit;
    font-size: 13px;
    transition: background 0.15s;
}

.dao-tao-viewer-side-item:hover {
    background: var(--mud-palette-action-default-hover);
}

.dao-tao-viewer-side-item.active {
    background: var(--mud-palette-primary-hover);
    color: var(--mud-palette-primary);
    font-weight: 600;
}

.dao-tao-viewer-side-num {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--mud-palette-action-default-hover);
    color: var(--mud-palette-text-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    flex-shrink: 0;
}

.dao-tao-viewer-side-item.active .dao-tao-viewer-side-num {
    background: var(--mud-palette-primary);
    color: white;
}

.dao-tao-viewer-side-meta {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.dao-tao-viewer-side-name {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dao-tao-viewer-side-sub {
    font-size: 11px;
    color: var(--mud-palette-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dao-tao-viewer-side-foot {
    padding: 8px;
    border-top: 1px solid var(--mud-palette-lines-default);
}

.dao-tao-viewer-main {
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.dao-tao-viewer-canvas {
    background: var(--mud-palette-surface);
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 8px;
    flex: 1 1 auto;          /* co giãn lấp đầy chiều cao còn lại của cột main */
    min-height: 0;
    display: flex;
    flex-direction: column;
}

.dao-tao-viewer-video-wrap {
    position: relative;
    width: 100%;
    padding-top: 56.25%;     /* 16:9 */
    background: #000;
    border-radius: 8px;
    overflow: hidden;
}

.dao-tao-viewer-video-wrap > iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

/* LINK ngoài inline iframe — chiều cao cố định + border subtle.
   Nhiều site sẽ trống do X-Frame-Options/CSP; fallback "Mở tab mới" lo phần đó. */
.dao-tao-viewer-link-frame {
    width: 100%;
    height: 480px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 8px;
    overflow: hidden;
    background: var(--mud-palette-surface);
}

.dao-tao-viewer-link-frame > iframe {
    width: 100%;
    height: 100%;
    border: 0;
}

/* Wrap DocumentViewerBody trong page (KHÔNG phải modal) — fix chiều cao + scroll riêng. */
.dao-tao-viewer-doc-wrap {
    width: 100%;
    flex: 1 1 auto;          /* lấp đầy canvas → PDF cao tối đa */
    min-height: 0;
    display: flex;
    flex-direction: column;
}

/* Mobile: bỏ ràng buộc full-viewport (cột stack), nhưng giữ canvas đủ cao để đọc PDF. */
@media (max-width: 960px) {
    .dao-tao-viewer-grid { height: auto; }
    .dao-tao-viewer-canvas { min-height: 68vh; }
}

.dao-tao-viewer-doc-wrap > .doc-viewer-root {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    background: var(--mud-palette-surface);
    border-radius: 8px;
    overflow: hidden;
}

.dao-tao-viewer-doc-wrap .doc-viewer-content {
    flex: 1;
    min-height: 0;
    overflow: auto;
}

.dao-tao-viewer-confirm {
    position: sticky;
    bottom: 0;
    z-index: 5;
    background: var(--mud-palette-surface);
    transition: border-color 0.18s, box-shadow 0.18s;
}

.dao-tao-viewer-confirm.is-on {
    border-color: var(--mud-palette-primary);
    box-shadow: 0 -2px 8px rgba(10, 65, 116, 0.06);
}

/* ── Test Intro stat ── */
.dao-tao-intro-card {
    background: var(--mud-palette-surface);
}

.dao-tao-intro-stat {
    background: var(--mud-palette-action-default-hover);
    border-radius: 8px;
    padding: 12px;
    text-align: center;
}

.dao-tao-intro-stat-label {
    font-size: 11px;
    color: var(--mud-palette-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
}

.dao-tao-intro-stat-val {
    font-size: 28px;
    font-weight: 700;
    color: var(--mud-palette-text-primary);
    margin-top: 4px;
}

.dao-tao-intro-stat-unit {
    font-size: 12px;
    color: var(--mud-palette-text-secondary);
    font-weight: 400;
}

/* ── Result page — hero + side ── */
.dao-tao-result-grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 16px;
    align-items: start;
}

.dao-tao-result-hero {
    text-align: center;
}

.dao-tao-result-hero.is-passed {
    background: linear-gradient(135deg, rgba(76, 175, 80, 0.06), transparent);
    border-color: var(--mud-palette-success);
}

.dao-tao-result-hero.is-failed {
    background: linear-gradient(135deg, rgba(244, 67, 54, 0.06), transparent);
    border-color: var(--mud-palette-error);
}

.dao-tao-result-bar {
    position: relative;
    width: 100%;
    max-width: 480px;
    height: 8px;
    background: var(--mud-palette-action-default-hover);
    border-radius: 999px;
    overflow: hidden;
}

.dao-tao-result-bar-fill {
    height: 100%;
    border-radius: 999px;
    transition: width 0.4s;
}

.dao-tao-result-bar-fill.is-passed { background: var(--mud-palette-success); }
.dao-tao-result-bar-fill.is-failed { background: var(--mud-palette-error); }

.dao-tao-result-bar-mark {
    position: absolute;
    top: -4px;
    width: 2px;
    height: 16px;
    background: var(--mud-palette-text-secondary);
    z-index: 1;
}

.dao-tao-result-side {
    background: var(--mud-palette-surface);
}

/* Hero result: Avatar 72×72 + h2 score (font ~3.75rem MudBlazor default). Desktop OK,
   mobile thu lại để không chiếm hết viewport. */
.dao-tao-result-hero-avatar {
    width: 72px !important;
    height: 72px !important;
}

@media (max-width: 600px) {
    /* Hero compact mobile */
    .dao-tao-result-hero {
        padding: 16px !important;
    }
    .dao-tao-result-hero-avatar {
        width: 56px !important;
        height: 56px !important;
    }
    .dao-tao-result-hero-avatar .mud-icon-root {
        font-size: 28px !important;
    }
    .dao-tao-result-hero-score {
        font-size: 2.5rem !important;  /* h2 default ~3.75rem desktop → 2.5rem mobile */
    }
    /* Result bar dài 480px desktop → 100% mobile, mark dot to hơn để thấy rõ. */
    .dao-tao-result-bar {
        max-width: 100%;
    }

    /* Course banner TheoDoiKetQua: meta info wrap đẹp mobile.
       State pills cuộn ngang giống .dao-tao-seg để không chèn vỡ bố cục. */
    .dao-tao-state-pills {
        overflow-x: auto;
        flex-wrap: nowrap;
        max-width: 100%;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
    }
    .dao-tao-state-pills::-webkit-scrollbar { height: 4px; }
    .dao-tao-state-pill {
        flex-shrink: 0;
        padding: 5px 10px;
        font-size: 12.5px;
    }
    .dao-tao-state-pill-count {
        min-width: 20px;
        height: 20px;
        font-size: 10.5px;
    }

    /* Course banner padding gọn mobile. */
    .dao-tao-course-banner {
        padding: 12px !important;
    }
    .dao-tao-course-banner-ma {
        font-size: 12px;
        padding: 2px 6px;
    }
}

/* ════════════════════════════════════════════════════════════════════════
   Certificate FORMAL variant — khớp design ELCertFormal (ElearningScreen.test.jsx + .css).
   Double-border (brand + accent inner), eyebrow uppercase, name lớn brand color,
   foot 3 cột (signature + date + stamp đỏ rotate -8°), QR row footer.
   ════════════════════════════════════════════════════════════════════════ */

.dao-tao-cert-stage {
    background: var(--mud-palette-action-default-hover);
    border-radius: 16px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    /* container-type: inline-size cho phép cert con scale theo width stage (qua 100cqi).
       cqi mặc định = content-box width (sau padding 24px*2 = 48px). */
    container-type: inline-size;
}

/* Wrapper aspect-ratio 210/148 — reserve không gian layout cho cert scaled.
   Cần wrapper vì transform: scale() KHÔNG ảnh hưởng layout box, nếu thiếu cert sẽ
   tràn padding stage trên mobile. width 100% max 210mm = không bao giờ vượt khổ A5. */
.dao-tao-cert-formal-wrap {
    width: 100%;
    max-width: 210mm;
    aspect-ratio: 210 / 148;
    position: relative;
    overflow: hidden;
}

.dao-tao-cert-formal {
    /* Kích thước A5 landscape CỐ ĐỊNH (210mm × 148mm) — KHÔNG responsive content,
       chỉ scale visually qua transform để giữ tỉ lệ + font + layout chuẩn cert.
       max-width:100% BỎ vì sẽ shrink width nhưng height fixed → méo aspect ratio. */
    width: 210mm;
    height: 148mm;
    box-sizing: border-box;
    background: white;
    border-radius: 6px;
    padding: 14px;
    box-shadow: 0 12px 32px -8px rgba(15, 23, 42, 0.25);
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    /* Scale theo container width: tan(atan2(x, y)) = x/y (CSS trig functions).
       100cqi = stage content width. 210mm = cert target. Khi cqi >= 210mm: scale = 1 (full).
       Khi cqi < 210mm: scale < 1 (thu nhỏ proportional, không méo).
       Supported: Chrome 111+, Safari 15.4+, Firefox 108+. */
    transform-origin: top left;
    transform: scale(min(1, tan(atan2(100cqi, 210mm))));
}

.dao-tao-cert-formal-border {
    border: 2px solid var(--mud-palette-primary);
    border-radius: 4px;
    padding: 4px;
    position: relative;
}

.dao-tao-cert-formal-border::before {
    content: '';
    position: absolute;
    inset: 6px;
    border: 1px solid rgba(10, 65, 116, 0.4);
    border-radius: 2px;
    opacity: 0.5;
    pointer-events: none;
}

.dao-tao-cert-formal-inner {
    /* Padding nhỏ hơn bản cũ (32/48/40) cho fit A5 landscape — content không tràn 148mm. */
    padding: 18px 32px 22px;
    position: relative;
}

.dao-tao-cert-formal-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding-bottom: 18px;
    border-bottom: 1px solid #E2E8F0;
    margin-bottom: 24px;
}

.dao-tao-cert-formal-logo {
    display: flex;
    align-items: center;
    gap: 12px;
}

.dao-tao-cert-formal-org {
    font-size: 14px;
    font-weight: 800;
    color: var(--mud-palette-primary);
    letter-spacing: 0.05em;
}

.dao-tao-cert-formal-org-sub {
    font-size: 11px;
    color: #64748B;
    letter-spacing: 0.04em;
}

.dao-tao-cert-formal-id {
    text-align: right;
}

.dao-tao-cert-formal-id-label {
    font-size: 10px;
    color: #64748B;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.dao-tao-cert-formal-id-val {
    font-family: 'JetBrains Mono', monospace;
    font-size: 13px;
    color: var(--mud-palette-primary);
    font-weight: 700;
}

.dao-tao-cert-formal-eyebrow {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.18em;
    color: var(--mud-palette-primary);
    text-align: center;
    text-transform: uppercase;
    margin-bottom: 18px;
}

.dao-tao-cert-formal-name {
    font-family: 'Be Vietnam Pro', serif;
    font-size: 44px;
    font-weight: 800;
    color: var(--mud-palette-primary);
    text-align: center;
    letter-spacing: -0.01em;
    line-height: 1.1;
    margin-bottom: 8px;
    /* Tên dài KHÔNG được đẩy chữ ký/ngày/QR vượt 148mm (cert overflow:hidden → clip mất). Clamp 2 dòng. */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
}

.dao-tao-cert-formal-emp {
    text-align: center;
    font-size: 13px;
    color: #475569;
    margin-bottom: 24px;
}

.dao-tao-cert-formal-body {
    text-align: center;
    font-size: 14px;
    color: #475569;
    line-height: 1.9;
    margin-bottom: 32px;
}

.dao-tao-cert-formal-course {
    font-size: 22px;
    font-weight: 700;
    color: #0F172A;
    letter-spacing: -0.01em;
    line-height: 1.3;
    padding: 8px 16px;
    margin: 6px auto;
    max-width: 600px;
    /* Tên khóa dài → clamp 2 dòng (cùng lý do .dao-tao-cert-formal-name): không clip footer/QR. */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
}

.dao-tao-cert-formal-status {
    margin-top: 14px;
}

.dao-tao-cert-formal-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 18px;
    background: rgba(76, 175, 80, 0.10);
    border: 1.5px solid var(--mud-palette-success);
    color: var(--mud-palette-success);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.dao-tao-cert-formal-foot {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
    align-items: end;
    margin-top: 28px;
}

.dao-tao-cert-formal-sig {
    text-align: center;
}

.dao-tao-cert-formal-sig-line {
    width: 100%;
    border-bottom: 1px solid #94A3B8;
    margin-bottom: 8px;
    height: 32px;
}

.dao-tao-cert-formal-sig-name {
    font-size: 13px;
    font-weight: 700;
    color: #0F172A;
}

.dao-tao-cert-formal-sig-role {
    font-size: 11px;
    color: #64748B;
}

.dao-tao-cert-formal-date {
    text-align: center;
}

.dao-tao-cert-formal-date-label {
    font-size: 11px;
    color: #64748B;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.dao-tao-cert-formal-date-val {
    font-size: 16px;
    font-weight: 700;
    color: #0F172A;
    margin-top: 6px;
}

.dao-tao-cert-formal-stamp {
    display: flex;
    justify-content: center;
}

.dao-tao-cert-formal-stamp-circle {
    width: 90px;
    height: 90px;
    border-radius: 999px;
    border: 2px solid var(--mud-palette-error);
    color: var(--mud-palette-error);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    letter-spacing: 0.06em;
    transform: rotate(-8deg);
    opacity: 0.7;
}

.dao-tao-cert-formal-stamp-text-1 { font-size: 13px; }
.dao-tao-cert-formal-stamp-text-2 { font-size: 9px; margin: 1px 0; }
.dao-tao-cert-formal-stamp-text-3 { font-size: 8px; opacity: 0.8; }

.dao-tao-cert-formal-qr {
    display: flex;
    gap: 10px;
    align-items: center;
    margin-top: 16px;
    padding: 12px 16px;
    background: var(--mud-palette-surface);
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 8px;
    width: max-content;
    margin-left: auto;
    margin-right: auto;
}

.dao-tao-cert-formal-qr-img {
    width: 48px;
    height: 48px;
    border-radius: 4px;
    background: #0F172A;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
}

.dao-tao-cert-formal-qr-t {
    font-size: 11px;
    font-weight: 600;
    color: #475569;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.dao-tao-cert-formal-qr-s {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    color: var(--mud-palette-primary);
}

/* @media print — chỉ in dao-tao-cert-stage, ẩn navbar/header/breadcrumb/buttons. */
@media print {
    /* Khổ giấy A5 landscape — khớp kích thước cert formal (.dao-tao-cert-formal: 210mm × 148mm). */
    @page { size: A5 landscape; margin: 0; }

    /* FIX "tràn 2 trang": visibility:hidden chỉ ẩn HIỂN THỊ, phần tử ẩn VẪN chiếm chiều cao
       trong layout → layout trang gốc cao hơn 1 trang sẽ sinh trang trắng thứ 2. Kẹp html/body
       về đúng 1 trang A5 ngang + overflow:hidden để clip toàn bộ flow ẩn → in ĐÚNG 1 trang
       (kể cả khi trình duyệt không honor @page size, vẫn fit trong 1 trang đầu). */
    html, body {
        width: 210mm;
        height: 148mm;
        margin: 0 !important;
        padding: 0 !important;
        overflow: hidden !important;
    }

    body * { visibility: hidden; }
    #cert-print-area, #cert-print-area * { visibility: visible; }
    #cert-print-area {
        position: absolute;
        left: 0;
        top: 0;
        width: 210mm;
        height: 148mm;
        background: white;
        padding: 0;
        border-radius: 0;
        overflow: hidden;
    }
    .no-print, .mud-app-bar, .mud-drawer, header, nav { display: none !important; }
    /* Print: reset stage + wrapper + cert về static + scale 1.
       Vì @page A5 landscape đã đúng size 210×148mm, không cần scale transform. */
    .dao-tao-cert-stage {
        background: white;
        padding: 0;
        container-type: normal;
    }
    .dao-tao-cert-formal-wrap {
        width: 210mm;
        max-width: none;
        aspect-ratio: auto;
        overflow: visible;
    }
    .dao-tao-cert-formal {
        position: static;
        transform: none;
        width: 210mm;
        height: 148mm;
        max-width: none;
        box-shadow: none;
        page-break-after: avoid;
        page-break-inside: avoid;
    }
}

/* KHÔNG có responsive collapse content cho cert — luôn cố định khổ A5 landscape,
   chỉ scale visually qua transform: scale ở .dao-tao-cert-formal (xem trên).
   Layout content (font 44px name, foot 3-col, top flex-row) giữ nguyên mọi viewport. */

/* QR block trong dialog share — desktop: inline-left cùng URL; mobile: full row + center. */
.dao-tao-cert-share-qr {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}

@media (max-width: 600px) {
    .dao-tao-cert-share-qr {
        width: 100%;
        align-items: center;
    }
}

/* ── Responsive: collapse 2-col grid → 1-col mobile ── */
@media (max-width: 960px) {
    .dao-tao-detail-grid,
    .dao-tao-viewer-grid,
    .dao-tao-result-grid,
    .dao-tao-test-grid {
        grid-template-columns: 1fr;
    }

    .dao-tao-detail-side,
    .dao-tao-viewer-side,
    .dao-tao-test-side {
        position: static;
        max-height: none;
    }
}

/* ════════════════════════════════════════════════════════════════════════
   Modal "Xác nhận nộp bài" (KhoaHocNopBaiDialog) — bảng tóm tắt trước khi nộp.
   ════════════════════════════════════════════════════════════════════════ */
.dao-tao-nopbai-stats {
    border-radius: 10px;
    overflow: hidden;
}

.dao-tao-nopbai-stat-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    font-size: 14px;
    border-bottom: 1px solid var(--mud-palette-lines-default);
}

.dao-tao-nopbai-stat-row:last-child {
    border-bottom: none;
}

.dao-tao-nopbai-stat-row > span:first-child {
    color: var(--mud-palette-text-secondary);
}

.dao-tao-nopbai-stat-row .v {
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.dao-tao-nopbai-stat-row .v.warn { color: var(--mud-palette-warning); }
.dao-tao-nopbai-stat-row .v.ok   { color: var(--mud-palette-success); }

/* ════════════════════════════════════════════════════════════════════════
   Kết quả bài test — hero card (vòng tròn điểm + 4 ô stat + CTA).
   Khớp design ELUserTest A7 variant "hero-page".
   ════════════════════════════════════════════════════════════════════════ */
.dao-tao-result-card {
    padding: 40px 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    border-radius: 16px;
}

.dao-tao-result-mark {
    position: relative;
    width: 220px;
    height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}

.dao-tao-result-ring {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.dao-tao-result-score {
    position: relative;
    font-size: 64px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.03em;
    color: var(--mud-palette-text-primary);
    font-variant-numeric: tabular-nums;
}

.dao-tao-result-score .of {
    font-size: 14px;
    font-weight: 500;
    color: var(--mud-palette-text-secondary);
    margin-left: 3px;
}

.dao-tao-result-title {
    font-size: 24px;
    font-weight: 700;
    color: var(--mud-palette-text-primary);
    letter-spacing: -0.01em;
}

.dao-tao-result-sub {
    font-size: 14px;
    color: var(--mud-palette-text-secondary);
    margin-top: 6px;
    max-width: 460px;
}

.dao-tao-result-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    width: 100%;
    max-width: 480px;
    background: var(--mud-palette-action-default-hover);
    border-radius: 12px;
    padding: 16px;
    margin: 28px 0 20px;
}

.dao-tao-result-stat .lbl {
    font-size: 11px;
    font-weight: 600;
    color: var(--mud-palette-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.dao-tao-result-stat .val {
    font-size: 22px;
    font-weight: 700;
    margin-top: 4px;
    color: var(--mud-palette-text-primary);
    font-variant-numeric: tabular-nums;
}

.dao-tao-result-stat .val.ok    { color: var(--mud-palette-success); }
.dao-tao-result-stat .val.fail  { color: var(--mud-palette-error); }
.dao-tao-result-stat .val.brand { color: var(--mud-palette-primary); }
.dao-tao-result-stat .val.muted { color: var(--mud-palette-text-secondary); }

.dao-tao-result-cta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: center;
}

@media (max-width: 600px) {
    .dao-tao-result-card  { padding: 28px 16px; }
    .dao-tao-result-mark  { width: 160px; height: 160px; }
    .dao-tao-result-score { font-size: 48px; }
    .dao-tao-result-stats { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .dao-tao-result-cta   { width: 100%; flex-direction: column; }
    .dao-tao-result-cta > * { width: 100%; }
}

/* ════════════════════════════════════════════════════════════════════════
   Xem lại kết quả (KhoaHocXemKetQuaDialog) — card mỗi câu + option đúng/sai.
   ════════════════════════════════════════════════════════════════════════ */
.dao-tao-rv-q {
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 12px;
    padding: 14px 16px;
}

.dao-tao-rv-q-head {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    flex-wrap: wrap;
}

.dao-tao-rv-q-num {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--mud-palette-text-secondary);
}

.dao-tao-rv-q-noidung {
    font-weight: 500;
    margin-bottom: 10px;
}

.dao-tao-rv-opt {
    display: flex;
    flex-wrap: wrap;            /* mobile: nhãn (Đáp án đúng/Bạn chọn) xuống dòng riêng */
    align-items: center;
    gap: 6px 8px;
    padding: 8px 12px;
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 8px;
    font-size: 14px;
}

/* Cụm id + text + icon (1 dòng); text wrap tự nhiên (full dòng) nhờ min-width:0. */
.dao-tao-rv-opt-main {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1 1 auto;
    min-width: 0;
}

/* Cụm nhãn — desktop inline cùng dòng; mobile (≤600px) chiếm full dòng → xuống dưới đáp án. */
.dao-tao-rv-opt-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    flex: 0 1 auto;
}

@media (max-width: 600px) {
    .dao-tao-rv-opt-tags { flex-basis: 100%; }
}

.dao-tao-rv-opt.correct {
    border-color: var(--mud-palette-success);
    background: var(--mud-palette-success-hover, rgba(46, 160, 67, 0.10));
}

.dao-tao-rv-opt.wrong {
    border-color: var(--mud-palette-error);
    background: var(--mud-palette-error-hover, rgba(229, 57, 53, 0.10));
}

.dao-tao-rv-opt-id {
    font-weight: 700;
    min-width: 20px;
    color: var(--mud-palette-text-secondary);
}

.dao-tao-rv-opt-text { flex: 1; min-width: 0; }

.dao-tao-rv-opt-tag {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 999px;
    white-space: nowrap;
}

.dao-tao-rv-opt-tag.ok { background: var(--mud-palette-success); color: #fff; }
.dao-tao-rv-opt-tag.no { background: var(--mud-palette-error);   color: #fff; }

.dao-tao-rv-essay {
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 8px;
    padding: 10px 12px;
    background: var(--mud-palette-action-default-hover);
}

.dao-tao-rv-essay-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--mud-palette-text-secondary);
    margin-bottom: 4px;
}

.dao-tao-rv-essay-text { font-size: 14px; white-space: pre-wrap; }

/* ════════════════════════════════════════════════════════════════════════
   Test engine — sticky header + timer + question cards + navigator grid.
   Khớp design ELUserTest (ElearningScreen.test.jsx + ElearningScreen.css).
   ════════════════════════════════════════════════════════════════════════ */

.dao-tao-test-header {
    position: sticky;
    top: 64px;            /* dưới app bar MainLayout */
    z-index: 10;
    background: var(--mud-palette-surface);
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 10px;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}

/* Timer "pill" — đổi màu dần khi gần hết: default → warning < 5 phút → error < 1 phút. */
.dao-tao-test-timer {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    background: var(--mud-palette-action-default-hover);
    color: var(--mud-palette-text-primary);
    font-family: 'JetBrains Mono', monospace;
    font-weight: 600;
    font-size: 14px;
    min-width: 88px;
    justify-content: center;
}

.dao-tao-test-timer.is-warning {
    background: rgba(255, 152, 0, 0.12);
    color: var(--mud-palette-warning);
}

.dao-tao-test-timer.is-low {
    background: rgba(244, 67, 54, 0.12);
    color: var(--mud-palette-error);
    animation: dao-tao-pulse 1s ease-in-out infinite alternate;
}

@keyframes dao-tao-pulse {
    from { box-shadow: 0 0 0 0 rgba(244, 67, 54, 0); }
    to   { box-shadow: 0 0 0 4px rgba(244, 67, 54, 0.18); }
}

.dao-tao-test-progress {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* Body grid: questions chính + navigator sticky bên phải. */
.dao-tao-test-grid {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 16px;
    align-items: start;
}

.dao-tao-test-questions {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.dao-tao-test-side {
    position: sticky;
    top: 168px;      /* dưới sticky header + progress */
    display: flex;
    flex-direction: column;
}

/* Card mỗi câu hỏi — hover highlight nhẹ. */
.dao-tao-test-q-card {
    transition: border-color 0.18s, box-shadow 0.18s;
    scroll-margin-top: 180px;   /* tránh sticky header che khi scroll-to qua navigator */
}

.dao-tao-test-q-card:hover {
    border-color: var(--mud-palette-primary);
    box-shadow: 0 2px 8px rgba(10, 65, 116, 0.04);
}

/* Wrapper từng option (radio/checkbox) — khoảng cách + hover background. */
.dao-tao-test-q-option {
    padding: 4px 8px;
    border-radius: 8px;
    transition: background 0.15s;
}

.dao-tao-test-q-option:hover {
    background: var(--mud-palette-action-default-hover);
}

/* Navigator: grid 5 cột với button số 1-N — highlight done = primary filled. */
.dao-tao-test-nav-card {
    background: var(--mud-palette-surface);
}

.dao-tao-test-nav-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 6px;
}

.dao-tao-test-nav-cell {
    appearance: none;
    border: 1px solid var(--mud-palette-lines-default);
    background: var(--mud-palette-surface);
    color: var(--mud-palette-text-primary);
    font-family: inherit;
    font-weight: 600;
    font-size: 13px;
    border-radius: 6px;
    height: 32px;
    cursor: pointer;
    transition: all 0.15s;
}

.dao-tao-test-nav-cell:hover {
    border-color: var(--mud-palette-primary);
    color: var(--mud-palette-primary);
}

.dao-tao-test-nav-cell.done {
    background: var(--mud-palette-primary);
    border-color: var(--mud-palette-primary);
    color: white;
}

.dao-tao-test-nav-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    border: 1px solid var(--mud-palette-lines-default);
    background: var(--mud-palette-surface);
}

.dao-tao-test-nav-dot.done {
    background: var(--mud-palette-primary);
    border-color: var(--mud-palette-primary);
}

/* ════════════════════════════════════════════════════════════════════════
   Mobile-first cho engine làm bài (KhoaHocTest) — ưu tiên trải nghiệm trên điện thoại:
   - Sticky header tách 2 hàng (back+title trên, timer+nộp bài dưới).
   - Touch target ≥40px cho nav cell + option (quy tắc DESIGN.md §20).
   - Q card padding gọn để tận dụng chiều ngang.
   - Tips ẩn (đã hiển thị ở /test-intro).
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
    /* Sticky header wrap thành 2 hàng. Cha .dao-tao-test-header là flex 1 row
       — bật flex-wrap để row 2 (timer + nộp) tự tụt xuống full width. */
    .dao-tao-test-header {
        flex-wrap: wrap;
        gap: 8px 12px;
        padding: 8px 12px;
        top: 56px; /* mobile app bar thấp hơn desktop ~64px */
    }
    /* Right group (timer + nộp bài): mobile full width + space-between để bấm trúng. */
    .dao-tao-test-header > .mud-stack:last-child {
        width: 100%;
        justify-content: space-between;
        flex-wrap: nowrap;
    }

    /* Question card: pa-4 desktop → pa-3 mobile cho thêm chiều ngang đọc đề. */
    .dao-tao-test-q-card {
        padding: 12px !important;
        scroll-margin-top: 140px; /* sticky header mobile cao hơn (2 hàng) */
    }

    /* Option radio/checkbox: padding rộng + min-height 40px cho touch target.
       4px 8px desktop quá hẹp ngón tay — mobile cần 8px 10px tối thiểu. */
    .dao-tao-test-q-option {
        padding: 8px 10px;
        min-height: 40px;
    }

    /* Navigator grid: cell height 40px (chuẩn touch), font 14px dễ nhìn,
       grid 6 cột để bảng ô gọn hơn 5 cột mặc định. */
    .dao-tao-test-nav-cell {
        height: 40px;
        font-size: 14px;
    }
    .dao-tao-test-nav-grid {
        grid-template-columns: repeat(6, 1fr);
        gap: 8px;
    }

    /* Tips card hide mobile — tips đã đầy đủ ở /khoa-hoc/{id}/test-intro,
       trên màn làm bài bỏ để focus question + nav. */
    .dao-tao-test-tips { display: none; }

    /* Foot CTA: 2 nút (Thoát + Nộp bài) → mobile mỗi nút full width tách dòng,
       không bị SpaceBetween squash. */
    .dao-tao-test-foot-cta {
        flex-wrap: wrap;
        gap: 8px;
    }
    .dao-tao-test-foot-cta > .mud-button-root {
        width: 100%;
    }

    /* Timer mobile: giảm min-width để fit nhỏ */
    .dao-tao-test-timer {
        min-width: 72px;
        font-size: 13px;
        padding: 5px 10px;
    }

    /* Progress text + bar mobile rút gọn line-height */
    .dao-tao-test-progress {
        margin-top: 8px !important;
    }
}

/* Touch target tối thiểu cho nav cell desktop cũng nâng nhẹ (32→36) — DESIGN.md §20. */
@media (max-width: 960px) {
    .dao-tao-test-nav-cell { height: 36px; }
}

/* ════════════════════════════════════════════════════════════════════════
   KhoaHocViewer — info/actions blocks + link header (desktop + mobile).
   ════════════════════════════════════════════════════════════════════════ */
/* Desktop: info block flex grow inline cùng actions; actions giữ kích thước con. */
.dao-tao-viewer-confirm-info {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1 1 280px;
    min-width: 0;
}
.dao-tao-viewer-confirm-actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}

/* ════════════════════════════════════════════════════════════════════════
   Mobile-first cho trang đọc tài liệu (KhoaHocViewer) — tối ưu chiều ngang:
   - Body overflow-x:hidden chống horizontal scroll khi nội dung dài (URL, alert text).
   - Side list compact (max-height 180px, scroll bên trong) thay vì chiếm 1/3 màn hình.
   - Ẩn side-foot (nút "Quay lại khóa học") vì breadcrumb đã có.
   - Doc canvas / link iframe height dùng dvh để fit mobile viewport (web bar đẩy).
   - Confirm bar info + actions tách 2 row: actions buttons full-width.
   - Link header button "Mở tab mới" full-width row 2.
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
    /* Defense: cấm horizontal scroll mobile dù child có overflow do text/URL/iframe dài. */
    html, body { overflow-x: hidden; }

    /* Side container mobile: tự co theo nội dung (collapsed = chỉ header; expanded = header + list capped). */
    .dao-tao-viewer-side {
        max-height: none;
        position: static !important;
    }

    /* Head mobile: button toggle thật sự — cursor pointer + hover. */
    .dao-tao-viewer-side-head {
        cursor: pointer;
        padding: 10px 12px;
        font-size: 12.5px;
    }
    .dao-tao-viewer-side-head:hover,
    .dao-tao-viewer-side-head:focus-visible {
        background: var(--mud-palette-action-default-hover);
    }
    .dao-tao-viewer-side-chevron {
        display: inline-flex;
    }

    /* Collapsed: list + foot ẩn hoàn toàn → header chỉ chiếm ~40px. */
    .dao-tao-viewer-side.is-collapsed .dao-tao-viewer-side-list,
    .dao-tao-viewer-side.is-collapsed .dao-tao-viewer-side-foot {
        display: none;
    }
    /* Expanded: list bung ra với scroll giới hạn 280px (~5 items), foot vẫn ẩn (đã có breadcrumb). */
    .dao-tao-viewer-side.is-expanded .dao-tao-viewer-side-list {
        max-height: 280px;
        overflow-y: auto;
    }
    .dao-tao-viewer-side-foot {
        display: none;
    }

    .dao-tao-viewer-side-item {
        padding: 9px 10px;
        font-size: 12.5px;
        gap: 8px;
        min-width: 0;
        min-height: 44px;        /* touch target ≥40px DESIGN.md §20 */
    }
    .dao-tao-viewer-side-num {
        width: 24px;
        height: 24px;
        font-size: 11px;
    }

    /* Canvas wrapper bỏ min-height 420px để fit nội dung mobile (esp. LINK + empty). */
    .dao-tao-viewer-canvas {
        min-height: 320px;
    }

    /* Doc viewer wrap mobile: offset gọn hơn vì side collapsed mặc định chỉ ~40px.
       offset 200px = appbar 60 + breadcrumb 28 + side head 40 + confirm ~80 + gap. */
    .dao-tao-viewer-doc-wrap {
        min-height: 320px;
        max-height: calc(100dvh - 200px);
    }

    /* Link iframe mobile: 360px (rộng hơn 320 vì side collapsed giải phóng chỗ). */
    .dao-tao-viewer-link-frame {
        height: 360px;
    }

    /* Link header mobile: button "Mở tab mới" tự xuống dòng full width nhờ Wrap. */
    .dao-tao-viewer-link-open {
        flex: 1 1 100%;
    }

    /* Confirm bar: padding gọn + 2 block (info + actions) mỗi block full row. */
    .dao-tao-viewer-confirm {
        padding: 10px !important;
    }
    .dao-tao-viewer-confirm-info,
    .dao-tao-viewer-confirm-actions {
        flex: 1 1 100%;
    }
    /* Actions buttons mobile: mỗi nút 1 dòng full width cho dễ tap. */
    .dao-tao-viewer-confirm-actions {
        flex-direction: column;
    }
    .dao-tao-viewer-confirm-actions > .mud-button-root {
        width: 100%;
    }
}

/* Desktop: side luôn show list, ẩn count badge (chỉ là cue mobile khi collapsed). */
@media (min-width: 601px) {
    .dao-tao-viewer-side-head-count { display: none; }
}

/* ════════════════════════════════════════════════════════════════════════
   MOBILE SHELL — tận dụng toàn bộ không gian màn hình điện thoại:
   1. Drawer ở chế độ mini (closed) → ẨN HOÀN TOÀN (không show icon-only).
   2. Drawer khi MỞ → overlay floating, KHÔNG push content (như Temporary variant).
   3. Main content margin-left:0 + container padding gọn (8px thay 24px).
   4. AppBar: ẩn search bar + user info text + giảm gap toolbar.
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
    /* ─── 1. Drawer mini closed → ẩn hoàn toàn ───
       MudBlazor 9 class: aside.mud-drawer.mud-drawer-mini.mud-drawer--closed.
       Dùng transform để giữ transition mượt khi user toggle mở/đóng. */
    aside.mud-drawer.mud-drawer-mini.mud-drawer--closed {
        transform: translateX(-100%) !important;
        visibility: hidden !important;
        width: 0 !important;
        min-width: 0 !important;
    }

    /* ─── 2. Drawer mở → overlay floating ───
       Mini variant mặc định push content; mobile cần overlay 260px + shadow đậm. */
    aside.mud-drawer.mud-drawer-mini.mud-drawer--open {
        position: fixed !important;
        z-index: 1400 !important;
        width: 260px !important;
        max-width: 80vw !important;
        box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25) !important;
    }

    /* ─── 3. AppBar + Main content reset margin-left ───
       MudBlazor set margin-left = drawer mini width (76px) qua inline style + scoped CSS.
       Cần !important + selector đủ mạnh để override. AppBar: `left:0 + width:100%`
       defeat cả inline style của MudBlazor (vd `.mud-appbar { left: var(--mud-drawer-width...) }`). */
    header.crm-app-bar.mud-appbar,
    header.mud-appbar.mud-appbar-fixed-top {
        margin-left: 0 !important;
        left: 0 !important;
        width: 100% !important;
    }
    .app-main-content,
    .mud-main-content {
        margin-left: 0 !important;
        padding-left: 0 !important;
    }
    /* Container con bên trong (MudContainer pa-6 pa-md-8) — mobile 8px tận dụng chiều ngang. */
    .app-main-content > .mud-container,
    .mud-main-content > .mud-container {
        padding: 8px !important;
    }

    /* ─── 4. AppBar gọn mobile ───
       Search bar đầy: ẩn (user vẫn dùng Ctrl+K hoặc /search page nếu có). */
    .crm-search-bar {
        display: none !important;
    }
    /* User info text (tên + role) ẩn — chỉ giữ avatar tròn cho menu. */
    .crm-user-info {
        display: none !important;
    }
    /* User stack gọn padding — chỉ avatar + chevron. */
    .crm-user-stack {
        padding: 4px 6px 4px 4px !important;
        gap: 4px !important;
    }
    /* Toolbar padding/gap mobile — specificity 4 class > scoped razor.css 3 class+attr.
       Cần đủ specificity để thắng `::deep .crm-app-bar .mud-toolbar` ở MainLayout.razor.css. */
    header.crm-app-bar.mud-appbar.mud-appbar-fixed-top .mud-toolbar,
    header.crm-app-bar.mud-appbar .mud-toolbar.mud-toolbar {
        padding: 0 8px !important;
        gap: 4px !important;
    }
}

