/* ============================================
   BLOCK: Button
   ============================================ */

.button {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-bold);
    /* 46px - 56px */
    line-height: clamp(2.875rem, 5.5vw, 3.5rem);
    text-align: center;
    text-decoration: none;
    min-width: 12.5rem;
    padding: 0 var(--space-md);
    background-color: var(--color-primary);
    color: var(--color-light);
    border-radius: 0.25rem;
    display: inline-block;
    position: relative;
    z-index: 1;
}

.button:before {
    content: "";
    width: 0%;
    height: 100%;
    background: var(--color-purple-400);
    opacity: 1;
    border-radius: 0.25rem;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    transition: width 0.3s;
}

.button:hover:before {
    width: 100%;
}
