/* ============================================================
   PRICING CALCULATOR — scoped styles
   Every selector is prefixed with `.build-2026` so these rules
   beat the theme's universal reset (`.build-2026 * { margin:0; padding:0 }`
   in 2026-build.css), matching the convention used elsewhere in the theme.
   `--section-alt` (undefined here) is mapped to `--off-white`.
   ============================================================ */

.build-2026 .pricing-calculator-block {
    max-width: 868px;
    margin: 0 auto;
    padding: 80px 24px;
    box-sizing: border-box;
}

/* ---- Phase 1: Questions ---- */
.build-2026 .calc-questions {
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 30px rgba(15, 31, 61, 0.08);
    overflow: hidden;
    border: 1.5px solid var(--border);
}
.build-2026 .calc-q {
    padding: 36px 40px;
    border-bottom: 1.5px solid var(--border);
}
.build-2026 .calc-q:last-child { border-bottom: none; }
.build-2026 .calc-q-num {
    font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.12em;
    font-weight: 800; color: var(--gold); margin-bottom: 6px;
}
.build-2026 .calc-q-label {
    font-size: 1.15rem; font-weight: 700; font-family: Georgia, serif;
    color: var(--navy); margin-bottom: 22px; line-height: 1.35;
}
.build-2026 .slider-value-display {
    font-size: 2.6rem; font-weight: 800; font-family: Georgia, serif;
    color: var(--navy); margin-bottom: 16px; line-height: 1;
}
.build-2026 .slider-value-display span { color: var(--gold); }
.build-2026 .calc-slider {
    -webkit-appearance: none; appearance: none;
    width: 100%; height: 6px; border-radius: 100px;
    background: var(--border); outline: none; cursor: pointer;
}
.build-2026 .calc-slider::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--navy); border: 4px solid white;
    box-shadow: 0 2px 10px rgba(15, 31, 61, 0.3); cursor: pointer;
    transition: transform 0.12s;
}
.build-2026 .calc-slider::-webkit-slider-thumb:hover { transform: scale(1.1); }
.build-2026 .calc-slider::-moz-range-thumb {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--navy); border: 4px solid white;
    box-shadow: 0 2px 10px rgba(15, 31, 61, 0.3); cursor: pointer;
}
.build-2026 .slider-range-labels {
    display: flex; justify-content: space-between;
    font-size: 0.75rem; color: var(--text-mid);
    margin-top: 8px; font-weight: 600;
}
.build-2026 .slider-hint {
    font-size: 0.82rem; color: var(--text-mid);
    margin-top: 14px; line-height: 1.5;
}

/* Calculate button */
.build-2026 .calc-submit-wrap {
    padding: 32px 40px;
    background: var(--off-white);
    border-top: 1.5px solid var(--border);
    display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
}
.build-2026 .calc-btn {
    display: inline-flex; align-items: center; gap: 10px;
    background: var(--gold); color: var(--navy);
    padding: 16px 32px; border-radius: var(--radius);
    font-weight: 800; font-size: 1rem; border: none; cursor: pointer;
    font-family: Georgia, serif; text-transform: none;
    box-shadow: 0 4px 16px rgba(201, 168, 76, 0.35);
    transition: background 0.18s, transform 0.12s;
}
.build-2026 .calc-btn:hover { background: #d4b05a; transform: translateY(-1px); }
.build-2026 .calc-btn-note { font-size: 0.8rem; color: var(--text-mid); }

/* ---- Phase 2: Results ---- */
.build-2026 .calc-results-section {
    display: none;
    margin-top: 32px;
}
.build-2026 .calc-results-section.visible { display: block; }

/* Package recommendation card */
.build-2026 .rec-card {
    background: var(--navy); border-radius: var(--radius-lg);
    padding: 36px 40px; color: white; margin-bottom: 24px;
    position: relative; overflow: hidden;
}
.build-2026 .rec-card::before {
    content: ''; position: absolute;
    top: 0; right: 0; width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(201, 168, 76, 0.15) 0%, transparent 70%);
}
.build-2026 .rec-label {
    font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.12em;
    font-weight: 800; color: var(--gold-light); margin-bottom: 6px;
}
.build-2026 .rec-name {
    font-size: 1.7rem; font-family: Georgia, serif; font-weight: 700;
    color: white; margin-bottom: 6px;
}
.build-2026 .rec-detail { font-size: 0.87rem; color: rgba(255, 255, 255, 0.6); margin-bottom: 24px; }
.build-2026 .rec-why {
    font-size: 0.9rem; color: rgba(255, 255, 255, 0.8); line-height: 1.65;
    margin-bottom: 24px; max-width: 640px;
}
.build-2026 .rec-pricing-row {
    display: flex; gap: 32px; flex-wrap: wrap; align-items: flex-end;
    padding-top: 20px; border-top: 1px solid rgba(255, 255, 255, 0.13);
}
.build-2026 .rec-price-label {
    font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.5); margin-bottom: 3px; font-weight: 700;
}
.build-2026 .rec-price-value {
    font-size: 2.2rem; font-weight: 800; font-family: Georgia, serif;
    color: var(--gold-light); line-height: 1;
}
.build-2026 .rec-price-sub { font-size: 0.78rem; color: rgba(255, 255, 255, 0.45); margin-top: 4px; }
.build-2026 .rec-roi {
    background: rgba(111, 207, 151, 0.12); border: 1px solid rgba(111, 207, 151, 0.3);
    border-radius: var(--radius); padding: 10px 16px; align-self: center;
}
.build-2026 .rec-roi-label { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.08em; color: #6fcf97; font-weight: 700; margin-bottom: 2px; }
.build-2026 .rec-roi-value { font-size: 0.92rem; font-weight: 700; color: #6fcf97; }

/* Impact numbers */
.build-2026 .impact-row {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
    margin-bottom: 24px;
}
.build-2026 .impact-card {
    background: white; border: 1.5px solid var(--border);
    border-radius: var(--radius); padding: 20px;
    box-shadow: 0 2px 8px rgba(15, 31, 61, 0.05);
}
.build-2026 .impact-value {
    font-size: 1.8rem; font-weight: 800; font-family: Georgia, serif;
    color: var(--navy); line-height: 1; margin-bottom: 4px;
}
.build-2026 .impact-label { font-size: 0.78rem; color: var(--text-mid); line-height: 1.4; }
.build-2026 .impact-note {
    font-size: 0.72rem; color: var(--text-mid);
    margin-top: 8px; text-align: center; font-style: italic;
}

/* Lead capture form */
.build-2026 .lead-form-card {
    background: white; border: 1.5px solid var(--border);
    border-radius: var(--radius-lg); padding: 36px 40px;
    box-shadow: 0 2px 16px rgba(15, 31, 61, 0.06);
}
.build-2026 .lead-form-header { margin-bottom: 24px; }
.build-2026 .lead-form-title {
    font-size: 1.3rem; font-family: Georgia, serif; font-weight: 700;
    color: var(--navy); margin-bottom: 6px;
}
.build-2026 .lead-form-sub { font-size: 0.87rem; color: var(--text-mid); line-height: 1.6; }
.build-2026 .lead-form-card .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.build-2026 .lead-form-card .form-group { display: flex; flex-direction: column; gap: 5px; }
.build-2026 .lead-form-card .form-group label {
    font-size: 0.78rem; font-weight: 700; color: var(--navy);
    text-transform: uppercase; letter-spacing: 0.05em;
}
.build-2026 .lead-form-card .form-group input {
    padding: 12px 14px; border: 2px solid var(--border);
    border-radius: var(--radius); font-size: 0.93rem;
    font-family: Arial, sans-serif; color: var(--navy);
    transition: border-color 0.15s; background: white;
}
.build-2026 .lead-form-card .form-group input:focus { border-color: var(--navy); outline: none; }
.build-2026 .lead-form-card .form-group input.optional { background: #fafbfd; }
.build-2026 .lead-form-consent {
    font-size: 0.77rem; color: var(--text-mid); line-height: 1.6;
    margin-bottom: 18px; padding: 12px 14px;
    background: var(--off-white); border-radius: var(--radius);
}
.build-2026 .lead-form-submit-btn {
    width: 100%; padding: 17px 24px;
    background: var(--navy); color: white; border: none;
    border-radius: var(--radius); font-size: 1rem;
    font-weight: 800; font-family: Georgia, serif;
    cursor: pointer; transition: background 0.18s, transform 0.12s;
    display: flex; align-items: center; justify-content: center; gap: 10px;
}
.build-2026 .lead-form-submit-btn:hover { background: #1a3260; transform: translateY(-1px); }
.build-2026 .lead-form-submit-btn:disabled { background: #9ca3af; cursor: not-allowed; transform: none; }
.build-2026 .lead-form-error {
    display: none; background: #fef2f2; border: 1px solid #fca5a5;
    color: #b91c1c; border-radius: var(--radius); padding: 12px 14px;
    font-size: 0.85rem; margin-bottom: 14px;
}
.build-2026 .lead-form-error.visible { display: block; }

/* Deadline banner */
.build-2026 .deadline-banner {
    display: flex; align-items: center; gap: 14px;
    background: rgba(201, 168, 76, 0.13);
    border: 1.5px solid rgba(201, 168, 76, 0.4);
    border-radius: var(--radius); padding: 14px 18px;
    margin-bottom: 22px; flex-wrap: wrap;
}
.build-2026 .deadline-icon { font-size: 1.4rem; flex-shrink: 0; }
.build-2026 .deadline-body { flex: 1; }
.build-2026 .deadline-title {
    font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.1em;
    font-weight: 800; color: var(--gold-light); margin-bottom: 3px;
}
.build-2026 .deadline-date {
    font-size: 1rem; font-weight: 700; font-family: Georgia, serif;
    color: white; line-height: 1.3;
}
.build-2026 .deadline-sub { font-size: 0.8rem; color: rgba(255, 255, 255, 0.6); margin-top: 2px; }
.build-2026 .deadline-pill {
    background: var(--gold); color: var(--navy);
    border-radius: 100px; padding: 6px 14px;
    font-weight: 800; font-size: 0.82rem; white-space: nowrap;
    flex-shrink: 0;
}

/* Bonus strip */
.build-2026 .bonus-strip {
    background: rgba(201, 168, 76, 0.08); border: 1.5px solid rgba(201, 168, 76, 0.25);
    border-radius: var(--radius); padding: 16px 20px;
    display: flex; align-items: flex-start; gap: 12px; margin-bottom: 20px;
}
.build-2026 .bonus-strip-icon { font-size: 1.3rem; flex-shrink: 0; }
.build-2026 .bonus-strip-title { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 800; color: var(--gold); margin-bottom: 2px; }
.build-2026 .bonus-strip-desc { font-size: 0.82rem; color: var(--text-mid); line-height: 1.5; }

/* Responsive */
@media (max-width: 700px) {
    .build-2026 .pricing-calculator-block { padding: 60px 16px; }
    .build-2026 .calc-q { padding: 26px 20px; }
    .build-2026 .calc-submit-wrap { padding: 24px 20px; }
    .build-2026 .rec-card { padding: 28px 22px; }
    .build-2026 .lead-form-card { padding: 26px 20px; }
    .build-2026 .lead-form-card .form-row { grid-template-columns: 1fr; }
    .build-2026 .impact-row { grid-template-columns: 1fr; }
    .build-2026 .rec-pricing-row { gap: 20px; }
    .build-2026 .slider-value-display { font-size: 2rem; }
    .build-2026 .rec-name { font-size: 1.3rem; }
}
