/* ═══════════════════════════════════════════════
   VALORANL THEME — Consumes tokens from valoranl-tokens.css
   ═══════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════
   GLOBAL OVERRIDES (dark teal theme)
   ═══════════════════════════════════════════════ */
body {
    font-family: var(--vn-font-body);
    color: var(--vn-text-primary);
    background:
        radial-gradient(circle at 15% 10%, rgba(44, 122, 139, 0.28), transparent 45%),
        radial-gradient(circle at 85% 15%, rgba(74, 85, 104, 0.35), transparent 40%),
        linear-gradient(135deg, var(--vn-deep-teal) 0%, #012e3a 48%, var(--vn-dark) 100%);
    background-attachment: fixed;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--vn-gold);
    font-family: var(--vn-font-heading);
    font-weight: 700;
    letter-spacing: -0.02em;
}

/* Missing font-size classes used in home.php */
.cs_fs_42 {
    font-size: 42px;
    line-height: 1.1em;
}
.cs_fs_29 {
    font-size: 29px;
    line-height: 1.3em;
}

/* Missing section padding class used in home.php */
.cs_p96_66 {
    padding: 96px 0 66px;
}

/* ═══════════════════════════════════════════════
   HEADER / NAVBAR
   ═══════════════════════════════════════════════ */

/* Base header: glass, transparent start */
.cs_site_header.cs_style_1 {
    background: rgba(0, 43, 54, 0.45);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid transparent;
    transition: background 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

/* Sticky active: denser glass */
.cs_site_header.cs_style_1.cs_sticky_active {
    background: rgba(0, 43, 54, 0.92);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.25);
    border-bottom-color: var(--vn-glass-border);
}

/* Inner layout */
.vn-header {
    padding: 0;
}

.vn-header__inner {
    display: flex;
    align-items: center;
    gap: 2rem;
    min-height: 68px;
}

/* Logo */
.vn-header__logo {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
}

.vn-header__logo img {
    height: 34px;
    width: auto;
    filter: drop-shadow(0 1px 3px rgba(0, 0, 0, 0.2));
    transition: filter var(--vn-ease-fast);
}

.vn-header__logo:hover img {
    filter: drop-shadow(0 2px 6px rgba(230, 215, 184, 0.25));
}

/* Nav links — uppercase micro */
.cs_nav .cs_nav_list > li > a {
    font-size: 0.72rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--vn-gold);
    position: relative;
    padding-bottom: 2px;
    transition: color var(--vn-ease-fast);
}

/* Underline animation from center */
.cs_nav .cs_nav_list > li > a::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 50%;
    width: 0;
    height: 1.5px;
    background: var(--vn-gold-bright);
    transition: width 0.25s ease, left 0.25s ease;
}

.cs_nav .cs_nav_list > li > a:hover::after,
.cs_nav .cs_nav_list > li > a:focus::after {
    width: 100%;
    left: 0;
}

.cs_nav .cs_nav_list > li > a:hover {
    color: var(--vn-gold-bright);
}

/* Actions area */
.vn-header__actions {
    margin-left: auto;
    flex-shrink: 0;
    display: flex;
    align-items: center;
}

/* CTA pill */
.vn-header__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.42rem 1.1rem;
    border: 1px solid rgba(230, 215, 184, 0.3);
    border-radius: var(--vn-radius-pill);
    background: transparent;
    color: var(--vn-gold);
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
    transition: background var(--vn-ease-fast), color var(--vn-ease-fast), border-color var(--vn-ease-fast);
}

.vn-header__cta:hover {
    background: var(--vn-gold);
    color: var(--vn-deep-teal);
    border-color: var(--vn-gold);
}

.vn-header__cta:focus-visible {
    outline: 2px solid var(--vn-gold);
    outline-offset: 2px;
}

.vn-header__cta i {
    font-size: 0.78rem;
}

/* Hamburger icon color on dark header */
.cs_menu_toggle {
    color: var(--vn-gold) !important;
}

/* Hamburger: custom 2-line style */
.cs_menu_toggle span {
    background-color: var(--vn-gold);
}

/* Focus-visible on nav links */
.cs_nav .cs_nav_list > li > a:focus-visible {
    outline: 2px solid var(--vn-gold);
    outline-offset: 3px;
    border-radius: 2px;
}

/* ─── Header mobile ─── */
@media screen and (max-width: 1199px) {
    .vn-header__inner {
        min-height: 60px;
    }

    .vn-header .container {
        background-color: transparent;
    }

    .cs_nav .cs_nav_list {
        background: linear-gradient(180deg, var(--vn-deep-teal) 0%, #011e26 100%);
        color: var(--vn-gold);
    }

    .cs_nav .cs_nav_list > li > a {
        color: var(--vn-gold);
        font-size: 0.82rem;
        letter-spacing: 0.04em;
    }

    .cs_nav .cs_nav_list > li > a:hover {
        color: var(--vn-gold-bright);
    }

    .cs_nav .cs_nav_list > li > a::after {
        display: none;
    }

    .cs_menu_dropdown_toggle {
        color: var(--vn-gold);
    }

    /* Hide CTA on mobile to save space */
    .vn-header__actions {
        display: none;
    }

    /* Header spacer */
    .cs_height_116 {
        height: 80px !important;
    }
    .cs_height_lg_110 {
        height: 80px !important;
    }
}

/* ═══════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════ */
.vn-footer {
    background: linear-gradient(180deg, rgba(0, 43, 54, 0.92) 0%, rgba(31, 55, 63, 0.97) 100%);
    border-top: 1px solid var(--vn-glass-border);
}

/* Main area */
.vn-footer__main {
    padding: 56px 0 40px;
}

/* Grid: 3 columns */
.vn-footer__grid {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr 1fr;
    gap: 48px;
}

/* Brand column */
.vn-footer__brand img {
    height: 30px;
    width: auto;
    margin-bottom: 0.85rem;
    filter: drop-shadow(0 1px 3px rgba(0, 0, 0, 0.2));
}

.vn-footer__brand p {
    color: var(--vn-text-muted);
    font-size: 0.9rem;
    line-height: 1.55;
    max-width: 280px;
    margin: 0;
}

/* Section headings */
.vn-footer__nav h3,
.vn-footer__contact h3 {
    color: var(--vn-sage-light);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 1.1rem;
}

/* Nav list */
.vn-footer__nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.vn-footer__nav ul li {
    margin-bottom: 0.6rem;
}

.vn-footer__nav ul li a {
    color: var(--vn-text-secondary);
    text-decoration: none;
    font-size: 0.88rem;
    transition: color var(--vn-ease-fast);
}

.vn-footer__nav ul li a:hover {
    color: var(--vn-gold);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.vn-footer__nav ul li a:focus-visible {
    outline: 2px solid var(--vn-gold);
    outline-offset: 2px;
    border-radius: 2px;
}

/* Contact list */
.vn-footer__contact ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.vn-footer__contact ul li {
    margin-bottom: 0.6rem;
    color: var(--vn-text-secondary);
    font-size: 0.88rem;
}

.vn-footer__contact ul li i {
    color: var(--vn-cyan);
    width: 1.2em;
    text-align: center;
    margin-right: 0.3rem;
}

.vn-footer__contact ul li a {
    color: var(--vn-text-secondary);
    text-decoration: none;
    transition: color var(--vn-ease-fast);
}

.vn-footer__contact ul li a:hover {
    color: var(--vn-gold);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.vn-footer__contact ul li a:focus-visible {
    outline: 2px solid var(--vn-gold);
    outline-offset: 2px;
    border-radius: 2px;
}

/* Bottom bar */
.vn-footer__bottom {
    border-top: 1px solid rgba(230, 215, 184, 0.12);
    padding: 16px 0;
}

.vn-footer__bottom-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.vn-footer__bottom-inner p {
    margin: 0;
    color: var(--vn-text-muted);
    font-size: 0.82rem;
}

.vn-footer__disclaimer {
    font-style: italic;
    opacity: 0.8;
}

/* ─── Footer responsive ─── */
@media (max-width: 767.98px) {
    .vn-footer__main {
        padding: 40px 0 28px;
    }

    .vn-footer__grid {
        grid-template-columns: 1fr;
        gap: 32px;
        text-align: center;
    }

    .vn-footer__brand p {
        max-width: none;
        margin: 0 auto;
    }

    .vn-footer__bottom-inner {
        flex-direction: column;
        gap: 0.4rem;
        text-align: center;
    }
}

/* ═══════════════════════════════════════════════
   PRELOADER & SCROLL-TOP (theme match)
   ═══════════════════════════════════════════════ */
.cs_preloader {
    background: var(--vn-deep-teal);
}
.cs_preloader .cs_preloader_in span {
    background: var(--vn-deep-teal);
    color: var(--vn-gold);
}
.cs_scrolltop_btn {
    background: var(--vn-gold) !important;
    color: var(--vn-deep-teal) !important;
    border: none;
}
.cs_scrolltop_btn:hover {
    background: var(--vn-gold-bright) !important;
    box-shadow: var(--vn-shadow-glow);
}
.cs_scrolltop_btn:focus-visible {
    outline: 2px solid var(--vn-gold);
    outline-offset: 2px;
}

/* ═══════════════════════════════════════════════
   VALUATION PAGE
   ═══════════════════════════════════════════════ */
.valuation-page {
    background: rgba(1, 31, 39, 0.76) url(../img/valoranl/pattern.png) repeat;
    background-size: 25%;
}

.valuation-card {
    background: rgba(6, 43, 54, 0.84);
    border: 1px solid rgba(230, 215, 184, 0.28);
    box-shadow: var(--vn-shadow-md);
    border-radius: var(--vn-radius-lg);
}

.valuation-card,
.valuation-card p,
.valuation-card li,
.valuation-card strong,
.valuation-card .form-label,
.valuation-card .text-muted {
    color: var(--vn-text-primary) !important;
}

.valuation-card .form-control,
.valuation-card .form-select {
    background-color: rgba(255, 255, 255, 0.98);
    color: #12303a;
    border: 1px solid rgba(18, 48, 58, 0.26);
    border-radius: 10px;
    padding: 0.6rem 0.85rem;
    transition: border-color var(--vn-ease-default), box-shadow var(--vn-ease-default);
}

.valuation-card .form-control::placeholder {
    color: #5f6f76;
}

.valuation-card .form-control:focus,
.valuation-card .form-select:focus {
    border-color: var(--vn-cyan);
    box-shadow: 0 0 0 0.2rem rgba(44, 122, 139, 0.25);
}

.valuation-help-card ul {
    padding-left: 1.1rem;
}

/* ─── Stepper ─── */
.vn-stepper {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 2rem;
    position: relative;
}

.vn-stepper__step {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    z-index: 1;
    cursor: pointer;
    flex: 0 0 auto;
}

.vn-stepper__circle {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    border: 2px solid rgba(230, 215, 184, 0.3);
    background: rgba(6, 43, 54, 0.7);
    color: rgba(230, 215, 184, 0.5);
    transition: all var(--vn-ease-default);
}

.vn-stepper__step.active .vn-stepper__circle {
    background: var(--vn-gold);
    color: var(--vn-deep-teal);
    border-color: var(--vn-gold);
    box-shadow: var(--vn-shadow-glow);
}

.vn-stepper__step.completed .vn-stepper__circle {
    background: var(--vn-gold);
    color: var(--vn-deep-teal);
    border-color: var(--vn-gold);
}

.vn-stepper__label {
    margin-top: 0.5rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: rgba(230, 215, 184, 0.5);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    transition: color var(--vn-ease-default);
    white-space: nowrap;
}

.vn-stepper__step.active .vn-stepper__label,
.vn-stepper__step.completed .vn-stepper__label {
    color: var(--vn-gold);
}

.vn-stepper__line {
    flex: 1;
    height: 2px;
    background: rgba(230, 215, 184, 0.18);
    margin: 0 0.5rem;
    margin-bottom: 1.6rem;
    transition: background var(--vn-ease-default);
    min-width: 40px;
}

.vn-stepper__line.completed {
    background: var(--vn-gold);
}

/* ─── Step panels ─── */
.vn-step-panel {
    display: none;
    animation: vnFadeIn 0.4s ease;
}

.vn-step-panel.active {
    display: block;
}

@keyframes vnFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ─── Step navigation buttons ─── */
.vn-step-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 1.5rem;
    gap: 1rem;
}

.vn-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 1.5rem;
    border-radius: 10px;
    font-weight: 600;
    font-size: 0.95rem;
    border: none;
    cursor: pointer;
    transition: all var(--vn-ease-default);
}

.vn-btn:focus-visible {
    outline: 2px solid var(--vn-gold);
    outline-offset: 2px;
}

.vn-btn--primary {
    background: var(--vn-gold);
    color: var(--vn-deep-teal);
}

.vn-btn--primary:hover {
    background: var(--vn-gold-bright);
    box-shadow: 0 4px 16px rgba(230, 215, 184, 0.3);
}

.vn-btn--secondary {
    background: rgba(230, 215, 184, 0.12);
    color: var(--vn-gold);
    border: 1px solid rgba(230, 215, 184, 0.25);
}

.vn-btn--secondary:hover {
    background: rgba(230, 215, 184, 0.2);
}

.vn-btn--lg {
    padding: 0.85rem 2.2rem;
    font-size: 1.05rem;
    border-radius: var(--vn-radius-md);
}

.vn-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* ─── Input with icon ─── */
.vn-input-icon {
    position: relative;
}

.vn-input-icon > .fa-solid,
.vn-input-icon > .fa-regular {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: #5f6f76;
    font-size: 0.9rem;
    pointer-events: none;
    z-index: 2;
}

.vn-input-icon > .form-control,
.vn-input-icon > .form-select {
    padding-left: 2.5rem;
}

/* ─── Summary mini card (step 3) ─── */
.vn-summary-mini {
    background: rgba(44, 122, 139, 0.12);
    border: 1px solid rgba(44, 122, 139, 0.25);
    border-radius: var(--vn-radius-md);
    padding: 1rem 1.25rem;
}

.vn-summary-mini__row {
    display: flex;
    justify-content: space-between;
    padding: 0.25rem 0;
    font-size: 0.88rem;
}

.vn-summary-mini__label {
    color: var(--vn-text-secondary);
}

.vn-summary-mini__value {
    color: var(--vn-gold);
    font-weight: 600;
}

/* ─── Help sidebar ─── */
.vn-help-card {
    border-radius: var(--vn-radius-lg);
    height: 100%;
}

.vn-help-card .vn-help-item {
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.vn-help-card .vn-help-item i {
    color: var(--vn-gold);
    font-size: 1.1rem;
    margin-top: 0.15rem;
    flex-shrink: 0;
}

.vn-help-card .vn-help-item span {
    font-size: 0.92rem;
    line-height: 1.45;
}

/* Mobile: help as collapsible banner */
@media (max-width: 1023.98px) {
    .vn-help-sidebar {
        order: -1;
    }
    .vn-help-card {
        height: auto;
    }
}

/* ─── Coordinates toggle ─── */
.vn-coords-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.88rem;
    color: var(--vn-cyan);
    cursor: pointer;
    text-decoration: none;
    transition: color var(--vn-ease-default);
}

.vn-coords-toggle:hover {
    color: var(--vn-gold);
}

/* ═══════════════════════════════════════════════
   RESULTS SECTION
   ═══════════════════════════════════════════════ */

/* ─── Result hero ─── */
.vn-result-hero {
    background:
        radial-gradient(ellipse at 30% 0%, rgba(44, 122, 139, 0.25), transparent 60%),
        var(--vn-surface-card);
    backdrop-filter: blur(16px);
    border: 1px solid var(--vn-glass-border);
    border-radius: var(--vn-radius-lg);
    padding: 2.5rem 2rem;
    text-align: center;
    margin-bottom: 1.5rem;
}

.vn-result-hero__label {
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: var(--vn-tracking-cap);
    color: var(--vn-text-muted);
    margin-bottom: 0.5rem;
}

.vn-result-hero__value {
    font-size: 3rem;
    font-weight: 800;
    color: var(--vn-gold);
    letter-spacing: -0.02em;
    line-height: 1.1;
    margin-bottom: 0.75rem;
}

.vn-result-hero__message {
    font-size: 0.95rem;
    color: var(--vn-text-secondary);
    margin-bottom: 1.5rem;
}

/* ─── Range bar ─── */
.vn-range-bar {
    position: relative;
    height: 10px;
    border-radius: 5px;
    background: rgba(255, 255, 255, 0.1);
    margin: 0 auto 0.75rem;
    max-width: 420px;
    overflow: visible;
}

.vn-range-bar__fill {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    border-radius: 5px;
    background: linear-gradient(90deg, var(--vn-cyan), var(--vn-gold));
    transition: width 1s ease;
}

.vn-range-bar__marker {
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--vn-gold);
    border: 3px solid var(--vn-deep-teal);
    box-shadow: 0 0 10px rgba(230, 215, 184, 0.4);
    transition: left 1s ease;
}

.vn-range-bar__labels {
    display: flex;
    justify-content: space-between;
    max-width: 420px;
    margin: 0.4rem auto 0;
    font-size: 0.8rem;
    color: var(--vn-text-muted);
}

/* ─── Confidence badge ─── */
.vn-confidence-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 1rem;
    border-radius: 20px;
    font-weight: 700;
    font-size: 0.95rem;
}

.vn-confidence-badge--high {
    background: rgba(34, 197, 94, 0.18);
    color: var(--vn-success);
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.vn-confidence-badge--medium {
    background: rgba(234, 179, 8, 0.18);
    color: var(--vn-warning);
    border: 1px solid rgba(234, 179, 8, 0.3);
}

.vn-confidence-badge--low {
    background: rgba(239, 68, 68, 0.18);
    color: var(--vn-danger);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

/* ─── Metric cards (glassmorphism) ─── */
.vn-metrics-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.vn-metric-card {
    background: var(--vn-glass-bg);
    backdrop-filter: blur(12px);
    border: 1px solid var(--vn-glass-border);
    border-radius: 14px;
    padding: 1.25rem;
    text-align: center;
    transition: transform var(--vn-ease-default), box-shadow var(--vn-ease-default);
}

.vn-metric-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--vn-shadow-md);
}

.vn-metric-card__icon {
    font-size: 1.6rem;
    color: var(--vn-cyan);
    margin-bottom: 0.5rem;
}

.vn-metric-card__label {
    font-size: 0.78rem;
    color: var(--vn-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 0.3rem;
}

.vn-metric-card__value {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--vn-gold);
    margin: 0;
}

/* ─── Residual breakdown cards ─── */
.vn-residual-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.vn-residual-card {
    background: rgba(44, 122, 139, 0.1);
    border: 1px solid rgba(44, 122, 139, 0.22);
    border-radius: var(--vn-radius-md);
    padding: 1rem;
    text-align: center;
}

.vn-residual-card__icon {
    font-size: 1.3rem;
    color: var(--vn-cyan);
    margin-bottom: 0.4rem;
}

.vn-residual-card__label {
    font-size: 0.75rem;
    color: var(--vn-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-bottom: 0.2rem;
}

.vn-residual-card__value {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--vn-text-primary);
    margin: 0;
}

/* ─── AI powered banner ─── */
#ai-powered-banner {
    border: 1px solid rgba(230, 215, 184, 0.45);
    background: linear-gradient(135deg, #f3e9ca 0%, #efe1bb 100%);
    color: #2f2a1d;
    border-radius: var(--vn-radius-md);
    box-shadow: var(--vn-shadow-md);
}

#ai-powered-banner strong,
#ai-powered-banner span,
#ai-powered-banner div {
    color: #2f2a1d !important;
}

#ai-powered-banner .badge {
    background: #132a34 !important;
    color: #f8e7b6 !important;
    border: 1px solid rgba(248, 231, 182, 0.35);
    font-weight: 600;
}

/* ─── Dual result comparison ─── */
.dual-result-card {
    background: rgba(2, 53, 67, 0.55);
    border: 1px solid rgba(230, 215, 184, 0.35);
    border-radius: var(--vn-radius-md);
    padding: 1rem;
}

.dual-result-original {
    border-left: 4px solid rgba(176, 190, 197, 0.85);
}

.dual-result-ai {
    border-left: 4px solid rgba(230, 215, 184, 0.95);
}

#dual-results-comparison small {
    color: #dbe7ec !important;
}

/* ─── Accordion breakdown ─── */
.vn-accordion .accordion-item {
    background: var(--vn-glass-bg);
    border: 1px solid var(--vn-glass-border);
    border-radius: var(--vn-radius-md) !important;
    margin-bottom: 0.75rem;
    overflow: hidden;
}

.vn-accordion .accordion-button {
    background: transparent;
    color: var(--vn-gold);
    font-weight: 600;
    font-size: 0.95rem;
    padding: 1rem 1.25rem;
    box-shadow: none;
}

.vn-accordion .accordion-button:focus-visible {
    outline: 2px solid var(--vn-gold);
    outline-offset: -2px;
}

.vn-accordion .accordion-button::after {
    filter: invert(0.85) sepia(0.2) hue-rotate(10deg);
}

.vn-accordion .accordion-button:not(.collapsed) {
    background: rgba(44, 122, 139, 0.1);
    color: var(--vn-gold);
}

.vn-accordion .accordion-body {
    color: #dbe7ec;
    font-size: 0.92rem;
    padding: 0.75rem 1.25rem 1.25rem;
}

.vn-accordion .accordion-body ul {
    padding-left: 1.2rem;
    margin-bottom: 0;
}

.vn-accordion .accordion-body li {
    margin-bottom: 0.35rem;
    color: #dbe7ec;
}

.vn-accordion .vn-breakdown-item {
    display: flex;
    justify-content: space-between;
    padding: 0.45rem 0;
    border-bottom: 1px solid rgba(230, 215, 184, 0.08);
}

.vn-accordion .vn-breakdown-item:last-child {
    border-bottom: none;
}

.vn-accordion .vn-breakdown-label {
    color: rgba(219, 231, 236, 0.7);
    font-size: 0.88rem;
}

.vn-accordion .vn-breakdown-value {
    color: var(--vn-text-primary);
    font-weight: 600;
    font-size: 0.88rem;
}

/* ─── Comparables table (desktop) ─── */
.vn-comparables-table {
    background: rgba(247, 250, 252, 0.97);
    border-radius: var(--vn-radius-md);
    overflow: hidden;
}

.vn-comparables-table thead th {
    background: #0f2b35;
    color: var(--vn-gold);
    font-weight: 600;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 0.85rem 0.75rem;
    border: none;
}

.vn-comparables-table tbody td {
    color: #1e293b;
    font-size: 0.9rem;
    padding: 0.75rem;
    vertical-align: middle;
    border-color: #e2e8f0;
}

.vn-comparables-table tbody tr:hover {
    background: rgba(44, 122, 139, 0.06);
}

/* ─── Comparable cards (mobile) ─── */
.vn-comparable-cards {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.vn-comparable-card {
    background: var(--vn-glass-bg);
    border: 1px solid var(--vn-glass-border);
    border-radius: var(--vn-radius-md);
    padding: 1rem;
}

.vn-comparable-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.75rem;
}

.vn-comparable-card__title {
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--vn-text-primary);
    flex: 1;
    margin-right: 0.5rem;
}

.vn-comparable-card__price {
    font-size: 1rem;
    font-weight: 700;
    color: var(--vn-gold);
    white-space: nowrap;
}

.vn-comparable-card__details {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
}

.vn-comparable-card__detail {
    font-size: 0.82rem;
}

.vn-comparable-card__detail-label {
    color: var(--vn-text-muted);
}

.vn-comparable-card__detail-value {
    color: var(--vn-text-primary);
    font-weight: 600;
}

.vn-comparable-card__footer {
    margin-top: 0.75rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--vn-glass-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.82rem;
}

.vn-comparable-card__location {
    color: var(--vn-text-secondary);
}

.vn-comparable-card__link a {
    color: var(--vn-cyan);
    text-decoration: none;
    font-weight: 600;
}

/* ─── Confidence progress bar ─── */
.vn-confidence-bar {
    height: 6px;
    border-radius: 3px;
    background: rgba(255, 255, 255, 0.1);
    overflow: hidden;
    margin-top: 0.5rem;
}

.vn-confidence-bar__fill {
    height: 100%;
    border-radius: 3px;
    transition: width 1.2s ease;
}

.vn-confidence-bar__fill--high {
    background: linear-gradient(90deg, var(--vn-success), #4ade80);
}

.vn-confidence-bar__fill--medium {
    background: linear-gradient(90deg, var(--vn-warning), #facc15);
}

.vn-confidence-bar__fill--low {
    background: linear-gradient(90deg, var(--vn-danger), #f87171);
}

/* ─── Confidence reasons ─── */
.vn-confidence-reasons {
    list-style: none;
    padding: 0;
    margin: 0;
}

.vn-confidence-reasons li {
    padding: 0.3rem 0;
    padding-left: 1.2rem;
    position: relative;
    font-size: 0.88rem;
    color: #dbe7ec;
}

.vn-confidence-reasons li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.7rem;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--vn-cyan);
}

/* ─── Form label enhancement ─── */
.valuation-card .form-label {
    font-size: 0.88rem;
    font-weight: 600;
    margin-bottom: 0.35rem;
}

/* ─── Section headings ─── */
.vn-section-heading {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--vn-gold);
    margin-bottom: 1rem;
}

/* ─── Scroll reveal helper ─── */
.vn-reveal {
    visibility: hidden;
}

/* ─── Form errors in step context ─── */
#valuation-form-errors {
    border-radius: 10px;
}

/* ─── Geocode status ─── */
#geocode-status {
    font-size: 0.85rem;
    padding: 0.3rem 0.6rem;
    border-radius: var(--vn-radius-sm);
}

#geocode-status.geocode-searching {
    color: var(--vn-cyan);
}

#geocode-status.geocode-success {
    color: var(--vn-success);
}

#geocode-status.geocode-error {
    color: var(--vn-warning);
}

/* ─── Address input group ─── */
.valuation-card .input-group .input-group-text {
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid rgba(18, 48, 58, 0.26);
    border-right: none;
    color: #5f6f76;
    border-radius: 10px 0 0 10px;
}

.valuation-card .input-group .form-control {
    border-radius: 0;
}

.valuation-card .input-group .btn {
    border-radius: 0 10px 10px 0;
    white-space: nowrap;
}

/* ─── Readonly coords styling ─── */
.valuation-card .form-control[readonly] {
    background-color: rgba(255, 255, 255, 0.85);
    color: var(--vn-cyan);
    font-weight: 600;
}

/* ─── Odometer in hero ─── */
.vn-result-hero__value .odometer {
    display: inline-block;
    vertical-align: baseline;
}

/* Currency prefix next to odometer */
.vn-result-hero__currency {
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
    vertical-align: baseline;
}

/* Fix odometer digits: inline → inline-block for proper absolute positioning */
.vn-result-hero__value .odometer.odometer-auto-theme,
.vn-result-hero__value .odometer.odometer-theme-default {
    display: inline-block;
    line-height: 1.1;
}

.vn-result-hero__value .odometer .odometer-digit {
    display: inline-block;
    vertical-align: baseline;
    position: relative;
}

.vn-result-hero__value .odometer .odometer-digit .odometer-digit-spacer {
    display: inline-block;
    visibility: hidden;
}

.vn-result-hero__value .odometer .odometer-formatting-mark {
    display: inline-block;
    vertical-align: baseline;
}

.vn-result-hero__value .odometer .odometer-digit .odometer-digit-inner {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow: hidden;
}

.vn-result-hero__value .odometer .odometer-value {
    color: var(--vn-gold);
}

/* ═══════════════════════════════════════════════
   RESPONSIVE — Tablet (≤1023px)
   ═══════════════════════════════════════════════ */
@media (max-width: 1023.98px) {
    .cs_p96_66 {
        padding: 60px 0 40px;
    }
    .cs_fs_42 {
        font-size: 32px;
    }
    .cs_fs_29 {
        font-size: 24px;
    }
    .vn-metrics-row {
        grid-template-columns: repeat(2, 1fr);
    }
    .vn-section-heading {
        font-size: 1.2rem;
    }
    /* Accordion buttons: smaller on tablet */
    .vn-accordion .accordion-button {
        font-size: 0.88rem;
        padding: 0.85rem 1rem;
    }
}

/* ═══════════════════════════════════════════════
   RESPONSIVE — Mobile (≤767px)
   ═══════════════════════════════════════════════ */
@media (max-width: 767.98px) {
    .cs_p96_66 {
        padding: 40px 0 30px;
    }
    .vn-result-hero__value {
        font-size: 2.5rem;
    }
    .vn-residual-row {
        grid-template-columns: repeat(2, 1fr);
    }
    /* Dual result cards stack */
    .dual-result-card {
        padding: 0.85rem;
    }
    /* Breakdown items: stack on narrow screens */
    .vn-accordion .vn-breakdown-item {
        flex-direction: column;
        gap: 0.15rem;
    }
    .vn-accordion .vn-breakdown-value {
        text-align: right;
    }
}

/* ═══════════════════════════════════════════════
   RESPONSIVE — Small mobile (≤479px)
   ═══════════════════════════════════════════════ */
@media (max-width: 479.98px) {
    .cs_fs_42 {
        font-size: 26px;
    }
    .cs_fs_29 {
        font-size: 20px;
    }
    /* Stepper compact */
    .vn-stepper {
        gap: 0;
    }
    .vn-stepper__circle {
        width: 36px;
        height: 36px;
        font-size: 0.88rem;
    }
    .vn-stepper__label {
        font-size: 0.68rem;
    }
    .vn-stepper__line {
        min-width: 24px;
    }
    /* Hero compact */
    .vn-result-hero {
        padding: 1.75rem 1.25rem;
    }
    .vn-result-hero__value {
        font-size: 2.2rem;
    }
    /* Metric cards compact */
    .vn-metrics-row {
        grid-template-columns: 1fr 1fr;
        gap: 0.75rem;
    }
    .vn-metric-card {
        padding: 1rem 0.75rem;
    }
    .vn-metric-card__value {
        font-size: 1.1rem;
    }
    /* Buttons: full width on mobile */
    .vn-step-nav {
        flex-direction: column-reverse;
        gap: 0.75rem;
    }
    .vn-step-nav .vn-btn {
        width: 100%;
        justify-content: center;
    }
    .vn-btn--lg {
        padding: 0.75rem 1.5rem;
        font-size: 1rem;
    }
    /* Geocode button: icon only on very small screens */
    #geocode-btn .fa-solid {
        margin-right: 0;
    }
    /* Summary mini: smaller text */
    .vn-summary-mini__row {
        font-size: 0.82rem;
    }
    /* Residual cards compact */
    .vn-residual-card {
        padding: 0.75rem 0.5rem;
    }
    .vn-residual-card__value {
        font-size: 0.95rem;
    }
    .vn-residual-card__label {
        font-size: 0.7rem;
    }
    /* Section heading smaller */
    .vn-section-heading {
        font-size: 1.1rem;
    }
    /* Comparable card details: single column */
    .vn-comparable-card__details {
        grid-template-columns: 1fr;
    }
    /* Confidence badge smaller */
    .vn-confidence-badge {
        font-size: 0.85rem;
        padding: 0.3rem 0.75rem;
    }
    /* Touch target minimum */
    .vn-btn {
        min-height: 44px;
    }
}

/* ═══════════════════════════════════════════════
   RESPONSIVE — Extra small (≤400px → unified to 479px above)
   Keeping only unique rules not covered above
   ═══════════════════════════════════════════════ */
@media (max-width: 379.98px) {
    .cs_fs_42 {
        font-size: 22px;
    }
    .vn-result-hero__value {
        font-size: 1.8rem;
    }
    .vn-metric-card__value {
        font-size: 0.95rem;
    }
    /* Address input group: stack button below */
    .valuation-card .input-group {
        flex-wrap: wrap;
    }
    .valuation-card .input-group .input-group-text {
        border-radius: 10px 0 0 10px;
    }
    .valuation-card .input-group .form-control {
        border-radius: 0 10px 10px 0;
        flex: 1 1 auto;
    }
    .valuation-card .input-group .btn {
        border-radius: 10px;
        width: 100%;
        margin-top: 0.5rem;
    }
}

/* ═══════════════════════════════════════════════
   ACCESSIBILITY — Reduced motion
   ═══════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}
