.nc-button {
    color: var(--color) !important;
    background: var(--color-bg);
    display: inline-grid;
    place-content: center;
    font-family: 'Noto Sans JP', sans-serif;
    box-sizing: border-box;
    box-shadow: 0px 2px 4px 2px rgba(0, 0, 0, 0.2);
    text-decoration: none;
    line-height: 1;

    &:hover,
    &:focus {
        opacity: 0.8;
        text-decoration: none;
    }
}

.nc-button-primary {
    --color: var(--white);
    --color-bg: linear-gradient(90deg, #1F8CA6 0%, #41B1B7 77%, #41B1B7 100%);
}

/* .nc-button-secondary {
    --color: var(--white);
    --color-bg: linear-gradient(180deg, #181818 0%, #303030 78%, #303030 100%);
} */

.nc-button-emphasize {
    --color: var(--white);
    --color-bg: linear-gradient(90deg, #BF0014 0%, #FF3139 78%);

}

.nc-button-black {
    --color: var(--white);
    --color-bg: linear-gradient(90deg, #181818 0%, #303030 78%, #303030 100%);
}

.nc-button-white {
    --color: var(--gray-900);
    --color-bg: linear-gradient(to right, rgba(219, 229, 230, 1) 0%, rgba(255, 255, 255, 1) 78%, rgba(255, 255, 255, 1) 100%)
}

/* elevation */
.nc-button-elevation-0 {
    box-shadow: none;
}



/* size */
.nc-button-xl {
    height: 100px;
    padding: 0 var(--space-lvl4);

    @media screen and (max-width: 639px) {
        height: 75px;
        padding: 0 var(--space-lvl4);
        width: 100%;
    }
}

/* .nc-button-lg {
    height: 100px;
    padding: 0 var(--space-lvl4);
    font-size: 16px;
} */

/*
.nc-button-md {
    padding: 8px 16px;
    font-size: 16px;
    min-width: 100px;
}

.nc-button-sm {
    padding: 8px 16px;
    font-size: 14px;
    min-width: 100px;
} */

/* arrow */
.nc-button-arrow {
    position: relative;

    &::after {
        content: '';
        display: block;
        width: 8px;
        height: 8px;
        border-top: 3px solid var(--color);
        border-right: 3px solid var(--color);
        position: absolute;
        top: 50%;
        right: var(--space-lvl4);
        transform: rotate(45deg) translateX(-50%);
    }
}

/* font size variations */
.nc-button-font-xxl {
    font-size: var(--font-size-xx-large);
    letter-spacing: 0;
}

.nc-button-font-xl {
    font-size: var(--font-size-x-large);
    letter-spacing: 0;
}

.nc-button-font-md {
    font-size: var(--font-size-medium);
    letter-spacing: 0;
}

/* .nc-button-font-md {
    font-size: 16px;
}
.nc-button-font-lg {
    font-size: 18px;
}
.nc-button-font-xl {
    font-size: 20px;
} */

@media screen and (max-width:639px) {
    .nc-button-font-xxl {
        font-size: var(--font-size-medium);
    }

    .nc-button-font-xl {
        font-size: var(--font-size-large);
        letter-spacing: 0;
    }

    .nc-button-font-md {
        font-size: var(--font-size-small);
        letter-spacing: 0;
    }
}