﻿@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --bg:#eef6f0;
  --surface:#fff;
  --surface2:#f6faf7;
  --ink:#0d2137;
  --muted:#587366;
  --line:#cbdccf;
  --green:#17762b;
  --green2:#24963a;
  --gold:#d4a017;
  --red:#d33c47;
  --purple:#3b1c5a;
  --shadow:0 15px 35px rgba(13,33,55,.13);
  --radius:14px
}

[data-theme="dark"] {
  --bg:#08141f;
  --surface:#102234;
  --surface2:#152b3f;
  --ink:#eef7f1;
  --muted:#a9b8c8;
  --line:#294156;
  --green:#2dc35c;
  --green2:#37d46a;
  --gold:#f3bb28;
  --red:#ff6976;
  --purple:#d8c6ff;
  --shadow:0 15px 35px rgba(0,0,0,.35)
}
* {
  box-sizing:border-box
}
body {
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:Poppins,Arial,sans-serif;
  font-size:11px
}
a {
  color:inherit;
  text-decoration:none
}
.muted {
  color:var(--muted)
}
.no-print {
}
button,input,select,textarea {
  font-family:inherit
}
label {
  display:block;
  font-size:9px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:800;
  color:#315a3d;
  margin:10px 0 7px
}
input,select,textarea {
  width:100%;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--surface2);
  color:var(--ink);
  font-size:11px;
  outline:none
}
input:focus,select:focus,textarea:focus {
  border-color:var(--green);
  box-shadow:0 0 0 4px rgba(23,118,43,.10);
  background:#fff
}
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  color:#254833;
  padding:12px 18px;
  font-weight:800;
  cursor:pointer;
  min-height:44px
}
.btn:hover {
  transform:translateY(-1px);
  box-shadow:0 10px 20px rgba(13,33,55,.10)
}
.btn-primary {
  background:linear-gradient(135deg,#147326,#208d34);
  color:#fff;
  border-color:#147326;
  box-shadow:0 10px 22px rgba(23,118,43,.22)
}
.btn-gold {
  background:#fff8e5;
  color:#946700;
  border-color:#ead58e
}
.btn-danger {
  background:#fff0f1;
  color:#b21e2a;
  border-color:#f1b2b8
}
.btn-purple {
  background:#f5f0ff;
  color:#3b1c5a;
  border-color:#dcccf8
}
.badge {
  display:inline-flex;
  align-items:center;
  gap:6px;
  border-radius:999px;
  padding:5px 10px;
  font-weight:800;
  font-size:11px
}
.badge.pass {
  background:#eaf8ed;
  color:#147326
}
.badge.fail {
  background:#fff0f1;
  color:#b21e2a
}
.badge.mid {
  background:#fff8e5;
  color:#946700
}
.alert {
  padding:13px 16px;
  border-radius:10px;
  margin:12px 0;
  border-left:5px solid var(--green);
  background:#edf8ef;
  color:#174e25;
  font-weight:600
}
.alert.error {
  border-color:var(--red);
  background:#fff0f1;
  color:#a3202a
}
.alert.info {
  border-color:#3b82f6;
  background:#eef6ff;
  color:#164278
}
.login {
  min-height:100vh;
  display:grid;
  grid-template-columns:1.6fr 520px;
  background:#fff
}
.login-art {
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:68px;
  background:linear-gradient(150deg,rgba(10,35,54,.86),rgba(19,104,42,.72)),radial-gradient(circle at 70% 35%,rgba(255,255,255,.18),transparent 25%),linear-gradient(120deg,#0d2137,#14652a);
  color:#fff
}
.login-art:before {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(115deg,transparent 0 45%,rgba(255,255,255,.08) 45% 46%,transparent 46% 50%,rgba(255,255,255,.08) 50% 51%,transparent 51%);
  opacity:.5
}
.login-art>* {
  position:relative
}
.login-badge {
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:max-content;
  padding:8px 17px;
  border-radius:999px;
  background:rgba(212,160,23,.18);
  border:1px solid rgba(212,160,23,.55);
  color:#f4cf45;
  font-weight:800;
  font-size:11px
}
.login-art h1 {
  font-size:48px;
  line-height:1.12;
  margin:34px 0 20px;
  font-weight:900
}
.login-art h1 span {
  color:#f4cf45
}
.login-art p {
  max-width:560px;
  line-height:1.85;
  color:rgba(255,255,255,.78)
}
.login-footer {
  border-top:1px solid rgba(255,255,255,.16);
  padding-top:22px;
  margin-top:46px;
  color:rgba(255,255,255,.48)
}
.login-panel {
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  padding:52px
}
.login-panel:before {
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:5px;
  background:linear-gradient(#d4a017,#17762b,#0d2137)
}
.card-login {
  width:100%;
  max-width:420px
}
.kw-logo {
  display:flex;
  align-items:center;
  gap:18px;
  margin-bottom:38px
}
.login-logo {
  width:102px;
  height:auto;
  object-fit:contain;
  border-radius:16px;
  background:#fff;
  padding:8px;
  box-shadow:0 8px 20px rgba(13,33,55,.08);
}
.kw-word {
  font-size:39px;
  letter-spacing:-3px;
  font-weight:900;
  color:#087039
}
.kw-org {
  font-size:11px;
  text-transform:uppercase;
  color:#667b91;
  font-weight:800;
  line-height:1.4
}
.card-login h2 {
  font-size:29px;
  color:#071a33;
  margin:0 0 6px
}
.role-tabs {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:28px 0
}
.role-tabs label {
  margin:0;
  text-transform:none;
  letter-spacing:0
}
.role-tabs input {
  display:none
}
.role-tabs span {
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  border:1px solid #d9e2e9;
  border-radius:9px;
  padding:12px;
  background:#f8fafc;
  color:#664c82;
  font-weight:800
}
.role-tabs input:checked+span {
  background:#f0fbf2;
  border-color:#17762b;
  color:#126022
}
.pin-input {
  font-size:29px!important;
  letter-spacing:.28em!important;
  font-weight:600!important
}
.topbar {
  height:70px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 28px;
  background:#0c1d2f;
  color:#d9e7df;
  position:sticky;
  top:0;
  z-index:99;
  box-shadow:0 8px 20px rgba(0,0,0,.25);
  border-bottom:3px solid rgba(212,160,23,.6)
}
.topbrand {
  display:flex;
  align-items:center;
  gap:16px
}
.topbrand-logo {
  width:74px;
  height:auto;
  object-fit:contain;
  border-radius:12px;
  background:#fff;
  padding:6px;
}
.topbrand .kw-word {
  font-size:35px;
  color:#1aa34a
}
.topbrand .title {
  border-left:1px solid rgba(255,255,255,.14);
  padding-left:16px
}
.topbrand b {
  color:#f3bb28;
  letter-spacing:.28em
}
.nav {
  display:flex;
  align-items:center;
  gap:8px
}
.menu-toggle {
  display:none
}
.theme-toggle {
  cursor:pointer
}
.nav a,.nav button {
  padding:12px 18px;
  border-radius:10px;
  color:#88ba95;
  background:transparent;
  border:0;
  font-weight:700
}
.nav a:hover,.nav a.active {
  background:rgba(23,118,43,.18);
  color:#2fc756
}
.nav .logout {
  border:1px solid rgba(255,255,255,.35);
  color:#d7e5db
}
.shell {
  max-width:1180px;
  margin:0 auto;
  padding:28px 22px
}
.card,.kpi {
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow)
}
.card {
  padding:28px;
  margin-bottom:26px
}
.card h2,.card h3 {
  margin:0 0 14px;
  color:#132b20
}
.card-title {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  border-bottom:1px solid #e7eee8;
  padding-bottom:16px;
  margin-bottom:20px
}
.section-note {
  background:#edf6ee;
  border:1px solid #d5ead8;
  border-radius:10px;
  padding:14px 16px;
  color:#315a3d
}
.grid {
  display:grid;
  gap:18px
}
.grid-2 {
  grid-template-columns:repeat(2,minmax(0,1fr))
}
.grid-3 {
  grid-template-columns:repeat(3,minmax(0,1fr))
}
.grid-4 {
  grid-template-columns:repeat(4,minmax(0,1fr))
}
.grid-5 {
  grid-template-columns:repeat(5,minmax(0,1fr))
}
.kpi {
  padding:24px 28px;
  border-left:4px solid var(--green);
  min-height:126px
}
.kpi small {
  text-transform:uppercase;
  letter-spacing:.1em;
  color:#4d7658;
  font-weight:800
}
.kpi .num {
  font-size:33px;
  font-weight:900;
  margin-top:14px;
  color:#10281b
}
.kpi .sub {
  color:#6d8673
}
table {
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:var(--surface);
  border:1px solid #d9e4dc;
  border-radius:10px;
  overflow:hidden
}
th,td {
  padding:14px 16px;
  border-bottom:1px solid #dfe9e1;
  text-align:left;
  vertical-align:middle
}
th {
  background:var(--surface2);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:11px;
  color:#143020
}
tr:last-child td {
  border-bottom:0
}

.page-head {
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin:8px 0 24px
}
.page-head h1 {
  margin:6px 0;
  font-size:33px;
  line-height:1;
  color:var(--ink)
}
.page-head h1.page-title {
  display:inline-flex;
  align-items:center;
  gap:14px;
  position:relative;
}
.page-head h1.page-title::after {
  content:"";
  position:absolute;
  left:0;
  bottom:-8px;
  width:70px;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg,#147326,#f3bb28);
}
.page-head h1.page-title .title-icon {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:rgba(23,118,43,.12);
  color:#147326;
  font-size:1.1rem;
}
.page-subtitle {
  margin:8px 0 0;
  color:var(--muted);
  font-size:14px;
  line-height:1.5;
}
.eyebrow {
  display:inline-flex;
  border:1px solid rgba(212,160,23,.45);
  background:rgba(212,160,23,.12);
  color:var(--gold);
  border-radius:999px;
  padding:6px 12px;
  font-weight:900;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em
}
.menu-grid {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px
}
.menu-card {
  display:flex;
  flex-direction:column;
  gap:10px;
  min-height:150px;
  padding:22px;
  border:1px solid var(--line);
  border-radius:14px;
  background:linear-gradient(180deg,var(--surface2),var(--surface));
  box-shadow:0 8px 18px rgba(13,33,55,.07)
}
.menu-card b {
  font-size:17px;
  color:var(--ink)
}
.menu-card span {
  color:var(--muted);
  line-height:1.6
}
.menu-card:hover {
  transform:translateY(-2px);
  border-color:var(--green);
  box-shadow:0 14px 28px rgba(13,33,55,.13)
}
.score-row {
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:18px;
  align-items:center;
  padding:18px;
  border:1px solid #e0eae2;
  border-radius:12px;
  margin:12px 0;
  background:#fbfdfb
}
.score-options {
  display:flex;
  gap:8px;
  justify-content:flex-end
}
.score-options label {
  margin:0
}
.score-options input {
  display:none
}
.score-options span {
  display:flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  font-weight:900
}
.score-options input:checked+span {
  background:var(--green);
  color:#fff;
  border-color:var(--green)
}
.totalbar {
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:#eff8f1;
  border:1px solid #d3ead7;
  border-radius:10px;
  padding:14px
}
.progress {
  height:8px;
  background:#e6eee8;
  border-radius:20px;
  overflow:hidden
}
.progress i {
  display:block;
  height:100%;
  background:linear-gradient(90deg,var(--green),var(--gold));
  border-radius:20px
}
.toolbar {
  display:flex;
  align-items:center;
  gap:12px;
  justify-content:space-between;
  flex-wrap:wrap
}
.page-toolbar {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  width:100%;
}
.page-toolbar .actions {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
}
.page-toolbar .actions > * {
  width:auto;
  min-width:170px;
}
.page-toolbar .actions input.searchbar {
  max-width:240px;
}
.searchbar {
  max-width:280px
}
.actions {
  display:flex;
  gap:8px;
  flex-wrap:wrap
}
.print-only {
  display:none
}
@media(max-width:900px) {
  .login {
    grid-template-columns:1fr
  }
  .login-art {
    display:none
  }
  .login-panel {
    min-height:100vh
  }
  .topbar {
    height:auto;
    align-items:flex-start;
    gap:15px;
    flex-direction:column;
    padding:18px
  }
  .menu-toggle {
    display:inline-flex;
    position:absolute;
    right:18px;
    top:18px;
    padding:10px 14px;
    border-radius:9px;
    border:1px solid rgba(255,255,255,.2);
    background:rgba(255,255,255,.08);
    color:#fff;
    font-weight:800
  }
  .nav {
    display:none;
    flex-wrap:wrap;
    width:100%
  }
  .nav.open {
    display:flex
  }
  .menu-grid {
    grid-template-columns:1fr
  }
  .page-head {
    align-items:flex-start;
    flex-direction:column
  }
  .grid-2,.grid-3,.grid-4,.grid-5 {
    grid-template-columns:1fr
  }
  .score-row {
    grid-template-columns:1fr
  }
  .score-options {
    justify-content:flex-start
  }
  .shell {
    padding:20px 14px;
    max-width:100%
  }
}
@media print {
  .no-print,.topbar,.btn,.toolbar {
    display:none!important
  }
  body {
    background:#fff;
    color:#000
  }
  .shell {
    max-width:none;
    padding:0
  }
  .card,.kpi {
    box-shadow:none;
    border:1px solid #999;
    break-inside:avoid
  }
  .print-only {
    display:block
  }
  .card {
    padding:16px;
    margin:0 0 14px
  }
  table {
    font-size:10px
  }
  th,td {
    padding:7px
  }
  .login {
    display:none
  }
}

[data-theme="dark"] input,[data-theme="dark"] select,[data-theme="dark"] textarea {
  background:var(--surface2);
  border-color:var(--line);
  color:var(--ink)
}
[data-theme="dark"] .card h2,[data-theme="dark"] .card h3,[data-theme="dark"] .kpi .num {
  color:var(--ink)
}
[data-theme="dark"] .section-note,[data-theme="dark"] .totalbar {
  background:var(--surface2);
  border-color:var(--line);
  color:var(--ink)
}
[data-theme="dark"] .btn {
  background:var(--surface2);
  color:var(--ink);
  border-color:var(--line)
}
[data-theme="dark"] .btn-primary {
  background:linear-gradient(135deg,#147326,#208d34);
  color:#fff
}
[data-theme="dark"] .score-row,[data-theme="dark"] .score-options span {
  background:var(--surface2);
  border-color:var(--line)
}
[data-theme="dark"] td,[data-theme="dark"] th {
  border-color:var(--line)
}

/* ================= UI POLISH v4: compact login, safer dark mode, better spacing ================= */
:root {

  --card-gap:30px;
}

body {
  font-size:12.5px;
  line-height:1.55;
}

.shell {
  max-width:1080px;
  padding:24px 18px 42px;
}

.card {
  padding:24px;
  margin-bottom:var(--card-gap);
}

.card + .card,.grid + .card,.card + .grid {
  margin-top:8px;
}

.card-title {
  padding-bottom:14px;
  margin-bottom:18px;
  border-bottom-color:var(--line);
}

.card h2,.card h3 {
  color:var(--ink);
  line-height:1.25;
}

label {
  color:var(--muted);
  font-size:10px;
  margin:8px 0 6px;
}

input,select,textarea {
  padding:12px 14px;
  font-size:12px;
}

.btn {
  padding:10px 15px;
  min-height:40px;
  font-size:12px;
}

.page-head {
  margin:6px 0 22px;
}

.page-head h1 {
  font-size:29px;
}

.kpi {
  padding:20px 22px;
  min-height:112px;
  margin-bottom:14px;
}

.kpi small {
  color:var(--muted);
}

.kpi .num {
  font-size:29px;
  color:var(--ink);
}

.kpi .sub {
  color:var(--muted);
}

.grid {
  gap:18px;
  margin-bottom:22px;
}

.menu-grid {
  gap:18px;
  margin-bottom:28px;
}

.menu-card {
  margin-bottom:4px;
}

th {
  color:var(--ink);
}
 td {
  color:var(--ink);
}
 table {
  margin-bottom:24px;
  border-color:var(--line);
}
 th,td {
  border-bottom-color:var(--line);
}

/* Compact login page */
.login {
  grid-template-columns:1.45fr 460px;
}

.login-art {
  padding:54px 58px;
}

.login-badge {
  padding:7px 14px;
  font-size:10px;
}

.login-art h1 {
  font-size:41px;
  margin:28px 0 16px;
}

.login-art p {
  font-size:12px;
  line-height:1.75;
  max-width:520px;
}

.login-footer {
  font-size:11px;
  margin-top:38px;
  padding-top:18px;
}

.login-panel {
  padding:42px;
}

.card-login {
  max-width:360px;
}

.kw-logo {
  gap:14px;
  margin-bottom:30px;
}

.kw-word {
  font-size:33px;
  letter-spacing:-2px;
}

.kw-org {
  font-size:9.5px;
}

.card-login h2 {
  font-size:24px;
  margin-bottom:4px;
  color:var(--ink);
}

.card-login p {
  font-size:11.5px;
}

.role-tabs {
  gap:8px;
  margin:22px 0;
}

.role-tabs span {
  padding:10px 9px;
  font-size:11.5px;
}

.pin-input {
  font-size:19px!important;
  letter-spacing:.18em!important;
  padding:12px 14px!important;
}

.card-login .btn {
  margin-top:18px!important;
}

.card-login .muted[style] {
  margin-top:24px!important;
  padding-top:18px!important;
}

/* Dark mode readability fixes */
[data-theme="dark"] body {
  background:var(--bg);
  color:var(--ink);
}

[data-theme="dark"] .muted,
[data-theme="dark"] p,
[data-theme="dark"] span,
[data-theme="dark"] small,
[data-theme="dark"] label,
[data-theme="dark"] .kpi small,
[data-theme="dark"] .kpi .sub,
[data-theme="dark"] .menu-card span {
  color:var(--muted)!important;
}

[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] .card h2,
[data-theme="dark"] .card h3,
[data-theme="dark"] .menu-card b,
[data-theme="dark"] .kpi .num,
[data-theme="dark"] .page-head h1,
[data-theme="dark"] th,
[data-theme="dark"] td {
  color:var(--ink)!important;
}

[data-theme="dark"] .card,
[data-theme="dark"] .kpi,
[data-theme="dark"] table {
  background:var(--surface);
  border-color:var(--line);
  box-shadow:0 14px 32px rgba(0,0,0,.28);
}

[data-theme="dark"] .menu-card {
  background:linear-gradient(180deg,var(--surface2),var(--surface));
  border-color:var(--line);
}

[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] textarea:focus {
  background:#102a3f;
  border-color:var(--green);
  box-shadow:0 0 0 4px rgba(45,195,92,.13);
}

[data-theme="dark"] .card-title {
  border-bottom-color:var(--line);
}

[data-theme="dark"] .alert {
  background:#102f23;
  color:#d9ffe3;
  border-left-color:var(--green);
}

[data-theme="dark"] .alert.error {
  background:#3a1720;
  color:#ffdce1;
  border-left-color:var(--red);
}

[data-theme="dark"] .alert.info {
  background:#112a45;
  color:#dbeafe;
  border-left-color:#60a5fa;
}

[data-theme="dark"] .badge.pass {
  background:#123c24;
  color:#8dffad;
}

[data-theme="dark"] .badge.fail {
  background:#421a23;
  color:#ffb9c0;
}

[data-theme="dark"] .badge.mid {
  background:#3c3113;
  color:#ffe08a;
}

[data-theme="dark"] .btn-gold {
  background:#3c3113;
  color:#ffe08a;
  border-color:#6f5716;
}

[data-theme="dark"] .btn-danger {
  background:#421a23;
  color:#ffb9c0;
  border-color:#6d2a35;
}

[data-theme="dark"] .btn-purple {
  background:#2c2142;
  color:#d8c6ff;
  border-color:#4b3c67;
}

[data-theme="dark"] .role-tabs span {
  background:var(--surface2);
  border-color:var(--line);
  color:var(--muted);
}

[data-theme="dark"] .role-tabs input:checked+span {
  background:#143b25;
  border-color:var(--green);
  color:#9dffb6;
}

@media(max-width:900px) {

  .shell {
    padding:18px 12px 34px;
    max-width:100%;
  }

  .card {
    padding:18px;
    margin-bottom:24px;
  }

  .login-panel {
    padding:28px 20px;
  }

  .card-login {
    max-width:340px;
  }

  .kw-word {
    font-size:29px;
  }

  .card-login h2 {
    font-size:22px;
  }
}

/* ================= UI COMPACT v5: wider pages, shorter cards/navbar, smaller typography ================= */
:root {

  --radius:12px;

  --shadow:0 8px 22px rgba(13,33,55,.10);

  --card-gap:24px;
}

body {
  font-size:12px;
  line-height:1.45;
}

.shell {
  max-width:1250px;
  width:88vw;
  padding:20px 18px 38px;
}

.topbar {
  height:60px;
  padding:0 22px;
  border-bottom-width:2px;
}

.topbrand {
  gap:12px;
}

.topbrand .kw-word {
  font-size:27px;
  letter-spacing:-1.5px;
}

.topbrand .title {
  padding-left:12px;
  font-size:10px;
  line-height:1.2;
}

.topbrand b {
  letter-spacing:.18em;
  font-size:9px;
}

.nav {
  gap:5px;
}

.nav a,.nav button {
  padding:8px 12px;
  border-radius:8px;
  font-size:11px;
}

.card,.kpi {
  border-radius:12px;
}

.card {
  padding:16px;
  margin-bottom:24px;
}

.card-title {
  padding-bottom:10px;
  margin-bottom:14px;
  gap:10px;
}

.card h2 {
  font-size:18px;
  margin-bottom:10px;
}

.card h3 {
  font-size:15px;
  margin-bottom:10px;
}

.page-head {
  margin:4px 0 18px;
}

.page-head h1 {
  font-size:25px;
  line-height:1.1;
}

.eyebrow {
  padding:5px 10px;
  font-size:9.5px;
}

.grid {
  gap:14px;
  margin-bottom:18px;
}

.grid-4,.grid-5 {
  gap:14px;
}

.kpi {
  padding:14px 16px;
  min-height:98px;
  margin-bottom:8px;
  border-left-width:3px;
}

.kpi small {
  font-size:9.5px;
  letter-spacing:.08em;
}

.kpi .num {
  font-size:23px;
  margin-top:8px;
}

.kpi .sub {
  font-size:11px;
}

.menu-grid {
  gap:14px;
  margin-bottom:22px;
}

.menu-card {
  min-height:108px;
  padding:15px;
  gap:6px;
  border-radius:12px;
}

.menu-card b {
  font-size:14px;
}

.menu-card span {
  font-size:11px;
  line-height:1.45;
}

.score-row {
  padding:12px;
  gap:12px;
  margin:9px 0;
  border-radius:10px;
}

.score-options span {
  width:36px;
  height:36px;
  border-radius:8px;
  font-size:11px;
}

.totalbar {
  padding:10px 12px;
}

.section-note {
  padding:10px 12px;
  font-size:11.5px;
}

label {
  font-size:9.5px;
  margin:7px 0 5px;
  letter-spacing:.07em;
}

input,select,textarea {
  padding:10px 12px;
  border-radius:8px;
  font-size:11.5px;
}

.btn {
  padding:8px 12px;
  min-height:36px;
  border-radius:8px;
  font-size:11px;
}

th,td {
  padding:10px 12px;
  font-size:11px;
}

th {
  font-size:9.5px;
  letter-spacing:.07em;
}

.toolbar {
  gap:9px;
}

.searchbar {
  max-width:260px;
}

.actions {
  gap:6px;
}

.badge {
  padding:4px 8px;
  font-size:9.5px;
}

.alert {
  padding:10px 12px;
  font-size:11.5px;
  margin:10px 0;
}

/* Smaller, calmer login page */
.login {
  grid-template-columns:minmax(0,1.45fr) 430px;
}

.login-art {
  padding:44px 48px;
}

.login-badge {
  padding:6px 12px;
  font-size:9px;
  gap:7px;
}

.login-art h1 {
  font-size:33px;
  line-height:1.12;
  margin:24px 0 13px;
}

.login-art p {
  font-size:11px;
  line-height:1.65;
  max-width:490px;
}

.login-footer {
  font-size:10px;
  margin-top:30px;
  padding-top:15px;
}

.login-panel {
  padding:34px;
}

.card-login {
  max-width:330px;
}

.kw-logo {
  gap:11px;
  margin-bottom:24px;
}

.kw-word {
  font-size:28px;
  letter-spacing:-1.5px;
}

.kw-org {
  font-size:8.5px;
  line-height:1.28;
}

.card-login h2 {
  font-size:21px;
  margin-bottom:3px;
}

.card-login p {
  font-size:10.5px;
}

.role-tabs {
  gap:7px;
  margin:18px 0;
}

.role-tabs span {
  padding:8px 7px;
  font-size:10.5px;
  border-radius:8px;
}

.pin-input {
  font-size:15px!important;
  letter-spacing:.15em!important;
  padding:10px 12px!important;
}

.card-login .btn {
  margin-top:14px!important;
  min-height:42px!important;
  font-size:12px!important;
}

.card-login .muted[style] {
  margin-top:18px!important;
  padding-top:14px!important;
  font-size:9.5px!important;
}

/* Wider pages without looking stretched */
@media(min-width:1200px) {

  .grid-5 {
    grid-template-columns:repeat(5,minmax(0,1fr));
  }

  .grid-4 {
    grid-template-columns:repeat(4,minmax(0,1fr));
  }

  .card .grid-2 {
    gap:14px 18px;
  }
}

@media(max-width:900px) {

  .shell {
    width:100%;
    padding:16px 12px 32px;
  }

  .topbar {
    height:auto;
    padding:14px;
  }

  .topbrand .kw-word {
    font-size:24px;
  }

  .nav a,.nav button {
    font-size:11px;
    padding:8px 10px;
  }

  .card {
    padding:14px;
    margin-bottom:20px;
  }

  .kpi {
    min-height:86px;
    padding:12px 14px;
  }

  .kpi .num {
    font-size:21px;
  }

  .page-head h1 {
    font-size:22px;
  }

  .login-panel {
    padding:24px 18px;
  }

  .card-login {
    max-width:320px;
  }

  .kw-word {
    font-size:26px;
  }

  .card-login h2 {
    font-size:19px;
  }
}

/* ================= v7: premium official print reports + CONFIDENTIAL watermark ================= */
@page {
  size:A4 landscape;
  margin:10mm
}

.print-body {
  background:#fff!important;
  color:#07172c!important;
  font-family:Arial,Helvetica,sans-serif;
  font-size:10.5px;
  line-height:1.35;
  -webkit-print-color-adjust:exact;
  print-color-adjust:exact
}

.report-sheet {
  width:100%;
  min-height:100vh;
  padding:22px 28px 24px;
  position:relative;
  background:#fff;
  overflow:hidden;
  border-top:5px solid #0b5b20
}

.report-sheet:before {
  content:"CONFIDENTIAL";
  position:fixed;
  left:50%;
  top:52%;
  transform:translate(-50%,-50%) rotate(-33deg);
  font-size:117px;
  font-weight:900;
  letter-spacing:.08em;
  color:rgba(178,31,31,.075);
  white-space:nowrap;
  z-index:0;
  pointer-events:none
}

.report-sheet>* {
  position:relative;
  z-index:1
}
.report-watermark {
  display:none
}

.report-head {
  display:grid;
  grid-template-columns:1fr 1.35fr 1fr;
  align-items:center;
  gap:18px;
  padding-bottom:10px
}

.report-head b {
  font-size:11px;
  color:#002a5b;
  letter-spacing:.02em
}
.report-head span {
  font-size:9.5px;
  color:#667085
}
.report-logo {
  text-align:center;
  color:#006838;
  font-size:55px;
  font-weight:900;
  letter-spacing:-5px;
  line-height:.82;
  text-shadow:0 1px 0 rgba(0,0,0,.06)
}

.report-logo small {
  display:block;
  font-size:8px;
  letter-spacing:.03em;
  color:#006838;
  margin-top:9px;
  font-weight:800
}
.report-right {
  text-align:right
}
.report-right b {
  font-size:15px;
  letter-spacing:.04em
}
.report-right em {
  display:inline-block;
  margin-top:6px;
  border:1.5px solid #e00000;
  color:#e00000;
  font-style:normal;
  letter-spacing:.2em;
  font-size:9px;
  padding:2px 11px;
  border-radius:2px;
  font-weight:800;
  background:#fff
}

.report-rule {
  border:0;
  border-top:3px solid #0b5b20;
  margin:8px 0 18px
}
.report-kpis {
  display:grid;
  grid-template-columns:repeat(8,1fr);
  gap:10px;
  margin-bottom:20px
}
.report-kpis div {
  border:1px solid #b7d6c1;
  background:#f3faf5;
  border-radius:6px;
  text-align:center;
  padding:8px 7px;
  min-height:53px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85)
}

.report-kpis small {
  display:block;
  text-transform:uppercase;
  font-size:8.5px;
  color:#394b61;
  letter-spacing:.055em;
  line-height:1.2
}
.report-kpis b {
  display:block;
  color:#00305d;
  font-size:17px;
  line-height:1.05;
  margin-top:3px
}
.report-kpis .good {
  color:#006838
}
.report-kpis .bad {
  color:#d40000
}
.report-kpis .warn {
  color:#c78a00
}

.report-table {
  width:100%;
  border-collapse:collapse;
  border-radius:0;
  margin:0 0 19px;
  background:#fff;
  border:1px solid #bfcbbf;
  page-break-inside:auto
}
.report-table thead {
  display:table-header-group
}
.report-table tr {
  page-break-inside:avoid;
  page-break-after:auto
}
.report-table th {
  background:#0b5b20!important;
  color:#fff!important;
  text-align:center;
  font-size:9.5px;
  padding:8px 9px;
  border:1px solid #c8d1c8;
  text-transform:none;
  letter-spacing:0;
  font-weight:800
}
.report-table td {
  font-size:9.8px;
  color:#000!important;
  padding:7px 9px;
  border:1px solid #c8d1c8;
  vertical-align:middle
}
.report-table tr:nth-child(even) td {
  background:#f2f8f3!important
}
.report-table.compact {
  max-width:340px
}

.attestation {
  border:1.2px solid #0b5b20;
  border-radius:5px;
  padding:16px 24px;
  margin-top:30px;
  background:rgba(252,255,253,.88);
  break-inside:avoid
}
.attestation h3,.report-section-title {
  color:#00305d;
  letter-spacing:.08em;
  font-size:12px;
  margin:16px 0 9px
}
.attestation h3 {
  color:#006838;
  margin-top:0
}
.attestation p {
  line-height:1.65
}
.sign-row {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:38px;
  margin-top:58px
}
.sign-row span {
  border-top:1px solid #111;
  padding-top:6px;
  color:#1f2937
}
.report-foot {
  display:flex;
  justify-content:space-between;
  gap:20px;
  border-top:1px solid #d9d9d9;
  margin-top:22px;
  padding-top:10px;
  color:#8b949e;
  font-size:8.5px
}

.mini-bar {
  display:inline-block;
  vertical-align:middle;
  width:92px;
  height:7px;
  border-radius:999px;
  background:#ddd;
  margin-left:8px;
  overflow:hidden
}
.mini-bar i {
  display:block;
  height:100%;
  background:#0b5b20
}
.pin-table {
  width:72%;
  margin-top:22px;
  border-collapse:collapse;
  background:#fff
}
.pin-table th {
  background:#eef3fb!important;
  color:#000!important;
  font-size:12px;
  text-align:left;
  padding:11px 16px;
  border:1px solid #c9ced6;
  text-transform:uppercase
}
.pin-table td {
  font-size:17px;
  padding:14px 16px;
  border:1px solid #c9ced6;
  color:#000!important
}
.pin-table .pin-code {
  font-size:25px;
  font-weight:900;
  letter-spacing:.28em;
  color:#1d55a6!important
}
.pin-table td:nth-child(3) {
  font-size:12px;
  color:#374151!important
}
.report-sheet h2 {
  font-size:21px;
  margin:20px 0 8px;
  color:#000
}
.report-sheet p {
  color:#111827
}

@media print {
  html,body {
    width:100%;
    height:auto
  }
  .print-body {
    font-size:9.8px
  }
  .report-sheet {
    padding:18px 24px 34px;
    border-top:4px solid #0b5b20
  }
  .report-sheet:before {
    display:block!important;
    font-size:109px;
    color:rgba(178,31,31,.07)!important
  }
  .report-logo {
    font-size:51px
  }
  .report-kpis {
    grid-template-columns:repeat(8,1fr);
    gap:9px
  }
  .report-kpis div {
    min-height:48px;
    padding:7px
  }
  .report-kpis b {
    font-size:16px
  }
  .report-foot {
    position:fixed;
    left:24px;
    right:24px;
    bottom:13px;
    background:#fff
  }
  .pin-table {
    width:64%
  }
}

@media(max-width:900px) {
  .live-actions {
    flex-wrap:wrap;
    justify-content:flex-start
  }
  .bulk-info {
    align-items:flex-start;
    flex-direction:column
  }
  .report-kpis {
    grid-template-columns:repeat(2,1fr)
  }
  .report-head {
    grid-template-columns:1fr
  }
  .report-logo {
    text-align:left
  }
  .report-right {
    text-align:left
  }
  .pin-table {
    width:100%
  }
  .report-sheet:before {
    font-size:53px
  }
}

/* ================= v8: Panelist scoring page like uploaded workpad + extra polish ================= */
.panelist-workspace {
  max-width:1180px;
  margin:0 auto
}
.panelist-hero {
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:18px;
  margin:4px 0 18px
}
.panelist-hero h1 {
  margin:7px 0 4px;
  font-size:24px;
  line-height:1.1;
  color:var(--ink)
}
.panelist-hero p {
  max-width:670px;
  margin:0;
  font-size:11.5px
}
.panelist-mini-stats {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  min-width:360px
}
.panelist-mini-stats div,.panelist-bottom-stats div {
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:12px;
  padding:11px 14px;
  text-align:center;
  box-shadow:0 8px 18px rgba(13,33,55,.07)
}
.panelist-mini-stats b,.panelist-bottom-stats b {
  display:block;
  font-size:20px;
  color:var(--green);
  line-height:1
}
.panelist-mini-stats span,.panelist-bottom-stats span {
  display:block;
  margin-top:5px;
  color:var(--muted);
  font-size:9px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:800
}
.panelist-progress-card {
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:12px;
  padding:13px 16px;
  margin-bottom:18px;
  box-shadow:var(--shadow)
}
.panelist-progress-top {
  display:flex;
  justify-content:space-between;
  gap:16px;
  margin-bottom:9px;
  color:var(--ink)
}
.panelist-progress-top span {
  color:var(--muted);
  font-size:11px
}
.progress.big {
  height:10px
}
.panelist-layout {
  display:grid;
  grid-template-columns:330px minmax(0,1fr);
  gap:18px;
  align-items:start
}
.panelist-search-panel {
  position:sticky;
  top:78px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:14px;
  padding:15px;
  box-shadow:var(--shadow)
}
.candidate-search-wrap {
  display:flex;
  align-items:center;
  gap:8px;
  background:var(--surface2);
  border:1px solid var(--line);
  border-radius:10px;
  padding:0 10px
}
.candidate-search-wrap input {
  border:0;
  background:transparent;
  box-shadow:none!important;
  padding:10px 0
}
.candidate-list {
  display:flex;
  flex-direction:column;
  gap:8px;
  max-height:62vh;
  overflow:auto;
  margin-top:12px;
  padding-right:3px
}
.candidate-pill {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:var(--surface2);
  border:1px solid var(--line);
  border-radius:10px;
  padding:11px 12px;
  color:var(--ink)
}
.candidate-pill:hover,.candidate-pill.active {
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(23,118,43,.10);
  transform:translateY(-1px)
}
.candidate-pill b {
  display:block;
  font-size:11.5px
}
.candidate-pill small {
  display:block;
  color:var(--muted);
  font-size:9.5px;
  margin-top:2px
}
.candidate-pill em {
  font-style:normal;
  border-radius:999px;
  padding:4px 7px;
  font-size:8px;
  font-weight:900
}
.candidate-pill em.done {
  background:#eaf8ed;
  color:#147326
}
.candidate-pill em.pending {
  background:#fff8e5;
  color:#946700
}
.quick-next {
  width:100%;
  margin-top:14px
}
.panelist-score-area {
  min-width:0
}
.scoring-form-card {
  max-width:560px;
  margin:0 auto 28px
}
.candidate-focus-card,.criterion-card,.field-card {
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:13px;
  box-shadow:0 8px 18px rgba(13,33,55,.07)
}
.candidate-focus-card {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:15px 16px;
  margin-bottom:13px
}
.candidate-focus-card h2 {
  margin:0;
  color:var(--ink);
  font-size:16px
}
.candidate-focus-card p {
  margin:4px 0 0;
  color:var(--muted);
  font-size:10px
}
.criteria-stack {
  display:flex;
  flex-direction:column;
  gap:12px
}
.criterion-card {
  padding:13px 14px
}
.criterion-title {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:10px
}
.criterion-title b {
  font-size:11px;
  color:var(--ink);
  line-height:1.45
}
.criterion-title span {
  font-size:9px;
  color:var(--muted);
  font-weight:800;
  white-space:nowrap
}
.score-options-modern {
  justify-content:flex-start
}
.score-options-modern span {
  width:34px;
  height:34px;
  border-radius:50%;
  background:var(--surface2);
  font-size:11px
}
.score-options-modern input:checked+span {
  background:linear-gradient(135deg,var(--green),var(--green2));
  box-shadow:0 7px 16px rgba(23,118,43,.25)
}
.panel-total {
  margin:12px 0;
  background:var(--surface);
  border-color:var(--line)
}
.panel-total strong {
  font-size:15px;
  color:var(--green)
}
.field-card {
  padding:12px 14px;
  margin-bottom:12px
}
.field-card label {
  margin-top:0;
  color:var(--ink);
  text-transform:none;
  letter-spacing:0;
  font-size:11px
}
.field-card textarea {
  min-height:86px;
  resize:vertical
}
.panelist-submit-row {
  display:flex;
  gap:10px;
  align-items:center;
  margin:12px 0
}
.panelist-submit-row .btn-primary {
  flex:1
}
.panelist-bottom-stats {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-top:14px
}
.empty-state {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  min-height:310px;
  color:var(--muted);
  background:transparent;
  border:1px dashed var(--line);
  border-radius:14px;
  padding:28px
}
.empty-state.small {
  min-height:90px;
  font-size:11px
}
.empty-icon {
  font-size:41px;
  margin-bottom:10px
}
.panelist-empty b {
  color:var(--ink);
  margin-bottom:5px
}
[data-theme="dark"] .candidate-pill em.done {
  background:#123c24;
  color:#8dffad
}
[data-theme="dark"] .candidate-pill em.pending {
  background:#3c3113;
  color:#ffe08a
}
[data-theme="dark"] .candidate-search-wrap input:focus {
  background:transparent
}
.btn:disabled {
  opacity:.55;
  cursor:not-allowed;
  transform:none!important;
  box-shadow:none!important
}

@media(max-width:1000px) {
  .panelist-layout {
    grid-template-columns:1fr
  }
  .panelist-search-panel {
    position:static
  }
  .scoring-form-card {
    max-width:100%
  }
  .panelist-hero {
    align-items:flex-start;
    flex-direction:column
  }
  .panelist-mini-stats {
    min-width:0;
    width:100%
  }
}

@media(max-width:620px) {
  .panelist-mini-stats,.panelist-bottom-stats {
    grid-template-columns:1fr 1fr
  }
  .panelist-submit-row {
    flex-direction:column
  }
  .panelist-submit-row .btn {
    width:100%
  }
  .candidate-focus-card,.criterion-title,.panelist-progress-top {
    flex-direction:column;
    align-items:flex-start
  }
  .score-options-modern {
    flex-wrap:wrap
  }
}

/* ================= v10: Panelist review modal + responsive candidate workflow ================= */
body.modal-open {
  overflow:hidden;
}

.review-modal {
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(2,8,23,.68);
  backdrop-filter:blur(4px);
  z-index:9999;
  padding:18px;
}

.review-modal.show {
  display:flex;
}

.review-modal-card {
  position:relative;
  width:min(650px,96vw);
  max-height:92vh;
  overflow:auto;
  background:#182437;
  color:#dbeafe;
  border:1px solid #263954;
  border-right:5px solid #1a8f3a;
  border-radius:16px;
  padding:20px 28px;
  box-shadow:0 28px 90px rgba(0,0,0,.45);
}

.review-modal-card h2 {
  margin:0 0 18px;
  color:#22c55e;
  font-size:18px;
  letter-spacing:.01em;
}

.review-close {
  position:absolute;
  top:14px;
  right:18px;
  border:0;
  background:transparent;
  color:#7fa0ca;
  font-size:33px;
  line-height:1;
  cursor:pointer;
}

.review-close:hover {
  color:#fff;
  transform:rotate(90deg);
}

.review-candidate-box {
  background:#21334d;
  border:1px solid rgba(127,160,202,.12);
  border-radius:11px;
  padding:14px 16px;
  margin-bottom:18px;
}

.review-candidate-box b {
  display:block;
  color:#fff;
  font-size:15px;
  line-height:1.15;
}

.review-candidate-box span {
  display:block;
  color:#8fb4e6;
  font-size:11px;
  margin-top:4px;
}

.review-table {
  margin-bottom:18px;
}

.review-table-head,.review-row,.review-total-row {
  display:grid;
  grid-template-columns:minmax(0,1fr) 90px;
  gap:16px;
  align-items:center;
}

.review-table-head {
  background:#21334d;
  color:#7998bf;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:900;
  font-size:10px;
  padding:10px 12px;
  border-radius:0;
  margin-bottom:2px;
}

.review-row {
  padding:10px 12px;
  border-bottom:1px solid rgba(127,160,202,.16);
}

.review-row span {
  color:#9cc3f5;
  font-size:13px;
  line-height:1.35;
}

.review-row b {
  text-align:center;
  color:#22e364;
  font-size:14px;
}

.review-total-row {
  padding:15px 12px;
  border-top:1px solid rgba(127,160,202,.25);
}

.review-total-row b {
  font-size:14px;
  color:#fff;
}

.review-total-row strong {
  color:#22c55e;
  text-align:center;
  font-size:17px;
  line-height:1.1;
}

.review-total-row em {
  display:block;
  color:#54739b;
  font-style:normal;
  font-size:12px;
  margin-top:4px;
}

.review-field {
  margin-bottom:12px;
}

.review-field label {
  display:block;
  margin:0 0 6px;
  color:#6f91bb;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:10px;
  font-weight:900;
}

.review-readonly {
  min-height:40px;
  background:#21334d;
  color:#a7c8f7;
  border:1px solid rgba(127,160,202,.12);
  border-radius:10px;
  padding:10px 12px;
  white-space:pre-wrap;
}

.review-warning {
  background:#34352d;
  color:#ffbd15;
  border-radius:10px;
  padding:13px 15px;
  margin:16px 0 20px;
  font-size:13px;
  line-height:1.45;
}

.review-actions {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.review-actions .btn {
  min-height:46px;
  font-size:13px;
  font-weight:900;
}

.review-back {
  background:#273449!important;
  color:#9ebee8!important;
  border:1px solid rgba(127,160,202,.14)!important;
}

.review-confirm {
  background:#188c35!important;
  color:#fff!important;
  box-shadow:0 8px 20px rgba(24,140,53,.25)!important;
}

[data-theme="light"] .review-modal-card {
  background:#172235;
  color:#dbeafe;
}

.candidate-pill {
  transition:.18s ease;
}

.candidate-list::-webkit-scrollbar,.review-modal-card::-webkit-scrollbar {
  width:7px;
}

.candidate-list::-webkit-scrollbar-thumb,.review-modal-card::-webkit-scrollbar-thumb {
  background:#1a8f3a;
  border-radius:99px;
}

.scoring-form-card:has(button:disabled) .criterion-card {
  opacity:.92;
}

@media(max-width:620px) {
  .review-modal {
    padding:8px;
    align-items:flex-start
  }
  .review-modal-card {
    padding:18px 18px;
    margin-top:10px
  }
  .review-table-head,.review-row,.review-total-row {
    grid-template-columns:1fr 70px
  }
  .review-row span {
    font-size:12px
  }
  .review-actions {
    grid-template-columns:1fr
  }
  .review-close {
    right:12px;
    top:10px
  }
}

/* ================= v11: Candidate grade summary + full video-like candidate section ================= */
.candidate-admin-card {
  overflow:hidden
}
.candidate-add-form {
  align-items:end
}
.candidate-toolbar {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  margin:16px 0 10px
}
.candidate-tools {
  display:flex;
  align-items:center;
  gap:10px;
  min-width:min(620px,100%)
}
.candidate-tools select {
  max-width:240px
}
.candidate-tools .searchbar {
  margin:0;
  min-width:260px
}
.grade-summary-panel {
  background:var(--surface2);
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px;
  margin:18px 0 6px
}
.grade-summary-head {
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:12px;
  margin-bottom:12px
}
.grade-summary-head h3 {
  margin:0;
  color:var(--ink);
  font-size:14px
}
.grade-summary-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:12px
}
.grade-summary-card {
  appearance:none;
  text-align:left;
  width:100%;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:13px;
  padding:13px 14px;
  color:var(--ink);
  box-shadow:0 8px 18px rgba(13,33,55,.06);
  cursor:pointer;
  transition:.18s ease
}
.grade-summary-card:hover {
  transform:translateY(-2px);
  border-color:var(--green);
  box-shadow:0 12px 28px rgba(13,33,55,.11)
}
.grade-summary-card span {
  display:inline-flex;
  margin-bottom:8px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(23,118,43,.10);
  color:var(--green);
  font-weight:900;
  font-size:9px;
  text-transform:uppercase;
  letter-spacing:.08em
}
.grade-summary-card b {
  display:block;
  font-size:12px;
  margin-bottom:10px;
  line-height:1.25
}
.grade-stat-row {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:6px;
  margin-bottom:10px
}
.grade-stat-row em {
  font-style:normal;
  background:var(--surface2);
  border:1px solid var(--line);
  border-radius:8px;
  text-align:center;
  padding:5px 3px;
  font-size:5px;
  color:var(--muted);
  font-weight:800
}
.grade-summary-card small {
  display:block;
  margin-top:8px;
  color:var(--muted);
  font-weight:700
}
.candidate-table-wrap {
  overflow:auto;
  margin-top:14px;
  border:1px solid var(--line);
  border-radius:13px
}
.candidate-table-wrap table {
  margin:0;
  border-radius:0
}
.candidate-table-wrap th {
  position:sticky;
  top:0;
  z-index:2
}
.badge.warn {
  background:#fff8e5;
  color:#946700;
  border-color:#f1d07a
}
[data-theme="dark"] .badge.warn {
  background:#3c3113;
  color:#ffe08a;
  border-color:#705b1d
}
[data-theme="dark"] .grade-summary-card span {
  background:#123c24;
  color:#8dffad
}
.dropzone.loaded {
  border-color:var(--green);
  background:rgba(23,118,43,.08)
}

@media(max-width:920px) {
  .candidate-toolbar {
    align-items:stretch;
    flex-direction:column
  }
  .candidate-tools {
    min-width:0;
    flex-direction:column;
    align-items:stretch
  }
  .candidate-tools select,.candidate-tools .searchbar {
    max-width:none;
    min-width:0;
    width:100%
  }
  .grade-summary-head {
    align-items:flex-start;
    flex-direction:column
  }
  .grade-stat-row {
    grid-template-columns:1fr
  }
}

/* ================= v12: final missing HTML features + improved reporting ================= */
.live-top-toolbar {
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:16px;
  margin-bottom:14px
}
.live-top-toolbar h1 {
  margin:0 0 4px;
  font-size:23px
}
.live-actions-inline {
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap
}
.mini-link {
  display:inline-block;
  margin-top:5px;
  color:var(--green);
  font-size:10px;
  font-weight:800;
  text-decoration:none
}
.mini-link:hover {
  text-decoration:underline
}
.mini-bar.dist {
  width:100%;
  max-width:220px;
  height:12px
}
.heat-0 {
  background:var(--surface2)!important
}
.heat-1 {
  background:#ffe4e6!important;
  color:#7f1d1d!important
}
.heat-2 {
  background:#fef3c7!important;
  color:#78350f!important
}
.heat-3 {
  background:#dcfce7!important;
  color:#14532d!important
}
.heat-4,.heat-5 {
  background:#bbf7d0!important;
  color:#052e16!important
}
[data-theme="dark"] .heat-1 {
  background:#3b1216!important;
  color:#fecdd3!important
}
[data-theme="dark"] .heat-2 {
  background:#3b2d12!important;
  color:#fde68a!important
}
[data-theme="dark"] .heat-3 {
  background:#12351f!important;
  color:#bbf7d0!important
}
[data-theme="dark"] .heat-4,[data-theme="dark"] .heat-5 {
  background:#0e4a28!important;
  color:#dcfce7!important
}

@media(max-width:900px) {
  .live-top-toolbar {
    align-items:flex-start;
    flex-direction:column
  }
  .live-actions-inline {
    width:100%
  }
  .live-actions-inline .btn {
    width:100%
  }
}

@media print {
  .report-sheet:before {
    content:"CONFIDENTIAL"!important;
    display:block!important
  }
  .report-candidate .report-kpis {
    grid-template-columns:repeat(4,1fr)
  }
  .report-pins {
    min-height:100vh
  }
  .report-pins .report-sheet:before {
    font-size:94px
  }
  .no-print {
    display:none!important
  }
}


/* ================= v16: Live report candidate detail modal ================= */
.candidate-detail-link {
  border:0;
  padding:0;
  background:transparent;
  color:var(--ink);
  cursor:pointer;
  font-weight:900;
  font-size:12px;
  text-align:left;
}

.candidate-detail-link:hover {
  color:var(--green);
  text-decoration:underline;
}

.btn-mini {
  min-height:28px;
  padding:5px 9px;
  font-size:10px;
  border-radius:7px;
}

.candidate-modal-backdrop {
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:22px;
  background:rgba(2,8,15,.76);
  z-index:9999;
  backdrop-filter:blur(3px);
}

.candidate-modal-backdrop.show {
  display:flex;
}

.candidate-modal {
  width:min(860px,96vw);
  max-height:88vh;
  overflow:auto;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:0 28px 70px rgba(0,0,0,.38);
  padding:26px;
}

.candidate-modal-head {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:22px;
}

.candidate-modal-head h2 {
  margin:0;
  font-size:19px;
  color:var(--ink);
}

.modal-close {
  width:36px;
  height:36px;
  border:0;
  border-radius:10px;
  background:transparent;
  color:var(--muted);
  cursor:pointer;
  font-size:29px;
  line-height:1;
}

.modal-close:hover {
  background:var(--surface2);
  color:var(--red);
}

.candidate-modal-grid {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}

.candidate-mini-card {
  background:var(--surface2);
  border:1px solid var(--line);
  border-radius:11px;
  padding:15px 17px;
  min-height:82px;
}

.candidate-mini-card small {
  display:block;
  color:var(--muted);
  font-size:9.5px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.09em;
  margin-bottom:6px;
}

.candidate-mini-card b {
  color:var(--ink);
  display:block;
  font-size:19px;
  line-height:1.2;
}

.candidate-mini-card span {
  display:inline-block;
  margin-top:6px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(212,160,23,.18);
  color:var(--gold);
  font-size:10px;
  font-weight:800;
}

.success-text {
  color:var(--green)!important;
}

.candidate-modal-table-wrap {
  max-height:340px;
  overflow:auto;
  border:1px solid var(--line);
  border-radius:12px;
}

.candidate-modal-table {
  border:0;
  border-radius:0;
  margin:0;
}

.candidate-modal-table thead th {
  position:sticky;
  top:0;
  z-index:2;
  background:var(--surface2)!important;
}

.candidate-modal-table th,
.candidate-modal-table td {
  padding:10px 13px;
  white-space:nowrap;
}

[data-theme="dark"] .candidate-modal-backdrop {
  background:rgba(0,0,0,.76);
}

[data-theme="dark"] .candidate-mini-card,
[data-theme="dark"] .candidate-modal-table thead th {
  background:#1a2e44!important;
}

[data-theme="dark"] .candidate-modal {
  background:#142338;
}

@media(max-width:760px) {
  .candidate-modal {
    padding:18px;
  }

  .candidate-modal-grid {
    grid-template-columns:1fr;
  }

  .candidate-modal-head {
    align-items:flex-start;
    flex-direction:column;
  }
}

/* ================= v17: candidate upload/manual tabs + drag/drop polish ================= */
.candidate-tabs {
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:4px 0 16px;
}
.candidate-tab {
  appearance:none;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--muted);
  border-radius:999px;
  padding:10px 18px;
  font-weight:900;
  cursor:pointer;
  transition:.18s ease;
}
.candidate-tab:hover {
  border-color:var(--green);
  color:var(--green);
  transform:translateY(-1px);
}
.candidate-tab.active {
  background:var(--green);
  border-color:var(--green);
  color:#fff;
  box-shadow:0 12px 26px rgba(23,118,43,.22);
}
.candidate-tab-panel.hidden,
.hidden {
  display:none !important;
}
.bulk-upload-box,
.manual-candidate-box {
  background:var(--surface2);
  border:1px solid var(--line);
  border-radius:16px;
  padding:16px;
  margin-bottom:18px;
}
.bulk-info {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:6px 18px;
  margin-bottom:14px;
  border-radius:13px;
  border:1px solid rgba(23,118,43,.25);
  background:rgba(23,118,43,.08);
  color:var(--ink);
}

.bulk-info b {
  font-size:9px;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:900;
}
.bulk-info span {
  font-size:11px;
  color:var(--muted);
}

.card-title span {
  display:block;
  margin-top:4px;
  font-size:11px;
  color:var(--muted);
}

.dropzone {
  display:block;
  width:100%;
  text-align:center;
  border:2px dashed var(--line);
  background:var(--surface);
  border-radius:16px;
  padding:24px 18px;
  color:var(--muted);
  cursor:pointer;
  transition:.18s ease;
  margin-bottom:14px;
}
.dropzone input[type="file"] {
  display:none;
}
.dropzone .folder {
  display:block;
  font-size:35px;
  margin-bottom:8px;
}
.dropzone b {
  color:var(--accent);
}
.dropzone:hover,
.dropzone.dragover {
  border-color:var(--green);
  background:rgba(23,118,43,.08);
  transform:translateY(-1px);
}
.dropzone.loaded {
  border-color:var(--green);
  background:rgba(23,118,43,.10);
}
[data-theme="dark"] .bulk-upload-box,
[data-theme="dark"] .manual-candidate-box {
  background:#111c2d;
}
[data-theme="dark"] .dropzone {
  background:#172439;
  border-color:#27405f;
}
[data-theme="dark"] .bulk-info {
  background:rgba(28,185,84,.08);
  border-color:rgba(28,185,84,.28);
}
@media(max-width:900px) {
  .bulk-info {
    align-items:flex-start;
    flex-direction:column;
  }
  .candidate-tab {
    flex:1;
  }
}

/* ================= v19: final HR-matching UI fixes ================= */
:root {
  --compact-font: 14px;
}
body {
  font-size: var(--compact-font);
}
.app-shell,
.main,
.container,
.page-wrap {
  max-width: 1480px !important;
}
.main,
.page-content,
.content {
  width: min(92vw, 1480px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
h1 { font-size: 1.473rem !important; }
h2 { font-size: 1.064rem !important; }
h3 { font-size: 0.95rem !important; }
.card,
.kpi,
.candidate-modal,
.review-modal-card {
  border-radius: 14px !important;
}
.card {
  padding: 18px !important;
  margin-bottom: 18px !important;
}
.compact-card {
  padding: 18px !important;
}
.kpi {
  min-height: 88px !important;
  padding: 16px !important;
}
.kpi small {
  font-size: 0.684rem !important;
  letter-spacing: .12em;
}
.kpi .num {
  font-size: 1.473rem !important;
  line-height: 1.1;
}
.kpi-row {
  display: grid;
  gap: 12px;
  margin-bottom: 16px;
}
.kpi-row-8 {
  grid-template-columns: repeat(8, minmax(0, 1fr));
}
.kpi-row-6 {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
.page-toolbar {
  max-width: 1480px;
  margin: 0 auto 16px;
}
.toolbar + .card,
.page-toolbar + .card,
.toolbar + .kpi-row,
.page-toolbar + .kpi-row,
.toolbar + .grid,
.page-toolbar + .grid {
  margin-top: 18px;
}
.success-text { color: var(--green) !important; }
.danger-text { color: var(--red) !important; }
.warn-text { color: var(--gold) !important; }
.kpi .num.success-text,
.card .num.success-text {
  color: var(--green) !important;
}
.kpi .num.danger-text,
.card .num.danger-text {
  color: var(--red) !important;
}
.kpi .num.warn-text,
.card .num.warn-text {
  color: var(--gold) !important;
}
.muted-strong { color: var(--muted) !important; }
.tiny-note {
  font-size: 0.713rem;
  margin-top: 12px;
}
.table, table {
  font-size: 0.817rem !important;
}
th, td {
  padding: 11px 12px !important;
}
input,
select,
textarea,
button,
.btn {
  font-size: 0.736rem !important;
}
.btn-mini {
  padding: 7px 10px !important;
  font-size: 0.741rem !important;
}
.form-button-row {
  display: flex;
  align-items: flex-end;
}
.exercise-details-card {
  margin-bottom: 16px !important;
}
.exercise-details-card .card-title h2 {
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: .12em;
}
.candidate-admin-card {
  max-width: 1480px;
  margin-left: auto;
  margin-right: auto;
}
.candidate-tabs {
  display: flex;
  gap: 10px;
  margin: 12px 0 16px;
}
.candidate-tab {
  border-radius: 999px;
  padding: 10px 18px;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--accent);
  cursor: pointer;
}
.candidate-tab.active {
  background: var(--green);
  color: #fff;
  border-color: var(--green);
}
.candidate-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin: 14px 0;
}
.candidate-tools {
  display: flex;
  gap: 10px;
}
.grade-summary-panel {
  margin: 16px 0;
  padding: 16px;
  border-radius: 14px;
  background: var(--surface2);
  border: 1px solid var(--line);
}
.grade-summary-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 12px;
}
.grade-summary-grid {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
}
.grade-summary-card {
  min-width: 190px;
  padding: 13px 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  cursor: pointer;
}
.grade-summary-card:hover,
.grade-summary-card:has(input:checked) {
  border-color: var(--gold);
  box-shadow: 0 0 0 1px rgba(226, 170, 11, .35) inset;
}
.grade-summary-card b {
  display: flex;
  gap: 8px;
  align-items: center;
  color: var(--gold);
  margin: 4px 0;
}
.grade-summary-card span,
.grade-summary-card em,
.grade-summary-card small {
  color: var(--muted);
  font-size: 0.713rem;
  font-style: normal;
}
.grade-stat-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.candidate-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 12px;
}
.candidate-modal.exam-adjust-modal,
.exam-adjust-modal {
  width: min(520px, 94vw) !important;
}
.exam-adjust-form {
  display: grid;
  gap: 12px;
}
.two-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.adjust-exam-btn {
  margin-top: 10px;
  width: max-content;
}
.consistency-list {
  display: grid;
  gap: 0;
}
.consistency-row {
  display: grid;
  grid-template-columns: 170px 90px 1fr 150px 130px;
  gap: 16px;
  align-items: center;
  padding: 11px 0;
  border-bottom: 1px solid var(--line);
}
.meter,
.mini-bar {
  display: inline-block;
  width: 100%;
  height: 8px;
  border-radius: 999px;
  background: rgba(148, 163, 184, .22);
  overflow: hidden;
  vertical-align: middle;
}
.meter i,
.mini-bar i {
  display: block;
  height: 100%;
  border-radius: 999px;
  background: var(--green);
}
.analytics-grid-two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
.analytics-panel {
  min-height: 300px;
}
.empty-analytics {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 160px;
  color: var(--muted);
  text-align: center;
}
.distribution-chart {
  display: flex;
  align-items: flex-end;
  gap: 14px;
  min-height: 160px;
  padding: 12px 0;
}
.dist-col {
  flex: 1;
  display: grid;
  gap: 6px;
  justify-items: center;
  color: var(--muted);
}
.dist-bar {
  width: 100%;
  max-width: 42px;
  border-radius: 8px 8px 0 0;
  background: var(--red);
}
.dist-bar.pass-band { background: var(--green); }
.legend-row {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
  font-size: 0.741rem;
  flex-wrap: wrap;
}
.legend {
  width: 12px;
  height: 12px;
  border-radius: 3px;
  display: inline-block;
}
.legend.fail { background: var(--red); }
.legend.pass { background: var(--green); }
.grade-stat-list {
  display: grid;
  gap: 14px;
}
.grade-stat-card {
  border-bottom: 1px solid var(--line);
  padding-bottom: 14px;
}
.grade-stat-top {
  display: grid;
  grid-template-columns: 80px 1fr 70px;
  gap: 10px;
  align-items: center;
}
.grade-breakdown {
  display: flex;
  gap: 14px;
  margin-top: 8px;
  font-size: 0.779rem;
}
.heatmap-table td,
.heatmap-table th {
  text-align: center;
}
.heatmap-table td:first-child,
.heatmap-table th:first-child {
  text-align: left;
}
.heat {
  font-weight: 800;
  border-radius: 0;
}
.heat-empty { background: rgba(148, 163, 184, .15); color: var(--muted); }
.heat-0,.heat-1,.heat-2 { background: rgba(239, 68, 68, .16); color: var(--red); }
.heat-3 { background: rgba(226, 170, 11, .18); color: var(--gold); }
.heat-4,.heat-5 { background: rgba(22, 163, 74, .18); color: var(--green); }
.heatmap-average-row td {
  border-top: 2px solid var(--green);
  background: rgba(22, 163, 74, .08);
}
.heat-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
}
.heat-dot.strong { background: #22c55e; }
.heat-dot.good { background: #38bdf8; }
.heat-dot.mid { background: #eab308; }
.heat-dot.weak { background: #ef4444; }
.review-modal.show,
.candidate-modal-backdrop.show {
  display: flex !important;
}
.review-modal-card {
  max-width: 650px !important;
}
.review-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
}
.review-row b {
  color: var(--green);
}
[data-theme="dark"] .card,
[data-theme="dark"] .kpi,
[data-theme="dark"] .candidate-modal,
[data-theme="dark"] .review-modal-card,
[data-theme="dark"] .candidate-mini-card,
[data-theme="dark"] .grade-summary-panel,
[data-theme="dark"] .grade-summary-card {
  background: #121d2e !important;
  border-color: #263b58 !important;
}
[data-theme="dark"] table thead th {
  background: #20344f !important;
  color: #dbeafe !important;
}
[data-theme="dark"] td,
[data-theme="dark"] th,
[data-theme="dark"] p,
[data-theme="dark"] label,
[data-theme="dark"] span,
[data-theme="dark"] a,
[data-theme="dark"] .muted {
  color: #9db8da;
}
[data-theme="dark"] b,
[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] .num {
  color: #f8fafc;
}
[data-theme="dark"] .success-text { color: #22c55e !important; }
[data-theme="dark"] .danger-text { color: #ff4d4d !important; }
[data-theme="dark"] .warn-text { color: #f6c416 !important; }
[data-theme="dark"] .kpi .num.success-text,
[data-theme="dark"] .card .num.success-text {
  color: #22c55e !important;
}
[data-theme="dark"] .kpi .num.danger-text,
[data-theme="dark"] .card .num.danger-text {
  color: #ff4d4d !important;
}
[data-theme="dark"] .kpi .num.warn-text,
[data-theme="dark"] .card .num.warn-text {
  color: #f6c416 !important;
}
@media (max-width: 1200px) {
  .kpi-row-8 { grid-template-columns: repeat(4, 1fr); }
  .kpi-row-6 { grid-template-columns: repeat(3, 1fr); }
  .analytics-grid-two { grid-template-columns: 1fr; }
  .consistency-row { grid-template-columns: 1fr; gap: 6px; }
}
@media (max-width: 720px) {
  .kpi-row-8,
  .kpi-row-6 { grid-template-columns: repeat(2, 1fr); }
  .candidate-toolbar,
  .grade-summary-head,
  .page-toolbar { flex-direction: column; align-items: stretch; }
  .candidate-tools { flex-direction: column; }
  .page-toolbar .actions > * {
    min-width: auto;
    width: 100%;
  }
}

/* Unified card styling to match the Results Board aesthetic */
.card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 20px 40px rgba(13,33,55,.08);
  padding: 20px;
  margin-bottom: 22px;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover {
  transform: translateY(-1px);
  box-shadow: 0 24px 48px rgba(13,33,55,.12);
}
.card-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding-bottom: 16px;
  margin-bottom: 20px;
  border-bottom: 1px solid rgba(226,234,226,.85);
}
.card-title h2,
.card-title h3 {
  margin: 0;
  color: var(--ink);
  font-size: 1.08rem;
}
.card-title span,
.card-title .muted {
  color: var(--muted);
  font-size: 0.95rem;
}
.compact-card {
  padding: 18px;
}
.kpi {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 18px;
}
.kpi small {
  color: var(--muted);
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.kpi .num {
  font-size: 1.75rem;
  line-height: 1;
  color: var(--ink);
}
.badge.pass {
  background: rgba(23,118,43,.12);
  color: var(--green);
  border-color: rgba(23,118,43,.3);
}
.badge.fail {
  background: rgba(211,60,71,.12);
  color: var(--red);
  border-color: rgba(211,60,71,.3);
}
.badge.mid,
.badge.warn {
  background: rgba(212,160,23,.14);
  color: var(--gold);
  border-color: rgba(212,160,23,.3);
}
.success-text { color: var(--green) !important; }
.danger-text { color: var(--red) !important; }
.warn-text { color: var(--gold) !important; }

/* .grade-summary-panel {
    background: #20324a;
    border-radius: 10px;
    padding: 18px 22px;
    margin-top: 18px;
    border: 1px solid rgba(148, 163, 184, 0.18);
} */

/* .grade-summary-panel h3 {
    margin: 0 0 4px;
    font-size: 14px;
    font-weight: 700;
    color: #ffffff;
}

.grade-summary-note {
    margin: 0 0 14px;
    font-size: 11px;
    color: #6f8ab3;
}

.grade-summary-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.grade-summary-card {
    min-width: 170px;
    height: 54px;
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 10px 14px;
    border-radius: 8px;
    background: #142236;
    border: 1px solid transparent;
    cursor: pointer;
    transition: 0.2s ease;
}

.grade-summary-card:hover {
    border-color: rgba(234, 179, 8, 0.45);
}

.grade-summary-card.active {
    border-color: #eab308;
    background: #21314a;
}

.grade-summary-card input {
    width: 16px;
    height: 16px;
    accent-color: #eab308;
    cursor: pointer;
}

.grade-summary-card strong {
    display: block;
    font-size: 14px;
    line-height: 1.1;
    color: #ffffff;
}

.grade-summary-card small {
    display: block;
    margin-top: 3px;
    font-size: 10px;
    color: #6f8ab3;
}

.grade-summary-card.active small {
    color: #facc15;
}

.candidate-summary-row {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin: 14px 0 10px;
} */

.candidate-summary-row > span {
    color: #8fb3e8;
    font-size: 13px;
}

.candidate-summary-row em {
    color: #49658b;
    font-style: normal;
    margin: 0 4px;
}

.candidate-summary-row strong {
    color: #16a34a;
    font-weight: 700;
}

.candidate-exam-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.inline-upload-form {
    display: inline-flex;
    margin: 0;
}

/* .grade-summary-panel {
    background: #20324a !important;
    border: 1px solid rgba(148, 163, 184, 0.18) !important;
    border-radius: 10px !important;
    margin: 12px 0 18px !important;
    padding: 18px 22px !important;
}

.grade-summary-panel h3 {
    color: #ffffff !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    margin: 0 0 4px !important;
}

.grade-summary-note {
    color: #58739b !important;
    display: block !important;
    font-size: 11px !important;
    line-height: 1.4 !important;
    margin: 0 0 14px !important;
}

.grade-summary-grid {
    align-items: center !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}

.grade-summary-card {
    align-items: center !important;
    background: #142236 !important;
    border: 1px solid transparent !important;
    border-radius: 8px !important;
    box-shadow: none !important;
    cursor: pointer !important;
    display: flex !important;
    gap: 11px !important;
    height: 58px !important;
    justify-content: flex-start !important;
    margin: 0 !important;
    min-width: 190px !important;
    padding: 10px 14px !important;
    transition: border-color .2s ease, background-color .2s ease !important;
}

.grade-summary-card:hover {
    border-color: rgba(234, 179, 8, 0.45) !important;
}

.grade-summary-card.active,
.grade-summary-card:has(input:checked) {
    background: #21314a !important;
    border-color: #eab308 !important;
}

.grade-summary-card input[type="checkbox"] {
    accent-color: #eab308 !important;
    cursor: pointer !important;
    flex: 0 0 auto !important;
    height: 16px !important;
    margin: 0 !important;
    width: 16px !important;
}

.grade-summary-text {
    display: block !important;
    min-width: 0 !important;
}

.grade-summary-card strong {
    color: #ffffff !important;
    display: block !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1.1 !important;
    margin: 0 !important;
}

.grade-summary-card small {
    color: #58739b !important;
    display: block !important;
    font-size: 10px !important;
    line-height: 1.2 !important;
    margin-top: 4px !important;
    white-space: nowrap !important;
}

.grade-summary-card small em {
    color: inherit !important;
    font-style: normal !important;
}

.grade-summary-card.active strong,
.grade-summary-card:has(input:checked) strong {
    color: #facc15 !important;
}

.grade-summary-card.active small em,
.grade-summary-card:has(input:checked) small em {
    color: #facc15 !important;
}  */

.candidate-table-tools {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    margin: 0 0 10px;
}

.candidate-table-tools select,
.candidate-table-tools input {
    max-width: 240px;
}

@media (max-width: 760px) {
    .candidate-summary-row,
    .candidate-exam-actions,
    .candidate-table-tools {
        align-items: stretch;
        flex-direction: column;
    }

    .grade-summary-card {
        width: 100% !important;
    }
}

