/**
 * IT Optimization Self Assessment - Frontend Styles
 * All sections visible, one question at a time per section
 */

/* ==============================
   WRAPPER (uses CSS variables from settings)
   ============================== */
   .qap-wrap {
    max-width: var(--qap-max-width, 860px);
    margin: 0 auto;
    padding: 0 20px 30px;
    font-family: var(--qap-font-body, inherit);
    font-weight: var(--qap-font-weight-body, 400);
    font-style: var(--qap-font-style-body, normal);
    line-height: var(--qap-font-lh-body, 1.6);
    color: var(--qap-text, #333);
    background: var(--qap-bg, transparent);
}
.qap-wrap *,
.qap-wrap *::before,
.qap-wrap *::after {
    box-sizing: border-box;
}
.qap-empty {
    text-align: center;
    padding: 60px 20px;
    color: #999;
    font-size: 16px;
}

/* ==============================
   PAGE HEADER (above all sections)
   ============================== */
.qap-page-header {
    text-align: var(--qap-page-header-align, left);
    width: var(--qap-page-header-width, auto);
    margin-top: var(--qap-page-header-mt, 0);
    margin-bottom: var(--qap-page-header-mb, 28px);
    margin-left: auto;
    margin-right: auto;
    background: var(--qap-page-header-bg, linear-gradient(105deg, rgba(6, 52, 94, 0.88) 0%, rgba(11, 96, 161, 0.78) 45%, rgba(11, 96, 161, 0.38) 100%));
    border-style: solid;
    border-color: var(--qap-page-header-border-color, transparent);
    border-top-width: var(--qap-page-header-border-top, 0);
    border-right-width: var(--qap-page-header-border-right, 0);
    border-bottom-width: var(--qap-page-header-border-bottom, 0);
    border-left-width: var(--qap-page-header-border-left, 0);
    border-radius: var(--qap-card-radius, 16px);
    padding: 42px 42px;
    position: relative;
    overflow: hidden;
}
.qap-page-header::before {
    content: var(--qap-page-header-before-content, "");
    display: var(--qap-page-header-before-display, block);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background: var(--qap-page-header-before-bg, #d6281a);
    color: var(--qap-page-header-before-color, #fff);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.2px;
    line-height: 1.2;
    padding: 10px 16px;
    text-align: center;
    z-index: 2;
}
.qap-page-header::after {
    content: "";
    display: var(--qap-page-header-after-display, block);
    position: absolute;
    inset: 42px 0 0 0;
    background: var(--qap-page-header-after-bg, linear-gradient(to bottom, rgba(0, 57, 103, 0.15), rgba(0, 57, 103, 0.55)));
    pointer-events: none;
}
.qap-page-heading {
    font-family: var(--qap-font-title, inherit) !important;
    font-size: calc(var(--qap-font-size-title, 26px) + 2px) !important;
    font-weight: var(--qap-font-weight-title, 700) !important;
    font-style: var(--qap-font-style-title, normal) !important;
    text-transform: var(--qap-font-transform-title, none) !important;
    letter-spacing: var(--qap-font-spacing-title, 0px) !important;
    line-height: var(--qap-font-lh-title, 1.3) !important;
    color: var(--qap-page-heading-color, #ffffff) !important;
    margin: 28px 0 14px !important;
    font-size: clamp(28px, 4.2vw, 52px) !important;
    max-width: 780px !important;
    position: relative !important;
    z-index: 1 !important;
}
.qap-page-subheading {
    font-size: var(--qap-page-subheading-size, 16px) !important;
    color: var(--qap-page-subheading-color, rgba(255, 255, 255, 0.92)) !important;
    max-width: var(--qap-page-subheading-max-width, 620px) !important;
    margin: var(--qap-page-subheading-mt, 0) 0 var(--qap-page-subheading-mb, 0) !important;
    line-height: var(--qap-page-subheading-lh, 1.7) !important;
    position: relative !important;
    z-index: 1 !important;
}
/* Rich HTML content styling */
.qap-page-subheading h1,
.qap-page-subheading h2,
.qap-page-subheading h3,
.qap-page-subheading h4,
.qap-page-subheading h5,
.qap-page-subheading h6 {
    color: var(--qap-title-color, #1a1a2e);
    margin: 14px 0 8px;
    line-height: 1.3;
}
.qap-page-subheading h1 { font-size: 24px; }
.qap-page-subheading h2 { font-size: 20px; }
.qap-page-subheading h3 { font-size: 18px; }
.qap-page-subheading h4 { font-size: 16px; }
.qap-page-subheading h5 { font-size: 14px; }
.qap-page-subheading h6 { font-size: 13px; }
.qap-page-subheading p {
    margin: 0 0 10px !important;
	color:#000000 !important;
}
.qap-page-subheading strong,
.qap-page-subheading b {
    font-weight: 700 !important;
    color: var(--qap-title-color, #1a1a2e) !important;
}
.qap-page-subheading em,
.qap-page-subheading i {
    font-style: italic !important;
}
.qap-page-subheading ul,
.qap-page-subheading ol {
    margin: 8px 0 12px 20px;
    padding: 0;
}
.qap-page-subheading li {
    margin-bottom: 4px;
}
.qap-page-subheading table {
    width: 100%;
    border-collapse: collapse;
    margin: 12px 0;
    font-size: 13px;
}
.qap-page-subheading table th,
.qap-page-subheading table td {
    padding: 8px 12px;
    border: 1px solid var(--qap-border, #e5e7eb);
    text-align: left;
}
.qap-page-subheading table th {
    background: var(--qap-primary, #E87D0F);
    color: #fff;
    font-weight: 600;
}
.qap-page-subheading table tr:nth-child(even) td {
    background: #f8f9fb;
}
.qap-page-subheading a {
    color: var(--qap-primary, #E87D0F);
    text-decoration: underline;
}
.qap-page-subheading blockquote {
    border-left: 3px solid var(--qap-primary, #E87D0F);
    margin: 12px 0;
    padding: 8px 16px;
    color: #666;
    font-style: italic;
    background: #fafafa;
    border-radius: 0 6px 6px 0;
}
.qap-page-subheading hr {
    border: none;
    border-top: 1px solid var(--qap-border, #e5e7eb);
    margin: 14px 0;
}
.qap-page-subheading img {
    max-width: 100%;
    height: auto;
    border-radius: 6px;
}

/* ==============================
   SECTION
   ============================== */
.qap-section {
    margin-bottom: 40px;
}

/* ==============================
   SECTION CARD
   ============================== */
.qap-section-card {
    background: var(--qap-card-bg, #fff);
    border-radius: var(--qap-card-radius, 16px);
    box-shadow: var(--qap-card-shadow, 0 2px 12px rgba(0,0,0,0.06));
    padding: 36px 40px;
}

/* ==============================
   SECTION TITLE (Section Heading – full style from backend)
   ============================== */
.qap-sec-title {
    font-family: var(--qap-sectitle-font, inherit);
    font-size: var(--qap-sectitle-size, 26px);
    font-weight: var(--qap-sectitle-weight, 700);
    text-align: var(--qap-sectitle-align, left);
    color: var(--qap-sectitle-color, #1a1a2e);
    border-color: var(--qap-sectitle-border-color, #e5e7eb);
    border-style: solid;
    border-top-width: var(--qap-sectitle-border-top, 0);
    border-right-width: var(--qap-sectitle-border-right, 0);
    border-bottom-width: var(--qap-sectitle-border-bottom, 1px);
    border-left-width: var(--qap-sectitle-border-left, 0);
    margin-top: var(--qap-sectitle-mt, 0);
    margin-bottom: var(--qap-sectitle-mb, 12px);
    margin-left: var(--qap-sectitle-ml, 0);
    margin-right: var(--qap-sectitle-mr, 0);
    padding-top: var(--qap-sectitle-pt, 0);
    padding-bottom: var(--qap-sectitle-pb, 12px);
    padding-left: var(--qap-sectitle-pl, 0);
    padding-right: var(--qap-sectitle-pr, 0);
}
/* Section Description – full style from backend */
.qap-sec-description {
    font-family: var(--qap-secdesc-font, inherit);
    font-size: var(--qap-secdesc-size, 14px);
    font-weight: var(--qap-secdesc-weight, 400);
    color: var(--qap-secdesc-color, #555555);
    line-height: 1.6;
    border-color: var(--qap-secdesc-border-color, transparent);
    border-style: solid;
    border-top-width: var(--qap-secdesc-border-top, 0);
    border-right-width: var(--qap-secdesc-border-right, 0);
    border-bottom-width: var(--qap-secdesc-border-bottom, 0);
    border-left-width: var(--qap-secdesc-border-left, 0);
    margin-top: var(--qap-secdesc-mt, 0);
    margin-bottom: var(--qap-secdesc-mb, 12px);
    margin-left: var(--qap-secdesc-ml, 0);
    margin-right: var(--qap-secdesc-mr, 0);
    padding-top: var(--qap-secdesc-pt, 0);
    padding-bottom: var(--qap-secdesc-pb, 0);
    padding-left: var(--qap-secdesc-pl, 0);
    padding-right: var(--qap-secdesc-pr, 0);
}
.qap-sec-description p { margin: 0 0 8px; }
.qap-sec-description p:last-child { margin-bottom: 0; }

/* ==============================
   QUESTION
   ============================== */
.qap-question {
    animation: qapFadeIn 0.3s ease;
}
@keyframes qapFadeIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.qap-q-badge {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: var(--qap-qbadge-font-size, 11px) !important;
    font-weight: 600 !important;
    color: var(--qap-qbadge-text, #555) !important;
    background: var(--qap-qbadge-bg, #fff) !important;
    padding: 4px 14px !important;
    margin-bottom: 12px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    font-family: var(--qap-qbadge-font, inherit) !important;
    border: var(--qap-qbadge-border, 1px) solid var(--qap-qbadge-border-color, #b3b3b3) !important;
    border-radius: var(--qap-qbadge-radius, 8px) !important;
    height: var(--qap-qbadge-height, auto) !important;
    width: var(--qap-qbadge-width, auto) !important;
    box-sizing: border-box !important;
    line-height: 1.3 !important;
}
.qap-q-text {
    font-size: calc(var(--qap-font-size-base, 15px) + 1px);
    font-weight: 500;
    color: var(--qap-text, #222);
    margin: 0 0 22px;
    line-height: 1.6;
    font-family: var(--qap-font-body, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
}
.qap-q-text h1, .qap-q-text h2, .qap-q-text h3, .qap-q-text h4, .qap-q-text h5, .qap-q-text h6, .qap-q-text strong {
    margin: 0;
}
.qap-q-text h1 { font-family: var(--qap-qtext-h1-font, inherit) !important; font-size: var(--qap-qtext-h1-size, 26px) !important; color: var(--qap-qtext-h1-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h1-weight, 700); margin-top: var(--qap-qtext-h1-mt, 0); margin-bottom: var(--qap-qtext-h1-mb, 10px); margin-left: var(--qap-qtext-h1-ml, 0) !important; margin-right: var(--qap-qtext-h1-mr, 0) !important; }
.qap-q-text h2 { font-family: var(--qap-qtext-h2-font, inherit) !important; font-size: var(--qap-qtext-h2-size, 22px) !important; color: var(--qap-qtext-h2-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h2-weight, 700) !important; margin-top: var(--qap-qtext-h2-mt, 0) !important; margin-bottom: var(--qap-qtext-h2-mb, 10px); margin-left: var(--qap-qtext-h2-ml, 0); margin-right: var(--qap-qtext-h2-mr, 0); }
.qap-q-text h3 { font-family: var(--qap-qtext-h3-font, inherit) !important; font-size: var(--qap-qtext-h3-size, 20px) !important; color: var(--qap-qtext-h3-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h3-weight, 600) !important; margin-top: var(--qap-qtext-h3-mt, 0) !important; margin-bottom: var(--qap-qtext-h3-mb, 10px); margin-left: var(--qap-qtext-h3-ml, 0); margin-right: var(--qap-qtext-h3-mr, 0); }
.qap-q-text h4 { font-family: var(--qap-qtext-h4-font, inherit) !important; font-size: var(--qap-qtext-h4-size, 18px) !important; color: var(--qap-qtext-h4-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h4-weight, 600) !important; margin-top: var(--qap-qtext-h4-mt, 0) !important; margin-bottom: var(--qap-qtext-h4-mb, 10px); margin-left: var(--qap-qtext-h4-ml, 0); margin-right: var(--qap-qtext-h4-mr, 0); }
.qap-q-text h5 { font-family: var(--qap-qtext-h5-font, inherit) !important; font-size: var(--qap-qtext-h5-size, 16px) !important; color: var(--qap-qtext-h5-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h5-weight, 600) !important; margin-top: var(--qap-qtext-h5-mt, 0) !important; margin-bottom: var(--qap-qtext-h5-mb, 10px); margin-left: var(--qap-qtext-h5-ml, 0); margin-right: var(--qap-qtext-h5-mr, 0); }
.qap-q-text h6 { font-family: var(--qap-qtext-h6-font, inherit) !important; font-size: var(--qap-qtext-h6-size, 14px) !important; color: var(--qap-qtext-h6-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h6-weight, 600) !important; margin-top: var(--qap-qtext-h6-mt, 0) !important; margin-bottom: var(--qap-qtext-h6-mb, 10px); margin-left: var(--qap-qtext-h6-ml, 0); margin-right: var(--qap-qtext-h6-mr, 0); }
.qap-q-text strong { font-family: var(--qap-qtext-strong-font, inherit) !important; font-size: var(--qap-qtext-strong-size, 14px) !important; color: var(--qap-qtext-strong-color, #1a1a2e) !important; font-weight: var(--qap-qtext-strong-weight, 700) !important; margin-top: var(--qap-qtext-strong-mt, 0) !important; margin-bottom: var(--qap-qtext-strong-mb, 10px) !important; margin-left: var(--qap-qtext-strong-ml, 0) !important; margin-right: var(--qap-qtext-strong-mr, 0) !important; }
.qap-q-text h1 { font-family: var(--qap-qtext-h1-font, inherit); font-size: var(--qap-qtext-h1-size, 26px); color: var(--qap-qtext-h1-color, #1a1a2e); font-weight: var(--qap-qtext-h1-weight, 700); margin: var(--qap-qtext-h1-mt, 0) var(--qap-qtext-h1-mr, 0) var(--qap-qtext-h1-mb, 10px) var(--qap-qtext-h1-ml, 0) !important; }
.qap-q-text h2 { font-family: var(--qap-qtext-h2-font, inherit) !important; font-size: var(--qap-qtext-h2-size, 22px) !important; color: var(--qap-qtext-h2-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h2-weight, 700) !important; margin: var(--qap-qtext-h2-mt, 0) var(--qap-qtext-h2-mr, 0) var(--qap-qtext-h2-mb, 10px) var(--qap-qtext-h2-ml, 0) !important; }
.qap-q-text h3 { font-family: var(--qap-qtext-h3-font, inherit) !important; font-size: var(--qap-qtext-h3-size, 20px) !important; color: var(--qap-qtext-h3-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h3-weight, 600) !important; margin: var(--qap-qtext-h3-mt, 0) var(--qap-qtext-h3-mr, 0) var(--qap-qtext-h3-mb, 10px) var(--qap-qtext-h3-ml, 0) !important; }
.qap-q-text h4 { font-family: var(--qap-qtext-h4-font, inherit) !important; font-size: var(--qap-qtext-h4-size, 18px) !important; color: var(--qap-qtext-h4-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h4-weight, 600) !important; margin: var(--qap-qtext-h4-mt, 0) var(--qap-qtext-h4-mr, 0) var(--qap-qtext-h4-mb, 10px) var(--qap-qtext-h4-ml, 0) !important; }
.qap-q-text h5 { font-family: var(--qap-qtext-h5-font, inherit) !important; font-size: var(--qap-qtext-h5-size, 16px) !important; color: var(--qap-qtext-h5-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h5-weight, 600) !important; margin: var(--qap-qtext-h5-mt, 0) var(--qap-qtext-h5-mr, 0) var(--qap-qtext-h5-mb, 10px) var(--qap-qtext-h5-ml, 0) !important; }
.qap-q-text h6 { font-family: var(--qap-qtext-h6-font, inherit) !important; font-size: var(--qap-qtext-h6-size, 14px) !important; color: var(--qap-qtext-h6-color, #1a1a2e) !important; font-weight: var(--qap-qtext-h6-weight, 600) !important; margin: var(--qap-qtext-h6-mt, 0) var(--qap-qtext-h6-mr, 0) var(--qap-qtext-h6-mb, 10px) var(--qap-qtext-h6-ml, 0) !important; }
.qap-q-text strong { font-family: var(--qap-qtext-strong-font, inherit); font-size: var(--qap-qtext-strong-size, 14px); color: var(--qap-qtext-strong-color, #1a1a2e); font-weight: var(--qap-qtext-strong-weight, 700) !important; margin: var(--qap-qtext-strong-mt, 0) var(--qap-qtext-strong-mr, 0) var(--qap-qtext-strong-mb, 10px) var(--qap-qtext-strong-ml, 0) !important; }
.qap-q-text p{color:#000000 !important;}
/* ==============================
   ANSWER OPTIONS
   ============================== */
.qap-options {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 28px;
}
.qap-option {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 15px 20px;
    border: 2px solid var(--qap-opt-border, #e5e7eb);
    border-radius: var(--qap-opt-radius, 10px);
    cursor: pointer;
    transition: all 0.2s ease;
    background: var(--qap-opt-bg, #fff);
    position: relative;
}
.qap-option:hover {
    border-color: var(--qap-opt-hover-border, #f5c48a);
    background: var(--qap-opt-hover-bg, #fffaf3);
}
/* Selected: label keeps default bg; overlay shows selected color + backend opacity */
.qap-option.selected {
    border-color: var(--qap-opt-active-border, #E87D0F);
    background: var(--qap-opt-bg, #fff);
}
.qap-option.selected:hover {
    border-color: var(--qap-opt-active-hover-border, #d06d0a);
    background: var(--qap-opt-bg, #fff);
}
.qap-option-selected-overlay {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    pointer-events: none;
    z-index: 0;
    background-color: var(--qap-opt-active-bg, #fff8f0);
    opacity: 0;
    transition: opacity 0.2s ease;
}
.qap-option.selected .qap-option-selected-overlay {
    opacity: var(--qap-opt-selected-opacity, 1);
}
.qap-option.selected:hover .qap-option-selected-overlay {
    background-color: var(--qap-opt-active-hover-bg, #fff0e0);
}
.qap-opt-letter,
.qap-opt-text {
    position: relative !important;
    z-index: 1 !important;
}
.qap-radio {
    position: absolute !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    pointer-events: none !important;
}
.qap-opt-letter {
    font-weight: 700 !important;
    font-size: 15px !important;
    color: #444 !important;
    min-width: 22px !important;
    flex-shrink: 0 !important;
    transition: color 0.2s ease !important;
}
.qap-opt-text {
    font-family: var(--qap-opt-text-font, inherit) !important;
    font-size: var(--qap-font-size-base, 15px) !important;
    font-weight: var(--qap-opt-text-weight, 400) !important;
    color: var(--qap-opt-text-color, #333) !important;
    flex: 1 !important;
    transition: color 0.2s ease !important;
    line-height: 1.4 !important;
}
.qap-option:hover .qap-opt-text {
    color: var(--qap-opt-text-color-hover, #222) !important;
}
.qap-option.selected .qap-opt-letter,
.qap-option.selected .qap-opt-text {
    color: var(--qap-opt-text-color-selected, #222);
}
.qap-option.selected:hover .qap-opt-text {
    color: var(--qap-opt-text-color-selected-hover, #111);
}
.qap-option.selected:hover .qap-opt-letter {
    color: var(--qap-opt-text-color-selected-hover, #111);
}

/* ----- Show/hide option letter (backend: Show option letter) ----- */
.qap-wrap[data-show-opt-letter="0"] .qap-opt-letter {
    display: none;
}
/* When letter is ON: in multiple-answer, hide checkbox (::before) and checkmark (::after) */
.qap-wrap[data-show-opt-letter="1"] .qap-question[data-allow-multiple="1"] .qap-option::before,
.qap-wrap[data-show-opt-letter="1"] .qap-question[data-allow-multiple="1"] .qap-option::after {
    display: none !important;
}
.qap-wrap[data-show-opt-letter="1"] .qap-question[data-allow-multiple="1"] .qap-option {
    padding-left: 20px;
    min-height: auto;
}

/* ----- Multiple-answer: stylish checkbox ----- */
.qap-question[data-allow-multiple="1"] .qap-options {
    gap: 12px;
}
.qap-question[data-allow-multiple="1"] .qap-option {
    padding-left: 52px;
    border-radius: 12px;
    min-height: 52px;
}
.qap-question[data-allow-multiple="1"] .qap-option::before {
    content: '';
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    width: var(--qap-checkbox-size, 24px);
    height: var(--qap-checkbox-size, 24px);
    border: 2px solid var(--qap-checkbox-border, #c5cbd3);
    border-radius: var(--qap-checkbox-radius, 6px);
    background: var(--qap-checkbox-bg, #fff);
    transition: all 0.22s ease;
    box-sizing: border-box;
}
.qap-question[data-allow-multiple="1"] .qap-option:hover::before {
    border-color: var(--qap-checkbox-border-hover, #E87D0F);
    background: var(--qap-checkbox-bg-hover, #fffaf5);
}
.qap-question[data-allow-multiple="1"] .qap-option.selected::before {
    border-color: var(--qap-checkbox-border-active, #E87D0F);
    background: var(--qap-checkbox-bg-active, #E87D0F);
}
.qap-question[data-allow-multiple="1"] .qap-option.selected::after {
    content: '';
    position: absolute;
    left: calc(18px + (var(--qap-checkbox-size, 24px) / 2));
    top: 50%;
    width: calc(var(--qap-checkmark-size, 10px) * 6 / 11);
    height: var(--qap-checkmark-size, 10px);
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: translate(-50%, -50%) rotate(45deg);
    box-sizing: border-box;
}
.qap-question[data-allow-multiple="1"] .qap-opt-letter {
    margin-left: 2px;
}

/* ==============================
   NAVIGATION
   ============================== */
.qap-nav {
    display: flex;
    align-items: center;
    gap: 16px;
    padding-top: var(--qap-nav-padding-top, 24px);
    border-top: var(--qap-nav-border, 1px solid #f0f0f0);
}

/* Buttons */
.qap-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 32px;
    font-family: var(--qap-font-button, inherit);
    font-size: var(--qap-font-size-button, 14px);
    font-weight: var(--qap-font-weight-button, 600);
    font-style: var(--qap-font-style-button, normal);
    text-transform: var(--qap-font-transform-button, none);
    letter-spacing: var(--qap-font-spacing-button, 0px);
    border: none;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 120px;
    line-height: 1.4;
    white-space: nowrap;
}

/* Previous (Secondary Button) */
.qap-prev {
    background: var(--qap-btn-secondary-bg, #1a1a2e) !important;
    color: var(--qap-btn-secondary-text, #fff) !important;
}
.qap-prev:disabled {
    background: var(--qap-btn-disabled-bg, #e5e7eb);
    color: var(--qap-btn-disabled-text, #aaa);
    cursor: not-allowed;
}
.qap-prev:hover:not(:disabled) {
    background: var(--qap-btn-secondary-hover-bg, #2c2c4a) !important;
    color: var(--qap-btn-secondary-hover-text, #fff) !important;
}
.qap-prev:focus:not(:disabled) {
    background: var(--qap-btn-secondary-focus-bg, #2c2c4a) !important;
    color: var(--qap-btn-secondary-focus-text, #fff) !important;
}

/* Next (Primary Button) */
.qap-next {
    background: var(--qap-btn-primary-bg, #E87D0F) !important;
    color: var(--qap-btn-primary-text, #fff) !important;
}
.qap-next:disabled {
    background: var(--qap-btn-disabled-bg, #e5e7eb);
    color: var(--qap-btn-disabled-text, #aaa);
    cursor: not-allowed;
}
.qap-next:hover:not(:disabled) {
    background: var(--qap-btn-primary-hover-bg, #d06d0a) !important;
    color: var(--qap-btn-primary-hover-text, #fff) !important;
}
.qap-next:focus:not(:disabled) {
    background: var(--qap-btn-primary-focus-bg, #d06d0a) !important;
    color: var(--qap-btn-primary-focus-text, #fff) !important;
}

/* ==============================
   PROGRESS BAR
   ============================== */
.qap-progress {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 14px;
}
.qap-progress-bar {
    flex: 1;
    height: var(--qap-progress-height, 8px);
    background: var(--qap-progress-bg, #e5e7eb);
    border-radius: var(--qap-progress-radius, 4px);
    overflow: hidden;
    border: var(--qap-progress-border, 0) solid var(--qap-progress-border-color, #e5e7eb);
    box-sizing: border-box;
}
.qap-progress-fill {
    height: 100%;
    background: var(--qap-progress-fill, #E87D0F);
    border-radius: var(--qap-progress-radius, 4px);
    transition: width 0.4s ease;
    width: 0;
}
.qap-progress-pct {
    font-size: 14px;
    font-weight: 600;
    color: var(--qap-progress-text, #666);
    min-width: 38px;
    text-align: right;
    white-space: nowrap;
}

/* ==============================
   CONTACT FORM (per section)
   ============================== */
/* When form is visible, section card uses form width */
.qap-section-card.qap-contact-form-visible {
    max-width: var(--qap-form-width, 500px);
}
.qap-section-card.qap-contact-form-visible.qap-form-align-left {
    margin-left: 0;
    margin-right: auto;
}
.qap-section-card.qap-contact-form-visible.qap-form-align-center {
    margin-left: auto;
    margin-right: auto;
}
.qap-section-card.qap-contact-form-visible.qap-form-align-right {
    margin-left: auto;
    margin-right: 0;
}
.qap-form-hide-sec-heading .qap-section-card.qap-contact-form-visible .qap-sec-title,
.qap-form-hide-sec-heading .qap-section-card.qap-contact-form-visible .qap-sec-description {
    display: none !important;
}
.qap-contact-form-area {
    max-width: var(--qap-form-width, 500px);
    margin: 0 auto;
    animation: qapFadeIn 0.3s ease;
}
.qap-form-title {
    font-family: var(--qap-form-title-font, inherit) !important;
    font-size: var(--qap-form-title-size, 24px) !important;
    font-weight: var(--qap-form-title-weight, 700) !important;
    font-style: var(--qap-form-title-style, italic) !important;
    color: var(--qap-form-title-color, #1a1a2e) !important;
    text-align: center !important;
    margin: var(--qap-form-title-mt, 0) var(--qap-form-title-mr, 0) var(--qap-form-title-mb, 24px) var(--qap-form-title-ml, 0) !important;
    padding: var(--qap-form-title-pt, 0) var(--qap-form-title-pr, 0) var(--qap-form-title-pb, 0) var(--qap-form-title-pl, 0) !important;
    line-height: 1.4 !important;
}
.qap-contact-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
}
.qap-field {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
}
.qap-field label {
    font-family: var(--qap-form-label-font, inherit) !important;
    font-size: var(--qap-font-size-label, 14px) !important;
    font-weight: var(--qap-font-weight-label, 600) !important;
    font-style: var(--qap-font-style-label, normal) !important;
    text-transform: var(--qap-font-transform-label, none) !important;
    color: var(--qap-form-label-color, #333333) !important;
    margin: var(--qap-form-label-mt, 0) var(--qap-form-label-mr, 0) var(--qap-form-label-mb, 4px) var(--qap-form-label-ml, 0) !important;
    padding: var(--qap-form-label-pt, 0) var(--qap-form-label-pr, 0) var(--qap-form-label-pb, 0) var(--qap-form-label-pl, 0) !important;
}
.qap-input {
    height: var(--qap-form-field-height, 44px) !important;
    box-sizing: border-box !important;
    padding: 0 16px !important;
    font-family: var(--qap-font-field, inherit) !important;
    font-size: var(--qap-font-size-field, 15px) !important;
    font-weight: var(--qap-font-weight-field, 400) !important;
    border: 2px solid var(--qap-form-field-border-color, #e5e7eb) !important;
    border-radius: 10px !important;
    outline: none !important;
    background: #fff !important;
    color: var(--qap-text, #333) !important;
    transition: border-color 0.2s ease !important;
    width: 100% !important;
	margin:0px !important;
}
.qap-input:focus {
    border-color: var(--qap-form-field-focus-border-color, #E87D0F) !important;
}
.qap-input::placeholder {
    color: var(--qap-form-field-placeholder-color, #999) !important;
}
.qap-field.has-error .qap-input {
    border-color: #dc3545 !important;
}
.qap-field-error {
    font-size: 12px !important;
    color: #dc3545 !important;
    margin-top: 2px !important;
}
.qap-form-submit {
    background: var(--qap-form-btn-bg, #E87D0F) !important;
    color: var(--qap-form-btn-text, #fff) !important;
    width: 100%;
    padding: var(--qap-form-btn-pt, 14px) var(--qap-form-btn-pr, 16px) var(--qap-form-btn-pb, 14px) var(--qap-form-btn-pl, 16px) !important;
    margin: var(--qap-form-btn-mt, 6px) var(--qap-form-btn-mr, 0) var(--qap-form-btn-mb, 0) var(--qap-form-btn-ml, 0) !important;
    font-size: var(--qap-form-submit-size, 16px) !important;
    font-weight: var(--qap-form-submit-weight, 600) !important;
    border: var(--qap-form-btn-border-width, 0) solid var(--qap-form-btn-border-color, transparent) !important;
    border-radius: var(--qap-form-btn-radius, 10px) !important;
}
.qap-form-submit:hover:not(:disabled) {
    background: var(--qap-form-btn-hover-bg, #d06d0a) !important;
    color: var(--qap-form-btn-hover-text, #fff) !important;
}
.qap-form-submit:focus:not(:disabled) {
    background: var(--qap-form-btn-hover-bg, #d06d0a) !important;
    color: var(--qap-form-btn-hover-text, #fff) !important;
}

/* ==============================
   RESULT POPUP (matches screenshot design)
   ============================== */
.qap-result-popup-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    z-index: 2147483646;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    animation: qapFadeIn 0.3s ease;
}
.qap-result-popup {
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 6px;
    width: var(--qap-popup-box-width, 520px);
    max-width: 92vw;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: 0 12px 50px rgba(0, 0, 0, 0.25);
    text-align: center;
    padding: var(--qap-popup-box-pt, 50px) var(--qap-popup-box-pr, 44px) var(--qap-popup-box-pb, 40px) var(--qap-popup-box-pl, 44px);
    animation: qapPopupIn 0.35s ease-out;
}
.qap-result-icon-circle { order: var(--qap-order-icon, 1); }
.qap-result-badge { order: var(--qap-order-badge, 2); }
.qap-result-title { order: var(--qap-order-title, 3); }
.qap-result-section-name { order: var(--qap-order-section, 4); }
.qap-result-recommendation { order: var(--qap-order-rec, 5); }
.qap-result-score-wrap { order: var(--qap-order-score, 6); width: 100%; display: flex; justify-content: var(--qap-score-align, center); }
.qap-result-br { order: var(--qap-order-br, 7); }
.qap-result-above-btns { order: var(--qap-order-above-btns, 8); width: 100%; }
.qap-result-buttons { order: var(--qap-order-buttons, 9); }
@keyframes qapPopupIn {
    from { opacity: 0; transform: scale(0.92) translateY(-20px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* Circle icon - block level, centered; one size keeps it round */
.qap-result-icon-circle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--qap-popup-icon-size, 110px);
    height: var(--qap-popup-icon-size, 110px);
    aspect-ratio: 1;
    border-radius: 50%;
    background: var(--qap-popup-icon-bg, #E87D0F);
    color: var(--qap-popup-icon-color, #fff);
    margin: 0 auto 16px;
}
.qap-result-icon-circle .dashicons {
    font-size: calc(var(--qap-popup-icon-size, 110px) * 0.45);
    width: calc(var(--qap-popup-icon-size, 110px) * 0.45);
    height: calc(var(--qap-popup-icon-size, 110px) * 0.45);
    color: inherit;
}
.qap-result-icon-circle i {
    font-size: calc(var(--qap-popup-icon-size, 110px) * 0.42);
    color: inherit;
}
.qap-result-icon-circle svg {
    width: calc(var(--qap-popup-icon-size, 110px) * 0.49);
    height: calc(var(--qap-popup-icon-size, 110px) * 0.49);
}

/* Milestone Achievement badge - block on new line; hidden if content empty via PHP */
.qap-result-badge {
    display: block;
    width: fit-content;
    margin: var(--qap-popup-badge-mt, 0) var(--qap-popup-badge-mr, 0) var(--qap-popup-badge-mb, 14px) var(--qap-popup-badge-ml, 0);
    margin-left: auto;
    margin-right: auto;
    font-size: var(--qap-popup-badge-size, 11px);
    font-weight: 500;
    color: var(--qap-popup-badge-color, #555);
    border-width: var(--qap-popup-badge-border-top, 1px) var(--qap-popup-badge-border-right, 1px) var(--qap-popup-badge-border-bottom, 1px) var(--qap-popup-badge-border-left, 1px);
    border-style: solid;
    border-color: var(--qap-popup-badge-border-color, #ddd);
    padding: var(--qap-popup-badge-pt, 4px) var(--qap-popup-badge-pr, 16px) var(--qap-popup-badge-pb, 4px) var(--qap-popup-badge-pl, 16px);
    border-radius: var(--qap-popup-badge-radius, 4px);
    letter-spacing: 0.3px;
}

/* Thank You heading; hidden if content empty via PHP */
.qap-result-title {
    font-family: var(--qap-popup-title-font, var(--qap-font-title, inherit));
    font-size: var(--qap-popup-title-size, 34px);
    font-weight: var(--qap-popup-title-weight, 700);
    font-style: var(--qap-popup-title-style, italic);
    text-transform: var(--qap-popup-title-transform, none);
    color: var(--qap-popup-title-color, #1a1a2e);
    margin: var(--qap-popup-title-mt, 0) var(--qap-popup-title-mr, 0) var(--qap-popup-title-mb, 14px) var(--qap-popup-title-ml, 0);
    padding: var(--qap-popup-title-pt, 0) var(--qap-popup-title-pr, 0) var(--qap-popup-title-pb, 0) var(--qap-popup-title-pl, 0);
    border-width: var(--qap-popup-title-border-top, 0) var(--qap-popup-title-border-right, 0) var(--qap-popup-title-border-bottom, 0) var(--qap-popup-title-border-left, 0);
    border-style: solid;
    border-color: var(--qap-popup-title-border-color, transparent);
    border-radius: var(--qap-popup-title-radius, 0);
}

/* Section name */
.qap-result-section-name {
    font-size: 14px;
    font-weight: 600;
    color: #666;
    margin-bottom: 14px;
}

/* Recommendation text (supports rich HTML) */
.qap-result-recommendation {
    font-size: 15px;
    color: #444;
    line-height: 1.7;
    text-align: left;
    margin-bottom: 20px;
    word-wrap: break-word;
}
.qap-result-recommendation p { margin: 0 0 10px; }
.qap-result-recommendation p:last-child { margin-bottom: 0; }
.qap-result-recommendation h1,
.qap-result-recommendation h2,
.qap-result-recommendation h3,
.qap-result-recommendation h4,
.qap-result-recommendation h5,
.qap-result-recommendation h6 {
    margin: 0 0 10px;
    color: var(--qap-title-color, #1a1a2e);
    line-height: 1.3;
}
.qap-result-recommendation h1 { font-size: 1.8em; }
.qap-result-recommendation h2 { font-size: 1.5em; }
.qap-result-recommendation h3 { font-size: 1.25em; }
.qap-result-recommendation h4 { font-size: 1.1em; }
.qap-result-recommendation h5 { font-size: 1em; }
.qap-result-recommendation h6 { font-size: 0.9em; }
.qap-result-recommendation strong,
.qap-result-recommendation b { font-weight: 700; }
.qap-result-recommendation em,
.qap-result-recommendation i { font-style: italic; }
.qap-result-recommendation u { text-decoration: underline; }
.qap-result-recommendation ul,
.qap-result-recommendation ol {
    margin: 8px 0 12px 20px !important;
    padding-left: 10px !important;
    text-align: left !important;
}
.qap-result-recommendation ul { list-style: disc; }
.qap-result-recommendation ol { list-style: decimal; }
.qap-result-recommendation li { margin-bottom: 4px; }
.qap-result-recommendation table {
    width: 100% !important;
    border-collapse: collapse !important;
    margin: 10px 0 !important;
    font-size: 14px !important;
}
.qap-result-recommendation table th,
.qap-result-recommendation table td {
    border: 1px solid var(--qap-border, #e5e7eb) !important;
    padding: 8px 12px !important;
    text-align: left !important;
}
.qap-result-recommendation table th {
    background: var(--qap-primary, #E87D0F) !important;
    color: #fff !important;
    font-weight: 600 !important;
}
.qap-result-recommendation table tr:nth-child(even) td {
    background: rgba(0,0,0,0.02) !important;
}
.qap-result-recommendation a {
    color: var(--qap-primary, #E87D0F) !important;
    text-decoration: underline !important;
}
.qap-result-recommendation blockquote {
    margin: 10px 0 !important;
    padding: 10px 16px !important;
    border-left: 4px solid var(--qap-primary, #E87D0F) !important;
    background: rgba(0,0,0,0.02) !important;
    font-style: italic !important;
}
.qap-result-recommendation hr {
    border: none !important;
    border-top: 1px solid var(--qap-border, #e5e7eb) !important;
    margin: 12px 0 !important;
}
.qap-result-recommendation img {
    max-width: 100% !important;
    height: auto !important;
    border-radius: 6px !important;
}
.qap-section.qap-sectitle-outside > .qap-sec-title {
    margin-bottom: var(--qap-sectitle-mb, 12px) !important;
}

/* Score tag – position via order; alignment & width from settings */
.qap-result-score-tag {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    width: var(--qap-score-width, auto) !important;
    max-width: 100% !important;
    margin: var(--qap-score-mt, 0) var(--qap-score-mr, 0) var(--qap-score-mb, 24px) var(--qap-score-ml, 0) !important;
    padding: var(--qap-score-pt, 5px) var(--qap-score-pr, 18px) var(--qap-score-pb, 5px) var(--qap-score-pl, 18px) !important;
    border-width: var(--qap-score-border-top, 1px) var(--qap-score-border-right, 1px) var(--qap-score-border-bottom, 1px) var(--qap-score-border-left, 1px) !important;
    border-style: solid !important;
    border-color: var(--qap-score-border-color, #e0e0e0) !important;
    border-radius: var(--qap-score-radius, 20px) !important;
    font-size: var(--qap-score-size, 13px) !important;
    line-height: var(--qap-score-lh, 1.2) !important;
    font-weight: var(--qap-score-weight, 400) !important;
    color: var(--qap-score-color, #555) !important;
    background: var(--qap-score-bg, transparent) !important;
}
.qap-result-score-tag strong.qap-result-score-value {
    color: var(--qap-score-value-color, #E87D0F);
    font-size: var(--qap-score-size, 13px);
    font-weight: var(--qap-score-value-weight, 700);
}

/* Popup content above buttons – HTML + custom CSS in Content → Result Popup */
.qap-result-above-btns { text-align: left; word-wrap: break-word !important; }
.qap-result-above-btn-inner { margin-bottom: 16px !important; }
.qap-result-above-btn-inner:last-child { margin-bottom: 0 !important; }

/* Popup Buttons Row */
.qap-result-buttons {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 20px !important;
    flex-wrap: wrap !important;
}

/* Back To Home button */
.qap-result-close,
.qap-btn-home-link {
    background: var(--qap-btn-primary-bg, #E87D0F) !important;
    color: var(--qap-btn-primary-text, #fff) !important;
    padding: 13px 44px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    min-width: 180px !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: none !important;
    cursor: pointer !important;
}
.qap-result-close:hover,
.qap-btn-home-link:hover {
    background: var(--qap-btn-primary-hover-bg, #d06d0a) !important;
    color: var(--qap-btn-primary-hover-text, #fff) !important;
    text-decoration: none !important;
}
.qap-result-close:focus,
.qap-btn-home-link:focus {
    background: var(--qap-btn-primary-focus-bg, #d06d0a) !important;
    color: var(--qap-btn-primary-focus-text, #fff) !important;
}

/* Contact Us button */
.qap-btn-contact {
    background: var(--qap-btn-contact-bg, #1a1a2e) !important;
    color: var(--qap-btn-contact-text, #fff) !important;
    padding: 13px 44px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    min-width: 180px !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background 0.25s, transform 0.15s !important;
    cursor: pointer !important;
    border: none !important;
    text-align: center !important;
}
.qap-btn-contact:hover {
    background: var(--qap-btn-contact-hover, #2c2c4a) !important;
    color: var(--qap-btn-contact-text, #fff) !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
}

/* ==============================
   SECTION DONE STATE
   ============================== */
/* ==============================
   SECTION DONE - Animated Success
   ============================== */
.qap-section-done {
    text-align: center !important;
    padding: 50px 30px 45px !important;
    animation: qapFadeSlideUp 0.5s ease !important;
}

/* Animated SVG Checkmark */
.qap-done-check {
    display: inline-block !important;
    margin: 0 auto 22px !important;
    width: 72px !important;
    height: 72px !important;
}
.qap-done-checkmark {
    width: 72px !important;
    height: 72px !important;
    border-radius: 50% !important;
    display: block !important;
    stroke-width: 2 !important;
    stroke: #4ade80 !important;
    stroke-miterlimit: 10 !important;
    animation: qapCheckFill 0.4s ease-in-out 0.4s forwards, qapCheckScale 0.3s ease-in-out 0.9s both !important;
    box-shadow: inset 0 0 0 #4ade80 !important;
}
.qap-done-checkmark-circle {
    stroke-dasharray: 166 !important;
    stroke-dashoffset: 166 !important;
    stroke-width: 2 !important;
    stroke-miterlimit: 10 !important;
    stroke: #4ade80 !important;
    fill: none !important;
    animation: qapCheckStroke 0.6s cubic-bezier(0.65, 0, 0.45, 1) forwards !important;
}
.qap-done-checkmark-check {
    transform-origin: 50% 50% !important;
    stroke-dasharray: 48 !important;
    stroke-dashoffset: 48 !important;
    stroke-width: 3 !important;
    stroke: #4ade80 !important;
    animation: qapCheckStroke 0.3s cubic-bezier(0.65, 0, 0.45, 1) 0.8s forwards !important;
}

@keyframes qapCheckStroke {
    100% { stroke-dashoffset: 0 !important; }
}
@keyframes qapCheckScale {
    0%, 100% { transform: none !important; }
    50% { transform: scale3d(1.1, 1.1, 1) !important; }
}
@keyframes qapCheckFill {
    100% { box-shadow: inset 0 0 0 36px rgba(74, 222, 128, 0.08) !important; }
}
@keyframes qapFadeSlideUp {
    from { opacity: 0; transform: translateY(18px) !important; }
    to { opacity: 1; transform: translateY(0) !important; }
}

.qap-done-title {
    font-family: var(--qap-done-title-font, inherit) !important;
    font-size: var(--qap-done-title-size, 20px) !important;
    font-weight: var(--qap-done-title-weight, 700) !important;
    font-style: var(--qap-done-title-style, normal) !important;
    color: var(--qap-done-title-color, #1a1a2e) !important;
    margin: var(--qap-done-title-mt, 0) var(--qap-done-title-mr, 0) var(--qap-done-title-mb, 8px) var(--qap-done-title-ml, 0) !important;
    padding: var(--qap-done-title-pt, 0) var(--qap-done-title-pr, 0) var(--qap-done-title-pb, 0) var(--qap-done-title-pl, 0) !important;
}
.qap-done-subtitle {
    font-family: var(--qap-done-subtitle-font, inherit) !important;
    font-size: var(--qap-done-subtitle-size, 13px) !important;
    font-weight: var(--qap-done-subtitle-weight, 400) !important;
    font-style: var(--qap-done-subtitle-style, normal) !important;
    color: var(--qap-done-subtitle-color, #999) !important;
    line-height: 1.6 !important;
    max-width: 360px !important;
    margin: var(--qap-done-subtitle-mt, 0) var(--qap-done-subtitle-mr, 0) var(--qap-done-subtitle-mb, 24px) var(--qap-done-subtitle-ml, 0) !important;
    padding: var(--qap-done-subtitle-pt, 0) var(--qap-done-subtitle-pr, 0) var(--qap-done-subtitle-pb, 0) var(--qap-done-subtitle-pl, 0) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Retake Button */
.qap-retake-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px !important;
    padding: 10px 28px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--qap-primary, #5b6abf) !important;
    background: transparent !important;
    border: 1.5px solid var(--qap-primary, #5b6abf) !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: all 0.25s ease !important;
}
.qap-retake-btn:hover {
    background: var(--qap-primary, #5b6abf) !important;
    color: #fff !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 14px rgba(91, 106, 191, 0.25) !important;
}
.qap-retake-btn svg {
    flex-shrink: 0 !important;
}

/* ==============================
   LOADING STATE
   ============================== */
.qap-btn.loading {
    position: relative !important;
    color: transparent !important;
    pointer-events: none !important;
}
.qap-btn.loading::after {
    content: '' !important;
    position: absolute !important;
    width: 18px !important;
    height: 18px !important;
    top: 50% !important;
    left: 50% !important;
    margin: -9px 0 0 -9px !important;
    border: 2px solid transparent;
    border-top-color: #fff !important;
    border-radius: 50% !important;
    animation: qapSpin 0.7s linear infinite !important;
}
@keyframes qapSpin {
    to { transform: rotate(360deg) !important; }
}

/* ==============================
   RESPONSIVE
   ============================== */
@media (max-width: 640px) {
    .qap-wrap {
        padding: 0 10px 16px !important;
    }
    .qap-page-header {
        padding: 24px 20px 26px !important;
        margin-bottom: 24px !important;
    }
    .qap-page-header::before {
        font-size: 11px !important;
        padding: 8px 10px !important;
    }
    .qap-page-heading {
        font-size: 28px !important;
        margin-top: 22px !important;
    }
    .qap-page-subheading {
        font-size: 14px !important;
    }
    .qap-section {
        margin-bottom: 24px !important;
    }
    .qap-section-card {
        padding: 24px 20px !important;
        border-radius: 12px !important;
    }
    .qap-q-text {
        font-size: 15px !important;
    }
    .qap-option {
        padding: 12px 14px !important;
        gap: 10px !important;
    }
    .qap-opt-letter {
        font-size: 14px !important;
    }
    .qap-opt-text {
        font-size: 14px !important;
    }
    .qap-nav {
        flex-wrap: wrap !important;
        gap: 12px !important;
    }
    .qap-btn {
        padding: 10px 22px !important;
        font-size: 13px !important;
        min-width: 100px !important;
    }
    .qap-progress {
        order: 3 !important;
        width: 100% !important;
    }
    .qap-form-title {
        font-size: 20px !important;
    }
    .qap-input {
        padding: 11px 14px !important;
        font-size: 14px !important;
    }
    .qap-result-popup {
        padding: 36px 24px 30px !important;
    }
    .qap-result-icon-circle {
        width: min(var(--qap-popup-icon-size, 110px), 90px) !important;
        height: min(var(--qap-popup-icon-size, 110px), 90px) !important;
    }
    .qap-result-icon-circle .dashicons,
    .qap-result-icon-circle i,
    .qap-result-icon-circle svg {
        /* scaled by circle size in main rule */
    }
    .qap-result-title {
        font-size: 26px !important;
    }
    .qap-result-recommendation {
        font-size: 13px !important;
    }
    .qap-result-score-tag {
        font-size: 12px !important;
    }
    .qap-section-done {
        padding: 35px 20px 30px !important;
    }
    .qap-done-check {
        width: 60px !important;
        height: 60px !important;
    }
    .qap-done-checkmark {
        width: 60px !important;
        height: 60px !important;
    }
}

@media (max-width: 400px) {
    .qap-section-card {
        padding: 18px 14px !important;
    }
    .qap-nav {
        flex-direction: column !important;
    }
    .qap-btn {
        width: 100% !important;
    }
    .qap-progress {
        order: 0 !important;
        width: 100% !important;
    }
}

/* ==============================
   THEME OVERRIDE PROTECTION
   ============================== */
.qap-wrap .qap-section-card {
    background: var(--qap-card-bg, #fff) !important;
    border-radius: var(--qap-card-radius, 16px) !important;
    box-shadow: var(--qap-card-shadow, 0 2px 12px rgba(0,0,0,0.06)) !important;
}
.qap-wrap .qap-sec-title {
    color: var(--qap-sectitle-color, #1a1a2e) !important;
    font-family: var(--qap-sectitle-font, inherit) !important;
    font-size: var(--qap-sectitle-size, 26px) !important;
    font-weight: var(--qap-sectitle-weight, 700) !important;
    text-align: var(--qap-sectitle-align, left) !important;
}
.qap-wrap .qap-sec-description {
    color: var(--qap-secdesc-color, #555555) !important;
    font-family: var(--qap-secdesc-font, inherit) !important;
    font-weight: var(--qap-secdesc-weight, 400) !important;
}
.qap-wrap .qap-q-text {
    color: var(--qap-text, #222) !important;
    font-family: var(--qap-font-body, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif) !important;
}
.qap-wrap .qap-opt-text {
    color: var(--qap-opt-text-color, #333) !important;
    font-family: var(--qap-opt-text-font, inherit) !important;
    font-weight: var(--qap-opt-text-weight, 400) !important;
}
.qap-wrap .qap-option {
    background: var(--qap-opt-bg, #fff) !important;
    border-color: var(--qap-opt-border, #e5e7eb) !important;
}
.qap-wrap .qap-option:hover {
    background: var(--qap-opt-hover-bg, #fffaf3) !important;
    border-color: var(--qap-opt-hover-border, #f5c48a) !important;
}
.qap-wrap .qap-option.selected {
    border-color: var(--qap-opt-active-border, #E87D0F) !important;
}
.qap-wrap .qap-btn,
.qap-wrap .qap-form-submit,
.qap-wrap .qap-result-close,
.qap-wrap .qap-btn-home-link,
.qap-wrap .qap-btn-contact {
    text-decoration: none !important;
}
.qap-wrap .qap-input {
    background: #fff !important;
    color: var(--qap-text, #333) !important;
    border-color: var(--qap-form-field-border-color, #e5e7eb) !important;
}
.qap-wrap .qap-input:focus {
    border-color: var(--qap-form-field-focus-border-color, #E87D0F) !important;
}
.qap-wrap .qap-result-popup {
    background: #fff !important;
}
.qap-wrap .qap-page-heading {
    color: var(--qap-page-heading-color, #ffffff) !important;
}
.qap-wrap .qap-page-subheading {
    color: var(--qap-page-subheading-color, rgba(255, 255, 255, 0.92)) !important;
}
