/* ============================================================
   SEO-GEO - Базовые компоненты клиентских продукт-экранов
   Направление «Чистый документ». Все значения - из tokens.css.
   Подключать ПОСЛЕ tokens.css:
     <link rel="stylesheet" href="tokens.css">
     <link rel="stylesheet" href="components.css">

   Принципы:
   - цвет точечно, разделение через границы и воздух, не «парение»;
   - честный блокер и дисклеймер выглядят спокойно, а не как ошибка;
   - брендовый лайм - только заливка/акцент, ссылки - --accent-ink.
   ============================================================ */

/* -------------------- Reset / база -------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Документная колонка */
.doc {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-7) var(--content-pad) var(--space-8);
}

/* -------------------- Типографика -------------------- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  color: var(--text-heading);
  line-height: var(--lh-tight);
  font-weight: var(--fw-bold);
  letter-spacing: -0.01em;
}
.display { font-family: var(--font-display); font-size: var(--fs-display); line-height: 1.15; font-weight: var(--fw-bold); letter-spacing: -0.02em; color: var(--text-heading); }
h1, .h1 { font-size: var(--fs-h1); }
h2, .h2 { font-size: var(--fs-h2); }
h3, .h3 { font-size: var(--fs-h3); }

p { margin: 0; }
.lead { font-size: var(--fs-lead); line-height: var(--lh-body); color: var(--text-secondary); }
.text-sm { font-size: var(--fs-sm); }
.text-muted { color: var(--text-muted); }
.text-secondary { color: var(--text-secondary); }

/* Метка-капс (над значением, в индикаторах, в таблицах) */
.label {
  font-size: var(--fs-2xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-label);
  color: var(--text-muted);
}

code, .mono { font-family: var(--font-mono); font-size: 0.92em; }

/* Ссылки - брендовый оттенок, но читаемый (--accent-ink), не лайм */
a, .link {
  color: var(--accent-ink);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  transition: color var(--transition);
}
a:hover, .link:hover { color: var(--accent-ink-hover); }

/* Доступный фокус для всех интерактивных элементов */
a:focus-visible, button:focus-visible, input:focus-visible,
summary:focus-visible, [tabindex]:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* -------------------- Кнопки / CTA -------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  line-height: 1;
  padding: 11px 20px;
  border: 1.5px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-decoration: none;
  transition: background var(--transition), border-color var(--transition), color var(--transition), opacity var(--transition);
}
.btn:disabled, .btn[aria-disabled="true"] { opacity: .5; cursor: not-allowed; }

/* Главный CTA - фирменная лаймовая заливка с тёмным текстом (как akrotova.ru) */
.btn--primary { background: var(--brand); color: var(--on-brand); border-color: var(--brand); }
.btn--primary:not(:disabled):hover { background: var(--brand-strong); border-color: var(--brand-strong); }

/* Вторичная - контурная, нейтральная */
.btn--secondary { background: var(--surface); color: var(--text); border-color: var(--border-strong); }
.btn--secondary:not(:disabled):hover { border-color: var(--brand-border); background: var(--brand-soft); }

/* Тихая текстовая кнопка */
.btn--ghost { background: transparent; color: var(--accent-ink); border-color: transparent; padding-left: 8px; padding-right: 8px; }
.btn--ghost:not(:disabled):hover { color: var(--accent-ink-hover); background: var(--brand-soft); }

/* Скачивание (PDF/Markdown) - сдержанная, не конкурирует с CTA */
.btn--download { background: var(--surface); color: var(--text-secondary); border-color: var(--border-strong); font-size: var(--fs-xs); padding: 9px 16px; }
.btn--download:not(:disabled):hover { border-color: var(--text-muted); }

.btn--sm { padding: 8px 14px; font-size: var(--fs-xs); }
.btn--block { width: 100%; }

/* Состояние «выбрано» для CTA пакета (тонкая обводка + галочка через разметку) */
.btn--selected { background: var(--brand); color: var(--on-brand); border-color: var(--brand-strong); }

/* -------------------- Иконки -------------------- */
/* Инлайн-SVG: размер из токенов, цвет наследуется через currentColor.
   Декоративные иконки в разметке несут aria-hidden="true" focusable="false". */
.icon { display: inline-block; flex-shrink: 0; width: var(--icon-sm); height: var(--icon-sm); vertical-align: middle; }
.icon--xs { width: var(--icon-xs); height: var(--icon-xs); }
.icon--chip { width: var(--icon-sm); height: var(--icon-sm); }

/* Квадратная плашка-иконка: мягкий бренд-фон, оливковая иконка.
   Переиспользуется в шапке контактов и в кикере. */
.icon-chip {
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
  width: var(--icon-chip); height: var(--icon-chip);
  background: var(--brand-soft); color: var(--accent-ink);
  border-radius: var(--radius-sm);
}

/* -------------------- Бейджи / статус-пилюли -------------------- */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: var(--fs-2xs);
  font-weight: var(--fw-bold);
  line-height: 1;
  padding: 5px 10px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
}
.badge--ok    { background: var(--ok-soft);   color: var(--ok-text); }
.badge--warn  { background: var(--warn-soft);  color: var(--warn-text); }
.badge--crit  { background: var(--crit-soft);  color: var(--crit-text); }
.badge--info  { background: var(--info-soft);  color: var(--info-text); }
.badge--brand { background: var(--brand-soft); color: var(--accent-ink); border: 1px solid var(--brand-border); }

/* Точка-индикатор перед текстом бейджа (необязательно) */
.badge__dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; flex-shrink: 0; }

/* Пилюля-статус в строках под-блоков (компактнее бейджа) */
.status-pill {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  padding: 2px 10px; border-radius: var(--radius-pill);
}
.status-pill--ok   { background: var(--ok-soft);   color: var(--ok-text); }
.status-pill--warn { background: var(--warn-soft);  color: var(--warn-text); }
.status-pill--crit { background: var(--crit-soft);  color: var(--crit-text); }
.status-pill--info { background: var(--info-soft);  color: var(--info-text); }

/* -------------------- Карточки -------------------- */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-5) var(--space-5);
  margin-bottom: var(--space-4);
  box-shadow: var(--shadow-sm);
}
.card__title { font-family: var(--font-display); font-size: var(--fs-h3); color: var(--text-heading); margin-bottom: var(--space-3); }
.card__lead  { font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-body); margin-bottom: var(--space-3); }

/* Карточка с акцентной левой чертой по severity */
.card--accent { border-left: 4px solid var(--border-strong); }
.card--ok    { border-left: 4px solid var(--ok-border); }
.card--warn  { border-left: 4px solid var(--warn-border); }
.card--crit  { border-left: 4px solid var(--crit-border); }
.card--brand { border-left: 4px solid var(--brand); background: var(--surface-accent); }

/* Шапка-плашка внутри карточки: мягкий бренд-фон, нижняя граница,
   контент выходит в края карточки (как у .tariff__band). Требует
   у карточки overflow: hidden, чтобы плашка обрезалась по радиусу.
   Негативные поля совпадают с паддингом .card (--space-5). */
.card--band { overflow: hidden; }
.card__band {
  display: flex; align-items: center; gap: var(--space-3);
  margin: calc(-1 * var(--space-5)) calc(-1 * var(--space-5)) var(--space-4);
  padding: var(--space-4) var(--space-5);
  background: var(--brand-soft);
  border-bottom: 1px solid var(--brand-border);
}
.card__band-title { font-family: var(--font-display); font-size: var(--fs-h3); font-weight: var(--fw-bold); color: var(--text-heading); line-height: var(--lh-tight); }

/* Ряд контакт-кнопок в блоке апселла (Telegram лаймом + email контуром) */
.upsell__contacts { display: flex; flex-wrap: wrap; gap: var(--space-3); margin: var(--space-4) 0; }

/* Бренд-панель первого экрана (форма ввода): мягкая подложка + бренд-граница,
   декоративный лаймовый круг за контентом. Только токены, без новых цветов. */
.input-hero {
  position: relative;
  overflow: hidden;
  background: var(--surface-accent);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}
.input-hero > * { position: relative; z-index: 1; }
/* Декоративный круг — чистый псевдоэлемент, не нужен aria-hidden */
.input-hero::after {
  content: "";
  position: absolute;
  z-index: 0;
  top: calc(-1 * var(--space-6));
  right: calc(-1 * var(--space-6));
  width: 180px; height: 180px;
  background: var(--brand-soft);
  border-radius: 50%;
}
.input-hero__kicker { margin-bottom: var(--space-3); }

/* -------------------- Шапка отчёта (блок 0) -------------------- */
.report-head { display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-5); align-items: baseline; justify-content: space-between; }
.report-head__url { font-family: var(--font-display); font-size: var(--fs-h2); font-weight: var(--fw-bold); color: var(--text-heading); word-break: break-word; }
.report-head__date { font-size: var(--fs-xs); color: var(--text-muted); }
.report-head__note { width: 100%; margin-top: var(--space-2); font-size: var(--fs-xs); color: var(--text-muted); line-height: var(--lh-snug); }

/* -------------------- Вердикт (блок 1) -------------------- */
.verdict-badge {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: var(--fs-sm); font-weight: var(--fw-bold);
  padding: 6px 14px; border-radius: var(--radius-pill); margin-bottom: var(--space-3);
}
/* Плотная статус-заливка с белым текстом (AA подтверждается на приёмке Фазы 5;
   если контраст не проходит — откат к мягкому --*-soft фону). */
.verdict-badge--good { background: var(--ok);   color: var(--surface); }
.verdict-badge--warn { background: var(--warn);  color: var(--surface); }
.verdict-badge--crit { background: var(--crit);  color: var(--surface); }
.verdict-summary { font-size: var(--fs-lead); color: var(--text); line-height: var(--lh-body); margin-bottom: var(--space-4); }

/* Индикаторы (сетка карточек-показателей) */
.indicators { display: grid; grid-template-columns: repeat(auto-fill, minmax(168px, 1fr)); gap: var(--space-3); }
.indicator { background: var(--surface-sunken); border-radius: var(--radius-sm); padding: var(--space-3) var(--space-3); }
.indicator__value { font-size: var(--fs-lead); font-weight: var(--fw-semibold); color: var(--text); margin-top: 4px; }
/* Цветной рейл = индикация по уже показанному числу (дублирует, не вводит новый смысл). */
.indicator--crit { border-left: 3px solid var(--crit-border); }
.indicator--warn { border-left: 3px solid var(--warn-border); }

/* -------------------- Рекомендации (план действий) -------------------- */
.rec {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 4px solid var(--border-strong);
  border-radius: var(--radius);
  padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-3);
}
.rec--crit   { border-left-color: var(--crit-border); }
.rec--high   { border-left-color: var(--high); }
.rec--medium { border-left-color: var(--warn-border); }
.rec--low    { border-left-color: var(--border-strong); }
.rec__head { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.rec__step { font-size: var(--fs-2xs); font-weight: var(--fw-bold); color: var(--accent-ink); letter-spacing: var(--tracking-label); }
.rec__priority { font-size: var(--fs-2xs); font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: var(--tracking-label); }
.rec__priority--crit   { color: var(--crit); }
.rec__priority--high   { color: var(--high); }
.rec__priority--medium { color: var(--warn); }
.rec__priority--low    { color: var(--text-muted); }
.rec__title { font-size: var(--fs-body); font-weight: var(--fw-semibold); color: var(--text); margin: var(--space-1) 0 var(--space-2); }
.rec__body { font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-body); }
.rec__body + .rec__body { margin-top: var(--space-2); }
.rec__steps { margin: var(--space-2) 0 0 18px; font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-body); }
.rec__caveat { margin-top: var(--space-2); padding: 7px 12px; background: var(--surface-sunken); border-radius: var(--radius-sm); font-size: var(--fs-xs); color: var(--text-muted); }
.rule-id { font-size: var(--fs-2xs); color: var(--text-muted); font-family: var(--font-mono); margin-bottom: 6px; }

/* -------------------- Таблицы -------------------- */
.table { width: 100%; border-collapse: collapse; font-size: var(--fs-xs); margin-top: var(--space-3); }
.table th, .table td { text-align: left; vertical-align: top; padding: 9px 11px; border: 1px solid var(--border); color: var(--text-secondary); line-height: var(--lh-snug); }
.table th { background: var(--surface-sunken); font-weight: var(--fw-bold); color: var(--text); font-size: var(--fs-2xs); text-transform: uppercase; letter-spacing: var(--tracking-label); }
.table td strong { color: var(--text); }
.table tr:nth-child(even) td { background: var(--surface); }
.table .is-muted { color: var(--text-muted); font-style: italic; }

/* -------------------- Теги / чипы -------------------- */
.tags { display: flex; flex-wrap: wrap; gap: 6px; }
.tag { font-size: var(--fs-2xs); font-weight: var(--fw-semibold); padding: 3px 9px; border-radius: var(--radius-pill); background: var(--info-soft); color: var(--info-text); }

.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  display: inline-flex; align-items: center; gap: 4px; max-width: 100%;
  font-size: var(--fs-xs); color: var(--text); background: var(--brand-soft);
  border: 1px solid var(--brand-border); border-radius: var(--radius-pill); padding: 4px 10px;
}
.chip strong { color: var(--accent-ink); white-space: nowrap; }

/* -------------------- Query-plan (полная картина спроса + этапы) -------------------- */
.qp-status {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: var(--fs-2xs); font-weight: var(--fw-bold);
  padding: 5px 10px; border-radius: var(--radius-pill);
  background: var(--info-soft); color: var(--info-text); margin-bottom: var(--space-2);
}
.qp-primary { font-size: var(--fs-sm); color: var(--text); margin-bottom: var(--space-2); }
.qp-note { font-size: var(--fs-xs); color: var(--text-muted); line-height: var(--lh-snug); margin-bottom: var(--space-3); }

/* Спрос vs страница - две панели */
.qp-world { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr); gap: var(--space-3); margin: var(--space-3) 0; }
.qp-panel { border: 1px solid var(--border); border-radius: var(--radius-sm); padding: var(--space-3) var(--space-3); background: var(--surface-accent); }
.qp-panel__title { font-size: var(--fs-sm); color: var(--text); margin-bottom: var(--space-2); font-weight: var(--fw-semibold); }

/* Этапы спроса - бакеты */
.qp-buckets { display: flex; flex-direction: column; gap: var(--space-3); margin: var(--space-3) 0; }
.qp-bucket { border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--surface); padding: var(--space-3); }
.qp-bucket__title { font-size: var(--fs-sm); color: var(--text); margin-bottom: var(--space-2); font-weight: var(--fw-semibold); }
.qp-bucket__summary { margin: 0 0 var(--space-2); padding: 8px 10px; border-radius: var(--radius-sm); background: var(--surface-sunken); color: var(--text-secondary); font-size: var(--fs-xs); line-height: var(--lh-snug); }
.qp-bucket__item { border-top: 1px solid var(--border); padding-top: var(--space-2); margin-top: var(--space-2); font-size: var(--fs-xs); color: var(--text-secondary); line-height: var(--lh-snug); }
.qp-bucket__item:first-of-type { border-top: 0; padding-top: 0; margin-top: 0; }
.qp-bucket__phrase { font-weight: var(--fw-bold); color: var(--text); }

/* Куда применить (title/H1/FAQ) */
.qp-targets { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-2); margin: var(--space-3) 0; }
.qp-target { border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--surface-accent); padding: var(--space-2) var(--space-3); font-size: var(--fs-xs); color: var(--text-secondary); line-height: var(--lh-snug); }
.qp-target strong { display: block; color: var(--text); margin-bottom: 4px; }

/* -------------------- GEO-план -------------------- */
.geo-question { padding: var(--space-3) 0; border-bottom: 1px solid var(--border); }
.geo-question:last-of-type { border-bottom: none; }
.geo-quote { margin: var(--space-2) 0 0; padding: 8px 12px; background: var(--surface-sunken); border-left: 3px solid var(--border-strong); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-size: var(--fs-xs); color: var(--text-secondary); font-style: italic; line-height: var(--lh-snug); }
.geo-plan-card { border: 1px solid var(--border); border-radius: var(--radius-sm); padding: var(--space-3) var(--space-3); margin: var(--space-3) 0; background: var(--surface-sunken); }
.geo-plan-card h4 { font-family: var(--font-sans); font-size: var(--fs-sm); color: var(--text); margin-bottom: var(--space-2); font-weight: var(--fw-semibold); }
.geo-plan-card__meta { font-size: var(--fs-xs); color: var(--text-secondary); line-height: var(--lh-snug); margin: 4px 0; }
.geo-plan-card__note { font-size: var(--fs-2xs); color: var(--text-muted); line-height: var(--lh-snug); margin-top: var(--space-2); }

/* -------------------- Дисклеймер -------------------- */
/* Спокойный, документный, НЕ как ошибка. */
.disclaimer { margin-top: var(--space-3); padding: var(--space-4) var(--space-4); background: var(--surface-sunken); border-radius: var(--radius-sm); font-size: var(--fs-xs); color: var(--text-secondary); line-height: var(--lh-body); }
.disclaimer--inline { margin-top: var(--space-3); padding: 10px 14px; background: var(--surface-sunken); border-radius: var(--radius-sm); font-size: var(--fs-xs); color: var(--text-secondary); line-height: var(--lh-snug); }

/* -------------------- Честный блокер vs ошибка (инвариант честности) -------------------- */
/* Блокер = ожидаемое ограничение (нет токена Wordstat, заблокированная
   страница). Спокойный нейтральный вид, НЕ красный «сломалось». */
.notice { border-radius: var(--radius); padding: var(--space-4) var(--space-5); margin-bottom: var(--space-4); line-height: var(--lh-body); }
.notice__title { font-family: var(--font-sans); font-size: var(--fs-body); font-weight: var(--fw-semibold); margin-bottom: var(--space-2); display: flex; align-items: center; gap: var(--space-2); }
.notice__body { font-size: var(--fs-sm); }
.notice--blocker { background: var(--info-soft); border: 1px solid var(--info-border); color: var(--text-secondary); }
.notice--blocker .notice__title { color: var(--text); }
/* Настоящая ошибка фетча - красный, отличается от блокера */
.notice--error { background: var(--crit-soft); border: 1px solid var(--crit-border); color: var(--crit-text); }
.notice--error .notice__title { color: var(--crit-text); }
.notice__detail { margin-top: var(--space-2); padding: 8px 12px; background: rgba(0,0,0,.03); border-radius: var(--radius-sm); font-family: var(--font-mono); font-size: var(--fs-2xs); color: var(--text-secondary); word-break: break-all; }

/* -------------------- Зелёная страница (нет проблем) -------------------- */
.green-summary__lead { background: var(--ok-soft); border-radius: var(--radius); padding: var(--space-3) var(--space-4); color: var(--ok-text); font-size: var(--fs-sm); margin-bottom: var(--space-4); }

/* Скрыто визуально, доступно скринридеру (подписи полей на однострочной форме) */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }

/* -------------------- Форма (экран ввода) -------------------- */
/* Поля и кнопка на одной линии, выровнены по высоте; главное поле шире, кнопка фикс. */
.form-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: var(--space-4); box-shadow: var(--shadow-sm); display: flex; gap: var(--space-3); flex-wrap: wrap; align-items: stretch; }
.input { flex: 1 1 260px; min-width: 220px; padding: 0 14px; height: 48px; border: 1.5px solid var(--border-strong); border-radius: var(--radius-sm); font-family: var(--font-sans); font-size: var(--fs-body); color: var(--text); background: var(--surface); outline: none; transition: border-color var(--transition); }
.input::placeholder { color: var(--text-muted); }
.input:focus { border-color: var(--focus-ring); }
/* Узкое поле (регион) - фиксированная ширина, не тянется */
.input--compact { flex: 0 0 168px; min-width: 132px; }
/* Кнопка формы фикс по высоте полей, не растягивается */
.form-card .btn { flex: 0 0 auto; height: 48px; }

/* Статус-бар (идёт аудит / ошибка) */
.status-bar { margin-top: var(--space-4); padding: var(--space-3) var(--space-4); border-radius: var(--radius-sm); font-size: var(--fs-sm); }
.status-bar--running { background: var(--brand-soft); color: var(--accent-ink); display: flex; align-items: center; gap: var(--space-3); }
.status-bar--error { background: var(--crit-soft); color: var(--crit-text); }
.spinner { width: 18px; height: 18px; border: 2.5px solid var(--brand-border); border-top-color: var(--accent-ink); border-radius: 50%; animation: spin .7s linear infinite; flex-shrink: 0; }
@keyframes spin { to { transform: rotate(360deg); } }

/* -------------------- Под-блоки разделов (SEO/GEO/Яндекс) -------------------- */
.subblock { padding: var(--space-3) 0; border-bottom: 1px solid var(--border); }
.subblock:last-child { border-bottom: none; }
.subblock__head { display: flex; align-items: center; gap: var(--space-2); font-size: var(--fs-sm); flex-wrap: wrap; }
.subblock__name { font-weight: var(--fw-semibold); color: var(--text); }

/* -------------------- Глубина отчёта (4b): детали проверок, заметки, черновики -------------------- */
/* «Что проверили» — раскрываемый список проверок под-блока (спокойный, документный). */
.subblock-details { margin-top: var(--space-2); }
.subblock-details > summary {
  cursor: pointer; list-style: none; display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--accent-ink);
  padding: 4px 0;
}
.subblock-details > summary::-webkit-details-marker { display: none; }
.subblock-details > summary::before { content: "▸"; font-size: 0.85em; transition: transform var(--transition); }
.subblock-details[open] > summary::before { transform: rotate(90deg); }
.subblock-checks { margin: var(--space-2) 0 0 18px; font-size: var(--fs-xs); color: var(--text-secondary); line-height: var(--lh-snug); }
.subblock-checks li { margin-bottom: 4px; }
.check-detail { color: var(--text-muted); }
.check-res--ok    { color: var(--ok);   font-weight: var(--fw-semibold); }
.check-res--warn  { color: var(--warn); font-weight: var(--fw-semibold); }
.check-res--crit  { color: var(--crit); font-weight: var(--fw-semibold); }
.check-res--muted { color: var(--text-muted); }
.subblock__improve { margin-top: var(--space-2); }
.subblock__improve-title { font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--text); }
.subblock__max { margin-top: var(--space-2); font-size: var(--fs-xs); color: var(--text-muted); }

/* Подзаголовок внутри раздела отчёта (мельче h2-блока, без гарнитуры заголовка). */
.sub-heading { font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--text-heading); margin: var(--space-4) 0 var(--space-2); }
/* Пояснительный абзац раздела — приглушённый, документный. */
.section-note { font-size: var(--fs-xs); color: var(--text-muted); line-height: var(--lh-body); margin: var(--space-2) 0; }
.section-note strong { color: var(--text-secondary); }

/* GEO: вводный абзац и заметка под вопросом. */
.geo-intro { font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-body); margin-bottom: var(--space-3); }
.geo-note { margin-top: var(--space-2); font-size: var(--fs-xs); color: var(--text-secondary); line-height: var(--lh-snug); }

/* Скролл-обёртка таблиц — на узких экранах таблица не ломает колонку. */
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* Готовые тексты (ready_texts) — карточка-черновик для вставки. */
.draft-card { border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--surface-sunken); padding: var(--space-3) var(--space-4); margin-bottom: var(--space-3); }
.draft-card__label { font-size: var(--fs-2xs); font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: var(--tracking-label); color: var(--text-muted); margin-bottom: var(--space-2); }
.draft-card__value { font-size: var(--fs-sm); color: var(--text); line-height: var(--lh-body); }
.draft-card__value.is-empty { color: var(--text-muted); font-style: italic; }
.draft-card__variants { list-style: none; display: flex; flex-direction: column; gap: var(--space-2); }
.draft-card__variants li { position: relative; padding-left: 16px; font-size: var(--fs-sm); color: var(--text); line-height: var(--lh-snug); }
.draft-card__variants li::before { content: "—"; position: absolute; left: 0; color: var(--text-muted); }
.draft-card__variants--faq li { padding-left: 0; }
.draft-card__variants--faq li::before { content: none; }
.draft-card__variants--faq strong { color: var(--text-heading); }

/* -------------------- Внедрение (4c): структура / ТЗ / дорожная карта / объём / расширение -------------------- */
/* Документный список — нумерованный (структура страницы) или маркированный
   (ТЗ, пункты этапов и идей). Спокойный, читаемый, от токенов. */
.doc-list { margin: var(--space-2) 0 0 20px; font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-body); }
.doc-list li { margin-bottom: var(--space-2); }
.doc-list li:last-child { margin-bottom: 0; }
.doc-list li strong { color: var(--text); }
.doc-list .doc-list { margin-top: var(--space-1); margin-bottom: var(--space-1); }
/* «Где внедрять» — приглушённая подпись в пункте ТЗ. */
.doc-where { color: var(--text-muted); font-size: var(--fs-xs); }
/* Приоритет «эффект / трудозатраты» — нейтральная подпись рядом с пунктом. */
.prio-note { font-size: var(--fs-xs); color: var(--text-muted); }

/* Карточка-идея: горизонт роста, этап объёма работ, идея расширения.
   Тот же спокойный документный вид, что и у GEO-плана. */
.idea-card { border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--surface-sunken); padding: var(--space-3) var(--space-4); margin: var(--space-3) 0; }
.idea-card__head { font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--text); margin-bottom: var(--space-2); }

/* -------------------- Пакет-переключатель / бейдж пакета -------------------- */
.pkg-toggle { display: inline-flex; gap: 6px; flex-wrap: wrap; }
.pkg-toggle button { border: 1.5px solid var(--border-strong); background: var(--surface); color: var(--text-secondary); padding: 6px 12px; border-radius: var(--radius-sm); font-family: var(--font-sans); font-size: var(--fs-xs); font-weight: var(--fw-semibold); cursor: pointer; transition: var(--transition); }
.pkg-toggle button:hover { border-color: var(--text-muted); }
.pkg-toggle button.is-active { background: var(--brand); color: var(--on-brand); border-color: var(--brand); }
.pkg-badge { display: inline-block; font-size: var(--fs-2xs); font-weight: var(--fw-bold); padding: 4px 11px; border-radius: var(--radius-pill); background: var(--brand-soft); color: var(--accent-ink); border: 1px solid var(--brand-border); }

/* -------------------- Тарифные карточки (витрина пакетов) -------------------- */
/* Считываемая продающая карточка: крупная цена, заметный заголовок,
   галочки у «что входит», CTA на всю ширину. Все значения - из токенов.
   Выбор пакета = фирменное кольцо; «рекомендуем/хит» по умолчанию нет. */
/* Email для чека/доступа — над сеткой тарифов; компактный, в одну колонку. */
.pkg-email { display: flex; flex-direction: column; gap: var(--space-1); max-width: 28rem; margin-bottom: var(--space-4); }
.tariff-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-4); }
.tariff {
  display: flex; flex-direction: column;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  overflow: hidden; /* шапка-плашка выходит в края карточки и обрезается по радиусу */
  transition: border-color var(--transition), box-shadow var(--transition);
}
.tariff:hover { border-color: var(--border-strong); box-shadow: var(--shadow); }

/* Шапка карточки — равная высота у всех (правило равных карточек):
   слот бейджа зарезервирован на ВСЕХ карточках и выровнен вправо,
   подзаголовок-результат фиксирован под 2 строки. Плашка выходит в края. */
.tariff__band {
  margin: calc(-1 * var(--space-5)) calc(-1 * var(--space-5)) var(--space-2);
  padding: var(--space-4) var(--space-5) var(--space-3);
  background: var(--brand-soft);
  border-bottom: 1px solid var(--brand-border);
}
.tariff__badge-slot { display: flex; justify-content: flex-end; align-items: center; height: 22px; margin-bottom: var(--space-2); }
.tariff__rec-badge {
  display: inline-block; line-height: 1;
  font-size: var(--fs-2xs); font-weight: var(--fw-bold);
  text-transform: uppercase; letter-spacing: var(--tracking-label);
  padding: 4px 11px; border-radius: var(--radius-pill);
  background: var(--on-brand); color: var(--brand);
}
.tariff__band .tariff__result { min-height: 2.9em; }

/* Выделенный пакет («Популярный»): фирменная заливка шапки, кольцо, мягкая подложка */
.tariff--featured { border-color: var(--brand-strong); background: var(--surface-accent); box-shadow: 0 0 0 2px var(--brand-strong), var(--shadow); }
.tariff--featured .tariff__band { background: var(--brand); border-bottom-color: var(--brand-strong); }
.tariff__name { font-family: var(--font-display); font-size: var(--fs-h2); font-weight: var(--fw-bold); color: var(--text-heading); letter-spacing: -0.01em; }
.tariff__result { margin-top: var(--space-2); font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-snug); min-height: 2.7em; }
.tariff__price { display: flex; align-items: baseline; gap: 6px; margin: var(--space-4) 0 var(--space-1); }
.tariff__amount { font-family: var(--font-display); font-size: var(--fs-price); font-weight: var(--fw-bold); color: var(--accent-ink); line-height: 1; letter-spacing: -0.02em; }
.tariff__currency { font-size: var(--fs-h3); font-weight: var(--fw-semibold); color: var(--text-secondary); }
.tariff__price-note { font-size: var(--fs-xs); color: var(--text-muted); margin-bottom: var(--space-4); }
.tariff__divider { border: 0; border-top: 1px solid var(--border); margin: 0 0 var(--space-4); }
.tariff__label { display: block; margin-bottom: var(--space-2); }
.tariff__list { list-style: none; display: flex; flex-direction: column; gap: var(--space-2); margin: 0 0 var(--space-4); }
.tariff__list:last-of-type { margin-bottom: var(--space-5); }
.tariff__item { position: relative; padding-left: 24px; font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-snug); }
.tariff__item::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--ok); font-weight: var(--fw-bold); }
.tariff__list--out .tariff__item { color: var(--text-muted); }
.tariff__list--out .tariff__item::before { content: "–"; color: var(--text-muted); }
.tariff__cta { margin-top: auto; }

/* Выбранный пакет - фирменное лаймовое кольцо */
.tariff.is-selected { border-color: var(--brand-strong); box-shadow: 0 0 0 2px var(--brand-strong), var(--shadow); }

@media (max-width: 860px) {
  .tariff-grid { grid-template-columns: 1fr; }
}

/* -------------------- Адаптив -------------------- */
@media (max-width: 720px) {
  .doc { padding: var(--space-5) 16px var(--space-7); }
  .qp-world { grid-template-columns: 1fr; }
  .qp-targets { grid-template-columns: 1fr; }
  .display { font-size: 1.875rem; }
}

/* Узкий телефон: клиентские блоки отчёта остаются читаемыми */
@media (max-width: 480px) {
  .indicators { grid-template-columns: 1fr 1fr; }
  .geo-plan-card, .idea-card, .rec, .subblock { padding: var(--space-3); }
  .form-card { flex-direction: column; align-items: stretch; }
  /* В column flex-basis: 260px из base .input управляет высотой — сбрасываем,
     иначе поля раздуваются на весь экран. */
  .form-card .input, .form-card .btn { width: 100%; flex: 0 0 auto; }
}

/* -------------------- Печать / PDF -------------------- */
@media print {
  body { background: #fff; }
  .card, .rec, .notice { box-shadow: none; break-inside: avoid; }
  .btn, .form-card, .status-bar { display: none !important; }
  /* Бренд-панель формы в печати — без подложки/границы/декор-круга */
  .input-hero { background: none; border: none; border-radius: 0; padding: 0; box-shadow: none; }
  .input-hero::after { display: none !important; }
  /* Вердикт-бейдж: в печати фоны браузер не печатает → плотную заливку с белым
     текстом возвращаем к мягкому виду с тёмным текстом, чтобы он остался читаемым. */
  .verdict-badge--good { background: var(--ok-soft);  color: var(--ok-text); }
  .verdict-badge--warn { background: var(--warn-soft); color: var(--warn-text); }
  .verdict-badge--crit { background: var(--crit-soft); color: var(--crit-text); }
}
