/* ===================================
   Seed I.T - Effet Survol Texte Souligné Animé
   Variables et styles globaux
   =================================== */

:root {
  /* Variables Seed I.T officielles */
  --seedit-primary: #037CFB;
  --seedit-primary-light: #4DB6FF;
  --seedit-bg-dark: #1a1a2e;
  --seedit-bg-darker: #16213e;
  --seedit-radius: 12px;
  --seedit-transition: 0.25s ease;
  --seedit-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);

  /* Variables spécifiques au soulignement */
  --seedit-underline-color: var(--seedit-primary-light);
  --seedit-underline-thickness: 2px;
  --seedit-underline-offset: 4px;
  --seedit-underline-duration: 0.3s;

  /* Couleurs variantes */
  --seedit-success: #10B981;
  --seedit-warning: #FFB703;
  --seedit-danger: #EF4444;
}

/* Reset et base */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
  color: #ffffff;
  min-height: 100vh;
  padding: 2rem;
}

/* ===================================
   Conteneur principal de démonstration
   =================================== */

.seedit-underline-demo {
  max-width: 1000px;
  margin: 0 auto;
}

.seedit-underline-demo__title {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 1rem;
  background: linear-gradient(135deg, var(--seedit-primary) 0%, var(--seedit-primary-light) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.seedit-underline-demo__description {
  text-align: center;
  font-size: 1.1rem;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 3rem;
}

/* ===================================
   Sections de démonstration
   =================================== */

.seedit-underline-demo__section {
  background: rgba(255, 255, 255, 0.05);
  border-radius: var(--seedit-radius);
  padding: 2rem;
  margin-bottom: 2rem;
  backdrop-filter: blur(10px);
}

.seedit-underline-demo__section--dark {
  background: rgba(0, 0, 0, 0.3);
}

.seedit-underline-demo__section-title {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--seedit-primary-light);
  text-align: center;
}

.seedit-underline-demo__section-desc {
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 2rem;
  text-align: center;
}

.seedit-underline-demo__examples {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: center;
  align-items: center;
}

/* ===================================
   Composant de base - Texte souligné animé
   =================================== */

.seedit-underline {
  /* Structure */
  position: relative;
  display: inline-block;

  /* Style de base */
  color: #ffffff;
  text-decoration: none;
  font-size: 1.1rem;
  font-weight: 500;
  padding-bottom: var(--seedit-underline-offset);

  /* Transitions */
  transition: color var(--seedit-transition);

  /* Curseur */
  cursor: pointer;
}

/* Pseudo-élément pour le soulignement */
.seedit-underline::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: var(--seedit-underline-thickness);
  background: var(--seedit-underline-color);
  transform-origin: left;
  transition: transform var(--seedit-underline-duration) ease;
}

/* État focus pour l'accessibilité */
.seedit-underline:focus {
  outline: 2px solid var(--seedit-primary-light);
  outline-offset: 4px;
  border-radius: 2px;
}

/* ===================================
   VARIANTE : Slide-in (gauche → droite)
   =================================== */

.seedit-underline--slide::after {
  transform: scaleX(0);
  transform-origin: left;
}

.seedit-underline--slide:hover::after,
.seedit-underline--slide:focus::after {
  transform: scaleX(1);
}

/* ===================================
   VARIANTE : Center-out (centre → extérieur)
   =================================== */

.seedit-underline--center::after {
  transform: scaleX(0);
  transform-origin: center;
}

.seedit-underline--center:hover::after,
.seedit-underline--center:focus::after {
  transform: scaleX(1);
}

/* ===================================
   VARIANTE : Fade-in (apparition progressive)
   =================================== */

.seedit-underline--fade::after {
  opacity: 0;
  transform: scaleX(1);
}

.seedit-underline--fade:hover::after,
.seedit-underline--fade:focus::after {
  opacity: 1;
}

/* ===================================
   VARIANTE : Bounce (rebond élastique)
   =================================== */

.seedit-underline--bounce::after {
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

.seedit-underline--bounce:hover::after,
.seedit-underline--bounce:focus::after {
  transform: scaleX(1);
}

/* ===================================
   MODIFICATEURS : Épaisseur
   =================================== */

.seedit-underline--thick::after {
  height: 4px;
}

/* ===================================
   MODIFICATEURS : Style de trait
   =================================== */

.seedit-underline--dotted::after {
  background: none;
  border-bottom: var(--seedit-underline-thickness) dotted var(--seedit-underline-color);
  height: 0;
}

/* ===================================
   MODIFICATEURS : Couleurs
   =================================== */

.seedit-underline--primary::after {
  background: var(--seedit-primary);
}

.seedit-underline--light::after {
  background: var(--seedit-primary-light);
}

.seedit-underline--success::after {
  background: var(--seedit-success);
}

.seedit-underline--warning::after {
  background: var(--seedit-warning);
}

.seedit-underline--danger::after {
  background: var(--seedit-danger);
}

/* ===================================
   MODIFICATEUR : Dégradé
   =================================== */

.seedit-underline--gradient::after {
  background: linear-gradient(90deg, var(--seedit-primary) 0%, var(--seedit-primary-light) 100%);
}

/* ===================================
   Exemple : Menu de navigation
   =================================== */

.seedit-nav {
  max-width: 800px;
  margin: 0 auto;
}

.seedit-nav__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2.5rem;
  list-style: none;
  padding: 1rem 0;
}

.seedit-nav__item {
  /* Pas de style spécifique */
}

.seedit-nav__link {
  font-size: 1.1rem;
  color: rgba(255, 255, 255, 0.9);
}

.seedit-nav__link[aria-current="page"] {
  color: var(--seedit-primary-light);
  font-weight: 600;
}

.seedit-nav__link[aria-current="page"]::after {
  transform: scaleX(1);
}

/* ===================================
   Exemple : Contenu de paragraphe
   =================================== */

.seedit-content {
  max-width: 700px;
  margin: 0 auto;
}

.seedit-content__text {
  font-size: 1.1rem;
  line-height: 1.8;
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: 1.5rem;
}

.seedit-content__text .seedit-underline {
  font-size: inherit;
  font-weight: 600;
  color: #ffffff;
}

/* ===================================
   Responsive Design
   =================================== */

@media (max-width: 768px) {
  .seedit-underline-demo__title {
    font-size: 2rem;
  }

  .seedit-underline-demo__section {
    padding: 1.5rem;
  }

  .seedit-underline-demo__examples {
    gap: 1.5rem;
    flex-direction: column;
  }

  .seedit-underline {
    font-size: 1rem;
  }

  .seedit-nav__list {
    gap: 1.5rem;
  }

  .seedit-nav__link {
    font-size: 1rem;
  }

  .seedit-content__text {
    font-size: 1rem;
  }
}

@media (max-width: 375px) {
  .seedit-underline-demo__title {
    font-size: 1.75rem;
  }

  .seedit-underline-demo__description {
    font-size: 1rem;
  }

  .seedit-underline-demo__section {
    padding: 1.25rem;
  }

  .seedit-underline {
    font-size: 0.95rem;
  }

  .seedit-nav__list {
    flex-direction: column;
    gap: 1rem;
    align-items: center;
  }
}
