/* ===== 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(135deg, #ffffff 0%, #f8f9fa 50%, #f0f2f5 100%);
    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: 180px;
    height: 180px;
    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: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    margin-top: -20px;
}

.logo-container::after {
    content: '';
    position: absolute;
    width: 160px;
    height: 160px;
    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: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    margin-top: -20px;
    opacity: 0.8;
}

@keyframes spinRing {
    from { transform: translate(-50%, -50%) rotate(0deg); }
    to { transform: translate(-50%, -50%) rotate(360deg); }
}

.impactiq-logo {
    width: 120px;
    height: 120px;
    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: 140px;
        height: 140px;
    }

    .logo-container::after {
        width: 120px;
        height: 120px;
    }

    .impactiq-logo {
        width: 90px;
        height: 90px;
    }

    .logo-text {
        font-size: 2rem;
    }

    .loading-text {
        font-size: 0.875rem;
        margin-top: var(--spacing-lg);
    }
}

@media (max-width: 375px) {
    .logo-container::before {
        width: 120px;
        height: 120px;
    }

    .logo-container::after {
        width: 100px;
        height: 100px;
    }

    .impactiq-logo {
        width: 70px;
        height: 70px;
    }

    .logo-text {
        font-size: 1.75rem;
    }

    .loading-text {
        font-size: 0.75rem;
    }
}

/* ===== 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);
}

.nav-logo {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.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: 80px;
    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 h2,
.recent-activity h2 {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: var(--spacing-md);
}

.action-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.action-btn {
    background: var(--white);
    border: 2px solid var(--light-gray);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-sm);
    cursor: pointer;
    transition: all 0.2s;
    box-shadow: var(--shadow-sm);
}

.action-btn:active {
    transform: translateY(2px);
    box-shadow: none;
}

.action-btn i {
    font-size: 2rem;
    color: var(--primary-gold);
}

.action-btn span {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--charcoal);
    text-align: center;
}

/* ===== 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: var(--white);
    border-top: 1px solid var(--light-gray);
    padding: var(--spacing-sm);
    display: flex;
    justify-content: space-around;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
    z-index: 100;
}

.nav-btn {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.25rem;
    padding: var(--spacing-sm);
    border: none;
    background: none;
    color: var(--gray);
    cursor: pointer;
    transition: all 0.2s;
}

.nav-btn i {
    font-size: 1.5rem;
}

.nav-btn span {
    font-size: 0.7rem;
    font-weight: 600;
}

.nav-btn.active {
    color: var(--primary-gold);
}

/* ===== 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 {
        grid-template-columns: repeat(4, 1fr);
    }

    .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 {
    display: none; /* Logo shown on loading screen only */
}

@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;
}

/* 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: var(--charcoal);
    border: 1px solid rgba(212, 175, 55, 0.3);
    border-radius: var(--radius-xl);
    width: 100%;
    max-width: 600px;
    max-height: 90vh;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
    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: rgba(212, 175, 55, 0.1);
    border-bottom: 1px solid rgba(212, 175, 55, 0.2);
}

.modal-header h2 {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1.25rem;
    color: var(--gold);
    margin: 0;
}

.modal-header h2 i {
    font-size: 1.5rem;
}

.modal-close-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    color: var(--light-gray);
    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.2);
    color: #ef4444;
}

.modal-body {
    padding: var(--spacing-xl);
    overflow-y: auto;
    max-height: calc(90vh - 80px);
}

/* =============================================================================
   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: 700px;
    max-height: 90vh;
}

.edit-lead-modal .modal-body {
    padding: 0;
    overflow-y: auto;
    max-height: calc(90vh - 70px);
}

#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, var(--charcoal), #2a2a2a);
    padding: var(--spacing-lg);
    color: var(--white);
}

.schedule-lead-info .lead-summary h3 {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
    color: var(--white);
}

.schedule-lead-info .lead-summary p {
    font-size: 0.9rem;
    color: var(--light-gray);
}

/* 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);
}

.contact-lead-info {
    background: linear-gradient(135deg, var(--charcoal), #2a2a2a);
    padding: var(--spacing-lg);
    color: var(--white);
    text-align: center;
}

.contact-lead-info h3 {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
    color: var(--white);
}

.contact-lead-info p {
    font-size: 0.9rem;
    color: var(--light-gray);
}

/* 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;
    }
}

/* =============================================================================
   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%;
    }
}
