/* ============================================================================
   audit.css — лид-магнит «Анализ сайта» (tech.quillon.ru/audit/)
   Язык дизайн-системы qt-* (navy + red, Manrope + IBM Plex Mono, hairlines).
   ========================================================================== */

:root {
  --au-good:  #1FA971;   /* ≥90  */
  --au-warn:  #E8A23D;   /* 70–89 */
  --au-bad:   #E63946;   /* <70 (= accent) */
  --au-good-soft: rgba(31, 169, 113, 0.12);
  --au-warn-soft: rgba(232, 162, 61, 0.14);
  --au-bad-soft:  rgba(230, 57, 70, 0.10);
}

/* ─── HERO URL launcher (на deep navy) ────────────────────────────────── */
.audit-hero__copy { max-width: 760px; }

.audit-launch { margin: var(--qt-s-6) 0 0; }
.audit-launch__field {
  display: flex;
  align-items: stretch;
  gap: 8px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--qt-line-deep-strong);
  border-radius: var(--qt-r-lg);
  padding: 8px;
  transition: border-color .15s, background .15s;
}
.audit-launch__field:focus-within {
  border-color: var(--qt-accent-on-deep);
  background: rgba(255, 255, 255, 0.09);
}
.audit-launch__proto {
  display: flex;
  align-items: center;
  padding: 0 4px 0 12px;
  font-family: var(--qt-font-mono);
  font-size: 15px;
  color: var(--qt-text-on-low);
  user-select: none;
}
.audit-launch__input {
  flex: 1 1 auto;
  min-width: 0;
  background: transparent;
  border: 0;
  outline: 0;
  color: #fff;
  font-family: var(--qt-font-display);
  font-size: clamp(16px, 1.5vw, 19px);
  font-weight: var(--qt-fw-medium);
  padding: 12px 4px;
}
.audit-launch__input::placeholder { color: var(--qt-text-on-low); }
.audit-launch__btn { flex: none; white-space: nowrap; }
.audit-launch__note {
  margin: 14px 2px 0;
  font-family: var(--qt-font-mono);
  font-size: var(--qt-t-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--qt-text-on-low);
}
.audit-launch__error {
  margin: 12px 2px 0;
  font-size: var(--qt-t-sm);
  color: var(--qt-accent-on-deep);
}
@media (max-width: 620px) {
  .audit-launch__field { flex-wrap: wrap; }
  .audit-launch__input { flex-basis: 60%; }
  .audit-launch__btn { width: 100%; }
}

/* hero «что проверяем» — пилюли с галочкой (на deep navy) */
.audit-tags {
  display: flex; flex-wrap: wrap; gap: 10px;
  list-style: none; margin: 28px 0 0; padding: 0;
}
.audit-tags__item {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: var(--qt-t-sm); font-weight: var(--qt-fw-medium); color: #fff;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--qt-line-deep-strong);
  border-radius: var(--qt-r-pill); padding: 8px 15px;
}
.audit-tags__item svg { width: 13px; height: 13px; flex: none; color: var(--au-good); }

/* ─── Stage wrapper (результаты) ──────────────────────────────────────── */
.audit-stage-wrap {
  background: var(--qt-bg-page);
  padding: clamp(40px, 6vw, 88px) 0;
  border-bottom: 1px solid var(--qt-line);
  scroll-margin-top: 88px;
}
.audit-stage { display: flex; flex-direction: column; gap: var(--qt-s-6); }

/* ─── Scanning state ──────────────────────────────────────────────────── */
.au-scanning__head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px; flex-wrap: wrap; margin-bottom: 8px;
}
.au-scanning__title { font-size: var(--qt-t-h3); font-weight: var(--qt-fw-bold); color: var(--qt-text-hi); }
.au-scanning__url { font-family: var(--qt-font-mono); font-size: var(--qt-t-sm); color: var(--qt-text-low); word-break: break-all; }
.au-bar {
  height: 8px; border-radius: var(--qt-r-pill);
  background: var(--qt-bg-card); overflow: hidden; margin: 18px 0 24px;
}
.au-bar__fill {
  height: 100%; border-radius: var(--qt-r-pill);
  background: linear-gradient(90deg, var(--qt-accent), var(--qt-accent-on-deep));
  width: 6%; transition: width .5s ease;
}
.au-modules { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.au-module {
  display: flex; align-items: center; gap: 12px;
  font-size: var(--qt-t-sm); color: var(--qt-text-mid);
}
.au-module__dot {
  width: 18px; height: 18px; flex: none; border-radius: 50%;
  border: 2px solid var(--qt-line-strong); position: relative;
}
.au-module--running .au-module__dot {
  border-color: var(--qt-accent);
  border-top-color: transparent; animation: au-spin .7s linear infinite;
}
.au-module--done .au-module__dot { border-color: var(--au-good); background: var(--au-good); }
.au-module--done .au-module__dot::after {
  content: ''; position: absolute; inset: 0; margin: auto;
  width: 5px; height: 9px; border: solid #fff; border-width: 0 2px 2px 0;
  transform: translateY(-1px) rotate(45deg);
}
.au-module--done .au-module__name { color: var(--qt-text-hi); }
@keyframes au-spin { to { transform: rotate(360deg); } }

/* ─── Scorecard (overall + категории) ─────────────────────────────────── */
.au-scorecard {
  display: grid;
  grid-template-columns: minmax(220px, 280px) 1fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
  background: var(--qt-bg-elev);
  border: 1px solid var(--qt-line);
  border-radius: var(--qt-r-xl);
  padding: clamp(24px, 4vw, 48px);
  box-shadow: 0 1px 2px rgba(20,33,61,.04), 0 8px 28px rgba(20,33,61,.06);
}
.au-scorecard__url {
  font-family: var(--qt-font-mono); font-size: var(--qt-t-xs);
  letter-spacing: .04em; color: var(--qt-text-low);
  word-break: break-all; margin-bottom: 4px;
}
.au-overall { text-align: center; }
.au-gauge { position: relative; display: inline-grid; place-items: center; }
.au-gauge svg { display: block; transform: rotate(-90deg); }
.au-gauge__num {
  position: absolute; display: flex; flex-direction: column; align-items: center; line-height: 1;
}
.au-gauge__val { font-size: 44px; font-weight: var(--qt-fw-extra); color: var(--qt-text-hi); font-variant-numeric: tabular-nums; }
.au-gauge__max { font-family: var(--qt-font-mono); font-size: 12px; color: var(--qt-text-low); margin-top: 4px; }
.au-overall__label {
  display: inline-block; margin-top: 14px;
  font-family: var(--qt-font-mono); font-size: var(--qt-t-mono); letter-spacing: .08em; text-transform: uppercase;
  padding: 5px 12px; border-radius: var(--qt-r-pill);
}

/* категории */
.au-cats { display: grid; gap: 14px; }
.au-cat { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 14px; }
.au-cat__name { font-size: var(--qt-t-sm); font-weight: var(--qt-fw-semibold); color: var(--qt-text-hi); }
.au-cat__track { grid-column: 1 / -1; height: 6px; border-radius: var(--qt-r-pill); background: var(--qt-bg-card); overflow: hidden; }
.au-cat__fill { height: 100%; border-radius: var(--qt-r-pill); transition: width .8s ease; }
.au-cat__val { font-family: var(--qt-font-mono); font-size: var(--qt-t-sm); font-weight: 500; color: var(--qt-text-mid); font-variant-numeric: tabular-nums; }

@media (max-width: 720px) {
  .au-scorecard { grid-template-columns: 1fr; text-align: center; }
  .au-cats { text-align: left; }
}

/* ─── Email-гейт (карточка нормального потока — ничего не клипается) ───── */
.au-gate {
  border: 1px solid var(--qt-line);
  border-radius: var(--qt-r-xl);
  overflow: hidden;
  background: var(--qt-bg-elev);
  box-shadow: 0 1px 2px rgba(20,33,61,.04), 0 8px 28px rgba(20,33,61,.06);
}
/* декоративная «размытая» полоса сверху — фикс. высота, перелива нет */
.au-gate__preview { position: relative; height: 148px; overflow: hidden; padding: 28px clamp(20px, 4vw, 40px) 0; }
.au-gate__rows { filter: blur(6px); opacity: .4; }
.au-gate__preview::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 30%, var(--qt-bg-elev));
}
.au-gate__skeleton { height: 13px; border-radius: 6px; background: var(--qt-bg-card); margin: 0 0 14px; }
/* панель — нормальный поток, подтянута над фейдом */
.au-gate__panel {
  position: relative;
  display: flex; flex-direction: column; align-items: center; text-align: center;
  margin-top: -54px;
  padding: 0 clamp(20px, 4vw, 40px) clamp(32px, 4vw, 44px);
}
.au-gate__lock {
  display: inline-flex; width: 52px; height: 52px; border-radius: 50%;
  align-items: center; justify-content: center; margin-bottom: 18px;
  background: var(--qt-accent-soft); color: var(--qt-accent);
  box-shadow: 0 0 0 6px var(--qt-bg-elev);
}
.au-gate__lock svg { width: 22px; height: 22px; }
.au-gate__title { font-size: var(--qt-t-h3); font-weight: var(--qt-fw-bold); color: var(--qt-text-hi); margin-bottom: 10px; max-width: 24ch; }
.au-gate__sub { font-size: var(--qt-t-body); color: var(--qt-text-mid); max-width: 48ch; margin-bottom: 26px; line-height: 1.55; }
.au-gate__form { display: flex; flex-direction: column; gap: 14px; width: 100%; max-width: 460px; }
.au-gate__row { display: flex; gap: 10px; }
.au-gate__input {
  flex: 1 1 auto; min-width: 0;
  background: var(--qt-bg-page); border: 1px solid var(--qt-line-strong); border-radius: var(--qt-r-md);
  padding: 14px 16px; font-family: var(--qt-font-display); font-size: 16px; color: var(--qt-text-hi);
}
.au-gate__input:focus { outline: 0; border-color: var(--qt-accent); box-shadow: 0 0 0 3px var(--qt-accent-soft); }
.au-gate__row .qt-btn { flex: none; white-space: nowrap; }
.au-gate__consent {
  display: flex; align-items: flex-start; gap: 9px; text-align: left;
  font-size: var(--qt-t-xs); color: var(--qt-text-low); line-height: 1.5;
}
.au-gate__consent input { margin-top: 2px; accent-color: var(--qt-accent); flex: none; }
.au-gate__consent a { color: var(--qt-text-mid); text-decoration: underline; }
.au-gate__error { font-size: var(--qt-t-sm); color: var(--qt-accent); min-height: 0; margin: 0; }
@media (max-width: 520px) {
  .au-gate__row { flex-direction: column; }
  .au-gate__row .qt-btn { width: 100%; }
}

/* ─── Отчёт (unlocked) ────────────────────────────────────────────────── */
.au-report { display: flex; flex-direction: column; gap: var(--qt-s-6); }
.au-block {
  background: var(--qt-bg-elev); border: 1px solid var(--qt-line);
  border-radius: var(--qt-r-xl); padding: clamp(24px, 4vw, 40px);
}
.au-block__eyebrow {
  font-family: var(--qt-font-mono); font-size: var(--qt-t-mono); letter-spacing: .12em;
  text-transform: uppercase; color: var(--qt-accent); margin-bottom: 12px;
}
.au-block__title { font-size: var(--qt-t-h3); font-weight: var(--qt-fw-bold); color: var(--qt-text-hi); margin-bottom: 8px; }
.au-block__lead { font-size: var(--qt-t-body); color: var(--qt-text-mid); line-height: 1.6; }

/* AI roadmap items */
.au-ai { display: grid; gap: 16px; margin-top: 24px; }
.au-ai__item {
  border: 1px solid var(--qt-line); border-radius: var(--qt-r-lg);
  padding: 22px 24px; background: var(--qt-bg-paper);
}
.au-ai__top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.au-ai__title { font-size: var(--qt-t-h4); font-weight: var(--qt-fw-bold); color: var(--qt-text-hi); flex: 1 1 240px; }
.au-ai__rationale { font-size: var(--qt-t-sm); color: var(--qt-text-mid); line-height: 1.6; margin-bottom: 14px; }
.au-ai__steps { margin: 0 0 0 0; padding-left: 20px; display: grid; gap: 6px; }
.au-ai__steps li { font-size: var(--qt-t-sm); color: var(--qt-text-mid); line-height: 1.5; }
.au-ai__meta { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 14px; }
.au-ai__metric { font-family: var(--qt-font-mono); font-size: var(--qt-t-xs); color: var(--qt-text-low); }
.au-ai__metric b { color: var(--qt-text-hi); font-weight: 600; }
.au-code {
  margin: 14px 0 0; padding: 16px; border-radius: var(--qt-r-md);
  background: var(--qt-bg-deep); color: #E6ECF7; overflow-x: auto;
  font-family: var(--qt-font-mono); font-size: 13px; line-height: 1.55;
}

/* находки по модулям */
.au-findings { display: grid; gap: 12px; margin-top: 20px; }
.au-finding {
  display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: start;
  padding: 16px 0; border-top: 1px solid var(--qt-line);
}
.au-finding:first-child { border-top: 0; }
.au-finding__body { min-width: 0; }
.au-finding__title { font-size: var(--qt-t-sm); font-weight: var(--qt-fw-semibold); color: var(--qt-text-hi); }
.au-finding__summary { font-size: var(--qt-t-sm); color: var(--qt-text-mid); margin-top: 3px; line-height: 1.5; }
.au-finding__rec { font-size: var(--qt-t-sm); color: var(--qt-text-low); margin-top: 6px; line-height: 1.5; }
.au-finding__rec b { color: var(--qt-text-mid); font-weight: 600; }

/* severity / priority chips */
.au-chip {
  display: inline-flex; align-items: center; gap: 6px; flex: none;
  font-family: var(--qt-font-mono); font-size: 10px; letter-spacing: .06em; text-transform: uppercase;
  padding: 4px 9px; border-radius: var(--qt-r-pill); font-weight: 600; white-space: nowrap;
}
.au-chip--critical, .au-chip--high { background: var(--au-bad-soft); color: var(--au-bad); }
.au-chip--medium { background: var(--au-warn-soft); color: #B9791F; }
.au-chip--low, .au-chip--info { background: var(--qt-bg-card); color: var(--qt-text-low); }
.au-chip--pass { background: var(--au-good-soft); color: var(--au-good); }

.au-module-group { margin-top: 8px; }
.au-module-group__head {
  display: flex; align-items: center; gap: 12px; justify-content: space-between;
  cursor: pointer; padding: 14px 0; list-style: none;
}
.au-module-group__head::-webkit-details-marker { display: none; }
.au-module-group__name { font-size: var(--qt-t-h4); font-weight: var(--qt-fw-bold); color: var(--qt-text-hi); }
.au-module-group__count { font-family: var(--qt-font-mono); font-size: var(--qt-t-xs); color: var(--qt-text-low); }

/* error state */
.au-error {
  text-align: center; padding: clamp(32px, 6vw, 64px);
  background: var(--qt-bg-elev); border: 1px solid var(--qt-line); border-radius: var(--qt-r-xl);
}
.au-error__title { font-size: var(--qt-t-h3); font-weight: var(--qt-fw-bold); color: var(--qt-text-hi); margin-bottom: 8px; }
.au-error__text { font-size: var(--qt-t-body); color: var(--qt-text-mid); max-width: 44ch; margin: 0 auto 24px; }

/* ─── FAQ accordion ───────────────────────────────────────────────────── */
.audit-faq { max-width: 820px; }
.audit-faq__item { border-top: 1px solid var(--qt-line-strong); }
.audit-faq__item:last-child { border-bottom: 1px solid var(--qt-line-strong); }
.audit-faq__q {
  list-style: none; cursor: pointer; padding: 22px 0;
  font-size: var(--qt-t-h4); font-weight: var(--qt-fw-semibold); color: var(--qt-text-hi);
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.audit-faq__q::-webkit-details-marker { display: none; }
.audit-faq__q::after {
  content: ''; flex: none; width: 11px; height: 11px;
  border: solid var(--qt-text-low); border-width: 0 2px 2px 0;
  transform: rotate(45deg); transition: transform .2s; margin-right: 4px;
}
.audit-faq__item[open] .audit-faq__q::after { transform: rotate(-135deg); }
.audit-faq__a { padding: 0 0 24px; font-size: var(--qt-t-body); color: var(--qt-text-mid); line-height: 1.65; max-width: 70ch; }

/* current nav link */
.qt-topbar__link--current { color: var(--qt-accent); }

/* ─── Анти-горизонтальный-скролл в отчёте ─────────────────────────────────
   Длинный код (<pre>) и неразрывный текст AI-рекомендаций растягивали grid-
   контейнер (implicit auto-колонка) шире вьюпорта. Constrain + min-width:0. */
.audit-stage, .au-report, .au-block, .au-ai__item,
.au-finding, .au-finding__body { min-width: 0; }
.au-ai, .au-findings { grid-template-columns: minmax(0, 1fr); }
.au-block, .au-ai__item, .au-code { max-width: 100%; }
.au-block__lead, .au-ai__rationale, .au-ai__title, .au-finding__title,
.au-finding__summary, .au-finding__rec, .au-ai__steps li { overflow-wrap: anywhere; }
