@font-face {
  font-display: swap;
  font-family: "Black Ops One";
  font-style: normal;
  font-weight: 400;
  src: url("../assets/fonts/black-ops-one.ttf") format("truetype");
}

/* Ridgeback visual system */
:root {
  --ridge-display-font: "Black Ops One", "Stencil", "Impact", system-ui, sans-serif;
  --ridge-ink: #101417;
  --ridge-panel: #172024;
  --ridge-panel-soft: #223035;
  --ridge-line: rgba(255, 255, 255, 0.14);
  --ridge-text: #f4f7f5;
  --ridge-muted: #b8c5c1;
  --ridge-cyan: #67d7dd;
  --ridge-orange: #e8752f;
  --ridge-orange-soft: #ffb072;
  --ridge-green: #86c96f;
  --ridge-radius: 0.4rem;
  --ridge-shadow: 0 1.1rem 2.6rem rgba(0, 0, 0, 0.22);
}

[data-md-color-scheme="default"] {
  --md-primary-fg-color: #19262b;
  --md-primary-fg-color--light: #2c4148;
  --md-accent-fg-color: #c9521f;
  --md-typeset-a-color: #ad4218;
}

[data-md-color-scheme="slate"] {
  --md-primary-fg-color: #121a1e;
  --md-primary-fg-color--light: #24333a;
  --md-accent-fg-color: #e8752f;
  --md-typeset-a-color: #72dce2;
}

.md-header,
.md-tabs {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.md-header__button.md-logo {
  margin: 0.22rem 0.35rem 0.22rem 0.2rem;
  padding: 0.12rem;
}

.md-nav__button.md-logo {
  margin: 0.25rem 0.45rem 0.25rem 0;
  padding: 0.12rem;
}

.md-header__button.md-logo img,
.md-header__button.md-logo svg,
.md-nav__button.md-logo img,
.md-nav__button.md-logo svg {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 50%;
  box-shadow: 0 0.45rem 1rem rgba(0, 0, 0, 0.18);
  display: block;
  height: 1.85rem;
  padding: 0.16rem;
  width: 1.85rem;
}

.md-nav__button.md-logo img,
.md-nav__button.md-logo svg {
  height: 1.65rem;
  width: 1.65rem;
}

.md-header__title,
.md-header__topic {
  font-family: var(--ridge-display-font);
  font-weight: 400;
  letter-spacing: 0;
}

.md-tabs {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--md-primary-fg-color), #000 6%), var(--md-primary-fg-color));
}

.md-tabs__link {
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0;
  opacity: 0.78;
  transition:
    color 160ms ease,
    opacity 160ms ease;
}

.md-tabs__link:hover,
.md-tabs__item--active .md-tabs__link {
  color: var(--ridge-orange-soft);
  opacity: 1;
}

.md-sidebar--secondary,
.md-nav--secondary,
.md-nav__link[for="__toc"] {
  display: none;
}

@media screen and (min-width: 76.25em) {
  .md-header__inner {
    gap: 0.45rem;
    margin-left: auto;
    margin-right: auto;
    max-width: 58rem;
  }

  .md-header__title {
    flex: 0 1 auto;
    max-width: 20rem;
    min-width: 15rem;
  }

  .md-header__button.md-logo img,
  .md-header__button.md-logo svg {
    height: 2.1rem;
    width: 2.1rem;
  }

  .md-tabs {
    display: none;
  }

  .ridge-header-nav {
    align-items: center;
    display: flex;
    flex: 1 1 auto;
    gap: 0.1rem;
    justify-content: flex-end;
    min-width: 0;
  }

  .ridge-header-nav__item {
    position: relative;
  }

  .ridge-header-nav__item::after {
    bottom: -0.45rem;
    content: "";
    height: 0.5rem;
    left: 0;
    position: absolute;
    right: 0;
  }

  .ridge-header-nav__link {
    align-items: center;
    border-radius: var(--ridge-radius);
    color: rgba(255, 255, 255, 0.8);
    display: inline-flex;
    font-size: 0.72rem;
    font-weight: 800;
    gap: 0.25rem;
    letter-spacing: 0;
    min-height: 2rem;
    padding: 0.38rem 0.5rem;
    text-decoration: none;
    transition:
      background-color 160ms ease,
      color 160ms ease;
    white-space: nowrap;
  }

  .ridge-header-nav__link:hover,
  .ridge-header-nav__link:focus-visible,
  .ridge-header-nav__item:focus-within > .ridge-header-nav__link,
  .ridge-header-nav__item:hover > .ridge-header-nav__link,
  .ridge-header-nav__link[aria-current="page"] {
    background: rgba(255, 255, 255, 0.08);
    color: var(--ridge-orange-soft);
  }

  .ridge-header-nav__link:focus-visible {
    outline: 3px solid var(--ridge-cyan);
    outline-offset: 2px;
  }

  .ridge-header-nav__chevron {
    border-bottom: 2px solid currentcolor;
    border-right: 2px solid currentcolor;
    display: inline-block;
    height: 0.36rem;
    margin-left: 0.08rem;
    transform: translateY(-0.08rem) rotate(45deg);
    transition: transform 160ms ease;
    width: 0.36rem;
  }

  .ridge-header-nav__item:hover .ridge-header-nav__chevron,
  .ridge-header-nav__item:focus-within .ridge-header-nav__chevron {
    transform: translateY(0.08rem) rotate(225deg);
  }

  .ridge-header-nav__menu {
    background: #172024;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--ridge-radius);
    box-shadow: var(--ridge-shadow);
    display: grid;
    gap: 0.15rem;
    left: 0;
    min-width: 11rem;
    opacity: 0;
    padding: 0.45rem;
    pointer-events: none;
    position: absolute;
    top: calc(100% + 0.08rem);
    transform: translateY(-0.25rem);
    transition:
      opacity 160ms ease,
      transform 160ms ease;
    z-index: 10;
  }

  .ridge-header-nav__item:hover .ridge-header-nav__menu,
  .ridge-header-nav__item:focus-within .ridge-header-nav__menu {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  .ridge-header-nav__menu a {
    border-radius: calc(var(--ridge-radius) - 0.1rem);
    color: rgba(255, 255, 255, 0.82);
    font-size: 0.72rem;
    font-weight: 800;
    padding: 0.52rem 0.6rem;
    text-decoration: none;
    white-space: nowrap;
  }

  .ridge-header-nav__menu a:hover,
  .ridge-header-nav__menu a:focus-visible,
  .ridge-header-nav__menu a[aria-current="page"] {
    background: rgba(232, 117, 47, 0.16);
    color: var(--ridge-orange-soft);
  }

  .ridge-header-nav__menu a:focus-visible {
    outline: 3px solid var(--ridge-cyan);
    outline-offset: 2px;
  }

  .md-tabs.ridge-tabs-inline {
    background: transparent;
    border-bottom: 0;
    box-shadow: none;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    position: static;
    z-index: auto;
  }

  .md-tabs.ridge-tabs-inline .md-grid {
    margin: 0;
    max-width: 100%;
  }

  .md-tabs.ridge-tabs-inline .md-tabs__list {
    justify-content: flex-start;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .md-tabs.ridge-tabs-inline .md-tabs__list::-webkit-scrollbar {
    display: none;
  }

  .md-tabs.ridge-tabs-inline .md-tabs__item {
    height: 2.4rem;
  }

  .md-tabs.ridge-tabs-inline .md-tabs__link {
    margin-top: 0.66rem;
    white-space: nowrap;
  }

  .md-sidebar--primary {
    display: none;
  }

  .md-main__inner.md-grid {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-top: 0.125rem;
    max-width: 58rem;
    width: 100%;
  }

  .md-content {
    max-width: 54rem;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
  }

  .md-content__inner {
    margin-top: 0;
    padding-top: 0;
  }

  .md-content__inner::before {
    display: none;
  }
}

@media screen and (max-width: 76.234375em) {
  .ridge-header-nav {
    display: none;
  }
}

.ridge-skip-link {
  background: var(--ridge-orange);
  border-radius: var(--ridge-radius);
  color: #ffffff;
  font-weight: 800;
  left: 1rem;
  padding: 0.6rem 0.85rem;
  position: absolute;
  top: 0.75rem;
  transform: translateY(-180%);
  transition: transform 160ms ease;
  z-index: 1000;
}

.ridge-skip-link:focus,
.ridge-skip-link:focus-visible {
  outline: 3px solid var(--ridge-cyan);
  outline-offset: 3px;
  transform: translateY(0);
}

#main-content:focus {
  outline: 0;
}

.md-typeset a:focus-visible,
.md-typeset button:focus-visible,
.md-typeset summary:focus-visible,
.md-typeset .md-button:focus-visible,
.ridge-featured-series__episodes a:focus-visible,
.ridge-social-row a:focus-visible,
.ridge-card-title a:focus-visible {
  outline: 3px solid var(--ridge-cyan);
  outline-offset: 3px;
}

.ridge-featured-series__episodes a:focus-visible,
.md-typeset .md-button:focus-visible {
  transform: translateY(-1px);
}

.md-typeset .md-button {
  align-items: center;
  border-radius: var(--ridge-radius);
  box-sizing: border-box;
  cursor: pointer;
  display: inline-flex;
  font-weight: 700;
  justify-content: center;
  letter-spacing: 0;
  min-height: 2.35rem;
  min-width: min(100%, 9.5rem);
  overflow-wrap: normal;
  position: relative;
  text-align: center;
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    color 160ms ease,
    transform 160ms ease;
  white-space: normal;
  word-break: normal;
  z-index: 0;
}

.md-typeset .md-button:hover {
  transform: translateY(-1px);
}

.md-typeset .md-button--primary {
  background-color: var(--ridge-orange);
  border-color: var(--ridge-orange);
  color: #ffffff;
}

.md-typeset .md-button--primary:hover {
  background-color: #ff8946;
  border-color: #ff8946;
}

.md-typeset .grid.cards > ul > li,
.md-typeset .grid.cards > ol > li {
  border-radius: var(--ridge-radius);
  box-shadow: none;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}

.md-typeset .grid.cards > ul > li:hover,
.md-typeset .grid.cards > ol > li:hover {
  border-color: color-mix(in srgb, var(--md-accent-fg-color), transparent 38%);
  box-shadow: 0 0.55rem 1.4rem rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}

/* Announcement */
.md-banner__inner {
  margin-bottom: 0.22rem;
  margin-top: 0.22rem;
}

.ridge-announce {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.6rem;
  justify-content: center;
  line-height: 1.25;
  text-align: center;
}

.ridge-announce__text {
  display: inline;
  font-size: 0.68rem;
  font-weight: 800;
  margin: 0;
}

.ridge-announce .md-button {
  display: inline-flex;
  font-size: 0.62rem;
  line-height: 1.1;
  min-width: 0;
  padding: 0.24rem 0.55rem;
}

/* Homepage */
.ridge-home {
  margin: -0.8rem auto 0;
}

.ridge-home *,
.ridge-training *,
.ridge-page *,
.ridge-events *,
.ridge-about * {
  box-sizing: border-box;
}

.ridge-home h1,
.ridge-home h2,
.ridge-home h3,
.ridge-training h1,
.ridge-training h2,
.ridge-training h3,
.ridge-about h1,
.ridge-about h2,
.ridge-about h3,
.ridge-events h1,
.ridge-events h2,
.ridge-events h3,
.ridge-page h1,
.ridge-page h2,
.ridge-page h3 {
  font-family: var(--ridge-display-font);
  font-weight: 400;
  letter-spacing: 0;
}

.ridge-home p,
.ridge-training p,
.ridge-about p,
.ridge-events p,
.ridge-page p {
  letter-spacing: 0;
}

.ridge-hero {
  align-items: stretch;
  background:
    linear-gradient(135deg, rgba(16, 20, 23, 0.94), rgba(24, 37, 42, 0.9)),
    radial-gradient(circle at 10% 15%, rgba(103, 215, 221, 0.22), transparent 28%),
    var(--ridge-ink);
  border: 1px solid var(--ridge-line);
  border-radius: 0.65rem;
  box-shadow: var(--ridge-shadow);
  color: var(--ridge-text);
  display: grid;
  gap: 0;
  grid-template-columns: 1fr;
  margin: 0 0 1.6rem;
  overflow: hidden;
}

.ridge-hero__copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 62rem;
  padding: clamp(1.4rem, 4vw, 3.2rem);
}

.ridge-brand-lockup {
  align-items: center;
  display: inline-flex;
  gap: 0.75rem;
  margin-bottom: 1.1rem;
  max-width: 100%;
}

.ridge-brand-lockup img {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 50%;
  box-shadow: 0 0.65rem 1.6rem rgba(0, 0, 0, 0.2);
  flex: 0 0 auto;
  height: clamp(3.2rem, 7vw, 4.4rem);
  padding: 0.32rem;
  width: clamp(3.2rem, 7vw, 4.4rem);
}

.ridge-brand-lockup span {
  display: grid;
  gap: 0.15rem;
  min-width: 0;
}

.ridge-brand-lockup strong {
  color: var(--ridge-text);
  font-family: var(--ridge-display-font);
  font-size: clamp(1rem, 1.6vw, 1.3rem);
  font-weight: 400;
  line-height: 1.1;
}

.ridge-brand-lockup small {
  color: var(--ridge-muted);
  font-size: 0.68rem;
  font-weight: 800;
  line-height: 1.25;
  text-transform: uppercase;
}

.ridge-kicker {
  color: var(--ridge-cyan);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  margin: 0 0 0.55rem;
  text-transform: uppercase;
}

.ridge-phrase {
  display: inline-block;
}

.ridge-hero h1 {
  color: var(--ridge-text);
  font-size: clamp(1.8rem, 2.55vw, 2.65rem);
  font-weight: 400;
  line-height: 1.02;
  margin: 0;
  max-width: 19ch;
}

.ridge-lede {
  color: var(--ridge-muted);
  font-size: clamp(0.88rem, 1.15vw, 1rem);
  line-height: 1.58;
  margin: 0.85rem 0 0;
  max-width: 42rem;
}

.ridge-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1.4rem;
}

.ridge-actions .md-button {
  flex: 0 0 auto;
}

.ridge-hero .md-button:not(.md-button--primary),
.ridge-training-hero .md-button:not(.md-button--primary),
.ridge-about-hero .md-button:not(.md-button--primary),
.ridge-events-hero .md-button:not(.md-button--primary),
.ridge-page-hero .md-button:not(.md-button--primary),
.ridge-featured-series .md-button:not(.md-button--primary),
.ridge-instructor .md-button:not(.md-button--primary),
.ridge-final-cta .md-button:not(.md-button--primary) {
  background-color: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.34);
  color: var(--ridge-text);
}

.ridge-hero .md-button:not(.md-button--primary):hover,
.ridge-training-hero .md-button:not(.md-button--primary):hover,
.ridge-about-hero .md-button:not(.md-button--primary):hover,
.ridge-events-hero .md-button:not(.md-button--primary):hover,
.ridge-page-hero .md-button:not(.md-button--primary):hover,
.ridge-featured-series .md-button:not(.md-button--primary):hover,
.ridge-instructor .md-button:not(.md-button--primary):hover,
.ridge-final-cta .md-button:not(.md-button--primary):hover {
  background-color: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.56);
  color: #ffffff;
}

.ridge-hero__media {
  height: clamp(18rem, 34vw, 30rem);
  position: relative;
}

.ridge-hero__media .glightbox {
  display: block;
  inset: 0;
  position: absolute;
}

.ridge-hero__media img {
  height: 100%;
  inset: 0;
  object-fit: cover;
  object-position: 54% 28%;
  position: absolute;
  width: 100%;
}

.ridge-hero__media::after {
  background:
    linear-gradient(90deg, rgba(16, 20, 23, 0.64), transparent 34%),
    linear-gradient(0deg, rgba(16, 20, 23, 0.38), transparent 45%);
  content: "";
  inset: 0;
  position: absolute;
}

.ridge-proof {
  background-color: color-mix(in srgb, var(--md-default-bg-color), var(--md-primary-fg-color) 6%);
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
  border-radius: var(--ridge-radius);
  display: grid;
  gap: 0;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 1.35rem 0 2rem;
  overflow: hidden;
}

.ridge-proof__item {
  padding: 1rem;
}

.ridge-proof__item + .ridge-proof__item {
  border-left: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
}

.ridge-proof strong {
  display: block;
  font-size: clamp(1.15rem, 2.3vw, 1.7rem);
  line-height: 1.1;
}

.ridge-proof span {
  color: var(--md-default-fg-color--light);
  display: block;
  font-size: 0.72rem;
  line-height: 1.4;
  margin-top: 0.25rem;
}

.ridge-section {
  margin: 2.4rem 0;
}

.ridge-section__header {
  margin-bottom: 1rem;
  max-width: 46rem;
}

.ridge-section__header h2 {
  font-size: clamp(1.45rem, 3vw, 2.25rem);
  margin: 0;
}

.ridge-section__header p {
  color: var(--md-default-fg-color--light);
  font-size: 0.95rem;
  line-height: 1.65;
  margin: 0.55rem 0 0;
}

.ridge-home-pathway {
  align-items: center;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-accent-fg-color) 7%), var(--md-default-bg-color));
  border: 1px solid color-mix(in srgb, var(--md-accent-fg-color), transparent 66%);
  border-radius: var(--ridge-radius);
  display: grid;
  gap: 0.85rem;
  grid-template-columns: repeat(2, minmax(0, 1fr)) auto;
  margin: 0 0 1rem;
  padding: 0.9rem 1rem;
}

.ridge-home-pathway div {
  min-width: 0;
}

.ridge-home-pathway span,
.ridge-home-pathway strong {
  display: block;
}

.ridge-home-pathway span {
  color: var(--md-default-fg-color--light);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.ridge-home-pathway strong {
  font-size: 1rem;
}

.ridge-course-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ridge-course-card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-primary-fg-color) 7%), var(--md-default-bg-color));
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  min-width: 0;
  padding: clamp(1rem, 2.4vw, 1.35rem);
}

.ridge-course-card h3 {
  font-size: 1.35rem;
  margin: 0;
}

.ridge-course-card p {
  margin: 0;
}

.ridge-course-card__meta {
  display: grid;
  gap: 0.55rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ridge-course-card__meta span,
.ridge-chip {
  background-color: color-mix(in srgb, var(--md-default-fg-color), transparent 94%);
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
  border-radius: 999rem;
  color: var(--md-default-fg-color--light);
  display: inline-flex;
  font-size: 0.7rem;
  font-weight: 700;
  justify-content: center;
  line-height: 1.25;
  padding: 0.42rem 0.6rem;
  text-align: center;
}

.ridge-course-card__price {
  color: var(--md-default-fg-color);
  font-size: 1.85rem;
  font-weight: 900;
  line-height: 1;
}

.ridge-course-card__footer {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  justify-content: space-between;
  margin-top: auto;
}

.ridge-resource-grid,
.ridge-feature-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ridge-feature,
.ridge-resource {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  min-width: 0;
  overflow-wrap: anywhere;
  padding: 1rem;
}

a.ridge-resource {
  color: inherit;
  cursor: pointer;
  text-decoration: none;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}

a.ridge-resource:hover,
a.ridge-resource:focus-visible {
  border-color: color-mix(in srgb, var(--md-accent-fg-color), transparent 45%);
  box-shadow: 0 0.75rem 1.5rem rgba(16, 20, 23, 0.12);
  color: inherit;
  transform: translateY(-1px);
}

a.ridge-resource:focus-visible {
  outline: 3px solid var(--ridge-cyan);
  outline-offset: 3px;
}

.ridge-feature strong,
.ridge-resource strong {
  display: block;
}

.ridge-feature p,
.ridge-resource p {
  color: var(--md-default-fg-color--light);
  font-size: 0.82rem;
  line-height: 1.55;
  margin: 0;
}

.ridge-resource span {
  color: var(--md-typeset-a-color);
  font-size: 0.78rem;
  font-weight: 800;
  margin-top: auto;
}

.ridge-instructor {
  align-items: stretch;
  background: var(--ridge-panel);
  border: 1px solid var(--ridge-line);
  border-radius: var(--ridge-radius);
  color: var(--ridge-text);
  display: grid;
  gap: 1.2rem;
  grid-template-columns: minmax(10rem, 0.55fr) minmax(0, 1.45fr);
  overflow: hidden;
}

.ridge-instructor img {
  aspect-ratio: 1;
  height: 100%;
  object-fit: cover;
  object-position: 50% 35%;
  width: 100%;
}

.ridge-instructor .glightbox {
  display: block;
  height: 100%;
  min-height: 100%;
}

.ridge-instructor__copy {
  padding: 1.25rem 1.25rem 1.25rem 0;
}

.ridge-instructor h2 {
  color: var(--ridge-text);
  margin-top: 0;
}

.ridge-instructor p {
  color: var(--ridge-muted);
}

.ridge-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.ridge-instructor .ridge-chip {
  background-color: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.14);
  color: var(--ridge-text);
}

.ridge-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.ridge-trust span {
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  color: var(--md-default-fg-color--light);
  display: flex;
  flex: 1 1 12rem;
  font-size: 0.74rem;
  font-weight: 800;
  justify-content: center;
  max-width: 18rem;
  min-height: 4rem;
  overflow-wrap: normal;
  padding: 0.75rem;
  text-align: center;
}

.ridge-final-cta {
  background:
    linear-gradient(135deg, rgba(16, 20, 23, 0.98), rgba(34, 48, 53, 0.98)),
    var(--ridge-ink);
  border: 1px solid var(--ridge-line);
  border-radius: 0.65rem;
  color: var(--ridge-text);
  margin: 2.5rem 0 0;
  padding: clamp(1.25rem, 4vw, 2rem);
}

.ridge-final-cta h2 {
  color: var(--ridge-text);
  margin: 0;
}

.ridge-final-cta p {
  color: var(--ridge-muted);
  margin: 0.55rem 0 0;
}

/* Training page */
.ridge-training {
  margin: -0.8rem auto 0;
}

.ridge-training-hero {
  align-items: stretch;
  background:
    linear-gradient(135deg, rgba(16, 20, 23, 0.95), rgba(31, 45, 50, 0.9)),
    var(--ridge-ink);
  border: 1px solid var(--ridge-line);
  border-radius: 0.65rem;
  box-shadow: var(--ridge-shadow);
  color: var(--ridge-text);
  display: grid;
  gap: 0;
  grid-template-columns: 1fr;
  margin-bottom: 1.4rem;
  overflow: hidden;
}

.ridge-training-hero__copy {
  align-self: center;
  max-width: 62rem;
  padding: clamp(1.4rem, 4vw, 3rem);
}

.ridge-training-hero h1 {
  color: var(--ridge-text);
  font-size: clamp(1.8rem, 2.45vw, 2.55rem);
  font-weight: 400;
  line-height: 1.03;
  margin: 0;
  max-width: 20ch;
}

.ridge-training-hero__media {
  height: clamp(18rem, 34vw, 30rem);
  position: relative;
}

.ridge-training-hero__media .glightbox {
  display: block;
  inset: 0;
  position: absolute;
}

.ridge-training-hero__media img {
  height: 100%;
  inset: 0;
  object-fit: cover;
  object-position: 42% 30%;
  position: absolute;
  width: 100%;
}

.ridge-training-hero__media::after {
  background: linear-gradient(90deg, rgba(16, 20, 23, 0.52), transparent 42%);
  content: "";
  inset: 0;
  position: absolute;
}

.ridge-training-note {
  background-color: color-mix(in srgb, var(--md-default-bg-color), var(--md-accent-fg-color) 7%);
  border: 1px solid color-mix(in srgb, var(--md-accent-fg-color), transparent 68%);
  border-radius: var(--ridge-radius);
  color: var(--md-default-fg-color);
  margin: 1rem 0 2rem;
  padding: 0.9rem 1rem;
}

.ridge-training-note p {
  margin: 0;
}

.ridge-course-picker {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 1rem 0 1.35rem;
}

.ridge-course-picker__card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-primary-fg-color) 7%), var(--md-default-bg-color));
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 84%);
  border-radius: var(--ridge-radius);
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  min-width: 0;
  padding: clamp(1rem, 2.4vw, 1.3rem);
}

.ridge-course-picker__card--accent {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-accent-fg-color) 9%), var(--md-default-bg-color));
  border-color: color-mix(in srgb, var(--md-accent-fg-color), transparent 56%);
}

.ridge-course-picker__card h3 {
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
  line-height: 1.2;
  margin: 0;
}

.ridge-course-picker__card p {
  color: var(--md-default-fg-color--light);
  line-height: 1.55;
  margin: 0;
}

.ridge-course-picker__card ul {
  margin: 0;
  padding-left: 1rem;
}

.ridge-course-picker__card li {
  margin-bottom: 0.35rem;
}

.ridge-course-picker__card .md-button {
  align-self: flex-start;
  margin-top: auto;
}

.ridge-compare {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  display: grid;
  grid-template-columns: minmax(8rem, 0.65fr) repeat(2, minmax(0, 1fr));
  margin-top: 1rem;
  overflow: hidden;
}

.ridge-compare div {
  border-bottom: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
  padding: 0.75rem 0.85rem;
}

.ridge-compare div:nth-child(3n + 2),
.ridge-compare div:nth-child(3n + 3) {
  border-left: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
}

.ridge-compare div:nth-last-child(-n + 3) {
  border-bottom: 0;
}

.ridge-compare__head {
  background-color: color-mix(in srgb, var(--md-default-bg-color), var(--md-primary-fg-color) 10%);
  font-weight: 900;
}

.ridge-training-course {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: 0.65rem;
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
  margin: 1rem 0;
  min-width: 0;
  overflow: hidden;
}

.ridge-training-course__summary {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-primary-fg-color) 8%), var(--md-default-bg-color));
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  padding: clamp(1rem, 2.6vw, 1.35rem);
}

.ridge-training-course__summary h2 {
  font-size: clamp(1.35rem, 2.8vw, 2rem);
  margin: 0;
}

.ridge-training-course__summary p,
.ridge-training-course__body p {
  color: var(--md-default-fg-color--light);
  line-height: 1.6;
  margin: 0;
}

.ridge-training-course__stats {
  display: grid;
  gap: 0.5rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ridge-training-course__stats span {
  background-color: color-mix(in srgb, var(--md-default-fg-color), transparent 94%);
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
  border-radius: var(--ridge-radius);
  display: block;
  font-size: 0.72rem;
  line-height: 1.35;
  padding: 0.55rem;
}

.ridge-training-course__stats strong {
  display: block;
  font-size: 0.95rem;
}

.ridge-training-course__body {
  padding: clamp(1rem, 2.6vw, 1.35rem);
}

.ridge-training-lists {
  display: grid;
  gap: 0.85rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 1rem;
}

.ridge-training-lists > div {
  background-color: color-mix(in srgb, var(--md-default-fg-color), transparent 96%);
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 89%);
  border-radius: var(--ridge-radius);
  min-width: 0;
  padding: 0.85rem;
}

.ridge-training-lists h3 {
  font-size: 0.9rem;
  margin: 0 0 0.45rem;
}

.ridge-training-lists ul,
.ridge-live-grid ul {
  margin: 0;
  padding-left: 1rem;
}

.ridge-training-lists li,
.ridge-live-grid li {
  margin-bottom: 0.35rem;
}

.ridge-live-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ridge-live-card {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  min-width: 0;
  overflow-wrap: anywhere;
  padding: 1rem;
}

.ridge-live-card strong {
  display: block;
  margin-bottom: 0.35rem;
}

.ridge-question-band {
  align-items: center;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-primary-fg-color) 9%), var(--md-default-bg-color));
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: 0.65rem;
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(0, 1fr) auto;
  margin: 1.5rem 0;
  padding: clamp(1rem, 2.6vw, 1.35rem);
}

.ridge-question-band h2,
.ridge-question-band p {
  margin: 0;
}

.ridge-question-band p {
  color: var(--md-default-fg-color--light);
  line-height: 1.55;
  margin-top: 0.35rem;
}

.ridge-router-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ridge-router-card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-primary-fg-color) 6%), var(--md-default-bg-color));
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 85%);
  border-radius: var(--ridge-radius);
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  min-width: 0;
  padding: clamp(1rem, 2.4vw, 1.25rem);
}

.ridge-router-card h3,
.ridge-router-card p {
  margin: 0;
}

.ridge-router-card h3 {
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
}

.ridge-router-card p {
  color: var(--md-default-fg-color--light);
  line-height: 1.55;
}

.ridge-router-card__meta {
  background-color: color-mix(in srgb, var(--md-default-fg-color), transparent 95%);
  border-left: 0.18rem solid var(--md-accent-fg-color);
  margin-top: auto;
  min-width: 0;
  padding: 0.65rem 0.75rem;
}

.ridge-router-card__meta span,
.ridge-router-card__meta strong {
  display: block;
}

.ridge-router-card__meta span {
  color: var(--md-default-fg-color--light);
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
}

.ridge-router-card__meta strong {
  font-size: 0.88rem;
  overflow-wrap: anywhere;
}

.ridge-router-card .md-button {
  align-self: flex-start;
}

.ridge-faq-page {
  display: grid;
  gap: 1rem;
}

.ridge-faq-section {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 87%);
  border-radius: 0.65rem;
  overflow: hidden;
}

.ridge-faq-section .ridge-section__header {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-primary-fg-color) 6%), var(--md-default-bg-color));
  margin-bottom: 0;
  padding: clamp(1rem, 2.4vw, 1.35rem);
}

.ridge-faq-section .ridge-section__header h2,
.ridge-faq-section .ridge-section__header p {
  margin: 0;
}

.ridge-faq-section .ridge-section__header p {
  margin-top: 0.35rem;
}

.ridge-faq-item {
  border-top: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 89%);
  padding: clamp(1rem, 2.4vw, 1.35rem);
}

.ridge-faq-item h3 {
  font-size: clamp(1rem, 1.8vw, 1.22rem);
  margin: 0;
}

.ridge-faq-item p {
  color: var(--md-default-fg-color--light);
  line-height: 1.65;
  margin: 0.45rem 0 0;
  max-width: 62rem;
}

/* About page */
.ridge-about {
  margin: -0.8rem auto 0;
}

.ridge-about * {
  box-sizing: border-box;
}

.ridge-about-hero {
  align-items: stretch;
  background:
    linear-gradient(135deg, rgba(16, 20, 23, 0.96), rgba(31, 45, 50, 0.92)),
    var(--ridge-ink);
  border: 1px solid var(--ridge-line);
  border-radius: 0.65rem;
  box-shadow: var(--ridge-shadow);
  color: var(--ridge-text);
  display: grid;
  gap: 0;
  grid-template-columns: 1fr;
  margin-bottom: 1.4rem;
  overflow: hidden;
}

.ridge-about-hero__copy {
  align-self: center;
  max-width: 62rem;
  padding: clamp(1.4rem, 4vw, 3rem);
}

.ridge-about-hero h1 {
  color: var(--ridge-text);
  font-size: clamp(1.8rem, 2.45vw, 2.55rem);
  font-weight: 400;
  line-height: 1.03;
  margin: 0;
  max-width: 20ch;
}

.ridge-about-hero__media {
  height: clamp(18rem, 34vw, 30rem);
  position: relative;
}

.ridge-about-hero__media .glightbox {
  display: block;
  inset: 0;
  position: absolute;
}

.ridge-about-hero__media img {
  height: 100%;
  inset: 0;
  object-fit: cover;
  object-position: 50% 24%;
  position: absolute;
  width: 100%;
}

.ridge-about-hero__media::after {
  background: linear-gradient(90deg, rgba(16, 20, 23, 0.42), transparent 42%);
  content: "";
  inset: 0;
  position: absolute;
}

.ridge-impact-grid {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 1rem 0 2rem;
}

.ridge-impact-card {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  min-width: 0;
  padding: 1rem;
}

.ridge-impact-card strong {
  display: block;
  font-size: clamp(1.25rem, 2.6vw, 1.9rem);
  line-height: 1;
}

.ridge-impact-card span {
  color: var(--md-default-fg-color--light);
  display: block;
  font-size: 0.75rem;
  line-height: 1.4;
  margin-top: 0.35rem;
}

.ridge-founder {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: 0.65rem;
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(12rem, 0.7fr) minmax(0, 1.3fr);
  min-width: 0;
  overflow: hidden;
}

.ridge-founder__media {
  background: var(--ridge-panel);
}

.ridge-founder__media .glightbox {
  display: block;
  height: 100%;
}

.ridge-founder__media img {
  height: 100%;
  object-fit: cover;
  object-position: 50% 32%;
  width: 100%;
}

.ridge-founder__copy {
  padding: clamp(1rem, 2.6vw, 1.35rem);
}

.ridge-founder__copy h2 {
  margin-top: 0;
}

.ridge-founder__copy p {
  color: var(--md-default-fg-color--light);
  line-height: 1.65;
}

.ridge-social-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}

.ridge-social-row a {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 84%);
  border-radius: 999rem;
  font-size: 0.75rem;
  font-weight: 800;
  padding: 0.35rem 0.65rem;
}

.ridge-cert-grid,
.ridge-difference-grid,
.ridge-recognition-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ridge-cert,
.ridge-difference,
.ridge-recognition {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  min-width: 0;
  overflow-wrap: anywhere;
  padding: 1rem;
}

.ridge-cert strong,
.ridge-difference strong,
.ridge-recognition strong {
  display: block;
  margin-bottom: 0.35rem;
}

.ridge-cert span,
.ridge-difference p,
.ridge-recognition p {
  color: var(--md-default-fg-color--light);
  font-size: 0.82rem;
  line-height: 1.55;
  margin: 0;
}

/* Events page */
.ridge-events {
  margin: -0.8rem auto 0;
}

.ridge-events * {
  box-sizing: border-box;
}

.ridge-events-hero {
  align-items: stretch;
  background:
    linear-gradient(135deg, rgba(16, 20, 23, 0.96), rgba(31, 45, 50, 0.92)),
    var(--ridge-ink);
  border: 1px solid var(--ridge-line);
  border-radius: 0.65rem;
  box-shadow: var(--ridge-shadow);
  color: var(--ridge-text);
  display: grid;
  gap: 0;
  grid-template-columns: 1fr;
  margin-bottom: 1.4rem;
  overflow: hidden;
}

.ridge-events-hero__copy {
  align-self: center;
  max-width: 62rem;
  padding: clamp(1.4rem, 4vw, 3rem);
}

.ridge-events-hero h1 {
  color: var(--ridge-text);
  font-size: clamp(1.8rem, 2.45vw, 2.55rem);
  font-weight: 400;
  line-height: 1.03;
  margin: 0;
  max-width: 21ch;
}

.ridge-events-hero__media {
  height: clamp(18rem, 34vw, 30rem);
  position: relative;
}

.ridge-events-hero__media .glightbox {
  display: block;
  inset: 0;
  position: absolute;
}

.ridge-events-hero__media img {
  height: 100%;
  inset: 0;
  object-fit: cover;
  object-position: 52% 42%;
  position: absolute;
  width: 100%;
}

.ridge-events-hero__media::after {
  background: linear-gradient(90deg, rgba(16, 20, 23, 0.42), transparent 42%);
  content: "";
  inset: 0;
  position: absolute;
}

.ridge-event-next {
  align-items: center;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-accent-fg-color) 8%), var(--md-default-bg-color));
  border: 1px solid color-mix(in srgb, var(--md-accent-fg-color), transparent 62%);
  border-radius: 0.65rem;
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(0, 1fr) auto;
  margin: 1.4rem 0 2rem;
  padding: clamp(1rem, 2.8vw, 1.45rem);
}

.ridge-event-next h2,
.ridge-event-next p {
  margin: 0;
}

.ridge-event-next h2 {
  font-size: clamp(1.25rem, 2.2vw, 1.65rem);
}

.ridge-event-next p {
  color: var(--md-default-fg-color--light);
  line-height: 1.6;
  margin-top: 0.35rem;
  max-width: 58rem;
}

.ridge-event-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ridge-event-card {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: 0.65rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  min-width: 0;
  overflow-wrap: anywhere;
  padding: clamp(1rem, 2.5vw, 1.25rem);
}

.ridge-event-card__top {
  align-items: flex-start;
  display: flex;
  gap: 0.75rem;
  justify-content: space-between;
}

.ridge-event-date {
  background-color: color-mix(in srgb, var(--md-accent-fg-color), transparent 88%);
  border: 1px solid color-mix(in srgb, var(--md-accent-fg-color), transparent 68%);
  border-radius: var(--ridge-radius);
  color: var(--md-default-fg-color);
  display: grid;
  flex: 0 0 auto;
  min-width: 4.5rem;
  padding: 0.55rem;
  text-align: center;
}

.ridge-event-date strong {
  font-size: 1.35rem;
  line-height: 1;
}

.ridge-event-date span {
  color: var(--md-default-fg-color--light);
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
}

.ridge-event-card h2 {
  font-size: clamp(1.2rem, 2.5vw, 1.6rem);
  margin: 0;
}

.ridge-event-card p {
  color: var(--md-default-fg-color--light);
  line-height: 1.6;
  margin: 0;
}

.ridge-event-meta {
  display: grid;
  gap: 0.5rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ridge-event-meta span {
  background-color: color-mix(in srgb, var(--md-default-fg-color), transparent 94%);
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
  border-radius: var(--ridge-radius);
  font-size: 0.72rem;
  line-height: 1.35;
  padding: 0.55rem;
}

.ridge-event-meta strong {
  display: block;
}

.ridge-event-card .ridge-actions {
  margin-top: auto;
}

.ridge-past-highlight-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ridge-past-highlight {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-primary-fg-color) 5%), var(--md-default-bg-color));
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  color: var(--md-default-fg-color);
  display: block;
  min-width: 0;
  padding: 1rem;
  text-decoration: none;
  transition:
    border-color 160ms ease,
    transform 160ms ease;
}

.ridge-past-highlight:hover {
  border-color: color-mix(in srgb, var(--md-accent-fg-color), transparent 44%);
  transform: translateY(-2px);
}

.ridge-past-highlight span {
  color: var(--md-accent-fg-color);
  display: block;
  font-size: 0.7rem;
  font-weight: 900;
  text-transform: uppercase;
}

.ridge-past-highlight strong {
  display: block;
  font-size: 1rem;
  margin-top: 0.35rem;
}

.ridge-past-highlight p {
  color: var(--md-default-fg-color--light);
  font-size: 0.82rem;
  line-height: 1.55;
  margin: 0.35rem 0 0;
}

.ridge-appearance-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ridge-appearance {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  min-width: 0;
  overflow-wrap: anywhere;
  padding: 1rem;
}

.ridge-appearance strong {
  display: block;
  margin-bottom: 0.35rem;
}

.ridge-appearance p {
  color: var(--md-default-fg-color--light);
  font-size: 0.82rem;
  line-height: 1.55;
  margin: 0;
}

/* Shared interior pages */
.ridge-page {
  margin: -0.8rem auto 0;
}

.ridge-page * {
  box-sizing: border-box;
}

.ridge-page-hero {
  background:
    linear-gradient(135deg, rgba(16, 20, 23, 0.96), rgba(31, 45, 50, 0.92)),
    var(--ridge-ink);
  border: 1px solid var(--ridge-line);
  border-radius: 0.65rem;
  box-shadow: var(--ridge-shadow);
  color: var(--ridge-text);
  margin-bottom: 1.4rem;
  padding: clamp(1.4rem, 4vw, 3rem);
}

.ridge-page-hero h1 {
  color: var(--ridge-text);
  font-size: clamp(1.8rem, 2.45vw, 2.55rem);
  font-weight: 400;
  line-height: 1.03;
  margin: 0;
  max-width: 21ch;
}

.ridge-page-hero .ridge-lede {
  max-width: 48rem;
}

.ridge-card-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ridge-card-grid--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ridge-info-card {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  min-width: 0;
  overflow-wrap: anywhere;
  padding: 1rem;
}

a.ridge-info-card {
  color: inherit;
  cursor: pointer;
  position: relative;
  text-decoration: none;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}

a.ridge-info-card:hover,
a.ridge-info-card:focus-visible {
  border-color: color-mix(in srgb, var(--md-accent-fg-color), transparent 45%);
  box-shadow: 0 0.75rem 1.5rem rgba(16, 20, 23, 0.12);
  color: inherit;
  transform: translateY(-1px);
}

a.ridge-info-card:focus-visible {
  outline: 3px solid var(--ridge-cyan);
  outline-offset: 3px;
}

.ridge-friend-card::after,
.ridge-recording-card::after {
  color: var(--md-accent-fg-color);
  content: "external link";
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  opacity: 0;
  position: absolute;
  right: 0.85rem;
  text-transform: uppercase;
  top: 0.85rem;
  transform: translateY(-0.2rem);
  transition:
    opacity 160ms ease,
    transform 160ms ease;
}

.ridge-recording-card::after {
  content: attr(data-ridge-action);
}

.ridge-friend-card:hover::after,
.ridge-friend-card:focus-visible::after,
.ridge-recording-card:hover::after,
.ridge-recording-card:focus-visible::after {
  opacity: 1;
  transform: translateY(0);
}

.ridge-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: auto;
}

.ridge-card-actions a {
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--md-accent-fg-color), transparent 58%);
  border-radius: var(--ridge-radius);
  color: var(--md-typeset-a-color);
  cursor: pointer;
  display: inline-flex;
  font-size: 0.72rem;
  font-weight: 800;
  justify-content: center;
  min-height: 1.9rem;
  padding: 0.38rem 0.55rem;
  text-decoration: none;
}

.ridge-card-actions a:hover,
.ridge-card-actions a:focus-visible {
  background: color-mix(in srgb, var(--md-accent-fg-color), transparent 90%);
}

.ridge-info-card h2,
.ridge-info-card h3 {
  margin: 0;
}

.ridge-info-card p {
  color: var(--md-default-fg-color--light);
  line-height: 1.6;
  margin: 0;
}

.ridge-info-card ul {
  margin: 0;
  padding-left: 1rem;
}

.ridge-info-card li {
  margin-bottom: 0.35rem;
}

.ridge-tool-feature {
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(0, 1.2fr) minmax(18rem, 0.8fr);
}

.ridge-tool-card {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  min-width: 0;
  overflow-wrap: anywhere;
  padding: clamp(1rem, 2.4vw, 1.25rem);
}

.ridge-tool-card--featured {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--md-default-bg-color), var(--md-accent-fg-color) 7%), var(--md-default-bg-color));
  border-color: color-mix(in srgb, var(--md-accent-fg-color), transparent 56%);
}

.ridge-tool-card h2,
.ridge-tool-card p {
  margin: 0;
}

.ridge-tool-card p {
  color: var(--md-default-fg-color--light);
  line-height: 1.6;
}

.ridge-tool-card ul {
  margin: 0;
  padding-left: 1rem;
}

.ridge-tool-card li {
  margin-bottom: 0.35rem;
}

.ridge-tool-card .ridge-actions {
  align-items: stretch;
}

.ridge-tool-card .ridge-actions .md-button {
  flex: 1 1 12rem;
}

.ridge-tool-card > span[id$="-stats"] {
  color: var(--md-accent-fg-color);
  font-size: 0.78rem;
  font-weight: 800;
  min-height: 1rem;
}

.ridge-tool-fit {
  background-color: color-mix(in srgb, var(--md-default-fg-color), transparent 95%);
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
  border-radius: var(--ridge-radius);
  padding: 0.85rem;
}

.ridge-tool-fit strong {
  display: block;
  margin-bottom: 0.4rem;
}

.ridge-card-title {
  align-items: center;
  display: flex;
  gap: 0.5rem;
  min-width: 0;
}

.ridge-card-title a {
  min-width: 0;
  overflow-wrap: anywhere;
}

.ridge-card-title img {
  flex: 0 0 auto;
  height: 1.4rem;
  width: 1.4rem;
}

.ridge-favicon {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  flex: 0 0 auto;
  height: 1.4rem;
  width: 1.4rem;
}

.ridge-favicon--redsiege { background-image: url("https://www.google.com/s2/favicons?domain=redsiege.com&sz=32"); }
.ridge-favicon--bhis { background-image: url("https://www.google.com/s2/favicons?domain=blackhillsinfosec.com&sz=32"); }
.ridge-favicon--antisyphon { background-image: url("https://www.google.com/s2/favicons?domain=antisyphontraining.com&sz=32"); }
.ridge-favicon--defensive-origins { background-image: url("https://www.google.com/s2/favicons?domain=defensiveorigins.com&sz=32"); }
.ridge-favicon--exploresec { background-image: url("https://www.google.com/s2/favicons?domain=exploresec.com&sz=32"); }
.ridge-favicon--ddi { background-image: url("https://www.google.com/s2/favicons?domain=digitaldefenseinstitute.com&sz=32"); }
.ridge-favicon--noct { background-image: url("https://www.google.com/s2/favicons?domain=noctinfosec.com&sz=32"); }
.ridge-favicon--youtube { background-image: url("https://www.google.com/s2/favicons?domain=youtube.com&sz=32"); }
.ridge-favicon--wwhf { background-image: url("https://www.google.com/s2/favicons?domain=wildwesthackinfest.com&sz=32"); }
.ridge-favicon--kernelcon { background-image: url("https://www.google.com/s2/favicons?domain=kernelcon.org&sz=32"); }
.ridge-favicon--bsideshbg { background-image: url("https://www.google.com/s2/favicons?domain=bsideshbg.com&sz=32"); }
.ridge-favicon--bsidescharleston { background-image: url("https://www.google.com/s2/favicons?domain=bsidescharleston.org&sz=32"); }
.ridge-favicon--bsidesgreenville { background-image: url("https://www.google.com/s2/favicons?domain=bsidesgreenville.org&sz=32"); }
.ridge-favicon--bsidesbergen { background-image: url("https://www.google.com/s2/favicons?domain=bsidesbergen.no&sz=32"); }
.ridge-favicon--bsideskc { background-image: url("https://www.google.com/s2/favicons?domain=bsideskc.org&sz=32"); }
.ridge-favicon--bsides312 { background-image: url("https://www.google.com/s2/favicons?domain=bsides312.org&sz=32"); }
.ridge-favicon--elbsides { background-image: url("https://www.google.com/s2/favicons?domain=elbsides.eu&sz=32"); }

.ridge-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.ridge-featured-series {
  background:
    linear-gradient(135deg, rgba(16, 20, 23, 0.98), rgba(36, 52, 58, 0.96)),
    var(--ridge-ink);
  border: 1px solid var(--ridge-line);
  border-radius: 0.65rem;
  box-shadow: var(--ridge-shadow);
  color: var(--ridge-text);
  display: grid;
  gap: clamp(1rem, 3vw, 1.6rem);
  grid-template-columns: minmax(0, 1.25fr) minmax(16rem, 0.75fr);
  margin: 1.4rem 0 2.2rem;
  min-width: 0;
  overflow: hidden;
  padding: clamp(1.25rem, 4vw, 2rem);
}

.ridge-featured-series h2 {
  color: var(--ridge-text);
  font-size: clamp(1.75rem, 4vw, 3rem);
  line-height: 1;
  margin: 0;
  max-width: 12ch;
}

.ridge-featured-series p {
  color: var(--ridge-muted);
  line-height: 1.65;
  margin: 0.8rem 0 0;
}

.ridge-featured-series__tagline {
  color: var(--ridge-orange-soft) !important;
  font-size: 1.02rem;
  font-weight: 800;
}

.ridge-featured-series .ridge-meta-row {
  margin-top: 1rem;
}

.ridge-featured-series .ridge-chip {
  background-color: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.14);
  color: var(--ridge-text);
}

.ridge-featured-series__episodes {
  align-self: center;
  display: grid;
  gap: 0.65rem;
  grid-template-columns: repeat(auto-fit, minmax(4.1rem, 1fr));
  min-width: 0;
}

.ridge-featured-series__episodes a {
  background-color: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--ridge-radius);
  box-sizing: border-box;
  color: var(--ridge-text);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 7rem;
  min-width: 0;
  overflow: hidden;
  padding: 0.75rem 0.55rem;
  text-align: center;
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    transform 160ms ease;
}

.ridge-featured-series__episodes a:hover {
  background-color: rgba(232, 117, 47, 0.18);
  border-color: rgba(232, 117, 47, 0.62);
  transform: translateY(-2px);
}

.ridge-featured-series__episodes span {
  color: var(--ridge-muted);
  font-size: 0.68rem;
  font-weight: 800;
  line-height: 1;
  max-width: 100%;
  text-transform: uppercase;
  overflow-wrap: normal;
  white-space: nowrap;
  word-break: normal;
}

.ridge-featured-series__episodes strong {
  font-size: clamp(1.8rem, 4vw, 3rem);
  line-height: 1;
  margin-top: 0.2rem;
}

.ridge-media-band {
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: 0.65rem;
  margin: 2rem 0;
  overflow: hidden;
}

.ridge-media-band .glightbox,
.ridge-media-band img {
  display: block;
  width: 100%;
}

.ridge-media-band img {
  max-height: 28rem;
  object-fit: cover;
}

.md-typeset .md-typeset__table,
.md-typeset #main-content > table {
  border-radius: var(--ridge-radius);
  margin: 1rem auto;
  overflow-x: auto;
  width: 100%;
}

.md-typeset .md-typeset__table table,
.md-typeset #main-content > table {
  border: 0;
  border-collapse: separate;
  border-spacing: 0;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  margin: 0;
  width: 100%;
}

.md-typeset #main-content > table {
  max-width: 54rem;
}

.md-typeset .md-typeset__table table th,
.md-typeset .md-typeset__table table td,
.md-typeset #main-content > table th,
.md-typeset #main-content > table td {
  border-left: 0;
  border-right: 0;
}

.ridge-note {
  background-color: color-mix(in srgb, var(--md-default-bg-color), var(--md-primary-fg-color) 7%);
  border: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 86%);
  border-radius: var(--ridge-radius);
  padding: 1rem;
}

@media screen and (max-width: 76em) {
  .ridge-hero,
  .ridge-training-hero,
  .ridge-training-course,
  .ridge-about-hero,
  .ridge-events-hero {
    grid-template-columns: 1fr;
  }

  .ridge-hero__media,
  .ridge-training-hero__media,
  .ridge-about-hero__media,
  .ridge-events-hero__media {
    height: clamp(17rem, 44vw, 26rem);
    order: 0;
  }

  .ridge-hero h1,
  .ridge-training-hero h1,
  .ridge-about-hero h1,
  .ridge-events-hero h1 {
    max-width: 18ch;
  }

  .ridge-hero__media img {
    object-position: 52% 24%;
  }

  .ridge-training-hero__media img {
    object-position: 40% 24%;
  }

  .ridge-about-hero__media img {
    object-position: 50% 18%;
  }

  .ridge-events-hero__media img {
    object-position: 52% 45%;
  }

  .ridge-instructor {
    grid-template-columns: minmax(12rem, 0.7fr) minmax(0, 1.3fr);
  }

  .ridge-live-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Footer compact design support */
.md-footer-copyright {
  width: 100%;
}

.ridge-footer {
  text-align: center;
}

.ridge-footer__brand {
  align-items: center;
  display: inline-flex;
  gap: 0.65rem;
  justify-content: center;
  margin-bottom: 0.75rem;
  max-width: 100%;
}

.ridge-footer__brand img {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 50%;
  box-shadow: 0 0.45rem 1rem rgba(0, 0, 0, 0.18);
  flex: 0 0 auto;
  height: 2.4rem;
  padding: 0.2rem;
  width: 2.4rem;
}

.ridge-footer__brand div {
  min-width: 0;
}

.ridge-footer__brand span {
  display: inline-block;
  font-size: 0.9em;
  margin-left: 1em;
  opacity: 0.7;
}

.ridge-footer__links {
  display: flex;
  flex-wrap: wrap;
  font-size: 0.9em;
  gap: 0.5em 1.5em;
  justify-content: center;
  line-height: 1.4;
}

.ridge-footer__links div {
  white-space: nowrap;
}

.ridge-footer__built {
  font-size: 0.75em;
  margin-top: 0.5em;
  opacity: 0.6;
}

.md-footer-copyright a {
  color: var(--md-footer-fg-color);
  text-decoration: none;
}

.md-footer-copyright a:hover {
  text-decoration: underline;
}

@media screen and (max-width: 59.9375em) {
  .ridge-hero,
  .ridge-instructor {
    grid-template-columns: 1fr;
  }

  .ridge-hero__media {
    height: clamp(17rem, 58vw, 25rem);
    order: 0;
  }

  .ridge-instructor .glightbox,
  .ridge-instructor img {
    aspect-ratio: 16 / 10;
    max-height: 20rem;
  }

  .ridge-instructor__copy {
    padding: 0 1.1rem 1.2rem;
  }

  .ridge-course-grid,
  .ridge-resource-grid,
  .ridge-feature-grid,
  .ridge-training-hero,
  .ridge-course-picker,
  .ridge-training-course,
  .ridge-question-band,
  .ridge-home-pathway,
  .ridge-router-grid,
  .ridge-event-next,
  .ridge-live-grid,
  .ridge-tool-feature,
  .ridge-founder,
  .ridge-impact-grid,
  .ridge-cert-grid,
  .ridge-difference-grid,
  .ridge-recognition-grid,
  .ridge-event-grid,
  .ridge-past-highlight-grid,
  .ridge-appearance-grid,
  .ridge-featured-series {
    grid-template-columns: 1fr;
  }

  .ridge-featured-series__episodes {
    grid-template-columns: repeat(auto-fit, minmax(4.1rem, 1fr));
    overflow-x: auto;
    padding-bottom: 0.15rem;
  }

  .ridge-featured-series__episodes a {
    min-height: 5.8rem;
  }

  .ridge-card-grid,
  .ridge-card-grid--three {
    grid-template-columns: 1fr;
  }

  .ridge-training-course__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ridge-proof {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ridge-proof__item + .ridge-proof__item {
    border-left: 0;
  }

  .ridge-proof__item:nth-child(even) {
    border-left: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
  }

  .ridge-proof__item:nth-child(n + 3) {
    border-top: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
  }

  .ridge-training-hero__media {
    height: clamp(17rem, 58vw, 25rem);
    order: 0;
  }

  .ridge-about-hero__media,
  .ridge-events-hero__media {
    height: clamp(17rem, 58vw, 25rem);
    max-height: 26rem;
  }

  .ridge-founder__media img {
    min-height: clamp(18rem, 58vw, 25rem);
    max-height: 26rem;
  }

  .ridge-about-hero__media,
  .ridge-events-hero__media {
    order: 0;
  }

  .ridge-compare {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }

  .ridge-compare div:nth-child(-n + 3) {
    display: none;
  }

  .ridge-compare div {
    display: grid;
    grid-template-columns: 9rem 1fr;
    white-space: normal;
  }

  .ridge-compare div:nth-child(3n + 1)::before {
    content: "Detail";
    color: var(--md-default-fg-color--light);
    font-weight: 700;
  }

  .ridge-compare div:nth-child(3n + 2)::before {
    content: "OTF";
    color: var(--md-default-fg-color--light);
    font-weight: 700;
  }

  .ridge-compare div:nth-child(3n + 3)::before {
    content: "OTO";
    color: var(--md-default-fg-color--light);
    font-weight: 700;
  }

  .ridge-compare div,
  .ridge-compare div:nth-child(3n + 2),
  .ridge-compare div:nth-child(3n + 3),
  .ridge-compare div:nth-last-child(-n + 3) {
    border-left: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
  }
}

@media screen and (max-width: 34em) {
  .ridge-hero h1,
  .ridge-training-hero h1,
  .ridge-about-hero h1,
  .ridge-events-hero h1,
  .ridge-page-hero h1 {
    font-size: 1.8rem;
  }

  .ridge-hero__copy,
  .ridge-training-hero__copy,
  .ridge-about-hero__copy,
  .ridge-events-hero__copy {
    padding: 1.15rem;
  }

  .ridge-page-hero {
    padding: 1.15rem;
  }

  .ridge-actions {
    gap: 0.5rem;
  }

  .ridge-actions .md-button {
    flex: 1 1 100%;
  }

  .ridge-tool-card .ridge-actions .md-button {
    flex-basis: 100%;
  }

  .ridge-question-band .md-button {
    justify-self: stretch;
    text-align: center;
  }

  .ridge-router-card .md-button {
    align-self: stretch;
    text-align: center;
  }

  .ridge-home-pathway .md-button {
    justify-self: stretch;
    text-align: center;
  }

  .ridge-event-next .ridge-actions {
    width: 100%;
  }

  .ridge-featured-series__episodes {
    grid-template-columns: repeat(2, minmax(4.1rem, 1fr));
  }

  .ridge-proof,
  .ridge-course-card__meta,
  .ridge-training-course__stats,
  .ridge-training-lists,
  .ridge-event-meta {
    grid-template-columns: 1fr;
  }

  .ridge-proof__item:nth-child(even) {
    border-left: 0;
  }

  .ridge-proof__item + .ridge-proof__item {
    border-top: 1px solid color-mix(in srgb, var(--md-default-fg-color), transparent 88%);
  }

  .ridge-footer__brand {
    align-items: center;
    flex-direction: column;
    gap: 0.45rem;
  }

  .ridge-footer__brand span {
    display: block;
    margin-left: 0;
    margin-top: 0.25rem;
  }

  .ridge-footer__links div {
    white-space: normal;
  }
}

@media screen and (max-width: 24em) {
  .ridge-hero h1,
  .ridge-training-hero h1,
  .ridge-about-hero h1,
  .ridge-events-hero h1,
  .ridge-page-hero h1 {
    font-size: 1.65rem;
  }

  .ridge-lede {
    font-size: 0.86rem;
  }

  .ridge-trust {
    display: grid;
    grid-template-columns: 1fr;
  }

  .ridge-trust span {
    max-width: none;
  }
}

.ridge-home h1,
.ridge-home h2,
.ridge-home h3,
.ridge-training h1,
.ridge-training h2,
.ridge-training h3,
.ridge-about h1,
.ridge-about h2,
.ridge-about h3,
.ridge-events h1,
.ridge-events h2,
.ridge-events h3,
.ridge-page h1,
.ridge-page h2,
.ridge-page h3 {
  font-family: var(--ridge-display-font);
  font-weight: 400;
  letter-spacing: 0;
}
