/**
 * Smart Evento Design System
 * Sistema centralizado de estilos para todo o sistema (público, painel e outros)
 * 
 * Este arquivo contém:
 * - Tipografia (fonte Inter)
 * - Paleta de cores (cor primária #0f172a)
 * - Variáveis CSS globais
 * - Componentes compartilhados
 */

/* Importação da fonte Inter do Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;700;900&display=swap');

:root {
    /* Cor Primária - #0f172a */
    --color-primary: #0f172a;
    --color-primary-50: #f8fafc;
    --color-primary-100: #f1f5f9;
    --color-primary-200: #e2e8f0;
    --color-primary-300: #cbd5e1;
    --color-primary-400: #94a3b8;
    --color-primary-500: #64748b;
    --color-primary-600: #475569;
    --color-primary-700: #334155;
    --color-primary-800: #1e293b;
    --color-primary-900: #0f172a;
    
    /* Cores Secundárias */
    --color-blue: #3B82F6;
    --color-blue-light: #60A5FA;
    --color-blue-dark: #1E40AF;
    
    /* Cores Neutras */
    --slate-50: #F8FAFC;
    --slate-100: #F1F5F9;
    --slate-200: #E2E8F0;
    --slate-300: #CBD5E1;
    --slate-400: #94A3B8;
    --slate-500: #64748B;
    --slate-600: #475569;
    --slate-700: #334155;
    --slate-800: #1E293B;
    --slate-900: #0F172A;
    
    /* Tipografia - Inter */
    --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-bold: 700;
    --font-weight-black: 900;
    
    /* Espaçamentos */
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
    --spacing-2xl: 3rem;
    --spacing-3xl: 4rem;
    
    /* Bordas */
    --radius-sm: 0.5rem;
    --radius-md: 0.75rem;
    --radius-lg: 1rem;
    --radius-xl: 1.5rem;
    --radius-2xl: 2rem;
    
    /* Sombras */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

/* Reset e Base */
* {
    font-family: var(--font-family);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    font-family: var(--font-family);
    color: var(--slate-900);
}

/* Aplicação da cor primária globalmente */
:root {
    --primary: var(--color-primary);
}

/* Utility Classes para Cor Primária */
.bg-primary {
    background-color: var(--color-primary);
}

.text-primary {
    color: var(--color-primary);
}

.border-primary {
    border-color: var(--color-primary);
}

/* Utility Classes para Cores Secundárias */
.bg-smart-navy {
    background-color: var(--color-primary);
}

.text-smart-blue {
    color: var(--color-blue);
}

.bg-smart-blue {
    background-color: var(--color-blue);
}

.border-smart-blue {
    border-color: var(--color-blue);
}

/* Padrões e Efeitos */
.pattern-grid {
    background-image: radial-gradient(var(--color-blue) 0.5px, transparent 0.5px);
    background-size: 30px 30px;
}

.gradient-smart {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-800) 50%, var(--color-primary-700) 100%);
}

/* Transições suaves */
.transition-smooth {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Hover effects */
.hover-lift {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.hover-lift:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-xl);
}

/* Classes de utilidade para espaçamento */
.spacing-xs { padding: var(--spacing-xs); }
.spacing-sm { padding: var(--spacing-sm); }
.spacing-md { padding: var(--spacing-md); }
.spacing-lg { padding: var(--spacing-lg); }
.spacing-xl { padding: var(--spacing-xl); }
.spacing-2xl { padding: var(--spacing-2xl); }
.spacing-3xl { padding: var(--spacing-3xl); }

/* Classes de utilidade para bordas */
.radius-sm { border-radius: var(--radius-sm); }
.radius-md { border-radius: var(--radius-md); }
.radius-lg { border-radius: var(--radius-lg); }
.radius-xl { border-radius: var(--radius-xl); }
.radius-2xl { border-radius: var(--radius-2xl); }
