/*
 * Runtime UI parity styles for publisher-rendered /novosti/* pages.
 * Mirrors the Astro shell styles used on blog/article pages.
 */

.site-footer {
  position: relative;
  border-top: 1px solid rgba(125, 150, 175, 0.22);
  background: linear-gradient(180deg, #121821 0%, #0d131b 100%);
}

.site-footer::before {
  content: '';
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(95, 130, 167, 0.45), transparent);
  pointer-events: none;
}

.site-footer__inner {
  display: grid;
  gap: 1.1rem;
  grid-template-columns: 1.3fr 1.2fr repeat(2, minmax(0, 1fr));
  align-items: start;
  padding: 1.55rem 0 2.05rem;
}

.footer-card {
  position: relative;
  overflow: clip;
  border: 1px solid #2f3d4b;
  border-radius: 1.1rem;
  background: linear-gradient(180deg, rgba(24, 32, 42, 0.98), rgba(15, 21, 29, 0.98));
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.03);
  padding: 1.05rem 1.08rem;
}

.footer-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 24%);
  pointer-events: none;
}

.footer-card > * {
  position: relative;
  z-index: 1;
}

.footer-card--brand {
  background:
    radial-gradient(circle at top right, rgba(116, 200, 255, 0.12), transparent 40%),
    linear-gradient(155deg, #1a222b 0%, #17222c 58%, #132029 100%);
}

.footer-card--requisites {
  background: linear-gradient(180deg, rgba(20, 28, 36, 0.99), rgba(16, 23, 31, 0.99));
  padding: 0.82rem 0.85rem 0.92rem;
}

.footer-card--subscribe {
  background:
    radial-gradient(circle at top right, rgba(82, 154, 200, 0.12), transparent 42%),
    linear-gradient(180deg, rgba(25, 34, 45, 0.98), rgba(16, 23, 30, 0.98));
}

.footer-card--social {
  background:
    radial-gradient(circle at bottom right, rgba(116, 200, 255, 0.1), transparent 42%),
    linear-gradient(180deg, rgba(22, 31, 40, 0.98), rgba(15, 22, 29, 0.98));
}

.footer-title {
  margin: 0 0 0.65rem;
  font-weight: 700;
  font-size: 1.1rem;
  letter-spacing: -0.01em;
}

.footer-section-title {
  margin: 0 0 0.72rem;
  font-size: 0.83rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #97aec4;
}

.footer-section-title--sub {
  margin-top: 0.88rem;
  margin-bottom: 0.42rem;
  font-size: 0.73rem;
}

.footer-copy {
  margin: 0 0 0.72rem;
  font-size: 0.9rem;
  color: #c1cfdd;
  line-height: 1.58;
}

.footer-copy--muted {
  margin-bottom: 0;
  color: #94a8bb;
}

.footer-links {
  display: grid;
  gap: 0.46rem;
  margin: 0.95rem 0 0.85rem;
}

.footer-links a {
  color: #e4eef7;
  text-decoration: none;
  font-size: 0.91rem;
}

.footer-links a:hover {
  color: #ffffff;
  text-decoration: underline;
  text-decoration-color: rgba(116, 200, 255, 0.55);
}

.footer-links--compact {
  margin-top: 0.34rem;
  margin-bottom: 0.45rem;
  gap: 0.34rem;
}

.footer-links--compact a {
  font-size: 0.83rem;
}

.footer-links--legal a {
  font-size: 0.84rem;
  color: #d8e9f8;
}

.footer-accordion {
  border: 1px solid #324253;
  border-radius: 0.9rem;
  background: linear-gradient(180deg, #141d26 0%, #101821 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.footer-accordion__summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  padding: 0.74rem 0.8rem;
  color: #dbe7f4;
  font-weight: 700;
  font-size: 0.87rem;
}

.footer-accordion__summary::-webkit-details-marker {
  display: none;
}

.footer-accordion__summary:hover {
  color: #ffffff;
}

.footer-accordion__title {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
}

.footer-accordion__title::before {
  content: '▸';
  color: #95b8d9;
  font-size: 0.76rem;
  transform: rotate(0deg);
  transition: transform 0.18s ease;
}

.footer-accordion[open] .footer-accordion__title::before {
  transform: rotate(90deg);
}

.footer-accordion__chevron {
  color: #8fb8d8;
  font-size: 0.9rem;
  transition: transform 0.18s ease;
}

.footer-accordion[open] .footer-accordion__chevron {
  transform: rotate(180deg);
}

.footer-accordion__content {
  padding: 0 0.8rem 0.82rem;
  display: grid;
  gap: 0.76rem;
}

.footer-kv-group {
  border-top: 1px solid #2f3d4b;
  padding-top: 0.66rem;
}

.footer-kv-group:first-child {
  border-top: 0;
  padding-top: 0.5rem;
}

.footer-kv-group__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.48rem;
  margin-bottom: 0.4rem;
}

.footer-kv-title {
  margin: 0;
  font-size: 0.77rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #9db4c8;
}

.footer-kv {
  margin: 0;
  display: grid;
  gap: 0.44rem;
}

.footer-kv dt {
  margin: 0;
  font-size: 0.72rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #96abc0;
}

.footer-kv dd {
  margin: 0.22rem 0 0;
  font-size: 0.83rem;
  color: #dce6ef;
  line-height: 1.4;
  word-break: break-word;
}

.footer-kv-item {
  border-top: 1px solid #2c3946;
  padding-top: 0.48rem;
}

.footer-kv-item:first-child {
  border-top: 0;
  padding-top: 0;
}

.footer-kv-item__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.42rem;
}

.footer-copy-btn {
  border: 1px solid #3b5368;
  border-radius: 0.62rem;
  background: linear-gradient(180deg, #1c2935, #17212b);
  color: #d4e4f2;
  width: 1.95rem;
  height: 1.95rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  font-size: 0.82rem;
  line-height: 1;
  transition: border-color 0.15s, color 0.15s, transform 0.15s, box-shadow 0.15s;
}

.footer-copy-btn:hover {
  border-color: #77dfff;
  color: #eaf9ff;
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(47, 120, 170, 0.2);
}

.footer-copy-btn[data-copied='true'] {
  border-color: #4fdda8;
  color: #4fdda8;
}

.footer-copy-btn--row {
  width: 1.56rem;
  height: 1.56rem;
  border-radius: 0.5rem;
  font-size: 0.74rem;
}

.footer-copy-status {
  margin: 0.5rem 0 0;
  min-height: 1.1em;
  font-size: 0.77rem;
  color: #a6bbce;
}

.footer-copy-status[data-state='ok'] {
  color: #8df2b6;
}

.footer-copy-status[data-state='error'] {
  color: #ffb6b6;
}

.footer-subscribe {
  display: grid;
  gap: 0.58rem;
}

.footer-subscribe label {
  font-size: 0.8rem;
  color: #a8bed0;
}

.footer-consent {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 0.52rem;
  margin-top: 0.18rem;
  font-size: 0.77rem;
  color: #a4b9cc;
  line-height: 1.35;
}

.footer-consent input[type='checkbox'] {
  width: 0.95rem;
  height: 0.95rem;
  margin-top: 0.1rem;
  accent-color: #66b8f0;
}

.footer-consent a {
  color: #d3efff;
}

.footer-consent a:hover {
  color: #ffffff;
}

.footer-subscribe input {
  width: 100%;
  border: 1px solid #3a4d61;
  border-radius: 0.82rem;
  background: rgba(12, 19, 27, 0.86);
  color: #e8eef5;
  font: inherit;
  padding: 0.66rem 0.78rem;
}

.footer-subscribe input:focus {
  outline: none;
  border-color: #74c8ff;
  box-shadow: 0 0 0 3px rgba(116, 200, 255, 0.18);
}

.footer-subscribe button {
  border: 1px solid #529ac8;
  border-radius: 0.82rem;
  background: linear-gradient(180deg, #2e81b8, #246a95);
  color: #f6fffe;
  font: inherit;
  font-weight: 700;
  padding: 0.68rem 0.78rem;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s, background 0.15s;
}

.footer-subscribe button:hover {
  background: linear-gradient(180deg, #3790ca, #2c78a9);
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(33, 91, 131, 0.22);
}

.footer-subscribe button:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.footer-subscribe button:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(116, 200, 255, 0.3);
  border-color: #74c8ff;
}

.footer-subscribe__status {
  margin: 0.62rem 0 0;
  min-height: 1.2em;
  font-size: 0.84rem;
  color: #adc0d2;
}

.footer-subscribe__status[data-state='ok'] {
  color: #86f4b0;
}

.footer-subscribe__status[data-state='error'] {
  color: #ffb2b2;
}

.footer-subscribe__status[data-state='info'] {
  color: #ffe4ae;
}

.footer-subscribe__meta {
  margin: 0.62rem 0 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  font-size: 0.77rem;
  color: #96aec3;
}

.footer-subscribe__meta a {
  color: #d7f4ff;
}

.footer-subscribe__meta a:hover {
  color: #ffffff;
}

.footer-social-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.5rem;
}

.footer-social-list a {
  display: flex;
  flex-direction: column;
  gap: 0.16rem;
  border: 1px solid #33495d;
  border-radius: 0.82rem;
  background: linear-gradient(180deg, rgba(22, 32, 42, 0.96), rgba(16, 24, 32, 0.96));
  color: #e6eef7;
  text-decoration: none;
  padding: 0.62rem 0.72rem;
  transition: transform 0.15s, border-color 0.15s, background 0.15s;
}

.footer-social-list a:hover {
  border-color: #74c8ff;
  color: #ffffff;
  transform: translateY(-1px);
  background: linear-gradient(180deg, rgba(27, 38, 49, 0.98), rgba(17, 26, 34, 0.98));
}

.footer-social-list small {
  font-size: 0.75rem;
  color: #a8bccf;
}

.cookie-consent {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  width: min(23.5rem, calc(100vw - 1.4rem));
  z-index: 70;
}

.cookie-consent__card {
  width: 100%;
  border: 1px solid #435668;
  border-radius: 1.05rem;
  background: linear-gradient(165deg, #172432 0%, #13202c 55%, #101823 100%);
  box-shadow: 0 20px 42px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(10px);
  padding: 0.9rem 0.95rem;
}

.cookie-consent__headline {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: #d7efff;
  font-size: 0.73rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.cookie-consent__copy {
  margin: 0.46rem 0 0;
  color: #c1d0de;
  font-size: 0.81rem;
  line-height: 1.5;
}

.cookie-consent__copy a {
  color: #cae7ff;
}

.cookie-consent__copy a:hover {
  color: #ffffff;
}

.cookie-consent__actions {
  margin-top: 0.74rem;
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.cookie-consent__actions .cookie-btn {
  flex: 1;
  min-width: 9.1rem;
}

.cookie-btn {
  min-height: 2.45rem;
  border: 1px solid #465d72;
  border-radius: 0.72rem;
  background: linear-gradient(180deg, #1d2b38, #182430);
  color: #e7eef6;
  font: inherit;
  font-size: 0.8rem;
  font-weight: 700;
  cursor: pointer;
  padding: 0.42rem 0.68rem;
  transition: border-color 0.15s, background 0.15s, transform 0.15s;
}

.cookie-btn:hover {
  border-color: #79a6c7;
  background: linear-gradient(180deg, #213243, #1a2a38);
  transform: translateY(-1px);
}

.cookie-btn:focus-visible,
.cookie-consent-open:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(116, 200, 255, 0.3);
  border-color: #74c8ff;
}

.cookie-btn--primary {
  border-color: #6dbcf0;
  background: linear-gradient(180deg, #3895ca, #2b78a9);
  color: #f8fffe;
}

.cookie-btn--primary:hover {
  border-color: #a4dafc;
  background: linear-gradient(180deg, #42a2d9, #307fad);
}

.cookie-consent__text-link {
  border: 0;
  background: transparent;
  color: #a8d5f6;
  font: inherit;
  font-size: 0.76rem;
  font-weight: 700;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 0.16em;
  padding: 0.2rem 0.16rem;
}

.cookie-consent__text-link:hover {
  color: #d8ecff;
}

.cookie-consent__details-row {
  margin-top: 0.42rem;
  display: flex;
  justify-content: flex-start;
}

.cookie-consent__details-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.34rem;
  border: 0;
  background: transparent;
  color: #9ed5f4;
  font: inherit;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  padding: 0.18rem 0.1rem;
}

.cookie-consent__details-btn:hover {
  color: #ffffff;
}

.cookie-consent__details-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(116, 200, 255, 0.3);
  border-radius: 4px;
}

.cookie-details-gear {
  font-size: 0.9em;
  line-height: 1;
}

.cookie-consent__chevron {
  display: inline-block;
  width: 0.42rem;
  height: 0.42rem;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.2s ease;
  margin-top: -0.1em;
  flex-shrink: 0;
}

.cookie-consent__details-btn[aria-expanded="true"] .cookie-consent__chevron {
  transform: rotate(225deg);
  margin-top: 0.15em;
}

.cookie-consent__prefs {
  margin-top: 0.66rem;
  border-top: 1px solid #334658;
  padding-top: 0.7rem;
  display: grid;
  gap: 0.48rem;
}

.cookie-consent__prefs-title {
  margin: 0;
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #a8c0d4;
}

.cookie-toggle {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.5rem;
  align-items: center;
  border: 1px solid #34495c;
  border-radius: 0.72rem;
  background: rgba(24, 35, 46, 0.9);
  padding: 0.54rem 0.62rem;
}

.cookie-toggle strong {
  display: block;
  font-size: 0.82rem;
  color: #e8eef5;
}

.cookie-toggle small {
  display: block;
  margin-top: 0.12rem;
  color: #a6bacd;
  font-size: 0.72rem;
  line-height: 1.3;
}

.cookie-toggle input[type='checkbox'] {
  width: 0.96rem;
  height: 0.96rem;
  accent-color: #66b8f0;
}

.cookie-toggle input[type='checkbox'][disabled] {
  opacity: 0.75;
  cursor: not-allowed;
}

.cookie-consent__prefs-actions {
  display: flex;
  justify-content: flex-end;
}

.cookie-consent__prefs-actions .cookie-btn {
  min-height: 2rem;
}

.cookie-consent-open {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 65;
  border: 1px solid #45627b;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(24, 37, 48, 0.96), rgba(17, 28, 38, 0.96));
  color: #e6f2fb;
  font: inherit;
  font-weight: 700;
  font-size: 0.75rem;
  padding: 0.42rem 0.74rem;
  cursor: pointer;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.28);
}

.cookie-consent-open:hover {
  border-color: #8bd5ff;
  color: #ffffff;
}

@media (max-width: 920px) {
  .site-footer__inner {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .cookie-consent {
    right: 0.6rem;
    bottom: 0.72rem;
    width: min(100%, calc(100vw - 1.2rem));
  }

  .cookie-consent__card {
    padding: 0.8rem;
  }

  .cookie-consent-open {
    right: 0.6rem;
    bottom: 0.72rem;
    font-size: 0.72rem;
  }
}

/* Quiz Funnel — self-contained modal + widgets */
:root {
  --qf-orange:       #f26400;
  --qf-orange-hover: #d45500;
  --qf-orange-dim:   rgba(242, 100, 0, 0.18);
  --qf-bg:           #0f1319;
  --qf-surface:      #161c26;
  --qf-border:       #2a3448;
  --qf-text:         #f0f4ff;
  --qf-muted:        #8896b0;
  --qf-loading-bg:   #1a0500;
}

/* ── Модальный диалог ────────────────────────────────────────────────────── */
dialog.qf-modal {
  position: fixed;
  inset: 0;
  width: 100%;
  max-width: 100%;
  height: 100dvh;
  max-height: 100dvh;
  margin: 0;
  border: 0;
  padding: 0;
  overflow-y: auto;
  background: var(--qf-bg);
  color: var(--qf-text);
}

dialog.qf-modal::backdrop {
  background: rgba(0, 0, 0, 0.88);
  backdrop-filter: blur(6px);
}

/* ── Кнопка закрытия ─────────────────────────────────────────────────────── */
.qf-close {
  /* Sticky row — крестик прибит к верху при скролле */
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  padding: 0.85rem 1rem 0.35rem;
  border: 0;
  background: transparent;
  cursor: pointer;
  /* Крестик-кружок */
  color: rgba(255,255,255,0.45);
  font-size: 1.1rem;
  line-height: 2.2rem;
  /* Визуально делаем нажимаемую зону кружком */
  text-align: center;
}
.qf-close span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.3);
  font-size: 1.1rem;
  line-height: 1;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.qf-close:hover span {
  background: rgba(255,255,255,0.12);
  color: #fff;
  border-color: rgba(255,255,255,0.7);
}
.qf-close:hover { color: #fff; }

/* ── Прогресс-бар ────────────────────────────────────────────────────────── */
.qf-progress {
  position: sticky;
  top: 2.8rem;
  z-index: 9;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0 1.2rem 0.6rem;
  background: var(--qf-bg);
}
.qf-progress__fill-track {
  flex: 1;
  height: 3px;
  background: var(--qf-border);
  border-radius: 99px;
  overflow: hidden;
}
.qf-progress__fill {
  height: 3px;
  width: 0%;
  background: var(--qf-orange);
  border-radius: 99px;
  transition: width 0.32s ease;
}
.qf-progress__label {
  font-size: 0.72rem;
  color: var(--qf-muted);
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

/* ── Аватар-эксперт с баблом ─────────────────────────────────────────────── */
.qf-expert {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  padding: 0 1.2rem 0.5rem;
  max-width: 680px;
  margin: 0 auto;
}
.qf-expert__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--qf-orange);
  flex-shrink: 0;
}
.qf-expert__bubble {
  position: relative;
  background: var(--qf-surface);
  border: 1px solid var(--qf-border);
  border-radius: 10px;
  padding: 0.6rem 0.85rem;
  font-size: 0.84rem;
  line-height: 1.55;
  color: var(--qf-muted);
  margin: 0;
}
.qf-expert__bubble::before {
  content: '';
  position: absolute;
  left: -8px;
  top: 14px;
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-right: 8px solid var(--qf-border);
}
.qf-expert__bubble::after {
  content: '';
  position: absolute;
  left: -6px;
  top: 15px;
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-right: 7px solid var(--qf-surface);
}

/* ── Обёртка шагов ───────────────────────────────────────────────────────── */
.qf-steps-wrap {
  max-width: 680px;
  margin: 0 auto;
  padding: 0.5rem 1.2rem 3rem;
  min-height: 60vh;
}

/* ── Анимация шагов ──────────────────────────────────────────────────────── */
.qf-step {
  opacity: 0;
  transform: translateX(18px);
  transition: opacity 0.22s ease, transform 0.22s ease;
}
.qf-step.is-active {
  opacity: 1;
  transform: none;
}
.qf-step.is-leaving {
  opacity: 0;
  transform: translateX(-18px);
  pointer-events: none;
}

/* ── Контент шага ────────────────────────────────────────────────────────── */
.qf-step__inner {
  padding-top: 0.5rem;
}
.qf-step__kicker {
  margin: 0 0 0.5rem;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--qf-orange);
  font-weight: 700;
}
.qf-step__title {
  margin: 0 0 0.75rem;
  font-size: clamp(1.35rem, 3vw + 0.6rem, 2rem);
  font-weight: 700;
  line-height: 1.25;
  color: var(--qf-text);
}
.qf-step__desc {
  margin: 0 0 1.4rem;
  font-size: 0.97rem;
  line-height: 1.65;
  color: var(--qf-muted);
}

/* ── URL инпут на первом шаге ────────────────────────────────────────────── */
.qf-url-group {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
@media (min-width: 500px) {
  .qf-url-group { flex-direction: row; }
}
.qf-url-input {
  flex: 1;
  padding: 0.72rem 0.9rem;
  border: 1.5px solid var(--qf-border);
  border-radius: 8px;
  background: var(--qf-surface);
  color: var(--qf-text);
  font-size: 0.95rem;
  outline: none;
  transition: border-color 0.15s;
}
.qf-url-input::placeholder { color: var(--qf-muted); }
.qf-url-input:focus { border-color: var(--qf-orange); }
.qf-btn-next {
  padding: 0.72rem 1.4rem;
  border: 0;
  border-radius: 8px;
  background: var(--qf-orange);
  color: #fff;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}
.qf-btn-next:hover { background: var(--qf-orange-hover); }

/* ── Кнопки-варианты ответа ──────────────────────────────────────────────── */
.qf-answers {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.qf-answer-btn {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.85rem 1.1rem;
  border: 1.5px solid var(--qf-border);
  border-radius: 10px;
  background: var(--qf-surface);
  color: var(--qf-text);
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, transform 0.1s;
}
.qf-answer-btn:hover {
  border-color: var(--qf-orange);
  background: var(--qf-orange-dim);
  transform: translateX(3px);
}
.qf-answer-btn__label {
  font-size: 0.97rem;
  font-weight: 600;
  line-height: 1.3;
}
.qf-answer-btn__desc {
  font-size: 0.83rem;
  color: var(--qf-muted);
  line-height: 1.4;
}

/* ── Loading экран ───────────────────────────────────────────────────────── */
.qf-step--loading .qf-step__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 55vh;
  text-align: center;
}
.qf-step--loading {
  background: var(--qf-loading-bg);
  min-height: 100dvh;
}
.qf-loading__title {
  font-size: clamp(1.1rem, 2.5vw + 0.5rem, 1.6rem);
  color: #f0dbc8;
  margin-bottom: 2rem;
}
.qf-loading__title span {
  color: var(--qf-orange);
  font-style: italic;
}
.qf-loading-bar {
  width: 100%;
  max-width: 360px;
  height: 5px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: 1.2rem;
}
.qf-loading-bar__fill {
  height: 100%;
  width: 0%;
  background: var(--qf-orange);
  border-radius: 99px;
}
.qf-loading__status {
  font-size: 0.88rem;
  color: #c08060;
  margin: 0;
  min-height: 1.4em;
}

/* ── Лид-форма ───────────────────────────────────────────────────────────── */
.qf-lead-header {
  margin-bottom: 1.4rem;
}
.qf-lead-badge {
  display: inline-block;
  padding: 0.28rem 0.75rem;
  border-radius: 999px;
  background: var(--qf-orange-dim);
  color: var(--qf-orange);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  margin-bottom: 0.7rem;
}
.qf-accent { color: var(--qf-orange); }

.qf-lead-form {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.qf-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.7rem;
}
@media (max-width: 440px) {
  .qf-form-row { grid-template-columns: 1fr; }
}
.qf-field {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.qf-field__label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--qf-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.qf-field__label span { color: var(--qf-orange); }
.qf-input {
  padding: 0.7rem 0.9rem;
  border: 1.5px solid var(--qf-border);
  border-radius: 8px;
  background: var(--qf-surface);
  color: var(--qf-text);
  font-size: 0.95rem;
  font-family: inherit;
  outline: none;
  transition: border-color 0.15s;
  appearance: none;
  -webkit-appearance: none;
}
.qf-input::placeholder { color: var(--qf-muted); }
.qf-input:focus { border-color: var(--qf-orange); }
.qf-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238896b0' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.85rem center;
  padding-right: 2.5rem;
  cursor: pointer;
}
.qf-btn-submit {
  padding: 0.9rem 1.4rem;
  border: 0;
  border-radius: 10px;
  background: var(--qf-orange);
  color: #fff;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s;
  margin-top: 0.3rem;
}
.qf-btn-submit:hover { background: var(--qf-orange-hover); transform: translateY(-1px); }
.qf-btn-submit:disabled { opacity: 0.65; cursor: not-allowed; transform: none; }
.qf-form-status {
  min-height: 1.2rem;
  font-size: 0.84rem;
  color: var(--qf-muted);
  text-align: center;
  margin: 0;
}
.qf-form-status--error { color: #f87171; }
.qf-field-error { border-color: #f87171 !important; }
.qf-form-fine {
  font-size: 0.75rem;
  color: var(--qf-muted);
  text-align: center;
  margin: 0;
  line-height: 1.5;
}
.qf-form-fine a { color: var(--qf-muted); text-decoration: underline; }

/* ── Success экран ───────────────────────────────────────────────────────── */
.qf-success__notice {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.9rem 1.1rem;
  border-radius: 10px;
  background: rgba(34, 197, 94, 0.12);
  border: 1px solid rgba(34, 197, 94, 0.3);
  font-size: 0.9rem;
  color: #86efac;
  margin-bottom: 1.8rem;
}
.qf-success__check {
  font-size: 1.1rem;
  flex-shrink: 0;
}
.qf-success__notice strong { color: #fff; }

.qf-success__body {
  max-width: 540px;
}
.qf-success__title {
  font-size: clamp(1.2rem, 2.5vw + 0.5rem, 1.75rem);
  font-weight: 700;
  line-height: 1.3;
  color: var(--qf-text);
  margin: 0 0 1rem;
}
.qf-success__desc {
  font-size: 0.97rem;
  line-height: 1.7;
  color: var(--qf-muted);
  margin: 0 0 0.9rem;
}
.qf-success__cta-lead {
  font-size: 0.9rem;
  color: var(--qf-muted);
  margin: 0 0 1.1rem;
}
.qf-btn-calendly {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 2rem;
  border-radius: 10px;
  background: var(--qf-orange);
  color: #fff;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-decoration: none;
  transition: background 0.15s, transform 0.1s;
}
.qf-btn-calendly:hover { background: var(--qf-orange-hover); transform: translateY(-1px); }

/* ── Sidebar виджет (blog, news) ─────────────────────────────────────────── */
.qf-widget {
  position: relative;
  overflow: hidden;
  padding: 1.35rem 1.15rem 1.2rem;
  border: 1.5px solid rgba(242, 100, 0, 0.92);
  border-radius: 1.15rem;
  background:
    radial-gradient(circle at top, rgba(242, 100, 0, 0.18), transparent 34%),
    linear-gradient(180deg, #241005 0%, #130700 72%, #0d0400 100%);
  display: flex;
  flex-direction: column;
  gap: 0.82rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 18px 36px rgba(0, 0, 0, 0.34);
}
.qf-widget::after {
  content: '';
  position: absolute;
  inset: auto -2.5rem -3rem auto;
  width: 8rem;
  height: 8rem;
  background: radial-gradient(circle, rgba(242, 100, 0, 0.22), transparent 68%);
  pointer-events: none;
}
.qf-widget__badge {
  position: relative;
  z-index: 1;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 700;
  color: #ff8a2e;
}
.qf-widget__title {
  margin: 0;
  position: relative;
  z-index: 1;
  font-size: clamp(1.25rem, 1.05rem + 0.6vw, 1.65rem);
  font-weight: 700;
  line-height: 1.22;
  color: #fff2e8;
}
.qf-widget__desc {
  margin: 0;
  position: relative;
  z-index: 1;
  font-size: 0.94rem;
  line-height: 1.55;
  color: #c79884;
}
.qf-widget__input {
  position: relative;
  z-index: 1;
  min-height: 3.1rem;
  padding: 0.8rem 0.95rem;
  border: 1px solid rgba(255, 150, 86, 0.22);
  border-radius: 0.95rem;
  background: rgba(255, 255, 255, 0.04);
  color: #f0dbc8;
  font-size: 0.9rem;
  font-family: inherit;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}
.qf-widget__input::placeholder { color: #8d6250; }
.qf-widget__input:focus {
  border-color: var(--qf-orange);
  background: rgba(255, 255, 255, 0.06);
  box-shadow: 0 0 0 3px rgba(242, 100, 0, 0.16);
}
.qf-widget__btn {
  position: relative;
  z-index: 1;
  min-height: 3.35rem;
  padding: 0.82rem 1rem;
  border: 0;
  border-radius: 1rem;
  background: linear-gradient(180deg, #ff7d10, var(--qf-orange));
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 12px 20px rgba(242, 100, 0, 0.24);
  transition: background 0.15s, transform 0.15s, box-shadow 0.15s;
  text-align: center;
}
.qf-widget__btn:hover {
  background: linear-gradient(180deg, #ff8c28, var(--qf-orange-hover));
  transform: translateY(-1px);
  box-shadow: 0 14px 24px rgba(242, 100, 0, 0.28);
}
.qf-widget__fine {
  margin: 0;
  position: relative;
  z-index: 1;
  font-size: 0.78rem;
  color: #a17360;
  text-align: center;
}

/* ── Strip виджет (калькуляторы) ─────────────────────────────────────────── */
.qf-strip {
  margin: 2rem 0 0;
  border-left: 3px solid var(--qf-orange);
  background: linear-gradient(90deg, #140800 0%, #0f1117 100%);
  border-radius: 0 10px 10px 0;
}
.qf-strip__content {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  padding: 1.1rem 1.3rem;
}
@media (min-width: 640px) {
  .qf-strip__content {
    flex-direction: row;
    align-items: center;
    gap: 1.4rem;
  }
}
.qf-strip__text {
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
  flex: 1;
}
.qf-strip__title {
  font-size: 0.97rem;
  font-weight: 700;
  color: #f0dbc8;
  line-height: 1.3;
}
.qf-strip__desc {
  font-size: 0.82rem;
  color: #9a7060;
  line-height: 1.45;
}
.qf-strip__right {
  display: flex;
  gap: 0.5rem;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.qf-strip__input {
  padding: 0.52rem 0.75rem;
  border: 1px solid #3a2010;
  border-radius: 7px;
  background: #1e0c00;
  color: #f0dbc8;
  font-size: 0.85rem;
  font-family: inherit;
  outline: none;
  min-width: 180px;
  transition: border-color 0.15s;
}
.qf-strip__input::placeholder { color: #7a5040; }
.qf-strip__input:focus { border-color: var(--qf-orange); }
.qf-strip__btn {
  padding: 0.52rem 1rem;
  border: 0;
  border-radius: 7px;
  background: var(--qf-orange);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}
.qf-strip__btn:hover { background: var(--qf-orange-hover); }

/* ── Padding fix: widget inside article-toc sidebar ─────────────────────── */
.article-toc .qf-widget {
  margin-top: 1.1rem;
}
/* Если TOC нет — первый и единственный ребёнок, отступ не нужен */
.article-toc > .qf-widget:first-child {
  margin-top: 0;
}

/* ── Specificity fix: reset .article-toc p pollution on widget paragraphs ─ */
/* .article-toc p (0,1,1) beats .qf-widget__title (0,1,0).
   .qf-widget p.class (0,2,1) beats .article-toc p — restores correct styles */
.qf-widget p.qf-widget__title {
  text-transform: none;
  letter-spacing: normal;
  font-size: clamp(1.25rem, 1.05rem + 0.6vw, 1.65rem);
  font-weight: 700;
  line-height: 1.22;
  color: #fff2e8;
  margin: 0;
}
.qf-widget p.qf-widget__desc {
  text-transform: none;
  letter-spacing: normal;
  font-size: 0.94rem;
  font-weight: 400;
  line-height: 1.55;
  color: #c79884;
  margin: 0;
}
.qf-widget p.qf-widget__fine {
  text-transform: none;
  letter-spacing: normal;
  font-size: 0.78rem;
  font-weight: 400;
  color: #a17360;
  text-align: center;
  margin: 0;
}

/* ── Light theme overrides ───────────────────────────────────────────────── */
/* Модал (dialog.qf-modal) намеренно остаётся тёмным — так лучше для UX     */
/* Виджеты (sidebar + strip) адаптируются под светлую тему сайта            */
[data-theme="light"] .qf-widget {
  background:
    radial-gradient(circle at top, rgba(242, 100, 0, 0.14), transparent 34%),
    linear-gradient(180deg, #fff3ea 0%, #ffe8da 100%);
  border-color: var(--qf-orange);
  box-shadow: 0 18px 34px rgba(185, 103, 44, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.9);
}
[data-theme="light"] .qf-widget__title {
  color: #2f1205;
}
[data-theme="light"] .qf-widget__desc {
  color: #7d4d34;
}
[data-theme="light"] .qf-widget__input {
  background: #fff;
  border-color: #e5b697;
  color: #2d1306;
}
[data-theme="light"] .qf-widget__input::placeholder {
  color: #b08878;
}
[data-theme="light"] .qf-widget__fine {
  color: #9f6b59;
}

[data-theme="light"] .qf-strip {
  background: linear-gradient(90deg, #fff4ee 0%, #fffaf8 100%);
}
[data-theme="light"] .qf-strip__title {
  color: #1a0800;
}
[data-theme="light"] .qf-strip__desc {
  color: #7a4a30;
}
[data-theme="light"] .qf-strip__input {
  background: #fff;
  border-color: #e0b89a;
  color: #1a0800;
}
[data-theme="light"] .qf-strip__input::placeholder {
  color: #b08878;
}

/* Light theme overrides for specificity-boosted paragraph selectors */
[data-theme="light"] .qf-widget p.qf-widget__title { color: #2f1205; }
[data-theme="light"] .qf-widget p.qf-widget__desc  { color: #7d4d34; }
[data-theme="light"] .qf-widget p.qf-widget__fine  { color: #9f6b59; }

/* ── Фикс: прогресс-бар track обёртка (вынесена отдельно для flex) ──────── */
/* Структура: .qf-progress > .qf-progress__fill-track > .qf-progress__fill */
.qf-progress {
  /* переопределяем внутренность чтобы track был flex-child */
  align-items: center;
}
.qf-progress > .qf-progress__fill-track {
  flex: 1;
  height: 3px;
  background: var(--qf-border);
  border-radius: 99px;
  overflow: hidden;
}
