/* pages/glossary.css
   Glossary hub and term-page browser/filter/readability styles.
   Source: assets/css/ss.css migration split. */

/* BJJ Glossary visibility system */

body.page-glossary.page-bjj-glossary {
  --glossary-dark-bg: #071314;
  --glossary-dark-panel: #0d2022;
  --glossary-dark-panel-soft: #112b2d;
  --glossary-dark-text: #f4fbfb;
  --glossary-dark-muted: #b8cccc;
  --glossary-dark-border: rgba(255, 255, 255, 0.14);
  --glossary-dark-border-strong: rgba(0, 221, 224, 0.42);
  --glossary-light-bg: #fbfaf8;
  --glossary-light-panel: #ffffff;
  --glossary-light-panel-soft: #f4f1ed;
  --glossary-light-text: #1f1712;
  --glossary-light-muted: #4f433c;
  --glossary-light-border: rgba(54, 43, 36, 0.16);
  --glossary-accent: #00dde0;
  --glossary-accent-text: #8ffcff;
  --glossary-orange: #b94700;
  --glossary-orange-text: #ff9a58;
  --glossary-pill-bg: #173033;
  --glossary-pill-hover-bg: #1c3b3f;
  --glossary-pill-disabled-bg: #122224;
  --glossary-pill-disabled-text: #8ea4a4;
  --ss-text: var(--glossary-dark-text);
  --ss-muted: var(--glossary-dark-muted);
  --ss-border: var(--glossary-dark-border);
  background: var(--glossary-dark-bg);
  color: var(--glossary-dark-text);
}

body.page-glossary.page-bjj-glossary .ss-main {
  background:
    radial-gradient(circle at top left, rgba(0, 221, 224, 0.14), transparent 34rem),
    radial-gradient(circle at top right, rgba(224, 85, 0, 0.10), transparent 30rem),
    var(--glossary-dark-bg) !important;
  color: var(--glossary-dark-text);
}

body.page-glossary.page-bjj-glossary .ss-main > section {
  background: transparent;
}

body.page-glossary.page-bjj-glossary .ss-main > section::before {
  content: none !important;
  display: none !important;
}

body.page-glossary.page-bjj-glossary .glossary-surface--dark {
  border: 1px solid var(--glossary-dark-border);
  background:
    radial-gradient(circle at 15% 20%, rgba(0, 221, 224, 0.14), transparent 34%),
    linear-gradient(135deg, #0b3032 0%, #111c22 52%, #071214 100%) !important;
  color: var(--glossary-dark-text);
  box-shadow: 0 22px 60px rgba(0, 0, 0, 0.24);
}

body.page-glossary.page-bjj-glossary .glossary-surface--dark :where(h1, h2, h3, h4, label, legend, summary) {
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-surface--dark :where(p, li, .glossary-filter-group > p, .glossary-results-header p) {
  color: var(--glossary-dark-muted) !important;
}

body.page-glossary.page-bjj-glossary .glossary-surface--light {
  border: 1px solid var(--glossary-light-border);
  background: var(--glossary-light-panel) !important;
  color: var(--glossary-light-text);
  box-shadow: 0 18px 45px rgba(31, 23, 18, 0.12);
}

body.page-glossary.page-bjj-glossary .glossary-surface--light :where(h1, h2, h3, h4, label, legend, summary) {
  color: var(--glossary-light-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-surface--light :where(p, li) {
  color: var(--glossary-light-muted) !important;
}

body.page-glossary.page-bjj-glossary .ss-page-feed .ss-community-post {
  border-color: var(--glossary-light-border) !important;
  background: var(--glossary-light-panel) !important;
  color: var(--glossary-light-text);
}

body.page-glossary.page-bjj-glossary .ss-page-feed .ss-community-post :where(h2, .ss-community-author) {
  color: var(--glossary-light-text) !important;
}

body.page-glossary.page-bjj-glossary .ss-page-feed .ss-community-post :where(p, .ss-community-context) {
  color: var(--glossary-light-muted) !important;
}

body.page-glossary.page-bjj-glossary .ss-page-feed .ss-community-avatar {
  background: var(--glossary-light-panel-soft) !important;
  color: var(--glossary-light-text) !important;
}

body.page-glossary.page-bjj-glossary .ss-page-feed .ss-community-pill:not(.ss-primary) {
  border-color: var(--glossary-light-border) !important;
  background: var(--glossary-light-panel) !important;
  color: var(--glossary-light-text) !important;
}

body.page-glossary.page-bjj-glossary .ss-page-feed .ss-community-pill:not(.ss-primary):hover,
body.page-glossary.page-bjj-glossary .ss-page-feed .ss-community-pill:not(.ss-primary):focus-visible {
  border-color: rgba(40, 159, 161, 0.45) !important;
  color: var(--glossary-light-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-hero-grid,
body.page-glossary.page-bjj-glossary .glossary-start-path {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.065), rgba(255, 255, 255, 0.025)),
    var(--glossary-dark-panel) !important;
  border-color: var(--glossary-dark-border) !important;
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-hero h1,
body.page-glossary.page-bjj-glossary .glossary-section-header h2,
body.page-glossary.page-bjj-glossary .day-one-card h3 {
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-eyebrow,
body.page-glossary.page-bjj-glossary .day-one-card .num,
body.page-glossary.page-bjj-glossary .ss-paths-eyebrow {
  color: var(--glossary-accent-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-hero-copy > p:not(.glossary-eyebrow),
body.page-glossary.page-bjj-glossary .glossary-section-header p,
body.page-glossary.page-bjj-glossary .day-one-card p,
body.page-glossary.page-bjj-glossary .glossary-start-cta p {
  color: var(--glossary-dark-muted) !important;
}

body.page-glossary.page-bjj-glossary .day-one-card {
  background: var(--glossary-dark-panel-soft) !important;
  border-color: var(--glossary-dark-border) !important;
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-btn {
  text-shadow: none;
}

body.page-glossary.page-bjj-glossary .glossary-btn-primary {
  background: var(--glossary-orange) !important;
  border-color: var(--glossary-orange) !important;
  color: #ffffff !important;
  box-shadow: 0 14px 28px rgba(185, 71, 0, 0.3);
}

body.page-glossary.page-bjj-glossary .glossary-btn-primary:hover,
body.page-glossary.page-bjj-glossary .glossary-btn-primary:focus-visible {
  background: #9f3d00 !important;
  border-color: #9f3d00 !important;
  color: #ffffff !important;
}

body.page-glossary.page-bjj-glossary .glossary-btn-secondary {
  border-color: rgba(255, 255, 255, 0.28) !important;
  background: rgba(255, 255, 255, 0.08) !important;
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-btn-secondary:hover,
body.page-glossary.page-bjj-glossary .glossary-btn-secondary:focus-visible {
  border-color: var(--glossary-dark-border-strong) !important;
  background: rgba(0, 221, 224, 0.16) !important;
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-next-steps {
  margin: 28px auto 0;
  padding: clamp(18px, 3vw, 28px);
  border-radius: 28px;
}

body.page-glossary.page-bjj-glossary .glossary-next-steps .glossary-start-cta {
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin: 0;
  text-align: center;
}

body.page-glossary.page-bjj-glossary .glossary-next-steps .glossary-start-cta p {
  flex-basis: 100%;
  margin: 0;
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-filter-panel {
  position: relative !important;
  top: auto !important;
  z-index: 2 !important;
  float: none !important;
  border-color: var(--glossary-dark-border) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.02)),
    var(--glossary-dark-panel) !important;
  color: var(--glossary-dark-text) !important;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.24) !important;
}

body.page-glossary.page-bjj-glossary .glossary-filter-header label,
body.page-glossary.page-bjj-glossary .glossary-filter-group > p,
body.page-glossary.page-bjj-glossary .glossary-results-header p {
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-search {
  border-color: rgba(0, 221, 224, 0.72) !important;
  background: #102625 !important;
  color: #ffffff !important;
}

body.page-glossary.page-bjj-glossary .glossary-search::placeholder {
  color: rgba(255, 255, 255, 0.74) !important;
}

body.page-glossary.page-bjj-glossary .glossary-utility-links button,
body.page-glossary.page-bjj-glossary .glossary-utility-links select,
body.page-glossary.page-bjj-glossary #reset-filters,
body.page-glossary.page-bjj-glossary .glossary-chip,
body.page-glossary.page-bjj-glossary .glossary-alpha {
  border-color: rgba(255, 255, 255, 0.22) !important;
  background: var(--glossary-pill-bg) !important;
  color: var(--glossary-dark-text) !important;
  opacity: 1;
  text-shadow: none;
}

body.page-glossary.page-bjj-glossary .glossary-utility-links button:hover,
body.page-glossary.page-bjj-glossary .glossary-utility-links button:focus-visible,
body.page-glossary.page-bjj-glossary .glossary-utility-links select:hover,
body.page-glossary.page-bjj-glossary #reset-filters:hover,
body.page-glossary.page-bjj-glossary .glossary-chip:hover,
body.page-glossary.page-bjj-glossary .glossary-chip:focus-visible,
body.page-glossary.page-bjj-glossary .glossary-chip.is-active,
body.page-glossary.page-bjj-glossary .glossary-chip[aria-pressed="true"],
body.page-glossary.page-bjj-glossary .glossary-alpha:hover,
body.page-glossary.page-bjj-glossary .glossary-alpha:focus-visible,
body.page-glossary.page-bjj-glossary .glossary-alpha.is-active,
body.page-glossary.page-bjj-glossary .glossary-alpha[aria-pressed="true"] {
  border-color: var(--glossary-accent) !important;
  background: var(--glossary-accent) !important;
  color: #062022 !important;
}

body.page-glossary.page-bjj-glossary .glossary-utility-links button:hover,
body.page-glossary.page-bjj-glossary .glossary-utility-links button:focus-visible,
body.page-glossary.page-bjj-glossary .glossary-utility-links select:hover,
body.page-glossary.page-bjj-glossary #reset-filters:hover,
body.page-glossary.page-bjj-glossary .glossary-chip:not(.is-active):not([aria-pressed="true"]):hover,
body.page-glossary.page-bjj-glossary .glossary-chip:not(.is-active):not([aria-pressed="true"]):focus-visible,
body.page-glossary.page-bjj-glossary .glossary-alpha:not(.is-active):not([aria-pressed="true"]):hover,
body.page-glossary.page-bjj-glossary .glossary-alpha:not(.is-active):not([aria-pressed="true"]):focus-visible {
  border-color: rgba(0, 221, 224, 0.58) !important;
  background: var(--glossary-pill-hover-bg) !important;
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-alpha.is-disabled {
  border-color: rgba(255, 255, 255, 0.1) !important;
  background: var(--glossary-pill-disabled-bg) !important;
  color: var(--glossary-pill-disabled-text) !important;
  opacity: 1;
}

body.page-glossary.page-bjj-glossary .glossary-secondary-paths .ss-glossary-paths {
  width: 100%;
  max-width: none;
  margin: 16px 0 0;
  padding: clamp(18px, 3vw, 28px);
  border-radius: 20px;
}

body.page-glossary.page-bjj-glossary .ss-paths-inner {
  max-width: 100%;
}

body.page-glossary.page-bjj-glossary .ss-paths-header {
  max-width: 760px;
  margin: 0 auto 18px;
  text-align: center;
}

body.page-glossary.page-bjj-glossary .ss-paths-header h2 {
  margin: 0 0 8px;
  color: var(--glossary-dark-text) !important;
  font-size: clamp(1.45rem, 3vw, 2.2rem);
  line-height: 1.05;
  letter-spacing: 0;
}

body.page-glossary.page-bjj-glossary .ss-paths-header p {
  max-width: 680px;
  margin: 0 auto;
  color: var(--glossary-dark-muted) !important;
}

body.page-glossary.page-bjj-glossary .ss-path-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

body.page-glossary.page-bjj-glossary .ss-path-card {
  min-width: 0;
  min-height: 100%;
  padding: 16px;
  border: 1px solid var(--glossary-dark-border) !important;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.07) !important;
  color: var(--glossary-dark-text) !important;
  box-shadow: none;
}

body.page-glossary.page-bjj-glossary .ss-path-card h3 {
  margin: 0 0 8px;
  color: var(--glossary-dark-text) !important;
  font-size: 1rem;
  line-height: 1.2;
}

body.page-glossary.page-bjj-glossary .ss-path-card p {
  min-height: auto;
  margin: 0 0 12px;
  color: var(--glossary-dark-muted) !important;
  font-size: 0.92rem;
  line-height: 1.45;
}

body.page-glossary.page-bjj-glossary .ss-path-link {
  color: var(--glossary-accent-text) !important;
  font-weight: 900;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

body.page-glossary.page-bjj-glossary .ss-path-link:hover,
body.page-glossary.page-bjj-glossary .ss-path-link:focus-visible {
  color: #ffffff !important;
}

body.page-glossary.page-bjj-glossary .ss-path-chips {
  display: flex !important;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 2px;
}

body.page-glossary.page-bjj-glossary .ss-path-chips a {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 5px 8px;
  border: 1px solid rgba(0, 221, 224, 0.36);
  border-radius: 999px;
  background: var(--glossary-pill-bg);
  color: var(--glossary-dark-text) !important;
  font-size: 0.76rem;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
}

body.page-glossary.page-bjj-glossary .ss-path-chips a:hover,
body.page-glossary.page-bjj-glossary .ss-path-chips a:focus-visible {
  border-color: var(--glossary-accent) !important;
  background: var(--glossary-pill-hover-bg) !important;
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-card,
body.page-glossary.page-bjj-glossary .term-card.glossary-card,
body.page-glossary.page-bjj-glossary .ss-glossary-term-card.glossary-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.025)),
    var(--glossary-dark-panel) !important;
  border-color: var(--glossary-dark-border) !important;
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-card h3,
body.page-glossary.page-bjj-glossary .glossary-card h3 a,
body.page-glossary.page-bjj-glossary .term-card__title,
body.page-glossary.page-bjj-glossary .term-card__title a {
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-card p,
body.page-glossary.page-bjj-glossary .term-card__summary,
body.page-glossary.page-bjj-glossary .ss-glossary-term-def,
body.page-glossary.page-bjj-glossary .glossary-related,
body.page-glossary.page-bjj-glossary .glossary-related span {
  color: var(--glossary-dark-muted) !important;
}

body.page-glossary.page-bjj-glossary .glossary-related a {
  color: var(--glossary-dark-text) !important;
  border-bottom-color: var(--glossary-dark-border-strong) !important;
}

body.page-glossary.page-bjj-glossary .glossary-pill {
  min-height: 26px;
  align-items: center;
  border: 1px solid rgba(0, 221, 224, 0.42) !important;
  background: var(--glossary-pill-bg) !important;
  color: var(--glossary-accent-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-card-cta,
body.page-glossary.page-bjj-glossary .term-card__cta,
body.page-glossary.page-bjj-glossary .ss-glossary-term-cta {
  border: 1px solid var(--glossary-dark-border-strong) !important;
  background: rgba(0, 221, 224, 0.14) !important;
  color: var(--glossary-dark-text) !important;
}

body.page-glossary.page-bjj-glossary .glossary-card-cta:hover,
body.page-glossary.page-bjj-glossary .glossary-card-cta:focus-visible,
body.page-glossary.page-bjj-glossary .term-card__cta:hover,
body.page-glossary.page-bjj-glossary .term-card__cta:focus-visible {
  background: var(--glossary-accent) !important;
  color: #062022 !important;
}

body.page-glossary-term.page-bjj-glossary {
  --glossary-term-dark-panel: #151f25;
  --glossary-term-dark-panel-soft: #102629;
  --glossary-term-dark-text: #f4fbfb;
  --glossary-term-dark-muted: #cfe1e1;
  --glossary-term-dark-border: rgba(255, 255, 255, 0.16);
  --glossary-term-accent: #8ffcff;
}

body.page-glossary-term.page-bjj-glossary .term-hero,
body.page-glossary-term.page-bjj-glossary .glossary-card,
body.page-glossary-term.page-bjj-glossary .term-card,
body.page-glossary-term.page-bjj-glossary .ss-glossary-rich-sidebar-card,
body.page-glossary-term.page-bjj-glossary .on-this-page,
body.page-glossary-term.page-bjj-glossary section[id] {
  border-color: var(--glossary-term-dark-border) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.02)),
    var(--glossary-term-dark-panel) !important;
  color: var(--glossary-term-dark-text) !important;
}

body.page-glossary-term.page-bjj-glossary .term-hero h1,
body.page-glossary-term.page-bjj-glossary .glossary-card h2,
body.page-glossary-term.page-bjj-glossary .glossary-card h3,
body.page-glossary-term.page-bjj-glossary .glossary-card h4,
body.page-glossary-term.page-bjj-glossary .term-card h3,
body.page-glossary-term.page-bjj-glossary .related-term-card h3,
body.page-glossary-term.page-bjj-glossary summary {
  color: var(--glossary-term-dark-text) !important;
}

body.page-glossary-term.page-bjj-glossary .term-meta,
body.page-glossary-term.page-bjj-glossary .term-summary,
body.page-glossary-term.page-bjj-glossary .glossary-card p,
body.page-glossary-term.page-bjj-glossary .glossary-card li,
body.page-glossary-term.page-bjj-glossary .term-card p,
body.page-glossary-term.page-bjj-glossary section[id] p,
body.page-glossary-term.page-bjj-glossary section[id] li {
  color: var(--glossary-term-dark-muted) !important;
}

body.page-glossary-term.page-bjj-glossary .term-tags span,
body.page-glossary-term.page-bjj-glossary .glossary-pill,
body.page-glossary-term.page-bjj-glossary .badge {
  border: 1px solid rgba(0, 221, 224, 0.34) !important;
  background: rgba(0, 221, 224, 0.13) !important;
  color: var(--glossary-term-dark-text) !important;
}

body.page-glossary-term.page-bjj-glossary .glossary-card a,
body.page-glossary-term.page-bjj-glossary .term-card a,
body.page-glossary-term.page-bjj-glossary section[id] a {
  color: var(--glossary-term-accent) !important;
}

body.page-glossary-term.page-bjj-glossary .glossary-card a:hover,
body.page-glossary-term.page-bjj-glossary .term-card a:hover,
body.page-glossary-term.page-bjj-glossary section[id] a:hover,
body.page-glossary-term.page-bjj-glossary .glossary-card a:focus-visible,
body.page-glossary-term.page-bjj-glossary .term-card a:focus-visible,
body.page-glossary-term.page-bjj-glossary section[id] a:focus-visible {
  color: #ffffff !important;
}

@media (max-width: 920px) {
  body.page-glossary.page-bjj-glossary .ss-path-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  body.page-glossary.page-bjj-glossary .glossary-next-steps {
    width: min(100% - 22px, 1120px);
  }

  body.page-glossary.page-bjj-glossary .glossary-next-steps .glossary-start-cta,
  body.page-glossary.page-bjj-glossary .glossary-next-steps .d-flex {
    display: grid !important;
    grid-template-columns: 1fr;
    width: 100%;
  }

  body.page-glossary.page-bjj-glossary .glossary-next-steps .glossary-btn {
    width: 100%;
  }

  body.page-glossary.page-bjj-glossary .ss-path-grid {
    grid-template-columns: 1fr;
  }
}

/* Fix visibility issues for .ss-mini-link sidebar items on term pages */
.ss-mini-link {
  display: block;
  text-decoration: none !important;
  transition: transform 0.2s ease;
}

.ss-mini-link:hover {
  transform: translateY(-1px);
}

.ss-mini-link strong {
  display: block;
  color: #1f1712 !important; /* Force dark text on white background */
  font-size: 1.1rem;
  line-height: 1.2;
  margin-bottom: 2px;
}

.ss-mini-link span {
  display: block;
  color: #4f433c !important; /* Force muted dark text on white background */
  font-size: 0.9rem;
  line-height: 1.3;
}

/* Bulletproof fix for glossary-btn-secondary visibility */
body.page-glossary.page-bjj-glossary a.glossary-btn-secondary,
.page-glossary main.glossary-page a.glossary-btn-secondary,
.glossary-shell.glossary-next-steps a.glossary-btn-secondary,
.glossary-next-steps .d-flex a.glossary-btn-secondary,
.glossary-start-cta a.glossary-btn-secondary {
  color: #ffffff !important;
  border-color: rgba(255, 255, 255, 0.45) !important;
  background: rgba(255, 255, 255, 0.15) !important;
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}

body.page-glossary.page-bjj-glossary .glossary-pill {
  background: var(--glossary-pill-bg) !important;
  color: #8ffcff !important;
  font-weight: 700;
  border: 1px solid rgba(0, 221, 224, 0.42) !important;
}

/* Glossary system */
.page-glossary .ss-main,
.page-glossary-term .ss-main {
  background:
    radial-gradient(1100px 420px at 15% -5%, rgba(40, 159, 161, 0.16), transparent 55%),
    radial-gradient(900px 360px at 95% 0%, rgba(224, 85, 0, 0.10), transparent 58%),
    linear-gradient(180deg, #fffdfa 0%, #f9f5ef 100%);
}

.ss-glossary-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.9rem;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ss-slate);
}

.ss-glossary-kicker::before {
  content: "";
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--ss-orange), var(--ss-teal));
  box-shadow: 0 0 0 5px rgba(40, 159, 161, 0.12);
}

.ss-glossary-hero,
.ss-glossary-term-hero {
  padding-top: clamp(2.8rem, 8vw, 5.8rem);
  padding-bottom: clamp(2.4rem, 6vw, 4rem);
}

.ss-glossary-hero h1,
.ss-glossary-term-hero h1 {
  font-size: clamp(2.5rem, 6vw, 4.9rem);
  max-width: 12ch;
}

.ss-glossary-term-hero h1 span {
  display: block;
  font-size: clamp(1rem, 2vw, 1.35rem);
  color: var(--ss-muted);
  font-weight: 600;
  margin-top: 0.5rem;
}

.ss-glossary-hero__support {
  font-size: 1.05rem;
  max-width: 58ch;
}

.ss-glossary-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  margin-top: 1.4rem;
}

.ss-glossary-jumpnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-bottom: 1.6rem;
}

.ss-glossary-jumpnav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.4rem;
  min-height: 2.4rem;
  padding: 0.25rem 0.55rem;
  border-radius: 999px;
  border: 1px solid rgba(54, 43, 36, 0.14);
  background: rgba(255, 255, 255, 0.82);
  color: var(--ss-text);
  text-decoration: none;
  font-weight: 700;
}

.ss-glossary-jumpnav a:hover,
.ss-glossary-jumpnav a:focus-visible {
  background: rgba(40, 159, 161, 0.12);
  color: var(--ss-slate);
}

.ss-glossary-jumpnav a.is-disabled {
  opacity: 0.38;
  pointer-events: none;
}

.ss-glossary-controls {
  display: grid;
  gap: 1rem;
  margin-bottom: 1rem;
}

.page-glossary .glossary-controls {
  position: static;
  margin-top: 0;
  padding-top: clamp(1.25rem, 3vw, 2rem);
}

.page-glossary .ss-glossary-paths + fieldset {
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.ss-glossary-search input {
  width: 100%;
  min-height: 3.3rem;
  padding: 0.85rem 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(54, 43, 36, 0.14);
  background: rgba(255, 255, 255, 0.92);
  color: var(--ss-text);
  box-shadow: 0 12px 30px rgba(31, 23, 18, 0.08);
}

.ss-glossary-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.ss-glossary-filter {
  padding: 0.65rem 0.95rem;
  border-radius: 999px;
  border: 1px solid rgba(54, 43, 36, 0.14);
  background: rgba(255, 255, 255, 0.85);
  color: var(--ss-text);
  font-weight: 700;
  transition: background-color 160ms ease, color 160ms ease, border-color 160ms ease;
}

.ss-glossary-filter.is-active,
.ss-glossary-filter:hover,
.ss-glossary-filter:focus-visible {
  background: var(--ss-teal);
  border-color: var(--ss-teal);
  color: #fff;
}

.ss-glossary-results {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--ss-slate);
  margin-bottom: 1.2rem;
}

.ss-glossary-empty {
  border: 1px dashed rgba(54, 43, 36, 0.18);
  border-radius: 1rem;
  padding: 1rem 1.1rem;
  background: rgba(255, 255, 255, 0.75);
  margin-bottom: 1.4rem;
}

.ss-glossary-letter-section + .ss-glossary-letter-section {
  margin-top: 2rem;
}

.ss-glossary-letter-heading {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: baseline;
  margin-bottom: 1rem;
}

.ss-glossary-letter-heading h2 {
  font-size: clamp(2rem, 4vw, 2.9rem);
  margin-bottom: 0;
}

.ss-glossary-letter-heading span {
  color: var(--ss-muted);
  font-size: 0.92rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ss-glossary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
}

.ss-glossary-card {
  height: 100%;
  padding: 1.2rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(54, 43, 36, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 244, 238, 0.92));
  box-shadow: 0 14px 34px rgba(31, 23, 18, 0.08);
}

.ss-glossary-card h2,
.ss-glossary-card p {
  max-width: none;
}

.ss-glossary-card__eyebrow {
  margin-bottom: 0.55rem;
  color: var(--ss-slate);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.78rem;
  font-weight: 800;
}

.ss-glossary-card__link {
  display: inline-flex;
  margin-top: 0.9rem;
  font-weight: 700;
}

.ss-glossary-cta__panel,
.ss-glossary-term-cta,
.ss-glossary-related,
.ss-glossary-term-block {
  border: 1px solid rgba(54, 43, 36, 0.12);
  border-radius: 1.35rem;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 14px 34px rgba(31, 23, 18, 0.08);
}

.ss-glossary-cta__panel {
  padding: clamp(1.4rem, 3vw, 2.2rem);
}

.ss-glossary-term-layout {
  display: grid;
  gap: 1.2rem;
}

.ss-glossary-term-main {
  display: grid;
  gap: 1rem;
}

.ss-glossary-term-block,
.ss-glossary-related,
.ss-glossary-term-cta {
  padding: 1.25rem;
}

.ss-glossary-term-block h2,
.ss-glossary-related h2,
.ss-glossary-term-cta h2 {
  margin-bottom: 0.7rem;
  font-size: 1.28rem;
}

.ss-glossary-related ul {
  padding-left: 1.1rem;
  margin-bottom: 0;
}

.ss-glossary-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-bottom: 1rem;
  color: var(--ss-muted);
  font-size: 0.94rem;
}

.ss-glossary-breadcrumbs a {
  color: var(--ss-slate);
}

.ss-glossary-actions--stack {
  flex-direction: column;
  align-items: stretch;
}

@media (min-width: 992px) {
  .ss-glossary-controls {
    grid-template-columns: minmax(280px, 1fr) auto;
    align-items: center;
  }

  .ss-glossary-term-layout {
    grid-template-columns: minmax(0, 1.75fr) minmax(280px, 0.95fr);
    align-items: start;
  }

  .ss-glossary-term-side {
    position: sticky;
    top: 1rem;
    display: grid;
    gap: 1rem;
  }
}

@media (max-width: 767.98px) {
  .ss-glossary-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .ss-glossary-actions .btn {
    width: 100%;
  }

  .ss-glossary-letter-heading {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 640px) {
  .glossary-hero-actions {
    display: grid;
  }

  .glossary-hero-actions .btn {
    width: 100%;
  }
}

.ss-glossary-hero-v2 {
  padding-top: 1.4rem;
  padding-bottom: 2.1rem;
  border-bottom: 1px solid rgba(54, 43, 36, 0.1);
}

.glossary-hero.conversion-bridge {
  max-width: 980px;
  margin: 0 auto;
  padding: clamp(2.5rem, 6vw, 5rem) 1rem 2rem;
  text-align: center;
}

.glossary-hero .eyebrow,
.first-class-terms .eyebrow {
  margin: 0 0 0.75rem;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ss-orange, #E05500);
}

.glossary-hero h1 {
  max-width: 850px;
  margin: 0 auto;
  font-size: clamp(2.35rem, 7vw, 4.6rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
}

.glossary-hero-copy {
  max-width: 720px;
  margin: 1rem auto 0;
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  line-height: 1.45;
}

.glossary-hero-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.8rem;
  margin-top: 1.5rem;
}

.glossary-hero-actions .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0.85rem 1.15rem;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
}

.glossary-btn-primary {
  background: var(--ss-teal, #289FA1);
  color: #fff;
}

.glossary-btn-secondary {
  border: 2px solid currentColor;
  color: inherit;
  background: transparent;
}

.glossary-reassurance {
  max-width: 620px;
  margin: 1rem auto 0;
  font-size: 0.98rem;
  opacity: 0.82;
}

.first-class-terms {
  max-width: 980px;
  margin: 0 auto 2rem;
  padding: 1rem;
}

.first-class-terms-header {
  max-width: 700px;
  margin-bottom: 1rem;
}

.first-class-terms-header h2 {
  margin: 0 0 0.35rem;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  line-height: 1.05;
}

.first-class-terms-header p {
  margin: 0;
  line-height: 1.5;
}

.first-class-term-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.first-class-term-links a {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0.65rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(0, 0, 0, 0.14);
  text-decoration: none;
  font-weight: 700;
  color: inherit;
  background: rgba(255, 255, 255, 0.72);
}

/* Glossary refresh buckets */
.page-glossary .glossary-page {
  background:
    radial-gradient(1100px 420px at 15% -5%, rgba(40, 159, 161, 0.16), transparent 55%),
    radial-gradient(900px 360px at 95% 0%, rgba(224, 85, 0, 0.10), transparent 58%),
    linear-gradient(180deg, #fffdfa 0%, #f9f5ef 100%);
}

.page-glossary .glossary-page .container {
  max-width: var(--ss-max);
}

.page-glossary .glossary-page .container--narrow {
  max-width: 860px;
}

.page-glossary .glossary-page .section {
  padding: clamp(2rem, 4vw, 3.5rem) 0;
}

.page-glossary .glossary-page .section--compact {
  padding: clamp(1.4rem, 3vw, 2.2rem) 0;
}

.page-glossary .glossary-hero,
.page-glossary .starter-terms,
.page-glossary .glossary-how-to,
.page-glossary .glossary-browser,
.page-glossary .glossary-results,
.page-glossary .glossary-cta-strip {
  position: relative;
}

.page-glossary .glossary-hero__eyebrow {
  display: inline-flex;
  min-height: 2.1rem;
  align-items: center;
  padding: 0.3rem 0.8rem;
  border-radius: 999px;
  background: #eef7f7;
  color: var(--ss-teal);
  font-size: 0.84rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.page-glossary .glossary-hero__title {
  margin: 0.9rem 0 0.8rem;
  font-size: clamp(2.2rem, 4.7vw, 4rem);
  line-height: 1;
  max-width: 12ch;
}

.page-glossary .glossary-hero__lede {
  max-width: 68ch;
}

.page-glossary .button-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  align-items: center;
}

.page-glossary .btn-secondary {
  border: 1px solid rgba(54, 43, 36, 0.14);
  background: rgba(255, 255, 255, 0.86);
  color: var(--ss-text);
}

.page-glossary .chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  list-style: none;
  padding: 0;
  margin: 1rem 0 0;
}

.page-glossary .chip {
  display: inline-flex;
  align-items: center;
  min-height: 2.2rem;
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
  border: 1px solid rgba(54, 43, 36, 0.12);
  background: #fff;
  font-size: 0.9rem;
  font-weight: 700;
}

.page-glossary .chip--soft {
  background: rgba(255, 255, 255, 0.86);
}

.page-glossary .chip--filter {
  cursor: pointer;
}

.page-glossary .chip--filter.is-active,
.page-glossary .chip--filter:hover,
.page-glossary .chip--filter:focus-visible {
  background: var(--ss-teal);
  border-color: var(--ss-teal);
  color: #fff;
}

.page-glossary .chip--link {
  text-decoration: none;
  color: var(--ss-text);
}

.page-glossary .term-pill {
  display: inline-flex;
  margin: 0;
  min-height: 1.8rem;
  align-items: center;
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  background: #eef7f7;
  color: var(--ss-teal);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.page-glossary .card-grid {
  display: grid;
  gap: 1rem;
}

.page-glossary .card-grid--4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

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

.page-glossary .starter-card,
.page-glossary .glossary-card,
.page-glossary .glossary-cta-strip__inner {
  border: 1px solid rgba(54, 43, 36, 0.12);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 14px 34px rgba(31, 23, 18, 0.08);
}

.page-glossary .starter-card,
.page-glossary .glossary-card {
  padding: 1.1rem;
  border-radius: 1.25rem;
}

.page-glossary .starter-card {
  box-shadow: 0 8px 20px rgba(31, 23, 18, 0.05);
  background: rgba(255, 255, 255, 0.9);
}

.page-glossary .starter-card__title,
.page-glossary .glossary-card__title {
  margin: 0.55rem 0 0;
  font-size: 1.2rem;
}

.page-glossary .starter-card__text,
.page-glossary .glossary-card__definition {
  margin: 0.75rem 0;
}

@media (min-width: 768px) {
  .page-glossary .glossary-card__definition {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
  }
}

.page-glossary .text-link {
  color: var(--ss-orange);
  font-weight: 800;
  text-decoration: none;
}

.page-glossary .glossary-browser__controls {
  border: 1px solid rgba(54, 43, 36, 0.12);
  border-radius: 1.4rem;
  background: #f7fafb;
  padding: 1.1rem;
}

.page-glossary .glossary-browser__search .form-control {
  min-height: 3.15rem;
  border-radius: 0.95rem;
}

.page-glossary .glossary-browser__filters {
  margin-top: 1rem;
  display: grid;
  gap: 0.8rem;
}

.page-glossary .filter-group {
  margin: 0;
}

.page-glossary .filter-group__label {
  font-size: 0.85rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.4rem;
}

.page-glossary .glossary-alpha {
  margin-top: 1rem;
}

.page-glossary .glossary-alpha__list {
  display: grid;
  grid-template-columns: repeat(13, minmax(0, 1fr));
  gap: 0.45rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.page-glossary .glossary-alpha__link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 2.2rem;
  border-radius: 0.8rem;
  border: 1px solid rgba(54, 43, 36, 0.12);
  background: #fff;
  color: var(--ss-text);
  font-weight: 800;
  text-decoration: none;
}

.page-glossary .glossary-alpha__link.is-disabled {
  opacity: 0.35;
  pointer-events: none;
}

.page-glossary .glossary-browser__summary {
  margin: 1rem 0 0;
  font-weight: 700;
}

.page-glossary .glossary-browser__empty {
  margin-top: 0.7rem;
}

.page-glossary .glossary-browser__empty.is-hidden {
  display: none;
}

.page-glossary .glossary-letter-group {
  margin-top: 1.6rem;
}

.page-glossary .glossary-letter-group__title {
  margin-bottom: 1rem;
  font-size: 1.75rem;
  scroll-margin-top: 108px;
}

.page-glossary .glossary-card {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  height: 100%;
}

.page-glossary .glossary-card__related {
  margin-top: auto;
  margin-bottom: 0;
}

.page-glossary .glossary-cta-strip__inner {
  border-radius: 1.5rem;
  padding: 1.5rem;
}

.page-glossary .glossary-cta-strip__microcopy {
  margin: 0.8rem 0 0;
  font-size: 0.92rem;
}

@media (max-width: 1100px) {
  .page-glossary .card-grid--4,
  .page-glossary .card-grid--3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page-glossary .glossary-alpha__list {
    grid-template-columns: repeat(9, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  .page-glossary .button-row {
    flex-direction: column;
    align-items: stretch;
  }

  .page-glossary .button-row .btn {
    width: 100%;
  }

  .page-glossary .card-grid--4,
  .page-glossary .card-grid--3,
  .page-glossary .glossary-alpha__list {
    grid-template-columns: 1fr;
  }
}

/* Glossary term page parity with glossary index visual system */
.page-glossary-term .term-page-parity {
  max-width: var(--ss-max);
  margin-inline: auto;
  padding: clamp(1rem, 3vw, 1.75rem) var(--ss-pad, 16px) clamp(2rem, 4vw, 3rem);
}

.page-glossary-term .glossary-term-breadcrumbs,
.page-glossary-term .glossary-term-return,
.page-glossary-term .glossary-term-pagination {
  margin-bottom: 0.95rem;
}

.page-glossary-term .glossary-term-return,
.page-glossary-term .glossary-term-pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  align-items: center;
}

.page-glossary-term .glossary-term-return a,
.page-glossary-term .glossary-term-pagination a {
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  padding: 0.35rem 0.8rem;
  border-radius: 999px;
  border: 1px solid rgba(54, 43, 36, 0.14);
  background: rgba(255, 255, 255, 0.86);
  font-weight: 700;
  text-decoration: none;
}

.page-glossary-term .glossary-page .glossary-hero {
  margin-bottom: 1rem;
}

.page-glossary-term .glossary-page .glossary-hero__title {
  margin: 0.55rem 0 0.65rem;
  font-size: clamp(2rem, 4.4vw, 3.2rem);
  max-width: 14ch;
}

.page-glossary-term .glossary-page .glossary-hero__lede {
  margin-bottom: 0.75rem;
  max-width: 68ch;
}

.page-glossary-term .term-tags.chip-list {
  margin-top: 0.5rem;
}

.page-glossary-term .glossary-term-section,
.page-glossary-term .glossary-term-relationship-grid > .glossary-card {
  border: 1px solid rgba(54, 43, 36, 0.12);
  border-radius: 1.25rem;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 14px 34px rgba(31, 23, 18, 0.08);
  padding: 1.1rem;
  margin-bottom: 1rem;
}

.page-glossary-term .glossary-term-section > h2 {
  margin-bottom: 0.7rem;
}

.page-glossary-term .glossary-term-check-list li {
  margin-bottom: 0.65rem;
}

.page-glossary-term .glossary-term-best-next,
.page-glossary-term .glossary-term-relationship-map {
  margin-top: 1.1rem;
}

.page-glossary-term .glossary-term-best-next h3,
.page-glossary-term .glossary-term-relationship-map h3 {
  margin-bottom: 0.65rem;
}

.page-glossary-term .glossary-term-relationship-grid h4 {
  margin-bottom: 0.55rem;
  font-size: 1rem;
}

.glossary-term-cta {
  margin: 1.5rem 0;
  padding: clamp(1.35rem, 3vw, 2.35rem);
  border-radius: 1.5rem;
  background: #102a2b;
  color: #fff;
  box-shadow: 0 16px 36px rgba(16, 42, 43, 0.18);
}

.glossary-term-cta h2,
.glossary-term-cta p {
  color: #fff;
}

.glossary-term-cta__kicker {
  margin: 0 0 0.25rem;
  color: #75d6d8 !important;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.82rem;
}

.glossary-term-cta__actions,
.glossary-term-review-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
}

.glossary-term-cta__actions {
  margin-top: 1rem;
}

.glossary-term-cta__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0.75rem 1.1rem;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
}

.glossary-term-cta__button--primary {
  background: #e05500;
  color: #fff !important;
}

.glossary-term-cta__button--secondary {
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.12);
  color: #fff !important;
}

.glossary-term-cta__trust {
  margin-top: 1rem;
  font-weight: 800;
  opacity: 0.92;
}

.glossary-term-review-grid {
  align-items: stretch;
}

.glossary-term-review-card {
  flex: 1 1 18rem;
  margin: 0;
}

.glossary-term-review-card blockquote {
  margin: 0 0 0.75rem;
  color: var(--gls-muted, var(--ss-muted));
  line-height: 1.6;
}

.glossary-term-review-card figcaption {
  color: var(--gls-text, var(--ss-text));
  font-weight: 800;
}

.glossary-early-cta {
  margin: 1.25rem 0 2rem;
  padding: 1.15rem;
  border: 1px solid rgba(40, 159, 161, 0.28);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(40, 159, 161, 0.10), rgba(0, 221, 224, 0.06));
}

.glossary-early-cta__kicker {
  margin: 0 0 0.25rem;
  font-weight: 800;
  font-size: 1rem;
}

.glossary-early-cta__text {
  margin: 0 0 0.85rem;
  max-width: 42rem;
}

.glossary-early-cta__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.75rem 1rem;
  border-radius: 999px;
  background: #e05500;
  color: #fff;
  font-weight: 800;
  text-decoration: none;
}

.glossary-early-cta__button:hover,
.glossary-early-cta__button:focus {
  background: #b94600;
  color: #fff;
  text-decoration: none;
}

.page-glossary-term .glossary-term-section :is(ul, ol) {
  margin-bottom: 0;
  padding-left: 1.2rem;
}

.page-glossary-term .glossary-term-related-grid,
.page-glossary-term .glossary-term-relationship-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

.page-glossary-term .glossary-term-relationship-grid > .glossary-card {
  margin-bottom: 0;
}

.page-glossary-term .glossary-term-faq-list {
  display: grid;
  gap: 0.75rem;
}

.page-glossary-term .glossary-term-faq-list details.glossary-card {
  margin: 0;
  padding: 0.9rem 1rem;
}

.page-glossary-term .glossary-term-faq-list summary {
  cursor: pointer;
  list-style: none;
  font-weight: 800;
}

.page-glossary-term .glossary-term-faq-list summary::-webkit-details-marker {
  display: none;
}

.page-glossary-term .glossary-term-faq-list details p {
  margin-top: 0.75rem;
}

.page-glossary-term .glossary-term-pagination {
  justify-content: center;
}

@media (max-width: 1100px) {
  .page-glossary-term .glossary-term-related-grid,
  .page-glossary-term .glossary-term-relationship-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767.98px) {
  .page-glossary-term .glossary-term-return,
  .page-glossary-term .glossary-term-pagination {
    flex-direction: column;
    align-items: stretch;
  }

  .page-glossary-term .glossary-term-return :is(a, button),
  .page-glossary-term .glossary-term-pagination a {
    width: 100%;
    justify-content: center;
  }

  .page-glossary-term .glossary-term-cta__button {
    width: 100%;
  }
}

/* Glossary modality polish (scoped override layer) */
.page-glossary[data-glossary-theme-root],
.page-glossary-term[data-glossary-theme-root] {
  --gls-bg: #f9f5ef;
  --gls-surface: #ffffff;
  --gls-surface-2: #f7fafb;
  --gls-text: #1f1712;
  --gls-muted: #4f433c;
  --gls-border: rgba(54, 43, 36, 0.14);
  --gls-accent: #289fa1;
  --gls-accent-strong: #e05500;
  --gls-focus: rgba(40, 159, 161, 0.32);
}

.page-glossary-term[data-glossary-theme-root][data-glossary-theme="dark"] {
  --gls-bg: #12171b;
  --gls-surface: #192027;
  --gls-surface-2: #141b21;
  --gls-text: #ecf2f4;
  --gls-muted: #b9c3c9;
  --gls-border: rgba(220, 234, 241, 0.2);
  --gls-accent: #3ab8ba;
  --gls-accent-strong: #ff8b45;
  --gls-focus: rgba(58, 184, 186, 0.45);
}

/* Index currently uses multiple light-surface legacy blocks; keep dark toggle readable here. */
.page-glossary[data-glossary-theme-root][data-glossary-theme="dark"] {
  --gls-bg: #f9f5ef;
  --gls-surface: #ffffff;
  --gls-surface-2: #f7fafb;
  --gls-text: #1f1712;
  --gls-muted: #4f433c;
  --gls-border: rgba(54, 43, 36, 0.14);
  --gls-accent: #289fa1;
  --gls-accent-strong: #e05500;
  --gls-focus: rgba(40, 159, 161, 0.32);
}

.page-glossary[data-glossary-theme-root],
.page-glossary-term[data-glossary-theme-root] {
  color: var(--gls-text);
}

.page-glossary[data-glossary-theme-root] h1,
.page-glossary[data-glossary-theme-root] h2,
.page-glossary[data-glossary-theme-root] h3,
.page-glossary-term[data-glossary-theme-root] h1,
.page-glossary-term[data-glossary-theme-root] h2,
.page-glossary-term[data-glossary-theme-root] h3,
.page-glossary-term[data-glossary-theme-root] summary,
.page-glossary-term[data-glossary-theme-root] .term-meta,
.page-glossary-term[data-glossary-theme-root] .term-tags span {
  color: var(--gls-text);
}

.page-glossary[data-glossary-theme-root] p,
.page-glossary[data-glossary-theme-root] li,
.page-glossary-term[data-glossary-theme-root] p,
.page-glossary-term[data-glossary-theme-root] li,
.page-glossary-term[data-glossary-theme-root] .term-summary {
  color: var(--gls-muted);
}

.page-glossary[data-glossary-theme-root] .ss-main,
.page-glossary-term[data-glossary-theme-root] .ss-main {
  background: var(--gls-bg);
}

.page-glossary[data-glossary-theme-root][data-glossary-theme="dark"] .ss-main,
.page-glossary-term[data-glossary-theme-root][data-glossary-theme="dark"] .ss-main {
  background:
    radial-gradient(900px 360px at 15% -5%, rgba(58, 184, 186, 0.18), transparent 55%),
    radial-gradient(820px 320px at 95% 0%, rgba(255, 139, 69, 0.12), transparent 58%),
    var(--gls-bg);
}

.page-glossary[data-glossary-theme-root] .ss-glossary-term-card,
.page-glossary[data-glossary-theme-root] .term-card,
.page-glossary-term[data-glossary-theme-root] .term-hero,
.page-glossary-term[data-glossary-theme-root] .term-card,
.page-glossary-term[data-glossary-theme-root] .ss-glossary-rich-sidebar-card,
.page-glossary-term[data-glossary-theme-root] .on-this-page,
.page-glossary-term[data-glossary-theme-root] section[id] {
  background: var(--gls-surface);
  border-color: var(--gls-border);
  color: var(--gls-text);
}

.page-glossary[data-glossary-theme-root] .ss-glossary-term-def,
.page-glossary-term[data-glossary-theme-root] p,
.page-glossary-term[data-glossary-theme-root] li {
  color: var(--gls-muted);
}

.page-glossary[data-glossary-theme-root] a,
.page-glossary-term[data-glossary-theme-root] a {
  color: color-mix(in srgb, var(--gls-accent) 90%, var(--gls-text));
}

.page-glossary[data-glossary-theme-root] a:hover,
.page-glossary[data-glossary-theme-root] a:focus-visible,
.page-glossary-term[data-glossary-theme-root] a:hover,
.page-glossary-term[data-glossary-theme-root] a:focus-visible {
  color: color-mix(in srgb, var(--gls-accent-strong) 85%, var(--gls-text));
}

.page-glossary-term[data-glossary-theme-root] .term-tags span {
  border: 1px solid var(--gls-border);
  background: var(--gls-surface-2);
}

.page-glossary-term[data-glossary-theme-root] .term-hero h1 {
  color: var(--gls-text);
}

.page-glossary-term[data-glossary-theme-root] .term-hero .term-meta,
.page-glossary-term[data-glossary-theme-root] .term-hero .term-summary {
  color: var(--gls-muted);
}

.page-glossary-term[data-glossary-theme-root] section[id] h2,
.page-glossary-term[data-glossary-theme-root] .related-term-card h3,
.page-glossary-term[data-glossary-theme-root] .term-card__cta,
.page-glossary-term[data-glossary-theme-root] .relationship-grid h3,
.page-glossary-term[data-glossary-theme-root] .relationship-grid h4 {
  color: var(--gls-text);
}

.page-glossary-term[data-glossary-theme-root] section[id] a,
.page-glossary-term[data-glossary-theme-root] .term-card h3 a,
.page-glossary-term[data-glossary-theme-root] .term-card__cta {
  color: color-mix(in srgb, var(--gls-accent) 92%, var(--gls-text));
}

.page-glossary-term[data-glossary-theme-root] section[id] a:hover,
.page-glossary-term[data-glossary-theme-root] section[id] a:focus-visible,
.page-glossary-term[data-glossary-theme-root] .term-card h3 a:hover,
.page-glossary-term[data-glossary-theme-root] .term-card__cta:hover {
  color: color-mix(in srgb, var(--gls-accent-strong) 88%, var(--gls-text));
}

.page-glossary[data-glossary-theme-root] .ss-main > section.ss-starter-pack {
  border-color: rgba(40, 159, 161, 0.25);
  background:
    radial-gradient(circle at top left, rgba(0, 221, 224, 0.14), transparent 34%),
    linear-gradient(135deg, rgba(8, 20, 24, 0.96), rgba(12, 34, 40, 0.96));
  color: #ffffff;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.18);
}

.page-glossary[data-glossary-theme-root] .ss-starter-pack .ss-starter-card {
  border-color: rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.075);
  box-shadow: none;
  color: #ffffff;
}

.page-glossary[data-glossary-theme-root] .ss-starter-pack .ss-starter-card:hover,
.page-glossary[data-glossary-theme-root] .ss-starter-pack .ss-starter-card:focus-visible {
  border-color: rgba(0, 221, 224, 0.55);
  background: rgba(255, 255, 255, 0.12);
}

.page-glossary[data-glossary-theme-root] .ss-starter-pack .ss-starter-card__number {
  color: #00dde0;
}

.page-glossary[data-glossary-theme-root] .ss-starter-pack .ss-starter-card strong {
  color: #ffffff;
}

.page-glossary[data-glossary-theme-root] .ss-starter-pack .ss-starter-card span:last-child {
  color: rgba(255, 255, 255, 0.78);
}

.page-glossary[data-glossary-theme-root] .ss-starter-pack h2 {
  color: #ffffff;
}

.page-glossary[data-glossary-theme-root] .ss-starter-pack p {
  color: rgba(255, 255, 255, 0.84);
}

.page-glossary[data-glossary-theme-root] .ss-starter-pack__cta,
.page-glossary[data-glossary-theme-root] .ss-starter-pack__footer a {
  background: #e05500;
  color: #ffffff;
}

.page-glossary[data-glossary-theme-root] .ss-starter-pack__cta:hover,
.page-glossary[data-glossary-theme-root] .ss-starter-pack__cta:focus-visible,
.page-glossary[data-glossary-theme-root] .ss-starter-pack__footer a:hover,
.page-glossary[data-glossary-theme-root] .ss-starter-pack__footer a:focus-visible {
  color: #ffffff;
}

.page-glossary[data-glossary-theme-root] #copy-state-link,
.page-glossary[data-glossary-theme-root] #surprise-me-inline,
.page-glossary[data-glossary-theme-root] #surprise-me-az,
.page-glossary-term[data-glossary-theme-root] #copy-term-link {
  min-height: 2.25rem;
  border-radius: 999px;
  border: 1px solid var(--gls-border);
  background: var(--gls-surface-2);
  color: var(--gls-text);
  font-weight: 700;
  transition: border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease, background 140ms ease;
}

.page-glossary[data-glossary-theme-root] #surprise-me-inline,
.page-glossary[data-glossary-theme-root] #surprise-me-az {
  border-color: color-mix(in srgb, var(--gls-accent) 45%, var(--gls-border));
}

.page-glossary[data-glossary-theme-root] #copy-state-link:hover,
.page-glossary[data-glossary-theme-root] #surprise-me-inline:hover,
.page-glossary[data-glossary-theme-root] #surprise-me-az:hover,
.page-glossary-term[data-glossary-theme-root] #copy-term-link:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--gls-accent) 60%, var(--gls-border));
  box-shadow: 0 8px 16px rgba(31, 23, 18, 0.1);
}

.page-glossary[data-glossary-theme-root] #copy-state-link:active,
.page-glossary[data-glossary-theme-root] #surprise-me-inline:active,
.page-glossary[data-glossary-theme-root] #surprise-me-az:active,
.page-glossary-term[data-glossary-theme-root] #copy-term-link:active {
  transform: translateY(0);
}

.page-glossary[data-glossary-theme-root] #copy-state-link:focus-visible,
.page-glossary[data-glossary-theme-root] #surprise-me-inline:focus-visible,
.page-glossary[data-glossary-theme-root] #surprise-me-az:focus-visible,
.page-glossary-term[data-glossary-theme-root] #copy-term-link:focus-visible,
.page-glossary[data-glossary-theme-root] #glossary-theme:focus-visible,
.page-glossary[data-glossary-theme-root] .ss-glossary-chip:focus-visible,
.page-glossary[data-glossary-theme-root] .ss-glossary-az-nav a:focus-visible {
  outline: 3px solid var(--gls-focus);
  outline-offset: 2px;
}

.page-glossary[data-glossary-theme-root] #glossary-theme {
  min-height: 2.25rem;
  border-radius: 0.8rem;
  border: 1px solid var(--gls-border);
  background: var(--gls-surface-2);
  color: var(--gls-text);
  font-weight: 650;
}

.page-glossary[data-glossary-theme-root] .ss-glossary-chip {
  border-color: var(--gls-border);
  background: var(--gls-surface);
  color: var(--gls-text);
}

.page-glossary[data-glossary-theme-root] .ss-glossary-chip.is-active,
.page-glossary[data-glossary-theme-root] .ss-glossary-chip[aria-pressed="true"],
.page-glossary[data-glossary-theme-root] .ss-glossary-chip:hover {
  border-color: var(--gls-accent);
  background: color-mix(in srgb, var(--gls-accent) 88%, #ffffff 12%);
  color: #ffffff;
}

.page-glossary[data-glossary-theme-root] .ss-glossary-az-nav a {
  border-color: var(--gls-border);
  background: var(--gls-surface);
  color: var(--gls-text);
}

.page-glossary[data-glossary-theme-root] #glossary-az-rail {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.5rem;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 0.2rem;
  -webkit-overflow-scrolling: touch;
}

.page-glossary[data-glossary-theme-root] #glossary-az-rail > a[data-letter-link] {
  flex: 0 0 2.4rem;
}

.page-glossary[data-glossary-theme-root] #surprise-me-az {
  flex: 0 0 auto;
}

.page-glossary[data-glossary-theme-root] .ss-glossary-az-nav a.is-disabled {
  opacity: 0.5;
  filter: saturate(0.5);
  background: color-mix(in srgb, var(--gls-surface-2) 88%, transparent);
}

.page-glossary[data-glossary-theme-root] .badge.text-bg-dark,
.page-glossary[data-glossary-theme-root] .badge.text-bg-secondary {
  display: inline-flex;
  align-items: center;
  min-height: 1.55rem;
  padding: 0.16rem 0.52rem;
  border-radius: 999px;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  font-size: 0.68rem;
  font-weight: 800;
  border: 1px solid transparent;
}

.page-glossary[data-glossary-theme-root] .badge.text-bg-dark {
  background: color-mix(in srgb, var(--gls-accent) 92%, #0b1718 8%) !important;
  color: #ffffff !important;
}

.page-glossary[data-glossary-theme-root] .badge.text-bg-secondary {
  background: color-mix(in srgb, var(--gls-accent-strong) 88%, #0f0f0f 12%) !important;
  color: #ffffff !important;
}

.page-glossary[data-glossary-theme-root] .ss-glossary-term-card p {
  margin-bottom: 0.45rem;
}

.page-glossary[data-glossary-theme-root] .ss-glossary-term-card p .badge + .badge {
  margin-left: 0.35rem;
}

.glossary-proof-block {
  margin: clamp(2rem, 5vw, 4rem) auto 1.5rem;
  padding: 0 1rem;
}

.glossary-proof-card {
  max-width: 980px;
  margin: 0 auto;
  padding: clamp(1.5rem, 4vw, 2.5rem);
  border: 1px solid rgba(40, 159, 161, 0.24);
  border-radius: 24px;
  background:
    radial-gradient(circle at top left, rgba(0, 221, 224, 0.12), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(245, 252, 252, 0.96));
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.08);
}

.glossary-proof-kicker {
  margin: 0 0 0.5rem;
  color: #289fa1;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.glossary-proof-card h2 {
  max-width: 720px;
  margin: 0 0 1.25rem;
  font-size: clamp(1.55rem, 3vw, 2.25rem);
  line-height: 1.1;
}

.glossary-proof-quotes {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}

.glossary-proof-quotes blockquote {
  margin: 0;
  padding: 1rem;
  border-left: 4px solid #e05500;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.78);
  font-weight: 700;
  line-height: 1.35;
}

@media (max-width: 760px) {
  .glossary-proof-quotes {
    grid-template-columns: 1fr;
  }
}

.glossary-inline-cta {
  margin: 1.5rem 0 1.75rem;
  padding: 1.25rem;
  border: 1px solid rgba(0, 221, 224, 0.35);
  border-radius: 1rem;
  background:
    radial-gradient(circle at top left, rgba(0, 221, 224, 0.16), transparent 34rem),
    linear-gradient(135deg, rgba(10, 28, 34, 0.96), rgba(8, 16, 22, 0.96));
  color: #ffffff;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.22);
}

.glossary-inline-cta__eyebrow {
  margin: 0 0 0.4rem;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #00dde0;
}

.glossary-inline-cta h2 {
  margin: 0 0 0.55rem;
  font-size: clamp(1.35rem, 3vw, 2rem);
  line-height: 1.1;
}

.glossary-inline-cta p {
  max-width: 46rem;
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
}

.glossary-inline-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1rem;
}

.glossary-inline-cta__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0.75rem 1rem;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
}

.glossary-inline-cta__button--primary {
  background: #e05500;
  color: #ffffff;
}

.glossary-inline-cta__button--secondary {
  border: 1px solid rgba(255, 255, 255, 0.36);
  color: #ffffff;
  background: rgba(255, 255, 255, 0.08);
}

.glossary-inline-cta__button:hover,
.glossary-inline-cta__button:focus {
  transform: translateY(-1px);
  text-decoration: none;
}

@media (min-width: 760px) {
  .glossary-inline-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 1.4rem 1.6rem;
  }

  .glossary-inline-cta__actions {
    margin-top: 0;
    flex-shrink: 0;
  }
}

.page-glossary[data-glossary-theme-root] .glossary-surface--dark.ss-glossary-paths,
.page-glossary[data-glossary-theme-root] .glossary-surface--dark.ss-glossary-paths h2,
.page-glossary[data-glossary-theme-root] .glossary-surface--dark.ss-glossary-paths h3,
.page-glossary[data-glossary-theme-root] .glossary-surface--dark.ss-glossary-paths p {
  color: #f5fbfb !important;
}

.page-glossary[data-glossary-theme-root] .glossary-surface--dark .ss-paths-header p,
.page-glossary[data-glossary-theme-root] .glossary-surface--dark .ss-path-card p {
  color: rgba(245, 251, 251, 0.74) !important;
}

.page-glossary[data-glossary-theme-root] .glossary-surface--dark .ss-paths-eyebrow,
.page-glossary[data-glossary-theme-root] .glossary-surface--dark .ss-path-link {
  color: #58f4f6 !important;
}

.page-glossary[data-glossary-theme-root] .glossary-surface--dark .ss-path-chips a {
  color: #58f4f6 !important;
}

.page-glossary[data-glossary-theme-root] .glossary-surface--dark .ss-path-btn {
  color: #ffffff !important;
}

@media (max-width: 640px) {
  .page-glossary .glossary-page {
    overflow-x: hidden;
  }

  .page-glossary .glossary-hero,
  .page-glossary .ss-starter-pack,
  .page-glossary .glossary-controls > .container,
  .page-glossary .ss-glossary-paths {
    box-sizing: border-box;
    width: calc(100vw - 20px);
    max-width: calc(100vw - 20px);
    margin-left: auto;
    margin-right: auto;
  }

  .page-glossary .glossary-hero h1,
  .page-glossary .ss-starter-pack h2,
  .page-glossary .ss-paths-header h2 {
    overflow-wrap: anywhere;
  }
}

/* Glossary A-Z rail hard lock: always horizontal */
.page-glossary[data-glossary-theme-root] .ss-glossary-az-nav {
  display: block !important;
  grid-template-columns: none !important;
}

.page-glossary[data-glossary-theme-root] #glossary-az-rail {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center;
  gap: 0.5rem;
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  -webkit-overflow-scrolling: touch;
}

.page-glossary[data-glossary-theme-root] #glossary-az-rail > a[data-letter-link],
.page-glossary[data-glossary-theme-root] #glossary-az-rail > button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  min-height: 2.25rem;
  flex: 0 0 auto !important;
  transform: none;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}

@media (min-width: 768px) {
  .page-glossary[data-glossary-theme-root] #glossary-az-rail {
    justify-content: center;
    overflow-x: visible;
  }
}

/* ================================
   Glossary Screenshot Fix Pass
   ================================ */

/* 1. Fix dark CTA readability */
.page-glossary .glossary-cta-band,
.page-glossary .glossary-bottom-cta,
.page-glossary .start-cta,
.page-glossary .glossary-inline-cta {
  color: #f6fbfb;
}

.page-glossary .glossary-cta-band h2,
.page-glossary .glossary-bottom-cta h2,
.page-glossary .start-cta h2,
.page-glossary .glossary-inline-cta h2 {
  color: #ffffff !important;
}

.page-glossary .glossary-cta-band p,
.page-glossary .glossary-bottom-cta p,
.page-glossary .start-cta p,
.page-glossary .glossary-inline-cta p {
  color: rgba(246, 251, 251, 0.78) !important;
}

.page-glossary .glossary-cta-band .eyebrow,
.page-glossary .glossary-bottom-cta .eyebrow,
.page-glossary .start-cta .eyebrow,
.page-glossary .glossary-inline-cta__eyebrow {
  color: #00dde0 !important;
  opacity: 1;
}

/* 2. Improve CTA band layout */
.page-glossary .glossary-cta-band,
.page-glossary .glossary-bottom-cta,
.page-glossary .start-cta,
.page-glossary .glossary-inline-cta {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  max-width: 1120px;
  margin: 24px auto 72px;
  padding: clamp(26px, 4vw, 40px);
  border-radius: 20px;
  background:
    radial-gradient(circle at left, rgba(0, 221, 224, 0.14), transparent 38%),
    linear-gradient(135deg, #083033 0%, #071318 100%);
  border: 1px solid rgba(0, 221, 224, 0.28);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.2);
}

.page-glossary .glossary-cta-band h2,
.page-glossary .glossary-bottom-cta h2,
.page-glossary .start-cta h2,
.page-glossary .glossary-inline-cta h2 {
  margin: 0 0 10px;
  font-size: clamp(1.65rem, 4vw, 2.65rem);
  line-height: 1;
  letter-spacing: -0.045em;
}

.page-glossary .glossary-cta-actions,
.page-glossary .cta-actions,
.page-glossary .glossary-inline-cta__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
  margin-top: 0;
}

/* 3. Better CTA buttons */
.page-glossary .glossary-cta-band .btn,
.page-glossary .glossary-bottom-cta .btn,
.page-glossary .start-cta .btn,
.page-glossary .glossary-inline-cta__button {
  min-height: 52px;
  padding: 13px 20px;
  border-radius: 999px;
  font-weight: 900;
  letter-spacing: 0.01em;
}

.page-glossary .glossary-cta-band .btn-primary,
.page-glossary .glossary-bottom-cta .btn-primary,
.page-glossary .start-cta .btn-primary,
.page-glossary .glossary-inline-cta__button--primary {
  background: #e05500;
  border-color: #e05500;
  color: #ffffff !important;
  box-shadow: 0 12px 28px rgba(224, 85, 0, 0.26);
}

.page-glossary .glossary-cta-band .btn-outline,
.page-glossary .glossary-bottom-cta .btn-outline,
.page-glossary .start-cta .btn-outline,
.page-glossary .glossary-cta-band .btn-secondary,
.page-glossary .glossary-bottom-cta .btn-secondary,
.page-glossary .start-cta .btn-secondary,
.page-glossary .glossary-inline-cta__button--secondary {
  background: transparent;
  border: 1px solid rgba(246, 251, 251, 0.38);
  color: #58f4f6 !important;
}

.page-glossary .glossary-bottom-cta .glossary-btn,
.page-glossary .glossary-cta-band .glossary-btn,
.page-glossary .start-cta .glossary-btn,
.page-glossary .glossary-inline-cta .glossary-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 13px 22px;
  border-radius: 999px;
  font-weight: 900;
  line-height: 1.1;
  text-align: center;
  text-decoration: none;
}

.page-glossary .glossary-bottom-cta .glossary-btn-primary,
.page-glossary .glossary-cta-band .glossary-btn-primary,
.page-glossary .start-cta .glossary-btn-primary,
.page-glossary .glossary-inline-cta .glossary-btn-primary {
  background: #e05500 !important;
  border-color: #e05500 !important;
  color: #ffffff !important;
  box-shadow: 0 12px 28px rgba(224, 85, 0, 0.26);
}

/* 4. Stop bottom bar from covering card content on desktop */
.page-glossary .glossary-sticky-cta,
.page-glossary .sticky-cta,
.page-glossary .desktop-sticky-cta,
.page-glossary .mobile-action-bar,
.page-glossary .floating-cta {
  position: static !important;
  inset: auto !important;
  transform: none !important;
  width: fit-content;
  max-width: calc(100% - 28px);
  margin: 18px auto 48px;
}

/* 5. Add room before glossary cards */
.page-glossary .glossary-grid,
.page-glossary .terms-grid,
.page-glossary .term-grid,
.page-glossary .ss-glossary-term-grid {
  margin-top: 42px;
  margin-bottom: 80px;
}

/* 6. Polish glossary cards */
.page-glossary .glossary-card,
.page-glossary .term-card,
.page-glossary .card.term-card,
.page-glossary .ss-glossary-term-card {
  padding: 22px 20px 24px;
  border-radius: 22px;
  background: #ffffff;
  border: 1px solid rgba(7, 19, 20, 0.12);
  box-shadow: 0 18px 44px rgba(7, 19, 20, 0.08);
  overflow: hidden;
}

.page-glossary .glossary-card h3,
.page-glossary .term-card h3,
.page-glossary .card.term-card h3,
.page-glossary .ss-glossary-term-title {
  margin-top: 16px;
  margin-bottom: 12px;
  color: #087f82;
  font-size: 1.24rem;
  line-height: 1.15;
}

.page-glossary .glossary-card p,
.page-glossary .term-card p,
.page-glossary .card.term-card p,
.page-glossary .ss-glossary-term-def {
  color: #3f4f50;
  font-size: 1rem;
  line-height: 1.58;
}

.page-glossary .glossary-card .category,
.page-glossary .term-card .category,
.page-glossary .glossary-card .badge,
.page-glossary .term-card .badge,
.page-glossary .ss-glossary-term-tag {
  display: block;
  width: 100%;
  padding: 9px 12px;
  border-radius: 999px;
  background: #edf8f8;
  color: #3f4f50;
  text-align: center;
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* 7. Mobile behavior */
@media (max-width: 760px) {
  .page-glossary .glossary-cta-band,
  .page-glossary .glossary-bottom-cta,
  .page-glossary .start-cta,
  .page-glossary .glossary-inline-cta {
    grid-template-columns: 1fr;
    text-align: center;
    margin-bottom: calc(48px + env(safe-area-inset-bottom));
  }

  .page-glossary .glossary-cta-actions,
  .page-glossary .cta-actions,
  .page-glossary .glossary-inline-cta__actions {
    justify-content: center;
  }

  .page-glossary .mobile-sticky-cta {
    display: none !important;
  }
}

.ss-book-hero,
.ss-book-intro {
  padding: clamp(3rem, 7vw, 5.5rem) 0;
  background: #FBFAF8;
}

.ss-book-hero {
  padding-bottom: clamp(2.75rem, 5vw, 4.25rem);
}

.ss-book-intro .ss-eyebrow {
  margin-bottom: .5rem;
  color: #E05500;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ss-book-hero .ss-eyebrow {
  margin-bottom: .5rem;
  color: #E05500;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ss-book-hero h1 {
  margin-bottom: .75rem;
  color: #1F1712;
  font-size: clamp(2.2rem, 6vw, 4.25rem);
  line-height: .95;
}

.ss-book-hero .ss-lede,
.ss-book-intro .ss-lede {
  max-width: 820px;
  margin-bottom: 1.25rem;
  color: #306061;
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  font-weight: 700;
}

.ss-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

.ss-hero-actions .btn {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
}

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

.ss-lane-card {
  display: flex;
  flex-direction: column;
  gap: .7rem;
  padding: 1.25rem;
  background: #fff;
  border: 1px solid rgba(54, 43, 36, .14);
  border-radius: 1.25rem;
  box-shadow: 0 14px 34px rgba(54, 43, 36, .08);
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.ss-lane-card:hover,
.ss-lane-card:focus-within {
  transform: translateY(-2px);
  border-color: var(--ss-teal);
  box-shadow: var(--ss-shadow);
}

.ss-lane-card h2 {
  margin: 0;
  color: #1F1712;
  font-size: 1.35rem;
}

.ss-lane-card p {
  margin: 0;
  color: #4F433C;
}

.ss-lane-btn {
  width: 100%;
  margin-top: .35rem;
  padding: .85rem 1rem;
  border-radius: 999px;
  font-weight: 800;
}

.ss-lane-pressure {
  color: #306061;
  font-size: 0.93rem;
  font-weight: 800;
  line-height: 1.35;
}

.ss-learn-link {
  color: #306061;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: .2em;
}

.ss-lane-help {
  margin-top: 1.4rem;
  color: #4F433C;
  font-weight: 700;
}

.ss-lane-help a {
  color: #E05500;
}

.ss-gear-note {
  max-width: 760px;
  margin: 0 0 1.5rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(40, 159, 161, 0.24);
  border-radius: var(--ss-radius);
  background: rgba(40, 159, 161, 0.08);
  color: #1F1712;
  font-weight: 800;
}

.ss-safety-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
  margin: 1.5rem 0;
}

.ss-safety-strip__item,
.ss-step-card,
.ss-proof-card,
.ss-location-card,
.ss-final-cta-card,
.ss-booking-status {
  border: 1px solid var(--ss-border);
  border-radius: var(--ss-radius);
  background: var(--ss-surface);
  box-shadow: var(--ss-shadow-soft);
}

.ss-safety-strip__item {
  padding: 0.85rem 1rem;
  color: var(--ss-text);
  font-weight: 800;
}

.ss-booking-proof__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
  margin: 1rem 0 1.25rem;
}

.ss-booking-proof figure {
  margin: 0;
  padding: 1rem;
  border: 1px solid rgba(54, 43, 36, 0.12);
  border-radius: var(--ss-radius);
  background: rgba(255, 255, 255, 0.82);
}

.ss-booking-proof blockquote {
  margin: 0 0 0.65rem;
  color: #1F1712;
  font-weight: 800;
  line-height: 1.45;
}

.ss-booking-proof figcaption {
  color: #306061;
  font-size: 0.92rem;
  font-weight: 800;
}

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

.ss-step-card {
  padding: 1rem;
}

.ss-step-card h3 {
  margin-bottom: 0.45rem;
}

.ss-step-card__number {
  display: block;
  color: var(--ss-orange);
  font-weight: 900;
  margin-bottom: 0.35rem;
}

.ss-booking-status {
  margin-top: 1rem;
  padding: 0.85rem 1rem;
  color: var(--ss-text);
  font-weight: 700;
}

.page-book-intro .ss-main > .ss-section:not(.ss-book-hero) {
  padding: clamp(2.25rem, 5vw, 4rem) 0;
}

.page-book-intro .ss-main > .ss-section + .ss-section {
  border-top: 1px solid rgba(54, 43, 36, 0.1);
}

.page-book-intro .ss-eyebrow {
  margin-bottom: 0.5rem;
  color: var(--ss-orange);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.page-book-intro .ss-section-lede {
  max-width: 760px;
  margin-bottom: 1.25rem;
  color: var(--ss-muted);
  font-size: 1.05rem;
}

.ss-guided-panel,
.ss-location-card,
.ss-final-cta-card {
  padding: clamp(1.25rem, 3vw, 2rem);
}

.ss-guided-panel {
  border-radius: var(--ss-radius-lg);
  background: linear-gradient(135deg, rgba(40, 159, 161, 0.08), rgba(224, 85, 0, 0.06));
}

.ss-review-panel h2,
.ss-location-card h2,
.ss-final-cta-card h2 {
  color: var(--ss-text);
}

.ss-location-list {
  color: var(--ss-muted);
}

.ss-proof-link a {
  color: var(--ss-orange);
  font-weight: 800;
}

.ss-location-card {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 1.25rem;
  align-items: center;
}

.ss-location-list {
  display: grid;
  gap: 0.5rem;
  padding-left: 1.2rem;
}

.ss-final-cta-card {
  background: #102a2b;
  color: #fff;
}

.ss-final-cta-card h2,
.ss-final-cta-card p {
  color: #fff;
}

.ss-final-cta-card .ss-eyebrow {
  color: #75d6d8;
}

.ss-final-cta-actions {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

.ss-final-cta-actions .btn {
  min-width: 0;
  min-height: 48px;
  font-weight: 800;
  white-space: normal;
}

.ss-final-microcopy {
  margin: 1rem 0 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.95rem;
  font-weight: 800;
}

.ss-pricing-toggle {
  display: inline-flex;
  gap: 0.35rem;
  padding: 0.35rem;
  border: 1px solid var(--ss-border);
  border-radius: 999px;
  background: var(--ss-surface);
}

.ss-pricing-toggle button {
  min-height: 44px;
  padding: 0.55rem 1rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--ss-text);
  font-weight: 800;
}

.ss-pricing-toggle button.is-active {
  background: var(--ss-teal);
  color: #fff;
}

.ss-pricing-switcher {
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(2.5rem, 5vw, 5rem) 1rem;
}

.ss-pricing-header {
  max-width: 760px;
  margin: 0 auto 1.5rem;
  text-align: center;
}

.ss-eyebrow,
.ss-card-label {
  margin: 0 0 0.5rem;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ss-teal);
}

.ss-pricing-note {
  font-weight: 800;
}

.ss-pricing-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
  width: min(520px, 100%);
  margin: 1.5rem auto 2rem;
  padding: 0.4rem;
  border: 1px solid rgba(40, 159, 161, 0.28);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
}

.ss-pricing-tab {
  border: 0;
  border-radius: 999px;
  padding: 0.9rem 1rem;
  background: transparent;
  color: #123;
  font-weight: 900;
  cursor: pointer;
  transition: transform 0.18s ease, background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.ss-pricing-tab span {
  display: block;
  margin-top: 0.15rem;
  font-size: 0.76rem;
  font-weight: 700;
  opacity: 0.75;
}

.ss-pricing-tab:hover {
  transform: translateY(-1px);
}

.ss-pricing-tab:focus-visible {
  outline: 3px solid rgba(0, 221, 224, 0.65);
  outline-offset: 3px;
}

.ss-pricing-tab.is-active,
.ss-pricing-tab[aria-selected="true"] {
  background: var(--ss-teal);
  color: #fff;
  box-shadow: 0 10px 24px rgba(40, 159, 161, 0.32);
}

.ss-pricing-switcher > [data-pricing-panel] {
  display: none !important;
}

.ss-pricing-switcher > [data-pricing-panel].is-active {
  display: block !important;
}

.ss-pricing-switcher > [data-pricing-panel][hidden] {
  display: none !important;
}

.ss-panel-heading {
  text-align: center;
  margin-bottom: 1.25rem;
}

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

.ss-price-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 1.35rem;
  border: 1px solid rgba(18, 34, 51, 0.1);
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.08);
}

.ss-featured-card {
  border-color: rgba(224, 85, 0, 0.45);
  box-shadow: 0 18px 44px rgba(224, 85, 0, 0.13);
}

.ss-price-card h4 {
  margin: 0 0 0.65rem;
  font-size: clamp(1.35rem, 2vw, 1.75rem);
  line-height: 1.05;
}

.ss-price {
  margin: 0 0 0.85rem;
  font-size: clamp(1.85rem, 3vw, 2.45rem);
  font-weight: 950;
  letter-spacing: -0.04em;
}

.ss-price span {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: 0;
  color: rgba(18, 34, 51, 0.68);
}

.ss-price-card ul {
  margin: 1rem 0;
  padding-left: 1.1rem;
}

.ss-price-card li {
  margin-bottom: 0.45rem;
}

.ss-best-for {
  margin-top: auto;
  padding-top: 1rem;
  font-weight: 800;
}

@media (max-width: 850px) {
  .ss-pricing-grid {
    grid-template-columns: 1fr;
  }

  .ss-pricing-tabs {
    position: sticky;
    top: 0.75rem;
    z-index: 5;
  }
}

@media (max-width: 900px) {
  .ss-safety-strip,
  .ss-booking-proof__grid,
  .ss-step-grid,
  .ss-final-cta-actions,
  .ss-location-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .ss-lane-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767.98px) {
  .page-book-intro .ss-main > .ss-section:not(.ss-book-hero) {
    padding: 2rem 0;
  }

  .ss-hero-actions .btn {
    width: 100%;
  }

  .ss-final-cta-actions {
    display: grid;
  }

  .ss-final-cta-actions .btn {
    width: 100%;
  }
}

/* ================================
   Sensei Sandy BJJ Glossary Polish
   ================================ */

.page-glossary.glossary-page {
  --ss-bg: #071314;
  --ss-panel: #0d2022;
  --ss-panel-soft: #112b2d;
  --ss-text: #f4fbfb;
  --ss-muted: #b8cccc;
  --ss-teal: #289fa1;
  --ss-cyan: #00dde0;
  --ss-orange: #e05500;
  --ss-border: rgba(255, 255, 255, 0.12);
  --ss-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
  --ss-radius-xl: 28px;
  --ss-radius-lg: 20px;
  --ss-radius-md: 14px;
  background:
    radial-gradient(circle at top left, rgba(0, 221, 224, 0.14), transparent 34rem),
    radial-gradient(circle at top right, rgba(224, 85, 0, 0.12), transparent 30rem),
    var(--ss-bg) !important;
  color: var(--ss-text);
}

.page-glossary.glossary-page h1,
.page-glossary.glossary-page h2,
.page-glossary.glossary-page h3,
.page-glossary.glossary-page p,
.page-glossary.glossary-page li {
  color: inherit;
}

.page-glossary.glossary-page a {
  color: inherit;
}

.page-glossary .glossary-shell {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
}

.page-glossary .glossary-hero {
  padding: clamp(56px, 8vw, 108px) 0 44px;
}

.page-glossary .glossary-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, 0.85fr);
  gap: clamp(24px, 5vw, 56px);
  align-items: center;
}

.page-glossary .glossary-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 16px;
  color: var(--ss-cyan);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.page-glossary .glossary-hero h1 {
  max-width: 760px;
  margin: 0 0 18px;
  color: var(--ss-text);
  font-size: clamp(2.4rem, 6vw, 5.2rem);
  line-height: 0.95;
  letter-spacing: -0.045em;
}

.page-glossary .glossary-hero-copy > p:not(.glossary-eyebrow) {
  max-width: 660px;
  margin: 0 0 28px;
  color: var(--ss-muted);
  font-size: clamp(1.05rem, 2vw, 1.28rem);
  line-height: 1.55;
}

.page-glossary .glossary-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.page-glossary .glossary-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 13px 18px;
  border: 1px solid var(--ss-border);
  border-radius: 999px;
  font-weight: 850;
  line-height: 1.1;
  text-align: center;
  text-decoration: none;
}

.page-glossary .glossary-btn-primary {
  border-color: var(--ss-orange);
  background: var(--ss-orange);
  color: #fff;
  box-shadow: 0 12px 30px rgba(224, 85, 0, 0.28);
}

.page-glossary .glossary-btn-secondary {
  background: rgba(255, 255, 255, 0.06);
  color: var(--ss-text);
}

.page-glossary .glossary-visit-card {
  padding: clamp(22px, 4vw, 32px);
  border: 1px solid var(--ss-border);
  border-radius: var(--ss-radius-xl);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.025)),
    var(--ss-panel);
  box-shadow: var(--ss-shadow);
}

.page-glossary .glossary-visit-card h2 {
  margin: 0 0 14px;
  color: var(--ss-text);
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1.05;
  letter-spacing: -0.035em;
}

.page-glossary .glossary-visit-card ul {
  display: grid;
  gap: 10px;
  margin: 18px 0 24px;
  padding: 0;
  list-style: none;
}

.page-glossary .glossary-visit-card li {
  display: flex;
  gap: 10px;
  color: var(--ss-muted);
}

.page-glossary .glossary-visit-card li::before {
  content: "✓";
  color: var(--ss-cyan);
  font-weight: 900;
}

.page-glossary .glossary-start-path {
  margin: 28px auto 42px;
  padding: clamp(22px, 4vw, 34px);
  border: 1px solid var(--ss-border);
  border-radius: var(--ss-radius-xl);
  background: rgba(255, 255, 255, 0.045);
}

.page-glossary .glossary-section-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 22px;
}

.page-glossary .glossary-section-header h2 {
  margin: 0;
  color: var(--ss-text);
  font-size: clamp(1.7rem, 4vw, 3rem);
  line-height: 1;
  letter-spacing: -0.045em;
}

.page-glossary .glossary-section-header p {
  max-width: 560px;
  margin: 0;
  color: var(--ss-muted);
  line-height: 1.5;
}

.page-glossary .day-one-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 12px;
}

.page-glossary .day-one-card {
  display: block;
  min-height: 150px;
  padding: 16px;
  border: 1px solid var(--ss-border);
  border-radius: var(--ss-radius-lg);
  background: var(--ss-panel-soft);
  color: var(--ss-text);
  text-decoration: none;
}

.page-glossary .day-one-card:hover,
.page-glossary .day-one-card:focus-visible {
  border-color: rgba(0, 221, 224, 0.5);
  transform: translateY(-2px);
}

.page-glossary .day-one-card .num {
  display: block;
  margin-bottom: 12px;
  color: var(--ss-cyan);
  font-weight: 900;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
}

.page-glossary .day-one-card h3 {
  margin: 0 0 8px;
  color: var(--ss-text);
  font-size: 1.06rem;
  line-height: 1.05;
}

.page-glossary .day-one-card p {
  margin: 0;
  color: var(--ss-muted);
  font-size: 0.92rem;
  line-height: 1.38;
}

.page-glossary .glossary-start-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 22px;
}

.page-glossary .glossary-start-cta p {
  margin: 0;
  color: var(--ss-muted);
  font-weight: 800;
}

.page-glossary .glossary-filter-panel {
  position: relative;
  z-index: 10;
  margin: 28px 0;
  padding: 16px;
  border: 1px solid var(--ss-border);
  border-radius: var(--ss-radius-xl);
  background: rgba(7, 19, 20, 0.92) !important;
  color: var(--ss-text);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(18px);
}

.page-glossary .glossary-filter-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.page-glossary .glossary-filter-header label {
  color: var(--ss-text);
  font-size: 1.1rem;
  font-weight: 900;
}

.page-glossary .glossary-utility-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.page-glossary .glossary-utility-links button,
.page-glossary .glossary-utility-links select,
.page-glossary #reset-filters {
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid var(--ss-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.055);
  color: var(--ss-text);
  font-weight: 800;
  font-size: 0.82rem;
}

.page-glossary .glossary-utility-links select {
  color-scheme: dark;
}

.page-glossary .glossary-search {
  width: 100%;
  min-height: 52px;
  padding: 0 16px;
  border: 1px solid var(--ss-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
  color: var(--ss-text);
  font-size: 1rem;
}

.page-glossary .glossary-search::placeholder {
  color: rgba(244, 251, 251, 0.6);
}

.page-glossary .glossary-filter-group {
  margin-top: 12px;
}

.page-glossary .glossary-secondary-paths .ss-glossary-paths {
  margin: 14px 0 0;
  padding: 14px;
  border: 1px solid var(--ss-border);
  border-radius: var(--ss-radius-lg);
  background: rgba(255, 255, 255, 0.035);
}

.page-glossary .glossary-secondary-paths .ss-paths-header {
  margin-bottom: 12px;
}

.page-glossary .glossary-secondary-paths .ss-paths-header h2 {
  margin: 0 0 4px;
  color: var(--ss-text) !important;
  font-size: 1.1rem;
  letter-spacing: 0;
}

.page-glossary .glossary-secondary-paths .ss-paths-header p:not(.ss-paths-eyebrow),
.page-glossary .glossary-secondary-paths .ss-path-card p {
  color: var(--ss-muted) !important;
  font-size: 0.9rem;
}

.page-glossary .glossary-secondary-paths .ss-path-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.page-glossary .glossary-secondary-paths .ss-path-card {
  padding: 12px;
  border: 1px solid var(--ss-border);
  border-radius: var(--ss-radius-md);
  background: rgba(255, 255, 255, 0.045);
}

.page-glossary .glossary-secondary-paths .ss-path-card h3 {
  margin: 0 0 6px;
  color: var(--ss-text) !important;
  font-size: 1rem;
}

.page-glossary .glossary-secondary-paths .ss-path-chips,
.page-glossary .glossary-secondary-paths .ss-path-link {
  display: none;
}

.page-glossary .glossary-secondary-paths .ss-path-btn {
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid var(--ss-border);
  border-radius: 999px;
  background: rgba(0, 221, 224, 0.12);
  color: var(--ss-text) !important;
  font-weight: 800;
  font-size: 0.82rem;
}

.page-glossary .glossary-filter-group p {
  margin: 0 0 8px;
  color: var(--ss-muted);
  font-size: 0.9rem;
  font-weight: 900;
}

.page-glossary .glossary-chip-row,
.page-glossary .glossary-alpha-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 0;
}

.page-glossary .glossary-chip,
.page-glossary .glossary-alpha {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 8px 12px;
  border: 1px solid var(--ss-border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.055);
  color: var(--ss-text);
  font-weight: 800;
  font-size: 0.86rem;
  line-height: 1;
  text-decoration: none;
}

.page-glossary .glossary-alpha {
  min-width: 36px;
  padding-inline: 10px;
}

.page-glossary .glossary-chip.is-active,
.page-glossary .glossary-chip[aria-pressed="true"],
.page-glossary .glossary-alpha.is-active,
.page-glossary .glossary-alpha[aria-pressed="true"] {
  border-color: var(--ss-cyan);
  background: var(--ss-cyan);
  color: #062022;
}

.page-glossary .glossary-alpha.is-disabled {
  opacity: 0.42;
}

.page-glossary .glossary-advanced-filters {
  margin-top: 12px;
  color: var(--ss-muted);
}

.page-glossary .glossary-advanced-filters summary {
  cursor: pointer;
  color: var(--ss-cyan);
  font-weight: 900;
}

.page-glossary .glossary-advanced-filters fieldset {
  margin: 12px 0 0;
  padding: 0;
  border: 0;
}

.page-glossary .glossary-advanced-filters legend {
  margin: 0 0 8px;
  color: var(--ss-muted);
  font-size: 0.88rem;
  font-weight: 900;
}

.page-glossary .glossary-results-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 18px 0 0;
  color: var(--ss-muted);
}

.page-glossary .glossary-results-header p {
  margin: 0;
  color: var(--ss-muted);
  font-weight: 850;
}

.page-glossary .glossary-grid,
.page-glossary .ss-glossary-term-grid.glossary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.page-glossary .glossary-results {
  padding: 0 0 12px;
}

.page-glossary .glossary-card,
.page-glossary .term-card.glossary-card,
.page-glossary .ss-glossary-term-card.glossary-card {
  display: flex;
  flex-direction: column;
  min-height: 280px;
  padding: 20px;
  border: 1px solid var(--ss-border);
  border-radius: var(--ss-radius-xl);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.025)),
    var(--ss-panel) !important;
  color: var(--ss-text);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.18);
}

.page-glossary .glossary-card:hover {
  border-color: rgba(0, 221, 224, 0.38);
  transform: translateY(-2px);
}

.page-glossary .glossary-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 14px;
}

.page-glossary .glossary-pill {
  display: inline-flex;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(0, 221, 224, 0.22) !important;
  color: #8ffcff !important;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid rgba(0, 221, 224, 0.35) !important;
}

.page-glossary .glossary-card h3 {
  margin: 0 0 10px;
  color: var(--ss-text);
  font-size: 1.34rem;
  line-height: 1.05;
  letter-spacing: -0.03em;
}

.page-glossary .glossary-card h3 a {
  color: var(--ss-text);
  text-decoration: none;
}

.page-glossary .glossary-card p {
  margin: 0 0 16px;
  color: var(--ss-muted);
  line-height: 1.48;
}

.page-glossary .glossary-related {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: auto;
  padding-top: 16px;
  color: var(--ss-muted);
}

.page-glossary .glossary-related span {
  flex-basis: 100%;
  color: var(--ss-muted);
  font-size: 0.8rem;
  font-weight: 900;
  text-transform: uppercase;
}

.page-glossary .glossary-related a {
  color: var(--ss-text);
  border-bottom: 1px solid rgba(0, 221, 224, 0.45);
  font-size: 0.84rem;
  text-decoration: none;
}

.page-glossary .glossary-card-cta {
  margin-top: 18px;
  color: var(--ss-cyan);
  font-weight: 900;
  text-decoration: none;
}

.page-glossary .glossary-empty {
  padding: 24px;
  border: 1px solid var(--ss-border);
  border-radius: var(--ss-radius-lg);
  background: rgba(255, 255, 255, 0.045);
}

.page-glossary .glossary-bottom-cta {
  margin: 54px auto;
  padding: clamp(26px, 5vw, 44px);
  border: 1px solid var(--ss-border);
  border-radius: var(--ss-radius-xl);
  background:
    linear-gradient(135deg, rgba(224, 85, 0, 0.22), rgba(0, 221, 224, 0.14)),
    var(--ss-panel);
  text-align: center;
}

.page-glossary .glossary-bottom-cta h2 {
  margin: 0 0 10px;
  color: var(--ss-text);
  font-size: clamp(1.8rem, 5vw, 3.4rem);
  letter-spacing: -0.05em;
}

.page-glossary .glossary-bottom-cta p {
  max-width: 620px;
  margin: 0 auto 24px;
  color: var(--ss-muted);
}

@media (max-width: 920px) {
  .page-glossary .glossary-hero-grid {
    grid-template-columns: 1fr;
  }

  .page-glossary .day-one-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page-glossary .glossary-grid,
  .page-glossary .ss-glossary-term-grid.glossary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page-glossary .glossary-section-header,
  .page-glossary .glossary-results-header,
  .page-glossary .glossary-filter-header,
  .page-glossary .glossary-start-cta {
    align-items: start;
    flex-direction: column;
  }

  .page-glossary .glossary-secondary-paths .ss-path-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .page-glossary .glossary-shell {
    width: min(100% - 22px, 1120px);
  }

  .page-glossary .glossary-hero {
    padding-top: 38px;
  }

  .page-glossary .glossary-hero h1 {
    font-size: clamp(2.25rem, 13vw, 3.5rem);
  }

  .page-glossary .day-one-grid,
  .page-glossary .glossary-grid,
  .page-glossary .ss-glossary-term-grid.glossary-grid {
    grid-template-columns: 1fr;
  }

  .page-glossary .glossary-filter-panel {
    top: 0;
    margin-right: -11px;
    margin-left: -11px;
    border-radius: 0 0 22px 22px;
  }

  .page-glossary .glossary-alpha-row {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 6px;
  }

  .page-glossary .glossary-alpha {
    flex: 0 0 auto;
  }

  .page-glossary .glossary-card,
  .page-glossary .term-card.glossary-card,
  .page-glossary .ss-glossary-term-card.glossary-card {
    min-height: auto;
  }

  .page-glossary .glossary-secondary-paths .ss-path-grid {
    grid-template-columns: 1fr;
  }
}

/* Glossary contrast hardening: keep new hub readable over legacy glossary surfaces. */
.page-glossary main.glossary-page {
  background:
    radial-gradient(circle at top left, rgba(0, 221, 224, 0.14), transparent 34rem),
    radial-gradient(circle at top right, rgba(224, 85, 0, 0.12), transparent 30rem),
    #071314 !important;
  color: #f4fbfb !important;
}

.page-glossary main.glossary-page .glossary-hero {
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  padding: clamp(56px, 8vw, 108px) 0 44px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #f4fbfb !important;
}

.page-glossary main.glossary-page .glossary-hero-grid,
.page-glossary main.glossary-page .glossary-start-path {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.065), rgba(255, 255, 255, 0.025)),
    #0d2022 !important;
  color: #f4fbfb !important;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
}

.page-glossary main.glossary-page .glossary-hero-grid {
  padding: clamp(22px, 4vw, 38px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 28px;
}

.page-glossary main.glossary-page .glossary-hero h1,
.page-glossary main.glossary-page .glossary-section-header h2,
.page-glossary main.glossary-page .day-one-card h3 {
  color: #f4fbfb !important;
  opacity: 1 !important;
}

.page-glossary main.glossary-page .glossary-eyebrow,
.page-glossary main.glossary-page .day-one-card .num {
  color: #00dde0 !important;
  opacity: 1 !important;
}

.page-glossary main.glossary-page .glossary-hero-copy > p:not(.glossary-eyebrow),
.page-glossary main.glossary-page .glossary-section-header p,
.page-glossary main.glossary-page .day-one-card p,
.page-glossary main.glossary-page .glossary-start-cta p {
  color: #b8cccc !important;
  opacity: 1 !important;
}

.page-glossary main.glossary-page .glossary-btn-primary {
  background: #e05500 !important;
  border-color: #e05500 !important;
  color: #ffffff !important;
}

/* Bulletproof fix for glossary-btn-secondary visibility */
body.page-glossary.page-bjj-glossary a.glossary-btn-secondary,
.page-glossary main.glossary-page a.glossary-btn-secondary,
.glossary-shell.glossary-next-steps a.glossary-btn-secondary,
.glossary-next-steps .d-flex a.glossary-btn-secondary,
.glossary-start-cta a.glossary-btn-secondary {
  color: #ffffff !important;
  border-color: rgba(255, 255, 255, 0.45) !important;
  background: rgba(255, 255, 255, 0.15) !important;
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.page-glossary main.glossary-page .day-one-card {
  background: #112b2d !important;
  border-color: rgba(255, 255, 255, 0.12) !important;
  color: #f4fbfb !important;
}

.page-glossary main.glossary-page .glossary-card,
.page-glossary main.glossary-page .term-card.glossary-card,
.page-glossary main.glossary-page .ss-glossary-term-card.glossary-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.025)),
    #0d2022 !important;
  border-color: rgba(255, 255, 255, 0.12) !important;
  color: #f4fbfb !important;
}

.page-glossary main.glossary-page .glossary-card h3,
.page-glossary main.glossary-page .glossary-card h3 a,
.page-glossary main.glossary-page .term-card__title,
.page-glossary main.glossary-page .term-card__title a {
  color: #f4fbfb !important;
  opacity: 1 !important;
}

.page-glossary main.glossary-page .glossary-card p,
.page-glossary main.glossary-page .term-card__summary,
.page-glossary main.glossary-page .ss-glossary-term-def {
  color: #b8cccc !important;
  opacity: 1 !important;
}

.page-glossary main.glossary-page .glossary-related,
.page-glossary main.glossary-page .glossary-related span {
  color: #b8cccc !important;
  opacity: 1 !important;
}

.page-glossary main.glossary-page .glossary-related a {
  color: #f4fbfb !important;
  border-bottom-color: rgba(0, 221, 224, 0.55) !important;
  opacity: 1 !important;
}

.page-glossary main.glossary-page .glossary-card-cta,
.page-glossary main.glossary-page .term-card__cta,
.page-glossary main.glossary-page .ss-glossary-term-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  margin-top: 18px;
  padding: 12px 16px;
  border: 1px solid rgba(0, 221, 224, 0.42) !important;
  border-radius: 999px;
  background: rgba(0, 221, 224, 0.14) !important;
  color: #f4fbfb !important;
  font-weight: 900;
  text-decoration: none !important;
  opacity: 1 !important;
}

.page-glossary main.glossary-page .glossary-card-cta:hover,
.page-glossary main.glossary-page .glossary-card-cta:focus-visible,
.page-glossary main.glossary-page .term-card__cta:hover,
.page-glossary main.glossary-page .term-card__cta:focus-visible {
  background: #00dde0 !important;
  color: #062022 !important;
}

/* Term-page related cards need their own contrast because they are anchors, not term-card articles. */
.page-glossary-term main.glossary-page #related-terms .ss-glossary-rich-related-card,
.page-glossary-term main.glossary-page #related-terms .related-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.025)),
    #0d2022 !important;
  border-color: rgba(255, 255, 255, 0.16) !important;
  color: #f4fbfb !important;
}

.page-glossary-term main.glossary-page #related-terms .ss-glossary-rich-related-card h3,
.page-glossary-term main.glossary-page #related-terms .related-card h3 {
  color: #f4fbfb !important;
  opacity: 1 !important;
}

.page-glossary-term main.glossary-page #related-terms .ss-glossary-rich-related-card p,
.page-glossary-term main.glossary-page #related-terms .related-card p {
  color: #b8cccc !important;
  opacity: 1 !important;
}

.page-glossary-term main.glossary-page #related-terms .ss-glossary-rich-related-card span,
.page-glossary-term main.glossary-page #related-terms .related-card span {
  color: #ff7a2b !important;
  opacity: 1 !important;
}

.page-glossary-term main.glossary-page #related-terms .glossary-term-relationship-grid > .glossary-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)),
    #0d2022 !important;
  border-color: rgba(255, 255, 255, 0.14) !important;
  color: #f4fbfb !important;
}

.page-glossary-term main.glossary-page #related-terms .glossary-term-best-next h3,
.page-glossary-term main.glossary-page #related-terms .glossary-term-relationship-map h3,
.page-glossary-term main.glossary-page #related-terms .glossary-term-relationship-grid h4 {
  color: #f4fbfb !important;
}

.page-glossary-term main.glossary-page #related-terms .glossary-term-best-next a,
.page-glossary-term main.glossary-page #related-terms .glossary-term-relationship-grid a {
  color: #00dde0 !important;
}

@media (max-width: 640px) {
  .page-glossary main.glossary-page,
  .page-glossary main.glossary-page * {
    box-sizing: border-box;
  }

  .page-glossary .glossary-shell,
  .page-glossary main.glossary-page .glossary-hero-grid,
  .page-glossary main.glossary-page .glossary-start-path,
  .page-glossary main.glossary-page .glossary-bottom-cta {
    width: calc(100vw - 72px) !important;
    max-width: calc(100vw - 72px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .page-glossary main.glossary-page .glossary-hero-grid {
    grid-template-columns: minmax(0, 1fr) !important;
    padding: 22px !important;
    overflow: hidden;
  }

  .page-glossary main.glossary-page .glossary-hero-copy,
  .page-glossary main.glossary-page .glossary-visit-card,
  .page-glossary main.glossary-page .glossary-bottom-cta {
    min-width: 0;
  }

  .page-glossary main.glossary-page .glossary-hero-copy {
    display: grid;
    justify-items: center;
  }

  .page-glossary main.glossary-page .glossary-hero h1,
  .page-glossary main.glossary-page .glossary-hero-copy > p:not(.glossary-eyebrow),
  .page-glossary main.glossary-page .glossary-bottom-cta h2,
  .page-glossary main.glossary-page .glossary-bottom-cta p {
    max-width: 100%;
    overflow-wrap: anywhere;
  }

  .page-glossary main.glossary-page .glossary-hero-copy > p:not(.glossary-eyebrow) {
    width: min(100%, 286px);
  }

  .page-glossary main.glossary-page .glossary-hero h1 {
    font-size: clamp(2.1rem, 11vw, 3.05rem) !important;
  }

  .page-glossary main.glossary-page .glossary-hero-actions {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    width: 100%;
  }

  .page-glossary main.glossary-page .glossary-btn {
    box-sizing: border-box;
    width: min(100%, 286px) !important;
    max-width: 286px !important;
    min-width: 0;
    white-space: normal;
  }
}

/* Headings inside the white learning card */
.page-bjj-glossary .glossary-card h1,
.page-bjj-glossary .glossary-card h2,
.page-bjj-glossary .glossary-card h3,
.page-bjj-glossary .glossary-path-card h1,
.page-bjj-glossary .glossary-path-card h2,
.page-bjj-glossary .glossary-path-card h3,
.page-bjj-glossary .learning-path-card h1,
.page-bjj-glossary .learning-path-card h2,
.page-bjj-glossary .learning-path-card h3,
.page-bjj-glossary .path-card h1,
.page-bjj-glossary .path-card h2,
.page-bjj-glossary .path-card h3 {
  color: var(--ss-teal-dark) !important;
  font-weight: 800;
}

/* Paragraphs and helper text */
.page-bjj-glossary .glossary-card p,
.page-bjj-glossary .glossary-path-card p,
.page-bjj-glossary .learning-path-card p,
.page-bjj-glossary .path-card p,
.page-bjj-glossary .cta-card p,
.page-bjj-glossary .intro-card p,
.page-bjj-glossary .ready-card p {
  color: var(--ss-muted) !important;
}

/* Links inside light cards */
.page-bjj-glossary .glossary-card a,
.page-bjj-glossary .glossary-path-card a,
.page-bjj-glossary .learning-path-card a,
.page-bjj-glossary .path-card a,
.page-bjj-glossary .cta-card a,
.page-bjj-glossary .intro-card a,
.page-bjj-glossary .ready-card a {
  color: var(--ss-orange) !important;
  font-weight: 800;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

/* The orange CTA should stay loud and readable */
.page-bjj-glossary .btn,
.page-bjj-glossary .btn-primary,
.page-bjj-glossary .btn-orange,
.page-bjj-glossary .reserve-free-intro,
.page-bjj-glossary a[href*="book-free-intro"] {
  background: var(--ss-orange) !important;
  color: #ffffff !important;
  border-color: var(--ss-orange) !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

/* Top “Ready to see the words in class?” band */
.page-bjj-glossary .ready-card,
.page-bjj-glossary .cta-card,
.page-bjj-glossary .glossary-cta {
  background: var(--ss-surface-soft) !important;
  border: 1px solid var(--ss-border);
}

.page-bjj-glossary .ready-card strong,
.page-bjj-glossary .ready-card p,
.page-bjj-glossary .cta-card strong,
.page-bjj-glossary .cta-card p,
.page-bjj-glossary .glossary-cta strong,
.page-bjj-glossary .glossary-cta p {
  color: var(--ss-teal-dark) !important;
}

/* Keep the dark search/filter shell readable */
.page-bjj-glossary .glossary-search-shell,
.page-bjj-glossary .filter-shell,
.page-bjj-glossary .glossary-filters {
  color: #ffffff !important;
}

.page-bjj-glossary .glossary-search-shell label,
.page-bjj-glossary .filter-shell label,
.page-bjj-glossary .glossary-filters label,
.page-bjj-glossary .glossary-search-shell strong,
.page-bjj-glossary .filter-shell strong,
.page-bjj-glossary .glossary-filters strong {
  color: #ffffff !important;
}

/* Search input contrast */
.page-bjj-glossary input[type="search"],
.page-bjj-glossary input[type="text"] {
  background: #102625 !important;
  color: #ffffff !important;
  border: 1px solid #289fa1 !important;
}

.page-bjj-glossary input::placeholder {
  color: rgba(255, 255, 255, 0.7) !important;
}

/* Pills and letter buttons */
.page-bjj-glossary .pill,
.page-bjj-glossary .tag,
.page-bjj-glossary .filter-chip,
.page-bjj-glossary .letter-filter,
.page-bjj-glossary .letter-btn {
  background: #ffffff !important;
  color: var(--ss-ink) !important;
  border: 1px solid var(--ss-border) !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

.page-bjj-glossary .pill:hover,
.page-bjj-glossary .tag:hover,
.page-bjj-glossary .filter-chip:hover,
.page-bjj-glossary .letter-filter:hover,
.page-bjj-glossary .letter-btn:hover {
  background: #f4f1ed !important;
  color: var(--ss-teal-dark) !important;
}

/* Badge text in the white card */
.page-bjj-glossary .badge,
.page-bjj-glossary .eyebrow,
.page-bjj-glossary .kicker {
  color: var(--ss-orange) !important;
  background: rgba(224, 85, 0, 0.09) !important;
}

/* Prevent translucent panels from washing out text */
.page-bjj-glossary [style*="opacity"] {
  opacity: 1;
}

/* Fix visibility issues for .ss-mini-link sidebar items on term pages */
.ss-mini-link {
  display: block;
  text-decoration: none !important;
  transition: transform 0.2s ease;
}

.ss-mini-link:hover {
  transform: translateY(-1px);
}

.ss-mini-link strong {
  display: block;
  color: #1f1712 !important; /* Force dark text on white background */
  font-size: 1.1rem;
  line-height: 1.2;
  margin-bottom: 2px;
}

.ss-mini-link span {
  display: block;
  color: #4f433c !important; /* Force muted dark text on white background */
  font-size: 0.9rem;
  line-height: 1.3;
}

/* --- BJJ GLOSSARY CRO OVERHAUL 2024 --- */

body.page-glossary {
  --ss-surface: var(--gls-surface);
  --ss-surface2: var(--gls-surface-2);
  --ss-bg: var(--gls-bg, transparent);
  --ss-ink: var(--gls-text);
  --ss-muted: var(--gls-muted);
  --ss-slate: var(--gls-muted);
  --ss-border: var(--gls-border);
  --ss-orange: var(--gls-accent-strong, #e05500);
  --ss-teal: var(--gls-accent, #289fa1);
}

/* 1. Mobile & Core CRO Styles */

.ss-glossary-mobile-hero,
.ss-day-one-mobile,
.ss-glossary-mobile-search {
  padding: 1.25rem 1rem;
}

.ss-glossary-mobile-hero h1 {
  font-size: clamp(2rem, 9vw, 3.15rem);
  line-height: .96;
  letter-spacing: -0.045em;
  margin-bottom: .85rem;
}

.ss-hero-copy {
  font-size: 1.05rem;
  color: var(--ss-muted);
  margin-bottom: 1rem;
}

.ss-hero-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: .65rem;
  margin: 1rem 0;
}

.ss-btn-primary {
  background: var(--ss-orange);
  color: #fff;
  border: 2px solid var(--ss-orange);
  border-radius: 999px;
  font-weight: 900;
  padding: .82rem 1rem;
}

.ss-btn-secondary {
  background: var(--ss-surface2);
  color: var(--ss-ink);
  border: 2px solid var(--ss-border);
  border-radius: 999px;
  font-weight: 900;
  padding: .82rem 1rem;
}

.ss-first-visit-card,
.ss-soft-cta,
.ss-inline-mobile-cta,
.ss-inline-card,
.ss-term-card {
  background: var(--ss-surface);
  border: 1px solid var(--ss-border);
  border-radius: 1.2rem;
  box-shadow: 0 12px 28px rgba(0, 0, 0, .08);
}

.ss-first-visit-card {
  padding: 1rem;
  margin-top: 1rem;
}

.ss-first-visit-card h2 {
  font-size: 1.25rem;
  line-height: 1.1;
}

.ss-first-visit-card ul {
  display: grid;
  gap: .45rem;
  padding-left: 1.1rem;
  margin: .75rem 0 1rem;
}

.ss-day-one-strip {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(178px, 78%);
  gap: .75rem;
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
  padding: .25rem 0 1rem;
}

.ss-word-pill {
  scroll-snap-align: start;
  display: grid;
  gap: .35rem;
  text-decoration: none;
  color: var(--ss-ink);
  background: var(--ss-surface);
  border: 1px solid var(--ss-border);
  border-radius: 1rem;
  padding: 1rem;
  min-height: 132px;
}

.ss-word-pill span {
  color: var(--ss-orange);
  font-weight: 900;
  font-size: .8rem;
}

.ss-word-pill strong {
  font-size: 1.15rem;
}

.ss-word-pill small {
  color: var(--ss-muted);
  font-size: .9rem;
}

.ss-soft-cta {
  padding: 1rem;
  margin-top: .5rem;
}

.ss-search-label {
  display: block;
  font-weight: 900;
  color: var(--ss-ink);
  margin-bottom: .5rem;
}

.ss-search-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .5rem;
  align-items: center;
}

.ss-search-input {
  min-height: 48px;
  border-radius: 999px;
  border: 1px solid var(--ss-border);
  padding-left: 1rem;
}

.ss-filter-btn {
  min-height: 48px;
  border-radius: 999px;
  background: var(--ss-ink);
  color: #fff;
  font-weight: 900;
  padding-inline: 1rem;
}

.ss-quick-filter-row {
  display: flex;
  gap: .5rem;
  overflow-x: auto;
  padding: .85rem 0 .35rem;
}

.ss-chip {
  border: 1px solid var(--ss-border);
  background: var(--ss-surface);
  color: var(--ss-ink);
  border-radius: 999px;
  padding: .55rem .8rem;
  font-weight: 800;
  white-space: nowrap;
}

.ss-chip.is-active {
  background: var(--ss-orange);
  border-color: var(--ss-orange);
  color: #fff;
}

.ss-results-count {
  color: var(--ss-muted);
  margin: .35rem 0 0;
}

.ss-filter-drawer {
  height: 82vh;
  border-radius: 1.25rem 1.25rem 0 0;
}

.ss-filter-drawer .offcanvas-header {
  border-bottom: 1px solid var(--ss-border);
}

.ss-filter-drawer h2 {
  font-size: 1.25rem;
  font-weight: 900;
}

.ss-filter-group {
  margin-bottom: 1.25rem;
}

.ss-filter-group h3 {
  font-size: .95rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--ss-muted);
  margin-bottom: .6rem;
}

.ss-filter-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .5rem;
}

.ss-filter-option {
  border: 1px solid var(--ss-border);
  background: var(--ss-surface);
  border-radius: .85rem;
  padding: .75rem;
  font-weight: 800;
  text-align: left;
}

.ss-filter-option.is-active {
  background: var(--ss-surface2);
  border-color: var(--ss-orange);
}

.ss-filter-actions {
  position: sticky;
  bottom: 0;
  background: var(--ss-surface);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .65rem;
  padding-top: .75rem;
}

.ss-term-card {
  padding: 1rem;
  margin-bottom: .85rem;
}

.ss-term-meta {
  display: flex;
  gap: .35rem;
  flex-wrap: wrap;
  margin-bottom: .55rem;
}

.ss-term-meta span {
  background: var(--ss-surface2);
  color: var(--ss-muted);
  border-radius: 999px;
  padding: .25rem .5rem;
  font-size: .75rem;
  font-weight: 800;
}

.ss-term-card h3 {
  font-size: 1.28rem;
  margin-bottom: .35rem;
}

.ss-term-card h3 a {
  color: var(--ss-ink);
  text-decoration: none;
}

.ss-term-card p {
  color: var(--ss-muted);
  margin-bottom: .75rem;
}

.ss-related-row {
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
  margin-bottom: .75rem;
}

.ss-related-row a {
  border: 1px solid var(--ss-border);
  border-radius: 999px;
  padding: .35rem .55rem;
  text-decoration: none;
  color: var(--ss-slate);
  font-weight: 800;
  font-size: .82rem;
}

.ss-learn-link {
  color: var(--ss-orange);
  font-weight: 900;
  text-decoration: none;
}

.ss-inline-mobile-cta {
  padding: 1rem;
  margin: 1.25rem 0;
}

.ss-inline-mobile-cta h2 {
  font-size: 1.35rem;
  line-height: 1.1;
}

.ss-inline-actions {
  display: grid;
  gap: .55rem;
}

.ss-glossary-mobile-bar {
  position: fixed;
  z-index: 1040;
  left: 0;
  right: 0;
  bottom: 0;
  display: grid;
  grid-template-columns: 1fr 1.25fr 1fr;
  gap: .5rem;
  padding: .65rem;
  background: color-mix(in srgb, var(--gls-surface) 97%, transparent);
  border-top: 1px solid var(--ss-border);
  box-shadow: 0 -10px 24px rgba(0, 0, 0, .14);
}

.ss-glossary-mobile-bar a {
  display: grid;
  place-items: center;
  min-height: 44px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 900;
}

.ss-bar-primary {
  background: var(--ss-orange);
  color: #fff;
}

.ss-bar-link {
  background: var(--ss-surface2);
  color: var(--ss-ink);
}

@media (max-width: 767.98px) {
  body {
    padding-bottom: 78px;
  }
}

/* 2. Desktop CRO Styles */

.ss-glossary-hero {
  padding: clamp(3rem, 7vw, 6rem) 0;
  background:
    radial-gradient(circle at 15% 20%, rgba(224, 85, 0, .12), transparent 32%),
    linear-gradient(135deg, var(--ss-bg), var(--ss-surface2));
}

.ss-glossary-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
}

.ss-glossary-hero h1 {
  max-width: 11ch;
  font-size: clamp(3.25rem, 7vw, 6.5rem);
  line-height: .9;
  letter-spacing: -.065em;
  margin-bottom: 1rem;
}

.ss-lead {
  max-width: 760px;
  color: var(--ss-muted);
  font-size: clamp(1.15rem, 2vw, 1.45rem);
  line-height: 1.45;
}

.ss-hero-actions {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  margin-top: 1.25rem;
}

.ss-first-visit-panel,
.ss-command-card,
.ss-day-card,
.ss-path-card,
.ss-term-card,
.ss-rail-card,
.ss-glossary-inline-cta,
.ss-learning-cta {
  background: var(--ss-surface);
  border: 1px solid var(--ss-border);
  border-radius: 1.35rem;
  box-shadow: 0 14px 34px rgba(54, 43, 36, .08);
}

.ss-first-visit-panel {
  padding: 1.35rem;
}

.ss-first-visit-panel h2 {
  font-size: 1.65rem;
  line-height: 1.05;
  margin-bottom: 1rem;
}

.ss-check-list {
  display: grid;
  gap: .5rem;
  padding-left: 1.2rem;
  margin-bottom: 1.25rem;
}

.ss-text-link {
  display: inline-block;
  margin-top: .8rem;
  color: var(--ss-orange);
  font-weight: 900;
  text-decoration: none;
}

.ss-section-heading {
  max-width: 760px;
  margin-bottom: 1.35rem;
}

.ss-section-heading h2 {
  font-size: clamp(2rem, 4vw, 3.25rem);
  line-height: .95;
  letter-spacing: -.04em;
}

.ss-day-one-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .75rem;
}

.ss-day-card {
  display: block;
  min-height: 170px;
  padding: 1rem;
  color: var(--ss-ink);
  text-decoration: none;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.ss-day-card:hover {
  transform: translateY(-3px);
  border-color: rgba(224, 85, 0, .42);
  box-shadow: 0 18px 42px rgba(54, 43, 36, .12);
}

.ss-day-card span {
  color: var(--ss-orange);
  font-weight: 900;
  font-size: .8rem;
}

.ss-day-card h3 {
  font-size: 1.1rem;
  margin: .45rem 0;
}

.ss-day-card p {
  color: var(--ss-muted);
  font-size: .94rem;
  margin: 0;
}

.ss-learning-cta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-top: 1rem;
  padding: 1rem 1.2rem;
}

.ss-learning-cta p {
  margin: 0;
  font-weight: 800;
}

.ss-glossary-command {
  position: sticky;
  top: 0;
  z-index: 20;
  padding: .85rem 0;
  background: color-mix(in srgb, var(--gls-surface) 92%, transparent);
  backdrop-filter: blur(14px);
  border-top: 1px solid var(--ss-border);
  border-bottom: 1px solid var(--ss-border);
}

.ss-command-card {
  padding: 1rem;
}

.ss-search-main label,
.ss-filter-grid label {
  display: block;
  font-weight: 900;
  margin-bottom: .45rem;
}

.ss-search-main input {
  min-height: 54px;
  border-radius: 999px;
  border: 1px solid var(--ss-border);
  padding-inline: 1.1rem;
  font-size: 1.05rem;
}

.ss-command-actions,
.ss-chip-row,
.ss-az-row {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .8rem;
}

.ss-mini-btn,
.ss-chip,
.ss-reset-btn {
  border: 1px solid var(--ss-border);
  background: var(--ss-surface2);
  color: var(--ss-ink);
  border-radius: 999px;
  padding: .55rem .85rem;
  font-weight: 900;
}

.ss-chip.is-active {
  background: var(--ss-orange);
  border-color: var(--ss-orange);
  color: #fff;
}

.ss-filter-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
  gap: .75rem;
  align-items: end;
  margin-top: 1rem;
}

.ss-filter-grid select {
  min-height: 46px;
  border-radius: .9rem;
}

.ss-reset-btn {
  min-height: 46px;
}

.ss-az-row {
  align-items: center;
  padding-top: .4rem;
}

.ss-az-row a {
  color: var(--ss-slate);
  font-weight: 900;
  text-decoration: none;
  padding: .1rem .18rem;
}

.ss-results-line {
  color: var(--ss-muted);
  margin: .7rem 0 0;
}

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

.ss-path-card {
  padding: 1.2rem;
}

.ss-path-card h3 {
  font-size: 1.35rem;
}

.ss-path-card p {
  color: var(--ss-muted);
}

.ss-path-card a {
  color: var(--ss-orange);
  font-weight: 900;
  text-decoration: none;
}

.ss-glossary-layout {
  display: grid;
  grid-template-columns: minmax(0, 8fr) minmax(300px, 4fr);
  gap: 1.25rem;
  align-items: start;
}

.ss-term-results {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .95rem;
}

.ss-term-card {
  padding: 1.1rem;
}

.ss-term-tags,
.ss-related-row {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}

.ss-term-tags {
  margin-bottom: .65rem;
}

.ss-term-tags span {
  background: var(--ss-surface2);
  color: var(--ss-muted);
  border-radius: 999px;
  padding: .25rem .55rem;
  font-size: .76rem;
  font-weight: 900;
}

.ss-term-card h3 {
  font-size: 1.45rem;
  line-height: 1.08;
  margin-bottom: .45rem;
}

.ss-term-card h3 a {
  color: var(--ss-ink);
  text-decoration: none;
}

.ss-term-card p {
  color: var(--ss-muted);
  margin-bottom: .85rem;
}

.ss-related-row {
  align-items: center;
  margin-bottom: .8rem;
}

.ss-related-row span {
  color: var(--ss-muted);
  font-weight: 900;
  font-size: .85rem;
}

.ss-related-row a {
  color: var(--ss-slate);
  border: 1px solid var(--ss-border);
  border-radius: 999px;
  padding: .28rem .52rem;
  text-decoration: none;
  font-weight: 800;
  font-size: .83rem;
}

.ss-learn-link {
  color: var(--ss-orange);
  text-decoration: none;
  font-weight: 900;
}

.ss-glossary-rail {
  position: sticky;
  top: 220px;
  display: grid;
  gap: 1rem;
}

.ss-rail-card {
  padding: 1.15rem;
}

.ss-rail-card h2 {
  font-size: 1.35rem;
  line-height: 1.08;
}

.ss-rail-card p {
  color: var(--ss-muted);
}

.ss-rail-list {
  display: grid;
  gap: .45rem;
  padding-left: 1.1rem;
  margin-bottom: 0;
}

.ss-rail-list a {
  color: var(--ss-slate);
  font-weight: 900;
  text-decoration: none;
}

.ss-glossary-inline-cta {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 1.25rem;
  padding: 1.35rem;
  margin: .5rem 0;
}

.ss-glossary-inline-cta h2 {
  font-size: 1.8rem;
  line-height: 1.05;
}

.ss-inline-actions {
  display: flex;
  gap: .65rem;
  flex-wrap: wrap;
}

@media (min-width: 1400px) {
  .ss-term-results {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1199.98px) {
  .ss-day-one-grid,
  .ss-path-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .ss-glossary-layout {
    grid-template-columns: 1fr;
  }

  .ss-glossary-rail {
    position: static;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  .ss-glossary-command {
    position: static;
  }

  .ss-glossary-hero-grid,
  .ss-term-results,
  .ss-filter-grid,
  .ss-glossary-inline-cta,
  .ss-glossary-rail {
    grid-template-columns: 1fr;
  }

  .ss-day-one-grid,
  .ss-path-grid {
    grid-template-columns: 1fr;
  }

  .ss-learning-cta {
    display: grid;
  }
}

@media (min-width: 768px) {
  .ss-glossary-mobile-bar {
    display: none;
  }

  .ss-hero-actions {
    grid-template-columns: auto auto;
    justify-content: start;
  }
}

/* 
   DEFINITIVE HIGH-LEVEL FIX: Glossary CTA & Footer Address
   Targets glossary pages specifically to force black text and light background for the final CTA.
*/

/* 1. Force the CTA container and all its text elements to black (except primary button) */
html body.page-bjj-glossary .ss-global-final-cta__eyebrow,
html body.page-bjj-glossary .ss-global-final-cta__card h2,
html body.page-bjj-glossary .ss-global-final-cta__copy,
html body.page-bjj-glossary .ss-global-final-cta .ss-global-btn--soft,
html body.page-bjj-glossary .ss-global-final-cta .ss-global-btn--link {
  color: #000000 !important;
}

/* 2. Force secondary/link buttons to have black borders and text */
html body.page-bjj-glossary .ss-global-final-cta .ss-global-btn--soft {
  border-color: #000000 !important;
  background: #ffffff !important;
}

/* 3. Ensure the CTA card has a light background for black text visibility */
html body.page-bjj-glossary .ss-global-final-cta__card {
  background: #ffffff !important;
  border-color: rgba(0, 0, 0, 0.12) !important;
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.12) !important;
}

/* 4. Force the footer address to black and bold */
html body.page-bjj-glossary .ss-footer-address,
html body.page-bjj-glossary .ss-footer-address * {
  color: #000000 !important;
  font-weight: 700 !important;
}

/* 5. Override any remaining variables within the CTA scope */
html body.page-bjj-glossary .ss-global-final-cta {
  --ss-ink: #000 !important;
  --ss-muted: #000 !important;
  --ss-text: #000 !important;
  --ss-orange: #000 !important; /* Eyebrow override */
}

/* 6. Restore original primary button styling */
html body.page-bjj-glossary .ss-global-final-cta .ss-global-btn--primary {
  background: #E05500 !important;
  border-color: #E05500 !important;
  color: #ffffff !important;
}
