/* aiadapter.ru — public marketing site. Dark theme, shared palette with the cabinet. */
:root{
  --bg:#000000; --bg2:#000000; --card:#0c0c0e; --card2:#121216;
  --line:#23232a; --txt:#EAEAEA; --mut:#8a8a93; --accent:#CBC5EA;
  --accent-d:#b3aadf; --ok:#3fbf7f; --warn:#e0a83f; --bad:#C20114;
  --maxw:1080px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--txt);
  font:15px/1.6 ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;
  -webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:none}
h1,h2,h3{line-height:1.2;margin:0 0 .5em}
h1{font-size:clamp(28px,4vw,44px);letter-spacing:-.02em}
h2{font-size:clamp(22px,3vw,30px);letter-spacing:-.01em}
p{margin:0 0 1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.muted{color:var(--mut)}
.center{text-align:center}

/* ── Header ─────────────────────────────────────────── */
header.site{position:sticky;top:0;z-index:40;background:rgba(0,0,0,.85);
  backdrop-filter:blur(10px)}
header.site .bar{display:flex;align-items:center;gap:24px;height:62px}
.brand{display:inline-flex;align-items:center;gap:9px;font-weight:400;font-size:19px;letter-spacing:-.02em;color:var(--txt);white-space:nowrap}
.brand:hover{text-decoration:none}
.brand b{color:var(--accent);font-weight:400}
.brand .logo{display:inline-flex;color:var(--accent);flex:none}
.brand .logo svg{display:block}
header.site nav{display:flex;gap:22px;flex:1}
header.site nav a{color:var(--mut);font-weight:500;font-size:15px;white-space:nowrap}
header.site nav a:hover{color:var(--txt);text-decoration:none}
/* У залогиненного в меню 6 пунктов + баланс и почта справа: ужимаем зазор,
   чтобы всё помещалось в 1080px без переносов (класс ставит auth.js). */
header.site nav.nav-in{gap:18px}
.auth{display:flex;gap:10px;align-items:center}
.auth .btn-ghost::before{content:"[ ";color:var(--mut);transition:.15s}
.auth .btn-ghost::after{content:" ]";color:var(--mut);transition:.15s}
.auth .btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.auth .btn-ghost:hover::before,.auth .btn-ghost:hover::after{color:var(--accent)}
.btn{display:inline-block;border:0;border-radius:10px;padding:10px 18px;font:inherit;
  font-weight:600;cursor:pointer;font-size:15px;transition:.15s}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--accent);color:#000}
.btn-primary:hover{background:var(--accent-d)}
.btn-ghost{background:transparent;color:var(--txt);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--mut)}
.btn-lg{padding:13px 26px;font-size:16px;border-radius:11px}
.nav-toggle{display:none}
/* ── Правый кластер шапки залогиненного ─────────────────
   баланс + [ почта ] с дропдауном; разметку строит auth.js.
   Блок скопирован в src/ui/theme.ts (шапка кабинета) — правки вносить в оба файла. */
header.site .hauth{display:flex;align-items:center;gap:14px;margin-left:auto}
header.site .hauth .who{background:none;border:0;padding:0;font:inherit;color:var(--txt);font-weight:500;font-size:15px;cursor:pointer;display:inline-flex;align-items:center;transition:.15s}
header.site .hauth .who::before{content:"[ ";color:var(--mut)}
header.site .hauth .who::after{content:" ]";color:var(--mut)}
header.site .hauth .who:hover,header.site .hauth .who:hover::before,header.site .hauth .who:hover::after{color:var(--accent)}
.who .who-t{display:inline-block;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* Баланс окрашен по состоянию (t-класс приходит из /api/me как balance_level);
   на hover — акцентный, как почта (.who) рядом. */
.hbal{color:var(--txt);font-weight:500;font-size:15px;white-space:nowrap;transition:.15s}
.hbal:hover{color:var(--accent)}
.t-ok{color:var(--ok)}
.t-warn{color:var(--warn)}
.t-bad{color:var(--bad)}
.hmenu-wrap{position:relative}
.hmenu{display:none;position:absolute;right:0;top:calc(100% + 12px);background:var(--card);border:1px solid var(--line);border-radius:10px;min-width:220px;z-index:50;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.hmenu.open{display:block}
.hmenu a,.hmenu button{display:block;width:100%;text-align:left;background:none;border:0;color:var(--txt);padding:10px 14px;font:inherit;font-size:14px;cursor:pointer}
.hmenu a:hover,.hmenu button:hover{background:#0c0e12;text-decoration:none}
.hmenu form{margin:0;border-top:1px solid var(--line)}
.hmenu .danger{color:var(--bad)}
header.site nav a.active{color:var(--txt)}

/* ── Hero ───────────────────────────────────────────── */
.hero{padding:48px 0 56px;
  background:radial-gradient(1100px 480px at 50% -120px,rgba(203,197,234,.14),transparent)}
.hero h1{font-size:clamp(22px,3vw,30px);letter-spacing:-.01em;margin:0 0 12px}
.hero .seclabel{margin-bottom:0}
.pill{display:inline-block;font-size:13px;color:var(--accent);background:rgba(203,197,234,.1);
  border:1px solid rgba(203,197,234,.25);border-radius:30px;padding:5px 14px;margin-bottom:22px}

/* ── Sections ───────────────────────────────────────── */
section{padding:56px 0}
section.alt{background:var(--bg)}
.section-head{text-align:center;max-width:640px;margin:0 auto 40px}
.section-head p{color:var(--mut);margin:0}

.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px}
.card h3{font-size:18px;margin-bottom:8px}
.card p{color:var(--mut);margin:0;font-size:15px}
.ico{width:40px;height:40px;border-radius:10px;background:rgba(203,197,234,.14);color:var(--accent);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px}

.steps{counter-reset:s}
.step{position:relative;padding-left:54px;margin-bottom:26px}
.step::before{counter-increment:s;content:counter(s);position:absolute;left:0;top:0;
  width:36px;height:36px;border-radius:50%;background:var(--accent);color:#000;
  display:flex;align-items:center;justify-content:center;font-weight:700}
.step h3{font-size:17px;margin-bottom:4px}
.step p{color:var(--mut);margin:0}

/* ── Code ───────────────────────────────────────────── */
pre,code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
pre{background:#0c0e12;border:1px solid var(--line);border-radius:12px;padding:18px 20px;
  overflow:auto;font-size:13.5px;line-height:1.55;margin:0 0 1em}
code{background:#0c0e12;border:1px solid var(--line);border-radius:6px;padding:2px 6px;font-size:.9em}
pre code{background:0;border:0;padding:0}
.tok-c{color:var(--mut)}.tok-s{color:#9ece6a}.tok-k{color:var(--accent)}

/* ── Внутренние страницы: заголовок как hero-h1, подпись как seclabel ─ */
.page{padding-bottom:30px}
.page-h1{font-size:clamp(22px,3vw,30px);letter-spacing:-.01em;margin:0 0 20px}
.sub-h{font-size:clamp(18px,2vw,22px);letter-spacing:-.01em;margin:30px 0 16px}

/* ── Tables / model list ────────────────────────────── */
.toolbar{display:flex;gap:12px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.toolbar input{flex:1;min-width:220px;background:#0c0e12;border:1px solid var(--line);
  border-radius:10px;color:var(--txt);padding:11px 14px;font:inherit}
/* No extra frame on focus (drops the browser/Safari focus ring on text fields). */
input:focus,select:focus,textarea:focus{outline:none;box-shadow:none}
.fbtn{flex:none;display:flex;align-items:center;justify-content:center;width:44px;height:44px;
  background:#0c0e12;border:1px solid var(--line);border-radius:10px;color:var(--mut);
  cursor:pointer;position:relative;transition:.15s}
.fbtn:hover{border-color:var(--mut);color:var(--txt)}
.fbtn.on{color:var(--accent);border-color:var(--accent)}
.fbtn.on::after{content:"";position:absolute;top:7px;right:7px;width:7px;height:7px;
  border-radius:50%;background:var(--accent);box-shadow:0 0 0 2px #0c0e12}
/* раскрывается плавно сверху вниз (grid-rows 0fr→1fr, симметрично в обе стороны) */
.fpanel{display:grid;grid-template-rows:0fr;margin:0;
  transition:grid-template-rows .3s ease,margin .3s ease}
.fpanel.open{grid-template-rows:1fr;margin:-2px 0 18px}
.fpanel-clip{overflow:hidden;min-height:0}
.fpanel-inner{border:1px solid var(--line);border-radius:10px;overflow:hidden}
.frow{display:flex;align-items:center;gap:16px;flex-wrap:wrap;min-height:44px;
  padding:8px 14px;background:#0c0e12}
.frow+.frow{border-top:1px solid var(--line)}
.flabel{color:var(--mut);font-size:12px;text-transform:uppercase;letter-spacing:.04em;min-width:64px}
/* кастомный чекбокс [ ] / [x] в моноширинном стиле сайта */
.fchk{display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-size:14px;
  color:var(--txt);user-select:none}
.fchk input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.fchk .cbx{color:var(--mut);font-weight:600;transition:color .15s}
.fchk .cbx::before{content:"[ ]"}
.fchk:hover .cbx{color:var(--txt)}
.fchk input:checked~.cbx{color:var(--accent)}
.fchk input:checked~.cbx::before{content:"[x]"}
.fchk input:focus-visible~.cbx{outline:1px solid var(--accent);outline-offset:2px}
table{width:100%;border-collapse:collapse;font-size:14.5px}
th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line)}
th{color:var(--mut);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
th.sortable{cursor:pointer;user-select:none;white-space:nowrap}
th.sortable:hover{color:var(--txt)}
th.sortable.act{color:var(--accent)}
.sar{display:inline-block;margin-left:6px;font-size:10px;color:var(--mut)}
th.sortable.act .sar{color:var(--accent)}
tbody tr:hover{background:var(--card)}
.mname{font-weight:600}
.mprov{color:var(--mut);font-size:12.5px}
.prov{display:inline-flex;align-items:center;gap:8px}
.pico{width:18px;height:18px;border-radius:4px;object-fit:contain;flex:none;background:#fff1}
.pico-mono{display:inline-flex;align-items:center;justify-content:center;color:#fff;
  font-size:10px;font-weight:700}
/* ── «Топ»: карточки моделей с логотипом провайдера ──── */
.mcard{display:block}
.mcard-head{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.mcard-head .pico{width:22px;height:22px;border-radius:5px}
.mcard-head b{font-size:15px;line-height:1.3;color:var(--txt)}
.mcard-spec{display:flex;justify-content:space-between;gap:12px;font-size:13.5px;padding:4px 0}
.mcard-spec span:first-child{color:var(--mut)}
.mcard-spec span:last-child{font-variant-numeric:tabular-nums}
/* ── Кнопка «наверх» под списком моделей ─────────────── */
.totop-wrap{text-align:center}
.totop{margin-top:44px;background:transparent;border:1px solid var(--line);color:var(--mut);
  font:inherit;font-weight:600;padding:9px 20px;border-radius:10px;cursor:pointer;transition:.15s}
.totop:hover{border-color:var(--accent);color:var(--accent)}
.tag{display:inline-block;font-size:12px;color:var(--mut);border:1px solid var(--line);
  border-radius:6px;padding:2px 8px;margin:0 6px 6px 0;background:var(--card)}

/* ── Model detail ───────────────────────────────────── */
.crumbs{font-size:13px;color:var(--mut);margin:28px 0 10px}
.crumbs a{color:var(--mut)}

/* заголовок: лого провайдера + название в стиле «~/ Модели» */
.model-title{display:flex;align-items:center;gap:14px;margin:20px 0 20px}
.model-title h1{margin:0}
.model-title .pico{width:34px;height:34px;border-radius:8px}
.model-title .pico-mono{width:34px;height:34px;border-radius:8px;font-size:17px}

/* строка "model":"…": зелёный токен без рамки + кнопка копирования сразу справа */
.copyline{display:flex;align-items:center;gap:6px;margin:6px 0 26px}
.copyline pre{margin:0;padding:0;background:0;border:0;border-radius:0;min-width:0;overflow:auto}
.copyline code{white-space:pre}
.copybtn{flex:none;display:inline-flex;align-items:center;justify-content:center;padding:4px;
  background:0;border:0;color:var(--mut);cursor:pointer;transition:.15s}
.copybtn:hover{color:var(--accent)}
.copybtn svg{display:block}
.copybtn .ic-ok{display:none}
.copybtn.ok{color:var(--ok)}
.copybtn.ok .ic-copy{display:none}
.copybtn.ok .ic-ok{display:block}

/* сетка: 3 карточки сверху, описание (2 колонки) + цена (3-я колонка) снизу */
.model-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start;margin:0 0 8px}
.model-grid .spec-card{padding:16px 18px}
.spec-card .k{color:var(--mut);margin-bottom:5px}
.spec-card .v{font-size:15px;font-weight:600}
.model-grid .model-desc{grid-column:1 / span 2;max-width:none;margin:0}
.model-grid .price-card{grid-column:3 / 4;margin:0}

.price-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px}
.price-card .k{color:var(--mut);margin-bottom:8px}
.price-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--line)}
.price-row:last-child{border:0}
.price-row .muted{font-size:13px}
.price-row .v{font-weight:600;font-variant-numeric:tabular-nums}
.price-sub{display:block;font-size:11px;line-height:1.3;margin-top:1px}

.model-desc{color:var(--txt)}
.model-desc p{margin:0 0 1em}
.model-desc p:last-child{margin-bottom:0}
.model-desc a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.model-desc ul,.model-desc ol{padding-left:22px;margin:0 0 1em}
.model-desc li{margin:4px 0}
.model-desc code{background:var(--card2);border:1px solid var(--line);border-radius:5px;
  padding:1px 5px;font-size:.92em}

/* поддерживаемые параметры: терминальный man-page список */
.params{margin:14px 0 0}
.param{padding:13px 0}
.param+.param{border-top:1px solid var(--line)}
.param-head{display:flex;gap:14px;align-items:baseline;flex-wrap:wrap}
.param-orig{color:#9ece6a;font-size:13.5px}
.param-orig::before{content:"> ";color:var(--mut)}
.param-ru{color:var(--txt);font-weight:600}
.param-desc{color:var(--mut);font-size:13px;line-height:1.55;margin:5px 0 0}

/* быстрый старт: во всю ширину, кнопка копирования — внутри блока с кодом, справа вверху */
.quickstart{margin-top:34px}
.qs-code{position:relative}
.qs-copy{position:absolute;top:8px;right:10px}

/* ── FAQ ────────────────────────────────────────────── */
/* padding живёт на summary, а не на details: так кликабелен весь блок вопроса */
details{background:var(--card);border:1px solid var(--line);border-radius:12px;
  margin-bottom:12px;transition:border-color .15s}
details:hover{border-color:var(--accent-d)}
details summary{cursor:pointer;font-weight:600;list-style:none;padding:16px 20px}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"[+]";float:right;color:var(--mut)}
details[open] summary::after{content:"[–]"}
details p{margin:0;padding:0 20px 16px;color:var(--mut)}

/* ── Страница «Цены» ────────────────────────────────── */
.price-cols{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;margin-top:30px}
.price-cols>*{min-width:0}
/* чек-лист принципов: маркер «[x]» как у чекбоксов фильтров */
.checklist{list-style:none;padding:0;margin:0}
.checklist li{position:relative;padding-left:40px;margin-bottom:20px;color:var(--mut);font-size:14.5px}
.checklist li:last-child{margin-bottom:0}
.checklist li::before{content:"[x]";position:absolute;left:0;top:0;color:var(--accent);font-weight:600}
.checklist li b{display:block;color:var(--txt);font-size:15.5px;margin-bottom:2px}
/* мини-прайс: на узких экранах таблица скроллится внутри, не распирая страницу */
.tscroll{overflow-x:auto;margin-top:6px}
.ptable .prov{gap:10px}
.ptable td:first-child{min-width:220px}
.ptable .num{white-space:nowrap}
.ptable .mname:hover{color:var(--accent)}
.linkmore-wrap{text-align:center;margin-top:22px}
.linkmore{color:var(--txt);font-weight:600}
.linkmore::before{content:"[ ";color:var(--mut);transition:.15s}
.linkmore::after{content:" ]";color:var(--mut);transition:.15s}
.linkmore:hover{color:var(--accent)}
.linkmore:hover::before,.linkmore:hover::after{color:var(--accent)}
/* способы оплаты: «[ СБП ]»-плашки + строки-выводы терминала */
.paytags{display:flex;flex-wrap:wrap;gap:10px 18px;margin:18px 0 22px}
.paytag{white-space:nowrap;color:var(--txt);font-size:14.5px}
.paytag::before{content:"[ ";color:var(--mut)}
.paytag::after{content:" ]";color:var(--mut)}
.tline{color:var(--mut);font-size:14px;margin:0 0 7px}
.tline::before{content:"> ";color:var(--ok)}

/* ── Footer ─────────────────────────────────────────── */
footer.site{border-top:1px solid var(--line);background:var(--bg2);padding:44px 0;margin-top:40px}
footer.site .cols{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
footer.site a{color:var(--mut);display:block;margin:6px 0;font-size:14px}
footer.site a:hover{color:var(--txt);text-decoration:none}
footer.site .brand{display:inline-flex;font-size:19px;color:var(--txt);margin:0 0 10px}
footer.site .brand:hover{color:var(--txt)}
footer.site .col h4{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--mut);margin:0 0 10px}
footer.site .legal{margin-top:28px;color:var(--mut);font-size:13px}
footer.site .legal-links{margin-top:6px}
footer.site .legal-links a{display:inline-block;margin:0 20px 0 0;font-size:13px}

/* ── Legal documents ────────────────────────────────── */
.legal-doc{padding-bottom:30px}
.legal-doc h1{margin-top:16px}
.legal-doc h2{margin-top:32px;font-size:23px}
.legal-doc h3{margin-top:24px;font-size:18px}
.legal-doc p,.legal-doc li{color:var(--txt)}
.legal-doc ul,.legal-doc ol{padding-left:22px;margin:0 0 1em}
.legal-doc li{margin:5px 0}
.legal-doc table{margin:6px 0 1.4em}
.legal-doc td{vertical-align:top}
blockquote.note{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--warn);
  border-radius:8px;padding:12px 16px;margin:0 0 1.4em;color:var(--mut)}

/* ── Stats (в футере, на месте колонок ссылок) ──────── */
.stats{display:flex;gap:38px;justify-content:center;flex-wrap:wrap;margin:0}
footer.site .cols{align-items:center}
.stat{text-align:center}
.stat .v{font-size:24px;font-weight:700;color:var(--accent)}
.stat .k{font-size:12.5px;color:var(--mut)}
/* кликабельная стата (313 моделей): меняется только курсор */
footer.site a.stat{display:block;margin:0}
footer.site a.stat:hover .v{color:var(--accent)}
footer.site a.stat:hover .k{color:var(--mut)}

/* ── «Как это работает»: сеть + терминал ────────────── */
.seclabel{color:var(--mut);font-size:13px;margin-bottom:10px;letter-spacing:.02em}
.seclabel::before{content:"// ";color:var(--accent)}
.hiw{display:grid;grid-template-columns:1.35fr 1fr;gap:22px;align-items:center;margin-top:26px}
.hiw>*{min-width:0}
.hiw-label{color:#55555e;font-size:11px;letter-spacing:2px;margin-bottom:12px}

/* пиксельная схема маршрутизации: canvas + DOM-чипы провайдеров */
.net{position:relative;container-type:inline-size}
.net canvas{display:block;width:100%;height:auto;image-rendering:pixelated}
.net-tag{position:absolute;color:#55555e;font-size:11px;font-size:clamp(8px,1.9cqw,11px);letter-spacing:2px}
.net-chip{position:absolute;left:0;transform:translateY(-50%);width:31%;
  display:flex;align-items:center;gap:8px;padding:3px 9px;
  background:var(--card);border:1px solid #2e2e38;border-radius:0;
  box-shadow:3px 3px 0 0 rgba(0,0,0,.55);
  color:#c9c9d1;font-size:13px;font-size:clamp(8px,2.2cqw,13.5px);
  white-space:nowrap;overflow:hidden;transition:border-color .25s}
.net-chip svg,.net-chip img{width:14px;width:clamp(9px,2.4cqw,15px);height:auto;flex:none;display:block}
#netmodel.sel{background:var(--accent);color:#000}
.term [hidden]{display:none!important}
.net-alabel{position:absolute;left:69.3%;top:62%;transform:translateX(-50%);
  text-align:center;line-height:1.5;font-size:12px;font-size:clamp(8px,2cqw,12.5px)}
.net-alabel b{display:block;color:var(--txt)}
.net-alabel span{display:block;color:var(--mut);font-size:.85em}
/* ── «Зачем это нужно»: пиксельная комната ──────────── */
.room{position:relative;margin-top:26px;container-type:inline-size}
.room canvas{display:block;width:100%;height:auto;image-rendering:pixelated;
  border:1px solid var(--line);border-radius:14px;background:#1c1636}
.room [hidden]{display:none!important}
.room-bubble{position:absolute;right:1.5%;top:4%;max-width:31%;background:rgba(10,9,16,.94);
  border:2px solid var(--txt);border-radius:2px;padding:12px 14px;
  box-shadow:4px 4px 0 0 rgba(0,0,0,.55);animation:roomin .22s steps(3)}
.room-bubble p{margin:0;font-size:13px;font-size:clamp(10px,1.5cqw,15px);line-height:1.45;color:var(--txt)}
.room-bubble button{display:block;margin:10px 0 0 auto;background:transparent;border:1px solid var(--accent);color:var(--accent);
  font:inherit;font-weight:600;padding:3px 12px;cursor:pointer;border-radius:2px;
  font-size:12px;font-size:clamp(10px,1.4cqw,14px)}
.room-bubble button:hover{background:var(--accent);color:#000}
.room-tv{position:absolute;left:33.9%;top:36%;width:14.6%;height:21.3%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  text-align:center;overflow:hidden;animation:roomin .25s steps(4)}
.room-tv .badge{font-size:7px;font-size:clamp(5px,.8cqw,8px);letter-spacing:.08em;text-transform:uppercase;
  background:#C20114;color:#fff;padding:0 5px;border-radius:1px;white-space:nowrap}
.room-tv p{margin:0;font-size:9px;font-size:clamp(6px,1cqw,10px);line-height:1.3;color:#fff}
.room-tv .logo svg{display:block;width:22px;width:clamp(12px,2.4cqw,24px);height:auto}
@keyframes roomin{from{opacity:0}to{opacity:1}}

/* ── «Какие боли закрываем»: Морфеус с таблетками ───── */
.pills{position:relative;margin-top:26px;container-type:inline-size}
.pills canvas{display:block;width:100%;height:auto;image-rendering:pixelated}
.pill-block{position:absolute;top:50%;transform:translateY(-50%);width:25%;transition:opacity .28s}
.pill-block.fade{opacity:0}
.pill-yes{left:8.5%}
.pill-no{right:8.5%}
.pill-block h3{margin:0 0 8px;font-size:15px;font-size:clamp(11px,1.5cqw,16px);line-height:1.35}
.pill-yes h3{color:#ff5a68}
.pill-no h3{color:#8fa8f0}
.pill-block p{margin:0;color:var(--mut);font-size:13px;font-size:clamp(10px,1.3cqw,14px);line-height:1.5}
.pill-nav{position:absolute;left:50%;top:88%;transform:translateX(-50%);margin-top:2.2em;z-index:3;background:transparent;
  border:1px solid var(--accent);color:var(--accent);font:inherit;font-weight:600;
  padding:5px 14px;cursor:pointer;border-radius:2px;font-size:13px;font-size:clamp(11px,1.5cqw,15px)}
.pill-nav:hover{background:var(--accent);color:#000}
@container (max-width:620px){
  .pills canvas{width:72%;margin:0 auto}
  .pill-block{position:static;width:auto;transform:none;margin-top:14px}
  .pill-nav{position:static;transform:none;display:block;margin:16px auto 0}
}
@container (max-width:620px){
  .room-bubble{max-width:46%}
  .room-tv{left:32.4%;width:18%}
}

/* окно «Ваше приложение» — пиксельная рамка в стиле остальных сцен */
.term{background:#000;border:2px solid #2e2e38;border-radius:0;overflow:hidden;
  box-shadow:6px 6px 0 0 rgba(0,0,0,.55)}
.term-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;
  border-bottom:2px solid #2e2e38;background:#000}
.term-bar .dot{width:10px;height:10px;border-radius:0;flex:none}
.dot-r{background:#7a2730}.dot-y{background:#7a6427}.dot-g{background:#2b6e4d}
.term-title{flex:1;text-align:center;color:var(--mut);font-size:12.5px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:48px}
.term-body{position:relative;padding:16px 18px;font-size:13px;line-height:1.65;
  white-space:pre-wrap;overflow-wrap:anywhere}
.term-body::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.013) 0 1px,transparent 1px 3px)}
.term-body code{display:block;background:0;border:0;padding:0;font-size:inherit;border-radius:0}
#demo{min-height:196px}
.t-p{color:var(--ok)}.t-s{color:#9ece6a}.t-f{color:var(--accent)}.t-m{color:var(--mut)}
.cursor{display:inline-block;width:.58em;height:1.05em;background:var(--accent);
  vertical-align:-.12em;margin-left:2px;animation:blink 1.06s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

@media(max-width:980px){
  .hiw{grid-template-columns:1fr}
  .price-cols{grid-template-columns:1fr}
}
@media(max-width:760px){
  .grid-3,.grid-2{grid-template-columns:1fr}
  header.site nav{display:none}
  .model-grid{grid-template-columns:1fr}
  .model-grid .model-desc,.model-grid .price-card{grid-column:auto}
}
@media(max-width:480px){
  .wrap{padding:0 14px}
  header.site .bar{gap:10px}
  .brand{font-size:17px}
  .auth .btn{padding:8px 10px;font-size:13px}
}
@media(prefers-reduced-motion:reduce){
  .hiw .pulse{display:none}
  .cursor{animation:none}
  .room-bubble,.room-tv{animation:none}
}

/* ── Документация API (/docs): полноширинный заголовок + меню слева + контент ── */
.docs-layout{display:grid;grid-template-columns:200px 1fr;gap:0 40px;align-items:start;max-width:1060px}
.docs-title{grid-column:1/-1}
.docs-main{min-width:0;padding-bottom:56px}
/* Снимаем глобальный section{padding:56px 0} внутри доки — иначе пустой отступ сверху */
.docs-main section{scroll-margin-top:80px;padding:0}
.docs-main>.api-endpoint:first-child{margin-top:0;padding-top:0;border-top:0}
.docs-main>section:first-child,.docs-main>section:first-child>:first-child{margin-top:0}
.docs-toc{position:sticky;top:78px;align-self:start;max-height:calc(100vh - 96px);overflow:auto;font-size:13px}
/* Перелинковка методов на хабе */
.api-index{margin:6px 0 10px}
.api-index-row{display:grid;grid-template-columns:62px minmax(160px,220px) 1fr;gap:14px;align-items:baseline;padding:9px 10px;border:1px solid transparent;border-radius:8px}
.api-index-row:hover{background:#0c0e12;border-color:var(--line)}
.api-index-row .api-method{justify-self:start} /* пилюля по содержимому, не на всю колонку */
.api-index-name{color:var(--txt)}
.api-index-sum{color:var(--mut);font-size:13px;line-height:1.5}
/* «Будет полезно» на быстром старте */
.docs-list{margin:8px 0 0;padding-left:20px;color:var(--mut)}
.docs-list li{margin:8px 0;line-height:1.6}
.docs-list a{text-decoration:underline;text-underline-offset:2px}
.lnk-postman{color:#EE7547}
.lnk-postman:hover{color:#e2632f}
/* Конверт ошибки на странице «Ошибки» — красный, как «Выйти» в ЛК (--bad) */
.code-bad,.code-bad code{color:var(--bad)}
.docs-toc a{display:block;color:var(--mut);padding:3px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.docs-toc a::before{content:"> ";color:#33333a}
.docs-toc a:hover{color:var(--txt)}
.docs-toc a.active{color:var(--accent)}
.docs-toc a.active::before{color:var(--accent)}
.docs-toc .toc-group{color:var(--mut);font-size:11px;text-transform:uppercase;letter-spacing:.05em;margin:18px 0 6px;opacity:.7}
.docs-toc .toc-group:first-child{margin-top:0}
/* Кнопка скачивания Postman — фирменный оранжевый Postman */
.btn-postman{background:#EE7547;color:#fff;border-color:#EE7547}
.btn-postman:hover{background:#e2632f;border-color:#e2632f;color:#fff}

.docs-main .api-h2{font-size:clamp(20px,2.4vw,26px);margin:42px 0 12px}
#overview.api-h2,.docs-main #overview .api-h2{margin-top:0}
.api-group{margin:48px 0 6px}
.api-sub{margin:20px 0 8px;font-size:14px;color:var(--mut)}
.api-status{color:var(--ok);font-size:12px;font-weight:400}
.api-endpoint{margin:36px 0;padding-top:20px;border-top:1px solid var(--line)}
.api-endpoint h3{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:18px;margin:0}
.api-path{color:var(--txt);font-size:15px}
.api-note{color:var(--mut);font-size:13px;line-height:1.6;border-left:2px solid var(--line);padding-left:12px;margin-top:12px}

/* HTTP-метод как «пилюля»: GET зелёный, POST оранжевый, PUT/PATCH сиреневый, DELETE красный */
.api-method{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.05em;padding:2px 8px;border-radius:5px;border:1px solid;text-transform:uppercase}
.api-get{color:var(--ok);border-color:var(--ok);background:rgba(63,191,127,.08)}
.api-post{color:var(--warn);border-color:var(--warn);background:rgba(224,168,63,.08)}
.api-put,.api-patch{color:var(--accent);border-color:var(--accent);background:rgba(203,197,234,.08)}
.api-delete{color:var(--bad);border-color:var(--bad);background:rgba(194,1,20,.14)}
.api-badge{display:inline-block;font-size:11px;color:var(--accent);background:rgba(203,197,234,.1);border:1px solid rgba(203,197,234,.25);border-radius:30px;padding:1px 10px}

/* Строка запроса: метод + полный URL + копирование */
.req-line{display:flex;align-items:center;gap:10px;background:#0c0e12;border:1px solid var(--line);border-radius:10px;padding:10px 14px;margin:12px 0}
.req-path{background:0;border:0;padding:0;color:var(--txt);font-size:13.5px;overflow:auto;white-space:nowrap;flex:1}
.req-line .copybtn{flex:none}

.param-type{color:var(--mut);font-size:12px;border:1px solid var(--line);border-radius:4px;padding:0 6px}
.param-req{color:var(--warn);font-size:11px;letter-spacing:.04em}
.param-req::before{content:"* "}

/* Вкладки примеров кода (curl / Python / JS) */
.code-tabs{margin:8px 0 4px}
.tab-btns{display:flex;flex-wrap:wrap;border:1px solid var(--line);border-bottom:0;border-radius:10px 10px 0 0;overflow:hidden;background:#0c0e12}
.tab-btn{background:0;border:0;border-right:1px solid var(--line);color:var(--mut);font:inherit;font-size:12.5px;padding:8px 16px;cursor:pointer;transition:.15s}
.tab-btn:hover{color:var(--txt)}
.tab-btn.active{color:var(--accent)}
.tab-btn.active::before{content:"> ";color:var(--accent)}
.code-tabs .tab-pane{display:none;position:relative}
.code-tabs .tab-pane.active{display:block}
.code-tabs pre{border-radius:0 0 12px 12px;margin:0}
.code-tabs .tab-pane>.copybtn{position:absolute;top:10px;right:12px;z-index:1}

@media(max-width:860px){
  .docs-layout{grid-template-columns:1fr}
  .docs-toc{display:none}
  .api-index-row{grid-template-columns:1fr;gap:4px}
}

/* ── Cookie-баннер: прибит к низу ЭКРАНА (fixed), терминальная «полка» в духе .term ── */
.cookie-bar{position:fixed;left:0;right:0;bottom:0;z-index:50;
  background:var(--bg);border-top:1px solid var(--line);
  transition:transform .4s ease;animation:cookiein .28s steps(4)}
.cookie-bar.is-out{transform:translateY(120%)}
.cookie-row{display:flex;align-items:center;gap:16px;padding:12px 20px}
.cookie-ico{flex:none;line-height:0}
.cookie-ico .cookie-svg{width:34px;height:34px;image-rendering:pixelated;display:block}
.cookie-txt{flex:1;color:var(--mut);font-size:13.5px;line-height:1.5}
.cookie-txt a{color:var(--accent);text-decoration:none}
.cookie-txt a:hover{color:var(--accent-d)}
/* Кнопка в стиле [ Войти ] (.auth .btn-ghost): прозрачная, скобки + акцент на hover */
.cookie-ok{flex:none;white-space:nowrap}
.cookie-ok::before{content:"[ ";color:var(--mut);transition:.15s}
.cookie-ok::after{content:" ]";color:var(--mut);transition:.15s}
.cookie-ok:hover{border-color:var(--accent);color:var(--accent)}
.cookie-ok:hover::before,.cookie-ok:hover::after{color:var(--accent)}
@keyframes cookiein{from{transform:translateY(100%)}to{transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){.cookie-bar{animation:none}.cookie-bar.is-out{transition:none}}
