/* ============================================================
   quiz.css — стили инлайн-квиза (5 шагов + dead-end + контактный)
   ============================================================ */

.quiz-section {
    background-color: var(--color-bg-soft);   /* персиковый фон, как на бренд-картинке */
    padding-top: var(--space-7);
    padding-bottom: var(--space-7);
}
@media (min-width: 1024px) {
    .quiz-section { padding-top: var(--space-8); padding-bottom: var(--space-8); }
}

.quiz-section__head {
    text-align: center;
    margin-bottom: var(--space-5);
}
.quiz-section__head h2 {
    color: var(--color-brand);              /* brand (заменил inline style) */
    margin-bottom: var(--space-2);
}
.quiz-section__head h2 em {
    color: var(--color-accent);
    font-style: normal;
}
.quiz-section__head p {
    color: var(--color-text-muted);
}

/* ---------- Карточка квиза ---------- */
.quiz {
    background-color: var(--color-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    max-width: 720px;
    margin: 0 auto;
    box-shadow: var(--shadow-lg);    /* квиз — главное конверсионное место, тень акцентом */
}
@media (min-width: 768px) {
    .quiz { padding: var(--space-6); }
}

/* ---------- Прогресс ---------- */
.quiz__progress-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-bottom: 12px;
    font-size: 15px;
    color: var(--color-text-muted);
}
.quiz__progress-label {
    color: var(--color-brand);
    font-weight: 700;
}
.quiz__progress-num,
.quiz__progress-total {
    color: var(--color-accent);
    font-weight: 800;
}
.quiz__progress-time {
    font-size: 14px;
    color: var(--color-text-muted);
}
.quiz__progress {
    height: 6px;
    background-color: #f4f4f5;
    border-radius: var(--radius-full);
    overflow: hidden;
    margin-bottom: 32px;
}
.quiz__progress-bar {
    height: 100%;
    background-color: var(--color-accent);
    width: 0%;
    transition: width 380ms cubic-bezier(.2, .8, .3, 1);
    border-radius: var(--radius-full);
}
@media (max-width: 575px) {
    .quiz__progress-row { font-size: 13px; }
    .quiz__progress-time { display: none; }
}

/* ---------- Шаги: КАРУСЕЛЬНАЯ анимация ----------
   Контейнер .quiz__steps-track — CSS Grid с одной "ячейкой-стопкой": все шаги
   накладываются друг на друга, высота родителя = высоте самого высокого шага.
   Активный шаг видим, остальные с opacity:0 + translateX. Переход через transition. */
.quiz__steps-track {
    display: grid;
    grid-template-areas: "stack";
    position: relative;
}
.quiz__step {
    grid-area: stack;          /* все шаги в одной ячейке, друг над другом */
    opacity: 0;
    transform: translateX(40px);
    pointer-events: none;
    visibility: hidden;
    transition:
        opacity 380ms cubic-bezier(.2, .8, .3, 1),
        transform 460ms cubic-bezier(.2, .8, .3, 1),
        visibility 0s linear 460ms;     /* visibility меняется ПОСЛЕ transition */
}
.quiz__step.is-active {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
    visibility: visible;
    transition:
        opacity 380ms cubic-bezier(.2, .8, .3, 1),
        transform 460ms cubic-bezier(.2, .8, .3, 1),
        visibility 0s linear 0s;
    z-index: 2;
}
/* Уходящий шаг — летит влево */
.quiz__step.is-leaving {
    opacity: 0;
    transform: translateX(-40px);
    z-index: 1;
}
/* При навигации НАЗАД меняем направление: уходящий вправо, входящий слева */
.quiz__steps-track.is-back .quiz__step:not(.is-active):not(.is-leaving) {
    transform: translateX(-40px);
}
.quiz__steps-track.is-back .quiz__step.is-leaving {
    transform: translateX(40px);
}

/* Плавная анимация переключения опций */
.quiz__option-body {
    transition:
        background-color 220ms ease,
        border-color 220ms ease,
        transform 180ms ease,
        box-shadow 220ms ease;
}
.quiz__option input:checked + .quiz__option-body {
    transform: translateX(2px);
    box-shadow: 0 8px 22px rgba(var(--accent-rgb), 0.12);
}
.quiz__option-checkbox {
    transition:
        background-color 240ms cubic-bezier(.3, 1.2, .5, 1),
        color 240ms ease,
        transform 220ms cubic-bezier(.3, 1.2, .5, 1);
}
.quiz__option input:checked + .quiz__option-body .quiz__option-checkbox {
    transform: scale(1.1);
}

/* Прогресс-бар плавнее */
.quiz__progress-bar {
    transition: width 380ms cubic-bezier(.2, .8, .3, 1);
}

.quiz__question {
    font-size: 26px;
    font-weight: 800;
    margin: 0 0 10px;
    color: var(--color-brand);
    letter-spacing: -0.015em;
    line-height: 1.15;
}
@media (min-width: 768px) {
    .quiz__question { font-size: clamp(28px, 2.6vw, 36px); }
}
.quiz__subtitle {
    margin: 0 0 28px;
    color: var(--color-text-muted);
    font-size: 15px;
    line-height: 1.45;
}

/* ---------- Опции — большие radio-карточки с заголовком + подписью ---------- */
.quiz__options {
    display: grid;
    gap: 16px;
    grid-template-columns: 1fr;
    margin-bottom: 24px;
}
@media (min-width: 480px) {
    .quiz__options--cols-2 { grid-template-columns: 1fr 1fr; }
    .quiz__options--cols-3 { grid-template-columns: repeat(3, 1fr); }
}

.quiz__option {
    position: relative;
    display: block;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    height: 100%;                  /* тянем на всю высоту grid-ячейки */
}
.quiz__option input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    width: 1px;
    height: 1px;
}
.quiz__option-body {
    display: flex;
    align-items: center;
    gap: 16px;
    background-color: var(--color-bg-warm);
    border: 2px solid transparent;
    border-radius: 16px;
    padding: 20px 22px;
    transition:
        background-color 220ms ease,
        border-color 220ms ease,
        box-shadow 220ms ease,
        transform 180ms ease;
    min-height: 84px;
    height: 100%;                  /* тянем на всю высоту опции — выравнивание по самой высокой */
    box-shadow: 0 2px 0 rgba(var(--brand-rgb), 0.03) inset;
}
.quiz__option-checkbox {
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
    border-radius: 8px;
    background-color: #fff;
    border: 1.5px solid rgba(var(--brand-rgb), 0.18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: transparent;
    transition: all 240ms cubic-bezier(.3, 1.2, .5, 1);
}
.quiz__option-checkbox svg { width: 18px; height: 18px; }

.quiz__option-text {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}
/* Единый стиль для strong в опции — независимо от того, обёрнут он в .quiz__option-text или нет */
.quiz__option-body strong {
    color: var(--color-brand);
    font-weight: 800;
    font-size: 19px;
    line-height: 1.2;
}
.quiz__option-text span {
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.4;
}

.quiz__option:hover .quiz__option-body {
    background-color: #f5ece0;           /* чуть темнее бежевого */
    transform: translateY(-1px);
}
.quiz__option input:checked + .quiz__option-body {
    background-color: #fff7f3;
    border-color: var(--color-accent);
    box-shadow: 0 10px 28px rgba(var(--accent-rgb), 0.15);
}
.quiz__option input:checked + .quiz__option-body .quiz__option-checkbox {
    background-color: var(--color-accent);
    color: #fff;
    border-color: var(--color-accent);
    transform: scale(1.05);
}
.quiz__option input:focus-visible + .quiz__option-body {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

/* Простой вариант (шаг 1 — только сумма, без описаний) */
.quiz__option--simple .quiz__option-body {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 12px;
    padding: 24px 16px;
    min-height: 130px;
    justify-content: center;
}
.quiz__option--simple .quiz__option-text {
    align-items: center;
    text-align: center;
    gap: 4px;
}
.quiz__option--simple .quiz__option-text strong {
    color: var(--color-brand);
    font-weight: 800;
    font-size: 17px;
    line-height: 1.25;
}
.quiz__option--simple .quiz__option-checkbox {
    width: 32px; height: 32px; flex: 0 0 32px;
}
.quiz__option-warn {
    color: var(--color-brand);          /* фирменный тёмно-коричневый — как заголовок */
    font-size: 14px;
    font-weight: 600;
    line-height: 1.3;
    opacity: 0.7;                        /* чуть прозрачнее, чтобы был ниже по иерархии */
}
.quiz__option:has(input[value="less_300"]:checked) .quiz__option-warn {
    color: var(--color-accent);
    font-weight: 700;
    opacity: 1;
}

/* ---------- Info-блок «Почему это важно?» (под ответами) ---------- */
.quiz__info {
    margin-top: 8px;
    margin-bottom: 28px;
    background: var(--color-bg-warm);
    border-radius: 14px;
    padding: 18px 22px;
    border: 1px solid rgba(var(--brand-rgb), 0.08);
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.quiz__info-title {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--color-text-muted);
    font-weight: 700;
    font-size: 15px;
}
.quiz__info-title svg {
    width: 22px; height: 22px; flex: 0 0 22px;
    color: var(--color-text-muted);
    background: #fff;
    border: 1.5px solid rgba(var(--brand-rgb), 0.18);
    border-radius: 50%;
    padding: 2px;
    box-sizing: border-box;
}
.quiz__info p {
    margin: 0 0 0 32px;
    color: var(--color-text-muted);
    font-size: 14px;
    line-height: 1.5;
}

/* ---------- Мобильная вёрстка квиза (узкие телефоны < 480px) ---------- */
@media (max-width: 479px) {
    .quiz--big { padding: 24px 18px; border-radius: 18px; }
    .quiz__question { font-size: 22px; line-height: 1.2; margin-bottom: 8px; }
    .quiz__subtitle { font-size: 14px; margin-bottom: 22px; }

    /* На очень узких — все опции в одну колонку */
    .quiz__options { grid-template-columns: 1fr; gap: 12px; margin-bottom: 20px; }
    .quiz__option-body { padding: 16px 18px; gap: 14px; min-height: 72px; border-radius: 14px; }
    .quiz__option-checkbox { width: 32px; height: 32px; flex: 0 0 32px; border-radius: 7px; }
    .quiz__option-checkbox svg { width: 16px; height: 16px; }
    .quiz__option-text strong { font-size: 17px; }
    .quiz__option-text span { font-size: 13px; }
    .quiz__option--simple .quiz__option-body {
        flex-direction: row;
        justify-content: flex-start;
        text-align: left;
        padding: 16px 18px;
        min-height: 64px;
        gap: 14px;
    }
    .quiz__option--simple .quiz__option-body strong { font-size: 16px; }

    .quiz__info { padding: 14px 16px; margin-bottom: 22px; }
    .quiz__info-title { font-size: 14px; gap: 8px; }
    .quiz__info-title svg { width: 20px; height: 20px; flex: 0 0 20px; }
    .quiz__info p { margin-left: 28px; font-size: 14px; }

    .quiz__controls { padding-top: 16px; gap: 10px; }
    .quiz__back, .quiz__next { padding: 12px 16px; font-size: 14px; flex: 1; justify-content: center; }
    .quiz__back svg, .quiz__next svg { width: 12px; height: 12px; }
}

/* ---------- Контролы: «Назад» (outlined) + «Продолжить» (primary) ---------- */
.quiz__controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding-top: 22px;
    border-top: 1px solid rgba(var(--brand-rgb), 0.08);
}

/* Outlined-кнопка «Назад» */
.quiz__back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 24px;
    border: 1.5px solid #d4d4d8;
    background: #fff;
    color: var(--color-brand);
    font-size: 15px;
    font-weight: 600;
    border-radius: 12px;
    cursor: pointer;
    transition: background var(--t-fast) ease, border-color var(--t-fast) ease, transform var(--t-fast) ease;
}
.quiz__back svg { width: 14px; height: 14px; }
.quiz__back:hover {
    background: #fafafa;
    border-color: #a1a1aa;
    transform: translateX(-2px);
}
.quiz__back[hidden] { display: none; }
/* На первом шаге кнопки «Назад» нет — выравниваем «Продолжить» вправо */
.quiz__step[data-step="1"] .quiz__controls { justify-content: flex-end; }

/* Primary-кнопка «Продолжить» */
.quiz__next {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    border: 0;
    background: linear-gradient(180deg, #ff6a4a 0%, #ed5339 100%);
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    border-radius: 12px;
    cursor: pointer;
    box-shadow: 0 14px 28px rgba(var(--accent-rgb), 0.28);
    transition: transform var(--t-fast) ease, box-shadow var(--t-fast) ease, opacity var(--t-fast) ease;
}
.quiz__next svg { width: 18px; height: 18px; transition: transform var(--t-fast) ease; }
.quiz__next:hover:not(:disabled) {
    transform: translateY(-1px);
    box-shadow: 0 18px 36px rgba(var(--accent-rgb), 0.34);
}
.quiz__next:hover:not(:disabled) svg { transform: translateX(4px); }
.quiz__next:disabled {
    opacity: 0.45;
    cursor: not-allowed;
    box-shadow: none;
}

@media (max-width: 575px) {
    .quiz__controls { padding-top: 18px; }
    .quiz__back, .quiz__next { padding: 12px 18px; font-size: 14px; }
    .quiz__back svg, .quiz__next svg { width: 13px; height: 13px; }
}

/* На шагах с авто-переходом Далее скрыта; на финальном — справа */
.quiz__next {
    margin-left: auto;
}

/* ---------- Финальный шаг (имя/телефон) ---------- */
.quiz__form-fields {
    display: grid;
    gap: var(--space-3);
    grid-template-columns: 1fr;
    margin-bottom: var(--space-4);
}
@media (min-width: 520px) {
    .quiz__form-fields { grid-template-columns: 1fr 1fr; }
}

.quiz__input {
    width: 100%;
    padding: 14px var(--space-4);
    background-color: var(--color-card-soft);
    border: 2px solid transparent;
    border-radius: var(--radius-md);
    font-size: 15px;
    color: var(--color-text);
    transition: border-color var(--t-fast) ease, background-color var(--t-fast) ease;
}
.quiz__input::placeholder { color: var(--color-text-muted); }   /* a11y: WCAG AA 4.5:1 */
.quiz__input:focus {
    outline: none;
    border-color: var(--color-accent);
    background-color: var(--color-card);
}
.quiz__input[aria-invalid="true"] {
    border-color: var(--color-danger);
}

/* honeypot */
.quiz__hp {
    position: absolute;
    left: -9999px;
    width: 1px; height: 1px;
    opacity: 0;
    pointer-events: none;
}

.quiz__submit { width: 100%; }
.quiz__legal {
    font-size: 12px;
    color: var(--color-text-soft);
    margin-top: var(--space-3);
    text-align: center;
    line-height: 1.5;
}
.quiz__legal a {
    color: var(--color-accent-text);   /* a11y */
    text-decoration: underline;
}

.quiz__error {
    color: var(--color-danger);
    font-size: 14px;
    margin-top: var(--space-3);
    min-height: 20px;
}

/* ---------- Dead-end экран («менее 300К») ---------- */
.quiz__dead-end {
    text-align: center;
    padding: var(--space-4) 0;
    opacity: 0;
    transform: translateY(16px);
    transition:
        opacity 380ms cubic-bezier(.2, .8, .3, 1),
        transform 460ms cubic-bezier(.2, .8, .3, 1);
}
.quiz__dead-end:not([hidden]) {
    opacity: 1;
    transform: translateY(0);
}
.quiz__dead-end-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--space-4);
    color: var(--color-text-muted);
    background-color: var(--color-card-soft);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.quiz__dead-end-icon svg { width: 32px; height: 32px; }
.quiz__dead-end h3 {
    margin-bottom: var(--space-3);
}
.quiz__dead-end p {
    color: var(--color-text-muted);
    margin-bottom: var(--space-4);
    max-width: 40ch;
    margin-left: auto; margin-right: auto;
}

/* ---------- Loading state ---------- */
.quiz__submit[aria-busy="true"] {
    opacity: 0.7;
    pointer-events: none;
}
.quiz__submit[aria-busy="true"]::after {
    content: '';
    width: 16px;
    height: 16px;
    border: 2px solid currentColor;
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin-left: 8px;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ============================================================
   QUIZ--BIG: плакатный full-width квиз (Тимур: «сделай большим»)
   ============================================================ */
.quiz-section--big {
    padding-top: var(--space-8);
    padding-bottom: var(--space-8);
}
.quiz-section--big .quiz-section__head {
    text-align: center;
    margin-bottom: var(--space-6);
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
}
.quiz-section--big .quiz-section__head h2 {
    font-size: clamp(32px, 3.5vw, 52px);
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin-bottom: var(--space-3);
}
.quiz-section--big .quiz-section__sub {
    font-size: clamp(16px, 1.4vw, 20px);
    color: var(--color-text-muted);
    line-height: 1.45;
}

/* Большая центральная карточка квиза */
.quiz--big {
    max-width: 880px;
    padding: 40px;
    border-radius: 20px;
}
@media (min-width: 768px) {
    .quiz--big { padding: 56px 64px; }
}

/* Прогресс-бар толще */
.quiz--big .quiz__progress {
    height: 10px;
    margin-bottom: var(--space-6);
}

/* Вопрос крупнее */
.quiz--big .quiz__question {
    font-size: 22px;
    font-weight: 700;
    margin-bottom: var(--space-5);
    color: var(--color-brand);
}
@media (min-width: 768px) {
    .quiz--big .quiz__question { font-size: 28px; line-height: 1.25; }
}

/* Опции крупнее */
.quiz--big .quiz__options {
    gap: var(--space-3);
}
.quiz--big .quiz__option-body {
    padding: 22px 26px;
    font-size: 18px;
    font-weight: 600;
    border-radius: 12px;
    gap: var(--space-4);
}
@media (min-width: 768px) {
    .quiz--big .quiz__option-body { font-size: 19px; padding: 24px 28px; }
}
.quiz--big .quiz__option-checkbox {
    width: 28px;
    height: 28px;
    flex: 0 0 28px;
    border-radius: 8px;
}
.quiz--big .quiz__option-checkbox svg { width: 18px; height: 18px; }

/* Назад/Далее */
.quiz--big .quiz__controls { margin-top: var(--space-6); }
.quiz--big .quiz__back {
    padding: 14px 22px;
    font-size: 16px;
}

/* Финальная форма — крупнее */
.quiz--big .quiz__input {
    padding: 20px 24px;
    font-size: 17px;
    border-radius: 12px;
}
.quiz--big .quiz__submit {
    padding: 20px 28px;
    font-size: 18px;
    border-radius: 12px;
    min-height: 62px;
}
.quiz--big .quiz__legal { font-size: 13px; margin-top: var(--space-4); }

/* Dead-end побольше */
.quiz--big .quiz__dead-end-icon { width: 80px; height: 80px; }
.quiz--big .quiz__dead-end-icon svg { width: 40px; height: 40px; }
.quiz--big .quiz__dead-end h3 { font-size: 26px; }
.quiz--big .quiz__dead-end p { font-size: 17px; max-width: 50ch; }

/* Мобильная адаптация big-квиза: уменьшаем шрифты и отступы,
   иначе на 360px вылезает за viewport. */
@media (max-width: 767px) {
    .quiz-section--big { padding-top: var(--space-6); padding-bottom: var(--space-6); }
    .quiz--big {
        padding: 24px 20px;
        border-radius: 14px;
    }
    .quiz--big .quiz__progress { height: 8px; margin-bottom: var(--space-4); }
    .quiz--big .quiz__question { font-size: 19px; }
    .quiz--big .quiz__option-body {
        padding: 16px 18px;
        font-size: 16px;
        border-radius: 10px;
    }
    .quiz--big .quiz__option-checkbox {
        width: 24px;
        height: 24px;
        flex: 0 0 24px;
    }
    .quiz--big .quiz__option-checkbox svg { width: 14px; height: 14px; }
    .quiz--big .quiz__input {
        padding: 14px 16px;
        font-size: 16px;
        border-radius: 10px;
    }
    .quiz--big .quiz__submit {
        padding: 16px 22px;
        font-size: 16px;
        min-height: 54px;
        border-radius: 10px;
    }
    .quiz--big .quiz__back { padding: 10px 16px; font-size: 14px; }
}
