﻿/* ============================================================================
   OUTREACH MODULE STYLES - outreach.css
   Modern, polished UI for campaign management
   ============================================================================ */

/* ============================================================================
   CSS VARIABLES
   ============================================================================ */
:root {
    --outreach-primary: #6366f1;
    --outreach-primary-dark: #4f46e5;
    --outreach-success: #22c55e;
    --outreach-warning: #f59e0b;
    --outreach-danger: #ef4444;
    --outreach-info: #3b82f6;
    --outreach-bg: #ffffff;
    --outreach-bg-secondary: #f8fafc;
    --outreach-border: #e2e8f0;
    --outreach-text: #1e293b;
    --outreach-text-muted: #64748b;
    --outreach-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --outreach-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

[data-theme="dark"] {
    --outreach-bg: #1e293b;
    --outreach-bg-secondary: #0f172a;
    --outreach-border: #334155;
    --outreach-text: #f1f5f9;
    --outreach-text-muted: #94a3b8;
}

/* ============================================================================
   OUTREACH MODAL
   ============================================================================ */
.outreach-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    display: none;
    align-items: center;
    justify-content: center;
}

    .outreach-modal.active {
        display: flex;
    }

.outreach-modal-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
}

.outreach-modal-container {
    position: relative;
    width: 95%;
    max-width: 900px;
    max-height: 90vh;
    background: var(--outreach-bg);
    border-radius: 16px;
    box-shadow: var(--outreach-shadow-lg);
    overflow: hidden;
    animation: modalSlideIn 0.3s ease;
}

@keyframes modalSlideIn {
    from {
        opacity: 0;
        transform: translateY(20px) scale(0.98);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.outreach-modal-content {
    max-height: 90vh;
    overflow-y: auto;
}

/* Expanded modal state */
.outreach-modal-expanded .outreach-modal-container {
    max-width: 95vw !important;
    width: 95vw !important;
    max-height: 95vh !important;
    height: 95vh !important;
    border-radius: 8px;
    transition: all 0.3s ease;
}

.outreach-modal-expanded .outreach-modal-content {
    max-height: 95vh !important;
    height: 100%;
}

.outreach-modal-expanded .crp-leads-container,
.outreach-modal-expanded .cd-campaigns-grid,
.outreach-modal-expanded .ca-section {
    max-height: calc(95vh - 280px) !important;
}

/* Mobile full screen expansion */
@media (max-width: 768px) {
    .outreach-modal-expanded .outreach-modal-container {
        max-width: 100vw !important;
        width: 100vw !important;
        max-height: 100vh !important;
        height: 100vh !important;
        border-radius: 0 !important;
    }
}

.outreach-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px;
    gap: 16px;
}

.outreach-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--outreach-border);
    border-top-color: var(--outreach-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

/* ============================================================================
   CAMPAIGN PREPARATION CARD (in chat)
   ============================================================================ */
.outreach-prep-card {
    background: var(--outreach-bg);
    border: 1px solid var(--outreach-border);
    border-radius: 16px;
    padding: 20px;
    max-width: 450px;
    box-shadow: var(--outreach-shadow);
}

.opc-header {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 20px;
}

.opc-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .opc-icon.preparing {
        background: linear-gradient(135deg, #818cf8, #6366f1);
        color: white;
    }

    .opc-icon.ready {
        background: linear-gradient(135deg, #4ade80, #22c55e);
        color: white;
    }

    .opc-icon .material-icons {
        font-size: 24px;
    }

        .opc-icon .material-icons.spin {
            animation: spin 1.5s linear infinite;
        }

.opc-title-section {
    flex: 1;
}

.opc-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--outreach-text);
    margin: 0 0 4px 0;
}

.opc-subtitle {
    font-size: 13px;
    color: var(--outreach-text-muted);
    margin: 0;
}

.opc-progress-section {
    margin-bottom: 20px;
}

.opc-progress-bar {
    height: 8px;
    background: var(--outreach-border);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 8px;
}

.opc-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, #6366f1, #8b5cf6);
    border-radius: 4px;
    transition: width 0.5s ease;
}

.opc-progress-text {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: var(--outreach-text-muted);
}

.opc-steps {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 20px;
}

.opc-step {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--outreach-bg-secondary);
    border-radius: 8px;
    font-size: 13px;
    color: var(--outreach-text-muted);
    transition: all 0.3s ease;
}

    .opc-step .material-icons {
        font-size: 18px;
    }

    .opc-step.active {
        background: linear-gradient(135deg, #ede9fe, #ddd6fe);
        color: #6366f1;
    }

[data-theme="dark"] .opc-step.active {
    background: linear-gradient(135deg, #3730a3, #4338ca);
    color: #a5b4fc;
}

.opc-step.active .material-icons {
    animation: pulse 1.5s ease infinite;
}

.opc-step.complete {
    background: linear-gradient(135deg, #dcfce7, #bbf7d0);
    color: #166534;
}

[data-theme="dark"] .opc-step.complete {
    background: linear-gradient(135deg, #14532d, #166534);
    color: #4ade80;
}

/* Step loading indicator */
.step-loading {
    display: inline-flex;
    align-items: center;
    margin-left: auto;
    padding-left: 8px;
}

.step-loading .material-icons {
    font-size: 16px;
    animation: spin 1s linear infinite;
}

/* Step progress text (e.g., "2 of 5") */
.step-progress-text {
    font-size: 11px;
    font-weight: 600;
    margin-left: auto;
    padding: 2px 8px;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 10px;
}

[data-theme="dark"] .step-progress-text {
    background: rgba(0, 0, 0, 0.2);
}

.opc-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}

.opc-stat {
    text-align: center;
    padding: 12px;
    background: var(--outreach-bg-secondary);
    border-radius: 10px;
}

.opc-stat-value {
    display: block;
    font-size: 24px;
    font-weight: 700;
    color: var(--outreach-primary);
}

.opc-stat-label {
    display: block;
    font-size: 11px;
    color: var(--outreach-text-muted);
    margin-top: 2px;
}

.opc-actions {
    display: flex;
    gap: 10px;
}

.opc-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .opc-btn.primary {
        background: linear-gradient(135deg, #6366f1, #4f46e5);
        color: white;
    }

        .opc-btn.primary:hover {
            background: linear-gradient(135deg, #4f46e5, #4338ca);
            transform: translateY(-1px);
        }

    .opc-btn.secondary {
        background: var(--outreach-bg-secondary);
        color: var(--outreach-text-muted);
        border: 1px solid var(--outreach-border);
    }

        .opc-btn.secondary:hover {
            background: var(--outreach-border);
        }

/* ============================================================================
   OUTREACH LEADS CARDS (in campaign preparation card)
   ============================================================================ */
.opc-leads-section {
    margin-top: 12px;
    border: 1px solid var(--outreach-border, #e5e7eb);
    border-radius: 10px;
    overflow: hidden;
}

.opc-leads-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
    cursor: pointer;
    background: var(--outreach-bg-secondary, #f9fafb);
    transition: background 0.2s;
    user-select: none;
}

.opc-leads-toggle:hover {
    background: var(--outreach-border, #e5e7eb);
}

.opc-leads-toggle-info {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--outreach-text, #374151);
    flex-wrap: wrap;
}

.opc-leads-toggle-info .material-icons {
    font-size: 18px;
    color: #6366f1;
}

.opc-leads-intent-summary {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--outreach-text-muted, #6b7280);
}

.opc-intent-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    display: inline-block;
    margin-left: 4px;
}

.opc-intent-dot.high { background: #10b981; }
.opc-intent-dot.medium { background: #f59e0b; }
.opc-intent-dot.low { background: #9ca3af; }

.opc-email-count {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: 12px;
    color: #059669;
}

.opc-leads-chevron {
    font-size: 20px;
    color: var(--outreach-text-muted, #6b7280);
    transition: transform 0.3s;
}

.opc-leads-cards-container {
    overflow: hidden;
    transition: max-height 0.35s ease;
    max-height: 400px;
    overflow-y: auto;
}

.opc-leads-cards-container.collapsed {
    max-height: 0;
}

.opc-lead-card {
    padding: 10px 14px;
    border-bottom: 1px solid var(--outreach-border, #e5e7eb);
    transition: background 0.15s;
}

.opc-lead-card:last-child {
    border-bottom: none;
}

.opc-lead-card:hover {
    background: var(--outreach-bg-secondary, #f9fafb);
}

.opc-lead-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
}

.opc-lead-info {
    flex: 1;
    min-width: 0;
}

.opc-lead-name {
    font-weight: 600;
    font-size: 13px;
    color: var(--outreach-text, #1f2937);
    display: flex;
    align-items: center;
}

.opc-lead-title {
    font-size: 12px;
    color: var(--outreach-text-muted, #6b7280);
    margin-top: 1px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 280px;
}

.opc-lead-company {
    font-size: 12px;
    color: var(--outreach-text-muted, #6b7280);
    display: flex;
    align-items: center;
    gap: 3px;
    margin-top: 2px;
}

.opc-lead-intent {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 4px 8px;
    border-radius: 8px;
    font-size: 11px;
    font-weight: 600;
    flex-shrink: 0;
    min-width: 48px;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.opc-lead-intent.clickable:hover {
    transform: scale(1.08);
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}

.opc-lead-intent-score {
    font-size: 14px;
    font-weight: 700;
}

.opc-lead-intent-label {
    font-size: 9px;
    letter-spacing: 0.5px;
    opacity: 0.8;
}

.opc-lead-meta {
    display: flex;
    gap: 6px;
    margin-top: 6px;
    flex-wrap: wrap;
}

.opc-lead-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 7px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 500;
}

.opc-lead-badge.email {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.opc-lead-badge.no-email {
    background: rgba(245, 158, 11, 0.1);
    color: #d97706;
}

.opc-lead-badge.location {
    background: rgba(99, 102, 241, 0.08);
    color: #6366f1;
}

/* ============================================================================
   CAMPAIGN REVIEW PANEL
   ============================================================================ */
.campaign-review-panel {
    display: flex;
    flex-direction: column;
    height: 90vh;
    max-height: 90vh;
}

.crp-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 24px;
    border-bottom: 1px solid var(--outreach-border);
    background: var(--outreach-bg);
    position: sticky;
    top: 0;
    z-index: 10;
}

.crp-header-info {
    flex: 1;
}

.crp-title {
    font-size: 18px;
    font-weight: 700;
    color: var(--outreach-text);
    margin: 0 0 6px 0;
}

.crp-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 13px;
}

.crp-status {
    padding: 4px 10px;
    border-radius: 12px;
    font-weight: 600;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

    .crp-status.status-draft,
    .status-draft {
        background: #f1f5f9;
        color: #475569;
    }

    .crp-status.status-ready,
    .status-ready {
        background: #dcfce7;
        color: #15803d;
    }

    .crp-status.status-partialapproved,
    .status-partialapproved {
        background: #fef3c7;
        color: #b45309;
    }

    .crp-status.status-approved,
    .status-approved {
        background: #dcfce7;
        color: #15803d;
    }

    .crp-status.status-rejected,
    .status-rejected {
        background: #fee2e2;
        color: #b91c1c;
    }

    .crp-status.status-edited,
    .status-edited {
        background: #dbeafe;
        color: #1e40af;
    }

    .crp-status.status-active,
    .status-active {
        background: #ede9fe;
        color: #6d28d9;
    }

    .crp-status.status-completed,
    .status-completed {
        background: #d1fae5;
        color: #047857;
    }

    .crp-status.status-pending,
    .status-pending {
        background: #fef3c7;
        color: #b45309;
    }

.crp-count {
    color: var(--outreach-text-muted);
}

.crp-expires {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--outreach-warning);
    font-size: 12px;
}

    .crp-expires .material-icons {
        font-size: 14px;
    }

.crp-header-actions {
    display: flex;
    gap: 8px;
}

.crp-btn.icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--outreach-bg-secondary);
    border: 1px solid var(--outreach-border);
    color: var(--outreach-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
}

    .crp-btn.icon:hover {
        background: var(--outreach-border);
        color: var(--outreach-text);
    }

/* Stats Bar - Compact inline design */
.crp-stats-bar {
    display: flex;
    gap: 8px;
    padding: 12px 24px;
    background: var(--outreach-bg-secondary);
    border-bottom: 1px solid var(--outreach-border);
}

.crp-stat-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--outreach-bg);
    border-radius: 8px;
    border: 1px solid var(--outreach-border);
}

    .crp-stat-item.approved {
        background: #f0fdf4;
        border-color: #86efac;
    }

    .crp-stat-item.approved .crp-stat-value {
        color: #16a34a;
    }

    .crp-stat-item.pending {
        background: #fffbeb;
        border-color: #fcd34d;
    }

    .crp-stat-item.pending .crp-stat-value {
        color: #d97706;
    }

    .crp-stat-item.rejected {
        background: #fef2f2;
        border-color: #fca5a5;
    }

    .crp-stat-item.rejected .crp-stat-value {
        color: #dc2626;
    }

.crp-stat-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--outreach-primary);
    line-height: 1;
}

.crp-stat-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    color: var(--outreach-text-muted);
    font-weight: 500;
}

/* Dark mode stat items */
[data-theme="dark"] .crp-stat-item.approved {
    background: #052e16;
    border-color: #22c55e;
}

[data-theme="dark"] .crp-stat-item.pending {
    background: #451a03;
    border-color: #f59e0b;
}

[data-theme="dark"] .crp-stat-item.rejected {
    background: #450a0a;
    border-color: #ef4444;
}

/* Bulk Actions */
.crp-bulk-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 24px;
    background: var(--outreach-bg);
    border-bottom: 1px solid var(--outreach-border);
}

.crp-select-all {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
}

    .crp-select-all input[type="checkbox"] {
        width: 16px;
        height: 16px;
        accent-color: var(--outreach-primary);
    }

.crp-selected-count {
    color: var(--outreach-text-muted);
    font-size: 11px;
}

.crp-bulk-btns {
    display: flex;
    gap: 8px;
}

.crp-bulk-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border: 1px solid transparent;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .crp-bulk-btn.approve {
        background: #dcfce7;
        color: #15803d;
        border-color: #86efac;
    }

        .crp-bulk-btn.approve:hover {
            background: #22c55e;
            color: white;
        }

    .crp-bulk-btn.reject {
        background: #fee2e2;
        color: #b91c1c;
        border-color: #fca5a5;
    }

        .crp-bulk-btn.reject:hover {
            background: #ef4444;
            color: white;
        }

    .crp-bulk-btn .material-icons {
        font-size: 18px;
    }

/* Leads Container */
.crp-leads-container {
    flex: 1;
    overflow-y: auto;
    padding: 12px 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.crp-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px;
    color: var(--outreach-text-muted);
}

    .crp-empty .material-icons {
        font-size: 48px;
        margin-bottom: 12px;
        opacity: 0.5;
    }

/* Lead Cards */
.crp-lead-card {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    gap: 12px;
    padding: 10px 14px;
    background: var(--outreach-bg);
    border: 1px solid var(--outreach-border);
    border-radius: 8px;
    transition: all 0.2s ease;
    border-left: 3px solid var(--outreach-warning);
}

    .crp-lead-card:hover {
        border-color: var(--outreach-primary);
        border-left-color: var(--outreach-primary);
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    }

    /* APPROVED - Green theme */
    .crp-lead-card.approved {
        background: #f0fdf4;
        border-color: #86efac;
        border-left: 3px solid #22c55e;
    }

    .crp-lead-card.approved:hover {
        border-color: #22c55e;
        border-left-color: #22c55e;
    }

    /* REJECTED - Red theme */
    .crp-lead-card.rejected {
        background: #fef2f2;
        border-color: #fca5a5;
        border-left: 3px solid #ef4444;
        opacity: 0.7;
    }

    .crp-lead-card.rejected:hover {
        border-color: #ef4444;
        border-left-color: #ef4444;
    }

    /* PENDING - Yellow/Orange theme */
    .crp-lead-card.pending {
        background: #fffbeb;
        border-color: #fcd34d;
        border-left: 3px solid #f59e0b;
    }

    .crp-lead-card.pending:hover {
        border-color: #f59e0b;
        border-left-color: #f59e0b;
    }

    /* EDITED - Blue theme */
    .crp-lead-card.edited {
        background: #eff6ff;
        border-color: #93c5fd;
        border-left: 3px solid #3b82f6;
    }

    .crp-lead-card.edited:hover {
        border-color: #3b82f6;
        border-left-color: #3b82f6;
    }

/* Dark mode lead cards */
[data-theme="dark"] .crp-lead-card.approved {
    background: #052e16;
    border-color: #22c55e;
}

[data-theme="dark"] .crp-lead-card.rejected {
    background: #450a0a;
    border-color: #ef4444;
}

[data-theme="dark"] .crp-lead-card.pending {
    background: #451a03;
    border-color: #f59e0b;
}

[data-theme="dark"] .crp-lead-card.edited {
    background: #1e3a5f;
    border-color: #3b82f6;
}

.crp-lead-select {
    display: flex;
    align-items: flex-start;
    padding-top: 4px;
}

    .crp-lead-select input[type="checkbox"] {
        width: 18px;
        height: 18px;
        accent-color: var(--outreach-primary);
    }

.crp-lead-info {
    min-width: 200px;
}

.crp-lead-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
}

.crp-lead-position {
    background: var(--outreach-bg-secondary);
    color: var(--outreach-text-muted);
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
}

.crp-lead-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--outreach-text);
    margin: 0;
}

.crp-lead-status {
    font-size: 9px;
    padding: 3px 8px;
    border-radius: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

    .crp-lead-status.status-approved {
        background: #22c55e;
        color: white;
    }

    .crp-lead-status.status-pending {
        background: #f59e0b;
        color: white;
    }

    .crp-lead-status.status-rejected {
        background: #ef4444;
        color: white;
    }

    .crp-lead-status.status-edited {
        background: #3b82f6;
        color: white;
    }

.crp-lead-meta {
    font-size: 12px;
    color: var(--outreach-text-muted);
    margin-bottom: 8px;
}

.crp-lead-email {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--outreach-text-muted);
}

    .crp-lead-email .material-icons {
        font-size: 14px;
    }

    .crp-lead-email.missing {
        color: var(--outreach-danger);
    }

.email-confidence {
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 600;
}

    .email-confidence.high {
        background: #dcfce7;
        color: #166534;
    }

    .email-confidence.medium {
        background: #fef3c7;
        color: #92400e;
    }

    .email-confidence.low {
        background: #fee2e2;
        color: #991b1b;
    }

/* Source Data (Post/Reaction reference) */
.crp-lead-source {
    margin: 8px 0;
    padding: 8px 10px;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.08) 0%, rgba(99, 102, 241, 0.08) 100%);
    border-radius: 8px;
    border-left: 3px solid var(--outreach-primary);
}

.crp-source-badge {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 4px;
}

    .crp-source-badge .material-icons {
        font-size: 16px;
        color: var(--outreach-primary);
    }

.crp-source-type {
    font-size: 11px;
    font-weight: 600;
    color: var(--outreach-primary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.crp-source-link {
    margin-left: auto;
    font-size: 11px;
    color: var(--outreach-primary);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 4px;
}

    .crp-source-link:hover {
        text-decoration: underline;
    }

.crp-source-content {
    font-size: 12px;
    color: var(--outreach-text-secondary);
    line-height: 1.4;
    font-style: italic;
}

/* Email Preview */
.crp-lead-email-preview {
    flex: 1;
    padding: 8px 10px;
    background: var(--outreach-bg-secondary);
    border-radius: 6px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: all 0.2s ease;
}

    .crp-lead-email-preview:hover {
        background: var(--outreach-border);
    }

        .crp-lead-email-preview:hover .crp-email-preview-overlay {
            opacity: 1;
        }

.crp-email-subject {
    font-size: 12px;
    margin-bottom: 4px;
}

    .crp-email-subject strong {
        color: var(--outreach-text-muted);
        font-weight: 500;
    }

.crp-email-body-preview {
    font-size: 11px;
    color: var(--outreach-text-muted);
    line-height: 1.4;
    max-height: 40px;
    overflow: hidden;
}

.crp-email-preview-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(99, 102, 241, 0.9);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: white;
    font-size: 13px;
    font-weight: 500;
    opacity: 0;
    transition: opacity 0.2s ease;
}

/* Lead Actions */
.crp-lead-actions {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.crp-lead-btn {
    width: 30px;
    height: 30px;
    border: none;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .crp-lead-btn .material-icons {
        font-size: 16px;
    }

    .crp-lead-btn.approve {
        background: #dcfce7;
        color: #166534;
    }

        .crp-lead-btn.approve:hover {
            background: #22c55e;
            color: white;
        }

    .crp-lead-btn.reject {
        background: #fee2e2;
        color: #991b1b;
    }

        .crp-lead-btn.reject:hover {
            background: #ef4444;
            color: white;
        }

    .crp-lead-btn.undo,
    .crp-lead-btn.restore {
        background: var(--outreach-bg-secondary);
        color: var(--outreach-text-muted);
    }

        .crp-lead-btn.undo:hover,
        .crp-lead-btn.restore:hover {
            background: var(--outreach-border);
            color: var(--outreach-text);
        }

    .crp-lead-btn.edit {
        background: #e0e7ff;
        color: #4f46e5;
    }

        .crp-lead-btn.edit:hover {
            background: #6366f1;
            color: white;
        }

    .crp-lead-btn.regenerate {
        background: var(--outreach-bg-secondary);
        color: var(--outreach-text-muted);
    }

        .crp-lead-btn.regenerate:hover {
            background: var(--outreach-primary);
            color: white;
        }

/* Follow-ups badge */
.crp-lead-followups {
    grid-column: 2 / -1;
    display: flex;
    align-items: center;
    gap: 6px;
    padding-top: 8px;
    border-top: 1px solid var(--outreach-border);
    font-size: 12px;
    color: var(--outreach-text-muted);
}

    .crp-lead-followups .material-icons {
        font-size: 14px;
        color: var(--outreach-info);
    }

/* Footer */
.crp-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 20px;
    background: var(--outreach-bg);
    border-top: 1px solid var(--outreach-border);
    position: sticky;
    bottom: 0;
    z-index: 10;
}

.crp-footer-info {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--outreach-text-muted);
    background: var(--outreach-bg-secondary);
    padding: 6px 12px;
    border-radius: 6px;
}

    .crp-footer-info .material-icons {
        font-size: 16px;
        color: var(--outreach-primary);
    }

.crp-footer-actions {
    display: flex;
    gap: 8px;
}

.crp-action-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border: none;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
    overflow: hidden;
}

    .crp-action-btn .material-icons {
        font-size: 16px;
    }

    /* Primary button - Send emails */
    .crp-action-btn.primary {
        background: linear-gradient(135deg, #22c55e, #16a34a);
        color: white;
        box-shadow: 0 2px 6px rgba(34, 197, 94, 0.3);
    }

        .crp-action-btn.primary:hover:not(:disabled) {
            background: linear-gradient(135deg, #16a34a, #15803d);
            box-shadow: 0 3px 8px rgba(34, 197, 94, 0.4);
        }

        .crp-action-btn.primary:disabled {
            opacity: 0.5;
            cursor: not-allowed;
            box-shadow: none;
        }

    /* Secondary button - Approve all */
    .crp-action-btn.secondary {
        background: var(--outreach-bg-secondary);
        color: var(--outreach-text);
        border: 1px solid var(--outreach-border);
    }

        .crp-action-btn.secondary:hover {
            background: var(--outreach-border);
            border-color: var(--outreach-primary);
        }

        .crp-action-btn.secondary .material-icons {
            color: var(--outreach-primary);
        }

[data-theme="dark"] .crp-action-btn.secondary {
    background: linear-gradient(135deg, #334155, #1e293b);
    border-color: #475569;
}

[data-theme="dark"] .crp-action-btn.secondary:hover {
    background: linear-gradient(135deg, #475569, #334155);
}

/* ============================================================================
   EMAIL EDITOR MODAL
   ============================================================================ */
.email-editor-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10001;
    display: none;
    align-items: center;
    justify-content: center;
}

    .email-editor-modal.active {
        display: flex;
    }

.email-editor-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
}

.email-editor-container {
    position: relative;
    width: 95%;
    max-width: 700px;
    max-height: 90vh;
    overflow-y: auto;
    overflow-x: hidden;
}

.email-editor-panel {
    background: var(--outreach-bg);
    border-radius: 16px;
    box-shadow: var(--outreach-shadow-lg);
    animation: modalSlideIn 0.25s ease;
    overflow: visible;
    display: flex;
    flex-direction: column;
}

.eep-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid var(--outreach-border);
}

.eep-header-info h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--outreach-text);
    margin: 0 0 4px 0;
}

.eep-header-info p {
    font-size: 13px;
    color: var(--outreach-text-muted);
    margin: 0;
}

.eep-close {
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 8px;
    background: var(--outreach-bg-secondary);
    color: var(--outreach-text-muted);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

    .eep-close:hover {
        background: var(--outreach-border);
        color: var(--outreach-text);
    }

.eep-recipient {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: var(--outreach-bg-secondary);
    font-size: 13px;
    color: var(--outreach-text-muted);
}

    .eep-recipient .material-icons {
        font-size: 16px;
    }

.eep-field {
    padding: 16px 24px;
}

    .eep-field label {
        display: block;
        font-size: 13px;
        font-weight: 600;
        color: var(--outreach-text);
        margin-bottom: 8px;
    }

    .eep-field input[type="text"],
    .eep-field textarea {
        width: 100%;
        padding: 12px 14px;
        border: 1px solid var(--outreach-border);
        border-radius: 10px;
        font-size: 14px;
        font-family: inherit;
        background: var(--outreach-bg);
        color: var(--outreach-text);
        transition: border-color 0.2s ease;
    }

        .eep-field input[type="text"]:focus,
        .eep-field textarea:focus {
            outline: none;
            border-color: var(--outreach-primary);
        }

    .eep-field textarea {
        resize: vertical;
        min-height: 200px;
        line-height: 1.6;
    }

.eep-field-hint {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    font-size: 11px;
    color: var(--outreach-text-muted);
}

    .eep-field-hint .material-icons {
        font-size: 14px;
        color: var(--outreach-warning);
    }

.eep-field-actions {
    display: flex;
    gap: 8px;
    margin-top: 10px;
}

.eep-action-btn {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 6px 10px;
    border: 1px solid var(--outreach-border);
    border-radius: 6px;
    background: var(--outreach-bg);
    color: var(--outreach-text-muted);
    font-size: 12px;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .eep-action-btn:hover {
        background: var(--outreach-primary);
        border-color: var(--outreach-primary);
        color: white;
    }

    .eep-action-btn .material-icons {
        font-size: 14px;
    }

.eep-personalization {
    padding: 0 24px 16px;
}

    .eep-personalization h4 {
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 13px;
        font-weight: 600;
        color: var(--outreach-text);
        margin: 0 0 10px 0;
    }

        .eep-personalization h4 .material-icons {
            font-size: 16px;
            color: var(--outreach-warning);
        }

    .eep-personalization ul {
        margin: 0;
        padding-left: 20px;
        font-size: 12px;
        color: var(--outreach-text-muted);
        line-height: 1.8;
    }

/* Reference link section in email editor */
.eep-reference {
    padding: 0 24px 16px;
}

    .eep-reference h4 {
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 13px;
        font-weight: 600;
        color: var(--outreach-text);
        margin: 0 0 10px 0;
    }

        .eep-reference h4 .material-icons {
            font-size: 16px;
            color: var(--outreach-primary);
        }

.eep-reference-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    padding: 8px 12px;
    background: var(--outreach-bg-secondary);
    border-radius: 6px;
    border: 1px solid var(--outreach-border);
}

.eep-reference-label {
    font-weight: 600;
    color: var(--outreach-text);
    white-space: nowrap;
}

.eep-reference-link {
    color: var(--outreach-primary);
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

    .eep-reference-link:hover {
        text-decoration: underline;
    }

.eep-reference-none {
    font-size: 12px;
    color: var(--outreach-text-muted);
    font-style: italic;
    margin: 0;
}

.eep-reference-empty {
    opacity: 0.7;
}

.eep-footer {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    padding: 16px 24px;
    border-top: 1px solid var(--outreach-border);
    background: var(--outreach-bg-secondary);
}

.eep-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .eep-btn.primary {
        background: linear-gradient(135deg, #22c55e, #16a34a);
        color: white;
    }

        .eep-btn.primary:hover {
            background: linear-gradient(135deg, #16a34a, #15803d);
        }

    .eep-btn.secondary {
        background: var(--outreach-bg);
        color: var(--outreach-text);
        border: 1px solid var(--outreach-border);
    }

        .eep-btn.secondary:hover {
            background: var(--outreach-border);
        }

/* ============================================================================
   CAMPAIGN EXECUTION CARD
   ============================================================================ */
.outreach-execution-card {
    background: var(--outreach-bg);
    border: 1px solid var(--outreach-border);
    border-radius: 16px;
    padding: 20px;
    max-width: 450px;
    box-shadow: var(--outreach-shadow);
}

.oec-header {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 16px;
}

.oec-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .oec-icon.success {
        background: linear-gradient(135deg, #4ade80, #22c55e);
        color: white;
    }

    .oec-icon .material-icons {
        font-size: 24px;
    }

.oec-title-section h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--outreach-text);
    margin: 0 0 4px 0;
}

.oec-title-section p {
    font-size: 13px;
    color: var(--outreach-text-muted);
    margin: 0;
}

.oec-stats {
    display: flex;
    gap: 16px;
    margin-bottom: 16px;
}

.oec-stat {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--outreach-text-muted);
}

    .oec-stat .material-icons {
        font-size: 16px;
    }

    .oec-stat.error {
        color: var(--outreach-danger);
    }

.oec-timeline {
    background: var(--outreach-bg-secondary);
    border-radius: 10px;
    padding: 12px;
    margin-bottom: 16px;
}

.oec-timeline-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    font-size: 13px;
    color: var(--outreach-text-muted);
}

    .oec-timeline-item .material-icons {
        font-size: 16px;
        color: var(--outreach-success);
    }

    .oec-timeline-item:not(:last-child) {
        border-bottom: 1px dashed var(--outreach-border);
    }

.oec-actions {
    display: flex;
    gap: 10px;
}

.oec-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    background: var(--outreach-primary);
    color: white;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .oec-btn:hover {
        background: var(--outreach-primary-dark);
        transform: translateY(-1px);
    }

/* ============================================================================
   CAMPAIGNS DASHBOARD
   ============================================================================ */
.campaigns-dashboard {
    min-height: 400px;
}

.cd-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid var(--outreach-border);
}

    .cd-header h2 {
        display: flex;
        align-items: center;
        gap: 10px;
        font-size: 20px;
        font-weight: 700;
        color: var(--outreach-text);
        margin: 0;
    }

        .cd-header h2 .material-icons {
            color: var(--outreach-primary);
        }

.cd-btn.icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--outreach-bg-secondary);
    border: 1px solid var(--outreach-border);
    color: var(--outreach-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
}

    .cd-btn.icon:hover {
        background: var(--outreach-border);
    }

.cd-header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.cd-filters {
    display: flex;
    gap: 8px;
    padding: 16px 24px;
    border-bottom: 1px solid var(--outreach-border);
}

.cd-filter-btn {
    padding: 8px 16px;
    border: 1px solid var(--outreach-border);
    border-radius: 20px;
    background: var(--outreach-bg);
    color: var(--outreach-text-muted);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .cd-filter-btn:hover {
        border-color: var(--outreach-primary);
        color: var(--outreach-primary);
    }

    .cd-filter-btn.active {
        background: var(--outreach-primary);
        border-color: var(--outreach-primary);
        color: white;
    }

.cd-campaigns-list {
    padding: 16px 24px;
    max-height: 500px;
    overflow-y: auto;
}

.cd-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px;
    color: var(--outreach-text-muted);
}

    .cd-empty .material-icons {
        font-size: 48px;
        margin-bottom: 12px;
        opacity: 0.5;
    }

.cd-empty-hint {
    font-size: 13px;
    margin-top: 8px;
}

.cd-campaign-card {
    display: flex;
    align-items: center;
    padding: 16px;
    background: var(--outreach-bg);
    border: 1px solid var(--outreach-border);
    border-radius: 12px;
    margin-bottom: 12px;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .cd-campaign-card:hover {
        border-color: var(--outreach-primary);
        box-shadow: var(--outreach-shadow);
    }

.cd-campaign-info {
    flex: 1;
}

    .cd-campaign-info h3 {
        font-size: 15px;
        font-weight: 600;
        color: var(--outreach-text);
        margin: 0 0 6px 0;
    }

.cd-campaign-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 12px;
    color: var(--outreach-text-muted);
}

.cd-campaign-status {
    padding: 3px 8px;
    border-radius: 12px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
}

.cd-campaign-stats {
    display: flex;
    gap: 20px;
    margin-right: 16px;
}

.cd-mini-stat {
    text-align: center;
}

.cd-mini-value {
    display: block;
    font-size: 18px;
    font-weight: 700;
    color: var(--outreach-primary);
}

.cd-mini-label {
    display: block;
    font-size: 10px;
    color: var(--outreach-text-muted);
}

.cd-campaign-arrow {
    color: var(--outreach-text-muted);
}

/* ============================================================================
   CAMPAIGN ANALYTICS
   ============================================================================ */
.campaign-analytics {
    padding-bottom: 24px;
}

.ca-header {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px;
    border-bottom: 1px solid var(--outreach-border);
}

.ca-back,
.ca-close {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--outreach-bg-secondary);
    border: 1px solid var(--outreach-border);
    color: var(--outreach-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
}

    .ca-back:hover,
    .ca-close:hover {
        background: var(--outreach-border);
        color: var(--outreach-text);
    }

.ca-header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.ca-btn.icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--outreach-bg-secondary);
    border: 1px solid var(--outreach-border);
    color: var(--outreach-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
}

    .ca-btn.icon:hover {
        background: var(--outreach-border);
        color: var(--outreach-text);
    }

.ca-header-info {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 12px;
}

    .ca-header-info h2 {
        font-size: 18px;
        font-weight: 700;
        color: var(--outreach-text);
        margin: 0;
    }

.ca-status {
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
}

.ca-section {
    padding: 20px 24px;
    border-bottom: 1px solid var(--outreach-border);
}

    .ca-section h3 {
        display: flex;
        align-items: center;
        gap: 8px;
        font-size: 14px;
        font-weight: 600;
        color: var(--outreach-text);
        margin: 0 0 16px 0;
    }

        .ca-section h3 .material-icons {
            font-size: 18px;
            color: var(--outreach-primary);
        }

.ca-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}

    .ca-stats-grid.three {
        grid-template-columns: repeat(3, 1fr);
    }

.ca-stat-card {
    text-align: center;
    padding: 16px;
    background: var(--outreach-bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--outreach-border);
}

    .ca-stat-card.highlight {
        background: linear-gradient(135deg, #ede9fe, #ddd6fe);
        border-color: #c4b5fd;
    }

[data-theme="dark"] .ca-stat-card.highlight {
    background: linear-gradient(135deg, #3730a3, #4338ca);
    border-color: #6366f1;
}

.ca-stat-card.success {
    background: linear-gradient(135deg, #dcfce7, #bbf7d0);
    border-color: #86efac;
}

[data-theme="dark"] .ca-stat-card.success {
    background: linear-gradient(135deg, #14532d, #166534);
    border-color: #22c55e;
}

.ca-stat-card.warning .ca-stat-value {
    color: var(--outreach-danger);
}

.ca-stat-value {
    display: block;
    font-size: 28px;
    font-weight: 700;
    color: var(--outreach-text);
}

.ca-stat-label {
    display: block;
    font-size: 12px;
    color: var(--outreach-text-muted);
    margin-top: 4px;
}

.ca-stat-rate {
    display: block;
    font-size: 11px;
    color: var(--outreach-primary);
    font-weight: 600;
    margin-top: 4px;
}

.ca-interest-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}

.ca-interest-card {
    text-align: center;
    padding: 16px;
    border-radius: 12px;
    border: 1px solid var(--outreach-border);
}

    .ca-interest-card.hot {
        background: linear-gradient(135deg, #fef2f2, #fee2e2);
        border-color: #fca5a5;
    }

    .ca-interest-card.engaged {
        background: linear-gradient(135deg, #fefce8, #fef3c7);
        border-color: #fcd34d;
    }

    .ca-interest-card.warm {
        background: linear-gradient(135deg, #fff7ed, #ffedd5);
        border-color: #fdba74;
    }

    .ca-interest-card.cold {
        background: linear-gradient(135deg, #f0f9ff, #e0f2fe);
        border-color: #7dd3fc;
    }

.ca-interest-icon {
    font-size: 24px;
    display: block;
    margin-bottom: 4px;
}

.ca-interest-value {
    display: block;
    font-size: 24px;
    font-weight: 700;
    color: var(--outreach-text);
}

.ca-interest-label {
    display: block;
    font-size: 11px;
    color: var(--outreach-text-muted);
    margin-top: 2px;
}

.ca-actions {
    display: flex;
    gap: 12px;
    padding: 20px 24px;
}

.ca-action-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px;
    background: var(--outreach-bg-secondary);
    border: 1px solid var(--outreach-border);
    border-radius: 10px;
    color: var(--outreach-text);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .ca-action-btn:hover {
        background: var(--outreach-primary);
        border-color: var(--outreach-primary);
        color: white;
    }

/* ============================================================================
   ENGAGED LEADS VIEW
   ============================================================================ */
.engaged-leads-view {
    min-height: 400px;
}

.elv-header {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px;
    border-bottom: 1px solid var(--outreach-border);
}

.elv-back {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--outreach-bg-secondary);
    border: 1px solid var(--outreach-border);
    color: var(--outreach-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
}

    .elv-back:hover {
        background: var(--outreach-border);
    }

.elv-header h2 {
    flex: 1;
    font-size: 18px;
    font-weight: 700;
    color: var(--outreach-text);
    margin: 0;
}

.elv-count {
    font-size: 13px;
    color: var(--outreach-text-muted);
    padding: 6px 12px;
    background: var(--outreach-bg-secondary);
    border-radius: 20px;
}

.elv-list {
    padding: 16px 24px;
    max-height: 500px;
    overflow-y: auto;
}

.elv-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px;
    color: var(--outreach-text-muted);
}

    .elv-empty .material-icons {
        font-size: 48px;
        margin-bottom: 12px;
        opacity: 0.5;
    }

.elv-lead-card {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 16px;
    background: var(--outreach-bg);
    border: 1px solid var(--outreach-border);
    border-radius: 12px;
    margin-bottom: 12px;
}

.elv-lead-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6366f1, #8b5cf6);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 14px;
    flex-shrink: 0;
}

.elv-lead-info {
    flex: 1;
}

    .elv-lead-info h4 {
        font-size: 14px;
        font-weight: 600;
        color: var(--outreach-text);
        margin: 0 0 2px 0;
    }

    .elv-lead-info p {
        font-size: 12px;
        color: var(--outreach-text-muted);
        margin: 0 0 8px 0;
    }

.elv-lead-meta {
    display: flex;
    align-items: center;
    gap: 12px;
}

.elv-engagement-date {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    color: var(--outreach-text-muted);
}

    .elv-engagement-date .material-icons {
        font-size: 12px;
    }

.elv-interest-score {
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 10px;
    font-weight: 600;
}

    .elv-interest-score.interest-hot {
        background: #fef2f2;
        color: #dc2626;
    }

    .elv-interest-score.interest-engaged {
        background: #fefce8;
        color: #ca8a04;
    }

    .elv-interest-score.interest-warm {
        background: #fff7ed;
        color: #ea580c;
    }

    .elv-interest-score.interest-cold {
        background: #f0f9ff;
        color: #0284c7;
    }

.elv-reply-preview {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    margin-top: 10px;
    padding: 10px;
    background: var(--outreach-bg-secondary);
    border-radius: 8px;
    font-size: 12px;
    color: var(--outreach-text-muted);
    font-style: italic;
}

    .elv-reply-preview .material-icons {
        font-size: 14px;
        color: var(--outreach-primary);
        flex-shrink: 0;
    }

.elv-lead-actions {
    display: flex;
    gap: 8px;
}

.elv-action-btn {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--outreach-bg-secondary);
    border: 1px solid var(--outreach-border);
    color: var(--outreach-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
}

    .elv-action-btn:hover {
        background: var(--outreach-border);
        color: var(--outreach-text);
    }

    .elv-action-btn.primary {
        background: var(--outreach-primary);
        border-color: var(--outreach-primary);
        color: white;
    }

        .elv-action-btn.primary:hover {
            background: var(--outreach-primary-dark);
        }

/* ============================================================================
   ENGAGEMENT NOTIFICATION CARDS
   ============================================================================ */
.engagement-notification-card {
    background: var(--outreach-bg);
    border: 1px solid var(--outreach-border);
    border-radius: 16px;
    padding: 20px;
    max-width: 400px;
    box-shadow: var(--outreach-shadow);
}

    .engagement-notification-card.reply {
        border-left: 4px solid var(--outreach-success);
    }

.enc-header {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
}

.enc-icon {
    font-size: 32px;
}

.enc-info h4 {
    font-size: 15px;
    font-weight: 600;
    color: var(--outreach-text);
    margin: 0 0 4px 0;
}

.enc-info p {
    font-size: 13px;
    color: var(--outreach-text-muted);
    margin: 0;
}

.enc-preview {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 12px;
    background: var(--outreach-bg-secondary);
    border-radius: 10px;
    font-size: 13px;
    color: var(--outreach-text);
    font-style: italic;
    line-height: 1.5;
    margin-bottom: 16px;
}

    .enc-preview .material-icons {
        color: var(--outreach-primary);
        flex-shrink: 0;
    }

.enc-actions {
    display: flex;
    gap: 10px;
}

.enc-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 14px;
    border: none;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .enc-btn.primary {
        background: var(--outreach-success);
        color: white;
    }

        .enc-btn.primary:hover {
            background: #16a34a;
        }

    .enc-btn.secondary {
        background: var(--outreach-bg-secondary);
        color: var(--outreach-text);
        border: 1px solid var(--outreach-border);
    }

        .enc-btn.secondary:hover {
            background: var(--outreach-border);
        }

/* ============================================================================
   CAMPAIGN CONFIG MODAL
   ============================================================================ */
.campaign-config-modal {
    padding: 24px;
}

    .campaign-config-modal h3 {
        display: flex;
        align-items: center;
        gap: 10px;
        font-size: 18px;
        font-weight: 700;
        color: var(--outreach-text);
        margin: 0 0 20px 0;
    }

        .campaign-config-modal h3 .material-icons {
            color: var(--outreach-primary);
        }

.ccm-summary {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: linear-gradient(135deg, #ede9fe, #ddd6fe);
    border-radius: 10px;
    font-size: 14px;
    font-weight: 500;
    color: #5b21b6;
    margin-bottom: 20px;
}

[data-theme="dark"] .ccm-summary {
    background: linear-gradient(135deg, #3730a3, #4338ca);
    color: #c4b5fd;
}

.ccm-field {
    margin-bottom: 16px;
}

    .ccm-field label {
        display: block;
        font-size: 13px;
        font-weight: 600;
        color: var(--outreach-text);
        margin-bottom: 8px;
    }

    .ccm-field input[type="text"],
    .ccm-field textarea {
        width: 100%;
        padding: 12px 14px;
        border: 1px solid var(--outreach-border);
        border-radius: 10px;
        font-size: 14px;
        font-family: inherit;
        background: var(--outreach-bg);
        color: var(--outreach-text);
        transition: border-color 0.2s ease;
    }

        .ccm-field input:focus,
        .ccm-field textarea:focus {
            outline: none;
            border-color: var(--outreach-primary);
        }

.ccm-followups {
    padding: 16px;
    background: var(--outreach-bg-secondary);
    border-radius: 10px;
}

.ccm-checkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    cursor: pointer;
}

    .ccm-checkbox input[type="checkbox"] {
        width: 18px;
        height: 18px;
        accent-color: var(--outreach-primary);
    }

.ccm-followup-config {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--outreach-border);
    font-size: 13px;
}

    .ccm-followup-config select {
        padding: 8px 12px;
        border: 1px solid var(--outreach-border);
        border-radius: 6px;
        background: var(--outreach-bg);
        color: var(--outreach-text);
        font-size: 13px;
    }

.ccm-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    margin-top: 24px;
}

.ccm-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .ccm-btn.primary {
        background: linear-gradient(135deg, #6366f1, #4f46e5);
        color: white;
    }

        .ccm-btn.primary:hover {
            background: linear-gradient(135deg, #4f46e5, #4338ca);
        }

    .ccm-btn.secondary {
        background: var(--outreach-bg-secondary);
        color: var(--outreach-text);
        border: 1px solid var(--outreach-border);
    }

        .ccm-btn.secondary:hover {
            background: var(--outreach-border);
        }

/* ============================================================================
   CANVAS OUTREACH BUTTON
   ============================================================================ */
.canvas-action-btn.outreach {
    background: linear-gradient(135deg, #6366f1, #8b5cf6);
    color: white;
    border: none;
}

    .canvas-action-btn.outreach:hover {
        background: linear-gradient(135deg, #4f46e5, #7c3aed);
        transform: translateY(-1px);
    }

/* ============================================================================
   RESPONSIVE STYLES
   ============================================================================ */
@media (max-width: 768px) {
    .outreach-modal-container {
        width: 100%;
        max-width: 100%;
        height: 100%;
        max-height: 100%;
        border-radius: 0;
    }

    .campaign-review-panel {
        height: 100vh;
        max-height: 100vh;
    }

    .crp-stats-bar {
        grid-template-columns: repeat(2, 1fr);
    }

    .crp-lead-card {
        grid-template-columns: auto 1fr;
    }

    .crp-lead-email-preview {
        grid-column: 1 / -1;
        order: 3;
    }

    .crp-lead-actions {
        grid-column: 1 / -1;
        flex-direction: row;
        order: 4;
        margin-top: 12px;
    }

    .crp-footer {
        flex-direction: column;
        gap: 12px;
    }

    .crp-footer-actions {
        width: 100%;
    }

    .crp-action-btn {
        flex: 1;
    }

    .ca-stats-grid,
    .ca-interest-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .cd-campaign-card {
        flex-direction: column;
        align-items: flex-start;
    }

    .cd-campaign-stats {
        width: 100%;
        justify-content: space-between;
        margin: 12px 0 0 0;
        padding-top: 12px;
        border-top: 1px solid var(--outreach-border);
    }

    .cd-campaign-arrow {
        display: none;
    }
}

/* ============================================================================
   ANIMATIONS
   ============================================================================ */
@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }

    50% {
        opacity: 0.5;
    }
}

.spin {
    animation: spin 1s linear infinite;
}

/* ============================================================================
   EMAIL PROVIDER SELECTION
   ============================================================================ */
.crp-email-provider {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 24px;
    background: var(--outreach-bg-secondary);
    border-bottom: 1px solid var(--outreach-border);
}

    .crp-email-provider label {
        display: flex;
        align-items: center;
        gap: 6px;
        font-size: 13px;
        font-weight: 600;
        color: var(--outreach-text);
        white-space: nowrap;
    }

        .crp-email-provider label .material-icons {
            font-size: 18px;
            color: var(--outreach-primary);
        }

.crp-provider-select {
    flex: 1;
    max-width: 400px;
    padding: 10px 14px;
    border: 1px solid var(--outreach-border);
    border-radius: 8px;
    background: var(--outreach-bg);
    color: var(--outreach-text);
    font-size: 13px;
    cursor: pointer;
    transition: border-color 0.2s ease;
}

    .crp-provider-select:focus {
        outline: none;
        border-color: var(--outreach-primary);
    }

.crp-email-provider-warning {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: #fef2f2;
    border-bottom: 1px solid #fecaca;
    color: #dc2626;
    font-size: 13px;
}

[data-theme="dark"] .crp-email-provider-warning {
    background: #450a0a;
    border-color: #7f1d1d;
    color: #fca5a5;
}

    .crp-email-provider-warning .material-icons {
        font-size: 18px;
    }

    .crp-email-provider-warning a {
        color: var(--outreach-primary);
        text-decoration: underline;
    }

/* ============================================================================
   FOLLOW-UP DISPLAY IN LEAD CARDS
   ============================================================================ */
.crp-lead-followups-detail {
    grid-column: 1 / -1;
    margin-top: 12px;
    border-top: 1px solid var(--outreach-border);
    padding-top: 12px;
}

.crp-followups-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--outreach-bg-secondary);
    border-radius: 8px;
    font-size: 12px;
    color: var(--outreach-text-muted);
    cursor: pointer;
    transition: background 0.2s ease;
}

    .crp-followups-header:hover {
        background: var(--outreach-border);
    }

    .crp-followups-header .material-icons {
        font-size: 16px;
        color: var(--outreach-primary);
    }

.crp-followups-chevron {
    margin-left: auto;
    color: var(--outreach-text-muted) !important;
}

.crp-followups-list {
    margin-top: 10px;
    padding-left: 24px;
}

.crp-followup-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    background: var(--outreach-bg);
    border: 1px solid var(--outreach-border);
    border-radius: 8px;
    margin-bottom: 8px;
}

    .crp-followup-item.sent {
        opacity: 0.6;
        background: var(--outreach-bg-secondary);
    }

    .crp-followup-item.paused {
        border-color: var(--outreach-warning);
        background: #fef3c7;
    }

[data-theme="dark"] .crp-followup-item.paused {
    background: #451a03;
}

.crp-followup-info {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.crp-followup-num {
    font-size: 11px;
    font-weight: 700;
    color: var(--outreach-text-muted);
    padding: 2px 6px;
    background: var(--outreach-bg-secondary);
    border-radius: 4px;
}

.crp-followup-status {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    padding: 3px 8px;
    border-radius: 10px;
}

    .crp-followup-status.status-pending {
        background: #e0f2fe;
        color: #0369a1;
    }

    .crp-followup-status.status-scheduled {
        background: #ede9fe;
        color: #6d28d9;
    }

    .crp-followup-status.status-sent {
        background: #dcfce7;
        color: #15803d;
    }

    .crp-followup-status.status-paused {
        background: #fef3c7;
        color: #b45309;
    }

    .crp-followup-status.status-cancelled {
        background: #fee2e2;
        color: #dc2626;
    }

.crp-followup-date,
.crp-followup-offset {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--outreach-text-muted);
}

    .crp-followup-date .material-icons,
    .crp-followup-offset .material-icons {
        font-size: 14px;
        color: var(--outreach-primary);
    }

.crp-followup-actions {
    display: flex;
    gap: 6px;
}

.crp-followup-btn {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--outreach-bg-secondary);
    border: 1px solid var(--outreach-border);
    color: var(--outreach-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
}

    .crp-followup-btn .material-icons {
        font-size: 16px;
    }

    .crp-followup-btn:hover {
        background: var(--outreach-border);
        color: var(--outreach-text);
    }

    .crp-followup-btn.edit:hover {
        background: var(--outreach-primary);
        border-color: var(--outreach-primary);
        color: white;
    }

    .crp-followup-btn.pause:hover {
        background: var(--outreach-warning);
        border-color: var(--outreach-warning);
        color: white;
    }

    .crp-followup-btn.resume:hover {
        background: var(--outreach-success);
        border-color: var(--outreach-success);
        color: white;
    }

/* ============================================================================
   FOLLOW-UP EDITOR MODAL
   ============================================================================ */
.followup-editor-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10001;
    display: none;
    align-items: center;
    justify-content: center;
}

    .followup-editor-modal.active {
        display: flex;
    }

.followup-editor-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(2px);
}

.followup-editor-container {
    position: relative;
    width: 95%;
    max-width: 600px;
    max-height: 85vh;
    background: var(--outreach-bg);
    border-radius: 16px;
    box-shadow: var(--outreach-shadow-lg);
    overflow-y: auto;
    animation: modalSlideIn 0.2s ease;
}

.followup-editor-panel {
    padding: 24px;
}

.fep-header {
    position: relative;
    margin-bottom: 20px;
}

    .fep-header h3 {
        font-size: 18px;
        font-weight: 700;
        color: var(--outreach-text);
        margin: 0 0 4px 0;
    }

    .fep-header p {
        font-size: 13px;
        color: var(--outreach-text-muted);
        margin: 0;
    }

.fep-close {
    position: absolute;
    top: 0;
    right: 0;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    color: var(--outreach-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
}

    .fep-close:hover {
        background: var(--outreach-bg-secondary);
        color: var(--outreach-text);
    }

.fep-status {
    margin-bottom: 20px;
}

.fep-status-badge {
    display: inline-flex;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
}

    .fep-status-badge.status-pending {
        background: #e0f2fe;
        color: #0369a1;
    }

    .fep-status-badge.status-scheduled {
        background: #ede9fe;
        color: #6d28d9;
    }

    .fep-status-badge.status-sent {
        background: #dcfce7;
        color: #15803d;
    }

    .fep-status-badge.status-paused {
        background: #fef3c7;
        color: #b45309;
    }

.fep-field {
    margin-bottom: 20px;
}

    .fep-field label {
        display: block;
        font-size: 13px;
        font-weight: 600;
        color: var(--outreach-text);
        margin-bottom: 8px;
    }

    .fep-field input[type="text"],
    .fep-field input[type="datetime-local"],
    .fep-field textarea {
        width: 100%;
        padding: 12px 14px;
        border: 1px solid var(--outreach-border);
        border-radius: 10px;
        font-size: 14px;
        font-family: inherit;
        background: var(--outreach-bg);
        color: var(--outreach-text);
        transition: border-color 0.2s ease;
    }

        .fep-field input:focus,
        .fep-field textarea:focus {
            outline: none;
            border-color: var(--outreach-primary);
        }

    .fep-field textarea {
        resize: vertical;
        min-height: 150px;
    }

.fep-field-hint {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    font-size: 12px;
    color: var(--outreach-text-muted);
}

    .fep-field-hint .material-icons {
        font-size: 14px;
        color: var(--outreach-primary);
    }

.fep-footer {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid var(--outreach-border);
}

.fep-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .fep-btn.primary {
        background: linear-gradient(135deg, #6366f1, #4f46e5);
        color: white;
    }

        .fep-btn.primary:hover {
            background: linear-gradient(135deg, #4f46e5, #4338ca);
        }

        .fep-btn.primary:disabled {
            opacity: 0.7;
            cursor: not-allowed;
        }

    .fep-btn.secondary {
        background: var(--outreach-bg-secondary);
        color: var(--outreach-text);
        border: 1px solid var(--outreach-border);
    }

        .fep-btn.secondary:hover {
            background: var(--outreach-border);
        }

    .fep-btn.danger {
        background: #fee2e2;
        color: #dc2626;
        border: 1px solid #fecaca;
    }

        .fep-btn.danger:hover {
            background: #fecaca;
        }

[data-theme="dark"] .fep-btn.danger {
    background: #450a0a;
    border-color: #7f1d1d;
    color: #fca5a5;
}

    [data-theme="dark"] .fep-btn.danger:hover {
        background: #7f1d1d;
    }

/* ============================================================================
   RESPONSIVE FOLLOW-UP STYLES
   ============================================================================ */
@media (max-width: 768px) {
    .crp-followup-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .crp-followup-actions {
        width: 100%;
        justify-content: flex-end;
    }

    .fep-footer {
        flex-direction: column;
    }

    .fep-btn {
        width: 100%;
        justify-content: center;
    }
}

/* ============================================================================
   SESSION CAMPAIGNS CARD
   ============================================================================ */
.session-campaigns-card {
    background: var(--outreach-bg);
    border: 1px solid var(--outreach-border);
    border-radius: 16px;
    overflow: hidden;
    max-width: 500px;
}

.session-campaigns-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 16px 20px;
    background: linear-gradient(135deg, var(--outreach-primary), var(--outreach-primary-dark));
    color: white;
}

    .session-campaigns-header .material-icons {
        font-size: 24px;
    }

    .session-campaigns-header h4,
    .session-campaigns-header span {
        margin: 0;
        font-size: 16px;
        font-weight: 600;
    }

.session-campaigns-summary {
    background: var(--outreach-bg);
    border: 1px solid var(--outreach-border);
    border-radius: 16px;
    overflow: hidden;
    max-width: 500px;
}

    .session-campaigns-summary .session-campaigns-inline {
        padding: 12px;
    }

.session-campaigns-list {
    padding: 12px;
}

.session-campaign-item {
    padding: 14px 16px;
    background: var(--outreach-bg-secondary);
    border-radius: 10px;
    margin-bottom: 10px;
    cursor: pointer;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}

    .session-campaign-item:last-child {
        margin-bottom: 0;
    }

    .session-campaign-item:hover {
        background: var(--outreach-bg);
        border-color: var(--outreach-primary);
        transform: translateY(-1px);
    }

.session-campaign-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.session-campaign-name {
    font-weight: 600;
    font-size: 14px;
    color: var(--outreach-text);
}

.session-campaign-status {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    padding: 3px 8px;
    border-radius: 10px;
}

    .session-campaign-status.status-ready {
        background: #dcfce7;
        color: #15803d;
    }

    .session-campaign-status.status-preparing {
        background: #e0f2fe;
        color: #0369a1;
    }

    .session-campaign-status.status-executing {
        background: #ede9fe;
        color: #6d28d9;
    }

    .session-campaign-status.status-completed {
        background: #d1fae5;
        color: #065f46;
    }

    .session-campaign-status.status-draft {
        background: var(--outreach-bg-secondary);
        color: var(--outreach-text-muted);
    }

.session-campaign-stats {
    display: flex;
    gap: 16px;
    font-size: 12px;
    color: var(--outreach-text-muted);
}

    .session-campaign-stats strong {
        color: var(--outreach-text);
    }

.session-campaigns-footer {
    padding: 12px 16px;
    border-top: 1px solid var(--outreach-border);
    display: flex;
    justify-content: center;
}

    .session-campaigns-footer .btn-secondary {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 10px 20px;
        background: var(--outreach-bg-secondary);
        border: 1px solid var(--outreach-border);
        border-radius: 8px;
        font-size: 13px;
        font-weight: 600;
        color: var(--outreach-text);
        cursor: pointer;
        transition: all 0.2s ease;
    }

        .session-campaigns-footer .btn-secondary:hover {
            background: var(--outreach-border);
        }

        .session-campaigns-footer .btn-secondary .material-icons {
            font-size: 18px;
            color: var(--outreach-primary);
        }

/* ============================================================================
   SEARCH AND SORT CONTROLS
   ============================================================================ */
.crp-search-sort {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 24px;
    background: var(--outreach-bg);
    border-bottom: 1px solid var(--outreach-border);
    flex-wrap: wrap;
}

.crp-search-container {
    flex: 1;
    min-width: 200px;
    position: relative;
}

.crp-search-container .material-icons {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 18px;
    color: var(--outreach-text-muted);
}

.crp-search-input {
    width: 100%;
    padding: 10px 14px 10px 40px;
    border: 1px solid var(--outreach-border);
    border-radius: 8px;
    background: var(--outreach-bg-secondary);
    color: var(--outreach-text);
    font-size: 13px;
    transition: all 0.2s ease;
}

.crp-search-input:focus {
    outline: none;
    border-color: var(--outreach-primary);
    background: var(--outreach-bg);
}

.crp-search-input::placeholder {
    color: var(--outreach-text-muted);
}

.crp-sort-container {
    display: flex;
    align-items: center;
    gap: 8px;
}

.crp-sort-container label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--outreach-text-muted);
    white-space: nowrap;
}

.crp-sort-container label .material-icons {
    font-size: 16px;
}

.crp-sort-select {
    padding: 10px 14px;
    border: 1px solid var(--outreach-border);
    border-radius: 8px;
    background: var(--outreach-bg-secondary);
    color: var(--outreach-text);
    font-size: 13px;
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 180px;
}

.crp-sort-select:focus {
    outline: none;
    border-color: var(--outreach-primary);
}

.crp-sort-select:hover {
    background: var(--outreach-bg);
}

/* Responsive adjustments */
@media (max-width: 600px) {
    .crp-search-sort {
        flex-direction: column;
        align-items: stretch;
    }

    .crp-search-container {
        min-width: 100%;
    }

    .crp-sort-container {
        width: 100%;
    }

    .crp-sort-select {
        flex: 1;
    }
}

/* ============================================================================
   INLINE SESSION CAMPAIGNS (Chat Flow)
   ============================================================================ */
.session-campaigns-inline {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.session-campaigns-inline .session-campaign-item {
    padding: 12px 14px;
    background: var(--outreach-bg-secondary);
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}

.session-campaigns-inline .session-campaign-item:hover {
    background: var(--outreach-bg);
    border-color: var(--outreach-primary);
    transform: translateX(4px);
}

.session-campaigns-inline .session-campaign-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 6px;
}

.session-campaigns-inline .session-campaign-name {
    font-weight: 600;
    font-size: 14px;
    color: var(--outreach-text);
}

.session-campaigns-inline .session-campaign-status {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    padding: 2px 8px;
    border-radius: 10px;
}

.session-campaigns-inline .session-campaign-stats {
    display: flex;
    gap: 12px;
    font-size: 12px;
    color: var(--outreach-text-muted);
}

.session-campaigns-inline .session-campaign-stats strong {
    color: var(--outreach-primary);
}

.session-campaigns-inline .session-campaign-actions {
    margin-top: 10px;
    display: flex;
    gap: 8px;
}

.session-campaign-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: linear-gradient(135deg, var(--outreach-primary), var(--outreach-primary-dark));
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.session-campaign-action-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(20, 184, 166, 0.3);
}

.session-campaign-action-btn .material-icons {
    font-size: 16px;
}

/* Active/Launched campaign status */
.session-campaign-status.status-active,
.session-campaign-status.status-launched,
.session-campaign-status.status-sending {
    background: #ede9fe;
    color: #6d28d9;
}

.session-campaign-status.status-sent {
    background: #d1fae5;
    color: #065f46;
}

/* ============================================================================
   CAMPAIGN SIDEBAR & MODAL STYLES
   ============================================================================ */

/* Sidebar campaign item */
.outreach-campaign-item {
    cursor: pointer;
    transition: background 0.2s ease;
}

.outreach-campaign-item:hover {
    background: rgba(20, 184, 166, 0.08);
}

.outreach-campaign-item .nav-item-title {
    display: flex;
    align-items: center;
    gap: 8px;
}

.outreach-campaign-item .nav-item-title .material-icons {
    font-size: 16px;
    color: var(--outreach-primary);
}

.campaign-status-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
}

.campaign-status-badge.status-ready,
.campaign-status-badge.status-draft {
    background: #e2e8f0;
    color: #475569;
}

.campaign-status-badge.status-preparing {
    background: #fef3c7;
    color: #92400e;
}

.campaign-status-badge.status-active,
.campaign-status-badge.status-sending {
    background: #dbeafe;
    color: #1d4ed8;
}

.campaign-status-badge.status-completed,
.campaign-status-badge.status-sent {
    background: #d1fae5;
    color: #065f46;
}

.campaign-status-badge.status-paused {
    background: #fee2e2;
    color: #dc2626;
}

/* Session header in sidebar */
.outreach-session-header {
    padding: 8px 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--outreach-primary);
    letter-spacing: 0.5px;
}

.outreach-session-divider {
    height: 1px;
    background: var(--outreach-border);
    margin: 8px 12px;
}

/* Campaign Detail Modal */
.campaign-detail-modal {
    max-width: 600px;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
}

.campaign-detail-modal .modal-body {
    flex: 1;
    overflow-y: auto;
    max-height: calc(80vh - 120px);
}

.campaign-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 40px;
    color: #64748b;
}

.campaign-loading .material-icons {
    font-size: 24px;
    color: var(--outreach-primary);
}

.campaign-error {
    text-align: center;
    padding: 40px;
    color: #dc2626;
}

.campaign-detail-content {
    padding: 20px;
}

.campaign-stats-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}

.campaign-stat {
    text-align: center;
    padding: 16px 8px;
    background: var(--outreach-bg-secondary);
    border-radius: 12px;
}

.campaign-stat .stat-value {
    font-size: 24px;
    font-weight: 700;
    color: var(--outreach-primary);
}

.campaign-stat .stat-label {
    font-size: 11px;
    color: #64748b;
    text-transform: uppercase;
    margin-top: 4px;
}

/* Campaign Rates Section */
.campaign-rates {
    display: flex;
    gap: 24px;
    margin-bottom: 20px;
    padding: 12px 16px;
    background: linear-gradient(135deg, rgba(14, 165, 233, 0.1) 0%, rgba(99, 102, 241, 0.1) 100%);
    border-radius: 10px;
}

.rate-item {
    display: flex;
    align-items: center;
    gap: 8px;
}

.rate-label {
    color: #64748b;
    font-size: 13px;
}

.rate-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--outreach-primary);
}

/* Status Icon Colors */
.text-success {
    color: #22c55e !important;
    font-size: 18px;
}

.text-primary {
    color: #0ea5e9 !important;
    font-size: 18px;
}

.text-warning {
    color: #f59e0b !important;
    font-size: 18px;
}

.text-info {
    color: #06b6d4 !important;
    font-size: 18px;
}

.text-muted {
    color: #94a3b8 !important;
    font-size: 18px;
}

.text-danger {
    color: #ef4444 !important;
    font-size: 18px;
}

/* Lead Status in Modal */
.lead-status {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
}

.campaign-status-section {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--outreach-border);
}

.campaign-date {
    color: #64748b;
    font-size: 13px;
}

.campaign-leads-section {
    margin-bottom: 20px;
}

.campaign-leads-section h4 {
    margin: 0 0 12px 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--outreach-text);
}

.campaign-leads-list {
    max-height: 250px;
    overflow-y: auto;
    border: 1px solid var(--outreach-border);
    border-radius: 8px;
    padding: 8px;
}

.campaign-lead-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px;
    border-radius: 8px;
    transition: background 0.2s ease;
}

.campaign-lead-item:hover {
    background: var(--outreach-bg-secondary);
}

.campaign-lead-item .lead-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--outreach-primary), var(--outreach-primary-dark));
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
}

.campaign-lead-item .lead-info {
    flex: 1;
}

.campaign-lead-item .lead-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--outreach-text);
}

.campaign-lead-item .lead-company {
    font-size: 11px;
    color: #64748b;
}

.campaign-lead-item .lead-status .material-icons {
    font-size: 18px;
}

.campaign-no-leads {
    text-align: center;
    padding: 20px;
    color: #64748b;
    font-size: 13px;
    background: var(--outreach-bg-secondary);
    border-radius: 10px;
    margin-bottom: 20px;
}

.leads-more {
    text-align: center;
    padding: 12px;
    color: #64748b;
    font-size: 12px;
}

.campaign-actions-section {
    display: flex;
    justify-content: center;
    padding: 16px 0 8px 0;
    margin-top: 16px;
    border-top: 1px solid var(--outreach-border);
    background: var(--outreach-bg);
    position: sticky;
    bottom: 0;
}

.campaign-actions-section .btn-primary {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: linear-gradient(135deg, var(--outreach-primary), var(--outreach-primary-dark));
    color: white;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.campaign-actions-section .btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(20, 184, 166, 0.3);
}

.campaign-actions-section .btn-primary .material-icons {
    font-size: 18px;
}

/* Responsive */
@media (max-width: 600px) {
    .campaign-stats-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .campaign-stat .stat-value {
        font-size: 20px;
    }
}

/* Paper plane icon - rotated to point upward at angle */
.outreach-plane-icon {
    transform: rotate(-45deg);
    display: inline-block;
}

/* ============================================================================
   PLAYBOOK MODE STYLES
   ============================================================================ */

.opc-playbook {
    border-left: 3px solid var(--outreach-primary);
}

.opc-playbook-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    background: linear-gradient(135deg, #6366f1, #8b5cf6);
    color: white;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.3px;
    vertical-align: middle;
    margin-left: 8px;
}

.crp-playbook-info {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 16px;
    margin: 0 16px 8px;
    background: #f0f0ff;
    border: 1px solid #e0e0ff;
    border-radius: 8px;
    font-size: 12px;
    color: #4338ca;
    line-height: 1.4;
}

.crp-playbook-info .material-icons {
    flex-shrink: 0;
    margin-top: 1px;
}

/* ============================================================================
   PLAYBOOK STEPS IN FOOTER (sequence summary bar)
   ============================================================================ */

.crp-playbook-steps-summary {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: #f8f7ff;
    border-top: 1px solid #e8e6ff;
    flex-wrap: wrap;
}

.crp-playbook-step-item {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: #374151;
}

.crp-step-arrow {
    color: #9ca3af;
    font-size: 14px;
    font-weight: 600;
}

.crp-step-tag {
    display: inline-block;
    padding: 1px 6px;
    border-radius: 8px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.crp-step-tag.task {
    background: #dbeafe;
    color: #1d4ed8;
}

.crp-step-tag.auto {
    background: #ede9fe;
    color: #6d28d9;
}

/* ============================================================================
   PLAYBOOK STEPS PER LEAD (expandable section on each lead card)
   ============================================================================ */

.crp-lead-playbook-steps {
    margin-top: 4px;
    border-top: 1px solid #f0f0f0;
    padding-top: 4px;
}

.crp-playbook-steps-header {
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    padding: 4px 8px;
    font-size: 12px;
    font-weight: 500;
    color: #6366f1;
    border-radius: 6px;
    transition: background 0.15s;
}

.crp-playbook-steps-header:hover {
    background: #f5f3ff;
}

.crp-playbook-steps-note {
    font-size: 11px;
    color: #9ca3af;
    font-weight: 400;
    font-style: italic;
}

.crp-playbook-steps-list {
    padding: 6px 8px 6px 16px;
}

.crp-playbook-step {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
}

.crp-playbook-step-icon {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.crp-playbook-step-icon .material-icons {
    font-size: 15px;
}

.crp-playbook-step-icon.linkedin {
    background: #e8f4fd;
    color: #0a66c2;
}

.crp-playbook-step-icon.email {
    background: #ede9fe;
    color: #6366f1;
}

.crp-playbook-step-info {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}

.crp-playbook-step-name {
    font-size: 12px;
    font-weight: 600;
    color: #1e293b;
}

.crp-playbook-step-detail {
    font-size: 11px;
    color: #64748b;
}

.crp-playbook-step-divider {
    width: 1px;
    height: 12px;
    background: #d1d5db;
    margin-left: 13px;
}

/* =============================================
   PLAYBOOK BADGES & TYPE INDICATORS
   ============================================= */

.playbook-type-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    background: linear-gradient(135deg, #6366f1, #8b5cf6);
    color: white;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.3px;
    white-space: nowrap;
}

.email-only-type-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    background: linear-gradient(135deg, #0ea5e9, #0284c7);
    color: white;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.3px;
    white-space: nowrap;
}

/* Mini playbook badge for sidebar */
.playbook-badge-mini {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 1px 5px;
    background: linear-gradient(135deg, #6366f1, #8b5cf6);
    color: white;
    border-radius: 6px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.5px;
    margin-left: 4px;
    vertical-align: middle;
}

/* Playbook steps mini row (used in table and cards) */
.playbook-steps-mini {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: 4px;
    font-size: 12px;
    color: #6b7280;
}

.playbook-steps-mini .step-arrow {
    color: #d1d5db;
    font-size: 10px;
}

.playbook-steps-mini i {
    font-size: 13px;
}

.playbook-steps-mini .fa-envelope,
.playbook-steps-mini .fa-reply {
    color: #8b5cf6;
}

.playbook-steps-mini .fa-linkedin,
.playbook-steps-mini .fa-linkedin-in {
    color: #0077b5;
}

/* Session campaign sequence row */
.session-campaign-sequence {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 0;
    font-size: 12px;
    color: #6b7280;
}

.session-campaign-sequence .step-arrow {
    color: #d1d5db;
    font-size: 10px;
}

.session-campaign-sequence i {
    font-size: 12px;
}

.session-campaign-sequence .fa-envelope,
.session-campaign-sequence .fa-reply {
    color: #8b5cf6;
}

.session-campaign-sequence .fa-linkedin,
.session-campaign-sequence .fa-linkedin-in {
    color: #0077b5;
}

/* Campaign detail modal - playbook sequence */
.campaign-playbook-sequence {
    padding: 12px 0;
    margin-top: 8px;
    border-top: 1px solid rgba(255,255,255,0.1);
}

.campaign-playbook-sequence .playbook-sequence-title {
    font-size: 12px;
    color: #9ca3af;
    margin-bottom: 8px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.campaign-playbook-sequence .playbook-sequence-steps {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.campaign-playbook-sequence .playbook-step-item {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    color: #e5e7eb;
}

.campaign-playbook-sequence .playbook-step-item small {
    color: #9ca3af;
    font-size: 11px;
}

.campaign-playbook-sequence .playbook-step-arrow {
    color: #6b7280;
    font-size: 12px;
}

/* ============================================================================
   SEND CONFIRMATION MODAL
   ============================================================================ */

.send-confirm-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    z-index: 10100;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: scmFadeIn 0.2s ease;
}

@keyframes scmFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.send-confirm-modal {
    background: var(--scm-bg, #ffffff);
    border: 1px solid var(--scm-border, #e5e7eb);
    border-radius: 16px;
    width: 90%;
    max-width: 460px;
    max-height: 85vh;
    padding: 0;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
    animation: scmSlideUp 0.25s ease;
    overflow-y: auto;
    overflow-x: hidden;
    color: var(--scm-text, #111827);
    --scm-bg: #ffffff;
    --scm-border: #e5e7eb;
    --scm-text: #111827;
    --scm-text-muted: #6b7280;
    --scm-text-light: #374151;
    --scm-heading: #111827;
    --scm-accent: #0d9488;
    --scm-bar-bg: #e5e7eb;
    --scm-bar-fill: #0d9488;
    --scm-btn-secondary-bg: #f3f4f6;
    --scm-btn-secondary-text: #374151;
}
[data-theme="dark"] .send-confirm-modal {
    --scm-bg: #1e1e2e;
    --scm-border: #374151;
    --scm-text: #e5e7eb;
    --scm-text-muted: #9ca3af;
    --scm-text-light: #d1d5db;
    --scm-heading: #f3f4f6;
    --scm-accent: #818cf8;
    --scm-bar-bg: #374151;
    --scm-bar-fill: #818cf8;
    --scm-btn-secondary-bg: #374151;
    --scm-btn-secondary-text: #d1d5db;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

@keyframes scmSlideUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.scm-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 20px 24px 16px;
    border-bottom: 1px solid var(--scm-border);
}

.scm-header-icon {
    font-size: 28px;
    color: var(--scm-accent);
}

.scm-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: var(--scm-heading);
}

/* Warning banners */
.scm-warning {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 24px;
    font-size: 13px;
    line-height: 1.4;
}

.scm-warning .material-icons {
    font-size: 20px;
    flex-shrink: 0;
    margin-top: 1px;
}

.scm-warning-error {
    background: rgba(239, 68, 68, 0.12);
    color: #fca5a5;
    border-bottom: 1px solid rgba(239, 68, 68, 0.2);
}

.scm-warning-error .material-icons {
    color: #ef4444;
}

.scm-warning-caution {
    background: rgba(245, 158, 11, 0.12);
    color: #fcd34d;
    border-bottom: 1px solid rgba(245, 158, 11, 0.2);
}

.scm-warning-caution .material-icons {
    color: #f59e0b;
}

/* Details section */
.scm-details {
    padding: 16px 24px;
}

.scm-detail-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid var(--scm-border);
}

.scm-detail-row:last-child {
    border-bottom: none;
}

.scm-detail-highlight {
    padding: 14px 0;
}

.scm-detail-label {
    color: var(--scm-text-muted);
    font-size: 13px;
}

.scm-detail-value {
    color: var(--scm-text);
    font-size: 14px;
    text-align: right;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}

.scm-email-count {
    font-size: 28px;
    font-weight: 700;
    color: var(--scm-accent);
}

.scm-provider-email {
    font-size: 12px;
    color: var(--scm-text-muted);
}

/* Sender-name auto-match note */
.scm-sender-note {
    font-size: 11px;
    color: #94a3b8;
    font-style: italic;
}
[data-theme="dark"] .scm-sender-note { color: #64748b; }

/* Schedule preview section (Smart Send Scheduler) */
.scm-schedule-preview {
    padding: 12px 24px 0;
}
.scm-schedule-preview h4 {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--scm-text-muted);
    margin: 0 0 8px;
}
.scm-schedule-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 10px;
}
.scm-schedule-metric {
    background: #f0fdfa;
    border: 1px solid #ccfbf1;
    border-radius: 10px;
    padding: 10px;
    text-align: center;
}
.scm-schedule-metric-value {
    font-size: 22px;
    font-weight: 700;
    color: #0f766e;
}
.scm-schedule-metric-label {
    font-size: 11px;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}
.scm-schedule-timeline {
    background: #ecfdf5;
    border-left: 3px solid var(--scm-accent, #0d9488);
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 13px;
    margin-bottom: 6px;
    color: var(--scm-text);
}
.scm-schedule-timeline > div + div { margin-top: 3px; }
.scm-schedule-hint {
    font-size: 11px;
    color: var(--scm-text-muted);
    margin-top: 6px;
}
.scm-schedule-hint a {
    color: var(--scm-accent, #0d9488);
    text-decoration: underline;
}

[data-theme="dark"] .scm-schedule-metric {
    background: rgba(15, 118, 110, 0.12);
    border-color: rgba(15, 118, 110, 0.25);
}
[data-theme="dark"] .scm-schedule-metric-value { color: #5eead4; }
[data-theme="dark"] .scm-schedule-timeline { background: rgba(15, 118, 110, 0.15); }
[data-theme="dark"] .scm-schedule-metric-label { color: #94a3b8; }

/* Capacity section */
.scm-capacity {
    padding: 12px 24px 16px;
    border-top: 1px solid var(--scm-border);
}

.scm-capacity h4 {
    margin: 0 0 10px;
    font-size: 12px;
    font-weight: 600;
    color: var(--scm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.scm-capacity-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
    font-size: 12px;
}

.scm-capacity-email {
    color: var(--scm-text-light);
    flex-shrink: 0;
    width: 140px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.scm-capacity-bar {
    flex: 1;
    height: 6px;
    background: var(--scm-bar-bg);
    border-radius: 3px;
    overflow: hidden;
}

.scm-capacity-fill {
    display: block;
    height: 100%;
    background: var(--scm-bar-fill);
    border-radius: 3px;
    transition: width 0.3s ease;
}

.scm-capacity-count {
    color: var(--scm-text-muted);
    flex-shrink: 0;
    font-size: 11px;
}

/* Playbook info */
.scm-playbook-info {
    padding: 12px 24px 16px;
    border-top: 1px solid var(--scm-border);
}

.scm-playbook-info h4 {
    margin: 0 0 10px;
    font-size: 12px;
    font-weight: 600;
    color: var(--scm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.scm-step {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    font-size: 13px;
    color: var(--scm-text-light);
}

.scm-step .material-icons {
    font-size: 18px;
    color: var(--scm-accent);
}

/* Action buttons */
.scm-actions {
    display: flex;
    gap: 12px;
    padding: 16px 24px 20px;
    border-top: 1px solid var(--scm-border);
}

.scm-btn {
    flex: 1;
    padding: 12px 20px;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: all 0.15s ease;
}

.scm-btn .material-icons {
    font-size: 18px;
}

.scm-btn-cancel {
    background: var(--scm-btn-secondary-bg);
    color: var(--scm-btn-secondary-text);
}

.scm-btn-cancel:hover {
    opacity: 0.85;
}

.scm-btn-confirm {
    background: var(--scm-accent);
    color: #fff;
}

.scm-btn-confirm:hover {
    background: #6366f1;
}

.scm-btn-confirm:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* ============================================================================
   ALL LEADS VIEW (Campaign Analytics → View All Leads)
   ============================================================================ */

.all-leads-view {
    display: flex;
    flex-direction: column;
    height: 100%;
    max-height: 85vh;
}

.alv-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    border-bottom: 1px solid #374151;
    flex-shrink: 0;
}

.alv-back {
    background: none;
    border: none;
    color: #9ca3af;
    cursor: pointer;
    padding: 4px;
    border-radius: 6px;
    display: flex;
    align-items: center;
}

.alv-back:hover {
    background: #374151;
    color: #e5e7eb;
}

.alv-header-info {
    flex: 1;
    min-width: 0;
}

.alv-header-info h2 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: #f3f4f6;
}

.alv-subtitle {
    font-size: 12px;
    color: #6b7280;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alv-count {
    background: #374151;
    color: #d1d5db;
    font-size: 12px;
    padding: 4px 10px;
    border-radius: 12px;
    flex-shrink: 0;
}

.alv-header-actions {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
}

/* Filters */
.alv-filters {
    display: flex;
    gap: 6px;
    padding: 12px 20px;
    border-bottom: 1px solid #2d2d3d;
    flex-wrap: wrap;
    flex-shrink: 0;
}

.alv-filter-btn {
    background: transparent;
    border: 1px solid #374151;
    color: #9ca3af;
    padding: 5px 12px;
    border-radius: 16px;
    font-size: 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px;
    transition: all 0.15s ease;
}

.alv-filter-btn .material-icons {
    font-size: 14px;
}

.alv-filter-btn:hover {
    border-color: #6b7280;
    color: #d1d5db;
}

.alv-filter-btn.active {
    background: #818cf8;
    border-color: #818cf8;
    color: #fff;
}

/* Search */
.alv-search {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 20px;
    border-bottom: 1px solid #2d2d3d;
    flex-shrink: 0;
}

.alv-search .material-icons {
    color: #6b7280;
    font-size: 20px;
}

.alv-search input {
    flex: 1;
    background: transparent;
    border: none;
    color: #e5e7eb;
    font-size: 13px;
    outline: none;
    padding: 6px 0;
}

.alv-search input::placeholder {
    color: #4b5563;
}

/* Lead cards list */
.alv-list {
    flex: 1;
    overflow-y: auto;
    padding: 8px 12px;
}

.alv-empty {
    text-align: center;
    padding: 40px 20px;
    color: #6b7280;
}

.alv-empty .material-icons {
    font-size: 40px;
    display: block;
    margin-bottom: 8px;
}

/* Individual lead card */
.alv-lead-card {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 12px;
    border-radius: 10px;
    border: 1px solid transparent;
    transition: all 0.15s ease;
    margin-bottom: 4px;
}

.alv-lead-card:hover {
    background: #1a1a2e;
    border-color: #374151;
}

.alv-lead-position {
    color: #6b7280;
    font-size: 12px;
    font-weight: 600;
    min-width: 28px;
    text-align: center;
    padding-top: 2px;
    flex-shrink: 0;
}

.alv-lead-info {
    flex: 1;
    min-width: 0;
}

.alv-lead-name-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.alv-lead-name-row h4 {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    color: #f3f4f6;
}

.alv-lead-role {
    margin: 2px 0 0;
    font-size: 12px;
    color: #9ca3af;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alv-lead-email {
    margin: 4px 0 0;
    font-size: 12px;
    color: #818cf8;
    display: flex;
    align-items: center;
    gap: 4px;
}

.alv-lead-email .material-icons {
    font-size: 14px;
}

.alv-no-email {
    color: #6b7280;
}

.alv-lead-subject {
    margin: 4px 0 0;
    font-size: 12px;
    color: #6b7280;
    display: flex;
    align-items: center;
    gap: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alv-lead-subject .material-icons {
    font-size: 14px;
}

.alv-reply-preview {
    margin-top: 6px;
    padding: 8px 10px;
    background: rgba(16, 185, 129, 0.08);
    border-left: 2px solid #10b981;
    border-radius: 0 6px 6px 0;
    font-size: 12px;
    color: #a7f3d0;
    font-style: italic;
    display: flex;
    align-items: flex-start;
    gap: 6px;
}

.alv-reply-preview .material-icons {
    font-size: 14px;
    color: #10b981;
    flex-shrink: 0;
    margin-top: 1px;
}

/* Engagement badges */
.alv-badge {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    flex-shrink: 0;
}

.alv-badge-replied {
    background: rgba(16, 185, 129, 0.15);
    color: #34d399;
}

.alv-badge-clicked {
    background: rgba(59, 130, 246, 0.15);
    color: #60a5fa;
}

.alv-badge-opened {
    background: rgba(168, 85, 247, 0.15);
    color: #c084fc;
}

.alv-badge-bounced {
    background: rgba(239, 68, 68, 0.15);
    color: #fca5a5;
}

.alv-badge-sent {
    background: rgba(129, 140, 248, 0.15);
    color: #a5b4fc;
}

.alv-badge-approved {
    background: rgba(16, 185, 129, 0.1);
    color: #6ee7b7;
}

.alv-badge-rejected {
    background: rgba(239, 68, 68, 0.1);
    color: #fca5a5;
}

.alv-badge-pending {
    background: rgba(107, 114, 128, 0.15);
    color: #9ca3af;
}

/* Lead actions */
.alv-lead-actions {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: 4px;
    padding-top: 2px;
}

.alv-action-link {
    color: #6b7280;
    padding: 4px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    text-decoration: none;
    transition: all 0.15s ease;
}

.alv-action-link:hover {
    color: #818cf8;
    background: rgba(129, 140, 248, 0.1);
}

.alv-action-link .material-icons {
    font-size: 18px;
}

/* Primary action button in analytics */
.ca-action-btn.primary {
    background: #818cf8;
    color: #fff;
    border-color: #818cf8;
}

.ca-action-btn.primary:hover {
    background: #6366f1;
    border-color: #6366f1;
}
