.bos-academy-tool {
  --bos-ink: #21334d;
  --bos-muted: #657387;
  --bos-blue: #154b86;
  --bos-blue-strong: #0d345f;
  --bos-red: #c94b35;
  --bos-paper: #fffdfa;
  --bos-surface: #f5f1e8;
  --bos-surface-strong: #ede5d7;
  --bos-line: rgba(33, 51, 77, 0.14);
  --bos-radius: 22px;
  --bos-shadow: 0 22px 52px rgba(25, 34, 46, 0.1);
  --bos-font: "Poppins", "Aptos", "Segoe UI", sans-serif;
  background: linear-gradient(180deg, rgba(245, 241, 232, 0.72), rgba(255, 253, 250, 0.96));
  color: var(--bos-ink);
  font-family: var(--bos-font);
  isolation: isolate;
  position: relative;
}

.bos-academy-tool::before {
  background: linear-gradient(90deg, var(--bos-red), rgba(201, 75, 53, 0));
  content: "";
  height: 3px;
  inset: 0 0 auto;
  position: absolute;
  z-index: -1;
}

.bos-academy-tool *,
.bos-academy-tool *::before,
.bos-academy-tool *::after {
  box-sizing: border-box;
}

.bos-academy-tool--plain {
  --bos-paper: transparent;
  --bos-shadow: none;
  background: transparent;
}

.bos-academy-tool--plain::before,
.bos-academy-tool--embedded::before {
  content: none;
}

.bos-academy-tool--compact {
  --bos-radius: 16px;
}

.bos-academy-shell {
  color: var(--bos-ink);
  margin: 0 auto;
  max-width: 1180px;
  padding: clamp(24px, 4vw, 52px) 20px clamp(40px, 6vw, 74px);
}

.bos-academy-shell--embedded {
  max-width: none;
  padding: 0;
}

.bos-academy-shell--narrow {
  max-width: 780px;
}

.bos-academy-hero {
  display: grid;
  gap: 18px;
  margin-bottom: clamp(24px, 4vw, 40px);
  max-width: 760px;
  padding-bottom: clamp(22px, 4vw, 36px);
  position: relative;
}

.bos-academy-hero::after {
  background: linear-gradient(90deg, var(--bos-blue), rgba(21, 75, 134, 0));
  bottom: 0;
  content: "";
  height: 1px;
  left: 0;
  position: absolute;
  width: min(100%, 520px);
}

.bos-academy-brandline {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.bos-academy-brandline img {
  display: block;
  height: auto;
  max-width: 210px;
}

.bos-academy-brandline span,
.bos-academy-kicker {
  color: var(--bos-blue);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  line-height: 1.3;
  margin: 0;
  text-transform: uppercase;
}

.bos-academy-hero h1,
.bos-academy-panel h1,
.bos-academy-panel h2,
.bos-academy-panel h3,
.bos-academy-form h2 {
  color: var(--bos-ink);
  font-family: var(--bos-font);
  font-weight: 650;
  letter-spacing: -0.04em;
  line-height: 1.02;
  margin: 0;
  text-wrap: balance;
}

.bos-academy-hero h1 {
  font-size: clamp(2.25rem, 5vw, 4.35rem);
  max-width: 11.5ch;
}

.bos-academy-hero p,
.bos-academy-panel p,
.bos-academy-run p {
  color: var(--bos-muted);
  font-size: clamp(1rem, 1.3vw, 1.08rem);
  line-height: 1.65;
  margin: 0;
}

.bos-academy-run-grid {
  display: grid;
  gap: 0;
}

.bos-academy-run-grid--grid {
  gap: 20px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bos-academy-run-grid--compact .bos-academy-run {
  gap: 12px;
  padding-block: 14px;
}

.bos-academy-run {
  align-items: start;
  background: transparent;
  border-top: 1px solid var(--bos-line);
  display: grid;
  gap: clamp(18px, 2.5vw, 30px);
  grid-template-columns: 76px minmax(0, 1.08fr) minmax(260px, 0.82fr) minmax(132px, auto);
  padding: clamp(20px, 3vw, 30px) 0;
  position: relative;
  transition: border-color 0.18s ease, transform 0.18s ease;
}

.bos-academy-run:first-child {
  border-top: 0;
  padding-top: 0;
}

.bos-academy-run::before {
  background: var(--bos-red);
  content: "";
  height: calc(100% - 30px);
  left: -18px;
  opacity: 0;
  position: absolute;
  top: 15px;
  transform: scaleY(0.6);
  transform-origin: center;
  transition: opacity 0.18s ease, transform 0.18s ease;
  width: 3px;
}

.bos-academy-run:hover {
  border-color: rgba(21, 75, 134, 0.26);
  transform: translateX(4px);
}

.bos-academy-run:hover::before {
  opacity: 1;
  transform: scaleY(1);
}

.bos-academy-run-grid--grid .bos-academy-run {
  background: rgba(255, 253, 250, 0.76);
  border: 1px solid var(--bos-line);
  border-radius: var(--bos-radius);
  box-shadow: 0 16px 34px rgba(25, 34, 46, 0.07);
  grid-template-columns: 1fr;
  padding: 24px;
}

.bos-academy-run-grid--grid .bos-academy-run:first-child {
  border-top: 1px solid var(--bos-line);
  padding-top: 24px;
}

.bos-academy-run-grid--grid .bos-academy-run::before {
  inset: 0 auto 0 0;
  height: auto;
}

.bos-academy-run-thumb {
  align-self: start;
  aspect-ratio: 1;
  background: linear-gradient(135deg, rgba(21, 75, 134, 0.08), rgba(201, 75, 53, 0.1));
  border: 1px solid rgba(33, 51, 77, 0.1);
  border-radius: 16px;
  display: block;
  margin: 0;
  overflow: hidden;
  position: relative;
  width: 76px;
}

.bos-academy-run-thumb img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.bos-academy-run-thumb--empty {
  align-items: center;
  color: var(--bos-blue);
  display: flex;
  font-size: 1.45rem;
  font-weight: 800;
  justify-content: center;
  letter-spacing: -0.04em;
}

.bos-academy-run-grid--grid .bos-academy-run-thumb {
  border-radius: calc(var(--bos-radius) - 4px);
  margin-bottom: 2px;
  width: 100%;
}

.bos-academy-run-grid--grid .bos-academy-run-thumb:not(.bos-academy-run-thumb--empty) {
  aspect-ratio: 16 / 10;
}

.bos-academy-run-grid--compact .bos-academy-run {
  grid-template-columns: 58px minmax(0, 1fr) minmax(132px, auto);
}

.bos-academy-run-grid--compact .bos-academy-run-thumb {
  border-radius: 13px;
  width: 58px;
}

.bos-academy-run-grid--compact .bos-academy-meta {
  grid-column: 2 / 3;
}

.bos-academy-run-grid--compact .bos-academy-actions {
  grid-column: 3 / 4;
  grid-row: 1 / span 2;
}

.bos-academy-run__main {
  display: grid;
  gap: 9px;
  min-width: 0;
}

.bos-academy-run__main h2 {
  color: var(--bos-ink);
  font-size: clamp(1.32rem, 2.3vw, 1.8rem);
  letter-spacing: -0.035em;
  line-height: 1.05;
  margin: 0;
  overflow-wrap: anywhere;
  text-wrap: balance;
}

.bos-academy-course-image {
  border-radius: calc(var(--bos-radius) + 4px);
  margin: 0 0 26px;
  max-height: 420px;
  overflow: hidden;
  position: relative;
}

.bos-academy-course-image::after {
  background: linear-gradient(180deg, rgba(33, 51, 77, 0), rgba(33, 51, 77, 0.18));
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
}

.bos-academy-course-image img {
  aspect-ratio: 16 / 7;
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.bos-academy-detail-layout {
  display: grid;
  gap: 24px;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
  margin-bottom: 26px;
}

.bos-academy-panel,
.bos-academy-form {
  background: rgba(255, 253, 250, 0.88);
  border: 1px solid var(--bos-line);
  border-radius: var(--bos-radius);
  box-shadow: var(--bos-shadow);
  padding: clamp(20px, 3vw, 30px);
}

.bos-academy-panel {
  display: grid;
  gap: 16px;
}

.bos-academy-tool--embedded {
  background: transparent;
}

.bos-academy-tool--embedded .bos-academy-panel,
.bos-academy-tool--embedded .bos-academy-form,
.bos-academy-tool--embedded .bos-academy-filter {
  background: transparent;
  border-radius: 0;
  box-shadow: none;
}

.bos-academy-tool--embedded .bos-academy-form {
  border-top: 1px solid var(--bos-line);
  padding-top: 22px;
}

.bos-academy-meta {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0;
  min-width: 0;
}

.bos-academy-meta dt {
  color: var(--bos-blue);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.bos-academy-meta dd {
  color: var(--bos-ink);
  font-weight: 650;
  line-height: 1.35;
  margin: 4px 0 0;
  min-width: 0;
  overflow-wrap: anywhere;
}

.bos-academy-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-start;
  margin-top: 18px;
}

.bos-academy-actions--top {
  margin: 0 0 20px;
}

.bos-academy-button,
.bos-academy-form button,
.bos-academy-filter button {
  align-items: center;
  background: var(--bos-blue);
  border: 0;
  border-radius: 999px;
  color: #ffffff;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-weight: 800;
  justify-content: center;
  min-height: 44px;
  padding: 12px 19px;
  text-decoration: none;
  touch-action: manipulation;
  transition: transform 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}

.bos-academy-button:hover,
.bos-academy-form button:hover,
.bos-academy-filter button:hover {
  background: var(--bos-blue-strong);
  box-shadow: 0 14px 26px rgba(21, 75, 134, 0.18);
  color: #ffffff;
  transform: translateY(-1px);
}

.bos-academy-form button:disabled,
.bos-academy-filter button:disabled {
  cursor: wait;
  opacity: 0.72;
  transform: none;
}

.bos-academy-button:focus-visible,
.bos-academy-form button:focus-visible,
.bos-academy-filter button:focus-visible,
.bos-academy-form input:focus-visible,
.bos-academy-form textarea:focus-visible,
.bos-academy-filter input:focus-visible,
.bos-academy-filter select:focus-visible {
  outline: 3px solid rgba(21, 75, 134, 0.3);
  outline-offset: 2px;
}

.bos-academy-button--muted,
.bos-academy-button--ghost {
  background: transparent;
  border: 1px solid var(--bos-line);
  color: var(--bos-ink);
}

.bos-academy-button--muted:hover,
.bos-academy-button--ghost:hover {
  background: rgba(21, 75, 134, 0.06);
  box-shadow: none;
  color: var(--bos-ink);
}

.bos-academy-filter {
  background: transparent;
  border-bottom: 1px solid var(--bos-line);
  border-top: 1px solid var(--bos-line);
  box-shadow: none;
  display: grid;
  gap: 12px;
  margin-bottom: 24px;
  padding: 14px 0 15px;
}

.bos-academy-filter-grid,
.bos-academy-form-grid {
  display: grid;
  gap: 10px;
}

.bos-academy-filter-grid {
  align-items: end;
  grid-template-columns:
    minmax(160px, 1.1fr)
    minmax(124px, 0.78fr)
    minmax(124px, 0.78fr)
    minmax(118px, 0.66fr)
    minmax(118px, 0.66fr)
    minmax(138px, auto);
}

.bos-academy-form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bos-academy-form--stacked {
  display: grid;
  gap: 14px;
}

.bos-academy-form-grid__full {
  grid-column: 1 / -1;
}

.bos-academy-form label,
.bos-academy-filter label {
  color: var(--bos-ink);
  display: block;
  font-size: 0.82rem;
  font-weight: 800;
  margin: 0 0 6px;
}

.bos-academy-form input,
.bos-academy-form textarea,
.bos-academy-filter input,
.bos-academy-filter select {
  background: #ffffff;
  border: 1px solid rgba(33, 51, 77, 0.18);
  border-radius: 12px;
  color: var(--bos-ink);
  font: inherit;
  min-height: 42px;
  padding: 10px 12px;
  width: 100%;
}

.bos-academy-form textarea {
  min-height: 124px;
  resize: vertical;
}

.bos-academy-form input::placeholder,
.bos-academy-form textarea::placeholder,
.bos-academy-filter input::placeholder {
  color: rgba(101, 115, 135, 0.76);
}

.bos-academy-filter select {
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--bos-blue) 50%),
    linear-gradient(135deg, var(--bos-blue) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) 50%,
    calc(100% - 12px) 50%;
  background-repeat: no-repeat;
  background-size: 6px 6px, 6px 6px;
  padding-right: 34px;
}

.bos-academy-results[aria-busy="true"] {
  opacity: 0.62;
  transition: opacity 160ms ease;
}

.bos-academy-live-status {
  align-self: center;
  color: var(--bos-muted);
  font-size: 0.82rem;
  min-height: 1.2em;
}

.bos-academy-checkbox {
  align-items: center;
  display: flex;
  gap: 9px;
  min-height: 42px;
}

.bos-academy-checkbox input {
  accent-color: var(--bos-blue);
  flex: 0 0 auto;
  height: 17px;
  width: 17px;
}

.bos-academy-checkbox span {
  line-height: 1.2;
}

.bos-academy-consent,
.bos-academy-muted {
  color: var(--bos-muted);
  font-size: 0.94rem;
  line-height: 1.6;
}

.bos-academy-schedule {
  display: grid;
  gap: 14px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.bos-academy-schedule li {
  border-bottom: 1px solid var(--bos-line);
  padding-bottom: 14px;
}

.bos-academy-schedule li:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.bos-academy-schedule strong {
  color: var(--bos-ink);
}

.bos-academy-schedule span {
  color: var(--bos-muted);
  display: block;
  margin-top: 6px;
}

.bos-academy-notice {
  border-radius: var(--bos-radius);
  margin: 0 0 22px;
  padding: 17px 19px;
}

.bos-academy-notice p {
  margin: 0;
}

.bos-academy-notice--action {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: space-between;
}

.bos-academy-notice--action .bos-academy-button {
  flex: 0 0 auto;
}

.bos-academy-notice--error {
  background: #fde8e5;
  color: #7d231b;
}

.bos-academy-notice--warning {
  background: #fff3d6;
  color: #74520f;
}

.bos-academy-notice--info {
  background: #e8f2ef;
  color: #194539;
}

.bos-academy-location-panel {
  align-items: stretch;
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 0.68fr);
  margin-bottom: 26px;
  overflow: hidden;
}

.bos-academy-location-panel address {
  color: var(--bos-muted);
  font-style: normal;
  line-height: 1.55;
  white-space: pre-line;
}

.bos-academy-location-panel__privacy {
  grid-column: 1 / -1;
}

.bos-academy-map-preview {
  background:
    linear-gradient(135deg, rgba(21, 75, 134, 0.14) 0 2px, transparent 2px 40px),
    linear-gradient(45deg, transparent 0 46%, rgba(201, 75, 53, 0.35) 46% 48%, transparent 48% 100%),
    linear-gradient(180deg, rgba(237, 229, 215, 0.82), rgba(255, 253, 250, 0.92));
  border: 1px solid var(--bos-line);
  border-radius: calc(var(--bos-radius) - 4px);
  min-height: 210px;
  position: relative;
}

.bos-academy-map-preview span {
  background: var(--bos-red);
  border: 5px solid #ffffff;
  border-radius: 999px 999px 999px 0;
  box-shadow: 0 16px 30px rgba(33, 51, 77, 0.2);
  height: 32px;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -70%) rotate(-45deg);
  width: 32px;
}

.bos-academy-request-band {
  align-items: center;
  border-top: 1px solid var(--bos-line);
  display: flex;
  gap: 18px;
  justify-content: space-between;
  margin-top: 28px;
  padding-top: 24px;
}

.bos-academy-request-band h2 {
  color: var(--bos-ink);
  font-size: clamp(1.35rem, 2vw, 2rem);
  letter-spacing: -0.035em;
  line-height: 1.08;
  margin: 0;
}

.bos-academy-request-band p {
  color: var(--bos-muted);
  margin: 7px 0 0;
}

.bos-academy-legal {
  border-top: 1px solid var(--bos-line);
  display: grid;
  gap: 9px;
  padding-top: 14px;
}

.bos-academy-legal p {
  color: var(--bos-muted);
  font-size: 0.94rem;
  line-height: 1.55;
  margin: 0;
}

.bos-academy-legal a {
  color: var(--bos-blue);
  font-weight: 800;
}

.bos-academy-legal-document {
  gap: 18px;
}

.bos-academy-legal-document h1,
.bos-academy-legal-document h2,
.bos-academy-legal-document h3 {
  color: var(--bos-ink);
  letter-spacing: -0.03em;
  line-height: 1.12;
  margin: 0.95em 0 0.35em;
}

.bos-academy-legal-document h1:first-child,
.bos-academy-legal-document h2:first-child,
.bos-academy-legal-document h3:first-child {
  margin-top: 0;
}

.bos-academy-legal-document p,
.bos-academy-legal-document li {
  color: var(--bos-muted);
  font-size: 1rem;
  line-height: 1.72;
}

.bos-academy-legal-document p {
  margin: 0 0 0.9em;
}

.bos-academy-legal-document ul,
.bos-academy-legal-document ol {
  display: grid;
  gap: 8px;
  margin: 0 0 1em 1.15em;
  padding: 0;
}

.bos-academy-legal-document a {
  color: var(--bos-blue);
  font-weight: 800;
}

.bos-academy-legal-document__meta {
  background: rgba(21, 75, 134, 0.06);
  border: 1px solid rgba(21, 75, 134, 0.12);
  border-radius: 999px;
  color: var(--bos-blue) !important;
  display: inline-flex;
  font-size: 0.84rem !important;
  font-weight: 800;
  margin: 0 !important;
  padding: 8px 12px;
  width: fit-content;
}

.bos-academy-legal-document__content {
  display: flow-root;
}

.bos-academy-checkout-summary {
  background: rgba(21, 75, 134, 0.06);
  border: 1px solid rgba(21, 75, 134, 0.16);
  border-radius: calc(var(--bos-radius) - 8px);
  display: grid;
  gap: 12px;
  padding: 18px;
}

.bos-academy-checkout-summary h3 {
  color: var(--bos-ink);
  font-size: clamp(1.08rem, 2vw, 1.28rem);
  margin: 0;
}

.bos-academy-checkout-summary dl {
  display: grid;
  gap: 8px;
  margin: 0;
}

.bos-academy-checkout-summary dl > div {
  display: grid;
  gap: 6px;
  grid-template-columns: minmax(120px, 0.42fr) 1fr;
}

.bos-academy-checkout-summary dt {
  color: var(--bos-muted);
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.bos-academy-checkout-summary dd {
  color: var(--bos-ink);
  font-weight: 750;
  margin: 0;
}

.bos-academy-panel--success {
  background:
    linear-gradient(90deg, rgba(21, 75, 134, 0.1), rgba(21, 75, 134, 0)),
    rgba(255, 253, 250, 0.94);
  border-color: rgba(21, 75, 134, 0.2);
}

.bos-academy-certificate-result {
  background:
    linear-gradient(135deg, rgba(21, 75, 134, 0.12), rgba(255, 253, 250, 0.96) 44%),
    var(--bos-paper);
  overflow: hidden;
  padding-left: clamp(24px, 5vw, 42px);
  position: relative;
}

.bos-academy-certificate-result::before {
  background: var(--bos-red);
  content: "";
  inset: 0 auto 0 0;
  position: absolute;
  width: 5px;
}

.bos-academy-certificate-result--warning {
  background:
    linear-gradient(135deg, rgba(201, 75, 53, 0.16), rgba(255, 243, 214, 0.92) 44%),
    var(--bos-paper);
  border-color: rgba(201, 75, 53, 0.34);
  padding-bottom: clamp(28px, 5vw, 44px);
  padding-top: clamp(28px, 5vw, 44px);
}

.bos-academy-certificate-result--warning::before {
  background: var(--bos-red);
  width: 8px;
}

.bos-academy-certificate-result--warning h2 {
  color: #7d231b;
  font-size: clamp(1.55rem, 3vw, 2.55rem);
  max-width: 14ch;
}

.bos-academy-certificate-result--warning .bos-academy-kicker {
  color: #7d231b;
}

.bos-academy-certificate-result--warning .bos-academy-certificate-result__seal {
  border-color: rgba(201, 75, 53, 0.34);
}

.bos-academy-certificate-result--warning .bos-academy-certificate-result__seal::after {
  color: var(--bos-red);
  content: "!";
  font-size: 44px;
  transform: translate(-50%, -56%);
}

.bos-academy-certificate-result__seal {
  border: 2px solid rgba(21, 75, 134, 0.22);
  border-radius: 999px;
  height: 74px;
  opacity: 0.75;
  position: absolute;
  right: 22px;
  top: 22px;
  width: 74px;
}

.bos-academy-certificate-result__seal::after {
  color: var(--bos-blue);
  content: "\2713";
  font-size: 34px;
  font-weight: 900;
  inset: 50% auto auto 50%;
  position: absolute;
  transform: translate(-50%, -55%);
}

.bos-academy-field-error {
  color: var(--bos-red);
  font-weight: 800;
}

.bos-academy-hp {
  height: 0;
  left: -10000px;
  overflow: hidden;
  position: absolute;
  top: auto;
  width: 1px;
}

.bos-academy-validation-shell {
  display: grid;
  gap: 18px;
}

.bos-academy-tool[data-bos-mode="divi"] {
  background: transparent;
  position: relative;
}

.bos-academy-tool[data-bos-mode="divi"] .bos-academy-run-grid {
  gap: 8px;
}

.bos-academy-tool[data-bos-mode="divi"] .bos-academy-filter {
  backdrop-filter: none;
  background: transparent;
  border-bottom: 1px solid var(--bos-line);
  border-left: 0;
  border-radius: 0;
  border-right: 0;
  border-top: 1px solid var(--bos-line);
  box-shadow: none;
  position: sticky;
  top: 0;
  z-index: 2;
}

.bos-academy-tool[data-bos-mode="divi"] .bos-academy-panel,
.bos-academy-tool[data-bos-mode="divi"] .bos-academy-form {
  background: rgba(255, 253, 250, 0.78);
}

@keyframes bos-academy-rise {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.bos-academy-tool {
  animation: bos-academy-rise 0.34s ease both;
}

@media (prefers-reduced-motion: reduce) {
  .bos-academy-tool,
  .bos-academy-run,
  .bos-academy-run::before,
  .bos-academy-button,
  .bos-academy-form button,
  .bos-academy-filter button {
    animation: none;
    transition: none;
  }
}

@media (max-width: 920px) {
  .bos-academy-detail-layout,
  .bos-academy-location-panel,
  .bos-academy-form-grid,
  .bos-academy-meta,
  .bos-academy-run-grid--grid {
    grid-template-columns: 1fr;
  }

  .bos-academy-filter-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .bos-academy-shell {
    padding: 28px 16px 52px;
  }

  .bos-academy-run {
    grid-template-columns: 64px minmax(0, 1fr);
    transform: none;
  }

  .bos-academy-run-thumb {
    border-radius: 14px;
    width: 64px;
  }

  .bos-academy-run__main {
    grid-column: 2 / 3;
  }

  .bos-academy-run .bos-academy-meta,
  .bos-academy-run .bos-academy-actions {
    grid-column: 1 / -1;
  }

  .bos-academy-run-grid--grid .bos-academy-run {
    grid-template-columns: 1fr;
  }

  .bos-academy-run-grid--grid .bos-academy-run-thumb {
    width: 100%;
  }

  .bos-academy-hero h1 {
    max-width: 12.5ch;
  }

  .bos-academy-brandline img {
    max-width: 176px;
  }

  .bos-academy-run::before {
    left: -10px;
  }

  .bos-academy-tool[data-bos-mode="divi"] .bos-academy-filter {
    position: static;
  }

  .bos-academy-checkbox {
    margin-top: 0;
  }

  .bos-academy-certificate-result__seal {
    height: 56px;
    opacity: 0.45;
    width: 56px;
  }

  .bos-academy-request-band {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 640px) {
  .bos-academy-filter-grid {
    grid-template-columns: 1fr;
  }

  .bos-academy-filter-actions,
  .bos-academy-notice--action,
  .bos-academy-request-band {
    align-items: stretch;
    flex-direction: column;
  }

  .bos-academy-filter-actions .bos-academy-button,
  .bos-academy-filter-actions button,
  .bos-academy-notice--action .bos-academy-button,
  .bos-academy-request-band .bos-academy-button {
    width: 100%;
  }

  .bos-academy-course-image img {
    aspect-ratio: 4 / 3;
  }

  .bos-academy-run {
    grid-template-columns: 56px minmax(0, 1fr);
  }

  .bos-academy-run-thumb {
    width: 56px;
  }

  .bos-academy-run-grid--grid .bos-academy-run-thumb {
    width: 100%;
  }
}
