/* ==========================================================
   SALUMA — Tema sobre Bootstrap 5.3
   Paleta extraída da logo oficial:
   navy #0A1024 · navy-2 #101A36 · gold #C9962E · gold-strong #E6B84C
   gold-light #FFDB6A · ink #1B2233 · gray #F8FAFC
   ========================================================== */

:root {
    --sal-navy: #0A1024;
    --sal-navy-2: #101A36;
    --sal-navy-3: #18244A;
    --sal-gold: #C9962E;
    --sal-gold-strong: #E6B84C;
    --sal-gold-light: #FFDB6A;
    --sal-gold-deep: #A87B1F;
    --sal-ink: #1B2233;
    --sal-gray: #F8FAFC;
    --sal-soft: #B9C2D8;
    --sal-radius: 18px;
    --sal-shadow: 0 18px 45px rgba(10, 16, 36, .12);
    --sal-gold-grad: linear-gradient(135deg, #E6B84C 0%, #C9962E 60%, #A87B1F 100%);
}

html { scroll-behavior: smooth; scroll-padding-top: 84px; }
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    * { transition: none !important; animation: none !important; }
}

body.saluma-body {
    font-family: 'Poppins', system-ui, -apple-system, sans-serif;
    color: var(--sal-ink);
    background: var(--sal-gray);
}

/* ---------- Navbar ---------- */
.saluma-navbar {
    background: rgba(10, 16, 36, .92);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(201, 150, 46, .25);
    padding-top: .65rem;
    padding-bottom: .65rem;
}
.saluma-navbar .brand-text {
    color: var(--sal-gold-strong);
    font-weight: 800;
    letter-spacing: 3px;
    font-size: 1.15rem;
}
.saluma-navbar .navbar-logo { border-radius: 50%; }
.saluma-navbar .nav-link { color: #E7EBF5; font-weight: 500; }
.saluma-navbar .nav-link:hover,
.saluma-navbar .nav-link:focus { color: var(--sal-gold-light); }
.saluma-navbar .navbar-toggler { border-color: rgba(230, 184, 76, .5); }
.saluma-navbar .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(230,184,76,1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* ---------- Botões ---------- */
.btn-gold {
    background: var(--sal-gold-grad);
    color: var(--sal-navy);
    font-weight: 700;
    border: 0;
    border-radius: 14px;
    box-shadow: 0 10px 26px rgba(201, 150, 46, .35);
    transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.btn-gold:hover, .btn-gold:focus {
    color: var(--sal-navy);
    filter: brightness(1.08);
    transform: translateY(-1px);
    box-shadow: 0 14px 32px rgba(201, 150, 46, .45);
}
.btn-gold:active { transform: translateY(0); color: var(--sal-navy); }
.btn-outline-gold {
    color: var(--sal-gold-strong);
    border: 2px solid var(--sal-gold);
    border-radius: 14px;
    font-weight: 600;
    background: transparent;
}
.btn-outline-gold:hover, .btn-outline-gold:focus {
    background: rgba(201, 150, 46, .12);
    color: var(--sal-gold-light);
    border-color: var(--sal-gold-strong);
}

/* ---------- Seções ---------- */
.section-navy { background: radial-gradient(1100px 540px at 80% -10%, #15214a 0%, var(--sal-navy) 55%); color: #E7EBF5; }
.section-light { background: var(--sal-gray); }
.section-cta { background: linear-gradient(160deg, var(--sal-navy) 0%, var(--sal-navy-2) 70%, #1a1430 100%); }

.text-gold { color: var(--sal-gold-strong) !important; }
.text-gold-dark { color: var(--sal-gold-deep) !important; }
.text-soft { color: var(--sal-soft) !important; }

.eyebrow {
    display: inline-block;
    color: var(--sal-gold-light);
    background: rgba(201, 150, 46, .14);
    border: 1px solid rgba(201, 150, 46, .35);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    border-radius: 999px;
    padding: .35rem .9rem;
    margin-bottom: 1rem;
}
.eyebrow-dark { color: var(--sal-gold-deep); background: rgba(201, 150, 46, .12); border-color: rgba(201, 150, 46, .3); }

.section-title { font-weight: 700; letter-spacing: -.01em; }

/* ---------- Hero ---------- */
.hero { padding: 8.5rem 0 4.5rem; }
.hero-title { font-size: clamp(1.9rem, 4.2vw, 3.1rem); font-weight: 800; line-height: 1.18; color: #fff; margin-bottom: 1rem; }
.hero-subtitle { font-size: clamp(1rem, 2vw, 1.2rem); color: var(--sal-soft); margin-bottom: 1.75rem; }
.hero-visual { max-width: 460px; filter: drop-shadow(0 30px 60px rgba(0, 0, 0, .45)); }
.hero-trust { display: flex; flex-wrap: wrap; gap: .5rem 1.25rem; justify-content: inherit; }
.hero-trust .trust-item { font-size: .85rem; color: var(--sal-gold-light); font-weight: 500; }

/* ---------- Cards: dores / benefícios ---------- */
.pain-card, .benefit-card {
    background: #fff;
    border: 1px solid #E5E9F2;
    border-radius: var(--sal-radius);
    padding: 1.5rem 1.35rem;
    box-shadow: 0 8px 24px rgba(10, 16, 36, .05);
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.pain-card:hover, .benefit-card:hover {
    transform: translateY(-3px);
    border-color: rgba(201, 150, 46, .45);
    box-shadow: var(--sal-shadow);
}
.pain-icon, .benefit-icon { font-size: 1.8rem; margin-bottom: .6rem; }
.pain-card h3, .benefit-card h3 { color: var(--sal-navy); }
.pain-card p, .benefit-card p { color: #5A6478; }

/* ---------- Solução ---------- */
.solution-panel {
    background: var(--sal-navy-2);
    border: 1px solid rgba(201, 150, 46, .3);
    border-radius: var(--sal-radius);
    padding: 1.75rem;
    box-shadow: var(--sal-shadow);
}
.solution-row {
    display: flex; align-items: center; gap: .85rem;
    background: rgba(255, 255, 255, .04);
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 12px;
    padding: .9rem 1rem;
    font-weight: 500; font-size: .95rem;
}
.solution-row-gold { background: rgba(201, 150, 46, .15); border-color: rgba(230, 184, 76, .5); color: var(--sal-gold-light); }
.solution-num {
    flex: 0 0 30px; height: 30px; width: 30px;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--sal-gold-grad); color: var(--sal-navy);
    border-radius: 50%; font-weight: 700; font-size: .85rem;
}
.solution-arrow { text-align: center; color: var(--sal-gold); padding: .3rem 0; font-size: 1.05rem; }

/* ---------- Como funciona ---------- */
.step-card {
    background: rgba(255, 255, 255, .04);
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: var(--sal-radius);
    padding: 1.6rem 1.35rem;
    transition: border-color .15s ease, transform .15s ease;
}
.step-card:hover { border-color: rgba(230, 184, 76, .55); transform: translateY(-3px); }
.step-num {
    display: inline-block; color: var(--sal-gold-light);
    font-size: .75rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
    margin-bottom: .6rem;
}
.step-card-gold { background: var(--sal-gold-grad); border: 0; color: var(--sal-navy); }
.step-card-gold .step-num, .step-card-gold p { color: rgba(10, 16, 36, .8); }
.step-card-gold h3 { color: var(--sal-navy); }

/* ---------- Depoimentos ---------- */
.testimonial-card {
    background: #fff;
    border: 1px solid #E5E9F2;
    border-radius: var(--sal-radius);
    padding: 1.5rem 1.35rem;
    margin: 0;
    box-shadow: 0 8px 24px rgba(10, 16, 36, .05);
}
.testimonial-stars { color: var(--sal-gold); letter-spacing: 2px; margin-bottom: .6rem; }
.testimonial-card blockquote { color: #424D63; }
.testimonial-avatar {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--sal-navy); color: var(--sal-gold-strong);
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 700;
}

/* ---------- FAQ ---------- */
.saluma-accordion .accordion-item {
    border: 1px solid #E5E9F2;
    border-radius: 14px !important;
    margin-bottom: .75rem;
    overflow: hidden;
    box-shadow: 0 4px 14px rgba(10, 16, 36, .04);
}
.saluma-accordion .accordion-button {
    font-weight: 600; color: var(--sal-navy); background: #fff;
    padding: 1.05rem 1.25rem;
}
.saluma-accordion .accordion-button:not(.collapsed) {
    background: var(--sal-navy); color: var(--sal-gold-light); box-shadow: none;
}
.saluma-accordion .accordion-button:not(.collapsed)::after { filter: invert(80%) sepia(60%) saturate(500%) hue-rotate(360deg); }
.saluma-accordion .accordion-button:focus { box-shadow: 0 0 0 3px rgba(201, 150, 46, .35); }
.saluma-accordion .accordion-body { color: #5A6478; font-size: .95rem; }

/* ---------- Footer ---------- */
.saluma-footer { background: var(--sal-navy); color: #E7EBF5; }
.footer-divider { border-color: rgba(201, 150, 46, .25); opacity: 1; }

/* ---------- Flash ---------- */
.flash-wrapper { position: relative; z-index: 1050; padding-top: 84px; margin-bottom: -64px; }

/* ---------- Questionário ---------- */
.quiz-section { padding: 7.5rem 0 4rem; min-height: 100vh; }
.quiz-progress .progress { height: 10px; border-radius: 999px; background: #E3E8F2; }
.quiz-progress-bar { background: var(--sal-gold-grad); border-radius: 999px; transition: width .3s ease; }

.card-step {
    background: #fff;
    border: 1px solid #E5E9F2;
    border-radius: var(--sal-radius);
    padding: 1.75rem 1.5rem;
    box-shadow: var(--sal-shadow);
}
.step-title { font-size: 1.2rem; font-weight: 700; color: var(--sal-navy); margin-bottom: 1.25rem; float: none; width: 100%; }

.form-control, .form-select { border-radius: 12px; border-color: #D7DEEB; }
.form-control:focus, .form-select:focus {
    border-color: var(--sal-gold);
    box-shadow: 0 0 0 .25rem rgba(201, 150, 46, .2);
}

.option-card {
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .4rem;
    width: 100%; min-height: 86px;
    background: #fff;
    border: 2px solid #D7DEEB;
    border-radius: 14px;
    padding: .9rem .6rem;
    font-weight: 600; font-size: .9rem; color: var(--sal-ink);
    text-align: center; cursor: pointer; user-select: none;
    transition: border-color .12s ease, background .12s ease, transform .12s ease;
}
.option-card:hover { border-color: var(--sal-gold); transform: translateY(-2px); }
.btn-check:focus-visible + .option-card { outline: 3px solid rgba(201, 150, 46, .45); outline-offset: 2px; }
.btn-check:checked + .option-card {
    border-color: var(--sal-gold);
    background: linear-gradient(180deg, rgba(230, 184, 76, .16), rgba(201, 150, 46, .1));
    color: var(--sal-navy);
    box-shadow: 0 8px 20px rgba(201, 150, 46, .25);
}
.option-emoji { font-size: 1.5rem; line-height: 1; }
.option-card-lg { min-height: 110px; font-size: 1rem; }
.option-card-row { flex-direction: row; min-height: 64px; justify-content: flex-start; padding-left: 1.1rem; text-align: left; }
.option-card-num { min-height: 72px; font-size: 1.25rem; }

/* ---------- Resultado ---------- */
.result-card {
    background: #fff;
    border-radius: 22px;
    padding: 2.25rem 1.75rem;
    box-shadow: 0 30px 80px rgba(0, 0, 0, .35);
}
.result-badge {
    width: 72px; height: 72px; margin: -4.25rem auto 1rem;
    background: var(--sal-gold-grad);
    border: 5px solid #fff;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem;
    box-shadow: 0 14px 30px rgba(201, 150, 46, .45);
}
.result-panel {
    background: var(--sal-gray);
    border: 1px solid #E5E9F2;
    border-radius: 14px;
    padding: 1.15rem 1.25rem;
}
.result-item { padding: .35rem 0; font-weight: 500; color: var(--sal-ink); }
.result-price-box {
    border: 2px dashed rgba(201, 150, 46, .55);
    border-radius: 14px;
    padding: 1.15rem;
    background: rgba(230, 184, 76, .07);
}
.result-price { font-size: 2.4rem; font-weight: 800; color: var(--sal-gold-deep); line-height: 1.1; }

/* ---------- Mobile ---------- */
@media (max-width: 575.98px) {
    .hero { padding-top: 7rem; }
    .card-step { padding: 1.35rem 1.1rem; }
    .option-card { min-height: 78px; font-size: .82rem; }
    .option-card-num { min-height: 64px; }
    .quiz-section { padding-top: 6.5rem; }
    .result-card { padding: 2rem 1.25rem; }
}

/* ---------- Pagamento / PIX (Fase 2) ---------- */
.pix-box {
    background: var(--sal-gray);
    border: 1px solid #E5E9F2;
    border-radius: 14px;
    padding: 1.15rem;
}
.pix-qr {
    border: 4px solid #fff;
    border-radius: 12px;
    box-shadow: 0 10px 26px rgba(10, 16, 36, .14);
    background: #fff;
}

/* ---------- Análise ativa (Fase 2.1) ---------- */
.result-active-box {
    border-color: rgba(6, 118, 71, .45);
    background: rgba(6, 118, 71, .07);
}
.result-active-box .fw-semibold { color: #067647; }
