/* ============================================================
   Scout UI — Unified Design System
   Modern, mobile-first CSS using custom properties, flexbox & grid.
   No external utility frameworks needed.
   ============================================================ */

/* Hide scrollbar */
html {
    scrollbar-width: none;
}
html::-webkit-scrollbar {
    display: none;
}

/* ---------- 1. Design Tokens ---------- */
:root {
    /* Brand Palette */
    --scout-navy: #0f1b2d;
    --scout-navy-light: #1a2d47;
    --scout-navy-mid: #162540;
    --scout-gold: #d4a843;
    --scout-gold-hover: #c49a35;

    /* Semantic */
    --scout-success: #22c55e;
    --scout-danger: #ef4444;
    --scout-danger-dark: #dc2626;
    --scout-warning: #f59e0b;
    --scout-info: #3b82f6;

    /* Neutrals */
    --scout-white: #ffffff;
    --scout-bg: #f0f2f5;
    --scout-gray-50: #f8fafc;
    --scout-gray-100: #f1f5f9;
    --scout-gray-200: #e2e8f0;
    --scout-gray-300: #cbd5e1;
    --scout-gray-400: #94a3b8;
    --scout-gray-500: #64748b;
    --scout-gray-600: #475569;
    --scout-gray-700: #334155;
    --scout-gray-800: #1e293b;
    --scout-gray-900: #0f172a;

    /* Typography */
    --font-display: 'Montserrat', 'Segoe UI', system-ui, sans-serif;
    --font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
    --font-xs: 0.7rem;
    --font-sm: 0.8rem;
    --font-base: 0.9rem;
    --font-md: 1rem;
    --font-lg: 1.15rem;
    --font-xl: 1.35rem;
    --font-2xl: 1.6rem;
    --font-3xl: 2rem;

    /* Spacing */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;

    /* Borders & Radius */
    --radius-sm: 0.375rem;
    --radius-md: 0.625rem;
    --radius-lg: 0.875rem;
    --radius-xl: 1.25rem;
    --radius-full: 9999px;

    /* Shadows */
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.12);
    --shadow-xl: 0 12px 36px rgba(0, 0, 0, 0.16);
    --shadow-card: 0 2px 8px rgba(0, 0, 0, 0.06), 0 8px 24px rgba(0, 0, 0, 0.08);

    /* Transitions */
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --transition: 0.2s var(--ease-out);
}


/* ---------- 2. Reset & Base ---------- */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

body {
    margin: 0;
    padding: 0;
    background-color: var(--scout-gray-800);
    color: var(--scout-gray-700);
    font-family: var(--font-family);
    font-size: var(--font-base);
    line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0;
    color: var(--scout-gray-800);
    font-weight: 700;
    line-height: 1.2;
}


/* ---------- 3. Scout Component Classes ---------- */

/* ---- Sticky Header ---- */
.scout-header-sticky {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(15, 23, 42, 0.92);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.3);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem 1rem;
    min-height: 60px;
    max-width: 480px;
    margin: 0 auto;
    gap: 0.75rem;
}

/* -- Logo group -- */
.header-logo-group {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    text-decoration: none;
    color: var(--scout-white);
    flex-shrink: 0;
}
.header-logo-group:hover { color: var(--scout-white); text-decoration: none; }

.header-logo-text {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: -0.5px;
    color: var(--scout-white);
}

.header-tagline {
    font-size: 0.7rem;
    color: rgba(255, 255, 255, 0.55);
    font-weight: 400;
    white-space: nowrap;
}

/* -- Desktop nav -- */
.header-desktop-nav {
    display: none;
    align-items: center;
    gap: 0.25rem;
}

.header-desktop-nav a {
    color: rgba(255, 255, 255, 0.75);
    font-size: 0.95rem;
    font-weight: 600;
    text-decoration: none;
    padding: 0.5rem 0.75rem;
    border-radius: var(--radius-sm);
    min-height: 48px;
    display: flex;
    align-items: center;
    transition: color var(--transition), background var(--transition);
    position: relative;
}

.header-desktop-nav a:hover {
    color: var(--scout-white);
    background: rgba(255, 255, 255, 0.08);
}

.header-desktop-nav a.nav-active {
    color: var(--scout-gold);
    border-bottom: 3px solid var(--scout-gold);
    border-radius: 0;
    padding-bottom: calc(0.5rem - 3px);
}

/* -- Status area (right side) -- */
.header-status-area {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}

/* -- Credit pill -- */
.header-credit-pill {
    font-size: 0.75rem;
    font-weight: 700;
    padding: 0.3rem 0.75rem;
    border-radius: 9999px;
    white-space: nowrap;
    letter-spacing: 0.02em;
}
.pill-ok {
    background: rgba(34, 197, 94, 0.2);
    color: #4ade80;
}
.pill-zero {
    background: rgba(220, 38, 38, 0.25);
    color: #fca5a5;
    border: 1px solid rgba(220, 38, 38, 0.4);
}
.pill-unlimited {
    background: rgba(59, 130, 246, 0.2);
    color: #93c5fd;
}

/* -- Auth buttons (desktop) -- */
.header-logout-btn,
.header-login-btn {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    padding: 0.4rem 0.75rem;
    border-radius: var(--radius-sm);
    min-height: 48px;
    display: flex;
    align-items: center;
    transition: color var(--transition), background var(--transition);
}
.header-logout-btn:hover,
.header-login-btn:hover {
    color: var(--scout-white);
    background: rgba(255, 255, 255, 0.08);
}

.header-desktop-only { display: none; }

/* -- Login button (always visible in header when not authenticated) -- */
.header-login-btn-mobile {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    padding: 0.35rem 0.75rem;
    border-radius: 0.4rem;
    display: flex;
    align-items: center;
    transition: color var(--transition), background var(--transition);
}
.header-login-btn-mobile:hover {
    color: var(--scout-white);
    background: rgba(255, 255, 255, 0.08);
}

/* -- Mobile menu button -- */
.header-menu-btn {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: var(--scout-white);
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0.625rem 0.875rem;
    border-radius: var(--radius-sm);
    cursor: pointer;
    height: 48px;
    min-width: 48px;
    justify-content: center;
    transition: background var(--transition);
}
.header-menu-btn:hover,
.header-menu-btn:active {
    background: rgba(255, 255, 255, 0.18);
}

/* -- Mobile menu overlay + panel (hidden by default, shown via .menu-open) -- */
.mobile-menu-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    z-index: 1001;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease-out;
}
.mobile-menu-backdrop.menu-open {
    opacity: 1;
    pointer-events: auto;
}

.mobile-menu-panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(320px, 85vw);
    background: linear-gradient(180deg, var(--scout-navy) 0%, #0c1524 100%);
    z-index: 1002;
    display: flex;
    flex-direction: column;
    box-shadow: -8px 0 32px rgba(0, 0, 0, 0.4);
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform 0.25s var(--ease-out);
}
.mobile-menu-panel.menu-open {
    transform: translateX(0);
}

@keyframes slideIn {
    from { transform: translateX(100%); }
    to { transform: translateX(0); }
}
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.mobile-menu-header {
    padding: 2rem 1.5rem 1.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.mobile-menu-title {
    display: block;
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--scout-white);
    letter-spacing: -0.5px;
}
.mobile-menu-subtitle {
    display: block;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.5);
    margin-top: 0.25rem;
}

.mobile-menu-links {
    flex: 1;
    padding: 1rem 0;
}

.mobile-menu-link {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 1rem 1.5rem;
    color: rgba(255, 255, 255, 0.8);
    font-size: 1.125rem;
    font-weight: 600;
    text-decoration: none;
    min-height: 56px;
    transition: background var(--transition), color var(--transition);
}
.mobile-menu-link:hover,
.mobile-menu-link:active {
    background: rgba(255, 255, 255, 0.06);
    color: var(--scout-white);
}
.mobile-menu-link.nav-active {
    color: var(--scout-gold);
    background: rgba(212, 168, 67, 0.08);
    border-left: 3px solid var(--scout-gold);
}

.mobile-menu-footer {
    padding: 1rem 0;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    margin-top: auto;
}

.mobile-menu-logout {
    color: rgba(239, 68, 68, 0.85) !important;
}
.mobile-menu-logout:hover {
    color: #ef4444 !important;
    background: rgba(239, 68, 68, 0.08) !important;
}

.mobile-menu-login {
    color: var(--scout-gold) !important;
}

.mobile-menu-powered {
    display: block;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.3);
    padding: 1rem 1.5rem 0.5rem;
}

/* -- Desktop nav is hidden — app is 480px max-width, always use mobile layout -- */

/* Hide tagline on very small screens to prevent wrapping */
@media (max-width: 350px) {
    .header-tagline { display: none; }
    .header-credit-pill { font-size: 0.65rem; padding: 0.25rem 0.5rem; }
}

/* ---- Search Section (extends header gradient on Home page) ---- */
.scout-search-section {
    background: linear-gradient(160deg, var(--scout-navy-light) 0%, var(--scout-navy) 100%);
    padding: var(--space-2) var(--space-4) var(--space-8);
    text-align: center;
    position: relative;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
}

.scout-search-section .scout-search-wrap {
    margin-top: 0;
}

/* ---- Search Bar ---- */
.scout-search-wrap {
    margin-top: var(--space-6);
    padding: 0 var(--space-2);
}

.scout-search-bar {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    background: var(--scout-white);
    border-radius: var(--radius-full);
    padding: var(--space-1);
    box-shadow: var(--shadow-lg);
    border: 2px solid transparent;
    transition: border-color var(--transition);
}

.scout-search-bar.has-error {
    border-color: var(--scout-danger);
}

.scout-search-bar .e-input-group {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    flex: 1;
}

.scout-search-bar .e-input-group input.e-input {
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.5px !important;
    padding: var(--space-2) var(--space-3) !important;
    height: 40px;
}

.scout-search-bar .e-input-group::before,
.scout-search-bar .e-input-group::after {
    display: none !important;
}

.scout-search-bar .e-btn.scout-search-btn,
.scout-search-bar .e-css.e-btn.scout-search-btn,
.scout-search-btn {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
    padding: 0 !important;
    border-radius: var(--radius-full) !important;
    background-color: var(--scout-gold) !important;
    border: none !important;
    border-color: var(--scout-gold) !important;
    color: var(--scout-white) !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color var(--transition), transform var(--transition);
    box-shadow: 0 2px 8px rgba(212, 168, 67, 0.3);
    flex-shrink: 0;
    pointer-events: auto !important;
    position: relative;
    z-index: 50;
    outline: none;
    border: none;
}

.scout-search-btn .e-icons {
    color: var(--scout-white);
    font-size: 1rem;
}

.scout-search-bar .e-btn.scout-search-btn:hover,
.scout-search-btn:hover {
    background-color: var(--scout-gold-hover) !important;
    border-color: var(--scout-gold-hover) !important;
    transform: scale(1.05);
}

.scout-search-bar .e-btn.scout-search-btn:active,
.scout-search-btn:active {
    transform: scale(0.97);
}

/* ---- Ask AI Button ---- */
.scout-search-bar .e-btn.scout-ask-btn,
.scout-search-bar .e-css.e-btn.scout-ask-btn,
.scout-ask-btn {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
    padding: 0 !important;
    border-radius: var(--radius-full) !important;
    background-color: var(--scout-info) !important;
    border: none !important;
    border-color: var(--scout-info) !important;
    color: var(--scout-white) !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color var(--transition), transform var(--transition), box-shadow var(--transition);
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.3);
    flex-shrink: 0;
    pointer-events: auto !important;
    position: relative;
    z-index: 50;
    outline: none;
    border: none;
}

.scout-ask-btn .e-icons {
    color: var(--scout-white);
    font-size: 1rem;
}

.scout-search-bar .e-btn.scout-ask-btn:hover,
.scout-ask-btn:hover {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
    transform: scale(1.05);
}

.scout-search-bar .e-btn.scout-ask-btn:active,
.scout-ask-btn:active {
    transform: scale(0.97);
}

.scout-search-bar .e-btn.scout-ask-btn.active,
.scout-ask-btn.active {
    background-color: #1d4ed8 !important;
    border-color: #1d4ed8 !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.3), 0 2px 8px rgba(59, 130, 246, 0.3);
}

/* ---- Camera/Scan Button ---- */
.scout-scan-btn {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
    padding: 0 !important;
    border-radius: var(--radius-full) !important;
    background-color: var(--scout-success) !important;
    border: none !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: var(--transition);
    flex-shrink: 0;
}

.scout-scan-btn .e-icons {
    color: var(--scout-white);
    font-size: 1rem;
}

.scout-scan-btn:hover {
    background-color: #16a34a !important;
    transform: scale(1.05);
}

.scout-scan-btn:active {
    transform: scale(0.97);
}

/* ---- AI Answer Card ---- */
.ai-answer-card {
    background: var(--scout-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
    border: 1px solid rgba(59, 130, 246, 0.2);
    overflow: hidden;
    animation: ai-slide-in 0.35s var(--ease-out) both;
}

@keyframes ai-slide-in {
    from {
        opacity: 0;
        transform: translateY(-12px) scale(0.97);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.ai-answer-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
    border-bottom: 1px solid rgba(59, 130, 246, 0.1);
}

.ai-answer-icon {
    color: var(--scout-info);
    font-size: 1.1rem;
}

.ai-answer-label {
    font-weight: 700;
    font-size: var(--font-sm);
    color: var(--scout-info);
    flex: 1;
    letter-spacing: 0.3px;
}

.ai-answer-close {
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--space-1);
    border-radius: var(--radius-sm);
    color: var(--scout-gray-400);
    transition: color var(--transition), background var(--transition);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
}

.ai-answer-close:hover {
    color: var(--scout-gray-700);
    background: rgba(0, 0, 0, 0.05);
}

.ai-answer-close .e-icons {
    font-size: 0.75rem;
}

.ai-answer-body {
    padding: var(--space-4);
}

.ai-question {
    font-size: var(--font-sm);
    font-style: italic;
    color: var(--scout-gray-400);
    margin: 0 0 var(--space-3);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--scout-gray-100);
}

.ai-response {
    font-size: var(--font-sm);
    color: var(--scout-gray-700);
    margin: 0;
    line-height: 1.65;
}

/* Typing indicator dots */
.ai-typing-indicator {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: var(--space-2) 0;
}

.ai-typing-indicator span {
    width: 8px;
    height: 8px;
    border-radius: var(--radius-full);
    background: var(--scout-info);
    opacity: 0.4;
    animation: ai-typing-bounce 1.2s infinite ease-in-out;
}

.ai-typing-indicator span:nth-child(1) {
    animation-delay: 0s;
}

.ai-typing-indicator span:nth-child(2) {
    animation-delay: 0.15s;
}

.ai-typing-indicator span:nth-child(3) {
    animation-delay: 0.3s;
}

@keyframes ai-typing-bounce {

    0%,
    60%,
    100% {
        opacity: 0.3;
        transform: translateY(0);
    }

    30% {
        opacity: 1;
        transform: translateY(-4px);
    }
}

.validation-msg {
    color: var(--scout-danger);
    font-size: var(--font-xs);
    margin-top: var(--space-1);
    padding-left: var(--space-4);
}

/* ---- Cards ---- */
.scout-card {
    background: var(--scout-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
    padding: var(--space-5);
    margin-bottom: var(--space-4);
    border: 1px solid var(--scout-gray-200);
    transition: box-shadow var(--transition);
}

.scout-card:hover {
    box-shadow: var(--shadow-md);
}

/* ---- Landing Feature Cards ---- */
.landing-card {
    background: var(--scout-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
    padding: var(--space-6) var(--space-5);
    text-align: center;
    border: 1px solid var(--scout-gray-200);
}

.landing-card h2 {
    font-family: var(--font-display);
    font-size: var(--font-xl);
    font-weight: 700;
    margin-bottom: var(--space-2);
}

.landing-card>p {
    color: var(--scout-gray-500);
    font-size: var(--font-sm);
    margin: 0 0 var(--space-6);
}

.feature-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
}

.feature-item {
    padding: var(--space-6);
    background: var(--scout-gray-50);
    border-radius: var(--radius-md);
    border: 1px solid var(--scout-gray-200);
    transition: transform var(--transition), box-shadow var(--transition);
    display: flex;
    flex-direction: column;
    align-items: center;
}

.feature-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
}

.feature-icon {
    font-size: 1.6rem;
    margin-bottom: var(--space-2);
    display: block;
}

.feature-icon-img {
    width: 56px;
    height: 56px;
    margin-bottom: var(--space-3);
}

.feature-check {
    width: 32px;
    height: 32px;
    border-radius: var(--radius-full);
    background: var(--scout-success);
    color: var(--scout-white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: var(--space-3);
    flex-shrink: 0;
}

.feature-item h3 {
    font-size: var(--font-sm);
    font-weight: 700;
    margin-bottom: var(--space-1);
}

.feature-item p {
    font-size: var(--font-xs);
    color: var(--scout-gray-500);
    margin: 0;
    line-height: 1.4;
}

/* ---- Risk Gauge Card ---- */
.risk-card {
    background: var(--scout-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
    padding: var(--space-5);
    border: 1px solid var(--scout-gray-200);
    text-align: center;
}

/* #16: Moved inline styles to classes */
.gauge-wrapper {
    height: 200px;
    position: relative;
}

.gauge-annotation {
    text-align: center;
    margin-top: -20px;
}

.gauge-score {
    font-size: 2.75rem;
    font-weight: 700;
    color: var(--scout-gray-800);
    line-height: 1;
}

.gauge-label {
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 1px;
    margin-top: 4px;
}

.risk-card .risk-summary {
    margin-top: var(--space-3);
}

.risk-card .risk-summary .risk-prediction {
    font-size: var(--font-base);
    font-weight: 600;
    color: var(--scout-gray-700);
    line-height: 1.4;
}

.risk-card .risk-summary .risk-basis {
    font-size: var(--font-sm);
    color: var(--scout-gray-500);
    margin-top: var(--space-1);
}

/* Vehicle Life Expectancy bar */
.life-bar-track {
    position: relative;
    height: 1.5rem;
    background: var(--scout-gray-200);
    border-radius: var(--radius-full);
    margin-bottom: 0.375rem;
    overflow: hidden;
}

.life-bar-fill {
    height: 100%;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    transition: width 0.8s var(--ease-out);
}

.life-bar-over {
    background: linear-gradient(90deg, #dc2626 0%, #b91c1c 100%);
}

.life-bar-ok {
    background: linear-gradient(90deg, #10b981 0%, #059669 100%);
}

/* Owner & Usage two-column grid */
.owner-usage-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-bottom: 1px solid var(--scout-gray-200);
    background: var(--scout-gray-50);
}

.owner-usage-cell {
    text-align: center;
    padding: var(--space-2) var(--space-3);
}

.owner-usage-cell:first-child {
    border-right: 1px solid var(--scout-gray-200);
}

.owner-badge {
    display: inline-block;
    font-size: 0.6rem;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: var(--radius-full);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: #fff;
}

/* View Risk Factors button */
.risk-factors-btn {
    margin-top: var(--space-2);
    color: var(--scout-info);
    font-size: var(--font-sm);
    font-weight: 500;
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-1);
    margin-left: auto;
    margin-right: auto;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-md);
    transition: background var(--transition), color var(--transition);
}

.risk-factors-btn:hover {
    color: #1d4ed8;
    background: rgba(59, 130, 246, 0.08);
}

/* #11: Risk Factors overlay — positioned above the card */
.risk-breakdown-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    overflow: hidden;
    background: var(--scout-white);
    z-index: 100;
    padding: var(--space-4);
    border-radius: 1rem;
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--scout-gray-200);
    display: flex;
    flex-direction: column;
    animation: fadeIn 0.2s ease-out forwards;
}

@keyframes fadeIn {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}

.risk-breakdown-close {
    color: var(--scout-gray-500);
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--space-1);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color var(--transition), background var(--transition);
}

.risk-breakdown-close:hover {
    color: var(--scout-gray-700);
    background: rgba(0, 0, 0, 0.05);
}

.risk-breakdown-close .e-icons {
    font-size: 1.1rem;
}

/* Risk tags — passive informational labels */
.risk-tag {
    background: #f1f5f9;
    color: #475569;
    border: 1px solid #cbd5e1;
    font-size: 0.5rem;
    font-weight: 500;
    padding: 2px 8px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    display: inline-block;
}

/* Action buttons — 2×2 grid under the risk gauge card */
.action-btn {
    width: 100%;
    text-align: center;
    padding: 0.5rem 1rem;
    font-size: 0.65rem;
    font-weight: 700;
    color: var(--scout-gray-600, #4b5563);
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);
}

.action-btn:hover {
    background: #f9fafb;
}

.action-btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.premium-star {
    color: var(--scout-gold, #d4a843);
    font-size: 0.8rem;
    margin-right: 3px;
}

/* Dark blue premium buttons (Vehicle History & Expert Report) */
.action-btn.action-btn-dark {
    background: #1e293b;
    color: #ffffff;
    border-color: #1e293b;
}
.action-btn.action-btn-dark:hover {
    background: #334155;
}
.action-btn.action-btn-dark:disabled {
    background: #475569;
    border-color: #475569;
    opacity: 0.7;
}
.action-btn.action-btn-dark .premium-star {
    color: #fbbf24;
}
/* Full-width button spanning both grid columns */
.action-btn.action-btn-full {
    grid-column: 1 / -1;
}

/* Locked premium buttons (free/unpaid users) */
.action-btn.premium-locked {
    background: #E2E8F0;
    color: #64748B;
    border-color: #cbd5e1;
    cursor: pointer;
}
.action-btn.premium-locked:hover {
    background: #cbd5e1;
}

.premium-lock-icon {
    display: inline-block;
    vertical-align: middle;
    margin-right: 3px;
    color: #64748B;
}

/* Car History Alert Banners */
.car-history-alert {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 0.5rem;
    font-size: 0.8rem;
    line-height: 1.4;
    border: 1px solid;
}

.car-history-alert .alert-icon {
    font-size: 1.1rem;
    flex-shrink: 0;
    margin-top: 1px;
}

.car-history-alert .alert-content strong {
    display: block;
    font-size: 0.75rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.car-history-alert .alert-detail {
    font-size: 0.75rem;
    margin-top: 2px;
    opacity: 0.85;
}

.alert-stolen {
    background: #fef2f2;
    border-color: #fca5a5;
    color: #991b1b;
}

.alert-writeoff {
    background: #fffbeb;
    border-color: #fcd34d;
    color: #92400e;
}

.alert-finance {
    background: #eff6ff;
    border-color: #93c5fd;
    color: #1e40af;
}

/* Alert disclaimer footnote (Stolen/Finance/Write-Off) */
.alert-disclaimer {
    font-size: 0.55rem;
    font-style: italic;
    color: #4B5563;
    margin-top: 2px;
    line-height: 1.3;
}

/* Dispute link below report */
.dispute-link {
    display: block;
    text-align: center;
    font-size: 0.7rem;
    color: #64748B;
    text-decoration: underline;
    margin: 8px 0 4px;
}
.dispute-link:hover {
    color: #475569;
}

/* Premium Feature Modal */
.premium-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    animation: fadeIn 0.15s ease-out;
}

.premium-modal {
    background: #fff;
    border-radius: var(--radius-xl);
    padding: 2rem 1.5rem;
    max-width: 340px;
    width: 100%;
    text-align: center;
    box-shadow: var(--shadow-xl);
    animation: slideUp 0.2s var(--ease-out);
}

@keyframes slideUp {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.premium-modal-icon {
    margin-bottom: 0.75rem;
}

.premium-modal h3 {
    margin: 0 0 0.5rem;
    color: var(--scout-gray-800);
    font-size: 1.25rem;
}

.premium-modal p {
    color: var(--scout-gray-500);
    font-size: 0.9rem;
    margin-bottom: 1.25rem;
    line-height: 1.5;
}

.premium-modal-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 48px;
    background: var(--scout-navy);
    color: #fff;
    border-radius: var(--radius-md);
    font-weight: 700;
    text-decoration: none;
    font-size: 1rem;
    transition: background var(--transition);
}
.premium-modal-cta:hover {
    background: var(--scout-navy-light);
    color: #fff;
}

.premium-modal-close {
    display: block;
    width: 100%;
    margin-top: 0.75rem;
    background: none;
    border: none;
    color: var(--scout-gray-400);
    font-size: 0.85rem;
    cursor: pointer;
    min-height: 48px;
    transition: color var(--transition);
}
.premium-modal-close:hover {
    color: var(--scout-gray-600);
}

.risk-breakdown-content {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    text-align: left;
    flex: 1;
    min-height: 0;
}

.risk-reasoning-text {
    font-size: var(--font-sm);
    color: var(--scout-gray-800);
    line-height: 1.5;
    background: var(--scout-gray-50);
    padding: var(--space-3);
    border-radius: var(--radius-md);
    border: 1px solid var(--scout-gray-100);
    white-space: pre-wrap;
    margin-top: var(--space-1);
}

.risk-stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
}

.risk-stat-card {
    padding: var(--space-3);
    border-radius: var(--radius-md);
    text-align: center;
}

.risk-stat-blue {
    background: #eff6ff;
}

.risk-stat-red {
    background: #fef2f2;
}

.risk-stat-label {
    display: block;
    font-size: var(--font-xs);
    font-weight: 700;
    text-transform: uppercase;
}

.risk-stat-blue .risk-stat-label {
    color: #2563eb;
}

.risk-stat-red .risk-stat-label {
    color: var(--scout-danger-dark);
}

.risk-stat-value {
    display: block;
    font-size: var(--font-xl);
    font-weight: 700;
    margin-top: var(--space-1);
}

.risk-stat-blue .risk-stat-value {
    color: #1e3a8a;
}

.risk-stat-red .risk-stat-value {
    color: #991b1b;
}

/* ---- Checks Page ---- */
.checks-page-title {
    color: var(--scout-gold);
    font-size: var(--font-lg);
    font-weight: 700;
    margin-top: var(--space-4);
    margin-bottom: 0;
    text-align: center;
    letter-spacing: 0.3px;
}

.checks-content {
    padding: var(--space-4);
    max-width: 480px;
    margin: var(--space-6) auto 0;
}

.checks-table-card {
    background: var(--scout-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
    padding: var(--space-4);
    border: 1px solid var(--scout-gray-200);
}

.checks-table {
    width: 100%;
    text-align: left;
    border-collapse: collapse;
}

.checks-table thead tr {
    border-bottom: 2px solid var(--scout-gray-200);
}

.checks-table th {
    padding: var(--space-3) var(--space-2);
    font-size: var(--font-xs);
    font-weight: 700;
    color: var(--scout-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.checks-table tbody tr {
    border-bottom: 1px solid var(--scout-gray-100);
}

.checks-table tbody tr:last-child {
    border-bottom: none;
}

.checks-reg {
    padding: var(--space-3) var(--space-2);
    font-weight: 700;
    text-transform: uppercase;
    color: var(--scout-navy);
    font-size: var(--font-sm);
}

.checks-date {
    padding: var(--space-3) var(--space-2);
    font-size: var(--font-xs);
    color: var(--scout-gray-500);
}

.checks-action {
    padding: var(--space-3) var(--space-2);
    text-align: right;
}

.checks-btn {
    background: var(--scout-navy) !important;
    color: var(--scout-white) !important;
    font-size: var(--font-xs) !important;
    font-weight: 700 !important;
    border-radius: var(--radius-md) !important;
    padding: 6px 12px !important;
    border: none !important;
}

.checks-btn:hover {
    background: var(--scout-navy-light) !important;
}

.checks-btn-loading {
    opacity: 0.5;
}

.checks-free-label {
    font-size: var(--font-xs);
    color: var(--scout-gray-400);
    font-style: italic;
}

.checks-empty {
    margin-top: var(--space-8);
    padding: var(--space-8);
    text-align: center;
}

.checks-empty h3 {
    color: var(--scout-navy);
    margin-bottom: var(--space-2);
}

.checks-empty p {
    color: var(--scout-gray-500);
    font-size: var(--font-sm);
    margin-bottom: var(--space-4);
}

/* ---- Accordion / Report ---- */
.report-section {
    padding-bottom: var(--space-12);
}

/* Syncfusion Accordion Overrides */
.e-accordion {
    border: none !important;
    background: transparent !important;
}

.e-accordion .e-acrdn-item {
    border: none !important;
    margin-bottom: var(--space-2);
    border-radius: var(--radius-md) !important;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.e-accordion .e-acrdn-item .e-acrdn-header {
    background: linear-gradient(135deg, var(--scout-navy-light) 0%, var(--scout-navy) 100%) !important;
    border-radius: var(--radius-md) !important;
    margin-bottom: 0 !important;
    color: var(--scout-white) !important;
    padding: var(--space-3) var(--space-4) !important;
    min-height: 48px;
    transition: opacity var(--transition);
}

.e-accordion .e-acrdn-item .e-acrdn-header:hover {
    opacity: 0.92;
}

.e-accordion .e-acrdn-item .e-acrdn-header .e-acrdn-header-content {
    color: var(--scout-white) !important;
    font-weight: 600;
    font-size: var(--font-base);
}

.e-accordion .e-acrdn-item .e-acrdn-header .e-icons {
    color: var(--scout-white) !important;
}

.e-accordion .e-acrdn-item .e-acrdn-header .e-toggle-icon {
    color: rgba(255, 255, 255, 0.7) !important;
}

.e-accordion .e-acrdn-item.e-expand-state .e-acrdn-header {
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.e-accordion .e-acrdn-item .e-acrdn-panel {
    background: var(--scout-white) !important;
    border: 1px solid var(--scout-gray-200) !important;
    border-top: none !important;
    border-bottom-left-radius: var(--radius-md) !important;
    border-bottom-right-radius: var(--radius-md) !important;
    padding: var(--space-4) !important;
}

.e-accordion .e-acrdn-item .e-acrdn-panel .e-acrdn-content {
    padding: 0 !important;
}

/* Accordion Header Icon */
.accordion-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-weight: 600;
}

.accordion-header .e-icons {
    font-size: 1.1rem;
}

/* ---- Advisories List ---- */
.advisories-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.advisories-list li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    padding: var(--space-2) 0;
    font-size: var(--font-sm);
    color: var(--scout-gray-600);
    border-bottom: 1px solid var(--scout-gray-100);
    line-height: 1.5;
}

.advisories-list li:last-child {
    border-bottom: none;
}

.advisories-list li::before {
    content: '';
    width: 6px;
    height: 6px;
    min-width: 6px;
    border-radius: var(--radius-full);
    background: var(--scout-warning);
    margin-top: 7px;
}

/* ---- MOT Timeline ---- */
.mot-timeline {
    padding: var(--space-1) 0;
    margin-left: var(--space-4);
    padding-left: 8px;
}

.timeline-entry {
    position: relative;
    padding-left: var(--space-8);
    padding-bottom: var(--space-5);
    border-left: 2px solid var(--scout-gray-200);
}

.timeline-entry:last-child {
    border-left-color: transparent;
    padding-bottom: 0;
}

.timeline-dot {
    position: absolute;
    left: -7px;
    top: 2px;
    width: 12px;
    height: 12px;
    border-radius: var(--radius-full);
    border: 2px solid var(--scout-white);
    box-shadow: 0 0 0 2px var(--scout-gray-300);
}

.timeline-dot.pass {
    background: var(--scout-success);
    box-shadow: 0 0 0 2px var(--scout-success);
}

.timeline-dot.fail {
    background: var(--scout-danger);
    box-shadow: 0 0 0 2px var(--scout-danger);
}

.timeline-status {
    font-weight: 700;
    font-size: var(--font-sm);
}

.timeline-status.pass {
    color: var(--scout-success);
}

.timeline-status.fail {
    color: var(--scout-danger);
}

.timeline-meta {
    font-size: var(--font-xs);
    color: var(--scout-gray-500);
    margin-top: 2px;
}

/* ---- Car Details Grid ---- */
.car-details-grid {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0;
    font-size: var(--font-sm);
}

.car-details-grid .detail-label,
.car-details-grid .detail-value {
    padding: var(--space-2) var(--space-3);
    border-bottom: 1px solid var(--scout-gray-100);
}

.car-details-grid .detail-label {
    font-weight: 700;
    color: var(--scout-gray-700);
    white-space: nowrap;
}

.car-details-grid .detail-value {
    color: var(--scout-gray-600);
}

.car-details-grid .detail-label:nth-child(4n+1),
.car-details-grid .detail-value:nth-child(4n+2) {
    background: var(--scout-gray-50);
}


/* ---------- 4. Paywall / Dialog ---------- */

/* Syncfusion Dialog overrides */
.e-dialog {
    border-radius: var(--radius-lg) !important;
    overflow: hidden;
    box-shadow: var(--shadow-xl) !important;
    border: none !important;
}

.e-dialog .e-dlg-header-content {
    padding: 0 !important;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
    border-bottom: none !important;
}

.e-dialog .e-dlg-header {
    width: 100%;
}

.e-dialog .e-dlg-content {
    padding: var(--space-5) !important;
}

.e-dialog .e-footer-content {
    padding: 0 var(--space-5) var(--space-5) !important;
    border-top: none !important;
}

.e-dialog .e-footer-content .e-btn {
    width: 100%;
    height: 44px;
    border-radius: var(--radius-md) !important;
    font-weight: 600 !important;
    font-size: var(--font-base) !important;
}

/* Dialog header branding */
.paywall-header {
    background: linear-gradient(160deg, var(--scout-navy-light) 0%, var(--scout-navy) 100%);
    color: var(--scout-white);
    padding: var(--space-6) var(--space-4) var(--space-5);
    text-align: center;
}

.paywall-header h1 {
    color: var(--scout-white);
    font-family: var(--font-display);
    font-size: var(--font-2xl);
    font-weight: 700;
}

.paywall-header .subtitle {
    font-size: var(--font-sm);
    opacity: 0.75;
    margin-top: 2px;
}

.paywall-header .powered-by {
    font-size: var(--font-xs);
    opacity: 0.45;
    margin-top: var(--space-2);
}

.paywall-header .header-divider {
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    margin-top: var(--space-3);
    padding-top: var(--space-3);
}

.paywall-header .header-title {
    font-weight: 700;
    font-size: var(--font-lg);
    opacity: 0.95;
}

/* Progress Steps */
.progress-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    margin-bottom: var(--space-5);
}

.progress-step {
    width: 32px;
    height: 32px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-sm);
    font-weight: 700;
    transition: all var(--transition);
}

.progress-step.active {
    background: var(--scout-navy);
    color: var(--scout-white);
    box-shadow: 0 2px 8px rgba(15, 27, 45, 0.3);
}

.progress-step.completed {
    background: var(--scout-success);
    color: var(--scout-white);
}

.progress-step.inactive {
    background: var(--scout-gray-200);
    color: var(--scout-gray-400);
}

.progress-line {
    width: 40px;
    height: 2px;
    background: var(--scout-gray-200);
    transition: background var(--transition);
}

.progress-line.active {
    background: var(--scout-navy);
}

.step-label {
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--scout-gray-700);
    text-align: center;
    margin-bottom: var(--space-4);
}

/* OTP override */
.otp-container {
    display: flex;
    justify-content: center;
    margin-top: var(--space-2);
}

.otp-container .e-otp-input input {
    width: 44px !important;
    height: 52px !important;
    font-size: var(--font-xl) !important;
    font-weight: 700 !important;
    border-radius: var(--radius-md) !important;
    border: 2px solid var(--scout-gray-200) !important;
    text-align: center;
    transition: border-color var(--transition);
}

.otp-container .e-otp-input input:focus {
    border-color: var(--scout-navy) !important;
    box-shadow: 0 0 0 3px rgba(15, 27, 45, 0.1) !important;
}

/* Pricing Cards */
.pricing-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
}

.pricing-grid-3,
.pricing-grid-4 {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
    max-width: 900px;
    margin: 0 auto;
}

/* 3-column grid disabled — app container is 480px max, so cards stay stacked */

.pricing-card {
    border: 2px solid var(--scout-gray-200);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    text-align: center;
    transition: all var(--transition);
    position: relative;
    background: var(--scout-white);
}

.pricing-card.recommended {
    border-color: var(--scout-navy);
    box-shadow: 0 4px 16px rgba(15, 27, 45, 0.12);
}

.pricing-badge {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--scout-gold);
    color: var(--scout-white);
    font-size: var(--font-xs);
    font-weight: 700;
    padding: 2px 10px;
    border-radius: var(--radius-full);
    white-space: nowrap;
}

.pricing-card h3 {
    font-size: var(--font-lg);
    font-weight: 700;
    color: var(--scout-navy);
    margin-bottom: var(--space-2);
}

.pricing-amount {
    font-size: var(--font-2xl);
    font-weight: 700;
    color: var(--scout-gray-800);
}

.pricing-amount span {
    font-size: var(--font-sm);
    font-weight: 400;
    color: var(--scout-gray-500);
}

.pricing-features {
    list-style: none;
    padding: 0;
    margin: var(--space-3) 0 var(--space-4);
    text-align: left;
}

.pricing-features li {
    font-size: var(--font-xs);
    color: var(--scout-gray-600);
    padding: var(--space-1) 0;
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.pricing-features li::before {
    content: '\2713';
    color: var(--scout-success);
    font-weight: 700;
    font-size: var(--font-sm);
    min-width: 1em;
}

.subscribe-btn {
    width: 100%;
    height: 38px;
    border-radius: var(--radius-md) !important;
    font-weight: 600 !important;
    font-size: var(--font-sm) !important;
}

.no-card-note {
    font-size: var(--font-xs);
    color: var(--scout-gray-400);
    text-align: center;
    margin-top: var(--space-3);
}

.pricing-note {
    text-align: center;
    font-size: var(--font-xs);
    color: var(--scout-gray-500);
    margin-top: var(--space-3);
}

/* Pricing Page */
.pricing-title {
    font-size: var(--font-xl);
    font-weight: 700;
    color: var(--scout-navy);
    margin-bottom: var(--space-1);
}

.pricing-subtitle {
    font-size: var(--font-sm);
    color: var(--scout-gray-500);
}

.pricing-error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #991b1b;
    padding: var(--space-3);
    border-radius: var(--radius-md);
    text-align: center;
    margin-top: var(--space-4);
    font-size: var(--font-sm);
}

/* Why Upgrade Section */
.why-upgrade-section {
    margin-top: var(--space-8);
    text-align: center;
}

.why-upgrade-section h3 {
    font-size: var(--font-lg);
    font-weight: 700;
    color: var(--scout-navy);
    margin-bottom: var(--space-4);
}

.upgrade-comparison {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
    text-align: left;
}

.upgrade-col {
    border-radius: var(--radius-lg);
    padding: var(--space-6);
}

.upgrade-col h4 {
    font-size: var(--font-md);
    font-weight: 700;
    margin: 0 0 var(--space-1);
}

.upgrade-col .col-subtitle {
    font-size: var(--font-xs);
    color: var(--scout-gray-500);
    margin: 0 0 var(--space-3);
}

.upgrade-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.upgrade-col ul li {
    font-size: var(--font-xs);
    padding: var(--space-1) 0;
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.free-col {
    background: var(--scout-gray-50, #f8fafc);
    border: 1px solid var(--scout-gray-200);
}

.free-col h4 {
    color: var(--scout-gray-600);
}

.free-col ul li::before {
    content: '\2713';
    color: var(--scout-success);
    font-weight: 700;
    min-width: 1em;
}

.paid-col {
    background: #f0f9ff;
    border: 1px solid #bae6fd;
}

.paid-col h4 {
    color: var(--scout-navy);
}

.paid-col ul li::before {
    content: '\2713';
    color: var(--scout-success);
    font-weight: 700;
    min-width: 1em;
}

/* ---- #6: Loading Skeleton ---- */
.skeleton-card {
    background: var(--scout-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
    padding: var(--space-6);
    border: 1px solid var(--scout-gray-200);
    margin-bottom: var(--space-3);
}

.skeleton-gauge {
    width: 140px;
    height: 140px;
    border-radius: var(--radius-full);
    background: linear-gradient(110deg, var(--scout-gray-100) 8%, var(--scout-gray-50) 18%, var(--scout-gray-100) 33%);
    background-size: 200% 100%;
    animation: skeleton-shimmer 1.2s linear infinite;
    margin: 0 auto var(--space-4);
}

.skeleton-line {
    height: 14px;
    border-radius: var(--radius-sm);
    background: linear-gradient(110deg, var(--scout-gray-100) 8%, var(--scout-gray-50) 18%, var(--scout-gray-100) 33%);
    background-size: 200% 100%;
    animation: skeleton-shimmer 1.2s linear infinite;
    margin-bottom: var(--space-3);
}

.skeleton-line:last-child {
    margin-bottom: 0;
}

.skeleton-line.w-40 { width: 40%; margin-left: auto; margin-right: auto; }
.skeleton-line.w-60 { width: 60%; margin-left: auto; margin-right: auto; }
.skeleton-line.w-80 { width: 80%; }

@keyframes skeleton-shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ---- #14: AI Backdrop ---- */
.ai-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3);
    z-index: 999;
}

/* ---- Accordion Badge (advisory/history count) ---- */
.accordion-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    border-radius: var(--radius-full);
    background: rgba(255, 255, 255, 0.2);
    color: var(--scout-white);
    font-size: var(--font-xs);
    font-weight: 700;
    padding: 0 var(--space-1);
    margin-left: auto;
}

/* ---- #13: Report Source attribution ---- */
.report-source {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    justify-content: center;
    font-size: var(--font-xs);
    color: var(--scout-gray-400);
    padding: var(--space-4) 0 var(--space-2);
    font-style: italic;
}

.report-source .e-icons {
    font-size: 0.7rem;
    opacity: 0.6;
}

/* ---- #9: Search Another Button ---- */
.search-another-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    width: 100%;
    padding: var(--space-3) var(--space-4);
    margin-bottom: var(--space-8);
    background: var(--scout-white);
    color: var(--scout-navy);
    border: 2px solid var(--scout-gray-200);
    border-radius: var(--radius-md);
    font-size: var(--font-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition);
}

.search-another-btn:hover {
    border-color: var(--scout-navy);
    background: var(--scout-gray-50);
    box-shadow: var(--shadow-sm);
}

.search-another-btn:active {
    transform: scale(0.98);
}

.search-another-btn .e-icons {
    font-size: 0.9rem;
}

/* ---- #5: Auto-uppercase reg input ---- */
.reg-input-upper input.e-input {
    text-transform: uppercase;
}

/* ---- #8: AI prompt hint text ---- */
.ai-prompt-hint {
    font-size: var(--font-xs);
    color: var(--scout-gray-400);
    align-self: center;
    margin-right: var(--space-2);
}

/* ---- Spinner animation class ---- */
.icon-spin {
    animation: spin 1s linear infinite;
}

/* ---------- 5. Global Utility Classes ---------- */

/* Display */
.flex {
    display: flex;
}

.grid {
    display: grid;
}

.grid-cols-2 {
    grid-template-columns: repeat(2, 1fr);
}

.block {
    display: block;
}

.inline-flex {
    display: inline-flex;
}

.hidden {
    display: none;
}

/* Flex */
.flex-col {
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

.flex-1 {
    flex: 1 1 0%;
}

.flex-grow {
    flex-grow: 1;
}

.flex-shrink-0 {
    flex-shrink: 0;
}

.items-center {
    align-items: center;
}

.items-start {
    align-items: flex-start;
}

.justify-center {
    justify-content: center;
}

.justify-between {
    justify-content: space-between;
}

/* Spacing */
.gap-1 {
    gap: var(--space-1);
}

.gap-2 {
    gap: var(--space-2);
}

.gap-3 {
    gap: var(--space-3);
}

.gap-4 {
    gap: var(--space-4);
}

.mt-1 {
    margin-top: var(--space-1);
}

.mt-2 {
    margin-top: var(--space-2);
}

.mt-3 {
    margin-top: var(--space-3);
}

.mt-4 {
    margin-top: var(--space-4);
}

.mt-6 {
    margin-top: var(--space-6);
}

.mt-8 {
    margin-top: var(--space-8);
}

.mt-10 {
    margin-top: var(--space-10);
}

.mb-0 {
    margin-bottom: 0;
}

.mb-1 {
    margin-bottom: var(--space-1);
}

.mb-2 {
    margin-bottom: var(--space-2);
}

.mb-3 {
    margin-bottom: var(--space-3);
}

.mb-4 {
    margin-bottom: var(--space-4);
}

.mb-6 {
    margin-bottom: var(--space-6);
}

.-mt-6 {
    margin-top: calc(-1 * var(--space-6));
}

.ml-2 {
    margin-left: var(--space-4);
}

.mr-2 {
    margin-right: var(--space-2);
}

.my-2 {
    margin-top: var(--space-2);
    margin-bottom: var(--space-2);
}

.px-2 {
    padding-left: var(--space-2);
    padding-right: var(--space-2);
}

.px-4 {
    padding-left: var(--space-4);
    padding-right: var(--space-4);
}

.px-5 {
    padding-left: var(--space-5);
    padding-right: var(--space-5);
}

.px-6 {
    padding-left: var(--space-6);
    padding-right: var(--space-6);
}

.py-2 {
    padding-top: var(--space-2);
    padding-bottom: var(--space-2);
}

.py-4 {
    padding-top: var(--space-4);
    padding-bottom: var(--space-4);
}

.py-6 {
    padding-top: var(--space-6);
    padding-bottom: var(--space-6);
}

.p-1 {
    padding: var(--space-1);
}

.p-2 {
    padding: var(--space-2);
}

.p-3 {
    padding: var(--space-3);
}

.p-4 {
    padding: var(--space-4);
}

.pb-8 {
    padding-bottom: var(--space-8);
}

.pb-20 {
    padding-bottom: 5rem;
}

.pl-5 {
    padding-left: var(--space-5);
}

.pl-6 {
    padding-left: var(--space-6);
}

.pt-2 {
    padding-top: var(--space-2);
}

/* Typography */
.text-xs {
    font-size: var(--font-xs);
}

.text-sm {
    font-size: var(--font-sm);
}

.text-base {
    font-size: var(--font-base);
}

.text-md {
    font-size: var(--font-md);
}

.text-lg {
    font-size: var(--font-lg);
}

.text-xl {
    font-size: var(--font-xl);
}

.text-2xl {
    font-size: var(--font-2xl);
}

.text-3xl {
    font-size: var(--font-3xl);
}

.font-normal {
    font-weight: 400;
}

.font-medium {
    font-weight: 500;
}

.font-semibold {
    font-weight: 600;
}

.font-bold {
    font-weight: 700;
}

.font-extrabold {
    font-weight: 700;
}

.font-black {
    font-weight: 700;
}

.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

/* Colors */
.text-white {
    color: var(--scout-white) !important;
}

.text-gray-400 {
    color: var(--scout-gray-400);
}

.text-gray-500 {
    color: var(--scout-gray-500);
}

.text-gray-600 {
    color: var(--scout-gray-600);
}

.text-gray-700 {
    color: var(--scout-gray-700);
}

.text-gray-800 {
    color: var(--scout-gray-800);
}

.text-gray-900 {
    color: var(--scout-gray-900);
}

.text-green-600 {
    color: #16a34a;
}

.text-blue-600 {
    color: #2563eb;
}

.text-red-500 {
    color: var(--scout-danger);
}

.text-red-600 {
    color: var(--scout-danger-dark);
}

.text-amber-500 {
    color: #f59e0b;
}

.text-emerald-500 {
    color: #10b981;
}

.bg-white {
    background-color: var(--scout-white);
}

.bg-gray-50 {
    background-color: var(--scout-gray-50);
}

.bg-gray-200 {
    background-color: var(--scout-gray-200);
}

.bg-blue-50 {
    background-color: #eff6ff;
}

.bg-blue-900 {
    background-color: #1e3a8a;
}

.bg-green-500 {
    background-color: var(--scout-success);
}

.bg-red-500 {
    background-color: var(--scout-danger);
}

.bg-red-600 {
    background-color: #dc2626;
}

.bg-red-800\/30 {
    background-color: rgba(153, 27, 27, 0.3);
}

.bg-amber-500 {
    background-color: #f59e0b;
}

.bg-amber-700\/30 {
    background-color: rgba(180, 83, 9, 0.3);
}

.bg-emerald-500 {
    background-color: #10b981;
}

.bg-gray-400 {
    background-color: #9ca3af;
}

.bg-yellow-500 {
    background-color: #eab308;
}

.bg-emerald-700\/30 {
    background-color: rgba(4, 120, 87, 0.3);
}

.bg-orange-500 {
    background-color: #f97316;
}

.bg-purple-600 {
    background-color: #9333ea;
}

.bg-gray-500 {
    background-color: var(--scout-gray-500);
}

.bg-indigo-600 {
    background-color: #4f46e5;
}

/* Opacity */
.opacity-90 {
    opacity: 0.9;
}

.opacity-80 {
    opacity: 0.8;
}

.opacity-60 {
    opacity: 0.6;
}

/* Borders & Radius */
.rounded {
    border-radius: var(--radius-sm);
}

.rounded-md {
    border-radius: var(--radius-md);
}

.rounded-lg {
    border-radius: var(--radius-lg);
}

.rounded-xl {
    border-radius: var(--radius-xl);
}

.rounded-full {
    border-radius: var(--radius-full);
}

.border {
    border: 1px solid var(--scout-gray-200);
}

.border-t {
    border-top: 1px solid var(--scout-gray-200);
}

.border-l-2 {
    border-left-width: 2px;
}

/* Sizing */
.w-full {
    width: 100%;
}

.h-1 {
    height: 0.25rem;
}

.w-3 {
    width: 0.75rem;
}

.h-3 {
    height: 0.75rem;
}

/* Positioning */
.relative {
    position: relative;
}

.absolute {
    position: absolute;
}

.fixed {
    position: fixed;
}

.sticky {
    position: sticky;
}

.top-0 {
    top: 0;
}

.bottom-4 {
    bottom: var(--space-4);
}

.left-0 {
    left: 0;
}

.right-0 {
    right: 0;
}

.z-10 {
    z-index: 10;
}

.z-20 {
    z-index: 20;
}

/* Shadows */
.shadow-sm {
    box-shadow: var(--shadow-sm);
}

.shadow-md {
    box-shadow: var(--shadow-md);
}

.shadow-lg {
    box-shadow: var(--shadow-lg);
}

/* Misc */
.overflow-hidden {
    overflow: hidden;
}

.list-disc {
    list-style-type: disc;
}

/* ---------- Risk Gauge Card Utilities ---------- */

/* State header — prominent risk state label */
.state-header-icon {
    font-size: 1.25rem;
}

.state-header-text {
    font-size: 1.3rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

/* Gauge clip wrapper — hides empty bottom half of semi-circle gauge */
.gauge-clip-wrapper {
    width: 100%;
    padding-left: var(--space-4);
    padding-right: var(--space-4);
    height: 210px !important;
    overflow: hidden !important;
}

/* Large score number inside gauge */
.gauge-score-number {
    font-size: 4rem;
    font-weight: 700;
    line-height: 1;
}

/* Font sizes — arbitrary values used by RiskGaugeCard */
.text-4xl {
    font-size: 2.25rem;
}

.text-\[0\.55rem\] {
    font-size: 0.55rem;
}

.text-\[0\.6rem\] {
    font-size: 0.6rem;
}

.text-\[0\.65rem\] {
    font-size: 0.65rem;
}

.text-\[0\.7rem\] {
    font-size: 0.7rem;
}

/* Line height */
.leading-none {
    line-height: 1;
}

.leading-tight {
    line-height: 1.25;
}

/* Letter spacing */
.tracking-wider {
    letter-spacing: 0.05em;
}

/* Text transform */
.uppercase {
    text-transform: uppercase;
}

/* Font family */
.font-sans {
    font-family: var(--font-family);
}

.font-mono {
    font-family: ui-monospace, SFMono-Regular, 'Cascadia Code', 'Consolas', monospace;
}

/* Flex align stretch */
.items-stretch {
    align-items: stretch;
}

/* Min/max widths */
.min-w-\[60px\] {
    min-width: 60px;
}

.max-w-md {
    max-width: 28rem;
}

.mx-auto {
    margin-left: auto;
    margin-right: auto;
}

/* Border radius */
.rounded-2xl {
    border-radius: 1rem;
}

/* Shadows */
.shadow-xl {
    box-shadow: var(--shadow-xl);
}

/* Border colors */
.border-gray-200 {
    border-color: var(--scout-gray-200);
}

.border-b {
    border-bottom: 1px solid var(--scout-gray-200);
}

/* Padding — fractional spacings */
.pt-2 {
    padding-top: var(--space-2);
}

.pt-3 {
    padding-top: var(--space-3);
}

.pb-1 {
    padding-bottom: var(--space-1);
}

.pb-2 {
    padding-bottom: var(--space-2);
}

.px-3 {
    padding-left: var(--space-3);
    padding-right: var(--space-3);
}

.py-1\.5 {
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
}

.p-3 {
    padding: var(--space-3);
}

/* Margin — fractional spacings */
.mt-0\.5 {
    margin-top: 0.125rem;
}

.mb-0\.5 {
    margin-bottom: 0.125rem;
}

.mb-1\.5 {
    margin-bottom: 0.375rem;
}

.-mt-3 {
    margin-top: calc(-1 * var(--space-3));
}

/* Heights */
.h-6 {
    height: 1.5rem;
}

.h-64 {
    height: 16rem;
}

/* Overflow */
.overflow-y-auto {
    overflow-y: auto;
}

/* Whitespace */
.whitespace-pre-wrap {
    white-space: pre-wrap;
}

/* Gap fractional */
.gap-0\.5 {
    gap: 0.125rem;
}

/* Padding fractional */
.py-0\.5 {
    padding-top: 0.125rem;
    padding-bottom: 0.125rem;
}

/* Extra small font sizes */
.text-\[0\.5rem\] {
    font-size: 0.5rem;
}

/* Hover states */
.hover\:text-gray-600:hover {
    color: var(--scout-gray-600);
}


/* ---------- 6. Syncfusion Global Overrides ---------- */

/* Primary buttons → scout-navy with gold accent */
.e-btn.e-primary,
.e-css.e-btn.e-primary {
    background-color: var(--scout-navy) !important;
    border-color: var(--scout-navy) !important;
    color: var(--scout-white) !important;
    border-radius: var(--radius-md) !important;
    font-weight: 600 !important;
    transition: all var(--transition);
}

.e-btn.e-primary:hover,
.e-css.e-btn.e-primary:hover {
    background-color: var(--scout-navy-light) !important;
    box-shadow: 0 2px 8px rgba(15, 27, 45, 0.2);
}

.e-btn.e-primary:active,
.e-css.e-btn.e-primary:active {
    transform: scale(0.98);
}

/* TextBox / Input overrides */
.e-input-group:not(.e-disabled) .e-input:focus,
.e-input-group.e-input-focus:not(.e-disabled) {
    border-color: var(--scout-navy) !important;
}

.e-input-group:not(.e-disabled)::after,
.e-input-group:not(.e-disabled)::before {
    background: var(--scout-navy) !important;
}

/* Card overrides */
.e-card {
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-card) !important;
    border: 1px solid var(--scout-gray-200) !important;
}


/* ---------- 7. Blazor Error UI ---------- */
#blazor-error-ui {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;

    right: 0.75rem;
    top: 0.5rem;
}


/* ---------- 8. AI Prompt Box ---------- */
.scout-search-wrap {
    position: relative;
    z-index: 200;
}

.ai-floating-overlay {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    width: 100%;
    padding-top: var(--space-3);
    z-index: 1000;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.ai-prompt-box {
    background: var(--scout-white);
    border-radius: var(--radius-lg);
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
    padding: var(--space-4);
    border: 1px solid var(--scout-info);
    animation: slide-in 0.3s var(--ease-out);
}

.ai-prompt-input textarea {
    min-height: 80px;
    resize: vertical;
    font-size: var(--font-sm) !important;
    padding: var(--space-2) !important;
    border: 1px solid var(--scout-gray-200) !important;
    border-radius: var(--radius-md) !important;
}

.ai-prompt-input textarea:focus {
    border-color: var(--scout-info) !important;
}

.ai-prompt-actions {
    margin-top: var(--space-3);
    display: flex;
    justify-content: flex-end;
}

@keyframes slide-in {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

/* #3: Shake animation for disabled-button tap */
@keyframes shake {
    0%, 100% { transform: translateX(0); }
    15% { transform: translateX(-6px); }
    30% { transform: translateX(5px); }
    45% { transform: translateX(-4px); }
    60% { transform: translateX(3px); }
    75% { transform: translateX(-2px); }
    90% { transform: translateX(1px); }
}

.scout-search-bar.shake {
    animation: shake 0.5s ease-out;
}
/* ============================================================
   Payment Pages Styling
   ============================================================ */

/* Checkout Page */
.checkout-page,
.payment-result-page {
    min-height: 100vh;
    background: linear-gradient(135deg, var(--scout-navy) 0%, var(--scout-navy-light) 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 2rem 1rem 3rem;
}

.checkout-header,
.payment-result-header {
    text-align: center;
    margin-bottom: var(--space-8);
}

.checkout-header h1,
.payment-result-header h1 {
    font-size: var(--font-3xl);
    font-weight: 700;
    color: var(--scout-gold);
    margin: 0 0 var(--space-2) 0;
    letter-spacing: 0.05em;
}

.checkout-header .subtitle,
.payment-result-header .subtitle {
    font-size: var(--font-sm);
    color: var(--scout-gray-300);
    font-style: italic;
    margin: 0;
}

/* Checkout Loading */
.checkout-loading {
    text-align: center;
    padding: var(--space-8);
    background: var(--scout-white);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    min-width: 300px;
}

.checkout-loading p {
    margin-top: var(--space-4);
    color: var(--scout-gray-600);
    font-size: var(--font-base);
}

.loading-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid var(--scout-gray-200);
    border-top-color: var(--scout-gold);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin: 0 auto;
}

/* Checkout Error */
.checkout-error {
    text-align: center;
    padding: var(--space-8);
    background: var(--scout-white);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    max-width: 400px;
}

.checkout-error .e-icons {
    font-size: 48px;
    color: var(--scout-danger);
    margin-bottom: var(--space-4);
}

.checkout-error h3 {
    font-size: var(--font-xl);
    color: var(--scout-gray-900);
    margin: 0 0 var(--space-3) 0;
}

.checkout-error p {
    color: var(--scout-gray-600);
    margin-bottom: var(--space-6);
}

/* Payment Success Card */
.payment-success-card,
.payment-error-card,
.payment-cancel-card {
    background: var(--scout-white);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    padding: var(--space-8);
    max-width: 500px;
    width: 100%;
    text-align: center;
}

.success-icon-wrapper,
.error-icon-wrapper,
.cancel-icon-wrapper {
    margin-bottom: var(--space-6);
}

.success-icon {
    font-size: 72px;
    color: var(--scout-success);
}

.error-icon {
    font-size: 72px;
    color: var(--scout-danger);
}

.cancel-icon {
    font-size: 72px;
    color: var(--scout-warning);
}

.payment-success-card h2,
.payment-error-card h2,
.payment-cancel-card h2 {
    font-size: var(--font-2xl);
    color: var(--scout-gray-900);
    margin: 0 0 var(--space-3) 0;
    font-weight: 700;
}

.success-message,
.error-message,
.cancel-message {
    color: var(--scout-gray-600);
    font-size: var(--font-base);
    margin-bottom: var(--space-6);
    line-height: 1.6;
}

/* Success Details */
.success-details {
    background: var(--scout-gray-50);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    margin-bottom: var(--space-6);
}

.detail-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--scout-gray-200);
}

.detail-row:last-child {
    border-bottom: none;
}

.detail-label {
    font-size: var(--font-sm);
    color: var(--scout-gray-500);
    font-weight: 500;
}

.detail-value {
    font-size: var(--font-base);
    color: var(--scout-gray-900);
    font-weight: 600;
}

.status-active {
    color: var(--scout-success);
}

/* Success Benefits */
.success-benefits {
    text-align: left;
    background: var(--scout-gold);
    background: linear-gradient(135deg, rgba(212, 168, 67, 0.1) 0%, rgba(212, 168, 67, 0.05) 100%);
    border: 1px solid rgba(212, 168, 67, 0.3);
    border-radius: var(--radius-md);
    padding: var(--space-5);
    margin-bottom: var(--space-6);
}

.success-benefits h3 {
    font-size: var(--font-lg);
    color: var(--scout-gray-900);
    margin: 0 0 var(--space-3) 0;
    text-align: center;
}

.success-benefits ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.success-benefits li {
    padding: var(--space-2) 0;
    color: var(--scout-gray-700);
    font-size: var(--font-base);
    line-height: 1.5;
}

/* Cancel Info */
.cancel-info {
    background: var(--scout-gray-50);
    border-radius: var(--radius-md);
    padding: var(--space-5);
    margin-bottom: var(--space-6);
    text-align: left;
}

.cancel-info p {
    font-weight: 600;
    color: var(--scout-gray-900);
    margin: 0 0 var(--space-3) 0;
}

.cancel-info ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.cancel-info li {
    padding: var(--space-2) 0;
    color: var(--scout-gray-700);
    font-size: var(--font-sm);
    border-bottom: 1px solid var(--scout-gray-200);
}

.cancel-info li:last-child {
    border-bottom: none;
}

/* Action Buttons */
.cancel-actions {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.btn-primary,
.btn-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-4) var(--space-6);
    border-radius: var(--radius-md);
    font-size: var(--font-base);
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: all var(--transition);
    width: 100%;
}

.btn-primary {
    background: var(--scout-navy);
    color: var(--scout-white);
}

.btn-primary:hover {
    background: var(--scout-navy-light);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.btn-primary:active {
    transform: translateY(0);
}

.btn-secondary {
    background: var(--scout-gray-100);
    color: var(--scout-gray-700);
    border: 1px solid var(--scout-gray-300);
}

.btn-secondary:hover {
    background: var(--scout-gray-200);
}

.btn-lg {
    padding: var(--space-5) var(--space-8);
    font-size: var(--font-lg);
}

/* Payment Verifying */
.payment-verifying {
    text-align: center;
    padding: var(--space-8);
    background: var(--scout-white);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    min-width: 300px;
}

.payment-verifying p {
    margin-top: var(--space-4);
    color: var(--scout-gray-600);
    font-size: var(--font-base);
}

/* Responsive adjustments */
@media (max-width: 480px) {
    .payment-success-card,
    .payment-error-card,
    .payment-cancel-card {
        padding: var(--space-6);
    }

    .success-icon,
    .error-icon,
    .cancel-icon {
        font-size: 56px;
    }
}


/* ============================================================
   Legal Pages, Cookie Banner, Footer, Data Attribution
   ============================================================ */

/* ---------- Legal Pages (Privacy, Cookies, Terms) ---------- */
.legal-page-container {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    min-height: 100vh;
    background: linear-gradient(160deg, var(--scout-navy-light, #1a2d47) 0%, var(--scout-navy, #0f1b2d) 100%);
    padding: 2rem 1rem 3rem;
}

.legal-card {
    background: var(--surface-bg, #fff);
    border: none;
    border-radius: 16px;
    padding: 2rem;
    width: 100%;
    max-width: 480px;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.4);
}

.legal-card.pricing-card-wide {
    max-width: 480px;
}

.legal-header {
    margin-bottom: var(--space-6);
}

.legal-back-link {
    display: inline-block;
    color: var(--scout-navy-light, #1a2d47);
    font-size: var(--font-sm);
    text-decoration: none;
    margin-bottom: var(--space-3);
}

.legal-back-link:hover {
    text-decoration: underline;
}

.legal-card h1 {
    font-size: var(--font-xl);
    font-weight: 700;
    color: var(--scout-navy);
    margin: 0 0 var(--space-2);
}

.legal-effective {
    font-size: var(--font-xs);
    color: var(--scout-gray-500);
    margin: 0;
}

.legal-body section {
    margin-bottom: var(--space-6);
}

.legal-body h2 {
    font-size: var(--font-base);
    font-weight: 700;
    color: var(--scout-navy);
    margin: 0 0 var(--space-3);
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--scout-gray-200);
}

.legal-body h3 {
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--scout-navy-light);
    margin: var(--space-4) 0 var(--space-2);
}

.legal-body p,
.legal-body li {
    font-size: var(--font-sm);
    color: var(--scout-gray-700);
    line-height: 1.65;
}

.legal-body ul,
.legal-body ol {
    padding-left: var(--space-5);
    margin: var(--space-2) 0;
}

.legal-body li {
    margin-bottom: var(--space-2);
}

.legal-body a {
    color: var(--scout-navy-light, #1a2d47);
    text-decoration: underline;
    font-weight: 600;
}

.legal-body code {
    background: var(--scout-gray-100);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    font-size: var(--font-xs);
}

/* Highlighted legal sections (OGL attribution, liability shield) */
.legal-highlight {
    background: var(--scout-gray-50);
    border-left: 4px solid var(--scout-gold);
    border-radius: var(--radius-md);
    padding: var(--space-4);
}

.legal-highlight.legal-warning {
    border-left-color: var(--scout-danger);
    background: #fef2f2;
}

/* ---- About page stat cards ---- */
.about-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
    margin-top: var(--space-4);
}

.about-stat-card {
    background: var(--scout-navy);
    border-radius: var(--radius-lg);
    padding: var(--space-4) var(--space-2);
    text-align: center;
}

.about-stat-number {
    font-size: var(--font-lg);
    font-weight: 700;
    color: var(--scout-gold);
    line-height: 1.2;
}

.about-stat-label {
    font-size: 0.65rem;
    color: rgba(255, 255, 255, 0.7);
    margin-top: var(--space-1);
    line-height: 1.3;
}

.ogl-attribution {
    background: var(--scout-white);
    border: 1px solid var(--scout-gold);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    margin: var(--space-3) 0;
}

.ogl-attribution p {
    margin: 0;
    font-size: var(--font-sm);
}

/* Legal tables */
.legal-table-wrapper {
    overflow-x: auto;
    margin: var(--space-3) 0;
    -webkit-overflow-scrolling: touch;
}

.legal-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-xs);
}

.legal-table th,
.legal-table td {
    text-align: left;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--scout-gray-200);
    vertical-align: top;
}

.legal-table th {
    background: var(--scout-navy);
    color: var(--scout-white);
    font-weight: 600;
    white-space: nowrap;
}

.legal-table td {
    color: var(--scout-gray-700);
    line-height: 1.5;
}

.legal-table tbody tr:nth-child(even) {
    background: var(--scout-gray-50);
}


/* ---------- Cookie Banner ---------- */
.cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 10000;
    background: var(--scout-navy);
    border-top: 2px solid var(--scout-gold);
    padding: var(--space-4);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.3);
}

.cookie-banner-content {
    max-width: 480px;
    margin: 0 auto;
}

.cookie-banner-content p {
    color: var(--scout-gray-200);
    font-size: var(--font-xs);
    line-height: 1.6;
    margin: 0 0 var(--space-3);
}

.cookie-banner-content a {
    color: var(--scout-gold);
    text-decoration: underline;
}

.cookie-banner-actions {
    display: flex;
    gap: var(--space-3);
}

.cookie-btn {
    flex: 1;
    padding: var(--space-2) var(--space-4);
    border: none;
    border-radius: var(--radius-md);
    font-size: var(--font-sm);
    font-weight: 600;
    cursor: pointer;
    transition: background var(--transition), transform var(--transition);
}

.cookie-btn:active {
    transform: scale(0.97);
}

.cookie-btn-accept {
    background: var(--scout-gold);
    color: var(--scout-navy);
}

.cookie-btn-accept:hover {
    background: var(--scout-gold-hover);
}

.cookie-btn-reject {
    background: transparent;
    color: var(--scout-gray-300);
    border: 1px solid var(--scout-gray-500);
}

.cookie-btn-reject:hover {
    background: rgba(255, 255, 255, 0.08);
    color: var(--scout-white);
}


/* ---------- Data Attribution Component ---------- */
.data-attribution {
    background: var(--scout-gray-50);
    border: 1px solid var(--scout-gray-200);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    margin: var(--space-4) var(--space-4) 0;
}

.data-attribution-ogl {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    font-size: var(--font-xs);
    color: var(--scout-gray-600);
    margin-bottom: var(--space-2);
}

.data-attribution-ogl .ogl-icon {
    flex-shrink: 0;
    margin-top: 2px;
    color: var(--scout-gold);
}

.data-attribution-ogl a {
    color: var(--scout-gold);
    text-decoration: underline;
}

.data-attribution-disclaimer {
    font-size: var(--font-xs);
    color: var(--scout-gray-500);
    line-height: 1.55;
    margin: 0;
}

.data-attribution-disclaimer a {
    color: var(--scout-gold);
    text-decoration: underline;
}


/* ---------- Site Footer ---------- */
.site-footer {
    background: var(--scout-navy);
    color: var(--scout-gray-400);
    padding: var(--space-6) var(--space-4);
    text-align: center;
    margin-top: auto;
}

.footer-links {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
}

.footer-links a {
    color: var(--scout-gray-300);
    font-size: var(--font-xs);
    text-decoration: none;
    transition: color var(--transition);
}

.footer-links a:hover {
    color: var(--scout-gold);
    text-decoration: underline;
}

.footer-divider {
    color: var(--scout-gray-600);
    font-size: var(--font-xs);
}

.footer-ogl {
    font-size: 0.65rem;
    color: var(--scout-gray-500);
    margin-bottom: var(--space-2);
    line-height: 1.5;
}

.footer-ogl a {
    color: var(--scout-gold);
    text-decoration: underline;
}

.footer-copyright {
    font-size: 0.65rem;
    color: var(--scout-gray-600);
}


/* ---------- Consent Checkbox (PaywallDialog) ---------- */
.terms-notice {
    font-size: var(--font-xs);
    color: var(--scout-gray-600);
    line-height: 1.5;
    text-align: center;
    margin: var(--space-3) 0;
}

.terms-notice a {
    color: var(--scout-gold);
    text-decoration: underline;
}


/* =============================================
   BLOG STYLES
   ============================================= */

.blog-page-card {
    max-width: 720px;
}

/* Blog List Grid */
.blog-list-grid {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.blog-card {
    display: block;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-lg);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: border-color var(--transition-fast), transform var(--transition-fast);
}

.blog-card:hover {
    border-color: var(--scout-gold);
    transform: translateY(-2px);
}

.blog-card-image {
    width: 100%;
    height: 180px;
    overflow: hidden;
}

.blog-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.blog-card-body {
    padding: var(--space-4);
}

.blog-card-category {
    display: inline-block;
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--scout-gold);
    background: rgba(212, 168, 67, 0.12);
    padding: 2px 10px;
    border-radius: var(--radius-full);
    margin-bottom: var(--space-2);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.blog-card-title {
    font-size: var(--text-lg);
    font-weight: 700;
    color: #fff;
    margin: 0 0 var(--space-2) 0;
    line-height: 1.3;
}

.blog-card-summary {
    font-size: var(--text-sm);
    color: var(--neutral-400);
    line-height: 1.5;
    margin: 0 0 var(--space-3) 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog-card-meta {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-xs);
    color: var(--neutral-500);
}

/* Blog Post Page */
.blog-back-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: var(--text-sm);
    color: var(--scout-gold);
    text-decoration: none;
    margin-bottom: var(--space-4);
}

.blog-back-link:hover {
    text-decoration: underline;
}

.blog-post-hero {
    width: calc(100% + 2 * var(--space-6));
    margin-left: calc(-1 * var(--space-6));
    margin-bottom: var(--space-5);
    max-height: 320px;
    overflow: hidden;
}

.blog-post-hero img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.blog-post-header {
    margin-bottom: var(--space-4);
}

.blog-post-meta {
    display: flex;
    gap: var(--space-4);
    font-size: var(--text-sm);
    color: var(--neutral-400);
    margin-top: var(--space-2);
}

/* Blog post content — rendered HTML */
.blog-post-content h1 {
    font-size: var(--text-2xl);
    font-weight: 700;
    color: #fff;
    margin: 0 0 var(--space-4) 0;
    line-height: 1.25;
}

.blog-post-content h2 {
    font-size: var(--text-xl);
    font-weight: 600;
    color: #fff;
    margin: var(--space-6) 0 var(--space-3) 0;
    line-height: 1.3;
}

.blog-post-content p {
    font-size: var(--text-base);
    color: var(--neutral-300);
    line-height: 1.7;
    margin: 0 0 var(--space-4) 0;
}

.blog-post-content strong {
    color: #fff;
    font-weight: 600;
}

.blog-post-content ul {
    margin: 0 0 var(--space-4) 0;
    padding-left: var(--space-5);
}

.blog-post-content li {
    font-size: var(--text-base);
    color: var(--neutral-300);
    line-height: 1.7;
    margin-bottom: var(--space-2);
}

.blog-post-content a {
    color: var(--scout-gold);
    text-decoration: underline;
}

.blog-post-content a:hover {
    color: #e6be5a;
}

/* "Did You Know?" callout box */
.blog-did-you-know {
    background: rgba(212, 168, 67, 0.08);
    border-left: 4px solid var(--scout-gold);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    padding: var(--space-4) var(--space-5);
    margin: var(--space-6) 0 var(--space-4) 0;
}

.blog-did-you-know h2 {
    font-size: var(--text-lg) !important;
    color: var(--scout-gold) !important;
    margin: 0 0 var(--space-2) 0 !important;
    display: flex;
    align-items: center;
    gap: 8px;
}

.blog-did-you-know h2::before {
    content: "\2728";
    font-size: var(--text-xl);
}

.blog-did-you-know p {
    color: var(--neutral-300) !important;
    margin: 0 !important;
    font-size: var(--text-sm) !important;
}

/* Blog loading / empty states */
.blog-loading,
.blog-empty {
    text-align: center;
    padding: var(--space-8) 0;
    color: var(--neutral-400);
    font-size: var(--text-base);
}

/* =============================================
   BLOG ADMIN STYLES
   ============================================= */

.blog-admin-card {
    max-width: 900px;
}

.blog-admin-status {
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
    font-size: var(--text-sm);
    font-weight: 500;
}

.blog-admin-status-success {
    background: rgba(34, 197, 94, 0.12);
    color: var(--success);
    border: 1px solid rgba(34, 197, 94, 0.2);
}

.blog-admin-status-error {
    background: rgba(239, 68, 68, 0.12);
    color: var(--danger);
    border: 1px solid rgba(239, 68, 68, 0.2);
}

.blog-admin-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.blog-admin-field {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    flex: 1;
}

.blog-admin-field label {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--neutral-300);
}

.blog-admin-field input[type="text"],
.blog-admin-field textarea,
.blog-admin-field select {
    background: #f8f9fa;
    border: 1px solid #d0d5dd;
    border-radius: var(--radius-md);
    color: #1a1a2e;
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
    font-family: inherit;
    transition: border-color var(--transition-fast);
}

.blog-admin-field input[type="text"]:focus,
.blog-admin-field textarea:focus,
.blog-admin-field select:focus {
    outline: none;
    border-color: var(--scout-gold);
}

.blog-admin-field textarea {
    resize: vertical;
    min-height: 80px;
}

.blog-admin-field select option {
    background: #fff;
    color: #1a1a2e;
}

.blog-admin-row {
    display: flex;
    gap: var(--space-4);
}

@media (max-width: 480px) {
    .blog-admin-row {
        flex-direction: column;
    }
}

.blog-admin-actions {
    display: flex;
    gap: var(--space-3);
}

.blog-admin-btn {
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: background var(--transition-fast);
}

.blog-admin-btn-save {
    background: var(--scout-gold);
    color: var(--scout-navy);
}

.blog-admin-btn-save:hover {
    background: #e6be5a;
}

.blog-admin-btn-cancel {
    background: rgba(255, 255, 255, 0.08);
    color: var(--neutral-300);
}

.blog-admin-btn-cancel:hover {
    background: rgba(255, 255, 255, 0.12);
}

.blog-admin-btn-edit {
    background: transparent;
    color: var(--scout-gold);
    padding: var(--space-1) var(--space-3);
    border: 1px solid rgba(212, 168, 67, 0.3);
}

.blog-admin-btn-edit:hover {
    background: rgba(212, 168, 67, 0.1);
}

.blog-admin-table-wrap {
    overflow-x: auto;
}

.blog-admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}

.blog-admin-table th {
    text-align: left;
    padding: var(--space-2) var(--space-3);
    color: var(--neutral-400);
    font-weight: 600;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    white-space: nowrap;
}

.blog-admin-table td {
    padding: var(--space-3) var(--space-3);
    color: var(--neutral-300);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.blog-admin-badge {
    font-size: var(--text-xs);
    font-weight: 600;
    padding: 2px 8px;
    border-radius: var(--radius-full);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.badge-published {
    background: rgba(34, 197, 94, 0.12);
    color: var(--success);
}

.badge-draft {
    background: rgba(234, 179, 8, 0.12);
    color: var(--warning);
}
