/* ============================================================
   SculkWard — лендинг (рескин в стиле mistral.ai)
   Тёплая «бумага» + фирменный block-flame градиент.
   app.css грузится первым и даёт палитру/шрифты/--flame-grad.
   Здесь — full-bleed раскладка, flame-мозаика героя, секции.
   ============================================================ */

:root {
  --s1: 4px; --s2: 8px; --s3: 16px; --s4: 24px; --s5: 40px; --s6: 64px;
  --maxw-prose: 64ch;
}

/* Лендинг — full-bleed: гасим узкий main из app.css только на этой странице.
   Первично — серверный класс body.is-landing (надёжно везде); :has() оставлен
   как прогрессивное усиление на случай отсутствия класса. */
body.is-landing main,
body:has(.lp) main { max-width: none; margin: 0; padding: 0; }

.lp { line-height: 1.6; }
.lp-wrap { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--s4); }
.lp-prose { max-width: var(--maxw-prose); }

/* ---- секции / ритм ---- */
.lp-sec { padding-block: clamp(56px, 9vw, 116px); position: relative; scroll-margin-top: 80px; }
.lp-hero { scroll-margin-top: 80px; }
.lp-sec--deep { background: var(--paper-2); border-block: 1px solid var(--line); }

/* надзаголовок-«вкладка» секции — нейтральная (тихая база, чтобы flame был редким) */
.lp-eyebrow {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin: 0 0 var(--s2);
}

/* ---- типографика лендинга ---- */
.lp-h1 {
  font-family: var(--display);
  font-size: clamp(34px, 5.6vw, 62px);
  line-height: 1.05;
  font-weight: 500;                 /* размер несёт авторитет, не жирность */
  letter-spacing: -0.018em;
  margin: var(--s3) 0 var(--s4);
  max-width: 16ch;
  text-wrap: balance;
}
/* Градиентная фраза в H1. Текстовый градиент НЕ начинается с жёлтого (тот сливается
   с кремом) — только читаемые orange→deep стопы (каждый ≥3:1 на бумаге для крупного
   текста). Литеральный фолбэк-цвет виден даже если background-clip:text не поддержан
   или app.css не загрузился; прозрачным текст становится лишь при поддержке клипа. */
.lp-grad {
  color: #c2390a;
  background: linear-gradient(100deg, #fa520f 0%, #ec440b 50%, #d4360a 100%);
  -webkit-background-clip: text;
  background-clip: text;
}
@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .lp-grad { color: transparent; -webkit-text-fill-color: transparent; }
}
.lp-h2 {
  font-family: var(--display);
  font-size: clamp(26px, 3.6vw, 40px);
  line-height: 1.1;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin: 0 0 var(--s4);
  text-wrap: balance;
}
.lp-card__h, .lp-step__h { font-family: var(--display); font-size: 19px; font-weight: 600; margin: 0 0 var(--s2); letter-spacing: -0.015em; }

.lp-kicker {
  display: inline-flex;
  align-items: center;
  gap: var(--s2);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-2);
  margin: 0;
}
.lp-spark { width: 9px; height: 9px; border-radius: 2px; background: var(--flame); box-shadow: 0 0 12px 1px color-mix(in srgb, var(--flame) 70%, transparent); animation: lp-blink 2.6s ease-in-out infinite; }
@keyframes lp-blink { 0%,100% { opacity: 1; } 50% { opacity: .35; } }

.lp-lede { font-size: clamp(16px, 1.55vw, 20px); color: var(--ink-2); margin: 0 0 var(--s4); max-width: 54ch; }
.lp-for  { color: var(--ink-3); font-size: 14px; margin: 0 0 var(--s5); max-width: 52ch; }

.lp-mono-sub { font-family: var(--mono); font-size: 14px; color: var(--ink-3); margin: calc(-1 * var(--s3)) 0 var(--s5); }
.lp-note { font-family: var(--mono); font-size: 13px; color: var(--ink-3); margin-top: var(--s5); line-height: 1.7; }

.lp code {
  font-family: var(--mono);
  font-size: 0.86em;
  background: var(--flame-tint);
  border: 1px solid color-mix(in srgb, var(--amber) 26%, var(--line));
  padding: 1px 6px;
  border-radius: 6px;
  color: #9a3a06;
}

.lp-prose p { font-size: clamp(16px, 1.4vw, 19px); color: var(--ink-2); }

/* ---- кнопки ---- */
.lp-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s2);
  font-family: var(--sans); font-weight: 600; font-size: 16px; text-decoration: none;
  padding: 13px 24px; border-radius: var(--r-pill); border: 1px solid transparent;
  cursor: pointer; transition: transform .12s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.lp-btn--primary { background: var(--flame-btn); color: #fff; box-shadow: var(--sh-sm); }
.lp-btn--primary:hover { background: var(--flame-btn-d); box-shadow: var(--glow); transform: translateY(-2px); }
.lp-btn--ghost { background: var(--surface); color: var(--ink); border-color: var(--line-2); box-shadow: var(--sh-sm); }
.lp-btn--ghost:hover { border-color: var(--ink); transform: translateY(-2px); box-shadow: var(--sh); }
.lp-btn--lg { padding: 16px 32px; font-size: 17px; }
.lp-cta-row { display: flex; gap: var(--s3); flex-wrap: wrap; }

/* =====================================================================
   HERO
   ===================================================================== */
.lp-hero { position: relative; overflow: clip; }
/* тёплая block-grid подложка, затухающая к низу */
.lp-hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 34px 34px;
  opacity: .3;
  -webkit-mask-image: radial-gradient(120% 90% at 70% 8%, #000 12%, transparent 72%);
          mask-image: radial-gradient(120% 90% at 70% 8%, #000 12%, transparent 72%);
  pointer-events: none;
}
.lp-hero__grid {
  position: relative; z-index: 1;
  max-width: var(--maxw); margin-inline: auto; padding-inline: var(--s4);
  padding-block: clamp(48px, 8vw, 104px);
  display: grid; grid-template-columns: 1.12fr .88fr;
  gap: clamp(28px, 5vw, 64px); align-items: center;
}
.lp-hero__text { animation: lp-fade-up .7s cubic-bezier(.2,.7,.2,1) both; }
@keyframes lp-fade-up { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }

/* trust-строка под CTA */
.lp-trust { list-style: none; display: flex; flex-wrap: wrap; gap: var(--s2) var(--s4); margin: var(--s5) 0 0; padding: 0; }
.lp-trust li { font-family: var(--mono); font-size: 12.5px; color: var(--ink-3); position: relative; padding-left: 16px; }
.lp-trust li::before { content: ""; position: absolute; left: 0; top: 6px; width: 6px; height: 6px; border-radius: 2px; background: var(--flame); }
.lp-trust b { color: var(--ink); font-weight: 600; }

/* ---- flame-мозаика: ДИСКРЕТНЫЕ плоские плитки (фирменный block-gradient) ----
   Не один градиент под сеткой, а сетка отдельных одноцветных блоков, ступенями
   жёлтый→глубокий по диагонали, с негативным пространством по светлому углу —
   мозаика как будто «собирается» из блоков. Без глянцевых бликов: матово. */
.lp-hero__art { position: relative; display: grid; place-items: center; min-height: 320px; }
.lp-mosaic {
  position: relative;
  width: min(384px, 86%); aspect-ratio: 1 / 1;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 1fr;
  gap: clamp(5px, 1.3vw, 9px);
  filter: drop-shadow(0 22px 44px rgba(120, 62, 20, .22));
}
@supports not (aspect-ratio: 1 / 1) { .lp-mosaic { height: min(384px, 86vw); } }
.lp-mosaic i {
  border-radius: 5px;
  background: var(--flame);
  transform: scale(.45);
  opacity: 0;
  animation: lp-tile .5s cubic-bezier(.2, .8, .2, 1) both;
}
/* ступенчатый flame-рамп — плоские цвета (не градиент) */
.lp-mosaic .c0 { background: #ffd900; }
.lp-mosaic .c1 { background: #ffc400; }
.lp-mosaic .c2 { background: #ffa110; }
.lp-mosaic .c3 { background: #ff8105; }
.lp-mosaic .c4 { background: #fb6424; }
.lp-mosaic .c5 { background: #fa520f; }
.lp-mosaic .c6 { background: #e8430c; }
.lp-mosaic .c7 { background: #cf330a; }
.lp-mosaic .cx { background: transparent; animation: none; opacity: 1; transform: none; } /* негатив */
/* построчная «сборка» (диагональная волна сверху) */
.lp-mosaic i:nth-child(n+7)  { animation-delay: .05s; }
.lp-mosaic i:nth-child(n+13) { animation-delay: .10s; }
.lp-mosaic i:nth-child(n+19) { animation-delay: .15s; }
.lp-mosaic i:nth-child(n+25) { animation-delay: .20s; }
.lp-mosaic i:nth-child(n+31) { animation-delay: .25s; }
@keyframes lp-tile { to { transform: none; opacity: 1; } }

/* плоские блоки, «отколовшиеся» от мозаики в бумагу */
.lp-blk { position: absolute; border-radius: 7px; box-shadow: var(--sh); }
.lp-blk--1 { width: 54px; height: 54px; background: #ffd900; top: -22px; left: 2%;   animation: lp-float 7s ease-in-out infinite; }
.lp-blk--2 { width: 38px; height: 38px; background: #fa520f; bottom: 4%; left: -18px; animation: lp-float 8.5s ease-in-out infinite reverse; }
.lp-blk--3 { width: 28px; height: 28px; background: #ffa110; bottom: -16px; right: 14%; animation: lp-float 6s ease-in-out infinite .4s; }
.lp-blk--4 { width: 20px; height: 20px; background: #cf330a; top: 12%; right: -14px;  animation: lp-float 9s ease-in-out infinite 1s; }
@keyframes lp-float { 0%, 100% { transform: translateY(0) rotate(0); } 50% { transform: translateY(-12px) rotate(4deg); } }

/* фирменная flame-линейка-разделитель */
.lp-flamerule { height: 4px; background: var(--flame-grad); max-width: var(--maxw); margin: 0 auto; border-radius: 99px; opacity: .9; }

/* =====================================================================
   КАРТОЧКИ / СЕТКИ
   ===================================================================== */
.lp-grid { display: grid; gap: var(--s4); }
.lp-grid--feat  { grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); }
.lp-grid--api   { grid-template-columns: repeat(auto-fit, minmax(330px, 1fr)); align-items: start; }
.lp-grid--modes { grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); }
.lp-grid--tiers { grid-template-columns: repeat(auto-fit, minmax(204px, 1fr)); }

.lp-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: var(--s4);
  box-shadow: var(--sh-sm);
  transition: border-color .2s ease, transform .15s ease, box-shadow .25s ease;
}
.lp-card:hover { border-color: var(--line-2); transform: translateY(-3px); box-shadow: var(--sh); }
.lp-card__p { margin: 0; color: var(--ink-2); font-size: 15px; }

.lp-tag {
  display: inline-block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-2);                 /* тихая нейтральная метка — flame экономим */
  background: var(--paper-2);
  border: 1px solid var(--line-2);
  padding: 3px 9px;
  border-radius: var(--r-pill);
  margin: 0 0 var(--s3);
}
/* real-time — премиальный, поэтому горячий (тёплый акцент вместо холодного зелёного) */
.lp-tag--rt { color: var(--flame-ink); background: var(--flame-tint); border-color: color-mix(in srgb, var(--amber) 32%, var(--line)); }

/* =====================================================================
   КОНВЕЙЕР «как работает»
   ===================================================================== */
.lp-pipe {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--s4);
  position: relative;
}
.lp-step {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: var(--s4);
  box-shadow: var(--sh-sm);
  transition: border-color .2s ease, transform .15s ease, box-shadow .25s ease;
}
.lp-step:hover { transform: translateY(-3px); box-shadow: var(--sh); border-color: var(--line-2); }
.lp-step:not(:last-child)::after { content: ""; position: absolute; display: none; }
@media (min-width: 1001px) {
  .lp-pipe { grid-template-columns: repeat(4, 1fr); }   /* 4 шага в один ряд — соединители валидны */
  .lp-step:not(:last-child)::after {
    display: block;
    top: calc(var(--s4) + 15px); right: calc(-1 * var(--s4));
    width: var(--s4); height: 2px;
    background: linear-gradient(90deg, var(--flame), transparent);
  }
}
.lp-step__n {
  display: inline-grid; place-items: center;
  width: 30px; height: 30px; border-radius: 9px;
  background: var(--flame-tint);
  border: 1px solid color-mix(in srgb, var(--amber) 30%, var(--line));
  font-family: var(--mono); font-size: 14px; font-weight: 500; color: var(--flame-ink);
  margin-bottom: var(--s3);
}
.lp-step__p { margin: 0; color: var(--ink-2); font-size: 14px; }

/* =====================================================================
   CODE-БЛОКИ (тёплый dark на кремовой странице)
   ===================================================================== */
.lp-code {
  margin: 0; overflow: hidden;
  background: var(--night);
  border: 1px solid var(--night-2);
  border-radius: var(--r);
  box-shadow: var(--sh);
}
.lp-code__bar {
  display: flex; align-items: center; gap: 7px;
  padding: 11px var(--s3);
  background: var(--night-2);
  border-bottom: 1px solid #000;
}
.lp-dot { width: 11px; height: 11px; border-radius: 50%; background: #3a2f25; }
.lp-dot:nth-child(1) { background: var(--flame); }
.lp-dot:nth-child(2) { background: var(--amber); }
.lp-dot:nth-child(3) { background: var(--gold); }
.lp-code__title { margin-left: auto; font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--on-night-dim); }
.lp-code__body {
  margin: 0; padding: var(--s4); overflow-x: auto;
  font-family: var(--mono); font-size: 13px; line-height: 1.65; color: var(--on-night-dim); tab-size: 2;
}
.lp-code__body code { background: none; border: 0; padding: 0; font-size: inherit; color: inherit; }

.t-kw   { color: var(--amber); font-weight: 600; }
.t-key  { color: var(--on-night); }
.t-str  { color: #ffcf8f; }
.t-num  { color: var(--flame-hi); }
.t-bool { color: var(--on-night-dim); }
.t-flag { color: var(--flame); font-weight: 600; }
.t-ad   { color: var(--gold); font-weight: 600; }

/* =====================================================================
   POST vs REAL-TIME
   ===================================================================== */
.lp-mode--rt { border-color: color-mix(in srgb, var(--flame) 45%, var(--line)); }

/* =====================================================================
   ТАРИФЫ
   ===================================================================== */
.lp-tier {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: var(--s4) var(--s4) var(--s5);
  display: flex; flex-direction: column;
  box-shadow: var(--sh-sm);
  transition: transform .15s ease, box-shadow .25s ease;
}
.lp-tier:hover { transform: translateY(-3px); box-shadow: var(--sh); }
.lp-tier--featured {
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    var(--flame-grad) border-box;
  border: 2px solid transparent;
  box-shadow: var(--glow), var(--sh);
}
.lp-tier__badge {
  position: absolute; top: -12px; left: var(--s4);
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: #fff; background: var(--flame);
  padding: 4px 10px; border-radius: var(--r-pill); margin: 0;
  box-shadow: var(--sh-sm);
}
.lp-tier__name { font-family: var(--display); font-size: 19px; font-weight: 700; margin: 0 0 var(--s2); }
.lp-tier__price { font-family: var(--display); font-size: 34px; font-weight: 700; margin: 0 0 var(--s3); letter-spacing: -0.03em; color: var(--ink); }
.lp-tier__per { font-family: var(--sans); font-size: 14px; color: var(--ink-3); font-weight: 500; }
.lp-tier__free { font-size: 22px; color: var(--ink-2); }
.lp-tier__list { list-style: none; margin: 0 0 var(--s4); padding: 0; flex: 1; }
.lp-tier__list li { font-size: 14px; color: var(--ink-2); padding: 7px 0 7px 22px; position: relative; }
.lp-tier__list li::before {
  content: ""; position: absolute; left: 0; top: 13px;
  width: 6px; height: 6px; border-radius: 2px; background: var(--line-2);
}
.lp-tier__list li.lp-tier__star::before { background: var(--flame); box-shadow: 0 0 8px color-mix(in srgb, var(--flame) 60%, transparent); }
.lp-tier__cta { width: 100%; }

/* =====================================================================
   ФИНАЛЬНЫЙ CTA
   ===================================================================== */
.lp-final__box { max-width: 760px; margin-inline: auto; }
.lp-final__card {
  text-align: center;
  background: var(--night);
  color: var(--on-night);
  border-radius: var(--r-lg);
  padding: clamp(36px, 6vw, 64px);
  position: relative; overflow: hidden;
  box-shadow: var(--sh-lg);
}
.lp-final__card::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(80% 120% at 50% -10%, rgba(250,82,15,.42), transparent 60%);
  pointer-events: none;
}
.lp-final__card > * { position: relative; }
.lp-final__card .lp-h2 { color: var(--on-night); }
.lp-final__card .lp-lede { color: var(--on-night-dim); margin-inline: auto; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.lp-footer { background: var(--night); color: var(--on-night-dim); padding-block: var(--s6) var(--s4); }
.lp-footer__cols { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: var(--s5); }
.lp-foot-logo { display: flex; align-items: center; gap: 9px; font-family: var(--display); font-weight: 700; font-size: 18px; color: var(--on-night); letter-spacing: -0.02em; margin: 0 0 var(--s2); }
.lp-footer__desc { color: var(--on-night-dim); font-size: 13px; margin: 0; max-width: 32ch; }
.lp-footer__h { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-night-dim); margin: 0 0 var(--s3); }
.lp-footer__nav { display: flex; flex-direction: column; gap: var(--s2); }
.lp-footer__nav a { color: var(--on-night); font-size: 14px; width: max-content; text-decoration: none; opacity: .82; transition: opacity .15s ease, color .15s ease; }
.lp-footer__nav a:hover { opacity: 1; color: var(--flame-hi); }
.lp-footer__bottom {
  display: flex; justify-content: space-between; align-items: center; gap: var(--s3); flex-wrap: wrap;
  margin-top: var(--s5); padding-top: var(--s4); border-top: 1px solid var(--night-2);
  color: var(--on-night-dim); font-size: 13px;
}
.lp-build { font-family: var(--mono); color: var(--flame-hi); }

/* =====================================================================
   АДАПТИВ
   ===================================================================== */
@media (max-width: 860px) {
  .lp-hero__grid { grid-template-columns: 1fr; }
  .lp-hero__art { min-height: 0; margin-top: var(--s4); }
  .lp-mosaic { width: min(320px, 76%); }
}
@media (max-width: 720px) {
  .lp-footer__cols { grid-template-columns: 1fr; gap: var(--s4); }
  .lp-pipe { grid-template-columns: 1fr; }
  .lp-step:not(:last-child)::after {
    display: block;
    top: auto; right: auto; bottom: calc(-1 * var(--s4)); left: calc(var(--s4) + 15px);
    width: 2px; height: var(--s4); background: linear-gradient(180deg, var(--flame), transparent);
  }
}

/* =====================================================================
   ДОСТУПНОСТЬ: меньше движения
   ===================================================================== */
@media (prefers-reduced-motion: reduce) {
  .lp * { animation: none !important; }
  /* плитки мозаики по умолчанию opacity:0 — без анимации их нужно явно показать */
  .lp-hero__text, .lp-mosaic, .lp-mosaic i { opacity: 1 !important; transform: none !important; }
}
