/* =============================================================
   Bình dân học vụ số ngành Tòa án — Giao diện
   Nhận diện: đỏ đô + vàng gold, hiện đại, thoáng
   ============================================================= */

:root {
  --red: #8B0A1A;
  --red-dark: #6E0814;
  --red-light: #A91B2E;
  --gold: #C9A227;
  --gold-light: #E6C75A;
  --ink: #1f2430;
  --muted: #6b7280;
  --line: #e6e8ec;
  --bg: #f4f5f7;
  --card: #ffffff;
  --green: #1F6F54;
  --blue: #1565A6;
  --radius: 14px;
  --shadow-sm: 0 1px 3px rgba(16,24,40,.08), 0 1px 2px rgba(16,24,40,.04);
  --shadow-md: 0 6px 18px rgba(16,24,40,.10);
  --shadow-lg: 0 18px 40px rgba(16,24,40,.18);
  --font: "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: var(--font);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
button { font-family: inherit; cursor: pointer; }
a { color: var(--red); text-decoration: none; }
::selection { background: var(--gold-light); }

.hidden { display: none !important; }

/* ---------- EMBLEM (quốc huy cách điệu) ---------- */
.emblem { display: inline-block; line-height: 0; }

/* =============================================================
   MÀN HÌNH ĐĂNG NHẬP
   ============================================================= */
#login-screen {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  background: var(--bg);
}
.login-hero {
  position: relative;
  background:
    radial-gradient(1200px 500px at 20% -10%, rgba(201,162,39,.35), transparent 60%),
    linear-gradient(160deg, var(--red) 0%, var(--red-dark) 100%);
  color: #fff;
  padding: 56px 60px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
}
.login-hero::after {
  content: "";
  position: absolute;
  right: -120px; bottom: -120px;
  width: 360px; height: 360px;
  border: 2px solid rgba(255,255,255,.12);
  border-radius: 50%;
  box-shadow: 0 0 0 40px rgba(255,255,255,.05);
}
.login-hero .brand-row { display: flex; align-items: center; gap: 16px; }
.login-hero .brand-row .emblem { filter: drop-shadow(0 4px 10px rgba(0,0,0,.3)); }
.login-hero h1 { font-size: 24px; font-weight: 700; letter-spacing: .2px; }
.login-hero .sub { color: var(--gold-light); font-size: 13.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px; }
.hero-mid { max-width: 460px; }
.hero-mid h2 { font-size: 34px; line-height: 1.2; font-weight: 800; margin-bottom: 14px; }
.hero-mid p { color: rgba(255,255,255,.85); font-size: 15.5px; }
.hero-points { margin-top: 26px; display: flex; flex-direction: column; gap: 12px; }
.hero-points .pt { display: flex; align-items: center; gap: 12px; font-size: 14.5px; color: rgba(255,255,255,.92); }
.hero-points .pt .dot { width: 30px; height: 30px; border-radius: 9px; background: rgba(255,255,255,.14); display: grid; place-items: center; font-size: 15px; }
.hero-foot { font-size: 12.5px; color: rgba(255,255,255,.6); }

.login-panel { display: grid; place-items: center; padding: 40px; }
.login-card {
  width: 100%; max-width: 380px;
  background: var(--card);
  border-radius: var(--radius);
  padding: 8px 4px;
}
.login-card h3 { font-size: 22px; font-weight: 750; }
.login-card .lead { color: var(--muted); font-size: 14px; margin: 6px 0 26px; }
.field { margin-bottom: 16px; }
.field label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 7px; color: #374151; }
.field input {
  width: 100%; padding: 12px 14px;
  border: 1.5px solid var(--line); border-radius: 10px;
  font-size: 15px; transition: border-color .15s, box-shadow .15s; background: #fcfcfd;
}
.field input:focus { outline: none; border-color: var(--red); box-shadow: 0 0 0 3.5px rgba(139,10,26,.12); background:#fff; }
.btn-primary {
  width: 100%; padding: 13px; border: none; border-radius: 10px;
  background: linear-gradient(135deg, var(--red-light), var(--red-dark));
  color: #fff; font-size: 15.5px; font-weight: 650; letter-spacing: .2px;
  box-shadow: 0 6px 16px rgba(139,10,26,.28); transition: transform .08s, box-shadow .2s;
}
.btn-primary:hover { box-shadow: 0 10px 22px rgba(139,10,26,.34); }
.btn-primary:active { transform: translateY(1px); }
.login-error { background:#fdeced; color:#9b1c2e; border:1px solid #f6c9ce; padding:10px 12px; border-radius:10px; font-size:13.5px; margin-bottom:16px; }

.demo-accounts { margin-top: 24px; border-top: 1px dashed var(--line); padding-top: 18px; }
.demo-accounts .t { font-size: 12.5px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; }
.demo-chip {
  display:flex; align-items:center; gap:10px; width:100%;
  border:1px solid var(--line); background:#fff; border-radius:10px;
  padding:9px 11px; margin-bottom:8px; text-align:left; transition: all .15s;
}
.demo-chip:hover { border-color: var(--red); background:#fffafa; transform: translateX(2px); }
.demo-chip .av { width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:700;flex:none; }
.demo-chip .meta { font-size:12.5px; line-height:1.3; }
.demo-chip .meta b { font-size:13px; }
.demo-chip .meta span { color: var(--muted); }
.demo-chip .go { margin-left:auto; color:var(--muted); font-size:12px; }

/* =============================================================
   KHUNG ỨNG DỤNG
   ============================================================= */
#app { min-height: 100vh; display: grid; grid-template-rows: auto 1fr; }

/* Header */
.topbar {
  position: sticky; top: 0; z-index: 40;
  background: linear-gradient(120deg, var(--red) 0%, var(--red-dark) 100%);
  color: #fff; height: 64px;
  display: flex; align-items: center; gap: 16px;
  padding: 0 20px; box-shadow: 0 2px 12px rgba(110,8,20,.28);
}
.topbar .menu-toggle { display:none; background:rgba(255,255,255,.14); border:none; color:#fff; width:38px;height:38px;border-radius:9px; font-size:18px; }
.topbar .brand { display: flex; align-items: center; gap: 12px; }
.topbar .brand .tt { line-height: 1.15; }
.topbar .brand .tt b { font-size: 15.5px; font-weight: 700; display:block; }
.topbar .brand .tt span { font-size: 11.5px; color: var(--gold-light); font-weight: 600; letter-spacing: .6px; }
.topbar .spacer { flex: 1; }
.topbar .top-action { background:rgba(255,255,255,.12); border:none; color:#fff; height:38px; padding:0 12px; border-radius:9px; font-size:13.5px; display:flex; align-items:center; gap:7px; }
.topbar .top-action:hover { background:rgba(255,255,255,.2); }

.user-menu { position: relative; }
.user-btn { display:flex; align-items:center; gap:10px; background:rgba(255,255,255,.12); border:none; color:#fff; padding:5px 10px 5px 5px; border-radius:30px; }
.user-btn:hover { background:rgba(255,255,255,.2); }
.user-btn .av { width:32px;height:32px;border-radius:50%;background:var(--gold);color:var(--red-dark);display:grid;place-items:center;font-weight:700;font-size:13px; }
.user-btn .nm { font-size:13.5px; font-weight:600; text-align:left; line-height:1.15; }
.user-btn .nm small { display:block; font-size:11px; color:var(--gold-light); font-weight:500; }
.dropdown {
  position:absolute; right:0; top:48px; width:240px;
  background:#fff; color:var(--ink); border-radius:12px; box-shadow:var(--shadow-lg);
  overflow:hidden; border:1px solid var(--line);
}
.dropdown .dh { padding:14px; border-bottom:1px solid var(--line); }
.dropdown .dh b { font-size:14px; } .dropdown .dh div { font-size:12.5px; color:var(--muted); }
.dropdown button { width:100%; text-align:left; background:none; border:none; padding:11px 14px; font-size:13.5px; display:flex; align-items:center; gap:10px; color:var(--ink); }
.dropdown button:hover { background:#f7f7f9; }
.dropdown button.danger { color:var(--red); border-top:1px solid var(--line); }

/* Body grid */
.shell { display: grid; grid-template-columns: 256px 1fr; min-height: calc(100vh - 64px); }

/* Sidebar */
.sidebar { background:#fff; border-right:1px solid var(--line); padding:18px 14px; }
.nav-group-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:#9aa1ad; padding:14px 12px 6px; }
.nav-item {
  display:flex; align-items:center; gap:12px; width:100%;
  padding:11px 12px; border:none; background:none; border-radius:10px;
  font-size:14.5px; color:#3b414d; font-weight:550; margin-bottom:3px; transition: all .14s;
}
.nav-item .ic { width:22px; text-align:center; font-size:17px; }
.nav-item:hover { background:#f6f1f1; color:var(--red); }
.nav-item.active { background: linear-gradient(135deg, rgba(139,10,26,.10), rgba(201,162,39,.10)); color:var(--red); font-weight:700; box-shadow: inset 3px 0 0 var(--red); }
.nav-badge { margin-left:auto; background:var(--red); color:#fff; font-size:11px; font-weight:700; padding:1px 8px; border-radius:20px; }

.sidebar-foot { margin-top:18px; padding:14px; background:linear-gradient(135deg,#fbf7ee,#fdf3f4); border:1px solid var(--line); border-radius:12px; }
.sidebar-foot .tt { font-size:12.5px; font-weight:700; color:var(--red); margin-bottom:4px; }
.sidebar-foot p { font-size:12px; color:var(--muted); }

/* Main */
.main { padding: 26px 30px 60px; overflow-x:hidden; }
.page-head { margin-bottom: 22px; }
.page-head h1 { font-size: 24px; font-weight: 780; letter-spacing:.2px; }
.page-head p { color: var(--muted); font-size: 14.5px; margin-top:4px; }
.breadcrumb { font-size:12.5px; color:var(--muted); margin-bottom:6px; }

/* Cards / utilities */
.card { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-sm); }
.section-title { font-size:16.5px; font-weight:700; margin:26px 0 14px; display:flex; align-items:center; gap:9px; }
.section-title .bar { width:4px; height:18px; background:var(--gold); border-radius:3px; }

/* Stat cards */
.stats { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.stat { padding:18px; display:flex; gap:14px; align-items:center; }
.stat .ic { width:48px;height:48px;border-radius:12px;display:grid;place-items:center;font-size:22px;color:#fff;flex:none; }
.stat .v { font-size:26px; font-weight:800; line-height:1; }
.stat .l { font-size:13px; color:var(--muted); margin-top:5px; }

/* Welcome banner */
.welcome {
  position:relative; overflow:hidden; color:#fff; border-radius:var(--radius);
  background: radial-gradient(800px 300px at 90% -40%, rgba(201,162,39,.4), transparent 60%),
              linear-gradient(120deg,var(--red),var(--red-dark));
  padding:26px 28px; margin-bottom:22px; box-shadow:var(--shadow-md);
}
.welcome h2 { font-size:22px; font-weight:780; }
.welcome p { color:rgba(255,255,255,.88); font-size:14.5px; margin-top:6px; max-width:640px; }
.welcome .chips { margin-top:16px; display:flex; flex-wrap:wrap; gap:9px; }
.welcome .chip { background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.18); padding:6px 13px; border-radius:30px; font-size:13px; font-weight:600; }
.welcome .cta { position:absolute; right:26px; bottom:24px; }
.btn-gold { background:linear-gradient(135deg,var(--gold-light),var(--gold)); color:var(--red-dark); border:none; padding:11px 18px; border-radius:10px; font-weight:750; font-size:14px; box-shadow:0 8px 18px rgba(201,162,39,.35); display:inline-flex; align-items:center; gap:8px; }
.btn-gold:hover { filter:brightness(1.04); }

/* Toolbar (search + filters) */
.toolbar { display:flex; flex-wrap:wrap; gap:12px; align-items:center; margin-bottom:18px; }
.search-box { flex:1; min-width:240px; position:relative; }
.search-box input { width:100%; padding:11px 14px 11px 40px; border:1.5px solid var(--line); border-radius:11px; font-size:14.5px; background:#fff; }
.search-box input:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3.5px rgba(139,10,26,.10); }
.search-box .si { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--muted); font-size:16px; }
.filter-chips { display:flex; flex-wrap:wrap; gap:8px; }
.fchip { border:1.5px solid var(--line); background:#fff; color:#444; padding:8px 14px; border-radius:30px; font-size:13.5px; font-weight:600; display:flex; align-items:center; gap:7px; transition:all .14s; }
.fchip:hover { border-color:var(--red); }
.fchip.active { background:var(--red); border-color:var(--red); color:#fff; }
.fchip .cnt { font-size:11px; opacity:.8; }

/* System cards grid */
.sys-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(310px,1fr)); gap:16px; }
.sys-card { padding:18px; display:flex; flex-direction:column; cursor:pointer; transition:transform .12s, box-shadow .2s, border-color .2s; }
.sys-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:#d9b8bd; }
.sys-card .top { display:flex; align-items:flex-start; gap:12px; margin-bottom:10px; }
.sys-card .sic { width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:20px;color:#fff;flex:none; }
.sys-card .tag { font-size:11px; font-weight:700; padding:3px 9px; border-radius:20px; align-self:flex-start; }
.sys-card h4 { font-size:15.5px; font-weight:700; line-height:1.32; margin-bottom:7px; }
.sys-card p { font-size:13.3px; color:var(--muted); flex:1; }
.sys-card .foot { margin-top:14px; display:flex; align-items:center; justify-content:space-between; }
.sys-card .ask { font-size:13px; font-weight:650; color:var(--red); display:flex; align-items:center; gap:6px; }
.sys-card .num { font-size:12px; color:#c2c6cd; font-weight:700; }

/* Tables */
.table-wrap { overflow-x:auto; border-radius:var(--radius); border:1px solid var(--line); }
table.tbl { width:100%; border-collapse:collapse; background:#fff; font-size:14px; }
table.tbl th { text-align:left; padding:13px 16px; background:#faf7f3; color:#6b5e52; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.6px; border-bottom:1px solid var(--line); }
table.tbl td { padding:13px 16px; border-bottom:1px solid #f0f1f3; }
table.tbl tr:last-child td { border-bottom:none; }
table.tbl tr:hover td { background:#fcfafb; }
.u-cell { display:flex; align-items:center; gap:11px; }
.u-av { width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;flex:none; }
.u-cell .nm b { font-size:14px; } .u-cell .nm span { font-size:12.5px; color:var(--muted); }

/* Badges */
.badge { display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:700; padding:4px 10px; border-radius:20px; }
.badge.role-admin { background:#fdeaec; color:#8B0A1A; }
.badge.role-manager { background:#fdf3df; color:#9a7b12; }
.badge.role-staff { background:#e7f4ef; color:#1F6F54; }
.badge.soft { background:#eef1f6; color:#475569; }

/* Department cards */
.dept-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; }
.dept-card { padding:20px; }
.dept-card .dh { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.dept-card .dcode { width:54px;height:54px;border-radius:12px;background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;display:grid;place-items:center;font-weight:800;font-size:12px;text-align:center;flex:none;padding:4px; }
.dept-card h4 { font-size:15.5px; font-weight:700; line-height:1.3; }
.dept-card p { font-size:13px; color:var(--muted); margin-bottom:14px; }
.dept-card .dstat { display:flex; gap:18px; border-top:1px solid var(--line); padding-top:13px; }
.dept-card .dstat div b { font-size:18px; font-weight:800; color:var(--red); } .dept-card .dstat div span { font-size:12px; color:var(--muted); display:block; }

/* Empty / info */
.empty { text-align:center; padding:50px 20px; color:var(--muted); }
.empty .e-ic { font-size:42px; margin-bottom:10px; }
.notice { background:#fffaf0; border:1px solid #f0e2c4; color:#7a6320; padding:13px 16px; border-radius:11px; font-size:13.3px; display:flex; gap:10px; align-items:flex-start; }
.notice .ni { font-size:16px; }

/* =============================================================
   MODAL (chi tiết hệ thống)
   ============================================================= */
.modal-overlay { position:fixed; inset:0; background:rgba(16,18,27,.55); backdrop-filter:blur(2px); z-index:60; display:grid; place-items:center; padding:20px; }
.modal { width:100%; max-width:600px; max-height:88vh; overflow:auto; background:#fff; border-radius:18px; box-shadow:var(--shadow-lg); }
.modal-head { position:sticky; top:0; padding:22px 24px; color:#fff; display:flex; gap:14px; align-items:flex-start;
  background:linear-gradient(120deg,var(--red),var(--red-dark)); }
.modal-head .sic { width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.16);display:grid;place-items:center;font-size:22px;flex:none; }
.modal-head h3 { font-size:18px; font-weight:750; line-height:1.3; } .modal-head .cat { font-size:12px; color:var(--gold-light); font-weight:600; margin-top:3px; }
.modal-head .x { margin-left:auto; background:rgba(255,255,255,.16); border:none; color:#fff; width:34px;height:34px;border-radius:9px; font-size:16px; flex:none; }
.modal-body { padding:22px 24px; }
.modal-body .blk { margin-bottom:18px; }
.modal-body .blk .lbl { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.6px; color:var(--red); margin-bottom:6px; display:flex; align-items:center; gap:7px; }
.modal-body .blk p { font-size:14px; color:#374151; }
.faq-item { border:1px solid var(--line); border-radius:11px; padding:13px 15px; margin-bottom:9px; }
.faq-item .q { font-size:13.7px; font-weight:700; margin-bottom:5px; display:flex; gap:8px; }
.faq-item .q::before { content:"Q"; background:var(--red); color:#fff; width:18px;height:18px;border-radius:5px;display:grid;place-items:center;font-size:10px;flex:none; }
.faq-item .a { font-size:13.5px; color:#4b5563; padding-left:26px; }

/* =============================================================
   CHATBOT
   ============================================================= */
.chat-wrap { display:grid; grid-template-rows:1fr auto; height:calc(100vh - 64px - 86px); max-height:760px; }
.chat-window { overflow-y:auto; padding:8px 4px 16px; }
.msg { display:flex; gap:11px; margin-bottom:18px; max-width:760px; }
.msg .av { width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:17px;flex:none; }
.msg.bot .av { background:linear-gradient(135deg,var(--red),var(--red-dark)); color:#fff; }
.msg.me { flex-direction:row-reverse; margin-left:auto; }
.msg.me .av { background:var(--gold); color:var(--red-dark); font-weight:700; font-size:13px; }
.bubble { padding:12px 15px; border-radius:14px; font-size:14.2px; line-height:1.6; }
.msg.bot .bubble { background:#fff; border:1px solid var(--line); border-top-left-radius:4px; box-shadow:var(--shadow-sm); }
.msg.me .bubble { background:linear-gradient(135deg,var(--red-light),var(--red-dark)); color:#fff; border-top-right-radius:4px; }
.bubble .src { margin-top:10px; padding-top:9px; border-top:1px dashed var(--line); font-size:12px; color:var(--muted); display:flex; align-items:center; gap:7px; }
.bubble .src .pill { background:#fdeaec; color:var(--red); font-weight:700; padding:2px 9px; border-radius:20px; }
.typing span { display:inline-block; width:7px;height:7px;border-radius:50%;background:var(--muted); margin:0 1px; animation:blink 1.2s infinite; }
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.25}40%{opacity:1}}

.quick-q { display:flex; flex-wrap:wrap; gap:8px; margin:2px 0 8px 47px; max-width:760px; }
.quick-q button { background:#fff; border:1.5px solid var(--line); color:var(--red); font-size:12.8px; font-weight:600; padding:7px 13px; border-radius:30px; transition:all .14s; }
.quick-q button:hover { border-color:var(--red); background:#fffafa; }

.chat-input { display:flex; gap:10px; padding:14px; background:#fff; border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow-sm); }
.chat-input input { flex:1; border:none; font-size:14.5px; padding:8px 6px; }
.chat-input input:focus { outline:none; }
.chat-input .send { background:linear-gradient(135deg,var(--red-light),var(--red-dark)); border:none; color:#fff; width:44px;height:44px;border-radius:11px; font-size:18px; flex:none; box-shadow:0 6px 14px rgba(139,10,26,.28); }
.chat-input .send:hover { filter:brightness(1.06); }
.chat-intro-pills { display:flex; flex-wrap:wrap; gap:9px; }

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width: 1080px){
  .stats{grid-template-columns:repeat(2,1fr);}
}
@media (max-width: 960px){
  #login-screen{grid-template-columns:1fr;}
  .login-hero{display:none;}
}
@media (max-width: 860px){
  .shell{grid-template-columns:1fr;}
  .sidebar{position:fixed; top:64px; bottom:0; left:0; width:262px; z-index:35; transform:translateX(-100%); transition:transform .25s; box-shadow:var(--shadow-lg);}
  .sidebar.open{transform:translateX(0);}
  .topbar .menu-toggle{display:grid; place-items:center;}
  .scrim{position:fixed; inset:64px 0 0 0; background:rgba(0,0,0,.4); z-index:34;}
  .main{padding:18px 16px 50px;}
  .welcome .cta{position:static; margin-top:16px;}
  .user-btn .nm{display:none;}
}
@media (max-width: 560px){
  .stats{grid-template-columns:1fr 1fr; gap:12px;}
  .sys-grid{grid-template-columns:1fr;}
  .topbar .brand .tt span{display:none;}
  .hero-mid h2{font-size:26px;}
}

/* =============================================================
   ĐÀO TẠO — lộ trình, bài học, quiz, chứng nhận
   ============================================================= */
.breadcrumb a{color:var(--red);font-weight:600;cursor:pointer}
.breadcrumb a:hover{text-decoration:underline}

.pbar{height:9px;background:#eef0f3;border-radius:20px;overflow:hidden}
.pbar.light{background:rgba(255,255,255,.28)}
.pbar-fill{height:100%;border-radius:20px;transition:width .5s ease}

.train-cta{display:flex;align-items:center;gap:16px;padding:18px 20px;cursor:pointer;transition:box-shadow .2s,transform .12s}
.train-cta:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.train-cta .tci{width:52px;height:52px;border-radius:13px;background:linear-gradient(135deg,var(--gold-light),var(--gold));display:grid;place-items:center;font-size:25px;flex:none}
.train-cta .tcm{flex:1}.train-cta .tcm b{font-size:15.5px}.train-cta .tcm span{font-size:13px;color:var(--muted)}

.path-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.path-card{padding:18px;cursor:pointer;transition:transform .12s,box-shadow .2s,border-color .2s}
.path-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:#d9b8bd}
.path-card .top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.path-card .sic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:21px;color:#fff}
.path-card h4{font-size:15.5px;font-weight:700;line-height:1.3;margin-bottom:12px;min-height:40px}
.cert-pill{background:#fef3d7;color:#9a7b12;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px}
.pmeta{display:flex;justify-content:space-between;align-items:center;margin-top:9px;font-size:13px;color:var(--muted)}
.pmeta b{color:var(--ink);font-size:15px}

.mycert-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:13px}
.mycert{display:flex;align-items:center;gap:13px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:13px;padding:14px;transition:all .15s;cursor:pointer}
.mycert:hover{border-color:var(--gold);background:#fffdf6;transform:translateX(2px)}
.mycert .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:21px;color:#fff;flex:none}
.mycert b{font-size:14px;display:block}.mycert span{font-size:12.5px;color:var(--muted)}

.lesson-list{display:flex;flex-direction:column;gap:9px}
.lesson-row{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 16px;transition:all .14s;cursor:pointer}
.lesson-row:hover{border-color:var(--red);background:#fffafa;transform:translateX(2px)}
.lesson-row .lnum{width:30px;height:30px;border-radius:50%;background:#eef0f3;color:#6b7280;display:grid;place-items:center;font-weight:700;font-size:13.5px;flex:none}
.lesson-row .lnum.done{background:#e7f4ef;color:#0a8a5f}
.lesson-row .linfo{flex:1}.lesson-row .linfo b{font-size:14.3px;display:block}.lesson-row .linfo span{font-size:12.7px;color:var(--muted)}
.lesson-row .lstatus{font-size:12.5px;font-weight:650;color:var(--muted);flex:none}
.lesson-row .lstatus.done{color:#0a8a5f}

.lesson-body{padding:22px;margin-bottom:18px}
.lesson-body .blk{margin-bottom:18px}.lesson-body .blk:last-child{margin-bottom:0}
.lesson-body .blk .lbl{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--red);margin-bottom:6px}
.lesson-body .blk>p{font-size:14.3px;color:#374151}

/* Quiz */
.quiz-card{padding:22px}
.quiz-note{font-size:13.5px;color:var(--muted);margin-bottom:16px}
.quiz-q{padding:16px 0;border-top:1px solid var(--line)}
.quiz-q:first-of-type{border-top:none;padding-top:4px}
.quiz-q .qt{font-size:14.5px;font-weight:650;margin-bottom:11px}
.opt{display:flex;align-items:center;gap:11px;padding:10px 13px;border:1.5px solid var(--line);border-radius:10px;margin-bottom:8px;cursor:pointer;transition:all .13s;font-size:14px}
.opt:hover{border-color:var(--red);background:#fffafa}
.opt input{position:absolute;opacity:0;width:0;height:0}
.opt .ob{width:19px;height:19px;border-radius:50%;border:2px solid #cfd3da;flex:none;transition:all .13s;position:relative}
.opt input:checked~.ob{border-color:var(--red)}
.opt input:checked~.ob::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--red)}
.opt.correct{border-color:#0a8a5f;background:#e9f7f0}
.opt.correct .ob{border-color:#0a8a5f}.opt.correct .ob::after{content:"✓";position:static;display:grid;place-items:center;color:#0a8a5f;font-size:12px;font-weight:800;background:none}
.opt.wrong{border-color:#c0392b;background:#fdecea}
.opt.wrong .ob{border-color:#c0392b}
.quiz-actions{margin-top:18px}
.qres{margin-top:14px;padding:12px 15px;border-radius:11px;font-size:14px;font-weight:600}
.qres.ok{background:#e9f7f0;color:#0a6b4a;border:1px solid #b6e2cf}
.qres.fail{background:#fdecea;color:#a5281b;border:1px solid #f3c4bd}
.qres.warn{background:#fffaf0;color:#7a6320;border:1px solid #f0e2c4}
.quiz-next{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.btn-light{background:#fff;border:1.5px solid var(--line);color:var(--ink);padding:11px 16px;border-radius:10px;font-weight:650;font-size:14px}
.btn-light:hover{border-color:var(--red);color:var(--red)}

/* Chứng nhận */
.certificate{background:#fff;border-radius:14px;padding:14px}
.cert-border{border:3px double var(--gold);border-radius:10px;padding:34px 30px;text-align:center;background:
  radial-gradient(900px 300px at 50% -30%,rgba(201,162,39,.14),transparent 60%),#fffdf8}
.cert-emblem{margin-bottom:8px}
.cert-org{font-size:17px;font-weight:800;color:var(--red);letter-spacing:.5px}
.cert-sub{font-size:12.5px;color:var(--gold);font-weight:700;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:18px}
.cert-title{font-size:27px;font-weight:800;color:var(--ink);letter-spacing:3px;margin-bottom:16px}
.cert-text{font-size:14px;color:#4b5563}
.cert-name{font-size:28px;font-weight:800;color:var(--red);margin:8px 0;font-family:Georgia,"Times New Roman",serif}
.cert-course{font-size:19px;font-weight:750;color:var(--ink);margin:8px 0 4px;font-style:italic}
.cert-foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:30px;gap:14px}
.cert-foot .cf-col{flex:1}
.cert-foot .cf-val{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:6px}
.cert-foot .cf-line{height:1px;background:#c9ccd2;margin-bottom:5px}
.cert-foot .cf-cap{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.cert-foot .cf-seal{width:62px;height:62px;border-radius:50%;border:2px dashed var(--gold);display:grid;place-items:center;font-size:26px;color:var(--red);flex:none}

@media print{
  body *{visibility:hidden !important}
  #cert-print,#cert-print *{visibility:visible !important}
  #cert-print{position:fixed;inset:0;margin:auto;width:96%;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .modal-overlay{background:#fff !important}
}

/* Chứng chỉ của tôi — danh sách */
.cert-list{display:flex;flex-direction:column;gap:12px;margin-top:6px}
.cert-item{display:flex;align-items:center;gap:14px;padding:16px 18px;cursor:pointer;transition:transform .12s,box-shadow .12s,border-color .12s}
.cert-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--gold)}
.cert-item .cert-item-ic{width:46px;height:46px;border-radius:12px;background:#fef3d7;color:#9a7b12;display:grid;place-items:center;font-size:23px;flex:none}
.cert-item .cert-item-body{flex:1;min-width:0}
.cert-item .cert-item-body h4{font-size:15px;font-weight:750;margin-bottom:5px}
.cert-item .cert-item-meta{display:flex;flex-wrap:wrap;gap:6px 18px;font-size:12.7px;color:var(--muted)}
.cert-item .cert-item-meta b{color:var(--ink)}
.cert-item .cert-item-view{flex:none;white-space:nowrap}

/* Khối chứng chỉ ở màn Kết quả làm bài */
.cert-award{display:flex;gap:16px;align-items:flex-start;padding:20px 22px;margin-bottom:18px;
  border:1px solid #e7d9a6;background:radial-gradient(700px 220px at 0% -40%,rgba(201,162,39,.12),transparent 60%),#fffdf6}
.cert-award .cert-award-ic{width:52px;height:52px;border-radius:14px;background:#fef3d7;color:#9a7b12;display:grid;place-items:center;font-size:27px;flex:none}
.cert-award .cert-award-body{flex:1;min-width:0}
.cert-award .cert-award-body h3{font-size:16px;font-weight:800;color:var(--red);margin-bottom:4px}
.cert-award .cert-award-lead{font-size:13px;color:#4b5563;margin-bottom:12px}
.cert-award .cert-award-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px 18px;margin-bottom:14px}
.cert-award .cert-award-grid .cl{display:block;font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px}
.cert-award .cert-award-grid b{font-size:14px;color:var(--ink);word-break:break-word}

/* Spinner nút đăng nhập (loading) */
.btn-spinner{display:inline-block;width:15px;height:15px;margin-right:9px;vertical-align:-2px;
  border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;animation:btn-spin .6s linear infinite}
.btn-primary.is-loading{opacity:.85;cursor:progress}
@keyframes btn-spin{to{transform:rotate(360deg)}}

/* =============================================================
   BÁO CÁO & THỐNG KÊ
   ============================================================= */
.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
.report-box{padding:20px}
.report-box.wide{grid-column:1/-1}
.rb-title{font-size:15px;font-weight:750;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.bars{display:flex;flex-direction:column;gap:13px}
.bar-row{display:grid;grid-template-columns:1fr 2fr auto;gap:12px;align-items:center}
.bar-row .bl{font-size:13.3px;font-weight:600;color:#374151;display:flex;align-items:center;gap:6px}
.bar-row .bl .badge{font-size:10px;padding:2px 7px}
.bar-row .track{height:11px;background:#eef0f3;border-radius:20px;overflow:hidden}
.bar-row .fill{height:100%;border-radius:20px;transition:width .6s ease}
.bar-row .bv{font-size:12.7px;font-weight:700;color:var(--muted);white-space:nowrap;text-align:right;min-width:48px}

.donut-wrap{display:flex;align-items:center;gap:20px;justify-content:center;padding:6px 0}
.donut-legend{display:flex;flex-direction:column;gap:14px}
.donut-legend div b{font-size:22px;font-weight:800;display:block;line-height:1}
.donut-legend div span{font-size:12.5px;color:var(--muted)}

.qlist{display:flex;flex-direction:column;gap:4px}
.qrow{display:flex;align-items:center;gap:12px;padding:9px 4px;border-bottom:1px solid #f1f2f4;font-size:13.5px}
.qrow:last-child{border-bottom:none}
.qrow .qrank{width:22px;height:22px;border-radius:6px;background:#fdeaec;color:var(--red);font-weight:800;font-size:11.5px;display:grid;place-items:center;flex:none}
.qrow .qtext{flex:1;color:#374151}
.qrow .qn{font-weight:700;color:var(--muted);font-size:12.5px}

.act-list{display:flex;flex-direction:column;gap:4px}
.act-row{display:flex;align-items:center;gap:12px;padding:9px 4px;border-bottom:1px solid #f1f2f4}
.act-row:last-child{border-bottom:none}
.act-row .act-info{font-size:13.3px;line-height:1.4}
.act-row .act-info b{font-weight:700}
.act-row .act-info span{font-size:12px;color:var(--muted)}

/* ---------- Service ④ Báo cáo: bổ sung nhỏ (tái dùng .tbl/.bars/.badge) ---------- */
.report-box .muted, .muted{color:var(--muted);font-size:13px}
.report-box .table-wrap{margin-top:14px}
.rep-tools{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.rep-select{padding:8px 12px;border:1px solid var(--line,#e3e5ea);border-radius:10px;background:#fff;font-size:13.5px;font-weight:600;color:#1f2430;max-width:100%;cursor:pointer}
.badge.ok{background:#e7f4ef;color:#1F6F54}
.badge.no{background:#f4e6e7;color:#9b1c2e}

@media (max-width:860px){
  .report-grid{grid-template-columns:1fr}
  .train-cta{flex-wrap:wrap}
  .bar-row{grid-template-columns:1fr 1.4fr auto}
}

/* ---------- Thông báo nổi (toast cho lỗi 403 / fallback API) ---------- */
.app-toast{
  position:fixed; left:50%; bottom:28px; transform:translateX(-50%) translateY(16px);
  background:#1f2430; color:#fff; padding:12px 18px; border-radius:10px;
  font-size:13.5px; font-weight:600; box-shadow:0 8px 26px rgba(0,0,0,.28);
  opacity:0; pointer-events:none; transition:opacity .25s, transform .25s; z-index:9999;
  max-width:90vw;
}
.app-toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }
.app-toast.warn{ background:#9b1c2e; }

/* =============================================================
   QUẢN LÝ NGƯỜI DÙNG — IAM (toolbar, bảng CRUD, modal form, toast)
   Bám biến/màu sẵn có (--red/--ink/--line/--shadow-lg). Badge role-*
   và .modal/.field/.btn-* tái dùng định nghĩa phía trên.
   ============================================================= */
.iam-toolbar { margin-bottom:14px; }
.iam-select {
  padding:11px 14px; border:1.5px solid var(--line); border-radius:10px;
  background:#fcfcfd; font-size:14px; color:var(--ink); min-width:170px;
  font-family:var(--font); transition:border-color .15s, box-shadow .15s;
}
.iam-select:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3.5px rgba(139,10,26,.12); background:#fff; }
.iam-select.w { width:100%; min-width:0; }
.btn-primary.iam { width:auto; padding:11px 18px; font-size:14px; border-radius:10px; white-space:nowrap; }

.iam-tbl td { vertical-align:middle; }
.iam-tbl tr.iam-off td { background:#fbf7f7; }
.iam-tbl tr.iam-off .u-cell .nm b { color:var(--muted); }
.iam-loading, .iam-empty { text-align:center; color:var(--muted); padding:26px 16px !important; }
.badge.soft.iam-ok { background:#e7f4ef; color:#1F6F54; }
.badge.soft.iam-locked { background:#f4e6e7; color:#9b1c2e; }

.iam-actions { display:flex; gap:6px; flex-wrap:wrap; justify-content:flex-end; }
.iam-act {
  border:1.5px solid var(--line); background:#fff; color:var(--ink);
  font-size:12.5px; font-weight:650; padding:6px 11px; border-radius:8px;
  cursor:pointer; white-space:nowrap; transition:border-color .15s, color .15s, background .15s;
}
.iam-act:hover { border-color:var(--red); color:var(--red); }
.iam-act.warn:hover { border-color:#c0392b; color:#c0392b; background:#fdf1ef; }
.iam-act.ok { border-color:#bfe2d2; color:#1F6F54; }
.iam-act.ok:hover { background:#e9f6f0; }
.iam-act-none { color:var(--line); }

/* Modal form (tái dùng .modal / .field) */
.iam-modal { max-width:560px; }
.iam-form .field { margin-bottom:14px; }
.iam-form .field input, .iam-form .field select { width:100%; }
.iam-grid2 { display:grid; grid-template-columns:1fr 1fr; gap:0 14px; }
.iam-hint { font-size:13.5px; color:#4b5563; margin-bottom:14px; }
.iam-form-actions { display:flex; gap:10px; justify-content:flex-end; margin-top:8px; }
.iam-form-actions .btn-light, .iam-form-actions .btn-primary { width:auto; }
.iam-form .login-error { display:block; }

/* Toast */
#iam-toast {
  position:fixed; left:50%; bottom:26px; transform:translateX(-50%) translateY(14px);
  background:var(--ink); color:#fff; font-size:14px; font-weight:600;
  padding:12px 20px; border-radius:11px; box-shadow:var(--shadow-lg);
  opacity:0; pointer-events:none; transition:opacity .22s, transform .22s; z-index:80; max-width:90vw;
}
#iam-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
#iam-toast.ok { background:#15694c; }
#iam-toast.err { background:#9b1c2e; }

@media (max-width:560px) {
  .iam-grid2 { grid-template-columns:1fr; }
  .iam-select { min-width:0; flex:1; }
  .iam-actions { justify-content:flex-start; }
}

/* =============================================================
   ĐƠN VỊ — Service ② Org (tái dùng .dept-card / .iam-*)
   ============================================================= */
.unit-head { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.unit-head .btn-primary.iam { flex:0 0 auto; }
.dept-card .unit-actions {
  margin-top:14px; padding-top:12px; border-top:1px solid var(--line);
  justify-content:flex-start;
}
.iam-textarea {
  width:100%; padding:11px 14px; border:1.5px solid var(--line); border-radius:10px;
  background:#fcfcfd; font-size:14px; color:var(--ink); font-family:var(--font);
  resize:vertical; min-height:74px; transition:border-color .15s, box-shadow .15s;
}
.iam-textarea:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3.5px rgba(139,10,26,.12); background:#fff; }
.btn-primary.iam.unit-danger { background:#9b1c2e; }
.btn-primary.iam.unit-danger:hover { background:#851626; }

@media (max-width:560px) {
  .unit-head { flex-direction:column; }
  .unit-head .btn-primary.iam { width:100%; }
}

/* =============================================================
   QUẢN TRỊ NỘI DUNG — Service ③.1 (bộ câu hỏi + trình dựng)
   Tái dùng .iam-* / .badge / .modal; bổ sung phần dựng câu hỏi.
   ============================================================= */
.qs-shuffle-field { margin-bottom:14px; }
.qs-check { display:inline-flex; align-items:center; gap:9px; font-size:14px; color:var(--ink); cursor:pointer; }
.qs-check input { width:auto; }
.btn-light.qs-add-q { width:100%; border-style:dashed; font-weight:650; }

.qs-qcard {
  border:1.5px solid var(--line); border-radius:12px; padding:14px 15px;
  margin-bottom:14px; background:#fcfcfd;
}
.qs-qcard-head { display:flex; align-items:center; gap:10px; margin-bottom:10px; flex-wrap:wrap; }
.qs-qnum { font-weight:800; font-size:13.5px; color:var(--red); white-space:nowrap; }
.qs-qmeta { display:flex; align-items:center; gap:8px; margin-left:auto; flex-wrap:wrap; }
.qs-qmeta .iam-select { min-width:120px; padding:8px 11px; font-size:13px; }
.qsq-points { width:64px; padding:9px 10px; border:1.5px solid var(--line); border-radius:9px; font-size:13px; font-family:var(--font); background:#fff; }
.qsq-points:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(139,10,26,.12); }
.qsq-del, .qsq-opt-del {
  border:1.5px solid var(--line); background:#fff; color:var(--muted);
  width:30px; height:30px; border-radius:8px; cursor:pointer; font-size:13px; flex:0 0 auto;
  transition:border-color .15s, color .15s, background .15s;
}
.qsq-del:hover, .qsq-opt-del:hover { border-color:#c0392b; color:#c0392b; background:#fdf1ef; }
.qsq-opts-label { font-size:12.5px; font-weight:700; color:#4b5563; margin:4px 0 8px; }
.qsq-hint { font-weight:500; color:var(--muted); }
.qsq-opt { display:flex; align-items:center; gap:9px; margin-bottom:8px; }
.qsq-correct-wrap { display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border:1.5px solid var(--line); border-radius:9px; background:#fff; cursor:pointer; flex:0 0 auto; }
.qsq-correct-wrap input { width:auto; margin:0; cursor:pointer; }
.qsq-opt-text { flex:1; min-width:0; padding:9px 12px; border:1.5px solid var(--line); border-radius:9px; font-size:13.5px; font-family:var(--font); background:#fff; }
.qsq-opt-text:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(139,10,26,.12); }
.qsq-opt-text[readonly] { background:#f4f5f7; color:var(--muted); }
.qsq-opt-spacer { width:30px; flex:0 0 auto; }
.qsq-add-opt { border:none; background:none; color:var(--red); font-weight:650; font-size:13px; cursor:pointer; padding:2px 0; }
.qsq-add-opt:hover { text-decoration:underline; }

@media (max-width:560px) {
  .qs-qmeta { margin-left:0; }
  .qs-qmeta .iam-select { min-width:0; flex:1; }
}

/* =============================================================
   ③.2 LÀM BÀI & KẾT QUẢ (Attempt / Scoring)
   ============================================================= */
.badge.warn { background:#fdecec; color:#b3261e; }

/* -- Danh sách bộ câu hỏi để làm bài -- */
.qz-set-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; }
.qz-set-card { display:flex; flex-direction:column; gap:8px; padding:18px; }
.qz-set-top { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.qz-set-card .qz-count { font-size:12.5px; font-weight:700; color:var(--red); }
.qz-set-card h4 { margin:2px 0; font-size:15.5px; line-height:1.35; }
.qz-scope { font-size:12.5px; color:var(--muted); }
.qz-best { display:inline-block; font-size:12.5px; font-weight:650; padding:5px 10px; border-radius:8px; margin:2px 0; }
.qz-best.pass { background:#e7f4ef; color:#1F6F54; }
.qz-best.fail { background:#fdecec; color:#b3261e; }
.qz-best.none { background:#eef1f6; color:#64748b; font-weight:500; }
.qz-set-actions { display:flex; gap:8px; margin-top:auto; padding-top:8px; }
.qz-set-actions .btn-primary { flex:1; }

/* -- Màn làm bài -- */
.qz-take-head { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:14px; }
.qz-take-head h1 { font-size:20px; margin:0 0 4px; }
.qz-take-head p { font-size:13px; color:var(--muted); margin:0; }
.qz-timer { flex:0 0 auto; background:#fff; border:1.5px solid var(--line); border-radius:10px; padding:8px 14px; font-size:15px; box-shadow:var(--shadow-sm); }
.qz-timer b { font-variant-numeric:tabular-nums; }
.qz-timer.warn { border-color:#b3261e; color:#b3261e; background:#fdecec; }
.qz-take-body { display:flex; flex-direction:column; gap:14px; }
.qz-q { padding:16px 18px; }
.qz-qt { font-size:14.5px; font-weight:650; line-height:1.5; margin-bottom:12px; }
.qz-qnum { display:inline-block; background:var(--red); color:#fff; font-size:12px; font-weight:700; padding:2px 9px; border-radius:20px; margin-right:6px; }
.qz-qpts { display:inline-block; background:#eef1f6; color:#475569; font-size:11.5px; font-weight:700; padding:2px 8px; border-radius:20px; margin-left:6px; }
.qz-qhint { display:block; font-size:12px; font-weight:500; color:var(--muted); margin-top:4px; }
.qz-opts { display:flex; flex-direction:column; gap:9px; }
.qz-opt { display:flex; align-items:center; gap:11px; padding:11px 14px; border:1.5px solid var(--line); border-radius:10px; cursor:pointer; transition:border-color .12s, background .12s; }
.qz-opt:hover { border-color:var(--gold); background:#fffdf6; }
.qz-opt input { width:18px; height:18px; margin:0; flex:0 0 auto; cursor:pointer; accent-color:var(--red); }
.qz-opt .qz-ob { display:none; }
.qz-ot { flex:1; font-size:13.8px; }
.qz-opt:has(input:checked) { border-color:var(--red); background:#fdf5f6; }
.qz-submit-bar { display:flex; justify-content:flex-end; gap:10px; margin-top:20px; }
.qz-submit-bar .btn-primary { min-width:150px; }

/* -- Màn kết quả -- */
.qz-result-head { display:flex; align-items:center; gap:22px; padding:22px 26px; margin-bottom:8px; border-left:6px solid var(--line); }
.qz-result-head.pass { border-left-color:#1F6F54; background:linear-gradient(120deg,#f0faf5,#fff); }
.qz-result-head.fail { border-left-color:#b3261e; background:linear-gradient(120deg,#fdf1f1,#fff); }
.qz-score-big { font-size:40px; font-weight:800; line-height:1; color:var(--ink); }
.qz-score-big span { font-size:20px; font-weight:600; color:var(--muted); }
.qz-score-mid { flex:1; }
.qz-ratio { font-size:26px; font-weight:800; }
.qz-score-sub { font-size:13px; color:var(--muted); }
.qz-verdict { font-size:22px; font-weight:800; letter-spacing:1px; padding:10px 22px; border-radius:12px; }
.qz-verdict.pass { background:#1F6F54; color:#fff; }
.qz-verdict.fail { background:#b3261e; color:#fff; }
.qz-review-list { display:flex; flex-direction:column; gap:12px; }
.qz-review { padding:15px 18px; border-left:5px solid var(--line); }
.qz-review.ok { border-left-color:#1F6F54; }
.qz-review.bad { border-left-color:#b3261e; }
.qz-rv-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.qz-rv-badge { font-size:12.5px; font-weight:700; padding:3px 10px; border-radius:20px; }
.qz-rv-badge.ok { background:#e7f4ef; color:#1F6F54; }
.qz-rv-badge.bad { background:#fdecec; color:#b3261e; }
.qz-rv-stem { font-size:14px; font-weight:650; line-height:1.5; margin-bottom:10px; }
.qz-rv-line { font-size:13.3px; margin-bottom:6px; line-height:1.7; }
.qz-rv-lbl { color:var(--muted); font-weight:600; margin-right:4px; }
.qz-chip { display:inline-block; font-size:12.5px; padding:3px 9px; border-radius:7px; margin:2px 3px 2px 0; }
.qz-chip.ok { background:#e7f4ef; color:#1F6F54; }
.qz-chip.bad { background:#fdecec; color:#b3261e; text-decoration:line-through; }
.qz-chip.none { background:#eef1f6; color:#64748b; }
.qz-rv-exp { font-size:13px; color:#4b5563; background:#f7f8fa; border-radius:9px; padding:9px 12px; margin-top:8px; line-height:1.6; }
.qz-hist-tbl td { font-size:13px; }

@media (max-width:560px) {
  .qz-take-head { flex-direction:column; }
  .qz-result-head { flex-wrap:wrap; gap:14px; }
  .qz-score-big { font-size:32px; }
}

/* =============================================================
   HỌC TẬP / LỘ TRÌNH (route learn / learnpath / learnlesson)
   ============================================================= */
.learn-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; }
.learn-card { display:flex; flex-direction:column; gap:10px; padding:18px; }
.learn-card-top { display:flex; align-items:center; justify-content:space-between; }
.learn-ic { width:46px; height:46px; border-radius:12px; display:grid; place-items:center; font-size:22px; color:#fff; }
.learn-card h4 { font-size:15.5px; line-height:1.35; margin:2px 0; }
.learn-card-meta { font-size:12.5px; color:var(--muted); }
.learn-card-prog { margin-top:2px; }
.learn-prog-cap { font-size:12px; color:var(--muted); margin-bottom:5px; font-weight:600; }
.learn-card-actions { display:flex; gap:8px; margin-top:auto; padding-top:8px; }
.learn-card-actions .btn-primary { flex:1; }

.learn-prog { display:flex; align-items:center; gap:10px; }
.learn-prog-track { flex:1; height:11px; background:#eef0f3; border-radius:20px; overflow:hidden; }
.learn-prog-fill { height:100%; border-radius:20px; background:linear-gradient(90deg,var(--green),#2f9e78); transition:width .6s ease; }
.learn-prog-val { font-size:12.7px; font-weight:700; color:var(--muted); min-width:40px; text-align:right; }

.learn-path-prog { padding:16px 18px; margin-bottom:8px; }
.learn-path-prog .lpp-head { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px; flex-wrap:wrap; }

.learn-lesson-list { display:flex; flex-direction:column; gap:10px; }
.learn-lesson-row { display:flex; align-items:center; gap:14px; width:100%; text-align:left; background:var(--card); border:1px solid var(--line); border-radius:12px; padding:14px 16px; transition:all .14s; box-shadow:var(--shadow-sm); }
.learn-lesson-row:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--red); }
.learn-lesson-row .lr-ix { width:30px; height:30px; flex:none; border-radius:50%; display:grid; place-items:center; font-weight:700; font-size:13.5px; background:#eef1f6; color:#64748b; }
.learn-lesson-row.done .lr-ix { background:#e7f4ef; color:var(--green); }
.learn-lesson-row .lr-title { flex:1; font-weight:650; font-size:14.2px; min-width:0; }
.learn-lesson-row .lr-status { flex:none; font-size:12.5px; color:var(--red); font-weight:650; white-space:nowrap; }
.learn-lesson-row.done .lr-status { color:var(--green); }

.learn-reader { padding:26px 30px; max-width:820px; }
.learn-reader-head { display:flex; align-items:center; gap:12px; justify-content:space-between; margin-bottom:16px; padding-bottom:14px; border-bottom:2px solid var(--line); }
.learn-reader-head h1 { font-size:22px; line-height:1.3; }
.learn-done-tag { flex:none; font-size:12.5px; font-weight:700; padding:4px 11px; border-radius:20px; background:#e7f4ef; color:var(--green); }
.learn-reader-actions { display:flex; gap:10px; justify-content:space-between; margin-top:24px; padding-top:18px; border-top:1px solid var(--line); }
.learn-done-btn { color:var(--green) !important; }

/* Markdown render an toàn (.md-body) */
.md-body { font-size:14.6px; line-height:1.75; color:#2b3240; }
.md-body h1, .md-body h2, .md-body h3, .md-body h4 { line-height:1.35; margin:18px 0 8px; color:var(--ink); }
.md-body h1 { font-size:20px; } .md-body h2 { font-size:17.5px; color:var(--red); }
.md-body h3 { font-size:15.5px; } .md-body h4 { font-size:14.5px; }
.md-body h1:first-child, .md-body h2:first-child { margin-top:0; }
.md-body p { margin:10px 0; }
.md-body ul, .md-body ol { margin:10px 0 10px 22px; } .md-body li { margin:5px 0; }
.md-body code { background:#f2f3f6; border:1px solid var(--line); border-radius:6px; padding:1px 6px; font-size:13px; font-family:"SFMono-Regular",Consolas,monospace; }
.md-body a { color:var(--red); font-weight:600; text-decoration:underline; }
.md-body strong { font-weight:750; } .md-body em { font-style:italic; }

/* =============================================================
   LÀM BÀI — banner lọc theo lộ trình
   ============================================================= */
.qz-filter-banner { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; background:#fff8ee; border:1px solid var(--gold-light); border-radius:12px; padding:12px 16px; margin-bottom:16px; font-size:13.5px; }
.qz-filter-banner b { color:var(--red); }

/* =============================================================
   TRỢ LÝ ẢO — placeholder chờ đối tác
   ============================================================= */
.chatbot-placeholder { display:flex; justify-content:center; padding:24px 0; }
.cbp-card { max-width:560px; width:100%; text-align:center; padding:40px 32px; }
.cbp-ic { width:72px; height:72px; margin:0 auto 16px; border-radius:20px; display:grid; place-items:center; font-size:34px; background:linear-gradient(135deg,var(--red),var(--red-dark)); color:#fff; box-shadow:var(--shadow-md); }
.cbp-card h2 { font-size:20px; margin-bottom:8px; }
.cbp-lead { color:var(--muted); font-size:14.5px; line-height:1.6; margin-bottom:22px; }
.cbp-slot { min-height:180px; border:2px dashed var(--line); border-radius:14px; background:#fafbfc; display:grid; place-items:center; }
.cbp-slot:empty::before { content:"Khu vực nhúng trợ lý ảo (đối tác tích hợp)"; color:#9aa3af; font-size:13px; }

@media (max-width:560px) {
  .learn-grid { grid-template-columns:1fr; }
  .learn-reader { padding:20px 18px; }
  .learn-reader-head h1 { font-size:19px; }
}
