/* ThyroQuiz 3.1 */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:wght@300;400;500&display=swap');

[id^="tq-app-"] {
    all: initial !important;
    font-family: 'DM Sans', sans-serif !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    background: #faf9f7 !important;
    color: #1a1612 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    -webkit-font-smoothing: antialiased !important;
}
[id^="tq-app-"] * { box-sizing: border-box !important; }
[id^="tq-app-"] button {
    font-family: 'DM Sans', sans-serif !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    box-shadow: none !important;
}

/* ── Header ───────────────────────────────────────────── */
.tq-header {
    width: 100% !important; max-width: 680px !important;
    padding: 24px 24px 0 !important;
    display: flex !important; align-items: center !important; justify-content: space-between !important;
}
.tq-close-btn {
    cursor: pointer !important; color: #7a6e65 !important; font-size: 20px !important;
    line-height: 1 !important; padding: 4px !important; background: none !important;
    border: none !important; display: flex !important; align-items: center !important;
    transition: color 0.15s !important;
}
.tq-close-btn:hover { color: #1a1612 !important; }
.tq-logo {
    font-family: 'DM Serif Display', serif !important;
    font-size: 22px !important; font-weight: 400 !important;
    letter-spacing: -0.5px !important; color: #1a1612 !important; text-transform: none !important;
}
.tq-logo em { font-style: italic !important; }

/* ── Progress bar ─────────────────────────────────────── */
.tq-progress-wrap {
    width: 100% !important; max-width: 680px !important; padding: 16px 0 0 !important;
}
/* The track: no padding, edge-to-edge within container */
.tq-progress-track {
    width: 100% !important; height: 2px !important;
    background: #e8e4df !important; overflow: visible !important; position: relative !important;
}
/* Fill: set by JS with inline style */
#tq-bar-1, #tq-bar-2, #tq-bar-3,
[id^="tq-bar-"] {
    height: 2px !important;
    background: #1a1612 !important;
    display: block !important;
    transition: width 0.4s ease !important;
    position: absolute !important; top: 0 !important; left: 0 !important;
}
.tq-progress-labels {
    display: flex !important; justify-content: space-between !important;
    margin-top: 8px !important; font-size: 12px !important;
    color: #7a6e65 !important; font-weight: 400 !important;
    letter-spacing: 0.02em !important;
}

/* ── Back button row ──────────────────────────────────── */
.tq-back-row {
    width: 100% !important; max-width: 680px !important; padding: 20px 24px 0 !important;
}
.tq-btn-back-circle {
    width: 44px !important; height: 44px !important; border-radius: 50% !important;
    border: 1.5px solid #e8e4df !important; background: #ffffff !important;
    cursor: pointer !important; display: flex !important;
    align-items: center !important; justify-content: center !important;
    color: #7a6e65 !important; transition: border-color 0.18s, color 0.18s !important;
}
.tq-btn-back-circle:hover { border-color: #b8a99a !important; color: #1a1612 !important; }
.tq-btn-back-circle svg { display: block !important; pointer-events: none !important; }

/* ── Stage ────────────────────────────────────────────── */
.tq-stage {
    width: 100% !important; max-width: 680px !important;
    padding: 40px 24px 80px !important; transition: opacity 0.25s !important;
}

/* ── Spinner ──────────────────────────────────────────── */
.tq-loading-msg {
    display: flex !important; flex-direction: column !important;
    align-items: center !important; gap: 16px !important;
    padding: 80px 0 !important; color: #7a6e65 !important; font-size: 14px !important;
}
.tq-spinner {
    width: 28px !important; height: 28px !important;
    border: 2px solid #e8e4df !important; border-top-color: #8b6f5e !important;
    border-radius: 50% !important; animation: tq-spin 0.7s linear infinite !important;
    background: none !important;
}
@keyframes tq-spin { to { transform: rotate(360deg); } }
@keyframes tq-fadein {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Question ─────────────────────────────────────────── */
.tq-question-wrap { animation: tq-fadein 0.35s ease !important; }
.tq-q-number {
    font-size: 11px !important; letter-spacing: 0.12em !important;
    text-transform: uppercase !important; color: #7a6e65 !important;
    margin-bottom: 16px !important; font-weight: 400 !important; display: block !important;
}
.tq-question-text {
    font-family: 'DM Serif Display', serif !important;
    font-size: clamp(26px, 5vw, 36px) !important; line-height: 1.25 !important;
    font-weight: 400 !important; color: #1a1612 !important;
    letter-spacing: -0.5px !important; text-transform: none !important;
    margin: 0 0 40px !important; display: block !important; background: none !important;
}

/* ── Options ──────────────────────────────────────────── */
.tq-options { display: flex !important; flex-direction: column !important; gap: 10px !important; }
.tq-option {
    appearance: none !important; -webkit-appearance: none !important;
    display: flex !important; align-items: center !important; gap: 14px !important;
    width: 100% !important; padding: 18px 22px !important;
    background: #ffffff !important; border: 1.5px solid #e8e4df !important;
    border-radius: 10px !important; text-align: left !important; cursor: pointer !important;
    font-family: 'DM Sans', sans-serif !important; font-size: 15px !important;
    font-weight: 400 !important; color: #1a1612 !important;
    transition: border-color 0.18s ease, background 0.18s ease !important;
    line-height: 1.45 !important; box-sizing: border-box !important;
    box-shadow: none !important; outline: none !important;
    text-transform: none !important; letter-spacing: normal !important; margin: 0 !important;
}
.tq-option:hover { border-color: #b8a99a !important; background: #fdfbf9 !important; }
.tq-option.tq-selected { background: #1a1612 !important; border-color: #1a1612 !important; color: #ffffff !important; }
.tq-opt-letter {
    display: flex !important; align-items: center !important; justify-content: center !important;
    flex-shrink: 0 !important; width: 28px !important; height: 28px !important; min-width: 28px !important;
    border-radius: 50% !important; border: 1.5px solid #e8e4df !important;
    font-size: 12px !important; font-weight: 500 !important; color: #7a6e65 !important;
    background: transparent !important; transition: border-color 0.18s, color 0.18s !important;
    box-sizing: border-box !important; text-transform: uppercase !important;
    line-height: 1 !important; padding: 0 !important; margin: 0 !important;
}
.tq-option:hover .tq-opt-letter { border-color: #b8a99a !important; color: #1a1612 !important; }
.tq-option.tq-selected .tq-opt-letter {
    background: rgba(255,255,255,0.15) !important;
    border-color: rgba(255,255,255,0.3) !important; color: #fff !important;
}

/* ── Transition overlay is built with inline styles in JS ─ */
/* These classes are for the heading/sub inside it */
.tq-trans-heading {
    font-family: 'DM Serif Display', serif !important;
    font-size: clamp(32px, 5.5vw, 52px) !important; font-weight: 400 !important;
    color: #ffffff !important; letter-spacing: -0.5px !important;
    line-height: 1.15 !important; text-transform: none !important;
    margin: 0 0 18px !important;
}

/* ── Result ───────────────────────────────────────────── */
.tq-result { text-align: center !important; animation: tq-fadein 0.5s ease !important; padding-top: 20px !important; }
.tq-result-badge {
    display: inline-flex !important; align-items: center !important; gap: 8px !important;
    background: #f0e8e3 !important; color: #8b6f5e !important; padding: 8px 18px !important;
    border-radius: 100px !important; font-size: 12px !important; font-weight: 500 !important;
    letter-spacing: 0.08em !important; text-transform: uppercase !important; margin-bottom: 28px !important;
}
.tq-result-title {
    font-family: 'DM Serif Display', serif !important;
    font-size: clamp(32px, 6vw, 48px) !important; font-weight: 400 !important;
    color: #1a1612 !important; letter-spacing: -1px !important;
    line-height: 1.1 !important; text-transform: none !important;
    margin: 0 0 20px !important; display: block !important;
}
.tq-score-bar-wrap {
    margin: 36px 0 !important; background: #e8e4df !important;
    border-radius: 4px !important; height: 6px !important; overflow: hidden !important;
}
.tq-score-bar {
    height: 100% !important; border-radius: 4px !important;
    background: linear-gradient(90deg, #d4a574, #8b6f5e) !important;
    width: 0% !important; transition: width 1.1s cubic-bezier(0.4,0,0.2,1) !important;
}
.tq-result-desc {
    font-size: 16px !important; line-height: 1.7 !important; color: #7a6e65 !important;
    max-width: 480px !important; margin: 0 auto 40px !important; display: block !important;
}
.tq-cat-grid {
    display: grid !important; grid-template-columns: repeat(3,1fr) !important;
    gap: 12px !important; margin-bottom: 40px !important;
}
.tq-cat-pill {
    padding: 16px !important; border: 1.5px solid #e8e4df !important;
    border-radius: 10px !important; font-size: 13px !important; font-weight: 500 !important;
    text-align: center !important; color: #7a6e65 !important; background: transparent !important;
    text-transform: none !important;
}
.tq-cat-pill.tq-active { border-color: #8b6f5e !important; background: #f0e8e3 !important; color: #8b6f5e !important; }

/* ── CTA / optin ──────────────────────────────────────── */
.tq-btn-cta {
    all: unset !important; display: block !important; width: 100% !important;
    padding: 17px !important; background: #1a1612 !important; color: #fff !important;
    border-radius: 10px !important; text-align: center !important;
    font-family: 'DM Sans', sans-serif !important; font-size: 16px !important;
    font-weight: 500 !important; cursor: pointer !important;
    transition: opacity 0.2s !important; margin-bottom: 12px !important; box-sizing: border-box !important;
}
.tq-btn-cta:hover { opacity: 0.85 !important; }
.tq-btn-secondary {
    all: unset !important; display: block !important; width: 100% !important;
    padding: 16px !important; color: #7a6e65 !important;
    border: 1.5px solid #e8e4df !important; border-radius: 10px !important;
    text-align: center !important; font-family: 'DM Sans', sans-serif !important;
    font-size: 15px !important; cursor: pointer !important;
    transition: border-color 0.18s, color 0.18s !important; box-sizing: border-box !important;
}
.tq-btn-secondary:hover { border-color: #b8a99a !important; color: #1a1612 !important; }
.tq-optin-box {
    background: #fff !important; border: 1.5px solid #e8e4df !important;
    border-radius: 14px !important; padding: 28px !important;
    text-align: left !important; margin-top: 8px !important;
}
.tq-optin-title {
    font-family: 'DM Serif Display', serif !important;
    font-size: 22px !important; font-weight: 400 !important; color: #1a1612 !important;
    margin: 0 0 6px !important; display: block !important;
}
.tq-optin-sub {
    font-size: 14px !important; color: #7a6e65 !important;
    margin: 0 0 20px !important; line-height: 1.5 !important; display: block !important;
}
.tq-input {
    all: unset !important; display: block !important; width: 100% !important;
    padding: 13px 16px !important; border: 1.5px solid #e8e4df !important;
    border-radius: 8px !important; font-family: 'DM Sans', sans-serif !important;
    font-size: 15px !important; color: #1a1612 !important; background: #fff !important;
    margin-bottom: 10px !important; box-sizing: border-box !important;
}
.tq-input:focus { border-color: #b8a99a !important; }
.tq-thanks {
    text-align: center !important; color: #2a7a4f !important;
    font-size: 15px !important; padding: 14px 0 0 !important; font-weight: 500 !important;
}

@media (max-width: 520px) {
    .tq-cat-grid { grid-template-columns: 1fr !important; }
    .tq-stage    { padding-left: 16px !important; padding-right: 16px !important; }
}
