/* ============================================================
   Woven — лендинг Маркетплейс Ассист (вертикальный срез)
   Дизайн-система: тёмная (основная) + светлая. Один сигнатурный
   эффект (woven-₽ в hero), остальное — сдержанные появления.
   ============================================================ */

/* === Шрифты (self-hosted, CSP-safe) === */
@font-face { font-family:'Inter'; src:url('../vendor/fonts/inter-cyrillic.woff') format('woff'),url('../vendor/fonts/inter-latin-ext.woff') format('woff'); font-weight:400 800; font-style:normal; font-display:swap; }
@font-face { font-family:'Manrope'; src:url('../vendor/fonts/manrope-cyrillic.woff') format('woff'),url('../vendor/fonts/manrope-latin-ext.woff') format('woff'); font-weight:400 800; font-style:normal; font-display:swap; }

/* === Токены === */
:root {
  --brand:#5b6ef5; --brand-2:#8b5cf6; --green:#34d96b; --gold:#ffd36b; --loss:#ff6b78;  /* --brand = канон-синий знака (#5b6ef5), един с «Ассист» в вордмарке */
  --font-display:'Manrope', system-ui, sans-serif;
  --font-body:'Inter', system-ui, sans-serif;
  --font-mono:ui-monospace,'SF Mono','JetBrains Mono',Menlo,Consolas,monospace;
  --maxw:1340px;
  --r:16px;
}
/* === Тиры контейнера: два шага вверх (L и XL) ===
   L (1480+, 15" FHD ноутбуки): --maxw 1440 — оставляет ~48px рельс при 1536.
   XL (1860+, 22–24" мониторы): --maxw 1600 — оставляет ~160px рельс при 1920.
   Базовый 1340 сохранён — оптимален для M (≤1479, включая 1366 нетбук). */
@media (min-width:1480px) { :root { --maxw:1440px; } }
@media (min-width:1860px) { :root { --maxw:1600px; } }

html[data-theme="dark"] {
  --bg:#06070e; --bg-2:#0b0d1c; --surface:rgba(18,21,40,.55); --surface-2:rgba(24,28,52,.5); --nav-bg:rgba(8,10,20,.86);
  --ink:#eef1fb; --ink-2:#9aa3c4; --ink-3:#626a8c; --line:rgba(255,255,255,.09); --line-2:rgba(255,255,255,.05);
  --grid:rgba(127,140,255,.05); --shadow:0 24px 70px rgba(0,0,0,.45);
  --scrim-rgb:6,7,14;
}
html[data-theme="light"] {
  --bg:#f5f6fb; --bg-2:#ffffff; --surface:rgba(255,255,255,.72); --surface-2:rgba(255,255,255,.85); --nav-bg:rgba(248,249,252,.9);
  --ink:#10142e; --ink-2:#565d80; --ink-3:#8b92b3; --line:rgba(20,24,60,.11); --line-2:rgba(20,24,60,.06);
  --grid:rgba(20,24,60,.045); --shadow:0 24px 60px rgba(60,70,120,.14);
  --scrim-rgb:245,246,251;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
/* width-lock: overflow-x:hidden на ОБОИХ (html+body) — иначе кольцо/чипы при повороте
   расширяют документ и мобильный браузер авто-отдаляет («зум»), теряя центр. */
/* scrollbar-gutter:stable both-edges — резервирует полосу симметрично с обеих сторон;
   контейнер остаётся визуально центрированным на широких тирах; width-lock (overflow-x)
   сохранён; мобильное кольцо/чипы не расширяют документ */
html { -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; scroll-behavior:smooth; -webkit-tap-highlight-color:transparent; overflow-x:hidden; width:100%; max-width:100%; scrollbar-gutter:stable both-edges; }
body { font-family:var(--font-body); color:var(--ink); background:var(--bg); line-height:1.5; overflow-x:hidden; width:100%; max-width:100%; transition:background .5s ease, color .5s ease; }
a { color:inherit; text-decoration:none; }
::selection { background:rgba(107,123,255,.3); }

/* Глобальный мягкий фон-сетка */
body::before {
  content:''; position:fixed; inset:0; z-index:-2; background:
    radial-gradient(110% 80% at 70% 8%, var(--bg-2) 0%, var(--bg) 60%), var(--bg);
  transition:background .5s ease;
}
body::after {
  content:''; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(ellipse 90% 60% at 60% 20%, black 0%, transparent 80%);
  mask-image:radial-gradient(ellipse 90% 60% at 60% 20%, black 0%, transparent 80%);
}

/* === Общие примитивы === */
.eyebrow { display:inline-flex; align-items:center; gap:10px; font-family:var(--font-body); font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:.15em; color:var(--brand); margin-bottom:18px; }
.eyebrow-bar { width:22px; height:2px; background:linear-gradient(90deg,var(--brand),var(--brand-2)); border-radius:2px; }
/* Специфичность повышена до html body .btn — перебивает портальный .btn{padding:6px 14px}
   из встроенного #rs-real-css (base.css портала, грузится как часть reveal-блока, применяется глобально) */
html body .btn { display:inline-flex; align-items:center; gap:9px; font-family:var(--font-body); font-size:15px; font-weight:600; padding:13px 22px; border-radius:12px; cursor:pointer; border:1px solid transparent; transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .25s, border-color .25s; }
html body .btn svg { transition:transform .25s; }
.btn-primary { background:linear-gradient(135deg,#5b6ef5,#8b5cf6); color:#fff; box-shadow:0 10px 30px rgba(91,110,245,.4); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 16px 40px rgba(91,110,245,.55); }
.btn-primary:hover svg { transform:translateX(4px); }
.btn-ghost { background:var(--surface); color:var(--ink); border-color:var(--line); backdrop-filter:blur(8px); }
.btn-ghost:hover { border-color:var(--brand); transform:translateY(-2px); }

/* === NAV === */
/* Шапка ВСЕГДА матовая (frosted glass): listener .scrolled завязан на window-скролл, а реальный
   скролл-контейнер тут = body (утечка rs-real-css аналитики) → .scrolled не добавлялся, шапка была
   прозрачной и контент просвечивал при скролле (Александр 2026-06-13). Делаем фон постоянным —
   надёжно, без зависимости от детекции скролла. --nav-bg ≈ цвету фона → у верха незаметно, при
   наезде контента — читается чётко. */
.nav { position:fixed; top:0; left:0; right:0; z-index:50; background:var(--nav-bg); backdrop-filter:blur(20px) saturate(1.7); -webkit-backdrop-filter:blur(20px) saturate(1.7); border-bottom:1px solid var(--line); box-shadow:0 6px 30px -14px rgba(0,0,0,.4); transition:background .3s, border-color .3s, box-shadow .3s; }
.nav.scrolled { box-shadow:0 8px 30px -8px rgba(0,0,0,.5); }
.nav-inner { max-width:var(--maxw); margin:0 auto; padding:16px 28px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand { display:inline-flex; align-items:center; gap:11px; }
.brand-mark { display:inline-flex; filter:drop-shadow(0 4px 14px rgba(91,110,245,.4)); }
.brand-name { font-size:15px; font-weight:600; letter-spacing:-.01em; color:var(--ink); }
.brand-name b { font-weight:800; color:var(--brand); }   /* канон: «Ассист» 800 фирменным синим (= знак) */
.nav-links { display:flex; gap:6px; }
.nav-links a { font-size:14px; color:var(--ink-2); padding:8px 13px; border-radius:9px; transition:color .2s, background .2s; }
.nav-links a:hover { color:var(--ink); background:var(--line-2); }
.nav-links a.soon { opacity:.5; }
.nav-right { display:flex; align-items:center; gap:14px; }
.theme-toggle { display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border-radius:10px; border:1px solid var(--line); background:var(--surface); color:var(--ink-2); cursor:pointer; transition:color .2s, border-color .2s, transform .2s; }
.theme-toggle:hover { color:var(--ink); border-color:var(--brand); }
.theme-toggle .ic-sun { display:none; }
html[data-theme="light"] .theme-toggle .ic-sun { display:block; }
html[data-theme="light"] .theme-toggle .ic-moon { display:none; }
.status-pill { display:inline-flex; align-items:center; gap:8px; font-size:12.5px; font-weight:500; color:var(--ink-2); padding:8px 14px; border:1px solid var(--line); border-radius:100px; background:var(--surface); }
.status-dot { width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 10px var(--green); animation:pulse 1.8s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:.45; transform:scale(.85)} 50%{opacity:1; transform:scale(1.15)} }

/* === HERO (v8: мобиль — центрированный с полосой ₽; десктоп — 2-колонки как v3) === */
/* min(100vh,920px) — HD-ноутбук 1366×768: при 768px viewport min-height=768, meta-row вписывается.
   На большом экране ≥920px viewport hero растягивается до 920px (не ниже — не обрезает контент). */
.hero { position:relative; min-height:min(100vh,920px); display:flex; align-items:flex-start; overflow:hidden; padding:64px 0 36px; }

/* Канвас ₽ — прямой дочерний элемент .hero.
   Мобиль: абсолютный, z-index:0. JS задаёт размер буфера = размеру полосы .hero-ruble-band.
   Канвас позиционирован по центру — ₽ виден в средней части hero.
   width:auto; height:auto — не растягиваем пиксели (иначе смаз). */
#hero-canvas {
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  z-index:3; /* мобиль: канвас НАД hero-inner(z:2) — чтобы палец зажимал и вращал ₽ (на десктопе вернём 0 ниже) */
  display:block;
}

/* Полоса — пустой вертикальный спейсер на мобиле: задаёт высоту «дыры» под ₽. */
/* Высота полосы ₽ увеличена для просторного рендера (мобиль: z=8.5, scale=0.92 → чётче) */
.hero-ruble-band { position:relative; width:100%; max-width:580px; height:clamp(220px,36vh,380px); margin:12px auto 16px; pointer-events:none; }

/* --- Десктоп: 2-колоночный hero (текст слева, ₽ справа на весь экран) --- */
@media (min-width:900px) {
  /* hero выравниваем по центру вертикально — как в v3 */
  .hero { align-items:center; padding:0; }
  /* Обёртка первого экрана нужна ТОЛЬКО на мобиле (flex 100svh). На десктопе делаем её
     «прозрачной» (display:contents) → её дети (eyebrow/H1/полоса/абзац) снова становятся
     прямыми элементами grid-сетки .hero-inner, как было до обёртки. Десктоп-раскладка не меняется. */
  .hero-firstscreen { display:contents; }
  /* На десктопе канвас занимает весь viewport: JS рендерит на полный размер */
  #hero-canvas { top:0; left:0; transform:none; width:100%; height:100%; z-index:0; }
  /* Полоса ₽ скрыта на десктопе: канвас уже абсолютный на весь viewport */
  .hero-ruble-band { display:none; }
  /* hero-inner: 2-колонная сетка, текст в первой колонке */
  .hero-inner {
    /* 2-колонная сетка: 55% текст | 45% прозрачная зона для ₽ */
    display:grid;
    grid-template-columns:55% 45%;
    grid-template-rows:auto;
    /* safe center: при высоком контенте откатывается на верх — eyebrow не уезжает под фикс-навбар */
    align-items:safe center;
    min-height:min(100vh,920px);
    margin:0 auto;
    padding:0 28px;
  }
  /* Все дочерние элементы текстовой колонки — в первую колонку.
     .hero-firstscreen на десктопе = display:contents, поэтому его дети (eyebrow/H1/абзац)
     становятся прямыми grid-элементами .hero-inner — их тоже кладём в колонку 1
     (иначе авто-раскладка grid разносит H1 во вторую колонку — регресс 06-12). */
  .hero-inner > *, .hero-firstscreen > * { grid-column:1; }
  /* eyebrow: отступ */
  .hero-inner .eyebrow { display:inline-flex; margin-bottom:14px; }
  /* Тонированная подложка: плотно слева, к ₽ справа в прозрачность — как в v3 */
  .hero-inner::before {
    content:''; position:absolute; z-index:-1; pointer-events:none;
    top:0; bottom:0; left:0; width:min(820px, 60%);
    background:linear-gradient(100deg,
      rgba(var(--scrim-rgb),.92) 0%,
      rgba(var(--scrim-rgb),.76) 42%,
      rgba(var(--scrim-rgb),.28) 66%,
      rgba(var(--scrim-rgb),0) 82%);
  }
}

/* === ИИ нового поколения (отдельный блок) === */
.ai-card { max-width:900px; margin:0 auto; text-align:center; padding:clamp(34px,5vw,56px) clamp(24px,4vw,44px); border-radius:24px; border:1px solid var(--line); background:linear-gradient(160deg, rgba(107,123,255,.12), rgba(139,92,246,.05)); position:relative; overflow:hidden; }
.ai-badge { display:inline-flex; align-items:center; gap:7px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:var(--brand); padding:7px 14px; border:1px solid var(--line); border-radius:100px; background:var(--surface); margin-bottom:22px; }
.ai-card h2 { font-family:var(--font-display); font-weight:800; font-size:clamp(28px,3.6vw,44px); line-height:1.06; letter-spacing:-.03em; margin-bottom:16px; }
.ai-lead { font-size:16.5px; line-height:1.62; color:var(--ink-2); max-width:660px; margin:0 auto 26px; }
.ai-lead b { color:var(--ink); }
.ai-tags { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; }
.ai-tags span { font-size:13px; color:var(--ink); padding:9px 15px; border-radius:100px; border:1px solid var(--line); background:var(--surface-2); }

/* === Use-cases: горизонтальный скролл (контент-сценарии) === */
.usecases { position:relative; max-width:980px; margin:40px auto 0; }
.uc-track { display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 2px 16px; -webkit-overflow-scrolling:touch; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }
.uc-track::-webkit-scrollbar { height:7px; }
.uc-track::-webkit-scrollbar-track { background:transparent; }
.uc-track::-webkit-scrollbar-thumb { background:var(--line); border-radius:7px; }
.uc-card { scroll-snap-align:start; flex:0 0 clamp(244px,25vw,290px); background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:22px 21px; backdrop-filter:blur(8px); transition:transform .35s cubic-bezier(.2,.8,.2,1), border-color .3s; }
.uc-card:hover { transform:translateY(-4px); border-color:var(--brand); }
.uc-ico { font-size:25px; margin-bottom:13px; line-height:1; }
.uc-card h4 { font-family:var(--font-display); font-weight:700; font-size:16.5px; letter-spacing:-.01em; margin-bottom:8px; color:var(--ink); }
.uc-card p { font-size:13.5px; line-height:1.55; color:var(--ink-2); }
.uc-hint { font-size:11.5px; color:var(--ink-3); text-align:right; margin-top:2px; letter-spacing:.06em; text-transform:uppercase; }

/* === Бета (3D-логотип) === */
/* display:flex + flex-direction:column — нужен для order:-1 на .beta-model-col (мобиль: модель выше текста).
   На десктопе (≥1100px) переключается на display:grid через @media ниже. */
.beta-inner { max-width:780px; margin:0 auto; text-align:center; display:flex; flex-direction:column; }
/* margin-bottom:16px — заголовок h2 теперь предшествует счётчику (не 3D-модели), нужен небольшой воздух */
.beta-inner h2 { font-family:var(--font-display); font-weight:800; font-size:clamp(30px,3.8vw,46px); line-height:1.05; letter-spacing:-.03em; margin-bottom:16px; }
.beta-counter { display:inline-flex; align-items:center; gap:26px; margin-top:8px; }
.bc-item { display:flex; flex-direction:column; align-items:center; }
.bc-num { font-family:var(--font-display); font-weight:800; font-size:46px; line-height:1; letter-spacing:-.02em; color:var(--ink); }
.bc-num.accent { background:linear-gradient(135deg,#5b6ef5,#8b5cf6); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.bc-lbl { font-size:12.5px; color:var(--ink-3); margin-top:7px; }
.bc-dot { font-size:30px; color:var(--ink-3); line-height:1; }
.beta-bar { width:min(300px,72%); height:6px; border-radius:6px; background:var(--line); margin:20px auto 0; overflow:hidden; }
.beta-bar span { display:block; height:100%; background:linear-gradient(90deg,#5b6ef5,#8b5cf6); border-radius:6px; }
.beta-prompt { font-size:16px; line-height:1.62; color:var(--ink-2); max-width:580px; margin:24px auto 16px; }
/* Приглашение WB/Яндекс — акцентный абзац под beta-prompt */
.beta-wb-invite { font-size:14.5px; line-height:1.62; color:var(--ink-2); max-width:580px; margin:0 auto 26px; padding:14px 18px; border-left:2px solid var(--brand); border-radius:0 10px 10px 0; background:rgba(107,123,255,.07); }
.beta-wb-invite b { color:var(--ink); font-weight:600; }
.beta-logo-cap { font-size:13.5px; color:var(--ink-3); margin:-4px auto 2px; max-width:440px; letter-spacing:.01em; }
.hero-inner { position:relative; z-index:2; max-width:920px; width:100%; margin:0 auto; padding:0 28px; text-align:center; }
.hero-title { font-family:var(--font-display); font-weight:800; font-size:clamp(38px,4.6vw,64px); line-height:1.04; letter-spacing:-.035em; margin:0 auto; max-width:840px; }
.hero-title .accent { background:linear-gradient(115deg,#5b6ef5 0%,#8b5cf6 46%,#34d96b 115%); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
/* v12-A: подстрока обратного ценообразования над сгибом */
.hero-reverse-price { font-size:clamp(15px,1.5vw,18px); line-height:1.55; color:var(--ink-2); max-width:600px; margin:14px auto 18px; }
.hero-reverse-price b { color:var(--ink); }
.hero-lead { font-family:var(--font-display); font-weight:600; font-size:clamp(18px,2vw,23px); color:var(--ink); max-width:620px; margin:0 auto 12px; letter-spacing:-.01em; }
.hero-sub { font-size:16.5px; line-height:1.6; color:var(--ink-2); max-width:560px; margin:0 auto 28px; }
/* gap между группой кнопок и сноской-дисклеймером: 16→24px — кнопки не прилипают к тексту */
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin-bottom:24px; }
.hero-disclaimer { font-size:13px; color:var(--ink-3); margin-bottom:32px; }
.hero-meta { display:flex; gap:40px; flex-wrap:wrap; justify-content:center; }
/* Десктоп: перебиваем text-align/margin базовых правил (каскад: media после base = побеждает). */
@media (min-width:900px) {
  /* ВАЖНО: этот блок ИДЁТ ПОСЛЕ базового `.hero-inner{padding:0 28px}` (ниже по файлу),
     поэтому верхний клиренс под фикс-навбар (~58px + воздух) задаём именно здесь — иначе
     базовое правило перебивает по source-order (равная специфичность). */
  .hero-inner { text-align:left; max-width:var(--maxw); padding:96px 28px 48px; }
  .hero-title { margin:0 0 22px; max-width:640px; }
  /* reverse-price прижимаем ВЛЕВО, как H1/lead (база даёт margin:auto → центрировался в колонке
     и уезжал правее остальных — Александр заметил 2026-06-13). */
  .hero-reverse-price { margin:14px 0 18px; }
  .hero-lead { margin:0 0 12px; }
  .hero-sub  { margin:0 0 28px; }
  .hero-actions { justify-content:flex-start; }
  .hero-disclaimer { text-align:left; }
  .hero-meta { justify-content:flex-start; }
}
/* Hero: защита от обрезания meta-row на коротких экранах (1366×768, ноутбуки с 768px высотой).
   ВАЖНО: этот блок идёт ПОСЛЕ `@media (min-width:900px)` который задаёт padding:96px 28px 48px —
   нужна большая специфичность по source-order.
   Уменьшаем hero-inner padding-top 96→56px, padding-bottom 48→16px → экономим ~72px.
   Итого контент ~824-72=~752px < 768px viewport → meta-row вписывается. */
@media (min-width:900px) and (max-height:820px) {
  .hero { min-height:auto; padding-top:0; padding-bottom:0; }
  .hero-inner { min-height:auto; padding-top:56px; padding-bottom:16px; }
  .hero-meta { gap:24px 32px; }
}
.meta-val { font-family:var(--font-display); font-weight:800; font-size:30px; letter-spacing:-.02em; background:linear-gradient(135deg,var(--ink),var(--ink-2)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
/* текстовая метрика (не число) — чуть меньше, чтобы попадать в ряд с цифрами */
.meta-val--txt { font-size:21px; line-height:1.36; }
.meta-lbl { font-size:12.5px; color:var(--ink-3); margin-top:3px; max-width:120px; }
.scroll-hint { position:absolute; bottom:28px; left:50%; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:7px; font-size:11px; text-transform:uppercase; letter-spacing:.16em; color:var(--ink-3); }
.scroll-hint svg { animation:bob 2s ease-in-out infinite; }
@keyframes bob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(5px)} }

/* === Секции ===
   Вертикальный ритм: единый отступ между секциями ~76px (был 120 — двоился в пустоту). */
.section { position:relative; max-width:var(--maxw); margin:0 auto; padding:76px 28px; }
.section-head { max-width:680px; margin:0 auto 44px; text-align:center; }
/* line-height 1.14 (был 1.06): хвост «у» в «Почему» не наезжает на строку ниже, строки дышат ровно. */
.section-head h2 { font-family:var(--font-display); font-weight:800; font-size:clamp(32px,4.2vw,52px); line-height:1.14; letter-spacing:-.018em; margin-bottom:18px; }
.section-lead { font-size:17px; line-height:1.6; color:var(--ink-2); max-width:600px; margin:0 auto; }

/* === ПРОБЛЕМА === */
.problem-grid { position:relative; display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.weave-broken { position:absolute; top:-30px; left:0; width:100%; height:30px; color:var(--ink-3); opacity:.6; }
.p-card { position:relative; background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:30px 28px 26px; backdrop-filter:blur(8px); overflow:hidden; transition:transform .35s cubic-bezier(.2,.8,.2,1), border-color .3s; }
.p-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--brand),transparent); opacity:.5; }
.p-card:hover { transform:translateY(-4px); border-color:var(--line); }
.p-num { font-family:var(--font-mono); font-size:13px; color:var(--brand); margin-bottom:18px; letter-spacing:.05em; }
.p-card h3 { font-family:var(--font-display); font-weight:700; font-size:20px; line-height:1.2; letter-spacing:-.01em; margin-bottom:12px; }
.p-card p { font-size:14.5px; line-height:1.6; color:var(--ink-2); margin-bottom:20px; }
.p-tag { font-size:12px; color:var(--ink-3); padding-top:16px; border-top:1px solid var(--line-2); }
.p-tag span { color:var(--ink); font-family:var(--font-mono); }

/* === Плитки «Бенто» (вариант A — выбран) === */
.tilesA { display:grid; grid-template-columns:1.5fr 1fr; grid-template-rows:auto auto; gap:18px; }
.tilesA .ta-card { background:var(--surface); border:1px solid var(--line); border-radius:18px; padding:28px 26px; position:relative; overflow:hidden; backdrop-filter:blur(8px); transition:transform .35s cubic-bezier(.2,.8,.2,1), border-color .3s; }
.tilesA .ta-card:hover { transform:translateY(-4px); border-color:var(--brand); }
.tilesA .ta-1 { grid-row:span 2; display:flex; flex-direction:column; justify-content:space-between; background:linear-gradient(165deg, rgba(107,123,255,.14), rgba(139,92,246,.05)); }
.ta-ico { width:48px; height:48px; border-radius:13px; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,#5b6ef5,#8b5cf6); color:#fff; margin-bottom:20px; box-shadow:0 8px 22px rgba(91,110,245,.3); }
.tilesA .ta-1 .ta-ico { width:58px; height:58px; }
.ta-card h3 { font-family:var(--font-display); font-weight:700; font-size:19px; line-height:1.2; letter-spacing:-.01em; margin-bottom:10px; }
.tilesA .ta-1 h3 { font-size:25px; }
.ta-card p { font-size:14px; line-height:1.6; color:var(--ink-2); }
.ta-badge { display:inline-block; margin-top:18px; font-size:11.5px; font-family:var(--font-mono); color:var(--ink-3); padding-top:14px; border-top:1px solid var(--line-2); }
/* Таблица «сколько раз меняли условия» в карточке проблемы (десктоп; на мобиле скрыта — узко). */
.ta-changes { width:100%; border-collapse:collapse; margin:18px 0 2px; font-size:13px; }
.ta-changes th, .ta-changes td { text-align:center; }
.ta-changes th:first-child, .ta-changes td:first-child { text-align:left; }
.ta-changes thead th { font-size:10.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-3); font-weight:700; font-family:var(--font-mono); padding:0 0 8px; }
.ta-changes tbody td { padding:7px 4px; border-top:1px solid var(--line-2); color:var(--ink-2); font-variant-numeric:tabular-nums; }
.ta-changes tbody td:first-child { color:var(--ink); }
.ta-changes .ta-changes-total td { font-weight:700; color:var(--ink); border-top:1px solid var(--line); padding-top:9px; }
.ta-changes-note { font-size:11px; color:var(--ink-3); margin-top:7px; line-height:1.5; }
@media (max-width:620px){ .ta-changes, .ta-changes-note { display:none; } }
@media (max-width:820px) { .tilesA { grid-template-columns:1fr; } .tilesA .ta-1 { grid-row:auto; } }

/* === РЕШЕНИЕ === */
/* Поджимаем кольцо кверху: меньше воздуха над диаграммой, секция выше.
   align-items:start — выравнивает кольцо и панель по верхнему краю; убирает
   пустоту под панелью деталей при коротком контенте (кольцо выше — пустота
   уходит вниз, где её не видно). */
/* Подпись-призыв над диаграммой «Из чего складывается прибыль?» */
.solution-diag-col { min-width:0; }   /* левая колонка: призыв + круг, оба центрированы → призыв ровно над кругом */
.solution-diagram-prompt { text-align:center; font-size:14px; line-height:1.5; color:var(--ink-2); margin:0 auto 16px; max-width:440px; }
.solution-diagram-prompt b { color:var(--ink); }
.solution { padding-top:40px; }
.solution .section-head { margin-bottom:20px; }
.solution-body { display:grid; grid-template-columns:0.9fr 1.1fr; gap:36px; align-items:start; scroll-margin-top:80px; }
.solution-slogan { text-align:center; max-width:780px; margin:34px auto 0; font-family:var(--font-display); font-weight:700; font-size:clamp(20px,2.4vw,30px); line-height:1.3; letter-spacing:-.02em; color:var(--ink); }
.solution-slogan .accent { background:linear-gradient(115deg,#5b6ef5,#8b5cf6 58%,#34d96b); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.solution-slogan-sub { text-align:center; max-width:680px; margin:14px auto 0; font-size:16px; line-height:1.6; color:var(--ink-2); }
.solution-slogan-sub b { color:var(--ink); font-weight:700; }
/* УТП-заявление: ведущая строка + «вау»-пилюля. Без warning-callout штампа — сноска-пилюля на токенах. */
.utp-claim { max-width:760px; margin:26px auto 0; text-align:center; }
.utp-lead { font-family:var(--font-display); font-weight:600; font-size:clamp(16px,1.5vw,19px); line-height:1.5; letter-spacing:-.01em; color:var(--ink-2); }
.utp-lead b { color:var(--ink); font-weight:700; }
.utp-wow { display:inline-flex; align-items:center; gap:9px; margin-top:16px; padding:9px 18px 9px 16px; border-radius:100px; background:color-mix(in srgb, var(--brand) 7%, var(--surface)); border:1px solid color-mix(in srgb, var(--brand) 24%, var(--line)); font-size:14.5px; font-weight:500; color:var(--ink-2); }
.utp-wow::before { content:""; flex:none; width:7px; height:7px; border-radius:50%; background:var(--brand); box-shadow:0 0 10px color-mix(in srgb, var(--brand) 70%, transparent); }
.utp-wow b { color:var(--brand); font-weight:800; }
.weave-diagram { position:relative; aspect-ratio:1/1; width:100%; max-width:440px; margin:0 auto; }
.weave-lines { position:absolute; inset:0; width:100%; height:100%; color:var(--brand); transform-origin:50% 50%; }
.weave-lines line { stroke:currentColor; stroke-width:1.1; opacity:.34; stroke-linecap:round; }
.wd-node { position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:120px; height:120px; border-radius:50%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px; background:radial-gradient(circle at 35% 30%, rgba(139,92,246,.9), rgba(91,110,245,.85)); color:#fff; box-shadow:0 0 50px rgba(107,123,255,.5), inset 0 1px 0 rgba(255,255,255,.3); z-index:3; }
.wd-node b { font-family:var(--font-display); font-weight:800; font-size:19px; letter-spacing:-.01em; }
.wd-node span { font-size:12px; opacity:.85; }
.wd-chip { position:absolute; transform:translate(-50%,-50%); display:inline-flex; align-items:center; gap:7px; white-space:nowrap; font-size:12.5px; font-weight:500; color:var(--ink); padding:7px 12px; border-radius:100px; background:var(--surface-2); border:1px solid var(--line); backdrop-filter:blur(8px); box-shadow:0 6px 18px rgba(0,0,0,.12); z-index:2; }
.wd-chip .dot { width:6px; height:6px; border-radius:50%; background:var(--brand); box-shadow:0 0 8px var(--brand); }

/* Интерактивный круг: узлы-кнопки + активное состояние + динамическая панель */
/* tap-highlight:transparent — убирает уродливый прямоугольник-подсветку при нажатии (артефакт мобильного/тач-клика). */
.wd-node, .wd-chip { font-family:inherit; cursor:pointer; -webkit-appearance:none; appearance:none; outline:none; -webkit-tap-highlight-color:transparent; -webkit-touch-callout:none; user-select:none; }
.wd-node:focus, .wd-chip:focus { outline:none; }
.wd-node:focus-visible, .wd-chip:focus-visible { outline:2px solid var(--brand); outline-offset:4px; }
/* Мягкие, плавные переходы (приятное переключение). */
.wd-node { transition:box-shadow .45s cubic-bezier(.2,.8,.2,1), transform .45s cubic-bezier(.2,.8,.2,1); }
.wd-chip { transition:border-color .3s ease, box-shadow .3s ease, color .3s ease, transform .35s cubic-bezier(.2,.8,.2,1), background .3s ease; }
.wd-chip:hover { transform:translate(-50%,-50%) scale(1.05); border-color:var(--brand); }
.wd-chip.is-active { border-color:transparent; color:#fff; background:linear-gradient(135deg,#5b6ef5,#8b5cf6); box-shadow:0 0 0 4px rgba(107,123,255,.16), 0 8px 22px rgba(91,110,245,.38); }
.wd-chip.is-active .dot { background:#fff; box-shadow:0 0 10px #fff; }
.wd-node:hover { transform:translate(-50%,-50%) scale(1.035); }
.wd-node.is-active { box-shadow:0 0 64px rgba(107,123,255,.62), inset 0 1px 0 rgba(255,255,255,.35); }
.weave-lines line { transition:opacity .3s, stroke-width .3s; }
.weave-lines line.is-active { opacity:.95; stroke-width:2.0; }

/* min-height:0 — снимаем жёсткий пол, панель растягивается ровно под контент.
   align-self:start — убирает старый center; теперь панель прижата к верхнему краю
   ряда вместе с кольцом, пустота под ней исчезает.
   padding-bottom — маленький воздух под последней строкой до следующего блока. */
.radial-detail { min-height:0; align-self:start; padding-bottom:8px; }
.rd-kicker { font-family:var(--font-body); font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.14em; color:var(--brand); margin-bottom:10px; }
.rd-title { font-family:var(--font-display); font-weight:700; font-size:26px; letter-spacing:-.02em; margin-bottom:10px; }
.rd-lead { font-size:15.5px; line-height:1.6; color:var(--ink-2); margin-bottom:18px; max-width:460px; }
.rd-items { list-style:none; display:flex; flex-direction:column; gap:11px; }
.rd-items li { display:flex; align-items:flex-start; gap:11px; font-size:14.5px; color:var(--ink); }
.rd-items li::before { content:''; flex-shrink:0; width:6px; height:6px; margin-top:7px; border-radius:50%; background:linear-gradient(135deg,#5b6ef5,#8b5cf6); }
/* Подсказки-инструкции убраны (по PO): выбор должен быть интуитивным, без «понажимайте». */
.rd-hint { display:none; }
.radial-detail.swap { animation:rdSwap .38s ease; }
@keyframes rdSwap { from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:none} }

/* Карточка экономики */
.pnl-card { background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow); backdrop-filter:blur(10px); }
.pnl-chrome { display:flex; align-items:center; gap:7px; padding:13px 16px; border-bottom:1px solid var(--line); }
.pnl-chrome .cd { width:10px; height:10px; border-radius:50%; background:var(--line); }
.pnl-addr { font-family:var(--font-mono); font-size:11.5px; color:var(--ink-3); margin-left:10px; }
.pnl-toolbar { display:flex; align-items:center; gap:8px; padding:12px 16px; border-bottom:1px solid var(--line-2); flex-wrap:wrap; }
.pnl-tab { font-size:13px; font-weight:600; padding:6px 12px; border-radius:8px; color:var(--ink-2); }
.pnl-tab.active { color:#fff; background:linear-gradient(135deg,#5b6ef5,#8b5cf6); }
.pnl-chip { font-size:12px; color:var(--ink-2); padding:6px 11px; border:1px solid var(--line); border-radius:100px; }
.pnl-table { width:100%; border-collapse:collapse; font-size:12.5px; }
.pnl-table th { font-weight:600; color:var(--ink-3); text-align:right; padding:11px 10px; font-size:11px; text-transform:uppercase; letter-spacing:.04em; border-bottom:1px solid var(--line); }
.pnl-table td { text-align:right; padding:11px 10px; border-bottom:1px solid var(--line-2); font-family:var(--font-mono); color:var(--ink-2); white-space:nowrap; }
.pnl-table .t-sku { text-align:left; font-family:var(--font-body); color:var(--ink); font-weight:500; }
.pnl-table tr:last-child td { border-bottom:none; }
.pnl-table .t-prof { font-weight:600; }
.pnl-table .pos { color:var(--green); }
.pnl-table .warn { color:var(--gold); }
.pnl-table .neg { color:var(--loss); }
.pnl-table tr.loss { background:rgba(255,107,120,.05); }
.m { display:inline-block; padding:3px 8px; border-radius:6px; font-family:var(--font-body); font-size:11.5px; font-weight:600; }
.m.good { color:var(--green); background:rgba(52,217,107,.12); }
.m.warn { color:var(--gold); background:rgba(255,211,107,.13); }
.m.bad { color:var(--loss); background:rgba(255,107,120,.13); }
.pnl-foot { display:flex; align-items:center; justify-content:space-between; gap:14px; padding:14px 16px; border-top:1px solid var(--line); flex-wrap:wrap; }
.pnl-total { display:flex; flex-direction:column; gap:2px; }
.pnl-total span { font-size:11px; color:var(--ink-3); }
.pnl-total b { font-family:var(--font-display); font-size:22px; font-weight:800; letter-spacing:-.01em; }
.pnl-tags { display:flex; gap:6px; flex-wrap:wrap; }
.pnl-tags span { font-size:11px; color:var(--ink-3); padding:4px 9px; border:1px solid var(--line); border-radius:6px; }
.solution-note { display:flex; align-items:center; gap:9px; justify-content:center; margin-top:34px; font-size:12.5px; color:var(--ink-3); max-width:660px; margin-left:auto; margin-right:auto; text-align:center; }
.solution-note svg { flex-shrink:0; color:var(--ink-3); }

/* === v2: спокойные highlights вместо таблицы + смягчение акцентов ниже hero === */
.sol-highlights { display:flex; flex-direction:column; gap:2px; }
.sol-hl { display:flex; gap:20px; align-items:flex-start; padding:20px 6px; border-bottom:1px solid var(--line-2); }
.sol-hl:last-child { border-bottom:none; }
.sol-hl-k { font-family:var(--font-display); font-weight:700; font-size:26px; letter-spacing:-.02em; color:var(--ink); min-width:56px; line-height:1.15; }
.sol-hl-b h4 { font-family:var(--font-display); font-weight:600; font-size:16px; letter-spacing:-.01em; margin-bottom:4px; color:var(--ink); }
.sol-hl-b p { font-size:13.5px; line-height:1.55; color:var(--ink-2); }
/* ниже hero — мягче: приглушаем номера/полоски карточек, спокойнее тон */
.p-card::before { opacity:.22; height:1px; }
.p-num { color:var(--ink-3); }
.wd-node { box-shadow:0 0 38px rgba(107,123,255,.34), inset 0 1px 0 rgba(255,255,255,.25); }

/* === МОДАЛКА ЗАЯВКИ В БЕТУ (v12-A — воздушный дизайн, 2-шаговая) ===
   Цель: премиально, с воздухом, ничего не налезает.
   Максимальная ширина 520px — компактнее 620px, меньше «пустоты по краям».
   Паддинг 38–40px — комфортно. Вертикальный ритм: gap между блоками 22px. */
.beta-modal { position:fixed; inset:0; z-index:200; display:none; }
.beta-modal.is-open { display:block; }
.bm-backdrop { position:absolute; inset:0; background:rgba(4,5,12,.66); backdrop-filter:blur(6px); animation:bmFade .25s ease; }
@keyframes bmFade { from{opacity:0} to{opacity:1} }
/* Карточка: 520px, паддинг 38px по бокам */
.bm-card {
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:min(520px,calc(100vw - 28px));
  max-height:calc(100vh - 48px);
  background:var(--bg-2); border:1px solid var(--line);
  border-radius:22px; box-shadow:var(--shadow);
  overflow:hidden; animation:bmPop .3s cubic-bezier(.2,.8,.2,1);
}
@keyframes bmPop { from{opacity:0; transform:translate(-50%,-46%) scale(.97)} to{opacity:1; transform:translate(-50%,-50%) scale(1)} }
/* Кнопка закрытия */
.bm-x { position:absolute; top:16px; right:16px; z-index:2; width:34px; height:34px; display:inline-flex; align-items:center; justify-content:center; border-radius:9px; border:1px solid var(--line); background:var(--surface); color:var(--ink-2); cursor:pointer; transition:color .2s, border-color .2s; }
.bm-x:hover { color:var(--ink); border-color:var(--brand); }
/* Скроллируемая внутренность: 38px по бокам, 36px сверху и снизу */
.bm-scroll { max-height:calc(100vh - 48px); overflow-y:auto; padding:36px 38px; }

/* === Шаг-контейнер === */
.bm-step { display:flex; flex-direction:column; gap:0; }

/* === Индикатор шагов — аккуратный, с отступом снизу 20px === */
.bm-steps-row { display:flex; align-items:center; gap:10px; margin-bottom:20px; }
.bm-step-badge {
  width:30px; height:30px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:700;
  border:2px solid var(--line); color:var(--ink-3); background:var(--surface); flex-shrink:0;
}
.bm-step-badge.active { border-color:var(--brand); color:var(--brand); background:rgba(91,110,245,.1); }
.bm-step-badge.done { border-color:var(--green); color:var(--green); background:rgba(52,217,107,.1); }
.bm-step-line { flex:1; height:1px; background:var(--line); border-radius:2px; }
.bm-step-line.done { background:var(--green); }

/* === Голова шага === */
.bm-head { margin-bottom:24px; }
.bm-head h3 { font-family:var(--font-display); font-weight:800; font-size:clamp(22px,3vw,28px); letter-spacing:-.02em; margin:4px 0 10px; }
.bm-head p { font-size:14px; line-height:1.6; color:var(--ink-2); }

/* === Формы: вертикальный gap между полями ===  */
#beta-form-step1 { display:flex; flex-direction:column; gap:22px; }
#beta-form        { display:flex; flex-direction:column; gap:22px; }

/* === Строка 2 колонки === */
.bm-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

/* === Поле === */
.bm-field { display:flex; flex-direction:column; gap:8px; }
.bm-field > span { font-size:13px; font-weight:600; color:var(--ink); }
.bm-field > span i { font-weight:400; color:var(--ink-3); font-style:normal; }
/* Инпут: паддинг 12px 14px, радиус 11px — комфортно, не тесно */
.bm-field input, .bm-field textarea {
  font-family:var(--font-body); font-size:14px; color:var(--ink);
  background:var(--surface); border:1px solid var(--line);
  border-radius:11px; padding:12px 14px;
  transition:border-color .2s, box-shadow .2s; resize:vertical;
}
.bm-field input::placeholder, .bm-field textarea::placeholder { color:var(--ink-3); }
.bm-field input:focus, .bm-field textarea:focus { outline:none; border-color:var(--brand); box-shadow:0 0 0 3px rgba(91,110,245,.14); }
.bm-field.is-error input, .bm-field.is-error textarea { border-color:var(--loss); }

/* === Группа с чипами === */
.bm-group { display:flex; flex-direction:column; gap:10px; }
.bm-label { font-size:13px; font-weight:600; color:var(--ink); }
/* Чипы: комфортный паддинг, не слипаются */
.bm-chips { display:flex; flex-wrap:wrap; gap:8px; }
.bm-chip {
  font-family:var(--font-body); font-size:13px; font-weight:500;
  color:var(--ink-2); background:var(--surface); border:1px solid var(--line);
  border-radius:100px; padding:9px 16px;
  cursor:pointer; transition:color .2s, border-color .2s, background .2s, transform .15s;
}
.bm-chip:hover { border-color:var(--brand); color:var(--ink); }
.bm-chip:active { transform:scale(.96); }
.bm-chip.is-on { color:#fff; border-color:transparent; background:linear-gradient(135deg,#5b6ef5,#8b5cf6); box-shadow:0 6px 16px rgba(91,110,245,.32); }
.bm-chips.is-error { outline:1px dashed var(--loss); outline-offset:6px; border-radius:14px; }

/* === Согласие === */
.bm-consent { display:flex; align-items:flex-start; gap:10px; font-size:13px; color:var(--ink-2); cursor:pointer; line-height:1.45; }
.bm-consent input { margin-top:2px; width:16px; height:16px; accent-color:var(--brand); flex-shrink:0; cursor:pointer; }
.bm-consent.is-error span { color:var(--loss); }

/* === Ошибки === */
.bm-error { font-size:13px; color:var(--loss); min-height:0; }
.bm-error:empty { display:none; }

/* === Кнопки Submit — без SVG-стрелки === */
/* html body-специфичность: перебивает портальный .btn{padding:6px 14px} из #rs-real-css */
html body .bm-submit { justify-content:center; width:100%; font-size:15px; font-weight:700; padding:14px 22px; }
.bm-submit.is-loading { opacity:.7; pointer-events:none; }
/* Строка «← Назад / Отправить» на шаге 2 */
.bm-nav-row { display:flex; gap:12px; align-items:center; }
html body .bm-back-btn { flex:0 0 auto; padding:14px 18px; font-size:14px; }
.bm-nav-row .bm-submit { flex:1; width:auto; }

/* === Успех === */
.bm-done { text-align:center; padding:24px 6px 8px; }
.bm-done-ico { width:64px; height:64px; margin:0 auto 20px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,rgba(52,217,107,.2),rgba(52,217,107,.06)); border:1px solid rgba(52,217,107,.4); color:var(--green); }
.bm-done h3 { font-family:var(--font-display); font-weight:800; font-size:26px; letter-spacing:-.02em; margin-bottom:10px; }
.bm-done p { font-size:15px; line-height:1.6; color:var(--ink-2); max-width:420px; margin:0 auto 22px; }

/* === Мобиль === */
@media (max-width:520px) {
  .bm-row { grid-template-columns:1fr; }
  .bm-scroll { padding:28px 22px; }
}

/* === Строка безопасности у кнопки заявки (beta-safety) === */
/* margin-bottom:20px — элемент стоит ПЕРЕД .hero-actions (DOM-порядок): кнопка не прилипает к тексту безопасности */
.beta-safety { display:flex; align-items:flex-start; gap:8px; font-size:13px; line-height:1.5; color:var(--ink-3); margin-top:12px; margin-bottom:20px; }
.beta-safety svg { flex-shrink:0; margin-top:1px; }

/* === FOOTER === */
.site-foot { border-top:1px solid var(--line); margin-top:60px; }
.foot-inner { max-width:var(--maxw); margin:0 auto; padding:36px 28px; display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.foot-brand { display:flex; flex-direction:column; gap:4px; }
.foot-wm { font-family:var(--font-display); font-weight:600; color:var(--ink); }
.foot-wm b { font-weight:800; color:var(--brand); }   /* канон: «Ассист» 800 фирменным синим */
.foot-brand span { font-size:13px; color:var(--ink-3); }
.foot-meta { font-size:12.5px; color:var(--ink-3); }
.foot-meta a { color:var(--brand); }

/* === МИССИЯ === */
/* Базовый кап 960px; L/XL тиры расширяют под контейнер (960→1120→1200).
   Абзац .mission-intro сохраняет кап 680px — мера читаемости не меняется. */
.mission-inner { max-width:960px; margin:0 auto; text-align:center; }
.mission-intro { font-family:var(--font-display); font-weight:600; font-size:clamp(17px,2vw,21px); line-height:1.5; color:var(--ink); max-width:680px; margin:0 auto 36px; letter-spacing:-.01em; }
.mission-intro b { background:linear-gradient(115deg,#5b6ef5,#8b5cf6 58%,#34d96b); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.mission-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; text-align:left; }
.mission-card { background:var(--surface); border:1px solid var(--line); border-radius:18px; padding:26px 24px; backdrop-filter:blur(8px); transition:transform .35s cubic-bezier(.2,.8,.2,1), border-color .3s; }
.mission-card:hover { transform:translateY(-4px); border-color:var(--brand); }
.mission-card h3 { font-family:var(--font-display); font-weight:800; font-size:18px; letter-spacing:-.01em; margin-bottom:10px; }
.mission-card h3 span { background:linear-gradient(135deg,#5b6ef5,#8b5cf6); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.mission-card p { font-size:14px; line-height:1.6; color:var(--ink-2); }
.mission-card p b { color:var(--ink); font-weight:600; }
@media (max-width:820px){ .mission-grid { grid-template-columns:1fr; } }

/* === ВОЛНЫ / ROADMAP (таймлайн-дорога) === */
.waves-timeline { max-width:920px; margin:0 auto; }
.wv-rail { position:relative; padding-left:36px; }
.wv-rail::before { content:''; position:absolute; left:9px; top:8px; bottom:8px; width:2px; background:linear-gradient(var(--brand),var(--brand-2),transparent); opacity:.5; }
.wv-node { position:relative; padding:0 0 36px; }
.wv-node:last-child { padding-bottom:0; }
.wv-dot { position:absolute; left:-36px; top:3px; width:18px; height:18px; border-radius:50%; background:var(--bg-2); border:2px solid var(--line); }
.wv-dot-on { background:linear-gradient(135deg,#5b6ef5,#8b5cf6); border-color:transparent; box-shadow:0 0 0 5px rgba(107,123,255,.16); }
.wv-now b { font-family:var(--font-display); font-weight:700; font-size:17px; }
.wv-now i { display:block; font-style:normal; font-size:13.5px; color:var(--ink-3); margin-top:3px; }
.wv-now { opacity:.85; }
.wv-wave-tag { display:inline-block; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:var(--brand); padding:5px 11px; border:1px solid var(--line); border-radius:100px; background:var(--surface); margin-bottom:12px; }
.wv-wave-title { font-family:var(--font-display); font-weight:800; font-size:clamp(21px,2.6vw,28px); letter-spacing:-.02em; line-height:1.12; margin-bottom:9px; }
.wv-wave-lead { font-size:15px; line-height:1.6; color:var(--ink-2); max-width:640px; margin-bottom:18px; }
.wv-tools-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.wv-tools-grid.wv-tools-3 { grid-template-columns:repeat(3,1fr); }
.wv-tool { background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:18px; backdrop-filter:blur(8px); transition:transform .35s cubic-bezier(.2,.8,.2,1), border-color .3s; }
.wv-tool:hover { transform:translateY(-3px); border-color:var(--brand); }
.wv-tool-ico { width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,#5b6ef5,#8b5cf6); color:#fff; margin-bottom:13px; box-shadow:0 8px 20px rgba(91,110,245,.28); transition:transform .4s cubic-bezier(.2,.8,.2,1); }
.wv-tool-ico svg { width:22px; height:22px; }
.wv-tool:hover .wv-tool-ico { transform:translateY(-2px) rotate(-5deg) scale(1.05); }
.wv-tool h4 { font-family:var(--font-display); font-weight:700; font-size:15.5px; letter-spacing:-.01em; margin-bottom:6px; color:var(--ink); }
.wv-tool p { font-size:13px; line-height:1.55; color:var(--ink-2); }
/* финал — со-разработка */
.wv-codev { padding-bottom:0; }
.wv-dot-glow { background:linear-gradient(135deg,#5b6ef5,#8b5cf6); border-color:transparent; animation:wvPulse 2.6s ease-in-out infinite; }
@keyframes wvPulse { 0%,100%{ box-shadow:0 0 0 5px rgba(107,123,255,.14), 0 0 16px rgba(107,123,255,.4) } 50%{ box-shadow:0 0 0 7px rgba(107,123,255,.20), 0 0 30px rgba(107,123,255,.6) } }
.wv-codev-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:14px; }
.wv-codev-card { background:linear-gradient(160deg, rgba(107,123,255,.12), rgba(139,92,246,.05)); border:1px solid var(--line); border-radius:16px; padding:20px 18px; transition:transform .35s cubic-bezier(.2,.8,.2,1), border-color .3s; }
.wv-codev-card:hover { transform:translateY(-3px); border-color:var(--brand); }
.wv-codev-ico { width:40px; height:40px; border-radius:11px; display:flex; align-items:center; justify-content:center; background:var(--surface-2); border:1px solid var(--line); color:var(--brand); margin-bottom:12px; }
.wv-codev-ico svg { width:21px; height:21px; }
.wv-codev-card h4 { font-family:var(--font-display); font-weight:700; font-size:15.5px; letter-spacing:-.01em; margin-bottom:6px; color:var(--ink); }
.wv-codev-card p { font-size:13px; line-height:1.55; color:var(--ink-2); }
@media (max-width:720px){ .wv-tools-grid, .wv-tools-grid.wv-tools-3, .wv-codev-grid { grid-template-columns:1fr; } }
@media (prefers-reduced-motion:reduce){ .wv-dot-glow { animation:none; } }

/* === Появления по скроллу === */
.reveal { opacity:0; transform:translateY(28px); }
.reveal.in { opacity:1; transform:none; transition:opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1); }

/* === Адаптив === */
@media (max-width:980px) {
  .solution-body { grid-template-columns:1fr; gap:22px; }   /* фактор↔кольцо ближе при стопке */
  .weave-diagram { max-width:380px; }
}
@media (max-width:820px) {
  .nav-links { display:none; }
  .hero-meta { gap:26px; }
  .problem-grid { grid-template-columns:1fr; }
  .weave-broken { display:none; }
  .status-pill { display:none; }
}
@media (max-width:560px) {
  .section { padding:44px 20px; }            /* был 84 — разрыв между блоками вдвое меньше */
  /* На мобильном дополнительно поджимаем — кольцо идёт сразу за заголовком */
  .solution { padding-top:24px; }
  .solution .section-head { margin-bottom:14px; }
  .hero { padding-top:72px; }                /* эйброу «Бета·Волна 01» должен очистить фикс-шапку (~52-58px) — Александр 06-12 */
  .nav-inner { padding:14px 18px; }
  .hero-inner { padding:0 20px; }
  .hero-meta { gap:22px; }
  .meta-val { font-size:24px; }
  .solution-slogan { margin-top:24px; }
  /* кольцо компактнее → чипы-факторы не вылезают за вьюпорт (часть width-lock) */
  .weave-diagram { max-width:320px; }
  .wd-chip { font-size:11.5px; padding:6px 10px; }
  .wd-node { width:104px; height:104px; }
}
/* Смартфон: вордмарк возвращён (по просьбе PO); переключатель версий вынесен в бургер → шапка не перегружена. */
@media (max-width:620px) {
  .brand-name { font-size:14px; }
  .nav-inner { padding:12px 16px; }
  /* ПЕРВЫЙ ЭКРАН (.hero-firstscreen) = ровно высота видимой области (100svh — учитывает
     показанную адрес-строку браузера). Внутри: шапка-eyebrow + H1 сверху, полоса ₽ по центру
     остатка (margin:auto), короткий абзац «…по каждому SKU» ПРИЖАТ к низу. Длинный «Один экран…»
     лежит уже ВНЕ обёртки → попадает сразу под сгиб. Работает на ЛЮБОМ телефоне (ширина 360-412,
     высота 640-880) БЕЗ магических констант: flex сам распределяет воздух. Размер глифа ₽ держим
     почти постоянным фикс-высотой полосы (в woven-hero.js ₽ ∝ высоте полосы — поэтому НЕ flex-grow,
     а clamp с узким диапазоном). */
  /* −72px = padding-top шапки .hero (см. выше): обёртка стартует на 72px ниже верха окна,
     поэтому её высоту уменьшаем на эти 72px — иначе низ обёртки уезжает под сгиб. */
  .hero-firstscreen { min-height:calc(100vh - 72px); min-height:calc(100svh - 72px); display:flex; flex-direction:column; box-sizing:border-box; padding-bottom:10px; }
  .hero-firstscreen > .eyebrow,
  .hero-firstscreen > .hero-title { flex:0 0 auto; }
  .hero-ruble-band { flex:0 1 auto; max-width:440px; height:clamp(260px, 46svh, 380px); margin:auto; }
  .hero-firstscreen > .hero-reverse-price { flex:0 0 auto; margin-bottom:0; }
  .hero-meta { gap:22px 28px; }

  /* FIX 3: Фон шапки на мобиле — всегда непрозрачный (на десктопе фон приходит через .scrolled,
     но на мобиле при старте страницы шапка прозрачная → контент просвечивает насквозь).
     Задаём surface + blur постоянно, не только при скролле. */
  .nav {
    background: var(--nav-bg);
    backdrop-filter: blur(20px) saturate(1.7);
    -webkit-backdrop-filter: blur(20px) saturate(1.7);
    border-bottom-color: var(--line);
  }

  /* FIX 2: Сжатие вертикального воздуха вокруг круга «Решение» на ~20%.
     .solution-diagram-prompt: снижаем margin-bottom 16→13px (−3px ≈ −19%).
     .weave-diagram: снижаем верхний и нижний gap — через уменьшение margin на .solution-body gap. */
  .solution-diagram-prompt { margin-bottom: 13px; }
  .solution-body { gap: 18px; }
  .solution-slogan { margin-top: 19px; }  /* было 24px → −20% */
  .solution .section-head { margin-bottom: 11px; }  /* было 14px → чуть плотнее */

  /* FIX 5: Пилюля «а у нас уже есть» — полная ширина контейнера + перенос по словам.
     inline-flex при узком viewport растягивается шире контейнера → уродливые разрывы.
     Переводим в block, убираем white-space:nowrap (по умолчанию normal), даём padding. */
  .utp-wow {
    display: block;
    border-radius: 16px;    /* скруглённый прямоугольник вместо pill-полуокружности */
    text-align: left;
    padding: 12px 18px;
  }
  .utp-wow::before {
    display: inline-block;
    vertical-align: middle;
    margin-right: 8px;
    margin-bottom: 1px;
  }
}

@media (prefers-reduced-motion:reduce) {
  .reveal { opacity:1; transform:none; }
  .status-dot, .scroll-hint svg { animation:none; }
  html { scroll-behavior:auto; }
}

/* === Скрин экономики: воздух сверху + горизонтальный скролл на узком === */
.pnl-card { margin-top:34px; }
.pnl-table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; }

/* === СРАВНЕНИЕ === */
.cmp-baseline { margin:0 auto 18px; background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:20px 24px; backdrop-filter:blur(8px); }
.cmp-baseline-head { display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:700; font-size:14.5px; color:var(--ink-2); margin-bottom:14px; }
.cmp-b-dot { width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 10px var(--green); flex-shrink:0; }
.cmp-baseline-items { display:grid; grid-template-columns:repeat(3,1fr); gap:10px 18px; }
.cmp-b-item { position:relative; font-size:13.5px; color:var(--ink); padding-left:22px; }
.cmp-b-item::before { content:'✓'; position:absolute; left:0; top:0; color:var(--green); font-weight:700; }

.cmp-table { border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--surface-2); backdrop-filter:blur(8px); }
.cmp-row { display:grid; grid-template-columns:2fr 1.4fr repeat(4,1fr); align-items:stretch; border-bottom:1px solid var(--line-2); }
.cmp-row:last-child { border-bottom:none; }
.cmp-head { background:rgba(127,140,255,.08); }
.cmp-head .cmp-col { font-family:var(--font-display); font-weight:700; font-size:12.5px; color:var(--ink); }
.cmp-feat { font-size:14px; color:var(--ink); padding:16px 18px; display:flex; align-items:center; font-weight:500; border-right:1px solid var(--line-2); }
.cmp-head .cmp-feat { font-family:var(--font-display); font-weight:700; font-size:13px; }
.cmp-col { justify-content:center; text-align:center; font-size:12.5px; color:var(--ink-3); padding:14px 8px; display:flex; align-items:center; justify-content:center; }
.cmp-us { background:linear-gradient(180deg, rgba(107,123,255,.12), rgba(139,92,246,.05)); color:var(--ink); font-weight:600; }
.cmp-us-logo { display:inline-flex; align-items:center; justify-content:center; width:24px; height:24px; border-radius:7px; background:linear-gradient(135deg,#5b6ef5,#8b5cf6); color:#fff; font-size:11px; font-weight:800; margin-right:8px; flex-shrink:0; }
.cmp-cell { display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; font-size:18px; color:var(--ink-3); padding:14px 8px; }
.cmp-cell-text { font-family:var(--font-display); font-weight:700; font-size:14.5px; color:var(--ink); line-height:1.2; gap:4px; }
.cmp-cell-text small { font-family:var(--font-body); font-weight:400; font-size:11px; color:var(--ink-3); line-height:1.35; margin-top:4px; }
.cmp-legend { display:flex; flex-wrap:wrap; align-items:center; gap:8px 20px; margin-top:16px; font-size:12.5px; color:var(--ink-3); }
.cmp-legend b { color:var(--ink-2); }
.cmp-legend-note { flex-basis:100%; font-size:11.5px; color:var(--ink-3); margin-top:4px; }

/* === Бета: причина дефицита + обмен ценностью === */
.beta-why { font-size:14.5px; line-height:1.6; color:var(--ink-2); max-width:600px; margin:22px auto 0; }
.beta-exchange { display:grid; grid-template-columns:1fr 1fr; gap:16px; max-width:760px; margin:26px auto 0; text-align:left; }
.beta-block { background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:22px; backdrop-filter:blur(8px); }
.beta-block-alt { background:var(--surface-2); }
.beta-block h3 { font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--ink); margin-bottom:14px; }
.beta-block ul { list-style:none; display:flex; flex-direction:column; gap:12px; }
.beta-block li { display:flex; gap:12px; align-items:flex-start; font-size:13.5px; line-height:1.5; color:var(--ink-2); }
.beta-block li b { color:var(--ink); font-weight:600; }
.bx-n { flex-shrink:0; font-family:var(--font-mono); font-size:11px; color:var(--brand); padding-top:1px; }

/* === Волны: «Честно с порога» — сноска-футнот (верхняя черта + брендовый ярлык, НЕ карточка) === */
.wv-honest { max-width:900px; margin:38px auto 0; padding:26px 2px 0; border-top:1px solid var(--line); background:none; border-radius:0; border:none; border-top:1px solid var(--line); }
.wv-honest-label { display:inline-flex; align-items:center; gap:10px; font-family:var(--font-body); font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.13em; color:var(--brand); margin-bottom:13px; }
.wv-honest p { font-size:14px; line-height:1.65; color:var(--ink-2); max-width:700px; margin:0; }
.wv-honest p b { color:var(--ink); font-weight:600; }
.wv-honest-mps { display:flex; flex-wrap:wrap; gap:10px; margin-top:18px; }
.wv-mp { display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:500; color:var(--ink-3); background:var(--surface-2); border:1px solid var(--line); border-radius:100px; padding:7px 14px; }
.wv-mp i { width:7px; height:7px; border-radius:50%; background:var(--ink-3); opacity:.5; flex-shrink:0; }
.wv-mp--on { color:var(--ink); }
.wv-mp--on i { background:var(--green); opacity:1; box-shadow:0 0 8px var(--green); }
.wv-mp--soon { color:var(--ink-2); }
.wv-mp--soon i { background:var(--brand); opacity:.9; }

/* === Адаптив новых блоков === */
@media (max-width:820px) {
  .cmp-baseline-items { grid-template-columns:1fr 1fr; }
  .beta-exchange { grid-template-columns:1fr; }
  /* На узком: оставляем «фичу» + «у нас», конкурентов прячем (их видно на десктопе) */
  .cmp-row { grid-template-columns:1.5fr 1fr; }
  .cmp-row > .cmp-col:not(.cmp-us), .cmp-row > .cmp-cell:not(.cmp-us) { display:none; }
}
@media (max-width:560px) {
  .cmp-baseline-items { grid-template-columns:1fr; }
}

/* ============================================================
   BETA-STAGE — 3D-логотип «МА» (новая обёртка взамен .hero-ruble-band).
   Класс .beta-stage НЕ пересекается с .hero-ruble-band:
   полоса ₽ по-прежнему скрывается на desktop (@media min-width:900px display:none),
   тогда как .beta-stage ВСЕГДА видим (нет display:none ни в одном тире).
   ============================================================ */

/* Базовый (мобиль ≤1099px): модель стопкой над подписью, центрирована */
/* .beta-stage: зона 3D-модели «МА» (канвас только).
   band = canvas.parentNode = .beta-stage.
   JS читает band.clientWidth/clientHeight → размер буфера рендера.
   Явная height обязательна: без неё clientHeight=0 и THREE.WebGLRenderer падает.
   overflow:hidden — канвас не вылезает за бокс после renderer.setSize(). */
.beta-stage {
  /* Видим на всех тирах — без display:none */
  position:relative;
  width:100%;
  max-width:520px;
  /* Высота буфера рендера: мобиль/планшет */
  height:clamp(240px,45vw,320px);
  margin:0 auto 0;
  pointer-events:auto; /* drag-rotate должен работать */
  overflow:hidden;
}
/* canvas: JS setSize задаёт width/height attributes + inline style.
   overflow:hidden на родителе гарантирует непересечение. */
.beta-stage canvas {
  display:block;
}

/* .beta-model-col: правая колонка в 2-col beta grid.
   На мобиле (≤1099): стопкой, центрирована, модель над текстом (order:-1 переставляет вверх). */
.beta-model-col {
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  order:-1; /* на мобиле модель идёт ВЫШЕ текстовой колонки */
}

/* Подпись 3D-модели (стала братом .beta-stage в .beta-model-col) */
.beta-model-col .beta-logo-cap {
  font-size:13px;
  line-height:1.55;
  color:var(--ink-3);
  text-align:center;
  max-width:420px;
  margin:0;
  letter-spacing:.01em;
}

/* === Бета: текстовая колонка (мобиль: обычный поток, центр) === */
.beta-text-col {
  /* На мобиле — единая колонка, центрирование наследуется от .beta-inner */
  width:100%; /* заполняет flex-родителя .beta-inner */
  display:flex;
  flex-direction:column;
  align-items:center; /* центр на мобиле */
}

/* === Beta 2-col grid на десктопе (≥1100px) ===
   spec §4: текст слева (1fr), модель справа (minmax(420px,520px)); gap 48px.
   На ≤1099px — одна колонка + модель стопкой сверху (мобиль/планшет). */
@media (min-width:1100px) {
  /* Снимаем кап 780px — теперь .section (max-width:var(--maxw)) задаёт ширину */
  .beta-inner {
    max-width:none;
    width:100%;
    display:grid;
    grid-template-columns:1fr minmax(420px,520px);
    gap:48px;
    align-items:center;
    text-align:left;
  }
  /* Текстовая колонка: левое выравнивание, обычный поток */
  .beta-text-col {
    align-items:flex-start;
    text-align:left;
  }
  /* .beta-bar, .beta-counter: на мобиле были justify-content:center — снимаем */
  .beta-text-col .beta-counter { display:inline-flex; }
  .beta-text-col .beta-bar { margin-left:0; margin-right:0; }
  /* .hero-actions: на мобиле justify-content:center — на десктопе flex-start */
  .beta-text-col .hero-actions { justify-content:flex-start; }
  /* .beta-why/.beta-prompt/.beta-wb-invite: снимаем auto-margin (центрировку), прижимаем к левому краю */
  .beta-text-col .beta-why { margin-left:0; margin-right:0; }
  .beta-text-col .beta-prompt { margin-left:0; margin-right:0; }
  .beta-text-col .beta-wb-invite { margin-left:0; margin-right:0; }
  /* .beta-exchange: внутри левой колонки, занимает всю ширину текстовой зоны */
  .beta-text-col .beta-exchange { max-width:none; margin-left:0; margin-right:0; }

  /* Правая колонка — .beta-model-col: flex-column, модель сверху + подпись снизу */
  .beta-model-col {
    order:0; /* сброс мобильного order:-1; на десктопе правая колонка = второй grid-item */
    align-self:center;
    align-items:center;
    gap:14px;
  }
  /* .beta-stage на десктопе: снимаем ограничение 520px, занимает всю ширину колонки */
  .beta-stage {
    max-width:none;
    width:100%;
    height:440px; /* высота буфера рендера на desktop M (1100-1479px) */
    margin:0;
  }
  /* Подпись под моделью: центр правой колонки */
  .beta-model-col .beta-logo-cap {
    text-align:center;
    max-width:none;
  }
}

/* === Tier L (1480+): расширяем inner-caps Mission/Roadmap ===
   .beta-inner уже на full container через max-width:none, не нужно трогать.
   --maxw уже переключён в 1440px через :root override выше. */
@media (min-width:1480px) {
  /* Mission: 960→1120 */
  .mission-inner { max-width:1120px; }
  /* Roadmap: 920→1040 */
  .waves-timeline { max-width:1040px; }
  .wv-honest { max-width:940px; }
  /* Beta stage: выше при большем контейнере (нужно — JS перечитывает clientHeight при resize) */
  .beta-stage { height:480px; }
}

/* === Tier XL (1860+): расширяем inner-caps Mission/Roadmap до максимума ===
   --maxw уже переключён в 1600px через :root override выше. */
@media (min-width:1860px) {
  /* Mission: 960→1200 */
  .mission-inner { max-width:1200px; }
  /* Roadmap: 920→1100 */
  .waves-timeline { max-width:1100px; }
  .wv-honest { max-width:980px; }
  /* Beta stage: полная высота при 1600px контейнере */
  .beta-stage { height:500px; }
}

/* Александр 06-11: при тапе по фактору на мобиле — прокрутка к подсказке с отступом под фикс-шапку */
.solution-diagram-prompt { scroll-margin-top: 73px; }


/* Александр 06-12: мобиль — первый экран заканчивается на «по каждому SKU»; сабтайтл «Маркетплейс
   показывает оборот…» уводим под фолд небольшим отступом под лидом (₽ крупный, позиция центр). */
@media (max-width:620px) {
  .hero-lead { margin-bottom:26px; }
}
