/* ============================================================
   OverBot — «Ночная смена»
   Иллюминированный гримуар-ведомость × машинный журнал.
   Палитра: тёмные тёплые чернила · пергамент · рубрика (красные
   чернила писца) · сусальное золото. Шрифты: Cormorant Garamond
   (архаичный дисплей) × Inter (тело) × JetBrains Mono (журнал).
   ============================================================ */
:root {
  --ink:     #15110b;   /* фон — тёмные тёплые чернила */
  --ink-2:   #1e1810;   /* панели/листы */
  --ink-3:   #271f15;   /* приподнятые поверхности */
  --parch:   #ece2cd;   /* пергамент — основной текст */
  --muted:   #a3977c;   /* выцветшие чернила */
  --rubric:  #c1402b;   /* красные чернила писца — ключевые слова */
  --gold:    #c9a24a;   /* иллюминация — скупо */
  --line:    rgba(201,162,74,.22);  /* волосяная золотая линейка */
  --line-soft: rgba(236,226,205,.10);

  --display: "Cormorant Garamond", Georgia, serif;
  --body:    "Inter", system-ui, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, monospace;
  --maxw:    1180px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--ink);
  color: var(--parch);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  position: relative;
  overflow-x: hidden;
  /* лёгкая «зернистость пергамента» */
  background-image:
    radial-gradient(circle at 18% 12%, rgba(201,162,74,.05), transparent 38%),
    radial-gradient(circle at 85% 0%, rgba(193,64,43,.05), transparent 34%);
}
a { color: inherit; text-decoration: none; }
::selection { background: var(--rubric); color: var(--parch); }

.vignette {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  box-shadow: inset 0 0 240px 40px rgba(0,0,0,.6);
}
body > * { position: relative; z-index: 1; }

/* рубрикация — красные чернила на ключевых словах */
.rubric { color: var(--rubric); font-style: normal; }

/* эйрбоу-метка */
.eyebrow {
  font-family: var(--mono);
  font-size: .72rem; letter-spacing: .28em; text-transform: uppercase;
  color: var(--muted); margin-bottom: 1.4rem;
}
.eyebrow--center { text-align: center; }

/* ── Кнопки ── */
.btn-seal, .btn-plain {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--mono); font-size: .82rem; letter-spacing: .12em;
  text-transform: uppercase; padding: .85rem 1.5rem; cursor: pointer;
  transition: transform .18s ease, background .2s, color .2s, box-shadow .2s;
}
.btn-seal {
  color: var(--ink); background: var(--gold);
  border: 1px solid var(--gold);
  box-shadow: 0 0 0 1px rgba(0,0,0,.4), 0 10px 26px rgba(201,162,74,.18);
}
.btn-seal:hover { transform: translateY(-2px); background: #d8b25c; }
.btn-seal--lg { padding: 1.05rem 2.1rem; font-size: .9rem; }
.btn-plain {
  color: var(--parch); background: transparent;
  border: 1px solid var(--line);
}
.btn-plain:hover { border-color: var(--gold); color: var(--gold); transform: translateY(-2px); }

/* ── Шапка ── */
.masthead {
  max-width: var(--maxw); margin: 0 auto;
  display: flex; align-items: center; gap: 2rem;
  padding: 1.5rem 1.8rem; border-bottom: 1px solid var(--line-soft);
}
.sigil { display: flex; align-items: center; gap: .6rem; }
.sigil__rune { color: var(--gold); font-size: 1.5rem; }
.sigil__word { font-family: var(--display); font-size: 1.4rem; font-weight: 600; letter-spacing: .01em; }
.sigil__word em { color: var(--rubric); font-style: italic; }
.masthead__nav { display: flex; gap: 1.8rem; margin-left: auto; }
.masthead__nav a {
  font-family: var(--mono); font-size: .78rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--muted); transition: color .2s;
}
.masthead__nav a:hover, .masthead__nav a.is-active { color: var(--parch); }
.lang { display: inline-flex; border: 1px solid var(--line); }
.lang button {
  font-family: var(--mono); font-size: .72rem; letter-spacing: .06em; color: var(--muted);
  background: transparent; border: 0; border-right: 1px solid var(--line);
  padding: .32rem .55rem; cursor: pointer; transition: background .15s, color .15s;
}
.lang button:last-child { border-right: 0; }
.lang button:hover { color: var(--parch); }
.lang button.is-on { background: var(--gold); color: var(--ink); }
.link-quill {
  font-family: var(--mono); font-size: .78rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--gold);
  border-bottom: 1px solid var(--line); padding-bottom: 2px;
}
.link-quill:hover { color: #d8b25c; }

/* ── Hero ── */
.hero {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1.05fr .95fr; gap: 4rem; align-items: center;
  padding: 5rem 1.8rem 4rem;
}
.hero__head {
  font-family: var(--display); font-weight: 600;
  font-size: clamp(2.8rem, 6.2vw, 5rem); line-height: 1.02;
  letter-spacing: -.01em; margin-bottom: 1.6rem;
}
.hero__lede { color: var(--muted); font-size: 1.12rem; max-width: 33rem; margin-bottom: 2.2rem; }
.hero__cta { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.6rem; }
.hero__foot { font-family: var(--mono); font-size: .74rem; letter-spacing: .06em; color: var(--muted); }
.hero__login {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  margin-bottom: 1.6rem; margin-top: .5rem;
  padding: 1rem 1.25rem;
  border: 1px solid var(--line);
  border-left: 3px solid var(--gold);
  background: rgba(216, 178, 92, 0.05);
  border-radius: 4px;
  max-width: max-content;
}
.hero__login-lbl { font-family: var(--mono); font-size: .78rem; letter-spacing: .04em; color: var(--parch); }

/* Кнопка «Войти в панель» в шапке */
.btn-dash {
  font-family: var(--mono); font-size: .74rem; letter-spacing: .08em;
  text-transform: uppercase; color: var(--gold);
  border: 1px solid var(--gold); border-radius: 3px;
  padding: .35rem .7rem; text-decoration: none;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.btn-dash:hover { background: var(--gold); color: var(--ink); }

/* Сигнатура — ведомость */
.ledger {
  background:
    linear-gradient(180deg, var(--ink-2), var(--ink));
  border: 1px solid var(--line);
  box-shadow: 0 30px 70px rgba(0,0,0,.55), inset 0 1px 0 rgba(236,226,205,.04);
  padding: 1.4rem 1.5rem 1.5rem;
}
.ledger__top {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: .9rem; margin-bottom: .9rem; border-bottom: 1px solid var(--line);
}
.ledger__title { font-family: var(--mono); font-size: .76rem; letter-spacing: .22em; color: var(--gold); }
.ledger__live {
  font-family: var(--mono); font-size: .72rem; letter-spacing: .12em;
  color: var(--rubric); display: inline-flex; align-items: center; gap: .45rem; text-transform: uppercase;
}
.ledger__live i { width: 7px; height: 7px; border-radius: 50%; background: var(--rubric); box-shadow: 0 0 8px var(--rubric); animation: pulse 1.6s infinite; }
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.25;} }

.ledger__lines { list-style: none; display: flex; flex-direction: column; gap: .55rem; min-height: 9.5rem; }
.ledger__lines li {
  font-family: var(--mono); font-size: .82rem; line-height: 1.5; color: var(--parch);
  padding-left: 0; opacity: .92;
}
.ledger__lines b { color: var(--gold); font-weight: 500; margin-right: .5rem; }
.ledger__lines s { color: var(--rubric); text-decoration: none; }
.ledger__lines em { color: var(--gold); font-style: normal; }
.ledger__lines li.appear { animation: scribe .5s ease both; }
@keyframes scribe { from { opacity: 0; transform: translateY(4px); } to { opacity: .92; transform: none; } }

.ledger__tally {
  margin-top: 1.1rem; padding-top: 1rem; border-top: 1px solid var(--line);
  display: flex; align-items: baseline; gap: .8rem;
}
.ledger__tally-num { font-family: var(--display); font-weight: 700; font-size: 2.8rem; color: var(--gold); line-height: 1; }
.ledger__tally-lbl { font-family: var(--mono); font-size: .74rem; color: var(--muted); letter-spacing: .04em; }

/* ── Полоса-кредо ── */
.creed {
  max-width: var(--maxw); margin: 0 auto;
  border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft);
  padding: 1.4rem 1.8rem; text-align: center;
  font-family: var(--display); font-style: italic; font-size: 1.3rem; color: var(--parch);
}

/* ── Лист (секция) ── */
.leaf { max-width: var(--maxw); margin: 0 auto; padding: 5.5rem 1.8rem; }
.leaf--rite { border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); }
.leaf__head { margin-bottom: 3rem; max-width: 40rem; }
.mark {
  font-family: var(--mono); font-size: .72rem; letter-spacing: .28em; text-transform: uppercase;
  color: var(--rubric); display: block; margin-bottom: .9rem;
}
.leaf__head h2 { font-family: var(--display); font-weight: 600; font-size: clamp(2rem, 4vw, 3rem); line-height: 1.08; }
.leaf__note { color: var(--muted); margin-top: .8rem; }

/* ── Деяния ── */
.deeds { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line-soft); border: 1px solid var(--line-soft); }
.deed { background: var(--ink); padding: 1.9rem 1.7rem; transition: background .2s; }
.deed:hover { background: var(--ink-2); }
.deed h3 { font-family: var(--display); font-weight: 600; font-size: 1.45rem; margin-bottom: .5rem; }
.deed h3::before { content: "⚔ "; color: var(--gold); font-size: .8em; }
.deed p { color: var(--muted); font-size: .96rem; }

/* ── Обряд (ступени) ── */
.rite { list-style: none; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.2rem; counter-reset: none; }
.rite__step { padding-top: 1.2rem; border-top: 2px solid var(--rubric); }
.rite__num { font-family: var(--display); font-weight: 700; font-size: 2.4rem; color: var(--gold); display: block; line-height: 1; margin-bottom: .9rem; }
.rite__step h3 { font-family: var(--display); font-weight: 600; font-size: 1.5rem; margin-bottom: .5rem; }
.rite__step p { color: var(--muted); font-size: .98rem; }

/* ── Грамоты (тарифы) ── */
.grades { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; align-items: stretch; }
.grade {
  background: var(--ink-2); border: 1px solid var(--line-soft);
  padding: 2rem 1.7rem; display: flex; flex-direction: column; position: relative;
}
.grade--seal { border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold), 0 24px 60px rgba(201,162,74,.14); }
.grade__ribbon {
  position: absolute; top: -.85rem; left: 1.6rem;
  font-family: var(--mono); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase;
  background: var(--rubric); color: var(--parch); padding: .28rem .8rem;
}
.grade h3 { font-family: var(--display); font-weight: 600; font-size: 1.7rem; }
.grade__price { font-family: var(--mono); font-size: 1.4rem; color: var(--gold); margin: .4rem 0 1.1rem; line-height: 1.25; }
.grade__price .per { display: block; font-size: .72rem; color: var(--muted); letter-spacing: .04em; margin-top: .1rem; }
/* переключатель валют */
.cur-switch { display: inline-flex; gap: 0; margin-top: 1.3rem; border: 1px solid var(--line); }
.cur-switch button {
  font-family: var(--mono); font-size: .9rem; color: var(--muted); background: transparent;
  border: 0; border-right: 1px solid var(--line); padding: .45rem .8rem; cursor: pointer;
  transition: background .15s, color .15s; min-width: 2.4rem;
}
.cur-switch button:last-child { border-right: 0; }
.cur-switch button:hover { color: var(--parch); }
.cur-switch button.is-on { background: var(--gold); color: var(--ink); }

.grade__price .stars { font-size: 1.6rem; color: var(--gold); }
.grade__price .fiat { font-size: .85rem; color: var(--muted); margin-left: .45rem; white-space: nowrap; }
.grades__aside .stars { color: var(--gold); }
.grades__aside .fiat { color: var(--muted); }
.grade__incl { font-family: var(--body); font-size: .82rem; color: var(--muted); font-style: italic; margin: -.4rem 0 .9rem; }
.grade ul { list-style: none; flex: 1; margin-bottom: 1.6rem; }
.grade__minus { color: var(--rubric); opacity: .85; }
.grade__minus::before { content: "✦" !important; color: var(--rubric) !important; }
.grade li { color: var(--muted); padding: .4rem 0 .4rem 1.5rem; position: relative; font-size: .96rem; border-bottom: 1px dashed var(--line-soft); }
.grade li:last-child { border-bottom: 0; }
.grade li::before { content: "✦"; position: absolute; left: 0; color: var(--gold); }
.grades__aside { text-align: center; color: var(--muted); font-family: var(--mono); font-size: .78rem; margin-top: 1.6rem; }

/* ── Свитки (FAQ) ── */
.scrolls { max-width: 50rem; display: flex; flex-direction: column; }
.scrolls details { border-bottom: 1px solid var(--line-soft); padding: 1.2rem 0; }
.scrolls summary { cursor: pointer; list-style: none; font-family: var(--display); font-size: 1.35rem; display: flex; justify-content: space-between; gap: 1rem; }
.scrolls summary::after { content: "✦"; color: var(--gold); transition: transform .2s; }
.scrolls details[open] summary::after { transform: rotate(180deg); color: var(--rubric); }
.scrolls p { color: var(--muted); margin-top: .8rem; max-width: 44rem; }

/* ── Доступ: VPN-блок ── */
.vpn {
  max-width: var(--maxw); margin: 0 auto; padding: 2.6rem 1.8rem;
  display: grid; grid-template-columns: 1.6fr 1fr; gap: 2.5rem; align-items: center;
  border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft);
}
.vpn h2 { font-family: var(--display); font-weight: 600; font-size: clamp(1.6rem, 3vw, 2.3rem); margin-bottom: .6rem; }
.vpn__lede { color: var(--muted); max-width: 38rem; }
.vpn__list { list-style: none; margin-top: 1.1rem; display: grid; grid-template-columns: 1fr 1fr; gap: .3rem 1.4rem; }
.vpn__list li { color: var(--parch); font-size: .92rem; padding-left: 1.3rem; position: relative; }
.vpn__list li::before { content: "✦"; position: absolute; left: 0; color: var(--gold); }
.vpn__cta { text-align: center; border-left: 1px solid var(--line-soft); padding-left: 2.5rem; }
.vpn__price { font-family: var(--display); font-size: 1.2rem; color: var(--muted); margin-bottom: .9rem; }
.vpn__price b { font-size: 2rem; color: var(--gold); }
.vpn__fine { font-family: var(--mono); font-size: .7rem; color: var(--muted); margin-top: .8rem; opacity: .8; }

/* ── Призыв ── */
.enlist {
  max-width: 62rem; margin: 5rem auto; padding: 4rem 2rem; text-align: center;
  border: 1px solid var(--line);
  background: radial-gradient(70% 120% at 50% 0%, rgba(201,162,74,.10), transparent 70%), var(--ink-2);
}
.enlist h2 { font-family: var(--display); font-weight: 600; font-size: clamp(2rem, 4vw, 3.2rem); }
.enlist__lede { color: var(--muted); margin: .9rem auto 2rem; max-width: 34rem; }
.enlist__cta { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ── Колофон ── */
.colophon {
  max-width: var(--maxw); margin: 0 auto; padding: 2.6rem 1.8rem;
  border-top: 1px solid var(--line-soft); display: flex; align-items: center; gap: 1.6rem; flex-wrap: wrap;
}
.colophon__sigil { font-family: var(--display); font-size: 1.2rem; color: var(--parch); }
.colophon__nav { display: flex; gap: 1.4rem; margin-left: auto; }
.colophon__nav a { font-family: var(--mono); font-size: .76rem; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.colophon__nav a:hover { color: var(--gold); }
.colophon__fine { flex-basis: 100%; color: var(--muted); font-size: .8rem; opacity: .7; }

/* ── Адаптив ── */
@media (max-width: 920px) {
  .hero { grid-template-columns: 1fr; gap: 2.5rem; padding-top: 3.5rem; }
  .ledger { order: 2; }
  .deeds { grid-template-columns: 1fr 1fr; }
  .rite, .grades { grid-template-columns: 1fr; }
  .masthead__nav { display: none; }
  .lang { margin-left: auto; }
  .link-quill { display: none; }
  .vpn { grid-template-columns: 1fr; gap: 1.6rem; }
  .vpn__cta { border-left: 0; padding-left: 0; text-align: left; }
}
@media (max-width: 560px) {
  body { font-size: 16px; }
  .deeds { grid-template-columns: 1fr; }
  .vpn__list { grid-template-columns: 1fr; }
  .hero__cta { flex-direction: column; align-items: stretch; }
  .btn-seal, .btn-plain { justify-content: center; }
  .hero__login { max-width: 100%; }
}

/* ── Доступность ── */
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
}
