:root{
  --ink:#101827;
  --muted:#667085;
  --subtle:#8a96a8;
  --line:#d9e2ec;
  --line-soft:#edf2f7;
  --soft:#eef4f8;
  --panel:#fff;
  --brand:#001e39;
  --brand-2:#062b4d;
  --blue:#126da8;
  --blue-soft:#e8f3fb;
  --green:#157347;
  --green-soft:#e8f6ee;
  --amber:#b86e00;
  --amber-soft:#fff4df;
  --red:#b42318;
  --red-soft:#fff0ef;
  --purple:#684fb6;
  --purple-soft:#f0ecff;
  --shadow:0 14px 32px rgba(17,24,39,.08);
  --shadow-sm:0 6px 18px rgba(17,24,39,.06);
  --radius:8px;
}

*{box-sizing:border-box}
[hidden]{display:none!important}
html{min-height:100%}
body{
  margin:0;
  min-height:100vh;
  background:var(--soft);
  color:var(--ink);
  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:15px;
  line-height:1.45;
  letter-spacing:0;
}
a{color:inherit}
button,input,select{letter-spacing:0}
.page-shell{width:min(1280px,calc(100% - 48px));margin:0 auto}
.portal-body--app .page-shell{
  width:min(1520px,calc(100% - 64px));
  margin-left:clamp(24px,2.5vw,48px);
  margin-right:auto;
}
.main-shell{padding:26px 0 52px}

.portal-body--app{background:linear-gradient(180deg,#edf4fa 0,#f6f8fb 34%,#f8fafc 100%)}
.portal-app-shell{display:grid;grid-template-columns:282px minmax(0,1fr);min-height:100vh}
.portal-sidebar{
  position:sticky;
  top:0;
  display:flex;
  flex-direction:column;
  gap:24px;
  height:100vh;
  padding:22px 18px;
  background:linear-gradient(180deg,#061b31 0,#09243f 100%);
  color:#dce8f5;
  border-right:1px solid rgba(255,255,255,.08);
}
.portal-brand{
  display:grid;
  gap:6px;
  justify-items:start;
  min-height:54px;
  padding:8px 10px;
  color:#fff;
  text-decoration:none;
}
.portal-brand__logo-wrap{display:block;max-width:178px;line-height:0}
.portal-brand__logo{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
}
.portal-brand__logo--blue{display:none}
.portal-brand__mark,.brand__mark{
  display:flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:8px;
  background:#fff;
  color:var(--brand);
  font-size:12px;
  font-weight:700;
}
.portal-brand strong,.brand strong{display:block;font-size:16px;font-weight:750;line-height:1.2}
.portal-brand small,.brand small{display:block;color:#a9b9ca;font-size:12px;line-height:1.3}
.portal-sidebar__nav{display:grid;gap:22px;min-width:0}
.portal-nav-group{display:grid;gap:6px}
.portal-nav-group__label{
  display:block;
  padding:0 10px 4px;
  color:#8fa2b7;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0;
}
.portal-nav-link{
  position:relative;
  display:flex;
  align-items:center;
  gap:11px;
  min-height:42px;
  padding:0 10px;
  border-radius:8px;
  color:#dce8f5;
  font-size:14px;
  text-decoration:none;
}
.portal-nav-link:hover{background:rgba(255,255,255,.08);color:#fff}
.portal-nav-link.is-active{background:#fff;color:#061b31;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.portal-nav-link.is-active::before{
  content:"";
  position:absolute;
  left:-18px;
  top:9px;
  width:4px;
  height:24px;
  border-radius:0 4px 4px 0;
  background:#39a3dc;
}
.portal-nav-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:25px;
  height:25px;
  border-radius:7px;
  background:rgba(255,255,255,.1);
  color:inherit;
  font-size:12px;
}
.portal-nav-icon svg{
  width:15px;
  height:15px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-nav-link.is-active .portal-nav-icon{background:#eaf4fb;color:#0b5c8d}
.portal-sidebar__footer{
  display:grid;
  gap:12px;
  margin-top:auto;
  padding-top:16px;
  border-top:1px solid rgba(255,255,255,.12);
}
.portal-user-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:10px;
  align-items:center;
  padding:10px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:8px;
  background:rgba(255,255,255,.06);
}
.portal-avatar{
  display:flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:999px;
  background:#d9f0ff;
  color:#06365c;
  font-size:12px;
  font-weight:730;
}
.portal-user-card strong,.portal-user-card small{
  display:block;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-user-card strong{color:#fff;font-size:13px;font-weight:700}
.portal-user-card small{color:#a9b9ca;font-size:12px}
.portal-workspace{min-width:0}
.portal-topbar{
  position:sticky;
  top:0;
  z-index:9;
  min-height:76px;
  padding:0;
  background:rgba(255,255,255,.84);
  border-bottom:1px solid rgba(217,226,236,.9);
  backdrop-filter:blur(14px);
}
.portal-topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  min-height:76px;
}
.portal-topbar span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase}
.portal-topbar strong{display:block;margin-top:2px;color:var(--ink);font-size:19px;font-weight:750}

.portal-body--auth{
  background:
    radial-gradient(circle at top left,rgba(18,109,168,.12),transparent 34%),
    linear-gradient(180deg,#f4f8fc 0,#f8fbfd 46%,#eef4f8 100%);
}

.site-header{
  position:sticky;
  top:0;
  z-index:10;
  background:rgba(255,255,255,.88);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(14px);
}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:72px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink);text-decoration:none}
.brand__logo-wrap{
  display:flex;
  align-items:center;
  width:156px;
  line-height:0;
}
.brand__logo{
  display:block;
  width:100%;
  height:auto;
}
.brand__mark{background:var(--brand);color:#fff}
.brand small{color:var(--muted)}
.top-nav{display:flex;align-items:center;gap:8px}
.top-nav a,.nav-button,.secondary-button,.primary-button,.small-button{
  transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .15s ease;
}
.top-nav a,.secondary-button,.nav-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 14px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fff;
  color:#334155;
  font:inherit;
  font-size:14px;
  font-weight:750;
  text-decoration:none;
  white-space:nowrap;
  cursor:pointer;
}
.top-nav a:hover,.secondary-button:hover,.nav-button:hover{background:#f7fafc;border-color:#bccbda}
.nav-button--full{width:100%;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14);color:#fff}
.nav-button--full:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.22)}
.header-form{margin:0}

.notice{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-bottom:18px;
  padding:14px 16px;
  border:1px solid #b8d8f0;
  border-radius:8px;
  background:#eff7fd;
  color:#164f78;
  box-shadow:var(--shadow-sm);
}
.notice.is-error{border-color:#fac5c0;background:var(--red-soft);color:#991b1b}
.notice.is-success{border-color:#b9e5c9;background:var(--green-soft);color:#166534}
.notice strong{white-space:nowrap;font-weight:740}
code{font-family:"SFMono-Regular",Consolas,monospace;font-size:.95em}

.hero-panel{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(240px,300px);
  gap:22px;
  align-items:stretch;
  margin-bottom:18px;
  padding:26px;
  border:1px solid #d8e4ef;
  border-radius:8px;
  background:#fff;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.hero-panel::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:4px;
  background:linear-gradient(90deg,#001e39,#126da8,#16a36f);
}
.hero-panel--compact{align-items:center}
.company-hero{background:linear-gradient(180deg,#fff 0,#f8fbff 100%)}
.eyebrow{
  margin:0 0 8px;
  color:#126da8;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0;
}
h1,h2,h3,p{letter-spacing:0}
h1{margin:0;color:var(--ink);font-size:34px;line-height:1.12;font-weight:760}
h2{margin:0 0 16px;color:#182230;font-size:19px;line-height:1.25;font-weight:740}
.hero-copy{max-width:720px;margin:10px 0 0;color:#475569;font-size:15px;line-height:1.6}
.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.hero-actions--stacked{align-items:stretch;flex-direction:column}
.status-card{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:6px;
  padding:18px;
  border:1px solid #dce7f2;
  border-radius:8px;
  background:#f8fbfe;
}
.status-card__label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:0}
.status-card strong{font-size:24px;line-height:1.15;font-weight:760}
.status-card small{color:var(--muted);font-size:13px;line-height:1.35}
.status-card.is-ready strong{color:var(--green)}
.status-card.is-blocked strong{color:#b54708}

.metric-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:18px}
.metric-card{
  position:relative;
  padding:18px;
  border:1px solid #dce7f2;
  border-radius:8px;
  background:#fff;
  box-shadow:var(--shadow-sm);
}
.metric-card::after{
  content:"";
  position:absolute;
  right:16px;
  top:16px;
  width:8px;
  height:8px;
  border-radius:999px;
  background:#c3d4e3;
}
.metric-card span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:0}
.metric-card strong{display:block;margin-top:7px;color:#0b1f33;font-size:28px;line-height:1;font-weight:650}

.content-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.56fr);gap:18px;align-items:start}
.content-grid--wide{grid-template-columns:minmax(0,1.45fr) minmax(320px,.55fr)}
.panel{
  padding:22px;
  border:1px solid #dce7f2;
  border-radius:8px;
  background:#fff;
  box-shadow:var(--shadow-sm);
}
.panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.panel-heading--compact{margin-bottom:12px}
.panel-heading h2{margin-bottom:0}
.panel-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:32px;
  height:30px;
  padding:0 9px;
  border:1px solid #d6e0eb;
  border-radius:999px;
  background:#f7fafc;
  color:#334155;
  font-size:13px;
}
.page-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:18px;padding:8px 0 6px}
.page-heading--toolbar{align-items:center}
.page-heading h1{font-size:31px}
.page-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px}

.primary-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border:1px solid var(--brand);
  border-radius:8px;
  background:var(--brand);
  color:#fff;
  font:inherit;
  font-size:14px;
  font-weight:720;
  text-decoration:none;
  cursor:pointer;
  white-space:nowrap;
}
.primary-button:hover{background:#062b4d;box-shadow:0 3px 8px rgba(0,30,57,.1);transform:none}
.primary-button:disabled,
.primary-button[aria-disabled="true"]{
  border-color:#d8e1eb;
  background:#eef3f8;
  color:#7b8ba0;
  box-shadow:none;
  cursor:not-allowed;
}
.primary-button:disabled:hover{
  background:#eef3f8;
  box-shadow:none;
}
.primary-button--compact,.secondary-button--compact{min-height:34px;padding:0 12px;font-size:13px}
.small-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:0 12px;
  border:1px solid var(--brand);
  border-radius:8px;
  background:var(--brand);
  color:#fff;
  font:inherit;
  font-size:13px;
  font-weight:720;
  cursor:pointer;
}
.small-button:disabled{border-color:#cbd5e1;background:#e2e8f0;color:#64748b;cursor:not-allowed}

.portal-body--auth .page-shell{
  width:100%;
  max-width:none;
  margin:0;
}
.portal-body--auth .main-shell{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-height:100vh;
  padding:clamp(28px,6vh,64px) 20px;
}
.portal-body--auth .notice{
  width:min(460px,100%);
  margin:0 0 14px;
  box-shadow:none;
}
.auth-shell{
  display:flex;
  justify-content:center;
  width:100%;
}
.auth-panel{
  position:relative;
  width:min(460px,100%);
  overflow:hidden;
  border:1px solid rgba(203,213,225,.88);
  border-radius:22px;
  background:#fff;
  box-shadow:0 26px 70px -42px rgba(15,23,42,.5),0 12px 30px -28px rgba(15,23,42,.28);
}
.auth-panel::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:4px;
  background:linear-gradient(90deg,#0ea5e9 0%,#2563eb 52%,#22c55e 100%);
}
.auth-copy{
  display:grid;
  justify-items:center;
  gap:16px;
  padding:34px 38px 22px;
  border-bottom:1px solid #eef2f7;
  background:#fff;
  text-align:center;
}
.auth-logo{
  display:block;
  width:min(260px,82%);
  height:auto;
}
.auth-product{
  display:grid;
  gap:3px;
}
.auth-product span{
  color:#64748b;
  font-size:12px;
  line-height:1.2;
  text-transform:uppercase;
}
.auth-product strong{
  color:#0f172a;
  font-size:24px;
  font-weight:760;
  line-height:1.16;
}
.auth-support-copy{
  max-width:340px;
  margin:2px auto 0;
  color:#64748b;
  font-size:13px;
  line-height:1.45;
}
.auth-card{
  display:grid;
  gap:0;
  margin:0;
  padding:24px 38px 34px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.auth-form-fields{
  display:grid;
  gap:16px;
}
.auth-actions{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:12px;
  padding-top:20px;
}
.auth-card__footer{
  display:flex;
  justify-content:center;
  color:#64748b;
  font-size:13px;
  line-height:1.4;
  text-align:center;
}
.auth-link{
  align-self:center;
  color:#2563eb;
  font-size:13px;
  text-decoration:none;
}
.auth-link--inline{align-self:auto}
.auth-link:hover{text-decoration:underline}
.auth-link:focus-visible,.text-action-button:focus-visible,.primary-button:focus-visible,.secondary-button:focus-visible,.nav-button:focus-visible,.top-nav a:focus-visible,.portal-nav-link:focus-visible{
  outline:3px solid rgba(37,99,235,.16);
  outline-offset:3px;
}
.auth-form-help{
  margin:0;
  color:#64748b;
  font-size:12px;
  line-height:1.4;
}
.auth-invite-context{
  margin:0 0 16px;
  padding:12px 14px;
  border:1px solid #d8e2ee;
  border-radius:12px;
  background:#f8fafc;
  color:#64748b;
  font-size:13px;
  line-height:1.45;
}
.auth-invite-context strong{color:#0f172a}
.field{display:grid;gap:7px;color:#475569;font-size:12px}
.field__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.field__row label{margin:0}
.auth-input-wrap{
  display:grid;
  grid-template-columns:18px minmax(0,1fr);
  align-items:center;
  gap:10px;
  min-height:44px;
  padding:0 13px;
  border:1px solid #d8e2ee;
  border-radius:12px;
  background:#fff;
  transition:border-color .14s ease,box-shadow .14s ease,background-color .14s ease;
}
.auth-input-wrap:focus-within{
  border-color:#93c5fd;
  background:#fbfdff;
  box-shadow:0 0 0 4px rgba(37,99,235,.1);
}
.auth-input-wrap svg{
  width:18px;
  height:18px;
  fill:none;
  stroke:#94a3b8;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.field input,.field select,.inline-create-form input,.inline-link-form select,.compact-select-form select{
  width:100%;
  height:44px;
  padding:0 13px;
  border:1px solid #cbd8e5;
  border-radius:8px;
  background:#fff;
  color:var(--ink);
  font:inherit;
  font-size:15px;
  font-weight:620;
  outline:none;
}
.auth-input-wrap input,
.auth-input-wrap input[type="email"],
.auth-input-wrap input[type="password"],
.auth-input-wrap input[type="text"]{
  width:100%;
  height:42px;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  color:#0f172a;
  font-size:14px;
  font-weight:600;
  box-shadow:none;
}
.auth-input-wrap input:focus{border:0;box-shadow:none}
.auth-card .primary-button{
  width:100%;
  min-height:44px;
  border-color:#2563eb;
  border-radius:12px;
  background:#2563eb;
  font-size:14px;
  font-weight:760;
}
.auth-card .primary-button:hover{background:#1d4ed8;box-shadow:0 0 0 2px rgba(37,99,235,.1);transform:none}
.field select,.inline-link-form select,.compact-select-form select{
  appearance:none;
  padding-right:38px;
  background-image:url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 6L8 10L12 6' stroke='%23475569' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
}
.field input:focus,.field select:focus,.inline-create-form input:focus,.inline-link-form select:focus,.compact-select-form select:focus{
  border-color:#126da8;
  box-shadow:0 0 0 3px rgba(18,109,168,.13);
}
.auth-input-wrap input:focus,
.auth-input-wrap input[type="email"]:focus,
.auth-input-wrap input[type="password"]:focus,
.auth-input-wrap input[type="text"]:focus{
  border:0;
  box-shadow:none;
}
.auth-actions .secondary-button{
  width:100%;
  min-height:44px;
  border-radius:12px;
  font-size:14px;
  font-weight:760;
}
.auth-empty-state{
  border-style:solid;
  background:#f8fbfe;
}
.stacked-form{display:grid;gap:13px}
.grid-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.field--wide{grid-column:1/-1}
.form-actions{display:flex;justify-content:flex-end}
.inline-create-form,.inline-link-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;margin:0 0 12px}
.inline-link-form,.compact-select-form{margin:0}

.data-table{
  display:grid;
  border:1px solid #dce7f2;
  border-radius:8px;
  overflow:hidden;
  background:#fff;
}
.data-table__row{
  display:grid;
  grid-template-columns:1fr 1.4fr 1fr .8fr;
  gap:14px;
  align-items:center;
  min-height:58px;
  padding:12px 16px;
  border-top:1px solid #eef3f7;
  background:#fff;
}
.data-table__row:first-child{border-top:0}
.data-table__row:nth-child(even):not(.data-table__row--head){background:#fbfdff}
.data-table__row--link{color:inherit;text-decoration:none}
.data-table__row--link:hover{background:#f4f8fb}
.data-table__row--head{
  min-height:42px;
  background:#f4f8fb;
  color:#64748b;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0;
}
.data-table--organizations .data-table__row{grid-template-columns:minmax(0,1.6fr) .7fr .5fr .5fr .5fr}
.data-table--orders .data-table__row{grid-template-columns:minmax(0,.85fr) minmax(0,1.1fr) minmax(0,.9fr) .65fr minmax(260px,1.1fr)}
.data-table--company-seats .data-table__row{grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) .55fr .55fr}
.data-table--learners .data-table__row{grid-template-columns:minmax(0,1.35fr) .6fr .8fr .8fr .4fr}
.data-table--failed-seats .data-table__row{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr) minmax(0,1.5fr) .35fr}
.data-table--history .data-table__row{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr) minmax(0,1.2fr) .55fr minmax(0,.9fr)}
.data-table--learner-history .data-table__row{grid-template-columns:minmax(0,1.4fr) .55fr .75fr .65fr}
.data-table__row span{min-width:0;font-size:13px;line-height:1.35}
.data-table__row strong{display:block;min-width:0;color:#0f172a;font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.data-table__row small{display:block;color:#64748b;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.empty-state{
  display:grid;
  gap:4px;
  padding:18px;
  border:1px dashed #cbd5e1;
  border-radius:8px;
  background:#fbfdff;
  color:#64748b;
  font-size:14px;
  line-height:1.45;
}
.empty-state strong{color:#0f172a}
.empty-state--large{min-height:160px;align-content:center;justify-items:start}
.empty-state--compact{padding:13px;align-content:start}
.empty-state--success{border-color:#b9e5c9;background:#f6fbf8}
.phase-list{margin:0;padding-left:20px;color:#475569;font-size:14px;line-height:1.65}
.phase-list strong{color:var(--ink)}
.check-list,.setup-summary,.order-link-list,.provisioning-failure-list,.provisioning-job-list,.company-seat-list,.purchase-card-list,.learner-roster-list,.resource-card-list,.support-record-list,.audit-event-list,.schema-table-list,.detail-list,.mini-list,.seat-list,.learner-training-list,.learner-purchase-list{display:grid;gap:12px}

.setup-summary{margin-top:16px}
.setup-summary div,.check-list div,.detail-list div,.assigned-seat div{
  display:grid;
  gap:4px;
  padding:12px;
  border:1px solid #edf2f7;
  border-radius:8px;
  background:#fbfdff;
}
.assigned-seat{
  padding:14px;
  border-radius:8px;
  background:#f8fbfe;
  box-shadow:inset 0 0 0 1px #edf2f7;
}
.assigned-seat div{
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
}
.setup-summary span,.detail-list span,.assigned-seat span{color:#64748b;font-size:12px;text-transform:uppercase;letter-spacing:0}
.setup-summary strong{font-size:20px}
.setup-summary--compact{grid-template-columns:repeat(2,minmax(0,1fr));margin:0 0 14px}
.setup-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:18px}
.setup-summary-card{padding:18px;border:1px solid #dce7f2;border-radius:8px;background:#fff;box-shadow:var(--shadow-sm)}
.setup-summary-card span{display:block;color:#64748b;font-size:12px;text-transform:uppercase;letter-spacing:0}
.setup-summary-card strong{display:block;margin-top:7px;font-size:25px;line-height:1}
.panel--setup{padding:18px}

.order-link-card,.provisioning-failure-card,.company-seat-card,.learner-roster-card,.support-record-card,.seat-card,.learner-training-card,.learner-purchase-card{
  border:1px solid #dce7f2;
  border-radius:8px;
  background:#fff;
  box-shadow:var(--shadow-sm);
}
.order-link-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,.42fr);gap:16px;padding:16px}
.order-link-card__main{display:grid;gap:14px}
.order-link-card__header,.provisioning-failure-card__header,.support-record-card__header,.learner-training-card__header,.seat-card__summary{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.order-link-card__header,.provisioning-failure-card__header{padding-bottom:12px;border-bottom:1px solid #edf2f7}
.order-link-card__label{display:block;margin-bottom:3px;color:#64748b;font-size:11px;text-transform:uppercase;letter-spacing:0}
.order-link-card__header strong{display:block;font-size:18px;line-height:1.2}
.order-link-card__details{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px 24px;
  padding:14px;
  border-radius:8px;
  background:#f8fbfe;
  box-shadow:inset 0 0 0 1px #edf2f7;
}
.order-link-card__details div,.support-meta-grid div,.support-record-card__body div,.learner-course-meta div{
  min-width:0;
  padding:11px 12px;
  border:0;
  border-radius:8px;
  background:#f8fbfe;
  box-shadow:inset 0 0 0 1px #edf2f7;
}
.order-link-card__details div{
  padding:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.order-link-card__details span,.support-meta-grid span,.support-record-card__body span,.learner-course-meta span,.learner-purchase-card span{
  display:block;
  margin-bottom:4px;
  color:#64748b;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0;
}
.order-link-card__details strong,.support-meta-grid strong,.support-record-card__body strong,.learner-course-meta strong,.learner-purchase-card strong{
  display:block;
  min-width:0;
  color:#0f172a;
  font-size:13px;
  font-weight:680;
  line-height:1.35;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.order-link-card__details small,.support-meta-grid small,.support-record-card__body small,.learner-course-meta small,.learner-purchase-card small{
  display:block;
  margin-top:3px;
  color:#64748b;
  font-size:12px;
  line-height:1.35;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.order-link-card__action{display:grid;align-content:start;gap:12px;padding:14px;border:1px solid #edf2f7;border-radius:8px;background:#fbfdff}
.order-link-form{
  display:grid;
  gap:12px;
}
.order-link-form .primary-button{
  justify-self:start;
  min-height:42px;
  min-width:112px;
  padding:0 18px;
}
.match-callout,.error-callout,.support-checklist,.phase-callout{
  display:grid;
  gap:5px;
  padding:12px;
  border:1px solid #dce7f2;
  border-radius:8px;
  background:#f7fafc;
}
.match-callout span,.support-checklist span,.phase-callout span{color:#475569;font-size:13px;line-height:1.45}
.match-callout strong,.support-checklist strong,.phase-callout strong{color:#0f172a;font-size:13px;line-height:1.35}
.match-callout.is-suggested{border-color:#b8d8f0;background:#eff7fd}
.match-callout.is-suggested strong{color:#126da8}
.error-callout{border-color:#fac5c0;background:var(--red-soft);color:#991b1b}
.error-callout--compact{padding:10px;border-color:#fed7aa;background:#fff7ed;color:#9a3412}
.provisioning-failure-card{display:grid;gap:14px;padding:16px}
.support-meta-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.provisioning-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px}
.provisioning-job-card,.audit-event-card,.schema-table-row,.resource-card,.purchase-card{
  padding:13px;
  border:1px solid #e1eaf3;
  border-radius:8px;
  background:#fff;
}
.job-stat-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.job-stat-row span{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 9px;border:1px solid #edf2f7;border-radius:8px;background:#fbfdff;color:#64748b;font-size:12px}
.job-stat-row strong{color:#0f172a;font-size:13px}
.job-time-row{display:grid;gap:3px}
.job-time-row span{color:#64748b;font-size:11px;text-transform:uppercase;letter-spacing:0}
.job-time-row strong{font-size:13px;font-weight:680}

.company-dashboard-grid{align-items:start}
.company-seat-card{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,.9fr) auto;gap:12px;align-items:center;padding:14px}
.company-seat-card__main,.company-seat-card__learner,.learner-roster-card__person{min-width:0}
.company-seat-card__main strong,.learner-roster-card__person strong{display:block;min-width:0;font-size:15px;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.company-seat-card__main small,.company-seat-card__learner small,.learner-roster-card__person small{display:block;margin-top:3px;color:#64748b;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.company-seat-card__learner span{display:block;min-width:0;color:#334155;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.purchase-card{display:grid;gap:8px}
.purchase-card>div{display:flex;align-items:center;justify-content:space-between;gap:12px}
.purchase-card strong{font-size:14px;line-height:1.3}
.purchase-card span{color:#64748b;font-size:12px}
.learner-roster-card{display:grid;grid-template-columns:minmax(0,1.35fr) auto minmax(180px,.75fr) minmax(180px,.75fr) auto;gap:12px;align-items:end;margin:0;padding:14px}
.learner-roster-card__person,.learner-roster-card__status{align-self:center}
.learner-roster-card__status{display:grid;gap:5px;justify-items:start}
.learner-roster-card__status small{color:#64748b;font-size:12px;white-space:nowrap}
.profile-form{align-items:start}
.profile-resource-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:18px}
.resource-card{display:grid;gap:3px;background:#fbfdff}
.resource-card strong{min-width:0;font-size:13px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.resource-card span,.resource-card small{min-width:0;color:#64748b;font-size:12px;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.support-history-layout{align-items:start}
.support-record-card{display:grid;gap:12px;padding:15px}
.support-record-card__header strong{display:block;font-size:16px;line-height:1.3}
.support-record-card__header small{display:block;margin-top:3px;color:#64748b;font-size:12px;line-height:1.35}
.support-record-card__body{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,.78fr) minmax(0,.78fr) minmax(0,1fr);gap:10px}
.audit-event-card{display:grid;gap:8px}
.audit-event-card__title{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.audit-event-card__title strong{font-size:14px;line-height:1.3}
.audit-event-card__title span{color:#64748b;font-size:11px;line-height:1.35;text-align:right;white-space:nowrap}
.audit-event-card__meta,.audit-event-card__detail{display:flex;flex-wrap:wrap;gap:6px}
.audit-event-card__meta span,.audit-event-card__detail span{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border:1px solid #edf2f7;border-radius:999px;background:#fbfdff;color:#475569;font-size:12px}
.schema-table-row{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#fbfdff}
.schema-table-row strong{display:block;font-size:13px;line-height:1.3}
.schema-table-row span:not(.status-pill){display:block;margin-top:2px;color:#64748b;font-size:12px;line-height:1.35}
.phase-callout{margin-top:16px;border-color:#b8d8f0;background:#eff7fd;color:#164f78}
.invite-form{margin-top:16px;padding-top:16px;border-top:1px solid #edf2f7}
.mini-list{margin-top:16px}
.mini-list div{display:grid;gap:2px;padding:10px;border:1px solid #edf2f7;border-radius:8px;background:#fbfdff}
.mini-list strong{font-size:13px}
.mini-list span{color:#64748b;font-size:12px}
.mini-list--invitations .invitation-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:5px 10px}
.mini-list--invitations strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mini-list--invitations span:not(.status-pill){grid-column:1;color:#64748b}
.mini-list--invitations .status-pill{grid-column:2;grid-row:1}
.mini-list--invitations form{grid-column:2;grid-row:2;margin:0;justify-self:end}
.text-action-button{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0;border:0;background:transparent;color:#0f5da8;font:inherit;font-size:12px;cursor:pointer}
.text-action-button:hover{text-decoration:underline}

.status-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:26px;
  padding:0 9px;
  border:1px solid #cbd8e5;
  border-radius:999px;
  background:#f8fafc;
  color:#334155;
  font-size:12px;
  font-weight:600;
  text-transform:capitalize;
  white-space:nowrap;
}
.status-pill--unassigned{border-color:#f2c489;background:var(--amber-soft);color:#9a5a00}
.status-pill--assigned{border-color:#b8d8f0;background:var(--blue-soft);color:#0f5da8}
.status-pill--queued,.status-pill--provisioning{border-color:#d7cdf7;background:var(--purple-soft);color:#684fb6}
.status-pill--provisioned,.status-pill--completed{border-color:#b9e5c9;background:var(--green-soft);color:#166534}
.status-pill--failed{border-color:#fac5c0;background:var(--red-soft);color:#991b1b}
.status-pill--access-pending{border-color:#d9c8f7;background:#f3edff;color:#5b3da6}
.status-pill--in-progress{border-color:#b8d8f0;background:#edf7ff;color:#0f5da8}
.status-pill--ready,.status-pill--not-started{border-color:#b9e5c9;background:#eef9f2;color:#166534}
.status-pill--access-issue,.status-pill--expired{border-color:#fac5c0;background:var(--red-soft);color:#991b1b}

.portal-role-learner .status-pill,
.portal-role-company .status-pill{
  text-transform:none;
}

.seat-list--support{max-height:640px;overflow:auto;padding-right:4px}
.seat-card{display:grid;gap:14px;padding:16px}
.seat-card__summary strong{display:block;font-size:15px;line-height:1.35}
.seat-card__summary span:not(.status-pill){display:block;margin-top:3px;color:#64748b;font-size:13px}
.assign-seat-form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;gap:10px;align-items:end;padding-top:12px;border-top:1px solid #edf2f7}
.organization-seat-panel{margin-bottom:18px}
.assigned-seat{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding-top:12px;border-top:1px solid #edf2f7}
.assigned-seat strong{font-size:14px}
.assigned-seat small{color:#64748b;font-size:12px}

.learner-hero .status-card strong{font-size:20px}
.learner-summary-grid{margin-top:-2px}
.learner-training-card{display:grid;gap:13px;padding:16px}
.learner-training-card--seat{border-color:#cfe2f3;background:linear-gradient(180deg,#fff,#f8fbff)}
.learner-training-card__header strong{display:block;min-width:0;font-size:16px;line-height:1.3}
.learner-training-card__header small{display:block;margin-top:3px;color:#64748b;font-size:12px;line-height:1.35}
.learner-course-meta{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.learner-certificate-cell{display:grid;align-content:start;gap:4px}
.learner-certificate-cell .secondary-button{justify-self:start}
.learner-purchases-panel{margin-top:18px}
.learner-purchase-card{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(130px,.45fr) minmax(150px,.5fr) minmax(130px,.45fr);gap:12px;align-items:center;padding:14px}
.learner-purchase-card>div{min-width:0}
.learner-purchase-card__main strong,.learner-purchase-card__amount strong{font-size:15px}
.learner-purchase-card__amount strong{color:#0f172a}

/* Client-facing portal treatments */
.portal-role-learner,.portal-role-company{
  background:linear-gradient(135deg,#e7f1fb 0,#f7fbff 44%,#eef7f5 100%);
}
.portal-role-learner .portal-app-shell,.portal-role-company .portal-app-shell{grid-template-columns:260px minmax(0,1fr)}
.portal-role-learner .portal-sidebar{
  padding:26px 18px;
  background:linear-gradient(180deg,#0758bd 0,#0d3f8e 52%,#092a5d 100%);
  border-right:0;
  box-shadow:18px 0 45px rgba(24,78,139,.16);
}
.portal-role-company .portal-sidebar{
  padding:26px 18px;
  background:#fbfdff;
  color:#203044;
  border-right:1px solid #dbe7f2;
  box-shadow:18px 0 45px rgba(24,78,139,.08);
}
.portal-role-learner .portal-brand,.portal-role-company .portal-brand{padding:8px 10px 18px}
.portal-role-company .portal-brand{color:#0f172a}
.portal-role-company .portal-brand__logo--light{display:none}
.portal-role-company .portal-brand__logo--blue{display:block}
.portal-role-company .portal-brand__mark{background:#0d6ecb;color:#fff}
.portal-role-company .portal-brand small{color:#60738a}
.portal-role-learner .portal-nav-group__label{color:#b8d6fa}
.portal-role-company .portal-nav-group__label{color:#6b7f95}
.portal-role-learner .portal-nav-link{color:#e9f3ff}
.portal-role-company .portal-nav-link{color:#344357}
.portal-role-learner .portal-nav-link:hover{background:rgba(255,255,255,.13)}
.portal-role-company .portal-nav-link:hover{background:#edf6ff;color:#0b4f91}
.portal-role-learner .portal-nav-link.is-active{
  background:#fff;
  color:#0a3d88;
  box-shadow:0 14px 28px rgba(0,36,94,.16);
}
.portal-role-company .portal-nav-link.is-active{
  background:#0d6ecb;
  color:#fff;
  box-shadow:0 14px 28px rgba(13,110,203,.18);
}
.portal-role-company .portal-nav-link.is-active .portal-nav-icon{background:rgba(255,255,255,.18);color:#fff}
.portal-role-company .portal-nav-link.is-active::before{background:#ffc94a}
.portal-role-company .portal-nav-icon{background:#e9f4ff;color:#0d6ecb}
.portal-role-company .portal-sidebar__footer{border-top-color:#dce8f4}
.portal-role-company .portal-user-card{background:#f5f9fd;border-color:#dbe7f2}
.portal-role-company .portal-user-card strong{color:#0f172a}
.portal-role-company .portal-user-card small{color:#60738a}
.portal-role-company .nav-button--full{background:#fff;border-color:#cddcea;color:#203044}
.portal-role-company .nav-button--full:hover{background:#f0f7ff;border-color:#a8cae8}
.portal-role-learner .portal-topbar,.portal-role-company .portal-topbar{
  min-height:74px;
  background:rgba(255,255,255,.78);
  border-bottom:1px solid rgba(205,220,234,.78);
}
.portal-role-learner .page-shell,.portal-role-company .page-shell{
  width:min(1480px,calc(100% - 64px));
  margin-left:clamp(28px,3vw,56px);
}
.portal-role-learner .page-shell{
  width:min(1240px,calc(100% - 64px));
  margin-left:auto;
  margin-right:auto;
}
.portal-role-learner .main-shell,.portal-role-company .main-shell{padding-top:28px}
.portal-role-learner .portal-topbar span,.portal-role-company .portal-topbar span{text-transform:none}

.student-dashboard{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,360px);
  gap:22px;
  align-items:start;
}
.student-main,.student-side{display:grid;gap:18px;min-width:0}
.student-welcome-card,.student-next-card,.student-section,.student-profile-card,.student-side-card{
  border:1px solid rgba(195,215,234,.82);
  border-radius:8px;
  background:rgba(255,255,255,.92);
  box-shadow:0 18px 36px rgba(32,78,125,.09);
}
.student-welcome-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(240px,310px);
  gap:22px;
  align-items:center;
  padding:30px;
  overflow:hidden;
  position:relative;
}
.student-welcome-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:5px;
  background:linear-gradient(90deg,#0758bd,#18a999,#ffc94a);
}
.student-welcome-card h1{font-size:38px}
.student-progress-card{
  display:grid;
  gap:8px;
  padding:18px;
  border-radius:8px;
  background:#f3f8fe;
  box-shadow:inset 0 0 0 1px #d7e7f5;
}
.student-progress-card span,.student-next-meta span,.student-course-details dt,.student-profile-card div span{
  color:#60738a;
  font-size:12px;
  text-transform:uppercase;
}
.student-progress-card strong{font-size:31px;line-height:1;color:#0758bd}
.student-progress-card small{color:#60738a;font-size:13px}
.student-progress-track{
  height:9px;
  overflow:hidden;
  border-radius:999px;
  background:#dce9f6;
}
.student-progress-track span{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#0758bd,#18a999);
}
.student-next-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  padding:24px;
  background:linear-gradient(135deg,#0a4ea7,#087cc1);
  color:#fff;
}
.student-next-card .eyebrow,.student-next-card .hero-copy,.student-next-card p{color:#dceeff}
.student-next-card h2{margin:0;color:#fff;font-size:25px}
.student-next-card p{margin:7px 0 0}
.student-next-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.student-next-meta{
  display:grid;
  gap:5px;
  min-width:180px;
  padding:14px;
  border-radius:8px;
  background:rgba(255,255,255,.13);
}
.student-next-meta span{color:#dceeff}
.student-next-meta strong{font-size:15px}
.student-section,.student-side-card{padding:22px}
.student-section-heading{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:16px;
}
.student-section-heading h2{margin:0;font-size:22px}
.student-section-heading>span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 10px;
  border-radius:999px;
  background:#edf6ff;
  color:#0d5ca4;
  font-size:13px;
}
.student-section-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:10px;
}
.student-section-actions>span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 10px;
  border-radius:999px;
  background:#edf6ff;
  color:#0d5ca4;
  font-size:13px;
}
.student-section-heading--compact{margin-bottom:12px}
.student-section-heading--compact h2{font-size:18px}
.student-section-link{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  color:#0b5ca8;
  font-size:13px;
  text-decoration:none;
}
.student-section-link:hover{text-decoration:underline}
.student-digitalchalk-link,
.student-digitalchalk-inline{
  gap:8px;
}
.student-digitalchalk-link img,
.student-digitalchalk-inline img{
  display:block;
  width:92px;
  max-width:34vw;
  height:auto;
  object-fit:contain;
}
.student-digitalchalk-link span,
.student-digitalchalk-inline span{
  white-space:nowrap;
}
.student-action-button.student-digitalchalk-link{
  min-height:40px;
  padding-left:9px;
}
.student-digitalchalk-inline{
  min-height:32px;
  padding:0 9px;
  border:1px solid #d7e5f2;
  border-radius:999px;
  background:#fff;
}
.student-digitalchalk-inline:hover{
  background:#f3f9ff;
  text-decoration:none;
}
.student-course-grid{display:grid;grid-template-columns:1fr;gap:14px}
.student-course-grid--home{grid-template-columns:1fr;gap:14px}
.student-course-grid--home>.student-course-card:last-child:nth-child(odd){grid-column:auto}
.student-course-card{
  position:relative;
  display:grid;
  grid-template-columns:minmax(230px,1fr) minmax(300px,1.2fr) minmax(150px,.45fr);
  grid-template-areas:
    "header details actions"
    "helper helper actions";
  gap:14px 22px;
  min-height:0;
  padding:19px 19px 17px;
  border:1px solid #d9e6f2;
  border-radius:8px;
  background:linear-gradient(180deg,#fff 0%,#fbfdff 100%);
  box-shadow:0 14px 30px rgba(32,78,125,.075);
  overflow:hidden;
}
.student-course-card:hover{
  border-color:#c6d9eb;
  box-shadow:0 18px 34px rgba(32,78,125,.105);
}
.student-course-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:4px;
  width:auto;
  background:#9db8d2;
}
.student-course-card--state-completed::before{background:#24a36b}
.student-course-card--state-access-pending::before{background:#8b6fd6}
.student-course-card--state-in-progress::before{background:#0d6ecb}
.student-course-card--state-ready::before,.student-course-card--state-not-started::before{background:#18a999}
.student-course-card--state-not-passed::before,.student-course-card--state-access-issue::before,.student-course-card--state-expired::before{background:#d92d20}
.student-course-card--blue,.student-course-card--gold,.student-course-card--green,.student-course-card--violet{background:#fff}
.student-course-card__header{
  grid-area:header;
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:10px;
  align-items:start;
  align-self:start;
}
.student-course-card__title-row{
  display:flex;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:10px;
}
.student-course-card h3{
  margin:0;
  color:#101827;
  font-size:20px;
  line-height:1.22;
  letter-spacing:0;
  overflow-wrap:anywhere;
}
.student-course-card__status{
  max-width:156px;
  min-height:27px;
  padding-inline:9px;
  justify-self:start;
  white-space:nowrap;
}
.student-course-details{
  grid-area:details;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0;
  margin:0;
  padding:0;
  border-block:0;
}
.student-course-details div{
  display:grid;
  gap:4px;
  min-width:0;
  padding:5px 14px;
}
.student-course-details div:nth-child(odd){
  padding-left:0;
  border-right:1px solid #e6eef7;
}
.student-course-details div:nth-child(even){
  padding-right:0;
}
.student-course-details div:nth-child(n+3){
  margin-top:10px;
}
.student-course-details div:last-child:nth-child(odd){
  grid-column:1/-1;
  padding-right:0;
  border-right:0;
}
.student-course-details dd{
  margin:0;
  min-width:0;
  color:#101827;
  font-size:13px;
  line-height:1.25;
  text-align:left;
  overflow-wrap:anywhere;
}
.student-course-helper{
  grid-area:helper;
  margin:0;
  padding:10px 12px;
  border-radius:8px;
  background:#f6f9fc;
  color:#52667d;
  font-size:13px;
  line-height:1.45;
}
.student-course-card__actions{
  grid-area:actions;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:9px;
  margin-top:0;
  padding-top:1px;
  align-self:end;
}
.student-action-status{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 10px;
  border-radius:8px;
  background:#f5f8fc;
  color:#5e7086;
  font-size:13px;
  line-height:1;
}
.student-action-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 13px;
  border:1px solid #0758bd;
  border-radius:8px;
  background:#0758bd;
  color:#fff;
  font:inherit;
  font-size:13px;
  line-height:1;
  text-decoration:none;
  white-space:nowrap;
  cursor:pointer;
}
.student-action-button:hover{background:#084b9e;box-shadow:0 3px 8px rgba(7,88,189,.1)}
.student-action-button--secondary{
  border-color:#c7daeb;
  background:#fff;
  color:#0b5ca8;
}
.student-action-button--secondary:hover{background:#f3f9ff}
.student-action-button--light{
  border-color:#fff;
  background:#fff;
  color:#0758bd;
}
.student-action-button--light:hover{background:#eef7ff}
.student-action-button--ghost{
  border-color:rgba(255,255,255,.55);
  background:rgba(255,255,255,.12);
  color:#fff;
}
.student-action-button--ghost:hover{background:rgba(255,255,255,.2)}
.student-action-button--disabled,
.student-action-button:disabled{
  border-color:#d8e3ee;
  background:#edf2f7;
  color:#64748b;
  box-shadow:none;
  cursor:not-allowed;
  transform:none;
}
.student-action-button--status{
  min-height:36px;
  padding:0 12px;
  border-color:#e0d6f7;
  background:#f6f1ff;
  color:#684fb6;
  box-shadow:none;
  cursor:default;
  pointer-events:none;
  transform:none;
}
.student-action-button--status:disabled{cursor:default}
.student-action-button--status:hover{
  background:#f6f1ff;
  box-shadow:none;
}
.student-next-card .student-action-button--status{
  border-color:rgba(255,255,255,.3);
  background:rgba(255,255,255,.16);
  color:#fff;
}
.student-action-button--light.student-action-button--disabled{
  border-color:rgba(255,255,255,.35);
  background:rgba(255,255,255,.22);
  color:#dceeff;
}
.student-link-action{
  align-self:end;
  justify-self:start;
  color:#0b5ca8;
  font-size:14px;
  text-decoration:none;
}
.student-link-action:hover{text-decoration:underline}
.student-profile-card{
  display:grid;
  gap:8px;
  justify-items:start;
  padding:22px;
}
.student-profile-card>.portal-avatar{
  width:48px;
  height:48px;
  font-size:14px;
  background:#0d6ecb;
  color:#fff;
}
.student-profile-card>strong{font-size:20px}
.student-profile-card>small,.student-muted{color:#60738a;font-size:13px}
.student-profile-card div{
  display:grid;
  gap:4px;
  width:100%;
  margin-top:8px;
  padding-top:14px;
  border-top:1px solid #e3edf6;
}
.student-profile-card div strong{font-size:14px}
.student-organization-card{
  gap:7px;
}
.student-organization-card .eyebrow{margin:0;color:#0d6ecb}
.student-organization-card>strong{
  max-width:100%;
  overflow-wrap:anywhere;
}
.student-organization-card>small{
  max-width:270px;
  line-height:1.45;
}
.student-mini-list{display:grid;gap:10px}
.student-mini-list article{
  display:grid;
  gap:3px;
  padding:12px;
  border:1px solid #e1ebf5;
  border-radius:8px;
  background:#f9fcff;
}
.student-mini-list strong{font-size:14px}
.student-mini-list span{color:#60738a;font-size:13px}
.student-mini-list a{
  justify-self:start;
  color:#0b5ca8;
  font-size:13px;
  text-decoration:none;
}
.student-help-card p:not(.eyebrow){margin:8px 0 0;color:#52667d;font-size:14px;line-height:1.55}
.student-help-card__link{justify-self:start;margin-top:14px}
.student-empty-card{
  display:grid;
  gap:4px;
  min-height:180px;
  align-content:center;
  padding:24px;
  border:1px dashed #b8cce0;
  border-radius:8px;
  background:#f8fbff;
  color:#60738a;
}
.student-empty-card strong{color:#101827}
.student-page{display:grid;gap:18px}
.student-welcome-card--page h1{font-size:36px;font-weight:700}
.student-summary-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:14px;
}
.student-summary-card{
  position:relative;
  display:grid;
  gap:6px;
  padding:18px;
  border:1px solid rgba(195,215,234,.82);
  border-radius:8px;
  background:rgba(255,255,255,.92);
  box-shadow:0 14px 30px rgba(32,78,125,.07);
}
.student-summary-card__icon{
  position:absolute;
  right:14px;
  top:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  border-radius:8px;
  background:#edf6ff;
  color:#0d6ecb;
  font-size:12px;
}
.student-summary-card__icon svg{
  width:15px;
  height:15px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.student-summary-card--active .student-summary-card__icon{background:#edf7ff;color:#0d6ecb}
.student-summary-card--pending .student-summary-card__icon{background:#f3edff;color:#684fb6}
.student-summary-card--completed .student-summary-card__icon{background:#e8f6ee;color:#166534}
.student-summary-card--issue .student-summary-card__icon{background:#fff1f0;color:#b42318}
.student-summary-card--total .student-summary-card__icon{background:#f2f6fb;color:#52667d}
.student-summary-card span{
  color:#60738a;
  font-size:12px;
  text-transform:uppercase;
}
.student-summary-card strong{
  color:#0f172a;
  font-size:29px;
  line-height:1;
}
.student-filter-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:-2px 0 16px;
}
.student-filter-tabs a{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 12px;
  border:1px solid #d7e5f2;
  border-radius:999px;
  background:#fff;
  color:#52667d;
  font-size:13px;
  font-weight:800;
  text-decoration:none;
}
.student-filter-tabs a:hover{background:#f3f9ff;color:#0b5ca8}
.student-filter-tabs a.is-active{border-color:#0758bd;background:#eaf5ff;color:#0758bd}
.student-pagination{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid #e2edf7;
}
.student-pagination p{
  margin:0;
  color:#60738a;
  font-size:13px;
}
.student-pagination nav{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:7px;
}
.student-pagination a,
.student-pagination span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  min-height:34px;
  padding:0 10px;
  border:1px solid #d7e5f2;
  border-radius:8px;
  background:#fff;
  color:#52667d;
  font-size:13px;
  text-decoration:none;
}
.student-pagination a:hover{
  border-color:#b9d5ee;
  background:#f3f9ff;
  color:#0b5ca8;
}
.student-pagination a.is-active{
  border-color:#0758bd;
  background:#0758bd;
  color:#fff;
}
.student-pagination span{
  background:#f5f8fc;
  color:#91a2b5;
}
.student-course-grid--wide{grid-template-columns:1fr}
.student-course-details--compact{gap:6px}
.student-course-details--compact div{padding-top:7px}
.student-certificate-card .student-course-details--compact div{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  justify-content:start;
  gap:5px;
}
.student-certificate-card .student-course-details--compact dt::after{content:""}
.student-certificate-card .student-course-details--compact dd{text-align:left}
.student-certificate-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:14px}
.student-certificate-card{
  display:grid;
  gap:12px;
  padding:18px;
  border:1px solid #d5e3f1;
  border-radius:8px;
  background:#fff;
  box-shadow:0 12px 28px rgba(32,78,125,.07);
}
.student-certificate-card__body{display:grid;gap:9px;min-width:0}
.student-certificate-card__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.student-certificate-card__top--status-only{
  justify-content:flex-end;
}
.student-certificate-card__title-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
  gap:12px;
}
.student-certificate-card__body>span{
  color:#60738a;
  font-size:12px;
  text-transform:uppercase;
}
.student-certificate-card h2{margin:0;font-size:20px;font-weight:700;line-height:1.25;overflow-wrap:anywhere}
.student-certificate-card p{margin:0;color:#52667d;font-size:14px;line-height:1.5}
.student-billing-list{display:grid;gap:12px}
.student-billing-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  grid-template-areas:
    "main actions"
    "meta meta";
  gap:14px 18px;
  align-items:center;
  padding:18px;
  border:1px solid #d5e3f1;
  border-radius:8px;
  background:#fff;
  box-shadow:0 12px 28px rgba(32,78,125,.07);
}
.student-billing-card__main{grid-area:main;min-width:0}
.student-billing-card__main>span{
  display:block;
  margin-bottom:5px;
  color:#60738a;
  font-size:12px;
  text-transform:uppercase;
  overflow-wrap:anywhere;
}
.student-billing-card h2{
  margin:0;
  min-width:0;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  font-size:18px;
  font-weight:700;
  line-height:1.28;
}
.student-billing-card p{margin:6px 0 0;color:#60738a;font-size:13px}
.student-billing-card__meta{
  grid-area:meta;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:0;
}
.student-billing-card__meta div{
  min-width:0;
  padding:11px 12px;
  border-radius:8px;
  background:#f8fbff;
  box-shadow:inset 0 0 0 1px #e2edf7;
}
.student-billing-card__meta dt{
  color:#60738a;
  font-size:11px;
  text-transform:uppercase;
}
.student-billing-card__meta dd{
  margin:4px 0 0;
  min-width:0;
  color:#101827;
  font-size:13px;
  overflow-wrap:anywhere;
}
.student-billing-card__actions{
  grid-area:actions;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  align-self:start;
  min-width:max-content;
}
.student-section--subtle{
  background:rgba(255,255,255,.72);
}

.portal-role-company .hero-panel{
  background:linear-gradient(135deg,#fff,#f3f9ff);
  box-shadow:0 18px 36px rgba(32,78,125,.08);
}
.portal-role-company .metric-card,.portal-role-company .setup-summary-card,.portal-role-company .panel{
  box-shadow:0 14px 30px rgba(32,78,125,.07);
}
.client-hero{grid-template-columns:minmax(0,1fr) minmax(260px,320px)}
.client-progress-card{
  display:grid;
  gap:8px;
  padding:18px;
  border:1px solid #d7e7f5;
  border-radius:8px;
  background:#f7fbff;
}
.client-progress-card span,.client-summary-card span{
  color:#60738a;
  font-size:12px;
  text-transform:uppercase;
}
.client-progress-card strong{
  color:#066e48;
  font-size:31px;
  line-height:1;
  font-weight:650;
}
.client-progress-card small,.client-summary-card small{color:#60738a;font-size:13px;line-height:1.4}
.client-summary-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.client-summary-card{
  display:grid;
  gap:6px;
  padding:18px;
  border:1px solid #dce8f4;
  border-radius:8px;
  background:#fff;
  box-shadow:0 14px 30px rgba(32,78,125,.07);
}
.client-summary-card strong{font-size:30px;line-height:1;color:#0f172a}
.client-summary-card.is-action{
  border-color:#a8d2f5;
  background:linear-gradient(180deg,#fff,#f0f8ff);
}
.client-panel .panel-heading h2{font-size:21px}

@media (max-width: 1100px){
  .portal-app-shell{grid-template-columns:236px minmax(0,1fr)}
  .portal-sidebar{padding:18px 14px}
  .content-grid,.content-grid--wide{grid-template-columns:1fr}
  .support-meta-grid,.client-summary-grid,.student-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .student-dashboard{grid-template-columns:1fr}
  .student-side{grid-template-columns:repeat(2,minmax(0,1fr))}
  .student-help-card{grid-column:1/-1}
  .student-course-grid,
  .student-course-grid--wide,
  .student-course-grid--home{grid-template-columns:1fr}
  .student-course-card{
    grid-template-columns:minmax(0,1fr);
    grid-template-areas:
      "header"
      "details"
      "helper"
      "actions";
  }
  .student-course-card__actions{
    justify-content:flex-start;
    align-self:start;
  }
  .student-course-grid--home>.student-course-card:last-child:nth-child(odd){grid-column:auto}
  .student-billing-card{
    grid-template-columns:1fr;
    grid-template-areas:
      "main"
      "meta"
      "actions";
  }
  .student-billing-card__actions{justify-content:flex-start}
}

@media (max-width: 820px){
  .page-shell{width:min(100% - 28px,1280px)}
  .portal-body--app .page-shell{width:min(100% - 28px,1280px);margin:0 auto}
  .portal-app-shell{display:block}
  .portal-sidebar{position:relative;height:auto;min-height:0;border-right:0;border-bottom:1px solid rgba(255,255,255,.1)}
  .portal-sidebar__nav{display:flex;gap:12px;overflow:auto;padding-bottom:2px}
  .portal-nav-group{min-width:max-content}
  .portal-nav-group__label{display:none}
  .portal-sidebar__footer{display:none}
  .portal-topbar{position:relative;min-height:66px}
  .portal-topbar__inner{min-height:66px}
  .hero-panel,.metric-grid,.auth-shell,.setup-summary-grid,.order-link-card,.order-link-card__details,.setup-summary--compact,.support-meta-grid,.support-record-card__body,.company-seat-card,.learner-roster-card,.profile-resource-grid,.learner-course-meta,.learner-purchase-card,.grid-form,.assign-seat-form,.assigned-seat,.student-welcome-card,.student-course-grid,.student-course-grid--home,.student-side,.client-summary-grid,.student-summary-grid,.student-certificate-grid,.student-billing-card__meta{grid-template-columns:1fr}
  .student-course-grid--home>.student-course-card:last-child:nth-child(odd){grid-column:auto}
  .student-next-card{align-items:flex-start;flex-direction:column}
  .site-header__inner{align-items:flex-start;flex-direction:column;padding:14px 0}
  .brand__logo-wrap{width:138px}
  .top-nav{align-items:flex-start;flex-wrap:wrap}
  .page-heading{flex-direction:column;padding:16px 0}
  .page-heading--toolbar{align-items:flex-start}
  .page-actions{justify-content:flex-start}
  h1{font-size:28px}
  .portal-body--auth .main-shell{justify-content:flex-start;padding:22px 14px}
  .auth-copy{padding:30px 24px 20px}
  .auth-card{padding:22px 24px 28px}
  .auth-product strong{font-size:22px}
  .data-table__row{grid-template-columns:1fr}
  .data-table__row--head{display:none}
  .provisioning-actions{justify-content:flex-start}
  .job-stat-row{grid-template-columns:1fr}
}

@media (max-width: 560px){
  .student-course-card__header,
  .student-course-details{grid-template-columns:1fr}
  .student-course-card__title-row{grid-template-columns:1fr}
  .student-course-card__status{justify-self:start}
  .student-course-details div,
  .student-course-details div:nth-child(odd),
  .student-course-details div:nth-child(even){
    padding:6px 0;
    border-right:0;
  }
  .student-course-details div:nth-child(n+2){border-top:1px solid #e6eef7}
  .student-course-details div:nth-child(n+3){margin-top:0}
}

/* Learner portal reference refresh */
.portal-topbar__actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  margin-left:auto;
}
.portal-home-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:40px;
  padding:0 16px;
  border:1px solid #dbe4ef;
  border-radius:14px;
  background:#fff;
  color:#334155;
  font-size:14px;
  text-decoration:none;
  box-shadow:0 8px 20px rgba(15,23,42,.04);
}
.portal-home-link svg{
  width:16px;
  height:16px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-home-link:hover{border-color:#c7d7e8;background:#f8fafc;color:#0f172a}
.portal-menu-button,
.portal-mobile-overlay{
  display:none;
}
.portal-menu-button{
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border:1px solid #e2e8f0;
  border-radius:16px;
  background:#fff;
  color:#0f172a;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
}
.portal-menu-button svg{
  width:20px;
  height:20px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.portal-role-learner,
.portal-role-company,
.portal-role-staff{
  background:#f8fafc;
}
.portal-role-learner h1,
.portal-role-learner h2,
.portal-role-learner h3,
.portal-role-company h1,
.portal-role-company h2,
.portal-role-company h3,
.portal-role-staff h1,
.portal-role-staff h2,
.portal-role-staff h3{
  font-family:inherit;
  font-weight:700;
}
.portal-role-learner .portal-app-shell,
.portal-role-company .portal-app-shell,
.portal-role-staff .portal-app-shell{
  grid-template-columns:288px minmax(0,1fr);
}
.portal-role-learner .portal-sidebar,
.portal-role-company .portal-sidebar,
.portal-role-staff .portal-sidebar{
  padding:0;
  background:#fff;
  color:#1e293b;
  border-right:1px solid #e2e8f0;
  box-shadow:none;
}
.portal-role-learner .portal-brand,
.portal-role-company .portal-brand,
.portal-role-staff .portal-brand{
  display:flex;
  align-items:center;
  min-height:73px;
  padding:16px 20px;
  border-bottom:1px solid #e2e8f0;
  color:#0f172a;
}
.portal-role-learner .portal-brand__logo-wrap,
.portal-role-company .portal-brand__logo-wrap,
.portal-role-staff .portal-brand__logo-wrap{
  max-width:210px;
}
.portal-role-learner .portal-brand__logo--light,
.portal-role-company .portal-brand__logo--light,
.portal-role-staff .portal-brand__logo--light{display:none}
.portal-role-learner .portal-brand__logo--blue,
.portal-role-company .portal-brand__logo--blue,
.portal-role-staff .portal-brand__logo--blue{display:block}
.portal-role-learner .portal-nav-group__label,
.portal-role-company .portal-nav-group__label,
.portal-role-staff .portal-nav-group__label{display:none}
.portal-role-learner .portal-sidebar__nav,
.portal-role-company .portal-sidebar__nav,
.portal-role-staff .portal-sidebar__nav{
  gap:10px;
  padding:16px 12px;
}
.portal-role-learner .portal-nav-group,
.portal-role-company .portal-nav-group,
.portal-role-staff .portal-nav-group{
  gap:8px;
}
.portal-role-learner .portal-nav-link,
.portal-role-company .portal-nav-link,
.portal-role-staff .portal-nav-link{
  min-height:48px;
  padding:0 16px;
  border-radius:16px;
  color:#334155;
  font-size:14px;
  font-weight:700;
}
.portal-role-learner .portal-nav-link:hover,
.portal-role-company .portal-nav-link:hover,
.portal-role-staff .portal-nav-link:hover{
  background:#f1f5f9;
  color:#0f172a;
}
.portal-role-learner .portal-nav-link.is-active,
.portal-role-company .portal-nav-link.is-active,
.portal-role-staff .portal-nav-link.is-active{
  background:#0f172a;
  color:#fff;
  box-shadow:none;
}
.portal-role-learner .portal-nav-link.is-active::before,
.portal-role-company .portal-nav-link.is-active::before,
.portal-role-staff .portal-nav-link.is-active::before{
  display:none;
}
.portal-role-learner .portal-nav-icon,
.portal-role-company .portal-nav-icon,
.portal-role-staff .portal-nav-icon{
  width:22px;
  height:22px;
  border-radius:0;
  background:transparent;
  color:inherit;
}
.portal-role-learner .portal-nav-icon svg,
.portal-role-company .portal-nav-icon svg,
.portal-role-staff .portal-nav-icon svg{
  width:18px;
  height:18px;
  stroke-width:2;
}
.portal-role-learner .portal-nav-link.is-active .portal-nav-icon,
.portal-role-company .portal-nav-link.is-active .portal-nav-icon,
.portal-role-staff .portal-nav-link.is-active .portal-nav-icon{
  background:transparent;
  color:#fff;
}
.portal-role-learner .portal-sidebar__footer,
.portal-role-company .portal-sidebar__footer,
.portal-role-staff .portal-sidebar__footer{
  padding:16px;
  border-top:1px solid #e2e8f0;
  gap:10px;
}
.portal-role-learner .portal-user-card,
.portal-role-company .portal-user-card,
.portal-role-staff .portal-user-card{
  border-color:#e2e8f0;
  border-radius:24px;
  background:#f1f5f9;
  padding:14px;
}
.portal-role-learner .portal-user-card strong,
.portal-role-company .portal-user-card strong,
.portal-role-staff .portal-user-card strong{color:#0f172a}
.portal-role-learner .portal-user-card small,
.portal-role-company .portal-user-card small,
.portal-role-staff .portal-user-card small{color:#64748b}
.portal-role-learner .portal-avatar,
.portal-role-company .portal-avatar,
.portal-role-staff .portal-avatar{
  width:40px;
  height:40px;
  border-radius:16px;
  background:#fff;
  color:#0f172a;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
}
.portal-role-learner .nav-button--full,
.portal-role-company .nav-button--full,
.portal-role-staff .nav-button--full{
  border-color:#e2e8f0;
  border-radius:14px;
  background:#fff;
  color:#334155;
}
.portal-role-learner .nav-button--full:hover,
.portal-role-company .nav-button--full:hover,
.portal-role-staff .nav-button--full:hover{
  background:#f8fafc;
  border-color:#cbd5e1;
}
.portal-role-learner .portal-topbar,
.portal-role-company .portal-topbar,
.portal-role-staff .portal-topbar{
  min-height:72px;
  padding:0;
  background:rgba(248,250,252,.9);
  border-bottom:1px solid #e2e8f0;
  backdrop-filter:blur(12px);
}
.portal-role-learner .portal-topbar__inner,
.portal-role-company .portal-topbar__inner,
.portal-role-staff .portal-topbar__inner{
  min-height:72px;
}
.portal-role-learner .portal-topbar span,
.portal-role-company .portal-topbar span,
.portal-role-staff .portal-topbar span{
  color:#64748b;
  font-size:12px;
  font-weight:600;
  text-transform:none;
  letter-spacing:0;
}
.portal-role-learner .portal-topbar strong,
.portal-role-company .portal-topbar strong,
.portal-role-staff .portal-topbar strong{
  margin-top:1px;
  color:#0f172a;
  font-size:21px;
  line-height:1.1;
  font-weight:700;
  letter-spacing:-.03em;
}
.portal-role-learner .page-shell,
.portal-role-company .page-shell,
.portal-role-staff .page-shell{
  width:min(1280px,calc(100% - 48px));
  margin-left:auto;
  margin-right:auto;
}
.portal-role-learner .main-shell,
.portal-role-company .main-shell,
.portal-role-staff .main-shell{
  padding-top:24px;
}

.portal-role-company .hero-panel,
.portal-role-staff .hero-panel{
  gap:28px;
  min-height:205px;
  padding:32px;
  border:0;
  border-radius:30px;
  background:#0f172a;
  color:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
  overflow:hidden;
}
.portal-role-company .hero-panel::before,
.portal-role-staff .hero-panel::before{
  display:none;
}
.portal-role-company .hero-panel h1,
.portal-role-staff .hero-panel h1{
  color:#fff;
  font-size:clamp(32px,4vw,44px);
  line-height:1.05;
  font-weight:700;
  letter-spacing:-.045em;
}
.portal-role-company .hero-panel .eyebrow,
.portal-role-staff .hero-panel .eyebrow{
  margin:0 0 8px;
  color:#cbd5e1;
  font-size:14px;
  font-weight:700;
  text-transform:none;
}
.portal-role-company .hero-panel .hero-copy,
.portal-role-staff .hero-panel .hero-copy{
  margin-top:14px;
  max-width:720px;
  color:#cbd5e1;
  font-size:16px;
  line-height:1.65;
}
.portal-role-company .hero-panel .primary-button,
.portal-role-staff .hero-panel .primary-button,
.portal-role-company .hero-panel .secondary-button,
.portal-role-staff .hero-panel .secondary-button{
  min-height:40px;
  border:0;
  border-radius:14px;
  background:#fff;
  color:#0f172a;
  box-shadow:none;
}
.portal-role-company .hero-panel .secondary-button,
.portal-role-staff .hero-panel .secondary-button{
  background:rgba(255,255,255,.12);
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.24);
}
.portal-role-company .hero-panel .primary-button:hover,
.portal-role-staff .hero-panel .primary-button:hover,
.portal-role-company .hero-panel .secondary-button:hover,
.portal-role-staff .hero-panel .secondary-button:hover{
  transform:none;
  box-shadow:none;
}
.portal-role-company .client-progress-card,
.portal-role-staff .status-card{
  border:1px solid rgba(255,255,255,.16);
  border-radius:20px;
  background:rgba(255,255,255,.10);
  color:#fff;
  box-shadow:none;
}
.portal-role-company .client-progress-card span,
.portal-role-company .client-progress-card small,
.portal-role-staff .status-card__label,
.portal-role-staff .status-card small{
  color:#cbd5e1;
  text-transform:none;
}
.portal-role-company .client-progress-card strong,
.portal-role-staff .status-card strong{
  color:#fff;
  font-weight:600;
}
.portal-role-company .client-summary-card,
.portal-role-staff .metric-card,
.portal-role-company .panel,
.portal-role-staff .panel,
.portal-role-company .setup-summary-card,
.portal-role-staff .setup-summary-card,
.portal-role-company .order-link-card,
.portal-role-staff .order-link-card,
.portal-role-company .provisioning-failure-card,
.portal-role-staff .provisioning-failure-card,
.portal-role-company .company-seat-card,
.portal-role-staff .company-seat-card,
.portal-role-company .learner-roster-card,
.portal-role-staff .learner-roster-card,
.portal-role-company .support-record-card,
.portal-role-staff .support-record-card,
.portal-role-company .seat-card,
.portal-role-staff .seat-card,
.portal-role-company .learner-training-card,
.portal-role-staff .learner-training-card,
.portal-role-company .learner-purchase-card,
.portal-role-staff .learner-purchase-card{
  border-color:#e2e8f0;
  border-radius:28px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
}
.portal-role-company .client-summary-card,
.portal-role-staff .metric-card{
  display:grid;
  grid-template-rows:auto auto minmax(34px,auto) auto;
  align-content:start;
  min-height:124px;
  padding:20px;
}
.portal-role-company .client-summary-card span,
.portal-role-staff .metric-card span{
  color:#475569;
  font-size:14px;
  font-weight:500;
  text-transform:none;
}
.portal-role-company .client-summary-card strong,
.portal-role-staff .metric-card strong,
.portal-role-company .setup-summary strong,
.portal-role-staff .setup-summary strong{
  margin-top:8px;
  color:#020617;
  font-size:32px;
  line-height:1;
  font-weight:650;
  letter-spacing:-.04em;
}
.portal-role-company .client-summary-card strong{
  min-height:32px;
}
.portal-role-company .client-summary-card small,
.portal-role-staff .metric-card small{
  display:block;
  margin-top:8px;
  color:#64748b;
}
.portal-role-company .metric-card::after,
.portal-role-staff .metric-card::after{
  display:none;
}
.portal-role-company .panel,
.portal-role-staff .panel{
  padding:22px;
}
.portal-role-company .panel-heading h2,
.portal-role-staff .panel-heading h2{
  font-size:22px;
  line-height:1.15;
  letter-spacing:-.03em;
}
.portal-role-company .panel-heading .eyebrow,
.portal-role-staff .panel-heading .eyebrow,
.portal-role-company .page-heading .hero-copy,
.portal-role-staff .page-heading .hero-copy{
  text-transform:none;
}
.portal-role-company .page-heading,
.portal-role-staff .page-heading{
  margin-bottom:24px;
}
.portal-role-company .page-heading h1,
.portal-role-staff .page-heading h1{
  color:#0f172a;
  font-size:34px;
  line-height:1.1;
  font-weight:700;
  letter-spacing:-.045em;
}
.portal-role-company .secondary-button,
.portal-role-staff .secondary-button,
.portal-role-company .nav-button,
.portal-role-staff .nav-button,
.portal-role-company .primary-button,
.portal-role-staff .primary-button,
.portal-role-company .small-button,
.portal-role-staff .small-button{
  border-radius:14px;
  font-weight:650;
}
.portal-role-company .primary-button,
.portal-role-staff .primary-button,
.portal-role-company .small-button,
.portal-role-staff .small-button{
  border-color:#0f172a;
  background:#0f172a;
}
.portal-role-company .primary-button:hover,
.portal-role-staff .primary-button:hover,
.portal-role-company .small-button:hover,
.portal-role-staff .small-button:hover{
  background:#1e293b;
  box-shadow:0 3px 8px rgba(15,23,42,.1);
  transform:none;
}
.portal-role-company .primary-button:disabled,
.portal-role-staff .primary-button:disabled,
.portal-role-company .small-button:disabled,
.portal-role-staff .small-button:disabled{
  border-color:#d8e1eb;
  background:#eef3f8;
  color:#7b8ba0;
  box-shadow:none;
  cursor:not-allowed;
}
.portal-role-company .primary-button:disabled:hover,
.portal-role-staff .primary-button:disabled:hover,
.portal-role-company .small-button:disabled:hover,
.portal-role-staff .small-button:disabled:hover{
  background:#eef3f8;
  box-shadow:none;
}
.portal-role-company .panel-count,
.portal-role-staff .panel-count{
  min-height:28px;
  border-color:#e2e8f0;
  background:#f8fafc;
  font-weight:600;
}

.setup-summary-grid--four{grid-template-columns:repeat(4,minmax(0,1fr))}
.setup-summary-grid--five{grid-template-columns:repeat(5,minmax(0,1fr))}
.setup-summary-card small{display:block;margin-top:8px;color:#64748b;font-size:12px}
.client-summary-grid--wide{grid-template-columns:repeat(6,minmax(0,1fr))}
.client-summary-card.is-attention{
  border-color:#fed7aa;
  background:linear-gradient(180deg,#fff,#fff7ed);
}
.company-summary-action{align-self:end;margin-top:12px}
.company-dashboard-layout{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(330px,.65fr);
  gap:18px;
  align-items:start;
}
.company-dashboard-side{
  display:grid;
  gap:18px;
  min-width:0;
}
.company-dashboard-side>.panel{
  min-width:0;
}
.company-seat-card--compact{
  grid-template-columns:minmax(0,1.25fr) minmax(0,.9fr) auto;
}
.company-activity-list{display:grid;gap:10px}
.company-activity-row{
  box-sizing:border-box;
  min-width:0;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 13px;
  border:1px solid #edf2f7;
  border-radius:14px;
  background:#fbfdff;
}
.company-activity-row div{min-width:0}
.company-activity-row small{flex:0 0 auto}
.company-activity-row strong,
.company-activity-row span{
  display:block;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.company-activity-row strong{color:#0f172a;font-size:13px;font-weight:650}
.company-activity-row span,
.company-activity-row small{color:#64748b;font-size:12px}
.company-panel-toolbar{
  gap:18px;
}
.company-panel-toolbar .company-filter-row{
  flex:1 1 auto;
  justify-content:flex-end;
}
.company-panel-toolbar--stacked,
.company-panel-toolbar--records{
  display:grid;
  grid-template-columns:1fr;
  align-items:start;
}
.company-panel-toolbar--stacked .company-filter-row,
.company-panel-toolbar--records .company-filter-row{
  width:100%;
  justify-content:flex-start;
}
.company-filter-row{
  display:flex;
  align-items:flex-end;
  flex-wrap:wrap;
  gap:10px;
}
.company-filter-row--records{
  display:grid;
  grid-template-columns:minmax(220px,1.3fr) minmax(150px,.7fr) minmax(220px,1fr) minmax(150px,.7fr) minmax(150px,.7fr);
  width:100%;
  max-width:none;
}
.company-filter-row--records .company-search-field{
  width:100%;
}
.company-search-field{width:min(280px,100%)}
.company-filter-select{
  display:grid;
  gap:5px;
  min-width:158px;
  color:#64748b;
  font-size:11px;
}
.company-filter-row--records .company-filter-select{
  min-width:0;
}
.company-filter-select span{
  color:#64748b;
  font-size:11px;
  font-weight:600;
}
.company-filter-select select{
  width:100%;
  height:40px;
  padding:0 34px 0 12px;
  border:1px solid #e2e8f0;
  border-radius:14px;
  appearance:none;
  background:#fff url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 6L8 10L12 6' stroke='%2364748b' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 12px center;
  color:#0f172a;
  font:inherit;
  font-size:13px;
  font-weight:600;
}
.company-filter-select select:focus{
  border-color:#bfdbfe;
  box-shadow:0 0 0 3px rgba(37,99,235,.1);
  outline:0;
}
.company-purchase-list{display:grid;gap:14px}
.company-purchase-card{
  display:grid;
  gap:16px;
  padding:18px;
  border:1px solid #e2e8f0;
  border-radius:24px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.company-purchase-card__header,
.company-purchase-card__actions{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.company-purchase-card__header strong{
  display:block;
  color:#0f172a;
  font-size:18px;
  line-height:1.25;
  font-weight:700;
}
.company-purchase-card__header small{display:block;margin-top:3px;color:#64748b;font-size:12px}
.company-purchase-card__body{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(340px,.85fr);
  gap:18px;
  align-items:end;
}
.company-purchase-card__main{
  display:grid;
  gap:14px;
  min-width:0;
}
.company-purchase-card__main h3{
  margin:0;
  color:#0f172a;
  font-size:18px;
  line-height:1.3;
  font-weight:650;
}
.company-course-summary{
  display:grid;
  gap:6px;
  min-width:0;
}
.company-course-summary span{
  min-width:0;
  color:#334155;
  font-size:13px;
  line-height:1.35;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.company-course-summary small{
  color:#64748b;
  font-size:12px;
}
.company-included-courses{
  border:1px solid #edf2f7;
  border-radius:14px;
  background:#fbfdff;
}
.company-included-courses summary{
  padding:10px 12px;
  color:#0f5da8;
  font-size:12px;
  cursor:pointer;
}
.company-included-courses summary:hover{text-decoration:underline}
.company-included-courses ul{
  display:grid;
  gap:6px;
  margin:0;
  padding:0 12px 12px 28px;
  color:#475569;
  font-size:13px;
}
.company-purchase-progress{
  display:grid;
  gap:8px;
  padding:12px;
  border:1px solid #edf2f7;
  border-radius:16px;
  background:#f8fafc;
}
.company-purchase-progress div:first-child{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.company-purchase-progress strong{color:#0f172a;font-size:13px;font-weight:650}
.company-purchase-progress span{color:#64748b;font-size:12px}
.company-purchase-meta{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:0;
  align-self:end;
}
.company-purchase-meta div{
  min-width:0;
  padding:12px;
  border:1px solid #edf2f7;
  border-radius:16px;
  background:#fbfdff;
}
.company-purchase-meta dt{
  margin:0 0 5px;
  color:#64748b;
  font-size:11px;
}
.company-purchase-meta dd{
  margin:0;
  min-width:0;
  color:#0f172a;
  font-size:13px;
  font-weight:650;
  overflow:hidden;
  overflow-wrap:anywhere;
}
.company-purchase-meta small{display:block;margin-top:3px;color:#64748b;font-size:12px}
.company-purchase-card__actions{
  justify-content:flex-start;
  flex-wrap:wrap;
  padding-top:2px;
}
.company-purchase-mini-card{border-radius:16px}
.company-filter-empty{margin-top:14px}
.company-seat-note{margin-bottom:14px}
.company-assignment-card{border-radius:20px}
.company-seat-group-list{max-height:none}
.company-seat-group-card{gap:16px}
.company-seat-section-label{
  display:block;
  margin-bottom:8px;
  color:#64748b;
  font-size:11px;
  font-weight:650;
  text-transform:uppercase;
}
.company-assigned-learners,
.company-available-seat-forms{
  display:grid;
  gap:10px;
  padding-top:14px;
  border-top:1px solid #edf2f7;
}
.company-assigned-learner-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  align-items:center;
  gap:12px;
  padding:12px;
  border:1px solid #edf2f7;
  border-radius:14px;
  background:#fbfdff;
}
.company-assigned-learner-row div{min-width:0}
.company-assigned-learner-row strong,
.company-assigned-learner-row small{
  display:block;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.company-assigned-learner-row strong{color:#0f172a;font-size:13px;font-weight:650}
.company-assigned-learner-row small{color:#64748b;font-size:12px}
.company-learner-card{
  grid-template-columns:minmax(0,1fr) minmax(330px,1fr) minmax(170px,.55fr) minmax(170px,.55fr) auto;
  border-radius:20px;
}
.company-learner-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:8px;
}
.company-learner-stats{
  display:grid;
  grid-template-columns:minmax(58px,.65fr) minmax(72px,.65fr) minmax(112px,1fr);
  gap:8px;
  align-self:center;
}
.company-learner-stats div{
  min-width:0;
  padding:8px 9px;
  border:1px solid #edf2f7;
  border-radius:12px;
  background:#fbfdff;
}
.company-learner-stats span{
  display:block;
  color:#64748b;
  font-size:11px;
}
.company-learner-stats strong{
  display:block;
  margin-top:3px;
  color:#0f172a;
  font-size:13px;
  font-weight:650;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.company-record-table{
  display:grid;
  border:1px solid #e2e8f0;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.company-record-row{
  display:grid;
  grid-template-columns:minmax(130px,.8fr) minmax(220px,1.45fr) minmax(120px,.65fr) minmax(100px,.55fr) minmax(100px,.55fr) minmax(100px,.55fr);
  gap:14px;
  align-items:center;
  min-height:62px;
  padding:13px 16px;
  border-top:1px solid #edf2f7;
}
.company-record-row:first-child{border-top:0}
.company-record-row:nth-child(even):not(.company-record-row--head){background:#fbfdff}
.company-record-row--head{
  min-height:42px;
  background:#f8fafc;
  color:#64748b;
  font-size:11px;
  font-weight:600;
}
.company-record-row div{min-width:0}
.company-record-row strong{
  display:block;
  min-width:0;
  color:#0f172a;
  font-size:13px;
  font-weight:650;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.company-record-row div:nth-child(2) strong{
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  white-space:normal;
}
.company-record-row>.status-pill{
  justify-self:start;
  width:112px;
  max-width:100%;
}
.company-record-row small,
.company-record-row span:not(.status-pill){
  display:block;
  min-width:0;
  color:#64748b;
  font-size:12px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.company-owner-card{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:14px;
  border:1px solid #edf2f7;
  border-radius:18px;
  background:#fbfdff;
}
.company-owner-card div{min-width:0}
.company-owner-card strong,
.company-owner-card small{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.company-owner-card strong{font-size:15px;font-weight:650}
.company-owner-card small{margin-top:2px;color:#64748b;font-size:12px}
.company-owner-card p,
.panel-note{margin:10px 0 0;color:#64748b;font-size:13px;line-height:1.45}
.organization-contact-layout{margin-top:18px}
.profile-resource-grid--settings{grid-template-columns:repeat(2,minmax(0,1fr))}
.company-settings-shell{
  display:grid;
  gap:18px;
}
.company-settings-tabs{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  padding:6px;
  border:1px solid #e2e8f0;
  border-radius:18px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.company-settings-tabs button{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:0 13px;
  border:0;
  border-radius:13px;
  background:transparent;
  color:#475569;
  font:inherit;
  font-size:13px;
  font-weight:650;
  cursor:pointer;
}
.company-settings-tabs button:hover,
.company-settings-tabs button:focus-visible{
  background:#f8fafc;
  color:#0f172a;
  outline:0;
}
.company-settings-tabs button.is-active{
  background:#0f172a;
  color:#fff;
}
.company-settings-tabs span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  min-height:22px;
  padding:0 7px;
  border-radius:999px;
  background:rgba(148,163,184,.16);
  color:inherit;
  font-size:12px;
}
.company-settings-panel{display:block}
.company-settings-panel[hidden]{display:none}
.company-settings-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,.42fr);
  gap:18px;
  align-items:start;
}
.company-settings-layout--split{
  grid-template-columns:minmax(0,1fr) minmax(320px,.45fr);
}
.company-owner-panel{align-self:start}
.company-settings-resource-panel{
  max-width:920px;
}
.company-resource-grid{
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
}
.company-inline-create{
  margin-bottom:16px;
}
.status-pill--available{border-color:#b9e5c9;background:#eef9f2;color:#166534}
.status-pill--full{border-color:#d7e3ef;background:#f4f7fb;color:#475569}
.status-pill--processing{border-color:#d7cdf7;background:var(--purple-soft);color:#684fb6}
.status-pill--certificate{border-color:#b9e5c9;background:#eef9f2;color:#166534}
.status-pill--paid{border-color:#b9e5c9;background:#eef9f2;color:#166534}
.status-pill--needs-review{border-color:#fed7aa;background:#fff7ed;color:#9a3412}
.company-muted-dash{color:#94a3b8!important;font-size:12px}

.portal-role-staff .metric-card--link{
  color:inherit;
  text-decoration:none;
  transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;
}
.portal-role-staff .status-pill{
  text-transform:none;
}
.portal-role-staff .page-heading .eyebrow{
  color:#64748b;
  font-size:13px;
  font-weight:650;
  text-transform:none;
}
.portal-role-staff .setup-summary-card span{
  color:#475569;
  font-size:14px;
  font-weight:500;
  text-transform:none;
}
.portal-role-staff .setup-summary span{
  text-transform:none;
}
.portal-role-staff .metric-card--link:hover,
.portal-role-staff .metric-card--link:focus-visible{
  border-color:#cbd5e1;
  box-shadow:0 8px 18px rgba(15,23,42,.07);
  outline:0;
  transform:translateY(-1px);
}
.staff-panel-toolbar{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:16px;
  align-items:center;
}
.staff-panel-toolbar .staff-filter-row{
  grid-column:1/-1;
}
.staff-panel-heading-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:8px;
}
.metric-grid--four{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.staff-filter-row{
  display:flex;
  align-items:flex-end;
  flex-wrap:wrap;
  gap:10px;
}
.staff-filter-row--grid{
  display:grid;
  grid-template-columns:minmax(230px,1.4fr) repeat(4,minmax(150px,.75fr));
  width:100%;
}
.staff-filter-row--compact{
  display:flex;
  align-items:flex-end;
  flex-wrap:wrap;
  width:100%;
}
.staff-filter-row--compact .staff-search-field{
  flex:1 1 290px;
  width:min(320px,100%);
  max-width:360px;
}
.staff-filter-row--compact .staff-filter-select{
  flex:0 1 180px;
}
.staff-search-field{
  width:100%;
}
.staff-filter-select{
  display:grid;
  gap:5px;
  min-width:150px;
  color:#64748b;
  font-size:11px;
}
.staff-filter-select span{
  color:#64748b;
  font-size:11px;
  font-weight:600;
}
.staff-filter-select select{
  width:100%;
  height:40px;
  padding:0 34px 0 12px;
  border:1px solid #e2e8f0;
  border-radius:14px;
  appearance:none;
  background:#fff url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 6L8 10L12 6' stroke='%2364748b' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 12px center;
  color:#0f172a;
  font:inherit;
  font-size:13px;
  font-weight:600;
}
.staff-filter-select select:focus{
  border-color:#bfdbfe;
  box-shadow:0 0 0 3px rgba(37,99,235,.1);
  outline:0;
}
.staff-filter-empty{
  margin-top:14px;
}
.staff-readiness-list{
  display:grid;
  gap:10px;
}
.staff-readiness-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  padding:13px;
  border:1px solid #e2e8f0;
  border-radius:18px;
  background:#fbfdff;
}
.staff-readiness-card strong,
.staff-readiness-card span{
  display:block;
}
.staff-readiness-card strong{
  color:#0f172a;
  font-size:14px;
  line-height:1.3;
  font-weight:650;
}
.staff-readiness-card span{
  margin-top:3px;
  color:#64748b;
  font-size:12px;
  line-height:1.4;
}
.staff-readiness-card__count{
  display:grid;
  justify-items:end;
  gap:7px;
}
.staff-readiness-card__count b{
  color:#0f172a;
  font-size:22px;
  line-height:1;
  letter-spacing:-.03em;
}
.staff-readiness-card.is-warning{
  border-color:#fed7aa;
  background:#fffaf5;
}
.staff-readiness-list--operational{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.staff-readiness-card--operational{
  align-items:start;
  min-height:118px;
}
.staff-readiness-card__meta{
  display:grid;
  justify-items:end;
  gap:7px;
}
.staff-readiness-card__meta b{
  color:#0f172a;
  font-size:24px;
  line-height:1;
  letter-spacing:-.03em;
}
.staff-readiness-card__meta .status-pill{
  display:inline-flex;
  margin-top:0;
}
.staff-operational-panel{
  margin-bottom:18px;
}
.schema-hero h2{
  color:#fff;
}
.staff-clamp-two{
  display:-webkit-box!important;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  white-space:normal!important;
}
.staff-tabs-shell{
  display:grid;
  gap:18px;
}
.staff-tabs{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  padding:6px;
  border:1px solid #e2e8f0;
  border-radius:18px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.staff-tabs button{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:0 13px;
  border:0;
  border-radius:13px;
  background:transparent;
  color:#475569;
  font:inherit;
  font-size:13px;
  font-weight:650;
  cursor:pointer;
}
.staff-tabs button:hover,
.staff-tabs button:focus-visible{
  background:#f8fafc;
  color:#0f172a;
  outline:0;
}
.staff-tabs button.is-active{
  background:#0f172a;
  color:#fff;
}
.staff-tabs span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  min-height:22px;
  padding:0 7px;
  border-radius:999px;
  background:rgba(148,163,184,.16);
  color:inherit;
  font-size:12px;
}
.staff-tab-panel[hidden]{display:none}
.staff-org-overview-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,.45fr);
  gap:18px;
  align-items:start;
}
.staff-detail-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.staff-detail-card{
  display:grid;
  gap:4px;
  min-width:0;
  padding:12px;
  border:1px solid #edf2f7;
  border-radius:14px;
  background:#fbfdff;
}
.staff-detail-card span{
  color:#64748b;
  font-size:11px;
  font-weight:600;
}
.staff-detail-card strong{
  min-width:0;
  color:#0f172a;
  font-size:14px;
  font-weight:650;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.staff-detail-card small{
  min-width:0;
  color:#64748b;
  font-size:12px;
  line-height:1.25;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.staff-muted-dash{
  color:#94a3b8!important;
  font-size:12px;
}
.staff-action-note{
  margin:0 0 14px;
  color:#64748b;
  font-size:13px;
  line-height:1.5;
}
.staff-jobs-panel{
  margin-top:0;
}
.staff-provisioning-main{
  display:grid;
  gap:10px;
  min-width:0;
}
.staff-provisioning-layout{
  gap:14px;
}
.staff-organization-layout{
  grid-template-columns:minmax(0,1.9fr) minmax(280px,.35fr);
}
.staff-secondary-panel{
  background:#fbfdff;
}
.staff-create-panel{
  align-self:start;
  padding:0;
  overflow:hidden;
}
.staff-create-details summary{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 52px 14px 18px;
  list-style:none;
  cursor:pointer;
}
.staff-create-details summary::-webkit-details-marker{display:none}
.staff-create-details summary::marker{content:""}
.staff-create-details summary:focus-visible{
  outline:2px solid rgba(14,116,190,.28);
  outline-offset:3px;
  border-radius:12px;
}
.staff-create-details summary span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:26px;
  padding:0 10px;
  border:1px solid #cfe3f4;
  border-radius:999px;
  background:#eff7fd;
  color:#0f5da8;
  font-size:12px;
  font-weight:700;
}
.staff-create-details summary strong{
  color:#0f172a;
  font-size:16px;
  line-height:1.25;
}
.staff-create-details summary::after{
  content:"";
  position:absolute;
  right:18px;
  top:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:10px;
  height:10px;
  border-right:2px solid #64748b;
  border-bottom:2px solid #64748b;
  pointer-events:none;
  transform:translateY(-50%) rotate(45deg);
  transition:transform .16s ease,border-color .16s ease;
}
.staff-create-details[open] summary::after{
  transform:translateY(-50%) rotate(225deg);
}
.staff-create-details{
  position:relative;
}
.staff-create-details .stacked-form{
  padding:0 18px 18px;
}
.staff-create-details:not([open]){
  background:#fbfdff;
}
.portal-role-staff .seat-list--support{
  max-height:none;
  overflow:visible;
  padding-right:0;
}
.order-link-card--compact{
  grid-template-columns:minmax(0,1fr) minmax(315px,.38fr);
  gap:8px;
  padding:10px;
}
.order-link-card--compact .order-link-card__main{
  gap:8px;
}
.order-link-card--compact .order-link-card__header{
  padding-bottom:8px;
}
.order-link-card--compact .order-link-card__details{
  grid-template-columns:minmax(120px,.95fr) minmax(115px,.8fr) minmax(200px,1.45fr) minmax(62px,.36fr) minmax(86px,.5fr) minmax(90px,.55fr);
  gap:8px 12px;
  padding:10px;
}
.order-link-card--compact .order-link-card__action{
  gap:7px;
  padding:8px;
  align-content:start;
}
.order-link-card--compact .match-callout{
  display:block;
  padding:0;
  border:0;
  background:transparent;
  color:#475569;
}
.order-link-card--compact .match-callout span,
.order-link-card--compact .match-callout strong{
  display:inline;
  font-size:12px;
  line-height:1.35;
}
.order-link-card--compact .match-callout span::after{
  content:": ";
}
.order-link-card--compact .match-callout.is-suggested strong{
  color:#126da8;
}
.order-link-card--compact .order-link-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:6px;
  align-items:end;
}
.order-link-card--compact .field{
  gap:4px;
}
.order-link-card--compact .field select{
  min-height:36px;
}
.order-link-card--compact .order-link-form .primary-button{
  min-height:36px;
  min-width:82px;
  padding:0 10px;
}
.order-link-card--compact .order-link-form .staff-action-note{
  grid-column:1 / -1;
  margin:0;
  color:#6b7d90;
  font-size:12px;
  line-height:1.3;
}
.provisioning-job-card--compact{
  display:grid;
  gap:8px;
  padding:10px 12px;
}
.provisioning-job-card__title{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.provisioning-job-card__title strong{
  display:block;
  min-width:0;
  color:#0f172a;
  font-size:14px;
  line-height:1.3;
  font-weight:650;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.provisioning-job-card__note{
  display:block;
  margin-top:4px;
  color:#6b7d90;
  font-size:12px;
  line-height:1.35;
}
.support-record-card--compact{
  display:grid;
  grid-template-columns:minmax(170px,.58fr) minmax(0,1.42fr) auto;
  gap:10px;
  align-items:center;
  padding:9px 11px;
}
.support-record-card--compact .support-record-card__header{
  display:contents;
}
.support-record-card--compact .support-record-card__header>div{
  min-width:0;
}
.support-record-card--compact .support-record-card__header .status-pill{
  grid-column:3;
  grid-row:1;
}
.support-record-card--compact .support-record-card__body{
  grid-column:2;
  grid-row:1;
  gap:7px;
}
.support-record-card--compact .support-record-card__body div{
  padding:0;
  background:transparent;
  box-shadow:none;
}
.staff-provisioning-main .empty-state--compact{
  display:flex;
  align-items:center;
  gap:8px;
  padding:9px 11px;
}
.staff-provisioning-main .empty-state--compact strong,
.staff-provisioning-main .empty-state--compact span{
  display:inline;
  line-height:1.35;
}
.support-record-card__body--missing-credential{
  grid-template-columns:minmax(0,1.55fr) minmax(110px,.72fr) minmax(110px,.72fr) minmax(58px,.25fr);
}
.support-record-card__credential.is-muted{
  padding:4px 0;
  background:transparent;
  box-shadow:none;
}
.staff-overview-mini-list{
  display:grid;
  gap:8px;
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid #edf2f7;
}
.staff-overview-mini-list__header,
.staff-overview-order-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.staff-overview-mini-list__header strong{
  color:#0f172a;
  font-size:14px;
}
.staff-overview-mini-list__header button{
  padding:0;
  border:0;
  background:transparent;
  color:#0f5da8;
  font:inherit;
  font-size:12px;
  cursor:pointer;
}
.staff-overview-mini-list__header button:hover{text-decoration:underline}
.staff-overview-order-row{
  min-width:0;
  padding:9px 10px;
  border:1px solid #edf2f7;
  border-radius:12px;
  background:#fbfdff;
}
.staff-overview-order-row span:first-child{
  min-width:0;
}
.staff-overview-order-row strong,
.staff-overview-order-row small{
  display:block;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.staff-overview-order-row strong{
  color:#0f172a;
  font-size:13px;
}
.staff-overview-order-row small{
  color:#64748b;
  font-size:12px;
}
.staff-overview-order-row b{
  flex:0 0 auto;
  color:#0f172a;
  font-size:13px;
  font-weight:650;
}
.portal-role-staff .data-table{
  border-color:#e2e8f0;
  border-radius:18px;
}
.portal-role-staff .data-table__row{
  min-height:62px;
  border-top-color:#edf2f7;
}
.portal-role-staff .data-table__row--head{
  min-height:42px;
  background:#f8fafc;
  color:#64748b;
  font-size:11px;
  font-weight:600;
  text-transform:none;
}
.portal-role-staff .data-table--organizations .data-table__row{
  grid-template-columns:minmax(0,1.65fr) minmax(0,.7fr) minmax(86px,.45fr) minmax(86px,.45fr) minmax(86px,.45fr) minmax(86px,.45fr);
}
.portal-role-staff .data-table--org-orders .data-table__row{
  grid-template-columns:minmax(0,.9fr) minmax(0,1.3fr) minmax(120px,.6fr) minmax(120px,.55fr);
}
.staff-record-status{
  justify-self:start;
  width:118px;
  max-width:100%;
}

@media (max-width: 1180px){
  .staff-filter-row--grid,
  .staff-filter-row--compact{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .metric-grid--four{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .staff-org-overview-grid{
    grid-template-columns:1fr;
  }
  .staff-readiness-list--operational,
  .staff-organization-layout{
    grid-template-columns:1fr;
  }
  .order-link-card--compact{
    grid-template-columns:1fr;
  }
  .order-link-card--compact .order-link-card__details{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .support-record-card--compact{
    grid-template-columns:1fr auto;
  }
  .support-record-card--compact .support-record-card__body{
    grid-column:1/-1;
    grid-row:2;
  }
  .support-record-card--compact .support-record-card__header .status-pill{
    grid-column:2;
    grid-row:1;
  }
}

@media (max-width: 720px){
  .staff-filter-row--grid,
  .staff-filter-row--compact,
  .metric-grid--four,
  .staff-detail-grid{
    grid-template-columns:1fr;
  }
  .staff-readiness-card{
    grid-template-columns:1fr;
  }
  .staff-readiness-card__count{
    justify-items:start;
  }
  .staff-readiness-card__meta{
    justify-items:start;
  }
  .staff-filter-row--compact .staff-search-field,
  .staff-filter-row--compact .staff-filter-select{
    flex:1 1 100%;
    width:100%;
    max-width:none;
  }
  .order-link-card--compact .order-link-card__details,
  .support-record-card--compact .support-record-card__body,
  .support-record-card__body--missing-credential{
    grid-template-columns:1fr;
  }
  .support-record-card--compact{
    grid-template-columns:1fr;
  }
  .support-record-card--compact .support-record-card__header .status-pill{
    grid-column:1;
    grid-row:2;
    justify-self:start;
  }
  .support-record-card--compact .support-record-card__body{
    grid-row:3;
  }
  .staff-overview-order-row{
    align-items:flex-start;
    flex-direction:column;
  }
}

.student-dashboard--home{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,360px);
  gap:22px;
  align-items:start;
}
.student-dashboard--home>.student-welcome-card,
.student-dashboard--home>.student-summary-grid{
  grid-column:1/-1;
}
.student-dashboard--home>.student-main{
  grid-column:1;
}
.student-dashboard--home>.student-side{
  grid-column:2;
}
.student-main,.student-side{
  gap:18px;
}
.student-reference-header{
  margin-bottom:24px;
}
.student-reference-header h1{
  margin:0;
  color:#0f172a;
  font-size:34px;
  line-height:1.1;
  font-weight:700;
  letter-spacing:-.045em;
}
.student-reference-header p{
  margin:8px 0 0;
  color:#64748b;
  font-size:15px;
  line-height:1.5;
}
.student-welcome-card,.student-next-card,.student-section,.student-profile-card,.student-side-card,.student-summary-card{
  border-color:#e2e8f0;
  border-radius:28px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
}
.student-welcome-card::before{
  display:none;
}
.student-welcome-card--dashboard{
  grid-template-columns:minmax(0,1fr) auto;
  gap:28px;
  min-height:205px;
  padding:32px;
  border:0;
  border-radius:30px;
  background:#0f172a;
  color:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
  margin-bottom:2px;
}
.student-welcome-card--dashboard h1{
  color:#fff;
  font-size:clamp(32px,4vw,44px);
  line-height:1.05;
  font-weight:700;
  letter-spacing:-.045em;
}
.student-welcome-card--dashboard .hero-copy{
  margin-top:14px;
  max-width:680px;
  color:#cbd5e1;
  font-size:16px;
  line-height:1.65;
}
.student-hero-kicker{
  margin:0 0 8px;
  color:#cbd5e1;
  font-size:14px;
  font-weight:700;
}
.student-hero-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  align-self:end;
  gap:12px;
}
.student-hero-stats article{
  display:grid;
  align-content:start;
  gap:0;
  min-width:0;
  min-height:84px;
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.10);
}
.student-hero-stats strong{
  color:#fff;
  font-size:26px;
  line-height:1;
  font-weight:600;
}
.student-hero-stats span{
  display:block;
  margin-top:7px;
  color:#cbd5e1;
  font-size:12px;
}
.student-summary-grid--home{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.student-summary-grid:not(.student-summary-grid--home){
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
}
.student-summary-card{
  min-height:124px;
  padding:20px;
}
.student-summary-card span:not(.student-summary-card__icon){
  color:#475569;
  font-size:14px;
  font-weight:500;
  text-transform:none;
}
.student-summary-card strong{
  margin-top:8px;
  color:#020617;
  font-size:32px;
  line-height:1;
  font-weight:650;
  letter-spacing:-.04em;
}
.student-summary-card small{
  color:#64748b;
  font-size:12px;
}
.student-summary-card__icon{
  right:20px;
  top:20px;
  width:46px;
  height:46px;
  border-radius:16px;
  background:#f1f5f9;
  color:#334155;
}
.student-summary-card__icon svg{
  width:20px;
  height:20px;
}
.student-section,.student-side-card{
  padding:20px;
}
.student-section--plain{
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.student-section-heading{
  align-items:flex-end;
  margin-bottom:20px;
}
.student-section-heading h2{
  font-size:28px;
  line-height:1.1;
  font-weight:700;
  letter-spacing:-.04em;
}
.student-section-heading p:not(.eyebrow){
  margin:4px 0 0;
  color:#64748b;
  font-size:14px;
}
.student-section-heading>span,
.student-section-actions>span{
  min-height:30px;
  border:1px solid #dbeafe;
  background:#eff6ff;
  color:#1d4ed8;
}
.student-section-link{
  min-height:40px;
  padding:0 15px;
  border:1px solid #dbe4ef;
  border-radius:14px;
  background:#fff;
  color:#334155;
  font-size:14px;
}
.student-section-link:hover{
  border-color:#cbd5e1;
  background:#f8fafc;
  text-decoration:none;
}
.student-course-grid,
.student-course-grid--home,
.student-course-grid--wide{
  grid-template-columns:1fr;
  gap:16px;
}
.student-course-card{
  grid-template-columns:minmax(0,1fr) auto;
  grid-template-areas:
    "header actions"
    "details details"
    "helper helper";
  gap:16px 20px;
  padding:20px 20px 18px;
  border-color:#e2e8f0;
  border-radius:28px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
}
.student-course-card:hover{
  border-color:#cbd5e1;
  box-shadow:0 12px 24px rgba(15,23,42,.08);
  transform:translateY(-2px);
}
.student-course-card::before{
  display:none;
}
.student-course-card__header{
  gap:5px;
}
.student-course-card__title-row{
  display:flex;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:12px;
}
.student-course-card__badges{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}
.student-course-card h3{
  margin:0;
  font-size:18px;
  font-weight:700;
  line-height:1.35;
  letter-spacing:-.02em;
}
.student-course-provider{
  margin:5px 0 0;
  color:#64748b;
  font-size:14px;
}
.student-course-card__status{
  max-width:none;
  min-height:28px;
  padding-inline:10px;
  font-weight:600;
}
.student-course-details{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin-top:0;
  color:#475569;
}
.student-course-details div,
.student-course-details div:nth-child(odd),
.student-course-details div:nth-child(even){
  display:flex;
  align-items:center;
  gap:6px;
  padding:0;
  border-right:0;
}
.student-course-details div:nth-child(n+3){
  margin-top:0;
}
.student-course-details svg{
  width:16px;
  height:16px;
  flex:0 0 auto;
  fill:none;
  stroke:#94a3b8;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.student-course-details dt{
  color:#475569;
  font-size:14px;
  text-transform:none;
}
.student-course-details dt::after{content:""}
.student-course-details dd{
  margin:0;
  color:#475569;
  font-size:14px;
}
.student-course-helper{
  padding-top:2px;
  border-radius:0;
  background:transparent;
  color:#64748b;
}
.student-course-card__actions{
  align-self:start;
  justify-content:flex-end;
  gap:8px;
}
.student-action-button{
  gap:8px;
  min-height:40px;
  padding:0 15px;
  border:0;
  border-radius:14px;
  background:#0f172a;
  font-size:14px;
  font-weight:800;
}
.student-action-button:hover{
  background:#1e293b;
  box-shadow:0 3px 8px rgba(15,23,42,.1);
  transform:none;
}
.student-action-button__chevron{
  width:16px;
  height:16px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.student-action-button--secondary{
  border-color:#dbe4ef;
  background:#fff;
  color:#0f172a;
}
.student-action-button--secondary:hover{
  border-color:#cbd5e1;
  background:#f8fafc;
}
.student-action-button--status,
.student-action-status{
  min-height:38px;
  border:1px solid #e9d5ff;
  border-radius:14px;
  background:#faf5ff;
  color:#6d28d9;
  font-size:13px;
  font-weight:600;
}
.student-next-panel__body{
  display:grid;
  gap:10px;
  margin-top:16px;
  padding:16px;
  border-radius:24px;
  background:#eff6ff;
  color:#172554;
}
.student-side-title{
  margin:0;
  color:#0f172a;
  font-size:16px;
  line-height:1.2;
  font-weight:700;
  letter-spacing:-.02em;
}
.student-next-panel__body .student-action-button:not(.student-action-button--secondary):not(.student-action-button--status){
  width:100%;
  margin-top:6px;
  background:#2563eb;
}
.student-next-panel__body .student-action-button:not(.student-action-button--secondary):not(.student-action-button--status):hover{
  background:#1d4ed8;
  box-shadow:0 3px 8px rgba(37,99,235,.1);
}
.student-next-panel__body h3{
  margin:0;
  color:#0f172a;
  font-size:16px;
  line-height:1.35;
  font-weight:700;
}
.student-next-panel__body p{
  margin:0;
  color:#475569;
  font-size:13px;
  line-height:1.45;
}
.student-next-panel__body .eyebrow{
  margin:0;
  color:#1d4ed8;
  font-size:12px;
}
.student-next-actions{
  margin-top:4px;
}
.student-update-list{
  display:grid;
  gap:12px;
  margin-top:16px;
}
.student-update-list article{
  display:grid;
  gap:7px;
  padding:12px;
  border-radius:18px;
  background:#f1f5f9;
}
.student-update-list article div{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.student-update-list strong{
  color:#0f172a;
  font-size:14px;
  line-height:1.25;
}
.student-update-list span{
  color:#94a3b8;
  font-size:12px;
  white-space:nowrap;
}
.student-update-list p{
  margin:0;
  color:#64748b;
  font-size:13px;
  line-height:1.45;
}
.student-mini-list article{
  border-color:#e2e8f0;
  border-radius:16px;
  background:#f8fafc;
}
.student-mini-list strong{
  color:#0f172a;
  font-size:14px;
  line-height:1.35;
}
.student-mini-list a{
  color:#2563eb;
}
.student-help-card p:not(.eyebrow){
  color:#64748b;
}
.student-welcome-card--page{
  border-radius:28px;
  padding:28px 30px;
}
.student-welcome-card--page h1{
  font-size:38px;
  font-weight:700;
}
.student-progress-card{
  border-radius:18px;
  background:#f8fafc;
  box-shadow:inset 0 0 0 1px #e2e8f0;
}
.student-progress-card strong{
  color:#2563eb;
  font-weight:650;
}
.student-certificate-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.student-certificate-card,
.student-billing-card{
  border-color:#e2e8f0;
  border-radius:28px;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
}
.student-certificate-card__body{
  grid-template-columns:1fr;
}
.student-certificate-card__title-row{
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
}
.student-certificate-card .student-course-details,
.student-certificate-card .student-course-card__actions{
  grid-area:auto;
}
.student-certificate-card .student-course-details{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px 18px;
  margin-top:16px;
}
.student-certificate-card .student-course-details--compact div{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
}
.student-certificate-card__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:16px;
}
.student-certificate-card__icon-box{
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  border-radius:18px;
  background:#ecfdf5;
  color:#047857;
}
.student-certificate-card__icon-box svg{
  width:22px;
  height:22px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.student-certificate-card .student-course-card__actions{
  justify-content:flex-start;
  align-self:auto;
  margin-top:4px;
}
.student-invoice-card{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
  padding:20px;
}
.student-invoice-card .student-billing-card__main{
  display:grid;
  gap:10px;
  min-width:0;
}
.student-invoice-card__top{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}
.student-invoice-card__top strong{
  color:#64748b;
  font-size:14px;
}
.student-invoice-card h2{
  display:block;
  margin:2px 0 0;
  font-size:19px;
  line-height:1.35;
  letter-spacing:-.02em;
}
.student-invoice-course-summary{
  display:grid;
  gap:6px;
  min-width:0;
  max-width:720px;
}
.student-invoice-course-summary span{
  min-width:0;
  color:#334155;
  font-size:13px;
  line-height:1.35;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.student-invoice-course-summary small{
  color:#64748b;
  font-size:12px;
}
.student-invoice-included-courses{
  max-width:720px;
  border:1px solid #edf2f7;
  border-radius:14px;
  background:#fbfdff;
}
.student-invoice-included-courses summary{
  padding:10px 12px;
  color:#0f5da8;
  font-size:12px;
  cursor:pointer;
}
.student-invoice-included-courses summary:hover{
  text-decoration:underline;
}
.student-invoice-included-courses ul{
  display:grid;
  gap:6px;
  margin:0;
  padding:0 12px 12px 28px;
  color:#475569;
  font-size:13px;
}
.student-invoice-card p{
  margin:0;
  color:#64748b;
  font-size:14px;
}
.student-invoice-card__actions{
  display:grid;
  justify-items:end;
  gap:12px;
  min-width:170px;
}
.student-invoice-card__actions strong{
  color:#0f172a;
  font-size:18px;
  font-weight:650;
  white-space:nowrap;
}
.student-billing-card__meta div{
  border-radius:16px;
  background:#f8fafc;
  box-shadow:inset 0 0 0 1px #e2e8f0;
}
.student-filter-tabs a,
.student-pagination a,
.student-pagination span,
.student-pagination button{
  border-color:#dbe4ef;
  border-radius:999px;
}
.student-filter-tabs a.is-active,
.student-pagination a.is-active,
.student-pagination button.is-active{
  border-color:#2563eb;
  background:#2563eb;
  color:#fff;
}
.student-filter-tabs{
  margin:0;
}
.student-filter-tabs a{
  min-height:40px;
  padding:0 14px;
}
.student-filter-tabs .tab-count{
  margin-left:4px;
  color:inherit;
  font-size:12px;
}
.student-search-row{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  margin:0;
}
.student-search-field{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:40px;
  width:260px;
  padding:0 12px;
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:#fff;
  color:#94a3b8;
}
.student-search-field svg{
  width:16px;
  height:16px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.student-search-field input{
  width:100%;
  min-width:0;
  height:38px;
  padding:0;
  border:0;
  background:transparent;
  color:#0f172a;
  font:inherit;
  font-size:14px;
  outline:0;
}
.student-search-field:focus-within{
  border-color:#bfdbfe;
  box-shadow:0 0 0 3px rgba(37,99,235,.1);
}
.student-section-heading--toolbar{
  align-items:center;
  justify-content:flex-start;
}
.student-filter-button{
  flex:0 0 auto;
}
.student-filter-dropdown{
  position:relative;
  flex:0 0 auto;
}
.student-filter-menu{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  z-index:30;
  display:grid;
  min-width:230px;
  padding:6px;
  border:1px solid #dbe4ef;
  border-radius:16px;
  background:#fff;
  box-shadow:0 18px 42px rgba(15,23,42,.14);
}
.student-filter-menu[hidden]{
  display:none;
}
.student-filter-menu__option{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  width:100%;
  min-height:38px;
  padding:0 10px;
  border:0;
  border-radius:12px;
  background:transparent;
  color:#334155;
  font:inherit;
  font-size:13px;
  font-weight:700;
  text-align:left;
  cursor:pointer;
}
.student-filter-menu__option:hover,
.student-filter-menu__option:focus-visible{
  background:#f8fafc;
  color:#0f172a;
  outline:0;
}
.student-filter-menu__option.is-active{
  background:#eff6ff;
  color:#1d4ed8;
}
.student-filter-menu__option .tab-count{
  color:inherit;
  font-size:12px;
  opacity:.72;
}
.student-pagination button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  min-height:34px;
  padding:0 10px;
  border:1px solid #dbe4ef;
  background:#fff;
  color:#52667d;
  font:inherit;
  font-size:13px;
  font-weight:800;
  cursor:pointer;
}
.student-pagination button:hover:not(:disabled){
  border-color:#b9d5ee;
  background:#f3f9ff;
  color:#0b5ca8;
}
.student-pagination button:disabled{
  background:#f5f8fc;
  color:#91a2b5;
  cursor:not-allowed;
}
.student-action-button--download{
  width:100%;
  margin-top:4px;
}

/* Product polish pass: consolidate the app into a calmer client-facing surface. */
.portal-role-learner,
.portal-role-company,
.portal-role-staff{
  --portal-bg:#f6f8fb;
  --portal-card:#fff;
  --portal-card-border:#dde7f1;
  --portal-card-shadow:0 1px 2px rgba(15,23,42,.04),0 18px 42px rgba(15,23,42,.035);
  --portal-card-shadow-hover:0 1px 2px rgba(15,23,42,.05),0 24px 54px rgba(15,23,42,.055);
  --portal-accent:#1d5d9f;
  background:
    linear-gradient(180deg,#f8fbff 0,#f6f8fb 32%,#f8fafc 100%);
}
.portal-role-learner .portal-workspace,
.portal-role-company .portal-workspace,
.portal-role-staff .portal-workspace{
  min-height:100vh;
  background:
    linear-gradient(180deg,rgba(255,255,255,.58),rgba(255,255,255,0) 260px),
    var(--portal-bg);
}
.portal-role-learner .portal-sidebar,
.portal-role-company .portal-sidebar,
.portal-role-staff .portal-sidebar{
  background:rgba(255,255,255,.94);
  box-shadow:1px 0 0 #e2e8f0;
}
.portal-role-learner .portal-brand,
.portal-role-company .portal-brand,
.portal-role-staff .portal-brand,
.portal-role-learner .portal-topbar,
.portal-role-company .portal-topbar,
.portal-role-staff .portal-topbar{
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(16px);
}
.portal-role-learner .portal-nav-link,
.portal-role-company .portal-nav-link,
.portal-role-staff .portal-nav-link{
  min-height:46px;
  border-radius:14px;
  font-weight:650;
}
.portal-role-learner .portal-nav-link.is-active,
.portal-role-company .portal-nav-link.is-active,
.portal-role-staff .portal-nav-link.is-active{
  background:#111827;
  box-shadow:0 10px 22px rgba(15,23,42,.10);
}
.portal-role-learner .portal-user-card,
.portal-role-company .portal-user-card,
.portal-role-staff .portal-user-card{
  background:#f8fafc;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.72);
}
.portal-role-learner .page-shell,
.portal-role-company .page-shell,
.portal-role-staff .page-shell{
  width:min(1360px,calc(100% - 56px));
}
.portal-role-learner .main-shell,
.portal-role-company .main-shell,
.portal-role-staff .main-shell{
  padding-top:30px;
  padding-bottom:68px;
}
.portal-role-learner .portal-topbar strong,
.portal-role-company .portal-topbar strong,
.portal-role-staff .portal-topbar strong{
  font-weight:650;
}
.portal-role-learner .portal-topbar span,
.portal-role-company .portal-topbar span,
.portal-role-staff .portal-topbar span{
  color:#74839a;
  font-weight:550;
}
.portal-home-link,
.portal-menu-button{
  border-color:#dbe5ef;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.portal-role-learner .student-welcome-card--dashboard,
.portal-role-company .hero-panel,
.portal-role-staff .hero-panel{
  position:relative;
  border-radius:26px;
  background:
    linear-gradient(135deg,#101827 0,#16243a 56%,#1f3d5c 100%);
  box-shadow:0 1px 2px rgba(15,23,42,.08),0 26px 60px rgba(15,23,42,.10);
}
.portal-role-learner .student-welcome-card--dashboard::after,
.portal-role-company .hero-panel::after,
.portal-role-staff .hero-panel::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.10);
}
.portal-role-learner .student-summary-card,
.portal-role-learner .student-side-card,
.portal-role-learner .student-course-card,
.portal-role-learner .student-certificate-card,
.portal-role-learner .student-billing-card,
.portal-role-company .client-summary-card,
.portal-role-company .panel,
.portal-role-company .setup-summary-card,
.portal-role-company .company-purchase-card,
.portal-role-company .company-seat-card,
.portal-role-company .learner-roster-card,
.portal-role-company .support-record-card,
.portal-role-staff .metric-card,
.portal-role-staff .panel,
.portal-role-staff .setup-summary-card,
.portal-role-staff .order-link-card,
.portal-role-staff .provisioning-failure-card,
.portal-role-staff .company-seat-card,
.portal-role-staff .support-record-card{
  border-color:var(--portal-card-border);
  border-radius:22px;
  background:var(--portal-card);
  box-shadow:var(--portal-card-shadow);
}
.portal-role-learner .student-course-card:hover,
.portal-role-company .company-purchase-card:hover,
.portal-role-company .company-seat-card:hover,
.portal-role-staff .metric-card--link:hover{
  border-color:#cbd8e6;
  box-shadow:var(--portal-card-shadow-hover);
  transform:translateY(-1px);
}
.portal-role-learner .student-reference-header,
.portal-role-company .page-heading,
.portal-role-staff .page-heading{
  margin-bottom:28px;
}
.portal-role-learner .student-reference-header h1,
.portal-role-company .page-heading h1,
.portal-role-staff .page-heading h1{
  font-size:clamp(32px,3vw,42px);
  font-weight:650;
  letter-spacing:-.045em;
}
.portal-role-learner .student-reference-header p,
.portal-role-company .page-heading .hero-copy,
.portal-role-staff .page-heading .hero-copy{
  max-width:720px;
  color:#5f7188;
  font-size:15px;
}
.student-section-heading h2,
.portal-role-company .panel-heading h2,
.portal-role-staff .panel-heading h2{
  font-weight:650;
}
.student-summary-card strong,
.portal-role-company .client-summary-card strong,
.portal-role-staff .metric-card strong{
  font-weight:620;
}
.student-action-button,
.primary-button,
.secondary-button,
.small-button,
.nav-button,
.student-section-link{
  font-weight:650;
}
.student-action-button{
  border-radius:12px;
}
.student-action-button:hover,
.primary-button:hover,
.secondary-button:hover,
.small-button:hover,
.student-section-link:hover{
  box-shadow:0 4px 12px rgba(15,23,42,.08);
  transform:none;
}
.student-action-button--secondary{
  border:1px solid #dbe4ef;
}
.student-invoice-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(190px,auto);
  gap:24px;
  align-items:start;
  padding:22px;
}
.student-invoice-card__top{
  gap:10px;
}
.student-invoice-card__top strong{
  color:#4b627c;
  font-weight:650;
}
.student-invoice-card h2{
  font-size:20px;
  font-weight:650;
}
.student-invoice-course-summary{
  max-width:780px;
}
.student-invoice-course-summary span{
  color:#334155;
}
.student-invoice-included-courses{
  max-width:780px;
  border-color:#dde7f1;
  background:#f8fbff;
}
.student-invoice-included-courses summary{
  color:#1d5d9f;
  font-weight:550;
}
.student-invoice-card__actions{
  align-self:stretch;
  justify-items:end;
  align-content:start;
  gap:13px;
  min-width:190px;
  padding-left:24px;
  border-left:1px solid #edf2f7;
}
.student-invoice-card__actions strong{
  margin-bottom:6px;
  font-size:20px;
  font-weight:650;
}
.student-invoice-card__actions .student-action-button{
  min-height:auto;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  color:#0f172a;
  box-shadow:none;
}
.student-invoice-card__actions .student-action-button:hover{
  color:#1d5d9f;
  background:transparent;
  box-shadow:none;
  text-decoration:underline;
}
.student-invoice-card__actions .student-action-button__chevron{
  width:15px;
  height:15px;
  color:#475569;
}
.company-purchase-card__main h3,
.company-seat-card__main strong,
.learner-roster-card strong,
.support-record-card strong{
  font-weight:650;
}
.portal-role-company .company-purchase-card{
  gap:18px;
  padding:20px;
}
.portal-role-company .company-purchase-card__body{
  grid-template-columns:minmax(0,1.45fr) minmax(300px,.55fr);
  align-items:start;
}
.portal-role-company .company-purchase-meta{
  grid-template-columns:1fr;
  align-self:start;
  gap:8px;
}
.portal-role-company .company-purchase-meta div{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:8px 14px;
  padding:13px 14px;
  border-radius:14px;
}
.portal-role-company .company-purchase-meta dt{
  margin:0;
}
.portal-role-company .company-purchase-meta dd{
  justify-self:end;
  text-align:right;
}
.portal-role-company .company-purchase-meta small{
  grid-column:1/-1;
  justify-self:end;
  margin-top:-3px;
}
.portal-role-company .company-purchase-card__actions{
  margin-top:-4px;
}
.company-course-summary span,
.student-invoice-course-summary span,
.company-activity-row span,
.purchase-card span{
  color:#475569;
}
.status-pill{
  font-weight:600;
}
.student-filter-menu__option,
.student-pagination button{
  font-weight:650;
}

/* Learner product dashboard overhaul. */
.portal-role-learner{
  --student-ink:#101827;
  --student-muted:#64748b;
  --student-soft:#f8fafc;
  --student-line:#e2e8f0;
  --student-blue:#1d5d9f;
}
.student-product{
  display:grid;
  gap:22px;
}
.student-product-pagehead{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(360px,.62fr);
  gap:24px;
  align-items:center;
  padding:30px;
  border:1px solid rgba(213,224,236,.92);
  border-radius:30px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,255,255,.94)),
    #fff;
  box-shadow:0 1px 2px rgba(15,23,42,.04),0 18px 42px rgba(15,23,42,.032);
}
.student-product-pagehead .student-product-kicker{
  margin-bottom:12px;
  color:var(--student-blue);
}
.student-product-pagehead h1{
  margin:0;
  color:var(--student-ink);
  font-size:clamp(38px,4vw,54px);
  line-height:.98;
  font-weight:650;
  letter-spacing:-.06em;
}
.student-product-pagehead p:not(.student-product-kicker){
  max-width:620px;
  margin:12px 0 0;
  color:var(--student-muted);
  font-size:16px;
  line-height:1.55;
}
.student-product-pagehead__stats{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.student-product-pagehead__stats article{
  min-height:88px;
  padding:16px;
  border:1px solid #e6edf5;
  border-radius:18px;
  background:#f8fafc;
}
.student-product-pagehead__stats span{
  display:block;
  color:#64748b;
  font-size:12px;
  font-weight:650;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.student-product-pagehead__stats strong{
  display:block;
  margin-top:10px;
  color:#101827;
  font-size:27px;
  line-height:1;
  font-weight:650;
  letter-spacing:-.04em;
}
.student-product-hero{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(340px,.65fr);
  gap:18px;
  align-items:stretch;
}
.student-product-hero__copy,
.student-product-next,
.student-product-panel,
.student-product-metrics{
  border:1px solid rgba(213,224,236,.92);
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.04),0 18px 42px rgba(15,23,42,.035);
}
.student-product-hero__copy{
  position:relative;
  overflow:hidden;
  min-height:244px;
  padding:34px;
  border-radius:30px;
  background:
    linear-gradient(135deg,#0f172a 0,#13243b 54%,#1d5d9f 130%);
  color:#fff;
}
.student-product-hero__copy::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:4px;
  background:linear-gradient(90deg,#1d5d9f,#6aa4df 45%,rgba(255,255,255,.5));
}
.student-product-hero__copy h1{
  position:relative;
  max-width:760px;
  margin:0;
  color:#fff;
  font-size:clamp(38px,4.6vw,58px);
  line-height:.98;
  font-weight:650;
  letter-spacing:-.058em;
}
.student-product-hero__copy p:not(.student-product-kicker){
  position:relative;
  max-width:640px;
  margin:18px 0 0;
  color:rgba(241,245,249,.82);
  font-size:17px;
  line-height:1.55;
}
.student-product-kicker,
.student-product-panel__header span,
.student-product-next>span,
.student-product-metrics span{
  margin:0;
  color:#64748b;
  font-size:12px;
  line-height:1;
  font-weight:650;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.student-product-kicker{
  position:relative;
  margin-bottom:18px;
  color:rgba(219,234,254,.86);
}
.student-product-next{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:18px;
  min-height:244px;
  padding:24px;
  border-radius:28px;
}
.student-product-next h2{
  margin:0;
  color:var(--student-ink);
  font-size:26px;
  line-height:1.13;
  font-weight:650;
  letter-spacing:-.035em;
}
.student-product-next p{
  margin:0;
  color:var(--student-muted);
  font-size:14px;
  line-height:1.55;
}
.student-product-next__meta{
  display:grid;
  gap:4px;
  margin-top:auto;
  padding-top:14px;
  border-top:1px solid #eef2f7;
}
.student-product-next__meta small{
  color:#94a3b8;
  font-size:12px;
}
.student-product-next__meta strong{
  color:var(--student-ink);
  font-size:15px;
  font-weight:650;
}
.student-product-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
}
.student-product-actions .student-action-button{
  min-height:42px;
  padding:0 16px;
}
.student-product-metrics{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1px;
  overflow:hidden;
  border-radius:24px;
  background:#e8eef5;
}
.student-product-metrics article{
  display:grid;
  align-content:start;
  min-height:116px;
  padding:22px;
  background:#fff;
}
.student-product-metrics strong{
  margin-top:12px;
  color:var(--student-ink);
  font-size:31px;
  line-height:1;
  font-weight:650;
  letter-spacing:-.045em;
}
.student-product-metrics small{
  margin-top:8px;
  color:#77869a;
  font-size:13px;
  line-height:1.35;
}
.student-product-layout{
  display:grid;
  grid-template-columns:minmax(0,1.52fr) minmax(320px,.48fr);
  gap:20px;
  align-items:start;
}
.student-product-panel{
  display:grid;
  gap:18px;
  min-width:0;
  padding:22px;
  border-radius:26px;
}
.student-product-panel--main{
  padding:24px;
}
.student-product-panel__header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
}
.student-product-panel__header--toolbar{
  align-items:flex-start;
  flex-direction:column;
}
.student-product-panel__header h2{
  margin:6px 0 0;
  color:var(--student-ink);
  font-size:24px;
  line-height:1.15;
  font-weight:650;
  letter-spacing:-.035em;
}
.student-product-panel__header .student-section-link{
  flex:0 0 auto;
  min-height:36px;
  padding:0 13px;
  border-radius:999px;
  font-size:13px;
}
.student-product-course-list{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.student-product-course-list .student-course-card{
  grid-template-columns:1fr;
  grid-template-areas:
    "header"
    "details"
    "helper"
    "actions";
  gap:15px;
  min-height:248px;
  padding:20px;
  border-radius:24px;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.student-product-course-list .student-course-card:hover{
  border-color:#cbd8e6;
  box-shadow:0 14px 28px rgba(15,23,42,.07);
}
.student-product-course-list .student-course-card__title-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
  gap:12px;
}
.student-product-course-list .student-course-card h3{
  font-size:18px;
  line-height:1.3;
  font-weight:650;
}
.student-product-course-list .student-course-card__status{
  justify-self:end;
  white-space:nowrap;
}
.student-product-course-list .student-course-details{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:9px 12px;
}
.student-product-course-list .student-course-details div,
.student-product-course-list .student-course-details div:nth-child(odd),
.student-product-course-list .student-course-details div:nth-child(even){
  align-items:flex-start;
}
.student-product-course-list .student-course-details dt,
.student-product-course-list .student-course-details dd{
  font-size:13px;
}
.student-product-course-list .student-course-card__actions{
  justify-content:flex-start;
  margin-top:auto;
}
.student-product-stack{
  display:grid;
  gap:20px;
}
.student-update-list--product{
  margin-top:0;
}
.student-update-list--product article{
  padding:0 0 14px;
  border-bottom:1px solid #eef2f7;
  border-radius:0;
  background:transparent;
}
.student-update-list--product article:last-child{
  padding-bottom:0;
  border-bottom:0;
}
.student-update-list--product strong{
  font-size:14px;
  font-weight:650;
}
.student-product-quick-links{
  display:grid;
  gap:10px;
}
.student-product-quick-links a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  min-height:58px;
  padding:13px 14px;
  border:1px solid #e2e8f0;
  border-radius:16px;
  background:#f8fafc;
  color:var(--student-ink);
  text-decoration:none;
}
.student-product-quick-links a:hover,
.student-product-quick-links a:focus-visible{
  border-color:#cbd8e6;
  background:#fff;
  box-shadow:0 8px 18px rgba(15,23,42,.055);
  outline:0;
}
.student-product-quick-links strong{
  font-size:14px;
  font-weight:650;
}
.student-product-quick-links span{
  color:#64748b;
  font-size:13px;
  white-space:nowrap;
}
.student-product-panel--browser{
  gap:22px;
}
.student-product-panel--browser .student-search-row{
  width:100%;
  flex:0 1 auto;
  justify-content:flex-start;
}
.student-product--courses .student-course-grid--wide{
  gap:14px;
}
.student-product--courses .student-course-card{
  min-height:158px;
  padding:20px;
  border-radius:22px;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.student-product--courses .student-course-card:hover{
  box-shadow:0 12px 24px rgba(15,23,42,.065);
}
.student-product--courses .student-course-details{
  grid-template-columns:repeat(2,minmax(160px,auto));
  justify-content:start;
  max-width:680px;
}
.student-product--courses .student-course-helper{
  max-width:620px;
}
.student-product--courses .student-course-card__actions{
  align-self:center;
}
.student-product--certificates .student-certificate-grid{
  gap:14px;
}
.student-product--certificates .student-certificate-card{
  border-radius:22px;
}
.student-product--billing .student-billing-list{
  display:grid;
  gap:14px;
}
.student-product--billing .student-product-pagehead__stats article:last-child:nth-child(odd){
  grid-column:1/-1;
}
.student-product--billing .student-invoice-card{
  border-radius:22px;
}

/* Learner depth pass: add hierarchy without decorative rails or heavy shadows. */
.portal-role-learner .portal-workspace{
  background:
    linear-gradient(180deg,rgba(244,248,252,.96) 0,rgba(248,250,252,1) 360px,rgba(248,250,252,1) 100%),
    #f7fafc;
}
.portal-role-learner .main-shell{
  background:transparent;
}
.portal-role-learner .student-product{
  gap:24px;
}
.portal-role-learner .student-product-hero__copy,
.portal-role-learner .student-product-next,
.portal-role-learner .student-product-pagehead,
.portal-role-learner .student-product-panel,
.portal-role-learner .student-product-metrics,
.portal-role-learner .student-course-card,
.portal-role-learner .student-certificate-card,
.portal-role-learner .student-invoice-card{
  border-color:#d9e4ef;
  box-shadow:
    0 1px 2px rgba(15,23,42,.035),
    0 10px 24px rgba(30,64,104,.04);
}
.student-product-pagehead{
  position:relative;
  overflow:hidden;
  padding:34px 36px;
  background:
    linear-gradient(135deg,rgba(255,255,255,.98) 0,rgba(248,252,255,.98) 50%,rgba(237,246,255,.94) 100%);
}
.student-product-pagehead::after{
  content:"";
  position:absolute;
  inset:auto 34px 28px 34px;
  height:1px;
  background:linear-gradient(90deg,rgba(29,93,159,.18),rgba(29,93,159,0));
  pointer-events:none;
}
.student-product-pagehead>*{
  position:relative;
  z-index:1;
}
.student-product-pagehead__stats article{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg,#fff 0,#f7fbff 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
}
.student-product-hero__copy{
  box-shadow:
    0 1px 2px rgba(15,23,42,.08),
    0 18px 44px rgba(15,23,42,.10);
}
.student-product-hero__progress{
  position:relative;
  display:grid;
  gap:12px;
  max-width:520px;
  margin-top:30px;
  padding:16px;
  border:1px solid rgba(255,255,255,.15);
  border-radius:20px;
  background:rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1);
}
.student-product-hero__progress div:first-child{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.student-product-hero__progress strong{
  color:#fff;
  font-size:14px;
  font-weight:650;
}
.student-product-hero__progress span{
  color:rgba(226,232,240,.88);
  font-size:13px;
}
.student-product-progress{
  height:9px;
  overflow:hidden;
  border-radius:999px;
  background:rgba(255,255,255,.18);
}
.student-product-progress span{
  display:block;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,#38bdf8,#22c55e);
}
.student-product-next{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg,#fff 0,#fbfdff 100%);
}
.student-product-metrics{
  gap:0;
  border:1px solid #d3e0ed;
  background:#dbe6f1;
}
.student-product-metrics article{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg,#fff 0,#fbfdff 100%);
}
.student-product-panel{
  background:
    linear-gradient(180deg,#fff 0,#fbfdff 100%);
}
.student-product-panel--main,
.student-product-panel--browser{
  background:
    linear-gradient(180deg,#fff 0,#fff 54%,#f8fbff 100%);
}
.student-product .student-course-card{
  position:relative;
  overflow:hidden;
  border-color:#d6e3ef;
  background:
    linear-gradient(180deg,#fff 0,#fbfdff 100%);
}
.student-product .student-course-card__header,
.student-product .student-course-details,
.student-product .student-course-helper,
.student-product .student-course-card__actions{
  position:relative;
  z-index:1;
}
.student-product .student-course-details div,
.student-product .student-course-details div:nth-child(odd),
.student-product .student-course-details div:nth-child(even){
  min-height:34px;
  padding:7px 9px;
  border:1px solid #edf2f7;
  border-radius:12px;
  background:#f8fafc;
}
.student-product .student-course-details svg{
  stroke:#7392b4;
}
.student-product .student-course-details dt{
  color:#64748b;
}
.student-product .student-course-details dd{
  color:#26364c;
}
.student-product--courses .student-course-card{
  grid-template-columns:minmax(0,1fr) minmax(150px,auto);
  grid-template-areas:
    "header actions"
    "details actions"
    "helper actions";
  padding-left:24px;
}
.student-product--courses .student-course-card__actions{
  align-self:stretch;
  align-items:center;
  justify-content:center;
  min-width:150px;
  margin:-20px -20px -20px 0;
  padding:20px;
  border-left:1px solid #edf2f7;
  background:linear-gradient(180deg,#f8fbff 0,#fff 100%);
}
.student-product-course-list .student-course-card{
  padding-left:24px;
}
.student-product-course-list .student-course-card__actions{
  padding-top:4px;
}
.student-product--certificates .student-certificate-card{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg,#fff 0,#fbfdff 100%);
}
.student-product--certificates .student-certificate-card .student-action-button--download{
  box-shadow:0 4px 10px rgba(15,23,42,.055);
}
.student-product--billing .student-invoice-card{
  background:
    linear-gradient(180deg,#fff 0,#fbfdff 100%);
}
.student-product--billing .student-invoice-card__actions{
  border-left-color:#e2e8f0;
  background:
    linear-gradient(180deg,#f8fbff 0,#fff 100%);
}
.student-product-quick-links a{
  background:
    linear-gradient(180deg,#fff 0,#f8fafc 100%);
}

@media (max-width: 1180px){
  .client-summary-grid--wide,
  .setup-summary-grid--five{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .company-dashboard-layout,
  .company-purchase-card__body,
  .company-learner-card{
    grid-template-columns:1fr;
  }
  .company-panel-toolbar{
    align-items:flex-start;
    flex-direction:column;
  }
  .company-panel-toolbar .company-filter-row{
    width:100%;
    justify-content:flex-start;
  }
  .company-filter-row--records{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .company-settings-layout,
  .company-settings-layout--split{
    grid-template-columns:1fr;
  }
  .company-record-row{
    grid-template-columns:minmax(0,1.2fr) minmax(0,1.2fr) minmax(130px,.6fr) minmax(100px,.45fr) minmax(100px,.45fr) minmax(110px,.5fr);
  }
  .student-summary-grid--home{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .student-welcome-card--dashboard{
    grid-template-columns:1fr;
  }
  .student-course-details{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .student-search-row{
    width:100%;
    justify-content:flex-start;
  }
  .student-search-field{
    flex:1;
    width:auto;
  }
  .student-hero-stats{
    width:100%;
  }
  .student-product-hero,
  .student-product-pagehead,
  .student-product-layout{
    grid-template-columns:1fr;
  }
  .student-product-stack{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .student-product-panel__header--toolbar{
    align-items:flex-start;
    flex-direction:column;
  }
  .student-product-panel--browser .student-search-row{
    width:100%;
    justify-content:flex-start;
  }
}

@media (max-width: 1100px){
  .portal-role-learner .portal-app-shell,
  .portal-role-company .portal-app-shell,
  .portal-role-staff .portal-app-shell{
    grid-template-columns:252px minmax(0,1fr);
  }
  .student-dashboard--home{
    grid-template-columns:1fr;
  }
  .student-dashboard--home>.student-main,
  .student-dashboard--home>.student-side{
    grid-column:1;
  }
  .student-side{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .student-help-card{
    grid-column:auto;
  }
  .setup-summary-grid--four,
  .setup-summary-grid--five,
  .client-summary-grid--wide{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .company-record-table{
    border-radius:18px;
  }
  .company-record-row{
    grid-template-columns:1fr;
    align-items:start;
    gap:7px;
  }
  .company-record-row--head{
    display:none;
  }
}

@media (max-width: 820px){
  .portal-role-learner .page-shell,
  .portal-role-company .page-shell,
  .portal-role-staff .page-shell{
    width:min(100% - 28px,1280px);
  }
  .portal-role-learner .portal-sidebar,
  .portal-role-company .portal-sidebar,
  .portal-role-staff .portal-sidebar{
    position:fixed;
    inset:0 auto 0 0;
    z-index:40;
    width:288px;
    height:100vh;
    min-height:100vh;
    border-right:1px solid #e2e8f0;
    border-bottom:0;
    transform:translateX(-100%);
    transition:transform .18s ease;
    box-shadow:0 12px 24px rgba(15,23,42,.08);
  }
  .portal-role-learner .portal-app-shell.is-nav-open .portal-sidebar,
  .portal-role-company .portal-app-shell.is-nav-open .portal-sidebar,
  .portal-role-staff .portal-app-shell.is-nav-open .portal-sidebar{
    transform:translateX(0);
  }
  .portal-role-learner .portal-app-shell.is-nav-open .portal-mobile-overlay,
  .portal-role-company .portal-app-shell.is-nav-open .portal-mobile-overlay,
  .portal-role-staff .portal-app-shell.is-nav-open .portal-mobile-overlay{
    display:block;
  }
  .portal-role-learner .portal-mobile-overlay,
  .portal-role-company .portal-mobile-overlay,
  .portal-role-staff .portal-mobile-overlay{
    position:fixed;
    inset:0;
    z-index:30;
    border:0;
    padding:0;
    background:rgba(15,23,42,.42);
  }
  .portal-menu-button{
    display:inline-flex;
  }
  .portal-home-link span{
    display:none;
  }
  .portal-home-link{
    width:42px;
    padding:0;
  }
  .student-welcome-card--dashboard,
  .student-welcome-card--page{
    padding:26px 24px;
    border-radius:24px;
  }
  .student-welcome-card--dashboard h1,
  .student-welcome-card--page h1{
    font-size:32px;
  }
  .student-summary-grid--home,
  .student-side,
  .student-certificate-grid{
    grid-template-columns:1fr;
  }
  .student-course-card{
    grid-template-columns:1fr;
    grid-template-areas:
      "header"
      "details"
      "helper"
      "actions";
  }
  .student-course-card__actions{
    justify-content:flex-start;
  }
  .student-invoice-card{
    flex-direction:column;
    align-items:stretch;
  }
  .student-invoice-card__actions{
    justify-items:start;
  }
  .student-product-hero__copy{
    min-height:0;
    padding:28px;
    border-radius:24px;
  }
  .student-product-hero__copy h1{
    font-size:38px;
  }
  .student-product-next,
  .student-product-panel{
    border-radius:22px;
  }
  .student-product-pagehead{
    padding:28px;
    border-radius:24px;
  }
  .student-product-metrics,
  .student-product-pagehead__stats,
  .student-product-course-list,
  .student-product-stack{
    grid-template-columns:1fr;
  }
  .student-product-metrics article{
    min-height:0;
  }
  .student-product--courses .student-course-card{
    grid-template-columns:1fr;
    grid-template-areas:
      "header"
      "details"
      "helper"
      "actions";
  }
  .student-product--courses .student-course-card__actions{
    align-self:auto;
    justify-content:flex-start;
    min-width:0;
    margin:0;
    padding:12px 0 0;
    border-top:1px solid #edf2f7;
    border-left:0;
    background:transparent;
  }
  .company-purchase-card__header,
  .company-purchase-card__actions,
  .company-purchase-progress div:first-child{
    align-items:flex-start;
    flex-direction:column;
  }
  .company-purchase-meta,
  .company-learner-stats,
  .profile-resource-grid--settings,
  .organization-contact-layout{
    grid-template-columns:1fr;
  }
  .company-assigned-learner-row,
  .assign-seat-form{
    grid-template-columns:1fr;
  }
}

@media (max-width: 560px){
  .portal-role-learner .portal-topbar strong,
  .portal-role-company .portal-topbar strong,
  .portal-role-staff .portal-topbar strong{
    font-size:18px;
  }
  .student-hero-stats{
    display:grid;
    grid-template-columns:1fr;
  }
  .student-hero-stats article{
    min-width:0;
  }
  .student-section,.student-side-card{
    padding:18px;
  }
  .student-section-heading{
    align-items:flex-start;
    flex-direction:column;
  }
  .student-section-heading--toolbar{
    align-items:stretch;
  }
  .student-search-row{
    flex-direction:column;
    align-items:stretch;
  }
  .student-search-field,
  .student-filter-dropdown,
  .student-filter-button{
    width:100%;
  }
  .student-filter-menu{
    left:0;
    right:auto;
    min-width:100%;
  }
  .setup-summary-grid--four,
  .setup-summary-grid--five,
  .client-summary-grid--wide,
  .company-filter-row,
  .company-filter-row--records{
    grid-template-columns:1fr;
  }
  .company-filter-row{
    display:grid;
    align-items:stretch;
  }
  .company-filter-row--records{
    grid-template-columns:1fr;
  }
  .company-search-field,
  .company-filter-select{
    width:100%;
    min-width:0;
  }
  .company-settings-tabs{
    align-items:stretch;
    flex-direction:column;
  }
  .company-settings-tabs button{
    width:100%;
    justify-content:space-between;
  }
  .student-course-details div:nth-child(n+2){
    border-top:0;
  }
  .student-course-details{
    grid-template-columns:1fr;
  }
  .student-product .student-course-details,
  .student-product--courses .student-course-details,
  .student-product-course-list .student-course-details,
  .student-certificate-card .student-course-details{
    grid-template-columns:1fr;
  }
}

/* Learner workspace refactor. Scoped to the learner role to avoid company/staff redesign drift. */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.portal-role-learner{
  --learner-ink:#142235;
  --learner-muted:#5f7188;
  --learner-subtle:#7c8ca2;
  --learner-bg:#f6f9fc;
  --learner-panel:#ffffff;
  --learner-soft:#eef6fb;
  --learner-line:#d9e5ef;
  --learner-blue:#1d6fb8;
  --learner-blue-dark:#0c3558;
  --learner-cyan:#0d97b7;
  --learner-green:#1d7b4f;
  --learner-amber:#a86200;
  --learner-purple:#6750b7;
  --learner-red:#b42318;
  --learner-focus:#2b8bd3;
  --learner-shadow:0 10px 24px rgba(20,34,53,.07);
  --learner-radius:8px;
  background:var(--learner-bg);
  color:var(--learner-ink);
}
.portal-role-learner h1,
.portal-role-learner h2,
.portal-role-learner h3{
  letter-spacing:0;
}
.portal-role-learner .portal-app-shell{
  grid-template-columns:268px minmax(0,1fr);
}
.portal-role-learner .portal-workspace{
  min-width:0;
  background:
    linear-gradient(180deg,#eef6fb 0,#f6f9fc 300px,#f8fafc 100%);
}
.portal-role-learner .page-shell{
  width:min(1360px,calc(100% - 56px));
  margin-left:auto;
  margin-right:auto;
}
.portal-role-learner .main-shell{
  padding-top:24px;
}
.portal-role-learner .portal-sidebar{
  gap:22px;
  padding:20px 16px;
  background:linear-gradient(180deg,#092642 0,#0c3558 58%,#102f4a 100%);
}
.portal-role-learner .portal-brand{
  min-height:70px;
  padding:10px 10px 18px;
}
.portal-role-learner .portal-brand__logo-wrap{
  max-width:184px;
}
.portal-role-learner .portal-nav-group__label{
  color:#b9d8ef;
  font-size:11px;
}
.portal-role-learner .portal-nav-link{
  min-height:44px;
  border-radius:var(--learner-radius);
  color:#e8f5ff;
}
.portal-role-learner .portal-nav-link:hover{
  background:rgba(255,255,255,.12);
  color:#fff;
}
.portal-role-learner .portal-nav-link.is-active{
  background:#fff;
  color:#0c3558;
  box-shadow:0 8px 20px rgba(0,0,0,.14);
}
.portal-role-learner .portal-nav-link.is-active::before{
  background:#22b8cf;
}
.portal-role-learner .portal-nav-icon{
  border-radius:var(--learner-radius);
  background:rgba(255,255,255,.12);
}
.portal-role-learner .portal-user-card{
  border-color:rgba(255,255,255,.16);
  border-radius:var(--learner-radius);
  background:rgba(255,255,255,.09);
}
.portal-role-learner .portal-user-card__meta{
  margin-top:2px;
  color:#c9e5f7;
}
.portal-role-learner .nav-button--full{
  min-height:38px;
  border-radius:var(--learner-radius);
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  color:#e9f6ff;
}
.portal-role-learner .portal-topbar{
  min-height:76px;
  background:rgba(255,255,255,.9);
  border-bottom-color:#dce8f2;
}
.portal-role-learner .portal-topbar__inner{
  min-height:76px;
  align-items:center;
}
.portal-role-learner .portal-topbar span{
  color:var(--learner-muted);
  text-transform:none;
}
.portal-role-learner .portal-topbar strong{
  color:var(--learner-ink);
  font-size:18px;
  letter-spacing:0;
}
.portal-topbar__actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  min-width:0;
}
.learner-global-search{
  width:min(460px,36vw);
  min-width:260px;
}
.learner-global-search label,
.learner-search-field{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:42px;
  padding:0 12px;
  border:1px solid var(--learner-line);
  border-radius:var(--learner-radius);
  background:#fff;
  color:var(--learner-muted);
}
.learner-global-search svg,
.learner-search-field svg{
  width:18px;
  height:18px;
  flex:0 0 auto;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-global-search input,
.learner-search-field input{
  width:100%;
  min-width:0;
  border:0;
  outline:0;
  background:transparent;
  color:var(--learner-ink);
  font:inherit;
}
.learner-global-search label:focus-within,
.learner-search-field:focus-within,
.learner-select-field:focus-within{
  border-color:var(--learner-focus);
  box-shadow:0 0 0 3px rgba(43,139,211,.18);
}
.learner-topbar-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border:1px solid var(--learner-line);
  border-radius:var(--learner-radius);
  background:#fff;
  color:var(--learner-blue-dark);
  text-decoration:none;
}
.learner-topbar-icon svg,
.learner-btn svg,
.learner-quick-card__arrow{
  width:18px;
  height:18px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-topbar-icon:hover,
.learner-topbar-icon:focus-visible{
  border-color:#b8d1e6;
  background:#f2f8fc;
  outline:0;
}
.portal-role-learner .learner-topbar-profile{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:9px;
  max-width:240px;
  min-height:42px;
  padding:4px 10px 4px 4px;
  border:1px solid var(--learner-line);
  border-radius:var(--learner-radius);
  background:#fff;
  cursor:pointer;
  list-style:none;
}
.portal-role-learner .learner-topbar-profile::-webkit-details-marker{
  display:none;
}
.learner-topbar-profile .portal-avatar{
  display:flex;
  flex:0 0 32px;
  width:32px;
  height:32px;
  line-height:1;
}
.learner-topbar-profile span:last-child{
  min-width:0;
}
.learner-topbar-profile strong,
.learner-topbar-profile small{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.learner-topbar-profile strong{
  margin:0;
  font-size:13px;
}
.learner-topbar-profile small{
  font-size:12px;
}
.learner-profile-menu{
  position:relative;
  display:block;
}
.learner-profile-menu[open]{
  z-index:20;
}
.learner-profile-menu[open] .learner-topbar-profile,
.learner-profile-menu .learner-topbar-profile:hover,
.learner-profile-menu .learner-topbar-profile:focus-visible{
  border-color:#b8d1e6;
  background:#f8fbfd;
  outline:0;
}
.learner-profile-menu .learner-topbar-profile:focus-visible{
  box-shadow:0 0 0 3px rgba(43,139,211,.18);
}
.learner-profile-menu__chevron{
  transition:transform .16s ease;
}
.learner-profile-menu[open] .learner-profile-menu__chevron{
  transform:rotate(180deg);
}
.learner-profile-menu__panel{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  display:grid;
  gap:4px;
  width:260px;
  padding:8px;
  border:1px solid #dbe5ef;
  border-radius:14px;
  background:#fff;
  box-shadow:0 18px 44px rgba(15,23,42,.14);
}
.learner-profile-menu__identity{
  display:grid;
  gap:2px;
  padding:10px 10px 12px;
  border-bottom:1px solid #e8eef4;
}
.learner-profile-menu__identity strong{
  color:var(--learner-ink);
  font-size:14px;
  line-height:1.25;
}
.learner-profile-menu__identity small{
  overflow:hidden;
  color:var(--learner-muted);
  font-size:12px;
  line-height:1.35;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.learner-profile-menu__panel a,
.learner-profile-menu__panel button{
  display:flex;
  align-items:center;
  width:100%;
  min-height:38px;
  padding:8px 10px;
  border:0;
  border-radius:10px;
  background:transparent;
  color:var(--learner-ink);
  font:inherit;
  font-size:13px;
  font-weight:650;
  text-align:left;
  text-decoration:none;
  cursor:pointer;
}
.learner-profile-menu__panel a:hover,
.learner-profile-menu__panel a:focus-visible,
.learner-profile-menu__panel button:hover,
.learner-profile-menu__panel button:focus-visible{
  background:#f2f8fc;
  color:var(--learner-blue-dark);
  outline:0;
}
.learner-profile-menu__panel form{
  margin:4px 0 0;
  padding-top:6px;
  border-top:1px solid #e8eef4;
}
.learner-profile-menu__panel button{
  color:#5d6c7b;
}
.learner-workspace{
  display:grid;
  gap:24px;
}
.learner-eyebrow{
  margin:0 0 8px;
  color:var(--learner-blue);
  font-size:12px;
  line-height:1;
  font-weight:750;
  text-transform:uppercase;
}
.learner-page-header{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,.55fr);
  gap:24px;
  align-items:center;
  padding:28px;
  border:1px solid #cfe0ee;
  border-radius:var(--learner-radius);
  background:
    radial-gradient(circle at right 20%,rgba(34,184,207,.14),transparent 28%),
    linear-gradient(135deg,#ffffff 0,#f3f9fd 58%,#e9f5fb 100%);
}
.learner-page-header h1{
  margin:0;
  color:var(--learner-ink);
  font-size:42px;
  line-height:1.05;
  font-weight:760;
}
.learner-page-header p:not(.learner-eyebrow){
  max-width:680px;
  margin:10px 0 0;
  color:var(--learner-muted);
  font-size:16px;
}
.learner-page-header__stats{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.learner-page-header__stats article,
.learner-stat-grid article,
.learner-action-item,
.learner-topic-card,
.learner-course-card,
.learner-certificate-card,
.learner-invoice-card,
.learner-quick-card{
  border:1px solid var(--learner-line);
  border-radius:var(--learner-radius);
  background:#fff;
}
.learner-page-header__stats article{
  min-height:82px;
  padding:14px;
}
.learner-page-header__stats span,
.learner-stat-grid span{
  display:block;
  color:var(--learner-muted);
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
}
.learner-page-header__stats strong{
  display:block;
  margin-top:8px;
  color:var(--learner-ink);
  font-size:25px;
  line-height:1;
}
.learner-hero{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(330px,.75fr);
  gap:18px;
}
.learner-hero__copy,
.learner-hero__next,
.learner-billing-summary,
.learner-support-card{
  border:1px solid #cfe0ee;
  border-radius:var(--learner-radius);
  box-shadow:var(--learner-shadow);
}
.learner-hero__copy{
  padding:30px;
  background:
    radial-gradient(circle at 88% 12%,rgba(34,184,207,.28),transparent 26%),
    linear-gradient(135deg,#0c3558 0,#1d6fb8 66%,#0d97b7 100%);
  color:#fff;
}
.learner-hero__copy .learner-eyebrow,
.learner-hero__copy p{
  color:#e8f7ff;
}
.learner-hero__copy h1{
  margin:0;
  color:#fff;
  font-size:44px;
  line-height:1.05;
  font-weight:780;
}
.learner-hero__copy>p{
  max-width:620px;
  margin:12px 0 0;
  font-size:17px;
}
.learner-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.learner-hero__next{
  position:relative;
  overflow:hidden;
  display:grid;
  align-content:space-between;
  min-height:260px;
  padding:24px;
  background:#fff;
}
.learner-hero__next h2{
  max-width:330px;
  margin:0;
  color:var(--learner-ink);
  font-size:25px;
  line-height:1.18;
}
.learner-hero__next p:not(.learner-eyebrow){
  max-width:350px;
  margin:10px 0 0;
  color:var(--learner-muted);
}
.learner-hero__meta{
  display:grid;
  gap:4px;
  max-width:280px;
  padding-top:16px;
  border-top:1px solid #e8eef5;
}
.learner-hero__meta span{
  color:var(--learner-subtle);
  font-size:12px;
}
.learner-hero__meta strong{
  color:var(--learner-ink);
}
.learner-hero__art{
  position:absolute;
  right:12px;
  bottom:8px;
  width:210px;
  height:auto;
  color:#1d6fb8;
  opacity:.18;
  fill:none;
  stroke:currentColor;
  stroke-width:5;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-progress{
  display:grid;
  gap:10px;
  max-width:560px;
  margin-top:22px;
  padding:14px;
  border:1px solid rgba(255,255,255,.28);
  border-radius:var(--learner-radius);
  background:rgba(255,255,255,.12);
}
.learner-progress__header{
  display:flex;
  justify-content:space-between;
  gap:14px;
  color:#fff;
}
.learner-progress__header strong,
.learner-progress__header span{
  color:#fff;
  font-size:14px;
}
.learner-progress__track{
  height:9px;
  overflow:hidden;
  border-radius:999px;
  background:rgba(255,255,255,.22);
}
.learner-progress__track span{
  display:block;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,#7dd3fc,#86efac);
}
.learner-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:42px;
  padding:0 16px;
  border:1px solid transparent;
  border-radius:var(--learner-radius);
  font-size:14px;
  font-weight:750;
  line-height:1;
  text-decoration:none;
  cursor:pointer;
}
.learner-btn--primary{
  background:var(--learner-blue-dark);
  color:#fff;
}
.learner-btn--primary:hover,
.learner-btn--primary:focus-visible{
  background:#092642;
  color:#fff;
}
.learner-btn--secondary{
  border-color:var(--learner-line);
  background:#fff;
  color:var(--learner-blue-dark);
}
.learner-btn--secondary:hover,
.learner-btn--secondary:focus-visible{
  border-color:#b8d1e6;
  background:#f3f9fd;
}
.learner-btn--tertiary{
  background:transparent;
  color:var(--learner-blue);
}
.learner-btn--status,
.learner-btn:disabled{
  border-color:#d8e3ee;
  background:#eef3f7;
  color:#687b90;
  cursor:default;
}
.learner-btn:focus-visible,
.learner-text-link:focus-visible,
.learner-status-tabs button:focus-visible,
.learner-filter-menu__option:focus-visible,
.learner-pagination button:focus-visible,
.learner-details-list summary:focus-visible{
  outline:3px solid rgba(43,139,211,.28);
  outline-offset:2px;
}
.learner-text-link{
  color:var(--learner-blue);
  font-size:14px;
  font-weight:750;
  text-decoration:none;
}
.learner-text-link:hover{
  text-decoration:underline;
}
.learner-icon-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  flex:0 0 auto;
  border-radius:var(--learner-radius);
  background:#eef6fb;
  color:var(--learner-blue);
}
.learner-icon-badge svg{
  width:21px;
  height:21px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-icon-badge--green,
.learner-icon-badge--certificate,
.learner-icon-badge--check{background:#eaf8f0;color:var(--learner-green)}
.learner-icon-badge--amber,
.learner-icon-badge--billing,
.learner-icon-badge--receipt{background:#fff4df;color:var(--learner-amber)}
.learner-icon-badge--purple,
.learner-icon-badge--help,
.learner-icon-badge--clock{background:#f1edff;color:var(--learner-purple)}
.learner-icon-badge--red,
.learner-icon-badge--alert{background:#fff0ef;color:var(--learner-red)}
.learner-icon-badge--blue,
.learner-icon-badge--training,
.learner-icon-badge--online-course,
.learner-icon-badge--in-person-course,
.learner-icon-badge--asbestos,
.learner-icon-badge--safety,
.learner-icon-badge--equipment,
.learner-icon-badge--blueprint,
.learner-icon-badge--management,
.learner-icon-badge--whmis{background:#e8f4fc;color:var(--learner-blue)}
.learner-icon-badge--muted{background:#eef3f7;color:#6b7c90}
.learner-status{
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-height:28px;
  padding:0 10px;
  border:1px solid #d8e3ee;
  border-radius:999px;
  background:#f5f8fb;
  color:#52677d;
  font-size:12px;
  font-weight:750;
  white-space:nowrap;
}
.learner-status svg{
  width:14px;
  height:14px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-status--completed,
.learner-status--active,
.learner-status--paid,
.learner-status--ok{border-color:#b9e5c9;background:#eaf8f0;color:var(--learner-green)}
.learner-status--in-progress{border-color:#b8d8f0;background:#e8f4fc;color:var(--learner-blue)}
.learner-status--ready{border-color:#b9e5c9;background:#ecfdf5;color:var(--learner-green)}
.learner-status--access-pending,
.learner-status--waiting{border-color:#d7cdf7;background:#f1edff;color:var(--learner-purple)}
.learner-status--expiring,
.learner-status--due{border-color:#f2c489;background:#fff4df;color:var(--learner-amber)}
.learner-status--expired,
.learner-status--not-passed,
.learner-status--access-issue,
.learner-status--error{border-color:#fac5c0;background:#fff0ef;color:var(--learner-red)}
.learner-action-required{
  display:grid;
  gap:14px;
}
.learner-action-required__grid,
.learner-stat-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.learner-stat-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.learner-action-item{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  gap:12px;
  min-height:86px;
  padding:16px;
}
.learner-action-item strong{
  display:block;
  color:var(--learner-ink);
  font-size:24px;
  line-height:1;
}
.learner-action-item small{
  display:block;
  margin-top:5px;
  color:var(--learner-muted);
  font-size:13px;
}
.learner-stat-grid article{
  min-height:108px;
  padding:18px;
}
.learner-stat-grid strong{
  display:block;
  margin-top:12px;
  color:var(--learner-ink);
  font-size:30px;
  line-height:1;
}
.learner-stat-grid small{
  display:block;
  margin-top:8px;
  color:var(--learner-muted);
  font-size:13px;
}
.learner-dashboard__grid{
  display:grid;
  grid-template-columns:minmax(0,1.52fr) minmax(320px,.48fr);
  gap:24px;
  align-items:start;
}
.learner-dashboard__side,
.learner-panel{
  display:grid;
  gap:18px;
  min-width:0;
}
.learner-section-heading,
.learner-browser__toolbar{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
}
.learner-section-heading h2,
.learner-browser__toolbar h2{
  margin:0;
  color:var(--learner-ink);
  font-size:24px;
  line-height:1.2;
}
.learner-section-heading h3{
  margin:0;
  color:var(--learner-ink);
  font-size:19px;
}
.learner-section-heading p:not(.learner-eyebrow){
  margin:6px 0 0;
  color:var(--learner-muted);
  font-size:14px;
}
.learner-card-grid{
  display:grid;
  gap:14px;
}
.learner-card-grid--two,
.learner-card-grid--certificates,
.learner-card-grid--topics{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.learner-card-grid--list{
  grid-template-columns:1fr;
}
.learner-course-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:16px;
  align-items:start;
  padding:18px;
  box-shadow:0 1px 2px rgba(20,34,53,.04);
}
.learner-course-card:hover{
  border-color:#bdd4e7;
  box-shadow:var(--learner-shadow);
}
.learner-course-card__body{
  min-width:0;
  display:grid;
  gap:12px;
}
.learner-course-card__top{
  display:flex;
  justify-content:space-between;
  gap:12px;
}
.learner-course-card__top p{
  margin:0 0 4px;
  color:var(--learner-muted);
  font-size:13px;
}
.learner-course-card h3{
  margin:0;
  color:var(--learner-ink);
  font-size:18px;
  line-height:1.3;
}
.learner-course-card__actions{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:8px;
  min-width:132px;
}
.learner-course-card--compact{
  grid-template-columns:auto minmax(0,1fr);
}
.learner-course-card--compact .learner-course-card__actions{
  grid-column:2;
  align-items:flex-start;
}
.learner-meta-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin:0;
}
.learner-meta-grid div{
  min-width:0;
  padding:9px 10px;
  border:1px solid #e7eef5;
  border-radius:var(--learner-radius);
  background:#f8fbfd;
}
.learner-meta-grid dt{
  color:var(--learner-subtle);
  font-size:11px;
  font-weight:750;
  text-transform:uppercase;
}
.learner-meta-grid dd{
  margin:3px 0 0;
  color:var(--learner-ink);
  font-size:13px;
}
.learner-card-note{
  margin:0;
  color:var(--learner-muted);
  font-size:14px;
}
.learner-static-action{
  min-height:36px;
  display:inline-flex;
  align-items:center;
  padding:0 12px;
  border:1px solid #d8e3ee;
  border-radius:var(--learner-radius);
  background:#f1f5f9;
  color:#687b90;
  font-size:13px;
  font-weight:700;
}
.learner-update-list{
  display:grid;
  gap:12px;
}
.learner-update-list article{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:12px;
  align-items:start;
  padding-bottom:12px;
  border-bottom:1px solid #e7eef5;
}
.learner-update-list article:last-child{
  padding-bottom:0;
  border-bottom:0;
}
.learner-update-list strong,
.learner-update-list small{
  display:block;
}
.learner-update-list strong{
  color:var(--learner-ink);
  font-size:14px;
}
.learner-update-list small{
  margin-top:3px;
  color:var(--learner-muted);
  font-size:13px;
}
.learner-update-list em{
  color:var(--learner-subtle);
  font-size:12px;
  font-style:normal;
}
.learner-quick-grid{
  display:grid;
  gap:10px;
}
.learner-quick-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  min-height:66px;
  padding:12px;
  color:var(--learner-ink);
  text-decoration:none;
}
.learner-quick-card:hover,
.learner-quick-card:focus-visible{
  border-color:#bdd4e7;
  box-shadow:var(--learner-shadow);
  outline:0;
}
.learner-quick-card strong,
.learner-quick-card small{
  display:block;
}
.learner-quick-card small{
  margin-top:3px;
  color:var(--learner-muted);
  font-size:12px;
}
.learner-control-row{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:10px;
}
.learner-search-field{
  width:320px;
}
.learner-select-field select{
  min-height:42px;
  min-width:160px;
  padding:0 34px 0 12px;
  border:1px solid var(--learner-line);
  border-radius:var(--learner-radius);
  background:#fff;
  color:var(--learner-ink);
  font:inherit;
}
.learner-filter-dropdown{
  position:relative;
}
.learner-filter-menu{
  position:absolute;
  right:0;
  top:calc(100% + 8px);
  z-index:8;
  display:grid;
  min-width:240px;
  padding:8px;
  border:1px solid var(--learner-line);
  border-radius:var(--learner-radius);
  background:#fff;
  box-shadow:var(--learner-shadow);
}
.learner-filter-menu__option{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-height:38px;
  padding:0 10px;
  border:0;
  border-radius:var(--learner-radius);
  background:transparent;
  color:var(--learner-ink);
  font:inherit;
  cursor:pointer;
}
.learner-filter-menu__option:hover,
.learner-filter-menu__option.is-active{
  background:#edf6fc;
  color:var(--learner-blue-dark);
}
.learner-filter-menu__option small{
  color:var(--learner-muted);
}
.learner-status-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.learner-status-tabs button{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:0 12px;
  border:1px solid var(--learner-line);
  border-radius:999px;
  background:#fff;
  color:var(--learner-muted);
  font:inherit;
  font-size:13px;
  font-weight:750;
  cursor:pointer;
}
.learner-status-tabs button.is-active,
.learner-status-tabs button:hover{
  border-color:#bdd4e7;
  background:#e8f4fc;
  color:var(--learner-blue-dark);
}
.learner-status-tabs small{
  color:inherit;
}
.learner-pagination{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  padding-top:8px;
}
.learner-pagination p{
  margin:0;
  color:var(--learner-muted);
  font-size:13px;
}
.learner-pagination nav{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.learner-pagination button{
  min-height:34px;
  padding:0 10px;
  border:1px solid var(--learner-line);
  border-radius:var(--learner-radius);
  background:#fff;
  color:var(--learner-ink);
  font:inherit;
  font-size:13px;
}
.learner-pagination button.is-active{
  background:var(--learner-blue-dark);
  color:#fff;
}
.learner-pagination button:disabled{
  color:#93a4b6;
  background:#f1f5f9;
}
.learner-certificate-section{
  display:grid;
  gap:12px;
}
.learner-certificate-card{
  display:grid;
  grid-template-columns:132px minmax(0,1fr);
  min-height:260px;
  overflow:hidden;
}
.learner-certificate-card__preview{
  display:grid;
  align-content:center;
  justify-items:center;
  gap:12px;
  padding:18px;
  background:
    radial-gradient(circle at 50% 30%,rgba(34,184,207,.15),transparent 34%),
    #f2f8fc;
  color:var(--learner-muted);
  font-size:12px;
  font-weight:750;
  text-transform:uppercase;
}
.learner-certificate-card__body{
  display:grid;
  gap:12px;
  padding:18px;
}
.learner-certificate-card__top{
  display:flex;
  justify-content:flex-end;
}
.learner-certificate-card h3{
  margin:0;
  color:var(--learner-ink);
  font-size:19px;
  line-height:1.25;
}
.learner-certificate-card p{
  margin:0;
  color:var(--learner-muted);
}
.learner-meta-grid--certificate{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.learner-billing-summary,
.learner-support-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:24px;
  padding:22px;
  background:
    radial-gradient(circle at right 20%,rgba(29,111,184,.11),transparent 28%),
    #fff;
}
.learner-billing-summary>div:first-child,
.learner-support-card__copy{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  gap:14px;
}
.learner-billing-summary h2,
.learner-support-card h2{
  margin:0;
  color:var(--learner-ink);
  font-size:26px;
}
.learner-billing-summary p,
.learner-support-card p:not(.learner-eyebrow){
  margin:8px 0 0;
  color:var(--learner-muted);
}
.learner-billing-summary dl{
  display:grid;
  grid-template-columns:repeat(3,minmax(118px,1fr));
  gap:10px;
  margin:0;
}
.learner-billing-summary dl div{
  padding:12px;
  border:1px solid #e7eef5;
  border-radius:var(--learner-radius);
  background:#f8fbfd;
}
.learner-billing-summary dt{
  color:var(--learner-muted);
  font-size:12px;
  font-weight:750;
}
.learner-billing-summary dd{
  margin:6px 0 0;
  color:var(--learner-ink);
  font-size:24px;
  font-weight:760;
}
.learner-invoice-list{
  display:grid;
  gap:12px;
}
.learner-invoice-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:18px;
  padding:18px;
}
.learner-invoice-card__main{
  min-width:0;
  display:grid;
  gap:10px;
}
.learner-invoice-card__top{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:start;
  gap:12px;
}
.learner-invoice-card__meta-line{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}
.learner-invoice-card__number{
  color:var(--learner-muted);
  font-size:13px;
}
.learner-invoice-card h3{
  margin:2px 0 0;
  color:var(--learner-ink);
  font-size:18px;
  line-height:1.3;
}
.learner-invoice-card__courses{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.learner-invoice-card__courses span,
.learner-invoice-card__courses small{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  max-width:320px;
  padding:0 9px;
  border-radius:999px;
  background:#f1f6fa;
  color:var(--learner-muted);
  font-size:12px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.learner-details-list{
  max-width:720px;
  border:1px solid #e7eef5;
  border-radius:var(--learner-radius);
  background:#fbfdff;
}
.learner-details-list summary{
  padding:9px 11px;
  color:var(--learner-blue);
  font-size:13px;
  font-weight:700;
  cursor:pointer;
}
.learner-details-list ul{
  display:grid;
  gap:6px;
  margin:0;
  padding:0 12px 12px 28px;
  color:var(--learner-muted);
  font-size:13px;
}
.learner-invoice-card p{
  margin:0;
  color:var(--learner-muted);
  font-size:13px;
}
.learner-invoice-card__actions{
  display:grid;
  justify-items:end;
  align-content:start;
  gap:10px;
  min-width:178px;
}
.learner-invoice-card__actions strong{
  color:var(--learner-ink);
  font-size:18px;
  white-space:nowrap;
}
.learner-topic-card{
  display:grid;
  gap:12px;
  align-content:start;
  min-height:170px;
  padding:18px;
}
.learner-topic-card h3{
  margin:0;
  color:var(--learner-ink);
  font-size:19px;
}
.learner-topic-card p{
  margin:0;
  color:var(--learner-muted);
}
.learner-support-card__art{
  width:180px;
  color:var(--learner-blue);
  fill:none;
  stroke:currentColor;
  stroke-width:5;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.23;
}
.learner-empty-state{
  display:grid;
  justify-items:start;
  gap:10px;
  padding:18px;
  border:1px dashed #cbdce9;
  border-radius:var(--learner-radius);
  background:#f8fbfd;
}
.learner-empty-state strong{
  color:var(--learner-ink);
}
.learner-empty-state span{
  color:var(--learner-muted);
}

@media (max-width: 1180px){
  .portal-role-learner .portal-app-shell{
    grid-template-columns:252px minmax(0,1fr);
  }
  .learner-hero,
  .learner-dashboard__grid,
  .learner-page-header,
  .learner-billing-summary,
  .learner-support-card{
    grid-template-columns:1fr;
  }
  .learner-dashboard__side{
    grid-template-columns:1fr;
  }
  .learner-stat-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .learner-global-search{
    width:min(360px,32vw);
    min-width:220px;
  }
}
@media (max-width: 900px){
  .portal-role-learner .portal-app-shell{
    display:block;
    grid-template-columns:1fr;
  }
  .portal-role-learner .page-shell{
    width:min(100% - 32px,1280px);
  }
  .portal-role-learner .learner-global-search,
  .portal-role-learner .learner-profile-menu,
  .portal-role-learner .learner-topbar-profile{
    display:none;
  }
  .learner-card-grid--two,
  .learner-card-grid--certificates,
  .learner-card-grid--topics,
  .learner-dashboard__side,
  .learner-action-required__grid{
    grid-template-columns:1fr;
  }
  .learner-course-card,
  .learner-invoice-card{
    grid-template-columns:1fr;
  }
  .learner-course-card__actions,
  .learner-invoice-card__actions{
    align-items:flex-start;
    justify-items:start;
    min-width:0;
  }
  .learner-course-card--compact .learner-course-card__actions{
    grid-column:auto;
  }
  .learner-control-row,
  .learner-browser__toolbar,
  .learner-section-heading{
    align-items:stretch;
    flex-direction:column;
  }
  .learner-search-field,
  .learner-select-field,
  .learner-select-field select,
  .learner-filter-dropdown,
  .learner-filter-button{
    width:100%;
  }
  .learner-filter-menu{
    left:0;
    right:auto;
    min-width:100%;
  }
}
@media (max-width: 820px){
  .portal-role-learner .portal-sidebar{
    width:288px;
  }
  .portal-role-learner .portal-topbar__inner{
    gap:12px;
  }
  .learner-page-header,
  .learner-hero__copy,
  .learner-hero__next,
  .learner-billing-summary,
  .learner-support-card{
    padding:22px;
  }
  .learner-page-header h1,
  .learner-hero__copy h1{
    font-size:34px;
  }
  .learner-hero__art,
  .learner-support-card__art{
    display:none;
  }
  .learner-certificate-card{
    grid-template-columns:1fr;
  }
  .learner-certificate-card__preview{
    min-height:96px;
  }
}
@media (max-width: 560px){
  .portal-role-learner .page-shell{
    width:min(100% - 24px,1280px);
  }
  .learner-topbar-icon{
    width:38px;
    height:38px;
  }
  .learner-page-header__stats,
  .learner-stat-grid,
  .learner-meta-grid,
  .learner-meta-grid--certificate,
  .learner-billing-summary dl{
    grid-template-columns:1fr;
  }
  .learner-page-header h1,
  .learner-hero__copy h1{
    font-size:30px;
  }
  .learner-hero__copy>p{
    font-size:15px;
  }
  .learner-progress__header,
  .learner-pagination{
    align-items:flex-start;
    flex-direction:column;
  }
  .learner-invoice-card__top,
  .learner-update-list article{
    grid-template-columns:auto minmax(0,1fr);
  }
  .learner-invoice-card__top .learner-status{
    grid-column:2;
    justify-self:start;
  }
}

/* Learner visual polish pass: same IA, richer surfaces, fewer hard outlines. */
.portal-role-learner{
  --learner-ink:#102033;
  --learner-muted:#607187;
  --learner-subtle:#8492a5;
  --learner-bg:#f6f9fb;
  --learner-panel:#ffffff;
  --learner-soft:#edf7fb;
  --learner-line:#d8e6ef;
  --learner-blue:#176fb5;
  --learner-blue-dark:#0b3354;
  --learner-cyan:#0d9cbb;
  --learner-green:#228052;
  --learner-amber:#b76b10;
  --learner-purple:#6854b8;
  --learner-red:#b42318;
  --learner-warm:#fff8ed;
  --learner-shadow:0 18px 42px rgba(29,54,84,.10);
  --learner-shadow-soft:0 10px 28px rgba(29,54,84,.075);
  --learner-shadow-raised:0 24px 58px rgba(13,51,84,.16);
  background:#f6f9fb;
}
.portal-role-learner .portal-workspace{
  background:
    radial-gradient(circle at 88% 2%,rgba(13,156,187,.11),transparent 24rem),
    radial-gradient(circle at 12% 16%,rgba(255,184,77,.11),transparent 20rem),
    linear-gradient(180deg,#f1f8fb 0,#f8faf9 44%,#fbfaf6 100%);
}
.portal-role-learner .portal-topbar{
  border-bottom-color:transparent;
  box-shadow:0 8px 28px rgba(14,42,69,.07);
}
.portal-role-learner .portal-sidebar{
  box-shadow:12px 0 34px rgba(6,28,48,.18);
}
.portal-role-learner .main-shell{
  padding-top:32px;
}
.portal-role-learner .learner-page-header,
.portal-role-learner .learner-hero__copy,
.portal-role-learner .learner-hero__next,
.portal-role-learner .learner-billing-summary,
.portal-role-learner .learner-support-card,
.portal-role-learner .learner-panel,
.portal-role-learner .learner-page-header__stats article,
.portal-role-learner .learner-stat-grid article,
.portal-role-learner .learner-action-item,
.portal-role-learner .learner-topic-card,
.portal-role-learner .learner-course-card,
.portal-role-learner .learner-certificate-card,
.portal-role-learner .learner-invoice-card,
.portal-role-learner .learner-quick-card{
  border-color:transparent;
}
.learner-page-header,
.learner-billing-summary,
.learner-support-card{
  box-shadow:var(--learner-shadow-soft);
}
.learner-page-header{
  padding:34px;
  background:
    radial-gradient(circle at 88% 24%,rgba(13,156,187,.17),transparent 16rem),
    radial-gradient(circle at 7% 12%,rgba(255,184,77,.16),transparent 12rem),
    linear-gradient(135deg,#fff 0,#f4fbff 58%,#fff8ed 100%);
}
.learner-page-header__stats article,
.learner-stat-grid article,
.learner-action-item{
  background:rgba(255,255,255,.82);
  box-shadow:0 10px 26px rgba(29,54,84,.07);
}
.learner-page-header__stats article{
  backdrop-filter:blur(10px);
}
.learner-panel{
  padding:24px;
  border-radius:var(--learner-radius);
  background:rgba(255,255,255,.76);
  box-shadow:var(--learner-shadow-soft);
  backdrop-filter:blur(16px);
}
.learner-section-heading h2,
.learner-browser__toolbar h2{
  font-size:25px;
}
.learner-eyebrow{
  color:#0b68a8;
  letter-spacing:0;
}
.learner-hero{
  gap:22px;
}
.learner-hero__copy{
  position:relative;
  overflow:hidden;
  min-height:318px;
  padding:38px 390px 38px 38px;
  background:
    radial-gradient(circle at 78% 25%,rgba(125,211,252,.24),transparent 18rem),
    radial-gradient(circle at 92% 76%,rgba(255,184,77,.22),transparent 14rem),
    linear-gradient(135deg,#0b3354 0,#176fb5 58%,#0d9cbb 100%);
  border:0;
  outline:0;
  box-shadow:0 18px 38px -26px rgba(7,31,51,.42);
}
.learner-hero__copy h1{
  max-width:700px;
  font-size:48px;
}
.learner-hero__copy>p{
  max-width:620px;
  color:#e9f8ff;
}
.learner-hero__copy::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg,rgba(255,255,255,.13),transparent 42%),
    radial-gradient(circle at 20% 90%,rgba(134,239,172,.18),transparent 16rem);
  pointer-events:none;
}
.learner-hero__copy>*:not(.learner-hero__illustration){
  position:relative;
  z-index:2;
}
.learner-hero__illustration{
  position:absolute;
  right:24px;
  top:50%;
  bottom:auto;
  z-index:1;
  width:min(400px,38%);
  height:auto;
  transform:translateY(-50%);
  object-fit:contain;
  overflow:visible;
  pointer-events:none;
  user-select:none;
}
.learner-hero__illustration-panel{
  fill:url(#learnerHeroPanel);
  stroke:rgba(255,255,255,.58);
  stroke-width:2;
}
.learner-hero__illustration-card{
  fill:rgba(255,255,255,.9);
  stroke:rgba(255,255,255,.62);
  stroke-width:2;
}
.learner-hero__illustration-shadow{
  fill:none;
  stroke:rgba(7,31,51,.24);
  stroke-width:18;
  stroke-linecap:round;
}
.learner-hero__illustration-line,
.learner-hero__illustration-ribbon{
  fill:none;
  stroke:#276c9a;
  stroke-width:8;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.42;
}
.learner-hero__illustration-line--short{
  opacity:.28;
}
.learner-hero__illustration-line--card{
  stroke-width:7;
  opacity:.32;
}
.learner-hero__illustration-progress-bg{
  fill:none;
  stroke:rgba(23,111,181,.14);
  stroke-width:14;
}
.learner-hero__illustration-progress{
  fill:none;
  stroke:url(#learnerHeroAccent);
  stroke-width:14;
  stroke-linecap:round;
}
.learner-hero__illustration-check{
  fill:none;
  stroke:#0b3354;
  stroke-width:9;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-hero__illustration-seal{
  fill:#fff8ed;
  stroke:#f6c36f;
  stroke-width:7;
}
.learner-hero__illustration-dot{
  fill:#fff;
  opacity:.58;
}
.learner-hero__illustration-dot--one{fill:#86efac}
.learner-hero__illustration-dot--two{fill:#7dd3fc}
.learner-hero__illustration-dot--three{fill:#ffd58a}
.learner-hero__illustration-screen{
  fill:rgba(255,255,255,.92);
  stroke:rgba(255,255,255,.58);
  stroke-width:1.5;
}
.learner-hero__illustration-divider,
.learner-hero__illustration-text,
.learner-hero__illustration-card-line{
  fill:none;
  stroke:#7fb8d0;
  stroke-width:5;
  stroke-linecap:round;
  opacity:.62;
}
.learner-hero__illustration-text{
  stroke:#5d9fbe;
  stroke-width:6;
}
.learner-hero__illustration-text--short{
  opacity:.45;
}
.learner-hero__illustration-chip{
  fill:#d8eff8;
}
.learner-hero__illustration-window-dot{
  fill:#b6ddee;
}
.learner-hero__illustration-progress-card{
  fill:rgba(255,255,255,.94);
  stroke:rgba(255,255,255,.7);
  stroke-width:1.5;
}
.learner-hero__illustration-ring-bg{
  fill:none;
  stroke:#dcecf4;
  stroke-width:8;
}
.learner-hero__illustration-ring{
  fill:none;
  stroke:#8fe3c1;
  stroke-width:8;
  stroke-linecap:round;
}
.learner-hero__illustration-checkmark{
  fill:none;
  stroke:#0b3354;
  stroke-width:6;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-progress{
  max-width:610px;
  margin-top:26px;
  padding:18px;
  border-color:rgba(255,255,255,.18);
  background:rgba(255,255,255,.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 16px 34px rgba(7,31,51,.16);
  backdrop-filter:blur(10px);
}
.learner-progress__header strong{
  font-size:15px;
}
.learner-progress__track{
  height:14px;
  background:rgba(255,255,255,.24);
  box-shadow:inset 0 1px 3px rgba(7,31,51,.18);
}
.learner-progress__track span{
  position:relative;
  background:linear-gradient(90deg,#7dd3fc 0,#6ee7b7 58%,#f8d67a 100%);
  box-shadow:0 0 22px rgba(125,211,252,.55);
}
.learner-progress__track span::after{
  content:"";
  position:absolute;
  right:-5px;
  top:50%;
  width:22px;
  height:22px;
  border:3px solid rgba(255,255,255,.92);
  border-radius:999px;
  background:#6ee7b7;
  transform:translateY(-50%);
  box-shadow:0 6px 18px rgba(7,31,51,.22);
}
.learner-hero__actions{
  margin-top:22px;
}
.learner-hero__next{
  background:
    radial-gradient(circle at 82% 78%,rgba(23,111,181,.12),transparent 11rem),
    linear-gradient(180deg,#fff 0,#f8fcff 100%);
  box-shadow:var(--learner-shadow-soft);
}
.learner-hero__art{
  opacity:.13;
  stroke-width:4;
}
.learner-btn{
  box-shadow:none;
  transition:transform .16s ease,box-shadow .16s ease,background .16s ease,color .16s ease;
}
.learner-btn--primary{
  background:linear-gradient(135deg,#0b3354,#176fb5);
  box-shadow:0 12px 28px rgba(11,51,84,.18);
}
.learner-btn--primary:hover,
.learner-btn--primary:focus-visible{
  background:linear-gradient(135deg,#082942,#0f5f9d);
  box-shadow:0 15px 34px rgba(11,51,84,.22);
  transform:translateY(-1px);
}
.learner-btn--secondary{
  border-color:transparent;
  background:rgba(255,255,255,.88);
  color:#0b3354;
  box-shadow:0 7px 18px rgba(29,54,84,.08);
}
.learner-btn--secondary:hover,
.learner-btn--secondary:focus-visible{
  border-color:transparent;
  background:#fff;
  box-shadow:0 12px 28px rgba(29,54,84,.12);
  transform:translateY(-1px);
}
.learner-icon-badge{
  width:46px;
  height:46px;
  background:#eaf6fc;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.82);
}
.learner-icon-badge svg{
  width:22px;
  height:22px;
  stroke-width:1.9;
}
.learner-icon-badge--green,
.learner-icon-badge--certificate,
.learner-icon-badge--check{background:linear-gradient(135deg,#e9f9f0,#d8f2e4);color:#1f7a50}
.learner-icon-badge--amber,
.learner-icon-badge--billing,
.learner-icon-badge--receipt{background:linear-gradient(135deg,#fff7e7,#ffe8b6);color:#a86200}
.learner-icon-badge--purple,
.learner-icon-badge--help,
.learner-icon-badge--clock{background:linear-gradient(135deg,#f3efff,#e4ddff);color:#6750b7}
.learner-icon-badge--red,
.learner-icon-badge--alert{background:linear-gradient(135deg,#fff1ef,#ffd9d4);color:#b42318}
.learner-icon-badge--blue,
.learner-icon-badge--training,
.learner-icon-badge--online-course,
.learner-icon-badge--in-person-course,
.learner-icon-badge--asbestos,
.learner-icon-badge--safety,
.learner-icon-badge--equipment,
.learner-icon-badge--blueprint,
.learner-icon-badge--management,
.learner-icon-badge--whmis{background:linear-gradient(135deg,#edf8ff,#dcefff);color:#176fb5}
.learner-status{
  border-color:transparent;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.56);
}
.learner-action-required__grid,
.learner-stat-grid{
  gap:18px;
}
.learner-action-item{
  min-height:100px;
  padding:20px;
  background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(249,252,254,.8));
}
.learner-action-item strong{
  font-size:30px;
}
.learner-stat-grid article{
  position:relative;
  overflow:hidden;
  min-height:130px;
  padding:22px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.94),rgba(255,255,255,.74)),
    radial-gradient(circle at 100% 0,rgba(23,111,181,.12),transparent 9rem);
  box-shadow:0 14px 34px rgba(29,54,84,.08);
}
.learner-stat-grid article::after{
  content:"";
  position:absolute;
  inset:auto 22px 0 22px;
  height:4px;
  border-radius:999px 999px 0 0;
  background:linear-gradient(90deg,rgba(23,111,181,.85),rgba(13,156,187,.55),rgba(255,184,77,.72));
  opacity:.68;
}
.learner-stat-grid strong{
  margin-top:14px;
  font-size:36px;
}
.learner-course-card{
  position:relative;
  overflow:hidden;
  gap:18px;
  padding:22px;
  background:
    linear-gradient(135deg,rgba(255,255,255,.96),rgba(255,255,255,.82)),
    radial-gradient(circle at 0 0,rgba(23,111,181,.12),transparent 13rem);
  box-shadow:0 12px 30px rgba(29,54,84,.075);
  transition:transform .16s ease,box-shadow .16s ease;
}
.learner-course-card::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:5px;
  background:linear-gradient(180deg,#7dd3fc,#86efac);
  opacity:.9;
}
.learner-course-card--completed::before{background:linear-gradient(180deg,#86efac,#1f7a50)}
.learner-course-card--access-pending::before{background:linear-gradient(180deg,#c4b5fd,#6750b7)}
.learner-course-card--not-passed::before,
.learner-course-card--access-issue::before,
.learner-course-card--expired::before{background:linear-gradient(180deg,#fecaca,#b42318)}
.learner-course-card:hover{
  border-color:transparent;
  box-shadow:0 20px 46px rgba(29,54,84,.13);
  transform:translateY(-2px);
}
.learner-course-card__icon .learner-icon-badge{
  width:58px;
  height:58px;
}
.learner-course-card__icon .learner-icon-badge svg{
  width:27px;
  height:27px;
}
.learner-course-card__top p{
  color:#6d7d90;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
}
.learner-course-card h3{
  font-size:19px;
}
.learner-meta-grid{
  gap:10px;
}
.learner-meta-grid div{
  border-color:transparent;
  background:rgba(239,247,251,.86);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.78);
}
.learner-card-note{
  padding:12px 14px;
  border-radius:var(--learner-radius);
  background:rgba(255,248,237,.82);
}
.learner-static-action{
  border-color:transparent;
  background:#eef3f7;
}
.learner-certificate-card{
  position:relative;
  background:
    linear-gradient(135deg,#fff 0,#fbf7ed 100%);
  box-shadow:0 16px 38px rgba(79,58,24,.11);
  transition:transform .16s ease,box-shadow .16s ease;
}
.learner-certificate-card:hover{
  box-shadow:0 24px 52px rgba(79,58,24,.15);
  transform:translateY(-2px);
}
.learner-certificate-card__preview{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 32%,rgba(255,213,138,.58),transparent 4.8rem),
    linear-gradient(180deg,#fff8ed,#eef9f3);
}
.learner-certificate-card__preview::before{
  content:"";
  position:absolute;
  width:118px;
  height:118px;
  border:2px solid rgba(183,107,16,.18);
  border-radius:999px;
  background:radial-gradient(circle,rgba(255,255,255,.46),rgba(255,255,255,0) 68%);
}
.learner-certificate-card__preview>*{
  position:relative;
  z-index:1;
}
.learner-certificate-card__preview .learner-icon-badge{
  width:64px;
  height:64px;
  background:linear-gradient(135deg,#fff,#ffe8b6);
  color:#a86200;
  box-shadow:0 12px 28px rgba(183,107,16,.18);
}
.learner-certificate-card__preview .learner-icon-badge svg{
  width:30px;
  height:30px;
}
.learner-certificate-card__preview span{
  color:#8c5c13;
}
.learner-certificate-card__body{
  padding:22px;
}
.learner-certificate-card h3{
  font-size:21px;
}
.learner-invoice-card,
.learner-topic-card,
.learner-quick-card{
  background:rgba(255,255,255,.88);
  box-shadow:0 10px 26px rgba(29,54,84,.07);
}
.learner-invoice-card__courses span,
.learner-invoice-card__courses small{
  background:#edf7fb;
}
.learner-details-list,
.learner-billing-summary dl div{
  border-color:transparent;
  background:rgba(240,247,251,.86);
}
.learner-update-list article{
  padding:12px;
  border-bottom:0;
  border-radius:var(--learner-radius);
  background:rgba(244,249,252,.86);
}
.learner-quick-card:hover,
.learner-quick-card:focus-visible{
  border-color:transparent;
  box-shadow:0 16px 34px rgba(29,54,84,.12);
}
.learner-topic-card{
  min-height:184px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.94),rgba(255,255,255,.82)),
    radial-gradient(circle at 100% 0,rgba(13,156,187,.11),transparent 9rem);
}
.learner-support-card__art{
  opacity:.31;
  stroke-width:4;
}
.learner-empty-state{
  border-color:transparent;
  background:rgba(244,249,252,.86);
  box-shadow:inset 0 0 0 1px rgba(216,230,239,.55);
}
.portal-role-learner .portal-user-card{
  border-color:rgba(255,255,255,.24);
  background:rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.portal-role-learner .portal-user-card strong{
  color:#f8fbff;
}
.portal-role-learner .portal-user-card small{
  color:rgba(233,245,255,.76);
}
.portal-role-learner .portal-user-card__meta{
  color:rgba(233,245,255,.62);
}
.portal-role-learner .portal-sidebar__footer .nav-button{
  border-color:rgba(255,255,255,.16);
  background:rgba(255,255,255,.09);
  color:#f8fbff;
}
.portal-role-learner .portal-sidebar__footer .nav-button:hover,
.portal-role-learner .portal-sidebar__footer .nav-button:focus-visible{
  background:rgba(255,255,255,.14);
}

@media (max-width: 1280px){
  .learner-hero__copy{
    padding-right:310px;
  }
  .learner-hero__illustration{
    width:300px;
  }
}
@media (max-width: 1180px){
  .learner-hero__copy{
    min-height:0;
    padding-right:38px;
  }
  .learner-hero__illustration{
    right:26px;
    width:250px;
    opacity:.42;
  }
}
@media (max-width: 820px){
  .learner-hero__illustration{
    display:none;
  }
  .learner-hero__copy{
    padding:26px;
  }
  .learner-progress{
    padding:15px;
  }
  .learner-course-card__icon .learner-icon-badge{
    width:50px;
    height:50px;
  }
}
@media (max-width: 560px){
  .learner-panel{
    padding:18px;
  }
  .learner-page-header{
    padding:22px;
  }
  .learner-stat-grid article,
  .learner-action-item,
  .learner-course-card,
  .learner-certificate-card__body,
  .learner-invoice-card{
    padding:18px;
  }
}

/* Learner restraint cleanup: calmer, flatter, and more consistent. */
.portal-role-learner{
  --learner-ink:#142235;
  --learner-muted:#5f6f82;
  --learner-subtle:#7d8da0;
  --learner-bg:#f5f7fa;
  --learner-panel:#fff;
  --learner-soft:#f1f5f8;
  --learner-line:#dfe7ee;
  --learner-blue:#176fb5;
  --learner-blue-dark:#0b3354;
  --learner-cyan:#0d8fad;
  --learner-green:#1f7a50;
  --learner-amber:#a9630c;
  --learner-purple:#6252a4;
  --learner-red:#b42318;
  --learner-shadow:0 1px 2px rgba(15,23,42,.05);
  --learner-shadow-soft:0 6px 16px rgba(15,35,55,.07);
  --learner-shadow-raised:0 14px 32px rgba(7,31,51,.16);
  background:var(--learner-bg);
}
.portal-role-learner .portal-workspace{
  background:linear-gradient(180deg,#f4f8fb 0,#f7f9fb 100%);
}
.portal-role-learner .portal-sidebar{
  background:#092b49;
  box-shadow:6px 0 18px rgba(6,28,48,.14);
}
.portal-role-learner .portal-brand{
  min-height:64px;
  padding:6px 8px 14px;
}
.portal-role-learner .portal-brand__logo-wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  max-width:none;
  min-height:62px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  background:#fff;
  box-shadow:0 6px 16px rgba(2,16,28,.12);
}
.portal-role-learner .portal-brand__logo--light{display:none}
.portal-role-learner .portal-brand__logo--blue{
  display:block;
  width:100%;
  max-width:184px;
  height:auto;
}
.portal-role-learner .portal-nav-link{
  border-radius:10px;
}
.portal-role-learner .portal-nav-link.is-active{
  box-shadow:none;
}
.portal-role-learner .portal-nav-link.is-active::before{
  display:none;
}
.portal-role-learner .portal-nav-icon,
.portal-role-learner .portal-nav-icon svg,
.learner-topbar-icon svg,
.learner-btn svg,
.learner-icon-badge svg,
.learner-status svg,
.learner-search-field svg,
.learner-global-search svg,
.learner-quick-card__arrow{
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-learner .portal-user-card{
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  padding:12px;
  border-color:rgba(255,255,255,.18);
  border-radius:12px;
  background:rgba(255,255,255,.08);
  box-shadow:none;
}
.portal-role-learner .portal-user-card>span:last-child{
  min-width:0;
}
.portal-role-learner .portal-user-card strong{
  color:#fff;
  white-space:normal;
}
.portal-role-learner .portal-user-card small{
  color:rgba(233,245,255,.76);
  white-space:normal;
}
.portal-role-learner .portal-user-card__meta{
  color:rgba(233,245,255,.82);
}
.portal-role-learner .portal-sidebar__footer .nav-button{
  border-color:rgba(255,255,255,.14);
  border-radius:10px;
  background:rgba(255,255,255,.08);
  box-shadow:none;
}
.portal-role-learner .portal-topbar{
  border-bottom-color:#e1e8ef;
  background:rgba(255,255,255,.94);
  box-shadow:0 1px 2px rgba(15,23,42,.05);
}
.portal-role-learner .learner-topbar-profile{
  grid-template-columns:auto auto auto;
  gap:8px;
  width:auto;
  max-width:none;
  min-height:42px;
  padding:4px 10px 4px 4px;
  border-color:#dfe7ee;
  border-radius:12px;
  background:#fff;
  box-shadow:var(--learner-shadow);
}
.learner-topbar-profile strong{
  max-width:120px;
  color:var(--learner-ink);
  font-size:13px;
  line-height:1;
}
.learner-topbar-profile svg{
  width:16px;
  height:16px;
  fill:none;
  stroke:var(--learner-muted);
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-page-header{
  grid-template-columns:minmax(0,1fr) auto;
  gap:20px;
  padding:22px 0 8px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.learner-page-header h1{
  font-size:34px;
}
.learner-page-header p:not(.learner-eyebrow){
  max-width:680px;
}
.learner-page-header__stats{
  gap:8px;
}
.learner-page-header__stats article{
  min-width:112px;
  padding:12px 14px;
  border:0;
  border-radius:12px;
  background:#fff;
  box-shadow:var(--learner-shadow);
  backdrop-filter:none;
}
.learner-page-header__stats strong{
  font-size:22px;
}
.learner-panel,
.learner-billing-summary,
.learner-support-card,
.learner-course-card,
.learner-certificate-card,
.learner-invoice-card,
.learner-quick-card,
.learner-topic-card,
.learner-action-item,
.learner-stat-grid article{
  border:1px solid transparent;
  border-radius:14px;
  background:#fff;
  box-shadow:var(--learner-shadow);
  backdrop-filter:none;
}
.learner-panel{
  padding:22px;
}
.learner-section-heading h2,
.learner-browser__toolbar h2{
  font-size:23px;
}
.learner-eyebrow{
  color:#1b6fa9;
  font-size:11px;
  letter-spacing:0;
}
.learner-hero{
  gap:20px;
  align-items:start;
}
.learner-hero__copy{
  min-height:300px;
  padding:36px 380px 36px 36px;
  background:linear-gradient(135deg,#0b3354 0,#166dad 58%,#0d93ad 100%);
  box-shadow:0 18px 38px -26px rgba(7,31,51,.42);
}
.learner-hero__copy::before{
  display:none;
}
.learner-hero__copy h1{
  font-size:46px;
}
.learner-hero__illustration{
  right:28px;
  top:50%;
  bottom:auto;
  width:min(410px,40%);
  transform:translateY(-50%);
  object-fit:contain;
}
.learner-hero__illustration-panel,
.learner-hero__illustration-card{
  stroke:rgba(255,255,255,.52);
  stroke-width:1.5;
}
.learner-hero__illustration-shadow,
.learner-hero__illustration-dot,
.learner-hero__illustration-ribbon{
  display:none;
}
.learner-hero__illustration-line{
  stroke:#2d789e;
  stroke-width:6;
  opacity:.34;
}
.learner-hero__illustration-line--card{
  stroke-width:5;
}
.learner-hero__illustration-check{
  stroke:#0b3354;
  stroke-width:7;
}
.learner-hero__illustration-seal{
  fill:#f8fcff;
  stroke:#6fb7d2;
  stroke-width:5;
}
.learner-progress{
  max-width:520px;
  padding:14px;
  border-color:rgba(255,255,255,.22);
  background:rgba(255,255,255,.14);
  box-shadow:none;
  backdrop-filter:none;
}
.learner-progress__track{
  height:10px;
  background:rgba(255,255,255,.24);
  box-shadow:none;
}
.learner-progress__track span{
  background:#8fe3c1;
  box-shadow:none;
}
.learner-progress__track span::after{
  display:none;
}
.learner-hero__next{
  background:#fff;
  box-shadow:var(--learner-shadow);
  min-height:0;
}
.learner-btn{
  min-height:40px;
  border-radius:10px;
  box-shadow:none;
  transition:background .14s ease,border-color .14s ease,color .14s ease;
}
.learner-btn:hover,
.learner-btn:focus-visible{
  transform:none;
}
.learner-btn--primary,
.learner-btn--primary:hover,
.learner-btn--primary:focus-visible{
  background:#0b3354;
  box-shadow:none;
}
.learner-btn--secondary{
  border-color:#d9e4ec;
  background:#fff;
  box-shadow:none;
}
.learner-btn--secondary:hover,
.learner-btn--secondary:focus-visible{
  border-color:#b9cbd9;
  background:#f7fafc;
  box-shadow:none;
}
.learner-btn--tertiary{
  min-height:34px;
  padding:0 4px;
  border:0;
  background:transparent;
  color:var(--learner-blue);
}
.learner-btn--compact{
  min-height:36px;
  padding:0 12px;
  font-size:13px;
}
.learner-icon-badge{
  width:40px;
  height:40px;
  border-radius:10px;
  background:#eef4f8;
  box-shadow:none;
}
.learner-icon-badge svg{
  width:20px;
  height:20px;
}
.learner-icon-badge--green,
.learner-icon-badge--certificate,
.learner-icon-badge--check{background:#eaf7f0;color:var(--learner-green)}
.learner-icon-badge--amber,
.learner-icon-badge--billing,
.learner-icon-badge--receipt{background:#fff4df;color:var(--learner-amber)}
.learner-icon-badge--purple,
.learner-icon-badge--help,
.learner-icon-badge--clock{background:#f1edff;color:var(--learner-purple)}
.learner-icon-badge--red,
.learner-icon-badge--alert{background:#fff0ef;color:var(--learner-red)}
.learner-icon-badge--blue,
.learner-icon-badge--training,
.learner-icon-badge--online-course,
.learner-icon-badge--in-person-course,
.learner-icon-badge--asbestos,
.learner-icon-badge--safety,
.learner-icon-badge--equipment,
.learner-icon-badge--blueprint,
.learner-icon-badge--management,
.learner-icon-badge--whmis{background:#eaf4fb;color:var(--learner-blue)}
.learner-status{
  min-height:26px;
  border:0;
  box-shadow:none;
}
.learner-action-required__grid,
.learner-stat-grid{
  gap:14px;
}
.learner-action-item{
  min-height:86px;
  padding:16px;
}
.learner-action-item strong{
  font-size:26px;
}
.learner-stat-grid article{
  min-height:108px;
  padding:18px;
  overflow:hidden;
}
.learner-stat-grid article::after{
  display:none;
}
.learner-stat-grid strong{
  font-size:30px;
}
.learner-course-card{
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:14px;
  padding:18px;
  overflow:visible;
  background:#fff;
  transition:border-color .14s ease,box-shadow .14s ease;
}
.learner-course-card::before{
  display:none;
}
.learner-course-card:hover{
  border-color:#d8e5ee;
  box-shadow:var(--learner-shadow-soft);
  transform:none;
}
.learner-course-card__icon .learner-icon-badge{
  width:44px;
  height:44px;
}
.learner-course-card__icon .learner-icon-badge svg{
  width:21px;
  height:21px;
}
.learner-course-card__top{
  align-items:flex-start;
}
.learner-course-card__top p{
  color:var(--learner-subtle);
  font-size:11px;
  letter-spacing:.02em;
  text-transform:uppercase;
}
.learner-course-card h3{
  font-size:18px;
}
.learner-meta-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px 18px;
}
.learner-meta-grid div{
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.learner-meta-grid dt{
  color:var(--learner-subtle);
}
.learner-card-note{
  border-radius:8px;
  background:#fff8ed;
  width:fit-content;
  max-width:min(44rem,100%);
}
.portal-role-learner .main-shell--learner-dashboard{
  width:min(1680px,calc(100% - 48px));
  margin-left:auto;
  margin-right:auto;
}
.portal-role-company .main-shell--company-dashboard{
  width:min(1680px,calc(100% - 48px));
  margin-left:auto;
  margin-right:auto;
}
.learner-dashboard{
  gap:20px;
}
.learner-dashboard__grid{
  grid-template-columns:minmax(0,1fr) minmax(320px,360px);
  gap:16px;
  align-items:start;
}
.learner-dashboard .learner-hero{
  grid-template-columns:1fr;
  gap:0;
}
.learner-dashboard__main{
  display:grid;
  gap:18px;
  min-width:0;
}
.learner-dashboard__side{
  align-content:start;
  gap:14px;
}
.learner-dashboard__side .learner-panel{
  gap:12px;
}
.learner-dashboard__side .learner-section-heading h2{
  font-size:20px;
}
.learner-dashboard__side .learner-hero__next{
  min-height:0;
  padding:20px;
}
.learner-dashboard__side .learner-action-required--rail{
  gap:10px;
}
.learner-dashboard__side .learner-action-required--rail .learner-action-required__grid{
  grid-template-columns:1fr;
  gap:10px;
}
.learner-dashboard__side .learner-action-required--rail .learner-action-item{
  grid-template-columns:40px minmax(0,1fr);
  min-height:70px;
  padding:12px 14px;
}
.learner-dashboard__side .learner-action-required--rail .learner-action-item>span:not(.learner-icon-badge){
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:baseline;
  gap:2px 8px;
}
.learner-dashboard__side .learner-action-required--rail .learner-action-item strong{
  font-size:20px;
}
.learner-dashboard__side .learner-action-required--rail .learner-action-item small{
  margin-top:0;
}
.learner-dashboard__side .learner-action-required--rail .learner-action-item em{
  grid-column:1 / -1;
  margin-top:2px;
}
.learner-dashboard__side .learner-action-required--rail .learner-action-item .learner-icon-badge{
  border-radius:12px;
}
.learner-dashboard__side .learner-action-required--rail .learner-action-item .learner-icon-badge--icon-lock svg,
.learner-dashboard__side .learner-action-required--rail .learner-action-item .learner-icon-badge--icon-calendar-alert svg{
  width:22px;
  height:22px;
  stroke-width:2;
}
.learner-dashboard .learner-stat-grid--compact{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
  padding-top:4px;
  border-top:1px solid #e4ebf1;
}
.learner-dashboard .learner-stat-grid--compact article{
  min-height:0;
  padding:10px 0 0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.learner-dashboard .learner-stat-grid--compact strong{
  margin-top:6px;
  font-size:22px;
}
.learner-dashboard .learner-stat-grid--compact small{
  margin-top:4px;
  font-size:12px;
}
.portal-role-learner .learner-dashboard .learner-stat-grid--compact,
.portal-role-company .learner-dashboard .learner-stat-grid--compact,
.portal-role-instructor .learner-dashboard .learner-stat-grid--compact{
  gap:12px;
  padding-top:0;
  border-top:0;
}
.portal-role-learner .learner-dashboard .learner-stat-grid--compact article,
.portal-role-company .learner-dashboard .learner-stat-grid--compact article,
.portal-role-instructor .learner-dashboard .learner-stat-grid--compact article{
  display:grid;
  align-content:start;
  min-height:92px;
  padding:14px 16px;
  border:1px solid #dfe8f0;
  border-radius:12px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.045);
}
.portal-role-learner .learner-dashboard .learner-stat-grid--compact article:hover,
.portal-role-company .learner-dashboard .learner-stat-grid--compact article:hover,
.portal-role-instructor .learner-dashboard .learner-stat-grid--compact article:hover{
  border-color:#d1deea;
  box-shadow:0 5px 16px rgba(15,35,55,.055);
}
.portal-role-learner .learner-dashboard .learner-stat-grid--compact span,
.portal-role-company .learner-dashboard .learner-stat-grid--compact span,
.portal-role-instructor .learner-dashboard .learner-stat-grid--compact span{
  margin-top:7px;
  color:#6b7d90;
  font-size:11px;
  line-height:1.2;
}
.portal-role-learner .learner-dashboard .learner-stat-grid--compact strong,
.portal-role-company .learner-dashboard .learner-stat-grid--compact strong,
.portal-role-instructor .learner-dashboard .learner-stat-grid--compact strong{
  order:-1;
  margin-top:0;
  color:#102034;
  font-size:24px;
  line-height:1;
}
.portal-role-learner .learner-dashboard .learner-stat-grid--compact small,
.portal-role-company .learner-dashboard .learner-stat-grid--compact small,
.portal-role-instructor .learner-dashboard .learner-stat-grid--compact small{
  margin-top:6px;
  color:#5f6f82;
  font-size:12px;
  line-height:1.3;
}
.learner-dashboard .learner-quick-access-panel{
  gap:14px;
}
.learner-dashboard__main .learner-quick-access-panel .learner-quick-grid{
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.learner-dashboard__main .learner-quick-card{
  min-height:70px;
  padding:12px;
  border-color:#edf2f7;
  background:#f8fafc;
  box-shadow:none;
}
.learner-dashboard__main .learner-quick-card .learner-icon-badge{
  width:36px;
  height:36px;
}
.learner-dashboard__side .learner-quick-access-panel .learner-quick-grid{
  grid-template-columns:1fr;
  gap:8px;
}
.learner-dashboard__side .learner-quick-card{
  min-height:58px;
  padding:10px 12px;
  border-color:#edf2f7;
  background:#f8fafc;
  box-shadow:none;
}
.learner-dashboard__side .learner-quick-card .learner-icon-badge{
  width:34px;
  height:34px;
}
.learner-static-action{
  border:0;
  background:#f1f5f8;
}
.learner-certificate-card{
  grid-template-columns:118px minmax(0,1fr);
  min-height:220px;
  overflow:hidden;
  background:#fff;
  transition:border-color .14s ease,box-shadow .14s ease;
}
.learner-certificate-card:hover{
  border-color:#d8e5ee;
  box-shadow:var(--learner-shadow-soft);
  transform:none;
}
.learner-certificate-card__preview{
  gap:10px;
  padding:18px 14px;
  background:#f7fafc;
}
.learner-certificate-card__preview::before{
  display:none;
}
.learner-certificate-card__preview>span:not(.learner-status){
  color:#607187;
  font-size:11px;
  letter-spacing:.02em;
}
.learner-certificate-card__document{
  display:block;
  width:62px;
  height:78px;
  overflow:visible;
}
.learner-certificate-card__document .certificate-sheet{
  fill:#fff;
  stroke:#b7c7d4;
  stroke-width:1.7;
}
.learner-certificate-card__document .certificate-fold{
  fill:none;
  stroke:#b7c7d4;
  stroke-width:1.7;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-certificate-card__document .certificate-line{
  fill:none;
  stroke:#a8bdca;
  stroke-width:2;
  stroke-linecap:round;
}
.learner-certificate-card__document .certificate-seal{
  fill:#fff7e7;
  stroke:#c8953a;
  stroke-width:2;
}
.learner-certificate-card__document .certificate-check{
  fill:none;
  stroke:#1f7a50;
  stroke-width:2.2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-certificate-card__document .certificate-ribbon{
  fill:#fff4df;
  stroke:#c8953a;
  stroke-width:1.6;
  stroke-linejoin:round;
}
.learner-certificate-card__body{
  align-content:start;
  gap:10px;
  padding:20px;
}
.learner-certificate-card__top{
  justify-content:flex-start;
}
.learner-certificate-card h3{
  font-size:20px;
}
.learner-certificate-facts{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px 22px;
  margin:2px 0 4px;
}
.learner-certificate-facts div{
  min-width:0;
}
.learner-certificate-facts dt{
  color:var(--learner-subtle);
  font-size:11px;
  font-weight:750;
  text-transform:uppercase;
}
.learner-certificate-facts dd{
  margin:3px 0 0;
  color:var(--learner-ink);
  font-size:14px;
}
.learner-certificate-facts .is-expiring dd{
  color:var(--learner-amber);
  font-weight:760;
}
.learner-certificate-card .learner-btn{
  justify-self:start;
  width:auto;
}
.learner-billing-summary{
  grid-template-columns:minmax(0,1fr) minmax(360px,.65fr);
  padding:22px;
  background:#fff;
}
.learner-billing-summary dl{
  grid-template-columns:1.1fr 1fr .8fr;
}
.learner-billing-summary dl div{
  padding:0 0 0 16px;
  border:0;
  border-left:1px solid #e4ebf1;
  border-radius:0;
  background:transparent;
}
.learner-billing-summary dl div:first-child dd{
  color:var(--learner-green);
}
.learner-billing-summary dd{
  white-space:nowrap;
}
.learner-invoice-card{
  grid-template-columns:minmax(0,1fr) auto;
  padding:16px;
  background:#fff;
}
.learner-invoice-card__courses span,
.learner-invoice-card__courses small{
  background:#f1f5f8;
}
.learner-invoice-card__actions{
  min-width:172px;
}
.learner-details-list{
  border-color:#e4ebf1;
  background:#fff;
}
.learner-update-list article{
  border-radius:12px;
  background:#f7fafc;
}
.learner-update-list article:last-child{
  padding-bottom:12px;
}
.learner-quick-card,
.learner-topic-card{
  background:#fff;
}
.learner-quick-card:hover,
.learner-quick-card:focus-visible{
  border-color:#d8e5ee;
  box-shadow:var(--learner-shadow-soft);
}
.learner-topic-card{
  min-height:150px;
  padding:16px;
}
.learner-topic-card h3{
  font-size:18px;
}
.learner-support-card{
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
  padding:22px;
  background:#fff;
}
.learner-support-card__copy{
  align-items:start;
}
.learner-support-list{
  display:grid;
  gap:6px;
  margin:12px 0 0;
  padding-left:18px;
  color:var(--learner-muted);
  font-size:14px;
}
.learner-support-list li::marker{
  color:var(--learner-blue);
}
.learner-support-card__art{
  display:none;
}
.learner-empty-state{
  border-color:#cbd8e3;
  background:#fff;
  box-shadow:none;
}

@media (max-width: 1280px){
  .learner-hero__copy{
    padding-right:310px;
  }
  .learner-hero__illustration{
    width:280px;
  }
}
@media (max-width: 1180px){
  .learner-page-header,
  .learner-billing-summary,
  .learner-support-card{
    grid-template-columns:1fr;
  }
  .learner-hero__copy{
    padding-right:32px;
  }
  .learner-hero__illustration{
    opacity:.28;
  }
}
@media (max-width: 900px){
  .learner-page-header__stats,
  .learner-billing-summary dl{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .learner-course-card{
    grid-template-columns:auto minmax(0,1fr);
  }
  .learner-course-card__actions{
    grid-column:2;
    align-items:flex-start;
    min-width:0;
  }
  .learner-certificate-card{
    grid-template-columns:1fr;
  }
  .learner-certificate-card__preview{
    min-height:112px;
  }
}
@media (max-width: 820px){
  .learner-hero__illustration{
    display:none;
  }
  .learner-hero__copy{
    padding:26px;
  }
}
@media (max-width: 560px){
  .learner-page-header{
    padding-top:10px;
  }
  .learner-page-header__stats,
  .learner-meta-grid,
  .learner-certificate-facts,
  .learner-billing-summary dl{
    grid-template-columns:1fr;
  }
  .learner-billing-summary dl div{
    padding:10px 0 0;
    border-left:0;
    border-top:1px solid #e4ebf1;
  }
  .learner-course-card,
  .learner-course-card--compact{
    grid-template-columns:1fr;
  }
  .learner-course-card__icon{
    margin-bottom:2px;
  }
  .learner-course-card__top{
    align-items:flex-start;
    flex-direction:column;
  }
  .learner-course-card__actions,
  .learner-course-card--compact .learner-course-card__actions{
    grid-column:auto;
    align-items:flex-start;
    min-width:0;
  }
  .learner-support-card .learner-btn{
    width:100%;
  }
}

/* Learner QA refinement: final restraint and density pass. */
.portal-role-learner .portal-brand{
  min-height:auto;
  padding:4px 12px 12px;
  background:transparent;
  backdrop-filter:none;
}
.portal-role-learner .portal-brand__logo-wrap{
  justify-content:flex-start;
  width:auto;
  max-width:160px;
  min-height:46px;
  margin:0;
  padding:7px 7px;
  border-color:rgba(255,255,255,.22);
  border-radius:10px;
  background:rgba(255,255,255,.96);
  box-shadow:none;
}
.portal-role-learner .portal-brand__logo--blue{
  max-width:144px;
}
.portal-role-learner .portal-brand__logo-wrap{
  display:block;
  width:auto;
  max-width:178px;
  min-height:0;
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  line-height:0;
}
.portal-role-learner .portal-brand__logo--light{
  display:block;
  width:100%;
  max-width:178px;
  height:auto;
}
.portal-role-learner .portal-brand__logo--blue{
  display:none;
}
.portal-role-learner .portal-nav-link.is-active{
  display:flex;
  align-items:center;
  gap:10px;
}
.portal-role-learner .portal-nav-link.is-active .portal-nav-icon{
  display:inline-flex;
  visibility:visible;
  opacity:1;
  color:#0b5c8d;
  background:#eaf4fb;
}
.portal-role-learner .portal-nav-link.is-active .portal-nav-icon svg{
  display:block;
  stroke:currentColor;
}
.portal-role-learner .portal-sidebar__footer{
  gap:8px;
  padding-top:14px;
}
.portal-role-learner .portal-user-card{
  padding:11px;
}
.portal-role-learner .portal-user-card strong,
.portal-role-learner .portal-user-card small,
.portal-role-learner .portal-user-card__meta{
  overflow:visible;
  text-overflow:clip;
}
.portal-role-learner .portal-user-card small.portal-user-card__meta{
  display:block;
  white-space:nowrap;
  font-size:11.5px;
}
.portal-role-learner .portal-sidebar__footer .nav-button{
  min-height:34px;
  border-color:transparent;
  background:transparent;
  color:rgba(233,245,255,.74);
  font-weight:650;
}
.portal-role-learner .portal-sidebar__footer .nav-button:hover,
.portal-role-learner .portal-sidebar__footer .nav-button:focus-visible{
  background:rgba(255,255,255,.08);
  color:#fff;
}
.portal-role-learner .learner-topbar-profile{
  grid-template-columns:auto auto;
  min-height:40px;
  padding:4px 10px 4px 4px;
}
.portal-role-learner .learner-topbar-profile .portal-avatar{
  background:#0b3354;
  color:#fff;
  box-shadow:0 0 0 2px #e8f1f8;
}
.learner-topbar-profile strong{
  max-width:150px;
}
.learner-eyebrow,
.learner-page-header__stats span,
.learner-stat-grid span,
.learner-course-card__top p,
.learner-meta-grid dt,
.learner-certificate-facts dt{
  text-transform:none;
}
.learner-page-header__stats span,
.learner-stat-grid span{
  font-size:13px;
  letter-spacing:0;
}
.learner-hero__copy h1{
  white-space:nowrap;
}
.learner-hero__next{
  gap:16px;
  align-content:start;
}
.learner-hero__next .learner-btn{
  justify-self:start;
}
.learner-action-item{
  color:inherit;
  text-decoration:none;
}
.learner-action-item[href]{
  cursor:pointer;
}
.learner-action-item[href]:hover,
.learner-action-item[href]:focus-visible{
  border-color:#cbdbe7;
  box-shadow:var(--learner-shadow-soft);
  outline:0;
}
.learner-action-item em{
  display:inline-flex;
  margin-top:6px;
  color:var(--learner-blue);
  font-size:13px;
  font-style:normal;
  font-weight:750;
}
.learner-text-link{
  display:inline-flex;
  align-items:center;
  min-height:34px;
}
.learner-search-field input,
.learner-global-search input{
  min-height:34px;
}
.learner-pagination button{
  min-width:36px;
  cursor:pointer;
}
.learner-pagination button:disabled,
.learner-pagination button.is-active{
  cursor:default;
}
.learner-action-required__empty{
  margin:0;
  padding:14px 0 0;
  color:var(--learner-muted);
  font-size:14px;
}
.learner-training .learner-browser{
  max-width:none;
  width:100%;
}
.learner-card-grid--list{
  gap:8px;
}
.learner-course-card{
  grid-template-columns:44px minmax(0,1fr) max-content;
  align-items:start;
  padding:12px 14px;
}
.learner-course-card__top{
  justify-content:flex-start;
  align-items:flex-start;
  gap:10px;
}
.learner-card-grid--list .learner-course-card__top{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:5px;
}
.learner-course-card__top>div{
  min-width:0;
}
.learner-course-card__top .learner-status{
  margin-top:1px;
}
.learner-card-grid--list .learner-course-card__top .learner-status{
  justify-self:start;
  margin-top:0;
}
.learner-course-card__message{
  margin:5px 0 0;
  color:var(--learner-muted);
  font-size:14px;
}
.learner-course-card__actions{
  min-width:112px;
}
.learner-course-card--compact .learner-course-card__top{
  display:block;
}
.learner-course-card--compact .learner-course-card__top .learner-status{
  margin-top:7px;
}
.learner-course-card--compact h3{
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  overflow:hidden;
  font-size:15px;
  line-height:1.28;
}
.learner-dashboard .learner-panel--main .learner-card-grid--two{
  gap:12px;
}
.learner-dashboard .learner-panel--main .learner-course-card--compact{
  gap:12px;
  padding:12px;
}
.learner-dashboard .learner-panel--main .learner-course-card--compact .learner-course-card__top .learner-status{
  margin-top:5px;
}
.learner-dashboard .learner-panel--main .learner-course-card__message{
  margin-top:4px;
}
.learner-dashboard .learner-panel--main .learner-course-card__actions{
  gap:6px;
}
.learner-card-grid--list .learner-course-card__actions .learner-btn--primary{
  background:#123f61;
}
.learner-card-grid--list .learner-course-card__actions .learner-btn{
  min-height:38px;
  padding:0 13px;
}
.learner-meta-grid{
  display:flex;
  flex-wrap:wrap;
  gap:6px 16px;
  margin-top:6px;
}
.learner-meta-grid div{
  min-width:auto;
}
.learner-meta-grid dt,
.learner-certificate-facts dt{
  font-size:12px;
  font-weight:650;
}
.learner-meta-grid dd{
  margin-top:1px;
}
.learner-certificate-section[data-certificate-section="expiring"] .learner-card-grid--certificates{
  grid-template-columns:1fr;
}
.learner-certificate-section[data-certificate-section="expiring"] .learner-certificate-card{
  min-height:0;
}
.learner-certificate-card{
  grid-template-columns:72px minmax(0,1fr);
  align-items:start;
  min-height:0;
}
.learner-certificate-card__preview{
  align-self:start;
  min-height:0;
  margin:14px 0 0 14px;
  padding:10px 8px;
  border-radius:10px;
  text-transform:none;
}
.learner-certificate-card__preview span{
  font-size:9px;
  letter-spacing:0;
  white-space:nowrap;
}
.learner-certificate-card__document{
  width:48px;
  height:60px;
}
.learner-certificate-card__heading{
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
  gap:10px;
}
.learner-certificate-card__heading>div{
  min-width:0;
  flex:0 1 auto;
}
.learner-certificate-card__heading p{
  margin:5px 0 0;
  color:var(--learner-muted);
  font-size:14px;
}
.learner-certificate-card__expiry{
  display:flex;
  align-items:baseline;
  flex-wrap:wrap;
  gap:8px;
  margin:8px 0 0;
  color:var(--learner-muted);
  font-size:15px;
}
.learner-certificate-card__expiry span{
  font-weight:650;
}
.learner-certificate-card__expiry strong{
  color:var(--learner-ink);
  font-size:18px;
}
.learner-certificate-card__expiry.is-expiring strong{
  color:var(--learner-amber);
  font-size:20px;
}
.learner-certificate-facts{
  display:grid;
  grid-template-columns:repeat(3,max-content);
  justify-content:start;
  gap:10px 22px;
  margin:10px 0 0;
}
.learner-certificate-facts div{
  display:grid;
  gap:3px;
  min-width:0;
}
.learner-certificate-facts dt{
  color:var(--learner-subtle);
  font-size:11px;
  line-height:1.2;
}
.learner-certificate-facts dd{
  margin:0;
  min-width:0;
  color:var(--learner-ink);
  font-size:13px;
  line-height:1.25;
  white-space:nowrap;
}
.learner-invoice-card{
  gap:18px;
  padding:14px 16px;
}
.learner-invoice-card__top{
  gap:10px;
}
.learner-invoice-card__meta-line .learner-status{
  min-height:22px;
  padding:0 8px;
  font-size:12px;
}
.learner-invoice-card__meta-line .learner-status svg{
  width:13px;
  height:13px;
}
.learner-invoice-card__courses span,
.learner-invoice-card__courses small{
  white-space:normal;
  overflow-wrap:anywhere;
}
.learner-invoice-card__actions{
  min-width:160px;
}
.learner-details-list{
  display:inline-block;
  width:auto;
  margin-top:10px;
  padding:0;
  border:0;
  background:transparent;
}
.learner-details-list summary{
  padding:0;
  color:var(--learner-blue);
  font-weight:750;
}
.learner-details-list[open]{
  display:block;
  width:min(100%,680px);
  padding:10px 12px;
  border:1px solid #dfe8f0;
  border-radius:10px;
  background:#f7fafc;
}
.learner-details-list[open] summary{
  margin-bottom:8px;
}
.learner-help .learner-card-grid--topics{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.learner-topic-card{
  display:grid;
  align-content:start;
  gap:10px;
  min-height:0;
  padding:15px;
  color:inherit;
  text-decoration:none;
  transition:border-color .16s ease, background .16s ease, transform .16s ease, box-shadow .16s ease;
}
.learner-topic-card:hover{
  border-color:#c8d9e8;
  background:#fbfdff;
  box-shadow:0 8px 18px rgba(15,23,42,.04);
  transform:translateY(-1px);
}
.learner-topic-card:focus-visible{
  outline:3px solid rgba(0,94,184,.2);
  outline-offset:3px;
}
.learner-topic-card h3{
  margin:3px 0 0;
}
.learner-topic-card p{
  margin:0;
  font-size:14px;
}
.learner-help-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(260px,320px);
  gap:18px;
  align-items:start;
}
.learner-help-layout__main{
  display:grid;
  gap:18px;
  min-width:0;
}
.learner-help-layout__side{
  display:grid;
  gap:18px;
  position:sticky;
  top:98px;
  min-width:0;
}
.learner-help-section{
  scroll-margin-top:96px;
}
.learner-help-section__header{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:start;
  gap:14px;
  margin-bottom:16px;
}
.learner-help-section__header h2,
.learner-help-tips h2{
  margin:0;
  color:var(--learner-ink);
  font-size:24px;
  line-height:1.2;
}
.learner-help-section__header p:not(.learner-eyebrow){
  margin:5px 0 0;
  color:var(--learner-muted);
  font-size:14px;
  line-height:1.55;
}
.learner-faq-list{
  display:grid;
  gap:10px;
}
.learner-faq-item{
  border:1px solid #e5edf4;
  border-radius:14px;
  background:#fff;
  overflow:hidden;
  transition:border-color .16s ease, background .16s ease, box-shadow .16s ease;
}
.learner-faq-item:hover{
  border-color:#d5e3ee;
  background:#fbfdff;
}
.learner-faq-item[open]{
  border-color:#d6e5f1;
  box-shadow:0 8px 18px rgba(15,23,42,.035);
}
.learner-faq-item summary{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:14px;
  min-height:54px;
  padding:15px 16px;
  color:var(--learner-ink);
  cursor:pointer;
  list-style:none;
}
.learner-faq-item summary::-webkit-details-marker{
  display:none;
}
.learner-faq-item summary span{
  min-width:0;
  font-size:15px;
  font-weight:750;
  line-height:1.35;
}
.learner-faq-item summary svg{
  width:18px;
  height:18px;
  color:#5f7590;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  transition:transform .16s ease;
}
.learner-faq-item[open] summary svg{
  transform:rotate(180deg);
}
.learner-faq-item summary:focus-visible{
  outline:3px solid rgba(0,94,184,.2);
  outline-offset:-3px;
}
.learner-faq-item p{
  margin:0;
  padding:0 16px 16px;
  color:#4f6075;
  font-size:14px;
  line-height:1.62;
}
.learner-help-tips{
  gap:12px;
}
.learner-help-tips ul{
  display:grid;
  gap:9px;
  margin:2px 0 0;
  padding-left:18px;
  color:#4f6075;
  font-size:14px;
  line-height:1.5;
}
.learner-help-link-list{
  display:grid;
  gap:8px;
}
.learner-help-link-list a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:42px;
  padding:10px 12px;
  border:1px solid #e3ebf3;
  border-radius:12px;
  background:#f8fbfd;
  color:var(--learner-blue);
  font-size:14px;
  font-weight:750;
  text-decoration:none;
}
.learner-help-link-list a::after{
  content:'>';
  color:#7a8fa7;
  font-size:16px;
  line-height:1;
}
.learner-help-link-list a:hover{
  border-color:#cdddea;
  background:#fff;
}
.learner-support-card .learner-btn{
  align-self:start;
}
@media (min-width: 901px){
  .portal-role-learner .portal-sidebar{
    position:fixed;
    inset:0 auto 0 0;
    width:268px;
    height:100vh;
    height:100dvh;
    overflow-y:auto;
    overscroll-behavior:contain;
  }
  .portal-role-learner .portal-workspace{
    grid-column:2;
  }
}
@media (min-width: 901px) and (max-width: 1180px){
  .portal-role-learner .portal-sidebar{
    width:252px;
  }
}
.learner-profile-menu__panel a,
.learner-profile-menu__panel button{
  gap:10px;
  justify-content:flex-start;
}
.learner-profile-menu__panel a svg{
  flex:0 0 17px;
  width:17px;
  height:17px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.learner-profile-menu__panel a span{
  min-width:0;
  color:inherit;
  font-size:13px;
  font-weight:650;
  text-transform:none;
}
.learner-account-layout{
  display:grid;
  grid-template-columns:minmax(260px,.38fr) minmax(0,1fr);
  gap:18px;
  align-items:start;
}
.learner-account-summary-card,
.learner-account-detail-card,
.learner-account-setting-card{
  align-content:start;
}
.learner-account-summary-card{
  gap:16px;
}
.learner-account-summary-card__identity{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  gap:12px;
}
.learner-account-summary-card__identity .portal-avatar{
  width:50px;
  height:50px;
  border-radius:16px;
  background:#e8f4fc;
  color:var(--learner-blue-dark);
}
.learner-account-summary-card h2,
.learner-account-setting-card h2,
.learner-account-support-card h2{
  margin:0;
  color:var(--learner-ink);
  font-size:22px;
  line-height:1.2;
}
.learner-account-summary-card p:not(.learner-eyebrow),
.learner-account-setting-card p:not(.learner-eyebrow),
.learner-account-support-card p:not(.learner-eyebrow){
  margin:6px 0 0;
  color:var(--learner-muted);
}
.learner-account-note{
  padding-top:2px;
  font-size:14px;
}
.learner-account-list{
  display:grid;
  margin:0;
}
.learner-account-list div{
  display:grid;
  grid-template-columns:minmax(120px,.34fr) minmax(0,1fr);
  gap:14px;
  padding:12px 0;
  border-top:1px solid #e6edf3;
}
.learner-account-list div:first-child{
  border-top:0;
  padding-top:0;
}
.learner-account-list div:last-child{
  padding-bottom:0;
}
.learner-account-list dt{
  color:var(--learner-muted);
  font-size:13px;
  font-weight:700;
}
.learner-account-list dd{
  margin:0;
  min-width:0;
  color:var(--learner-ink);
  font-size:14px;
  font-weight:700;
  overflow-wrap:anywhere;
}
.learner-account-stat-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.learner-account-stat-grid article{
  display:grid;
  gap:5px;
  min-height:86px;
  padding:14px;
  border-radius:12px;
  background:#f7fafc;
}
.learner-account-stat-grid span{
  color:var(--learner-muted);
  font-size:13px;
  font-weight:700;
}
.learner-account-stat-grid strong{
  color:var(--learner-ink);
  font-size:20px;
  line-height:1.2;
}
.learner-account-support-card{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
}
.learner-account-support-card>div{
  min-width:0;
}
.learner-account-settings-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.learner-account-setting-card{
  gap:14px;
}
.learner-account-setting-card__header{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  gap:12px;
}
.learner-account-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:2px;
}
.learner-account-actions .learner-btn{
  width:auto;
}

@media (max-width: 1180px){
  .portal-role-learner .main-shell--learner-dashboard,
  .portal-role-company .main-shell--company-dashboard{
    width:min(100% - 40px,1280px);
    margin-left:auto;
    margin-right:auto;
  }
  .learner-dashboard .learner-hero,
  .learner-dashboard__grid{
    grid-template-columns:1fr;
  }
  .learner-dashboard__side{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .learner-dashboard .learner-stat-grid--compact{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .learner-help .learner-card-grid--topics{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .learner-help-layout{
    grid-template-columns:1fr;
  }
  .learner-help-layout__side{
    position:static;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (min-width: 901px) and (max-width: 1500px){
  .learner-hero__copy{
    padding-right:330px;
  }
  .learner-hero__copy h1{
    font-size:40px;
  }
  .learner-hero__illustration{
    right:22px;
    width:min(320px,40%);
  }
}
@media (max-width: 900px){
  .portal-role-learner .main-shell--learner-dashboard{
    width:min(100% - 32px,1280px);
  }
  .learner-hero__illustration{
    display:none;
  }
  .portal-role-learner .portal-sidebar{
    position:fixed;
    inset:0 auto 0 0;
    z-index:40;
    width:288px;
    height:100vh;
    height:100dvh;
    min-height:100vh;
    min-height:100dvh;
    border-right:0;
    border-bottom:0;
    overflow-y:auto;
    transform:translateX(-100%);
    transition:transform .18s ease;
    box-shadow:none;
  }
  .portal-role-learner .portal-app-shell.is-nav-open .portal-sidebar{
    transform:translateX(0);
  }
  .portal-role-learner .portal-app-shell.is-nav-open .portal-mobile-overlay{
    display:block;
  }
  .portal-role-learner .portal-mobile-overlay{
    position:fixed;
    inset:0;
    z-index:30;
    border:0;
    padding:0;
    background:rgba(15,23,42,.42);
  }
  .portal-role-learner .portal-menu-button{
    display:inline-flex;
  }
  .portal-role-learner .portal-workspace{
    grid-column:auto;
  }
  .learner-dashboard__side{
    grid-template-columns:1fr;
  }
  .learner-course-card{
    grid-template-columns:44px minmax(0,1fr);
  }
  .learner-course-card--compact .learner-course-card__actions,
  .learner-course-card__actions{
    grid-column:2 / -1;
    min-width:0;
    width:100%;
  }
  .learner-hero__copy h1{
    white-space:normal;
  }
  .learner-dashboard .learner-quick-access-panel .learner-quick-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .learner-account-layout,
  .learner-account-settings-grid{
    grid-template-columns:1fr;
  }
  .learner-help-layout__side{
    grid-template-columns:1fr;
  }
  .learner-account-support-card{
    display:grid;
  }
}
@media (max-width: 560px){
  .portal-role-learner .main-shell--learner-dashboard,
  .portal-role-company .main-shell--company-dashboard{
    width:min(100% - 24px,1280px);
  }
  .portal-role-learner .portal-user-card__meta{
    white-space:normal;
  }
  .learner-hero__copy h1{
    font-size:40px;
    line-height:1.08;
  }
  .learner-help .learner-card-grid--topics{
    grid-template-columns:1fr;
  }
  .learner-dashboard .learner-quick-access-panel .learner-quick-grid{
    grid-template-columns:1fr;
  }
  .learner-dashboard .learner-stat-grid--compact{
    grid-template-columns:1fr;
  }
  .learner-course-card,
  .learner-certificate-card{
    grid-template-columns:1fr;
  }
  .learner-invoice-card{
    grid-template-columns:1fr;
  }
  .learner-account-list div,
  .learner-account-stat-grid{
    grid-template-columns:1fr;
  }
  .learner-account-list div{
    gap:4px;
  }
  .learner-account-actions .learner-btn{
    width:100%;
  }
  .learner-course-card--compact .learner-course-card__actions,
  .learner-course-card__actions{
    grid-column:auto;
    width:100%;
  }
  .learner-invoice-card__actions{
    align-items:flex-start;
    min-width:0;
    width:100%;
  }
  .learner-certificate-card__heading{
    flex-direction:column;
  }
  .learner-certificate-card__preview{
    align-items:flex-start;
    min-height:0;
  }
}
.portal-role-learner .learner-profile-menu__panel a span{
  color:inherit;
  font-size:13px;
  font-weight:650;
  text-transform:none;
}

/* Company portal client-facing polish: align company manager UI with the learner portal system. */
.portal-role-company{
  --learner-ink:#142235;
  --learner-muted:#5f6f82;
  --learner-subtle:#7d8da0;
  --learner-bg:#f5f7fa;
  --learner-panel:#fff;
  --learner-soft:#f1f5f8;
  --learner-line:#dfe7ee;
  --learner-blue:#176fb5;
  --learner-blue-dark:#0b3354;
  --learner-cyan:#0d8fad;
  --learner-green:#1f7a50;
  --learner-amber:#a9630c;
  --learner-purple:#6252a4;
  --learner-red:#b42318;
  --learner-shadow:0 1px 2px rgba(15,23,42,.05);
  --learner-shadow-soft:0 6px 16px rgba(15,35,55,.07);
  --learner-focus:#2b8bd3;
  --learner-radius:8px;
  background:var(--learner-bg);
}
.portal-role-company .portal-workspace{
  background:linear-gradient(180deg,#f4f8fb 0,#f7f9fb 100%);
}
.portal-role-company .portal-sidebar{
  background:#092b49;
  box-shadow:6px 0 18px rgba(6,28,48,.14);
}
.portal-role-company .portal-brand{
  min-height:64px;
  padding:6px 8px 14px;
}
.portal-role-company .portal-brand__logo-wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  max-width:none;
  min-height:62px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  background:#fff;
  box-shadow:0 6px 16px rgba(2,16,28,.12);
}
.portal-role-company .portal-brand__logo--light{display:none}
.portal-role-company .portal-brand__logo--blue{
  display:block;
  width:100%;
  max-width:184px;
  height:auto;
}
.portal-role-company .portal-nav-link{
  border-radius:10px;
  color:#dcecff;
}
.portal-role-company .portal-nav-link:hover{
  background:rgba(255,255,255,.13);
  color:#fff;
}
.portal-role-company .portal-nav-link.is-active{
  background:#fff;
  color:#092b49;
  box-shadow:none;
}
.portal-role-company .portal-nav-link.is-active::before{display:none}
.portal-role-company .portal-nav-link.is-active .portal-nav-icon{
  background:#eaf4fb;
  color:#0b5c8d;
}
.portal-role-company .portal-nav-icon,
.portal-role-company .portal-nav-icon svg{
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-company .portal-sidebar__footer{
  border-top-color:rgba(255,255,255,.14);
}
.portal-role-company .portal-user-card{
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  padding:12px;
  border-color:rgba(255,255,255,.18);
  border-radius:12px;
  background:rgba(255,255,255,.08);
  box-shadow:none;
}
.portal-role-company .portal-user-card>span:last-child{min-width:0}
.portal-role-company .portal-user-card strong{
  color:#fff;
  white-space:normal;
}
.portal-role-company .portal-user-card small{
  color:rgba(233,245,255,.76);
  white-space:normal;
}
.portal-role-company .portal-sidebar__footer .nav-button{
  border-color:rgba(255,255,255,.14);
  border-radius:10px;
  background:rgba(255,255,255,.08);
  color:#fff;
  box-shadow:none;
}
.portal-role-company .portal-topbar{
  border-bottom-color:#e1e8ef;
  background:rgba(255,255,255,.94);
  box-shadow:0 1px 2px rgba(15,23,42,.05);
}
.portal-role-company .portal-topbar span{
  color:var(--learner-muted);
  font-size:12px;
  letter-spacing:0;
  text-transform:none;
}
.portal-role-company .portal-topbar strong{
  margin-top:2px;
  color:var(--learner-ink);
  font-size:19px;
  font-weight:650;
}
.portal-role-company .main-shell{
  padding-top:30px;
}
.portal-role-company .page-heading{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:20px;
  align-items:end;
  margin:0 0 18px;
  padding:4px 0 8px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.portal-role-company .page-heading h1{
  margin:0;
  color:var(--learner-ink);
  font-size:34px;
  line-height:1.05;
  font-weight:700;
  letter-spacing:0;
}
.portal-role-company .page-heading .hero-copy{
  max-width:690px;
  margin:9px 0 0;
  color:var(--learner-muted);
  font-size:15px;
  line-height:1.55;
}
.portal-role-company .page-actions,
.portal-role-company .hero-actions,
.portal-role-company .company-purchase-card__actions,
.portal-role-company .company-learner-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
}
.portal-role-company .company-page-header__actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.portal-role-company .company-workspace{
  gap:22px;
}
.portal-role-company .company-browser{
  width:100%;
}
.portal-role-company .company-browser__toolbar{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
  align-items:start;
  justify-items:start;
}
.portal-role-company .company-browser__toolbar h2{
  margin:0;
  color:var(--learner-ink);
  font-size:23px;
  line-height:1.2;
  font-weight:650;
}
.portal-role-company .primary-button,
.portal-role-company .secondary-button,
.portal-role-company .small-button,
.portal-role-company .nav-button{
  min-height:40px;
  border-radius:10px;
  font-size:14px;
  font-weight:600;
  letter-spacing:0;
  box-shadow:none;
  transition:background .14s ease,border-color .14s ease,color .14s ease,box-shadow .14s ease;
}
.portal-role-company .primary-button,
.portal-role-company .small-button{
  border-color:#0b3354;
  background:#0b3354;
  color:#fff;
}
.portal-role-company .primary-button:hover,
.portal-role-company .small-button:hover{
  border-color:#092b49;
  background:#092b49;
  box-shadow:none;
}
.portal-role-company .secondary-button,
.portal-role-company .nav-button{
  border-color:#d9e4ec;
  background:#fff;
  color:#14324a;
}
.portal-role-company .secondary-button:hover,
.portal-role-company .nav-button:hover{
  border-color:#b9cbd9;
  background:#f7fafc;
  color:#0b3354;
  box-shadow:none;
}
.portal-role-company .primary-button--compact,
.portal-role-company .secondary-button--compact{
  min-height:36px;
  padding:0 12px;
  font-size:13px;
}
.portal-role-company .status-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  min-width:0;
  min-height:26px;
  padding:0 10px;
  border:0;
  border-radius:999px;
  font-size:12px;
  font-weight:500;
  line-height:1;
  letter-spacing:0;
  text-transform:none;
  white-space:nowrap;
  box-shadow:none;
}
.portal-role-company .status-pill--available,
.portal-role-company .status-pill--provisioned,
.portal-role-company .status-pill--completed,
.portal-role-company .status-pill--certificate,
.portal-role-company .status-pill--paid{
  background:#eaf7f0;
  color:var(--learner-green);
}
.portal-role-company .status-pill--assigned,
.portal-role-company .status-pill--in-progress{
  background:#eaf4fb;
  color:var(--learner-blue);
}
.portal-role-company .status-pill--queued,
.portal-role-company .status-pill--provisioning,
.portal-role-company .status-pill--processing,
.portal-role-company .status-pill--access-pending{
  background:#f1edff;
  color:var(--learner-purple);
}
.portal-role-company .status-pill--unassigned,
.portal-role-company .status-pill--needs-review{
  background:#fff4df;
  color:var(--learner-amber);
}
.portal-role-company .status-pill--failed,
.portal-role-company .status-pill--access-issue,
.portal-role-company .status-pill--expired{
  background:#fff0ef;
  color:var(--learner-red);
}
.portal-role-company .status-pill--full{
  background:#eef4f8;
  color:var(--learner-muted);
}
.portal-role-company .hero-panel.company-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(260px,320px);
  gap:22px;
  align-items:stretch;
  min-height:258px;
  margin-bottom:18px;
  padding:34px;
  border:0;
  border-radius:18px;
  background:linear-gradient(135deg,#0b3354 0,#166dad 58%,#0d93ad 100%);
  color:#fff;
  box-shadow:0 18px 38px -26px rgba(7,31,51,.42);
}
.portal-role-company .company-hero h1{
  margin:0;
  color:#fff;
  font-size:42px;
  line-height:1.08;
  font-weight:700;
  letter-spacing:0;
}
.portal-role-company .company-hero .hero-copy{
  max-width:620px;
  margin-top:12px;
  color:#dceeff;
  font-size:16px;
  line-height:1.55;
}
.portal-role-company .company-hero .hero-actions{
  margin-top:22px;
}
.portal-role-company .company-hero .primary-button{
  border-color:#fff;
  background:#fff;
  color:#0b3354;
}
.portal-role-company .company-hero .secondary-button{
  border-color:rgba(255,255,255,.24);
  background:rgba(255,255,255,.12);
  color:#fff;
}
.portal-role-company .company-hero .primary-button:hover{background:#eef7ff}
.portal-role-company .company-hero .secondary-button:hover{
  border-color:rgba(255,255,255,.36);
  background:rgba(255,255,255,.2);
  color:#fff;
}
.portal-role-company .client-progress-card{
  display:grid;
  align-content:center;
  gap:12px;
  min-height:0;
  padding:22px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:16px;
  background:rgba(255,255,255,.13);
  color:#fff;
  box-shadow:none;
}
.portal-role-company .client-progress-card span,
.portal-role-company .client-progress-card small{
  color:#dceeff;
  font-size:13px;
  line-height:1.35;
  text-transform:none;
}
.portal-role-company .client-progress-card strong{
  color:#fff;
  font-size:42px;
  line-height:1;
  font-weight:650;
  letter-spacing:0;
}
.portal-role-company .client-progress-card .student-progress-track{
  height:10px;
  background:rgba(255,255,255,.24);
  box-shadow:none;
}
.portal-role-company .client-progress-card .student-progress-track span{
  background:#8fe3c1;
  box-shadow:none;
}
.portal-role-company .learner-hero__copy{
  min-height:300px;
}
.portal-role-company .learner-hero__copy h1{
  max-width:620px;
}
.portal-role-company .learner-quick-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.portal-role-company .company-card-grid{
  gap:8px;
}
.portal-role-company .company-training-card .learner-course-card__message{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-company .company-action-required .learner-action-item{
  box-sizing:border-box;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  width:100%;
  min-height:0;
  padding:14px;
  text-decoration:none;
}
.portal-role-company .company-action-required .learner-action-required__grid{
  display:grid;
  grid-template-columns:1fr;
  width:100%;
}
.portal-role-company .company-action-required .learner-action-item span{
  display:grid;
  gap:4px;
  min-width:0;
}
.portal-role-company .company-action-required .learner-action-item strong{
  font-size:28px;
  line-height:1;
}
.portal-role-company .company-action-required .learner-action-item small{
  display:block;
  color:var(--learner-muted);
  font-size:13px;
  line-height:1.35;
}
.portal-role-company .company-action-required .learner-action-item em{
  color:var(--learner-blue);
  font-size:13px;
  font-style:normal;
}
.portal-role-company .setup-summary-grid,
.portal-role-company .client-summary-grid{
  gap:14px;
  margin-bottom:18px;
}
.portal-role-company .setup-summary-card,
.portal-role-company .client-summary-card,
.portal-role-company .panel,
.portal-role-company .company-purchase-card,
.portal-role-company .company-seat-card,
.portal-role-company .seat-card,
.portal-role-company .learner-roster-card,
.portal-role-company .company-record-table,
.portal-role-company .company-settings-tabs,
.portal-role-company .company-owner-card{
  border:1px solid transparent;
  border-radius:14px;
  background:#fff;
  box-shadow:var(--learner-shadow);
}
.portal-role-company .setup-summary-card,
.portal-role-company .client-summary-card{
  display:grid;
  align-content:start;
  min-height:108px;
  padding:18px;
  overflow:hidden;
}
.portal-role-company .setup-summary-card span,
.portal-role-company .client-summary-card span{
  color:var(--learner-subtle);
  font-size:12px;
  font-weight:500;
  letter-spacing:0;
  text-transform:none;
}
.portal-role-company .setup-summary-card strong,
.portal-role-company .client-summary-card strong{
  margin-top:8px;
  color:var(--learner-ink);
  font-size:30px;
  line-height:1;
  font-weight:650;
  letter-spacing:0;
}
.portal-role-company .setup-summary-card small,
.portal-role-company .client-summary-card small{
  margin-top:8px;
  color:var(--learner-muted);
  font-size:13px;
  line-height:1.4;
}
.portal-role-company .client-summary-card.is-action,
.portal-role-company .client-summary-card.is-attention{
  border-color:transparent;
  background:#fff;
}
.portal-role-company .client-summary-card.is-action strong{color:var(--learner-blue)}
.portal-role-company .client-summary-card.is-attention strong{color:var(--learner-amber)}
.portal-role-company .panel{
  padding:22px;
}
.portal-role-company .panel-heading{
  margin-bottom:16px;
}
.portal-role-company .panel-heading h2{
  margin:0;
  color:var(--learner-ink);
  font-size:23px;
  line-height:1.2;
  font-weight:650;
  letter-spacing:0;
}
.portal-role-company .panel-count{
  min-height:28px;
  border:0;
  border-radius:999px;
  background:#eef4f8;
  color:var(--learner-muted);
  font-size:12px;
  font-weight:500;
}
.portal-role-company .company-dashboard-layout{
  grid-template-columns:minmax(0,1.25fr) minmax(360px,.75fr);
  gap:18px;
}
.portal-role-company .company-dashboard-side{
  gap:18px;
}
.portal-role-company .company-seat-list,
.portal-role-company .purchase-card-list,
.portal-role-company .company-purchase-list,
.portal-role-company .seat-list,
.portal-role-company .learner-roster-list,
.portal-role-company .company-activity-list{
  gap:12px;
}
.portal-role-company .company-seat-card{
  padding:16px;
}
.portal-role-company .company-seat-card--compact{
  grid-template-columns:minmax(0,1.2fr) minmax(0,.85fr) auto;
}
.portal-role-company .order-link-card__label,
.portal-role-company .company-seat-section-label{
  color:var(--learner-subtle);
  font-size:11px;
  font-weight:500;
  letter-spacing:0;
  text-transform:none;
}
.portal-role-company .company-seat-card__main strong,
.portal-role-company .learner-roster-card__person strong,
.portal-role-company .company-assigned-learner-row strong,
.portal-role-company .company-purchase-card__header strong,
.portal-role-company .company-activity-row strong{
  color:var(--learner-ink);
  font-weight:650;
}
.portal-role-company .company-seat-card__main small,
.portal-role-company .company-seat-card__learner small,
.portal-role-company .learner-roster-card__person small,
.portal-role-company .company-assigned-learner-row small,
.portal-role-company .company-purchase-card__header small,
.portal-role-company .company-activity-row span,
.portal-role-company .company-activity-row small{
  color:var(--learner-muted);
}
.portal-role-company .company-activity-row,
.portal-role-company .company-assigned-learner-row,
.portal-role-company .company-purchase-progress,
.portal-role-company .company-purchase-meta div,
.portal-role-company .company-learner-stats div,
.portal-role-company .company-included-courses{
  border-color:#e6eef7;
  border-radius:12px;
  background:#f8fbfd;
}
.portal-role-company .company-activity-row{
  padding:13px 14px;
}
.portal-role-company .company-panel-toolbar{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  align-items:start;
}
.portal-role-company .company-panel-toolbar .company-filter-row{
  justify-content:flex-start;
}
.portal-role-company .company-filter-row{
  display:flex;
  align-items:flex-end;
  flex-wrap:wrap;
  gap:10px;
  width:100%;
  justify-content:flex-start;
}
.portal-role-company .learner-control-row.company-filter-row{
  justify-content:flex-start;
}
.portal-role-company .company-filter-row--records{
  display:grid;
  grid-template-columns:minmax(230px,1.4fr) minmax(150px,.65fr) minmax(230px,1fr) minmax(150px,.65fr) minmax(150px,.65fr);
}
.portal-role-company .student-search-field,
.portal-role-company .company-filter-select select{
  height:42px;
  border:1px solid #dfe7ee;
  border-radius:12px;
  background-color:#fff;
  box-shadow:none;
}
.portal-role-company .student-search-field{
  display:flex;
  align-items:center;
  gap:9px;
  width:min(320px,100%);
  padding:0 12px;
}
.portal-role-company .student-search-field svg{
  flex:0 0 auto;
  width:17px;
  height:17px;
  fill:none;
  stroke:var(--learner-muted);
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-company .student-search-field input{
  min-width:0;
  width:100%;
  height:100%;
  border:0;
  padding:0;
  background:transparent;
  color:var(--learner-ink);
  font:inherit;
  font-size:14px;
  outline:0;
}
.portal-role-company .company-filter-select{
  gap:6px;
  min-width:158px;
  color:var(--learner-muted);
  font-size:12px;
}
.portal-role-company .company-filter-select span{
  color:var(--learner-muted);
  font-size:12px;
  font-weight:500;
}
.portal-role-company .company-filter-select select{
  padding:0 34px 0 12px;
  color:var(--learner-ink);
  font:inherit;
  font-size:14px;
  font-weight:500;
}
.portal-role-company .student-search-field:focus-within,
.portal-role-company .company-filter-select select:focus{
  border-color:#b9cbd9;
  box-shadow:0 0 0 3px rgba(23,111,181,.09);
  outline:0;
}
.portal-role-company .company-purchase-card{
  gap:16px;
  padding:20px;
  transition:border-color .14s ease,box-shadow .14s ease;
}
.portal-role-company .company-purchase-card:hover{
  border-color:#d8e5ee;
  box-shadow:var(--learner-shadow-soft);
}
.portal-role-company .company-purchase-card__header{
  align-items:flex-start;
}
.portal-role-company .company-purchase-card__main{
  gap:12px;
}
.portal-role-company .company-purchase-card__main h3{
  color:var(--learner-ink);
  font-size:20px;
  line-height:1.25;
  font-weight:650;
  letter-spacing:0;
}
.portal-role-company .company-course-summary span{
  color:#31465a;
  font-size:14px;
}
.portal-role-company .company-course-summary small,
.portal-role-company .company-included-courses summary{
  color:var(--learner-blue);
  font-size:13px;
}
.portal-role-company .company-purchase-card__body{
  grid-template-columns:minmax(0,1.2fr) minmax(340px,.8fr);
  align-items:stretch;
}
.portal-role-company .company-purchase-progress{
  align-self:end;
  padding:13px;
}
.portal-role-company .company-purchase-progress strong,
.portal-role-company .company-purchase-meta dd,
.portal-role-company .company-learner-stats strong{
  color:var(--learner-ink);
  font-weight:600;
}
.portal-role-company .company-purchase-progress span,
.portal-role-company .company-purchase-meta dt,
.portal-role-company .company-purchase-meta small,
.portal-role-company .company-learner-stats span{
  color:var(--learner-muted);
  font-weight:500;
}
.portal-role-company .company-purchase-meta{
  align-self:stretch;
  gap:10px;
}
.portal-role-company .company-purchase-meta div{
  display:grid;
  align-content:center;
  min-height:78px;
  padding:12px;
}
.portal-role-company .company-assignment-card{
  padding:18px;
  border-radius:14px;
  transition:border-color .14s ease,box-shadow .14s ease;
}
.portal-role-company .company-assignment-card:hover{
  border-color:#d8e5ee;
  box-shadow:var(--learner-shadow-soft);
}
.portal-role-company .seat-card__summary{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  align-items:start;
}
.portal-role-company .seat-card__summary strong{
  color:var(--learner-ink);
  font-size:18px;
  line-height:1.25;
  font-weight:650;
}
.portal-role-company .seat-card__summary span:not(.status-pill){
  color:var(--learner-muted);
  font-size:13px;
}
.portal-role-company .company-assigned-learners,
.portal-role-company .company-available-seat-forms{
  border-top-color:#e6eef7;
}
.portal-role-company .assign-seat-form{
  grid-template-columns:repeat(4,minmax(0,1fr)) 34px;
  grid-template-areas:
    "first last email phone remove"
    ". . helper . .";
  align-items:end;
  column-gap:10px;
  row-gap:6px;
  padding:12px;
  border:1px solid #e6eef7;
  border-radius:12px;
  background:#f8fbfd;
}
.portal-role-company .company-seat-field--first{
  grid-area:first;
}
.portal-role-company .company-seat-field--last{
  grid-area:last;
}
.portal-role-company .company-seat-field--email{
  grid-area:email;
}
.portal-role-company .company-seat-field--phone{
  grid-area:phone;
}
.portal-role-company .assign-seat-form .learner-btn{
  grid-area:action;
  align-self:end;
  white-space:nowrap;
}
.portal-role-company .field{
  color:var(--learner-muted);
  font-size:12px;
}
.portal-role-company .field span{
  color:var(--learner-muted);
  font-weight:500;
}
.portal-role-company .field input,
.portal-role-company .field select{
  height:42px;
  border-color:#dfe7ee;
  border-radius:12px;
  color:var(--learner-ink);
  font-size:14px;
  font-weight:500;
  box-shadow:none;
}
.portal-role-company .field input:focus,
.portal-role-company .field select:focus{
  border-color:#b9cbd9;
  box-shadow:0 0 0 3px rgba(23,111,181,.09);
}
.portal-role-company .company-learner-card{
  grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr) minmax(160px,.5fr) minmax(160px,.5fr) auto;
  align-items:end;
  gap:14px;
  padding:16px;
  border-radius:14px;
}
.portal-role-company .company-learner-stats{
  grid-template-columns:minmax(70px,.55fr) minmax(78px,.55fr) minmax(112px,1fr);
}
.portal-role-company .company-learner-stats div{
  padding:10px;
}
.portal-role-company .company-record-table{
  overflow:hidden;
}
.portal-role-company .company-record-row{
  grid-template-columns:minmax(150px,.9fr) minmax(250px,1.5fr) minmax(116px,.55fr) minmax(100px,.45fr) minmax(100px,.45fr) minmax(100px,.45fr);
  gap:14px;
  min-height:64px;
  padding:14px 16px;
  border-top-color:#e6eef7;
}
.portal-role-company .company-record-row:nth-child(even):not(.company-record-row--head){
  background:#fbfdff;
}
.portal-role-company .company-record-row--head{
  min-height:42px;
  background:#f5f8fb;
  color:var(--learner-muted);
  font-size:12px;
  font-weight:500;
}
.portal-role-company .company-record-row strong{
  color:var(--learner-ink);
  font-weight:600;
}
.portal-role-company .company-record-row small,
.portal-role-company .company-record-row span:not(.status-pill){
  color:var(--learner-muted);
}
.portal-role-company .company-record-row>.status-pill{
  width:118px;
}
.portal-role-company .company-settings-tabs{
  gap:6px;
  padding:6px;
  border-color:transparent;
}
.portal-role-company .company-settings-tabs button{
  min-height:38px;
  border-radius:10px;
  color:var(--learner-muted);
  font-weight:600;
}
.portal-role-company .company-settings-tabs button:hover,
.portal-role-company .company-settings-tabs button:focus-visible{
  background:#f1f5f8;
  color:var(--learner-ink);
}
.portal-role-company .company-settings-tabs button.is-active{
  background:#0b3354;
  color:#fff;
}
.portal-role-company .company-owner-card{
  padding:16px;
  border-radius:14px;
  background:#fff;
}
.portal-role-company .company-owner-card p,
.portal-role-company .panel-note{
  color:var(--learner-muted);
  font-size:14px;
  line-height:1.5;
}
.portal-role-company .empty-state{
  border-color:#e6eef7;
  border-radius:14px;
  background:#f8fbfd;
}
.portal-role-company .student-pagination{
  border:0;
  border-radius:14px;
  background:#fff;
  box-shadow:var(--learner-shadow);
}
.portal-role-company .student-pagination button{
  border-radius:10px;
  font-weight:500;
}

/* Company role: final alignment with the student portal visual system. */
.portal-role-company .portal-app-shell{
  grid-template-columns:268px minmax(0,1fr);
}
.portal-role-company .portal-brand__logo-wrap{
  display:block;
  justify-content:flex-start;
  width:auto;
  max-width:178px;
  min-height:0;
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  line-height:0;
}
.portal-role-company .portal-sidebar{
  gap:22px;
  padding:20px 16px;
  background:#092b49;
  box-shadow:6px 0 18px rgba(6,28,48,.14);
}
.portal-role-company .portal-brand{
  min-height:auto;
  padding:4px 12px 12px;
  border-bottom:1px solid rgba(255,255,255,.68);
  background:transparent;
  backdrop-filter:none;
}
.portal-role-company .portal-brand__logo--light{
  display:block;
  width:100%;
  max-width:178px;
  height:auto;
}
.portal-role-company .portal-brand__logo--blue{display:none}
.portal-role-company .portal-nav-link{
  min-height:44px;
  border-radius:10px;
  color:#e8f5ff;
}
.portal-role-company .portal-nav-link:hover{
  background:rgba(255,255,255,.12);
  color:#fff;
}
.portal-role-company .portal-nav-link.is-active{
  background:#fff;
  color:#0c3558;
  box-shadow:none;
}
.portal-role-company .portal-nav-link.is-active::before{
  display:none;
}
.portal-role-company .portal-nav-icon{
  border-radius:var(--learner-radius);
  background:rgba(255,255,255,.12);
  color:inherit;
}
.portal-role-company .portal-nav-link.is-active .portal-nav-icon{
  display:inline-flex;
  visibility:visible;
  opacity:1;
  color:#0b5c8d;
  background:#eaf4fb;
}
.portal-role-company .portal-sidebar__footer{
  gap:8px;
  padding-top:14px;
  border-top-color:rgba(255,255,255,.12);
}
.portal-role-company .portal-user-card{
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  padding:11px;
  border-color:rgba(255,255,255,.18);
  border-radius:12px;
  background:rgba(255,255,255,.08);
  box-shadow:none;
}
.portal-role-company .portal-user-card>span:last-child{
  min-width:0;
}
.portal-role-company .portal-user-card strong{
  color:#fff;
  white-space:normal;
}
.portal-role-company .portal-user-card small{
  color:rgba(233,245,255,.76);
  white-space:normal;
}
.portal-role-company .portal-sidebar__footer .nav-button{
  min-height:34px;
  border-color:transparent;
  border-radius:10px;
  background:transparent;
  color:rgba(233,245,255,.74);
  font-weight:650;
  box-shadow:none;
}
.portal-role-company .portal-sidebar__footer .nav-button:hover,
.portal-role-company .portal-sidebar__footer .nav-button:focus-visible{
  background:rgba(255,255,255,.08);
  color:#fff;
}
.portal-role-company .portal-topbar__inner{
  min-height:76px;
  align-items:center;
}
.portal-role-company .learner-topbar-profile{
  display:grid;
  grid-template-columns:auto auto;
  align-items:center;
  gap:9px;
  min-height:42px;
  padding:4px 10px 4px 4px;
  border:1px solid var(--learner-line);
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  list-style:none;
}
.portal-role-company .learner-topbar-profile .portal-avatar{
  background:#0b3354;
  color:#fff;
  box-shadow:0 0 0 2px #e8f1f8;
}
.portal-role-company .learner-topbar-profile::-webkit-details-marker{display:none}
.portal-role-company .learner-profile-menu__panel a span{
  color:inherit;
  font-size:13px;
  font-weight:650;
  text-transform:none;
}
.portal-role-company .learner-search-field{
  min-height:42px;
  border-color:#dfe7ee;
  border-radius:12px;
  background:#fff;
  box-shadow:none;
}
.portal-role-company .learner-search-field:focus-within{
  border-color:#b9cbd9;
  box-shadow:0 0 0 3px rgba(23,111,181,.09);
}
.portal-role-company .company-purchase-card.learner-invoice-card,
.portal-role-company .company-assignment-card.learner-course-card,
.portal-role-company .company-learner-card.learner-course-card{
  border-radius:var(--learner-radius);
  border-color:var(--learner-line);
  box-shadow:none;
}
.portal-role-company .company-purchase-card.learner-invoice-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:18px;
  padding:18px;
}
.portal-role-company .company-purchase-card.learner-invoice-card:hover,
.portal-role-company .company-assignment-card.learner-course-card:hover,
.portal-role-company .company-learner-card.learner-course-card:hover{
  border-color:#d2e1ed;
  box-shadow:0 10px 24px rgba(15,35,55,.06);
}
.portal-role-company .company-purchase-card__actions{
  display:grid;
  justify-items:end;
  align-content:start;
  gap:10px;
  min-width:190px;
  padding-top:0;
}
.portal-role-company .company-purchase-card__actions>strong{
  display:grid;
  justify-items:end;
  gap:2px;
  color:var(--learner-ink);
  font-size:17px;
  line-height:1.2;
  font-weight:650;
}
.portal-role-company .company-purchase-card__actions>strong span{
  color:var(--learner-muted);
  font-size:11px;
  line-height:1.2;
  font-weight:500;
}
.portal-role-company .company-purchase-action-meta{
  display:grid;
  justify-items:end;
  gap:2px;
  color:var(--learner-muted);
  font-size:12px;
  line-height:1.35;
}
.portal-role-company .company-purchase-action-meta span{
  max-width:220px;
  overflow:hidden;
  color:var(--learner-muted);
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-company .company-purchase-action-meta .status-pill{
  max-width:none;
  color:#166534;
}
.portal-role-company .company-purchase-progress{
  max-width:720px;
  margin-top:2px;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
}
.portal-role-company .company-purchase-progress div:first-child{
  justify-content:flex-start;
}
.portal-role-company .company-purchase-progress .student-progress-track{
  height:8px;
}
.portal-role-company .company-workflow-note{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin:0 0 14px;
  padding:14px 16px;
  border:1px solid var(--learner-line);
  border-radius:var(--learner-radius-sm);
  background:#fbfdff;
  color:var(--learner-muted);
}
.portal-role-company .company-workflow-note span{
  display:grid;
  gap:2px;
  min-width:0;
}
.portal-role-company .company-workflow-note strong{
  color:var(--learner-ink);
  font-size:14px;
  line-height:1.35;
  font-weight:650;
}
.portal-role-company .company-workflow-note small{
  color:var(--learner-muted);
  font-size:13px;
  line-height:1.45;
}
.portal-role-company .field span em{
  color:var(--learner-muted);
  font-style:normal;
  font-weight:500;
}
.portal-role-company .company-field-helper{
  grid-area:helper;
  display:block;
  margin:0;
  color:var(--learner-muted);
  font-size:12px;
  line-height:1.35;
}
.portal-role-company .learner-invoice-card__courses.company-course-summary{
  display:flex;
  gap:6px;
}
.portal-role-company .learner-invoice-card__courses.company-course-summary span,
.portal-role-company .learner-invoice-card__courses.company-course-summary small{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  max-width:320px;
  padding:0 9px;
  border-radius:999px;
  background:#f1f6fa;
  color:var(--learner-muted);
  font-size:12px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-company .company-assignment-card.learner-course-card{
  align-items:start;
  padding:18px;
}
.portal-role-company .company-assignment-card .learner-course-card__body,
.portal-role-company .company-learner-card .learner-course-card__body{
  gap:14px;
}
.portal-role-company .company-learner-issue{
  margin:0;
  color:var(--learner-muted);
  font-size:13px;
  line-height:1.45;
}
.portal-role-company .seat-card__summary{
  grid-template-columns:minmax(0,1fr) auto;
}
.portal-role-company .seat-card__summary p,
.portal-role-company .learner-roster-card__person p{
  margin:0 0 2px;
  color:var(--learner-muted);
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
}
.portal-role-company .seat-card__summary h3,
.portal-role-company .learner-roster-card__person h3{
  margin:0;
  color:var(--learner-ink);
  font-size:19px;
  line-height:1.25;
}
.portal-role-company .seat-card__summary .company-seat-group-metrics{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  flex-wrap:wrap;
  gap:0;
  width:auto;
  max-width:none;
  margin-top:10px;
}
.portal-role-company .seat-card__summary .company-seat-group-metrics div{
  display:inline-flex;
  align-items:baseline;
  justify-content:flex-start;
  gap:4px;
  width:auto;
  text-align:left;
}
.portal-role-company .seat-card__summary .company-seat-group-metrics div:not(:last-child)::after{
  content:"\2022";
  margin:0 9px;
  color:#b3c0cc;
  font-size:12px;
  line-height:1;
}
.portal-role-company .seat-card__summary .company-seat-group-metrics dt{
  color:var(--learner-muted);
  font-size:12px;
  line-height:1.2;
  white-space:nowrap;
}
.portal-role-company .seat-card__summary .company-seat-group-metrics dd{
  order:-1;
  color:var(--learner-ink);
  font-size:13px;
  line-height:1.2;
}
.portal-role-company .learner-roster-card__person span{
  display:block;
  margin-top:3px;
  color:var(--learner-muted);
  font-size:13px;
}
.portal-role-company .company-assigned-learners,
.portal-role-company .company-available-seat-forms{
  display:grid;
  gap:10px;
  padding-top:2px;
  border-top:0;
}
.portal-role-company .company-seat-row-toolbar{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.portal-role-company .company-seat-row-count{
  margin-left:auto;
  color:var(--learner-muted);
  font-size:12px;
  line-height:1.2;
}
.portal-role-company .company-seat-submit-row{
  display:flex;
  justify-content:flex-end;
  padding-top:2px;
}
.portal-role-company .company-seat-submit-row .learner-btn{
  min-width:138px;
}
.portal-role-company .company-seat-submit-row .learner-btn.is-submitting{
  opacity:.72;
  cursor:progress;
}
.portal-role-company .company-assigned-learners__header{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.portal-role-company .company-assigned-learners__summary{
  margin-left:auto;
  color:var(--learner-muted);
  font-size:12px;
  line-height:1.2;
}
.portal-role-company .company-assigned-pagination{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  padding-top:2px;
}
.portal-role-company .company-assigned-pagination[hidden]{
  display:none;
}
.portal-role-company .company-assigned-pagination span{
  color:var(--learner-muted);
  font-size:12px;
  line-height:1.2;
}
.portal-role-company .company-assigned-pagination button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  padding:0 10px;
  border:1px solid #dce7ef;
  border-radius:9px;
  background:#fff;
  color:#176fb5;
  cursor:pointer;
  font:inherit;
  font-size:12px;
  line-height:1;
  transition:background .14s ease,border-color .14s ease,color .14s ease,box-shadow .14s ease;
}
.portal-role-company .company-assigned-pagination button:hover:not(:disabled){
  border-color:#c6d7e4;
  background:#f8fbfd;
  color:#0b5c8d;
  box-shadow:0 3px 10px rgba(15,35,55,.055);
}
.portal-role-company .company-assigned-pagination button:disabled{
  border-color:#e6eef5;
  background:#f7fafc;
  color:#9aabb9;
  cursor:not-allowed;
  box-shadow:none;
}
.portal-role-company .company-assigned-pagination button:focus-visible{
  outline:3px solid rgba(43,139,211,.24);
  outline-offset:2px;
}
.portal-role-company .company-seat-icon-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  width:34px;
  height:34px;
  padding:0;
  border:1px solid #dce7ef;
  border-radius:10px;
  background:#fff;
  color:#176fb5;
  cursor:pointer;
  transition:background .14s ease,border-color .14s ease,color .14s ease,box-shadow .14s ease;
}
.portal-role-company .company-seat-icon-button:hover{
  border-color:#c6d7e4;
  background:#f8fbfd;
  color:#0b5c8d;
  box-shadow:0 3px 10px rgba(15,35,55,.055);
}
.portal-role-company .company-seat-icon-button:focus-visible{
  outline:3px solid rgba(43,139,211,.24);
  outline-offset:2px;
}
.portal-role-company .company-seat-icon-button:disabled{
  border-color:#e6eef5;
  background:#f7fafc;
  color:#a8b7c5;
  cursor:not-allowed;
  box-shadow:none;
}
.portal-role-company .company-seat-icon-button svg{
  width:17px;
  height:17px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-company .company-seat-row-remove{
  grid-area:remove;
  align-self:end;
  color:#b42318;
  margin-bottom:4px;
}
.portal-role-company .company-seat-row-remove:hover{
  border-color:#f3c6c2;
  background:#fff7f6;
  color:#9b1c13;
}
.portal-role-company .company-assigned-learner-row{
  grid-template-columns:28px minmax(0,1fr) auto auto;
  padding:12px;
}
.portal-role-company .company-assigned-learner-row__number{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px;
  height:24px;
  border:1px solid #c6d9ea;
  border-radius:999px;
  background:#e3f0fa;
  color:#214b6b;
  font-size:12px;
  font-weight:650;
  line-height:1;
}
.portal-role-company .company-learner-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:start;
  gap:16px;
  padding:18px;
}
.portal-role-company .company-learner-stats{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.portal-role-company .company-learner-stats div{
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
}
.portal-role-company .company-learner-fields{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,220px));
  gap:10px;
}
.portal-role-company .company-learner-actions{
  display:grid;
  justify-items:end;
  gap:10px;
  min-width:150px;
}
.portal-role-company .company-record-table{
  display:grid;
  gap:0;
  overflow:hidden;
  border:1px solid var(--learner-line);
  border-radius:var(--learner-radius);
  background:#fff;
}
.portal-role-company .company-record-row{
  background:#fff;
}
.portal-role-company .company-record-row:nth-child(even):not(.company-record-row--head){
  background:#fff;
}
.portal-role-company .company-record-row:hover:not(.company-record-row--head){
  background:#fbfdff;
}
.portal-role-company .status-pill--attention{
  background:#fee8e6;
  color:#b42318;
}
.portal-role-company .company-record-list{
  display:grid;
  gap:12px;
}
.portal-role-company .company-record-card{
  align-items:start;
  padding:14px 16px;
}
.portal-role-company .company-record-card .learner-course-card__body{
  gap:10px;
}
.portal-role-company .company-record-card .learner-course-card__top p{
  margin:0 0 2px;
  color:var(--learner-muted);
  font-size:12px;
  line-height:1.35;
}
.portal-role-company .company-record-card .learner-course-card__top{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  align-items:start;
  gap:6px;
}
.portal-role-company .company-record-card .learner-course-card__top h3{
  font-size:17px;
}
.portal-role-company .company-record-title-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  min-width:0;
}
.portal-role-company .company-record-title-row h3{
  min-width:0;
}
.portal-role-company .company-record-title-row .status-pill{
  flex:0 0 auto;
}
.portal-role-company .company-record-card__context{
  display:block;
  margin-top:2px;
  color:var(--learner-muted);
  font-size:13px;
}
.portal-role-company .company-record-card__issue{
  display:block;
  margin-top:4px;
  color:#9f3412;
  font-size:13px;
  line-height:1.4;
}
.portal-role-company .company-record-meta{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.portal-role-company .company-record-meta dd{
  display:flex;
  align-items:center;
  min-height:24px;
}
.portal-role-company .company-muted-dash{
  color:var(--learner-muted);
  font-size:13px;
}
.portal-role-label{
  display:inline-flex!important;
  align-items:center;
  gap:6px;
  width:max-content;
  max-width:100%;
  min-height:26px;
  padding:0 9px;
  border:1px solid #d9e6ef;
  border-radius:999px;
  background:#fff;
  color:var(--learner-muted)!important;
  font-size:12px!important;
  font-weight:500!important;
  line-height:1;
  letter-spacing:0!important;
  text-transform:none!important;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.portal-role-label svg{
  width:14px;
  height:14px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.9;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-label--learner{
  border-color:#d8e9f5;
  background:#f7fbfe;
  color:#176fb5!important;
}
.portal-role-label--company{
  border-color:#dfe7ee;
  background:#f8fafc;
  color:#31465a!important;
}
@media (min-width: 901px){
  .portal-role-company .portal-sidebar{
    position:fixed;
    inset:0 auto 0 0;
    width:268px;
    height:100vh;
    height:100dvh;
    overflow-y:auto;
    overscroll-behavior:contain;
  }
  .portal-role-company .portal-workspace{
    grid-column:2;
  }
}
@media (max-width: 1180px){
  .portal-role-company .client-summary-grid--wide,
  .portal-role-company .setup-summary-grid--five{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .portal-role-company .company-dashboard-layout,
  .portal-role-company .company-settings-layout,
  .portal-role-company .company-settings-layout--split{
    grid-template-columns:1fr;
  }
  .portal-role-company .company-dashboard-side{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .portal-role-company .company-purchase-card__body,
  .portal-role-company .company-learner-card{
    grid-template-columns:1fr;
  }
  .portal-role-company .company-filter-row--records{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width: 860px){
  .portal-role-company .portal-sidebar{
    position:fixed;
    inset:0 auto 0 0;
    z-index:40;
    width:288px;
    max-width:86vw;
    height:100dvh;
    min-height:100vh;
    min-height:100dvh;
    border-right:0;
    border-bottom:0;
    overflow-y:auto;
    transform:translateX(-100%);
    transition:transform .18s ease;
    box-shadow:none;
  }
  .portal-role-company .portal-app-shell.is-nav-open .portal-sidebar{
    transform:translateX(0);
  }
  .portal-role-company .portal-app-shell.is-nav-open .portal-mobile-overlay{
    display:block;
  }
  .portal-role-company .portal-mobile-overlay{
    position:fixed;
    inset:0;
    z-index:30;
    border:0;
    padding:0;
    background:rgba(15,23,42,.42);
  }
  .portal-role-company .portal-menu-button{
    display:inline-flex;
  }
  .portal-role-company .portal-workspace{
    grid-column:auto;
  }
  .portal-role-company .page-heading,
  .portal-role-company .hero-panel.company-hero,
  .portal-role-company .company-record-row{
    grid-template-columns:1fr;
  }
  .portal-role-company .page-actions{
    justify-content:flex-start;
  }
  .portal-role-company .company-dashboard-side,
  .portal-role-company .setup-summary-grid,
  .portal-role-company .setup-summary-grid--four,
  .portal-role-company .setup-summary-grid--five,
  .portal-role-company .client-summary-grid,
  .portal-role-company .client-summary-grid--wide,
  .portal-role-company .company-filter-row--records,
  .portal-role-company .company-purchase-meta,
  .portal-role-company .assign-seat-form,
  .portal-role-company .profile-resource-grid--settings{
    grid-template-columns:1fr;
  }
  .portal-role-company .company-filter-select,
  .portal-role-company .student-search-field{
    width:100%;
  }
  .portal-role-company .assign-seat-form{
    grid-template-areas:none;
  }
  .portal-role-company .company-seat-field--first,
  .portal-role-company .company-seat-field--last,
  .portal-role-company .company-seat-field--email,
  .portal-role-company .company-seat-field--phone,
  .portal-role-company .company-field-helper,
  .portal-role-company .assign-seat-form .learner-btn,
  .portal-role-company .assign-seat-form .company-seat-icon-button{
    grid-area:auto;
  }
  .portal-role-company .assign-seat-form .learner-btn{
    width:100%;
  }
  .portal-role-company .company-seat-card--compact,
  .portal-role-company .company-assigned-learner-row,
  .portal-role-company .seat-card__summary{
    grid-template-columns:1fr;
  }
  .portal-role-company .company-record-row--head{
    display:none;
  }
  .portal-role-company .company-record-row{
    gap:8px;
    align-items:start;
    min-height:0;
  }
  .portal-role-company .company-record-row>.status-pill{
    width:max-content;
  }
  .portal-role-company .company-record-row:not(.company-record-row--head)>span:nth-child(4),
  .portal-role-company .company-record-row:not(.company-record-row--head)>span:nth-child(5),
  .portal-role-company .company-record-row:not(.company-record-row--head)>span:nth-child(6){
    display:grid;
    grid-template-columns:90px minmax(0,1fr);
    gap:8px;
    align-items:center;
  }
  .portal-role-company .company-record-row:not(.company-record-row--head)>span:nth-child(4)::before,
  .portal-role-company .company-record-row:not(.company-record-row--head)>span:nth-child(5)::before,
  .portal-role-company .company-record-row:not(.company-record-row--head)>span:nth-child(6)::before{
    color:var(--learner-subtle);
    font-size:12px;
    font-weight:500;
  }
  .portal-role-company .company-record-row:not(.company-record-row--head)>span:nth-child(4)::before{content:"Started"}
  .portal-role-company .company-record-row:not(.company-record-row--head)>span:nth-child(5)::before{content:"Completed"}
  .portal-role-company .company-record-row:not(.company-record-row--head)>span:nth-child(6)::before{content:"Certificate"}
}
@media (max-width: 560px){
  .portal-role-company .page-heading h1{
    font-size:30px;
  }
  .portal-role-company .company-hero h1{
    font-size:36px;
  }
  .portal-role-company .hero-panel.company-hero,
  .portal-role-company .panel,
  .portal-role-company .company-purchase-card{
    padding:18px;
  }
  .portal-role-company .page-actions .primary-button,
  .portal-role-company .page-actions .secondary-button,
  .portal-role-company .hero-actions .primary-button,
  .portal-role-company .hero-actions .secondary-button,
  .portal-role-company .company-purchase-card__actions .primary-button,
  .portal-role-company .company-purchase-card__actions .secondary-button,
  .portal-role-company .company-learner-actions .primary-button,
  .portal-role-company .company-learner-actions .secondary-button{
    width:100%;
  }
}

/* Marcus refinement batch 2: compact inline page-header stats. */
.portal-role-learner .learner-page-header,
.portal-role-company .learner-page-header,
.portal-role-instructor .learner-page-header{
  align-items:end;
}
.portal-role-learner .learner-page-header__stats,
.portal-role-company .learner-page-header__stats,
.portal-role-instructor .learner-page-header__stats{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  align-items:center;
  gap:0;
  width:max-content;
  max-width:100%;
  padding:8px 10px;
  border:1px solid #dfe8f0;
  border-radius:14px;
  background:rgba(255,255,255,.82);
  box-shadow:var(--learner-shadow);
  backdrop-filter:blur(12px);
}
.portal-role-learner .learner-page-header__stats article,
.portal-role-company .learner-page-header__stats article,
.portal-role-instructor .learner-page-header__stats article{
  display:flex;
  align-items:baseline;
  gap:7px;
  min-width:0;
  min-height:0;
  padding:4px 14px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
}
.portal-role-learner .learner-page-header__stats article + article,
.portal-role-company .learner-page-header__stats article + article,
.portal-role-instructor .learner-page-header__stats article + article{
  border-left:1px solid #e4ebf1;
}
.portal-role-learner .learner-page-header__stats span,
.portal-role-company .learner-page-header__stats span,
.portal-role-instructor .learner-page-header__stats span{
  color:var(--learner-muted);
  font-size:12px;
  font-weight:500;
  line-height:1.2;
  letter-spacing:0;
  text-transform:none;
  white-space:nowrap;
}
.portal-role-learner .learner-page-header__stats strong,
.portal-role-company .learner-page-header__stats strong,
.portal-role-instructor .learner-page-header__stats strong{
  order:-1;
  margin:0;
  color:var(--learner-ink);
  font-size:20px;
  line-height:1;
  font-weight:650;
  white-space:nowrap;
}
@media (max-width: 900px){
  .portal-role-learner .learner-page-header,
  .portal-role-company .learner-page-header,
  .portal-role-instructor .learner-page-header{
    align-items:start;
  }
  .portal-role-learner .learner-page-header__stats,
  .portal-role-company .learner-page-header__stats,
  .portal-role-instructor .learner-page-header__stats{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    width:100%;
    padding:0;
    border:0;
    border-radius:0;
    background:transparent;
    box-shadow:none;
    backdrop-filter:none;
    gap:10px;
  }
  .portal-role-learner .learner-page-header__stats article,
  .portal-role-company .learner-page-header__stats article,
  .portal-role-instructor .learner-page-header__stats article{
    justify-content:space-between;
    min-height:0;
    padding:12px 14px;
    border:1px solid #dfe8f0;
    border-radius:12px;
    background:#fff;
    box-shadow:var(--learner-shadow);
  }
  .portal-role-learner .learner-page-header__stats article + article,
  .portal-role-company .learner-page-header__stats article + article,
  .portal-role-instructor .learner-page-header__stats article + article{
    border-left:1px solid #dfe8f0;
  }
}
@media (max-width: 560px){
  .portal-role-learner .learner-page-header__stats,
  .portal-role-company .learner-page-header__stats,
  .portal-role-instructor .learner-page-header__stats{
    grid-template-columns:1fr;
  }
}

/* Marcus refinement batch 3/4: shared wide row-card treatment for learner pages. */
.portal-role-learner .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact){
  grid-template-columns:minmax(112px,.22fr) minmax(0,1.25fr) minmax(230px,.72fr) minmax(150px,auto);
  align-items:stretch;
  gap:0;
  padding:0;
  overflow:hidden;
}
.portal-role-learner .learner-course-card__state,
.portal-role-learner .learner-course-card__body,
.portal-role-learner .learner-course-card__meta,
.portal-role-learner .learner-course-card__helper,
.portal-role-learner .learner-course-card__actions{
  min-width:0;
  padding:18px;
}
.portal-role-learner .learner-course-card__state{
  display:grid;
  align-content:start;
  justify-items:start;
  gap:10px;
  border-right:1px solid #edf3f8;
  background:#fbfdff;
}
.portal-role-learner .learner-course-card__state .learner-status{
  max-width:100%;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__body{
  align-content:center;
  border-right:1px solid #edf3f8;
}
.portal-role-learner .learner-course-card__top{
  display:grid;
  gap:4px;
}
.portal-role-learner .learner-course-card__top h3{
  font-size:19px;
}
.portal-role-learner .learner-course-card__message{
  margin:0;
  color:var(--learner-muted);
}
.portal-role-learner .learner-course-card__meta{
  align-content:center;
  gap:10px;
  margin:0;
  border-right:1px solid #edf3f8;
}
.portal-role-learner .learner-course-card__meta div{
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
}
.portal-role-learner .learner-course-card__meta dt{
  margin:0 0 3px;
}
.portal-role-learner .learner-course-card__actions{
  justify-content:center;
  align-items:flex-end;
  align-self:stretch;
}
.portal-role-learner .learner-course-card--compact{
  grid-template-columns:auto minmax(0,1fr) auto;
}
.portal-role-learner .learner-course-card--compact .learner-course-card__state,
.portal-role-learner .learner-course-card--compact .learner-course-card__body,
.portal-role-learner .learner-course-card--compact .learner-course-card__actions{
  padding:0;
  border-right:0;
  background:transparent;
}
.portal-role-learner .learner-course-card--compact .learner-course-card__state{
  justify-items:start;
}
.portal-role-learner .learner-course-card--compact .learner-course-card__actions{
  grid-column:auto;
  align-items:flex-end;
}
.portal-role-learner .learner-certificate-card{
  grid-template-columns:minmax(96px,.18fr) minmax(0,1.25fr) minmax(230px,.65fr) minmax(154px,auto);
  align-items:stretch;
  min-height:0;
  overflow:hidden;
}
.portal-role-learner .learner-certificate-card__preview{
  min-height:0;
  padding:18px;
  border-right:1px solid #edf3f8;
}
.portal-role-learner .learner-certificate-card__body,
.portal-role-learner .learner-certificate-card__details,
.portal-role-learner .learner-certificate-card__actions{
  min-width:0;
  padding:18px;
}
.portal-role-learner .learner-certificate-card__body{
  align-content:center;
  border-right:1px solid #edf3f8;
}
.portal-role-learner .learner-certificate-card__details{
  display:grid;
  align-content:center;
  gap:10px;
  border-right:1px solid #edf3f8;
}
.portal-role-learner .learner-certificate-card__actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}
.portal-role-learner .learner-certificate-card__expiry{
  margin:0;
}
.portal-role-learner .learner-certificate-facts{
  display:grid;
  grid-template-columns:repeat(3,max-content);
  justify-content:start;
  gap:10px 22px;
  margin:0;
}
.portal-role-learner .learner-certificate-facts div{
  display:grid;
  gap:3px;
  min-width:0;
}
.portal-role-learner .learner-certificate-facts dt{
  color:var(--learner-subtle);
  font-size:11px;
  line-height:1.2;
}
.portal-role-learner .learner-certificate-facts dd{
  margin:0;
  min-width:0;
  overflow:hidden;
  color:var(--learner-ink);
  font-size:13px;
  line-height:1.25;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-learner .learner-invoice-card{
  grid-template-columns:minmax(0,1.05fr) minmax(260px,.85fr) minmax(210px,.5fr) minmax(160px,auto);
  align-items:stretch;
  gap:0;
  padding:0;
  overflow:hidden;
}
.portal-role-learner .learner-invoice-card__main,
.portal-role-learner .learner-invoice-card__courses-block,
.portal-role-learner .learner-invoice-card__payment,
.portal-role-learner .learner-invoice-card__actions{
  min-width:0;
  padding:18px;
}
.portal-role-learner .learner-invoice-card__main,
.portal-role-learner .learner-invoice-card__courses-block,
.portal-role-learner .learner-invoice-card__payment{
  border-right:1px solid #edf3f8;
}
.portal-role-learner .learner-invoice-card__main,
.portal-role-learner .learner-invoice-card__courses-block,
.portal-role-learner .learner-invoice-card__payment{
  align-content:center;
}
.portal-role-learner .learner-invoice-card__payment{
  display:grid;
  gap:6px;
}
.portal-role-learner .learner-invoice-card__payment span{
  color:var(--learner-muted);
  font-size:12px;
  font-weight:500;
}
.portal-role-learner .learner-invoice-card__payment strong{
  color:var(--learner-ink);
  font-size:18px;
  font-weight:650;
  white-space:nowrap;
}
.portal-role-learner .learner-invoice-card__payment small{
  color:var(--learner-muted);
  font-size:13px;
  line-height:1.45;
}
.portal-role-learner .learner-invoice-card__actions{
  align-content:center;
}
@media (max-width: 1100px){
  .portal-role-learner .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact),
  .portal-role-learner .learner-certificate-card,
  .portal-role-learner .learner-invoice-card{
    grid-template-columns:1fr;
  }
  .portal-role-learner .learner-course-card__state,
  .portal-role-learner .learner-card-grid--list .learner-course-card__body,
  .portal-role-learner .learner-course-card__meta,
  .portal-role-learner .learner-certificate-card__preview,
  .portal-role-learner .learner-certificate-card__body,
  .portal-role-learner .learner-certificate-card__details,
  .portal-role-learner .learner-invoice-card__main,
  .portal-role-learner .learner-invoice-card__courses-block,
  .portal-role-learner .learner-invoice-card__payment{
    border-right:0;
    border-bottom:1px solid #edf3f8;
  }
  .portal-role-learner .learner-course-card__actions,
  .portal-role-learner .learner-certificate-card__actions,
  .portal-role-learner .learner-invoice-card__actions{
    align-items:flex-start;
    justify-content:flex-start;
    justify-items:start;
  }
}

/* Marcus refinement batch 5/8: company row-card sections and company Help. */
.portal-role-company .company-purchase-card{
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(320px,.95fr) minmax(220px,.48fr);
  align-items:stretch;
  gap:0;
  padding:0;
  overflow:hidden;
}
.portal-role-company .company-purchase-card.learner-invoice-card{
  grid-template-columns:minmax(0,1.08fr) minmax(320px,.95fr) minmax(220px,.48fr);
  gap:0;
  padding:0;
}
.portal-role-company .company-purchase-card__course,
.portal-role-company .company-purchase-card__seats,
.portal-role-company .company-purchase-card__invoice{
  display:grid;
  align-content:start;
  gap:14px;
  min-width:0;
  padding:18px;
}
.portal-role-company .company-purchase-card__course,
.portal-role-company .company-purchase-card__seats{
  border-right:1px solid #edf3f8;
}
.portal-role-company .company-purchase-card__heading{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:start;
  gap:12px;
  min-width:0;
}
.portal-role-company .company-purchase-card__heading h3{
  margin:5px 0 0;
  color:var(--learner-ink);
  font-size:19px;
  line-height:1.25;
  overflow-wrap:anywhere;
}
.portal-role-company .company-course-summary{
  display:grid;
  gap:7px;
  min-width:0;
}
.portal-role-company .company-course-summary span{
  color:var(--learner-ink);
  font-size:14px;
  line-height:1.35;
  overflow-wrap:anywhere;
}
.portal-role-company .company-course-summary small,
.portal-role-company .company-included-courses summary{
  color:var(--learner-muted);
  font-size:13px;
}
.portal-role-company .company-included-courses ul{
  margin:9px 0 0;
  padding-left:18px;
  color:var(--learner-muted);
  font-size:13px;
  line-height:1.45;
}
.portal-role-company .company-purchase-metrics{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin:0;
}
.portal-role-company .company-purchase-metrics div{
  display:grid;
  gap:3px;
  min-width:0;
  padding:10px 11px;
  border:1px solid #edf3f8;
  border-radius:12px;
  background:#fbfdff;
}
.portal-role-company .company-purchase-metrics dt{
  color:var(--learner-muted);
  font-size:11px;
  font-weight:500;
  line-height:1.2;
}
.portal-role-company .company-purchase-metrics dd{
  margin:0;
  color:var(--learner-ink);
  font-size:18px;
  font-weight:650;
  line-height:1.1;
}
.portal-role-company .company-purchase-learners{
  display:grid;
  gap:4px;
  min-width:0;
}
.portal-role-company .company-purchase-learners span,
.portal-role-company .company-purchase-card__invoice>strong span,
.portal-role-company .company-record-card__certificate>span{
  color:var(--learner-muted);
  font-size:12px;
  font-weight:500;
}
.portal-role-company .company-purchase-learners p{
  margin:0;
  color:var(--learner-ink);
  font-size:14px;
  line-height:1.45;
  overflow-wrap:anywhere;
}
.portal-role-company .company-purchase-card__invoice{
  align-content:center;
}
.portal-role-company .company-purchase-card__invoice>strong{
  display:grid;
  gap:4px;
  color:var(--learner-ink);
  font-size:20px;
  font-weight:650;
}
.portal-role-company .company-purchase-action-meta{
  display:grid;
  justify-items:start;
  gap:8px;
  color:var(--learner-muted);
  font-size:13px;
}
.portal-role-company .company-purchase-action-meta>span:not(.status-pill){
  color:var(--learner-ink);
  overflow-wrap:anywhere;
}
.portal-role-company .company-learner-card{
  display:grid;
  grid-template-columns:minmax(108px,.2fr) minmax(0,1fr) minmax(240px,.56fr) minmax(250px,.58fr) minmax(170px,auto);
  align-items:stretch;
  gap:0;
  padding:0;
  overflow:hidden;
}
.portal-role-company .company-learner-card__state,
.portal-role-company .company-learner-card__identity,
.portal-role-company .company-learner-stats,
.portal-role-company .company-learner-fields,
.portal-role-company .company-learner-actions{
  min-width:0;
  padding:18px;
}
.portal-role-company .company-learner-card__state{
  display:grid;
  align-content:start;
  justify-items:start;
  gap:10px;
  border-right:1px solid #edf3f8;
  background:#fbfdff;
}
.portal-role-company .company-learner-card__identity,
.portal-role-company .company-learner-stats,
.portal-role-company .company-learner-fields{
  border-right:1px solid #edf3f8;
}
.portal-role-company .company-learner-card__identity{
  display:grid;
  align-content:center;
  gap:8px;
}
.portal-role-company .company-learner-stats{
  display:grid;
  align-content:center;
  grid-template-columns:1fr;
  gap:10px;
  margin:0;
}
.portal-role-company .company-learner-stats div{
  padding:0;
  border:0;
  background:transparent;
}
.portal-role-company .company-learner-fields{
  display:grid;
  align-content:center;
  gap:12px;
}
.portal-role-company .company-learner-actions{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:stretch;
  gap:10px;
}
.portal-role-company .company-record-card{
  display:grid;
  grid-template-columns:minmax(108px,.2fr) minmax(0,1.35fr) minmax(260px,.56fr) minmax(170px,auto);
  align-items:stretch;
  gap:0;
  padding:0;
  overflow:hidden;
}
.portal-role-company .company-record-card__state,
.portal-role-company .company-record-card__identity,
.portal-role-company .company-record-meta,
.portal-role-company .company-record-card__certificate{
  min-width:0;
  padding:18px;
}
.portal-role-company .company-record-card__state{
  display:grid;
  align-content:start;
  justify-items:start;
  gap:10px;
  border-right:1px solid #edf3f8;
  background:#fbfdff;
}
.portal-role-company .company-record-card__identity,
.portal-role-company .company-record-meta{
  border-right:1px solid #edf3f8;
}
.portal-role-company .company-record-card__identity{
  display:grid;
  align-content:center;
  gap:5px;
}
.portal-role-company .company-record-card__identity p,
.portal-role-company .company-record-card__identity h3{
  margin:0;
}
.portal-role-company .company-record-card__identity h3{
  color:var(--learner-ink);
  font-size:18px;
  line-height:1.28;
  overflow-wrap:anywhere;
}
.portal-role-company .company-record-meta{
  display:grid;
  align-content:center;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin:0;
}
.portal-role-company .company-record-meta div{
  display:grid;
  gap:4px;
  min-width:0;
}
.portal-role-company .company-record-meta dt{
  color:var(--learner-muted);
  font-size:12px;
  font-weight:500;
}
.portal-role-company .company-record-meta dd{
  margin:0;
  color:var(--learner-ink);
  font-size:14px;
  font-weight:560;
}
.portal-role-company .company-record-card__certificate{
  display:grid;
  align-content:center;
  justify-items:start;
  gap:8px;
}
.portal-role-company .company-readonly-note{
  margin:-6px 0 2px;
  color:var(--learner-muted);
  font-size:13px;
  line-height:1.45;
}
.portal-role-company .profile-form input[readonly]{
  color:#475569;
  border-color:#e2e8f0;
  background:#f8fafc;
  cursor:default;
}
.portal-role-company .company-help .learner-page-header{
  margin-bottom:18px;
}
@media (max-width: 1180px){
  .portal-role-company .company-purchase-card,
  .portal-role-company .company-purchase-card.learner-invoice-card,
  .portal-role-company .company-learner-card,
  .portal-role-company .company-record-card{
    grid-template-columns:1fr;
  }
  .portal-role-company .company-purchase-card__course,
  .portal-role-company .company-purchase-card__seats,
  .portal-role-company .company-learner-card__state,
  .portal-role-company .company-learner-card__identity,
  .portal-role-company .company-learner-stats,
  .portal-role-company .company-learner-fields,
  .portal-role-company .company-record-card__state,
  .portal-role-company .company-record-card__identity,
  .portal-role-company .company-record-meta{
    border-right:0;
    border-bottom:1px solid #edf3f8;
  }
  .portal-role-company .company-purchase-card__invoice,
  .portal-role-company .company-learner-actions,
  .portal-role-company .company-record-card__certificate{
    align-content:start;
  }
}
@media (max-width: 560px){
  .portal-role-company .company-purchase-metrics,
  .portal-role-company .company-record-meta{
    grid-template-columns:1fr;
  }
  .portal-role-company .company-purchase-card__course,
  .portal-role-company .company-purchase-card__seats,
  .portal-role-company .company-purchase-card__invoice,
  .portal-role-company .company-learner-card__state,
  .portal-role-company .company-learner-card__identity,
  .portal-role-company .company-learner-stats,
  .portal-role-company .company-learner-fields,
  .portal-role-company .company-learner-actions,
  .portal-role-company .company-record-card__state,
  .portal-role-company .company-record-card__identity,
  .portal-role-company .company-record-meta,
  .portal-role-company .company-record-card__certificate{
    padding:16px;
  }
}

/* Marcus refinement repair: soften over-rigid row cards without changing workflows. */
.portal-role-learner .portal-topbar__inner>div:first-of-type,
.portal-role-company .portal-topbar__inner>div:first-of-type{
  display:grid;
  gap:2px;
  align-content:center;
}
.portal-role-learner .portal-role-label,
.portal-role-company .portal-role-label{
  min-height:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  color:var(--learner-muted)!important;
  font-size:12px!important;
  font-weight:520!important;
}
.portal-role-learner .portal-role-label svg,
.portal-role-company .portal-role-label svg{
  width:13px;
  height:13px;
}

.portal-role-learner .learner-card-grid--certificates{
  grid-template-columns:1fr!important;
}
.portal-role-learner .learner-certificate-card{
  grid-template-columns:118px minmax(0,1.35fr) minmax(250px,.6fr) minmax(170px,auto);
  gap:18px;
  align-items:center;
  padding:18px;
}
.portal-role-learner .learner-certificate-card__preview,
.portal-role-learner .learner-certificate-card__body,
.portal-role-learner .learner-certificate-card__details,
.portal-role-learner .learner-certificate-card__actions{
  min-width:0;
  padding:0;
  border:0;
}
.portal-role-learner .learner-certificate-card__preview{
  width:max-content;
  max-width:104px;
  margin:0;
  overflow:visible;
  justify-content:start;
  justify-items:center;
  background:transparent;
}
.portal-role-learner .learner-certificate-card__preview .portal-state-label{
  width:max-content;
  max-width:104px;
  justify-self:center;
  text-align:center;
}
.portal-role-learner .learner-certificate-card__preview .portal-state-label--active{
  color:var(--learner-green);
}
.portal-role-learner .learner-certificate-card__preview .portal-state-label--expiring{
  color:var(--learner-amber);
}
.portal-role-learner .learner-certificate-card__preview .portal-state-label--expired{
  color:var(--learner-red);
}
.portal-role-learner .learner-certificate-card__body{
  align-content:center;
}
.portal-role-learner .learner-certificate-card__details{
  display:grid;
  align-content:center;
  gap:7px;
}
.portal-role-learner .learner-certificate-card__actions{
  justify-content:flex-end;
}
.portal-role-learner .learner-certificate-card h3{
  max-width:100%;
}

.portal-role-learner .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact){
  grid-template-columns:104px minmax(0,1fr) minmax(170px,.32fr) minmax(138px,auto);
  gap:18px;
  align-items:center;
  padding:18px;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__state,
.portal-role-learner .learner-card-grid--list .learner-course-card__body,
.portal-role-learner .learner-card-grid--list .learner-course-card__meta,
.portal-role-learner .learner-card-grid--list .learner-course-card__actions{
  min-width:0;
  padding:0;
  border:0;
  background:transparent;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__state{
  align-content:center;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__body{
  align-content:center;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__meta{
  align-content:center;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__actions{
  justify-content:flex-end;
  align-items:center;
}

.portal-role-learner .learner-invoice-card{
  grid-template-columns:minmax(0,1fr) minmax(230px,.42fr) minmax(190px,auto);
  grid-template-areas:
    "main payment actions"
    "courses payment actions";
  gap:10px 22px;
  align-items:center;
  padding:18px;
}
.portal-role-learner .learner-invoice-card--single-course{
  grid-template-areas:"main payment actions";
}
.portal-role-learner .learner-invoice-card__main,
.portal-role-learner .learner-invoice-card__courses-block,
.portal-role-learner .learner-invoice-card__payment,
.portal-role-learner .learner-invoice-card__actions{
  min-width:0;
  padding:0;
  border:0;
}
.portal-role-learner .learner-invoice-card__main{grid-area:main}
.portal-role-learner .learner-invoice-card__courses-block{grid-area:courses}
.portal-role-learner .learner-invoice-card__payment{grid-area:payment}
.portal-role-learner .learner-invoice-card__actions{
  grid-area:actions;
  justify-content:flex-end;
  align-content:center;
}

.portal-role-company .company-purchase-card.learner-invoice-card{
  grid-template-columns:minmax(0,1.08fr) minmax(300px,.78fr) minmax(220px,.45fr);
  gap:24px;
  padding:18px;
}
.portal-role-company .company-purchase-card__course,
.portal-role-company .company-purchase-card__seats,
.portal-role-company .company-purchase-card__invoice{
  min-width:0;
  padding:0;
  border:0;
}
.portal-role-company .company-purchase-card__heading h3{
  font-size:18px;
}
.portal-role-company .company-purchase-metrics{
  grid-template-columns:1fr;
  gap:7px;
}
.portal-role-company .company-purchase-metrics div{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:14px;
  padding:0 0 7px;
  border:0;
  border-bottom:1px solid #edf3f8;
  border-radius:0;
  background:transparent;
}
.portal-role-company .company-purchase-metrics div:last-child{
  border-bottom:0;
  padding-bottom:0;
}
.portal-role-company .company-purchase-metrics dd{
  font-size:15px;
}

.portal-role-company .company-learner-card{
  grid-template-columns:64px minmax(330px,1fr) minmax(180px,.38fr) minmax(220px,.46fr) minmax(158px,auto);
  gap:18px;
  align-items:center;
  padding:18px;
}
.portal-role-company .company-learner-card__state,
.portal-role-company .company-learner-card__identity,
.portal-role-company .company-learner-stats,
.portal-role-company .company-learner-fields,
.portal-role-company .company-learner-actions{
  min-width:0;
  padding:0;
  border:0;
  background:transparent;
}
.portal-role-company .company-learner-card__title-row{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.portal-role-company .company-learner-card__title-row h3{
  margin:0;
  min-width:0;
}
.portal-role-company .company-learner-card__title-row .status-pill{
  flex:0 0 auto;
}
.portal-role-company .company-learner-actions{
  align-items:stretch;
}

.portal-role-company .company-record-card{
  grid-template-columns:92px minmax(0,1fr) minmax(220px,.4fr) minmax(145px,auto);
  gap:18px;
  align-items:center;
  padding:16px 18px;
}
.portal-role-company .company-record-card__state,
.portal-role-company .company-record-card__identity,
.portal-role-company .company-record-meta,
.portal-role-company .company-record-card__certificate{
  min-width:0;
  padding:0;
  border:0;
  background:transparent;
}
.portal-role-company .company-record-card__state{
  align-content:center;
}
.portal-role-company .company-record-card__identity h3{
  font-size:17px;
}
.portal-role-company .company-record-meta{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.portal-role-company .company-record-card__certificate{
  align-content:center;
}

@media (max-width:1100px){
  .portal-role-learner .learner-certificate-card,
  .portal-role-learner .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact),
  .portal-role-learner .learner-invoice-card,
  .portal-role-company .company-purchase-card.learner-invoice-card,
  .portal-role-company .company-learner-card,
  .portal-role-company .company-record-card{
    grid-template-columns:1fr;
    grid-template-areas:none;
    gap:14px;
  }
  .portal-role-learner .learner-invoice-card__main,
  .portal-role-learner .learner-invoice-card__courses-block,
  .portal-role-learner .learner-invoice-card__payment,
  .portal-role-learner .learner-invoice-card__actions{
    grid-area:auto;
  }
  .portal-role-learner .learner-certificate-card__actions,
  .portal-role-learner .learner-card-grid--list .learner-course-card__actions,
  .portal-role-learner .learner-invoice-card__actions{
    justify-content:flex-start;
  }
  .portal-role-company .company-learner-card__title-row{
    flex-wrap:wrap;
  }
}

/* Purchases/training card repair: grouped scanability without table-like columns. */
.portal-role-learner .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact){
  grid-template-columns:72px minmax(0,1fr) minmax(148px,auto);
  grid-template-areas:
    "state body actions"
    "state meta actions"
    "state helper actions";
  gap:8px 20px;
  align-items:center;
  padding:18px 20px;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__state{
  grid-area:state;
  align-content:center;
  justify-items:start;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__body{
  grid-area:body;
}
.portal-role-learner .learner-course-card__title-line{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px 10px;
  min-width:0;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__top h3{
  max-width:760px;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__message{
  max-width:700px;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__meta{
  grid-area:meta;
  display:flex;
  flex-wrap:wrap;
  gap:8px 18px;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__meta div{
  display:grid;
  gap:2px;
  min-width:120px;
  padding:0;
  border:0;
  background:transparent;
  box-shadow:none;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__helper{
  grid-area:helper;
  margin:2px 0 0;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__actions{
  grid-area:actions;
  display:flex;
  justify-content:flex-end;
  align-items:center;
}

.portal-role-company .company-purchase-card.learner-invoice-card{
  grid-template-columns:minmax(0,1fr) minmax(260px,auto);
  grid-template-areas:
    "course invoice"
    "seats seats";
  gap:16px 24px;
  align-items:start;
  padding:20px;
}
.portal-role-company .company-purchase-card__course{
  grid-area:course;
  gap:12px;
}
.portal-role-company .company-purchase-card__heading h3{
  max-width:780px;
}
.portal-role-company .company-purchase-card__course>.learner-btn{
  width:max-content;
  justify-self:start;
}
.portal-role-company .company-purchase-card__invoice{
  grid-area:invoice;
  align-content:start;
  justify-items:end;
  gap:10px;
  text-align:right;
}
.portal-role-company .company-purchase-card__invoice>strong{
  justify-items:end;
}
.portal-role-company .company-purchase-action-meta{
  justify-items:end;
  gap:6px;
}
.portal-role-company .company-purchase-invoice-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:8px;
}
.portal-role-company .company-purchase-card__seats{
  grid-area:seats;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(240px,.34fr) auto;
  grid-template-areas:
    "metrics progress action"
    "learners progress action";
  align-items:center;
  gap:12px 18px;
  padding-top:16px;
  border-top:1px solid #edf3f8;
}
.portal-role-company .company-purchase-metrics{
  grid-area:metrics;
  display:flex;
  flex-wrap:wrap;
  gap:8px 18px;
}
.portal-role-company .company-purchase-metrics div{
  display:flex;
  align-items:baseline;
  justify-content:flex-start;
  gap:7px;
  padding:0;
  border:0;
  background:transparent;
}
.portal-role-company .company-purchase-metrics dt{
  white-space:nowrap;
}
.portal-role-company .company-purchase-metrics dd{
  font-size:15px;
}
.portal-role-company .company-purchase-progress{
  grid-area:progress;
  min-width:0;
}
.portal-role-company .company-purchase-learners{
  grid-area:learners;
}
.portal-role-company .company-purchase-card__seats>.learner-btn{
  grid-area:action;
  justify-self:end;
  align-self:center;
}

@media (max-width:1100px){
  .portal-role-learner .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact){
    grid-template-columns:1fr;
    grid-template-areas:
      "state"
      "body"
      "meta"
      "helper"
      "actions";
    gap:12px;
  }
  .portal-role-learner .learner-card-grid--list .learner-course-card__state{
    display:flex;
    align-items:center;
    gap:10px;
  }
  .portal-role-learner .learner-card-grid--list .learner-course-card__actions{
    justify-content:flex-start;
  }
  .portal-role-company .company-purchase-card.learner-invoice-card{
    grid-template-columns:1fr;
    grid-template-areas:
      "course"
      "seats"
      "invoice";
    gap:16px;
  }
  .portal-role-company .company-purchase-card__seats{
    grid-template-columns:1fr;
    grid-template-areas:
      "metrics"
      "progress"
      "learners"
      "action";
  }
  .portal-role-company .company-purchase-card__invoice,
  .portal-role-company .company-purchase-card__invoice>strong,
  .portal-role-company .company-purchase-action-meta{
    justify-items:start;
    text-align:left;
  }
  .portal-role-company .company-purchase-invoice-actions{
    justify-content:flex-start;
  }
  .portal-role-company .company-purchase-card__seats>.learner-btn{
    justify-self:start;
  }
}

/* Three-section correction: keep inline sections with clear dividers. */
.portal-role-learner .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact){
  grid-template-columns:72px minmax(0,1fr) minmax(210px,.34fr) minmax(148px,auto);
  grid-template-areas:
    "state body meta actions"
    "state body helper actions";
  gap:0;
  align-items:stretch;
  padding:0;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__state,
.portal-role-learner .learner-card-grid--list .learner-course-card__body,
.portal-role-learner .learner-card-grid--list .learner-course-card__meta,
.portal-role-learner .learner-card-grid--list .learner-course-card__helper,
.portal-role-learner .learner-card-grid--list .learner-course-card__actions{
  padding:18px;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__state{
  padding-right:0;
  background:transparent;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__body{
  display:grid;
  align-content:center;
  padding-left:12px;
  border-right:1px solid #edf3f8;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__meta{
  display:grid;
  align-content:center;
  grid-row:1 / -1;
  grid-template-columns:1fr;
  gap:10px;
  border-right:1px solid #edf3f8;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__meta div{
  min-width:0;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__helper{
  align-content:center;
  margin:0;
  border-right:1px solid #edf3f8;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__actions{
  align-self:stretch;
  justify-content:center;
  align-items:center;
}

.portal-role-company .company-purchase-card.learner-invoice-card{
  grid-template-columns:minmax(0,1.14fr) minmax(300px,.72fr) minmax(260px,.5fr);
  grid-template-areas:"course seats invoice";
  gap:0;
  align-items:stretch;
  padding:0;
}
.portal-role-company .company-purchase-card__course,
.portal-role-company .company-purchase-card__seats,
.portal-role-company .company-purchase-card__invoice{
  padding:18px;
}
.portal-role-company .company-purchase-card__course,
.portal-role-company .company-purchase-card__seats{
  border-right:1px solid #edf3f8;
}
.portal-role-company .company-purchase-card__course{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.portal-role-company .company-purchase-card__course>.learner-btn{
  margin-top:auto;
}
.portal-role-company .company-purchase-card__seats{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.portal-role-company .company-purchase-metrics{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:9px 14px;
}
.portal-role-company .company-purchase-metrics div{
  display:grid;
  gap:3px;
}
.portal-role-company .company-purchase-metrics dt{
  white-space:normal;
}
.portal-role-company .company-purchase-progress{
  margin-top:auto;
}
.portal-role-company .company-purchase-card__seats>.learner-btn{
  justify-self:auto;
  align-self:flex-start;
  margin-top:2px;
}
.portal-role-company .company-purchase-card__invoice{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  justify-content:flex-start;
  text-align:right;
}
.portal-role-company .company-purchase-invoice-actions{
  margin-top:auto;
}

@media (max-width:1100px){
  .portal-role-learner .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact),
  .portal-role-company .company-purchase-card.learner-invoice-card{
    grid-template-columns:1fr;
    grid-template-areas:none;
    gap:0;
  }
  .portal-role-learner .learner-card-grid--list .learner-course-card__state,
  .portal-role-learner .learner-card-grid--list .learner-course-card__body,
  .portal-role-learner .learner-card-grid--list .learner-course-card__meta,
  .portal-role-learner .learner-card-grid--list .learner-course-card__helper,
  .portal-role-company .company-purchase-card__course,
  .portal-role-company .company-purchase-card__seats{
    border-right:0;
    border-bottom:1px solid #edf3f8;
  }
  .portal-role-learner .learner-card-grid--list .learner-course-card__state{
    padding:16px 16px 0;
  }
  .portal-role-learner .learner-card-grid--list .learner-course-card__body{
    padding:12px 16px 16px;
  }
  .portal-role-learner .learner-card-grid--list .learner-course-card__actions,
  .portal-role-company .company-purchase-card__invoice{
    justify-content:flex-start;
    align-items:flex-start;
    text-align:left;
  }
  .portal-role-company .company-purchase-card__invoice,
  .portal-role-company .company-purchase-card__invoice>strong,
  .portal-role-company .company-purchase-action-meta{
    justify-items:start;
  }
  .portal-role-company .company-purchase-invoice-actions{
    justify-content:flex-start;
    margin-top:0;
  }
}

/* Purchases-only: one row made of three separate inner cards. */
.portal-role-company .company-purchase-card.learner-invoice-card{
  grid-template-columns:minmax(0,1.12fr) minmax(300px,.72fr) minmax(260px,.5fr);
  grid-template-areas:"course seats invoice";
  gap:14px;
  align-items:stretch;
  padding:0;
  border:0;
  background:transparent;
  box-shadow:none;
  overflow:visible;
}
.portal-role-company .company-purchase-card.learner-invoice-card:hover{
  border-color:transparent;
  box-shadow:none;
  transform:none;
}
.portal-role-company .company-purchase-card__course,
.portal-role-company .company-purchase-card__seats,
.portal-role-company .company-purchase-card__invoice{
  min-width:0;
  min-height:100%;
  padding:18px;
  border:1px solid #dfe8f0;
  border-radius:12px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.portal-role-company .company-purchase-card__course{
  grid-area:course;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.portal-role-company .company-purchase-card__seats{
  grid-area:seats;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.portal-role-company .company-purchase-card__invoice{
  grid-area:invoice;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  justify-content:flex-start;
  gap:10px;
  text-align:right;
}
.portal-role-company .company-purchase-card__course>.learner-btn{
  width:max-content;
  justify-self:start;
  margin-top:auto;
}
.portal-role-company .company-purchase-card__seats>.learner-btn{
  align-self:flex-start;
  margin-top:2px;
}
.portal-role-company .company-purchase-progress{
  margin-top:auto;
}
.portal-role-company .company-seat-stack{
  display:flex;
  align-items:center;
  min-width:0;
  margin-top:8px;
  padding-left:6px;
}
.portal-role-company .company-seat-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  margin-left:-6px;
  border:2px solid #fff;
  border-radius:999px;
  box-shadow:0 1px 2px rgba(15,23,42,.12);
}
.portal-role-company .company-seat-chip:first-child{
  margin-left:0;
}
.portal-role-company .company-seat-chip--in-use{
  background:#22a06b;
}
.portal-role-company .company-seat-chip--available{
  background:#d7e0e8;
}
.portal-role-company .company-seat-chip--more{
  min-width:30px;
  width:auto;
  padding:0 7px;
  background:#f3f6f9;
  color:#526477;
  font-size:10px;
  font-weight:650;
  line-height:1;
}
.portal-role-company .company-purchase-invoice-actions{
  margin-top:auto;
}

@media (max-width:1100px){
  .portal-role-company .company-purchase-card.learner-invoice-card{
    grid-template-columns:1fr;
    grid-template-areas:
      "course"
      "seats"
      "invoice";
    gap:12px;
  }
  .portal-role-company .company-purchase-card__invoice{
    align-items:flex-start;
    text-align:left;
  }
  .portal-role-company .company-purchase-card__invoice>strong,
  .portal-role-company .company-purchase-action-meta{
    justify-items:start;
  }
  .portal-role-company .company-purchase-invoice-actions{
    justify-content:flex-start;
    margin-top:0;
  }
}

/* Purchases-only alignment pass: consistent inner-card rows. */
.portal-role-company .company-purchase-card__course{
  display:grid;
  grid-template-rows:auto auto minmax(28px,auto) 1fr auto;
  align-content:stretch;
  gap:10px;
}
.portal-role-company .company-purchase-card__heading{
  min-height:54px;
}
.portal-role-company .company-course-summary{
  min-height:30px;
  align-content:start;
}
.portal-role-company .company-included-courses{
  min-height:26px;
}
.portal-role-company .company-purchase-card__course>.learner-btn{
  align-self:end;
  margin-top:0;
}

.portal-role-company .company-purchase-card__seats{
  display:grid;
  grid-template-columns:1fr;
  grid-template-rows:auto minmax(64px,auto) 1fr auto;
  grid-template-areas:none;
  align-content:stretch;
  gap:12px;
}
.portal-role-company .company-purchase-metrics,
.portal-role-company .company-purchase-progress,
.portal-role-company .company-purchase-learners,
.portal-role-company .company-purchase-card__seats>.learner-btn{
  grid-area:auto;
}
.portal-role-company .company-purchase-metrics{
  align-self:start;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px 16px;
}
.portal-role-company .company-purchase-metrics div{
  display:grid;
  grid-template-rows:30px auto;
  align-content:start;
  gap:3px;
}
.portal-role-company .company-purchase-metrics dt{
  display:flex;
  align-items:flex-end;
  min-height:30px;
  color:#66788a;
  font-size:11px;
  line-height:1.18;
}
.portal-role-company .company-purchase-metrics dd{
  color:#102034;
  font-size:16px;
  line-height:1.1;
}
.portal-role-company .company-purchase-progress{
  display:grid;
  align-content:start;
  justify-items:start;
  gap:8px;
  margin-top:0;
}
.portal-role-company .company-purchase-progress>div:first-child{
  display:grid;
  gap:3px;
}
.portal-role-company .company-purchase-learners{
  align-self:end;
  min-height:40px;
}
.portal-role-company .company-purchase-card__seats>.learner-btn{
  align-self:end;
  justify-self:start;
  margin-top:0;
}

.portal-role-company .company-purchase-card__invoice{
  display:grid;
  grid-template-rows:auto auto 1fr auto;
  align-content:stretch;
  justify-items:end;
  gap:10px;
}
.portal-role-company .company-purchase-card__invoice>strong{
  min-height:54px;
  align-content:start;
}
.portal-role-company .company-purchase-action-meta{
  min-height:66px;
  align-content:start;
}
.portal-role-company .company-purchase-invoice-actions{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  justify-content:flex-end;
  gap:8px;
  margin-top:0;
}
.portal-role-company .company-purchase-invoice-actions .learner-btn{
  width:max-content;
}

@media (max-width:1100px){
  .portal-role-company .company-purchase-card__course,
  .portal-role-company .company-purchase-card__seats,
  .portal-role-company .company-purchase-card__invoice{
    display:grid;
    grid-template-rows:auto;
  }
  .portal-role-company .company-purchase-card__heading,
  .portal-role-company .company-course-summary,
  .portal-role-company .company-included-courses,
  .portal-role-company .company-purchase-card__invoice>strong,
  .portal-role-company .company-purchase-action-meta,
  .portal-role-company .company-purchase-learners{
    min-height:0;
  }
  .portal-role-company .company-purchase-invoice-actions{
    align-items:flex-start;
  }
}
/* Final admin QA pass: tighten existing admin rows without changing page structure. */
.portal-role-staff .order-link-card--compact{
  grid-template-columns:minmax(0,1fr) minmax(310px,.4fr);
  gap:14px;
  padding:14px;
}
.portal-role-staff .order-link-card--compact .order-link-card__main{
  gap:12px;
}
.portal-role-staff .order-link-card--compact .order-link-card__header{
  padding-bottom:10px;
}
.portal-role-staff .order-link-card--compact .order-link-card__header strong{
  font-size:19px;
  letter-spacing:0;
}
.portal-role-staff .order-link-card__details--review{
  grid-template-columns:minmax(190px,1.1fr) minmax(150px,.75fr) minmax(230px,1.28fr) minmax(88px,.44fr) minmax(126px,.62fr) minmax(126px,.66fr);
  gap:11px 15px;
  align-items:start;
}
.portal-role-staff .order-link-card--compact .order-link-card__details--review .order-link-card__detail,
.portal-role-staff .support-record-card--compact .support-record-card__body div{
  min-width:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.portal-role-staff .order-link-card__detail--buyer strong,
.portal-role-staff .order-link-card__detail--company strong,
.portal-role-staff .order-link-card__detail--purchase strong{
  overflow:visible;
  text-overflow:clip;
  white-space:normal;
}
.portal-role-staff .order-link-card__detail--paid strong,
.portal-role-staff .order-link-card__detail--total strong{
  font-size:14px;
}
.portal-role-staff .order-link-card__detail--total strong{
  color:var(--admin-blue-dark);
  font-weight:650;
}
.portal-role-staff .order-link-card--compact .order-link-card__action{
  gap:10px;
  align-self:stretch;
  border-color:#e3ecf4;
  background:#f8fbfe;
}
.portal-role-staff .order-link-card--compact .match-callout{
  gap:2px;
}
.portal-role-staff .order-link-card--compact .order-link-form{
  grid-template-columns:minmax(0,1fr) auto;
  align-items:end;
  gap:9px;
}
.portal-role-staff .order-link-card--compact .order-link-form .primary-button:disabled{
  border-color:#d7e0ea;
  background:#edf2f7;
  color:#8291a3;
  cursor:not-allowed;
  opacity:1;
}
.portal-role-staff .order-link-card--compact .order-link-form .primary-button[aria-disabled="true"]{
  box-shadow:none;
}
.portal-role-staff .staff-action-note{
  color:#5f6f82;
  font-size:12px;
  line-height:1.35;
}

.portal-role-staff .provisioning-failure-card .support-meta-grid{
  grid-template-columns:minmax(145px,.8fr) minmax(220px,1.25fr) minmax(170px,.9fr) minmax(170px,.9fr);
  gap:10px;
}
.portal-role-staff .staff-date-value{
  overflow:visible;
  text-overflow:clip;
  white-space:normal;
  line-height:1.3;
}

.portal-role-staff .support-record-card--compact{
  grid-template-columns:minmax(220px,.68fr) minmax(0,1.32fr) auto;
  gap:12px;
  padding:11px 12px;
}
.portal-role-staff .support-record-card--compact .support-record-card__body{
  align-items:start;
  grid-template-columns:minmax(0,1.45fr) minmax(120px,.66fr) minmax(120px,.66fr) minmax(76px,.36fr);
  gap:10px 13px;
}
.portal-role-staff .support-record-card__body--missing-credential{
  grid-template-columns:minmax(0,1.45fr) minmax(120px,.66fr) minmax(120px,.66fr) minmax(58px,.26fr);
}
.portal-role-staff .support-record-card--compact .support-record-card__header strong{
  font-size:15px;
}
.portal-role-staff .support-record-card--compact .support-record-card__body strong{
  font-weight:620;
}

@media (max-width:1180px){
  .portal-role-staff .order-link-card--compact{
    grid-template-columns:1fr;
  }
  .portal-role-staff .order-link-card__details--review,
  .portal-role-staff .provisioning-failure-card .support-meta-grid,
  .portal-role-staff .support-record-card--compact .support-record-card__body,
  .portal-role-staff .support-record-card__body--missing-credential{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:720px){
  .portal-role-staff .order-link-card__details--review,
  .portal-role-staff .provisioning-failure-card .support-meta-grid,
  .portal-role-staff .support-record-card--compact,
  .portal-role-staff .support-record-card--compact .support-record-card__body,
  .portal-role-staff .support-record-card__body--missing-credential,
  .portal-role-staff .order-link-card--compact .order-link-form{
    grid-template-columns:1fr;
  }
  .portal-role-staff .order-link-card--compact .order-link-form .primary-button{
    width:100%;
  }
  .portal-role-staff .support-record-card--compact .support-record-card__header .status-pill{
    grid-column:1;
    grid-row:2;
    justify-self:start;
  }
}

/* Final staff shell parity override. Keep staff workflows, but use the same portal chrome as learner/company. */
.portal-role-staff{
  --admin-ink:#142235;
  --admin-muted:#5f6f82;
  --admin-subtle:#7d8da0;
  --admin-bg:#f5f7fa;
  --admin-panel:#fff;
  --admin-line:#dfe7ee;
  --admin-blue:#176fb5;
  --admin-blue-dark:#0b3354;
  --admin-green:#1f7a50;
  --admin-amber:#a9630c;
  --admin-red:#b42318;
  background:var(--admin-bg);
}
.portal-role-staff .portal-workspace{
  background:linear-gradient(180deg,#f4f8fb 0,#f7f9fb 100%);
}
.portal-role-staff .portal-sidebar{
  padding:0;
  border-right:0;
  background:#092b49;
  color:#dcecff;
  box-shadow:6px 0 18px rgba(6,28,48,.14);
}
.portal-role-staff .portal-brand{
  display:flex;
  align-items:center;
  min-height:72px;
  padding:18px 20px 16px;
  border-bottom:1px solid rgba(255,255,255,.28);
  background:#092b49;
  color:#fff;
}
.portal-role-staff .portal-brand__logo-wrap{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  max-width:210px;
  min-height:auto;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.portal-role-staff .portal-brand__logo--blue{display:none}
.portal-role-staff .portal-brand__logo--light{
  display:block;
  width:100%;
  max-width:196px;
  height:auto;
}
.portal-role-staff .portal-nav-group__label{display:none}
.portal-role-staff .portal-sidebar__nav{
  gap:10px;
  padding:16px 12px;
}
.portal-role-staff .portal-nav-group{gap:8px}
.portal-role-staff .portal-nav-link{
  min-height:48px;
  padding:0 16px;
  border-radius:10px;
  color:#dcecff;
  font-size:14px;
  font-weight:700;
}
.portal-role-staff .portal-nav-link:hover{
  background:rgba(255,255,255,.13);
  color:#fff;
}
.portal-role-staff .portal-nav-link.is-active{
  background:#fff;
  color:#092b49;
  box-shadow:none;
}
.portal-role-staff .portal-nav-link.is-active::before{display:none}
.portal-role-staff .portal-nav-icon{
  width:22px;
  height:22px;
  border-radius:0;
  background:transparent;
  color:inherit;
}
.portal-role-staff .portal-nav-icon svg{
  width:18px;
  height:18px;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-staff .portal-nav-link.is-active .portal-nav-icon{
  background:transparent;
  color:#092b49;
}
.portal-role-staff .portal-sidebar__footer{
  padding:16px;
  border-top:1px solid rgba(255,255,255,.28);
  gap:10px;
}
.portal-role-staff .portal-user-card{
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  padding:12px;
  border-color:rgba(255,255,255,.18);
  border-radius:12px;
  background:rgba(255,255,255,.08);
  box-shadow:none;
}
.portal-role-staff .portal-user-card>span:last-child{min-width:0}
.portal-role-staff .portal-user-card strong{
  color:#fff;
  white-space:normal;
}
.portal-role-staff .portal-user-card small{
  color:rgba(233,245,255,.76);
  white-space:normal;
}
.portal-role-staff .portal-avatar{
  width:38px;
  height:38px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  background:#fff;
  color:#092b49;
  box-shadow:none;
}
.portal-role-staff .portal-sidebar__footer .nav-button{
  border-color:rgba(255,255,255,.14);
  border-radius:10px;
  background:rgba(255,255,255,.08);
  color:#fff;
  box-shadow:none;
}
.portal-role-staff .portal-sidebar__footer .nav-button:hover{
  border-color:rgba(255,255,255,.28);
  background:rgba(255,255,255,.13);
}
.portal-role-staff .portal-topbar{
  min-height:72px;
  border-bottom:1px solid #e1e8ef;
  background:rgba(255,255,255,.94);
  box-shadow:0 1px 2px rgba(15,23,42,.05);
  backdrop-filter:blur(12px);
}
.portal-role-staff .portal-topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:72px;
}
.portal-role-staff .portal-topbar__inner>div:first-of-type{
  display:grid;
  gap:2px;
}
.portal-role-staff .portal-role-label{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:var(--admin-muted)!important;
  font-size:12px;
  line-height:1.2;
}
.portal-role-staff .portal-role-label svg{
  width:13px;
  height:13px;
}
.portal-role-staff .portal-topbar strong{
  margin-top:0;
  color:var(--admin-ink);
  font-size:19px;
  font-weight:650;
  letter-spacing:0;
}
.portal-role-staff .portal-topbar__actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
}
.portal-role-staff .learner-topbar-profile{
  display:grid;
  grid-template-columns:auto auto;
  align-items:center;
  gap:8px;
  min-height:42px;
  padding:4px 10px 4px 4px;
  border:1px solid var(--admin-line);
  border-radius:8px;
  background:#fff;
  color:var(--admin-ink);
  cursor:pointer;
  list-style:none;
}
.portal-role-staff .learner-topbar-profile::-webkit-details-marker{
  display:none;
}
.portal-role-staff .learner-topbar-profile .portal-avatar{
  flex:0 0 32px;
  width:32px;
  height:32px;
  border:0;
  background:#092b49;
  color:#fff;
}
.portal-role-staff .learner-topbar-profile .learner-profile-menu__chevron{
  width:16px;
  height:16px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-staff .learner-profile-menu__panel a svg{
  width:17px;
  height:17px;
  margin-right:9px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.9;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-staff .page-shell{
  width:min(1480px,calc(100% - 64px));
  margin-left:auto;
  margin-right:auto;
}
.portal-role-staff .main-shell{
  padding-top:28px;
}
.portal-role-staff .main-shell--staff-dashboard{
  width:min(1680px,calc(100% - 48px));
}
.portal-role-staff .hero-panel{
  border:1px solid rgba(195,215,234,.82);
  border-radius:8px;
  background:linear-gradient(135deg,#0a4ea7,#0d8fad);
  box-shadow:0 18px 36px rgba(32,78,125,.09);
}
.portal-role-staff .hero-panel--compact{
  min-height:278px;
}
.portal-role-staff .hero-panel .eyebrow,
.portal-role-staff .hero-panel .hero-copy{
  color:#dceeff;
}
.portal-role-staff .hero-panel h1{
  color:#fff;
  font-size:40px;
  font-weight:720;
  letter-spacing:0;
}
.portal-role-staff .hero-actions{
  margin-top:22px;
}
.portal-role-staff .hero-panel .secondary-button{
  min-height:42px;
  border-color:rgba(255,255,255,.25);
  background:rgba(255,255,255,.12);
  color:#fff;
}
.portal-role-staff .hero-panel .secondary-button:hover{
  background:rgba(255,255,255,.18);
  box-shadow:0 4px 12px rgba(7,35,61,.13);
}
.portal-role-staff .status-card{
  border:1px solid rgba(255,255,255,.18);
  border-radius:8px;
  background:rgba(255,255,255,.13);
  color:#fff;
  box-shadow:none;
}
.portal-role-staff .status-card__label,
.portal-role-staff .status-card small{
  color:#dceeff;
}
.portal-role-staff .status-card strong{
  color:#fff;
}

/* Staff portal shell parity: admin pages should feel like the same product as learner/company. */
.portal-role-staff{
  --admin-ink:#142235;
  --admin-muted:#5f6f82;
  --admin-subtle:#7d8da0;
  --admin-bg:#f5f7fa;
  --admin-panel:#fff;
  --admin-line:#dfe7ee;
  --admin-blue:#176fb5;
  --admin-blue-dark:#0b3354;
  --admin-green:#1f7a50;
  --admin-amber:#a9630c;
  --admin-red:#b42318;
  background:var(--admin-bg);
}
.portal-role-staff .portal-workspace{
  background:linear-gradient(180deg,#f4f8fb 0,#f7f9fb 100%);
}
.portal-role-staff .portal-app-shell{
  grid-template-columns:288px minmax(0,1fr);
}
.portal-role-staff .portal-sidebar{
  padding:0;
  border-right:0;
  background:#092b49;
  color:#dcecff;
  box-shadow:6px 0 18px rgba(6,28,48,.14);
}
.portal-role-staff .portal-brand{
  display:flex;
  align-items:center;
  min-height:72px;
  padding:18px 20px 16px;
  border-bottom:1px solid rgba(255,255,255,.28);
  color:#fff;
}
.portal-role-staff .portal-brand__logo-wrap{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  max-width:210px;
  min-height:auto;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.portal-role-staff .portal-brand__logo--blue{display:none}
.portal-role-staff .portal-brand__logo--light{
  display:block;
  width:100%;
  max-width:196px;
  height:auto;
}
.portal-role-staff .portal-nav-group__label{display:none}
.portal-role-staff .portal-sidebar__nav{
  gap:10px;
  padding:16px 12px;
}
.portal-role-staff .portal-nav-group{gap:8px}
.portal-role-staff .portal-nav-link{
  min-height:48px;
  padding:0 16px;
  border-radius:10px;
  color:#dcecff;
  font-size:14px;
  font-weight:700;
}
.portal-role-staff .portal-nav-link:hover{
  background:rgba(255,255,255,.13);
  color:#fff;
}
.portal-role-staff .portal-nav-link.is-active{
  background:#fff;
  color:#092b49;
  box-shadow:none;
}
.portal-role-staff .portal-nav-link.is-active::before{display:none}
.portal-role-staff .portal-nav-icon{
  width:22px;
  height:22px;
  border-radius:0;
  background:transparent;
  color:inherit;
}
.portal-role-staff .portal-nav-icon svg{
  width:18px;
  height:18px;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-staff .portal-nav-link.is-active .portal-nav-icon{
  background:transparent;
  color:#092b49;
}
.portal-role-staff .portal-sidebar__footer{
  padding:16px;
  border-top:1px solid rgba(255,255,255,.28);
  gap:10px;
}
.portal-role-staff .portal-user-card{
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  padding:12px;
  border-color:rgba(255,255,255,.18);
  border-radius:12px;
  background:rgba(255,255,255,.08);
  box-shadow:none;
}
.portal-role-staff .portal-user-card>span:last-child{min-width:0}
.portal-role-staff .portal-user-card strong{
  color:#fff;
  white-space:normal;
}
.portal-role-staff .portal-user-card small{
  color:rgba(233,245,255,.76);
  white-space:normal;
}
.portal-role-staff .portal-avatar{
  width:38px;
  height:38px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  background:#fff;
  color:#092b49;
  box-shadow:none;
}
.portal-role-staff .portal-sidebar__footer .nav-button{
  border-color:rgba(255,255,255,.14);
  border-radius:10px;
  background:rgba(255,255,255,.08);
  color:#fff;
  box-shadow:none;
}
.portal-role-staff .portal-sidebar__footer .nav-button:hover{
  border-color:rgba(255,255,255,.28);
  background:rgba(255,255,255,.13);
}
.portal-role-staff .portal-topbar{
  min-height:72px;
  border-bottom:1px solid #e1e8ef;
  background:rgba(255,255,255,.94);
  box-shadow:0 1px 2px rgba(15,23,42,.05);
  backdrop-filter:blur(12px);
}
.portal-role-staff .portal-topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:72px;
}
.portal-role-staff .portal-topbar__inner>div:first-of-type{
  display:grid;
  gap:2px;
}
.portal-role-staff .portal-role-label{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:var(--admin-muted)!important;
  font-size:12px;
  line-height:1.2;
}
.portal-role-staff .portal-role-label svg{
  width:13px;
  height:13px;
}
.portal-role-staff .portal-topbar strong{
  margin-top:0;
  color:var(--admin-ink);
  font-size:19px;
  font-weight:650;
  letter-spacing:0;
}
.portal-role-staff .portal-topbar__actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
}
.portal-role-staff .page-shell{
  width:min(1480px,calc(100% - 64px));
  margin-left:auto;
  margin-right:auto;
}
.portal-role-staff .main-shell--staff-dashboard{
  width:min(1680px,calc(100% - 48px));
}
.portal-role-staff .main-shell{
  padding-top:28px;
}
.portal-role-staff .hero-panel{
  border:1px solid rgba(195,215,234,.82);
  border-radius:8px;
  background:linear-gradient(135deg,#0a4ea7,#0d8fad);
  box-shadow:0 18px 36px rgba(32,78,125,.09);
}
.portal-role-staff .hero-panel--compact{
  min-height:278px;
}
.portal-role-staff .hero-panel .eyebrow,
.portal-role-staff .hero-panel .hero-copy{
  color:#dceeff;
}
.portal-role-staff .hero-panel h1{
  color:#fff;
  font-size:40px;
  font-weight:720;
  letter-spacing:0;
}
.portal-role-staff .hero-actions{
  margin-top:22px;
}
.portal-role-staff .hero-panel .secondary-button{
  min-height:42px;
  border-color:rgba(255,255,255,.25);
  background:rgba(255,255,255,.12);
  color:#fff;
}
.portal-role-staff .hero-panel .secondary-button:hover{
  background:rgba(255,255,255,.18);
  box-shadow:0 4px 12px rgba(7,35,61,.13);
}
.portal-role-staff .status-card{
  border:1px solid rgba(255,255,255,.18);
  border-radius:8px;
  background:rgba(255,255,255,.13);
  color:#fff;
  box-shadow:none;
}
.portal-role-staff .status-card__label,
.portal-role-staff .status-card small{
  color:#dceeff;
}
.portal-role-staff .status-card strong{
  color:#fff;
}

/* Staff/admin row repair: keep dense admin data scannable without nested box-heavy cells. */
.portal-role-staff .order-link-card--compact{
  gap:10px;
  padding:11px 12px;
}
.portal-role-staff .order-link-card--compact .order-link-card__main{
  gap:10px;
}
.portal-role-staff .order-link-card--compact .order-link-card__details{
  align-items:start;
  padding:0;
}
.portal-role-staff .order-link-card--compact .order-link-card__details div,
.portal-role-staff .support-record-card--compact .support-record-card__body div{
  min-width:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.portal-role-staff .order-link-card--compact .order-link-card__details span,
.portal-role-staff .support-record-card--compact .support-record-card__body span{
  margin-bottom:3px;
}
.portal-role-staff .order-link-card--compact .order-link-card__action{
  border-color:#e5eef6;
  background:#f8fbfe;
}
.portal-role-staff .support-record-card--compact{
  grid-template-columns:minmax(210px,.62fr) minmax(0,1.48fr) auto;
  gap:14px;
  padding:11px 13px;
}
.portal-role-staff .support-record-card--compact .support-record-card__body{
  align-items:start;
  grid-template-columns:minmax(0,1.55fr) minmax(96px,.62fr) minmax(96px,.62fr) minmax(82px,.45fr);
  gap:10px 14px;
}
.portal-role-staff .support-record-card__body--missing-credential{
  grid-template-columns:minmax(0,1.55fr) minmax(96px,.62fr) minmax(96px,.62fr) minmax(56px,.28fr);
}

/* Staff/admin final polish: align internal admin with the current portal visual system. */
.portal-role-staff{
  --admin-ink:#102034;
  --admin-muted:#5f6f82;
  --admin-subtle:#7d8da0;
  --admin-line:#dfe8f0;
  --admin-soft:#f8fbfd;
  --admin-panel:#fff;
  --admin-blue:#176fb5;
  --admin-blue-dark:#0b3354;
  --admin-green:#1f7a50;
  --admin-amber:#a9630c;
  --admin-red:#b42318;
}
.portal-role-staff .portal-topbar__inner>div:first-of-type{
  display:grid;
  align-content:center;
  gap:2px;
}
.portal-role-staff .portal-role-label{
  min-height:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  color:var(--admin-muted)!important;
  font-size:12px!important;
  font-weight:520!important;
}
.portal-role-staff .portal-role-label svg{
  width:13px;
  height:13px;
}
.portal-role-label--staff{
  color:var(--admin-blue-dark)!important;
}
.portal-role-staff .portal-topbar strong{
  margin-top:1px;
  color:var(--admin-ink);
  font-size:19px;
  font-weight:650;
}
.portal-role-staff .main-shell{
  padding-top:30px;
}
.portal-role-staff .hero-panel{
  grid-template-columns:minmax(0,1fr) minmax(260px,320px);
  gap:22px;
  min-height:246px;
  margin-bottom:18px;
  padding:32px;
  border:0;
  border-radius:18px;
  background:linear-gradient(135deg,#0b3354 0,#176fb5 62%,#0d93ad 100%);
  color:#fff;
  box-shadow:0 18px 38px -26px rgba(7,31,51,.42);
}
.portal-role-staff .hero-panel h1{
  color:#fff;
  font-size:42px;
  line-height:1.08;
  font-weight:700;
  letter-spacing:0;
}
.portal-role-staff .hero-panel .eyebrow,
.portal-role-staff .hero-panel .hero-copy{
  color:#dceeff;
}
.portal-role-staff .hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.portal-role-staff .hero-panel .secondary-button{
  border-color:rgba(255,255,255,.28);
  background:rgba(255,255,255,.13);
  color:#fff;
}
.portal-role-staff .hero-panel .secondary-button:hover{
  border-color:rgba(255,255,255,.42);
  background:rgba(255,255,255,.2);
  color:#fff;
}
.portal-role-staff .status-card{
  display:grid;
  align-content:center;
  gap:8px;
  min-height:0;
  padding:22px;
  border:1px solid rgba(255,255,255,.22);
  border-radius:16px;
  background:rgba(255,255,255,.13);
  color:#fff;
  box-shadow:none;
}
.portal-role-staff .status-card__label,
.portal-role-staff .status-card small{
  color:#dceeff;
  font-size:13px;
  line-height:1.35;
  text-transform:none;
}
.portal-role-staff .status-card strong{
  color:#fff;
  font-size:26px;
  line-height:1.15;
}
.portal-role-staff .metric-grid,
.portal-role-staff .setup-summary-grid{
  gap:12px;
  margin-bottom:18px;
}
.portal-role-staff .metric-grid{
  grid-template-columns:repeat(6,minmax(0,1fr));
}
.portal-role-staff .metric-card,
.portal-role-staff .setup-summary-card{
  display:grid;
  align-content:start;
  min-height:92px;
  padding:14px 16px;
  border:1px solid var(--admin-line);
  border-radius:12px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.045);
}
.portal-role-staff .metric-card:hover,
.portal-role-staff .metric-card--link:hover,
.portal-role-staff .setup-summary-card:hover{
  border-color:#d1deea;
  box-shadow:0 5px 16px rgba(15,35,55,.055);
  transform:none;
}
.portal-role-staff .metric-card span,
.portal-role-staff .setup-summary-card span{
  margin-top:7px;
  color:#6b7d90;
  font-size:11px;
  font-weight:500;
  line-height:1.2;
  letter-spacing:0;
  text-transform:none;
}
.portal-role-staff .metric-card strong,
.portal-role-staff .setup-summary-card strong{
  order:-1;
  margin-top:0;
  color:var(--admin-ink);
  font-size:24px;
  font-weight:650;
  line-height:1;
  letter-spacing:0;
}
.portal-role-staff .panel,
.portal-role-staff .order-link-card,
.portal-role-staff .provisioning-failure-card,
.portal-role-staff .provisioning-job-card,
.portal-role-staff .support-record-card,
.portal-role-staff .audit-event-card,
.portal-role-staff .schema-table-row,
.portal-role-staff .seat-card,
.portal-role-staff .staff-readiness-card,
.portal-role-staff .staff-detail-card,
.portal-role-staff .staff-order-preview-card{
  border:1px solid var(--admin-line);
  border-radius:14px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.045);
}
.portal-role-staff .panel{
  padding:22px;
}
.portal-role-staff .panel-heading{
  align-items:flex-start;
  gap:14px;
  margin-bottom:16px;
}
.portal-role-staff .panel-heading h2{
  color:var(--admin-ink);
  font-size:23px;
  font-weight:650;
  line-height:1.2;
  letter-spacing:0;
}
.portal-role-staff .panel-count{
  min-height:28px;
  border:0;
  border-radius:999px;
  background:#eef4f8;
  color:var(--admin-muted);
  font-size:12px;
  font-weight:500;
}
.portal-role-staff .page-heading{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:end;
  gap:20px;
  margin-bottom:18px;
  padding:4px 0 8px;
}
.portal-role-staff .page-heading h1{
  margin:0;
  color:var(--admin-ink);
  font-size:34px;
  line-height:1.05;
  font-weight:700;
  letter-spacing:0;
}
.portal-role-staff .page-heading .hero-copy{
  max-width:760px;
  margin-top:9px;
  color:var(--admin-muted);
  font-size:15px;
  line-height:1.55;
}
.portal-role-staff .page-actions,
.portal-role-staff .staff-panel-heading-actions,
.portal-role-staff .provisioning-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
}
.portal-role-staff .primary-button,
.portal-role-staff .secondary-button,
.portal-role-staff .small-button,
.portal-role-staff .nav-button{
  min-height:40px;
  border-radius:10px;
  font-size:14px;
  font-weight:600;
  letter-spacing:0;
  box-shadow:none;
}
.portal-role-staff .primary-button,
.portal-role-staff .small-button{
  border-color:var(--admin-blue-dark);
  background:var(--admin-blue-dark);
  color:#fff;
}
.portal-role-staff .primary-button:hover,
.portal-role-staff .small-button:hover{
  border-color:#092b49;
  background:#092b49;
  box-shadow:none;
}
.portal-role-staff .secondary-button,
.portal-role-staff .nav-button{
  border-color:#d9e4ec;
  background:#fff;
  color:#14324a;
}
.portal-role-staff .secondary-button:hover,
.portal-role-staff .nav-button:hover{
  border-color:#b9cbd9;
  background:#f7fafc;
  color:var(--admin-blue-dark);
  box-shadow:none;
}
.portal-role-staff .staff-panel-toolbar{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  align-items:start;
}
.portal-role-staff .staff-filter-row{
  display:flex;
  align-items:flex-end;
  flex-wrap:wrap;
  gap:10px;
  width:100%;
  justify-content:flex-start;
}
.portal-role-staff .staff-filter-row--grid{
  display:grid;
  grid-template-columns:minmax(250px,1.3fr) repeat(4,minmax(150px,.65fr));
}
.portal-role-staff .staff-search-field{
  width:100%;
}
.portal-role-staff .student-search-field,
.portal-role-staff .staff-filter-select select{
  height:42px;
  border:1px solid var(--admin-line);
  border-radius:12px;
  background-color:#fff;
  box-shadow:none;
}
.portal-role-staff .staff-filter-select{
  display:grid;
  gap:6px;
  min-width:0;
}
.portal-role-staff .staff-filter-select span{
  color:#6b7d90;
  font-size:12px;
  font-weight:500;
  line-height:1.2;
}
.portal-role-staff .staff-filter-select select{
  width:100%;
  padding:0 34px 0 12px;
  color:var(--admin-ink);
  font:inherit;
  font-size:14px;
  font-weight:500;
}
.portal-role-staff .data-table{
  display:grid;
  gap:8px;
  overflow:visible;
  border:0;
  border-radius:0;
  background:transparent;
}
.portal-role-staff .data-table__row{
  min-height:58px;
  padding:12px 14px;
  border:1px solid var(--admin-line);
  border-radius:12px;
  background:#fff;
}
.portal-role-staff .data-table__row:nth-child(even):not(.data-table__row--head){
  background:#fff;
}
.portal-role-staff .data-table__row--head{
  min-height:32px;
  padding:0 14px 2px;
  border:0;
  border-radius:0;
  background:transparent;
  color:#6b7d90;
  font-size:11px;
  font-weight:600;
}
.portal-role-staff .data-table__row--link:hover{
  border-color:#cfdce8;
  background:#fff;
  box-shadow:0 5px 16px rgba(15,35,55,.055);
}
.portal-role-staff .data-table__row strong{
  color:var(--admin-ink);
  font-weight:600;
}
.portal-role-staff .data-table__row small{
  color:#6b7d90;
}
.staff-order-preview-list{
  display:grid;
  gap:10px;
}
.staff-order-preview-card{
  display:grid;
  grid-template-columns:minmax(110px,.65fr) minmax(0,1.25fr) minmax(0,1fr) minmax(130px,.55fr);
  align-items:center;
  gap:14px;
  min-height:78px;
  padding:13px 14px;
}
.staff-order-preview-card span{
  display:block;
  color:#6b7d90;
  font-size:11px;
  line-height:1.2;
}
.staff-order-preview-card strong{
  display:block;
  min-width:0;
  overflow:hidden;
  color:var(--admin-ink);
  font-size:13px;
  font-weight:600;
  line-height:1.25;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.staff-order-preview-card small{
  display:block;
  min-width:0;
  margin-top:3px;
  overflow:hidden;
  color:#6b7d90;
  font-size:12px;
  line-height:1.25;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.staff-order-preview-card__main strong{
  font-size:15px;
}
.staff-order-preview-card__amount{
  text-align:right;
}
.staff-order-preview-card__amount strong{
  font-size:14px;
}
.staff-dashboard-hero .status-card small{
  line-height:1.4;
}
.staff-dashboard-grid{
  margin-bottom:18px;
}
.staff-dashboard-lower-grid{
  grid-template-columns:minmax(0,1.15fr) minmax(360px,.85fr);
}
.staff-dashboard-panel-copy{
  max-width:680px;
  margin:6px 0 0;
  color:#6b7d90;
  font-size:13px;
  line-height:1.45;
}
.staff-dashboard-readiness-list{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.staff-dashboard-readiness-list .staff-readiness-card{
  min-height:112px;
  align-items:start;
}
.staff-admin-tool-list{
  display:grid;
  gap:10px;
}
.staff-admin-tool-card{
  display:grid;
  gap:5px;
  padding:14px;
  border:1px solid #e3ecf3;
  border-radius:12px;
  background:#f9fcfe;
  color:var(--admin-ink);
  text-decoration:none;
}
.staff-admin-tool-card:hover,
.staff-admin-tool-card:focus-visible{
  border-color:#cbdbe8;
  background:#fff;
  box-shadow:0 5px 16px rgba(15,35,55,.055);
  outline:0;
}
.staff-admin-tool-card strong{
  color:var(--admin-ink);
  font-size:14px;
  font-weight:650;
  line-height:1.2;
}
.staff-admin-tool-card span{
  color:#6b7d90;
  font-size:13px;
  line-height:1.42;
}
.staff-admin-tool-card--review{
  border-color:#f2dfbb;
  background:#fffdf8;
}
.staff-order-preview-list--compact{
  gap:8px;
}
.staff-dashboard-audit-list{
  display:grid;
  gap:8px;
}
.staff-dashboard-audit-list article{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:12px;
  min-height:58px;
  padding:11px 12px;
  border:1px solid #e8eff6;
  border-radius:12px;
  background:#f9fcfe;
}
.staff-dashboard-audit-list strong,
.staff-dashboard-audit-list span{
  display:block;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.staff-dashboard-audit-list strong{
  color:var(--admin-ink);
  font-size:13px;
  font-weight:650;
}
.staff-dashboard-audit-list span,
.staff-dashboard-audit-list time{
  color:#6b7d90;
  font-size:12px;
  line-height:1.25;
}
.staff-dashboard-audit-list time{
  white-space:nowrap;
}
.portal-role-staff .staff-readiness-list,
.portal-role-staff .order-link-list,
.portal-role-staff .provisioning-failure-list,
.portal-role-staff .provisioning-job-list,
.portal-role-staff .support-record-list,
.portal-role-staff .audit-event-list,
.portal-role-staff .schema-table-list,
.portal-role-staff .seat-list{
  gap:10px;
}
.portal-role-staff .staff-seat-group-list{
  display:grid;
  gap:12px;
}
.portal-role-staff .staff-seat-group{
  display:grid;
  gap:0;
  overflow:hidden;
  border:1px solid var(--admin-line);
  border-radius:14px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.045);
}
.portal-role-staff .staff-seat-group__header{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
  gap:16px;
  padding:16px 16px 14px;
  border-bottom:1px solid #edf2f7;
}
.portal-role-staff .staff-seat-group__header h3{
  margin:3px 0 0;
  color:var(--admin-ink);
  font-size:18px;
  font-weight:650;
  line-height:1.25;
}
.portal-role-staff .staff-seat-group__header small{
  display:block;
  margin-top:5px;
  color:#6b7d90;
  font-size:12px;
  line-height:1.25;
}
.portal-role-staff .staff-section-label{
  color:#6b7d90;
  font-size:11px;
  font-weight:580;
  line-height:1.2;
  text-transform:none;
}
.portal-role-staff .staff-seat-group__stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(70px,1fr));
  gap:8px;
  min-width:330px;
}
.portal-role-staff .staff-seat-group__stats span{
  display:grid;
  gap:4px;
  justify-items:start;
  min-height:54px;
  padding:9px 10px;
  border:1px solid #edf2f7;
  border-radius:11px;
  background:#f8fbfd;
}
.portal-role-staff .staff-seat-group__stats span.is-warning{
  border-color:#f3d1c8;
  background:#fff7f6;
}
.portal-role-staff .staff-seat-group__stats b{
  color:var(--admin-ink);
  font-size:18px;
  font-weight:650;
  line-height:1;
}
.portal-role-staff .staff-seat-group__stats small{
  margin:0;
  color:#6b7d90;
  font-size:11px;
  line-height:1.1;
}
.portal-role-staff .staff-seat-group__body{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(310px,.72fr);
  gap:14px;
  align-items:start;
  padding:14px 16px 16px;
}
.portal-role-staff .staff-seat-group__section{
  display:grid;
  gap:10px;
  min-width:0;
  padding:13px;
  border:1px solid #edf2f7;
  border-radius:12px;
  background:#fbfdff;
}
.portal-role-staff .staff-seat-group__section--issues{
  grid-column:1 / -1;
  background:#fffafa;
}
.portal-role-staff .staff-seat-group__section-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.portal-role-staff .staff-seat-group__section-header strong{
  color:var(--admin-ink);
  font-size:14px;
  font-weight:650;
  line-height:1.2;
}
.portal-role-staff .staff-seat-group__section-header span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:28px;
  min-height:24px;
  padding:0 8px;
  border-radius:999px;
  background:#edf4fb;
  color:#31536e;
  font-size:12px;
  font-weight:600;
}
.portal-role-staff .staff-seat-learner-list{
  display:grid;
  gap:8px;
  max-height:288px;
  overflow:auto;
  padding-right:2px;
}
.portal-role-staff .staff-seat-learner-row{
  display:grid;
  grid-template-columns:36px minmax(0,1fr) auto minmax(92px,.35fr);
  align-items:center;
  gap:10px;
  min-height:54px;
  padding:8px 9px;
  border:1px solid #edf2f7;
  border-radius:10px;
  background:#fff;
}
.portal-role-staff .staff-seat-learner-row__avatar{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border:1px solid #cfe3f4;
  border-radius:999px;
  background:#eef7fd;
  color:#0b5c8d;
  font-size:11px;
  font-weight:700;
  line-height:1;
}
.portal-role-staff .staff-seat-learner-row__identity,
.portal-role-staff .staff-seat-learner-row__meta{
  min-width:0;
}
.portal-role-staff .staff-seat-learner-row__identity strong,
.portal-role-staff .staff-seat-issue-row strong{
  display:block;
  min-width:0;
  overflow:hidden;
  color:var(--admin-ink);
  font-size:13px;
  font-weight:620;
  line-height:1.25;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-staff .staff-seat-learner-row__identity small,
.portal-role-staff .staff-seat-issue-row small{
  display:block;
  min-width:0;
  margin-top:2px;
  overflow:hidden;
  color:#6b7d90;
  font-size:12px;
  line-height:1.25;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-staff .staff-seat-learner-row__meta span{
  display:block;
  color:#6b7d90;
  font-size:11px;
  line-height:1.2;
}
.portal-role-staff .staff-seat-learner-row__meta strong{
  display:block;
  margin-top:2px;
  color:var(--admin-ink);
  font-size:12px;
  font-weight:600;
  line-height:1.2;
}
.portal-role-staff .staff-seat-assignment-form{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  padding-top:0;
  border-top:0;
}
.portal-role-staff .staff-seat-assignment-form .primary-button{
  grid-column:1 / -1;
  width:100%;
}
.portal-role-staff .staff-seat-group__note{
  margin:0;
  color:#6b7d90;
  font-size:12px;
  line-height:1.45;
}
.portal-role-staff .staff-seat-empty{
  min-height:44px;
  padding:12px;
  border:1px dashed #d7e2ec;
  border-radius:10px;
  background:#fff;
  color:#718196;
  font-size:13px;
  line-height:1.4;
}
.portal-role-staff .staff-seat-issue-list{
  display:grid;
  gap:8px;
}
.portal-role-staff .staff-seat-issue-row{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:start;
  gap:10px;
  padding:9px;
  border:1px solid #f2d8d4;
  border-radius:10px;
  background:#fff;
}
@media (max-width:1120px){
  .portal-role-staff .staff-seat-group__header,
  .portal-role-staff .staff-seat-group__body{
    grid-template-columns:1fr;
  }
  .portal-role-staff .staff-seat-group__stats{
    min-width:0;
    width:100%;
  }
}
@media (max-width:760px){
  .portal-role-staff .staff-seat-group__stats{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .portal-role-staff .staff-seat-learner-row{
    grid-template-columns:36px minmax(0,1fr);
  }
  .portal-role-staff .staff-seat-learner-row .status-pill,
  .portal-role-staff .staff-seat-learner-row__meta{
    grid-column:2;
    justify-self:start;
  }
  .portal-role-staff .staff-seat-assignment-form{
    grid-template-columns:1fr;
  }
}
.portal-role-staff .staff-readiness-card{
  align-items:center;
  min-height:78px;
  padding:14px;
}
.portal-role-staff .staff-readiness-card.is-warning{
  border-color:#f0d7aa;
  background:#fffdf8;
}
.portal-role-staff .staff-readiness-card strong{
  color:var(--admin-ink);
  font-weight:650;
}
.portal-role-staff .staff-readiness-card span{
  color:var(--admin-muted);
}
.portal-role-staff .order-link-card,
.portal-role-staff .provisioning-failure-card,
.portal-role-staff .support-record-card,
.portal-role-staff .provisioning-job-card{
  padding:16px;
}
.portal-role-staff .order-link-card__header,
.portal-role-staff .provisioning-failure-card__header{
  border-bottom-color:#edf3f8;
}
.portal-role-staff .order-link-card__details div,
.portal-role-staff .support-meta-grid div,
.portal-role-staff .support-record-card__body div{
  border:1px solid #e8eff6;
  border-radius:12px;
  background:#f9fcfe;
}
.portal-role-staff .status-pill{
  border:0;
  border-radius:999px;
  font-weight:500;
}
.portal-role-staff .status-pill--completed,
.portal-role-staff .status-pill--paid{
  background:#eaf7f0;
  color:var(--admin-green);
}
.portal-role-staff .status-pill--queued,
.portal-role-staff .status-pill--assigned,
.portal-role-staff .status-pill--in-progress{
  background:#eaf4fb;
  color:var(--admin-blue);
}
.portal-role-staff .status-pill--needs-review,
.portal-role-staff .status-pill--unassigned{
  background:#fff4df;
  color:var(--admin-amber);
}
.portal-role-staff .status-pill--failed{
  background:#fff0ef;
  color:var(--admin-red);
}
.portal-role-staff .staff-tabs-shell{
  display:grid;
  gap:16px;
}
.portal-role-staff .staff-tabs{
  padding:6px;
  border:1px solid var(--admin-line);
  border-radius:14px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.045);
}
.portal-role-staff .staff-tabs button{
  border-radius:10px;
  font-weight:600;
}
.portal-role-staff .staff-tabs button.is-active{
  background:var(--admin-blue-dark);
  color:#fff;
}

@media (max-width:1280px){
  .portal-role-staff .metric-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .portal-role-staff .staff-filter-row--grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:820px){
  .portal-role-staff .hero-panel,
  .portal-role-staff .page-heading,
  .staff-order-preview-card{
    grid-template-columns:1fr;
  }
  .portal-role-staff .content-grid,
  .portal-role-staff .content-grid--wide,
  .portal-role-staff .panel{
    width:100%;
    max-width:100%;
    min-width:0;
  }
  .staff-dashboard-lower-grid,
  .staff-dashboard-readiness-list,
  .staff-dashboard-audit-list article{
    grid-template-columns:1fr;
  }
  .staff-dashboard-audit-list time{
    white-space:normal;
  }
  .portal-role-staff .data-table,
  .portal-role-staff .data-table__row{
    width:100%;
    max-width:100%;
    min-width:0;
  }
  .portal-role-staff .data-table__row:not(.data-table__row--head){
    grid-template-columns:1fr;
  }
  .portal-role-staff .metric-grid,
  .portal-role-staff .setup-summary-grid,
  .portal-role-staff .staff-filter-row--grid{
    grid-template-columns:1fr;
  }
  .staff-order-preview-card__amount{
    text-align:left;
  }
}

/* Company learners final row-card polish. */
.portal-role-company .learner-roster-list{
  gap:12px;
}
.portal-role-company .company-learner-card.learner-course-card{
  display:grid;
  grid-template-columns:72px minmax(260px,1fr) 340px 380px minmax(156px,auto);
  align-items:stretch;
  gap:12px;
  padding:14px 16px;
  border:1px solid #dfe8f0;
  border-radius:14px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.045);
  overflow:visible;
}
.portal-role-company .company-learner-card.learner-course-card:hover{
  border-color:#cfdce8;
  background:#fff;
  box-shadow:0 5px 16px rgba(15,35,55,.055);
  transform:none;
}
.portal-role-company .company-learner-card__state,
.portal-role-company .company-learner-card__identity,
.portal-role-company .company-learner-stats,
.portal-role-company .company-learner-fields,
.portal-role-company .company-learner-actions{
  min-width:0;
  padding:0;
  border:0;
  background:transparent;
}
.portal-role-company .company-learner-card__state{
  align-content:center;
}
.portal-role-company .company-learner-card__identity{
  display:grid;
  align-content:center;
  gap:8px;
}
.portal-role-company .learner-roster-card__person p{
  margin:0 0 4px;
  color:#6b7d90;
  font-size:11px;
  font-weight:600;
  line-height:1.1;
  letter-spacing:0;
  text-transform:none;
}
.portal-role-company .learner-roster-card__person h3{
  margin:0;
  color:#102034;
  font-size:18px;
  font-weight:650;
  line-height:1.22;
}
.portal-role-company .learner-roster-card__person span{
  display:block;
  margin-top:4px;
  overflow:hidden;
  color:#5f6f82;
  font-size:13px;
  line-height:1.35;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-company .company-learner-issue{
  max-width:480px;
  margin:0;
  color:#5f6f82;
  font-size:13px;
  line-height:1.45;
}
.portal-role-company .company-learner-stats{
  display:grid;
  grid-template-columns:minmax(62px,.65fr) minmax(78px,.75fr) minmax(118px,1.25fr);
  align-content:center;
  gap:10px;
  box-sizing:border-box;
  margin:0;
  min-height:92px;
  padding:12px 14px;
  border:1px solid #e5edf4;
  border-radius:12px;
  background:#f9fcfe;
}
.portal-role-company .company-learner-stats div{
  display:grid;
  align-content:center;
  gap:4px;
  min-width:0;
  padding:0;
  border:0;
  background:transparent;
}
.portal-role-company .company-learner-stats dt{
  overflow:hidden;
  color:#6b7d90;
  font-size:11px;
  line-height:1.2;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-company .company-learner-stats dd{
  margin:0;
  overflow:hidden;
  color:#102034;
  font-size:14px;
  font-weight:620;
  line-height:1.2;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-company .company-learner-fields{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  align-content:center;
  gap:10px;
  box-sizing:border-box;
  min-height:68px;
  padding:12px;
  border:1px solid #e5edf4;
  border-radius:12px;
  background:#f9fcfe;
}
.portal-role-company .company-learner-fields .field{
  min-width:0;
}
.portal-role-company .company-learner-fields .field span{
  margin-bottom:5px;
  color:#6b7d90;
  font-size:11px;
}
.portal-role-company .company-learner-fields select{
  height:38px;
  border-color:#d9e4ec;
  border-radius:10px;
  background-color:#fff;
  font-size:13px;
}
.portal-role-company .company-learner-actions{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:stretch;
  gap:8px;
  min-width:156px;
}
.portal-role-company .company-learner-actions .learner-btn{
  width:100%;
  justify-content:center;
  white-space:nowrap;
}

@media (max-width:1280px){
  .portal-role-company .company-learner-card.learner-course-card{
    grid-template-columns:72px minmax(280px,1fr) minmax(330px,.85fr) minmax(156px,auto);
  }
  .portal-role-company .company-learner-fields{
    grid-column:2 / -1;
  }
}

@media (max-width:1100px){
  .portal-role-company .company-learner-card.learner-course-card{
    grid-template-columns:1fr;
    gap:14px;
    padding:16px;
  }
  .portal-role-company .company-learner-card__state{
    width:auto;
    max-width:none;
    justify-items:start;
    text-align:left;
  }
  .portal-role-company .company-learner-stats,
  .portal-role-company .company-learner-fields{
    grid-template-columns:1fr;
    grid-column:auto;
  }
  .portal-role-company .company-learner-actions{
    align-items:flex-start;
    min-width:0;
  }
  .portal-role-company .company-learner-actions .learner-btn{
    width:auto;
  }
}

/* Learner billing final row treatment. */
.portal-role-learner .learner-billing .learner-invoice-card{
  display:grid;
  grid-template-columns:72px minmax(0,1fr) minmax(250px,.38fr) minmax(165px,.22fr) minmax(180px,auto);
  grid-template-areas:"state main dates payment actions";
  align-items:center;
  gap:18px 12px;
  min-height:124px;
  padding:18px;
  transition:border-color .14s ease, box-shadow .14s ease, background-color .14s ease;
}
.portal-role-learner .learner-billing .learner-invoice-card:hover{
  border-color:#d8e5ee;
  background:#fff;
  box-shadow:0 6px 16px rgba(15,35,55,.055);
}
.portal-role-learner .learner-billing .learner-invoice-card--has-courses{
  grid-template-columns:72px minmax(0,1fr) minmax(250px,.38fr) minmax(165px,.22fr) minmax(180px,auto);
  grid-template-areas:
    "state main dates payment actions"
    ". courses courses courses .";
  row-gap:10px;
}
.portal-role-learner .learner-billing .learner-invoice-card__state{
  grid-area:state;
  align-content:center;
  justify-items:center;
  width:72px;
  max-width:72px;
  padding:0;
  border:0;
  background:transparent;
}
.portal-role-learner .learner-billing .learner-invoice-card__state .portal-state-label{
  width:72px;
  max-width:72px;
  text-align:center;
}
.portal-role-learner .learner-billing .learner-invoice-card__main{
  grid-area:main;
  display:grid;
  align-content:center;
  gap:5px;
  min-width:0;
  padding:0;
  border:0;
}
.portal-role-learner .learner-billing .learner-invoice-card__top{
  display:block;
}
.portal-role-learner .learner-billing .learner-invoice-card__meta-line{
  min-width:0;
}
.portal-role-learner .learner-billing .learner-invoice-card__number{
  color:var(--learner-muted);
  font-size:12px;
  line-height:1.2;
}
.portal-role-learner .learner-billing .learner-invoice-card h3{
  max-width:720px;
  margin:0;
  overflow:hidden;
  color:var(--learner-ink);
  font-size:17px;
  line-height:1.3;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle{
  grid-area:courses;
  display:block;
  width:min(100%,460px);
  max-width:100%;
  margin:0;
  padding:0;
  border:1px solid #e5edf4;
  border-radius:10px;
  background:#f9fcfe;
  overflow:hidden;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  box-sizing:border-box;
  width:100%;
  min-height:44px;
  margin:0;
  padding:9px 11px;
  color:inherit;
  cursor:pointer;
  font:inherit;
  text-align:left;
  list-style:none;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle summary::-webkit-details-marker{
  display:none;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle summary span{
  display:grid;
  gap:2px;
  min-width:0;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle summary small{
  color:#6b7d90;
  font-size:11px;
  line-height:1.2;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle summary strong{
  min-width:0;
  overflow:hidden;
  color:#102034;
  font-size:13px;
  font-weight:650;
  line-height:1.2;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle summary em{
  flex:0 0 auto;
  color:#176fb5;
  font-size:12px;
  font-style:normal;
  font-weight:650;
  line-height:1;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle summary:hover{
  background:#fff;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle[open] summary{
  border-bottom:1px solid #e8f0f6;
  background:#fff;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle[open] summary em{
  font-size:0;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-toggle[open] summary em::after{
  content:"Hide";
  font-size:12px;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel{
  display:block;
  width:100%;
  max-width:460px;
  min-width:0;
  max-height:none;
  margin:0;
  padding:0;
  border:0;
  background:transparent;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul{
  display:block;
  max-height:184px;
  margin:0;
  padding:5px 9px;
  overflow-y:auto;
  overscroll-behavior:contain;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  scrollbar-width:thin;
  scrollbar-color:#bdcad7 #f4f8fb;
  -ms-overflow-style:auto;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul::-webkit-scrollbar{
  width:8px;
  height:8px;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul::-webkit-scrollbar-button,
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul::-webkit-scrollbar-button:single-button,
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul::-webkit-scrollbar-button:vertical:decrement,
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul::-webkit-scrollbar-button:vertical:increment,
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul::-webkit-scrollbar-button:vertical:start,
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul::-webkit-scrollbar-button:vertical:end{
  display:none!important;
  width:0!important;
  height:0!important;
  min-width:0!important;
  min-height:0!important;
  border:0!important;
  background:transparent!important;
  -webkit-appearance:none!important;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul::-webkit-scrollbar-track{
  margin:6px 0;
  border-radius:999px;
  background:#f4f8fb;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul::-webkit-scrollbar-thumb{
  border:3px solid #f4f8fb;
  border-radius:999px;
  background:#bdcad7;
  background-clip:padding-box;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel ul::-webkit-scrollbar-thumb:hover{
  background:#94a8ba;
  background-clip:padding-box;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel li{
  display:grid;
  align-content:center;
  overflow:hidden;
  min-height:42px;
  padding:7px 6px;
  border:0;
  border-bottom:1px solid #edf3f8;
  border-radius:0;
  background:transparent;
  color:#27384b;
  font-size:13px;
  line-height:1.25;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel li strong{
  min-width:0;
  overflow:hidden;
  color:#102034;
  font-size:13px;
  font-weight:650;
  line-height:1.2;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel li+li{
  border-top:0;
}
.portal-role-learner .learner-billing .learner-invoice-card__courses-panel li:last-child{
  border-bottom:0;
}
.portal-role-learner .learner-billing .learner-invoice-card__payment{
  grid-area:payment;
  display:grid;
  align-content:center;
  justify-items:start;
  gap:5px;
  min-width:0;
  padding:0;
  border:0;
}
.portal-role-learner .learner-billing .learner-invoice-card__payment-label{
  color:var(--learner-subtle);
  font-size:11px;
  line-height:1.2;
}
.portal-role-learner .learner-billing .learner-invoice-card__payment strong{
  color:var(--learner-ink);
  font-size:18px;
  line-height:1.15;
  white-space:nowrap;
}
.portal-role-learner .learner-billing .learner-invoice-card__dates{
  grid-area:dates;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  align-content:center;
  gap:6px 14px;
  min-width:0;
  padding:0;
  border:0;
}
.portal-role-learner .learner-billing .learner-invoice-card__dates span{
  display:grid;
  gap:2px;
  min-width:0;
}
.portal-role-learner .learner-billing .learner-invoice-card__dates small{
  color:var(--learner-subtle);
  font-size:11px;
  line-height:1.1;
}
.portal-role-learner .learner-billing .learner-invoice-card__dates em{
  overflow:hidden;
  color:var(--learner-muted);
  font-size:12px;
  font-style:normal;
  line-height:1.2;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-learner .learner-billing .learner-invoice-card__actions{
  grid-area:actions;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  justify-content:center;
  gap:8px;
  min-width:0;
  padding:0;
  border:0;
}

@media (max-width:1100px){
  .portal-role-learner .learner-billing .learner-invoice-card{
    grid-template-columns:72px minmax(0,1fr);
    grid-template-areas:
      "state main"
      "dates dates"
      "payment payment"
      "actions actions";
    align-items:start;
  }
  .portal-role-learner .learner-billing .learner-invoice-card__actions{
    align-items:flex-start;
  }
  .portal-role-learner .learner-billing .learner-invoice-card--has-courses{
    grid-template-areas:
      "state main"
      "courses courses"
      "dates dates"
      "payment payment"
      "actions actions";
  }
}

@media (max-width:640px){
  .portal-role-learner .learner-billing .learner-invoice-card{
    grid-template-columns:1fr;
    grid-template-areas:
      "state"
      "main"
      "dates"
      "payment"
      "actions";
  }
  .portal-role-learner .learner-billing .learner-invoice-card__state{
    width:auto;
    max-width:none;
    justify-items:start;
  }
  .portal-role-learner .learner-billing .learner-invoice-card__state .portal-state-label{
    width:auto;
    max-width:none;
    text-align:left;
  }
  .portal-role-learner .learner-billing .learner-invoice-card--has-courses{
    grid-template-areas:
      "state"
      "main"
      "courses"
      "dates"
      "payment"
      "actions";
  }
}

/* Learner training statuses: keep each row status visually distinct. */
.portal-role-learner .learner-training .learner-icon-badge--cyan{
  background:#e6f8fb;
  color:var(--learner-cyan);
}
.portal-role-learner .learner-training .learner-icon-badge--rose{
  background:#fff0f6;
  color:#be185d;
}
.portal-role-learner .learner-training .portal-state-label--completed{color:var(--learner-green)}
.portal-role-learner .learner-training .portal-state-label--ready{color:var(--learner-blue)}
.portal-role-learner .learner-training .portal-state-label--in-progress{color:var(--learner-blue)}
.portal-role-learner .learner-training .portal-state-label--access-pending{color:var(--learner-purple)}
.portal-role-learner .learner-training .portal-state-label--expired{color:var(--learner-amber)}
.portal-role-learner .learner-training .portal-state-label--access-issue{color:var(--learner-red)}
.portal-role-learner .learner-training .portal-state-label--not-passed{color:#be185d}
.portal-role-learner .learner-training .learner-course-card__icon{
  display:flex;
  justify-content:center;
  width:46px;
}
.portal-role-learner .learner-training .portal-state-label{
  display:block;
  width:max-content;
  max-width:72px;
  justify-self:center;
  text-align:center;
}
/* Final purchase-row seat metric cleanup. */
.portal-role-company .company-purchase-metrics{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.portal-role-company .company-purchase-card__seats{
  grid-template-rows:auto minmax(48px,auto) auto auto;
}

/* Purchases row cleanup: tighter course section, clearer seats progress. */
.portal-role-company .company-purchase-card__course{
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:9px;
}
.portal-role-company .company-purchase-card__heading{
  grid-template-columns:72px minmax(0,1fr);
  align-items:center;
  gap:16px;
  min-height:0;
}
.portal-role-company .company-purchase-card__icon{
  display:grid;
  place-items:center;
  width:46px;
}
.portal-role-company .company-purchase-card__icon .learner-icon-badge{
  width:46px;
  height:46px;
  border-radius:12px;
}
.portal-role-company .company-purchase-card__icon .learner-icon-badge svg{
  width:22px;
  height:22px;
}
.portal-role-company .company-purchase-card__heading .learner-invoice-card__meta-line{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:7px;
}
.portal-role-company .company-purchase-card__heading .status-pill{
  min-height:22px;
  padding-inline:8px;
  font-size:11px;
}
.portal-role-company .company-purchase-card__links{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px 14px;
  min-height:0;
}
.portal-role-company .company-purchase-card__links .company-included-courses{
  min-height:0;
}
.portal-role-company .company-purchase-card__links .learner-btn{
  margin:0;
}
.portal-role-company .company-purchase-card__seats{
  grid-template-rows:auto minmax(54px,auto) auto auto;
  gap:10px;
}
.portal-role-company .company-purchase-metrics{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.portal-role-company .company-purchase-progress{
  gap:7px;
}
.portal-role-company .company-purchase-progress>div:first-child{
  display:block;
}
.portal-role-company .company-seat-progressbar{
  width:100%;
  height:7px;
  overflow:hidden;
  border-radius:999px;
  background:#e7eef5;
  box-shadow:inset 0 0 0 1px rgba(13,47,78,.04);
}
.portal-role-company .company-seat-progressbar span{
  display:block;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,#22a06b 0%,#168a5c 100%);
}
.portal-role-company .company-purchase-invoice-actions{
  align-items:center;
  gap:8px 10px;
}
.portal-role-company .company-purchase-invoice-actions .learner-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

/* Learner courses: keep row layout without internal column borders. */
.portal-role-learner .learner-card-grid--list .learner-course-card__state,
.portal-role-learner .learner-card-grid--list .learner-course-card__body,
.portal-role-learner .learner-card-grid--list .learner-course-card__meta,
.portal-role-learner .learner-card-grid--list .learner-course-card__helper,
.portal-role-learner .learner-card-grid--list .learner-course-card__actions{
  border:0;
  background:transparent;
}

/* Company training records: icon and status should read as one compact unit. */
.portal-role-learner .learner-course-card__state,
.portal-role-learner .learner-invoice-card__state,
.portal-role-company .company-learner-card__state,
.portal-role-company .company-record-card__state,
.portal-role-company .company-assignment-card__state,
.portal-role-company .company-purchase-card__state,
.portal-role-company .company-training-card__state{
  display:grid;
  align-content:center;
  justify-items:center;
  gap:9px;
  width:72px;
  max-width:72px;
  text-align:center;
}
.portal-role-learner .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact){
  column-gap:16px;
}
.portal-role-learner .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact){
  grid-template-areas:
    "state body meta actions"
    "state helper meta actions";
}
.portal-role-learner .learner-card-grid--list .learner-course-card__state{grid-area:state}
.portal-role-learner .learner-card-grid--list .learner-course-card__body{grid-area:body}
.portal-role-learner .learner-card-grid--list .learner-course-card__meta{
  grid-area:meta;
  grid-row:1 / -1;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__helper{
  grid-area:helper;
  max-width:700px;
  padding-top:0;
}
.portal-role-learner .learner-card-grid--list .learner-course-card__actions{grid-area:actions}

.portal-role-learner .learner-training .learner-course-card__state{
  width:90px;
  max-width:90px;
  padding:0 0 0 18px;
  justify-items:start;
}
.portal-role-learner .learner-training .learner-course-card__icon{
  width:72px;
  justify-content:center;
}
.portal-role-learner .learner-training .portal-state-label{
  width:72px;
  max-width:72px;
  justify-self:start;
  text-align:center;
}
.portal-role-learner .learner-training .learner-course-card__actions{
  justify-content:center;
  align-items:flex-end;
}

@media (min-width:1101px){
  .portal-role-learner .learner-training .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact){
    grid-template-columns:90px minmax(0,1fr) minmax(420px,.8fr) 197px;
    grid-template-areas:"state body meta actions";
    min-height:154px;
  }
  .portal-role-learner .learner-training .learner-card-grid--list .learner-course-card__body{
    align-content:center;
    gap:6px;
  }
  .portal-role-learner .learner-training .learner-card-grid--list .learner-course-card__meta{
    grid-area:meta;
    grid-row:auto;
    display:grid;
    grid-template-columns:repeat(4,minmax(74px,1fr));
    align-content:center;
    align-items:center;
    gap:8px 12px;
  }
  .portal-role-learner .learner-training .learner-card-grid--list .learner-course-card__meta div{
    min-width:0;
  }
  .portal-role-learner .learner-training .learner-course-card__meta-item{
    grid-area:auto;
  }
  .portal-role-learner .learner-training .learner-card-grid--list .learner-course-card__helper{
    grid-area:auto;
    max-width:720px;
    margin:2px 0 0;
    padding:0;
  }
}
.portal-role-learner .learner-dashboard .learner-course-card--compact{
  grid-template-columns:72px minmax(0,1fr);
  column-gap:16px;
}
.portal-role-learner .learner-dashboard .learner-course-card--compact .learner-course-card__state{
  justify-items:center;
}
.portal-role-learner .learner-dashboard .learner-course-card--compact .learner-course-card__actions{
  grid-column:2;
  align-items:flex-start;
  align-self:start;
}
.portal-role-company .company-learner-card{
  grid-template-columns:72px minmax(0,1.1fr) minmax(180px,.42fr) minmax(220px,.55fr) minmax(180px,auto);
  column-gap:20px;
}
.portal-role-company .company-record-card{
  column-gap:20px;
}
.portal-role-company .company-assignment-card,
.portal-role-company .company-training-card{
  grid-template-columns:72px minmax(0,1fr) auto;
  column-gap:20px;
}
.portal-role-learner .learner-invoice-card__top{
  column-gap:16px;
}
@media (max-width:1100px){
  .portal-role-company .company-learner-card,
  .portal-role-company .company-assignment-card,
  .portal-role-company .company-training-card{
    grid-template-columns:1fr;
  }
  .portal-role-learner .learner-dashboard .learner-course-card--compact{
    grid-template-columns:1fr;
  }
}
.portal-role-learner .learner-course-card__state .learner-icon-badge,
.portal-role-learner .learner-invoice-card__state .learner-icon-badge,
.portal-role-company .company-learner-card__state .learner-icon-badge,
.portal-role-company .company-record-card__state .learner-icon-badge,
.portal-role-company .company-assignment-card__state .learner-icon-badge,
.portal-role-company .company-purchase-card__state .learner-icon-badge,
.portal-role-company .company-training-card__state .learner-icon-badge{
  width:46px;
  height:46px;
  border-radius:12px;
}
.portal-role-learner .learner-course-card__state .learner-icon-badge svg,
.portal-role-learner .learner-invoice-card__state .learner-icon-badge svg,
.portal-role-company .company-learner-card__state .learner-icon-badge svg,
.portal-role-company .company-record-card__state .learner-icon-badge svg,
.portal-role-company .company-assignment-card__state .learner-icon-badge svg,
.portal-role-company .company-purchase-card__state .learner-icon-badge svg,
.portal-role-company .company-training-card__state .learner-icon-badge svg{
  width:22px;
  height:22px;
}
.portal-role-company .company-training-card .learner-course-card__top p{
  margin:5px 0 0;
  color:#27384b;
  font-size:13px;
  font-weight:560;
  line-height:1.25;
  letter-spacing:0;
  text-transform:none;
}
.portal-role-company .company-training-card .learner-course-card__body{
  gap:4px;
}
.portal-role-company .company-training-card .learner-course-card__message{
  margin-top:0;
  color:#7d8da0;
  font-size:12px;
  line-height:1.35;
}
.portal-state-label{
  display:block;
  width:100%;
  color:var(--learner-muted);
  font-size:12px;
  font-weight:620;
  line-height:1.2;
  white-space:normal;
}
.portal-state-label--completed,
.portal-state-label--paid,
.portal-state-label--ok,
.portal-state-label--ready,
.portal-state-label--available,
.portal-state-label--full{
  color:var(--learner-green);
}
.portal-state-label--active,
.portal-state-label--in-progress,
.portal-state-label--assigned{
  color:var(--learner-blue);
}
.portal-state-label--access-pending,
.portal-state-label--pending,
.portal-state-label--waiting,
.portal-state-label--queued,
.portal-state-label--provisioning,
.portal-state-label--processing{
  color:var(--learner-purple);
}
.portal-state-label--due,
.portal-state-label--expiring,
.portal-state-label--unassigned{
  color:var(--learner-amber);
}
.portal-state-label--expired,
.portal-state-label--not-passed,
.portal-state-label--access-issue,
.portal-state-label--attention,
.portal-state-label--failed,
.portal-state-label--error{
  color:var(--learner-red);
}
.portal-role-learner .portal-state-label--ready{
  color:var(--learner-blue);
}
.portal-role-company .company-record-card__state{
  display:grid;
  align-content:center;
  justify-items:center;
  gap:9px;
  width:72px;
  max-width:72px;
  text-align:center;
}
.portal-role-company .company-record-card__state .learner-icon-badge{
  width:46px;
  height:46px;
  border-radius:12px;
}
.portal-role-company .company-record-card__state .learner-icon-badge svg{
  width:22px;
  height:22px;
}
.portal-role-company .company-record-card__state .status-pill{
  display:block;
  width:100%;
  min-width:0;
  min-height:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  font-size:12px;
  font-weight:620;
  line-height:1.2;
  white-space:normal;
}
.portal-role-company .company-record-card__state .status-pill--completed{color:var(--learner-green)}
.portal-role-company .company-record-card__state .status-pill--failed{color:var(--learner-red)}
.portal-role-company .company-record-card__state .status-pill--in-progress{color:var(--learner-blue)}
.portal-role-company .company-record-card__state .status-pill--queued{color:var(--learner-purple)}

/* Final icon/status unit treatment: match certificate rows with unboxed SVGs and colored labels. */
.portal-role-learner .learner-icon-badge svg,
.portal-role-company .learner-icon-badge svg{
  stroke-width:3;
  stroke-linecap:round;
  stroke-linejoin:round;
  vector-effect:non-scaling-stroke;
}
.portal-role-learner .learner-course-card__state,
.portal-role-learner .learner-invoice-card__state,
.portal-role-company .company-learner-card__state,
.portal-role-company .company-record-card__state,
.portal-role-company .company-assignment-card__state,
.portal-role-company .company-purchase-card__state,
.portal-role-company .company-training-card__state{
  gap:7px;
}
.portal-role-learner .learner-course-card__state .learner-icon-badge,
.portal-role-learner .learner-invoice-card__state .learner-icon-badge,
.portal-role-company .company-learner-card__state .learner-icon-badge,
.portal-role-company .company-record-card__state .learner-icon-badge,
.portal-role-company .company-assignment-card__state .learner-icon-badge,
.portal-role-company .company-purchase-card__state .learner-icon-badge,
.portal-role-company .company-training-card__state .learner-icon-badge{
  width:54px;
  height:46px;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
}
.portal-role-learner .learner-course-card__state .learner-icon-badge svg,
.portal-role-learner .learner-invoice-card__state .learner-icon-badge svg,
.portal-role-company .company-learner-card__state .learner-icon-badge svg,
.portal-role-company .company-record-card__state .learner-icon-badge svg,
.portal-role-company .company-assignment-card__state .learner-icon-badge svg,
.portal-role-company .company-purchase-card__state .learner-icon-badge svg,
.portal-role-company .company-training-card__state .learner-icon-badge svg{
  width:42px;
  height:42px;
  stroke-width:3;
  stroke-linecap:round;
  stroke-linejoin:round;
  filter:drop-shadow(0 1px 0 rgba(15,35,55,.06));
  vector-effect:non-scaling-stroke;
}
.portal-role-learner .learner-invoice-card__state .learner-icon-badge{
  width:58px;
  height:60px;
}
.portal-role-learner .learner-invoice-card__state .learner-icon-badge svg{
  width:48px;
  height:60px;
}
.portal-role-learner .learner-course-card__state .learner-icon-badge--icon-online-course,
.portal-role-learner .learner-course-card__state .learner-icon-badge--icon-in-person-course,
.portal-role-company .company-record-card__state .learner-icon-badge--icon-online-course,
.portal-role-company .company-record-card__state .learner-icon-badge--icon-in-person-course,
.portal-role-company .company-assignment-card__state .learner-icon-badge--icon-online-course,
.portal-role-company .company-assignment-card__state .learner-icon-badge--icon-in-person-course,
.portal-role-company .company-training-card__state .learner-icon-badge--icon-online-course,
.portal-role-company .company-training-card__state .learner-icon-badge--icon-in-person-course{
  width:58px;
  height:54px;
}
.portal-role-learner .learner-course-card__state .learner-icon-badge--icon-online-course svg,
.portal-role-learner .learner-course-card__state .learner-icon-badge--icon-in-person-course svg,
.portal-role-company .company-record-card__state .learner-icon-badge--icon-online-course svg,
.portal-role-company .company-record-card__state .learner-icon-badge--icon-in-person-course svg,
.portal-role-company .company-assignment-card__state .learner-icon-badge--icon-online-course svg,
.portal-role-company .company-assignment-card__state .learner-icon-badge--icon-in-person-course svg,
.portal-role-company .company-training-card__state .learner-icon-badge--icon-online-course svg,
.portal-role-company .company-training-card__state .learner-icon-badge--icon-in-person-course svg{
  width:50px;
  height:50px;
}
.portal-role-learner .learner-course-card__state .portal-state-label,
.portal-role-learner .learner-invoice-card__state .portal-state-label,
.portal-role-company .company-learner-card__state .portal-state-label,
.portal-role-company .company-record-card__state .portal-state-label,
.portal-role-company .company-assignment-card__state .portal-state-label,
.portal-role-company .company-purchase-card__state .portal-state-label,
.portal-role-company .company-training-card__state .portal-state-label{
  width:max-content;
  max-width:86px;
  justify-self:center;
  text-align:center;
}

/* Learner training rows: bind the icon and status label into one soft status unit. */
.portal-role-learner .learner-training .learner-card-grid--list .learner-course-card__state{
  --training-state-bg:rgba(23,111,181,.075);
  --training-state-border:rgba(23,111,181,.15);
  display:grid;
  align-self:center;
  justify-self:center;
  align-content:center;
  justify-items:center;
  gap:6px;
  box-sizing:border-box;
  width:76px;
  max-width:76px;
  min-height:92px;
  height:auto;
  padding:10px 9px;
  border-radius:16px;
  background:var(--training-state-bg);
  box-shadow:inset 0 0 0 1px var(--training-state-border);
}
.portal-role-learner .learner-training .learner-course-card--completed .learner-course-card__state{
  --training-state-bg:rgba(31,122,80,.085);
  --training-state-border:rgba(31,122,80,.17);
}
.portal-role-learner .learner-training .learner-course-card--ready .learner-course-card__state,
.portal-role-learner .learner-training .learner-course-card--in-progress .learner-course-card__state{
  --training-state-bg:rgba(23,111,181,.085);
  --training-state-border:rgba(23,111,181,.17);
}
.portal-role-learner .learner-training .learner-course-card--access-pending .learner-course-card__state{
  --training-state-bg:rgba(98,82,164,.085);
  --training-state-border:rgba(98,82,164,.17);
}
.portal-role-learner .learner-training .learner-course-card--expired .learner-course-card__state{
  --training-state-bg:rgba(169,99,12,.085);
  --training-state-border:rgba(169,99,12,.17);
}
.portal-role-learner .learner-training .learner-course-card--access-issue .learner-course-card__state{
  --training-state-bg:rgba(180,35,24,.085);
  --training-state-border:rgba(180,35,24,.17);
}
.portal-role-learner .learner-training .learner-course-card--not-passed .learner-course-card__state{
  --training-state-bg:rgba(190,24,93,.085);
  --training-state-border:rgba(190,24,93,.17);
}
.portal-role-learner .learner-training .learner-course-card__state .portal-state-label{
  width:100%;
  max-width:58px;
  justify-self:center;
  text-align:center;
}
.portal-role-learner .learner-training .learner-course-card__state .learner-course-card__icon{
  display:flex;
  justify-content:center;
  width:100%;
}

@media (min-width:1101px){
  .portal-role-learner .learner-training .learner-card-grid--list .learner-course-card:not(.learner-course-card--compact){
    grid-template-columns:92px minmax(0,1fr) minmax(380px,.46fr) 210px;
  }
}

.portal-role-learner .learner-training .learner-card-grid--list .learner-course-card__meta{
  align-content:center;
  justify-content:start;
  grid-template-columns:repeat(4,minmax(74px,1fr));
  gap:8px 14px;
}
.portal-role-learner .learner-training .learner-card-grid--list .learner-course-card__meta-item{
  display:grid;
  align-content:start;
  gap:3px;
  min-width:max-content;
}
.portal-role-learner .learner-training .learner-card-grid--list .learner-course-card__meta dt,
.portal-role-learner .learner-training .learner-card-grid--list .learner-course-card__meta dd{
  white-space:nowrap;
}
.portal-role-learner .learner-training .learner-course-card__actions .learner-btn{
  white-space:nowrap;
}

@media (max-width:1100px){
  .portal-role-learner .learner-training .learner-card-grid--list .learner-course-card__state{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    justify-self:start;
    width:max-content;
    max-width:100%;
    min-height:0;
    padding:8px 12px;
    border-radius:14px;
  }
  .portal-role-learner .learner-training .learner-course-card__state .learner-course-card__icon{
    width:auto;
  }
  .portal-role-learner .learner-training .learner-course-card__state .portal-state-label{
    max-width:none;
    text-align:left;
  }
}

/* Dashboard icon treatment: large unboxed object icons for quick/action/update cards. */
.portal-role-learner .learner-dashboard .learner-quick-card,
.portal-role-company .learner-dashboard .learner-quick-card,
.portal-role-instructor .learner-dashboard .learner-quick-card{
  grid-template-columns:62px minmax(0,1fr) auto;
}
.portal-role-learner .learner-dashboard .learner-quick-card .learner-icon-badge,
.portal-role-company .learner-dashboard .learner-quick-card .learner-icon-badge,
.portal-role-instructor .learner-dashboard .learner-quick-card .learner-icon-badge,
.portal-role-learner .learner-update-list .learner-icon-badge,
.portal-role-company .learner-update-list .learner-icon-badge,
.portal-role-instructor .learner-update-list .learner-icon-badge,
.portal-role-learner .learner-action-required .learner-action-item .learner-icon-badge,
.portal-role-company .learner-action-required .learner-action-item .learner-icon-badge,
.portal-role-instructor .learner-action-required .learner-action-item .learner-icon-badge,
.portal-role-company .company-action-required .learner-action-item .learner-icon-badge{
  width:58px;
  height:54px;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
}
.portal-role-learner .learner-dashboard .learner-quick-card .learner-icon-badge svg,
.portal-role-company .learner-dashboard .learner-quick-card .learner-icon-badge svg,
.portal-role-instructor .learner-dashboard .learner-quick-card .learner-icon-badge svg,
.portal-role-learner .learner-update-list .learner-icon-badge svg,
.portal-role-company .learner-update-list .learner-icon-badge svg,
.portal-role-instructor .learner-update-list .learner-icon-badge svg,
.portal-role-learner .learner-action-required .learner-action-item .learner-icon-badge svg,
.portal-role-company .learner-action-required .learner-action-item .learner-icon-badge svg,
.portal-role-instructor .learner-action-required .learner-action-item .learner-icon-badge svg,
.portal-role-company .company-action-required .learner-action-item .learner-icon-badge svg{
  width:50px!important;
  height:50px!important;
  filter:drop-shadow(0 1px 0 rgba(15,35,55,.06));
}
.portal-role-learner .learner-update-list article,
.portal-role-company .learner-update-list article{
  grid-template-columns:58px minmax(0,1fr) auto;
  align-items:center;
}
.portal-role-learner .learner-dashboard__side .learner-action-required--rail .learner-action-item,
.portal-role-company .learner-dashboard__side .learner-action-required--rail .learner-action-item,
.portal-role-company .learner-dashboard__side .company-action-required .learner-action-item{
  grid-template-columns:58px minmax(0,1fr);
}
.portal-role-company .company-selected-purchase{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  width:max-content;
  max-width:100%;
  margin-top:10px;
  padding:9px 10px;
  border:1px solid #dfe8f0;
  border-radius:10px;
  background:#f8fbfd;
  color:var(--learner-muted);
  font-size:13px;
  line-height:1.35;
}
.portal-role-company .company-selected-purchase span{
  color:var(--learner-subtle);
}
.portal-role-company .company-selected-purchase strong{
  color:var(--learner-ink);
  font-weight:650;
}
.portal-role-company .company-selected-purchase small{
  color:var(--learner-muted);
}
.portal-role-company .company-selected-purchase a{
  color:var(--learner-blue);
  font-weight:600;
  text-decoration:none;
}
.portal-role-company .company-selected-purchase a:hover{
  text-decoration:underline;
}

/* Purchases final row treatment: one unified card with three labeled sections. */
.portal-role-company .company-purchase-card.learner-invoice-card{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  grid-template-areas:"course seats invoice";
  gap:12px;
  align-items:stretch;
  padding:12px;
  border:1px solid #dfe8f0;
  border-radius:14px;
  background:#f8fbfd;
  box-shadow:0 1px 2px rgba(15,23,42,.045);
  overflow:visible;
}
.portal-role-company .company-purchase-card.learner-invoice-card:hover{
  border-color:#cfdce8;
  box-shadow:0 5px 16px rgba(15,35,55,.065);
  transform:none;
}
.portal-role-company .company-purchase-card__course,
.portal-role-company .company-purchase-card__seats,
.portal-role-company .company-purchase-card__invoice{
  min-width:0;
  min-height:0;
  padding:15px;
  border:1px solid #e4ecf3;
  border-radius:11px;
  background:#fff;
  box-shadow:none;
}
.portal-role-company .company-purchase-card__seats,
.portal-role-company .company-purchase-card__invoice{
  border-left:1px solid #e4ecf3;
}
.portal-role-company .company-purchase-section-label{
  display:block;
  margin:0 0 8px;
  color:#6b7d90;
  font-size:13px;
  font-weight:650;
  line-height:1.15;
  letter-spacing:0;
}
.portal-role-company .company-purchase-section-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-width:0;
  margin-bottom:10px;
}
.portal-role-company .company-purchase-section-header .company-purchase-section-label{
  margin:0;
}
.portal-role-company .company-purchase-card__course{
  grid-area:course;
  display:flex;
  flex-direction:column;
  gap:9px;
}
.portal-role-company .company-purchase-card__heading{
  display:grid;
  grid-template-columns:72px minmax(0,1fr);
  align-items:center;
  gap:16px;
  min-height:82px;
}
.portal-role-company .company-purchase-card__heading h3{
  margin:4px 0 0;
  font-size:17px;
  line-height:1.25;
}
.portal-role-company .company-course-summary{
  display:flex;
  flex-wrap:wrap;
  align-content:flex-start;
  gap:7px;
  min-height:0;
}
.portal-role-company .company-included-courses{
  min-height:0;
  border:0;
  border-radius:0;
  background:transparent;
}
.portal-role-company .company-included-courses summary{
  width:max-content;
  max-width:100%;
  padding:0;
  color:#0f5da8;
  font-size:12px;
  font-weight:650;
}
.portal-role-company .company-purchase-card__course>.learner-btn{
  align-self:flex-start;
  justify-self:start;
  width:max-content;
  margin-top:auto;
}
.portal-role-company .company-purchase-card__course>.learner-btn--secondary.learner-btn--compact{
  padding-inline:12px;
}
.portal-role-company .company-purchase-card__seats{
  grid-area:seats;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:9px;
}
.portal-role-company .company-purchase-metrics,
.portal-role-company .company-purchase-progress,
.portal-role-company .company-purchase-learners,
.portal-role-company .company-purchase-card__seats>.learner-btn{
  grid-area:auto;
}
.portal-role-company .company-purchase-metrics{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  justify-content:stretch;
  gap:9px 12px;
  align-self:stretch;
  width:100%;
  margin:0;
}
.portal-role-company .company-purchase-metrics div{
  display:flex;
  align-items:baseline;
  justify-content:center;
  gap:6px;
  min-width:0;
  text-align:center;
}
.portal-role-company .company-purchase-metrics dt{
  min-height:0;
  color:#6b7d90;
  font-size:11px;
  line-height:1.2;
  white-space:nowrap;
}
.portal-role-company .company-purchase-metrics dd{
  order:-1;
  margin:0;
  color:#102034;
  font-size:16px;
  line-height:1.1;
}
.portal-role-company .company-purchase-progress{
  display:grid;
  justify-items:start;
  align-self:stretch;
  gap:7px;
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  text-align:left;
}
.portal-role-company .company-purchase-progress>div:first-child{
  display:flex;
  align-items:baseline;
  justify-content:flex-start;
  flex-wrap:wrap;
  gap:5px 9px;
}
.portal-role-company .company-purchase-progress strong{
  font-size:13px;
}
.portal-role-company .company-purchase-progress span{
  font-size:12px;
}
.portal-role-company .company-seat-stack{
  margin-top:0;
}
.portal-role-company .company-purchase-learners{
  align-self:flex-start;
  min-height:0;
  margin-top:2px;
  justify-items:start;
  text-align:left;
}
.portal-role-company .company-purchase-learners.company-purchase-disclosure{
  margin-top:2px;
}
.portal-role-company .company-purchase-disclosure{
  display:block;
  width:100%;
  max-width:100%;
  margin-top:0;
  border:1px solid #e5edf4;
  border-radius:10px;
  background:#f9fcfe;
  overflow:hidden;
}
.portal-role-company .company-purchase-disclosure__toggle{
  display:flex !important;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  box-sizing:border-box;
  width:100%;
  min-height:44px;
  padding:9px 11px;
  border:0;
  background:transparent;
  cursor:pointer;
  font:inherit;
  text-align:left;
}
.portal-role-company .company-purchase-disclosure__toggle span{
  display:grid;
  gap:2px;
  min-width:0;
}
.portal-role-company .company-purchase-disclosure__toggle small{
  color:#6b7d90;
  font-size:11px;
  line-height:1.2;
}
.portal-role-company .company-purchase-disclosure__toggle strong{
  color:#102034;
  font-size:13px;
  font-weight:650;
  line-height:1.2;
}
.portal-role-company .company-purchase-disclosure__toggle em{
  flex:0 0 auto;
  color:#176fb5;
  font-size:12px;
  font-style:normal;
  font-weight:650;
  line-height:1;
}
.portal-role-company .company-purchase-disclosure__toggle[aria-expanded="true"]{
  border-bottom:1px solid #e8f0f6;
  background:#fff;
}
.portal-role-company .company-purchase-disclosure__toggle[aria-expanded="true"] em{
  font-size:0;
}
.portal-role-company .company-purchase-disclosure__toggle[aria-expanded="true"] em::after{
  content:"Hide";
  font-size:12px;
}
.portal-role-company .company-purchase-learner-scroll{
  position:relative;
  display:block;
  width:100%;
  min-width:0;
  max-height:184px;
  --company-learner-scrollbar-width:8px;
}
.portal-role-company .company-purchase-learner-list{
  display:block;
  box-sizing:border-box;
  width:100%;
  min-width:100%;
  inline-size:100%;
  max-height:184px;
  margin:0;
  padding:5px 18px 5px 9px;
  overflow-x:hidden;
  overflow-y:auto;
  scrollbar-gutter:auto;
  scrollbar-width:none;
  scrollbar-color:transparent transparent;
  -ms-overflow-style:none;
}
.portal-role-company .company-purchase-learner-list::-webkit-scrollbar{
  display:none!important;
  width:0!important;
  height:0!important;
}
.portal-role-company .company-purchase-learner-list::-webkit-scrollbar-button{
  display:none!important;
  width:0!important;
  height:0!important;
  border:0!important;
  background:transparent!important;
}
.portal-role-company .company-purchase-learner-list::-webkit-scrollbar-button:single-button,
.portal-role-company .company-purchase-learner-list::-webkit-scrollbar-button:vertical:decrement,
.portal-role-company .company-purchase-learner-list::-webkit-scrollbar-button:vertical:increment,
.portal-role-company .company-purchase-learner-list::-webkit-scrollbar-button:vertical:start,
.portal-role-company .company-purchase-learner-list::-webkit-scrollbar-button:vertical:end{
  display:none!important;
  width:0!important;
  height:0!important;
  min-width:0!important;
  min-height:0!important;
  border:0!important;
  background:transparent!important;
  -webkit-appearance:none!important;
}
.portal-role-company .company-purchase-learner-list::-webkit-scrollbar-track{
  margin:6px 0;
  border-radius:999px;
  background:#f4f8fb;
}
.portal-role-company .company-purchase-learner-list::-webkit-scrollbar-thumb{
  border:3px solid #f4f8fb;
  border-radius:999px;
  background:#bdcad7;
  background-clip:padding-box;
}
.portal-role-company .company-purchase-learner-list::-webkit-scrollbar-thumb:hover{
  background:#94a8ba;
  background-clip:padding-box;
}
.portal-role-company .company-purchase-custom-scrollbar{
  position:absolute;
  top:8px;
  right:6px;
  bottom:8px;
  width:var(--company-learner-scrollbar-width);
  border-radius:999px;
  background:#f4f8fb;
  pointer-events:none;
}
.portal-role-company .company-purchase-custom-scrollbar span{
  display:block;
  width:100%;
  min-height:30px;
  border:2px solid #f4f8fb;
  border-radius:999px;
  background:#bdcad7;
  background-clip:padding-box;
  transition:background-color .14s ease;
  will-change:transform,height;
}
.portal-role-company .company-purchase-learner-scroll.is-not-scrollable .company-purchase-custom-scrollbar{
  display:none;
}
.portal-role-company .company-purchase-learner-list ul{
  display:block;
  width:100%;
  margin:0;
  padding:0;
}
.portal-role-company .company-purchase-disclosure li{
  display:grid;
  gap:2px;
  min-height:42px;
  padding:7px 6px;
  border-bottom:1px solid #edf3f8;
  color:#27384b;
  font-size:13px;
  line-height:1.25;
}
.portal-role-company .company-purchase-disclosure li strong{
  min-width:0;
  overflow:hidden;
  color:#102034;
  font-size:13px;
  font-weight:650;
  line-height:1.2;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-company .company-purchase-disclosure li small{
  min-width:0;
  overflow:hidden;
  color:#6b7d90;
  font-size:12px;
  line-height:1.2;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-company .company-purchase-disclosure li:last-child{
  border-bottom:0;
}
.portal-role-company .company-purchase-card__seats>.learner-btn{
  align-self:flex-start;
  justify-self:start;
  margin-top:auto;
}
.portal-role-company .company-purchase-card__invoice{
  grid-area:invoice;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
  text-align:left;
}
.portal-role-company .company-purchase-card__invoice>strong{
  display:grid;
  justify-items:start;
  gap:4px;
  min-height:0;
  font-size:19px;
  text-align:left;
}
.portal-role-company .company-purchase-card__invoice>strong span{
  justify-self:start;
  text-align:left;
}
.portal-role-company .company-purchase-action-meta{
  display:grid;
  justify-items:start;
  gap:6px;
  min-height:0;
}
.portal-role-company .company-purchase-invoice-actions{
  display:flex;
  flex-direction:row;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  margin-top:auto;
}
.portal-role-company .company-purchase-invoice-actions .learner-btn{
  width:max-content;
}
.portal-role-company .company-purchase-card .learner-btn--compact{
  min-height:32px;
  padding:0 12px;
  font-size:12px;
}
.portal-role-company .company-purchase-card .learner-btn--tertiary.learner-btn--compact{
  padding-inline:0;
}
.portal-role-company .company-purchase-card__heading{
  grid-template-columns:1fr;
  min-height:0;
  gap:0;
  align-content:start;
}
.portal-role-company .company-purchase-card__heading h3{
  margin:0;
}
.portal-role-company .company-purchase-card__invoice{
  align-items:stretch;
  gap:12px;
}
.portal-role-company .company-purchase-invoice-total{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  grid-template-areas:
    "label status"
    "amount status";
  align-items:center;
  gap:4px 10px;
  min-width:0;
}
.portal-role-company .company-purchase-invoice-total>span:first-child{
  grid-area:label;
  color:#6b7d90;
  font-size:11px;
  line-height:1.2;
}
.portal-role-company .company-purchase-invoice-total>strong{
  grid-area:amount;
  min-width:0;
  color:#102034;
  font-size:20px;
  font-weight:680;
  line-height:1.12;
}
.portal-role-company .company-purchase-invoice-total>.status-pill{
  grid-area:status;
  justify-self:end;
  width:max-content;
}
.portal-role-company .company-purchase-action-meta{
  justify-items:stretch;
  gap:8px;
}
.portal-role-company .company-purchase-action-meta>div{
  display:grid;
  gap:3px;
  min-width:0;
}
.portal-role-company .company-purchase-action-meta span{
  color:#6b7d90;
  font-size:11px;
  line-height:1.2;
}
.portal-role-company .company-purchase-action-meta strong{
  min-width:0;
  overflow:hidden;
  color:#27384b;
  font-size:13px;
  font-weight:560;
  line-height:1.25;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-company .company-purchase-invoice-actions{
  align-items:center;
  justify-content:flex-start;
  gap:8px;
}

@media (max-width:560px){
  .portal-role-company .company-purchase-metrics{
    grid-template-columns:1fr;
    justify-content:stretch;
  }
}

@media (max-width:1100px){
  .portal-role-company .company-purchase-card.learner-invoice-card{
    grid-template-columns:1fr;
    grid-template-areas:
      "course"
      "seats"
      "invoice";
  }
  .portal-role-company .company-purchase-card__seats,
  .portal-role-company .company-purchase-card__invoice{
    border-left:1px solid #e4ecf3;
    border-top:1px solid #e4ecf3;
  }
  .portal-role-company .company-purchase-card__invoice{
    align-items:flex-start;
    text-align:left;
  }
  .portal-role-company .company-purchase-action-meta,
  .portal-role-company .company-purchase-card__invoice>strong{
    justify-items:start;
  }
  .portal-role-company .company-purchase-invoice-actions{
    align-items:flex-start;
  }
}
/* Final end-of-file admin override: keep staff polish above older duplicated rules. */
.portal-role-staff .page-shell{width:min(1620px,calc(100% - 56px))}
.portal-role-staff .main-shell,.portal-role-staff .main-shell--staff-dashboard{width:min(1620px,calc(100% - 56px))}
.portal-role-staff .portal-role-label{display:inline-flex!important;align-items:center;gap:6px;width:max-content;min-height:0;padding:0;border:0;background:transparent;box-shadow:none;color:#607489!important;font-size:12px!important;font-weight:520!important;line-height:1.2;letter-spacing:0!important;text-transform:none!important}
.portal-role-staff .portal-role-label svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.portal-role-staff .page-heading{grid-template-columns:minmax(0,1fr) auto;max-width:none}
.portal-role-staff .order-link-card--compact{grid-template-columns:minmax(0,1fr) minmax(330px,380px);align-items:stretch;gap:18px;padding:18px}
.portal-role-staff .order-link-card--compact .order-link-card__main{gap:14px}
.portal-role-staff .order-link-card--compact .order-link-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding-bottom:12px;border-bottom:1px solid #edf3f8}
.portal-role-staff .order-link-card__identity{min-width:0}
.portal-role-staff .order-link-card__identity strong{display:block;color:var(--admin-ink);font-size:22px;font-weight:690;line-height:1.08}
.portal-role-staff .order-link-card__header-meta{display:flex;flex:0 0 auto;align-items:center;justify-content:flex-end;gap:10px;min-width:max-content}
.portal-role-staff .order-link-card__total{color:var(--admin-blue-dark);font-size:18px;font-weight:680;line-height:1.1;white-space:nowrap}
.portal-role-staff .order-link-card__details--review{grid-template-columns:minmax(210px,1fr) minmax(170px,.78fr) minmax(330px,1.45fr) minmax(100px,.42fr) minmax(145px,.58fr);gap:13px 18px;align-items:start}
.portal-role-staff .order-link-card--compact .order-link-card__details--review .order-link-card__detail{min-width:0;padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}
.portal-role-staff .order-link-card__detail span,.portal-role-staff .support-record-card__body span{color:#748498;font-size:11px;font-weight:520;line-height:1.2;text-transform:none}
.portal-role-staff .order-link-card__detail strong,.portal-role-staff .support-record-card__body strong{color:#223247;font-size:14px;font-weight:590;line-height:1.28}
.portal-role-staff .order-link-card__detail small,.portal-role-staff .support-record-card__body small{margin-top:3px;color:#6d7d8f;font-size:12px;line-height:1.25}
.portal-role-staff .order-link-card__detail--buyer strong,.portal-role-staff .order-link-card__detail--company strong,.portal-role-staff .order-link-card__detail--purchase strong{overflow:visible;text-overflow:clip;white-space:normal}
.portal-role-staff .order-link-card__detail--purchase strong{max-width:680px}
.portal-role-staff .order-link-card__detail--seats strong{font-size:16px;font-weight:650}
.portal-role-staff .order-link-card--compact .order-link-card__action{display:grid;align-content:start;gap:13px;align-self:stretch;padding:16px;border:1px solid #e4edf5;border-radius:12px;background:#f8fbfe}
.portal-role-staff .order-link-card--compact .match-callout{gap:4px;padding-bottom:12px;border-bottom:1px solid #e8f0f7}
.portal-role-staff .order-link-card--compact .match-callout span{color:#748498;font-size:11px;font-weight:520}
.portal-role-staff .order-link-card--compact .match-callout strong{color:#223247;font-size:14px;font-weight:650;line-height:1.25}
.portal-role-staff .order-link-card--compact .order-link-form{grid-template-columns:1fr;gap:10px}
.portal-role-staff .order-link-card--compact .order-link-form .primary-button{width:100%;justify-content:center}
.portal-role-staff .order-link-card--compact .order-link-form .primary-button:disabled{border-color:#d7e0ea;background:#edf2f7;color:#8291a3;cursor:not-allowed;opacity:1}
.portal-role-staff .support-history-layout{grid-template-columns:minmax(0,1fr) minmax(300px,340px);gap:18px}
.portal-role-staff .support-record-card--compact{grid-template-columns:minmax(250px,.58fr) minmax(0,1.42fr);align-items:center;gap:18px;min-height:92px;padding:12px 14px}
.portal-role-staff .support-record-card--compact .support-record-card__header{display:grid;grid-column:1;grid-row:1;gap:8px;align-content:center;min-width:0}
.portal-role-staff .support-record-card--compact .support-record-card__header strong{color:var(--admin-ink);font-size:15px;font-weight:650;line-height:1.25}
.portal-role-staff .support-record-card--compact .support-record-card__header>div{min-width:0}
.portal-role-staff .support-record-card--compact .support-record-card__header .status-pill{grid-column:auto;grid-row:auto;justify-self:start;width:max-content;max-width:100%}
.portal-role-staff .support-record-card--compact .support-record-card__body{grid-column:2;grid-row:1;grid-template-columns:minmax(260px,1.28fr) minmax(132px,.58fr) minmax(132px,.58fr) minmax(170px,.7fr);align-items:start;gap:10px 18px;min-width:0}
.portal-role-staff .support-record-card__body--missing-credential{grid-template-columns:minmax(260px,1.28fr) minmax(132px,.58fr) minmax(132px,.58fr) minmax(96px,.34fr)}
.portal-role-staff .support-record-card--compact .support-record-card__body div{min-width:0;padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}
.portal-role-staff .support-record-card--compact .support-record-card__body strong{overflow:visible;text-overflow:clip;white-space:normal}
.portal-role-staff .support-record-card--compact .support-record-card__credential strong,.portal-role-staff .support-record-card--compact .support-record-card__credential small{overflow-wrap:anywhere}
.portal-role-staff .staff-date-value{overflow:visible!important;text-overflow:clip!important;white-space:normal!important;line-height:1.3}
.portal-role-staff .staff-record-status{justify-self:start;white-space:nowrap}
.portal-role-staff .provisioning-failure-card .support-meta-grid{grid-template-columns:minmax(150px,.75fr) minmax(230px,1.2fr) minmax(180px,.8fr) minmax(180px,.8fr);gap:11px}
.portal-role-staff .status-pill--needs-review{background:#fff4df;color:var(--admin-amber)}
.portal-role-staff .provisioning-job-card__note{max-width:560px;color:#66788b;white-space:normal}
.portal-role-staff .staff-organization-layout{grid-template-columns:minmax(0,1fr) minmax(300px,360px);align-items:start;gap:18px}
.portal-role-staff .data-table--organizations .data-table__row{grid-template-columns:minmax(300px,1.75fr) minmax(120px,.52fr) minmax(88px,.36fr) minmax(88px,.36fr) minmax(88px,.36fr) minmax(104px,.42fr);gap:16px}
.portal-role-staff .data-table--organizations .data-table__row:not(.data-table__row--head){min-height:70px}
.portal-role-staff .data-table--organizations .data-table__row strong,.portal-role-staff .data-table--organizations .data-table__row small{white-space:normal}
@media (max-width:1280px){.portal-role-staff .page-shell,.portal-role-staff .main-shell,.portal-role-staff .main-shell--staff-dashboard{width:min(100% - 40px,1420px)}.portal-role-staff .order-link-card--compact,.portal-role-staff .support-history-layout,.portal-role-staff .staff-organization-layout{grid-template-columns:1fr}.portal-role-staff .order-link-card__details--review,.portal-role-staff .support-record-card--compact .support-record-card__body,.portal-role-staff .support-record-card__body--missing-credential,.portal-role-staff .provisioning-failure-card .support-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){.portal-role-staff .page-shell,.portal-role-staff .main-shell,.portal-role-staff .main-shell--staff-dashboard{width:min(100% - 28px,100%)}.portal-role-staff .page-heading,.portal-role-staff .order-link-card__details--review,.portal-role-staff .support-record-card--compact,.portal-role-staff .support-record-card--compact .support-record-card__body,.portal-role-staff .support-record-card__body--missing-credential,.portal-role-staff .provisioning-failure-card .support-meta-grid,.portal-role-staff .data-table--organizations .data-table__row{grid-template-columns:1fr}.portal-role-staff .order-link-card--compact .order-link-card__header{flex-direction:column;align-items:flex-start}.portal-role-staff .order-link-card__header-meta{justify-content:flex-start}.portal-role-staff .staff-record-status{justify-self:start}}
.portal-role-staff .portal-app-shell{grid-template-columns:268px minmax(0,1fr)}
.portal-role-staff .portal-sidebar{position:fixed;inset:0 auto 0 0;width:268px;height:100vh;height:100dvh;padding:20px 16px;border-right:1px solid rgba(255,255,255,.12);background:#092b49;color:#1e293b;overflow-y:auto;overscroll-behavior:contain;box-shadow:6px 0 18px rgba(6,28,48,.14)}
.portal-role-staff .portal-workspace{grid-column:2}
.portal-role-staff .portal-brand{min-height:auto;padding:4px 12px 12px;border-bottom:1px solid rgba(255,255,255,.24);background:transparent;color:#fff}
.portal-role-staff .portal-brand__logo-wrap{max-width:178px}
.portal-role-staff .portal-brand__logo--blue{display:none}
.portal-role-staff .portal-brand__logo--light{display:block;width:100%;max-width:178px;height:auto}
.portal-role-staff .portal-sidebar__nav{gap:10px;padding:16px 0 0}
.portal-role-staff .portal-nav-group{gap:8px}
.portal-role-staff .portal-nav-link{min-height:44px;padding:0 16px;border-radius:10px;color:#e8f5ff;font-size:14px;font-weight:650}
.portal-role-staff .portal-nav-link:hover{background:rgba(255,255,255,.13);color:#fff}
.portal-role-staff .portal-nav-link.is-active{background:#fff;color:#0c3558;box-shadow:none}
.portal-role-staff .portal-nav-link.is-active::before{display:none}
.portal-role-staff .portal-nav-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:8px;background:rgba(255,255,255,.12);color:#e8f5ff}
.portal-role-staff .portal-nav-icon svg{width:18px;height:18px;stroke-width:1.8}
.portal-role-staff .portal-nav-link.is-active .portal-nav-icon{background:#eaf4fb;color:#0b5c8d}
.portal-role-staff .portal-sidebar__footer{padding:14px 16px 16px;border-top:1px solid rgba(255,255,255,.12);gap:8px}
.portal-role-staff .portal-user-card{padding:11px;border-color:rgba(255,255,255,.18);border-radius:12px;background:rgba(255,255,255,.08)}
.portal-role-staff .portal-sidebar__footer .nav-button{height:34px;min-height:34px;padding:0 14px;border-color:transparent;border-radius:10px;background:transparent;color:rgba(233,245,255,.74);font-size:14px;font-weight:650;box-shadow:none}
@media (max-width:860px){.portal-role-staff .portal-app-shell{grid-template-columns:1fr}.portal-role-staff .portal-sidebar{position:fixed;inset:0 auto 0 0;z-index:40;width:288px;max-width:86vw;height:100dvh;min-height:100vh;min-height:100dvh;border-right:0;border-bottom:0;overflow-y:auto;transform:translateX(-100%);transition:transform .18s ease;box-shadow:none}.portal-role-staff .portal-app-shell.is-nav-open .portal-sidebar{transform:translateX(0)}.portal-role-staff .portal-app-shell.is-nav-open .portal-mobile-overlay{display:block}.portal-role-staff .portal-mobile-overlay{position:fixed;inset:0;z-index:30;border:0;padding:0;background:rgba(15,23,42,.42)}.portal-role-staff .portal-menu-button{display:inline-flex}.portal-role-staff .portal-workspace{grid-column:auto}}

/* Instructor portal */
.portal-role-instructor .main-shell{
  width:min(1320px,calc(100% - 48px));
  padding-top:28px;
}
.portal-role-instructor .main-shell--instructor-dashboard{
  width:min(1680px,calc(100% - 48px));
  padding-top:28px;
}
.portal-role-instructor .portal-role-label{
  display:inline-flex;
  align-items:center;
  gap:6px;
  width:max-content;
  min-height:0;
  padding:0;
  border:0;
  background:transparent;
  box-shadow:none;
  color:#607489;
  font-size:12px;
  font-weight:520;
  line-height:1.2;
  letter-spacing:0;
  text-transform:none;
}
.portal-role-instructor .portal-role-label svg{
  width:13px;
  height:13px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.9;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-instructor .learner-page-header{
  grid-template-columns:minmax(0,1fr) auto;
}
.portal-role-instructor .instructor-help-flow{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:18px;
  padding:13px 16px;
  color:#51677d;
  font-size:13px;
  line-height:1.3;
}
.portal-role-instructor .instructor-help-flow span{
  color:#17283a;
  font-weight:560;
}
.portal-role-instructor .instructor-help-flow svg{
  width:15px;
  height:15px;
  fill:none;
  stroke:#8aa0b4;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.instructor-dashboard-grid{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(320px,.72fr);
  gap:18px;
  margin-bottom:18px;
}
.instructor-panel{
  min-width:0;
}
.instructor-session-list,
.instructor-review-list,
.instructor-record-list{
  display:grid;
  gap:12px;
}
.instructor-session-record-list{
  display:grid;
  gap:16px;
}
.instructor-session-record-group{
  display:grid;
  gap:12px;
  padding:14px;
  border:1px solid #e2ebf4;
  border-radius:20px;
  background:linear-gradient(180deg,#fbfdff 0%,#f7fafc 100%);
  box-shadow:0 14px 30px rgba(15,35,55,.045);
}
.instructor-session-record-group__header{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  align-items:center;
  gap:16px 22px;
  padding:2px 2px 10px;
  border-bottom:1px solid #e8eef5;
}
.instructor-session-record-group__header span,
.instructor-session-record-group__header dt{
  color:#7a8a9b;
  font-size:12px;
  font-weight:540;
  line-height:1.2;
}
.instructor-session-record-group__title{
  min-width:0;
}
.instructor-session-record-group__header h3{
  margin:5px 0 0;
  color:#17283a;
  font-size:20px;
  font-weight:690;
  line-height:1.18;
}
.instructor-session-record-group__details{
  display:grid;
  grid-template-columns:minmax(150px,.42fr) minmax(240px,1fr);
  gap:10px 20px;
  max-width:100%;
  margin:12px 0 0;
}
.instructor-session-record-group__meta-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  align-items:center;
  gap:12px 18px;
  margin-top:12px;
}
.instructor-session-record-group__summary{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  align-self:center;
  min-width:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  gap:0;
  margin:0;
}
.instructor-session-record-group__summary div{
  display:inline-flex;
  align-items:center;
  gap:4px;
  min-height:0;
  padding:0;
  border-radius:0;
  color:#607489;
}
.instructor-session-record-group__summary div:not(:last-child)::after{
  content:"·";
  margin:0 10px;
  color:#b6c2cf;
  font-size:13px;
  line-height:1;
}
.instructor-session-record-group__summary div.is-attention{
  background:transparent;
  color:#955a0c;
}
.instructor-session-record-group__header dd{
  margin:5px 0 0;
  color:#17283a;
  font-size:14px;
  font-weight:620;
  line-height:1.28;
  overflow:visible;
  text-overflow:clip;
  white-space:normal;
}
.instructor-session-record-group__summary dd{
  order:-1;
  margin:0;
  color:currentColor;
  font-size:14px;
  font-weight:650;
  line-height:1;
  white-space:nowrap;
}
.instructor-session-record-group__summary dt{
  color:currentColor;
  font-size:12px;
  font-weight:560;
  line-height:1;
  white-space:nowrap;
}
.instructor-session-record-group__toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  justify-self:end;
  align-self:center;
  gap:8px;
  min-width:118px;
  height:38px;
  padding:0 12px 0 14px;
  border:1px solid #d8e5ef;
  border-radius:12px;
  background:#fff;
  color:#0b3b5c;
  font-size:13px;
  font-weight:650;
  line-height:1;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(15,35,55,.045);
  transition:background-color .16s ease,border-color .16s ease,box-shadow .16s ease,transform .16s ease;
}
.instructor-session-record-group__toggle span{
  color:inherit;
  font-size:13px;
  font-weight:650;
  line-height:1;
}
.instructor-session-record-group__toggle svg{
  width:16px;
  height:16px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  transition:transform .18s ease;
}
.instructor-session-record-group__toggle[aria-expanded="true"] svg{
  transform:rotate(180deg);
}
.instructor-session-record-group__toggle:hover,
.instructor-session-record-group__toggle:focus-visible{
  border-color:#9ec4df;
  background:#f7fbff;
  box-shadow:0 10px 18px rgba(15,35,55,.07);
  outline:none;
  transform:translateY(-1px);
}
.instructor-session-record-group__body[hidden]{
  display:none;
}
.instructor-session-record-group__body-heading{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:14px;
  margin:0 2px 1px;
  padding:4px 0 2px;
}
.instructor-session-record-group__body-heading strong{
  color:#17283a;
  font-size:15px;
  font-weight:660;
  line-height:1.2;
}
.instructor-session-record-group__body-heading span{
  color:#607489;
  font-size:12px;
  line-height:1.35;
}
.instructor-browser__hint{
  margin:5px 0 0;
  color:#607489;
  font-size:13px;
  line-height:1.35;
}
.portal-role-instructor .instructor-session-dashboard{
  display:grid;
  gap:14px;
}
.portal-role-instructor .instructor-session-dashboard__heading{
  align-items:start;
  gap:14px;
}
.portal-role-instructor .instructor-session-dashboard__heading p{
  margin:5px 0 0;
  color:#607489;
  font-size:13px;
  line-height:1.35;
}
.portal-role-instructor .instructor-session-dashboard__controls{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:8px;
}
.portal-role-instructor .instructor-session-toggle-group{
  display:inline-flex;
  align-items:center;
  gap:4px;
  min-height:38px;
  padding:4px;
  border:1px solid #dfe8f0;
  border-radius:13px;
  background:#f7fafc;
}
.portal-role-instructor .instructor-session-toggle-group button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  min-height:30px;
  padding:0 11px;
  border:0;
  border-radius:9px;
  background:transparent;
  color:#607489;
  font:inherit;
  font-size:12px;
  font-weight:650;
  line-height:1;
  cursor:pointer;
}
.portal-role-instructor .instructor-session-toggle-group button strong{
  color:inherit;
  font-size:12px;
  font-weight:700;
}
.portal-role-instructor .instructor-session-toggle-group button.is-active{
  background:#fff;
  color:#0b3b5c;
  box-shadow:0 1px 2px rgba(15,35,55,.08);
}
.portal-role-instructor .instructor-session-toggle-group button:focus-visible{
  outline:3px solid rgba(43,116,180,.22);
  outline-offset:2px;
}
.portal-role-instructor .instructor-session-dashboard__list{
  display:grid;
  gap:10px;
}
.portal-role-instructor .instructor-session-dashboard__list[hidden],
.portal-role-instructor .instructor-session-dashboard-card[hidden],
.portal-role-instructor .instructor-session-calendar-day[hidden],
.portal-role-instructor .instructor-session-calendar-card[hidden]{
  display:none;
}
.portal-role-instructor .instructor-session-dashboard-card{
  display:grid;
  grid-template-columns:minmax(132px,.28fr) minmax(0,1fr) minmax(190px,.42fr) auto;
  align-items:center;
  gap:16px;
  min-height:92px;
  padding:14px;
  border:1px solid #e3ecf4;
  border-radius:14px;
  background:#fff;
  box-shadow:0 1px 2px rgba(15,23,42,.045);
  transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease;
}
.portal-role-instructor .instructor-session-dashboard-card:hover{
  border-color:#d1deea;
  box-shadow:0 5px 16px rgba(15,35,55,.055);
  transform:translateY(-1px);
}
.portal-role-instructor .instructor-session-dashboard-card__date{
  display:grid;
  gap:4px;
  min-width:0;
}
.portal-role-instructor .instructor-session-dashboard-card__date strong{
  color:#102034;
  font-size:15px;
  font-weight:650;
  line-height:1.2;
}
.portal-role-instructor .instructor-session-dashboard-card__date span,
.portal-role-instructor .instructor-session-dashboard-card__main span,
.portal-role-instructor .instructor-session-dashboard-card__main p,
.portal-role-instructor .instructor-session-dashboard-card__meta dt{
  color:#607489;
  font-size:12px;
  line-height:1.25;
}
.portal-role-instructor .instructor-session-dashboard-card__main{
  min-width:0;
}
.portal-role-instructor .instructor-session-dashboard-card__main h3{
  margin:3px 0;
  overflow:hidden;
  color:#17283a;
  font-size:17px;
  font-weight:660;
  line-height:1.24;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-instructor .instructor-session-dashboard-card__main p{
  margin:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-instructor .instructor-session-dashboard-card__meta{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin:0;
}
.portal-role-instructor .instructor-session-dashboard-card__meta dd{
  margin:3px 0 0;
  color:#17283a;
  font-size:14px;
  font-weight:650;
  line-height:1.2;
}
.portal-role-instructor .instructor-session-dashboard-card__action{
  justify-self:end;
}
.portal-role-instructor .instructor-session-dashboard__calendar{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}
.portal-role-instructor .instructor-session-dashboard__calendar[hidden]{
  display:none;
}
.portal-role-instructor .instructor-session-calendar-day{
  display:grid;
  gap:9px;
  min-height:160px;
  padding:12px;
  border:1px solid #e3ecf4;
  border-radius:14px;
  background:#fbfdff;
}
.portal-role-instructor .instructor-session-calendar-day header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding-bottom:8px;
  border-bottom:1px solid #e8eef5;
}
.portal-role-instructor .instructor-session-calendar-day header strong{
  color:#17283a;
  font-size:14px;
  font-weight:660;
}
.portal-role-instructor .instructor-session-calendar-day header span{
  color:#607489;
  font-size:12px;
}
.portal-role-instructor .instructor-session-calendar-day>div{
  display:grid;
  gap:8px;
}
.portal-role-instructor .instructor-session-calendar-card{
  display:grid;
  gap:4px;
  padding:10px;
  border:1px solid #e5edf4;
  border-radius:11px;
  background:#fff;
}
.portal-role-instructor .instructor-session-calendar-card span{
  color:#607489;
  font-size:11px;
  line-height:1.2;
}
.portal-role-instructor .instructor-session-calendar-card strong{
  color:#17283a;
  font-size:13px;
  font-weight:650;
  line-height:1.25;
}
.portal-role-instructor .instructor-session-calendar-card small{
  color:#607489;
  font-size:12px;
  line-height:1.3;
}
.portal-role-instructor .instructor-session-calendar-card a{
  width:max-content;
  color:#0b5c8d;
  font-size:12px;
  font-weight:650;
  text-decoration:none;
}
.portal-role-instructor .instructor-session-calendar-card a:hover{
  text-decoration:underline;
}
.portal-role-instructor .instructor-session-dashboard__empty{
  margin:0;
}
.portal-role-instructor .instructor-session-pagination{
  padding-top:2px;
}
.instructor-session-card{
  display:grid;
  grid-template-columns:56px minmax(0,1fr) auto;
  align-items:center;
  gap:14px;
  padding:14px;
  border:1px solid #e5edf4;
  border-radius:16px;
  background:#fff;
}
.instructor-session-card h3{
  margin:0;
  color:#17283a;
  font-size:15px;
  font-weight:660;
  line-height:1.25;
}
.instructor-session-card p,
.instructor-session-card span{
  display:block;
  margin:3px 0 0;
  color:#607489;
  font-size:13px;
  line-height:1.35;
}
.instructor-session-card dl{
  display:grid;
  grid-template-columns:repeat(2,minmax(70px,1fr));
  gap:10px;
  margin:0;
}
.instructor-session-card dt,
.instructor-record-card__result span{
  color:#7a8a9b;
  font-size:11px;
  font-weight:540;
  line-height:1.2;
}
.instructor-session-card dd{
  margin:3px 0 0;
  color:#17283a;
  font-size:16px;
  font-weight:650;
  line-height:1.1;
}
.instructor-review-item{
  display:grid;
  gap:4px;
  padding:13px 14px;
  border:1px solid #e8eef5;
  border-radius:14px;
  background:#fff;
  color:inherit;
  text-decoration:none;
  transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease;
}
.instructor-review-item:hover,
.instructor-review-item:focus-visible{
  border-color:#cfdce8;
  box-shadow:0 8px 18px rgba(15,44,70,.06);
  transform:translateY(-1px);
  outline:none;
}
.instructor-review-item span{
  color:#607489;
  font-size:12px;
  line-height:1.25;
}
.instructor-review-item strong{
  color:#17283a;
  font-size:14px;
  font-weight:650;
  line-height:1.25;
}
.instructor-review-item small{
  color:#a14624;
  font-size:12px;
  line-height:1.3;
}
.instructor-good-state{
  display:grid;
  justify-items:start;
  gap:8px;
  padding:18px;
  border:1px solid #e5edf4;
  border-radius:16px;
  background:#fbfdff;
}
.instructor-good-state strong{
  color:#17283a;
  font-size:15px;
  font-weight:660;
}
.instructor-good-state span{
  color:#607489;
  font-size:13px;
  line-height:1.4;
}
.portal-role-instructor .instructor-record-card{
  grid-template-columns:72px minmax(0,1.24fr) minmax(310px,.9fr) minmax(150px,.42fr);
  align-items:center;
  gap:18px;
  min-height:118px;
  padding:15px 18px;
  border-radius:18px;
}
.portal-role-instructor .instructor-record-card--collapsible{
  grid-template-columns:72px minmax(0,1.04fr) minmax(460px,1fr) minmax(138px,.32fr) auto;
  align-items:center;
  min-height:102px;
  padding:13px 15px;
}
.portal-role-instructor .instructor-record-card__state{
  display:grid;
  align-content:center;
  justify-items:center;
  gap:9px;
  width:72px;
  max-width:72px;
  text-align:center;
}
.portal-role-instructor .instructor-record-card__state .learner-icon-badge{
  width:46px;
  height:46px;
  border-radius:12px;
}
.portal-role-instructor .instructor-record-card__state .learner-icon-badge svg{
  width:22px;
  height:22px;
}
.instructor-record-card__main{
  display:grid;
  gap:4px;
  min-width:0;
}
.instructor-record-card__main p{
  margin:0;
  color:#607489;
  font-size:12px;
  line-height:1.25;
}
.instructor-record-card__main h3{
  margin:0;
  overflow:hidden;
  color:#17283a;
  font-size:18px;
  font-weight:680;
  line-height:1.18;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.instructor-record-card__main span{
  overflow:hidden;
  color:#405369;
  font-size:13px;
  line-height:1.3;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.instructor-record-card__issue{
  display:block;
  margin-top:4px;
  color:#a14624;
  font-size:12px;
  line-height:1.35;
}
.instructor-record-card__reason{
  display:block;
  margin-top:4px;
  color:#607489;
  font-size:12px;
  line-height:1.35;
}
.instructor-record-card__meta{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px 14px;
  align-items:center;
}
.portal-role-instructor .instructor-record-card--collapsible .instructor-record-card__meta{
  grid-template-columns:repeat(5,minmax(0,1fr));
}
.instructor-record-card__meta div{
  min-width:0;
}
.instructor-record-card__meta dt{
  color:#7a8a9b;
  font-size:11px;
  font-weight:540;
  line-height:1.2;
}
.instructor-record-card__meta dd{
  margin:4px 0 0;
  overflow:hidden;
  color:#24364b;
  font-size:13px;
  font-weight:590;
  line-height:1.28;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.instructor-record-card__result{
  display:grid;
  justify-items:end;
  gap:3px;
  min-width:0;
  text-align:right;
}
.instructor-record-card__result strong{
  color:#17283a;
  font-size:15px;
  font-weight:660;
  line-height:1.2;
}
.instructor-record-card__result small{
  overflow:hidden;
  max-width:100%;
  color:#607489;
  font-size:12px;
  line-height:1.25;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-instructor .instructor-record-card__toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  min-width:120px;
  height:38px;
  padding:0 12px;
  border:1px solid #d8e5ef;
  border-radius:12px;
  background:#fff;
  color:#0b3b5c;
  font-size:13px;
  font-weight:650;
  line-height:1;
  cursor:pointer;
  box-shadow:0 6px 14px rgba(15,35,55,.045);
  transition:background-color .16s ease,border-color .16s ease,box-shadow .16s ease,transform .16s ease;
}
.portal-role-instructor .instructor-record-card__toggle svg{
  width:16px;
  height:16px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  transition:transform .18s ease;
}
.portal-role-instructor .instructor-record-card__toggle[aria-expanded="true"] svg{
  transform:rotate(180deg);
}
.portal-role-instructor .instructor-record-card__toggle:hover,
.portal-role-instructor .instructor-record-card__toggle:focus-visible{
  border-color:#9ec4df;
  background:#f7fbff;
  box-shadow:0 9px 16px rgba(15,35,55,.07);
  outline:none;
  transform:translateY(-1px);
}
.portal-role-instructor .instructor-record-card__details{
  grid-column:1/-1;
  min-width:0;
  padding-top:2px;
}
.portal-role-instructor .instructor-record-card__details[hidden]{
  display:none;
}
.portal-role-instructor .portal-state-label--attention{
  color:var(--learner-red);
}
.instructor-filter-select{
  min-width:220px;
}
.portal-role-instructor .instructor-browser .learner-control-row{
  align-items:flex-end;
}
.portal-role-instructor .instructor-browser .learner-search-field{
  margin-top:17px;
}
.portal-role-instructor .instructor-browser .company-filter-select select{
  height:42px;
}
@media (max-width:1100px){
  .portal-role-instructor .learner-page-header,
  .instructor-dashboard-grid{
    grid-template-columns:1fr;
  }
  .portal-role-instructor .instructor-record-card{
    grid-template-columns:72px minmax(0,1fr);
    grid-template-areas:
      "state main"
      "state meta"
      "state result";
  }
  .portal-role-instructor .instructor-record-card--collapsible{
    grid-template-columns:72px minmax(0,1fr) auto;
    grid-template-areas:
      "state main toggle"
      "state meta meta"
      "state result result"
      "details details details";
  }
  .portal-role-instructor .instructor-record-card__state{grid-area:state}
  .portal-role-instructor .instructor-record-card__main{grid-area:main}
  .portal-role-instructor .instructor-record-card__meta{grid-area:meta}
  .portal-role-instructor .instructor-record-card__result{
    grid-area:result;
    justify-items:start;
    text-align:left;
  }
  .portal-role-instructor .instructor-record-card__toggle{grid-area:toggle}
  .portal-role-instructor .instructor-record-card__details{grid-area:details}
  .instructor-session-record-group__header{
    grid-template-columns:1fr;
  }
  .instructor-session-record-group__toggle{
    justify-self:start;
  }
  .instructor-session-record-group__summary{
    justify-content:flex-start;
    width:max-content;
    max-width:100%;
  }
}
@media (max-width:760px){
  .portal-role-instructor .main-shell,
  .portal-role-instructor .main-shell--instructor-dashboard{
    width:min(100% - 28px,100%);
  }
  .instructor-session-card,
  .portal-role-instructor .instructor-record-card{
    grid-template-columns:1fr;
  }
  .portal-role-instructor .instructor-record-card{
    grid-template-areas:none;
  }
  .portal-role-instructor .instructor-record-card__state{
    width:auto;
    max-width:none;
    justify-items:start;
    grid-area:auto;
  }
  .portal-role-instructor .instructor-record-card__main,
  .portal-role-instructor .instructor-record-card__meta,
  .portal-role-instructor .instructor-record-card__result,
  .portal-role-instructor .instructor-record-card__toggle,
  .portal-role-instructor .instructor-record-card__details{
    grid-area:auto;
  }
  .portal-role-instructor .instructor-record-card__toggle{
    width:100%;
  }
  .instructor-record-card__meta,
  .instructor-session-card dl{
    grid-template-columns:1fr;
  }
  .instructor-session-record-group{
    padding:12px;
    border-radius:16px;
  }
  .instructor-session-record-group__meta-row,
  .instructor-session-record-group__details{
    grid-template-columns:1fr;
  }
  .instructor-session-record-group__summary{
    min-width:0;
    width:auto;
  }
}
@media (max-width:1180px){
  .portal-role-instructor .instructor-session-dashboard-card{
    grid-template-columns:minmax(0,1fr) auto;
  }
  .portal-role-instructor .instructor-session-dashboard-card__date,
  .portal-role-instructor .instructor-session-dashboard-card__main,
  .portal-role-instructor .instructor-session-dashboard-card__meta{
    grid-column:1/-1;
  }
  .portal-role-instructor .instructor-session-dashboard-card__action{
    justify-self:start;
  }
}
@media (max-width:760px){
  .portal-role-instructor .instructor-session-dashboard__heading,
  .portal-role-instructor .instructor-session-dashboard-card{
    grid-template-columns:1fr;
  }
  .portal-role-instructor .instructor-session-dashboard__controls,
  .portal-role-instructor .instructor-session-toggle-group{
    width:100%;
  }
  .portal-role-instructor .instructor-session-toggle-group button{
    flex:1;
  }
}
.portal-role-staff .staff-panel-toolbar{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:14px}
.portal-role-staff .staff-panel-toolbar .staff-filter-row{grid-column:1/-1}
.portal-role-staff .staff-panel-toolbar .panel-count{justify-self:end;width:auto;min-width:0;padding-inline:12px}
.portal-role-staff .order-link-card--compact .order-link-card__header>*{width:auto;min-width:0}
.portal-role-staff .order-link-card__header-meta{margin-left:auto}
.portal-role-staff .order-link-card--compact .order-link-card__main{align-content:start}

/* Staff organization account access: read-only active company admin cards. */
.portal-role-staff .staff-account-access-list{
  display:grid;
  gap:10px;
  margin-top:14px;
}
.portal-role-staff .staff-account-access-card{
  display:grid;
  grid-template-columns:42px minmax(180px,1.4fr) repeat(3,minmax(105px,.62fr));
  align-items:center;
  gap:12px;
  padding:13px;
  border:1px solid #e3ecf4;
  border-radius:13px;
  background:#fff;
  box-shadow:0 10px 22px rgba(15,35,55,.045);
}
.portal-role-staff .staff-account-access-card__avatar{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border:1px solid #cfe3f4;
  border-radius:999px;
  background:#eef7fd;
  color:#0b5c8d;
  font-size:12px;
  font-weight:720;
  line-height:1;
}
.portal-role-staff .staff-account-access-card__identity,
.portal-role-staff .staff-account-access-card__meta{
  min-width:0;
}
.portal-role-staff .staff-account-access-card span{
  display:block;
  margin-bottom:3px;
  color:#748498;
  font-size:11px;
  font-weight:520;
  line-height:1.2;
}
.portal-role-staff .staff-account-access-card strong{
  display:block;
  min-width:0;
  color:#17283b;
  font-size:14px;
  font-weight:620;
  line-height:1.25;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.portal-role-staff .staff-account-access-card__identity strong{
  font-size:15px;
  font-weight:650;
}
.portal-role-staff .staff-account-access-card small{
  display:block;
  margin-top:2px;
  color:#60738a;
  font-size:12px;
  line-height:1.25;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
@media (max-width:1180px){
  .portal-role-staff .staff-account-access-card{
    grid-template-columns:42px minmax(0,1fr) minmax(120px,.5fr);
  }
}
@media (max-width:760px){
  .portal-role-staff .staff-account-access-card{
    grid-template-columns:42px minmax(0,1fr);
  }
  .portal-role-staff .staff-account-access-card__meta{
    grid-column:2;
  }
}

/* Link Orders cleanup: make buyer/order details read as review cards, not a raw table. */
.portal-role-staff .order-link-card--compact{
  grid-template-columns:minmax(0,1fr) minmax(330px,370px);
  align-items:start;
  padding:16px;
}
.portal-role-staff .order-link-card--compact .order-link-card__main{
  gap:12px;
}
.portal-role-staff .order-link-card--compact .order-link-card__header{
  align-items:center;
  padding-bottom:11px;
}
.portal-role-staff .order-link-card__details--review{
  display:grid;
  grid-template-columns:minmax(260px,.95fr) minmax(360px,1.35fr) minmax(104px,.34fr) minmax(132px,.46fr);
  grid-template-areas:
    "buyer purchase seats paid"
    "buyer company seats paid";
  gap:10px 14px;
  padding:0;
  background:transparent;
  box-shadow:none;
}
.portal-role-staff .order-link-card__detail--buyer{
  grid-area:buyer;
  display:grid;
  grid-template-columns:38px minmax(0,1fr);
  align-items:center;
  gap:11px;
  min-height:82px;
  padding:12px!important;
  border:1px solid #e3ecf4!important;
  border-radius:13px!important;
  background:#fff!important;
  box-shadow:0 10px 22px rgba(15,35,55,.045)!important;
}
.portal-role-staff .order-link-card__buyer-avatar{
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  margin:0!important;
  border:1px solid #cfe3f4;
  border-radius:999px;
  background:#eef7fd;
  color:#0b5c8d!important;
  font-size:12px!important;
  font-weight:720!important;
  line-height:1;
  text-transform:uppercase;
}
.portal-role-staff .order-link-card__buyer-copy{
  min-width:0;
}
.portal-role-staff .order-link-card__buyer-copy span{
  margin-bottom:3px;
}
.portal-role-staff .order-link-card__detail--buyer strong{
  color:#13283d;
  font-size:15px;
  font-weight:650;
  line-height:1.22;
}
.portal-role-staff .order-link-card__detail--buyer small{
  max-width:100%;
}
.portal-role-staff .order-link-card__detail--purchase{
  grid-area:purchase;
}
.portal-role-staff .order-link-card__detail--company{
  grid-area:company;
}
.portal-role-staff .order-link-card__detail--seats{
  grid-area:seats;
}
.portal-role-staff .order-link-card__detail--paid{
  grid-area:paid;
}
.portal-role-staff .order-link-card__detail--company,
.portal-role-staff .order-link-card__detail--purchase,
.portal-role-staff .order-link-card__detail--seats,
.portal-role-staff .order-link-card__detail--paid{
  align-self:stretch;
  padding:10px 0 0!important;
  border-top:1px solid #edf3f8!important;
}
.portal-role-staff .order-link-card__detail--purchase,
.portal-role-staff .order-link-card__detail--seats,
.portal-role-staff .order-link-card__detail--paid{
  padding-top:0!important;
  border-top:0!important;
}
.portal-role-staff .order-link-card__detail--purchase strong{
  max-width:none;
  color:#17283b;
  font-size:15px;
  font-weight:640;
}
.portal-role-staff .order-link-card__detail--company strong{
  color:#34465a;
  font-weight:560;
}
.portal-role-staff .order-link-card__detail--seats strong{
  color:#17283b;
  font-size:18px;
  font-weight:660;
}
.portal-role-staff .order-link-card__detail--paid strong{
  color:#17283b;
  font-size:14px;
  font-weight:620;
}
.portal-role-staff .order-link-card--compact .order-link-card__action{
  align-self:start;
  gap:12px;
  padding:14px;
  border-radius:13px;
}
.portal-role-staff .order-link-card--compact .match-callout{
  padding-bottom:11px;
}
.portal-role-staff .order-link-card--compact .order-link-form{
  grid-template-columns:minmax(0,1fr) 112px;
  align-items:end;
  gap:9px;
}
.portal-role-staff .order-link-card--compact .order-link-form .field{
  min-width:0;
}
.portal-role-staff .order-link-card--compact .order-link-form .primary-button{
  width:auto;
  min-width:112px;
  padding-inline:14px;
}
.portal-role-staff .order-link-card--compact .order-link-form .staff-action-note{
  grid-column:1/-1;
}
@media (max-width:1280px){
  .portal-role-staff .order-link-card--compact{
    grid-template-columns:1fr;
  }
  .portal-role-staff .order-link-card__details--review{
    grid-template-columns:minmax(240px,.9fr) minmax(0,1.1fr) minmax(120px,.45fr);
    grid-template-areas:
      "buyer purchase seats"
      "buyer company paid";
  }
}
@media (max-width:760px){
  .portal-role-staff .order-link-card__details--review{
    grid-template-columns:1fr;
    grid-template-areas:
      "buyer"
      "purchase"
      "company"
      "seats"
      "paid";
  }
  .portal-role-staff .order-link-card__detail--company,
  .portal-role-staff .order-link-card__detail--purchase,
  .portal-role-staff .order-link-card__detail--seats,
  .portal-role-staff .order-link-card__detail--paid{
    padding-top:10px!important;
    border-top:1px solid #edf3f8!important;
  }
  .portal-role-staff .order-link-card--compact .order-link-form{
    grid-template-columns:1fr;
  }
  .portal-role-staff .order-link-card--compact .order-link-form .primary-button{
    width:100%;
  }
}

.portal-role-instructor .instructor-record-card__workflow{
  grid-column:1/-1;
  display:grid;
  gap:9px;
  margin-top:0;
  padding:12px;
  border:1px solid #e4edf5;
  border-radius:14px;
  background:#f8fbfd;
}
.portal-role-instructor .instructor-workflow-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:8px;
}
.portal-role-instructor .instructor-workflow-grid label,
.portal-role-instructor .instructor-note-field{
  display:grid;
  gap:5px;
  min-width:0;
}
.portal-role-instructor .instructor-workflow-grid span,
.portal-role-instructor .instructor-note-field span{
  color:#607489;
  font-size:11px;
  font-weight:560;
  line-height:1.2;
}
.portal-role-instructor .instructor-workflow-grid select,
.portal-role-instructor .instructor-workflow-grid input,
.portal-role-instructor .instructor-note-field textarea{
  width:100%;
  min-width:0;
  border:1px solid #dbe7f1;
  border-radius:10px;
  background:#fff;
  color:#142235;
  font:inherit;
  font-size:13px;
  line-height:1.3;
  box-shadow:none;
}
.portal-role-instructor .instructor-workflow-grid select,
.portal-role-instructor .instructor-workflow-grid input{
  min-height:36px;
  padding:0 10px;
}
.portal-role-instructor .instructor-note-field textarea{
  min-height:52px;
  resize:vertical;
  padding:9px 11px;
}
.portal-role-instructor .instructor-note-preview{
  display:grid;
  gap:5px;
  padding:9px 11px;
  border:1px solid #dce8f2;
  border-radius:12px;
  background:#fff;
}
.portal-role-instructor .instructor-note-preview span{
  color:#607489;
  font-size:11px;
  font-weight:560;
  line-height:1.25;
}
.portal-role-instructor .instructor-note-preview p{
  margin:0;
  color:#24364b;
  font-size:13px;
  line-height:1.35;
}
.portal-role-instructor .instructor-note-history{
  margin-top:4px;
  padding-top:7px;
  border-top:1px solid #edf3f8;
}
.portal-role-instructor .instructor-note-history summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  cursor:pointer;
  list-style:none;
}
.portal-role-instructor .instructor-note-history summary::-webkit-details-marker{
  display:none;
}
.portal-role-instructor .instructor-note-history summary span{
  color:#0b5c8d;
  font-size:12px;
  font-weight:650;
}
.portal-role-instructor .instructor-note-history summary small{
  color:#607489;
  font-size:11px;
  font-weight:560;
  line-height:1.2;
}
.portal-role-instructor .instructor-note-history summary:focus-visible{
  border-radius:8px;
  outline:2px solid rgba(43,139,211,.34);
  outline-offset:3px;
}
.portal-role-instructor .instructor-note-history__scroll{
  position:relative;
  min-width:0;
  margin-top:8px;
}
.portal-role-instructor .instructor-note-history__list{
  display:grid;
  gap:7px;
  max-height:180px;
  padding-right:18px;
  overflow-x:hidden;
  overflow-y:auto;
  overscroll-behavior:contain;
  scrollbar-width:none;
  scrollbar-color:transparent transparent;
  -ms-overflow-style:none;
}
.portal-role-instructor .instructor-note-history__list::-webkit-scrollbar{
  display:none!important;
  width:0!important;
  height:0!important;
}
.portal-role-instructor .instructor-note-history__list::-webkit-scrollbar-button,
.portal-role-instructor .instructor-note-history__list::-webkit-scrollbar-button:single-button,
.portal-role-instructor .instructor-note-history__list::-webkit-scrollbar-button:vertical:decrement,
.portal-role-instructor .instructor-note-history__list::-webkit-scrollbar-button:vertical:increment,
.portal-role-instructor .instructor-note-history__list::-webkit-scrollbar-button:vertical:start,
.portal-role-instructor .instructor-note-history__list::-webkit-scrollbar-button:vertical:end{
  display:none!important;
  width:0!important;
  height:0!important;
  min-width:0!important;
  min-height:0!important;
  border:0!important;
  background:transparent!important;
  -webkit-appearance:none!important;
}
.portal-role-instructor .instructor-note-history__scrollbar{
  position:absolute;
  top:6px;
  right:4px;
  bottom:6px;
  width:8px;
  border-radius:999px;
  background:#f4f8fb;
  pointer-events:none;
}
.portal-role-instructor .instructor-note-history__scrollbar span{
  display:block;
  width:100%;
  min-height:28px;
  border:3px solid #f4f8fb;
  border-radius:999px;
  background:#bdcad7;
  background-clip:padding-box;
  transform:translateY(0);
}
.portal-role-instructor .instructor-note-history__scroll.is-not-scrollable .instructor-note-history__scrollbar{
  display:none;
}
.portal-role-instructor .instructor-note-history__list article{
  display:grid;
  gap:4px;
  padding-top:7px;
  border-top:1px solid #edf3f8;
}
.portal-role-instructor .instructor-note-history__list article:first-child{
  padding-top:0;
  border-top:0;
}
.portal-role-instructor .instructor-workflow-grid select:focus,
.portal-role-instructor .instructor-workflow-grid input:focus,
.portal-role-instructor .instructor-note-field textarea:focus{
  border-color:var(--learner-focus);
  outline:0;
  box-shadow:0 0 0 3px rgba(43,139,211,.16);
}
.portal-role-instructor .instructor-workflow-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.portal-role-instructor .instructor-workflow-actions small{
  color:#607489;
  font-size:12px;
  line-height:1.3;
}
@media (max-width:1180px){
  .portal-role-instructor .instructor-workflow-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}
@media (max-width:760px){
  .portal-role-instructor .instructor-workflow-grid{
    grid-template-columns:1fr;
  }
  .portal-role-instructor .instructor-workflow-actions{
    align-items:stretch;
    flex-direction:column;
  }
  .portal-role-instructor .instructor-workflow-actions .learner-btn{
    width:100%;
  }
}

/* Instructor shell alignment with the learner/company portal shell. */
.portal-role-instructor{
  --learner-ink:#142235;
  --learner-muted:#5f6f82;
  --learner-subtle:#7d8da0;
  --learner-bg:#f5f7fa;
  --learner-panel:#fff;
  --learner-soft:#f1f5f8;
  --learner-line:#dfe7ee;
  --learner-blue:#176fb5;
  --learner-blue-dark:#0b3354;
  --learner-cyan:#0d8fad;
  --learner-green:#1f7a50;
  --learner-amber:#a9630c;
  --learner-purple:#6252a4;
  --learner-red:#b42318;
  --learner-shadow:0 1px 2px rgba(15,23,42,.05);
  --learner-shadow-soft:0 6px 16px rgba(15,35,55,.07);
  --learner-focus:#2b8bd3;
  --learner-radius:8px;
  background:var(--learner-bg);
  color:var(--learner-ink);
}
.portal-role-instructor .portal-app-shell{
  grid-template-columns:268px minmax(0,1fr);
}
.portal-role-instructor .portal-workspace{
  grid-column:2;
  min-width:0;
  background:
    linear-gradient(180deg,rgba(244,248,252,.96) 0,rgba(248,250,252,1) 360px,rgba(248,250,252,1) 100%),
    #f7fafc;
}
.portal-role-instructor .page-shell{
  width:min(1360px,calc(100% - 56px));
  margin-left:auto;
  margin-right:auto;
}
.portal-role-instructor .main-shell{
  width:min(1320px,calc(100% - 48px));
  margin-left:auto;
  margin-right:auto;
  padding-top:28px;
}
.portal-role-instructor .main-shell--instructor-dashboard{
  width:min(1680px,calc(100% - 48px));
  margin-left:auto;
  margin-right:auto;
  padding-top:28px;
}
.portal-role-instructor .portal-sidebar{
  position:fixed;
  inset:0 auto 0 0;
  display:flex;
  flex-direction:column;
  gap:22px;
  width:268px;
  height:100vh;
  height:100dvh;
  padding:20px 16px;
  border-right:1px solid rgba(255,255,255,.12);
  background:#092b49;
  color:#e8f5ff;
  overflow-y:auto;
  overscroll-behavior:contain;
  box-shadow:6px 0 18px rgba(6,28,48,.14);
}
.portal-role-instructor .portal-brand{
  min-height:auto;
  padding:4px 12px 12px;
  border-bottom:1px solid rgba(255,255,255,.68);
  background:transparent;
  color:#fff;
}
.portal-role-instructor .portal-brand__logo-wrap{
  display:block;
  width:auto;
  max-width:178px;
  min-height:0;
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  line-height:0;
}
.portal-role-instructor .portal-brand__logo--blue{
  display:none;
}
.portal-role-instructor .portal-brand__logo--light{
  display:block;
  width:100%;
  max-width:178px;
  height:auto;
}
.portal-role-instructor .portal-nav-group__label{
  display:none;
}
.portal-role-instructor .portal-sidebar__nav{
  gap:10px;
  padding:16px 0 0;
}
.portal-role-instructor .portal-nav-group{
  gap:8px;
}
.portal-role-instructor .portal-nav-link{
  min-height:44px;
  padding:0 16px;
  border-radius:10px;
  color:#e8f5ff;
  font-size:14px;
  font-weight:650;
}
.portal-role-instructor .portal-nav-link:hover{
  background:rgba(255,255,255,.12);
  color:#fff;
}
.portal-role-instructor .portal-nav-link.is-active{
  background:#fff;
  color:#0c3558;
  box-shadow:none;
}
.portal-role-instructor .portal-nav-link.is-active::before{
  display:none;
}
.portal-role-instructor .portal-nav-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:22px;
  height:22px;
  border-radius:8px;
  background:rgba(255,255,255,.12);
  color:inherit;
}
.portal-role-instructor .portal-nav-icon svg{
  width:18px;
  height:18px;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-instructor .portal-nav-link.is-active .portal-nav-icon{
  background:#eaf4fb;
  color:#0b5c8d;
}
.portal-role-instructor .portal-sidebar__footer{
  gap:8px;
  padding:14px 16px 16px;
  border-top:1px solid rgba(255,255,255,.12);
}
.portal-role-instructor .portal-user-card{
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  padding:11px;
  border-color:rgba(255,255,255,.18);
  border-radius:12px;
  background:rgba(255,255,255,.08);
  box-shadow:none;
}
.portal-role-instructor .portal-user-card>span:last-child{
  min-width:0;
}
.portal-role-instructor .portal-user-card strong{
  color:#fff;
  white-space:normal;
}
.portal-role-instructor .portal-user-card small{
  color:rgba(233,245,255,.76);
  white-space:normal;
}
.portal-role-instructor .portal-sidebar__footer .nav-button{
  height:34px;
  min-height:34px;
  padding:0 14px;
  border-color:transparent;
  border-radius:10px;
  background:transparent;
  color:rgba(233,245,255,.74);
  font-size:14px;
  font-weight:650;
  box-shadow:none;
}
.portal-role-instructor .portal-sidebar__footer .nav-button:hover,
.portal-role-instructor .portal-sidebar__footer .nav-button:focus-visible{
  background:rgba(255,255,255,.08);
  color:#fff;
}
.portal-role-instructor .portal-topbar{
  min-height:76px;
  border-bottom-color:#e1e8ef;
  background:rgba(255,255,255,.94);
  box-shadow:0 1px 2px rgba(15,23,42,.05);
}
.portal-role-instructor .portal-topbar__inner{
  min-height:76px;
  align-items:center;
}
.portal-role-instructor .portal-topbar__inner>div:first-of-type{
  display:grid;
  gap:2px;
  align-content:center;
}
.portal-role-instructor .portal-role-label{
  display:inline-flex;
  align-items:center;
  gap:6px;
  width:max-content;
  min-height:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  color:var(--learner-muted)!important;
  font-size:12px!important;
  font-weight:520!important;
  line-height:1.2;
  letter-spacing:0!important;
  text-transform:none!important;
}
.portal-role-instructor .portal-role-label svg{
  width:13px;
  height:13px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.9;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.portal-role-instructor .portal-topbar strong{
  margin-top:2px;
  color:var(--learner-ink);
  font-size:19px;
  font-weight:650;
  line-height:1.1;
  letter-spacing:0;
}
.portal-role-instructor .learner-topbar-profile{
  display:grid;
  grid-template-columns:auto auto;
  align-items:center;
  gap:9px;
  min-height:42px;
  padding:4px 10px 4px 4px;
  border:1px solid var(--learner-line);
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  list-style:none;
}
.portal-role-instructor .learner-topbar-profile::-webkit-details-marker{
  display:none;
}
.portal-role-instructor .learner-topbar-profile .portal-avatar{
  flex:0 0 32px;
  width:32px;
  height:32px;
  border:0;
  background:#0b3354;
  color:#fff;
  box-shadow:0 0 0 2px #e8f1f8;
}
.portal-role-instructor .learner-profile-menu__panel a span{
  color:inherit;
  font-size:13px;
  font-weight:650;
  text-transform:none;
}
@media (max-width:1100px){
  .portal-role-instructor .portal-app-shell{
    grid-template-columns:252px minmax(0,1fr);
  }
  .portal-role-instructor .portal-sidebar{
    width:252px;
  }
}
@media (max-width:860px){
  .portal-role-instructor .portal-app-shell{
    grid-template-columns:1fr;
  }
  .portal-role-instructor .page-shell,
  .portal-role-instructor .main-shell,
  .portal-role-instructor .main-shell--instructor-dashboard{
    width:min(100% - 28px,100%);
  }
  .portal-role-instructor .portal-sidebar{
    position:fixed;
    inset:0 auto 0 0;
    z-index:40;
    width:288px;
    max-width:86vw;
    height:100dvh;
    min-height:100vh;
    min-height:100dvh;
    border-right:0;
    border-bottom:0;
    overflow-y:auto;
    transform:translateX(-100%);
    transition:transform .18s ease;
    box-shadow:none;
  }
  .portal-role-instructor .portal-app-shell.is-nav-open .portal-sidebar{
    transform:translateX(0);
  }
  .portal-role-instructor .portal-app-shell.is-nav-open .portal-mobile-overlay{
    display:block;
  }
  .portal-role-instructor .portal-mobile-overlay{
    position:fixed;
    inset:0;
    z-index:30;
    border:0;
    padding:0;
    background:rgba(15,23,42,.42);
  }
  .portal-role-instructor .portal-menu-button{
    display:inline-flex;
  }
  .portal-role-instructor .portal-workspace{
    grid-column:auto;
  }
}
