/**
 * Vinco Design Tokens
 * Version: 1.0.0
 *
 * Unified design system for Vinco Sport Ltd platform
 * Used by: Reports, Monitor, Moments Manager, Admin pages
 *
 * Fonts: Exo 2 (primary), Roboto (fallback)
 * To use: Add Google Fonts link to page:
 * <link href="https://fonts.googleapis.com/css2?family=Exo+2:wght@300;400;500;600;700&family=Roboto:wght@300;400;500;700&display=swap" rel="stylesheet">
 *
 * © 2026 Vinco Sport Ltd
 * Developed by: Matthew Quine, Claude (Anthropic AI Assistant)
 */

:root {
    /* ========================================
       TYPOGRAPHY
       ======================================== */

    --vinco-font-primary: 'Exo 2', 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --vinco-font-secondary: 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --vinco-font-mono: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, Consolas, monospace;

    /* Font Sizes */
    --vinco-text-xs: 11px;
    --vinco-text-sm: 12px;
    --vinco-text-base: 14px;
    --vinco-text-md: 15px;
    --vinco-text-lg: 16px;
    --vinco-text-xl: 18px;
    --vinco-text-2xl: 20px;
    --vinco-text-3xl: 24px;
    --vinco-text-4xl: 28px;

    /* Font Weights */
    --vinco-font-light: 300;
    --vinco-font-normal: 400;
    --vinco-font-medium: 500;
    --vinco-font-semibold: 600;
    --vinco-font-bold: 700;

    /* Line Heights */
    --vinco-leading-tight: 1.2;
    --vinco-leading-normal: 1.5;
    --vinco-leading-relaxed: 1.6;

    /* ========================================
       BRAND COLORS
       ======================================== */

    /* Primary - Vinco Orange */
    --vinco-primary: #f97316;
    --vinco-primary-hover: #ea580c;
    --vinco-primary-light: #fed7aa;
    --vinco-primary-dark: #c2410c;

    /* Secondary - Blue */
    --vinco-secondary: #2563eb;
    --vinco-secondary-hover: #1d4ed8;
    --vinco-secondary-light: #dbeafe;
    --vinco-secondary-dark: #1e40af;

    /* ========================================
       STATUS COLORS
       ======================================== */

    --vinco-success: #10b981;
    --vinco-success-light: #d1fae5;
    --vinco-success-dark: #059669;

    --vinco-warning: #f59e0b;
    --vinco-warning-light: #fef3c7;
    --vinco-warning-dark: #d97706;

    --vinco-danger: #ef4444;
    --vinco-danger-light: #fee2e2;
    --vinco-danger-dark: #dc2626;

    --vinco-info: #06b6d4;
    --vinco-info-light: #cffafe;
    --vinco-info-dark: #0891b2;

    /* ========================================
       LIGHT MODE (Default)
       ======================================== */

    --vinco-bg-primary: #ffffff;
    --vinco-bg-secondary: #f8f9fa;
    --vinco-bg-tertiary: #f0f0f1;
    --vinco-bg-elevated: #ffffff;

    --vinco-text-primary: #1d2327;
    --vinco-text-secondary: #646970;
    --vinco-text-muted: #6b7280;
    --vinco-text-inverse: #ffffff;

    --vinco-border-color: #dcdcde;
    --vinco-border-light: #e5e7eb;
    --vinco-border-dark: #c3c4c7;

    --vinco-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --vinco-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --vinco-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --vinco-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);

    /* ========================================
       SPACING
       ======================================== */

    --vinco-space-xs: 4px;
    --vinco-space-sm: 8px;
    --vinco-space-md: 12px;
    --vinco-space-lg: 16px;
    --vinco-space-xl: 24px;
    --vinco-space-2xl: 32px;
    --vinco-space-3xl: 48px;

    /* ========================================
       BORDER RADIUS
       ======================================== */

    --vinco-radius-sm: 4px;
    --vinco-radius-md: 6px;
    --vinco-radius-lg: 8px;
    --vinco-radius-xl: 12px;
    --vinco-radius-2xl: 16px;
    --vinco-radius-full: 9999px;

    /* ========================================
       TRANSITIONS
       ======================================== */

    --vinco-transition-fast: 150ms ease;
    --vinco-transition-normal: 250ms ease;
    --vinco-transition-slow: 350ms ease;

    /* ========================================
       Z-INDEX SCALE
       ======================================== */

    --vinco-z-dropdown: 1000;
    --vinco-z-sticky: 1020;
    --vinco-z-fixed: 1030;
    --vinco-z-modal-backdrop: 1040;
    --vinco-z-modal: 1050;
    --vinco-z-popover: 1060;
    --vinco-z-tooltip: 1070;
    --vinco-z-toast: 1080;
}

/* ========================================
   DARK MODE
   ======================================== */

.vinco-dark-mode,
[data-theme="dark"] {
    --vinco-bg-primary: #1a1a2e;
    --vinco-bg-secondary: #16213e;
    --vinco-bg-tertiary: #0f3460;
    --vinco-bg-elevated: #1e293b;

    --vinco-text-primary: #f1f5f9;
    --vinco-text-secondary: #94a3b8;
    --vinco-text-muted: #64748b;
    --vinco-text-inverse: #1d2327;

    --vinco-border-color: #2d3748;
    --vinco-border-light: #374151;
    --vinco-border-dark: #4b5563;

    --vinco-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
    --vinco-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4);
    --vinco-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5);
    --vinco-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.5);

    /* Adjusted status colors for dark mode */
    --vinco-primary-light: #7c2d12;
    --vinco-secondary-light: #1e3a8a;
    --vinco-success: #34d399;
    --vinco-success-light: #064e3b;
    --vinco-warning: #fbbf24;
    --vinco-warning-light: #78350f;
    --vinco-danger: #f87171;
    --vinco-danger-light: #7f1d1d;
    --vinco-info: #22d3ee;
    --vinco-info-light: #164e63;
}

/* System preference dark mode */
@media (prefers-color-scheme: dark) {
    .vinco-auto-theme {
        --vinco-bg-primary: #1a1a2e;
        --vinco-bg-secondary: #16213e;
        --vinco-bg-tertiary: #0f3460;
        --vinco-bg-elevated: #1e293b;
        --vinco-text-primary: #f1f5f9;
        --vinco-text-secondary: #94a3b8;
        --vinco-text-muted: #64748b;
        --vinco-border-color: #2d3748;
        --vinco-border-light: #374151;
    }
}

/* ========================================
   BASE STYLES
   ======================================== */

.vinco-base {
    font-family: var(--vinco-font-primary);
    font-size: var(--vinco-text-base);
    line-height: var(--vinco-leading-normal);
    color: var(--vinco-text-primary);
    background-color: var(--vinco-bg-primary);
}

/* ========================================
   UTILITY CLASSES
   ======================================== */

/* Text */
.vinco-text-primary { color: var(--vinco-text-primary); }
.vinco-text-secondary { color: var(--vinco-text-secondary); }
.vinco-text-muted { color: var(--vinco-text-muted); }
.vinco-text-success { color: var(--vinco-success); }
.vinco-text-warning { color: var(--vinco-warning); }
.vinco-text-danger { color: var(--vinco-danger); }

/* Backgrounds */
.vinco-bg-primary { background-color: var(--vinco-bg-primary); }
.vinco-bg-secondary { background-color: var(--vinco-bg-secondary); }
.vinco-bg-success { background-color: var(--vinco-success-light); }
.vinco-bg-warning { background-color: var(--vinco-warning-light); }
.vinco-bg-danger { background-color: var(--vinco-danger-light); }

/* Borders */
.vinco-border { border: 1px solid var(--vinco-border-color); }
.vinco-border-light { border: 1px solid var(--vinco-border-light); }
.vinco-rounded-sm { border-radius: var(--vinco-radius-sm); }
.vinco-rounded-md { border-radius: var(--vinco-radius-md); }
.vinco-rounded-lg { border-radius: var(--vinco-radius-lg); }

/* Shadows */
.vinco-shadow-sm { box-shadow: var(--vinco-shadow-sm); }
.vinco-shadow-md { box-shadow: var(--vinco-shadow-md); }
.vinco-shadow-lg { box-shadow: var(--vinco-shadow-lg); }

/* ========================================
   BUTTON STYLES
   ======================================== */

.vinco-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--vinco-space-sm) var(--vinco-space-lg);
    font-family: var(--vinco-font-primary);
    font-size: var(--vinco-text-sm);
    font-weight: var(--vinco-font-medium);
    line-height: var(--vinco-leading-tight);
    text-decoration: none;
    border: none;
    border-radius: var(--vinco-radius-md);
    cursor: pointer;
    transition: all var(--vinco-transition-fast);
}

.vinco-btn:focus {
    outline: 2px solid var(--vinco-secondary);
    outline-offset: 2px;
}

.vinco-btn-primary {
    background-color: var(--vinco-primary);
    color: var(--vinco-text-inverse);
}

.vinco-btn-primary:hover {
    background-color: var(--vinco-primary-hover);
}

.vinco-btn-secondary {
    background-color: var(--vinco-secondary);
    color: var(--vinco-text-inverse);
}

.vinco-btn-secondary:hover {
    background-color: var(--vinco-secondary-hover);
}

.vinco-btn-outline {
    background-color: transparent;
    color: var(--vinco-text-primary);
    border: 1px solid var(--vinco-border-color);
}

.vinco-btn-outline:hover {
    background-color: var(--vinco-bg-secondary);
}

/* ========================================
   CARD STYLES
   ======================================== */

.vinco-card {
    background-color: var(--vinco-bg-elevated);
    border: 1px solid var(--vinco-border-light);
    border-radius: var(--vinco-radius-lg);
    box-shadow: var(--vinco-shadow-sm);
    padding: var(--vinco-space-lg);
}

.vinco-card-header {
    font-family: var(--vinco-font-primary);
    font-size: var(--vinco-text-lg);
    font-weight: var(--vinco-font-semibold);
    color: var(--vinco-text-primary);
    margin-bottom: var(--vinco-space-md);
    padding-bottom: var(--vinco-space-md);
    border-bottom: 1px solid var(--vinco-border-light);
}

.vinco-card-body {
    color: var(--vinco-text-secondary);
}

/* ========================================
   FORM STYLES
   ======================================== */

.vinco-input,
.vinco-select,
.vinco-textarea {
    width: 100%;
    padding: var(--vinco-space-sm) var(--vinco-space-md);
    font-family: var(--vinco-font-secondary);
    font-size: var(--vinco-text-base);
    color: var(--vinco-text-primary);
    background-color: var(--vinco-bg-primary);
    border: 1px solid var(--vinco-border-color);
    border-radius: var(--vinco-radius-md);
    transition: border-color var(--vinco-transition-fast);
}

.vinco-input:focus,
.vinco-select:focus,
.vinco-textarea:focus {
    outline: none;
    border-color: var(--vinco-secondary);
    box-shadow: 0 0 0 3px var(--vinco-secondary-light);
}

.vinco-label {
    display: block;
    font-family: var(--vinco-font-primary);
    font-size: var(--vinco-text-sm);
    font-weight: var(--vinco-font-medium);
    color: var(--vinco-text-primary);
    margin-bottom: var(--vinco-space-xs);
}

/* ========================================
   TABLE STYLES
   ======================================== */

.vinco-table {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--vinco-font-secondary);
    font-size: var(--vinco-text-sm);
}

.vinco-table th,
.vinco-table td {
    padding: var(--vinco-space-sm) var(--vinco-space-md);
    text-align: left;
    border-bottom: 1px solid var(--vinco-border-light);
}

.vinco-table th {
    font-family: var(--vinco-font-primary);
    font-weight: var(--vinco-font-semibold);
    color: var(--vinco-text-primary);
    background-color: var(--vinco-bg-secondary);
}

.vinco-table td {
    color: var(--vinco-text-secondary);
}

.vinco-table tbody tr:hover {
    background-color: var(--vinco-bg-secondary);
}

/* ========================================
   BADGE/PILL STYLES
   ======================================== */

.vinco-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px var(--vinco-space-sm);
    font-family: var(--vinco-font-primary);
    font-size: var(--vinco-text-xs);
    font-weight: var(--vinco-font-medium);
    border-radius: var(--vinco-radius-full);
}

.vinco-badge-success {
    background-color: var(--vinco-success-light);
    color: var(--vinco-success-dark);
}

.vinco-badge-warning {
    background-color: var(--vinco-warning-light);
    color: var(--vinco-warning-dark);
}

.vinco-badge-danger {
    background-color: var(--vinco-danger-light);
    color: var(--vinco-danger-dark);
}

.vinco-badge-info {
    background-color: var(--vinco-info-light);
    color: var(--vinco-info-dark);
}

/* ========================================
   ACCESSIBILITY
   ======================================== */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Focus visible for keyboard navigation */
.vinco-btn:focus-visible,
.vinco-input:focus-visible,
.vinco-select:focus-visible {
    outline: 2px solid var(--vinco-secondary);
    outline-offset: 2px;
}

/* ========================================
   PRINT STYLES
   ======================================== */

@media print {
    .vinco-base {
        background-color: white !important;
        color: black !important;
    }

    .vinco-card {
        box-shadow: none !important;
        border: 1px solid #ccc !important;
    }

    .vinco-btn {
        display: none !important;
    }
}
