/* ─── Trainer Portal — Backstage Runbook Theme ─────────────────────── */
/* Slate / teal · IBM Plex + JetBrains Mono · distinct from student blue */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500&family=IBM+Plex+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ── Colour tokens ──────────────────────────────────────────────── */
:root {
  --trainer-accent: #0f766e;
  --trainer-accent-light: #14b8a6;
  --trainer-accent-bg: #f0fdfa;
  --trainer-border: #99f6e4;
  --trainer-badge-bg: #134e4a;
  --trainer-badge-text: #ccfbf1;
  --trainer-link: #0d9488;
  --trainer-header-bg: linear-gradient(135deg, #0f172a, #1e293b, #334155);
  --trainer-warn: #d97706;
  --trainer-warn-bg: #fffbeb;
  --trainer-surface: #ffffff;
  --trainer-font: "IBM Plex Sans", "Source Sans 3", -apple-system, BlinkMacSystemFont, sans-serif;
  --trainer-mono: "IBM Plex Mono", "JetBrains Mono", ui-monospace, monospace;
  --trainer-navbar-h: 56px;
}

/* ── Typography ─────────────────────────────────────────────────── */
html[data-trainer] body,
html[data-trainer] .navbar,
html[data-trainer] .sidebar,
html[data-trainer] .quarto-sidebar,
html[data-trainer] #quarto-content {
  font-family: var(--trainer-font) !important;
}

html[data-trainer] code,
html[data-trainer] pre,
html[data-trainer] kbd,
html[data-trainer] .sourceCode {
  font-family: var(--trainer-mono) !important;
}

/* ── Navbar ─────────────────────────────────────────────────────── */
html[data-trainer] .navbar,
html[data-trainer] nav.navbar {
  background: var(--trainer-header-bg) !important;
  border-bottom: 3px solid var(--trainer-accent-light) !important;
}
html[data-trainer] .navbar .navbar-brand,
html[data-trainer] .navbar .nav-link,
html[data-trainer] .navbar .navbar-title {
  color: #e2e8f0 !important;
}
html[data-trainer] .navbar .nav-link:hover {
  color: #fff !important;
}

@media (max-width: 768px) {
  html[data-trainer] .navbar {
    border-bottom: none !important;
  }
}

/* ── Facilitator bar (main content column only — scrolls with page) ─ */
.trainer-sticky-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.4rem 1rem;
  margin: 0 0 1.25rem;
  background: var(--trainer-badge-bg);
  color: var(--trainer-badge-text);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-bottom: 2px solid var(--trainer-accent-light);
  border-radius: 0 0 4px 4px;
  /* Static — sticky caused content to slide underneath while scrolling */
  position: relative;
  z-index: 1;
}
.trainer-sticky-bar-pulse {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--trainer-accent-light);
  box-shadow: 0 0 0 0 rgba(20, 184, 166, 0.6);
  animation: trainerPulse 2.4s ease infinite;
}
@keyframes trainerPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(20, 184, 166, 0.5); }
  50% { box-shadow: 0 0 0 6px rgba(20, 184, 166, 0); }
}

/* ── Sidebar ────────────────────────────────────────────────────── */
html[data-trainer] .sidebar,
html[data-trainer] .quarto-sidebar,
html[data-trainer] #quarto-sidebar {
  border-top: 3px solid var(--trainer-accent) !important;
}
html[data-trainer] .sidebar .sidebar-item-container a.active,
html[data-trainer] #quarto-sidebar a.sidebar-item-text.active {
  color: var(--trainer-accent) !important;
  font-weight: 700;
}

/* ── Page title ─────────────────────────────────────────────────── */
html[data-trainer] .page-header,
html[data-trainer] header.title {
  border-left: 5px solid var(--trainer-accent) !important;
  padding-left: 1.25rem;
  margin-bottom: 1.5rem;
}
html[data-trainer] h1.title {
  color: var(--trainer-accent) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em;
}
html[data-trainer] .subtitle {
  color: #475569;
  font-style: normal;
  font-weight: 500;
  font-size: 1.05rem;
}

/* ── Runbook phase header (checklist steps) ─────────────────────── */
.trainer-runbook-header {
  --step: 1;
  --total: 9;
  margin: 0 0 1.75rem;
  padding: 1rem 1.25rem;
  background: linear-gradient(135deg, #f0fdfa 0%, #ecfeff 55%, #f8fafc 100%);
  border: 1px solid var(--trainer-border);
  border-left: 4px solid var(--trainer-accent);
  border-radius: 8px;
}
.trainer-runbook-header[data-phase="2-weeks"] { border-left-color: var(--trainer-accent); }
.trainer-runbook-header[data-phase="1-week"] { border-left-color: #0891b2; }
.trainer-runbook-header[data-phase="day-before"] { border-left-color: var(--trainer-warn); background: linear-gradient(135deg, var(--trainer-warn-bg), #f8fafc); }
.trainer-runbook-header[data-phase="morning"] { border-left-color: #dc2626; background: linear-gradient(135deg, #fef2f2, #f8fafc); }
.trainer-runbook-header[data-phase="overview"] { border-left-color: var(--trainer-badge-bg); }

.trainer-runbook-header-top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-bottom: 0.65rem;
}
.trainer-phase-label {
  display: inline-block;
  padding: 0.2rem 0.65rem;
  background: var(--trainer-badge-bg);
  color: var(--trainer-badge-text);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-radius: 3px;
}
.trainer-runbook-header[data-phase="day-before"] .trainer-phase-label {
  background: #92400e;
  color: #fef3c7;
}
.trainer-runbook-header[data-phase="morning"] .trainer-phase-label {
  background: #991b1b;
  color: #fecaca;
}
.trainer-step-indicator {
  font-size: 0.85rem;
  font-weight: 600;
  color: #475569;
}
.trainer-step-indicator strong {
  color: var(--trainer-accent);
  font-size: 1rem;
}

.trainer-progress-track {
  height: 6px;
  background: #e2e8f0;
  border-radius: 99px;
  overflow: hidden;
}
.trainer-progress-fill {
  height: 100%;
  width: calc((var(--step) / var(--total)) * 100%);
  background: linear-gradient(90deg, var(--trainer-accent), var(--trainer-accent-light));
  border-radius: 99px;
  transition: width 0.35s ease;
}

/* ── Section headings ───────────────────────────────────────────── */
html[data-trainer] h2 {
  border-bottom: 2px solid var(--trainer-border);
  padding-bottom: 0.35rem;
  color: var(--trainer-accent);
  font-weight: 600;
}
html[data-trainer] h3 {
  color: var(--trainer-badge-bg);
  font-weight: 600;
}

/* ── Callouts ───────────────────────────────────────────────────── */
html[data-trainer] .callout-important {
  border-left-color: var(--trainer-accent) !important;
  background: var(--trainer-accent-bg) !important;
}
html[data-trainer] .callout-note {
  border-left-color: var(--trainer-badge-bg) !important;
}
html[data-trainer] .callout-tip {
  border-left-color: #15803d !important;
}
html[data-trainer] .callout-warning {
  border-left-color: #dc2626 !important;
}

/* ── Tables ─────────────────────────────────────────────────────── */
html[data-trainer] table thead th {
  background: var(--trainer-accent-bg);
  border-bottom: 2px solid var(--trainer-accent);
  color: var(--trainer-accent);
  font-weight: 600;
}
html[data-trainer] table tbody tr:hover {
  background: var(--trainer-accent-bg);
}

/* ── Role badges (facilitator tables) ───────────────────────────── */
html[data-trainer] .role-badge {
  display: inline-block;
  padding: 0.15rem 0.55rem;
  border-radius: 4px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
}
html[data-trainer] .role-lead {
  background: #1e293b;
  color: #f1f5f9;
}
html[data-trainer] .role-cotrainer {
  background: transparent;
  color: var(--trainer-accent);
  border: 1.5px solid var(--trainer-accent);
}

/* ── Checklist task rows ────────────────────────────────────────── */
html[data-trainer] ul.task-list {
  list-style: none;
  padding-left: 0;
  margin: 1rem 0;
}
html[data-trainer] ul.task-list > li.task-list-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.55rem 0.85rem;
  margin: 0.25rem 0;
  border-radius: 6px;
  border: 1px solid transparent;
  transition: background 0.15s, border-color 0.15s;
}
html[data-trainer] ul.task-list > li.task-list-item:hover {
  background: var(--trainer-accent-bg);
  border-color: var(--trainer-border);
}
html[data-trainer] ul.task-list li.task-list-item > input[type="checkbox"] {
  width: 1.2rem;
  height: 1.2rem;
  min-width: 1.2rem;
  margin-top: 0.15rem;
  accent-color: var(--trainer-accent);
  cursor: pointer;
}
html[data-trainer] ul.task-list li.task-list-item > label {
  flex: 1;
  cursor: pointer;
  line-height: 1.5;
}
html[data-trainer] ul.task-list li.task-list-item ul {
  margin-top: 0.35rem;
}

/* ── Trainer badge (in-content) ─────────────────────────────────── */
.trainer-badge-banner {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--trainer-badge-bg);
  color: var(--trainer-badge-text);
  padding: 4px 14px;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  margin-bottom: 0.75rem;
}

/* ── Next-step CTA ──────────────────────────────────────────────── */
.trainer-next-step {
  display: block;
  margin: 2rem 0 1rem;
  padding: 1rem 1.25rem 1rem 1rem;
  background: var(--trainer-accent-bg);
  border: 1px solid var(--trainer-border);
  border-left: 4px solid var(--trainer-accent);
  border-radius: 8px;
  text-decoration: none !important;
  color: inherit !important;
  transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
}
a.trainer-next-step:hover {
  transform: translateX(4px);
  box-shadow: 0 4px 14px rgba(15, 118, 110, 0.12);
  border-left-color: var(--trainer-accent-light);
}
.trainer-next-step-label {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--trainer-accent);
  margin-bottom: 0.35rem;
}
.trainer-next-step-title {
  display: block;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--trainer-badge-bg);
}
.trainer-next-step-hint {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.88rem;
  color: #64748b;
}
.trainer-next-step-arrow {
  float: right;
  font-size: 1.4rem;
  color: var(--trainer-accent-light);
  line-height: 1;
}

/* Non-link next-step wrapper (multiple links inside) */
.trainer-next-step-block {
  margin: 2rem 0 1rem;
  padding: 1rem 1.25rem;
  background: var(--trainer-accent-bg);
  border: 1px solid var(--trainer-border);
  border-left: 4px solid var(--trainer-accent);
  border-radius: 8px;
}
.trainer-next-step-block .trainer-next-step-label {
  margin-bottom: 0.5rem;
}

/* ── Trainer home dashboard ─────────────────────────────────────── */
.trainer-dashboard {
  margin: 1.5rem 0 2rem;
}
.trainer-dash-section {
  margin-bottom: 2rem;
}
.trainer-dash-section-title {
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #64748b !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 0 0.85rem !important;
}
.trainer-dash-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 0.85rem;
}
.trainer-dash-card {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: 1rem 1.1rem;
  background: var(--trainer-surface);
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  text-decoration: none !important;
  color: inherit !important;
  transition: border-color 0.15s, box-shadow 0.15s, transform 0.15s;
}
a.trainer-dash-card:hover {
  border-color: var(--trainer-accent-light);
  box-shadow: 0 6px 20px rgba(15, 118, 110, 0.1);
  transform: translateY(-2px);
}
.trainer-dash-card-primary {
  border-color: var(--trainer-accent);
  background: linear-gradient(145deg, #f0fdfa, #fff);
}
.trainer-dash-card-tag {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--trainer-accent);
}
.trainer-dash-card-tag-warn {
  color: var(--trainer-warn);
}
.trainer-dash-card-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--trainer-badge-bg);
  line-height: 1.3;
}
.trainer-dash-card-desc {
  font-size: 0.86rem;
  color: #64748b;
  line-height: 1.45;
  flex: 1;
}
.trainer-dash-card-external::after {
  content: " ↗";
  font-size: 0.8em;
  opacity: 0.5;
}

.trainer-rhythm-card {
  margin-top: 1.5rem;
  padding: 1.25rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
}
.trainer-rhythm-card h2 {
  margin-top: 0 !important;
}
.trainer-constraints {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 1rem 0;
}
.trainer-constraint-pill {
  padding: 0.35rem 0.75rem;
  background: var(--trainer-badge-bg);
  color: var(--trainer-badge-text);
  font-size: 0.8rem;
  font-weight: 600;
  border-radius: 99px;
}

/* ── Links ──────────────────────────────────────────────────────── */
html[data-trainer] #quarto-content a:not(.trainer-dash-card):not(.trainer-next-step) {
  color: var(--trainer-link);
}
html[data-trainer] #quarto-content a:not(.trainer-dash-card):not(.trainer-next-step):hover {
  color: var(--trainer-accent-light);
}

/* ── Code blocks ────────────────────────────────────────────────── */
html[data-trainer] code:not(.sourceCode) {
  color: var(--trainer-badge-bg);
  font-size: 0.9em;
}
html[data-trainer] pre {
  border-left: 3px solid var(--trainer-border);
}

/* ── Password gate ──────────────────────────────────────────────── */
.trainer-gate {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    linear-gradient(135deg, rgba(15, 23, 42, 0.97), rgba(30, 41, 59, 0.95)),
    repeating-linear-gradient(
      -45deg,
      transparent,
      transparent 12px,
      rgba(20, 184, 166, 0.03) 12px,
      rgba(20, 184, 166, 0.03) 24px
    );
  transition: opacity 0.4s ease;
}
.trainer-gate.unlocked {
  opacity: 0;
  pointer-events: none;
}
.trainer-gate-card {
  background: #1e293b;
  border: 1px solid #475569;
  border-top: 3px solid var(--trainer-accent-light);
  border-radius: 12px;
  padding: 2.5rem 2rem;
  max-width: 420px;
  width: 90%;
  text-align: center;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.55);
}
.trainer-gate-brand {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--trainer-accent-light);
  margin-bottom: 0.35rem;
}
.trainer-gate-card h2 {
  color: #f0fdfa !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  margin-bottom: 0.35rem !important;
  border: none !important;
  padding: 0 !important;
}
.trainer-gate-card .gate-subtitle {
  color: #94a3b8;
  font-size: 0.88rem;
  margin-bottom: 1.5rem;
  line-height: 1.45;
}
.trainer-gate-card .gate-icon {
  font-size: 2rem;
  margin-bottom: 0.75rem;
  opacity: 0.9;
}
.trainer-gate-error {
  color: #fca5a5;
  font-size: 0.85rem;
  margin-bottom: 0.5rem;
  min-height: 1.2em;
}
.trainer-gate-input {
  width: 100%;
  padding: 12px 16px;
  font-size: 1.1rem;
  font-family: var(--trainer-mono);
  text-align: center;
  letter-spacing: 0.08em;
  background: #0f172a;
  color: #5eead4;
  border: 2px solid #475569;
  border-radius: 8px;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  margin-bottom: 1rem;
  box-sizing: border-box;
}
.trainer-gate-input:focus {
  border-color: #14b8a6;
  box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.2);
}
.trainer-gate-input.error {
  border-color: #ef4444;
  animation: gateShake 0.4s ease;
}
@keyframes gateShake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-8px); }
  75% { transform: translateX(8px); }
}
.trainer-gate-btn {
  width: 100%;
  padding: 12px;
  font-size: 1rem;
  font-weight: 600;
  font-family: var(--trainer-font);
  background: #0f766e;
  color: #ccfbf1;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.2s;
}
.trainer-gate-btn:hover:not(:disabled) {
  background: #14b8a6;
}
.trainer-gate-btn:disabled {
  opacity: 0.6;
  cursor: wait;
}
.trainer-gate-hint {
  color: #64748b;
  font-size: 0.75rem;
  margin-top: 1rem;
  line-height: 1.4;
}

/* ── Dark mode ──────────────────────────────────────────────────── */
.quarto-dark {
  --trainer-accent: #2dd4bf;
  --trainer-accent-light: #5eead4;
  --trainer-accent-bg: rgba(45, 212, 191, 0.1);
  --trainer-border: rgba(45, 212, 191, 0.28);
  --trainer-link: #5eead4;
  --trainer-surface: #1e293b;
  --trainer-warn-bg: rgba(217, 119, 6, 0.12);
  --trainer-header-bg: linear-gradient(135deg, #020617, #0f172a, #1e293b);
}

.quarto-dark .trainer-runbook-header {
  background: linear-gradient(135deg, rgba(45, 212, 191, 0.08), rgba(15, 23, 42, 0.6));
  border-color: var(--trainer-border);
}
.quarto-dark .trainer-runbook-header[data-phase="day-before"] {
  background: linear-gradient(135deg, rgba(217, 119, 6, 0.1), rgba(15, 23, 42, 0.6));
}
.quarto-dark .trainer-runbook-header[data-phase="morning"] {
  background: linear-gradient(135deg, rgba(220, 38, 38, 0.08), rgba(15, 23, 42, 0.6));
}

.quarto-dark .trainer-phase-label {
  background: #134e4a;
  color: #ccfbf1;
}
.quarto-dark .trainer-step-indicator {
  color: #94a3b8;
}
.quarto-dark .trainer-step-indicator strong {
  color: var(--trainer-accent-light);
}
.quarto-dark .trainer-progress-track {
  background: #334155;
}

html.quarto-dark[data-trainer] .subtitle {
  color: #94a3b8 !important;
}
html.quarto-dark[data-trainer] h2 {
  color: var(--trainer-accent-light) !important;
}
html.quarto-dark[data-trainer] h3 {
  color: #99f6e4 !important;
}
html.quarto-dark[data-trainer] .trainer-badge-banner {
  background: #134e4a;
  color: #ccfbf1;
}

.quarto-dark .trainer-dash-card {
  background: #1e293b;
  border-color: #334155;
}
.quarto-dark a.trainer-dash-card:hover {
  border-color: var(--trainer-accent);
}
.quarto-dark .trainer-dash-card-primary {
  background: linear-gradient(145deg, rgba(45, 212, 191, 0.08), #1e293b);
}
.quarto-dark .trainer-dash-card-title {
  color: #f0fdfa;
}
.quarto-dark .trainer-dash-card-desc {
  color: #94a3b8;
}
.quarto-dark .trainer-dash-section-title {
  color: #94a3b8 !important;
}

.quarto-dark .trainer-next-step,
.quarto-dark .trainer-next-step-block {
  background: rgba(45, 212, 191, 0.08);
  border-color: var(--trainer-border);
}
.quarto-dark .trainer-next-step-title {
  color: #f0fdfa;
}
.quarto-dark .trainer-next-step-hint {
  color: #94a3b8;
}

html.quarto-dark[data-trainer] .role-lead {
  background: #334155;
  color: #f1f5f9;
}
html.quarto-dark[data-trainer] .role-cotrainer {
  color: var(--trainer-accent-light);
  border-color: var(--trainer-accent-light);
}

.quarto-dark .trainer-rhythm-card {
  background: #1e293b;
  border-color: #334155;
}

/* ── Checklist progress (local + D1 sync) ─────────────────────────── */
.trainer-checklist-status {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-top: 0.65rem;
  padding-top: 0.55rem;
  border-top: 1px solid var(--trainer-border, #e2e8f0);
  font-size: 0.82rem;
}

.trainer-checklist-status-text {
  font-weight: 600;
  color: var(--trainer-ink, #1e293b);
}

.trainer-checklist-status-text[data-storage="local"]::after {
  content: " · saved on this browser";
  font-weight: 400;
  color: #64748b;
}

.trainer-checklist-status-text[data-storage="cloud"]::after {
  content: " · synced to cloud";
  font-weight: 400;
  color: #0d9488;
}

.trainer-checklist-status-meta {
  color: #64748b;
}

.trainer-cohort-change {
  margin-left: 0.35rem;
  padding: 0.1rem 0.45rem;
  font-size: 0.72rem;
  border: 1px solid var(--trainer-border, #cbd5e1);
  border-radius: 4px;
  background: transparent;
  color: inherit;
  cursor: pointer;
}

.trainer-cohort-change:hover {
  border-color: var(--trainer-accent, #0d9488);
  color: var(--trainer-accent, #0d9488);
}

.trainer-checklist-summary {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--trainer-accent, #0f766e);
  margin: 0.35rem 0 1rem;
}

.trainer-page-progress {
  display: inline-block;
  margin-top: 0.25rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.trainer-page-progress[data-status="done"] {
  color: #0f766e;
}

.trainer-page-progress[data-status="partial"] {
  color: #b45309;
}

.trainer-page-progress[data-status="open"] {
  color: #64748b;
}

html[data-trainer] ul.task-list li.task-list-item:has(input[data-checklist-id]:checked) {
  opacity: 0.72;
  text-decoration: line-through;
  text-decoration-color: rgba(100, 116, 139, 0.45);
}

/* Dynamic fallback sidebar (legacy _sidebar-toggle) */
html[data-trainer] .sidebar-item-section .sidebar-section-text {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #64748b;
  padding: 0.65rem 0.5rem 0.25rem;
  margin-top: 0.35rem;
}

html.quarto-dark[data-trainer] .sidebar-item-section .sidebar-section-text {
  color: #94a3b8;
}

/* ── Print ──────────────────────────────────────────────────────── */
@media print {
  html[data-trainer] .navbar,
  html[data-trainer] .sidebar,
  html[data-trainer] #quarto-sidebar,
  html[data-trainer] .quarto-sidebar-toc,
  html[data-trainer] .trainer-badge-banner,
  html[data-trainer] .trainer-sticky-bar {
    display: none !important;
  }
  html[data-trainer] .page-columns.toc-left .column-body {
    margin-left: 0 !important;
  }
  html[data-trainer] .trainer-runbook-header {
    border: 1px solid #ccc;
    background: #f8f8f8 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  html[data-trainer] ul.task-list > li.task-list-item {
    break-inside: avoid;
    border: 1px solid #ddd;
    padding: 0.4rem 0.6rem;
  }
  html[data-trainer] ul.task-list li.task-list-item > input[type="checkbox"] {
    width: 14px;
    height: 14px;
    -webkit-appearance: none;
    appearance: none;
    border: 2px solid #333;
    border-radius: 2px;
    background: #fff;
  }
  html[data-trainer] .trainer-next-step,
  html[data-trainer] .trainer-next-step-block {
    border: 1px dashed #999;
    background: #f5f5f5 !important;
  }
}
