/* =================================
   SÉPARATEUR
   ================================= */

.separator {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}

.separator hr {
  margin: 0;
  padding: 0;
  border: none;
  background: var(--separator-color, #000);
}

/* Espacements */
.separator-spacing-small {
  margin: 2rem 0;
}

.separator-spacing-medium {
  margin: 4rem 0;
}

.separator-spacing-large {
  margin: 6rem 0;
}

/* Largeurs */
.separator-width-full hr {
  width: 100%;
}

.separator-width-large hr {
  width: 80%;
}

.separator-width-medium hr {
  width: 60%;
}

.separator-width-small hr {
  width: 40%;
}

/* Styles de ligne */
.separator-line hr {
  height: 1px;
}

.separator-thick hr {
  height: 3px;
}

.separator-dotted hr {
  height: 1px;
  background: transparent;
  border-top: 2px dotted var(--separator-color, #000);
}

.separator-dashed hr {
  height: 1px;
  background: transparent;
  border-top: 2px dashed var(--separator-color, #000);
}

.separator-double hr {
  height: 5px;
  background: transparent;
  border-top: 1px solid var(--separator-color, #000);
  border-bottom: 1px solid var(--separator-color, #000);
}

.separator-wave hr {
  height: 8px;
  background: transparent;
  border: none;
  position: relative;
  overflow: hidden;
}

.separator-wave hr::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 8px;
  background-image: repeating-linear-gradient(
    90deg,
    transparent,
    transparent 10px,
    var(--separator-color, #000) 10px,
    var(--separator-color, #000) 20px
  );
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 10'%3E%3Cpath d='M0,5 Q25,0 50,5 T100,5' fill='none' stroke='black' stroke-width='10'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 10'%3E%3Cpath d='M0,5 Q25,0 50,5 T100,5' fill='none' stroke='black' stroke-width='10'/%3E%3C/svg%3E");
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

/* Responsive */
@media (max-width: 600px) {
  .separator-spacing-small {
    margin: 1.5rem 0;
  }
  
  .separator-spacing-medium {
    margin: 3rem 0;
  }
  
  .separator-spacing-large {
    margin: 4rem 0;
  }
}