/* ===================================================================
   Glossaire — scoped under .ys-glossaire (listing) and .ys-glossaire-term (detail)
   Design-system: Plus Jakarta Sans, #3B82F6 primary, #0f172a text, #64748b secondary
   Breakpoints: 991px, 767px, 479px
   =================================================================== */

/* --- Global reset for glossaire scopes --- */
.ys-glossaire,
.ys-glossaire-term {
  font-family: 'Plus Jakarta Sans', sans-serif;
  color: #0f172a;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.ys-glossaire *,
.ys-glossaire *::before,
.ys-glossaire *::after,
.ys-glossaire-term *,
.ys-glossaire-term *::before,
.ys-glossaire-term *::after {
  box-sizing: border-box;
}

/* =====================================================================
   LISTING PAGE — .ys-glossaire
   ===================================================================== */

/* --- Hero --- */
.ys-glossaire .ys-glossaire-hero {
  position: relative;
  background: #151D53;
  overflow: hidden;
  padding: 8rem 2.5rem 3rem;
  text-align: center;
}

.ys-glossaire .ys-glossaire-hero__glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  pointer-events: none;
}

.ys-glossaire .ys-glossaire-hero__glow--left {
  width: 400px;
  height: 400px;
  top: -100px;
  left: -100px;
  background: rgba(59, 130, 246, 0.15);
}

.ys-glossaire .ys-glossaire-hero__glow--right {
  width: 350px;
  height: 350px;
  bottom: -80px;
  right: -80px;
  background: rgba(96, 165, 250, 0.12);
}

.ys-glossaire .ys-glossaire-hero__container {
  position: relative;
  max-width: 48rem;
  margin: 0 auto;
  z-index: 1;
}

.ys-glossaire .ys-glossaire-hero__title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 2.75rem;
  font-weight: 700;
  line-height: 1.2;
  color: #fff;
  margin: 0 0 1rem;
}

.ys-glossaire .ys-glossaire-hero__subtitle {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.0625rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.6;
  margin: 0 0 2rem;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
}

/* --- Letter Navigation --- */
.ys-glossaire .ys-glossaire-letter-nav {
  padding: 0 2.5rem;
  background: #fff;
  border-bottom: 1px solid #e2e8f0;
  position: sticky;
  top: 4.5rem;
  z-index: 10;
}

.ys-glossaire .ys-glossaire-letter-nav__container {
  max-width: 75rem;
  margin: 0 auto;
}

.ys-glossaire .ys-glossaire-letter-nav__list {
  display: flex;
  flex-wrap: wrap;
  gap: .25rem;
  list-style: none;
  padding: .75rem 0;
  margin: 0;
  justify-content: center;
}

.ys-glossaire .ys-glossaire-letter-nav__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .875rem;
  font-weight: 600;
  color: #64748b;
  background: transparent;
  border-radius: .375rem;
  text-decoration: none;
  transition: all .2s ease;
}

.ys-glossaire .ys-glossaire-letter-nav__link:hover {
  color: #3B82F6;
  background: #eff6ff;
}

.ys-glossaire .ys-glossaire-letter-nav__link--disabled {
  color: #cbd5e1;
  pointer-events: none;
}

/* --- Sections (letter groups) --- */
.ys-glossaire .ys-glossaire-sections {
  padding: 2rem 2.5rem 4rem;
}

.ys-glossaire .ys-glossaire-sections__container {
  max-width: 75rem;
  margin: 0 auto;
}

.ys-glossaire .ys-glossaire-section {
  margin-bottom: 3rem;
  scroll-margin-top: 8rem;
}

.ys-glossaire .ys-glossaire-section__heading {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 2rem;
  font-weight: 700;
  color: #3B82F6;
  margin: 0 0 1.5rem;
  padding-bottom: .75rem;
  border-bottom: 2px solid #e2e8f0;
}

.ys-glossaire .ys-glossaire-section__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .75rem;
}

/* --- Term Link --- */
.ys-glossaire .ys-glossaire-term-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .875rem 1.25rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: .5rem;
  text-decoration: none;
  color: #0f172a;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .9375rem;
  font-weight: 500;
  transition: all .2s ease;
}

.ys-glossaire .ys-glossaire-term-link:hover {
  border-color: #3B82F6;
  background: #eff6ff;
  color: #3B82F6;
}

.ys-glossaire .ys-glossaire-term-link__arrow {
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
  margin-left: .5rem;
  color: #94a3b8;
  transition: transform .2s ease, color .2s ease;
}

.ys-glossaire .ys-glossaire-term-link:hover .ys-glossaire-term-link__arrow {
  transform: translateX(4px);
  color: #3B82F6;
}

/* --- CTA section (same pattern as blog) --- */
.ys-glossaire .ys-glossaire-cta,
.ys-glossaire-term .ys-glossaire-cta {
  padding: 4rem 0;
  background: #f8f9fb;
}

.ys-glossaire .ys-glossaire-cta__container,
.ys-glossaire-term .ys-glossaire-cta__container {
  max-width: 75rem;
  margin: 0 auto;
  padding: 0 2.5rem;
}

.ys-glossaire .ys-glossaire-cta__card,
.ys-glossaire-term .ys-glossaire-cta__card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  background: #0f172a;
  padding: 3rem 4rem;
  border-radius: .5rem;
}

.ys-glossaire .ys-glossaire-cta__content,
.ys-glossaire-term .ys-glossaire-cta__content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.ys-glossaire .ys-glossaire-cta__heading,
.ys-glossaire-term .ys-glossaire-cta__heading {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.25;
  color: #fff;
  margin: 0;
}

.ys-glossaire .ys-glossaire-cta__text,
.ys-glossaire-term .ys-glossaire-cta__text {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .9375rem;
  font-weight: 400;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.6);
  margin: 0;
  max-width: 32rem;
}

.ys-glossaire .ys-glossaire-cta__btn,
.ys-glossaire-term .ys-glossaire-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .875rem 2rem;
  background: #3B82F6;
  color: #fff;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .9375rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: .375rem;
  transition: background .2s ease;
  white-space: nowrap;
  flex-shrink: 0;
}

.ys-glossaire .ys-glossaire-cta__btn:hover,
.ys-glossaire-term .ys-glossaire-cta__btn:hover {
  background: #2563eb;
}


/* =====================================================================
   DETAIL PAGE — .ys-glossaire-term
   ===================================================================== */

/* --- Breadcrumb --- */
.ys-glossaire-term .ys-glossaire-breadcrumb {
  padding: 7rem 2.5rem 0;
}

.ys-glossaire-term .ys-glossaire-breadcrumb__container {
  max-width: 75rem;
  margin: 0 auto;
}

.ys-glossaire-term .ys-glossaire-breadcrumb__list {
  display: flex;
  align-items: center;
  gap: .5rem;
  list-style: none;
  padding: 0;
  margin: 0;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .8125rem;
  font-weight: 400;
  color: #94a3b8;
}

.ys-glossaire-term .ys-glossaire-breadcrumb__link {
  color: #64748b;
  text-decoration: none;
  transition: color .2s ease;
}

.ys-glossaire-term .ys-glossaire-breadcrumb__link:hover {
  color: #3B82F6;
}

.ys-glossaire-term .ys-glossaire-breadcrumb__sep {
  color: #cbd5e1;
}

.ys-glossaire-term .ys-glossaire-breadcrumb__current {
  color: #0f172a;
  font-weight: 500;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  max-width: 20rem;
}

/* --- Detail Hero --- */
.ys-glossaire-term .ys-glossaire-detail-hero {
  position: relative;
  background: #151D53;
  overflow: hidden;
  padding: 3rem 2.5rem 3rem;
  margin-top: 1rem;
}

.ys-glossaire-term .ys-glossaire-detail-hero__glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  pointer-events: none;
}

.ys-glossaire-term .ys-glossaire-detail-hero__glow--left {
  width: 300px;
  height: 300px;
  top: -80px;
  left: -80px;
  background: rgba(59, 130, 246, 0.15);
}

.ys-glossaire-term .ys-glossaire-detail-hero__glow--right {
  width: 250px;
  height: 250px;
  bottom: -60px;
  right: -60px;
  background: rgba(96, 165, 250, 0.12);
}

.ys-glossaire-term .ys-glossaire-detail-hero__container {
  position: relative;
  max-width: 50rem;
  margin: 0 auto;
  z-index: 1;
}

.ys-glossaire-term .ys-glossaire-detail-hero__title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.2;
  color: #fff;
  margin: 0;
}

/* --- Detail Content --- */
.ys-glossaire-term .ys-glossaire-detail-content {
  padding: 2.5rem 2.5rem 4rem;
}

.ys-glossaire-term .ys-glossaire-detail-content__container {
  max-width: 50rem;
  margin: 0 auto;
}

/* Rich text styling (same as blog) */
.ys-glossaire-term .ys-richtext {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.0625rem;
  font-weight: 400;
  line-height: 1.75;
  color: #334155;
}

.ys-glossaire-term .ys-richtext h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.625rem;
  font-weight: 700;
  line-height: 1.3;
  color: #0f172a;
  margin: 2.5rem 0 1rem;
}

.ys-glossaire-term .ys-richtext h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.35;
  color: #0f172a;
  margin: 2rem 0 .75rem;
}

.ys-glossaire-term .ys-richtext h4 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.0625rem;
  font-weight: 600;
  line-height: 1.4;
  color: #0f172a;
  margin: 1.5rem 0 .5rem;
}

.ys-glossaire-term .ys-richtext p {
  margin: 0 0 1.25rem;
}

.ys-glossaire-term .ys-richtext > :first-child {
  margin-top: 0;
}

.ys-glossaire-term .ys-richtext > :last-child {
  margin-bottom: 0;
}

.ys-glossaire-term .ys-richtext ul,
.ys-glossaire-term .ys-richtext ol {
  margin: 0 0 1.25rem;
  padding-left: 1.5rem;
}

.ys-glossaire-term .ys-richtext li {
  margin-bottom: .5rem;
}

.ys-glossaire-term .ys-richtext a {
  color: #3B82F6;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color .2s ease;
}

.ys-glossaire-term .ys-richtext a:hover {
  color: #2563eb;
}

.ys-glossaire-term .ys-richtext blockquote {
  border-left: 3px solid #3B82F6;
  margin: 1.5rem 0;
  padding: 1rem 1.5rem;
  background: #f8fafc;
  border-radius: 0 .375rem .375rem 0;
  font-style: italic;
  color: #475569;
}

.ys-glossaire-term .ys-richtext blockquote p {
  margin-bottom: .5rem;
}

.ys-glossaire-term .ys-richtext blockquote p:last-child {
  margin-bottom: 0;
}

.ys-glossaire-term .ys-richtext pre {
  background: #1e293b;
  color: #e2e8f0;
  padding: 1.25rem;
  border-radius: .5rem;
  overflow-x: auto;
  margin: 1.5rem 0;
  font-size: .875rem;
  line-height: 1.6;
}

.ys-glossaire-term .ys-richtext code {
  font-family: 'Fira Code', 'Cascadia Code', monospace;
  font-size: .875em;
  background: #f1f5f9;
  padding: .125rem .375rem;
  border-radius: .25rem;
  color: #0f172a;
}

.ys-glossaire-term .ys-richtext pre code {
  background: none;
  padding: 0;
  border-radius: 0;
  color: inherit;
  font-size: inherit;
}

.ys-glossaire-term .ys-richtext img {
  display: block;
  max-width: 100%;
  height: auto;
  border-radius: .375rem;
  margin: 1.5rem 0;
}

.ys-glossaire-term .ys-richtext strong {
  font-weight: 600;
  color: #0f172a;
}

.ys-glossaire-term .ys-richtext hr {
  border: none;
  border-top: 1px solid #e2e8f0;
  margin: 2rem 0;
}

/* --- Detail Author Card --- */
.ys-glossaire-term .ys-glossaire-detail-author {
  padding: 0 2.5rem 3rem;
}

.ys-glossaire-term .ys-glossaire-detail-author__container {
  max-width: 50rem;
  margin: 0 auto;
}

.ys-glossaire-term .ys-glossaire-detail-author__card {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1.5rem;
  background: #f8fafc;
  border-radius: .5rem;
  border: 1px solid #e2e8f0;
  text-decoration: none;
  color: inherit;
  transition: border-color .2s ease;
}

.ys-glossaire-term .ys-glossaire-detail-author__card:hover {
  border-color: #3B82F6;
}

.ys-glossaire-term .ys-glossaire-detail-author__avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.ys-glossaire-term .ys-glossaire-detail-author__info {
  display: flex;
  flex-direction: column;
  gap: .1875rem;
}

.ys-glossaire-term .ys-glossaire-detail-author__label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .6875rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #94a3b8;
}

.ys-glossaire-term .ys-glossaire-detail-author__name {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  color: #0f172a;
}

.ys-glossaire-term .ys-glossaire-detail-author__position {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .8125rem;
  font-weight: 400;
  color: #64748b;
}

/* --- Related Terms --- */
.ys-glossaire-term .ys-glossaire-related {
  padding: 4rem 2.5rem;
  background: #f8f9fb;
}

.ys-glossaire-term .ys-glossaire-related__container {
  max-width: 75rem;
  margin: 0 auto;
}

.ys-glossaire-term .ys-glossaire-related__heading {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: #0f172a;
  margin: 0 0 2rem;
}

.ys-glossaire-term .ys-glossaire-related__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1rem;
}

.ys-glossaire-term .ys-glossaire-related__card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: .5rem;
  text-decoration: none;
  color: #0f172a;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .9375rem;
  font-weight: 500;
  transition: all .2s ease;
}

.ys-glossaire-term .ys-glossaire-related__card:hover {
  border-color: #3B82F6;
  background: #eff6ff;
  color: #3B82F6;
}

.ys-glossaire-term .ys-glossaire-related__arrow {
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
  margin-left: .5rem;
  color: #94a3b8;
  transition: transform .2s ease, color .2s ease;
}

.ys-glossaire-term .ys-glossaire-related__card:hover .ys-glossaire-related__arrow {
  transform: translateX(4px);
  color: #3B82F6;
}


/* =====================================================================
   RESPONSIVE — Tablet (max-width: 991px)
   ===================================================================== */
@media screen and (max-width: 991px) {
  /* Listing */
  .ys-glossaire .ys-glossaire-hero {
    padding: 7rem 2.5rem 2.5rem;
  }
  .ys-glossaire .ys-glossaire-hero__title {
    font-size: 2.25rem;
  }
  .ys-glossaire .ys-glossaire-section__list {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Detail */
  .ys-glossaire-term .ys-glossaire-detail-hero__title {
    font-size: 2rem;
  }
  .ys-glossaire-term .ys-glossaire-related__grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .ys-glossaire .ys-glossaire-cta__card,
  .ys-glossaire-term .ys-glossaire-cta__card {
    flex-direction: column;
    text-align: center;
    padding: 2.5rem 2rem;
  }
}

/* =====================================================================
   RESPONSIVE — Mobile Landscape (max-width: 767px)
   ===================================================================== */
@media screen and (max-width: 767px) {
  /* Listing */
  .ys-glossaire .ys-glossaire-hero {
    padding: 6rem 1.5rem 2rem;
  }
  .ys-glossaire .ys-glossaire-hero__title {
    font-size: 1.75rem;
  }
  .ys-glossaire .ys-glossaire-hero__subtitle {
    font-size: 1rem;
  }
  .ys-glossaire .ys-glossaire-letter-nav {
    padding: 0 1.5rem;
  }
  .ys-glossaire .ys-glossaire-letter-nav__list {
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .ys-glossaire .ys-glossaire-letter-nav__list::-webkit-scrollbar {
    display: none;
  }
  .ys-glossaire .ys-glossaire-letter-nav__link {
    flex-shrink: 0;
  }
  .ys-glossaire .ys-glossaire-sections {
    padding: 1.5rem 1.5rem 3rem;
  }
  .ys-glossaire .ys-glossaire-section__list {
    grid-template-columns: 1fr;
    gap: .5rem;
  }
  .ys-glossaire .ys-glossaire-section__heading {
    font-size: 1.5rem;
  }
  .ys-glossaire .ys-glossaire-cta,
  .ys-glossaire-term .ys-glossaire-cta {
    padding: 3rem 0;
  }
  .ys-glossaire .ys-glossaire-cta__container,
  .ys-glossaire-term .ys-glossaire-cta__container {
    padding: 0 1.5rem;
  }
  .ys-glossaire .ys-glossaire-cta__card,
  .ys-glossaire-term .ys-glossaire-cta__card {
    padding: 2rem 1.5rem;
  }
  .ys-glossaire .ys-glossaire-cta__heading,
  .ys-glossaire-term .ys-glossaire-cta__heading {
    font-size: 1.5rem;
  }

  /* Detail */
  .ys-glossaire-term .ys-glossaire-breadcrumb {
    padding: 6rem 1.5rem 0;
  }
  .ys-glossaire-term .ys-glossaire-detail-hero {
    padding: 2rem 1.5rem;
  }
  .ys-glossaire-term .ys-glossaire-detail-hero__title {
    font-size: 1.625rem;
  }
  .ys-glossaire-term .ys-glossaire-detail-content {
    padding: 2rem 1.5rem 3rem;
  }
  .ys-glossaire-term .ys-richtext {
    font-size: 1rem;
  }
  .ys-glossaire-term .ys-richtext h2 {
    font-size: 1.375rem;
  }
  .ys-glossaire-term .ys-richtext h3 {
    font-size: 1.125rem;
  }
  .ys-glossaire-term .ys-glossaire-detail-author {
    padding: 0 1.5rem 2.5rem;
  }
  .ys-glossaire-term .ys-glossaire-related {
    padding: 3rem 1.5rem;
  }
  .ys-glossaire-term .ys-glossaire-related__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* =====================================================================
   RESPONSIVE — Mobile Portrait (max-width: 479px)
   ===================================================================== */
@media screen and (max-width: 479px) {
  .ys-glossaire .ys-glossaire-hero__title {
    font-size: 1.5rem;
  }
  .ys-glossaire-term .ys-glossaire-detail-hero__title {
    font-size: 1.375rem;
  }
  .ys-glossaire-term .ys-glossaire-related__grid {
    grid-template-columns: 1fr;
  }
}
