:root {
  --bg: #f3f6fb;
  --card: #ffffff;
  --ink: #172033;
  --muted: #667085;
  --brand: #2854d8;
  --brand-dark: #173fae;
  --brand-soft: #eef4ff;
  --brand2: #0ea5a4;
  --border: #d9e1ef;
  --danger: #b42318;
  --ok: #027a48;
  --shadow: 0 12px 35px rgba(20, 35, 80, 0.08);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  background:
    radial-gradient(circle at top left, rgba(40, 84, 216, 0.08), transparent 35%),
    var(--bg);
  color: var(--ink);
  line-height: 1.5;
}

a {
  color: var(--brand);
  text-decoration: none;
  font-weight: 600;
}

a:hover {
  text-decoration: underline;
}

.topbar {
  background: #111827;
  color: #fff;
  padding: 16px 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.topbar a {
  color: #fff;
  margin-left: 18px;
  opacity: 0.9;
}

.topbar a:hover {
  opacity: 1;
}

.container {
  max-width: 1180px;
  margin: 30px auto;
  padding: 0 20px;
}

.hero {
  background: linear-gradient(135deg, #173fae, #13aaa6);
  color: #fff;
  border-radius: 26px;
  padding: 38px;
  box-shadow: 0 22px 55px rgba(20, 35, 80, 0.2);
}

.hero h1 {
  margin: 0 0 12px;
  font-size: 38px;
  letter-spacing: -0.03em;
}

.hero p {
  max-width: 780px;
  line-height: 1.6;
  font-size: 17px;
  opacity: 0.95;
}

.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 24px;
}

.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 24px;
  box-shadow: var(--shadow);
}

.card h2,
.card h3 {
  margin-top: 0;
  letter-spacing: -0.02em;
}

.btn {
  display: inline-block;
  background: var(--brand);
  color: #fff !important;
  border: 0;
  border-radius: 14px;
  padding: 12px 18px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(40, 84, 216, 0.22);
}

.btn:hover {
  background: var(--brand-dark);
  text-decoration: none;
}

.btn.secondary {
  background: #475569;
  box-shadow: none;
}

.btn.light {
  background: var(--brand-soft);
  color: #1d3c8b !important;
  box-shadow: none;
}

.form-row {
  margin-bottom: 16px;
}

label {
  display: block;
  font-weight: 700;
  margin-bottom: 7px;
  color: #26344d;
}

input,
textarea,
select {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  font-size: 15px;
  background: #fff;
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 4px rgba(40, 84, 216, 0.12);
}

textarea {
  min-height: 130px;
  resize: vertical;
}

.two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.three {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 18px;
}

.notice,
.alert,
.error {
  padding: 14px 16px;
  border-radius: 14px;
  margin-bottom: 18px;
}

.notice {
  background: #ecfdf3;
  color: #05603a;
  border: 1px solid #abefc6;
}

.alert {
  background: #fff8e6;
  color: #8a5b00;
  border: 1px solid #ffe69c;
}

.error {
  background: #fef3f2;
  color: var(--danger);
  border: 1px solid #fecdca;
}

.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  overflow: hidden;
}

.table th,
.table td {
  padding: 14px;
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: top;
}

.table th {
  background: #f8fafc;
  font-size: 13px;
  text-transform: uppercase;
  color: #475467;
  letter-spacing: 0.04em;
}

.table tr:last-child td {
  border-bottom: 0;
}

.badge {
  display: inline-block;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--brand-soft);
  color: #1d3c8b;
  font-size: 12px;
  font-weight: 700;
}

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

.actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.login-box {
  max-width: 450px;
  margin: 80px auto;
}

.evidence-list {
  padding-left: 20px;
}

.session-card {
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: 14px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 18px;
  margin: 14px 0;
  background: #fff;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(20, 35, 80, 0.05);
}

.session-card:hover {
  background: #f8fbff;
  border-color: #b7c7ef;
}

.session-card input {
  margin-top: 5px;
}

.record-draft {
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 22px;
  margin: 20px 0 26px;
  background: linear-gradient(180deg, #ffffff, #fbfdff);
  box-shadow: var(--shadow);
}

@media (max-width: 800px) {
  .grid,
  .two,
  .three {
    grid-template-columns: 1fr;
  }

  .hero {
    padding: 28px;
  }

  .hero h1 {
    font-size: 30px;
  }

  .topbar {
    display: block;
  }

  .topbar nav {
    margin-top: 10px;
  }

  .topbar a {
    display: inline-block;
    margin: 6px 12px 0 0;
  }
}

.unit-checklist {
  display: grid;
  gap: 10px;
  max-height: 320px;
  overflow: auto;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #f8fafc;
}
.check-row {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 10px;
  align-items: start;
  padding: 10px 12px;
  border: 1px solid #e4eaf5;
  border-radius: 12px;
  background: #fff;
  font-weight: 400;
}
.check-row input {
  width: auto;
  margin-top: 3px;
}

.admin-impersonation-bar {
  background: #fff8e6;
  border-bottom: 1px solid #ffe69c;
  color: #7a4b00;
  padding: 10px 24px;
  font-size: 14px;
}
.admin-impersonation-bar a {
  margin-left: 12px;
  font-weight: 700;
}
.admin-table-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.admin-danger-zone {
  border: 1px solid #fecdca;
  background: #fffafa;
}

.btn.danger {
  background: var(--danger);
  box-shadow: 0 8px 18px rgba(180, 35, 24, 0.18);
}

.btn.danger:hover {
  background: #8f1d14;
}

.beta-bar {
  background: #fff8e6;
  border-bottom: 1px solid #ffe69c;
  color: #6f4e00;
  padding: 10px 28px;
  font-size: 14px;
}

.beta-bar a {
  color: #1d3c8b;
  font-weight: 700;
}

.footer-links {
  max-width: 1180px;
  margin: 20px auto 30px;
  padding: 0 20px;
  color: var(--muted);
  font-size: 14px;
}

.code-block {
  display: block;
  background: #111827;
  color: #fff;
  border-radius: 12px;
  padding: 12px 14px;
  overflow-x: auto;
}


/* Mobile navigation and responsive tables */
.topbar-brand-row {display:flex;align-items:center;justify-content:space-between;gap:16px;}
.menu-toggle {display:none;background:rgba(255,255,255,0.12);color:#fff;border:1px solid rgba(255,255,255,0.22);border-radius:10px;padding:8px 11px;font-size:20px;line-height:1;cursor:pointer;}
.file-actions {display:flex;gap:8px;flex-wrap:wrap;margin-top:6px;}
.file-action-link {display:inline-block;padding:5px 9px;border-radius:999px;background:var(--brand-soft);color:#1d3c8b!important;font-size:12px;font-weight:700;}
.file-action-link.download {background:#eef2f7;color:#344054!important;}
.table-wrap {width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;}
@media (max-width:900px){
  .topbar{display:block;padding:14px 18px;}
  .menu-toggle{display:inline-block;}
  .topbar nav.main-nav{display:none;margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,0.15);}
  body.nav-open .topbar nav.main-nav{display:grid;gap:4px;}
  .topbar nav.main-nav a{display:block;margin:0;padding:10px 8px;border-radius:10px;}
  .topbar nav.main-nav a:hover{background:rgba(255,255,255,0.08);text-decoration:none;}
  .container{margin:18px auto;padding:0 12px;}
  .card{border-radius:18px;padding:18px;}
  .table{min-width:720px;}
  .beta-bar{padding:10px 14px;font-size:13px;}
}
@media (max-width:560px){
  .hero h1,h1{font-size:26px;}
  .btn{width:100%;text-align:center;}
  .actions,.export-actions,.admin-table-actions{flex-direction:column;align-items:stretch;}
  .file-actions{flex-direction:row;}
}


/* Branding, login and onboarding */
.brand-link { display:flex; align-items:center; color:#fff!important; }
.brand-link img { width:260px; max-width:70vw; height:auto; display:block; filter: brightness(0) invert(1); }
.auth-shell { max-width:1120px; margin:46px auto; padding:0 18px; display:grid; grid-template-columns:1.15fr .85fr; gap:24px; align-items:stretch; }
.auth-shell.single { max-width:820px; grid-template-columns:1fr; }
.auth-hero-panel, .auth-card { background:#fff; border:1px solid var(--border); border-radius:28px; padding:34px; box-shadow:var(--shadow); }
.auth-hero-panel { background:linear-gradient(135deg,#102a78,#0ea5a4); color:#fff; position:relative; overflow:hidden; }
.auth-hero-panel:after { content:""; position:absolute; right:-90px; bottom:-90px; width:240px; height:240px; border-radius:50%; background:rgba(255,255,255,.12); }
.auth-hero-panel h1 { font-size:40px; line-height:1.08; letter-spacing:-.04em; margin:26px 0 14px; max-width:720px; }
.auth-hero-panel p { font-size:18px; line-height:1.55; opacity:.95; max-width:680px; }
.auth-logo { width:360px; max-width:100%; height:auto; display:block; }
.auth-logo.compact { width:320px; margin-bottom:18px; }
.auth-points { display:grid; gap:12px; margin-top:28px; position:relative; z-index:2; }
.auth-points div { background:rgba(255,255,255,.13); border:1px solid rgba(255,255,255,.2); border-radius:18px; padding:15px; }
.auth-points strong { display:block; font-size:16px; }
.auth-points span { display:block; opacity:.88; margin-top:3px; }
.auth-card h2, .auth-card h1 { margin-top:0; }
.auth-card.wide { padding:36px; }
.auth-btn { width:100%; text-align:center; margin-top:4px; }
.auth-divider { height:1px; background:var(--border); margin:24px 0; }
.center-text { text-align:center; }
.wizard-hero { display:flex; justify-content:space-between; gap:24px; align-items:center; }
.eyebrow { color:var(--brand); text-transform:uppercase; letter-spacing:.08em; font-weight:800; font-size:12px; margin:0 0 8px; }
.wizard-progress { min-width:210px; text-align:right; }
.wizard-progress span { display:block; font-size:30px; font-weight:800; color:var(--brand); margin-bottom:8px; }
.wizard-progress div { height:12px; background:#e8eefb; border-radius:999px; overflow:hidden; }
.wizard-progress em { display:block; height:100%; background:linear-gradient(90deg,var(--brand),var(--brand2)); border-radius:999px; }
.wizard-progress.small { min-width:150px; }
.wizard-progress.small span { font-size:22px; }
.wizard-steps { display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:20px; }
.wizard-step { position:relative; }
.wizard-step.done { border-color:#abefc6; background:linear-gradient(180deg,#fff,#f6fffa); }
.wizard-step.done:after { content:"✓"; position:absolute; top:18px; right:20px; background:#027a48; color:#fff; width:28px; height:28px; border-radius:50%; display:grid; place-items:center; font-weight:800; }
.setup-progress-card { margin:20px 0; display:grid; grid-template-columns:1fr auto auto; gap:18px; align-items:center; border-left:5px solid var(--brand2); }
.menu-toggle { background:rgba(255,255,255,.12); color:#fff; border:1px solid rgba(255,255,255,.25); border-radius:10px; padding:8px 11px; }
@media (max-width: 900px) {
  .auth-shell { grid-template-columns:1fr; margin:20px auto; }
  .auth-hero-panel h1 { font-size:32px; }
  .wizard-hero, .setup-progress-card { grid-template-columns:1fr; display:grid; }
  .wizard-progress { text-align:left; width:100%; }
  .wizard-steps { grid-template-columns:1fr; }
  .brand-link img { width:230px; }
}

/* Branding/login refinements - 2026-05-22 */
.brand-link {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #fff !important;
  margin-left: 0 !important;
}
.brand-link:hover { text-decoration: none; opacity: 1; }
.brand-link .brand-icon {
  width: 48px !important;
  height: 48px !important;
  max-width: none !important;
  filter: none !important;
  display: block;
}
.brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.brand-text strong { font-size: 16px; color: #fff; letter-spacing: -0.01em; }
.brand-text small { font-size: 11px; color: rgba(255,255,255,.78); margin-top: 4px; }
.auth-brand-lockup {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
  position: relative;
  z-index: 2;
}
.auth-brand-lockup img {
  width: 72px;
  height: 72px;
  display: block;
  flex: 0 0 auto;
}
.auth-brand-lockup strong {
  display: block;
  font-size: 24px;
  line-height: 1.1;
  color: #fff;
  font-weight: 800;
}
.auth-brand-lockup span {
  display: block;
  color: rgba(255,255,255,.82);
  font-size: 13px;
  margin-top: 4px;
  font-weight: 600;
}
.auth-hero-panel h1, .auth-hero-panel p { position: relative; z-index: 2; }
@media (max-width: 800px) {
  .brand-link .brand-icon { width: 42px !important; height: 42px !important; }
  .brand-text strong { font-size: 14px; }
  .brand-text small { display: none; }
  .auth-brand-lockup { align-items: flex-start; }
  .auth-brand-lockup strong { font-size: 21px; }
}


/* MVP polish: dashboard widgets, alerts, timeline, search, empty states */
.metric-card .metric-big{font-size:34px;font-weight:800;margin:4px 0;color:#061735}.progress{height:8px;background:#edf2f7;border-radius:999px;overflow:hidden;margin-top:8px}.progress span{display:block;height:100%;background:linear-gradient(90deg,#2f5be7,#10a6a6);border-radius:999px}.alert-panel{border-left:4px solid #f59e0b}.inline-alert{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:12px 14px;border:1px solid #d7e0ef;border-radius:12px;margin:8px 0;background:#f8fafc}.inline-alert.warning{background:#fff8e6;border-color:#f8d47a}.inline-alert.danger{background:#fff1f2;border-color:#fecdd3}.inline-alert a{font-weight:700}.timeline{list-style:none;padding:0;margin:0}.timeline li{border-left:3px solid #d9e3f5;padding:0 0 14px 14px;margin:0 0 12px 0}.empty-state{padding:22px;border:1px dashed #cbd7ea;border-radius:16px;background:#f8fbff}.empty-state h3{margin:0 0 6px 0}.page-header-actions{display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap}.search-row{display:grid;grid-template-columns:1fr auto;gap:12px}.search-row input{min-height:46px}.dashboard-grid{align-items:stretch}@media(max-width:760px){.search-row{grid-template-columns:1fr}.page-header-actions{align-items:flex-start}.inline-alert{display:block}.inline-alert a{display:inline-block;margin-top:8px}}

/* Cleaner grouped navigation */
.topbar {
  gap: 24px;
  flex-wrap: nowrap;
}
.brand-link {
  margin-left: 0 !important;
  flex: 0 0 auto;
  gap: 10px;
}
.brand-link .brand-icon {
  width: 42px !important;
  height: 42px !important;
  max-width: 42px !important;
  filter: none !important;
}
.brand-text {
  display: grid;
  line-height: 1.05;
}
.brand-text strong {
  font-size: 18px;
  letter-spacing: -0.02em;
}
.brand-text small {
  font-size: 12px;
  opacity: .78;
  margin-top: 3px;
}
.main-nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  margin-left: auto;
  flex-wrap: wrap;
}
.topbar .main-nav a,
.topbar .main-nav summary {
  margin-left: 0;
  color: #fff;
  opacity: .92;
  text-decoration: none;
  font-weight: 700;
  border-radius: 10px;
  padding: 9px 11px;
  white-space: nowrap;
}
.topbar .main-nav a:hover,
.topbar .main-nav summary:hover,
.topbar .main-nav details[open] > summary {
  background: rgba(255,255,255,.10);
  opacity: 1;
  text-decoration: none;
}
.nav-menu {
  position: relative;
}
.nav-menu summary {
  list-style: none;
  cursor: pointer;
  user-select: none;
}
.nav-menu summary::-webkit-details-marker {
  display: none;
}
.nav-menu summary::after {
  content: "▾";
  font-size: 10px;
  margin-left: 7px;
  opacity: .72;
}
.nav-menu-panel {
  position: absolute;
  z-index: 1000;
  top: calc(100% + 10px);
  left: 0;
  min-width: 235px;
  padding: 10px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid var(--border);
  box-shadow: 0 20px 45px rgba(15, 23, 42, .18);
}
.nav-menu-panel-right {
  left: auto;
  right: 0;
}
.topbar .nav-menu-panel a {
  display: block;
  margin: 0;
  color: var(--ink);
  opacity: 1;
  padding: 11px 12px;
  border-radius: 10px;
  font-weight: 700;
}
.topbar .nav-menu-panel a:hover {
  background: var(--brand-soft);
  color: var(--brand-dark);
}
@media (max-width: 1100px) {
  .brand-text strong { font-size: 16px; }
  .brand-text small { display: none; }
  .topbar .main-nav a,
  .topbar .main-nav summary { padding: 8px 9px; font-size: 14px; }
}
@media (max-width: 900px) {
  .brand-text small { display: block; }
  .main-nav { align-items: stretch; justify-content: flex-start; }
  body.nav-open .topbar nav.main-nav { display: grid; }
  .topbar .main-nav a,
  .topbar .main-nav summary { display: block; width: 100%; padding: 11px 10px; }
  .nav-menu-panel,
  .nav-menu-panel-right {
    position: static;
    min-width: 0;
    margin: 4px 0 8px 10px;
    box-shadow: none;
    border-radius: 12px;
    background: rgba(255,255,255,.06);
    border-color: rgba(255,255,255,.12);
  }
  .topbar .nav-menu-panel a {
    color: #fff;
    background: transparent;
    padding: 9px 12px;
  }
  .topbar .nav-menu-panel a:hover {
    background: rgba(255,255,255,.08);
    color: #fff;
  }
}


/* Context return link - added 2026-05-27 */
.page-return {
  display: flex;
  justify-content: flex-start;
  margin: 0 0 16px;
}
.page-return .btn {
  box-shadow: none;
  border: 1px solid var(--border);
}
@media (max-width: 700px) {
  .page-return .btn { width: 100%; justify-content: center; }
}


/* Modern trainer profile page */
.profile-shell {
  max-width: 1160px;
  margin: 0 auto;
}
.profile-hero-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  background: linear-gradient(135deg, #ffffff 0%, #f7fbff 55%, #eef7ff 100%);
  border: 1px solid var(--border);
  border-radius: 28px;
  padding: 28px;
  box-shadow: var(--shadow);
  margin-bottom: 18px;
}
.profile-hero-main {
  display: flex;
  align-items: center;
  gap: 22px;
}
.profile-avatar,
.preview-avatar {
  width: 108px;
  height: 108px;
  border-radius: 28px;
  object-fit: cover;
  border: 4px solid #fff;
  box-shadow: 0 16px 34px rgba(40,84,216,.18);
  background: #eaf0ff;
}
.profile-avatar-placeholder {
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  font-weight: 900;
  font-size: 42px;
}
.profile-hero-card h1 {
  margin: 0 0 6px;
  font-size: 34px;
  letter-spacing: -.03em;
}
.profile-headline {
  margin: 0 0 6px;
  color: #344054;
  font-size: 17px;
  font-weight: 700;
}
.profile-strength-card {
  width: 250px;
  padding: 18px;
  background: rgba(255,255,255,.82);
  border: 1px solid var(--border);
  border-radius: 22px;
}
.profile-strength-card span {
  display: block;
  font-size: 32px;
  font-weight: 900;
  color: var(--brand);
  line-height: 1;
}
.profile-strength-card strong {
  display: block;
  margin: 6px 0 10px;
}
.profile-strength-card small {
  display: block;
  color: var(--muted);
  line-height: 1.35;
  margin-top: 10px;
}
.profile-progress {
  height: 10px;
  border-radius: 999px;
  background: #e8eefb;
  overflow: hidden;
}
.profile-progress em {
  display: block;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--brand), var(--brand2));
}
.profile-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 18px;
}
.profile-stat {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 18px;
  box-shadow: 0 8px 20px rgba(20,35,80,.04);
}
.profile-stat strong {
  display: block;
  font-size: 28px;
  color: var(--brand);
  line-height: 1;
}
.profile-stat span {
  display: block;
  color: var(--muted);
  font-weight: 700;
  margin-top: 7px;
}
.profile-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.profile-section h2 {
  margin-bottom: 6px;
}
.full-span { grid-column: 1 / -1; }
.trainer-preview-card {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  border: 1px solid var(--border);
  background: #f8fafc;
  border-radius: 20px;
  padding: 18px;
}
.trainer-preview-card .preview-avatar {
  width: 76px;
  height: 76px;
  border-radius: 20px;
  font-size: 30px;
  flex: 0 0 auto;
}
.trainer-preview-card strong {
  display: block;
  font-size: 20px;
  letter-spacing: -.02em;
}
.trainer-preview-card span {
  display: block;
  color: #344054;
  font-weight: 700;
  margin-top: 2px;
}
.trainer-preview-card p {
  margin: 8px 0 0;
  color: var(--muted);
}
.profile-save-bar {
  position: sticky;
  bottom: 14px;
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  padding: 14px;
  background: rgba(255,255,255,.86);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: 0 12px 30px rgba(20,35,80,.10);
  backdrop-filter: blur(12px);
}
@media (max-width: 900px) {
  .profile-hero-card,
  .profile-hero-main,
  .trainer-preview-card,
  .profile-save-bar {
    display: grid;
    justify-items: start;
  }
  .profile-strength-card { width: 100%; }
  .profile-stat-grid,
  .profile-form-grid { grid-template-columns: 1fr; }
  .profile-save-bar { position: static; }
}
@media (max-width: 560px) {
  .profile-hero-card { padding: 20px; border-radius: 22px; }
  .profile-hero-card h1 { font-size: 28px; }
  .profile-avatar { width: 88px; height: 88px; border-radius: 22px; }
}


/* Restored admin dashboard/sidebar styles */
.admin-layout {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}
.admin-sidebar-card {
  position: sticky;
  top: 104px;
  background: rgba(255,255,255,.92);
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 14px;
  box-shadow: var(--shadow);
}
.admin-sidebar-title {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 8px 10px 10px;
}
.admin-sidebar-card a {
  display: block;
  padding: 11px 12px;
  border-radius: 12px;
  color: var(--ink);
  font-weight: 800;
}
.admin-sidebar-card a:hover {
  background: var(--brand-soft);
  color: #1d3c8b;
  text-decoration: none;
}
.admin-main { min-width: 0; }
.admin-hero {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
}
.admin-hero h1 { margin: 0 0 8px; }
.admin-kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 18px 0;
}
.admin-kpi {
  display: block;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 18px;
  box-shadow: 0 8px 22px rgba(20,35,80,.05);
  color: var(--ink);
}
.admin-kpi:hover { text-decoration: none; transform: translateY(-1px); }
.admin-kpi strong { display:block; font-size: 32px; color: var(--brand); line-height: 1; }
.admin-kpi span { display:block; color: var(--muted); margin-top: 8px; font-weight: 800; }
.admin-kpi.ok strong { color: var(--ok); }
.admin-kpi.warn strong { color: #b54708; }
.admin-kpi.danger strong { color: var(--danger); }
.admin-dashboard-panels { align-items: start; }
.admin-timeline { display: grid; gap: 10px; }
.timeline-item {
  border-left: 4px solid var(--brand);
  background: #f8fafc;
  border-radius: 14px;
  padding: 10px 12px;
}
.timeline-item span { display:block; color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .04em; }
.timeline-item strong { display:block; }
.timeline-item small { color: var(--muted); }
.admin-filter-bar {
  margin-top: 18px;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr auto;
  gap: 12px;
  align-items: end;
  padding-bottom: 10px;
}
.admin-filter-bar .form-row { margin-bottom: 0; }
.admin-filter-actions { display:flex; gap:8px; }
.admin-users-table tbody tr:nth-child(even) td { background: #fcfdff; }
.status-dot { font-weight: 800; font-size: 13px; }
.status-dot::before { content:""; display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:6px; background: currentColor; }
.status-dot.ok { color: var(--ok); }
.status-dot.danger { color: var(--danger); }
.health-pill {
  display: inline-grid;
  gap: 2px;
  min-width: 112px;
  padding: 9px 11px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: #f8fafc;
}
.health-pill strong { font-size: 18px; line-height: 1; }
.health-pill span { color: var(--muted); font-weight: 800; font-size: 12px; }
.health-pill.ok { background:#ecfdf3; border-color:#abefc6; color:var(--ok); }
.health-pill.warn { background:#fff8e6; border-color:#ffe69c; color:#b54708; }
.health-pill.danger { background:#fef3f2; border-color:#fecdca; color:var(--danger); }
.admin-issue-list { color:#b54708; font-size: 12px; font-weight: 800; margin-top: 4px; }
.action-menu { position: relative; }
.action-menu summary {
  list-style: none;
  cursor: pointer;
  display: inline-block;
  background: var(--brand-soft);
  color: #1d3c8b;
  border-radius: 14px;
  padding: 12px 18px;
  font-weight: 800;
}
.action-menu summary::-webkit-details-marker { display: none; }
.action-menu div {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  min-width: 170px;
  z-index: 20;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 8px;
  box-shadow: 0 16px 35px rgba(2,6,23,.18);
}
.action-menu div a {
  display: block;
  padding: 10px 11px;
  border-radius: 10px;
  color: var(--ink);
}
.action-menu div a:hover { background: var(--brand-soft); text-decoration: none; }
@media (max-width: 1100px) {
  .admin-layout { grid-template-columns: 1fr; }
  .admin-sidebar-card { position: static; display:flex; gap:6px; overflow-x:auto; border-radius:18px; }
  .admin-sidebar-title { display:none; }
  .admin-sidebar-card a { white-space: nowrap; }
  .admin-filter-bar { grid-template-columns: 1fr 1fr; }
  .admin-filter-actions { grid-column: 1 / -1; }
}
@media (max-width: 700px) {
  .admin-hero { display: grid; }
  .admin-kpi-grid, .admin-filter-bar { grid-template-columns: 1fr; }
}

/* Canvas-style admin users list - 2026-05-26 */
.admin-user-panel { overflow: visible; }
.admin-section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 14px;
}
.admin-section-head h2 { margin: 0 0 6px; }
.admin-user-list {
  display: grid;
  gap: 10px;
}
.canvas-user-row {
  display: grid;
  grid-template-columns: minmax(280px, 1.45fr) minmax(240px, .9fr) minmax(190px, .75fr) minmax(180px, auto);
  gap: 18px;
  align-items: center;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 1px 0 rgba(15, 23, 42, .03);
}
.canvas-user-row:hover {
  border-color: #bdd0f7;
  background: #fcfdff;
}
.canvas-user-main {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  min-width: 0;
}
.canvas-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  background: #eef4ff;
  color: #1d4ed8;
  font-weight: 900;
  border: 1px solid #d6e4ff;
}
.canvas-user-text { min-width: 0; }
.canvas-user-text h3 {
  margin: 0 0 3px;
  font-size: 18px;
  line-height: 1.25;
}
.canvas-user-text p {
  margin: 0;
  color: var(--muted);
  overflow-wrap: anywhere;
}
.canvas-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 10px;
}
.canvas-issues {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}
.canvas-issues span {
  display: inline-flex;
  align-items: center;
  padding: 5px 8px;
  border-radius: 999px;
  background: #fff7ed;
  color: #9a3412;
  border: 1px solid #fed7aa;
  font-size: 12px;
  font-weight: 800;
}
.canvas-issues.ok span {
  background: #ecfdf3;
  color: var(--ok);
  border-color: #abefc6;
}
.canvas-user-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(44px, 1fr));
  gap: 8px;
}
.canvas-user-stats div {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 10px 8px;
  text-align: center;
  background: #f8fafc;
}
.canvas-user-stats strong {
  display: block;
  font-size: 20px;
  line-height: 1;
  color: var(--ink);
}
.canvas-user-stats span {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.canvas-health {
  min-width: 0;
}
.canvas-health-top {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
}
.canvas-health-top strong { font-size: 22px; }
.canvas-health-top span {
  color: var(--muted);
  font-weight: 900;
  font-size: 12px;
}
.canvas-health-bar {
  height: 8px;
  border-radius: 999px;
  background: #eef2f7;
  overflow: hidden;
  margin: 8px 0 6px;
}
.canvas-health-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--brand);
}
.canvas-health.ok .canvas-health-bar span { background: var(--ok); }
.canvas-health.warn .canvas-health-bar span { background: #f59e0b; }
.canvas-health.danger .canvas-health-bar span { background: var(--danger); }
.canvas-health small { color: var(--muted); font-weight: 700; }
.canvas-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.canvas-actions .btn { padding: 10px 14px; }
.empty-state {
  border: 1px dashed var(--border);
  border-radius: 16px;
  padding: 24px;
  color: var(--muted);
  text-align: center;
}
@media (max-width: 1260px) {
  .canvas-user-row {
    grid-template-columns: 1fr;
    align-items: stretch;
  }
  .canvas-actions { justify-content: flex-start; }
}
@media (max-width: 700px) {
  .canvas-user-row { padding: 14px; }
  .canvas-user-main { align-items: flex-start; }
  .canvas-user-stats { grid-template-columns: repeat(2, 1fr); }
  .canvas-actions { display: grid; grid-template-columns: 1fr; }
  .canvas-actions .btn, .canvas-actions .action-menu summary { text-align: center; width: 100%; }
}

/* Admin revamp v2 - calm Canvas-like layout, no horizontal scroll */
.admin-layout-canvas {
  grid-template-columns: 210px minmax(0, 920px);
  justify-content: center;
  gap: 24px;
}
.admin-main-canvas {
  width: 100%;
  max-width: 920px;
}
.admin-page-title,
.admin-search-panel,
.admin-list-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 10px 28px rgba(20,35,80,.06);
}
.admin-page-title {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  padding: 24px;
  margin-bottom: 16px;
}
.admin-page-title h1 { margin: 0 0 8px; font-size: 32px; }
.admin-search-panel {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) 130px 140px 150px auto auto;
  gap: 10px;
  padding: 16px;
  margin-bottom: 16px;
  align-items: center;
}
.admin-search-panel input,
.admin-search-panel select {
  min-width: 0;
  height: 44px;
}
.admin-list-card {
  padding: 0;
  overflow: hidden;
}
.admin-list-head {
  padding: 20px 24px;
  border-bottom: 1px solid var(--border);
  background: #fbfdff;
}
.admin-list-head h2 { margin: 0 0 6px; }
.admin-user-rows { display: grid; }
.admin-user-row-v2 {
  display: grid;
  grid-template-columns: minmax(250px, 1.35fr) minmax(210px, 1fr) minmax(150px, .72fr) minmax(190px, auto);
  gap: 18px;
  align-items: center;
  padding: 18px 24px;
  border-bottom: 1px solid var(--border);
  background: #fff;
}
.admin-user-row-v2:last-child { border-bottom: 0; }
.admin-user-row-v2:hover { background: #f8fbff; }
.user-identity { display: flex; align-items: flex-start; gap: 13px; min-width: 0; }
.user-identity h3 { margin: 0 0 3px; font-size: 18px; }
.user-identity p { margin: 0; color: var(--muted); overflow-wrap: anywhere; }
.user-badges { display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; align-items:center; }
.user-readiness { min-width: 0; }
.readiness-label { display:flex; justify-content:space-between; gap:8px; align-items:baseline; }
.readiness-label strong { font-size: 20px; }
.readiness-label span { color: var(--muted); font-weight: 900; font-size: 12px; }
.user-readiness.ok .canvas-health-bar span { background: var(--ok); }
.user-readiness.warn .canvas-health-bar span { background: #f59e0b; }
.user-readiness.danger .canvas-health-bar span { background: var(--danger); }
.issue-line { margin-top: 7px; color: #9a3412; font-size: 12px; font-weight: 800; line-height: 1.35; }
.issue-line.ok { color: var(--ok); }
.user-counts { display: grid; gap: 6px; color: var(--muted); font-size: 13px; }
.user-counts span { display:flex; justify-content:space-between; gap:10px; border-bottom: 1px dotted #d9e2f1; padding-bottom: 4px; }
.user-counts span:last-child { border-bottom: 0; padding-bottom: 0; }
.user-counts strong { color: var(--ink); }
.user-row-actions { display:flex; justify-content:flex-end; gap:8px; align-items:center; flex-wrap:wrap; }
.user-row-actions .btn { padding: 10px 13px; }
@media (max-width: 1180px) {
  .admin-layout-canvas { grid-template-columns: 1fr; max-width: 980px; margin-inline:auto; }
  .admin-main-canvas { max-width: none; }
}
@media (max-width: 980px) {
  .admin-search-panel { grid-template-columns: 1fr 1fr; }
  .admin-user-row-v2 { grid-template-columns: 1fr; align-items: stretch; }
  .user-row-actions { justify-content: flex-start; }
}
@media (max-width: 620px) {
  .admin-page-title { display:grid; padding: 18px; }
  .admin-search-panel { grid-template-columns: 1fr; }
  .admin-user-row-v2 { padding: 16px; }
  .user-identity { align-items:flex-start; }
}

/* Admin refinement v3 - Canvas-lite, flatter rows, no horizontal scroll */
.admin-layout-refined {
  grid-template-columns: 210px minmax(0, 980px);
  justify-content: center;
  gap: 24px;
  align-items: start;
}
.admin-main-refined {
  width: 100%;
  max-width: 980px;
}
.admin-layout-refined .admin-sidebar-card {
  box-shadow: none;
  border-radius: 12px;
  padding: 14px 0;
  border-color: #d8dee8;
  background: #fff;
}
.admin-layout-refined .admin-sidebar-title {
  padding: 0 18px 12px;
  color: #6b7280;
  font-size: 12px;
}
.admin-layout-refined .admin-sidebar-card a {
  border-radius: 0;
  padding: 11px 18px;
  font-size: 15px;
  border-left: 3px solid transparent;
}
.admin-layout-refined .admin-sidebar-card a:hover {
  background: #f5f9fc;
  border-left-color: #0ea5c6;
}
.admin-page-title-refined,
.admin-filter-bar,
.admin-users-panel {
  background: #fff;
  border: 1px solid #d8dee8;
  border-radius: 12px;
  box-shadow: none;
}
.admin-page-title-refined {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  padding: 22px 24px;
  margin-bottom: 14px;
}
.admin-page-title-refined h1 {
  margin: 0 0 7px;
  font-size: 30px;
  line-height: 1.15;
}
.admin-filter-bar {
  display: grid;
  grid-template-columns: minmax(260px, 1.3fr) 130px 145px 155px auto;
  gap: 12px;
  padding: 16px 18px;
  margin-bottom: 14px;
  align-items: end;
}
.admin-filter-bar label {
  display: block;
  margin: 0 0 6px;
  color: #344054;
  font-weight: 800;
  font-size: 13px;
}
.admin-filter-bar input,
.admin-filter-bar select {
  height: 42px;
  width: 100%;
  min-width: 0;
}
.filter-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}
.filter-actions .btn { height: 42px; display: inline-flex; align-items: center; }
.admin-users-panel { overflow: hidden; }
.admin-users-panel-head {
  padding: 18px 22px;
  border-bottom: 1px solid #d8dee8;
  background: #fbfdff;
}
.admin-users-panel-head h2 {
  margin: 0 0 4px;
  font-size: 22px;
}
.admin-user-list-refined { display: grid; }
.admin-user-line {
  display: grid;
  grid-template-columns: minmax(230px, 1.25fr) minmax(250px, 1.25fr) minmax(170px, .8fr) minmax(120px, auto);
  gap: 18px;
  align-items: center;
  padding: 18px 22px;
  border-bottom: 1px solid #d8dee8;
  background: #fff;
}
.admin-user-line:last-child { border-bottom: 0; }
.admin-user-line:hover { background: #fbfdff; }
.admin-user-person {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  min-width: 0;
}
.canvas-avatar.small {
  width: 36px;
  height: 36px;
  font-size: 14px;
}
.admin-user-nameblock { min-width: 0; }
.admin-user-nameblock h3 {
  margin: 0 0 3px;
  font-size: 17px;
  line-height: 1.25;
}
.admin-user-nameblock p {
  margin: 0;
  color: #475467;
  overflow-wrap: anywhere;
}
.admin-user-meta,
.evidence-counts-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 9px;
  color: #475467;
  font-size: 13px;
}
.admin-user-meta span:not(.status-dot) {
  padding-right: 10px;
  border-right: 1px solid #d8dee8;
}
.admin-user-meta span:last-child { border-right: 0; }
.evidence-counts-inline { margin-top: 0; gap: 14px; }
.evidence-counts-inline span { white-space: nowrap; }
.evidence-counts-inline strong {
  color: #101828;
  font-size: 16px;
}
.admin-empty-note {
  margin: 8px 0 0;
  color: #9a3412;
  font-size: 13px;
  line-height: 1.4;
}
.admin-empty-note.ok { color: #087443; }
.admin-user-health { min-width: 0; }
.health-compact-top {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: baseline;
}
.health-compact-top strong { font-size: 20px; }
.health-compact-top span {
  color: #475467;
  font-weight: 800;
  font-size: 12px;
}
.admin-user-line.ok .canvas-health-bar span { background: var(--ok); }
.admin-user-line.warn .canvas-health-bar span { background: #f59e0b; }
.admin-user-line.danger .canvas-health-bar span { background: var(--danger); }
.admin-user-health small {
  display: block;
  color: #667085;
  font-size: 12px;
  line-height: 1.35;
}
.admin-user-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.admin-user-actions .btn,
.admin-user-actions .action-menu summary {
  padding: 9px 12px;
  min-height: 38px;
}
@media (max-width: 1180px) {
  .admin-layout-refined {
    grid-template-columns: 1fr;
    max-width: 980px;
    margin-inline: auto;
  }
  .admin-layout-refined .admin-sidebar-card {
    position: static;
    display: flex;
    gap: 0;
    overflow-x: auto;
    padding: 0;
  }
  .admin-layout-refined .admin-sidebar-title { display: none; }
  .admin-layout-refined .admin-sidebar-card a {
    white-space: nowrap;
    border-left: 0;
    border-bottom: 3px solid transparent;
  }
  .admin-layout-refined .admin-sidebar-card a:hover { border-bottom-color: #0ea5c6; }
}
@media (max-width: 980px) {
  .admin-filter-bar { grid-template-columns: 1fr 1fr; }
  .filter-search { grid-column: 1 / -1; }
  .admin-user-line { grid-template-columns: 1fr; align-items: stretch; }
  .admin-user-actions { justify-content: flex-start; }
}
@media (max-width: 620px) {
  .admin-page-title-refined { display: grid; padding: 18px; }
  .admin-filter-bar { grid-template-columns: 1fr; }
  .admin-user-line { padding: 16px; gap: 14px; }
  .filter-actions { display: grid; grid-template-columns: 1fr 1fr; }
  .admin-user-actions { display: grid; grid-template-columns: 1fr 1fr; }
  .admin-user-actions .action-menu summary, .admin-user-actions .btn { text-align: center; justify-content: center; }
}

/* Canvas-like admin user profile refinement */
.admin-user-name-link {
  color: #0ea5c6;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.admin-user-name-link:hover { color: #087f9b; }
.admin-user-actions-links {
  justify-content: flex-start;
  align-content: center;
  gap: 8px 12px;
}
.admin-user-actions-links a {
  color: #0ea5c6;
  font-weight: 700;
  font-size: 13px;
  text-decoration: none;
  white-space: nowrap;
}
.admin-user-actions-links a:hover { text-decoration: underline; }
.canvas-admin-profile-head {
  background: #fff;
  border: 1px solid #d8dee8;
  border-radius: 12px;
  padding: 24px;
  margin-bottom: 16px;
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 18px;
  align-items: start;
}
.canvas-avatar.large {
  width: 64px;
  height: 64px;
  font-size: 24px;
}
.canvas-admin-profile-head h1 {
  margin: 0 0 6px;
  font-size: 31px;
  line-height: 1.15;
}
.canvas-profile-links {
  display: flex;
  gap: 6px 12px;
  flex-wrap: wrap;
  margin-top: 12px;
  font-size: 13px;
}
.canvas-profile-links a {
  color: #0ea5c6;
  font-weight: 700;
  text-decoration: none;
}
.canvas-profile-links a:hover { text-decoration: underline; }
.canvas-profile-links .danger-link { color: #b42318; }
.canvas-admin-section {
  background: #fff;
  border: 1px solid #d8dee8;
  border-radius: 12px;
  padding: 22px 24px;
  margin-bottom: 16px;
  box-shadow: none;
}
.canvas-admin-section h2 {
  margin: 0 0 16px;
  font-size: 20px;
  line-height: 1.2;
  font-weight: 800;
}
.canvas-admin-form .form-row { margin-bottom: 16px; }
.canvas-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 2px 0 16px;
  font-weight: 800;
}
.canvas-check input { width: auto; }
.canvas-login-row {
  border: 1px solid #d8dee8;
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 16px;
  background: #fbfdff;
}
.compact-password-form {
  max-width: 760px;
}
.canvas-evidence-summary {
  display: grid;
  grid-template-columns: repeat(5, minmax(120px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.canvas-evidence-summary div {
  border: 1px solid #d8dee8;
  border-radius: 10px;
  background: #fbfdff;
  padding: 14px;
}
.canvas-evidence-summary strong {
  display: block;
  font-size: 22px;
  margin-bottom: 2px;
}
.canvas-evidence-summary span {
  color: #475467;
  font-size: 13px;
  font-weight: 700;
}
.canvas-issues {
  border: 1px solid #fed7aa;
  background: #fff7ed;
  color: #9a3412;
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 12px;
}
@media (max-width: 980px) {
  .canvas-evidence-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .canvas-admin-profile-head { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .canvas-admin-section, .canvas-admin-profile-head { padding: 18px; }
  .canvas-evidence-summary { grid-template-columns: 1fr; }
}

/* Admin real-estate refinement: name links drive actions, last-login uses final column */
.admin-user-line {
  grid-template-columns: minmax(240px, 1.25fr) minmax(250px, 1.25fr) minmax(180px, .9fr) minmax(170px, .8fr);
}
.admin-user-login-summary {
  border-left: 1px solid #d8dee8;
  padding-left: 16px;
  min-width: 0;
}
.admin-user-login-summary span {
  display: block;
  color: #667085;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .03em;
  margin-bottom: 4px;
}
.admin-user-login-summary strong {
  display: block;
  color: #101828;
  font-size: 14px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.admin-user-login-summary small {
  display: block;
  color: #667085;
  line-height: 1.35;
  margin-top: 6px;
}
.admin-user-name-link {
  text-decoration: none;
  font-weight: 800;
}
.admin-user-name-link:hover {
  text-decoration: underline;
}

/* Admin user profile: put login and password where admins need it first */
.admin-profile-head-functional {
  grid-template-columns: 64px minmax(0, 1fr) minmax(230px, auto);
  align-items: center;
}
.admin-profile-title-block { min-width: 0; }
.admin-login-at-a-glance {
  border: 1px solid #d8dee8;
  border-radius: 10px;
  background: #fbfdff;
  padding: 14px 16px;
  min-width: 230px;
}
.admin-login-at-a-glance span,
.admin-login-detail span {
  display: block;
  color: #667085;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .03em;
  margin-bottom: 4px;
}
.admin-login-at-a-glance strong,
.admin-login-detail strong {
  display: block;
  color: #101828;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.admin-login-at-a-glance a {
  display: inline-flex;
  margin-top: 10px;
  color: #0ea5c6;
  font-weight: 800;
  text-decoration: none;
}
.admin-login-at-a-glance a:hover { text-decoration: underline; }
.admin-priority-section {
  border-color: #b8c7df;
  background: #ffffff;
}
.section-heading-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 16px;
}
.section-heading-row h2 { margin-bottom: 4px; }
.section-intro { margin-top: -8px; margin-bottom: 16px; }
.admin-login-details-grid {
  display: grid;
  grid-template-columns: minmax(220px, 1.4fr) minmax(100px, .5fr) minmax(180px, 1fr);
  gap: 10px;
  margin-bottom: 18px;
}
.admin-login-detail {
  border: 1px solid #d8dee8;
  border-radius: 10px;
  background: #fbfdff;
  padding: 14px;
  min-width: 0;
}
.compact-password-form {
  max-width: none;
  border-top: 1px solid #e5eaf2;
  padding-top: 16px;
}
.compact-password-form .actions {
  margin-top: 0;
}
@media (max-width: 1180px) {
  .admin-profile-head-functional { grid-template-columns: 64px 1fr; }
  .admin-login-at-a-glance { grid-column: 1 / -1; }
}
@media (max-width: 980px) {
  .admin-user-line { grid-template-columns: 1fr; }
  .admin-user-login-summary {
    border-left: 0;
    border-top: 1px solid #e5eaf2;
    padding-left: 0;
    padding-top: 12px;
  }
  .admin-login-details-grid { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .admin-profile-head-functional { grid-template-columns: 1fr; }
  .admin-login-at-a-glance { min-width: 0; }
}

/* Admin login tracking polish */
.admin-login-at-a-glance small {
  display: block;
  margin-top: 5px;
  color: #667085;
  line-height: 1.35;
}
.admin-login-details-grid.enhanced {
  grid-template-columns: repeat(4, minmax(150px, 1fr));
}
.admin-update-summary {
  border: 1px solid #b8c7df;
  background: #f8fbff;
  border-radius: 10px;
  padding: 12px 14px;
  margin: 0 0 16px;
  color: #344054;
  line-height: 1.45;
}
.admin-login-history {
  margin-bottom: 18px;
  border: 1px solid #d8dee8;
  border-radius: 10px;
  overflow: hidden;
}
.admin-login-history h3 {
  margin: 0;
  padding: 12px 14px;
  border-bottom: 1px solid #e5eaf2;
  font-size: 16px;
}
.admin-login-history table {
  width: 100%;
  border-collapse: collapse;
}
.admin-login-history th,
.admin-login-history td {
  text-align: left;
  padding: 10px 14px;
  border-bottom: 1px solid #eef2f7;
}
.admin-login-history tr:last-child td { border-bottom: 0; }
@media (max-width: 1180px) {
  .admin-login-details-grid.enhanced { grid-template-columns: repeat(2, minmax(150px, 1fr)); }
}
@media (max-width: 620px) {
  .admin-login-details-grid.enhanced { grid-template-columns: 1fr; }
}


/* Admin login redirect / mode toggle polish */
.admin-mode-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #26364a;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
  white-space: nowrap;
}
.admin-mode-pill::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #82d38a;
  display: inline-block;
}
.admin-view-link,
.trainer-view-link {
  font-weight: 600;
}
.trainer-view-link {
  border: 1px solid #d8dee8;
  border-radius: 8px;
  padding-inline: 10px;
  background: #fff;
}
@media (max-width: 760px) {
  .admin-mode-pill {
    align-self: flex-start;
    margin: 6px 0;
  }
  .trainer-view-link {
    display: inline-flex;
    width: fit-content;
  }
}

/* Admin levels polish */
.admin-sidebar-subtitle {
  font-size: 12px;
  color: #6b7280;
  margin: -6px 0 10px;
}
.admin-level-badge {
  display: inline-flex;
  align-items: center;
  border: 1px solid #d1d5db;
  background: #f9fafb;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 12px;
  color: #374151;
}
.admin-level-summary {
  border-left: 4px solid #475569;
}

/* Admin navigation cleanup */
.topbar .main-nav .admin-nav-menu-left > summary {
  background: transparent;
  border: 1px solid rgba(255,255,255,.10);
}
.topbar .main-nav .admin-nav-menu-left[open] > summary,
.topbar .main-nav .admin-nav-menu-left > summary:hover {
  background: rgba(255,255,255,.10);
}
.admin-version-footer {
  display: inline-block;
  margin-left: 12px;
  color: #667085;
  font-size: 12px;
  font-weight: 600;
}

/* Matrix section shortcut list on trainer dashboard */
.matrix-section-card .eyebrow { margin-bottom: 6px; }
.matrix-section-list { margin-top: 18px; border: 1px solid var(--border); border-radius: 18px; overflow: hidden; background: #fff; }
.matrix-section-list a { display: grid; grid-template-columns: minmax(230px, 0.9fr) 1.4fr 24px; gap: 18px; align-items: center; padding: 14px 18px; border-bottom: 1px solid var(--border); color: var(--ink); text-decoration: none; }
.matrix-section-list a:last-child { border-bottom: 0; }
.matrix-section-list a:hover { background: #f8fafc; text-decoration: none; }
.matrix-section-list a strong { color: var(--brand); }
.matrix-section-list a span { color: var(--muted); font-weight: 400; }
.matrix-section-list a::after { content: '→'; color: var(--brand); font-weight: 800; text-align: right; }

/* Status badge colours used across PD, planning and evidence tables */
.badge.status-complete, .badge.status-completed { background: #dcfce7; color: #166534; }
.badge.status-draft { background: #ffedd5; color: #9a3412; }
.badge.status-planned { background: #eef4ff; color: #1d3c8b; }
.badge.status-in_progress { background: #fef3c7; color: #92400e; }

@media (max-width: 760px) {
  .matrix-section-list a { grid-template-columns: 1fr; gap: 4px; }
  .matrix-section-list a::after { display: none; }
}
.section-update-link { float: right; font-size: 12px; padding: 4px 9px; border-radius: 999px; background: var(--brand-soft); color: #1d3c8b !important; border: 1px solid var(--border); }
.section-update-link:hover { text-decoration: none; background: #dbeafe; }

/* Trainer profile multi-select chips for VET specialisations */
.checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
  margin-top: 8px;
}
.check-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid #d9e1ef;
  border-radius: 12px;
  background: #f8fafc;
  font-weight: 600;
  color: #1f2937;
}
.check-pill input { width: auto; }
.check-pill:has(input:checked) {
  background: #ecfdf3;
  border-color: #86efac;
  color: #166534;
}

/* Manual unit scope status badges */
.badge.badge-green { background: #dcfce7; color: #166534; }
.badge.badge-orange { background: #ffedd5; color: #9a3412; }

/* Qualification unit lookup/import */
.card-subtle {
  border: 1px solid #d7dee8;
  background: #f8fafc;
  border-radius: 14px;
  padding: 16px;
  margin: 16px 0;
}
.unit-select-row:hover {
  background: #f8fafc !important;
  border-color: #b8c7da !important;
}
.unit-select-row input:checked + span strong {
  color: #166534;
}
