/* ============================================
   MAROCLY.COM — ENHANCEMENT LAYER CSS
   ============================================
   Ce fichier enrichit visuellement la SPA React
   sans modifier le bundle minifié.
   Injecter APRES le bundle React dans index.html.
   ============================================ */

/* ------------------------------------------
   1. VARIABLES CSS COMPLÉMENTAIRES
   ------------------------------------------ */
:root {
  /* Couleurs d'enrichissement */
  --mco-orange-primary: #e67a34;
  --mco-orange-light: #f08a45;
  --mco-orange-glow: rgba(230, 122, 52, 0.4);
  --mco-orange-shimmer: rgba(230, 122, 52, 0.15);
  --mco-gold: #d4a574;
  --mco-gold-light: #e8c9a0;

  /* Fonds sombres */
  --mco-dark-deep: #0a0a0f;
  --mco-dark-base: #1a1a1a;
  --mco-dark-card: #1e1e24;
  --mco-dark-elevated: #25252e;

  /* Fonds clairs */
  --mco-light-base: #f6f4f0;
  --mco-light-card: #ffffff;

  /* Bordures */
  --mco-border-orange: rgba(230, 122, 52, 0.15);
  --mco-border-orange-strong: rgba(230, 122, 52, 0.3);

  /* Glassmorphism amélioré */
  --mco-glass-bg: rgba(26, 26, 26, 0.75);
  --mco-glass-blur: 20px;
  --mco-glass-border: rgba(255, 255, 255, 0.08);

  /* Ombres premium */
  --mco-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.2);
  --mco-shadow-md: 0 4px 16px rgba(0, 0, 0, 0.3);
  --mco-shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.4);
  --mco-shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.5);
  --mco-shadow-orange: 0 4px 24px rgba(230, 122, 52, 0.25);
  --mco-shadow-orange-lg: 0 8px 40px rgba(230, 122, 52, 0.35);

  /* Transitions */
  --mco-transition-fast: 0.15s ease;
  --mco-transition-base: 0.3s ease;
  --mco-transition-slow: 0.6s ease-out;
  --mco-transition-bounce: 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Typographie */
  --mco-letter-spacing-tight: -0.02em;
  --mco-letter-spacing-base: 0.01em;
  --mco-letter-spacing-wide: 0.03em;
  --mco-line-height-tight: 1.2;
  --mco-line-height-base: 1.6;
  --mco-line-height-relaxed: 1.75;
}

/* ------------------------------------------
   2. BASE — AMÉLIORATIONS GLOBALES
   ------------------------------------------ */

/* Scrollbar personnalisée — fine et orange terracotta */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: var(--mco-dark-deep);
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--mco-orange-primary), var(--mco-gold));
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, var(--mco-orange-light), var(--mco-gold-light));
}

/* Firefox scrollbar */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--mco-orange-primary) var(--mco-dark-deep);
}

/* Couleur de sélection — orange terracotta */
::selection {
  background-color: rgba(230, 122, 52, 0.35) !important;
  color: #ffffff !important;
}

::-moz-selection {
  background-color: rgba(230, 122, 52, 0.35) !important;
  color: #ffffff !important;
}

/* Focus rings accessibles — orange glow */
*:focus-visible {
  outline: 2px solid var(--mco-orange-primary) !important;
  outline-offset: 2px !important;
  box-shadow: 0 0 0 4px rgba(230, 122, 52, 0.2) !important;
}

/* Smooth scroll global */
html {
  scroll-behavior: smooth;
}

/* Amélioration typographique globale */
body {
  letter-spacing: var(--mco-letter-spacing-base) !important;
  line-height: var(--mco-line-height-base) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Titres — letter-spacing et line-height optimisés */
h1, h2, h3, h4, h5, h6 {
  letter-spacing: var(--mco-letter-spacing-tight) !important;
  line-height: var(--mco-line-height-tight) !important;
}

/* Paragraphes — line-height relâché pour lisibilité */
p {
  line-height: var(--mco-line-height-relaxed) !important;
}

/* ------------------------------------------
   3. ANIMATE ON SCROLL — Fade-in au scroll
   ------------------------------------------ */
.animate-on-scroll {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity var(--mco-transition-slow), transform var(--mco-transition-slow);
  will-change: opacity, transform;
}

/* Classe ajoutée par l'Intersection Observer */
.animate-on-scroll.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Variantes de direction */
.animate-on-scroll.from-left {
  transform: translateX(-40px);
}

.animate-on-scroll.from-left.visible {
  transform: translateX(0);
}

.animate-on-scroll.from-right {
  transform: translateX(40px);
}

.animate-on-scroll.from-right.visible {
  transform: translateX(0);
}

.animate-on-scroll.scale-in {
  transform: scale(0.92);
}

.animate-on-scroll.scale-in.visible {
  transform: scale(1);
}

/* Délai d'animation stagger */
.animate-on-scroll.delay-1 { transition-delay: 0.1s; }
.animate-on-scroll.delay-2 { transition-delay: 0.2s; }
.animate-on-scroll.delay-3 { transition-delay: 0.3s; }
.animate-on-scroll.delay-4 { transition-delay: 0.4s; }
.animate-on-scroll.delay-5 { transition-delay: 0.5s; }

/* ------------------------------------------
   4. HOVER LIFT — Surélévation des cards
   ------------------------------------------ */
.mco-hover-lift,
[class*="card"],
[class*="Card"] {
  transition: transform var(--mco-transition-base), box-shadow var(--mco-transition-base) !important;
}

.mco-hover-lift:hover,
[class*="card"]:hover,
[class*="Card"]:hover {
  transform: translateY(-8px) !important;
  box-shadow: var(--mco-shadow-xl) !important;
}

/* Variante avec glow orange */
.mco-hover-lift-glow:hover {
  transform: translateY(-8px) !important;
  box-shadow: var(--mco-shadow-orange-lg) !important;
  border-color: var(--mco-border-orange-strong) !important;
}

/* ------------------------------------------
   5. GRADIENT TEXT ANIMÉ — Shimmer doré/orange
   ------------------------------------------ */
.gradient-text {
  background: linear-gradient(
    90deg,
    var(--mco-orange-primary) 0%,
    var(--mco-gold-light) 25%,
    var(--mco-orange-primary) 50%,
    var(--mco-gold) 75%,
    var(--mco-orange-primary) 100%
  );
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-text 3s linear infinite;
}

@keyframes shimmer-text {
  0% {
    background-position: 200% center;
  }
  100% {
    background-position: -200% center;
  }
}

/* Variante plus lente pour les titres principaux */
.gradient-text-slow {
  background: linear-gradient(
    90deg,
    var(--mco-orange-primary) 0%,
    var(--mco-gold-light) 30%,
    var(--mco-orange-primary) 60%,
    var(--mco-gold) 100%
  );
  background-size: 300% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: shimmer-text 5s linear infinite;
}

/* ------------------------------------------
   6. PULSE CTA — Animation subtile boutons
   ------------------------------------------ */
.mco-pulse-cta,
[class*="btn-primary"],
[class*="Button--primary"],
button[class*="primary"] {
  position: relative;
}

.mco-pulse-cta::after,
[class*="btn-primary"]::after,
[class*="Button--primary"]::after,
button[class*="primary"]::after {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: transparent;
  border: 2px solid var(--mco-orange-primary);
  opacity: 0;
  animation: pulse-ring 2.5s ease-out infinite;
  pointer-events: none;
}

@keyframes pulse-ring {
  0% {
    transform: scale(1);
    opacity: 0.6;
  }
  100% {
    transform: scale(1.15);
    opacity: 0;
  }
}

/* Hover scale sur les CTA */
.mco-pulse-cta:hover,
[class*="btn-primary"]:hover,
[class*="Button--primary"]:hover {
  transform: scale(1.03) !important;
  box-shadow: var(--mco-shadow-orange) !important;
}

/* ------------------------------------------
   7. SKELETON LOADING — Shimmer gradient
   ------------------------------------------ */
.skeleton {
  background: linear-gradient(
    90deg,
    var(--mco-dark-elevated) 25%,
    var(--mco-dark-card) 50%,
    var(--mco-dark-elevated) 75%
  );
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.5s ease-in-out infinite;
  border-radius: 8px;
  pointer-events: none;
}

@keyframes skeleton-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

/* Variantes de forme skeleton */
.skeleton.skeleton-text {
  height: 1em;
  margin-bottom: 0.5em;
  border-radius: 4px;
}

.skeleton.skeleton-title {
  height: 1.4em;
  width: 60%;
  margin-bottom: 0.75em;
  border-radius: 4px;
}

.skeleton.skeleton-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
}

.skeleton.skeleton-card {
  height: 200px;
  border-radius: 12px;
}

/* Mode clair pour skeleton */
@media (prefers-color-scheme: light) {
  .skeleton {
    background: linear-gradient(
      90deg,
      #e8e6e3 25%,
      #f0eeeb 50%,
      #e8e6e3 75%
    );
    background-size: 200% 100%;
  }
}

/* ------------------------------------------
   8. GLASSMORPHISM AMÉLIORÉ
   ------------------------------------------ */
.mco-glass {
  background: var(--mco-glass-bg) !important;
  backdrop-filter: blur(var(--mco-glass-blur)) saturate(1.4) !important;
  -webkit-backdrop-filter: blur(var(--mco-glass-blur)) saturate(1.4) !important;
  border: 1px solid var(--mco-glass-border) !important;
}

.mco-glass-strong {
  background: rgba(26, 26, 26, 0.85) !important;
  backdrop-filter: blur(30px) saturate(1.6) !important;
  -webkit-backdrop-filter: blur(30px) saturate(1.6) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

/* Glow subtil sur les éléments glass */
.mco-glass-glow {
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
}

/* ------------------------------------------
   9. SMOOTH SECTION TRANSITIONS
   ------------------------------------------ */

/* Espacement amélioré entre sections */
section {
  position: relative;
}

/* Séparateur de section subtil */
.mco-section-divider {
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    var(--mco-border-orange) 30%,
    var(--mco-border-orange-strong) 50%,
    var(--mco-border-orange) 70%,
    transparent 100%
  );
  margin: 0 auto;
  max-width: 80%;
}

/* Transition douce entre sections sombres/claires */
.mco-section-fade {
  position: relative;
}

.mco-section-fade::before {
  content: '';
  position: absolute;
  top: -80px;
  left: 0;
  right: 0;
  height: 160px;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    var(--mco-dark-base) 50%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 1;
}

/* ------------------------------------------
   10. TABLE COMPARATEUR AMÉLIORÉE
   ------------------------------------------ */
.mco-comparison-table,
[class*="comparison"],
[class*="comparateur"] {
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
}

.mco-comparison-table th,
[class*="comparison"] th,
[class*="comparateur"] th {
  background: var(--mco-dark-elevated) !important;
  color: var(--mco-orange-primary) !important;
  font-weight: 600;
  letter-spacing: var(--mco-letter-spacing-wide);
  text-transform: uppercase;
  font-size: 0.8rem;
  padding: 1rem;
  border-bottom: 2px solid var(--mco-border-orange-strong);
}

.mco-comparison-table td,
[class*="comparison"] td,
[class*="comparateur"] td {
  padding: 1rem;
  border-bottom: 1px solid var(--mco-border-orange);
  transition: background var(--mco-transition-fast);
}

/* Hover sur les lignes */
.mco-comparison-table tbody tr:hover td,
[class*="comparison"] tbody tr:hover td,
[class*="comparateur"] tbody tr:hover td {
  background: rgba(230, 122, 52, 0.08) !important;
}

/* Highlight économies (dernière colonne) */
.mco-comparison-table td:last-child,
[class*="comparison"] td:last-child,
[class*="comparateur"] td:last-child {
  color: var(--mco-orange-primary);
  font-weight: 600;
}

/* Cellule avec économie positive */
.mco-savings-positive {
  color: #4ade80 !important;
  font-weight: 700;
}

/* Cellule avec badge économie */
.mco-savings-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  background: rgba(74, 222, 128, 0.15);
  color: #4ade80;
  padding: 0.25rem 0.75rem;
  border-radius: 999px;
  font-size: 0.85rem;
  font-weight: 700;
}

/* Ligne mise en évidence (pack recommandé) */
.mco-comparison-table tbody tr.highlighted,
[class*="comparison"] tbody tr[class*="highlight"],
[class*="comparateur"] tbody tr[class*="recommande"] {
  background: rgba(230, 122, 52, 0.1) !important;
  border-left: 3px solid var(--mco-orange-primary);
}

.mco-comparison-table tbody tr.highlighted td,
[class*="comparison"] tbody tr[class*="highlight"] td,
[class*="comparateur"] tbody tr[class*="recommande"] td {
  border-bottom-color: var(--mco-border-orange-strong);
}

/* ------------------------------------------
   11. TOOLTIPS AMÉLIORÉS
   ------------------------------------------ */
.mco-tooltip {
  position: relative;
}

.mco-tooltip::before {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  background: var(--mco-dark-elevated);
  color: #ffffff;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  font-size: 0.8rem;
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--mco-transition-fast), transform var(--mco-transition-fast);
  box-shadow: var(--mco-shadow-lg);
  border: 1px solid var(--mco-glass-border);
  z-index: 1000;
  pointer-events: none;
}

.mco-tooltip::after {
  content: '';
  position: absolute;
  bottom: calc(100% + 3px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  border: 5px solid transparent;
  border-top-color: var(--mco-dark-elevated);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--mco-transition-fast), transform var(--mco-transition-fast);
}

.mco-tooltip:hover::before,
.mco-tooltip:hover::after {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

/* Variante tooltip en bas */
.mco-tooltip-bottom::before {
  bottom: auto;
  top: calc(100% + 8px);
  transform: translateX(-50%) translateY(-4px);
}

.mco-tooltip-bottom::after {
  bottom: auto;
  top: calc(100% + 3px);
  border-top-color: transparent;
  border-bottom-color: var(--mco-dark-elevated);
  transform: translateX(-50%) translateY(-4px);
}

.mco-tooltip-bottom:hover::before,
.mco-tooltip-bottom:hover::after {
  transform: translateX(-50%) translateY(0);
}

/* ------------------------------------------
   12. BACK TO TOP BUTTON
   ------------------------------------------ */
.mco-back-to-top {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--mco-orange-primary), var(--mco-gold));
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px) scale(0.8);
  transition: all var(--mco-transition-base);
  box-shadow: var(--mco-shadow-orange);
  z-index: 9999;
}

.mco-back-to-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.mco-back-to-top:hover {
  transform: translateY(-4px) scale(1.1) !important;
  box-shadow: var(--mco-shadow-orange-lg) !important;
}

.mco-back-to-top:active {
  transform: scale(0.95) !important;
}

/* Icône flèche */
.mco-back-to-top svg {
  width: 20px;
  height: 20px;
  stroke: #ffffff;
  stroke-width: 2.5;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* ------------------------------------------
   13. NAV INDICATOR — Lien actif
   ------------------------------------------ */
.mco-nav-link {
  position: relative;
  transition: color var(--mco-transition-fast);
}

.mco-nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--mco-orange-primary), var(--mco-gold));
  transition: width var(--mco-transition-base);
}

.mco-nav-link:hover::after,
.mco-nav-link.active::after {
  width: 100%;
}

.mco-nav-link.active {
  color: var(--mco-orange-primary) !important;
}

/* ------------------------------------------
   14. MOBILE MENU — Hamburger animation
   ------------------------------------------ */
.mco-hamburger {
  display: flex;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 8px;
  background: none;
  border: none;
}

.mco-hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
  transition: all var(--mco-transition-base);
  transform-origin: center;
}

/* Animation vers croix */
.mco-hamburger.is-open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.mco-hamburger.is-open span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.mco-hamburger.is-open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ------------------------------------------
   15. PARALLAX HERO — Styles de base
   ------------------------------------------ */
.mco-parallax-hero {
  position: relative;
  overflow: hidden;
}

.mco-parallax-bg {
  position: absolute;
  inset: -20%;
  will-change: transform;
  transition: transform 0.1s linear;
}

.mco-parallax-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Overlay gradient sur les heroes */
.mco-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(10, 10, 15, 0.3) 0%,
    rgba(10, 10, 15, 0.7) 60%,
    var(--mco-dark-deep) 100%
  );
  pointer-events: none;
}

/* ------------------------------------------
   16. COUNTER ANIMATION — Styles
   ------------------------------------------ */
.mco-counter {
  font-variant-numeric: tabular-nums;
  display: inline-block;
}

/* Variantes de couleur pour les compteurs */
.mco-counter-orange {
  color: var(--mco-orange-primary);
}

.mco-counter-gold {
  color: var(--mco-gold);
}

/* ------------------------------------------
   17. ANIMATIONS UTILITAIRES
   ------------------------------------------ */

/* Fade in simple */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.mco-fade-in {
  animation: fadeIn var(--mco-transition-slow) ease-out forwards;
}

/* Slide up */
@keyframes slideUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.mco-slide-up {
  animation: slideUp var(--mco-transition-slow) ease-out forwards;
}

/* Scale in */
@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.9); }
  to { opacity: 1; transform: scale(1); }
}

.mco-scale-in {
  animation: scaleIn var(--mco-transition-base) ease-out forwards;
}

/* Bounce subtil */
@keyframes bounce-soft {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

.mco-bounce-soft {
  animation: bounce-soft 2s ease-in-out infinite;
}

/* Spin lent (pour les loaders décoratifs) */
@keyframes spin-slow {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.mco-spin-slow {
  animation: spin-slow 8s linear infinite;
}

/* ------------------------------------------
   18. STAGGER ANIMATION — Pour les listes
   ------------------------------------------ */
.mco-stagger-children > * {
  opacity: 0;
  transform: translateY(20px);
  animation: slideUp 0.5s ease-out forwards;
}

.mco-stagger-children > *:nth-child(1) { animation-delay: 0s; }
.mco-stagger-children > *:nth-child(2) { animation-delay: 0.08s; }
.mco-stagger-children > *:nth-child(3) { animation-delay: 0.16s; }
.mco-stagger-children > *:nth-child(4) { animation-delay: 0.24s; }
.mco-stagger-children > *:nth-child(5) { animation-delay: 0.32s; }
.mco-stagger-children > *:nth-child(6) { animation-delay: 0.40s; }
.mco-stagger-children > *:nth-child(7) { animation-delay: 0.48s; }
.mco-stagger-children > *:nth-child(8) { animation-delay: 0.56s; }

/* ------------------------------------------
   19. RÉDUCTION MOTION — Accessibilité
   ------------------------------------------ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  html {
    scroll-behavior: auto;
  }

  .animate-on-scroll {
    opacity: 1;
    transform: none;
  }
}

/* ------------------------------------------
   20. RESPONSIVE — Mobile-first breakpoints
   ------------------------------------------ */

/* Small : 576px+ */
@media (min-width: 576px) {
  .mco-back-to-top {
    width: 44px;
    height: 44px;
  }
}

/* Medium : 768px+ */
@media (min-width: 768px) {
  .animate-on-scroll {
    transform: translateY(40px);
  }

  .mco-back-to-top {
    width: 48px;
    height: 48px;
    bottom: 2.5rem;
    right: 2.5rem;
  }
}

/* Large : 992px+ */
@media (min-width: 992px) {
  .mco-comparison-table th,
  .mco-comparison-table td {
    padding: 1.25rem 1.5rem;
  }
}

/* Extra Large : 1200px+ */
@media (min-width: 1200px) {
  .mco-section-divider {
    max-width: 60%;
  }
}

/* ------------------------------------------
   21. EFFETS SPÉCIAUX — Glow, Bordures animées
   ------------------------------------------ */

/* Bordure animée (effet tourbillon) */
.mco-animated-border {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
}

.mco-animated-border::before {
  content: '';
  position: absolute;
  inset: -2px;
  background: conic-gradient(
    from 0deg,
    transparent 0%,
    var(--mco-orange-primary) 20%,
    var(--mco-gold) 40%,
    transparent 60%,
    transparent 100%
  );
  animation: border-rotate 4s linear infinite;
  z-index: -1;
}

.mco-animated-border::after {
  content: '';
  position: absolute;
  inset: 1px;
  background: var(--mco-dark-card);
  border-radius: 11px;
  z-index: -1;
}

@keyframes border-rotate {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* Glow pulsant sur élément */
.mco-glow-pulse {
  animation: glow-pulse 2s ease-in-out infinite;
}

@keyframes glow-pulse {
  0%, 100% {
    box-shadow: 0 0 20px rgba(230, 122, 52, 0.2);
  }
  50% {
    box-shadow: 0 0 40px rgba(230, 122, 52, 0.4);
  }
}

/* Réseau de points décoratif (fond) */
.mco-dot-pattern {
  background-image: radial-gradient(
    circle,
    rgba(230, 122, 52, 0.15) 1px,
    transparent 1px
  );
  background-size: 24px 24px;
}

/* Gradient mesh subtil (fond décoratif) */
.mco-gradient-mesh {
  background:
    radial-gradient(ellipse at 20% 20%, rgba(230, 122, 52, 0.08) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(212, 165, 116, 0.06) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(230, 122, 52, 0.04) 0%, transparent 70%);
}

/* ------------------------------------------
   22. UTILITAIRES DE COULEUR ET TYPO
   ------------------------------------------ */

/* Texte orange */
.mco-text-orange { color: var(--mco-orange-primary) !important; }
.mco-text-gold { color: var(--mco-gold) !important; }
.mco-text-muted { color: rgba(255, 255, 255, 0.6) !important; }

/* Fonds */
.mco-bg-dark { background-color: var(--mco-dark-base) !important; }
.mco-bg-card { background-color: var(--mco-dark-card) !important; }
.mco-bg-elevated { background-color: var(--mco-dark-elevated) !important; }

/* Bordures */
.mco-border-orange {
  border: 1px solid var(--mco-border-orange) !important;
}

.mco-border-orange-strong {
  border: 1px solid var(--mco-border-orange-strong) !important;
}

/* Espacements responsives */
.mco-section-spacing {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

@media (min-width: 768px) {
  .mco-section-spacing {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }
}

@media (min-width: 1200px) {
  .mco-section-spacing {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }
}

/* ------------------------------------------
   23. PRINT STYLES
   ------------------------------------------ */
@media print {
  .mco-back-to-top,
  .mco-hamburger,
  .mco-tooltip::before,
  .mco-tooltip::after {
    display: none !important;
  }

  .animate-on-scroll {
    opacity: 1 !important;
    transform: none !important;
  }
}
