/**
 * ═══════════════════════════════════════════════════════════════
 *  RURAL CAFÉ - MODERN DESIGN SYSTEM v3.0
 *  Sistema de design moderno e profissional
 * ═══════════════════════════════════════════════════════════════
 */

/* ═══════════════════════════════════════════════════════════════
   1. DESIGN TOKENS - CORES
   ═══════════════════════════════════════════════════════════════ */

:root {
    /* Cores Primárias - Rural Café */
    --primary-50: #f0f4ff;
    --primary-100: #e0e9ff;
    --primary-200: #c7d7fe;
    --primary-300: #a5bbfc;
    --primary-400: #8197f8;
    --primary-500: #667eea;
    --primary-600: #4f5dd6;
    --primary-700: #4349bc;
    --primary-800: #3a3e98;
    --primary-900: #323678;

    /* Cores Secundárias - Terra/Café */
    --secondary-50: #faf5f0;
    --secondary-100: #f4e8dc;
    --secondary-200: #e8ceb8;
    --secondary-300: #d9ac8a;
    --secondary-400: #c88a5e;
    --secondary-500: #b56f3e;
    --secondary-600: #9b5a32;
    --secondary-700: #7d482b;
    --secondary-800: #683c28;
    --secondary-900: #563323;

    /* Cores de Status */
    --success-50: #f0fdf4;
    --success-100: #dcfce7;
    --success-500: #22c55e;
    --success-600: #16a34a;
    --success-700: #15803d;

    --warning-50: #fffbeb;
    --warning-100: #fef3c7;
    --warning-500: #f59e0b;
    --warning-600: #d97706;
    --warning-700: #b45309;

    --error-50: #fef2f2;
    --error-100: #fee2e2;
    --error-500: #ef4444;
    --error-600: #dc2626;
    --error-700: #b91c1c;

    --info-50: #eff6ff;
    --info-100: #dbeafe;
    --info-500: #3b82f6;
    --info-600: #2563eb;
    --info-700: #1d4ed8;

    /* Cores Neutras */
    --gray-50: #fafafa;
    --gray-100: #f5f5f5;
    --gray-200: #e5e5e5;
    --gray-300: #d4d4d4;
    --gray-400: #a3a3a3;
    --gray-500: #737373;
    --gray-600: #525252;
    --gray-700: #404040;
    --gray-800: #262626;
    --gray-900: #171717;

    /* Shadows & Elevations */
    --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);

    /* Border Radius */
    --radius-xs: 0.25rem;   /* 4px */
    --radius-sm: 0.375rem;  /* 6px */
    --radius-md: 0.5rem;    /* 8px */
    --radius-lg: 0.75rem;   /* 12px */
    --radius-xl: 1rem;      /* 16px */
    --radius-2xl: 1.5rem;   /* 24px */
    --radius-full: 9999px;

    /* Spacing */
    --space-1: 0.25rem;     /* 4px */
    --space-2: 0.5rem;      /* 8px */
    --space-3: 0.75rem;     /* 12px */
    --space-4: 1rem;        /* 16px */
    --space-5: 1.25rem;     /* 20px */
    --space-6: 1.5rem;      /* 24px */
    --space-8: 2rem;        /* 32px */
    --space-10: 2.5rem;     /* 40px */
    --space-12: 3rem;       /* 48px */
    --space-16: 4rem;       /* 64px */

    /* Typography */
    --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Helvetica Neue', sans-serif;
    --font-mono: 'JetBrains Mono', 'Fira Code', 'Consolas', monospace;

    --text-xs: 0.75rem;     /* 12px */
    --text-sm: 0.875rem;    /* 14px */
    --text-base: 1rem;      /* 16px */
    --text-lg: 1.125rem;    /* 18px */
    --text-xl: 1.25rem;     /* 20px */
    --text-2xl: 1.5rem;     /* 24px */
    --text-3xl: 1.875rem;   /* 30px */
    --text-4xl: 2.25rem;    /* 36px */

    /* Transitions */
    --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-base: 200ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 300ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-bounce: 500ms cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

/* ═══════════════════════════════════════════════════════════════
   2. BOTÕES MODERNOS - SISTEMA COMPLETO
   ═══════════════════════════════════════════════════════════════ */

/* Base do Botão */
.btn-modern {
    /* Layout & Size */
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-6);

    /* Typography */
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    font-weight: 600;
    line-height: 1.5;
    text-decoration: none;
    white-space: nowrap;

    /* Visual */
    border: 2px solid transparent;
    border-radius: var(--radius-lg);
    background: transparent;
    cursor: pointer;
    position: relative;
    overflow: hidden;

    /* Transitions */
    transition: all var(--transition-base);

    /* Interactions */
    user-select: none;
    -webkit-tap-highlight-color: transparent;
}

.btn-modern:focus {
    outline: none;
    box-shadow: 0 0 0 3px var(--primary-200);
}

.btn-modern:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* Variantes de Tamanho */
.btn-xs {
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-xs);
    border-radius: var(--radius-sm);
}

.btn-sm {
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-sm);
    border-radius: var(--radius-md);
}

.btn-lg {
    padding: var(--space-4) var(--space-8);
    font-size: var(--text-lg);
    border-radius: var(--radius-xl);
}

.btn-xl {
    padding: var(--space-5) var(--space-10);
    font-size: var(--text-xl);
    border-radius: var(--radius-2xl);
}

/* ══════════════════════════════════════════════════════════════
   PRIMARY BUTTON - Ações Principais
   ══════════════════════════════════════════════════════════════ */

.btn-primary-modern {
    background: linear-gradient(135deg, var(--primary-500) 0%, var(--primary-600) 100%);
    color: white;
    border-color: var(--primary-600);
    box-shadow: var(--shadow-sm), 0 0 0 0 var(--primary-300);
}

.btn-primary-modern:hover {
    background: linear-gradient(135deg, var(--primary-600) 0%, var(--primary-700) 100%);
    border-color: var(--primary-700);
    box-shadow: var(--shadow-lg), 0 0 0 0 var(--primary-300);
    transform: translateY(-1px);
}

.btn-primary-modern:active {
    transform: translateY(0);
    box-shadow: var(--shadow-sm);
}

/* Efeito Ripple */
.btn-primary-modern::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.4) 0%, transparent 70%);
    opacity: 0;
    transition: opacity var(--transition-fast);
}

.btn-primary-modern:active::after {
    opacity: 1;
    animation: ripple 0.6s ease-out;
}

@keyframes ripple {
    from {
        transform: scale(0);
        opacity: 1;
    }
    to {
        transform: scale(2.5);
        opacity: 0;
    }
}

/* ══════════════════════════════════════════════════════════════
   SECONDARY BUTTON - Ações Secundárias
   ══════════════════════════════════════════════════════════════ */

.btn-secondary-modern {
    background: white;
    color: var(--gray-700);
    border-color: var(--gray-300);
    box-shadow: var(--shadow-sm);
}

.btn-secondary-modern:hover {
    background: var(--gray-50);
    border-color: var(--gray-400);
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
}

.btn-secondary-modern:active {
    transform: translateY(0);
    box-shadow: var(--shadow-sm);
}

/* ══════════════════════════════════════════════════════════════
   SUCCESS BUTTON - Ações de Sucesso/Confirmação
   ══════════════════════════════════════════════════════════════ */

.btn-success-modern {
    background: linear-gradient(135deg, var(--success-500) 0%, var(--success-600) 100%);
    color: white;
    border-color: var(--success-600);
    box-shadow: var(--shadow-sm), 0 0 0 0 var(--success-200);
}

.btn-success-modern:hover {
    background: linear-gradient(135deg, var(--success-600) 0%, var(--success-700) 100%);
    border-color: var(--success-700);
    box-shadow: var(--shadow-lg), 0 4px 20px rgba(34, 197, 94, 0.3);
    transform: translateY(-1px);
}

.btn-success-modern:active {
    transform: translateY(0);
    box-shadow: var(--shadow-sm);
}

/* ══════════════════════════════════════════════════════════════
   DANGER BUTTON - Ações Destrutivas
   ══════════════════════════════════════════════════════════════ */

.btn-danger-modern {
    background: linear-gradient(135deg, var(--error-500) 0%, var(--error-600) 100%);
    color: white;
    border-color: var(--error-600);
    box-shadow: var(--shadow-sm), 0 0 0 0 var(--error-200);
}

.btn-danger-modern:hover {
    background: linear-gradient(135deg, var(--error-600) 0%, var(--error-700) 100%);
    border-color: var(--error-700);
    box-shadow: var(--shadow-lg), 0 4px 20px rgba(239, 68, 68, 0.3);
    transform: translateY(-1px);
}

.btn-danger-modern:active {
    transform: translateY(0);
    box-shadow: var(--shadow-sm);
}

/* ══════════════════════════════════════════════════════════════
   WARNING BUTTON - Ações de Alerta
   ══════════════════════════════════════════════════════════════ */

.btn-warning-modern {
    background: linear-gradient(135deg, var(--warning-500) 0%, var(--warning-600) 100%);
    color: white;
    border-color: var(--warning-600);
    box-shadow: var(--shadow-sm);
}

.btn-warning-modern:hover {
    background: linear-gradient(135deg, var(--warning-600) 0%, var(--warning-700) 100%);
    border-color: var(--warning-700);
    box-shadow: var(--shadow-lg), 0 4px 20px rgba(245, 158, 11, 0.3);
    transform: translateY(-1px);
}

/* ══════════════════════════════════════════════════════════════
   INFO BUTTON - Informações
   ══════════════════════════════════════════════════════════════ */

.btn-info-modern {
    background: linear-gradient(135deg, var(--info-500) 0%, var(--info-600) 100%);
    color: white;
    border-color: var(--info-600);
    box-shadow: var(--shadow-sm);
}

.btn-info-modern:hover {
    background: linear-gradient(135deg, var(--info-600) 0%, var(--info-700) 100%);
    border-color: var(--info-700);
    box-shadow: var(--shadow-lg), 0 4px 20px rgba(59, 130, 246, 0.3);
    transform: translateY(-1px);
}

/* ══════════════════════════════════════════════════════════════
   GHOST BUTTON - Botão Transparente
   ══════════════════════════════════════════════════════════════ */

.btn-ghost {
    background: transparent;
    color: var(--gray-700);
    border-color: transparent;
}

.btn-ghost:hover {
    background: var(--gray-100);
    color: var(--gray-900);
}

.btn-ghost:active {
    background: var(--gray-200);
}

/* ══════════════════════════════════════════════════════════════
   OUTLINE BUTTON - Botão com Contorno
   ══════════════════════════════════════════════════════════════ */

.btn-outline-primary {
    background: transparent;
    color: var(--primary-600);
    border-color: var(--primary-500);
}

.btn-outline-primary:hover {
    background: var(--primary-50);
    border-color: var(--primary-600);
    color: var(--primary-700);
}

.btn-outline-secondary {
    background: transparent;
    color: var(--gray-700);
    border-color: var(--gray-400);
}

.btn-outline-secondary:hover {
    background: var(--gray-50);
    border-color: var(--gray-500);
    color: var(--gray-900);
}

.btn-outline-success {
    background: transparent;
    color: var(--success-600);
    border-color: var(--success-500);
}

.btn-outline-success:hover {
    background: var(--success-50);
    border-color: var(--success-600);
    color: var(--success-700);
}

.btn-outline-danger {
    background: transparent;
    color: var(--error-600);
    border-color: var(--error-500);
}

.btn-outline-danger:hover {
    background: var(--error-50);
    border-color: var(--error-600);
    color: var(--error-700);
}

/* ══════════════════════════════════════════════════════════════
   BUTTON GROUPS - Grupos de Botões
   ══════════════════════════════════════════════════════════════ */

.btn-group {
    display: inline-flex;
    gap: var(--space-2);
}

.btn-group-compact {
    display: inline-flex;
    gap: 0;
}

.btn-group-compact .btn-modern {
    border-radius: 0;
}

.btn-group-compact .btn-modern:first-child {
    border-top-left-radius: var(--radius-lg);
    border-bottom-left-radius: var(--radius-lg);
}

.btn-group-compact .btn-modern:last-child {
    border-top-right-radius: var(--radius-lg);
    border-bottom-right-radius: var(--radius-lg);
}

/* ══════════════════════════════════════════════════════════════
   BUTTON WITH ICON - Botões com Ícones
   ══════════════════════════════════════════════════════════════ */

.btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-2);
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--radius-md);
}

.btn-icon-sm {
    width: 2rem;
    height: 2rem;
    padding: var(--space-1);
}

.btn-icon-lg {
    width: 3rem;
    height: 3rem;
    padding: var(--space-3);
}

.btn-modern .icon {
    font-size: 1.25em;
    line-height: 1;
}

.btn-modern .icon-left {
    margin-right: calc(var(--space-2) * -0.5);
}

.btn-modern .icon-right {
    margin-left: calc(var(--space-2) * -0.5);
}

/* ══════════════════════════════════════════════════════════════
   LOADING STATE - Estado de Carregamento
   ══════════════════════════════════════════════════════════════ */

.btn-loading {
    position: relative;
    pointer-events: none;
}

.btn-loading .btn-content {
    opacity: 0;
}

.btn-loading::before {
    content: '';
    position: absolute;
    width: 1rem;
    height: 1rem;
    border: 2px solid currentColor;
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ══════════════════════════════════════════════════════════════
   BUTTON BLOCK - Botão Full Width
   ══════════════════════════════════════════════════════════════ */

.btn-block {
    display: flex;
    width: 100%;
}

/* ══════════════════════════════════════════════════════════════
   FLOATING ACTION BUTTON - FAB
   ══════════════════════════════════════════════════════════════ */

.btn-fab {
    position: fixed;
    bottom: var(--space-6);
    right: var(--space-6);
    width: 3.5rem;
    height: 3.5rem;
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-xl);
    z-index: 100;
}

.btn-fab:hover {
    box-shadow: var(--shadow-2xl);
    transform: translateY(-2px) scale(1.05);
}

/* ══════════════════════════════════════════════════════════════
   3. CARDS & CONTAINERS MODERNOS
   ══════════════════════════════════════════════════════════════ */

.card-modern {
    background: white;
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    box-shadow: var(--shadow-md);
    border: 1px solid var(--gray-200);
    transition: all var(--transition-base);
}

.card-modern:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

.card-header-modern {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-4);
    border-bottom: 2px solid var(--gray-100);
}

.card-title-modern {
    font-size: var(--text-xl);
    font-weight: 700;
    color: var(--gray-900);
}

/* ══════════════════════════════════════════════════════════════
   4. BADGES & TAGS
   ══════════════════════════════════════════════════════════════ */

.badge-modern {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-xs);
    font-weight: 600;
    border-radius: var(--radius-full);
    line-height: 1;
}

.badge-primary {
    background: var(--primary-100);
    color: var(--primary-700);
}

.badge-success {
    background: var(--success-100);
    color: var(--success-700);
}

.badge-warning {
    background: var(--warning-100);
    color: var(--warning-700);
}

.badge-danger {
    background: var(--error-100);
    color: var(--error-700);
}

.badge-info {
    background: var(--info-100);
    color: var(--info-700);
}

/* ══════════════════════════════════════════════════════════════
   5. INPUTS MODERNOS
   ══════════════════════════════════════════════════════════════ */

.input-modern {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-base);
    color: var(--gray-900);
    background: white;
    border: 2px solid var(--gray-300);
    border-radius: var(--radius-lg);
    transition: all var(--transition-base);
    font-family: var(--font-sans);
}

.input-modern:focus {
    outline: none;
    border-color: var(--primary-500);
    box-shadow: 0 0 0 3px var(--primary-100);
}

.input-modern::placeholder {
    color: var(--gray-400);
}

.input-modern:disabled {
    background: var(--gray-100);
    cursor: not-allowed;
    opacity: 0.6;
}

/* ══════════════════════════════════════════════════════════════
   6. ANIMATIONS & TRANSITIONS
   ══════════════════════════════════════════════════════════════ */

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-fade-in {
    animation: fadeIn var(--transition-base) ease-out;
}

@keyframes slideIn {
    from {
        transform: translateX(-100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

.animate-slide-in {
    animation: slideIn var(--transition-slow) ease-out;
}

/* ══════════════════════════════════════════════════════════════
   7. UTILITIES
   ══════════════════════════════════════════════════════════════ */

.shadow-modern-sm { box-shadow: var(--shadow-sm); }
.shadow-modern-md { box-shadow: var(--shadow-md); }
.shadow-modern-lg { box-shadow: var(--shadow-lg); }
.shadow-modern-xl { box-shadow: var(--shadow-xl); }

.rounded-modern-sm { border-radius: var(--radius-sm); }
.rounded-modern-md { border-radius: var(--radius-md); }
.rounded-modern-lg { border-radius: var(--radius-lg); }
.rounded-modern-xl { border-radius: var(--radius-xl); }
.rounded-modern-full { border-radius: var(--radius-full); }

.text-primary { color: var(--primary-600); }
.text-success { color: var(--success-600); }
.text-warning { color: var(--warning-600); }
.text-danger { color: var(--error-600); }
.text-info { color: var(--info-600); }

.bg-primary { background: var(--primary-500); }
.bg-success { background: var(--success-500); }
.bg-warning { background: var(--warning-500); }
.bg-danger { background: var(--error-500); }
.bg-info { background: var(--info-500); }
