/*START*/
:root {
    --brand-bg: #1b2432;
    --brand-fg: #ffffff;
    --accent: #f4e4ba;
    --accent-text: #000000;
}

.quiz-layout {
    display: grid;
    grid-template-columns: 1fr 520px;
    min-height: 100vh;
}
@media (max-width: 900px) {
    .quiz-layout {
        grid-template-columns: 1fr;
    }
}

/* Ліва частина — медіа */
.quiz-media {
    position: relative;
    overflow: hidden;
    background: #000;
}
.quiz-bg {
    position: absolute;
    inset: 0;
    background-image: var(--bg-desktop);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
@media (max-width: 900px) {
    .quiz-bg {
        background-image: var(--bg-mobile, var(--bg-desktop));
    }
}
.quiz-video {
    position: absolute;
    inset: 0;
    pointer-events: none;
}
.quiz-video iframe {
    position: absolute;
    width: 120%;
    height: 120%;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    border: none;
}
.quiz-disclaimer {
    position: absolute;
    left: 12px;
    bottom: 10px;
    color: #fff;
    font-size: 13px;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.6) 60%, transparent);
    padding: 4px 10px;
    border-radius: 4px;
}

/* Права частина — контент */
.quiz-side {
    background: var(--brand-bg);
    color: var(--brand-fg);
    display: flex;
    flex-direction: column;
    padding: 30px 40px;
}
.quiz-company {
    font-weight: 600;
    opacity: 0.9;
}
.quiz-content {
    margin: auto 0;
}
.quiz-title {
    margin: 0 0 15px;
    font-size: 42px;
    line-height: 1.1;
}
.quiz-subtitle {
    margin: 0 0 25px;
    opacity: 0.9;
}
.quiz-btn {
    padding: 14px 26px;
    background: var(--accent);
    color: var(--accent-text);
    font-weight: 600;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.25);
}
.quiz-btn:hover {
    opacity: 0.9;
}
.quiz-footer {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    font-size: 14px;
    opacity: 0.8;
}
@media (max-width: 900px) {
    .quiz-side {
        padding: 20px;
    }
    .quiz-title {
        font-size: 32px;
    }
}
/*CHOICES*/
/* Секція/контейнер слайда */
.quiz-step{
    min-height:100vh;
    display:flex;
    flex-direction:column;
    background:var(--brand-bg);
    color:var(--brand-fg);
}
.quiz-inner{
    padding:42px 56px 24px;
    flex:1 1 auto;
    overflow:auto;
}
@media (max-width:900px){
    .quiz-inner{padding:28px 18px 16px}
}
.quiz-h{
    margin:0 0 22px;
    font-size:36px;
    line-height:1.2;
}

/* Сітка варіантів */
.quiz-answers{
    display:grid;
    gap:20px 24px;
}
.quiz-answers[data-columns="2"]{ grid-template-columns: repeat(2, minmax(280px, 1fr)); }
.quiz-answers[data-columns="3"]{ grid-template-columns: repeat(3, minmax(240px, 1fr)); }

@media (max-width:1000px){
    .quiz-answers{ grid-template-columns: 1fr !important; }
}

/* Елемент відповіді */
.qa input{ position:absolute; opacity:0; pointer-events:none }
.qa-box{
    display:flex; align-items:center; gap:12px;
    min-height:58px; padding:16px 18px;
    border:1px solid rgba(255,255,255,.08);
    border-radius:10px; cursor:pointer;
    background:rgba(255,255,255,.02);
    transition: border-color .15s ease, background .15s ease, box-shadow .15s ease;
}
.qa-box:hover{ border-color:rgba(255,255,255,.18); background:rgba(255,255,255,.04) }
.qa-text{ font-size:16px; line-height:1.35 }

/* Кастомні індикатори: радіо (single) */
.quiz-form--single .qa-check{
    width:18px; height:18px; border-radius:50%;
    border:2px solid rgba(255,255,255,.35); display:inline-block; flex:0 0 18px;
    position:relative;
}
.quiz-form--single input:checked + .qa-box .qa-check{
    border-color:var(--accent);
}
.quiz-form--single input:checked + .qa-box .qa-check::after{
    content:""; position:absolute; inset:4px; border-radius:50%; background:var(--accent);
}

/* Кастомні індикатори: чекбокси (multi) */
.quiz-form--multi .qa-check{
    width:18px; height:18px; border-radius:5px;
    border:2px solid rgba(255,255,255,.35); display:inline-block; flex:0 0 18px;
    position:relative;
}
.quiz-form--multi input:checked + .qa-box .qa-check{
    border-color:var(--accent); background:var(--accent);
}
.quiz-form--multi input:checked + .qa-box .qa-check::after{
    content:""; position:absolute; left:4px; top:1px; width:6px; height:12px;
    border:2px solid var(--accent-text); border-top:none; border-left:none;
    transform:rotate(45deg);
}

/* Активний/фокусований пункт */
.qa input:focus + .qa-box{ box-shadow:0 0 0 3px rgba(244,228,186,.2) }
.qa input:checked + .qa-box{
    border-color:var(--accent);
    background:rgba(244,228,186,.08);
}

/* Навігація знизу */
.quiz-nav{
    position:sticky; bottom:0; left:0; right:0;
    background:linear-gradient(180deg, rgba(27,36,50,.96), rgba(27,36,50,1));
    border-top:1px solid rgba(255,255,255,.06);
    padding:12px 16px;
    display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.quiz-nav__btns{ display:flex; gap:12px }
.btn{
    border:none; border-radius:10px; padding:12px 18px; font-weight:600; cursor:pointer;
    background:var(--accent); color:var(--accent-text);
}
.btn--ghost{
    background:transparent; color:#cbd5e1; border:1px solid rgba(255,255,255,.15);
}

/* Прогрес */
.quiz-progress{ display:flex; align-items:center; gap:10px; color:#cbd5e1; font-size:13px }
.quiz-progress .dot{
    width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.35); display:inline-block;
}
.quiz-progress .dot.is-active{ background:#fff }
.step-label{ opacity:.8; margin-left:6px }





/* Повноекранний слайд, поверх будь-якого контейнера */
.quiz-step--full{
    position: fixed;       /* перекриває обмеження батька */
    inset: 0;              /* top:0; right:0; bottom:0; left:0 */
    display: flex;
    flex-direction: column;
    background: var(--brand-bg);
    color: var(--brand-fg);
    overflow: hidden;      /* без горизонтальної прокрутки */
    z-index: 10;           /* якщо потрібно — підніми вище */
}

/* Прокручується лише контент */
.quiz-step--full .quiz-inner{
    flex: 1 1 auto;
    width: 100%;
    height: 100%;
    padding: 48px 64px 32px;
    overflow: auto;
    box-sizing: border-box;
}

/* Нижня панель завжди знизу */
.quiz-step--full .quiz-nav{
    flex-shrink: 0;
    margin-top: auto;
    width: 100%;
    background: linear-gradient(180deg, rgba(27,36,50,.96), rgba(27,36,50,1));
    border-top: 1px solid rgba(255,255,255,.06);
    padding: 12px 16px;
    box-sizing: border-box;
}

@media (max-width: 900px){
    .quiz-step--full .quiz-inner{ padding: 28px 20px 16px; }
}







/* ====== MODAL (safe, no :root vars, all scoped by .u-modal) ====== */

/* wrapper */
.u-modal{
    display:none;
    position:fixed;
    top:0; right:0; bottom:0; left:0;
    z-index:9999;
    padding:24px 14px;
}
.u-modal.is-open{ display:block; }

/* overlay */
.u-modal__overlay{
    position:absolute;
    top:0; right:0; bottom:0; left:0;
    background: rgba(0,0,0,.60);
}

/* dialog */
.u-modal__dialog{
    position:relative;
    width:520px;
    max-width: calc(100% - 28px);
    margin: 6vh auto 0;
    background:#ffffff;
    border-radius:14px;
    overflow:hidden;
    box-shadow: 0 18px 60px rgba(0,0,0,.35);
}

/* content (form) */
.u-modal__content{
    margin:0;
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    color:#1f2937;
}

/* header */
.u-modal__header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:16px 18px;
    border-bottom:1px solid #ececec;
}
.u-modal__title{
    font-size:18px;
    font-weight:700;
    line-height:1.2;
}
.u-modal__close{
    -webkit-appearance:none;
    appearance:none;
    border:0;
    background:transparent;
    cursor:pointer;
    font-size:28px;
    line-height:1;
    padding:0 6px;
    color:#6b7280;
}
.u-modal__close:hover{ color:#1f2937; }

/* body */
.u-modal__body{
    padding:18px;
    display:grid;
    gap:12px;
}
.u-modal__label{
    display:grid;
    gap:6px;
    font-size:13px;
    color:#6b7280;
}
.u-modal__input{
    width:100%;
    box-sizing:border-box;
    padding:10px 12px;
    border:1px solid #d7d7d7;
    border-radius:10px;
    outline:none;
    font-size:14px;
    color:#1f2937;
    background:#ffffff;
}
.u-modal__input:focus{
    border-color:#3b5bff;
    box-shadow: 0 0 0 4px rgba(59,91,255,.18);
}

.u-modal__captcha{ margin-top:4px; }
.u-modal__socials{ margin-top:6px; }

/* rows */
.u-modal__row{
    display:flex;
    align-items:center;
    gap:12px;
    flex-wrap:wrap;
}
.u-modal__row--between{ justify-content:space-between; }

/* checkbox */
.u-modal__checkbox{
    display:flex;
    align-items:center;
    gap:8px;
    font-size:14px;
    color:#1f2937;
    user-select:none;
}
.u-modal__checkbox input{ transform: translateY(1px); }

/* link */
.u-modal__link{
    font-size:14px;
    color:#3b5bff;
    text-decoration:none;
}
.u-modal__link:hover{ text-decoration:underline; }

/* footer */
.u-modal__footer{
    padding:14px 18px;
    border-top:1px solid #ececec;
    display:flex;
    gap:10px;
    justify-content:flex-end;
    flex-wrap:wrap;
}

/* buttons */
.u-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:10px 14px;
    border-radius:10px;
    border:1px solid transparent;
    text-decoration:none;
    cursor:pointer;
    font-size:14px;
    line-height:1;
    white-space:nowrap;
    user-select:none;
}
.u-btn--primary{
    background:#3b5bff;
    color:#ffffff;
}
.u-btn--primary:hover{ background:#2f49d6; }
.u-btn--ghost{
    background:#ffffff;
    border-color:#d7d7d7;
    color:#1f2937;
}
.u-btn--ghost:hover{ border-color:#bdbdbd; }

/* mobile */
@media (max-width: 420px){
    .u-modal__header{ padding:14px 14px; }
    .u-modal__body{ padding:14px; }
    .u-modal__footer{ padding:12px 14px; }
}


