/* ============================================================
   glossary-styles.css — Словарь ИИ
   Расширение blog-styles.css дизайн-системы (graphite-mint)
   ============================================================ */

:root {
  --bg:         #0e0e0d;
  --bg-deep:    #1a1a18;
  --bg-paper:   #161614;
  --bg-mint:    #133327;
  --fg:         #f2f2ee;
  --fg-soft:    #dcdcd6;
  --fg-mute:    #7a7a74;
  --fg-mute-2:  #5a5a55;
  --hair:       #2a2a26;
  --hair-soft:  #1f1f1d;
  --green:      #5dd6a3;
  --signal:     #ff4d1f;
  --f-display:  "Space Grotesk", ui-sans-serif, system-ui, sans-serif;
  --f-body:     "Space Grotesk", ui-sans-serif, system-ui, sans-serif;
  --f-read:     "Newsreader", "Iowan Old Style", Georgia, serif;
  --f-mono:     "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --f-serif:    "Instrument Serif", "Times New Roman", serif;
  --pad-edge:    clamp(24px, 4vw, 64px);
  --pad-section: clamp(72px, 7vw, 128px);
  --maxw:        1600px;
  --maxw-read:   720px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
html, body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--f-body);
  font-size: 16px; line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body { overflow-x: clip; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--green); color: #000; }
img { display: block; max-width: 100%; }

/* ============================================================
   Glossary ticker (под header)
   ============================================================ */
.gl-ticker {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-mute);
  border-bottom: 1px solid var(--hair);
  padding: 14px var(--pad-edge);
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: center;
}
.gl-ticker .gt-crumb a { color: var(--fg-mute); border-bottom: 1px solid transparent; transition: color .15s, border-color .15s; }
.gl-ticker .gt-crumb a:hover { color: var(--fg); border-bottom-color: var(--green); }
.gl-ticker .gt-crumb .cur { color: var(--fg); }
.gl-ticker .gt-stream { display: flex; gap: 18px; justify-content: center; align-items: center; flex-wrap: wrap; }
.gl-ticker .gt-stream b { color: var(--green); font-weight: 600; margin-right: 4px; }
.gl-ticker .gt-actions { display: flex; gap: 12px; }
.gl-ticker .gt-actions a { color: var(--fg-soft); border-bottom: 1px solid transparent; transition: color .15s, border-color .15s; }
.gl-ticker .gt-actions a:hover { color: var(--fg); border-bottom-color: var(--green); }

/* ============================================================
   Glossary hero
   ============================================================ */
.gl-hero {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: clamp(48px, 7vw, 96px) var(--pad-edge) clamp(48px, 6vw, 80px);
  border-bottom: 2px solid var(--fg);
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: clamp(40px, 5vw, 80px);
  align-items: end;
}
.gl-hero .gh-eyebrow {
  font-family: var(--f-mono);
  font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--fg-mute);
  margin-bottom: 24px;
  display: flex; gap: 14px; align-items: center; flex-wrap: wrap;
}
.gl-hero .gh-eyebrow .live::before {
  content: ""; display: inline-block;
  width: 8px; height: 8px; background: var(--green); border-radius: 50%;
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--green) 30%, transparent);
  margin-right: 8px;
  vertical-align: middle;
}
.gl-hero h1 {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(48px, 8vw, 128px);
  line-height: 0.92;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}
.gl-hero h1 em {
  display: block;
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green);
  text-transform: none;
  font-size: 0.45em;
  margin-bottom: 0.15em;
  letter-spacing: -0.02em;
}
.gl-hero .gh-aside {
  border-left: 2px solid var(--green);
  padding-left: 28px;
  max-width: 380px;
}
.gl-hero .gh-aside p {
  font-family: var(--f-read);
  font-size: 19px; line-height: 1.5;
  color: var(--fg-soft);
}
.gl-hero .gh-aside .meta {
  margin-top: 24px;
  font-family: var(--f-mono);
  font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--fg-mute);
  display: flex; gap: 18px; flex-wrap: wrap;
}
.gl-hero .gh-aside .meta b { color: var(--green); font-weight: 600; margin-right: 4px; }

/* ============================================================
   Term list (index)
   ============================================================ */
.gl-list-header {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(48px, 6vw, 80px) var(--pad-edge) 24px;
  display: grid; grid-template-columns: 80px 1fr auto;
  align-items: baseline; gap: 24px;
  font-family: var(--f-mono);
  font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--fg-mute);
  border-bottom: 1px solid var(--hair);
}
.gl-list-header h2 {
  font-family: var(--f-display);
  font-size: 20px; font-weight: 500; letter-spacing: -0.02em;
  color: var(--fg); text-transform: none;
}

.gl-list {
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--pad-edge);
}
.gl-term {
  display: grid;
  grid-template-columns: 80px 1fr 64px;
  gap: 32px;
  padding: 24px 0;
  border-bottom: 1px solid var(--hair);
  position: relative;
  transition: padding-left 0.3s cubic-bezier(0.2,0.7,0.2,1);
}
.gl-term::before {
  content: ""; position: absolute;
  inset: 0 -32px;
  background: var(--bg-paper); opacity: 0; transition: opacity 0.2s;
  z-index: -1;
}
.gl-term:hover { padding-left: 24px; }
.gl-term:hover::before { opacity: 1; }
.gl-term .gl-num {
  font-family: var(--f-mono);
  font-size: 11px; letter-spacing: 0.1em;
  color: var(--fg-mute);
}
.gl-term .gl-title {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(22px, 2.2vw, 30px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}
.gl-term .gl-title a { color: var(--fg); }
.gl-term:hover .gl-title a { color: var(--green); }
.gl-term .gl-desc {
  color: var(--fg-soft);
  font-size: 15px;
  max-width: 56ch;
}
.gl-term .gl-tag {
  display: inline-block; margin-top: 10px;
  font-family: var(--f-mono);
  font-size: 10px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--fg-mute);
  padding: 3px 6px; background: #1f1f1d;
}
.gl-term .gl-arr {
  font-family: var(--f-display);
  font-size: 24px; color: var(--fg-mute);
  align-self: center; text-align: right;
  transition: transform 0.2s, color 0.2s;
}
.gl-term:hover .gl-arr {
  transform: translateX(8px);
  color: var(--green);
}

/* ============================================================
   Term detail page (article-style)
   ============================================================ */
.gl-article {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(48px, 6vw, 96px) var(--pad-edge);
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: clamp(40px, 5vw, 72px);
}
.gl-article .gl-main { max-width: var(--maxw-read); }
.gl-article .gl-rail {
  position: sticky; top: 24px; align-self: start;
  display: flex; flex-direction: column; gap: 24px;
}

.gl-article-header {
  border-bottom: 1px solid var(--hair);
  padding-bottom: 24px; margin-bottom: 40px;
}
.gl-article-header .gl-meta {
  font-family: var(--f-mono);
  font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--fg-mute);
  margin-bottom: 16px;
  display: flex; gap: 16px; align-items: center; flex-wrap: wrap;
}
.gl-article-header .gl-meta .pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  background: var(--bg-paper);
  border: 1px solid var(--green);
  color: var(--green);
}
.gl-article-header .gl-meta .pill::before {
  content: ""; display: inline-block; width: 6px; height: 6px;
  background: var(--green); border-radius: 50%;
}
.gl-article-header h1 {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(40px, 5.5vw, 80px);
  line-height: 0.95;
  letter-spacing: -0.04em;
  margin-bottom: 16px;
}
.gl-article-header .gl-h1-en {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--green);
  font-size: 0.5em;
  display: block;
  margin-top: 8px;
  text-transform: none;
}
.gl-article-header .gl-tagline {
  font-family: var(--f-read);
  font-size: clamp(18px, 1.6vw, 22px);
  color: var(--fg-soft);
  font-style: italic;
}

.gl-body {
  font-family: var(--f-read);
  font-size: 18px;
  line-height: 1.65;
  color: var(--fg-soft);
}
.gl-body p { margin-bottom: 1.2em; }
.gl-body p strong { color: var(--fg); font-weight: 600; }
.gl-body h2 {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: clamp(24px, 2.4vw, 32px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--fg);
  margin-top: 48px; margin-bottom: 16px;
  padding-top: 24px;
  border-top: 1px solid var(--hair);
}
.gl-body h2:first-child { margin-top: 0; padding-top: 0; border-top: 0; }
.gl-body h3 {
  font-family: var(--f-display);
  font-weight: 600;
  font-size: 20px;
  color: var(--fg);
  margin-top: 32px; margin-bottom: 12px;
}
.gl-body ul, .gl-body ol {
  padding-left: 1.5em;
  margin-bottom: 1.2em;
}
.gl-body li { margin-bottom: 0.4em; }
.gl-body a {
  color: var(--green);
  background-image: linear-gradient(to right, var(--green), var(--green));
  background-repeat: no-repeat;
  background-size: 100% 1px;
  background-position: 0 100%;
  transition: background-size 0.3s, color 0.3s;
}
.gl-body a:hover {
  color: var(--green);
  background-size: 100% 2px;
}
.gl-body blockquote {
  border-left: 2px solid var(--green);
  padding-left: 24px;
  margin: 32px 0;
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 22px;
  color: var(--fg);
}
.gl-body code {
  font-family: var(--f-mono);
  font-size: 0.9em;
  background: var(--bg-paper);
  padding: 2px 6px;
  border: 1px solid var(--hair);
  color: var(--green);
}
.gl-body strong { color: var(--fg); }

/* ============================================================
   Rail blocks
   ============================================================ */
.gl-rail-block { display: flex; flex-direction: column; gap: 12px; }
.gl-rail-head {
  font-family: var(--f-mono);
  font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--fg-mute);
  display: flex; align-items: center; gap: 8px;
}
.gl-rail-head::after {
  content: ""; flex: 1; height: 1px; background: var(--hair);
}
.gl-rail-related a {
  display: grid; grid-template-columns: auto 1fr;
  gap: 12px; padding: 12px 14px;
  border: 1px solid var(--hair);
  background: var(--bg);
  transition: border-color .2s, transform .2s;
}
.gl-rail-related a:hover { border-color: var(--green); transform: translateX(2px); }
.gl-rail-related .rn {
  font-family: var(--f-mono); font-size: 10px;
  color: var(--fg-mute); align-self: start;
}
.gl-rail-related .rt {
  font-weight: 600; color: var(--fg);
}
.gl-rail-related a:hover .rt { color: var(--green); }
.gl-rail-cta {
  display: block;
  padding: 16px;
  border: 2px solid var(--green);
  background: linear-gradient(135deg, var(--bg-mint), var(--bg-paper));
  text-align: left;
}
.gl-rail-cta .rcta-eyebrow {
  display: block;
  font-family: var(--f-mono); font-size: 10px;
  color: var(--green); letter-spacing: 0.1em;
  text-transform: uppercase; margin-bottom: 8px;
}
.gl-rail-cta .rcta-title {
  display: block;
  font-family: var(--f-display); font-weight: 600;
  font-size: 16px; line-height: 1.3;
  color: var(--fg); margin-bottom: 12px;
}
.gl-rail-cta:hover { background: var(--green); border-color: var(--green); }
.gl-rail-cta:hover .rcta-eyebrow,
.gl-rail-cta:hover .rcta-title { color: var(--bg); }

/* ============================================================
   Mobile breakpoints
   ============================================================ */
@media (max-width: 1024px) {
  .gl-hero { grid-template-columns: 1fr; gap: 32px; }
  .gl-hero .gh-aside {
    border-left: 0; border-top: 1px solid var(--hair); padding: 24px 0 0; max-width: 100%;
  }
  .gl-article { grid-template-columns: 1fr; gap: 40px; }
  .gl-article .gl-rail { position: static; }
}
@media (max-width: 760px) {
  .gl-ticker { grid-template-columns: 1fr; gap: 12px; padding: 12px 16px; }
  .gl-ticker .gt-stream { justify-content: flex-start; }
  .gl-hero h1 { font-size: clamp(40px, 12vw, 72px); }
  .gl-list-header { grid-template-columns: 64px 1fr; }
  .gl-list-header > :last-child { display: none; }
  .gl-term { grid-template-columns: 60px 1fr; gap: 16px; }
  .gl-term .gl-arr { display: none; }
}

/* ============================================================
   Wiki-style cross-links (inline within text)
   ============================================================ */
.article-page p a.wlink,
.article-page li a.wlink {
  color: var(--green);
  border-bottom: 1px solid color-mix(in oklab, var(--green) 45%, transparent);
  transition: border-color .15s, background .15s;
  padding: 0 2px;
}
.article-page p a.wlink:hover,
.article-page li a.wlink:hover {
  background: color-mix(in oklab, var(--green) 14%, transparent);
  border-bottom-color: var(--green);
}

/* ============================================================
   CTA block внутри статьи (после Related terms)
   ============================================================ */
.cta-block {
  margin-top: 48px;
  padding: 32px clamp(20px, 4vw, 40px);
  background: linear-gradient(135deg, #1a1a18 0%, #161614 100%);
  border-left: 4px solid var(--green);
  border-right: 4px solid var(--signal);
}
.cta-block h3 {
  font-family: var(--f-display);
  font-size: clamp(20px, 2.4vw, 26px);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fg);
  margin-bottom: 12px;
}
.cta-block p {
  color: var(--fg-soft);
  font-family: var(--f-body);
  font-size: 15px;
  line-height: 1.55;
}
.cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  font-family: var(--f-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-right: 10px;
  margin-bottom: 8px;
  border: 2px solid transparent;
  transition: transform .12s, box-shadow .12s, background .15s, color .15s;
}
.cta-btn--signal {
  background: var(--signal);
  color: #fff;
  border-color: var(--signal);
}
.cta-btn--signal:hover {
  background: var(--fg);
  color: var(--bg);
  border-color: var(--fg);
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 var(--signal);
}
.cta-btn--mint {
  background: transparent;
  color: var(--green);
  border-color: var(--green);
}
.cta-btn--mint:hover {
  background: var(--green);
  color: var(--bg);
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 var(--fg);
}

@media (max-width: 640px) {
  .cta-block { padding: 24px 18px; }
  .cta-btn { display: block; margin-right: 0; text-align: center; }
}
