/* ========================================
   SECTION 2 : PLAYER APPLE MUSIC - L'IMMERSION TOTALE
   ======================================== */

.player-section {
  position: relative;
  height: 680px;
  min-height: 680px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: 
    radial-gradient(ellipse at center, rgba(255,255,255,0.02) 0%, transparent 70%),
    linear-gradient(135deg, #000000 0%, #0a0a0a 50%, #000000 100%);
  overflow: visible;
  padding: var(--spacing-lg) 0 var(--spacing-md) 0;
}

.player-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 100px;
  background: linear-gradient(to bottom, rgba(0,0,0,0.8), transparent);
  z-index: 1;
}

/* Container Player - Spécifications Exactes */
.player-container {
  width: min(95vw, 420px) !important;
  height: 580px !important;
  min-width: min(95vw, 420px) !important;
  min-height: 580px !important;
  background: rgba(0, 0, 0, 0.9);
  backdrop-filter: blur(40px) saturate(200%) brightness(1.1);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-2xl);
  box-shadow: 
    0 40px 80px rgba(0,0,0,0.5), 
    0 16px 32px rgba(0,0,0,0.3),
    inset 0 1px 0 rgba(255,255,255,0.1),
    0 0 30px rgba(255,255,255,0.05);
  padding: var(--spacing-md) var(--spacing-md) var(--spacing-lg) var(--spacing-md);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  position: relative;
  overflow: visible;
  animation: playerGlow 4s ease-in-out infinite alternate;
  transition: all 0.4s cubic-bezier(0.23, 1, 0.320, 1);
  cursor: pointer;
}

.player-container::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.05), transparent);
  animation: playerShine 4s ease-in-out infinite;
  pointer-events: none;
  transition: all 0.4s ease;
}

/* Effet de survol sophistiqué */
.player-container:hover {
  transform: translateY(-10px) scale(1.02);
  background: rgba(0, 0, 0, 0.95);
  backdrop-filter: blur(50px) saturate(250%) brightness(1.2);
  border-color: rgba(255, 255, 255, 0.25);
  box-shadow: 
    0 60px 120px rgba(0,0,0,0.6), 
    0 24px 48px rgba(0,0,0,0.4),
    inset 0 1px 0 rgba(255,255,255,0.15),
    0 0 50px rgba(255,255,255,0.1),
    0 0 100px rgba(255,255,255,0.05);
}

.player-container:hover::before {
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
  animation-duration: 2s;
}

/* Effet de lueur au survol */
.player-container::after {
  content: '';
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(
    45deg,
    rgba(255, 255, 255, 0.1) 0%,
    transparent 25%,
    transparent 75%,
    rgba(255, 255, 255, 0.1) 100%
  );
  border-radius: var(--radius-2xl);
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
  z-index: -1;
}

.player-container:hover::after {
  opacity: 1;
}

/* Player Header */
.player-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-sm);
  text-align: center;
  margin-bottom: 10px;
  margin-top: 15px;
}

/* Pochette Album Interactive */
.album-artwork {
  position: relative;
  width: 350px !important;
  height: 350px !important;
  min-width: 350px !important;
  min-height: 350px !important;
  max-width: 350px !important;
  max-height: 350px !important;
  border-radius: 60px;
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  transition: all 0.4s cubic-bezier(0.23, 1, 0.320, 1);
  /* Animation supprimée pour éviter la rotation sur iPhone */
  transform-style: preserve-3d;
  cursor: pointer;
}

/* Animation supprimée pour éviter la rotation sur iPhone */

/* Effets hover identiques sur tous les appareils */
.album-artwork:hover {
  transform: scale(1.05) rotateY(5deg);
  box-shadow: 
    0 30px 80px rgba(0,0,0,0.5),
    0 0 60px rgba(255,255,255,0.15),
    0 0 100px rgba(255,255,255,0.05);
  filter: brightness(1.1) contrast(1.05);
}

/* Effets hover identiques sur tous les appareils */
/* Purchase overlay hover supprimé */

.artwork-image {
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: cover !important;
  border-radius: 60px;
  filter: contrast(1.05) saturate(1.1);
  transition: filter 0.3s var(--ease-natural);
}

/* Effets hover identiques sur tous les appareils */
.album-artwork:hover .artwork-image {
  filter: contrast(1.1) saturate(1.2);
}

/* Artwork reflection supprimé pour éviter les différences mobile/desktop */

/* Purchase Overlay */
/* Purchase overlay supprimé */

/* Purchase content supprimé */

/* Métadonnées Musicales - Typography Premium */
.track-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  width: 100%;
}

.track-title {
  font-family: var(--font-family);
  font-size: 24px;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0;
}

.track-artist {
  font-family: var(--font-family);
  font-size: 18px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  line-height: 1.2;
  margin: 0;
}

.track-album {
  font-family: var(--font-family);
  font-size: 14px;
  font-weight: var(--font-weight-regular);
  color: var(--color-text-muted);
  line-height: 1.3;
  margin: 0;
}


/* Progress Bar - Précision Microscopique */
.progress-container {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  width: 100%;
  margin-top: 12px;
  margin-bottom: 12px;
}

.progress-bar {
  position: relative;
  width: 85%;
  height: 4px;
  cursor: pointer;
  transition: all 0.3s var(--ease-natural);
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 2px;
}

.progress-bar:hover {
  height: 6px;
  background: rgba(255, 255, 255, 0.2);
}

.progress-bar:active {
  height: 8px;
  background: rgba(255, 255, 255, 0.3);
}

.progress-track {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 3px;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.2);
}

.progress-fill {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 0%;
  background: #FFFFFF;
  border-radius: 2px;
  transition: width 0.1s linear;
}

/* Suppression du thumb rond */
.progress-thumb {
  display: none;
}

.time-display {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-family);
  font-size: 14px;
  font-weight: var(--font-weight-regular);
  color: var(--color-text-muted);
}

/* Contrôles Audio - États Fonctionnels Complets */
.player-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-xs);
  width: 100%;
  margin: 16px 0 0 0;
}

.control-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s cubic-bezier(0.23, 1, 0.320, 1);
  position: relative;
  overflow: hidden;
  width: 70px;
  height: 70px;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  -webkit-tap-highlight-color: transparent !important;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border-radius: 0;
  cursor: pointer;
  box-shadow: none !important;
}

.control-btn.prev-btn,
.control-btn.next-btn {
  width: 72px;
  height: 72px;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  -webkit-tap-highlight-color: transparent !important;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border-radius: 0;
  box-shadow: none !important;
}

.control-btn.pause-btn {
  width: 92px;
  height: 92px;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  -webkit-tap-highlight-color: transparent !important;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  font-size: 24px;
  border-radius: 0;
  box-shadow: none !important;
  position: relative;
}

.control-btn:hover {
  background: transparent !important;
  transform: scale(1.05);
  box-shadow: none !important;
  filter: brightness(1.1);
  border: none !important;
  outline: none !important;
}

.control-btn:active {
  transform: scale(0.92);
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

.control-btn i {
  width: 32px;
  height: 32px;
  color: #FFFFFF;
  transition: all 0.3s var(--ease-natural);
}

.control-btn.prev-btn i,
.control-btn.next-btn i {
  width: 28px;
  height: 28px;
  color: #FFFFFF;
}

.control-btn.pause-btn i {
  width: 32px;
  height: 32px;
  color: #FFFFFF;
}

/* Cacher les icônes Lucide */
.control-btn.prev-btn i,
.control-btn.pause-btn i,
.control-btn.next-btn i {
  display: block;
  color: #FFFFFF;
  font-size: 24px;
}

/* Pseudo-éléments supprimés pour éviter les boutons bleus sur iPhone */

/* Pseudo-éléments pause/play supprimés pour éviter les boutons bleus sur iPhone */

/* Pseudo-éléments next supprimés pour éviter les boutons bleus sur iPhone */

.control-btn.active {
  background: transparent;
  border: none;
}

.control-btn.active i {
  color: #FFFFFF;
}

/* Button States */
.control-btn.playing {
  background: transparent;
  border: none;
}

.control-btn.playing i {
  color: #FFFFFF;
}


/* Visualiseur Audio Temps-Réel */
.audio-visualizer {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  z-index: 1;
}

#visualizer-canvas {
  width: 100%;
  height: 100%;
  border-radius: var(--radius-2xl);
  opacity: 0.1;
}

/* Animations */
/* Animation artworkBreathing supprimée pour éviter la rotation sur iPhone */

/* @keyframes artworkPlaying supprimé pour éviter la rotation sur iPhone */

.album-artwork.playing {
  /* Animation supprimée pour éviter la rotation sur iPhone */
}

/* Loading States */
.control-btn.loading {
  position: relative;
}

/* Pseudo-éléments loading supprimés pour éviter les boutons bleus sur iPhone */

@keyframes spin {
  0% { transform: translate(-50%, -50%) rotate(0deg); }
  100% { transform: translate(-50%, -50%) rotate(360deg); }
}

@keyframes playerGlow {
  0% {
    box-shadow: 
      0 40px 80px rgba(0,0,0,0.5), 
      0 16px 32px rgba(0,0,0,0.3),
      inset 0 1px 0 rgba(255,255,255,0.1),
      0 0 30px rgba(255,255,255,0.05);
  }
  100% {
    box-shadow: 
      0 40px 80px rgba(0,0,0,0.5), 
      0 16px 32px rgba(0,0,0,0.3),
      inset 0 1px 0 rgba(255,255,255,0.1),
      0 0 50px rgba(255,255,255,0.1);
  }
}

@keyframes playerShine {
  0% {
    left: -100%;
  }
  100% {
    left: 100%;
  }
}

/* Responsive Design */
@media (max-width: 1024px) and (min-width: 769px) {
  .player-section {
    height: 680px;
    min-height: 680px;
    padding: var(--spacing-lg) 0 var(--spacing-lg) 0;
  }
  
  .player-container {
    height: 580px !important;
    min-height: 580px !important;
  }
}

/* Media queries supprimées pour éviter les différences mobile/desktop */

/* Media queries supprimées pour éviter les différences mobile/desktop */

/* Media queries supprimées pour éviter les différences mobile/desktop */

/* Performance Optimizations */
.player-container {
  will-change: transform;
  transform: translateZ(0);
}

.album-artwork {
  will-change: transform;
}

.control-btn {
  will-change: transform;
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
  .album-artwork {
    animation: none;
  }
  
  .album-artwork.playing {
    animation: none;
  }
  
  /* Pseudo-éléments loading supprimés */
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .player-container {
    background: var(--color-background);
    border: 2px solid var(--color-text-primary);
  }
  
  .control-btn {
    background: transparent;
    border: none;
  }
  
  .control-btn.active {
    background: transparent;
    color: #FFFFFF;
  }
}

/* Très petits écrans */
@media (max-width: 320px) {
  .player-section {
    min-height: auto;
    height: auto;
    padding: var(--spacing-sm) 0 var(--spacing-xs) 0;
    align-items: flex-start;
    justify-content: center;
    overflow: visible;
  }
  
  .player-container {
    width: min(98vw, 340px);
    height: min(95vh, 1000px);
    min-height: min(95vh, 1000px);
    padding: var(--spacing-xs);
    gap: var(--spacing-xs);
    overflow: visible;
  }
  
  .album-artwork {
    width: 280px;
    height: 280px;
    border-radius: 40px;
  }
  
  .control-btn {
    width: 45px;
    height: 45px;
    font-size: 18px;
  }
}

/* iOS safe button styles */
.control-btn {
  -webkit-appearance: none;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
}

.control-btn i {
  color: #FFFFFF !important;
}

/* Désactiver styles actifs bleus iOS */
.control-btn:focus,
.control-btn:active {
  outline: none !important;
  box-shadow: none !important;
}

/* Icônes pleines blanches pour les contrôles */
.player-controls .icon-fill {
  display: block;
}
.player-controls .icon-fill path,
.player-controls .icon-fill rect {
  fill: #FFFFFF !important;
}

/* Remonter les contrôles plus près de la barre de temps */
.player-controls {
  margin: 8px 0 0 0;
}

/* Tailles plus grandes */
.control-btn.prev-btn,
.control-btn.next-btn {
  width: 72px;
  height: 72px;
}
.control-btn.pause-btn {
  width: 92px;
  height: 92px;
}
.player-controls .icon-fill {
  width: 100%;
  height: 100%;
}

/* Bascule play/pause via classe */
#pause-btn .icon-play { display: block; }
#pause-btn .icon-pause { display: none; }
#pause-btn.playing .icon-play { display: none; }
#pause-btn.playing .icon-pause { display: block; }

/* Tailles ajustées plus petites */
.control-btn.prev-btn,
.control-btn.next-btn {
  width: 54px;
  height: 54px;
}
.control-btn.pause-btn {
  width: 72px;
  height: 72px;
}

/* Monter et décaler légèrement à gauche */
.player-controls {
  margin: 0 0 0 -8px;
}

/* Assurer remplissage blanc */
.player-controls .icon-fill path,
.player-controls .icon-fill rect,
.player-controls .icon-fill polygon {
  fill: #FFFFFF !important;
  stroke: #FFFFFF !important;
}

/* Tailles encore réduites */
.control-btn.prev-btn,
.control-btn.next-btn {
  width: 46px;
  height: 46px;
}
.control-btn.pause-btn {
  width: 64px;
  height: 64px;
}

/* Position plus haute et légèrement à gauche */
.player-controls {
  margin: -2px 0 0 -10px;
}

/* Espacement fin entre boutons */
.player-controls {
  gap: 18px;
  margin: -2px 0 0 -10px;
}

/* Ajustements de position */
.player-controls {
  margin: -4px 0 0 4px; /* un peu plus haut, légèrement à droite */
  gap: 20px;
}

/* Tailles des boutons pour matcher les SVG */
.control-btn.prev-btn,
.control-btn.next-btn {
  width: 52px;
  height: 48px;
}
.control-btn.pause-btn {
  width: 60px;
  height: 60px;
}

/* Position: plus haut et légèrement à gauche (fin) */
.player-controls {
  margin: -8px 0 0 -8px;
  gap: 22px;
}

/* Tailles conteneurs réduites pour matcher les SVG */
.control-btn.prev-btn,
.control-btn.next-btn {
  width: 56px;
  height: 42px;
}
.control-btn.pause-btn {
  width: 56px;
  height: 56px;
}
