/* ============================================================================
   GLOBAL.CSS - SISTEMA DE DESIGN OTIMIZADO - NEWGYM MULTI-CLIENTE
   ============================================================================
   Sistema harmonioso com paleta reduzida e consistente
   Baseado em princípios de Material Design e Tailwind CSS
   
   FILOSOFIA:
   - 5-6 tons por cor (light, main, dark + backgrounds)
   - Reutilização inteligente (ex: success serve para "pago", "disponível")
   - Cores semânticas > cores específicas demais
   ============================================================================
*/

:root {
    /* ========================================================================
       🎨 PALETA DA MARCA (Identidade Visual)
       ======================================================================== */
    
    /* Primária (Roxo) - Usada em: botões principais, links, destaques */
    --primary-50: #f5f3ff;                 /* Fundo muito claro */
    --primary-100: #ede9fe;                /* Fundo claro */
    --primary-500: hsl(32, 28%, 24%);                /* COR PRINCIPAL 667eea */
    --primary-600: #5a6fd8;                /* Hover/Active */
    --primary-700: #4c5fd1;                /* Pressed */
    --primary-900: hsl(173, 21%, 25%);                /* Acento escuro/gradiente 764ba2 */
    --primary-950: #490155;                /* roxo intermedio 5506a3*/
    --primary-960: #042c8a;                /* Azul escuro*/
    /*--primary-999: #2c3e50;                    */
    /*--primary-999: #7A3427;                   */
      --primary-999: #0a3f63;                  /* Azul escuro petróleo */
    /* Gradiente da marca */
    --gradient-brand: linear-gradient(135deg, var(--primary-500) 0%, var(--primary-900) 100%);
    
    
    /* ========================================================================
       ✅ CORES DE FEEDBACK (Estados e Ações)
       Cada cor tem 5 tons: 50 (bg), 100 (border light), 500 (main), 600 (hover), 700 (dark)
       ======================================================================== */
    
    /* SUCESSO (Verde) */
    --success-50: #CCD4C9;                 /* Fundo claro */
    --success-100: #6B746B;                /* Borda clara */
    --success-500: #22c55e;                /* PRINCIPAL - Verde vibrante */
    --success-600: #16a34a;                /* Hover */
    --success-700: #15803d;                /* Escuro/texto */
    
    /* AVISO (Amarelo/Laranja) */
    --warning-50: #fffbeb;                 /* Fundo claro */
    --warning-100: #fef3c7;                /* Borda clara */
    
    --warning-500: #FE9402;                /* PRINCIPAL - Âmbar */
    --warning-600: #D7A633;                /* Hover */
    --warning-700: #fd5602;                /* Escuro/texto */
    
    /* PERIGO (Vermelho) */
    --danger-50: #fef2f2;                  /* Fundo claro */
    --danger-100: #fee2e2;                 /* Borda clara */
    --danger-500: #ef4444;                 /* PRINCIPAL - Vermelho vibrante */
    --danger-600: #dc2626;                 /* Hover */
    --danger-700: #b91c1c;                 /* Escuro/texto */
    
    /* INFORMAÇÃO (Azul) */
    --info-50: #eff6ff;                    /* Fundo claro */
    --info-100: #dbeafe;                   /* Borda clara */
    --info-500: #3b82f6;                   /* PRINCIPAL - Azul vibrante */
    --info-600: #2563eb;                   /* Hover */
    --info-700: #1d4ed8;                   /* Escuro/texto */
    
    
    /* ========================================================================
       🎯 CORES CONTEXTUAIS (Reutilizam as cores de feedback)
       Evita duplicação - usa as cores semânticas já definidas
       ======================================================================== */
    
    /* Pagamentos (reutiliza success/warning/danger) */
    --payment-paid: var(--success-500);              /* Verde = Pago */
    --payment-pending: var(--warning-500);           /* Amarelo = Pendente */
    --payment-overdue: var(--warning-600);           /* Laranja escuro = Atrasado */
    --payment-cancelled: var(--gray-500);            /* Cinza = Cancelado */
    
    /* Sessões/Bookings (reutiliza cores semânticas) */
    --session-available: var(--success-500);         /* Verde = Disponível */
    --session-confirmed: var(--success-600);         /* Verde escuro = Confirmado */
    --session-pending: var(--warning-500);           /* Amarelo = Pendente */
    --session-full: var(--danger-500);               /* Vermelho = Lotada */
    --session-cancelled: var(--gray-500);            /* Cinza = Cancelada */
    
    
    /* ========================================================================
       🌈 Aulas em Grupo (Cores únicas e distintivas)
       Paleta especial para diferenciar tipos de atividades
       ======================================================================== */
    
    --theme-yoga: #a855f7;                 /* Roxo vibrante */
    --theme-pilates: var(--info-500);              /* Azul (reutiliza info) */
    --theme-functional: var(--success-500);           /* Verde (reutiliza success) */
    --theme-hiit: var(--danger-500);                 /* Vermelho (reutiliza danger) */
    --theme-cycling: #06b6d4;              /* Ciano */
    --theme-dance: #ec4899;                /* Rosa */
    --theme-mobility: var(--warning-500);             /* Âmbar (reutiliza warning) */
    --theme-recovery: #64748b;             /* Cinza médio */
    
    
    /* ========================================================================
       ⚪ ESCALA DE CINZAS (Harmonizada)
       10 tons suficientes para todos os casos: fundos, bordas, textos
       ======================================================================== */
    
    --gray-50: #f9fafb;                    /* Quase branco */
    --gray-100: #f3f4f6;                   /* Fundo muito claro */
    --gray-200: #e5e7eb;                   /* Fundo claro / borda clara */
    --gray-300: #d1d5db;                   /* Borda média */
    --gray-400: #9ca3af;                   /* Borda escura / texto desabilitado */
    --gray-500: #6b7280;                   /* Texto secundário */
    --gray-600: #4b5563;                   /* Texto normal */
    --gray-700: #374151;                   /* Texto forte */
    --gray-800: #1f2937;                   /* Texto muito escuro */
    --gray-900: #111827;                   /* Quase preto */
    
    /* Aliases semânticos para facilitar uso */
    --text-primary: var(--gray-800);       /* Texto principal */
    --text-secondary: var(--gray-600);     /* Texto secundário */
    --text-muted: var(--gray-500);         /* Texto desbotado */
    --text-disabled: var(--gray-400);      /* Texto desabilitado */
    
    --border-light: var(--gray-200);       /* Borda clara */
    --border-main: var(--gray-300);        /* Borda padrão */
    --border-dark: var(--gray-400);        /* Borda escura */
    
    --bg-page: var(--gray-50);             /* Fundo da página */
    --bg-card: var(--white);                    /* Fundo de cards */
    --bg-hover: var(--gray-100);           /* Fundo hover */
    --bg-disabled: var(--gray-200);        /* Fundo desabilitado */
    
    /* Cores fundamentais */
    --white: #ffffff;
    --black: #000000;
    
    
    /* ========================================================================
       🎨 CORES ESPECIAIS (Contextos únicos)
       ======================================================================== */
    
    /* Navegação (cor fixa, sempre presente) */
    /*--navbar-bg: #2c3e50;                  /* Azul escuro petróleo */
    /* --navbar-bg: var(--primary-999); */
    --navbar-bg: var(--bg2);
    --navbar-text: var(--white);
    --navbar-hover: #34495e;               /* Um tom mais claro */
    
    /* Links (reutiliza marca) */
    --link-color: var(--primary-500);
    --link-hover: var(--primary-600);
    --link-visited: var(--primary-700);
    
    /* Calendário (tons suaves para não cansar visualmente) */
    --calendar-available: var(--success-50);     /* Verde muito claro */
    --calendar-booked: var(--primary-50);        /* Roxo muito claro */
    --calendar-unavailable: var(--gray-100);     /* Cinza claro */
    --calendar-today: var(--info-50);            /* Azul muito claro */
    
    /* Overlay e sombras */
    --overlay-dark: rgba(0, 0, 0, 0.5);
    --overlay-light: rgba(255, 255, 255, 0.9);
    
    
    /* ========================================================================
       📏 SISTEMA DE ESPAÇAMENTO
       Escala consistente baseada em 4px
       ======================================================================== */
    
    --space-0: 0;
    --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 */
    --space-20: 5rem;        /* 80px */
    
    
    /* ========================================================================
       🔲 BORDAS E RAIOS
       ======================================================================== */
    
    --radius-sm: 0.25rem;    /* 4px */
    --radius-md: 0.375rem;   /* 6px */
    --radius-lg: 0.5rem;     /* 8px */
    --radius-xl: 0.75rem;    /* 12px */
    --radius-2xl: 1rem;      /* 16px */
    --radius-full: 9999px;   /* Círculo perfeito */
    
    --border-width: 1px;
    --border-width-2: 2px;
    --border-width-4: 4px;
    
    
    /* ========================================================================
       🌑 SOMBRAS (Profundidade visual)
       ======================================================================== */
    
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.15);
    --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.2);
    --shadow-2xl: 0 25px 50px rgba(0, 0, 0, 0.25);
    
    /* Sombras coloridas (sutis) */
    --shadow-primary: 0 4px 12px rgba(102, 126, 234, 0.3);
    --shadow-success: 0 4px 12px rgba(34, 197, 94, 0.3);
    --shadow-danger: 0 4px 12px rgba(239, 68, 68, 0.3);
    --shadow-warning: 0 4px 12px rgba(245, 158, 11, 0.3);
    
    --shadow-inner: inset 0 2px 4px rgba(0, 0, 0, 0.06);
    
    
    /* ========================================================================
       📐 BORDER RADIUS
       ======================================================================== */
    
    --border-radius-sm: 0.25rem;  /* 4px */
    --border-radius-md: 0.5rem;   /* 8px */
    --border-radius-lg: 0.75rem;  /* 12px */
    --border-radius-xl: 1rem;     /* 16px */
    --border-radius-2xl: 1.5rem;  /* 24px */
    --border-radius-full: 9999px;
    
    
    /* ========================================================================
       ⚡ TRANSIÇÕES E ANIMAÇÕES
       ======================================================================== */
    
    --transition-fast: 150ms ease;
    --transition-base: 300ms ease;
    --transition-slow: 500ms ease;
    
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    
    
    /* ========================================================================
       📝 TIPOGRAFIA
       ======================================================================== */
    
    --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;
    
    /* Tamanhos de fonte */
    --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 */
    
    /* Pesos */
    --font-normal: 400;
    --font-medium: 500;
    --font-semibold: 600;
    --font-bold: 700;
    
    /* Altura de linha */
    --leading-tight: 1.25;
    --leading-normal: 1.5;
    --leading-relaxed: 1.75;
    
    
    /* ========================================================================
       📚 Z-INDEX (Camadas)
       ======================================================================== */
    
    --z-dropdown: 1000;
    --z-sticky: 1020;
    --z-fixed: 1030;
    --z-modal-backdrop: 1040;
    --z-modal: 1050;
    --z-popover: 1060;
    --z-tooltip: 1070;

    /* ========================================================================
       igual ao root da styles.css na fromjc
       ======================================================================== */

  --bg1:#071a2c;
  --bg2:#0b2a44;
  --card: rgba(255,255,255,.08);
  --stroke: rgba(255,255,255,.14);
  --text:#eaf2ff;
  --muted: rgba(234,242,255,.75);
  --accent1:#7c3aed;
  --accent2:#06b6d4;
  --accent3:#22c55e;
  --shadow: 0 20px 60px rgba(0,0,0,.35);
  --radius: 18px;
  --radius2: 14px;

}


/* ============================================================================
   🎯 CLASSES UTILITÁRIAS
   ============================================================================ */

.container-main {
    max-width: 1600px;  /* Largura máxima para manter o conteúdo centrado em ecrãs grandes */
    margin: 0 auto;
    padding: 0 var(--space-4);
    margin-top: 85px;
}

/* Gradientes */
.bg-gradient-brand {
    background: var(--gradient-brand);
}

/* Sombras rápidas */
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }

/* Transições */
.transition { transition: var(--transition-base); }
.transition-fast { transition: var(--transition-fast); }




/* ============================================================================
   📱 RESPONSIVO
   ============================================================================ */

@media (max-width: 768px) {
    .container-main {
        margin-top: 70px;
        padding: 0 var(--space-2);
    }
}

@media (max-width: 480px) {
    .container-main {
        padding: 0 var(--space-1);
    }
}


/* ============================================================================
   📖 DOCUMENTAÇÃO DE USO
   ============================================================================
   
   ✅ PRINCÍPIOS DESTA PALETA:
   
   1. HARMONIA - Cada cor tem 5 tons consistentes (50, 100, 500, 600, 700)
   2. REUTILIZAÇÃO - Cores contextuais reutilizam cores semânticas
   3. SEMÂNTICA - Nomes descritivos (success em vez de green-500)
   4. ESCALABILIDADE - Fácil adicionar novos tons se necessário
   5. MANUTENÇÃO - Menos variáveis = mais fácil de manter
   
   
   🎨 COMPARAÇÃO: Antes vs Depois
   
   ANTES:
   - ~150 variáveis de cor
   - Muitas cores similares (10 tons de verde diferentes)
   - Difícil escolher qual usar
   - Inconsistência visual
   
   DEPOIS:
   - ~70 variáveis de cor (redução de 53%)
   - 5-6 tons por família
   - Clara hierarquia e propósito
   - Visual harmonioso e profissional
   
   ============================================================================
   💡 COMO USAR:
   
   Feedback de ações:
   .btn-success { background: var(--success-500); }
   .btn-success:hover { background: var(--success-600); }
   .alert-success { background: var(--success-50); border-color: var(--success-500); }
   
   Contextos específicos:
   .payment-paid { color: var(--payment-paid); }
   .session-available { background: var(--session-available); }
   
   Textos e bordas:
   .text-main { color: var(--text-primary); }
   .text-secondary { color: var(--text-secondary); }
   .border { border: 1px solid var(--border-main); }
   
   
   🎨 PERSONALIZAÇÃO POR CLIENTE:
   
   Criar arquivo: themes/cliente-blue.css
   :root {
       --primary-500: var(--info-500);
       --primary-600: var(--info-600);
       --primary-900: #1e40af;
       --gradient-brand: linear-gradient(135deg, var(--primary-500) 0%, var(--primary-900) 100%);
   }
   
   ============================================================================ */

/* ============================================================================
   CLASSES UTILITÁRIAS PARA BADGES E BOTÕES LARANJA
   ============================================================================ */

/* Badge laranja (para pagamentos atrasados) */
.bg-orange {
    background-color: var(--warning-700) !important;
    color: var(--white) !important;
}

/* Botão outline laranja */
.btn-outline-orange {
    border: 2px solid var(--warning-700);
    color: var(--warning-700);
    background: transparent;
}

.btn-outline-orange:hover {
    background-color: var(--warning-700);
    border-color: var(--warning-700);
    color: var(--white);
}

