:root {
  --navy-950: #07101f;
  --navy-900: #0b1426;
  --navy-800: #13203a;
  --ink-900: #13213a;
  --ink-700: #41516b;
  --ink-500: #6d7b91;
  --line: #dfe6ef;
  --surface: #ffffff;
  --surface-soft: #f4f7fb;
  --surface-blue: #eef4ff;
  --primary: #2563eb;
  --primary-dark: #194fbe;
  --good: #0b8f62;
  --good-soft: #e9f8f2;
  --warn: #b36a00;
  --warn-soft: #fff5df;
  --bad: #c43c3c;
  --bad-soft: #fff0f0;
  --info-soft: #eef4ff;
  --shadow: 0 18px 50px rgba(18, 32, 58, 0.08);
  --radius: 18px;
  --radius-sm: 10px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink-900);
  background: var(--surface-soft);
  font-synthesis: none;
}

* { box-sizing: border-box; }
html { min-height: 100%; background: var(--surface-soft); }
body {
  min-height: 100vh;
  margin: 0;
  background: radial-gradient(circle at top right, rgba(37, 99, 235, 0.08), transparent 30rem), var(--surface-soft);
}
button, input, select { font: inherit; }
a { color: inherit; text-decoration: none; }
code { padding: .12rem .35rem; border-radius: 6px; background: #edf1f7; font-size: .9em; }
button:disabled { cursor: not-allowed; opacity: .58; }

.boot-screen, .loading-state {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  min-height: 100vh;
  color: var(--ink-700);
}
.boot-screen p { margin: .25rem 0 0; color: var(--ink-500); }

.brand-mark {
  display: inline-grid;
  place-items: center;
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 16px;
  background: linear-gradient(135deg, #3b82f6, #1d4ed8);
  color: white;
  font-weight: 800;
  letter-spacing: .03em;
  box-shadow: 0 10px 28px rgba(37, 99, 235, .3);
}
.brand-mark.small { width: 2.3rem; height: 2.3rem; border-radius: 11px; font-size: .82rem; }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.65rem;
  padding: .7rem 1rem;
  border: 1px solid transparent;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 700;
  transition: transform 140ms ease, box-shadow 140ms ease, background 140ms ease;
}
.button:hover:not(:disabled) { transform: translateY(-1px); }
.button-primary { color: white; background: var(--primary); box-shadow: 0 8px 20px rgba(37,99,235,.22); }
.button-primary:hover:not(:disabled) { background: var(--primary-dark); }
.button-secondary { color: var(--ink-900); background: white; border-color: var(--line); }
.button-ghost { color: rgba(255,255,255,.76); background: transparent; border-color: rgba(255,255,255,.18); }
.button-ghost.light { color: var(--ink-700); border-color: var(--line); }
.full-width { width: 100%; }
.text-button { display: inline; padding: 0; border: 0; color: var(--primary); background: transparent; cursor: pointer; font-weight: 700; }

.eyebrow { display: block; margin-bottom: .45rem; color: var(--primary); font-size: .73rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.muted { color: var(--ink-500); }
.security-note { margin: 0; padding: .85rem 1rem; border: 1px solid #dce7f7; border-radius: 10px; color: var(--ink-500); background: #f7faff; font-size: .83rem; line-height: 1.5; }

.auth-page { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(24rem, .85fr); min-height: 100vh; }
.auth-panel { padding: clamp(2rem, 5vw, 5rem); }
.auth-visual {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  color: white;
  background: linear-gradient(145deg, rgba(7,16,31,.98), rgba(19,32,58,.94)), radial-gradient(circle at 80% 20%, #2563eb 0, transparent 26rem);
}
.auth-visual::after {
  position: absolute;
  right: -12rem;
  bottom: -12rem;
  width: 32rem;
  height: 32rem;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 50%;
  content: "";
  box-shadow: 0 0 0 5rem rgba(255,255,255,.025), 0 0 0 10rem rgba(255,255,255,.018);
}
.auth-brand, .driver-brand, .sidebar-brand { display: flex; align-items: center; gap: .8rem; }
.auth-brand { position: relative; z-index: 1; gap: 1rem; }
.auth-brand strong, .driver-brand strong, .sidebar-brand strong { display: block; }
.auth-brand small, .driver-brand small, .sidebar-brand small { display: block; margin-top: .18rem; color: rgba(255,255,255,.62); }
.auth-copy { position: relative; z-index: 1; max-width: 48rem; }
.auth-copy .eyebrow { color: #8eb7ff; }
.auth-copy h1 { max-width: 45rem; margin: 0 0 1.25rem; font-size: clamp(2.5rem, 5vw, 5rem); line-height: 1; letter-spacing: -.055em; }
.auth-copy > p { max-width: 43rem; color: rgba(255,255,255,.74); font-size: 1.08rem; line-height: 1.7; }
.auth-feature-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: .85rem; margin-top: 2rem; }
.auth-feature-grid > div { padding: 1rem; border: 1px solid rgba(255,255,255,.09); border-radius: 12px; background: rgba(255,255,255,.05); backdrop-filter: blur(10px); }
.auth-feature-grid strong, .auth-feature-grid span { display: block; }
.auth-feature-grid span { margin-top: .3rem; color: rgba(255,255,255,.62); font-size: .82rem; }
.auth-form-panel { display: grid; place-items: center; background: white; }
.auth-form { display: grid; gap: 1.15rem; width: min(100%,28rem); }
.auth-form h2 { margin: 0; font-size: 2rem; letter-spacing: -.035em; }
.auth-form p { margin: .4rem 0 0; color: var(--ink-500); line-height: 1.55; }
.auth-form label { display: grid; gap: .45rem; color: var(--ink-700); font-size: .87rem; font-weight: 700; }
.auth-form input, .filter-bar input, .filter-bar select, .compact-select { width: 100%; min-height: 2.8rem; padding: .75rem .85rem; border: 1px solid var(--line); border-radius: 10px; outline: none; color: var(--ink-900); background: white; }
.auth-form input:focus, .filter-bar input:focus, .filter-bar select:focus, .compact-select:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(37,99,235,.1); }
.form-message { padding: .8rem 1rem; border-radius: 10px; font-size: .87rem; }
.form-message.success { color: #086b4a; background: var(--good-soft); }
.form-message.error { color: #a72d2d; background: var(--bad-soft); }

.configuration-page { display: grid; place-items: center; min-height: 100vh; padding: 2rem; }
.configuration-card { width: min(100%,42rem); padding: clamp(1.5rem,5vw,3rem); border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: var(--shadow); }
.configuration-card h1 { margin: 1.3rem 0 .7rem; letter-spacing: -.035em; }
.configuration-card p, .configuration-card li { color: var(--ink-700); line-height: 1.65; }

.app-shell { display: grid; grid-template-columns: 17rem minmax(0,1fr); min-height: 100vh; }
.sidebar { position: sticky; top: 0; display: flex; flex-direction: column; height: 100vh; padding: 1.1rem; color: white; background: linear-gradient(180deg,rgba(11,20,38,.99),rgba(7,16,31,1)); }
.sidebar-brand { padding: .4rem .25rem 1.5rem; }
.sidebar-nav { display: grid; gap: .3rem; }
.sidebar-nav a { display: flex; align-items: center; gap: .8rem; padding: .78rem .85rem; border-radius: 10px; color: rgba(255,255,255,.66); font-weight: 650; }
.sidebar-nav a:hover, .sidebar-nav a.active { color: white; background: rgba(255,255,255,.09); }
.nav-icon { display: grid; place-items: center; width: 1.25rem; font-size: .95rem; }
.sidebar-footer { display: grid; gap: .65rem; margin-top: auto; }
.portal-switch { padding: .72rem; border: 1px solid rgba(255,255,255,.13); border-radius: 10px; color: #aecdff; text-align: center; font-weight: 700; }
.workspace { min-width: 0; }
.topbar { position: sticky; z-index: 20; top: 0; display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 5rem; padding: .9rem clamp(1rem,3vw,2.25rem); border-bottom: 1px solid rgba(223,230,239,.9); background: rgba(255,255,255,.92); backdrop-filter: blur(14px); }
.topbar-title h1 { margin: 0; font-size: 1.45rem; letter-spacing: -.035em; }
.topbar-title p { margin: .22rem 0 0; color: var(--ink-500); font-size: .84rem; }
.topbar-controls { display: flex; align-items: center; gap: .65rem; }
.compact-select { max-width: 18rem; min-height: 2.4rem; padding: .45rem .7rem; font-size: .82rem; }
.organisation-label, .user-chip { padding: .55rem .75rem; border: 1px solid var(--line); border-radius: 999px; color: var(--ink-700); background: white; font-size: .78rem; font-weight: 700; }
.user-chip { max-width: 15rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mobile-menu { display: none; }
.preview-banner { padding: .8rem clamp(1rem,3vw,2.25rem); border-bottom: 1px solid #f2d79e; color: #7a5000; background: var(--warn-soft); font-size: .86rem; }
.content-area { display: grid; gap: 1.25rem; padding: clamp(1rem,3vw,2.25rem); }

.page-actions { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.page-actions h2 { margin: 0; font-size: 1.65rem; letter-spacing: -.04em; }
.action-row { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.metric-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: .9rem; }
.metric-grid.compact { grid-template-columns: repeat(6,minmax(0,1fr)); }
.metric-card { min-width: 0; padding: 1.15rem; border: 1px solid var(--line); border-radius: var(--radius-sm); background: white; box-shadow: 0 8px 28px rgba(18,32,58,.045); }
.metric-card.metric-danger { border-color: #f4caca; background: linear-gradient(180deg,white,#fff8f8); }
.metric-label { overflow: hidden; color: var(--ink-500); font-size: .76rem; font-weight: 750; text-overflow: ellipsis; text-transform: uppercase; white-space: nowrap; }
.metric-value { margin-top: .45rem; font-size: clamp(1.45rem,3vw,2.25rem); font-weight: 820; letter-spacing: -.05em; }
.metric-hint { margin-top: .35rem; color: var(--ink-500); font-size: .76rem; }
.dashboard-columns { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 1.1rem; }
.panel { min-width: 0; padding: 1.25rem; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: 0 10px 35px rgba(18,32,58,.045); }
.panel-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
.panel-header h3 { margin: 0; font-size: 1.15rem; letter-spacing: -.025em; }
.panel-header > span { color: var(--ink-500); font-size: .82rem; }
.inline-link { display: inline-block; margin-top: 1rem; color: var(--primary); font-weight: 750; }

.status-pill { display: inline-flex; align-items: center; width: fit-content; padding: .28rem .55rem; border-radius: 999px; font-size: .7rem; font-weight: 800; letter-spacing: .01em; text-transform: capitalize; }
.status-good { color: #08704d; background: var(--good-soft); }
.status-warn { color: #865200; background: var(--warn-soft); }
.status-bad { color: #a82f2f; background: var(--bad-soft); }
.status-muted { color: #647186; background: #edf1f5; }
.status-info { color: #345b94; background: var(--info-soft); }

.issue-list { display: grid; gap: .65rem; margin: 0; padding: 0; list-style: none; }
.issue-list li { display: flex; align-items: flex-start; gap: .75rem; padding: .7rem; border: 1px solid var(--line); border-radius: 10px; background: #fbfcfe; }
.issue-list strong, .issue-list span { display: block; }
.issue-list span { margin-top: .2rem; color: var(--ink-500); font-size: .78rem; line-height: 1.45; }
.definition-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: .8rem; margin: 0; }
.definition-grid > div { min-width: 0; padding: .75rem; border: 1px solid var(--line); border-radius: 10px; background: #fbfcfe; }
.definition-grid dt { margin-bottom: .25rem; color: var(--ink-500); font-size: .72rem; font-weight: 750; text-transform: uppercase; }
.definition-grid dd { margin: 0; overflow-wrap: anywhere; font-weight: 700; }
.capability-grid, .settings-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: .7rem; }
.capability-item, .setting-item, .check-row { display: flex; align-items: center; justify-content: space-between; gap: .65rem; padding: .75rem; border: 1px solid var(--line); border-radius: 10px; background: #fbfcfe; font-size: .82rem; font-weight: 650; }

.filter-bar { display: grid; grid-template-columns: minmax(13rem,1fr) 12rem auto; gap: .6rem; width: min(100%,44rem); }
.result-count { color: var(--ink-500); font-size: .85rem; }
.table-panel { padding: 0; overflow: hidden; }
.table-panel .panel-header { padding: 1.25rem 1.25rem 0; }
.table-scroll { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: .83rem; }
th, td { padding: .85rem 1rem; border-bottom: 1px solid var(--line); text-align: left; vertical-align: middle; }
th { color: var(--ink-500); background: #f8fafc; font-size: .7rem; letter-spacing: .06em; text-transform: uppercase; white-space: nowrap; }
tbody tr:hover { background: #fafcff; }
.driver-name-link strong, .driver-name-link span, .table-subtext { display: block; }
.driver-name-link span, .table-subtext { margin-top: .18rem; color: var(--ink-500); font-size: .74rem; }

.driver-hero, .release-hero { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: clamp(1.25rem,3vw,2rem); border-radius: var(--radius); color: white; background: radial-gradient(circle at 85% 10%,rgba(78,144,255,.55),transparent 18rem), linear-gradient(135deg,#0b1426,#173768); box-shadow: var(--shadow); }
.driver-hero h2, .release-hero h2 { margin: 0; font-size: clamp(1.8rem,4vw,3rem); letter-spacing: -.05em; }
.driver-hero .eyebrow, .release-hero .eyebrow { color: #a8c8ff; }
.hero-meta { display: flex; align-items: center; gap: .65rem; margin-top: .8rem; color: rgba(255,255,255,.72); flex-wrap: wrap; }
.office-driver-hero .button-secondary { color: white; border-color: rgba(255,255,255,.2); background: rgba(255,255,255,.08); }
.stack-list { display: grid; gap: .7rem; }
.stack-card { display: grid; grid-template-columns: minmax(0,1fr) auto; gap: .9rem; padding: 1rem; border: 1px solid var(--line); border-radius: 12px; background: #fbfcfe; }
.stack-card > div:first-child span, .compact-card > div span { display: block; margin-top: .25rem; color: var(--ink-500); font-size: .78rem; }
.stack-card dl { grid-column: 1/-1; display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: .6rem; margin: 0; }
.stack-card dl div { padding: .55rem; border-radius: 8px; background: white; }
.stack-card dt { color: var(--ink-500); font-size: .68rem; text-transform: uppercase; }
.stack-card dd { margin: .2rem 0 0; font-size: .8rem; font-weight: 700; }
.compact-card { display: flex; align-items: center; justify-content: space-between; gap: .8rem; padding: .75rem; border: 1px solid var(--line); border-radius: 10px; background: #fbfcfe; }

.timeline { position: relative; display: grid; gap: .3rem; }
.timeline-item { position: relative; display: grid; grid-template-columns: 1rem minmax(0,1fr); gap: .75rem; padding: .7rem 0; }
.timeline-item::before { position: absolute; top: 1.65rem; bottom: -.65rem; left: .35rem; width: 1px; background: var(--line); content: ""; }
.timeline-item:last-child::before { display: none; }
.timeline-dot { z-index: 1; width: .72rem; height: .72rem; margin-top: .22rem; border: 2px solid white; border-radius: 50%; background: var(--primary); box-shadow: 0 0 0 2px #bdd0f5; }
.timeline-heading { display: flex; justify-content: space-between; gap: .8rem; }
.timeline-heading time, .timeline-item p, .timeline-item span { color: var(--ink-500); font-size: .75rem; }
.timeline-item p { margin: .28rem 0 .12rem; }

.finding-list { display: grid; gap: .85rem; }
.finding-card { padding: 1.1rem; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: 0 8px 28px rgba(18,32,58,.04); }
.finding-head { display: flex; justify-content: space-between; gap: 1rem; }
.finding-head h3 { margin: .55rem 0 .15rem; }
.finding-head p, .finding-count { margin: 0; color: var(--ink-500); font-size: .76rem; }
.finding-pills { display: flex; gap: .4rem; }
.compact-definitions { grid-template-columns: repeat(4,minmax(0,1fr)); margin-top: .85rem; }
.finding-card details { margin-top: .8rem; }
.finding-card summary { cursor: pointer; color: var(--primary); font-size: .8rem; font-weight: 750; }
.json-view { max-height: 22rem; overflow: auto; padding: .8rem; border-radius: 10px; color: #dce7fb; background: #0c1628; font-size: .72rem; line-height: 1.5; }
.finding-actions { display: flex; gap: .5rem; margin-top: .85rem; flex-wrap: wrap; }
.filter-toolbar { display: flex; align-items: center; justify-content: space-between; padding: .85rem 1rem; border: 1px solid var(--line); border-radius: 12px; background: white; }
.filter-toolbar span { display: block; margin-top: .2rem; color: var(--ink-500); font-size: .78rem; }

.release-hero p { max-width: 43rem; color: rgba(255,255,255,.72); }
.release-score, .driver-compliance-score { display: grid; place-items: center; min-width: 8rem; min-height: 8rem; padding: 1rem; border: 1px solid rgba(255,255,255,.18); border-radius: 50%; background: rgba(255,255,255,.08); text-align: center; }
.release-score strong, .driver-compliance-score strong { display: block; font-size: 2.35rem; line-height: 1; }
.release-score span, .driver-compliance-score span { display: block; margin-top: .25rem; color: rgba(255,255,255,.66); font-size: .75rem; }
.release-blocker-list, .check-list { display: grid; gap: .65rem; }
.release-blocker { display: flex; align-items: flex-start; gap: .75rem; padding: .8rem; border: 1px solid var(--line); border-radius: 10px; }
.release-blocker p { margin: .25rem 0; color: var(--ink-700); line-height: 1.45; }
.release-blocker span:last-child { color: var(--ink-500); font-size: .75rem; }
.callout { margin-top: 1rem; padding: .9rem 1rem; border-left: 4px solid var(--primary); border-radius: 0 10px 10px 0; background: var(--surface-blue); }
.callout p { margin: .3rem 0 0; color: var(--ink-700); }

.driver-shell { min-height: 100vh; }
.driver-topbar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 4.8rem; padding: .8rem clamp(1rem,4vw,3rem); color: white; background: var(--navy-900); }
.driver-actions { display: flex; align-items: center; gap: .6rem; }
.driver-content { display: grid; gap: 1.1rem; width: min(100%,82rem); margin: 0 auto; padding: clamp(1rem,4vw,3rem); }
.driver-page-title h1 { margin: 0; letter-spacing: -.04em; }
.driver-dashboard-grid { display: grid; grid-template-columns: minmax(0,1.45fr) minmax(20rem,.55fr); gap: 1rem; }
.driver-primary-card, .driver-side-card { padding: 1.35rem; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: 0 10px 35px rgba(18,32,58,.05); }
.driver-primary-card h3, .driver-side-card h3 { margin: 0; font-size: 1.35rem; }
.driver-primary-card > p, .driver-side-card > p { color: var(--ink-500); line-height: 1.55; }
.driver-primary-card .button { margin-top: 1rem; }

.empty-state { display: grid; place-items: center; padding: 1.5rem; color: var(--ink-500); text-align: center; }
.empty-state h3 { margin: .5rem 0 .25rem; color: var(--ink-900); }
.empty-state p { max-width: 30rem; margin: 0; line-height: 1.55; }
.empty-icon { display: grid; place-items: center; width: 2.6rem; height: 2.6rem; border-radius: 50%; color: var(--primary); background: var(--surface-blue); font-size: 1.2rem; }
.loading-state { min-height: 18rem; }
.spinner { width: 1.25rem; height: 1.25rem; border: 2px solid #d9e3f0; border-top-color: var(--primary); border-radius: 50%; animation: spin 700ms linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.error-panel { border-color: #f2c8c8; background: #fffafa; }
.toast-root { position: fixed; z-index: 100; right: 1rem; bottom: 1rem; display: grid; gap: .55rem; width: min(24rem,calc(100vw - 2rem)); }
.toast { padding: .85rem 1rem; border-radius: 10px; color: white; background: var(--navy-800); box-shadow: var(--shadow); transition: all 250ms ease; }
.toast-success { background: var(--good); }
.toast-error { background: var(--bad); }
.toast-out { opacity: 0; transform: translateY(.5rem); }

@media (max-width: 1180px) {
  .metric-grid, .metric-grid.compact { grid-template-columns: repeat(3,minmax(0,1fr)); }
  .capability-grid, .settings-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .compact-definitions { grid-template-columns: repeat(2,minmax(0,1fr)); }
}

@media (max-width: 900px) {
  .auth-page { grid-template-columns: 1fr; }
  .auth-visual { min-height: 34rem; }
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { position: fixed; z-index: 50; left: -18rem; width: 17rem; transition: left 180ms ease; }
  .sidebar.open { left: 0; box-shadow: 14px 0 50px rgba(7,16,31,.25); }
  .mobile-menu { display: inline-grid; place-items: center; width: 2.4rem; height: 2.4rem; border: 1px solid var(--line); border-radius: 9px; background: white; cursor: pointer; }
  .topbar-controls .user-chip { display: none; }
  .dashboard-columns, .driver-dashboard-grid { grid-template-columns: 1fr; }
  .stack-card dl { grid-template-columns: repeat(2,minmax(0,1fr)); }
}

@media (max-width: 680px) {
  .auth-panel { padding: 1.4rem; }
  .auth-feature-grid { grid-template-columns: 1fr; }
  .auth-copy h1 { font-size: 2.45rem; }
  .topbar { align-items: flex-start; }
  .topbar-controls { max-width: 45%; }
  .compact-select { max-width: 100%; }
  .content-area, .driver-content { padding: .85rem; }
  .page-actions, .driver-hero, .release-hero { align-items: flex-start; flex-direction: column; }
  .metric-grid, .metric-grid.compact { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .capability-grid, .settings-grid, .definition-grid, .compact-definitions { grid-template-columns: 1fr; }
  .filter-bar { grid-template-columns: 1fr; }
  .organisation-label { display: none; }
  .driver-actions .button-ghost { display: none; }
  .release-score, .driver-compliance-score { min-width: 6.5rem; min-height: 6.5rem; }
}

/* Package 24 — controlled write actions and launch controls */
.action-form { display: grid; gap: 1rem; }
.action-form label, .action-form fieldset { min-width: 0; }
.action-form label > span:first-child { display: block; margin-bottom: .42rem; color: var(--ink-700); font-size: .82rem; font-weight: 750; }
.action-form input:not([type="checkbox"]):not([type="radio"]),
.action-form select,
.action-form textarea {
  width: 100%;
  min-height: 2.75rem;
  padding: .72rem .82rem;
  border: 1px solid var(--line);
  border-radius: 10px;
  outline: none;
  color: var(--ink-900);
  background: white;
  font: inherit;
}
.action-form textarea { min-height: 6.5rem; resize: vertical; line-height: 1.5; }
.action-form input:focus, .action-form select:focus, .action-form textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37,99,235,.1);
}
.form-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: .85rem; }
.full-span { grid-column: 1 / -1; }
.dynamic-form { align-items: start; }
.dynamic-fieldset, .training-quiz fieldset {
  grid-column: 1 / -1;
  margin: 0;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fbfcfe;
}
.dynamic-fieldset legend, .training-quiz legend { padding: 0 .4rem; color: var(--ink-900); font-weight: 800; }
.checkbox-stack { display: grid; gap: .65rem; }
.checkbox-stack.two-columns { grid-template-columns: repeat(2,minmax(0,1fr)); }
.checkbox-card, .radio-card {
  display: flex !important;
  align-items: flex-start;
  gap: .7rem;
  padding: .8rem;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fbfcfe;
  cursor: pointer;
}
.checkbox-card input, .radio-card input { flex: 0 0 auto; width: 1rem; height: 1rem; margin-top: .14rem; accent-color: var(--primary); }
.checkbox-card span, .radio-card span { min-width: 0; margin: 0 !important; }
.checkbox-card strong { display: block; color: var(--ink-900); }
.checkbox-card small { display: block; margin-top: .25rem; color: var(--ink-500); line-height: 1.45; }
.action-panel { width: min(100%,68rem); margin-inline: auto; }
.action-card-list { display: grid; gap: .9rem; }
.action-record { padding: 1rem; border: 1px solid var(--line); border-radius: 12px; background: #fbfcfe; }
.action-record-head { display: flex; align-items: flex-start; justify-content: space-between; gap: .8rem; margin-bottom: .85rem; }
.action-record-head h3, .action-record-head h4 { margin: 0; }
.action-record-head p { margin: .25rem 0 0; color: var(--ink-500); }
.document-content { max-height: 28rem; overflow: auto; margin-bottom: 1rem; padding: 1rem; border: 1px solid var(--line); border-radius: 12px; background: #fbfcfe; white-space: pre-wrap; line-height: 1.65; }
.training-quiz { gap: 1.1rem; }
.training-quiz fieldset { display: grid; gap: .6rem; }
.declaration-list { display: grid; gap: .55rem; margin: 0 0 1rem; padding-left: 1.4rem; color: var(--ink-700); line-height: 1.55; }
.launch-columns { align-items: start; }
.action-form details, .panel details { margin-top: .75rem; }
.action-form summary, .panel summary { cursor: pointer; color: var(--primary); font-weight: 750; }

@media (max-width: 900px) {
  .form-grid, .checkbox-stack.two-columns { grid-template-columns: 1fr; }
  .full-span { grid-column: auto; }
}

/* Package 24 — office TOTP MFA gate */
.mfa-page { background: linear-gradient(145deg,#f8fbff 0%,#edf3fb 100%); }
.mfa-card { width: min(100%,48rem); }
.mfa-card-head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; }
.mfa-card-head h1 { margin: .2rem 0 0; }
.mfa-card .auth-form { width: 100%; }
.mfa-enrollment { display: grid; grid-template-columns: minmax(11rem,15rem) 1fr; align-items: center; gap: 1.5rem; margin-bottom: 1.4rem; }
.mfa-qr-wrap { display: grid; place-items: center; padding: .75rem; border: 1px solid var(--line); border-radius: 14px; background: white; }
.mfa-qr { display: block; width: 100%; max-width: 14rem; aspect-ratio: 1; }
.mfa-secret-label { margin-bottom: .35rem !important; font-size: .78rem; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; }
.mfa-secret { display: block; max-width: 100%; padding: .7rem; border-radius: 9px; overflow-wrap: anywhere; background: var(--surface-blue); color: var(--navy-800); }
.mfa-error { margin-bottom: 1rem; padding: .8rem 1rem; border: 1px solid #efb5b5; border-radius: 10px; color: #8f1f1f; background: #fff5f5; }
.mfa-footer { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-top: 1.5rem; padding-top: 1rem; border-top: 1px solid var(--line); color: var(--ink-500); }
@media (max-width: 680px) {
  .mfa-enrollment { grid-template-columns: 1fr; }
  .mfa-qr-wrap { width: min(100%,16rem); margin-inline: auto; }
  .mfa-footer { align-items: stretch; flex-direction: column; }
}
