/* ============================================================
   SPADE Consulting v2 — Shared Glossary (Ordliste) Styles
   Used by every /ordliste/<regulation>.html page.
   Pairs with /v2/glossary.js. Relies on tokens in subpage.css.
   ============================================================ */

.glossary-wrap { padding: var(--s6) 0 var(--s8); }

.glossary-intro {
  max-width: 820px;
  font-size: 1.05rem;
  line-height: 1.75;
  color: var(--td-med);
  margin-bottom: var(--s4);
}
.glossary-intro strong { color: var(--td-hi); }

/* ── Controls bar ───────────────────────────────────────────── */
.glossary-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--s3);
  margin-bottom: var(--s4);
  padding-bottom: var(--s3);
  border-bottom: 1px solid var(--bd-dark);
}
.glossary-search { flex: 1; min-width: 240px; position: relative; }
.glossary-search input {
  width: 100%;
  padding: .65rem 1rem .65rem 2.5rem;
  border-radius: var(--r2);
  background: var(--dark-2);
  color: var(--td-hi);
  border: 1.5px solid var(--bd-dark);
  font-family: var(--sans);
  font-size: .9rem;
  outline: none;
  transition: border-color .18s;
}
.glossary-search input::placeholder { color: var(--td-lo); }
.glossary-search input:focus { border-color: rgba(255,255,255,.25); }
.glossary-search::before {
  content: '⌕';
  position: absolute;
  left: .9rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.1rem;
  color: var(--td-lo);
  pointer-events: none;
}

.filter-group { display: flex; flex-wrap: wrap; gap: .5rem; }
.filter-pill {
  padding: .4rem 1rem;
  border-radius: var(--r5);
  font-size: .82rem;
  font-weight: 500;
  font-family: var(--sans);
  letter-spacing: -.01em;
  background: transparent;
  color: var(--td-med);
  border: 1.5px solid var(--bd-dark);
  cursor: pointer;
  transition: background .18s, border-color .18s, color .18s;
}
.filter-pill:hover {
  border-color: rgba(255,255,255,.25);
  color: var(--td-hi);
  background: rgba(255,255,255,.04);
}
.filter-pill.active {
  background: var(--cream-1);
  border-color: var(--cream-1);
  color: var(--dark-1);
  font-weight: 600;
}

.glossary-count {
  font-family: var(--mono);
  font-size: .72rem;
  color: var(--td-lo);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: var(--s4);
}

/* ── Two-column layout ──────────────────────────────────────── */
.glossary-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--s5);
  align-items: start;
}

/* ── Sticky term TOC + custom scrollbar ─────────────────────── */
.term-toc {
  position: sticky;
  top: 72px;                         /* clears the 57px fixed header + gap */
  align-self: start;                 /* don't stretch to grid row height */
  height: calc(100vh - 88px);        /* scales with the viewport */
  overflow-y: auto;
  padding-right: 4px;
  overscroll-behavior: contain;      /* scrolling the TOC doesn't scroll the page */
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.16) transparent;
}
.term-toc::-webkit-scrollbar { width: 8px; }
.term-toc::-webkit-scrollbar-track { background: transparent; }
.term-toc::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.14);
  border-radius: 8px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
.term-toc::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,.30);
  background-clip: padding-box;
}
.term-toc-label {
  font-family: var(--mono);
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--td-lo);
  margin-bottom: var(--s2);
}
.term-toc ul { list-style: none; }
.term-toc li { margin-bottom: .15rem; }
.term-toc a {
  display: block;
  padding: .35rem .65rem;
  border-radius: var(--r1);
  font-size: .85rem;
  color: var(--td-med);
  border-left: 2px solid transparent;
  transition: background .15s, color .15s, border-color .15s;
}
.term-toc a:hover {
  background: rgba(255,255,255,.04);
  color: var(--td-hi);
  border-left-color: var(--blue);
}
.term-toc a.active {
  background: rgba(91,158,255,.10);
  color: var(--td-hi);
  border-left-color: var(--blue);
}

/* ── Term cards ─────────────────────────────────────────────── */
.term-list { display: flex; flex-direction: column; gap: var(--s4); }

.term-group-label {
  font-family: var(--mono);
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--blue);
  margin-top: var(--s3);
  padding-bottom: .4rem;
  border-bottom: 1px solid var(--bd-dark);
}
.term-group-label:first-child { margin-top: 0; }

/* Pinned divider, injected by glossary.js */
.term-group-label.pinned-label {
  order: -2;
  color: #E0A94A;
  border-bottom-color: rgba(224,169,74,.35);
  display: none;
}
.term-group-label.pinned-label.show { display: block; }

.term-card {
  background: var(--dark-2);
  border: 1px solid var(--bd-dark);
  border-radius: var(--r3);
  padding: var(--s4);
  scroll-margin-top: 80px;
  transition: border-color .25s;
}
.term-card:hover { border-color: rgba(255,255,255,.16); }
.term-card:target {
  border-color: var(--blue);
  box-shadow: 0 0 0 1px rgba(91,158,255,.35);
}
.term-card.is-pinned {
  order: -1;
  border-color: rgba(224,169,74,.40);
}

.term-head {
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: var(--s2);
}
.term-head h2 {
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1.2;
  color: var(--td-hi);
}
.term-anchor {
  opacity: 0;
  font-size: .95rem;
  color: var(--td-lo);
  border: 1px solid var(--bd-dark);
  border-radius: var(--r1);
  width: 28px; height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: opacity .15s, color .15s, border-color .15s;
}
.term-card:hover .term-anchor { opacity: 1; }
.term-anchor:hover { color: var(--blue); border-color: var(--blue); }

/* Action cluster (anchor + copy-def + star), assembled by glossary.js */
.term-actions {
  display: flex;
  align-items: center;
  gap: .4rem;
  margin-left: auto;
  flex-shrink: 0;
}
.term-actions .term-anchor { width: 32px; height: 32px; opacity: .5; }
.term-card:hover .term-actions .term-anchor { opacity: 1; }

/* Copy-definition button, injected by glossary.js */
.term-copydef {
  flex-shrink: 0;
  width: 32px; height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  line-height: 1;
  border: 1px solid var(--bd-dark);
  border-radius: var(--r1);
  background: transparent;
  color: var(--td-lo);
  transition: color .15s, border-color .15s, background .15s, transform .15s;
}
.term-copydef:hover { color: var(--blue); border-color: var(--blue); }
.term-copydef:active { transform: scale(.9); }
.term-copydef.done { color: var(--green); border-color: rgba(0,232,122,.5); }

/* Star / pin button, injected by glossary.js */
.term-star {
  flex-shrink: 0;
  width: 32px; height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  line-height: 1;
  border: 1px solid var(--bd-dark);
  border-radius: var(--r1);
  background: transparent;
  color: var(--td-lo);
  transition: color .15s, border-color .15s, background .15s, transform .15s;
}
.term-star:hover { color: #E0A94A; border-color: rgba(224,169,74,.5); }
.term-star:active { transform: scale(.9); }
.term-star.on { color: #E0A94A; border-color: rgba(224,169,74,.5); background: rgba(224,169,74,.10); }

.term-chips {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: var(--s2);
}
.term-chip {
  font-family: var(--mono);
  font-size: .66rem;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--td-lo);
  border: 1px solid var(--bd-dark);
  border-radius: var(--r5);
  padding: .22rem .6rem;
}
.term-chip.chip-reg   { color: var(--blue); border-color: rgba(91,158,255,.35); }
.term-chip.chip-art   { color: var(--td-med); }
.term-chip.chip-alias { color: var(--td-lo); text-transform: none; letter-spacing: 0; }
.term-chip.chip-live    { color: var(--green); border-color: rgba(0,232,122,.35); }
.term-chip.chip-pending { color: #D98A3D; border-color: rgba(217,138,61,.40); }
.term-chip.chip-standard { color: #C2A86A; border-color: rgba(194,168,106,.40); }

.term-def {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--td-hi);
  font-weight: 500;
  margin-bottom: var(--s2);
}
.term-explainer p {
  font-size: .95rem;
  line-height: 1.75;
  color: var(--td-med);
  margin-bottom: var(--s2);
}
.term-explainer p:last-child { margin-bottom: 0; }

/* Inline cross-term links, injected by glossary.js */
.term-xref {
  color: var(--blue);
  text-decoration: underline;
  text-decoration-style: dotted;
  text-decoration-color: rgba(91,158,255,.45);
  text-underline-offset: 2px;
  transition: text-decoration-color .15s, color .15s;
}
.term-xref:hover { color: var(--td-hi); text-decoration-color: var(--blue); }

/* Search highlight */
mark.gl-mark {
  background: rgba(91,158,255,.30);
  color: inherit;
  border-radius: 3px;
  padding: 0 .12em;
}

/* Example callout */
.term-example {
  background: rgba(0,232,122,.06);
  border-left: 3px solid var(--green);
  border-radius: var(--r2);
  padding: var(--s2) var(--s3);
  margin: var(--s3) 0;
}
.term-example-label {
  font-family: var(--mono);
  font-size: .66rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: .4rem;
}
.term-example p { font-size: .92rem; line-height: 1.7; color: var(--td-med); }

/* Primary sources, rendered by glossary.js from window.__GLOSSARY_SOURCES__ */
.term-sources {
  margin-top: var(--s3);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .45rem;
}
.term-sources-label {
  font-family: var(--mono);
  font-size: .66rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--td-lo);
  width: 100%;
  margin-bottom: .15rem;
}
.term-source-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .8rem;
  font-weight: 500;
  color: var(--td-med);
  border: 1px solid var(--bd-dark);
  border-radius: var(--r5);
  padding: .28rem .7rem;
  transition: border-color .15s, color .15s, background .15s;
}
.term-source-link:hover { color: var(--td-hi); border-color: rgba(255,255,255,.28); background: rgba(255,255,255,.04); }
.term-source-link .src-badge {
  font-family: var(--mono);
  font-size: .58rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: .1rem .35rem;
  border-radius: var(--r1);
}
.term-source-link.src-lovdata .src-badge { color: var(--blue); background: rgba(91,158,255,.12); }
.term-source-link.src-datatilsynet .src-badge { color: var(--green); background: rgba(0,232,122,.12); }
.term-source-link.src-eurlex .src-badge { color: #C9A227; background: rgba(201,162,39,.14); }
.term-source-link.src-nsm .src-badge { color: #D98A3D; background: rgba(217,138,61,.14); }
.term-source-link.src-nkom .src-badge { color: #3DA8C0; background: rgba(61,168,192,.14); }
.term-source-link.src-finanstilsynet .src-badge { color: #9B8AD1; background: rgba(155,138,209,.16); }
.term-source-link.src-iso .src-badge { color: #D97A74; background: rgba(217,122,116,.14); }
.term-source-link.src-standardnorge .src-badge { color: #4FB0A0; background: rgba(79,176,160,.14); }
.term-source-link.src-regjeringen .src-badge { color: var(--td-med); background: rgba(255,255,255,.08); }
.term-source-link .src-ext { opacity: .5; font-size: .72rem; }

/* Reusable status / info callout for glossary intros */
.glossary-note {
  max-width: 820px;
  background: rgba(91,158,255,.06);
  border: 1px solid rgba(91,158,255,.22);
  border-left: 3px solid var(--blue);
  border-radius: var(--r2);
  padding: var(--s3) var(--s4);
  margin-bottom: var(--s5);
}
.glossary-note h2 {
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--td-hi);
  margin-bottom: var(--s2);
  display: flex;
  align-items: center;
  gap: .5rem;
}
.glossary-note p { font-size: .92rem; line-height: 1.7; color: var(--td-med); margin-bottom: var(--s2); }
.glossary-note p:last-child { margin-bottom: 0; }
.glossary-note strong { color: var(--td-hi); }
.glossary-note .note-status {
  font-family: var(--mono);
  font-size: .64rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .18rem .55rem;
  border-radius: var(--r5);
}
.glossary-note .note-status.in-force { color: var(--green); background: rgba(0,232,122,.12); }
.glossary-note .note-status.pending { color: #D98A3D; background: rgba(217,138,61,.14); }
.glossary-note .note-status.standard { color: #C2A86A; background: rgba(194,168,106,.14); }

/* Related links */
.term-related {
  margin-top: var(--s3);
  padding-top: var(--s2);
  border-top: 1px solid var(--bd-dark);
  font-size: .85rem;
  color: var(--td-lo);
}
.term-related .related-label {
  font-family: var(--mono);
  font-size: .66rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-right: .5rem;
}
.term-related a {
  color: var(--blue);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .15s;
}
.term-related a:hover { border-bottom-color: var(--blue); }
.term-related .sep { opacity: .3; margin: 0 .35rem; }

.term-updated {
  margin-top: var(--s2);
  font-family: var(--mono);
  font-size: .68rem;
  color: var(--td-lo);
  letter-spacing: .04em;
}

/* Inline contextual CTA, injected per category by glossary.js */
.term-cta-inline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--s3);
  background: rgba(91,158,255,.05);
  border: 1px dashed rgba(91,158,255,.30);
  border-radius: var(--r3);
  padding: var(--s3) var(--s4);
}
.term-cta-inline .cta-copy { flex: 1; min-width: 240px; }
.term-cta-inline h3 {
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--td-hi);
  margin-bottom: .3rem;
}
.term-cta-inline p { font-size: .9rem; line-height: 1.6; color: var(--td-med); margin: 0; }
.term-cta-inline .btn { flex-shrink: 0; }

/* Sticky mobile mini-search, injected by glossary.js */
#gl-sticky {
  position: fixed;
  top: 57px; left: 0; right: 0;
  z-index: 40;
  display: none;
  padding: .55rem var(--s3);
  background: var(--dark-2);
  border-bottom: 1px solid var(--bd-dark);
  transform: translateY(-120%);
  transition: transform .25s cubic-bezier(0.16,1,0.3,1);
}
#gl-sticky.show { transform: none; }
#gl-sticky input {
  width: 100%;
  padding: .6rem 1rem;
  border-radius: var(--r2);
  background: var(--dark-1);
  color: var(--td-hi);
  border: 1.5px solid var(--bd-dark);
  font-family: var(--sans);
  font-size: .9rem;
  outline: none;
}
#gl-sticky input::placeholder { color: var(--td-lo); }
@media (max-width: 900px) { #gl-sticky { display: block; } }

/* No results */
.no-terms {
  display: none;
  text-align: center;
  padding: var(--s6) var(--s4);
  color: var(--td-lo);
  font-family: var(--mono);
  font-size: .88rem;
}
.no-terms.visible { display: block; }
.no-terms .gl-suggest { color: var(--blue); cursor: pointer; text-decoration: underline; }

/* CTA */
.glossary-cta {
  margin-top: var(--s6);
  background: var(--dark-2);
  border: 1px solid var(--bd-dark);
  border-radius: var(--r3);
  padding: var(--s5);
  text-align: center;
}
.glossary-cta h2 { font-size: 1.5rem; font-weight: 700; margin-bottom: var(--s2); }
.glossary-cta p { color: var(--td-med); max-width: 52ch; margin: 0 auto var(--s3); line-height: 1.7; }

/* Trust line + secondary booking under the CTA, injected by glossary.js */
.glossary-cta-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--s2);
}
.glossary-cta-secondary {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .9rem;
  font-weight: 600;
  color: var(--td-med);
  border: 1.5px solid var(--bd-dark);
  border-radius: var(--r5);
  padding: .7rem 1.3rem;
  transition: border-color .18s, color .18s, background .18s;
}
.glossary-cta-secondary:hover { color: var(--td-hi); border-color: rgba(255,255,255,.28); background: rgba(255,255,255,.04); }
.glossary-cta-trust {
  margin-top: var(--s3);
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .06em;
  color: var(--td-lo);
  display: flex;
  flex-wrap: wrap;
  gap: .35rem .85rem;
  justify-content: center;
}
.glossary-cta-trust .sep { opacity: .4; }

/* Subtle PECB course cross-link, injected by glossary.js from __GLOSSARY_COURSE__ */
.glossary-course {
  margin-top: var(--s5);
  display: flex;
  align-items: center;
  gap: var(--s3);
  flex-wrap: wrap;
  padding: var(--s3) var(--s4);
  border: 1px solid var(--bd-dark);
  border-radius: var(--r3);
  background: rgba(255,255,255,.02);
}
.glossary-course .gc-icon { font-size: 1.35rem; line-height: 1; flex-shrink: 0; opacity: .85; }
.glossary-course .gc-body { flex: 1; min-width: 240px; }
.glossary-course .gc-eyebrow {
  font-family: var(--mono); font-size: .62rem; font-weight: 600; letter-spacing: .12em;
  text-transform: uppercase; color: var(--td-lo); margin-bottom: .25rem;
}
.glossary-course p { font-size: .9rem; line-height: 1.55; color: var(--td-med); margin: 0; }
.glossary-course a.gc-link {
  flex-shrink: 0; font-size: .85rem; font-weight: 600; color: var(--cream-1);
  display: inline-flex; align-items: center; gap: .4rem;
  border-bottom: 1px solid transparent; transition: gap .2s, border-color .15s;
}
.glossary-course a.gc-link:hover { gap: .6rem; border-bottom-color: var(--cream-1); }

/* Above-the-fold compact radar CTA, injected by glossary.js */
.glossary-radar-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--s2);
  max-width: 820px;
  margin: 0 0 var(--s4);
  padding: .65rem .65rem .65rem 1rem;
  background: rgba(0,232,122,.06);
  border: 1px solid rgba(0,232,122,.22);
  border-radius: var(--r2);
}
.glossary-radar-top .grt-text { font-size: .9rem; line-height: 1.5; color: var(--td-med); }
.glossary-radar-top .grt-text strong { color: var(--td-hi); }
.glossary-radar-top .grt-btn {
  flex-shrink: 0;
  font-family: var(--sans);
  font-size: .82rem;
  font-weight: 600;
  color: var(--dark-1);
  background: var(--green);
  border: none;
  border-radius: var(--r5);
  padding: .5rem 1.1rem;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s;
}
.glossary-radar-top .grt-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 14px rgba(0,232,122,.25); }
.glossary-radar-top .grt-btn:active { transform: scale(.97); }

/* Inline newsletter band (Regelverksradar), injected by glossary.js */
.glossary-signup {
  margin-top: var(--s5);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: var(--s3) var(--s4);
  background: rgba(0,232,122,.05);
  border: 1px solid rgba(0,232,122,.22);
  border-left: 3px solid var(--green);
  border-radius: var(--r3);
  padding: var(--s4);
}
.glossary-signup .gs-eyebrow {
  font-family: var(--mono);
  font-size: .66rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: .4rem;
}
.glossary-signup h3 { font-size: 1.15rem; font-weight: 700; letter-spacing: -.01em; color: var(--td-hi); margin-bottom: .3rem; }
.glossary-signup p { font-size: .9rem; line-height: 1.6; color: var(--td-med); margin: 0; max-width: 60ch; }
.glossary-signup form { display: flex; gap: .5rem; flex-wrap: wrap; }
.glossary-signup input[type=email] {
  flex: 1; min-width: 200px;
  padding: .7rem 1rem;
  border-radius: var(--r2);
  background: var(--dark-1);
  color: var(--td-hi);
  border: 1.5px solid var(--bd-dark);
  font-family: var(--sans);
  font-size: .9rem;
  outline: none;
  transition: border-color .18s;
}
.glossary-signup input[type=email]::placeholder { color: var(--td-lo); }
.glossary-signup input[type=email]:focus { border-color: var(--green); }
.glossary-signup.is-done { grid-template-columns: 1fr; text-align: center; }
.glossary-signup.is-done .gs-form-col { display: none; }
.glossary-signup .gs-done { display: none; font-size: .95rem; color: var(--td-hi); font-weight: 600; }
.glossary-signup.is-done .gs-done { display: block; }
.glossary-signup.is-done .gs-copy-col p { margin: 0 auto; }

/* Scroll-triggered toast, injected by glossary.js */
.gl-toast {
  position: fixed;
  right: var(--s3);
  bottom: var(--s3);
  z-index: 50;
  width: min(360px, calc(100vw - 2 * var(--s3)));
  background: var(--dark-3);
  border: 1px solid var(--bd-dark);
  border-radius: var(--r3);
  box-shadow: 0 16px 50px rgba(0,0,0,.45);
  padding: var(--s3) var(--s4);
  transform: translateY(140%);
  transition: transform .35s cubic-bezier(0.16,1,0.3,1);
}
.gl-toast.show { transform: none; }
.gl-toast .gl-toast-eyebrow {
  font-family: var(--mono);
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: .35rem;
}
.gl-toast p { font-size: .9rem; line-height: 1.55; color: var(--td-med); margin-bottom: var(--s2); }
.gl-toast p strong { color: var(--td-hi); }
.gl-toast-actions { display: flex; align-items: center; gap: var(--s2); }
.gl-toast .gl-toast-dismiss {
  background: none; border: none; color: var(--td-lo);
  font-size: .82rem; cursor: pointer; padding: .3rem;
}
.gl-toast .gl-toast-dismiss:hover { color: var(--td-hi); }
.gl-toast-close {
  position: absolute; top: .5rem; right: .6rem;
  background: none; border: none; color: var(--td-lo);
  font-size: 1.1rem; line-height: 1; cursor: pointer;
}
.gl-toast-close:hover { color: var(--td-hi); }
@media (prefers-reduced-motion: reduce) { .gl-toast { transition: none; } }

@media (max-width: 900px) {
  .glossary-layout { grid-template-columns: 1fr; }
  .term-toc { display: none; }
}
@media (max-width: 640px) {
  .glossary-controls { flex-direction: column; align-items: stretch; }
}

/* ── Light mode ─────────────────────────────────────────────── */
@media (prefers-color-scheme: light) {
  .glossary-intro { color: var(--tl-med); }
  .glossary-intro strong { color: var(--tl-hi); }
  .glossary-controls { border-bottom-color: rgba(0,0,0,.07); }
  .glossary-search input { background: var(--cream-0); color: var(--tl-hi); border-color: rgba(0,0,0,.12); }
  .glossary-search input::placeholder { color: var(--tl-lo); }
  .glossary-search input:focus { border-color: rgba(0,0,0,.28); }
  .glossary-search::before { color: var(--tl-lo); }
  .filter-pill { border-color: rgba(0,0,0,.12); color: var(--tl-med); }
  .filter-pill:hover { border-color: rgba(0,0,0,.25); color: var(--tl-hi); background: rgba(0,0,0,.03); }
  .filter-pill.active { background: var(--tl-hi); border-color: var(--tl-hi); color: var(--cream-1); }
  .glossary-count { color: var(--tl-lo); }

  .term-toc { scrollbar-color: rgba(0,0,0,.20) transparent; }
  .term-toc::-webkit-scrollbar-thumb { background: rgba(0,0,0,.16); background-clip: padding-box; }
  .term-toc::-webkit-scrollbar-thumb:hover { background: rgba(0,0,0,.30); background-clip: padding-box; }
  .term-toc-label { color: var(--tl-lo); }
  .term-toc a { color: var(--tl-med); }
  .term-toc a:hover { background: rgba(0,0,0,.03); color: var(--tl-hi); border-left-color: var(--blue-on-light); }
  .term-toc a.active { background: rgba(43,91,173,.08); color: var(--tl-hi); border-left-color: var(--blue-on-light); }

  .term-group-label { color: var(--blue-on-light); border-bottom-color: rgba(0,0,0,.08); }
  .term-group-label.pinned-label { color: #B9822A; border-bottom-color: rgba(185,130,42,.35); }

  .term-card { background: var(--cream-0); border-color: rgba(0,0,0,.08); }
  .term-card:hover { border-color: rgba(0,0,0,.16); box-shadow: 0 4px 12px rgba(0,0,0,.05); }
  .term-card:target { border-color: var(--blue-on-light); box-shadow: 0 0 0 1px rgba(43,91,173,.3); }
  .term-card.is-pinned { border-color: rgba(185,130,42,.45); }

  .term-head h2 { color: var(--tl-hi); }
  .term-anchor { color: var(--tl-lo); border-color: rgba(0,0,0,.12); }
  .term-anchor:hover { color: var(--blue-on-light); border-color: var(--blue-on-light); }
  .term-star { color: var(--tl-lo); border-color: rgba(0,0,0,.12); }
  .term-star:hover, .term-star.on { color: #B9822A; border-color: rgba(185,130,42,.5); }
  .term-star.on { background: rgba(185,130,42,.10); }
  .term-copydef { color: var(--tl-lo); border-color: rgba(0,0,0,.12); }
  .term-copydef:hover { color: var(--blue-on-light); border-color: var(--blue-on-light); }
  .term-copydef.done { color: var(--green-on-light); border-color: rgba(26,122,69,.5); }

  .term-cta-inline { background: rgba(43,91,173,.04); border-color: rgba(43,91,173,.28); }
  .term-cta-inline h3 { color: var(--tl-hi); }
  .term-cta-inline p { color: var(--tl-med); }

  #gl-sticky { background: var(--cream-0); border-bottom-color: rgba(0,0,0,.08); }
  #gl-sticky input { background: var(--cream-2); color: var(--tl-hi); border-color: rgba(0,0,0,.12); }
  #gl-sticky input::placeholder { color: var(--tl-lo); }

  .term-chip { color: var(--tl-lo); border-color: rgba(0,0,0,.1); }
  .term-chip.chip-reg { color: var(--blue-on-light); border-color: rgba(43,91,173,.3); }
  .term-chip.chip-art { color: var(--tl-med); }
  .term-chip.chip-live { color: var(--green-on-light); border-color: rgba(26,122,69,.35); }
  .term-chip.chip-pending { color: #B5641E; border-color: rgba(181,100,30,.40); }
  .term-chip.chip-standard { color: #8A7430; border-color: rgba(138,116,48,.40); }
  .term-def { color: var(--tl-hi); }
  .term-explainer p { color: var(--tl-med); }
  .term-xref { color: var(--blue-on-light); text-decoration-color: rgba(43,91,173,.45); }
  .term-xref:hover { color: var(--tl-hi); text-decoration-color: var(--blue-on-light); }
  mark.gl-mark { background: rgba(43,91,173,.22); }

  .term-example { background: rgba(26,122,69,.06); border-left-color: var(--green-on-light); }
  .term-example-label { color: var(--green-on-light); }
  .term-example p { color: var(--tl-med); }

  .term-sources-label { color: var(--tl-lo); }
  .term-source-link { color: var(--tl-med); border-color: rgba(0,0,0,.12); }
  .term-source-link:hover { color: var(--tl-hi); border-color: rgba(0,0,0,.28); background: rgba(0,0,0,.03); }
  .term-source-link.src-lovdata .src-badge { color: var(--blue-on-light); background: rgba(43,91,173,.12); }
  .term-source-link.src-datatilsynet .src-badge { color: var(--green-on-light); background: rgba(26,122,69,.12); }
  .term-source-link.src-eurlex .src-badge { color: #8A6D0B; background: rgba(138,109,11,.12); }
  .term-source-link.src-nsm .src-badge { color: #B5641E; background: rgba(181,100,30,.12); }
  .term-source-link.src-nkom .src-badge { color: #1E7D94; background: rgba(30,125,148,.12); }
  .term-source-link.src-finanstilsynet .src-badge { color: #5E4B9E; background: rgba(94,75,158,.12); }
  .term-source-link.src-iso .src-badge { color: #B0463F; background: rgba(176,70,63,.12); }
  .term-source-link.src-standardnorge .src-badge { color: #2E7D6E; background: rgba(46,125,110,.12); }
  .term-source-link.src-regjeringen .src-badge { color: var(--tl-med); background: rgba(0,0,0,.06); }

  .glossary-note { background: rgba(43,91,173,.05); border-color: rgba(43,91,173,.22); border-left-color: var(--blue-on-light); }
  .glossary-note h2 { color: var(--tl-hi); }
  .glossary-note p { color: var(--tl-med); }
  .glossary-note strong { color: var(--tl-hi); }
  .glossary-note .note-status.in-force { color: var(--green-on-light); background: rgba(26,122,69,.12); }
  .glossary-note .note-status.pending { color: #B5641E; background: rgba(181,100,30,.12); }
  .glossary-note .note-status.standard { color: #8A7430; background: rgba(138,116,48,.12); }

  .term-related { border-top-color: rgba(0,0,0,.08); color: var(--tl-lo); }
  .term-related a { color: var(--blue-on-light); }
  .term-related a:hover { border-bottom-color: var(--blue-on-light); }
  .term-updated { color: var(--tl-lo); }
  .no-terms { color: var(--tl-lo); }
  .no-terms .gl-suggest { color: var(--blue-on-light); }
  .glossary-cta { background: var(--cream-0); border-color: rgba(0,0,0,.08); }
  .glossary-cta p { color: var(--tl-med); }

  .glossary-cta-secondary { color: var(--tl-med); border-color: rgba(0,0,0,.14); }
  .glossary-cta-secondary:hover { color: var(--tl-hi); border-color: rgba(0,0,0,.28); background: rgba(0,0,0,.03); }
  .glossary-cta-trust { color: var(--tl-lo); }

  .glossary-course { background: rgba(0,0,0,.02); border-color: rgba(0,0,0,.08); }
  .glossary-course .gc-eyebrow { color: var(--tl-lo); }
  .glossary-course p { color: var(--tl-med); }
  .glossary-course a.gc-link { color: var(--tl-hi); }
  .glossary-course a.gc-link:hover { border-bottom-color: var(--tl-hi); }

  .glossary-radar-top { background: rgba(26,122,69,.05); border-color: rgba(26,122,69,.22); }
  .glossary-radar-top .grt-text { color: var(--tl-med); }
  .glossary-radar-top .grt-text strong { color: var(--tl-hi); }
  .glossary-radar-top .grt-btn { color: var(--cream-0); background: var(--green-on-light); }
  .glossary-signup { background: rgba(26,122,69,.05); border-color: rgba(26,122,69,.22); border-left-color: var(--green-on-light); }
  .glossary-signup .gs-eyebrow { color: var(--green-on-light); }
  .glossary-signup h3 { color: var(--tl-hi); }
  .glossary-signup p { color: var(--tl-med); }
  .glossary-signup input[type=email] { background: var(--cream-2); color: var(--tl-hi); border-color: rgba(0,0,0,.14); }
  .glossary-signup input[type=email]::placeholder { color: var(--tl-lo); }
  .glossary-signup input[type=email]:focus { border-color: var(--green-on-light); }
  .glossary-signup .gs-done { color: var(--tl-hi); }

  .gl-toast { background: var(--cream-0); border-color: rgba(0,0,0,.10); box-shadow: 0 16px 50px rgba(0,0,0,.18); }
  .gl-toast .gl-toast-eyebrow { color: var(--green-on-light); }
  .gl-toast p { color: var(--tl-med); }
  .gl-toast p strong { color: var(--tl-hi); }
  .gl-toast .gl-toast-dismiss, .gl-toast-close { color: var(--tl-lo); }
  .gl-toast .gl-toast-dismiss:hover, .gl-toast-close:hover { color: var(--tl-hi); }
}
