/**
 * Cyberpunk Improved Design System
 * King Size Game - Lisibilité et Esthétique Optimisées
 * Version: 4.0.0
 *
 * OBJECTIFS:
 * - Améliorer la lisibilité des textes
 * - Réduire les glows excessifs
 * - Créer une hiérarchie visuelle claire
 * - Maintenir l'esthétique cyberpunk
 */

/* ==========================================================================
   VARIABLES AMÉLIORÉES - LISIBILITÉ OPTIMALE
   ========================================================================== */

:root {
  /* === COULEURS PRIMAIRES (Révisées pour meilleure lisibilité) === */
  --cyan-primary: #00E5FF;        /* Cyan vif mais lisible */
  --cyan-bright: #4DFFFF;         /* Cyan très clair pour textes importants */
  --cyan-dark: #00BCD4;           /* Cyan foncé pour sous-titres */

  --magenta-primary: #FF1744;     /* Magenta vif */
  --magenta-bright: #FF4081;      /* Magenta clair */
  --magenta-dark: #C2185B;        /* Magenta foncé */

  --violet-primary: #651FFF;      /* Violet vif */
  --violet-bright: #7C4DFF;       /* Violet clair */
  --violet-dark: #4527A0;         /* Violet foncé */

  --green-matrix: #00FF41;        /* Vert Matrix pour succès */
  --orange-neon: #FF6E40;         /* Orange néon pour CTAs */
  --yellow-electric: #FFD740;     /* Jaune électrique pour warnings */

  /* === BACKGROUNDS (Plus de profondeur) === */
  --bg-void: #000000;             /* Noir absolu */
  --bg-base: #0A0A0F;             /* Noir très foncé */
  --bg-surface: #12121A;          /* Surface principale */
  --bg-elevated: #1A1A28;         /* Cartes élevées */
  --bg-highlight: #252538;        /* Éléments actifs */

  /* Overlays avec gradients */
  --overlay-dark: linear-gradient(180deg, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.9) 100%);
  --overlay-glass: rgba(18, 18, 26, 0.8);
  --overlay-glow: radial-gradient(circle at 50% 50%, rgba(0,229,255,0.1) 0%, transparent 70%);

  /* === TEXTES (Hiérarchie claire) === */
  --text-white: #FFFFFF;           /* Blanc pur - titres principaux */
  --text-primary: #E0E0E0;         /* Gris très clair - textes principaux */
  --text-secondary: #B0B0B0;       /* Gris clair - textes secondaires */
  --text-tertiary: #808080;        /* Gris moyen - textes tertiaires */
  --text-disabled: #505050;        /* Gris foncé - désactivé */

  /* === GLOWS SUBTILS (Lisibilité préservée) === */
  /* Glow pour titres - très subtil */
  --glow-title-cyan: 0 0 30px rgba(0, 229, 255, 0.2),
                     0 0 60px rgba(0, 229, 255, 0.1);

  --glow-title-magenta: 0 0 30px rgba(255, 23, 68, 0.2),
                        0 0 60px rgba(255, 23, 68, 0.1);

  /* Glow pour textes - extrêmement subtil */
  --glow-text-subtle: 0 0 10px rgba(255, 255, 255, 0.05);

  /* Glow pour bordures - visible mais pas éblouissant */
  --glow-border-cyan: 0 0 20px rgba(0, 229, 255, 0.4),
                      inset 0 0 20px rgba(0, 229, 255, 0.1);

  --glow-border-magenta: 0 0 20px rgba(255, 23, 68, 0.4),
                         inset 0 0 20px rgba(255, 23, 68, 0.1);

  /* === SHADOWS (Profondeur) === */
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.6);
  --shadow-xl: 0 16px 64px rgba(0,0,0,0.7);

  /* Shadow avec couleur néon */
  --shadow-cyan: 0 8px 32px rgba(0, 229, 255, 0.2);
  --shadow-magenta: 0 8px 32px rgba(255, 23, 68, 0.2);

  /* === SPACING === */
  --space-unit: 8px;
  --space-xs: 8px;
  --space-sm: 16px;
  --space-md: 24px;
  --space-lg: 32px;
  --space-xl: 48px;
  --space-xxl: 64px;
  --space-xxxl: 96px;

  /* === TRANSITIONS === */
  --transition-fast: 0.15s ease-out;
  --transition-base: 0.3s ease-out;
  --transition-slow: 0.5s ease-out;
  --transition-bounce: 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

/* ==========================================================================
   TYPOGRAPHIE AMÉLIORÉE
   ========================================================================== */

/* Titres principaux - Lisibilité maximale */
h1, .h1,
.elementor-heading-title {
  font-family: 'Orbitron', 'Rajdhani', sans-serif;
  font-weight: 700;
  color: var(--text-white);
  line-height: 1.2;
  letter-spacing: 0.02em;
  text-transform: uppercase;

  /* Glow TRÈS subtil pour ne pas gêner la lecture */
  text-shadow: var(--glow-title-cyan);
}

h1, .h1 {
  font-size: clamp(2rem, 5vw, 3.5rem);
  margin-bottom: var(--space-lg);
}

h2, .h2 {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700;
  color: var(--cyan-bright);
  line-height: 1.3;
  margin-bottom: var(--space-md);

  /* Glow réduit */
  text-shadow: 0 0 20px rgba(0, 229, 255, 0.15);
}

h3, .h3 {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(1.25rem, 3vw, 1.75rem);
  font-weight: 600;
  color: var(--text-white);
  line-height: 1.4;
  margin-bottom: var(--space-sm);

  /* Pas de glow sur h3 pour éviter la surcharge */
  text-shadow: none;
}

h4, .h4 {
  font-family: 'Inter', sans-serif;
  font-size: clamp(1rem, 2.5vw, 1.25rem);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.5;
  margin-bottom: var(--space-sm);
}

/* Paragraphes - Lisibilité optimale */
p, .paragraph {
  font-family: 'Inter', sans-serif;
  font-size: clamp(0.95rem, 1.5vw, 1.05rem);
  font-weight: 400;
  color: var(--text-primary);
  line-height: 1.8;
  margin-bottom: var(--space-md);

  /* Pas de glow sur les paragraphes */
  text-shadow: none;
}

/* Textes secondaires */
.text-secondary {
  color: var(--text-secondary);
  font-size: 0.9rem;
}

/* Textes tertiaires */
.text-tertiary {
  color: var(--text-tertiary);
  font-size: 0.85rem;
}

/* Liens - État clair et lisible */
a {
  color: var(--cyan-bright);
  text-decoration: none;
  transition: var(--transition-fast);

  /* Pas de glow par défaut */
  text-shadow: none;
}

a:hover {
  color: var(--magenta-bright);

  /* Glow subtil au hover uniquement */
  text-shadow: 0 0 15px rgba(255, 64, 129, 0.3);
}

/* ==========================================================================
   CARTES ET CONTAINERS
   ========================================================================== */

.card,
.cyberpunk-card {
  background: var(--bg-elevated);
  border-radius: 8px;
  padding: var(--space-lg);
  position: relative;
  overflow: hidden;

  /* Bordure subtile */
  border: 1px solid rgba(0, 229, 255, 0.2);

  /* Shadow pour profondeur */
  box-shadow: var(--shadow-md);

  /* Transition douce */
  transition: all var(--transition-base);
}

.card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--cyan-primary) 50%,
    transparent 100%
  );
  opacity: 0.5;
}

.card:hover {
  transform: translateY(-4px);
  border-color: rgba(0, 229, 255, 0.4);
  box-shadow: var(--shadow-lg), var(--shadow-cyan);
}

/* Card avec accent magenta */
.card-magenta {
  border-color: rgba(255, 23, 68, 0.2);
}

.card-magenta::before {
  background: linear-gradient(90deg,
    transparent 0%,
    var(--magenta-primary) 50%,
    transparent 100%
  );
}

.card-magenta:hover {
  border-color: rgba(255, 23, 68, 0.4);
  box-shadow: var(--shadow-lg), var(--shadow-magenta);
}

/* ==========================================================================
   BOUTONS - STYLE AMÉLIORÉ
   ========================================================================== */

.btn,
.elementor-button,
button[type="submit"] {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 14px 32px;
  border: 2px solid var(--cyan-primary);
  background: transparent;
  color: var(--cyan-bright);
  position: relative;
  cursor: pointer;
  overflow: hidden;
  transition: all var(--transition-base);

  /* Clip path pour angles coupés */
  clip-path: polygon(
    8px 0,
    100% 0,
    100% calc(100% - 8px),
    calc(100% - 8px) 100%,
    0 100%,
    0 8px
  );

  /* Glow subtil */
  box-shadow: var(--glow-border-cyan);
}

/* Effet de remplissage au hover */
.btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: var(--cyan-primary);
  transition: left var(--transition-base);
  z-index: -1;
}

.btn:hover {
  color: var(--bg-base);
  border-color: var(--cyan-bright);
  transform: translateY(-2px);
  box-shadow: 0 0 30px rgba(0, 229, 255, 0.5);
}

.btn:hover::before {
  left: 0;
}

/* Bouton secondary (Magenta) */
.btn-secondary {
  border-color: var(--magenta-primary);
  color: var(--magenta-bright);
  box-shadow: var(--glow-border-magenta);
}

.btn-secondary::before {
  background: var(--magenta-primary);
}

.btn-secondary:hover {
  border-color: var(--magenta-bright);
  box-shadow: 0 0 30px rgba(255, 23, 68, 0.5);
}

/* Bouton Success (Vert) */
.btn-success {
  border-color: var(--green-matrix);
  color: var(--green-matrix);
}

.btn-success::before {
  background: var(--green-matrix);
}

/* ==========================================================================
   SECTIONS ET ESPACEMENTS
   ========================================================================== */

section,
.elementor-section {
  padding: var(--space-xxxl) 0;
  position: relative;
}

.section-bg-dark {
  background: var(--bg-base);
}

.section-bg-surface {
  background: var(--bg-surface);
}

.section-bg-elevated {
  background: var(--bg-elevated);
}

/* Container avec largeur max */
.container,
.elementor-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-lg);
}

/* ==========================================================================
   BADGES ET LABELS
   ========================================================================== */

.badge,
.cyber-badge {
  display: inline-block;
  font-family: 'Rajdhani', sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 6px 16px;
  background: rgba(0, 229, 255, 0.1);
  border: 1px solid var(--cyan-primary);
  color: var(--cyan-bright);
  border-radius: 4px;

  /* Glow très subtil */
  box-shadow: 0 0 15px rgba(0, 229, 255, 0.2);
}

.badge-magenta {
  background: rgba(255, 23, 68, 0.1);
  border-color: var(--magenta-primary);
  color: var(--magenta-bright);
  box-shadow: 0 0 15px rgba(255, 23, 68, 0.2);
}

.badge-success {
  background: rgba(0, 255, 65, 0.1);
  border-color: var(--green-matrix);
  color: var(--green-matrix);
  box-shadow: 0 0 15px rgba(0, 255, 65, 0.2);
}

/* ==========================================================================
   INPUTS ET FORMULAIRES
   ========================================================================== */

input[type="text"],
input[type="email"],
input[type="tel"],
textarea,
select {
  width: 100%;
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  padding: 14px 20px;
  background: var(--bg-surface);
  border: 1px solid rgba(0, 229, 255, 0.2);
  border-radius: 4px;
  color: var(--text-primary);
  transition: all var(--transition-fast);
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--cyan-primary);
  box-shadow: var(--glow-border-cyan);
  background: var(--bg-elevated);
}

input::placeholder,
textarea::placeholder {
  color: var(--text-tertiary);
}

/* ==========================================================================
   GRILLES ET LAYOUTS
   ========================================================================== */

.grid {
  display: grid;
  gap: var(--space-lg);
}

.grid-2 {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.grid-3 {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.grid-4 {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* Flexbox utilities */
.flex {
  display: flex;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flex-column {
  display: flex;
  flex-direction: column;
}

/* ==========================================================================
   ANIMATIONS SUBTILES
   ========================================================================== */

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes pulse-subtle {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.8;
  }
}

@keyframes glow-pulse {
  0%, 100% {
    box-shadow: var(--glow-border-cyan);
  }
  50% {
    box-shadow: 0 0 30px rgba(0, 229, 255, 0.6),
                inset 0 0 30px rgba(0, 229, 255, 0.2);
  }
}

.animate-fade-in-up {
  animation: fadeInUp 0.6s ease-out;
}

.animate-pulse {
  animation: pulse-subtle 2s ease-in-out infinite;
}

/* ==========================================================================
   UTILITIES
   ========================================================================== */

/* Marges */
.mt-xs { margin-top: var(--space-xs); }
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }

.mb-xs { margin-bottom: var(--space-xs); }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }
.mb-xl { margin-bottom: var(--space-xl); }

/* Padding */
.p-xs { padding: var(--space-xs); }
.p-sm { padding: var(--space-sm); }
.p-md { padding: var(--space-md); }
.p-lg { padding: var(--space-lg); }
.p-xl { padding: var(--space-xl); }

/* Text align */
.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }

/* Colors */
.text-cyan { color: var(--cyan-bright); }
.text-magenta { color: var(--magenta-bright); }
.text-violet { color: var(--violet-bright); }
.text-green { color: var(--green-matrix); }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 768px) {
  :root {
    --space-xxxl: 64px;
    --space-xxl: 48px;
  }

  section,
  .elementor-section {
    padding: var(--space-xxl) 0;
  }

  .container {
    padding: 0 var(--space-md);
  }

  .grid-2,
  .grid-3,
  .grid-4 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .btn {
    padding: 12px 24px;
    font-size: 0.9rem;
  }
}
