/* ================================================================
   AHNAF.KZ — TEST PAGE v2
   public/assets/site/css/test.css
================================================================ */

.test-page { padding: 32px 0 72px; }
.test-wrap  { max-width: 700px; margin: 0 auto; }

/* ── Шапка (не sticky) ────────────────────────────────────────── */
.qz-top {
    display: flex; align-items: center;
    justify-content: space-between; gap: 16px;
    margin-bottom: 20px; flex-wrap: wrap;
}
.qz-top__left { display: flex; flex-direction: column; gap: 4px; }
.qz-back {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 12.5px; font-weight: 600;
    color: var(--teal); text-decoration: none;
    transition: opacity .2s;
}
.qz-back:hover { opacity: .7; }
.qz-title {
    font-family: var(--font-display);
    font-size: clamp(22px, 3.5vw, 32px);
    font-weight: 400; color: var(--ink); line-height: 1.1;
}

/* ── Таймер ──────────────────────────────────────────────────── */
.quiz-timer {
    display: inline-flex; align-items: center; gap: 7px;
    background: var(--teal-dark);
    border-radius: 22px; padding: 9px 18px;
    font-size: 18px; font-weight: 700;
    color: #fff; font-variant-numeric: tabular-nums; flex-shrink: 0;
    transition: background .4s;
}
.quiz-timer.is-warning { background: #d97706; }
.quiz-timer.is-danger  {
    background: #dc2626;
    animation: pulse-danger .8s ease-in-out infinite;
}
@keyframes pulse-danger { 0%,100% { opacity: 1; } 50% { opacity: .6; } }

/* ── Прогресс ────────────────────────────────────────────────── */
.qz-progress-row {
    display: flex; align-items: center; gap: 12px;
    margin-bottom: 20px;
}
.qz-progress-text { font-size: 13px; color: var(--muted); white-space: nowrap; }
.qz-progress-bar  { flex: 1; height: 6px; background: var(--cream-2); border-radius: 3px; overflow: hidden; }
.qz-progress-fill { height: 100%; background: var(--teal); border-radius: 3px; transition: width .35s ease; }

/* ── Карточка вопроса ────────────────────────────────────────── */
.qz-card {
    background: var(--white);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-card);
    padding: 24px 26px;
    margin-bottom: 20px;
    min-height: 220px;
}
.res-question-card { margin-top: 24px; }

.qz-card__header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 14px;
}
.qz-card__qnum {
    font-size: 11px; font-weight: 600;
    letter-spacing: .1em; text-transform: uppercase;
    color: var(--teal);
}
.qz-card__text {
    font-size: 16px; font-weight: 600;
    color: var(--ink); line-height: 1.5;
    margin-bottom: 22px;
}

/* ── Варианты ────────────────────────────────────────────────── */
.qcard__options {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
@media (max-width: 480px) { .qcard__options { grid-template-columns: 1fr; } }

.opt-item {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 14px;
    border: 1.5px solid var(--cream-2); border-radius: var(--r-md);
    background: var(--white); cursor: pointer; text-align: left;
    transition: border-color .2s, background .2s, transform .15s;
    font-family: var(--font-body); width: 100%;
}
.opt-item:hover:not(.opt-item--result) {
    border-color: var(--teal-light); background: var(--mint-soft); transform: translateY(-1px);
}
.opt-item.is-selected { border-color: var(--teal); background: var(--mint); }
.opt-item.is-selected .opt-item__letter { background: var(--teal); color: #fff; }

.opt-item__letter {
    width: 28px; height: 28px; flex-shrink: 0; border-radius: 7px;
    font-size: 12px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    transition: background .2s, color .2s;
}
.opt-item__text { font-size: 14px; font-weight: 500; color: var(--ink); line-height: 1.35; flex: 1; }

.opt-item--blue   .opt-item__letter { background: #dbeafe; color: #1d4ed8; }
.opt-item--green  .opt-item__letter { background: #dcfce7; color: #15803d; }
.opt-item--orange .opt-item__letter { background: #ffedd5; color: #c2410c; }
.opt-item--purple .opt-item__letter { background: #ede9fe; color: #6d28d9; }

/* Варианты в результатах */
.opt-item--result {
    cursor: default;
    color: var(--muted); border-color: var(--cream-2);
}
.opt-item--result .opt-item__letter { background: var(--cream-2); color: var(--muted); }

.opt-result--correct {
    border-color: #bbf7d0 !important; background: #f0fdf4 !important;
}
.opt-result--correct .opt-item__letter { background: #16a34a !important; color: #fff !important; }
.opt-result--correct .opt-item__text   { color: var(--ink) !important; font-weight: 600; }

.opt-result--wrong {
    border-color: #fecaca !important; background: #fef2f2 !important;
}
.opt-result--wrong .opt-item__letter { background: #dc2626 !important; color: #fff !important; }
.opt-result--wrong .opt-item__text   { color: var(--ink) !important; }

.res-opt-mark { font-size: 14px; font-weight: 700; flex-shrink: 0; }
.opt-result--correct .res-opt-mark { color: #16a34a; }
.opt-result--wrong   .res-opt-mark { color: #dc2626; }

/* ── Кнопки Алдыңғы / Келесі ─────────────────────────────────── */
.qz-nav-row {
    display: flex; justify-content: space-between; gap: 10px;
    margin-bottom: 20px;
}
.qz-nav-btn {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 10px 20px;
    border: 1.5px solid var(--cream-2); border-radius: var(--r-md);
    background: var(--white); color: var(--ink-2);
    font-size: 14px; font-weight: 500; font-family: var(--font-body);
    cursor: pointer; transition: border-color .2s, color .2s;
}
.qz-nav-btn:hover:not(.is-disabled) { border-color: var(--teal); color: var(--teal); }
.qz-nav-btn--next { margin-left: auto; }
.qz-nav-btn.is-disabled,
.qz-nav-btn:disabled { opacity: .35; cursor: not-allowed; pointer-events: none; }

/* ══════════════════════════════════════════════════════════════
   НУМЕРАЦИЯ (умная)
══════════════════════════════════════════════════════════════ */
.qz-numbers {
    display: flex; flex-wrap: wrap; gap: 6px;
    justify-content: center; margin-bottom: 24px;
}
.qz-num {
    width: 36px; height: 36px;
    border: 1.5px solid var(--cream-2); border-radius: 8px;
    font-size: 13px; font-weight: 600;
    background: var(--white); color: var(--muted);
    cursor: pointer; transition: all .18s;
}
.qz-num:hover { border-color: var(--teal); color: var(--teal); }

/* Текущий вопрос */
.qz-num.is-current {
    border-color: var(--teal); color: var(--teal);
    box-shadow: 0 0 0 3px rgba(11,110,107,.14);
}
/* Отвечен */
.qz-num.is-answered {
    background: var(--teal); border-color: var(--teal); color: #fff;
}
/* Текущий при просмотре результатов */
.qz-num.is-current-res {
    outline: 2.5px solid var(--ink);
    outline-offset: 1px;
}
/* Правильный (в результатах) */
.qz-num.is-correct {
    background: #16a34a; border-color: #16a34a; color: #fff;
}
/* Неправильный (в результатах) */
.qz-num.is-wrong {
    background: #dc2626; border-color: #dc2626; color: #fff;
}

/* ── Завершить ───────────────────────────────────────────────── */
.qz-submit-row {
    display: flex; flex-direction: column; align-items: center; gap: 12px;
    padding-top: 8px;
}
.qz-submit-hint {
    font-size: 13px; color: #ef4444; font-weight: 500;
    opacity: 0; transition: opacity .3s; text-align: center;
}
.qz-submit-hint.is-visible { opacity: 1; }

.quiz-submit-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 12px 36px;
    background: var(--teal); color: #fff;
    font-size: 15px; font-weight: 600; font-family: var(--font-body);
    border: none; border-radius: 28px; cursor: pointer;
    box-shadow: 0 4px 16px rgba(11,110,107,.28);
    transition: background var(--tr), transform var(--tr);
}
.quiz-submit-btn:hover { background: var(--teal-dark); transform: translateY(-1px); }

/* ══════════════════════════════════════════════════════════════
   НӘТИЖЕ / RESULTS
══════════════════════════════════════════════════════════════ */
.res-header {
    display: flex; align-items: center;
    justify-content: space-between; gap: 20px;
    margin-bottom: 28px; flex-wrap: wrap;
}
.res-score-card {
    display: flex; align-items: center; gap: 20px;
    background: var(--white);
    border-radius: var(--r-lg);
    padding: 20px 28px;
    box-shadow: var(--sh-card);
    border-left: 5px solid var(--teal);
    flex-wrap: wrap;
}
.res-score-card.is-good { border-left-color: #16a34a; }
.res-score-card.is-mid  { border-left-color: #d97706; }
.res-score-card.is-low  { border-left-color: #dc2626; }

.res-score__circle {
    width: 76px; height: 76px;
    border-radius: 50%; background: var(--teal);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; gap: 1px;
}
.res-score__circle.is-good { background: #16a34a; }
.res-score__circle.is-mid  { background: #d97706; }
.res-score__circle.is-low  { background: #dc2626; }

.res-score__num  { font-size: 28px; font-weight: 700; color: #fff; line-height: 1; }
.res-score__of   { font-size: 14px; color: rgba(255,255,255,.65); align-self: flex-end; padding-bottom: 3px; }
.res-score__pct  { font-size: 26px; font-weight: 700; color: var(--ink); }
.res-score__msg  { font-size: 13px; color: var(--muted); margin-top: 2px; }

.res-header__btns { display: flex; gap: 10px; flex-wrap: wrap; }
.res-btn {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 10px 20px; border-radius: 24px;
    font-size: 13.5px; font-weight: 600; font-family: var(--font-body);
    cursor: pointer; text-decoration: none; white-space: nowrap;
    transition: background var(--tr), color var(--tr);
}
.res-btn--outline {
    border: 1.5px solid var(--cream-2); color: var(--ink-2); background: var(--white);
}
.res-btn--outline:hover { border-color: var(--teal); color: var(--teal); }
.res-btn--teal { background: var(--teal); color: #fff; border: none; }
.res-btn--teal:hover { background: var(--teal-dark); }

/* Статус вопроса в результатах */
.res-q-status {
    font-size: 13px; font-weight: 700;
    padding: 4px 12px; border-radius: 20px;
}
.res-q-status.is-correct { background: #dcfce7; color: #16a34a; }
.res-q-status.is-wrong   { background: #fee2e2; color: #dc2626; }