/* ==========================================================================
   MASTER CSS BOOTSTRAP 5 - JEAN-PHILIPPE (JPVENANT.FR)
   Modèle intégral personnalisable via :root
   ========================================================================== */

/* 1. CONFIGURATION ET VARIABLES
   ========================================================================== */
/* --- 1. Police Texte --- */
@font-face {
  font-family: 'Poppins-Regular';
  src: url('../fonts/Poppins-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* --- 2. Police Titre --- */
@font-face {
  font-family: "Poppins-ExtraBold";
  src: url('../fonts/Poppins-ExtraBold.ttf') format('truetype');
  font-display: swap;
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

:root {
  /* Polices */
  --police-texte: "Poppins-Regular", sans-serif;
  --police-titre: "Poppins-ExtraBold", sans-serif;
  --police-taille: 1.2rem;

  --couleur-page: #121212;
  --couleur-texte: #ececec;
  --couleur-titre: #FFC107;

  --primary: #FFC107;
  --primary-dark: #cc9a06;
  --secondary: #282828;
  --secondary-dark: #181818;
  --info: var(--couleur-texte);
  --info-dark: var(--primary-dark);
  --success: #198754;
  --warning: #ffc107;
  --danger: var(--primary-dark);

  --white: #ffffff;
  --dark: #000000;
  --light: #808080;
  --semi-transparent: rgba(0, 0, 0, 0.5);

  --couleur-lien: var(--couleur-texte);
  --couleur-lien-survol: var(--primary);

  --box-shadow: rgba(0, 0, 0, 0.12) 0px 1px 3px, rgba(0, 0, 0, 0.24) 0px 1px 2px;
  --box-shadow-info: rgba(242, 5, 5, 0.45) 0px 25px 20px -20px;
  --transition: all 0.3s ease-in-out;

  /* ==========================================================
     ESPACEMENT, BORDURES ET EFFETS
     ========================================================== */
  --section-padding-y: 8rem;
  --header-margin-top: 0rem;
  --header-mobile-margin-top: 0rem;
  --border-radius: 0.25rem;
}



/* 2. STYLES GLOBAUX & SCROLLBAR
   ========================================================================== */
html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

html::-webkit-scrollbar {
  width: 10px;
}

html::-webkit-scrollbar-track {
  background: var(--couleur-page);
}

html::-webkit-scrollbar-thumb {
  border-radius: 12px;
  background: linear-gradient(180deg, var(--primary), var(--couleur-page), var(--primary));
}

body {
  font-family: var(--police-texte) !important;
  background-color: var(--couleur-page) !important;
  color: var(--couleur-texte) !important;
  font-size: var(--police-taille) !important;
  line-height: 1.6;
}

/* 3. TYPOGRAPHIE
   ========================================================================== */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--police-titre) !important;
  color: var(--couleur-titre) !important;
}

a {
  color: var(--couleur-lien) !important;
  transition: var(--transition);
  text-decoration: underline;
}

a:hover {
  color: var(--couleur-lien-survol) !important;
  text-decoration: none !important;
}

/* 4. UTILITAIRES DE COULEURS ET BORDURES
   ========================================================================== */
.bg-primary {
  background-color: var(--primary) !important;
}

.bg-secondary {
  background-color: var(--secondary) !important;
}

.bg-info {
  background-color: var(--info) !important;
}

.text-primary {
  color: var(--primary) !important;
}

.text-secondary {
  color: var(--secondary) !important;
}

.text-info {
  color: var(--info) !important;
}

.border-primary {
  border-color: var(--primary) !important;
}

.border-secondary {
  border-color: var(--secondary) !important;
}

.border-info {
  border-color: var(--info) !important;
}

/* 5. CARTES (CARDS) TRANSPARENTES
   ========================================================================== */
.card,
.card-header,
.card-body,
.card-footer {
  background-color: var(--secondary) !important;
  color: var(--couleur-texte) !important;
  border: none !important;
  /*border-color: rgba(0, 0, 0, 0.1) !important;*/
}

.card {
  transition: var(--transition);
  backdrop-filter: blur(5px);
}

.card:hover {
  transform: translateY(-8px);
  box-shadow: var(--box-shadow);
}

/* 6. BOUTONS (PLEINS & OUTLINE)
   ========================================================================== */
.btn {
  padding: 12px 25px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: var(--transition) !important;
}

/* Primary */
.btn-primary {
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
  color: var(--white) !important;
}

.btn-primary:hover {
  background-color: var(--primary-dark) !important;
}

.btn-outline-primary {
  color: var(--primary) !important;
  border: 2px solid var(--primary) !important;
  background-color: transparent !important;
}

.btn-outline-primary:hover {
  background-color: var(--primary) !important;
  color: var(--white) !important;
}

/* Secondary */
.btn-secondary {
  background-color: var(--secondary) !important;
  border-color: var(--secondary) !important;
  color: var(--white) !important;
}

.btn-secondary:hover {
  background-color: var(--secondary-dark) !important;
}

.btn-outline-secondary {
  color: var(--secondary) !important;
  border: 2px solid var(--secondary) !important;
  background-color: transparent !important;
}

.btn-outline-secondary:hover {
  background-color: var(--secondary) !important;
  color: var(--white) !important;
}

/* Info */
.btn-info {
  background-color: var(--info) !important;
  border-color: var(--info) !important;
  color: var(--dark) !important;
  box-shadow: var(--box-shadow-info);
}

.btn-info:hover {
  background-color: var(--info-dark) !important;
  color: var(--white) !important;
}

.btn-outline-info {
  color: var(--info) !important;
  border: 2px solid var(--info) !important;
  background-color: transparent !important;
}

.btn-outline-info:hover {
  background-color: var(--info) !important;
  color: var(--dark) !important;
}

/* 7. LECTEUR AUDIO PERSONNALISÃ‰
   ========================================================================== */
audio {
  width: 100%;
  border-radius: 50px;
}

/* Le panneau de contrÃ´le complet  */
audio::-webkit-media-controls-panel {
  background-color: var(--primary) !important;
}

/* La barre de progression (timeline) */
audio::-webkit-media-controls-timeline {
  background-color: var(--semi-transparent);
  border-radius: 50px;
  margin-left: 5px;
  margin-right: 5px;
}

/* Le bouton Play/Pause */
audio::-webkit-media-controls-play-button {
  background-color: var(--info);
  border-radius: 50px;
}

/* L'affichage du temps (00:00) */
audio::-webkit-media-controls-current-time-display,
audio::-webkit-media-controls-time-remaining-display {
  color: #ffffff;
  font-weight: bold;
}

/* Le curseur de volume */
audio::-webkit-media-controls-volume-slider {
  background-color: var(--semi-transparent);
  border-radius: 50px;
  padding-left: 5px;
  padding-right: 5px;
}

/* Panneau de contrÃ´le de la vidÃ©o */
video::-webkit-media-controls-panel {
  background-color: transparent !important;
}

/* Barre de progression vidÃ©o */
video::-webkit-media-controls-timeline {
  background-color: var(--couleur-texte);
}

/* Bouton Play au centre ou dans la barre */
video::-webkit-media-controls-play-button {
  background-color: var(--primary);
  border-radius: 50px;
  margin-right: 10px;
}

/* Curseur du volume */
video::-webkit-media-controls-volume-slider {
  background-color: var(--semi-transparent);
  padding-left: 10px;
  padding-right: 10px;
}

video::-webkit-media-controls-fullscreen-button {
  background-color: var(--primary);
  border-radius: 50px;
}

/* 8. NAVIGATION (NAVBAR)
   ========================================================================== */
.navbar {
  backdrop-filter: blur(15px);
  background-color: rgba(28, 28, 28, 0.8) !important;
}

.nav-link {
  color: var(--couleur-lien) !important;
  text-decoration: none !important;
}

.nav-link:hover,
.nav-link.active {
  color: var(--couleur-lien-survol) !important;
}


/* 8. Espacement Header - Section - Header animé
   ========================================================================== */
:target {
  scroll-margin-top: 6.8rem;
}

header {
  margin-top: var(--header-margin-top);
}

.header-animate {
  opacity: 0;
  transform: scale(0.8) rotate(-10deg);
  transition: all 0.8s ease-out;
}

.header-visible {
  opacity: 1;
  transform: scale(1) rotate(0);
}

section {
  margin-top: var(--section-padding-y);
  margin-bottom: var(--section-padding-y);
}


/* 10. RESPONSIVE
   ========================================================================== */
@media (max-width: 767px) {
  body {
    font-size: 1rem !important;
  }

  /* Hiérarchie des titres optimisée pour mobile */
  h1 {
    font-size: 1.8rem !important;
    line-height: 1.2;
  }

  h2 {
    font-size: 1.5rem !important;
    /* Taille impactante mais contenue */
    margin-bottom: 1.2rem;
  }

  h3 {
    font-size: 1.3rem !important;
  }

  h4 {
    font-size: 1.15rem !important;
  }

  .btn {
    padding: 10px 20px;
  }

  header {
    margin-top: var(--header-mobile-margin-top) !important;
  }

  section {
    margin-top: calc(var(--section-padding-y) / 2);
    margin-bottom: calc(var(--section-padding-y) / 2);
  }
}