﻿/* ===== IMPACTIQ MOBILE WEB APPLICATION STYLES ===== */
/* Modern, Professional Design with Golden/Black Theme */

:root {
    /* Color Palette */
    --primary-gold: #D4AF37;
    --dark-gold: #B8960F;
    --light-gold: #F4E5A1;
    --black: #000000;
    --charcoal: #1a1a1a;
    --dark-gray: #2a2a2a;
    --gray: #666666;
    --light-gray: #e5e5e5;
    --white: #ffffff;

    /* Status Colors */
    --success: #10b981;
    --warning: #f59e0b;
    --danger: #ef4444;
    --info: #3b82f6;

    /* Spacing */
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;

    /* Border Radius */
    --radius-sm: 0.375rem;
    --radius-md: 0.5rem;
    --radius-lg: 0.75rem;
    --radius-xl: 1rem;

    /* Shadows */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

/* ===== BASE STYLES ===== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html, body {
    height: 100%;
    width: 100%;
    overflow-x: hidden;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    background: var(--white);
    color: var(--charcoal);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ===== LOADING SCREEN ===== */
.loading-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(-45deg, #f8f9fa, #e3e7eb, #d4dce5, #c5d1de);
    background-size: 400% 400%;
    animation: gradientWave 10s ease infinite;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    opacity: 1;
    transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1),
                transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.loading-screen.fade-out {
    opacity: 0;
    transform: scale(1.1);
    pointer-events: none;
}

.logo-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-lg);
    position: relative;
}

/* Pulsing ring around logo */
.logo-container::before {
    content: '';
    position: absolute;
    width: 220px;
    height: 220px;
    border: 3px solid transparent;
    border-top-color: var(--primary-gold);
    border-right-color: var(--dark-gold);
    border-radius: 50%;
    animation: spinRing 2s linear infinite;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.logo-container::after {
    content: '';
    position: absolute;
    width: 195px;
    height: 195px;
    border: 2px solid transparent;
    border-bottom-color: var(--primary-gold);
    border-left-color: rgba(212, 175, 55, 0.3);
    border-radius: 50%;
    animation: spinRing 1.5s linear infinite reverse;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 0.8;
}

@keyframes spinRing {
    from { transform: translate(-50%, -50%) rotate(0deg); }
    to { transform: translate(-50%, -50%) rotate(360deg); }
}

.impactiq-logo {
    width: auto;
    height: 180px;
    max-width: 280px;
    object-fit: contain;
    animation: logoPulse 2s ease-in-out infinite, logoGlow 3s ease-in-out infinite;
    filter: drop-shadow(0 0 20px rgba(212, 175, 55, 0.3));
}

@keyframes logoPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.08); }
}

@keyframes logoGlow {
    0%, 100% { filter: drop-shadow(0 0 20px rgba(212, 175, 55, 0.3)); }
    50% { filter: drop-shadow(0 0 40px rgba(212, 175, 55, 0.6)); }
}

.logo-text {
    font-size: 2.5rem;
    font-weight: 300;
    color: var(--charcoal);
    letter-spacing: 0.1em;
    animation: textReveal 1s ease-out forwards;
    opacity: 0;
    animation-delay: 0.3s;
}

@keyframes textReveal {
    from {
        opacity: 0;
        letter-spacing: 0.3em;
    }
    to {
        opacity: 1;
        letter-spacing: 0.1em;
    }
}

.logo-text span {
    font-weight: 700;
    color: var(--primary-gold);
    text-shadow: 0 2px 10px rgba(212, 175, 55, 0.3);
}

.loading-text {
    margin-top: var(--spacing-xl);
    color: var(--dark-gold);
    font-size: 1rem;
    animation: loadingPulse 2s ease-in-out infinite;
    position: relative;
    padding-left: 20px;
}

.loading-text::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 8px;
    height: 8px;
    background: var(--primary-gold);
    border-radius: 50%;
    animation: loadingDot 1.5s ease-in-out infinite;
}

@keyframes loadingPulse {
    0%, 100% { opacity: 1; transform: translateY(0); }
    50% { opacity: 0.7; transform: translateY(-2px); }
}

@keyframes loadingDot {
    0%, 100% { transform: translateY(-50%) scale(1); opacity: 1; }
    50% { transform: translateY(-50%) scale(1.5); opacity: 0.5; }
}

/* Loading screen background particles */
.loading-screen .loading-particles {
    position: absolute;
    width: 100%;
    height: 100%;
    overflow: hidden;
    pointer-events: none;
}

.loading-screen .loading-particles span {
    position: absolute;
    width: 4px;
    height: 4px;
    background: var(--primary-gold);
    border-radius: 50%;
    animation: riseParticle 4s linear infinite;
    opacity: 0;
}

/* Mobile responsive loading screen */
@media (max-width: 480px) {
    .loading-screen {
        padding: env(safe-area-inset-top, 20px) env(safe-area-inset-right, 10px) env(safe-area-inset-bottom, 20px) env(safe-area-inset-left, 10px);
    }

    .logo-container {
        gap: var(--spacing-md);
    }

    .logo-container::before {
        width: 160px;
        height: 160px;
    }

    .logo-container::after {
        width: 140px;
        height: 140px;
    }

    .impactiq-logo {
        height: 140px;
        max-width: 200px;
    }

    .loading-text {
        font-size: 0.875rem;
        margin-top: var(--spacing-lg);
    }

    .login-logo {
        height: 110px;
        max-width: 170px;
    }
}

@media (max-width: 375px) {
    .logo-container::before {
        width: 130px;
        height: 130px;
    }

    .logo-container::after {
        width: 110px;
        height: 110px;
    }

    .impactiq-logo {
        height: 110px;
        max-width: 170px;
    }

    .loading-text {
        font-size: 0.75rem;
    }

    .login-logo {
        height: 90px;
        max-width: 140px;
    }
}

/* ===== APP CONTAINER ===== */
.app-container {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: #f9fafb;
    opacity: 0;
    transition: opacity 0.5s ease-out;
}

.app-container.fade-in {
    opacity: 1;
}

/* ===== TOP NAVIGATION ===== */
.top-nav {
    position: sticky;
    top: 0;
    background: var(--white);
    border-bottom: 1px solid var(--light-gray);
    padding: var(--spacing-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 100;
    box-shadow: var(--shadow-sm);
}

/* Hamburger Button */
.hamburger-btn {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    border: none;
    background: var(--light-gray);
    color: var(--charcoal);
    font-size: 1.25rem;
    cursor: pointer;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.hamburger-btn:hover {
    background: rgba(212, 175, 55, 0.15);
    color: var(--primary-gold);
}

.hamburger-btn:active {
    transform: scale(0.95);
    background: rgba(212, 175, 55, 0.25);
}

/* Side Menu Overlay */
.side-menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 999;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.side-menu-overlay.active {
    opacity: 1;
    visibility: visible;
}

/* Slide-out Side Menu */
.side-menu {
    position: fixed;
    top: 0;
    left: 0;
    width: 300px;
    max-width: 85vw;
    height: 100vh;
    background: #ffffff;
    z-index: 1000;
    transform: translateX(-100%);
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
    box-shadow: 4px 0 20px rgba(0, 0, 0, 0.15);
}

.side-menu.active {
    transform: translateX(0);
}

.side-menu-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-lg);
    border-bottom: 1px solid #e8e8e8;
    background: #f8f9fa;
}

.side-menu-logo {
    width: 36px;
    height: 36px;
}

.side-menu-title {
    font-size: 1.25rem;
    font-weight: 300;
    color: var(--charcoal);
    letter-spacing: 0.05em;
    flex: 1;
}

.side-menu-title strong {
    font-weight: 700;
    color: var(--primary-gold);
}

.side-menu-close {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: #ffffff;
    color: var(--charcoal);
    font-size: 1.125rem;
    cursor: pointer;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.side-menu-close:hover {
    background: rgba(220, 53, 69, 0.1);
    color: #dc3545;
}

.side-menu-nav {
    flex: 1;
    overflow-y: auto;
    padding: var(--spacing-md);
}

.side-menu-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    width: 100%;
    padding: 14px 16px;
    border: none;
    background: transparent;
    color: var(--charcoal);
    font-size: 0.95rem;
    font-weight: 500;
    text-align: left;
    cursor: pointer;
    border-radius: 12px;
    transition: all 0.2s;
    margin-bottom: 4px;
}

.side-menu-item i {
    width: 24px;
    font-size: 1.125rem;
    color: #888888;
    text-align: center;
    transition: color 0.2s;
}

.side-menu-item:hover {
    background: rgba(212, 175, 55, 0.1);
}

.side-menu-item:hover i {
    color: var(--primary-gold);
}

.side-menu-item:active {
    background: rgba(212, 175, 55, 0.2);
    transform: scale(0.98);
}

.side-menu-item.ai-item {
    background: linear-gradient(135deg, rgba(138, 43, 226, 0.08), rgba(0, 200, 255, 0.08));
    border: 1px solid rgba(138, 43, 226, 0.15);
}

.side-menu-item.ai-item i {
    color: #8a2be2;
}

.side-menu-item.ai-item:hover {
    background: linear-gradient(135deg, rgba(138, 43, 226, 0.15), rgba(0, 200, 255, 0.15));
}

.side-menu-divider {
    height: 1px;
    background: #e8e8e8;
    margin: var(--spacing-md) 0;
}

.nav-logo {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    cursor: pointer;
    padding: 8px 12px;
    border-radius: 10px;
    transition: all 0.2s ease;
}

.nav-logo:hover {
    background: rgba(212, 175, 55, 0.1);
    transform: scale(1.02);
}

.nav-logo:active {
    transform: scale(0.98);
}

.mini-logo {
    width: 32px;
    height: 32px;
}

.nav-logo span {
    font-size: 1.25rem;
    font-weight: 300;
    color: var(--charcoal);
    letter-spacing: 0.05em;
}

.nav-logo strong {
    font-weight: 700;
    color: var(--primary-gold);
}

.nav-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.notification-btn,
.user-menu-btn,
.user-avatar-btn {
    position: relative;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: none;
    background: var(--light-gray);
    color: var(--charcoal);
    font-size: 1.25rem;
    cursor: pointer;
    transition: all 0.2s;
}

.notification-btn:active,
.user-menu-btn:active,
.user-avatar-btn:active {
    transform: scale(0.95);
    background: var(--gray);
}

/* User Info Section */
.user-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    position: relative;
}

.user-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--charcoal);
    max-width: 100px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-avatar-btn {
    background: linear-gradient(135deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    color: var(--white);
}

.user-avatar-btn:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(212, 175, 55, 0.3);
}

/* User Menu Dropdown */
.user-menu {
    position: absolute;
    top: 50px;
    right: 0;
    width: 220px;
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    padding: var(--spacing-md);
    z-index: 200;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.user-menu.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.user-menu .menu-header {
    text-align: center;
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--light-gray);
    margin-bottom: var(--spacing-md);
}

.user-menu .menu-header strong {
    display: block;
    font-size: 1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.user-menu .menu-header small {
    font-size: 0.75rem;
    color: var(--gray);
}

.user-menu hr {
    display: none;
}

.user-menu button {
    display: block;
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: none;
    background: transparent;
    color: var(--charcoal);
    font-size: 0.875rem;
    text-align: left;
    cursor: pointer;
    border-radius: var(--radius-md);
    transition: all 0.2s;
}

.user-menu button:hover {
    background: var(--light-gray);
    color: var(--primary-gold);
}

.user-menu button:last-child {
    color: var(--danger);
    margin-top: var(--spacing-sm);
}

.user-menu button:last-child:hover {
    background: rgba(239, 68, 68, 0.1);
    color: var(--danger);
}

.badge {
    position: absolute;
    top: -4px;
    right: -4px;
    background: var(--danger);
    color: var(--white);
    font-size: 0.65rem;
    font-weight: 700;
    padding: 0.125rem 0.375rem;
    border-radius: 1rem;
}

/* ===== MAIN CONTENT ===== */
.main-content {
    flex: 1;
    padding: var(--spacing-md);
    padding-bottom: 100px; /* Extra padding to prevent bottom nav from cutting off content */
    overflow-y: auto;
}

.view {
    display: none;
    animation: slideIn 0.3s ease-out;
}

.view.active {
    display: block;
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateX(20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.view-header {
    margin-bottom: var(--spacing-lg);
}

.view-header h1 {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.subtitle {
    color: var(--gray);
    font-size: 0.875rem;
}

.back-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: none;
    background: var(--light-gray);
    color: var(--charcoal);
    font-size: 1.25rem;
    cursor: pointer;
    margin-bottom: var(--spacing-md);
    transition: all 0.2s;
}

.back-btn:active {
    transform: scale(0.95);
    background: var(--gray);
}

/* ===== KPI CARDS ===== */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.kpi-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-md);
    display: flex;
    gap: var(--spacing-md);
}

.kpi-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    flex-shrink: 0;
}

.kpi-icon.storm {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
    color: var(--white);
}

.kpi-icon.inspection {
    background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%);
    color: var(--white);
}

.kpi-icon.claim {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: var(--white);
}

.kpi-icon.revenue {
    background: linear-gradient(135deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    color: var(--white);
}

.kpi-content {
    flex: 1;
}

.kpi-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--charcoal);
    line-height: 1;
}

.kpi-label {
    font-size: 0.75rem;
    color: var(--gray);
    margin: var(--spacing-xs) 0;
}

.kpi-change {
    font-size: 0.7rem;
    font-weight: 600;
}

.kpi-change.positive {
    color: var(--success);
}

.kpi-change.negative {
    color: var(--danger);
}

.kpi-change.neutral {
    color: var(--gray);
}

/* ===== STORM ALERT BANNER ===== */
.storm-alert {
    background: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
    border-left: 4px solid var(--danger);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    display: flex;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    box-shadow: var(--shadow-md);
}

.alert-icon {
    font-size: 1.5rem;
    color: var(--danger);
    flex-shrink: 0;
}

.alert-content {
    flex: 1;
    font-size: 0.875rem;
}

.alert-content strong {
    color: var(--charcoal);
    font-weight: 700;
}

.alert-content small {
    color: var(--gray);
}

.alert-action {
    background: var(--danger);
    color: var(--white);
    border: none;
    border-radius: var(--radius-md);
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
}

/* ===== QUICK ACTIONS ===== */
.quick-actions {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-md);
    margin-bottom: var(--spacing-lg);
}

.quick-actions h2,
.recent-activity h2 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--light-gray);
    text-align: center;
}

.action-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
    justify-items: center;
}

.action-btn {
    background: #ffffff;
    border: 1px solid #e8e8e8;
    border-radius: 16px;
    padding: var(--spacing-md);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    cursor: pointer;
    transition: all 0.25s ease;
    min-height: 90px;
    width: 100%;
    max-width: 160px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.action-btn:hover {
    background: #fefefe;
    border-color: var(--primary-gold);
    box-shadow: 0 6px 20px rgba(212, 175, 55, 0.18);
    transform: translateY(-3px);
}

.action-btn:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
    background: rgba(212, 175, 55, 0.08);
}

.action-btn i {
    font-size: 1.5rem;
    color: var(--primary-gold);
}

.action-btn span {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--charcoal);
    text-align: center;
    line-height: 1.2;
    word-wrap: break-word;
    max-width: 100%;
}

/* Small tablets - 3 column grid */
@media (min-width: 540px) {
    .action-grid {
        grid-template-columns: repeat(3, 1fr);
        max-width: 540px;
        gap: var(--spacing-md);
    }

    .action-btn {
        max-width: 150px;
    }
}

/* Tablet and larger - 4 column grid */
@media (min-width: 768px) {
    .quick-actions {
        padding: var(--spacing-xl);
    }

    .action-grid {
        grid-template-columns: repeat(4, 1fr);
        max-width: 720px;
        gap: var(--spacing-lg);
    }

    .action-btn {
        min-height: 110px;
        padding: var(--spacing-lg);
        max-width: 160px;
        border-radius: 20px;
    }

    .action-btn i {
        font-size: 1.75rem;
    }

    .action-btn span {
        font-size: 0.8rem;
    }
}

/* Desktop - wider layout */
@media (min-width: 1024px) {
    .action-grid {
        max-width: 900px;
        gap: var(--spacing-xl);
    }

    .action-btn {
        min-height: 120px;
        max-width: 200px;
    }

    .action-btn i {
        font-size: 2rem;
    }

    .action-btn span {
        font-size: 0.85rem;
    }
}

/* Large desktop */
@media (min-width: 1200px) {
    .action-grid {
        max-width: 1000px;
    }

    .action-btn {
        max-width: 220px;
        min-height: 130px;
    }
}

/* ===== RECENT ACTIVITY ===== */
.activity-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.activity-item {
    background: var(--white);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    display: flex;
    gap: var(--spacing-md);
    box-shadow: var(--shadow-sm);
}

.activity-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-center;
    font-size: 1.25rem;
    flex-shrink: 0;
}

.activity-icon.inspection-complete {
    background: #d1fae5;
    color: var(--success);
}

.activity-icon.claim-approved {
    background: #dbeafe;
    color: var(--info);
}

.activity-icon.lead-assigned {
    background: #fef3c7;
    color: var(--warning);
}

.activity-content {
    flex: 1;
}

.activity-content strong {
    color: var(--charcoal);
    font-size: 0.875rem;
    font-weight: 600;
}

.activity-content p {
    color: var(--gray);
    font-size: 0.8rem;
    margin: var(--spacing-xs) 0;
}

.activity-content small {
    color: var(--gray);
    font-size: 0.7rem;
}

/* ===== LEADS VIEW ===== */
.filter-bar {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    display: flex;
    gap: var(--spacing-sm);
    box-shadow: var(--shadow-sm);
    flex-wrap: wrap;
}

.filter-group {
    flex: 1;
    min-width: 120px;
}

.filter-group label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--gray);
    margin-bottom: var(--spacing-xs);
}

.filter-select,
.form-input {
    width: 100%;
    padding: var(--spacing-sm);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    font-size: 0.875rem;
    background: var(--white);
    color: var(--charcoal);
}

.filter-btn {
    background: var(--primary-gold);
    color: var(--white);
    border: none;
    border-radius: var(--radius-md);
    padding: 0 var(--spacing-lg);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
}

/* ===== LEAD CARDS ===== */
.leads-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.lead-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-md);
}

.lead-card.hot {
    border-left: 4px solid var(--danger);
}

.lead-card.warm {
    border-left: 4px solid var(--warning);
}

.lead-card.cold {
    border-left: 4px solid var(--info);
}

.lead-priority {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
}

.priority-badge {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--white);
}

.priority-badge.hot {
    background: linear-gradient(135deg, var(--danger) 0%, #dc2626 100%);
}

.priority-badge.warm {
    background: linear-gradient(135deg, var(--warning) 0%, #ea580c 100%);
}

.priority-badge.cold {
    background: linear-gradient(135deg, var(--info) 0%, #2563eb 100%);
}

.lead-priority span {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--gray);
}

.lead-details h3 {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.lead-owner {
    color: var(--gray);
    font-size: 0.875rem;
    margin-bottom: var(--spacing-sm);
}

.lead-meta {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-sm);
}

.lead-meta span {
    font-size: 0.8rem;
    color: var(--gray);
}

.lead-meta i {
    width: 16px;
    color: var(--primary-gold);
    margin-right: var(--spacing-xs);
}

.lead-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
}

.tag {
    background: var(--light-gray);
    color: var(--charcoal);
    font-size: 0.7rem;
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius-sm);
    font-weight: 600;
}

.lead-actions {
    display: flex;
    gap: var(--spacing-sm);
}

.btn-primary,
.btn-secondary {
    flex: 1;
    padding: var(--spacing-sm) var(--spacing-md);
    border: none;
    border-radius: var(--radius-md);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
}

.btn-primary {
    background: var(--primary-gold);
    color: var(--white);
}

.btn-secondary {
    background: var(--light-gray);
    color: var(--charcoal);
}

/* ===== FORM STYLES ===== */
.report-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

.form-section {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-sm);
}

.form-section h2 {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: var(--spacing-md);
}

.section-note {
    color: var(--gray);
    font-size: 0.875rem;
    margin-bottom: var(--spacing-md);
}

.form-group {
    margin-bottom: var(--spacing-md);
}

.form-group label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.form-input {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    font-size: 1rem;
    background: var(--white);
    color: var(--charcoal);
}

.form-input:focus {
    outline: none;
    border-color: var(--primary-gold);
}

/* ===== PHOTO UPLOAD ===== */
.photo-upload-grid {
    display: grid;
    gap: var(--spacing-md);
}

.photo-upload-card {
    background: #f9fafb;
    border: 2px dashed var(--light-gray);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    text-align: center;
}

.upload-icon {
    width: 48px;
    height: 48px;
    margin: 0 auto var(--spacing-sm);
    background: var(--primary-gold);
    color: var(--white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
}

.photo-upload-card h3 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: var(--spacing-sm);
}

.upload-area {
    background: var(--white);
    border: 2px dashed var(--light-gray);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    cursor: pointer;
    transition: all 0.2s;
}

.upload-area:hover {
    border-color: var(--primary-gold);
    background: #fffbf0;
}

.upload-area i {
    font-size: 2rem;
    color: var(--gray);
    display: block;
    margin-bottom: var(--spacing-sm);
}

.upload-area p {
    color: var(--gray);
    font-size: 0.875rem;
    font-weight: 600;
}

.image-preview {
    margin-top: var(--spacing-sm);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.image-preview img {
    width: 100%;
    height: auto;
    display: block;
}

.btn-submit {
    width: 100%;
    background: linear-gradient(135deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    color: var(--white);
    border: none;
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    box-shadow: var(--shadow-lg);
}

/* ===== TEAM MANAGEMENT ===== */
.team-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.sort-controls {
    display: flex;
    gap: var(--spacing-sm);
    flex: 1;
}

.sort-order-btn {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-md);
    border: 1px solid var(--light-gray);
    background: var(--white);
    color: var(--charcoal);
    font-size: 1.125rem;
    cursor: pointer;
}

.team-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.team-member-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    display: flex;
    gap: var(--spacing-md);
    box-shadow: var(--shadow-md);
}

.member-avatar {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--light-gray);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: var(--gray);
    flex-shrink: 0;
}

.member-info {
    flex: 1;
}

.member-info h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.member-info p {
    font-size: 0.8rem;
    color: var(--gray);
    margin-bottom: var(--spacing-sm);
}

.member-stats {
    display: flex;
    gap: var(--spacing-md);
    font-size: 0.75rem;
    color: var(--gray);
}

.member-stats strong {
    color: var(--primary-gold);
    font-weight: 700;
}

.member-actions {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.btn-icon {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-md);
    border: 1px solid var(--light-gray);
    background: var(--white);
    color: var(--charcoal);
    font-size: 1rem;
    cursor: pointer;
}

.empty-state {
    text-align: center;
    padding: var(--spacing-xl);
}

.empty-state i {
    font-size: 4rem;
    color: var(--gray);
    margin-bottom: var(--spacing-md);
}

.empty-state h2 {
    font-size: 1.25rem;
    color: var(--gray);
    margin-bottom: var(--spacing-lg);
}

/* ===== ANALYTICS ===== */
.metrics-summary {
    display: grid;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.metric-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-md);
}

.metric-card h3 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--gray);
    margin-bottom: var(--spacing-sm);
}

.metric-value {
    font-size: 2rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.metric-trend {
    font-size: 0.8rem;
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
}

.metric-bar {
    width: 100%;
    height: 8px;
    background: var(--light-gray);
    border-radius: 4px;
    overflow: hidden;
}

.bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    transition: width 0.5s ease;
}

.bar-fill.warning {
    background: linear-gradient(90deg, var(--warning) 0%, #ea580c 100%);
}

.funnel-section,
.cycle-times,
.revenue-section {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    box-shadow: var(--shadow-md);
}

.funnel-section h2,
.cycle-times h2,
.revenue-section h2 {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: var(--spacing-md);
}

.funnel-chart {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.funnel-stage {
    background: linear-gradient(90deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    color: var(--white);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.875rem;
    font-weight: 600;
    transition: width 0.5s ease;
}

.time-metrics {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.time-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: #f9fafb;
    border-radius: var(--radius-md);
}

.time-card i {
    font-size: 1.5rem;
    color: var(--primary-gold);
}

.time-card div:nth-child(2) {
    flex: 1;
}

.time-card strong {
    display: block;
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--charcoal);
}

.time-card span {
    font-size: 0.8rem;
    color: var(--gray);
}

.sla-badge {
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius-sm);
    font-size: 0.75rem;
    font-weight: 700;
}

.sla-badge.success {
    background: #d1fae5;
    color: var(--success);
}

.revenue-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

.revenue-card {
    text-align: center;
    padding: var(--spacing-md);
    background: #f9fafb;
    border-radius: var(--radius-lg);
}

.revenue-icon {
    font-size: 2rem;
    margin-bottom: var(--spacing-sm);
}

.revenue-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.revenue-label {
    font-size: 0.75rem;
    color: var(--gray);
    font-weight: 600;
}

/* ===== BOTTOM NAVIGATION ===== */
.bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: #ffffff;
    border-top: 1px solid #e8e8e8;
    padding: var(--spacing-sm) var(--spacing-md);
    padding-bottom: calc(var(--spacing-sm) + env(safe-area-inset-bottom, 0px));
    display: flex;
    justify-content: space-around;
    align-items: center;
    gap: 0;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.06);
    z-index: 100;
    width: 100%;
}

.nav-btn {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    padding: var(--spacing-sm) var(--spacing-xs);
    min-height: 56px;
    border: none;
    background: #ffffff;
    color: #888888;
    cursor: pointer;
    transition: all 0.2s ease;
    border-radius: 12px;
    margin: 0 4px;
}

.nav-btn:hover {
    background: #f5f5f5;
    color: #666666;
}

.nav-btn:active {
    background: rgba(212, 175, 55, 0.15);
    color: var(--primary-gold);
}

.nav-btn i {
    font-size: 1.5rem;
}

.nav-btn span {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

/* Active state - Yellow/Gold highlight */
.nav-btn.active {
    background: rgba(212, 175, 55, 0.15);
    color: var(--primary-gold);
    border: 2px solid rgba(212, 175, 55, 0.3);
}

.nav-btn.active i {
    color: var(--primary-gold);
}

.nav-btn.active span {
    color: var(--primary-gold);
    font-weight: 700;
}

/* Report Button - Same style as others, better touch target */
.nav-btn.report-btn {
    background: #ffffff;
    color: #888888;
    box-shadow: none;
    min-width: 70px;
    min-height: 60px;
    padding: var(--spacing-sm) var(--spacing-md);
    /* Ensure entire button is clickable */
    position: relative;
    z-index: 1;
}

.nav-btn.report-btn:hover {
    background: #f5f5f5;
    color: #666666;
}

.nav-btn.report-btn:active {
    background: rgba(212, 175, 55, 0.2);
    color: var(--primary-gold);
    transform: scale(0.98);
}

.nav-btn.report-btn.active {
    background: rgba(212, 175, 55, 0.15);
    color: var(--primary-gold);
    border: 2px solid rgba(212, 175, 55, 0.3);
}

.nav-btn.report-btn i {
    font-size: 1.75rem;
    pointer-events: none; /* Prevent icon from blocking clicks */
}

.nav-btn.report-btn span {
    font-size: 0.75rem;
    font-weight: 700;
    pointer-events: none; /* Prevent text from blocking clicks */
}

/* ===== TOAST NOTIFICATION ===== */
.toast {
    position: fixed;
    bottom: 100px;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: var(--charcoal);
    color: var(--white);
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    font-size: 0.875rem;
    font-weight: 600;
    z-index: 1000;
    opacity: 0;
    transition: all 0.3s ease;
}

.toast.show {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* ===== RESPONSIVE DESIGN ===== */
@media (min-width: 640px) {
    .kpi-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    /* action-grid responsive handled in Quick Actions section */

    .photo-upload-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .revenue-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (min-width: 768px) {
    .app-container {
        /* Full width on desktop */
        max-width: 100%;
        width: 100%;
    }

    .main-content {
        padding: var(--spacing-xl) var(--spacing-xl);
        max-width: 100%;
        width: 100%;
    }

    .view {
        max-width: 100%;
    }

    .kpi-grid {
        gap: var(--spacing-lg);
    }

    .lead-card {
        flex-direction: row;
        align-items: center;
    }

    .lead-card .lead-info {
        flex: 1;
    }

    .lead-card .lead-actions {
        flex-direction: row;
        gap: var(--spacing-sm);
    }

    /* Leads list as a grid on desktop */
    .leads-list {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-lg);
    }
}

@media (min-width: 1024px) {
    .main-content {
        padding: var(--spacing-xl) calc(var(--spacing-xl) * 2);
    }

    .leads-list {
        grid-template-columns: repeat(2, 1fr);
    }

    .team-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1440px) {
    .main-content {
        padding: var(--spacing-xl) calc(var(--spacing-xl) * 3);
    }

    .leads-list {
        grid-template-columns: repeat(3, 1fr);
    }

    .kpi-grid {
        gap: var(--spacing-xl);
    }
}

@media (min-width: 1920px) {
    .leads-list {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* ===== LOGIN SCREEN STYLES ===== */
.login-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 50%, #f0f2f5 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9998;
    overflow-y: auto;
    overflow-x: hidden;
    opacity: 0;
    transform: scale(0.95);
    transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1),
                transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    padding: env(safe-area-inset-top, 20px) env(safe-area-inset-right, 0) env(safe-area-inset-bottom, 20px) env(safe-area-inset-left, 0);
}

.login-screen.visible {
    opacity: 1;
    transform: scale(1);
}

.login-container {
    width: 100%;
    max-width: 420px;
    padding: var(--spacing-xl);
    position: relative;
    z-index: 2;
    opacity: 0;
    transform: translateY(40px) scale(0.95);
}

.login-screen.visible .login-container {
    animation: loginSlideUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.2s forwards;
}

@keyframes loginSlideUp {
    from {
        opacity: 0;
        transform: translateY(40px) scale(0.95);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.login-header {
    text-align: center;
    margin-bottom: var(--spacing-xl);
}

/* Staggered animations for login elements */
.login-screen.visible .login-header {
    animation: fadeSlideIn 0.6s ease-out 0.3s forwards;
    opacity: 0;
}

.login-screen.visible .login-form {
    animation: fadeSlideIn 0.6s ease-out 0.4s forwards;
    opacity: 0;
}

.login-screen.visible .login-footer {
    animation: fadeSlideIn 0.6s ease-out 0.5s forwards;
    opacity: 0;
}

@keyframes fadeSlideIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.login-logo {
    width: auto;
    height: 140px;
    max-width: 220px;
    object-fit: contain;
    margin-bottom: var(--spacing-md);
    animation: logoFloat 3s ease-in-out infinite, logoShine 2s ease-in-out infinite;
}

@keyframes logoFloat {
    0%, 100% {
        transform: translateY(0) rotate(0deg);
    }
    50% {
        transform: translateY(-10px) rotate(2deg);
    }
}

@keyframes logoShine {
    0%, 100% {
        filter: drop-shadow(0 0 15px rgba(212, 175, 55, 0.3));
    }
    50% {
        filter: drop-shadow(0 0 30px rgba(212, 175, 55, 0.5));
    }
}

.login-title {
    font-size: 2rem;
    font-weight: 700;
    color: var(--charcoal);
    letter-spacing: 2px;
    position: relative;
    display: inline-block;
}

.login-title span {
    color: var(--primary-gold);
    text-shadow: 0 2px 15px rgba(212, 175, 55, 0.3);
    position: relative;
}

.login-title span::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--primary-gold), transparent);
    animation: titleUnderline 2s ease-in-out infinite;
}

@keyframes titleUnderline {
    0%, 100% { opacity: 0.3; transform: scaleX(0.5); }
    50% { opacity: 1; transform: scaleX(1); }
}

.login-subtitle {
    color: var(--gray);
    font-size: 0.875rem;
    margin-top: var(--spacing-sm);
    letter-spacing: 1px;
    animation: subtitleFade 1s ease-out 0.6s forwards;
    opacity: 0;
}

.login-screen.visible .login-subtitle {
    animation: subtitleFade 1s ease-out 0.6s forwards;
}

@keyframes subtitleFade {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Login Form */
.login-form {
    background: var(--white);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(212, 175, 55, 0.25);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
    position: relative;
    overflow: hidden;
    animation: formGlow 4s ease-in-out infinite;
}

/* Animated border glow */
.login-form::before {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    background: linear-gradient(45deg,
        transparent 30%,
        rgba(212, 175, 55, 0.4) 50%,
        transparent 70%);
    border-radius: var(--radius-xl);
    z-index: -1;
    animation: borderRotate 6s linear infinite;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.login-form:hover::before {
    opacity: 1;
}

@keyframes borderRotate {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes formGlow {
    0%, 100% {
        box-shadow: 0 4px 20px rgba(212, 175, 55, 0.1),
                    0 10px 40px rgba(0, 0, 0, 0.08);
    }
    50% {
        box-shadow: 0 8px 30px rgba(212, 175, 55, 0.15),
                    0 15px 50px rgba(0, 0, 0, 0.1);
    }
}

.login-form .form-group {
    margin-bottom: var(--spacing-lg);
}

.login-form label {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--light-gray);
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: var(--spacing-sm);
}

.login-form label i {
    color: var(--primary-gold);
}

.login-form input[type="email"],
.login-form input[type="password"],
.login-form input[type="text"] {
    width: 100%;
    padding: var(--spacing-md);
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-md);
    color: var(--white);
    font-size: 1rem;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
}

.login-form input::placeholder {
    color: var(--gray);
    transition: all 0.3s ease;
}

.login-form input:hover {
    border-color: rgba(212, 175, 55, 0.3);
    background: rgba(0, 0, 0, 0.5);
}

.login-form input:focus {
    outline: none;
    border-color: var(--primary-gold);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.15),
                0 0 20px rgba(212, 175, 55, 0.1),
                inset 0 0 20px rgba(212, 175, 55, 0.03);
    background: rgba(0, 0, 0, 0.6);
    transform: translateY(-2px);
}

.login-form input:focus::placeholder {
    color: transparent;
}

.password-input-wrapper {
    position: relative;
}

.toggle-password {
    position: absolute;
    right: var(--spacing-md);
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: var(--gray);
    cursor: pointer;
    padding: var(--spacing-xs);
    transition: color 0.2s;
}

.toggle-password:hover {
    color: var(--primary-gold);
}

/* Form Options */
.form-options {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}

.remember-me {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--gray);
    font-size: 0.875rem;
    cursor: pointer;
}

.remember-me input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--primary-gold);
}

.forgot-password {
    color: var(--primary-gold);
    font-size: 0.875rem;
    text-decoration: none;
    transition: all 0.2s;
}

.forgot-password:hover {
    color: var(--light-gold);
    text-decoration: underline;
}

/* Login Button */
.login-btn {
    width: 100%;
    padding: var(--spacing-md) var(--spacing-lg);
    background: linear-gradient(135deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    border: none;
    border-radius: var(--radius-md);
    color: var(--black);
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.login-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
    transition: 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.login-btn::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent 40%, rgba(255, 255, 255, 0.2) 50%, transparent 60%);
    animation: buttonShimmer 3s ease-in-out infinite;
    opacity: 0;
}

@keyframes buttonShimmer {
    0% { transform: translateX(-100%) rotate(45deg); opacity: 0; }
    50% { opacity: 1; }
    100% { transform: translateX(100%) rotate(45deg); opacity: 0; }
}

.login-btn:hover::before {
    left: 100%;
}

.login-btn:hover::after {
    opacity: 1;
}

.login-btn:hover {
    transform: translateY(-3px) scale(1.02);
    box-shadow: 0 10px 30px rgba(212, 175, 55, 0.5),
                0 0 60px rgba(212, 175, 55, 0.2);
    background: linear-gradient(135deg, #e6c04a 0%, var(--primary-gold) 100%);
}

.login-btn:active {
    transform: translateY(-1px) scale(0.98);
    box-shadow: 0 5px 15px rgba(212, 175, 55, 0.4);
}

.login-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.login-btn:disabled::before,
.login-btn:disabled::after {
    display: none;
}

.btn-loader {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
}

/* Login Error */
.login-error {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    background: rgba(239, 68, 68, 0.15);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    margin-top: var(--spacing-md);
    color: #ef4444;
    font-size: 0.875rem;
    animation: shakeError 0.4s ease-in-out;
}

@keyframes shakeError {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    75% { transform: translateX(5px); }
}

/* Google Login Divider */
.login-divider-or {
    display: flex;
    align-items: center;
    margin: var(--spacing-lg) 0;
}

.login-divider-or::before,
.login-divider-or::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(255, 255, 255, 0.2);
}

.login-divider-or span {
    padding: 0 var(--spacing-md);
    color: var(--light-gray);
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

/* Google Login Button */
.google-login-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--white);
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: var(--radius-md);
    color: var(--charcoal);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
}

.google-login-btn:hover {
    background: #f8f8f8;
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.2);
}

.google-login-btn:active {
    transform: translateY(0);
}

.google-icon {
    flex-shrink: 0;
}

/* Login Footer */
.login-footer {
    text-align: center;
    margin-top: var(--spacing-xl);
}

.demo-credentials {
    background: rgba(212, 175, 55, 0.1);
    border: 1px solid rgba(212, 175, 55, 0.2);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    color: var(--charcoal);
    font-size: 0.8rem;
    line-height: 1.6;
}

.demo-credentials strong {
    color: var(--black);
}

.login-divider {
    display: flex;
    align-items: center;
    margin: var(--spacing-lg) 0;
}

.login-divider::before,
.login-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(255, 255, 255, 0.1);
}

.login-divider span {
    padding: 0 var(--spacing-md);
    color: var(--gray);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.login-branding {
    color: var(--gray);
    font-size: 0.875rem;
    font-weight: 600;
}

/* Login Background Animations */
.login-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    pointer-events: none;
}

/* Animated gradient overlay */
.login-background::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 20% 50%, rgba(212, 175, 55, 0.08) 0%, transparent 50%),
                radial-gradient(ellipse at 80% 20%, rgba(212, 175, 55, 0.06) 0%, transparent 40%),
                radial-gradient(ellipse at 50% 80%, rgba(212, 175, 55, 0.05) 0%, transparent 45%);
    animation: gradientShift 10s ease-in-out infinite;
}

@keyframes gradientShift {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.8; transform: scale(1.1); }
}

.bg-shape {
    position: absolute;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.08) 0%, rgba(212, 175, 55, 0.02) 100%);
    backdrop-filter: blur(1px);
}

.bg-shape-1 {
    width: 500px;
    height: 500px;
    top: -250px;
    right: -150px;
    animation: floatShape1 25s ease-in-out infinite;
}

.bg-shape-2 {
    width: 400px;
    height: 400px;
    bottom: -200px;
    left: -150px;
    animation: floatShape2 30s ease-in-out infinite;
}

.bg-shape-3 {
    width: 250px;
    height: 250px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    animation: pulseShape 20s ease-in-out infinite;
    border: 1px solid rgba(212, 175, 55, 0.1);
}

@keyframes floatShape1 {
    0%, 100% {
        transform: translate(0, 0) rotate(0deg) scale(1);
    }
    33% {
        transform: translate(40px, 50px) rotate(120deg) scale(1.1);
    }
    66% {
        transform: translate(-30px, 30px) rotate(240deg) scale(0.95);
    }
}

@keyframes floatShape2 {
    0%, 100% {
        transform: translate(0, 0) rotate(0deg);
    }
    25% {
        transform: translate(50px, -30px) rotate(90deg);
    }
    50% {
        transform: translate(30px, 40px) rotate(180deg);
    }
    75% {
        transform: translate(-40px, 20px) rotate(270deg);
    }
}

@keyframes pulseShape {
    0%, 100% {
        transform: translate(-50%, -50%) scale(1) rotate(0deg);
        opacity: 0.4;
    }
    25% {
        transform: translate(-50%, -50%) scale(1.15) rotate(90deg);
        opacity: 0.2;
    }
    50% {
        transform: translate(-50%, -50%) scale(1.3) rotate(180deg);
        opacity: 0.3;
    }
    75% {
        transform: translate(-50%, -50%) scale(1.1) rotate(270deg);
        opacity: 0.25;
    }
}

/* Floating Particles - Enhanced */
.floating-particle {
    position: absolute;
    width: 4px;
    height: 4px;
    background: var(--primary-gold);
    border-radius: 50%;
    opacity: 0;
    box-shadow: 0 0 10px rgba(212, 175, 55, 0.5),
                0 0 20px rgba(212, 175, 55, 0.3);
    animation: floatParticle 12s ease-in-out infinite;
}

/* Create trail effect */
.floating-particle::after {
    content: '';
    position: absolute;
    width: 2px;
    height: 30px;
    background: linear-gradient(to bottom, rgba(212, 175, 55, 0.4), transparent);
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 2px;
}

.particle-1 { left: 10%; top: 100%; animation-delay: 0s; animation-duration: 10s; width: 5px; height: 5px; }
.particle-2 { left: 25%; top: 100%; animation-delay: 1.5s; animation-duration: 12s; width: 3px; height: 3px; }
.particle-3 { left: 40%; top: 100%; animation-delay: 3s; animation-duration: 9s; width: 6px; height: 6px; }
.particle-4 { left: 60%; top: 100%; animation-delay: 4.5s; animation-duration: 11s; width: 4px; height: 4px; }
.particle-5 { left: 75%; top: 100%; animation-delay: 2s; animation-duration: 13s; width: 5px; height: 5px; }
.particle-6 { left: 90%; top: 100%; animation-delay: 5s; animation-duration: 10s; width: 3px; height: 3px; }

@keyframes floatParticle {
    0% {
        transform: translateY(0) translateX(0) scale(0);
        opacity: 0;
    }
    5% {
        opacity: 0.8;
        transform: translateY(-5vh) translateX(0) scale(1);
    }
    50% {
        opacity: 0.6;
        transform: translateY(-50vh) translateX(20px) scale(0.8);
    }
    95% {
        opacity: 0.4;
        transform: translateY(-95vh) translateX(-10px) scale(0.5);
    }
    100% {
        transform: translateY(-100vh) translateX(15px) scale(0);
        opacity: 0;
    }
}

/* ===== ENHANCED ANIMATIONS ===== */

/* Smooth Card Hover */
.kpi-card {
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.kpi-card:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
}

/* Staggered Animation for Cards */
.kpi-grid .kpi-card:nth-child(1) { animation: cardSlideIn 0.5s ease-out 0.1s both; }
.kpi-grid .kpi-card:nth-child(2) { animation: cardSlideIn 0.5s ease-out 0.2s both; }
.kpi-grid .kpi-card:nth-child(3) { animation: cardSlideIn 0.5s ease-out 0.3s both; }
.kpi-grid .kpi-card:nth-child(4) { animation: cardSlideIn 0.5s ease-out 0.4s both; }

@keyframes cardSlideIn {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Button Press Effect */
.action-btn {
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.action-btn:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 24px rgba(212, 175, 55, 0.25);
}

.action-btn:active {
    transform: translateY(-2px) scale(0.98);
}

/* Activity Item Slide In */
.activity-item {
    animation: slideInRight 0.4s ease-out both;
}

.activity-list .activity-item:nth-child(1) { animation-delay: 0.1s; }
.activity-list .activity-item:nth-child(2) { animation-delay: 0.2s; }
.activity-list .activity-item:nth-child(3) { animation-delay: 0.3s; }

@keyframes slideInRight {
    from {
        opacity: 0;
        transform: translateX(20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Lead Card Animation */
.lead-card {
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.lead-card:hover {
    transform: scale(1.02);
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.12);
}

/* Priority Badge Pulse */
.priority-badge.hot {
    animation: hotPulse 2s ease-in-out infinite;
}

@keyframes hotPulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.4);
    }
    50% {
        box-shadow: 0 0 0 8px rgba(239, 68, 68, 0);
    }
}

/* Team Card Hover */
.team-card {
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.team-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.12);
}

/* Navigation Tab Transition */
.nav-btn {
    transition: all 0.3s ease;
    position: relative;
}

.nav-btn::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 0;
    height: 2px;
    background: var(--primary-gold);
    transition: all 0.3s ease;
    transform: translateX(-50%);
}

.nav-btn.active::after {
    width: 100%;
}

/* Storm Alert Glow */
.storm-alert {
    animation: alertGlow 2s ease-in-out infinite;
}

@keyframes alertGlow {
    0%, 100% {
        box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    }
    50% {
        box-shadow: 0 4px 20px rgba(245, 158, 11, 0.3);
    }
}

/* Notification Badge Bounce */
.notification-btn .badge {
    animation: badgeBounce 2s ease-in-out infinite;
}

@keyframes badgeBounce {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.1);
    }
}

/* View Transition */
.view {
    animation: viewFadeIn 0.4s ease-out;
}

@keyframes viewFadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

/* Funnel Animation */
.funnel-level {
    transition: all 0.3s ease;
}

.funnel-level:hover {
    transform: scaleX(1.02);
}

/* Chart Bar Animation */
.chart-bar {
    animation: barGrow 0.8s ease-out both;
}

@keyframes barGrow {
    from {
        transform: scaleY(0);
        transform-origin: bottom;
    }
    to {
        transform: scaleY(1);
        transform-origin: bottom;
    }
}

/* Loading Skeleton Animation */
.skeleton {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: skeletonShimmer 1.5s infinite;
}

@keyframes skeletonShimmer {
    0% {
        background-position: 200% 0;
    }
    100% {
        background-position: -200% 0;
    }
}

/* Success Checkmark Animation */
@keyframes checkmarkDraw {
    0% {
        stroke-dashoffset: 100;
    }
    100% {
        stroke-dashoffset: 0;
    }
}

/* Ripple Effect for Buttons */
.ripple {
    position: relative;
    overflow: hidden;
}

.ripple::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.3) 10%, transparent 10.01%);
    transform: scale(10);
    opacity: 0;
    transition: transform 0.5s, opacity 0.3s;
}

.ripple:active::after {
    transform: scale(0);
    opacity: 1;
    transition: 0s;
}

/* Responsive Login */
@media (max-width: 480px) {
    .login-screen {
        align-items: flex-start;
        padding-top: max(env(safe-area-inset-top, 20px), 30px);
        padding-bottom: max(env(safe-area-inset-bottom, 20px), 30px);
    }

    .login-container {
        padding: var(--spacing-md);
        margin-top: 0;
        margin-bottom: auto;
    }

    .login-header {
        margin-bottom: var(--spacing-lg);
    }

    .login-title {
        font-size: 1.5rem;
    }

    .login-subtitle {
        font-size: 0.75rem;
    }

    .login-form {
        padding: var(--spacing-md);
    }

    .form-group {
        margin-bottom: var(--spacing-sm);
    }

    .form-group label {
        font-size: 0.75rem;
        margin-bottom: var(--spacing-xs);
    }

    .login-form input {
        padding: 0.75rem;
        font-size: 0.875rem;
    }

    .login-btn,
    .google-login-btn {
        padding: 0.75rem;
        font-size: 0.875rem;
    }

    .login-footer {
        padding-top: var(--spacing-md);
    }

    .demo-credentials {
        font-size: 0.7rem;
        padding: var(--spacing-sm);
    }

    .user-name {
        display: none;
    }
}

/* Extra small screens (iPhone SE, etc.) */
@media (max-width: 375px) {
    .login-container {
        padding: var(--spacing-sm);
    }

    .login-title {
        font-size: 1.25rem;
    }

    .login-form {
        padding: var(--spacing-sm);
    }

    .login-btn,
    .google-login-btn {
        padding: 0.625rem;
    }
}

/* Short screens (landscape or small height) */
@media (max-height: 600px) {
    .login-screen {
        align-items: flex-start;
        padding-top: 10px;
    }

    .login-header {
        margin-bottom: var(--spacing-sm);
    }

    .login-title {
        font-size: 1.25rem;
    }

    .login-subtitle {
        font-size: 0.7rem;
        margin-top: var(--spacing-xs);
    }

    .login-form {
        padding: var(--spacing-sm);
    }

    .form-group {
        margin-bottom: var(--spacing-xs);
    }

    .login-form input {
        padding: 0.5rem 0.75rem;
    }

    .login-btn,
    .google-login-btn {
        padding: 0.5rem;
    }

    .login-footer {
        padding-top: var(--spacing-sm);
    }

    .demo-credentials {
        padding: var(--spacing-xs);
        font-size: 0.65rem;
    }

    .login-divider,
    .login-divider-or {
        margin: var(--spacing-xs) 0;
    }
}

/* ===== ENHANCED KPI VALUE ANIMATIONS ===== */
.kpi-value {
    transition: all 0.4s ease;
}

.kpi-value.updating {
    animation: valueUpdate 0.6s ease;
}

@keyframes valueUpdate {
    0% {
        transform: scale(1);
        color: var(--charcoal);
    }
    50% {
        transform: scale(1.15);
        color: var(--primary-gold);
    }
    100% {
        transform: scale(1);
        color: var(--charcoal);
    }
}

/* KPI Card Interactive States */
.kpi-card {
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

.kpi-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, transparent 100%);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.kpi-card:hover::before {
    opacity: 1;
}

/* KPI Card Arrow Icon */
.kpi-arrow {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%) translateX(10px);
    font-size: 14px;
    color: var(--primary-gold);
    opacity: 0;
    transition: all 0.3s ease;
}

.kpi-card:hover .kpi-arrow {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

.kpi-card:active {
    transform: translateY(-4px) scale(0.98);
}

/* Toast Enhancements */
.toast.success {
    background: var(--success);
}

.toast.error {
    background: var(--danger);
}

.toast.warning {
    background: var(--warning);
    color: var(--black);
}

/* ===== SMOOTH PAGE TRANSITIONS ===== */
.app-container {
    animation: appFadeIn 0.5s ease-out;
}

@keyframes appFadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

/* ===== MICRO-INTERACTIONS ===== */

/* Button Pulse on Important Actions */
.btn-primary {
    position: relative;
    overflow: hidden;
}

.btn-primary::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    transition: width 0.6s ease, height 0.6s ease;
}

.btn-primary:active::after {
    width: 300px;
    height: 300px;
}

/* Icon Rotation on Hover */
.action-btn i {
    transition: transform 0.3s ease;
}

.action-btn:hover i {
    transform: scale(1.2);
}

/* Form Input Focus Effects */
.form-input:focus {
    transform: scale(1.01);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.15);
}

/* ===== LOADING STATES ===== */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.loading-overlay.show {
    opacity: 1;
    visibility: visible;
}

.loading-spinner {
    width: 50px;
    height: 50px;
    border: 3px solid rgba(212, 175, 55, 0.3);
    border-top-color: var(--primary-gold);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* ===== ENHANCED STORM ALERT ===== */
.storm-alert {
    animation: alertSlideIn 0.5s ease-out, alertGlow 2s ease-in-out 0.5s infinite;
}

@keyframes alertSlideIn {
    from {
        opacity: 0;
        transform: translateX(-20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* ===== LEAD CARD ENHANCEMENTS ===== */
.lead-card {
    animation: leadFadeIn 0.4s ease-out both;
}

@keyframes leadFadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.leads-list .lead-card:nth-child(1) { animation-delay: 0.1s; }
.leads-list .lead-card:nth-child(2) { animation-delay: 0.2s; }
.leads-list .lead-card:nth-child(3) { animation-delay: 0.3s; }
.leads-list .lead-card:nth-child(4) { animation-delay: 0.4s; }
.leads-list .lead-card:nth-child(5) { animation-delay: 0.5s; }

/* ===== TEAM MEMBER CARDS ===== */
.team-member-card {
    animation: teamCardSlide 0.5s ease-out both;
}

@keyframes teamCardSlide {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.team-list .team-member-card:nth-child(1) { animation-delay: 0.1s; }
.team-list .team-member-card:nth-child(2) { animation-delay: 0.2s; }
.team-list .team-member-card:nth-child(3) { animation-delay: 0.3s; }

/* ===== NOTIFICATION BADGE ANIMATION ===== */
.notification-btn .badge {
    animation: badgePop 0.3s ease-out, badgeBounce 2s ease-in-out 0.3s infinite;
}

@keyframes badgePop {
    from {
        transform: scale(0);
    }
    to {
        transform: scale(1);
    }
}

/* ===== SCROLL ANIMATIONS ===== */
.scroll-fade-in {
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.6s ease-out;
}

.scroll-fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

/* ===== PHOTO UPLOAD ENHANCEMENTS ===== */
.photo-upload-card.has-image {
    border-color: var(--success);
    background: #f0fdf4;
}

.photo-upload-card.has-image .upload-icon {
    background: var(--success);
}

.upload-area {
    transition: all 0.3s ease;
}

.upload-area:hover {
    transform: scale(1.02);
}

/* ===== FORM SECTION ANIMATIONS ===== */
.form-section {
    animation: sectionFadeIn 0.5s ease-out both;
}

.form-section:nth-child(1) { animation-delay: 0.1s; }
.form-section:nth-child(2) { animation-delay: 0.2s; }
.form-section:nth-child(3) { animation-delay: 0.3s; }

@keyframes sectionFadeIn {
    from {
        opacity: 0;
        transform: translateY(15px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ===== ANALYTICS ENHANCEMENTS ===== */
.metric-card {
    animation: metricSlideIn 0.5s ease-out both;
}

.metrics-summary .metric-card:nth-child(1) { animation-delay: 0.1s; }
.metrics-summary .metric-card:nth-child(2) { animation-delay: 0.15s; }
.metrics-summary .metric-card:nth-child(3) { animation-delay: 0.2s; }
.metrics-summary .metric-card:nth-child(4) { animation-delay: 0.25s; }

@keyframes metricSlideIn {
    from {
        opacity: 0;
        transform: scale(0.9);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.bar-fill {
    animation: barGrowWidth 1s ease-out both;
    animation-delay: 0.5s;
}

@keyframes barGrowWidth {
    from {
        width: 0 !important;
    }
}

/* ===== FUNNEL ANIMATION ===== */
.funnel-stage {
    animation: funnelSlide 0.5s ease-out both;
}

.funnel-chart .funnel-stage:nth-child(1) { animation-delay: 0.1s; }
.funnel-chart .funnel-stage:nth-child(2) { animation-delay: 0.2s; }
.funnel-chart .funnel-stage:nth-child(3) { animation-delay: 0.3s; }
.funnel-chart .funnel-stage:nth-child(4) { animation-delay: 0.4s; }
.funnel-chart .funnel-stage:nth-child(5) { animation-delay: 0.5s; }
.funnel-chart .funnel-stage:nth-child(6) { animation-delay: 0.6s; }

@keyframes funnelSlide {
    from {
        opacity: 0;
        transform: translateX(-30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* ===== DARK MODE SUPPORT (Optional) ===== */
@media (prefers-color-scheme: dark) {
    :root {
        --bg-dark: #121212;
    }
}

/* ===== PRINT STYLES ===== */
@media print {
    .bottom-nav,
    .top-nav,
    .toast,
    .loading-screen,
    .login-screen {
        display: none !important;
    }

    .main-content {
        padding: 0;
        padding-bottom: 0;
    }

    .kpi-card,
    .lead-card,
    .team-member-card {
        break-inside: avoid;
    }
}

/* =============================================================================
   USER DROPDOWN MENU
   ============================================================================= */

.user-menu-container {
    position: relative;
}

.user-dropdown-menu {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    width: 280px;
    background: var(--charcoal);
    border: 1px solid rgba(212, 175, 55, 0.3);
    border-radius: var(--radius-lg);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s ease;
    z-index: 1000;
    overflow: hidden;
}

.user-dropdown-menu.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.dropdown-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    background: rgba(212, 175, 55, 0.1);
    border-bottom: 1px solid rgba(212, 175, 55, 0.2);
}

.dropdown-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: var(--gold);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.dropdown-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dropdown-avatar i {
    font-size: 2rem;
    color: var(--charcoal);
}

.dropdown-user-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.dropdown-user-name {
    font-weight: 600;
    color: var(--white);
    font-size: 1rem;
}

.dropdown-user-email {
    font-size: 0.8rem;
    color: var(--light-gray);
}

.dropdown-user-role {
    font-size: 0.75rem;
    color: var(--gold);
    text-transform: capitalize;
    font-weight: 500;
}

.dropdown-divider {
    height: 1px;
    background: rgba(255, 255, 255, 0.1);
    margin: var(--spacing-xs) 0;
}

.dropdown-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    width: 100%;
    padding: var(--spacing-md) var(--spacing-lg);
    background: transparent;
    border: none;
    color: var(--white);
    font-size: 0.9rem;
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: left;
}

.dropdown-item:hover {
    background: rgba(212, 175, 55, 0.1);
    color: var(--gold);
}

.dropdown-item i {
    width: 20px;
    text-align: center;
    color: var(--light-gray);
    transition: color 0.2s ease;
}

.dropdown-item:hover i {
    color: var(--gold);
}

.dropdown-item-danger {
    color: #ef4444;
}

.dropdown-item-danger:hover {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

.dropdown-item-danger i {
    color: #ef4444;
}

/* =============================================================================
   MODAL STYLES
   ============================================================================= */

.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(5px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
    padding: var(--spacing-lg);
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.modal-container {
    background: #ffffff;
    border: 1px solid #e8e8e8;
    border-radius: var(--radius-xl);
    width: 100%;
    max-width: 650px;
    max-height: 90vh;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
    animation: slideUp 0.3s ease;
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg) var(--spacing-xl);
    background: #f8f9fa;
    border-bottom: 1px solid #e8e8e8;
}

.modal-header h2 {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1.25rem;
    color: var(--charcoal);
    margin: 0;
}

.modal-header h2 i {
    font-size: 1.5rem;
    color: var(--primary-gold);
}

.modal-close-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #ffffff;
    border: 1px solid #e8e8e8;
    color: #666666;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-close-btn:hover {
    background: rgba(239, 68, 68, 0.1);
    border-color: #ef4444;
    color: #ef4444;
}

.modal-body {
    padding: var(--spacing-xl);
    overflow-y: auto;
    max-height: calc(90vh - 80px);
    background: #ffffff;
}

/* =============================================================================
   PROFILE SETTINGS
   ============================================================================= */

.profile-tabs {
    display: flex;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-xl);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    padding-bottom: var(--spacing-md);
}

.profile-tab {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: transparent;
    border: none;
    color: var(--light-gray);
    font-size: 0.9rem;
    cursor: pointer;
    border-radius: var(--radius-md);
    transition: all 0.2s ease;
}

.profile-tab:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--white);
}

.profile-tab.active {
    background: rgba(212, 175, 55, 0.2);
    color: var(--gold);
}

.profile-tab i {
    font-size: 1rem;
}

.profile-tab-content {
    display: none;
}

.profile-tab-content.active {
    display: block;
    animation: fadeIn 0.3s ease;
}

/* Avatar Section */
.profile-avatar-section {
    display: flex;
    align-items: center;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
    padding-bottom: var(--spacing-xl);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.profile-avatar-preview {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--gold), #b8941e);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border: 3px solid var(--gold);
}

.profile-avatar-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.profile-avatar-preview i {
    font-size: 4rem;
    color: var(--charcoal);
}

.profile-avatar-actions {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.btn-upload {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--gold);
    color: var(--charcoal);
    border-radius: var(--radius-md);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-upload:hover {
    background: #b8941e;
    transform: translateY(-1px);
}

.btn-remove-avatar {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: transparent;
    border: 1px solid rgba(239, 68, 68, 0.5);
    color: #ef4444;
    border-radius: var(--radius-md);
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-remove-avatar:hover {
    background: rgba(239, 68, 68, 0.1);
}

/* Profile Form Grid */
.profile-form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-lg);
}

.profile-form-grid .form-group.full-width {
    grid-column: 1 / -1;
}

.profile-form-grid .form-group label {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--light-gray);
    font-size: 0.85rem;
    margin-bottom: var(--spacing-sm);
}

.profile-form-grid .form-group label i {
    color: var(--gold);
    width: 16px;
}

.profile-form-grid .form-group input,
.profile-form-grid .form-group textarea,
.profile-form-grid .form-group select {
    width: 100%;
    padding: var(--spacing-md);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-md);
    color: var(--white);
    font-size: 0.95rem;
    transition: all 0.2s ease;
}

.profile-form-grid .form-group input:focus,
.profile-form-grid .form-group textarea:focus,
.profile-form-grid .form-group select:focus {
    outline: none;
    border-color: var(--gold);
    background: rgba(212, 175, 55, 0.05);
}

.profile-form-grid .form-group input:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.profile-form-grid .form-group textarea {
    resize: vertical;
    min-height: 80px;
}

.profile-form-grid .form-group select {
    cursor: pointer;
}

/* Profile Form Actions */
.profile-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-md);
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-xl);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.btn-primary {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-xl);
    background: var(--gold);
    color: var(--charcoal);
    border: none;
    border-radius: var(--radius-md);
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-primary:hover {
    background: #b8941e;
    transform: translateY(-1px);
}

.btn-secondary {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-xl);
    background: transparent;
    color: var(--light-gray);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-md);
    font-size: 0.95rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-secondary:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--white);
}

/* Security Tab */
.section-title {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--gold);
    font-size: 1rem;
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid rgba(212, 175, 55, 0.2);
}

.section-title i {
    font-size: 1.1rem;
}

.password-strength {
    margin-top: var(--spacing-sm);
    height: 4px;
    border-radius: 2px;
    background: rgba(255, 255, 255, 0.1);
    overflow: hidden;
}

.password-strength-bar {
    height: 100%;
    transition: width 0.3s ease, background 0.3s ease;
}

.password-strength-bar.weak {
    width: 33%;
    background: #ef4444;
}

.password-strength-bar.medium {
    width: 66%;
    background: #f59e0b;
}

.password-strength-bar.strong {
    width: 100%;
    background: #22c55e;
}

.security-info {
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-xl);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.security-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.security-item:last-child {
    border-bottom: none;
}

.security-item-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.security-item-info i {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(212, 175, 55, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gold);
}

.security-item-info div {
    display: flex;
    flex-direction: column;
}

.security-item-info strong {
    color: var(--white);
    font-size: 0.9rem;
}

.security-item-info span {
    color: var(--light-gray);
    font-size: 0.8rem;
}

/* Preferences Tab */
.preference-group {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.preference-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.preference-info strong {
    color: var(--white);
    font-size: 0.95rem;
}

.preference-info span {
    color: var(--light-gray);
    font-size: 0.8rem;
}

/* Toggle Switch */
.toggle-switch {
    position: relative;
    width: 50px;
    height: 26px;
    cursor: pointer;
}

.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-slider {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 26px;
    transition: all 0.3s ease;
}

.toggle-slider::before {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    left: 3px;
    bottom: 3px;
    background: var(--white);
    border-radius: 50%;
    transition: all 0.3s ease;
}

.toggle-switch input:checked + .toggle-slider {
    background: var(--gold);
}

.toggle-switch input:checked + .toggle-slider::before {
    transform: translateX(24px);
    background: var(--charcoal);
}

/* Responsive */
@media (max-width: 600px) {
    .modal-container {
        max-height: 100vh;
        border-radius: 0;
    }

    .profile-form-grid {
        grid-template-columns: 1fr;
    }

    .profile-avatar-section {
        flex-direction: column;
        text-align: center;
    }

    .profile-tabs {
        flex-wrap: wrap;
    }

    .profile-form-actions {
        flex-direction: column;
    }

    .btn-primary,
    .btn-secondary {
        width: 100%;
        justify-content: center;
    }
}

/* ===== EDIT LEAD MODAL STYLES ===== */

/* Lead Card Edit Button */
.lead-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-sm);
}

.lead-edit-btn {
    background: transparent;
    border: 1px solid var(--light-gray);
    color: var(--gray);
    width: 32px;
    height: 32px;
    border-radius: var(--radius-md);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.lead-edit-btn:hover {
    background: var(--primary-gold);
    border-color: var(--primary-gold);
    color: var(--white);
}

/* Edit Lead Modal */
.edit-lead-modal {
    max-width: 800px;
    max-height: 90vh;
    width: 95%;
}

.edit-lead-modal .modal-body {
    padding: 0;
    overflow-y: auto;
    max-height: calc(90vh - 70px);
    background: #ffffff;
}

/* Edit Lead Sections - Light Theme */
.edit-lead-modal .edit-lead-section {
    background: #ffffff;
    border-bottom: 1px solid #f0f0f0;
}

.edit-lead-modal .form-input,
.edit-lead-modal .form-textarea {
    background: #f8f9fa;
    border: 1px solid #e8e8e8;
    color: var(--charcoal);
}

.edit-lead-modal .form-input:focus,
.edit-lead-modal .form-textarea:focus {
    background: #ffffff;
    border-color: var(--primary-gold);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.1);
}

#editLeadForm {
    display: flex;
    flex-direction: column;
}

/* Schedule Inspection Modal */
.schedule-modal {
    max-width: 550px;
    max-height: 90vh;
}

.schedule-modal .modal-body {
    padding: 0;
    overflow-y: auto;
    max-height: calc(90vh - 70px);
}

.schedule-lead-info {
    background: linear-gradient(135deg, #f8f9fa, #f0f0f0);
    padding: var(--spacing-lg);
    color: var(--charcoal);
    border-bottom: 1px solid #e8e8e8;
}

.schedule-lead-info .lead-summary h3 {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
    color: var(--charcoal);
}

.schedule-lead-info .lead-summary p {
    font-size: 0.9rem;
    color: #666666;
}

/* Contact Lead Modal */
.contact-modal {
    max-width: 550px;
    max-height: 90vh;
}

.contact-modal .modal-body {
    padding: 0;
    overflow-y: auto;
    max-height: calc(90vh - 70px);
    background: #ffffff;
}

.contact-lead-info {
    background: linear-gradient(135deg, #f8f9fa, #f0f0f0);
    padding: var(--spacing-lg);
    color: var(--charcoal);
    text-align: center;
    border-bottom: 1px solid #e8e8e8;
}

.contact-lead-info h3 {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
    color: var(--charcoal);
}

.contact-lead-info p {
    font-size: 0.9rem;
    color: #666666;
}

/* Contact Methods */
.contact-options {
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--light-gray);
}

.contact-options h3 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.contact-options h3 i {
    color: var(--primary-gold);
}

.contact-method {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--off-white);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-sm);
}

.contact-method:last-child {
    margin-bottom: 0;
}

.contact-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--primary-gold);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--charcoal);
    font-size: 1rem;
}

.contact-details {
    flex: 1;
}

.contact-label {
    display: block;
    font-size: 0.75rem;
    color: var(--medium-gray);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.contact-value {
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--charcoal);
}

a.contact-value {
    color: var(--info);
    text-decoration: none;
}

a.contact-value:hover {
    text-decoration: underline;
}

.btn-sm {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: 0.8rem;
}

/* Form Sections */
.edit-lead-section {
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--light-gray);
}

.edit-lead-section:last-of-type {
    border-bottom: none;
}

.edit-lead-section h3 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.edit-lead-section h3 i {
    color: var(--primary-gold);
    font-size: 1rem;
}

/* Form Grid */
.edit-lead-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

.edit-lead-grid.three-col {
    grid-template-columns: repeat(3, 1fr);
}

.edit-lead-grid.four-col {
    grid-template-columns: repeat(4, 1fr);
}

/* Form Groups */
.form-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.form-group.full-width {
    grid-column: 1 / -1;
}

.form-group label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--gray);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.form-group input,
.form-group select,
.form-group textarea {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    font-size: 0.95rem;
    color: var(--charcoal);
    background: var(--white);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--primary-gold);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.1);
}

.form-group textarea {
    resize: vertical;
    min-height: 100px;
}

.form-group select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
}

/* Tags Editor */
.tags-editor {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.current-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    min-height: 36px;
    padding: var(--spacing-sm);
    background: var(--light-gray);
    border-radius: var(--radius-md);
}

.tag-item {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--white);
    border: 1px solid var(--primary-gold);
    border-radius: var(--radius-sm);
    font-size: 0.85rem;
    color: var(--charcoal);
}

.tag-item .remove-tag {
    background: none;
    border: none;
    color: var(--danger);
    cursor: pointer;
    padding: 0;
    font-size: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    transition: background-color 0.2s ease;
}

.tag-item .remove-tag:hover {
    background: rgba(239, 68, 68, 0.1);
}

.add-tag-row {
    display: flex;
    gap: var(--spacing-sm);
}

.add-tag-row input {
    flex: 1;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    font-size: 0.9rem;
}

.add-tag-row input:focus {
    outline: none;
    border-color: var(--primary-gold);
}

.btn-add-tag {
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--primary-gold);
    color: var(--white);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    transition: background-color 0.2s ease;
}

.btn-add-tag:hover {
    background: var(--dark-gold);
}

/* Modal Actions */
.modal-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-lg);
    background: var(--light-gray);
    border-top: 1px solid #ddd;
    gap: var(--spacing-md);
}

.modal-actions-left {
    display: flex;
    gap: var(--spacing-sm);
}

.modal-actions-right {
    display: flex;
    gap: var(--spacing-sm);
}

/* Button Styles */
.btn-danger {
    background: var(--danger);
    color: var(--white);
    border: none;
    padding: var(--spacing-sm) var(--spacing-lg);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    transition: background-color 0.2s ease;
}

.btn-danger:hover {
    background: #dc2626;
}

.btn-cancel {
    background: transparent;
    color: var(--gray);
    border: 1px solid var(--gray);
    padding: var(--spacing-sm) var(--spacing-lg);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 500;
    transition: all 0.2s ease;
}

.btn-cancel:hover {
    background: var(--light-gray);
    color: var(--charcoal);
}

.btn-save {
    background: var(--primary-gold);
    color: var(--white);
    border: none;
    padding: var(--spacing-sm) var(--spacing-lg);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    transition: background-color 0.2s ease;
}

.btn-save:hover {
    background: var(--dark-gold);
}

/* Lead Priority in Edit Form */
.edit-lead-section select option[value="hot"] {
    color: var(--danger);
}

.edit-lead-section select option[value="warm"] {
    color: var(--warning);
}

.edit-lead-section select option[value="cold"] {
    color: var(--info);
}

/* Responsive Edit Lead Modal */
@media (max-width: 600px) {
    .edit-lead-modal {
        max-height: 100vh;
        border-radius: 0;
    }

    .edit-lead-grid {
        grid-template-columns: 1fr;
    }

    .edit-lead-grid.three-col,
    .edit-lead-grid.four-col {
        grid-template-columns: 1fr 1fr;
    }

    .modal-actions {
        flex-direction: column;
    }

    .modal-actions-left,
    .modal-actions-right {
        width: 100%;
        justify-content: center;
    }

    .btn-danger,
    .btn-cancel,
    .btn-save {
        flex: 1;
        justify-content: center;
    }
}

/* =============================================================================
   TEAM MEMBER MODAL STYLES
   ============================================================================= */

.team-member-modal {
    max-width: 650px;
    width: 95%;
}

.team-member-modal .modal-body {
    background: #ffffff;
}

/* Member Profile Header (View Modal) */
.member-profile-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    padding: var(--spacing-xl);
    background: linear-gradient(135deg, #f8f9fa, #f0f0f0);
    border-bottom: 1px solid #e8e8e8;
}

.member-avatar-large {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--primary-gold);
    border-radius: 50%;
    flex-shrink: 0;
}

.member-avatar-large i {
    font-size: 2.5rem;
    color: white;
}

.member-profile-info h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: 4px;
}

.member-profile-info p {
    font-size: 0.9rem;
    color: #666666;
    margin-bottom: 8px;
}

.member-role-badge {
    display: inline-block;
    padding: 4px 12px;
    background: rgba(212, 175, 55, 0.15);
    color: var(--primary-gold);
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

/* Member Stats Grid */
.member-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-md);
}

.stat-card {
    background: #f8f9fa;
    border: 1px solid #e8e8e8;
    border-radius: 12px;
    padding: var(--spacing-md);
    text-align: center;
}

.stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-gold);
    margin-bottom: 4px;
}

.stat-label {
    font-size: 0.75rem;
    color: #666666;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Contact Info List */
.contact-info-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.contact-info-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) 0;
}

.contact-info-item i {
    width: 24px;
    color: var(--primary-gold);
    text-align: center;
}

.contact-info-item span {
    color: var(--charcoal);
    font-size: 0.95rem;
}

/* Responsive Team Modal */
@media (max-width: 600px) {
    .member-profile-header {
        flex-direction: column;
        text-align: center;
    }

    .member-stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* =============================================================================
   AI ANALYSIS VIEW STYLES
   ============================================================================= */

#aiAnalysisView {
    padding: var(--spacing-lg);
    padding-bottom: 100px;
}

#aiAnalysisView .view-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-xl);
}

#aiAnalysisView .view-header h1 {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1.5rem;
    color: var(--charcoal);
}

#aiAnalysisView .view-header h1 i {
    color: var(--primary-gold);
    font-size: 1.75rem;
}

.ai-badge {
    background: linear-gradient(135deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    color: var(--charcoal);
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    animation: pulse-glow 2s ease-in-out infinite;
}

@keyframes pulse-glow {
    0%, 100% { box-shadow: 0 0 5px rgba(212, 175, 55, 0.3); }
    50% { box-shadow: 0 0 20px rgba(212, 175, 55, 0.6); }
}

/* Analysis Tabs */
.analysis-tabs {
    display: flex;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-xl);
    background: var(--light-gray);
    padding: 4px;
    border-radius: var(--radius-lg);
}

.analysis-tab {
    flex: 1;
    padding: var(--spacing-md) var(--spacing-lg);
    border: none;
    background: transparent;
    color: var(--gray);
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    border-radius: var(--radius-md);
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.analysis-tab:hover {
    color: var(--charcoal);
    background: rgba(255, 255, 255, 0.5);
}

.analysis-tab.active {
    background: var(--white);
    color: var(--charcoal);
    box-shadow: var(--shadow-sm);
}

/* Tab Content */
.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
    animation: fadeIn 0.3s ease;
}

/* Upload Container */
.upload-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.upload-zone {
    border: 2px dashed rgba(212, 175, 55, 0.4);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
    text-align: center;
    background: rgba(212, 175, 55, 0.05);
    transition: all 0.3s ease;
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

.upload-zone:hover {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.1);
    transform: translateY(-2px);
}

.upload-zone.drag-over {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.15);
    box-shadow: 0 0 20px rgba(212, 175, 55, 0.3);
}

.upload-zone.has-file {
    border-style: solid;
    border-color: var(--success);
    background: rgba(16, 185, 129, 0.05);
}

.upload-icon {
    width: 60px;
    height: 60px;
    margin: 0 auto var(--spacing-md);
    background: linear-gradient(135deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.upload-icon i {
    font-size: 1.5rem;
    color: var(--white);
}

.upload-zone h3 {
    font-size: 1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-sm);
}

.upload-zone p {
    font-size: 0.85rem;
    color: var(--gray);
    margin-bottom: var(--spacing-md);
}

.upload-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-lg);
    background: var(--charcoal);
    color: var(--white);
    border: none;
    border-radius: var(--radius-md);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.upload-btn:hover {
    background: var(--primary-gold);
    color: var(--charcoal);
}

.upload-preview {
    display: none;
    margin-top: var(--spacing-md);
}

.upload-preview img {
    max-width: 100%;
    max-height: 150px;
    border-radius: var(--radius-md);
    object-fit: cover;
}

.upload-zone.has-file .upload-preview {
    display: block;
}

/* Analysis Settings */
.analysis-settings {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
}

.settings-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--light-gray);
}

.settings-header i {
    color: var(--primary-gold);
    font-size: 1.25rem;
}

.settings-header h3 {
    font-size: 1.1rem;
    color: var(--charcoal);
}

.settings-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-lg);
}

.setting-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.setting-group label {
    font-size: 0.85rem;
    color: var(--gray);
    font-weight: 500;
}

.setting-group select,
.setting-group input[type="range"] {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    background: var(--white);
    font-size: 0.9rem;
    color: var(--charcoal);
}

.setting-group input[type="range"] {
    padding: 0;
    height: 6px;
    -webkit-appearance: none;
    background: var(--light-gray);
    border-radius: 3px;
    cursor: pointer;
}

.setting-group input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    background: var(--primary-gold);
    border-radius: 50%;
    cursor: pointer;
}

.range-value {
    font-size: 0.8rem;
    color: var(--primary-gold);
    font-weight: 600;
}

/* Detection Options */
.detection-options {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--light-gray);
}

.detection-option {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(212, 175, 55, 0.1);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 0.2s ease;
}

.detection-option:hover {
    background: rgba(212, 175, 55, 0.2);
}

.detection-option input[type="checkbox"] {
    accent-color: var(--primary-gold);
    width: 16px;
    height: 16px;
}

.detection-option span {
    font-size: 0.85rem;
    color: var(--charcoal);
}

/* Start Analysis Button */
.start-analysis-btn {
    width: 100%;
    padding: var(--spacing-lg);
    background: linear-gradient(135deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    border: none;
    border-radius: var(--radius-xl);
    color: var(--charcoal);
    font-size: 1.1rem;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(212, 175, 55, 0.3);
}

.start-analysis-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(212, 175, 55, 0.4);
}

.start-analysis-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.start-analysis-btn i {
    font-size: 1.25rem;
}

/* Live Capture Tab */
.capture-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

.camera-preview {
    position: relative;
    background: var(--charcoal);
    border-radius: var(--radius-xl);
    overflow: hidden;
    aspect-ratio: 4/3;
}

.camera-preview video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.camera-guide {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    height: 80%;
    border: 2px dashed rgba(212, 175, 55, 0.5);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
}

.camera-guide span {
    background: rgba(0, 0, 0, 0.7);
    color: var(--white);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    font-size: 0.85rem;
}

.capture-controls {
    display: flex;
    gap: var(--spacing-md);
    justify-content: center;
}

.capture-btn {
    padding: var(--spacing-md) var(--spacing-xl);
    border: none;
    border-radius: var(--radius-lg);
    font-size: 1rem;
    font-weight: 500;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    transition: all 0.2s ease;
}

.capture-btn.primary {
    background: var(--primary-gold);
    color: var(--charcoal);
}

.capture-btn.secondary {
    background: var(--charcoal);
    color: var(--white);
}

.capture-btn:hover {
    transform: scale(1.05);
}

/* Results Tab */
.results-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

/* Analysis Progress */
.analysis-progress {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
}

.progress-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
}

.progress-header h3 {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1.1rem;
    color: var(--charcoal);
}

.progress-header h3 i {
    color: var(--primary-gold);
}

.progress-bar-container {
    height: 8px;
    background: var(--light-gray);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: var(--spacing-md);
}

.progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--primary-gold), var(--dark-gold));
    border-radius: 4px;
    width: 0%;
    transition: width 0.3s ease;
}

.progress-steps {
    display: flex;
    justify-content: space-between;
    font-size: 0.8rem;
    color: var(--gray);
}

.progress-step.active {
    color: var(--primary-gold);
    font-weight: 500;
}

.progress-step.completed {
    color: var(--success);
}

/* Results Summary */
.results-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--spacing-md);
}

.summary-card {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    text-align: center;
}

.summary-card.critical {
    border-color: var(--danger);
    background: rgba(239, 68, 68, 0.05);
}

.summary-card.warning {
    border-color: var(--warning);
    background: rgba(245, 158, 11, 0.05);
}

.summary-card.success {
    border-color: var(--success);
    background: rgba(16, 185, 129, 0.05);
}

.summary-icon {
    width: 48px;
    height: 48px;
    margin: 0 auto var(--spacing-md);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
}

.summary-card.critical .summary-icon {
    background: rgba(239, 68, 68, 0.1);
    color: var(--danger);
}

.summary-card.warning .summary-icon {
    background: rgba(245, 158, 11, 0.1);
    color: var(--warning);
}

.summary-card.success .summary-icon {
    background: rgba(16, 185, 129, 0.1);
    color: var(--success);
}

.summary-card h4 {
    font-size: 1.5rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.summary-card p {
    font-size: 0.85rem;
    color: var(--gray);
}

/* Annotated Image Viewer */
.annotated-viewer {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.viewer-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--charcoal);
    color: var(--white);
}

.viewer-header h3 {
    font-size: 1rem;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.viewer-controls {
    display: flex;
    gap: var(--spacing-sm);
}

.viewer-control {
    width: 32px;
    height: 32px;
    border: none;
    background: rgba(255, 255, 255, 0.1);
    color: var(--white);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.2s ease;
}

.viewer-control:hover,
.viewer-control.active {
    background: var(--primary-gold);
    color: var(--charcoal);
}

.viewer-canvas {
    position: relative;
    background: #f0f0f0;
    min-height: 400px;
}

.viewer-canvas img {
    width: 100%;
    height: auto;
}

.viewer-canvas canvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* Annotation Markers */
.annotation-marker {
    position: absolute;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: 2px solid var(--white);
    cursor: pointer;
    transform: translate(-50%, -50%);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--white);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    transition: transform 0.2s ease;
}

.annotation-marker:hover {
    transform: translate(-50%, -50%) scale(1.2);
}

.annotation-marker.hail {
    background: var(--danger);
}

.annotation-marker.wind {
    background: var(--warning);
}

.annotation-marker.wear {
    background: var(--info);
}

/* Roof Facet Grid */
.roof-grid-section {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
}

.grid-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
}

.grid-header h3 {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1.1rem;
    color: var(--charcoal);
}

.grid-header h3 i {
    color: var(--primary-gold);
}

.grid-legend {
    display: flex;
    gap: var(--spacing-md);
    font-size: 0.8rem;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.legend-color {
    width: 12px;
    height: 12px;
    border-radius: 2px;
}

.legend-color.severe { background: var(--danger); }
.legend-color.moderate { background: var(--warning); }
.legend-color.minor { background: var(--success); }
.legend-color.none { background: var(--light-gray); }

.roof-grid {
    display: grid;
    grid-template-columns: repeat(10, 1fr);
    gap: 2px;
    margin-bottom: var(--spacing-lg);
}

.grid-cell {
    aspect-ratio: 1;
    background: var(--light-gray);
    border-radius: 2px;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
}

.grid-cell:hover {
    transform: scale(1.1);
    z-index: 1;
}

.grid-cell.severe { background: var(--danger); }
.grid-cell.moderate { background: var(--warning); }
.grid-cell.minor { background: var(--success); }
.grid-cell.selected {
    box-shadow: 0 0 0 2px var(--primary-gold);
}

.facet-selector {
    display: flex;
    gap: var(--spacing-sm);
    justify-content: center;
}

.facet-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--light-gray);
    background: var(--white);
    border-radius: var(--radius-md);
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.facet-btn:hover,
.facet-btn.active {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.1);
    color: var(--primary-gold);
}

/* Findings List */
.findings-section {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
}

.findings-section h3 {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1.1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-lg);
}

.findings-section h3 i {
    color: var(--primary-gold);
}

.findings-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.finding-item {
    display: flex;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: rgba(0, 0, 0, 0.02);
    border-radius: var(--radius-md);
    border-left: 4px solid var(--light-gray);
}

.finding-item.critical { border-left-color: var(--danger); }
.finding-item.warning { border-left-color: var(--warning); }
.finding-item.info { border-left-color: var(--info); }

.finding-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.finding-item.critical .finding-icon {
    background: rgba(239, 68, 68, 0.1);
    color: var(--danger);
}

.finding-item.warning .finding-icon {
    background: rgba(245, 158, 11, 0.1);
    color: var(--warning);
}

.finding-item.info .finding-icon {
    background: rgba(59, 130, 246, 0.1);
    color: var(--info);
}

.finding-content h4 {
    font-size: 0.95rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.finding-content p {
    font-size: 0.85rem;
    color: var(--gray);
    margin-bottom: var(--spacing-sm);
}

.finding-meta {
    display: flex;
    gap: var(--spacing-md);
    font-size: 0.75rem;
    color: var(--gray);
}

.finding-meta span {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

/* Property Features */
.property-features {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
}

.property-features h3 {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1.1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-lg);
}

.property-features h3 i {
    color: var(--primary-gold);
}

.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--spacing-md);
}

.feature-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: rgba(212, 175, 55, 0.05);
    border: 1px solid rgba(212, 175, 55, 0.2);
    border-radius: var(--radius-md);
}

.feature-card i {
    font-size: 1.25rem;
    color: var(--primary-gold);
}

.feature-info h4 {
    font-size: 0.9rem;
    color: var(--charcoal);
}

.feature-info p {
    font-size: 0.8rem;
    color: var(--gray);
}

/* Export Options */
.export-options {
    display: flex;
    gap: var(--spacing-md);
    flex-wrap: wrap;
}

.export-btn {
    padding: var(--spacing-md) var(--spacing-lg);
    border: 1px solid var(--light-gray);
    background: var(--white);
    border-radius: var(--radius-md);
    font-size: 0.9rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    transition: all 0.2s ease;
}

.export-btn:hover {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.1);
}

.export-btn.primary {
    background: var(--primary-gold);
    color: var(--charcoal);
    border-color: var(--primary-gold);
}

.export-btn.primary:hover {
    background: var(--dark-gold);
}

/* =============================================================================
   POLICY OCR VIEW STYLES
   ============================================================================= */

#policyOcrView {
    padding: var(--spacing-lg);
    padding-bottom: 100px;
}

#policyOcrView .view-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-xl);
}

#policyOcrView .view-header h1 {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1.5rem;
    color: var(--charcoal);
}

#policyOcrView .view-header h1 i {
    color: var(--primary-gold);
}

.ocr-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
}

@media (max-width: 900px) {
    .ocr-container {
        grid-template-columns: 1fr;
    }
}

/* OCR Upload Section */
.ocr-upload-section {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
}

.ocr-upload-section h3 {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1.1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-lg);
}

.ocr-upload-section h3 i {
    color: var(--primary-gold);
}

.ocr-dropzone {
    border: 2px dashed rgba(212, 175, 55, 0.4);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl) * 2;
    text-align: center;
    background: rgba(212, 175, 55, 0.05);
    transition: all 0.3s ease;
    cursor: pointer;
}

.ocr-dropzone:hover,
.ocr-dropzone.drag-over {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.1);
}

.ocr-dropzone i {
    font-size: 3rem;
    color: var(--primary-gold);
    margin-bottom: var(--spacing-md);
}

.ocr-dropzone h4 {
    font-size: 1.1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-sm);
}

.ocr-dropzone p {
    font-size: 0.85rem;
    color: var(--gray);
}

.ocr-processing {
    display: none;
    text-align: center;
    padding: var(--spacing-xl);
}

.ocr-processing.active {
    display: block;
}

.ocr-spinner {
    width: 50px;
    height: 50px;
    border: 3px solid var(--light-gray);
    border-top-color: var(--primary-gold);
    border-radius: 50%;
    margin: 0 auto var(--spacing-md);
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* OCR Results Section */
.ocr-results-section {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
}

.ocr-results-section h3 {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1.1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-lg);
}

.ocr-results-section h3 i {
    color: var(--primary-gold);
}

.extracted-fields {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.field-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.field-group label {
    font-size: 0.8rem;
    color: var(--gray);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.field-value {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md);
    background: rgba(0, 0, 0, 0.02);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
}

.field-value input {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 0.95rem;
    color: var(--charcoal);
    outline: none;
}

.confidence-badge {
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 0.7rem;
    font-weight: 600;
}

.confidence-badge.high {
    background: rgba(16, 185, 129, 0.1);
    color: var(--success);
}

.confidence-badge.medium {
    background: rgba(245, 158, 11, 0.1);
    color: var(--warning);
}

.confidence-badge.low {
    background: rgba(239, 68, 68, 0.1);
    color: var(--danger);
}

.ocr-actions {
    display: flex;
    gap: var(--spacing-md);
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--light-gray);
}

.ocr-actions button {
    flex: 1;
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    transition: all 0.2s ease;
}

.ocr-actions .btn-secondary {
    background: var(--white);
    border: 1px solid var(--light-gray);
    color: var(--charcoal);
}

.ocr-actions .btn-secondary:hover {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.1);
}

.ocr-actions .btn-primary {
    background: var(--primary-gold);
    border: none;
    color: var(--charcoal);
}

.ocr-actions .btn-primary:hover {
    background: var(--dark-gold);
}

/* AI Action Button on Dashboard */
.action-btn.ai-action {
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.2) 0%, rgba(184, 150, 15, 0.2) 100%);
    border: 1px solid rgba(212, 175, 55, 0.4);
    position: relative;
    overflow: hidden;
}

.action-btn.ai-action::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: linear-gradient(45deg, transparent, rgba(212, 175, 55, 0.1), transparent);
    animation: shimmer 3s infinite;
}

@keyframes shimmer {
    0% { transform: translateX(-100%) translateY(-100%) rotate(45deg); }
    100% { transform: translateX(100%) translateY(100%) rotate(45deg); }
}

.action-btn.ai-action i {
    color: var(--primary-gold);
}

/* Responsive AI Analysis */
@media (max-width: 768px) {
    .upload-container {
        grid-template-columns: 1fr;
    }

    .settings-grid {
        grid-template-columns: 1fr;
    }

    .detection-options {
        flex-direction: column;
    }

    .results-summary {
        grid-template-columns: repeat(2, 1fr);
    }

    .roof-grid {
        grid-template-columns: repeat(5, 1fr);
    }

    .export-options {
        flex-direction: column;
    }

    .export-btn {
        width: 100%;
        justify-content: center;
    }
}

/* =============================================================================
   LEAD DETAIL VIEW STYLES
   ============================================================================= */

#leadDetailView {
    padding: var(--spacing-lg);
    padding-bottom: 100px;
}

#leadDetailView .view-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

#leadDetailView .back-btn {
    width: 40px;
    height: 40px;
    border: none;
    background: var(--light-gray);
    border-radius: var(--radius-md);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

#leadDetailView .back-btn:hover {
    background: var(--primary-gold);
    color: var(--white);
}

#leadDetailView .back-btn i {
    font-size: 1rem;
    color: var(--charcoal);
}

#leadDetailView .back-btn:hover i {
    color: var(--white);
}

/* Lead Summary Card */
.lead-summary-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
}

.lead-summary-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-md);
}

.lead-summary-info h2 {
    font-size: 1.25rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.lead-summary-info .lead-address {
    font-size: 0.9rem;
    color: var(--gray);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.lead-summary-status {
    display: flex;
    gap: var(--spacing-sm);
}

.lead-summary-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--light-gray);
}

.lead-meta-item {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.lead-meta-item .label {
    font-size: 0.75rem;
    color: var(--gray);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.lead-meta-item .value {
    font-size: 0.95rem;
    color: var(--charcoal);
    font-weight: 500;
}

/* Lead Detail Tabs */
.lead-detail-tabs {
    display: flex;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
    background: var(--light-gray);
    padding: 4px;
    border-radius: var(--radius-lg);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.lead-tab {
    flex: 1;
    min-width: fit-content;
    padding: var(--spacing-md) var(--spacing-lg);
    border: none;
    background: transparent;
    color: var(--gray);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    border-radius: var(--radius-md);
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    white-space: nowrap;
}

.lead-tab:hover {
    color: var(--charcoal);
    background: rgba(255, 255, 255, 0.5);
}

.lead-tab.active {
    background: var(--white);
    color: var(--charcoal);
    box-shadow: var(--shadow-sm);
}

.lead-tab i {
    font-size: 0.9rem;
}

/* Lead Tab Content */
.lead-tab-content {
    display: none;
}

.lead-tab-content.active {
    display: block;
    animation: fadeIn 0.3s ease;
}

/* Checklist Styles */
.checklist-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}

.checklist-header h3 {
    font-size: 1.1rem;
    color: var(--charcoal);
}

.checklist-progress {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 0.9rem;
    color: var(--gray);
}

.checklist-progress .progress-bar {
    width: 100px;
    height: 6px;
    background: var(--light-gray);
    border-radius: 3px;
    overflow: hidden;
}

.checklist-progress .progress-fill {
    height: 100%;
    background: var(--success);
    border-radius: 3px;
    transition: width 0.3s ease;
}

.checklist-items {
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.checklist-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--light-gray);
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.checklist-item:last-child {
    border-bottom: none;
}

.checklist-item:hover {
    background: rgba(212, 175, 55, 0.05);
}

.checklist-item.completed {
    background: rgba(16, 185, 129, 0.05);
}

.checklist-checkbox {
    width: 24px;
    height: 24px;
    border: 2px solid var(--gray);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.checklist-item.completed .checklist-checkbox {
    background: var(--success);
    border-color: var(--success);
}

.checklist-checkbox i {
    font-size: 0.75rem;
    color: var(--white);
    opacity: 0;
}

.checklist-item.completed .checklist-checkbox i {
    opacity: 1;
}

.checklist-content {
    flex: 1;
}

.checklist-content .title {
    font-size: 0.95rem;
    color: var(--charcoal);
    margin-bottom: 2px;
}

.checklist-item.completed .checklist-content .title {
    text-decoration: line-through;
    color: var(--gray);
}

.checklist-content .meta {
    font-size: 0.8rem;
    color: var(--gray);
}

/* Expense List Styles */
.expense-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}

.expense-header h3 {
    font-size: 1.1rem;
    color: var(--charcoal);
}

.expense-total {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--primary-gold);
}

.expense-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.expense-item {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md) var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.expense-info {
    flex: 1;
}

.expense-info .category {
    font-size: 0.75rem;
    color: var(--primary-gold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 2px;
}

.expense-info .description {
    font-size: 0.95rem;
    color: var(--charcoal);
    margin-bottom: 2px;
}

.expense-info .date {
    font-size: 0.8rem;
    color: var(--gray);
}

.expense-amount {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--charcoal);
}

/* Photo Grid Styles */
.photo-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}

.photo-filters {
    display: flex;
    gap: var(--spacing-sm);
}

.photo-filter-btn {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--light-gray);
    background: var(--white);
    border-radius: var(--radius-md);
    font-size: 0.85rem;
    color: var(--gray);
    cursor: pointer;
    transition: all 0.2s ease;
}

.photo-filter-btn:hover,
.photo-filter-btn.active {
    border-color: var(--primary-gold);
    color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.1);
}

.photo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: var(--spacing-md);
}

.photo-item {
    position: relative;
    aspect-ratio: 1;
    border-radius: var(--radius-lg);
    overflow: hidden;
    cursor: pointer;
}

.photo-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.photo-item:hover img {
    transform: scale(1.05);
}

.photo-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--spacing-sm);
    background: linear-gradient(transparent, rgba(0,0,0,0.7));
    color: var(--white);
}

.photo-overlay .photo-type {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    opacity: 0.9;
}

.photo-overlay .photo-date {
    font-size: 0.75rem;
    opacity: 0.8;
}

/* Claims List Styles */
.claims-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.claim-item {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
}

.claim-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-md);
}

.claim-info h4 {
    font-size: 1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.claim-info .claim-number {
    font-size: 0.85rem;
    color: var(--gray);
}

.claim-amount {
    text-align: right;
}

.claim-amount .amount {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--primary-gold);
}

.claim-amount .label {
    font-size: 0.75rem;
    color: var(--gray);
}

.claim-details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--light-gray);
}

.claim-detail-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.claim-detail-item .label {
    font-size: 0.75rem;
    color: var(--gray);
}

.claim-detail-item .value {
    font-size: 0.9rem;
    color: var(--charcoal);
}

/* Activity Timeline Styles */
.activity-list {
    position: relative;
    padding-left: var(--spacing-xl);
}

.activity-list::before {
    content: '';
    position: absolute;
    left: 12px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--light-gray);
}

.activity-item {
    position: relative;
    padding-bottom: var(--spacing-lg);
}

.activity-item:last-child {
    padding-bottom: 0;
}

.activity-icon {
    position: absolute;
    left: calc(-1 * var(--spacing-xl) + 4px);
    width: 20px;
    height: 20px;
    background: var(--white);
    border: 2px solid var(--primary-gold);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.activity-icon i {
    font-size: 0.6rem;
    color: var(--primary-gold);
}

.activity-content {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-sm);
}

.activity-content .title {
    font-size: 0.95rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.activity-content .description {
    font-size: 0.85rem;
    color: var(--gray);
    margin-bottom: var(--spacing-xs);
}

.activity-content .meta {
    font-size: 0.8rem;
    color: var(--gray);
    display: flex;
    gap: var(--spacing-md);
}

/* =============================================================================
   ADMIN PANEL VIEW STYLES
   ============================================================================= */

#adminView {
    padding: var(--spacing-lg);
    padding-bottom: 100px;
}

#adminView .view-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

#adminView .view-header h1 {
    font-size: 1.5rem;
    color: var(--charcoal);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

#adminView .view-header h1 i {
    color: var(--primary-gold);
}

/* Admin Tabs */
.admin-tabs {
    display: flex;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
    background: var(--light-gray);
    padding: 4px;
    border-radius: var(--radius-lg);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.admin-tab {
    flex: 1;
    min-width: fit-content;
    padding: var(--spacing-md) var(--spacing-lg);
    border: none;
    background: transparent;
    color: var(--gray);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    border-radius: var(--radius-md);
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    white-space: nowrap;
}

.admin-tab:hover {
    color: var(--charcoal);
    background: rgba(255, 255, 255, 0.5);
}

.admin-tab.active {
    background: var(--white);
    color: var(--charcoal);
    box-shadow: var(--shadow-sm);
}

.admin-tab i {
    font-size: 0.9rem;
}

/* Admin Tab Content */
.admin-tab-content {
    display: none;
}

.admin-tab-content.active {
    display: block;
    animation: fadeIn 0.3s ease;
}

/* Section Header */
.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}

.section-header h3 {
    font-size: 1.1rem;
    color: var(--charcoal);
}

/* Pricing Filters */
.pricing-filters {
    display: flex;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    flex-wrap: wrap;
}

.pricing-filters select,
.pricing-filters input {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    font-size: 0.9rem;
    background: var(--white);
}

.pricing-filters select {
    min-width: 150px;
}

.pricing-filters input {
    flex: 1;
    min-width: 200px;
}

/* Pricing Table */
.pricing-table-container {
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.pricing-table {
    width: 100%;
    border-collapse: collapse;
}

.pricing-table th,
.pricing-table td {
    padding: var(--spacing-md);
    text-align: left;
    border-bottom: 1px solid var(--light-gray);
}

.pricing-table th {
    background: var(--light-gray);
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--gray);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.pricing-table td {
    font-size: 0.9rem;
    color: var(--charcoal);
}

.pricing-table tr:hover {
    background: rgba(212, 175, 55, 0.05);
}

.pricing-table .actions {
    display: flex;
    gap: var(--spacing-sm);
}

.pricing-table .action-btn {
    width: 32px;
    height: 32px;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.pricing-table .action-btn.edit {
    background: rgba(212, 175, 55, 0.1);
    color: var(--primary-gold);
}

.pricing-table .action-btn.delete {
    background: rgba(239, 68, 68, 0.1);
    color: var(--danger);
}

.pricing-table .action-btn:hover {
    transform: scale(1.1);
}

/* Template Grid */
.template-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--spacing-lg);
}

.template-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.template-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.template-card h4 {
    font-size: 1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-sm);
}

.template-card .template-type {
    font-size: 0.75rem;
    color: var(--primary-gold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--spacing-md);
}

.template-card .template-preview {
    font-size: 0.85rem;
    color: var(--gray);
    line-height: 1.5;
    margin-bottom: var(--spacing-md);
    max-height: 60px;
    overflow: hidden;
}

.template-card .template-actions {
    display: flex;
    gap: var(--spacing-sm);
}

/* Supplier Section */
.supplier-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.supplier-card,
.manufacturer-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
}

.supplier-card h4,
.manufacturer-card h4 {
    font-size: 1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-sm);
}

.supplier-card .contact,
.manufacturer-card .contact {
    font-size: 0.85rem;
    color: var(--gray);
    margin-bottom: var(--spacing-xs);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.supplier-card .contact i,
.manufacturer-card .contact i {
    width: 16px;
    color: var(--primary-gold);
}

/* Users Table */
.users-filters {
    display: flex;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    flex-wrap: wrap;
}

.users-filters input,
.users-filters select {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    font-size: 0.9rem;
}

.users-table-container {
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.users-table {
    width: 100%;
    border-collapse: collapse;
}

.users-table th,
.users-table td {
    padding: var(--spacing-md);
    text-align: left;
    border-bottom: 1px solid var(--light-gray);
}

.users-table th {
    background: var(--light-gray);
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--gray);
    text-transform: uppercase;
}

.users-table td {
    font-size: 0.9rem;
    color: var(--charcoal);
}

.users-table .user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
}

.users-table .role-badge {
    padding: 4px 8px;
    border-radius: var(--radius-sm);
    font-size: 0.75rem;
    font-weight: 500;
}

.users-table .role-badge.admin {
    background: rgba(212, 175, 55, 0.1);
    color: var(--primary-gold);
}

.users-table .role-badge.manager {
    background: rgba(59, 130, 246, 0.1);
    color: var(--info);
}

.users-table .role-badge.sales {
    background: rgba(16, 185, 129, 0.1);
    color: var(--success);
}

/* Export Section */
.export-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--spacing-lg);
}

.export-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    box-shadow: var(--shadow-sm);
    text-align: center;
}

.export-card .icon {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--spacing-md);
}

.export-card .icon i {
    font-size: 1.5rem;
    color: var(--white);
}

.export-card h4 {
    font-size: 1.1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-sm);
}

.export-card p {
    font-size: 0.85rem;
    color: var(--gray);
    margin-bottom: var(--spacing-lg);
}

.export-card .export-btn {
    width: 100%;
}

/* Add Button */
.btn-add {
    padding: var(--spacing-sm) var(--spacing-lg);
    background: var(--primary-gold);
    color: var(--white);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    transition: background-color 0.2s ease;
}

.btn-add:hover {
    background: var(--dark-gold);
}

.btn-small {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: 0.8rem;
}

.btn-outline {
    background: transparent;
    border: 1px solid var(--primary-gold);
    color: var(--primary-gold);
}

.btn-outline:hover {
    background: var(--primary-gold);
    color: var(--white);
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--gray);
}

.empty-state i {
    font-size: 3rem;
    margin-bottom: var(--spacing-md);
    opacity: 0.5;
}

.empty-state p {
    font-size: 0.95rem;
}

/* Responsive Lead Detail & Admin */
@media (max-width: 768px) {
    .lead-detail-tabs,
    .admin-tabs {
        gap: var(--spacing-xs);
    }

    .lead-tab,
    .admin-tab {
        padding: var(--spacing-sm) var(--spacing-md);
        font-size: 0.8rem;
    }

    .lead-tab span,
    .admin-tab span {
        display: none;
    }

    .lead-summary-meta {
        grid-template-columns: repeat(2, 1fr);
    }

    .pricing-table,
    .users-table {
        font-size: 0.8rem;
    }

    .pricing-table th,
    .pricing-table td,
    .users-table th,
    .users-table td {
        padding: var(--spacing-sm);
    }

    .photo-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ============================================
   REGISTRATION SCREEN STYLES
   ============================================ */

/* Registration Screen Overlay */
.registration-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--dark-bg) 0%, #1a1a2e 100%);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-lg);
    overflow-y: auto;
}

.registration-screen.hidden {
    display: none;
}

/* Registration Container */
.registration-container {
    background: var(--card-bg);
    border-radius: var(--radius-lg);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
    width: 100%;
    max-width: 600px;
    padding: var(--spacing-xl);
    position: relative;
    border: 1px solid var(--border-color);
}

/* Registration Header */
.registration-header {
    text-align: center;
    margin-bottom: var(--spacing-xl);
}

.registration-header .logo-icon {
    width: 60px;
    height: 60px;
    margin-bottom: var(--spacing-md);
}

.registration-header h1 {
    font-size: 1.75rem;
    color: var(--white);
    margin-bottom: var(--spacing-xs);
}

.registration-header p {
    color: var(--gray);
    font-size: 0.95rem;
}

/* Registration Steps Indicator */
.registration-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--spacing-xl);
    gap: var(--spacing-sm);
}

.step-indicator {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.step-number {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--dark-bg);
    border: 2px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--gray);
    transition: all 0.3s ease;
}

.step-indicator.active .step-number {
    background: var(--primary-gold);
    border-color: var(--primary-gold);
    color: var(--dark-bg);
}

.step-indicator.completed .step-number {
    background: var(--success);
    border-color: var(--success);
    color: var(--white);
}

.step-label {
    font-size: 0.8rem;
    color: var(--gray);
    display: none;
}

.step-line {
    width: 40px;
    height: 2px;
    background: var(--border-color);
    transition: background 0.3s ease;
}

.step-line.active {
    background: var(--primary-gold);
}

/* Registration Form */
.registration-form {
    display: none;
}

.registration-form.active {
    display: block;
}

.step-title {
    font-size: 1.25rem;
    color: var(--white);
    margin-bottom: var(--spacing-lg);
    text-align: center;
}

/* Form Rows */
.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.form-row.three-col {
    grid-template-columns: 1fr 1fr 1fr;
}

.form-row .form-group {
    margin-bottom: 0;
}

/* OTP Input Container */
.otp-section {
    text-align: center;
    padding: var(--spacing-lg) 0;
}

.otp-info {
    color: var(--gray);
    margin-bottom: var(--spacing-lg);
    font-size: 0.95rem;
}

.otp-info strong {
    color: var(--primary-gold);
}

.otp-input-container {
    display: flex;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.otp-input {
    width: 50px;
    height: 60px;
    text-align: center;
    font-size: 1.5rem;
    font-weight: 600;
    background: var(--dark-bg);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--white);
    transition: all 0.3s ease;
}

.otp-input:focus {
    border-color: var(--primary-gold);
    outline: none;
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.2);
}

.otp-input.filled {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.1);
}

.otp-separator {
    display: flex;
    align-items: center;
    font-size: 1.5rem;
    color: var(--gray);
}

.otp-actions {
    margin-top: var(--spacing-lg);
}

.otp-resend {
    color: var(--gray);
    font-size: 0.9rem;
}

.otp-resend .link-btn {
    background: none;
    border: none;
    color: var(--primary-gold);
    cursor: pointer;
    font-size: 0.9rem;
    text-decoration: underline;
    padding: 0;
}

.otp-resend .link-btn:hover {
    color: var(--gold-hover);
}

.otp-resend .link-btn:disabled {
    color: var(--gray);
    cursor: not-allowed;
    text-decoration: none;
}

/* Demo OTP Display */
.demo-otp-display {
    background: rgba(212, 175, 55, 0.1);
    border: 1px dashed var(--primary-gold);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    margin-top: var(--spacing-lg);
    text-align: center;
}

.demo-otp-display p {
    color: var(--gray);
    font-size: 0.85rem;
    margin-bottom: var(--spacing-xs);
}

.demo-otp-display .demo-code {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-gold);
    letter-spacing: 0.3rem;
}

/* Success Screen */
.registration-success {
    display: none;
    text-align: center;
    padding: var(--spacing-xl) 0;
}

.registration-success.active {
    display: block;
}

.success-content {
    max-width: 400px;
    margin: 0 auto;
}

.success-icon {
    width: 80px;
    height: 80px;
    background: linear-gradient(135deg, var(--success), #2d8a4e);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--spacing-lg);
    animation: successPulse 0.5s ease-out;
}

.success-icon i {
    font-size: 2.5rem;
    color: var(--white);
}

@keyframes successPulse {
    0% {
        transform: scale(0);
        opacity: 0;
    }
    50% {
        transform: scale(1.2);
    }
    100% {
        transform: scale(1);
        opacity: 1;
    }
}

.success-content h2 {
    font-size: 1.5rem;
    color: var(--white);
    margin-bottom: var(--spacing-sm);
}

.success-content p {
    color: var(--gray);
    margin-bottom: var(--spacing-lg);
}

.success-details {
    background: var(--dark-bg);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    text-align: left;
}

.success-details p {
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--spacing-sm);
    font-size: 0.9rem;
}

.success-details p:last-child {
    margin-bottom: 0;
}

.success-details span:first-child {
    color: var(--gray);
}

.success-details span:last-child {
    color: var(--white);
    font-weight: 500;
}

/* Form Navigation Buttons */
.form-navigation {
    display: flex;
    gap: var(--spacing-md);
    margin-top: var(--spacing-xl);
}

.btn-secondary {
    flex: 1;
    padding: var(--spacing-md) var(--spacing-lg);
    background: var(--dark-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--white);
    font-size: 1rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.btn-secondary:hover {
    background: var(--border-color);
}

.btn-primary {
    flex: 2;
    padding: var(--spacing-md) var(--spacing-lg);
    background: linear-gradient(135deg, var(--primary-gold), var(--gold-hover));
    border: none;
    border-radius: var(--radius-md);
    color: var(--dark-bg);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(212, 175, 55, 0.4);
}

.btn-primary:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.btn-full {
    width: 100%;
    flex: none;
}

/* Back to Login Link */
.back-to-login {
    text-align: center;
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--border-color);
}

.back-to-login a {
    color: var(--primary-gold);
    text-decoration: none;
    font-size: 0.95rem;
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    transition: color 0.3s ease;
}

.back-to-login a:hover {
    color: var(--gold-hover);
}

/* Create Account Button on Login Page */
.login-divider {
    display: flex;
    align-items: center;
    margin: var(--spacing-lg) 0;
}

.login-divider::before,
.login-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border-color);
}

.login-divider span {
    padding: 0 var(--spacing-md);
    color: var(--gray);
    font-size: 0.85rem;
}

.create-account-btn {
    width: 100%;
    padding: var(--spacing-md);
    background: transparent;
    border: 1px solid var(--primary-gold);
    border-radius: var(--radius-md);
    color: var(--primary-gold);
    font-size: 0.95rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.create-account-btn:hover {
    background: var(--primary-gold);
    color: var(--dark-bg);
}

.create-account-btn i {
    font-size: 1rem;
}

/* Responsive Registration */
@media (max-width: 600px) {
    .registration-container {
        padding: var(--spacing-lg);
        margin: var(--spacing-md);
    }

    .registration-header h1 {
        font-size: 1.5rem;
    }

    .form-row {
        grid-template-columns: 1fr;
    }

    .form-row.three-col {
        grid-template-columns: 1fr;
    }

    .step-label {
        display: none;
    }

    .step-line {
        width: 20px;
    }

    .otp-input {
        width: 42px;
        height: 52px;
        font-size: 1.25rem;
    }

    .form-navigation {
        flex-direction: column;
    }

    .btn-secondary,
    .btn-primary {
        flex: none;
        width: 100%;
    }
}

/* =========================================
   AI ANALYSIS ERROR & RAW ANALYSIS STYLES
   ========================================= */

/* Analysis Error State */
.analysis-error {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--danger);
}

.analysis-error i {
    font-size: 3rem;
    margin-bottom: var(--spacing-md);
}

.analysis-error h3 {
    font-size: 1.5rem;
    margin-bottom: var(--spacing-sm);
    color: var(--charcoal);
}

.analysis-error p {
    color: var(--gray);
    margin-bottom: var(--spacing-lg);
}

.analysis-error .btn-primary {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
}

/* Raw AI Analysis Section */
.raw-analysis-section {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
    margin-top: var(--spacing-lg);
}

.raw-analysis-section h3 {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 1.1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-md);
}

.raw-analysis-section h3 i {
    color: var(--primary-gold);
}

.raw-analysis-content {
    background: var(--off-white);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    font-size: 0.95rem;
    line-height: 1.6;
    color: var(--dark-gray);
    max-height: 400px;
    overflow-y: auto;
}

.raw-analysis-content p {
    margin-bottom: var(--spacing-md);
}

.raw-analysis-content strong {
    color: var(--charcoal);
}

.raw-analysis-content em {
    color: var(--primary-gold);
}

/* Vision API Status Indicator */
.vision-status {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(34, 197, 94, 0.1);
    border-radius: var(--radius-md);
    font-size: 0.85rem;
    color: var(--success);
}

.vision-status.error {
    background: rgba(239, 68, 68, 0.1);
    color: var(--danger);
}

.vision-status i {
    font-size: 0.9rem;
}

/* Finding Item Success State */
.finding-item.success {
    border-left-color: var(--success);
}

.finding-item.success .finding-icon {
    background: rgba(34, 197, 94, 0.1);
    color: var(--success);
}

/* ===== AI ANALYSIS PAGE - COMPLETE OVERHAUL ===== */
/* Modern, Professional Design with Glassmorphism Effects */

/* Page Background */
.ai-analysis-content {
    background: linear-gradient(135deg, #f8f9fc 0%, #eef1f7 50%, #e8ecf4 100%);
    min-height: calc(100vh - 120px);
    padding: var(--spacing-lg);
}

/* Main Upload Container - Glass Card */
.simple-upload-container {
    max-width: 680px;
    margin: 0 auto;
    padding: var(--spacing-xl) var(--spacing-lg);
    text-align: center;
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 24px;
    border: 1px solid rgba(255, 255, 255, 0.6);
    box-shadow:
        0 4px 6px rgba(0, 0, 0, 0.02),
        0 12px 24px rgba(0, 0, 0, 0.04),
        0 24px 48px rgba(0, 0, 0, 0.06);
}

/* Title Styling */
.upload-title {
    font-size: 1.85rem;
    font-weight: 800;
    color: var(--charcoal);
    margin-bottom: var(--spacing-sm);
    letter-spacing: -0.5px;
    background: linear-gradient(135deg, var(--charcoal) 0%, #333 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.upload-subtitle {
    font-size: 1rem;
    color: #6b7280;
    margin-bottom: var(--spacing-xl);
    font-weight: 400;
    line-height: 1.6;
}

/* Upload Zone Container */
.simple-upload-zone {
    margin-bottom: var(--spacing-lg);
}

/* Upload Area - Elegant Dashed Border */
#uploadTab .upload-area {
    border: 2px dashed rgba(212, 175, 55, 0.4);
    border-radius: 20px;
    padding: var(--spacing-xl) var(--spacing-lg);
    background: linear-gradient(135deg, rgba(255,255,255,0.9) 0%, rgba(248,249,252,0.9) 100%);
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    min-height: 220px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

#uploadTab .upload-area::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.03) 0%, rgba(212, 175, 55, 0.08) 100%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

#uploadTab .upload-area:hover {
    border-color: var(--primary-gold);
    transform: translateY(-2px);
    box-shadow:
        0 8px 16px rgba(212, 175, 55, 0.12),
        0 16px 32px rgba(0, 0, 0, 0.06);
}

#uploadTab .upload-area:hover::before {
    opacity: 1;
}

#uploadTab .upload-area.drag-over {
    border-color: var(--primary-gold);
    border-style: solid;
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.08) 0%, rgba(212, 175, 55, 0.12) 100%);
    transform: scale(1.01);
}

/* Upload Icon */
#uploadTab .upload-area .upload-icon,
#uploadTab .upload-area i.fa-cloud-upload-alt {
    font-size: 3.5rem;
    background: linear-gradient(135deg, var(--primary-gold) 0%, var(--dark-gold) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: var(--spacing-md);
    filter: drop-shadow(0 2px 4px rgba(212, 175, 55, 0.3));
    transition: transform 0.3s ease;
}

#uploadTab .upload-area:hover i.fa-cloud-upload-alt {
    transform: scale(1.1) translateY(-4px);
}

#uploadTab .upload-area h3 {
    font-size: 1.15rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
    font-weight: 600;
    letter-spacing: -0.2px;
}

#uploadTab .upload-area p {
    color: #9ca3af;
    font-size: 0.875rem;
    font-weight: 400;
}

/* Upload Preview Area - Modern Card */
.upload-preview-area {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    box-shadow:
        0 8px 16px rgba(0, 0, 0, 0.15),
        0 16px 32px rgba(0, 0, 0, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.upload-preview-area img {
    width: 100%;
    max-height: 380px;
    object-fit: contain;
    display: block;
    padding: var(--spacing-sm);
}

.remove-image-btn {
    position: absolute;
    top: var(--spacing-md);
    right: var(--spacing-md);
    background: rgba(239, 68, 68, 0.95);
    color: white;
    border: none;
    padding: 10px 16px;
    border-radius: 12px;
    cursor: pointer;
    font-size: 0.8rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3);
}

.remove-image-btn:hover {
    background: #dc2626;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(239, 68, 68, 0.4);
}

/* Settings Section - Modern Select */
.simple-settings {
    margin-bottom: var(--spacing-lg);
    padding: var(--spacing-md) var(--spacing-lg);
    background: rgba(248, 249, 252, 0.8);
    border-radius: 16px;
    border: 1px solid rgba(0, 0, 0, 0.04);
}

.setting-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
}

.setting-row label {
    font-weight: 500;
    color: #4b5563;
    font-size: 0.95rem;
}

.setting-row select {
    padding: 10px 16px;
    padding-right: 40px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 12px;
    background: white;
    font-size: 0.95rem;
    color: var(--charcoal);
    min-width: 160px;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 16px;
}

.setting-row select:hover {
    border-color: var(--primary-gold);
}

.setting-row select:focus {
    outline: none;
    border-color: var(--primary-gold);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.15);
}

/* Analyze Button - Premium Gold */
.btn-analyze {
    width: 100%;
    max-width: 320px;
    padding: 16px 32px;
    font-size: 1.1rem;
    font-weight: 700;
    background: linear-gradient(135deg, var(--primary-gold) 0%, #c9a227 50%, var(--dark-gold) 100%);
    color: var(--charcoal);
    border: none;
    border-radius: 16px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow:
        0 4px 12px rgba(212, 175, 55, 0.3),
        0 8px 24px rgba(212, 175, 55, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 0.3);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    position: relative;
    overflow: hidden;
}

.btn-analyze::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.2) 0%, transparent 50%, rgba(0,0,0,0.1) 100%);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.btn-analyze:hover:not(:disabled) {
    transform: translateY(-3px);
    box-shadow:
        0 8px 20px rgba(212, 175, 55, 0.4),
        0 16px 40px rgba(212, 175, 55, 0.25),
        inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

.btn-analyze:hover:not(:disabled)::before {
    opacity: 1;
}

.btn-analyze:active:not(:disabled) {
    transform: translateY(-1px);
}

.btn-analyze:disabled {
    background: linear-gradient(135deg, #e5e7eb 0%, #d1d5db 100%);
    color: #9ca3af;
    cursor: not-allowed;
    box-shadow: none;
}

.btn-analyze i {
    font-size: 1.25rem;
}

/* ===== RESULTS SECTION STYLING ===== */
.results-container {
    max-width: 900px;
    margin: 0 auto;
}

/* Results Summary Cards */
.results-summary {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.summary-card {
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 20px;
    padding: var(--spacing-lg);
    border: 1px solid rgba(255, 255, 255, 0.6);
    box-shadow:
        0 4px 6px rgba(0, 0, 0, 0.02),
        0 10px 20px rgba(0, 0, 0, 0.04);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    transition: all 0.3s ease;
}

.summary-card:hover {
    transform: translateY(-4px);
    box-shadow:
        0 8px 16px rgba(0, 0, 0, 0.06),
        0 20px 40px rgba(0, 0, 0, 0.08);
}

.summary-card .summary-icon {
    width: 56px;
    height: 56px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--spacing-sm);
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, rgba(212, 175, 55, 0.2) 100%);
}

.summary-card .summary-icon i {
    font-size: 1.5rem;
    color: var(--primary-gold);
}

.summary-card.damage-score .summary-icon {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.1) 0%, rgba(239, 68, 68, 0.2) 100%);
}

.summary-card.damage-score .summary-icon i {
    color: #ef4444;
}

.summary-card .summary-icon.hail {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.1) 0%, rgba(59, 130, 246, 0.2) 100%);
}

.summary-card .summary-icon.hail i {
    color: #3b82f6;
}

.summary-card .summary-icon.regions {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.1) 0%, rgba(16, 185, 129, 0.2) 100%);
}

.summary-card .summary-icon.regions i {
    color: #10b981;
}

.summary-card .summary-icon.estimate {
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, rgba(212, 175, 55, 0.2) 100%);
}

.summary-card .summary-icon.estimate i {
    color: var(--primary-gold);
}

.summary-card .summary-value {
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--charcoal);
    display: block;
    margin-bottom: 4px;
    letter-spacing: -0.5px;
}

.summary-card .summary-label {
    font-size: 0.8rem;
    color: #6b7280;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Glass Card Section Base */
.annotated-viewer,
.roof-grid-section,
.findings-section,
.property-features-section,
.raw-analysis-section {
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 24px;
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-lg);
    border: 1px solid rgba(255, 255, 255, 0.6);
    box-shadow:
        0 4px 6px rgba(0, 0, 0, 0.02),
        0 12px 24px rgba(0, 0, 0, 0.04);
}

.annotated-viewer h3,
.roof-grid-section h3,
.findings-section h3,
.property-features-section h3,
.raw-analysis-section h3 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: 10px;
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid rgba(212, 175, 55, 0.2);
}

.annotated-viewer h3 i,
.roof-grid-section h3 i,
.findings-section h3 i,
.property-features-section h3 i,
.raw-analysis-section h3 i {
    color: var(--primary-gold);
    font-size: 1rem;
}

/* Viewer Controls - Modern Pill Buttons */
.viewer-controls {
    display: flex;
    gap: 8px;
    margin-bottom: var(--spacing-md);
    padding: 6px;
    background: rgba(248, 249, 252, 0.8);
    border-radius: 14px;
    width: fit-content;
}

.viewer-btn {
    padding: 10px 18px;
    border: none;
    background: transparent;
    border-radius: 10px;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 500;
    color: #6b7280;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 6px;
}

.viewer-btn:hover {
    background: rgba(255, 255, 255, 0.8);
    color: var(--charcoal);
}

.viewer-btn.active {
    background: white;
    color: var(--charcoal);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.viewer-btn i {
    font-size: 0.9rem;
}

/* Canvas Container */
.viewer-canvas-container {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    border-radius: 16px;
    padding: var(--spacing-md);
    position: relative;
}

.viewer-canvas-container canvas {
    width: 100%;
    border-radius: 12px;
}

/* Legend - Modern Style */
.viewer-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.8);
    padding: 6px 12px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 8px;
}

.legend-item .legend-color {
    width: 12px;
    height: 12px;
    border-radius: 4px;
}

.legend-item.severe .legend-color {
    background: linear-gradient(135deg, #ef4444, #dc2626);
}

.legend-item.moderate .legend-color {
    background: linear-gradient(135deg, #f59e0b, #d97706);
}

.legend-item.minor .legend-color {
    background: linear-gradient(135deg, #10b981, #059669);
}

.legend-item.metal .legend-color {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
}

/* Facet Tabs - Modern Pills */
.facet-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: var(--spacing-md);
    flex-wrap: wrap;
}

.facet-tab {
    padding: 8px 20px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: rgba(255, 255, 255, 0.8);
    border-radius: 10px;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 500;
    color: #6b7280;
    transition: all 0.3s ease;
}

.facet-tab:hover {
    border-color: var(--primary-gold);
    color: var(--charcoal);
}

.facet-tab.active {
    background: linear-gradient(135deg, var(--primary-gold), var(--dark-gold));
    color: var(--charcoal);
    border-color: transparent;
    font-weight: 600;
    box-shadow: 0 4px 12px rgba(212, 175, 55, 0.25);
}

/* Roof Grid Container */
.roof-grid-container {
    background: rgba(248, 249, 252, 0.5);
    border-radius: 16px;
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.roof-grid {
    display: grid;
    grid-template-columns: repeat(10, 1fr);
    gap: 4px;
}

.roof-grid .grid-cell {
    aspect-ratio: 1;
    background: rgba(255, 255, 255, 0.9);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s ease;
    border: 1px solid rgba(0, 0, 0, 0.06);
}

.roof-grid .grid-cell:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    z-index: 1;
}

.roof-grid .grid-cell.severe {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.8), rgba(220, 38, 38, 0.9));
}

.roof-grid .grid-cell.moderate {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.8), rgba(217, 119, 6, 0.9));
}

.roof-grid .grid-cell.minor {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.8), rgba(5, 150, 105, 0.9));
}

/* Grid Details */
.grid-details {
    padding: var(--spacing-md);
    background: rgba(248, 249, 252, 0.8);
    border-radius: 12px;
    text-align: center;
}

.grid-details p {
    color: #6b7280;
    font-size: 0.9rem;
}

/* Findings List */
.findings-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.finding-item {
    display: flex;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: rgba(248, 249, 252, 0.8);
    border-radius: 16px;
    border-left: 4px solid var(--primary-gold);
    transition: all 0.3s ease;
}

.finding-item:hover {
    background: rgba(248, 249, 252, 1);
    transform: translateX(4px);
}

.finding-item .finding-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.1), rgba(212, 175, 55, 0.2));
    flex-shrink: 0;
}

.finding-item .finding-icon i {
    color: var(--primary-gold);
    font-size: 1.25rem;
}

.finding-item .finding-content h4 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: 4px;
}

.finding-item .finding-content p {
    font-size: 0.875rem;
    color: #6b7280;
    line-height: 1.5;
}

.finding-item .finding-content .confidence-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    margin-top: 8px;
}


/* Storm Event Report Section */
.storm-report-section {
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 20px;
    padding: var(--spacing-lg);
    border: 1px solid rgba(255, 255, 255, 0.6);
    box-shadow:
        0 4px 6px rgba(0, 0, 0, 0.02),
        0 12px 24px rgba(0, 0, 0, 0.04);
    margin-bottom: var(--spacing-lg);
}

.storm-report-section h3 {
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: 10px;
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid rgba(212, 175, 55, 0.2);
}

.storm-report-section h3 i {
    color: var(--primary-gold);
    font-size: 1rem;
}

.storm-report-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--spacing-md);
}

.storm-stat {
    background: linear-gradient(135deg, rgba(248, 249, 252, 0.9), rgba(255, 255, 255, 0.95));
    border-radius: 16px;
    padding: var(--spacing-md);
    text-align: center;
    border: 1px solid rgba(0, 0, 0, 0.06);
    transition: all 0.3s ease;
}

.storm-stat:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08);
}

.storm-stat i {
    font-size: 1.5rem;
    color: var(--primary-gold);
    margin-bottom: 8px;
    display: block;
}

.storm-stat .storm-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--charcoal);
    display: block;
    margin-bottom: 4px;
}

.storm-stat .storm-label {
    font-size: 0.8rem;
    color: #6b7280;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Wind Damage Summary Icon */
.summary-icon.wind {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.15), rgba(37, 99, 235, 0.25));
}

.summary-icon.wind i {
    color: #3b82f6;
}

/* Export Actions Styling */
.export-actions {
    display: flex;
    gap: var(--spacing-md);
    flex-wrap: wrap;
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.export-actions button {
    flex: 1;
    min-width: 200px;
    padding: 14px 24px;
    border-radius: 14px;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.export-actions .btn-secondary {
    background: white;
    color: var(--charcoal);
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.export-actions .btn-secondary:hover {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.05);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

/* Raw Analysis Section */
.raw-analysis-content {
    background: rgba(248, 249, 252, 0.8);
    border-radius: 16px;
    padding: var(--spacing-lg);
    font-size: 0.9rem;
    line-height: 1.7;
    color: #4b5563;
}

.raw-analysis-content p {
    margin-bottom: var(--spacing-md);
}

.raw-analysis-content p:last-child {
    margin-bottom: 0;
}

/* Export Buttons - Modern Style */
.export-buttons {
    display: flex;
    gap: var(--spacing-md);
    flex-wrap: wrap;
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.export-buttons button {
    flex: 1;
    min-width: 200px;
    padding: 14px 24px;
    border-radius: 14px;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.export-buttons .btn-primary {
    background: linear-gradient(135deg, var(--primary-gold), var(--dark-gold));
    color: var(--charcoal);
    border: none;
    box-shadow: 0 4px 12px rgba(212, 175, 55, 0.25);
}

.export-buttons .btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(212, 175, 55, 0.35);
}

.export-buttons .btn-secondary {
    background: white;
    color: var(--charcoal);
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.export-buttons .btn-secondary:hover {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.05);
}

/* Progress Section - Modern */
.analysis-progress {
    padding: var(--spacing-xl);
    text-align: center;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(20px);
    border-radius: 24px;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.04);
}

.progress-header {
    margin-bottom: var(--spacing-lg);
}

.progress-header i {
    font-size: 3rem;
    color: var(--primary-gold);
    margin-bottom: var(--spacing-md);
    display: block;
}

.progress-header h3 {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--charcoal);
}

.progress-bar-container {
    height: 8px;
    background: rgba(0, 0, 0, 0.06);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: var(--spacing-lg);
}

.progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--primary-gold), var(--dark-gold));
    border-radius: 4px;
    transition: width 0.5s ease;
}

.progress-steps {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-md);
}

.progress-step {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: rgba(248, 249, 252, 0.8);
    border-radius: 10px;
    font-size: 0.85rem;
    color: #6b7280;
    transition: all 0.3s ease;
}

.progress-step.active {
    background: rgba(212, 175, 55, 0.1);
    color: var(--charcoal);
}

.progress-step.complete {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.progress-step.complete i {
    color: #10b981;
}

.progress-status {
    color: #6b7280;
    font-size: 0.9rem;
}

/* Error Section */
.analysis-error {
    text-align: center;
    padding: var(--spacing-xl);
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(20px);
    border-radius: 24px;
}

.analysis-error i {
    font-size: 4rem;
    color: #ef4444;
    margin-bottom: var(--spacing-md);
}

.analysis-error h3 {
    color: var(--charcoal);
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: var(--spacing-sm);
}

.analysis-error p {
    color: #6b7280;
    margin-bottom: var(--spacing-lg);
}

/* Responsive Adjustments */
@media (max-width: 768px) {
    .results-summary {
        grid-template-columns: repeat(2, 1fr);
    }

    .simple-upload-container {
        padding: var(--spacing-lg) var(--spacing-md);
        border-radius: 20px;
    }

    .viewer-controls {
        width: 100%;
        overflow-x: auto;
    }

    .export-buttons {
        flex-direction: column;
    }

    .export-buttons button {
        min-width: 100%;
    }
}

@media (max-width: 480px) {
    .results-summary {
        grid-template-columns: 1fr;
    }

    .upload-title {
        font-size: 1.5rem;
    }

    .facet-tabs {
        justify-content: center;
    }
}


/* Canvas Placeholder Styles */
.canvas-placeholder {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    color: rgba(255, 255, 255, 0.6);
    z-index: 10;
}

.canvas-placeholder i {
    font-size: 4rem;
    margin-bottom: 1rem;
    opacity: 0.5;
}

.canvas-placeholder h4 {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
    color: rgba(255, 255, 255, 0.8);
}

.canvas-placeholder p {
    font-size: 0.9rem;
    max-width: 280px;
    line-height: 1.5;
}

.canvas-placeholder.hidden {
    display: none;
}

/* Multi-Image Gallery Styles */
.image-gallery {
    margin-top: var(--spacing-md);
    padding: var(--spacing-md);
    background: rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.image-gallery h4 {
    font-size: 1rem;
    margin-bottom: var(--spacing-sm);
    color: var(--charcoal);
    display: flex;
    align-items: center;
    gap: 8px;
}

.image-gallery h4 i {
    color: var(--primary);
}

.gallery-thumbnails {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: var(--spacing-sm);
}

.gallery-thumbnail {
    position: relative;
    width: 100px;
    height: 100px;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.2s ease;
}

.gallery-thumbnail:hover {
    transform: scale(1.05);
    border-color: var(--primary);
}

.gallery-thumbnail.active {
    border-color: var(--primary);
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.2);
}

.gallery-thumbnail.analyzed {
    border-color: var(--success);
}

.gallery-thumbnail.analyzing {
    border-color: var(--warning);
}

.gallery-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.gallery-thumbnail .thumbnail-status {
    position: absolute;
    bottom: 4px;
    right: 4px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    color: white;
}

.gallery-thumbnail .thumbnail-status.pending {
    background: var(--charcoal);
}

.gallery-thumbnail .thumbnail-status.analyzing {
    background: var(--warning);
    animation: pulse 1s infinite;
}

.gallery-thumbnail .thumbnail-status.analyzed {
    background: var(--success);
}

.gallery-thumbnail .remove-thumb {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.6);
    color: white;
    border: none;
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 10px;
}

.gallery-thumbnail:hover .remove-thumb {
    display: flex;
}

.gallery-actions {
    display: flex;
    gap: 8px;
    padding-top: var(--spacing-sm);
    border-top: 1px solid rgba(0, 0, 0, 0.05);
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

/* Ensure viewer-canvas-container has relative positioning */
.viewer-canvas-container {
    position: relative;
}

/* Two-Column Layout for AI Analysis Page */
.analysis-two-column-layout {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: var(--spacing-xl) !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: var(--spacing-lg) !important;
    align-items: start !important;
}

.analysis-two-column-layout .simple-upload-container {
    max-width: none !important;
    margin: 0 !important;
}

.analysis-preview-panel {
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 24px;
    border: 1px solid rgba(255, 255, 255, 0.6);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08);
    padding: var(--spacing-lg);
    min-height: 500px;
}

.analysis-preview-panel .annotated-viewer {
    background: transparent;
    border: none;
    padding: 0;
}

.analysis-preview-panel .annotated-viewer h3 {
    font-size: 1.25rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: 10px;
}

.analysis-preview-panel .annotated-viewer h3 i {
    color: var(--primary);
}

.analysis-preview-panel .viewer-canvas-container {
    min-height: 400px;
    position: relative;
}

.analysis-preview-panel .canvas-placeholder {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    color: rgba(255, 255, 255, 0.7);
    z-index: 10;
}

.analysis-preview-panel .canvas-placeholder i {
    font-size: 4rem;
    margin-bottom: 1rem;
    opacity: 0.5;
}

.analysis-preview-panel .canvas-placeholder h4 {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
    color: rgba(255, 255, 255, 0.9);
}

.analysis-preview-panel .canvas-placeholder p {
    font-size: 0.9rem;
    max-width: 280px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.7);
}

/* Responsive: Stack on smaller screens */
@media (max-width: 1024px) {
    .analysis-two-column-layout {
        grid-template-columns: 1fr;
    }
    
    .analysis-preview-panel {
        order: 2;
    }
}

/* ============================================
   SIMPLE AI ANALYZER - SLEEK DESIGN
   ============================================ */

.simple-analyzer {
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
}

.analyzer-card {
    background: #ffffff;
    border-radius: 20px;
    padding: 40px;
    text-align: center;
    border: 1px solid rgba(0, 0, 0, 0.08);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
}

.upload-section {
    margin-bottom: 30px;
}

.upload-box {
    border: 2px dashed rgba(100, 116, 139, 0.5);
    border-radius: 16px;
    padding: 60px 40px;
    cursor: pointer;
    transition: all 0.3s ease;
    background: rgba(241, 245, 249, 0.9);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
}

.upload-box:hover {
    border-color: var(--primary-gradient-start, #3b82f6);
    background: rgba(59, 130, 246, 0.05);
}

.upload-box i {
    font-size: 48px;
    color: var(--primary-gradient-start, #3b82f6);
    margin-bottom: 16px;
    display: block;
}

.upload-box h3 {
    font-size: 20px;
    margin-bottom: 8px;
    color: #1e293b;
}

.upload-box p {
    color: #64748b;
    font-size: 14px;
    margin: 0;
}

.upload-box.drag-over {
    border-color: var(--primary-gradient-start, #3b82f6);
    background: rgba(59, 130, 246, 0.1);
    transform: scale(1.02);
}

.image-preview-box {
    position: relative;
    display: inline-block;
    margin-top: 20px;
}

.image-preview-box img {
    max-width: 100%;
    max-height: 400px;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

.image-preview-box .remove-btn {
    position: absolute;
    top: -10px;
    right: -10px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #ef4444;
    color: white;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    transition: transform 0.2s;
}

.image-preview-box .remove-btn:hover {
    transform: scale(1.1);
}

.analyze-btn {
    background: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);
    color: white;
    border: none;
    padding: 16px 48px;
    font-size: 18px;
    font-weight: 600;
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.analyze-btn:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(59, 130, 246, 0.4);
}

.analyze-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.analyze-btn i {
    font-size: 20px;
}

/* Progress Card */
.progress-card {
    background: rgba(255, 255, 255, 0.05);
    border-radius: 16px;
    padding: 40px;
    text-align: center;
    margin-top: 20px;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.progress-spinner {
    width: 60px;
    height: 60px;
    border: 4px solid rgba(255, 255, 255, 0.1);
    border-top-color: #3b82f6;
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto 20px;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

.progress-card h3 {
    color: #fff;
    margin-bottom: 20px;
}

.progress-bar-wrap {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    height: 8px;
    overflow: hidden;
    margin-bottom: 16px;
}

.progress-bar-wrap .progress-bar {
    height: 100%;
    background: linear-gradient(90deg, #3b82f6 0%, #8b5cf6 100%);
    border-radius: 10px;
    transition: width 0.3s ease;
}

.progress-card #progressStatus {
    color: rgba(255, 255, 255, 0.6);
    font-size: 14px;
}

/* Results Card */
.results-card {
    background: rgba(255, 255, 255, 0.05);
    border-radius: 16px;
    padding: 30px;
    margin-top: 20px;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.results-card h2 {
    color: #22c55e;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

/* Damage Summary */
.damage-summary {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-bottom: 30px;
    flex-wrap: wrap;
}

.damage-stat {
    background: rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    padding: 20px;
    min-width: 120px;
    text-align: center;
}

.damage-stat.main {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.2) 0%, rgba(239, 68, 68, 0.1) 100%);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.damage-stat i {
    font-size: 24px;
    color: var(--primary-gradient-start, #3b82f6);
    margin-bottom: 8px;
    display: block;
}

.damage-stat .stat-value {
    font-size: 28px;
    font-weight: 700;
    color: #fff;
    display: block;
}

.damage-stat.main .stat-value {
    color: #ef4444;
}

.damage-stat .stat-label {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.6);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Annotated Image Section */
.annotated-image-section {
    margin: 30px 0;
}

.annotated-image-section h3 {
    color: #fff;
    margin-bottom: 16px;
    font-size: 18px;
}

.image-viewer {
    background: #1a1a2e;
    border-radius: 12px;
    padding: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 300px;
}

.image-viewer canvas {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
}

.viewer-legend {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 16px;
}

.viewer-legend .legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.7);
}

.viewer-legend .dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

.viewer-legend .severe .dot { background: #ef4444; }
.viewer-legend .moderate .dot { background: #f59e0b; }
.viewer-legend .minor .dot { background: #22c55e; }

/* Findings Section */
.results-card .findings-section {
    margin: 30px 0;
    text-align: left;
}

.results-card .findings-section h3 {
    color: #fff;
    margin-bottom: 16px;
    font-size: 18px;
}

.results-card .findings-list {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 12px;
    padding: 20px;
    max-height: 300px;
    overflow-y: auto;
}

/* Result Actions */
.result-actions {
    display: flex;
    justify-content: center;
    gap: 16px;
    margin-top: 24px;
}

.result-actions .btn-primary {
    background: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);
    color: white;
    border: none;
    padding: 14px 28px;
    font-size: 16px;
    font-weight: 600;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.result-actions .btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(59, 130, 246, 0.4);
}

.result-actions .btn-secondary {
    background: rgba(255, 255, 255, 0.1);
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 14px 28px;
    font-size: 16px;
    font-weight: 500;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.result-actions .btn-secondary:hover {
    background: rgba(255, 255, 255, 0.15);
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .simple-analyzer {
        padding: 10px;
    }

    .analyzer-card {
        padding: 24px;
    }

    .upload-box {
        padding: 40px 20px;
    }

    .upload-box i {
        font-size: 36px;
    }

    .damage-summary {
        gap: 10px;
    }

    .damage-stat {
        min-width: 80px;
        padding: 12px;
    }

    .damage-stat .stat-value {
        font-size: 22px;
    }

    .result-actions {
        flex-direction: column;
    }

    .result-actions .btn-primary,
    .result-actions .btn-secondary {
        width: 100%;
        justify-content: center;
    }
}

/* Hide old complex styles */
.analysis-two-column-layout,
.analysis-preview-panel,
.simple-upload-container {
    display: none !important;
}

/* Gallery thumbnails for multi-image */
.simple-analyzer .image-gallery {
    margin-top: 16px;
}

.simple-analyzer .gallery-thumbnails {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: center;
}

.simple-analyzer .gallery-thumbnails .thumb {
    width: 80px;
    height: 80px;
    border-radius: 8px;
    overflow: hidden;
    position: relative;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.2s;
}

.simple-analyzer .gallery-thumbnails .thumb.active {
    border-color: #3b82f6;
}

.simple-analyzer .gallery-thumbnails .thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.simple-analyzer .gallery-thumbnails .thumb .remove {
    position: absolute;
    top: 2px;
    right: 2px;
    width: 20px;
    height: 20px;
    background: rgba(239, 68, 68, 0.9);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 10px;
    opacity: 0;
    transition: opacity 0.2s;
}

.simple-analyzer .gallery-thumbnails .thumb:hover .remove {
    opacity: 1;
}

/* ============================================
   NOTIFICATION PANEL STYLES
   ============================================ */

.notification-panel {
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    max-width: 400px;
    height: 100vh;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow: -4px 0 30px rgba(0, 0, 0, 0.15);
    z-index: 10001;
    transform: translateX(100%);
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
}

.notification-panel.active {
    transform: translateX(0);
}

.notification-panel-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 10000;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.notification-panel-overlay.active {
    opacity: 1;
    visibility: visible;
}

.notification-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--light-gray);
    background: var(--white);
}

.notification-panel-header h2 {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--charcoal);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.notification-panel-header h2 i {
    color: var(--primary-gold);
}

.notification-panel-close {
    width: 36px;
    height: 36px;
    border: none;
    background: var(--light-gray);
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--charcoal);
    transition: all 0.2s;
}

.notification-panel-close:hover {
    background: var(--danger);
    color: white;
}

.notification-panel-body {
    flex: 1;
    overflow-y: auto;
    padding: var(--spacing-md);
}

.notification-item {
    display: flex;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--white);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-sm);
    border: 1px solid var(--light-gray);
    cursor: pointer;
    transition: all 0.2s;
}

.notification-item:hover {
    border-color: var(--primary-gold);
    box-shadow: 0 2px 8px rgba(212, 175, 55, 0.15);
}

.notification-item.unread {
    background: rgba(212, 175, 55, 0.05);
    border-left: 3px solid var(--primary-gold);
}

.notification-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.notification-icon.storm {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.notification-icon.lead {
    background: rgba(16, 185, 129, 0.1);
    color: #10b981;
}

.notification-icon.alert {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

.notification-icon.info {
    background: rgba(212, 175, 55, 0.1);
    color: var(--primary-gold);
}

.notification-content {
    flex: 1;
    min-width: 0;
}

.notification-content h4 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: 2px;
}

.notification-content p {
    font-size: 0.75rem;
    color: var(--gray);
    line-height: 1.4;
}

.notification-time {
    font-size: 0.65rem;
    color: var(--gray);
    margin-top: 4px;
}

.notification-panel-footer {
    padding: var(--spacing-md);
    border-top: 1px solid var(--light-gray);
    background: var(--white);
}

.notification-panel-footer button {
    width: 100%;
    padding: var(--spacing-sm);
    border: none;
    background: var(--light-gray);
    border-radius: var(--radius-md);
    color: var(--charcoal);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.notification-panel-footer button:hover {
    background: var(--primary-gold);
    color: white;
}

/* User Info in Header */
.user-info .user-name {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--charcoal);
    max-width: 80px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

@media (max-width: 480px) {
    .user-info .user-name {
        display: none;
    }

    .notification-panel {
        max-width: 100%;
    }
}

/* =============================================================================
   SETTINGS PAGE STYLES
   ============================================================================= */

/* Settings Layout - Desktop First */
.settings-layout {
    display: flex;
    flex-direction: row;
    gap: var(--spacing-xl);
    min-height: calc(100vh - 200px);
    padding-bottom: var(--spacing-xl);
    max-width: 1400px;
    margin: 0 auto;
}

/* Settings Sidebar - Desktop */
.settings-sidebar {
    width: 280px;
    min-width: 280px;
    flex-shrink: 0;
    background: var(--white);
    border-radius: var(--radius-lg);
    border: 1px solid var(--light-gray);
    overflow-y: auto;
    max-height: calc(100vh - 180px);
    position: sticky;
    top: 100px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
    z-index: 101; /* Above bottom-nav z-index: 100 */
}

.settings-nav-section {
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--light-gray);
}

.settings-nav-section:last-child {
    padding-bottom: calc(var(--spacing-lg) + 80px); /* Account for fixed bottom nav */
    border-bottom: none;
}

/* Settings Nav Title */
.settings-nav-title {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--gray);
    margin-bottom: var(--spacing-md);
    padding: 0 var(--spacing-sm);
}

.settings-nav-title.admin-badge {
    color: var(--primary-gold);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.settings-nav-title.admin-badge i {
    font-size: 0.8rem;
}

.settings-nav-section h3 {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--gray);
    margin-bottom: var(--spacing-sm);
    padding: 0 var(--spacing-sm);
}

.settings-nav {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.settings-nav-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    width: 100%;
    padding: var(--spacing-md);
    background: transparent;
    border: none;
    border-radius: var(--radius-md);
    color: var(--charcoal);
    font-size: 0.9rem;
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: left;
}

.settings-nav-item i {
    width: 20px;
    text-align: center;
    color: var(--gray);
    transition: color 0.2s ease;
}

.settings-nav-item:hover {
    background: rgba(212, 175, 55, 0.1);
    color: var(--primary-gold);
}

.settings-nav-item:hover i {
    color: var(--primary-gold);
}

.settings-nav-item.active {
    background: var(--primary-gold);
    color: var(--white);
}

.settings-nav-item.active i {
    color: var(--white);
}

/* Settings Content - Desktop */
.settings-content {
    flex: 1;
    min-width: 0;
    max-width: 900px;
}

.settings-tab-content {
    display: none;
}

.settings-tab-content.active {
    display: block;
    animation: fadeIn 0.3s ease;
}

.settings-tab-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-xl);
    padding-bottom: var(--spacing-lg);
    border-bottom: 2px solid var(--light-gray);
}

.settings-tab-header h2 {
    font-size: 1.75rem;
    font-weight: 600;
    color: var(--charcoal);
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.settings-tab-header h2 i {
    color: var(--primary-gold);
    font-size: 1.5rem;
}

/* Settings Cards - Desktop */
.settings-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    border: 1px solid var(--light-gray);
    padding: var(--spacing-xl) var(--spacing-xxl);
    margin-bottom: var(--spacing-xl);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

/* Settings Form Row - Desktop Two Column Layout */
.settings-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-lg);
}

.settings-form-row.single-column {
    grid-template-columns: 1fr;
}

.settings-form-row.three-column {
    grid-template-columns: 1fr 1fr 1fr;
}

.settings-card h3 {
    font-size: 1.1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--light-gray);
}

/* Settings Section - Desktop */
.settings-section {
    margin-bottom: var(--spacing-xl);
}

.settings-section h2 {
    font-size: 1.75rem;
    font-weight: 600;
    color: var(--charcoal);
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.settings-section h2 i {
    color: var(--primary-gold);
    font-size: 1.5rem;
}

.settings-description {
    color: var(--gray);
    font-size: 0.95rem;
    margin-bottom: var(--spacing-xl);
    line-height: 1.6;
}

/* Profile Header Card - Desktop */
.profile-header-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-xl);
    padding: var(--spacing-xl);
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.05), rgba(212, 175, 55, 0.1));
    border-radius: var(--radius-lg);
    border: 1px solid rgba(212, 175, 55, 0.2);
    margin-bottom: var(--spacing-xl);
}

.profile-avatar-large {
    position: relative;
    width: 120px;
    height: 120px;
    flex-shrink: 0;
}

.profile-avatar-large img,
.profile-avatar-large i {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary-gold), #b8860b);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--white);
    font-size: 3rem;
    object-fit: cover;
    border: 4px solid var(--white);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.avatar-edit-btn {
    position: absolute;
    bottom: 5px;
    right: 5px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--primary-gold);
    border: 3px solid var(--white);
    color: var(--white);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    transition: all 0.2s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.avatar-edit-btn:hover {
    background: #c9a227;
    transform: scale(1.1);
}

.profile-header-info h3 {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.profile-header-info p {
    color: var(--gray);
    font-size: 0.95rem;
    margin-bottom: var(--spacing-sm);
}

.role-badge {
    display: inline-block;
    padding: 4px 12px;
    background: rgba(212, 175, 55, 0.15);
    color: var(--primary-gold);
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
}

/* Settings Form - Desktop */
.settings-form {
    background: var(--white);
    border-radius: var(--radius-lg);
    border: 1px solid var(--light-gray);
    padding: var(--spacing-xl);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.settings-form .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.settings-form .form-group {
    margin-bottom: var(--spacing-lg);
}

.settings-form .form-group label {
    display: block;
    font-weight: 500;
    color: var(--charcoal);
    margin-bottom: var(--spacing-sm);
    font-size: 0.9rem;
}

.settings-form .form-group input,
.settings-form .form-group textarea,
.settings-form .form-group select {
    width: 100%;
    padding: var(--spacing-md);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    font-size: 0.95rem;
    transition: all 0.2s ease;
    background: var(--white);
}

.settings-form .form-group input:focus,
.settings-form .form-group textarea:focus,
.settings-form .form-group select:focus {
    outline: none;
    border-color: var(--primary-gold);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.15);
}

.settings-form .form-group textarea {
    resize: vertical;
    min-height: 100px;
}

.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-md);
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--light-gray);
}

/* Settings Card with Header - Desktop */
.settings-card-header {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px solid var(--light-gray);
}

.settings-card-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    background: rgba(212, 175, 55, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.settings-card-icon i {
    font-size: 1.25rem;
    color: var(--primary-gold);
}

.settings-card-info h4 {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.settings-card-info p {
    color: var(--gray);
    font-size: 0.9rem;
    line-height: 1.5;
}

/* Avatar Upload */
.avatar-upload {
    display: flex;
    align-items: center;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
}

.avatar-preview {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary-gold), #b8860b);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border: 3px solid var(--white);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.avatar-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.avatar-preview i {
    font-size: 2.5rem;
    color: var(--white);
}

.avatar-actions {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.avatar-actions .btn-outline {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: 0.85rem;
}

.avatar-hint {
    font-size: 0.75rem;
    color: var(--gray);
}

/* Settings Form */
.settings-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.form-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-lg);
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.form-group.full-width {
    grid-column: 1 / -1;
}

.form-group label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--charcoal);
}

.form-group input,
.form-group textarea,
.form-group select {
    padding: var(--spacing-md);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    font-size: 0.9rem;
    color: var(--charcoal);
    background: var(--white);
    transition: all 0.2s ease;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--primary-gold);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.1);
}

.form-group textarea {
    min-height: 100px;
    resize: vertical;
}

.form-hint {
    font-size: 0.75rem;
    color: var(--gray);
}

/* Toggle Switch */
.toggle-switch {
    position: relative;
    width: 50px;
    height: 26px;
    flex-shrink: 0;
}

.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--light-gray);
    border-radius: 26px;
    transition: all 0.3s ease;
}

.toggle-slider:before {
    position: absolute;
    content: "";
    height: 20px;
    width: 20px;
    left: 3px;
    bottom: 3px;
    background: var(--white);
    border-radius: 50%;
    transition: all 0.3s ease;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.toggle-switch input:checked + .toggle-slider {
    background: var(--primary-gold);
}

.toggle-switch input:checked + .toggle-slider:before {
    transform: translateX(24px);
}

/* Settings Row */
.settings-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--light-gray);
}

.settings-row:last-child {
    border-bottom: none;
}

.settings-row-info h4 {
    font-size: 0.95rem;
    color: var(--charcoal);
    margin-bottom: 2px;
}

.settings-row-info p {
    font-size: 0.8rem;
    color: var(--gray);
}

/* Password Form */
.password-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    max-width: 400px;
}

.password-requirements {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-sm);
}

.password-requirements li {
    font-size: 0.75rem;
    color: var(--gray);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.password-requirements li i {
    color: var(--gray);
}

.password-requirements li.valid {
    color: #10b981;
}

.password-requirements li.valid i {
    color: #10b981;
}

/* 2FA Section */
.two-factor-section {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-lg);
    padding: var(--spacing-lg);
    background: rgba(212, 175, 55, 0.05);
    border-radius: var(--radius-md);
    border: 1px solid rgba(212, 175, 55, 0.2);
}

.two-factor-icon {
    width: 50px;
    height: 50px;
    background: var(--primary-gold);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.two-factor-icon i {
    font-size: 1.5rem;
    color: var(--white);
}

.two-factor-info {
    flex: 1;
}

.two-factor-info h4 {
    font-size: 1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.two-factor-info p {
    font-size: 0.85rem;
    color: var(--gray);
    margin-bottom: var(--spacing-md);
}

/* Login History */
.login-history {
    max-height: 200px;
    overflow-y: auto;
}

.login-history-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--bg-light);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-sm);
}

.login-history-item i {
    font-size: 1.2rem;
    color: var(--gray);
}

.login-history-item .device {
    flex: 1;
}

.login-history-item .device strong {
    display: block;
    font-size: 0.9rem;
    color: var(--charcoal);
}

.login-history-item .device span {
    font-size: 0.75rem;
    color: var(--gray);
}

.login-history-item .location {
    text-align: right;
}

.login-history-item .location strong {
    display: block;
    font-size: 0.85rem;
    color: var(--charcoal);
}

.login-history-item .location span {
    font-size: 0.75rem;
    color: var(--gray);
}

.current-session {
    font-size: 0.7rem;
    background: #10b981;
    color: white;
    padding: 2px 8px;
    border-radius: 10px;
    margin-left: var(--spacing-sm);
}

/* Theme Options */
.theme-options {
    display: flex;
    gap: var(--spacing-lg);
    margin-top: var(--spacing-md);
}

.theme-option {
    flex: 1;
    padding: var(--spacing-lg);
    background: var(--bg-light);
    border: 2px solid transparent;
    border-radius: var(--radius-lg);
    cursor: pointer;
    text-align: center;
    transition: all 0.2s ease;
}

.theme-option:hover {
    border-color: var(--primary-gold);
}

.theme-option.active {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.1);
}

.theme-preview {
    width: 100%;
    height: 60px;
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-sm);
    display: flex;
    align-items: center;
    justify-content: center;
}

.theme-preview.light {
    background: linear-gradient(180deg, #ffffff 50%, #f5f5f5 50%);
    border: 1px solid var(--light-gray);
}

.theme-preview.dark {
    background: linear-gradient(180deg, #1f2937 50%, #111827 50%);
}

.theme-preview.auto {
    background: linear-gradient(90deg, #ffffff 50%, #1f2937 50%);
    border: 1px solid var(--light-gray);
}

.theme-option span {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--charcoal);
}

/* Color Options */
.color-options {
    display: flex;
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
    flex-wrap: wrap;
}

.color-option {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    cursor: pointer;
    border: 3px solid transparent;
    transition: all 0.2s ease;
    position: relative;
}

.color-option:hover {
    transform: scale(1.1);
}

.color-option.active {
    border-color: var(--charcoal);
}

.color-option.active::after {
    content: '\f00c';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--white);
    font-size: 0.9rem;
}

.color-option.gold { background: var(--primary-gold); }
.color-option.blue { background: #3b82f6; }
.color-option.green { background: #10b981; }
.color-option.purple { background: #8b5cf6; }
.color-option.red { background: #ef4444; }
.color-option.teal { background: #14b8a6; }

/* Approval Cards */
.approval-cards {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.approval-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    padding: var(--spacing-lg);
    background: var(--bg-light);
    border-radius: var(--radius-lg);
    border: 1px solid var(--light-gray);
}

.approval-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: var(--primary-gold);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--white);
    font-weight: 600;
    font-size: 1.2rem;
    flex-shrink: 0;
}

.approval-info {
    flex: 1;
}

.approval-info h4 {
    font-size: 1rem;
    color: var(--charcoal);
    margin-bottom: 2px;
}

.approval-info p {
    font-size: 0.85rem;
    color: var(--gray);
    margin-bottom: 4px;
}

.approval-info .request-date {
    font-size: 0.75rem;
    color: var(--gray);
}

.approval-actions {
    display: flex;
    gap: var(--spacing-sm);
}

.approval-actions .btn-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.approval-actions .btn-approve {
    background: #10b981;
    color: white;
}

.approval-actions .btn-approve:hover {
    background: #059669;
}

.approval-actions .btn-reject {
    background: #ef4444;
    color: white;
}

.approval-actions .btn-reject:hover {
    background: #dc2626;
}

/* Roles Grid */
.roles-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--spacing-lg);
}

.role-card {
    background: var(--bg-light);
    border-radius: var(--radius-lg);
    border: 1px solid var(--light-gray);
    overflow: hidden;
}

.role-card-header {
    padding: var(--spacing-lg);
    background: var(--white);
    border-bottom: 1px solid var(--light-gray);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.role-card-header h4 {
    font-size: 1rem;
    color: var(--charcoal);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.role-card-header h4 i {
    color: var(--primary-gold);
}

.role-badge {
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 600;
}

.role-badge.admin {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

.role-badge.inspector {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.role-badge.viewer {
    background: rgba(107, 114, 128, 0.1);
    color: #6b7280;
}

.role-card-body {
    padding: var(--spacing-lg);
}

.permissions-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.permission-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 0.85rem;
    color: var(--charcoal);
}

.permission-item i {
    color: #10b981;
    font-size: 0.8rem;
}

/* Team Management Sub-Tabs */
.team-sub-tabs {
    display: flex;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--light-gray);
}

.team-sub-tab {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm) var(--spacing-md);
    background: transparent;
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    color: var(--gray);
    font-size: 0.9rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.team-sub-tab:hover {
    background: rgba(212, 175, 55, 0.1);
    border-color: var(--primary-gold);
    color: var(--primary-gold);
}

.team-sub-tab.active {
    background: var(--primary-gold);
    border-color: var(--primary-gold);
    color: var(--white);
}

.team-sub-tab i {
    font-size: 0.85rem;
}

.team-sub-tab .pending-badge {
    background: #ef4444;
    color: white;
    font-size: 0.7rem;
    padding: 2px 6px;
    border-radius: 10px;
    margin-left: 4px;
}

.team-sub-tab.active .pending-badge {
    background: white;
    color: var(--primary-gold);
}

.team-sub-content {
    display: none;
}

.team-sub-content.active {
    display: block;
}

/* Integrations Grid */
.integrations-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--spacing-lg);
}

.integration-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    border: 1px solid var(--light-gray);
    padding: var(--spacing-lg);
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
}

.integration-icon {
    width: 50px;
    height: 50px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.integration-icon.google {
    background: #ea4335;
    color: white;
}

.integration-icon.weather {
    background: #3b82f6;
    color: white;
}

.integration-icon.eagleview {
    background: #10b981;
    color: white;
}

.integration-icon.xactimate {
    background: #8b5cf6;
    color: white;
}

.integration-icon i {
    font-size: 1.5rem;
}

.integration-info {
    flex: 1;
}

.integration-info h4 {
    font-size: 1rem;
    color: var(--charcoal);
    margin-bottom: 4px;
}

.integration-info p {
    font-size: 0.8rem;
    color: var(--gray);
    margin-bottom: var(--spacing-sm);
}

.integration-status {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: 0.75rem;
}

.integration-status.connected {
    color: #10b981;
}

.integration-status.disconnected {
    color: var(--gray);
}

.integration-status i {
    font-size: 0.6rem;
}

/* Templates Grid */
.templates-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--spacing-lg);
}

.template-card {
    background: var(--bg-light);
    border-radius: var(--radius-lg);
    border: 1px solid var(--light-gray);
    padding: var(--spacing-lg);
    text-align: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

.template-card:hover {
    border-color: var(--primary-gold);
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.template-card i {
    font-size: 2rem;
    color: var(--primary-gold);
    margin-bottom: var(--spacing-md);
}

.template-card h4 {
    font-size: 0.95rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.template-card p {
    font-size: 0.75rem;
    color: var(--gray);
}

/* Export Options */
.export-options {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: var(--spacing-lg);
}

.export-card {
    background: var(--bg-light);
    border-radius: var(--radius-lg);
    border: 1px solid var(--light-gray);
    padding: var(--spacing-xl);
    text-align: center;
}

.export-card i {
    font-size: 2.5rem;
    color: var(--primary-gold);
    margin-bottom: var(--spacing-md);
}

.export-card h4 {
    font-size: 1rem;
    color: var(--charcoal);
    margin-bottom: var(--spacing-xs);
}

.export-card p {
    font-size: 0.8rem;
    color: var(--gray);
    margin-bottom: var(--spacing-lg);
}

/* System Info */
.system-info {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.system-info-item {
    background: var(--bg-light);
    padding: var(--spacing-lg);
    border-radius: var(--radius-md);
    text-align: center;
}

.system-info-item label {
    font-size: 0.75rem;
    color: var(--gray);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    display: block;
    margin-bottom: var(--spacing-xs);
}

.system-info-item span {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--charcoal);
}

/* Maintenance Actions */
.maintenance-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.maintenance-actions .btn-outline {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

/* API Keys */
.api-keys-section {
    background: var(--bg-light);
    padding: var(--spacing-lg);
    border-radius: var(--radius-md);
}

.api-key-row {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--light-gray);
}

.api-key-row:last-child {
    border-bottom: none;
}

.api-key-row label {
    min-width: 150px;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--charcoal);
}

.api-key-row code {
    flex: 1;
    background: var(--white);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-sm);
    font-family: monospace;
    font-size: 0.85rem;
    color: var(--charcoal);
    border: 1px solid var(--light-gray);
}

/* User Management Table */
.user-management-filters {
    display: flex;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    flex-wrap: wrap;
}

.user-management-filters input,
.user-management-filters select {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-md);
    font-size: 0.9rem;
}

.user-management-filters input {
    flex: 1;
    min-width: 200px;
}

.users-table {
    width: 100%;
    border-collapse: collapse;
}

.users-table th,
.users-table td {
    padding: var(--spacing-md);
    text-align: left;
    border-bottom: 1px solid var(--light-gray);
}

.users-table th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--gray);
    font-weight: 600;
    background: var(--bg-light);
}

.users-table td {
    font-size: 0.9rem;
    color: var(--charcoal);
}

.users-table .user-cell {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.users-table .user-avatar {
    width: 35px;
    height: 35px;
    border-radius: 50%;
    background: var(--primary-gold);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--white);
    font-size: 0.8rem;
    font-weight: 600;
}

.users-table .status-badge {
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 600;
}

.status-badge.active {
    background: rgba(16, 185, 129, 0.1);
    color: #10b981;
}

.status-badge.inactive {
    background: rgba(107, 114, 128, 0.1);
    color: #6b7280;
}

.status-badge.pending {
    background: rgba(245, 158, 11, 0.1);
    color: #f59e0b;
}

/* Responsive Settings - Tablet */
@media (max-width: 1024px) {
    .settings-layout {
        gap: var(--spacing-lg);
    }

    .settings-sidebar {
        width: 240px;
        min-width: 240px;
    }

    .settings-content {
        max-width: none;
    }
}

/* Responsive Settings - Mobile */
@media (max-width: 992px) {
    .settings-layout {
        flex-direction: column;
    }

    .settings-sidebar {
        width: 100%;
        min-width: 100%;
        position: static;
        top: auto;
    }

    .settings-nav-section {
        padding: var(--spacing-md);
    }

    .settings-nav-title {
        text-align: center;
        margin-bottom: var(--spacing-sm);
    }

    .settings-nav-item {
        padding: var(--spacing-sm) var(--spacing-md);
        font-size: 0.85rem;
    }

    .settings-form-row {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }

    .settings-form-row.three-column {
        grid-template-columns: 1fr;
    }

    .form-row {
        grid-template-columns: 1fr;
    }

    .theme-options {
        flex-direction: column;
    }

    .settings-tab-header h2 {
        font-size: 1.3rem;
    }

    .settings-card {
        padding: var(--spacing-lg);
    }
}

@media (max-width: 768px) {
    .settings-card {
        padding: var(--spacing-md);
    }

    .settings-tab-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }

    .avatar-upload {
        flex-direction: column;
        text-align: center;
    }

    .approval-card {
        flex-direction: column;
        text-align: center;
    }

    .approval-actions {
        justify-content: center;
    }

    .two-factor-section {
        flex-direction: column;
        text-align: center;
    }

    .user-management-filters {
        flex-direction: column;
    }

    .users-table {
        display: block;
        overflow-x: auto;
    }
}

/* ===== CLAIMS MANAGEMENT STYLES ===== */

/* Claims List Container */
.claims-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

/* Claim Card */
.claim-card {
    background: var(--white);
    border: 1px solid var(--light-gray);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: var(--shadow-sm);
}

.claim-card:hover {
    border-color: var(--primary-gold);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.claim-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-md);
}

.claim-card-header h4 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--charcoal);
    margin: 0;
}

.claim-card-header h4 i {
    color: var(--primary-gold);
    margin-right: var(--spacing-sm);
}

/* Claim Status Badge */
.claim-status {
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.claim-status.status-pending,
.claim-status.pending {
    background: rgba(245, 158, 11, 0.1);
    color: #f59e0b;
}

.claim-status.status-submitted,
.claim-status.submitted {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.claim-status.status-in_review,
.claim-status.in_review {
    background: rgba(139, 92, 246, 0.1);
    color: #8b5cf6;
}

.claim-status.status-approved,
.claim-status.approved {
    background: rgba(16, 185, 129, 0.1);
    color: #10b981;
}

.claim-status.status-denied,
.claim-status.denied {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

.claim-status.status-paid,
.claim-status.paid {
    background: rgba(212, 175, 55, 0.1);
    color: var(--dark-gold);
}

.claim-status.status-closed,
.claim-status.closed {
    background: rgba(107, 114, 128, 0.1);
    color: #6b7280;
}

/* Claim Card Details */
.claim-card-details {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm) var(--spacing-lg);
    margin-bottom: var(--spacing-md);
}

.claim-card-details span {
    font-size: 0.85rem;
    color: var(--gray);
}

.claim-card-details span i {
    width: 18px;
    color: var(--primary-gold);
    margin-right: var(--spacing-xs);
}

/* Claim Card Actions */
.claim-card-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-sm);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--light-gray);
}

.claim-card-actions button {
    padding: 6px 12px;
    border: none;
    border-radius: var(--radius-sm);
    font-size: 0.8rem;
    cursor: pointer;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.claim-card-actions .btn-view {
    background: var(--light-gray);
    color: var(--charcoal);
}

.claim-card-actions .btn-view:hover {
    background: var(--gray);
    color: var(--white);
}

.claim-card-actions .btn-edit {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.claim-card-actions .btn-edit:hover {
    background: #3b82f6;
    color: var(--white);
}

/* Claim Detail Modal Styles */
.claim-detail-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--light-gray);
    margin-bottom: var(--spacing-lg);
}

.claim-detail-header h3 {
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--charcoal);
    margin: 0;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.claim-detail-header h3 i {
    color: var(--primary-gold);
}

/* Claim Detail Sections */
.claim-detail-section {
    margin-bottom: var(--spacing-xl);
}

.claim-detail-section h4 {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid var(--primary-gold);
    display: inline-block;
}

.claim-detail-section h4 i {
    color: var(--primary-gold);
    margin-right: var(--spacing-sm);
}

/* Detail Grid */
.detail-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

.detail-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.detail-item label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--gray);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.detail-item span {
    font-size: 0.95rem;
    color: var(--charcoal);
}

.detail-item.full-width {
    grid-column: 1 / -1;
}

/* Documents List */
.documents-section {
    margin-top: var(--spacing-xl);
}

.documents-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-md);
}

.documents-header h4 {
    margin-bottom: 0;
    border-bottom: none;
    padding-bottom: 0;
}

.documents-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.document-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md);
    background: var(--light-gray);
    border-radius: var(--radius-md);
    transition: all 0.2s ease;
}

.document-item:hover {
    background: rgba(212, 175, 55, 0.1);
}

.document-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.document-icon {
    width: 40px;
    height: 40px;
    background: var(--white);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
}

.document-icon.pdf { color: #ef4444; }
.document-icon.image { color: #10b981; }
.document-icon.doc { color: #3b82f6; }
.document-icon.default { color: var(--gray); }

.document-details {
    display: flex;
    flex-direction: column;
}

.document-details .doc-name {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--charcoal);
}

.document-details .doc-meta {
    font-size: 0.75rem;
    color: var(--gray);
}

.document-actions {
    display: flex;
    gap: var(--spacing-sm);
}

.document-actions button {
    width: 32px;
    height: 32px;
    border: none;
    border-radius: var(--radius-sm);
    background: var(--white);
    color: var(--gray);
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.document-actions button:hover {
    background: var(--primary-gold);
    color: var(--white);
}

.document-actions button.btn-delete:hover {
    background: #ef4444;
}

/* Activity Log */
.activity-section {
    margin-top: var(--spacing-xl);
}

.activity-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    position: relative;
    padding-left: var(--spacing-lg);
}

.activity-list::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--light-gray);
}

.activity-item {
    display: flex;
    gap: var(--spacing-md);
    position: relative;
}

.activity-icon {
    position: absolute;
    left: -24px;
    width: 20px;
    height: 20px;
    background: var(--white);
    border: 2px solid var(--light-gray);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    color: var(--gray);
    z-index: 1;
}

.activity-icon.created { border-color: #10b981; color: #10b981; }
.activity-icon.status_change { border-color: #3b82f6; color: #3b82f6; }
.activity-icon.document_uploaded { border-color: #8b5cf6; color: #8b5cf6; }
.activity-icon.note_added { border-color: #f59e0b; color: #f59e0b; }

.activity-content {
    flex: 1;
    background: var(--light-gray);
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
}

.activity-content p {
    font-size: 0.85rem;
    color: var(--charcoal);
    margin: 0;
}

.activity-content .activity-meta {
    font-size: 0.75rem;
    color: var(--gray);
    margin-top: var(--spacing-xs);
}

/* Empty State */
.empty-state-small {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--gray);
}

.empty-state-small i {
    font-size: 2rem;
    color: var(--light-gray);
    margin-bottom: var(--spacing-md);
}

.empty-state-small p {
    font-size: 0.9rem;
    margin: 0;
}

/* File Upload Area */
.file-upload-area {
    border: 2px dashed var(--light-gray);
    border-radius: var(--radius-md);
    padding: var(--spacing-xl);
    text-align: center;
    cursor: pointer;
    transition: all 0.2s ease;
    margin-top: var(--spacing-md);
}

.file-upload-area:hover {
    border-color: var(--primary-gold);
    background: rgba(212, 175, 55, 0.05);
}

.file-upload-area i {
    font-size: 2rem;
    color: var(--gray);
    margin-bottom: var(--spacing-sm);
}

.file-upload-area p {
    color: var(--gray);
    font-size: 0.9rem;
    margin: 0;
}

.file-upload-area input[type="file"] {
    display: none;
}

/* Add Claim Modal Specifics */
#addClaimModal .modal-body,
#claimDetailModal .modal-body {
    max-height: 70vh;
    overflow-y: auto;
}

#addClaimModal .form-group {
    margin-bottom: var(--spacing-md);
}

#addClaimModal .form-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

#addClaimModal .form-section-title {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--charcoal);
    margin-top: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--light-gray);
}

#addClaimModal .form-section-title i {
    color: var(--primary-gold);
    margin-right: var(--spacing-sm);
}

/* Responsive Claims Styles */
@media (max-width: 768px) {
    .claim-card-details {
        grid-template-columns: 1fr;
    }

    .detail-grid {
        grid-template-columns: 1fr;
    }

    .claim-detail-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-sm);
    }

    .documents-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-sm);
    }

    .document-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-sm);
    }

    .document-actions {
        width: 100%;
        justify-content: flex-end;
    }

    #addClaimModal .form-row {
        grid-template-columns: 1fr;
    }

    .activity-list {
        padding-left: var(--spacing-md);
    }

    .activity-icon {
        left: -16px;
    }
}

/* ===== LOGOUT SCREEN STYLES ===== */
.logout-screen {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    z-index: 9998;
    overflow: hidden;
    opacity: 0;
    transform: scale(0.9) rotate(-2deg);
    transition: opacity 0.8s cubic-bezier(0.4, 0.0, 0.2, 1),
                transform 0.8s cubic-bezier(0.4, 0.0, 0.2, 1);
    background: linear-gradient(135deg, #000000 0%, #4A4A4A 25%, #FFD700 50%, #9E9E9E 75%, #FFFFFF 100%);
    background-size: 200% 200%;
    animation: gradientShift 8s ease infinite;
}

@keyframes gradientShift {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

.logout-screen.visible {
    opacity: 1;
    transform: scale(1) rotate(0deg);
}

.logout-container {
    text-align: center;
    padding: var(--spacing-xl);
    backdrop-filter: blur(8px) saturate(180%);
    background: rgba(255, 255, 255, 0.1);
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
    animation: containerFloat 3s ease-in-out infinite;
}

@keyframes containerFloat {
    0%, 100% { transform: translateY(0px); }
    50% { transform: translateY(-10px); }
}

.logout-logo {
    height: 80px;
    margin-bottom: var(--spacing-lg);
    filter: drop-shadow(0 8px 24px rgba(255, 215, 0, 0.4));
    animation: logoPulse 2s ease-in-out infinite;
    transition: transform 0.3s ease;
}

@keyframes logoPulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.05); opacity: 0.9; }
}

.logout-logo:hover {
    transform: scale(1.1) rotate(5deg);
}

.logout-title {
    color: #FFFFFF;
    font-size: 1.95rem;
    margin-bottom: var(--spacing-sm);
    text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.5),
                 0 0 20px rgba(255, 215, 0, 0.3);
    font-weight: 700;
    letter-spacing: 0.5px;
    animation: titleGlow 3s ease-in-out infinite;
}

@keyframes titleGlow {
    0%, 100% { text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.5), 0 0 20px rgba(255, 215, 0, 0.3); }
    50% { text-shadow: 2px 2px 12px rgba(0, 0, 0, 0.6), 0 0 30px rgba(255, 215, 0, 0.5); }
}

.logout-subtitle {
    color: #E0E0E0;
    margin-bottom: var(--spacing-lg);
    font-size: 1.05rem;
    text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.4);
    animation: subtitleFade 4s ease-in-out infinite;
}

@keyframes subtitleFade {
    0%, 100% { opacity: 0.9; }
    50% { opacity: 1; }
}

/* ===== LOGOUT OVERLAY STYLES ===== */
.logout-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #000000 0%, #4A4A4A 20%, #FFD700 40%, #9E9E9E 60%, #FFFFFF 80%, #000000 100%);
    background-size: 400% 400%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.5s ease, visibility 0.5s ease;
    animation: gradientWave 10s ease infinite;
}

@keyframes gradientWave {
    0% { background-position: 0% 50%; }
    25% { background-position: 50% 75%; }
    50% { background-position: 100% 50%; }
    75% { background-position: 50% 25%; }
    100% { background-position: 0% 50%; }
}

.logout-overlay.active {
    opacity: 1;
    visibility: visible;
}

.logout-animation {
    text-align: center;
    padding: 60px 40px;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(12px) saturate(200%);
    border-radius: 24px;
    border: 2px solid rgba(255, 215, 0, 0.3);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4),
                0 0 60px rgba(255, 215, 0, 0.2);
    animation: floatBounce 3s ease-in-out infinite;
    transform-origin: center;
}

@keyframes floatBounce {
    0%, 100% {
        transform: translateY(0px) scale(1);
        box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4), 0 0 60px rgba(255, 215, 0, 0.2);
    }
    50% {
        transform: translateY(-15px) scale(1.02);
        box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5), 0 0 80px rgba(255, 215, 0, 0.4);
    }
}

.logout-overlay-logo {
    width: 200px;
    height: auto;
    margin: 0 auto 30px;
    display: block;
    filter: drop-shadow(0 0 20px rgba(255, 215, 0, 0.6))
            drop-shadow(0 0 40px rgba(255, 255, 255, 0.3));
    animation: logoGlow 2s ease-in-out infinite;
}

@keyframes logoGlow {
    0%, 100% {
        filter: drop-shadow(0 0 20px rgba(255, 215, 0, 0.6))
                drop-shadow(0 0 40px rgba(255, 255, 255, 0.3));
        opacity: 1;
    }
    50% {
        filter: drop-shadow(0 0 30px rgba(255, 215, 0, 0.9))
                drop-shadow(0 0 60px rgba(255, 255, 255, 0.5));
        opacity: 0.95;
    }
}

.logout-spinner {
    width: 80px;
    height: 80px;
    margin: 0 auto 30px;
    border: 6px solid rgba(255, 255, 255, 0.2);
    border-top: 6px solid #FFD700;
    border-right: 6px solid #FFFFFF;
    border-radius: 50%;
    animation: spin 1s linear infinite, pulseGlow 2s ease-in-out infinite;
    box-shadow: 0 0 20px rgba(255, 215, 0, 0.5),
                inset 0 0 20px rgba(255, 215, 0, 0.3);
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

@keyframes pulseGlow {
    0%, 100% {
        box-shadow: 0 0 20px rgba(255, 215, 0, 0.5),
                    inset 0 0 20px rgba(255, 215, 0, 0.3);
    }
    50% {
        box-shadow: 0 0 40px rgba(255, 215, 0, 0.8),
                    inset 0 0 30px rgba(255, 215, 0, 0.5);
    }
}

.logout-animation h2 {
    color: #FFFFFF;
    font-size: 2rem;
    margin-bottom: 16px;
    font-weight: 700;
    letter-spacing: 1px;
    text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.6),
                 0 0 30px rgba(255, 215, 0, 0.4);
    animation: textShimmer 3s ease-in-out infinite;
}

@keyframes textShimmer {
    0%, 100% {
        text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.6), 0 0 30px rgba(255, 215, 0, 0.4);
        opacity: 1;
    }
    50% {
        text-shadow: 2px 2px 15px rgba(0, 0, 0, 0.7), 0 0 45px rgba(255, 215, 0, 0.6);
        opacity: 0.95;
    }
}

.logout-animation p {
    color: #E0E0E0;
    font-size: 1.2rem;
    margin: 0;
    text-shadow: 1px 1px 6px rgba(0, 0, 0, 0.5);
    animation: textFadeInOut 4s ease-in-out infinite;
}

@keyframes textFadeInOut {
    0%, 100% { opacity: 0.8; transform: translateY(0px); }
    50% { opacity: 1; transform: translateY(-3px); }
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .logout-animation {
        padding: 40px 30px;
        border-radius: 20px;
    }

    .logout-overlay-logo {
        width: 150px;
        margin-bottom: 20px;
    }

    .logout-spinner {
        width: 60px;
        height: 60px;
        margin-bottom: 20px;
        border-width: 5px;
    }

    .logout-animation h2 {
        font-size: 1.6rem;
    }

    .logout-animation p {
        font-size: 1rem;
    }
}

