.button {
	--btn-color: #fff;
	--btn-hover-color: var(--color-primary);

	display: inline-grid;
	align-items: center;
	align-content: center;
	justify-content: center;
	grid-template-columns: auto;
	grid-template-areas: "button-text";
	gap: 1rem;

	cursor: pointer;
	color: var(--btn-color);
	margin: 0;
	padding: 1.2rem 2.2rem;
	border: .2rem solid var(--btn-color);
	background-color: transparent;
	outline: none;
	font-family: 'Barlow Semi Condensed', sans-serif;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1;
	position: relative;
	overflow: hidden;
	width: auto;
	text-transform: uppercase;
	letter-spacing: .2rem;
	min-height: 5.2rem;
	transition: .25s ease-in-out;
}

.button:has(i) {
	grid-template-columns: 1.8rem auto;
	grid-template-areas: "button-icon button-text";
}

.button:has(i.icon-arrow-down-line),
.button:has(i.icon-arrow-right-line),
.button:has(i.icon-arrow-up-line),
.button:has(i.icon-arrow-right-down-line),
.button:has(i.icon-arrow-right-up-line),
.button:has(i.icon-arrow-down-s-fill),
.button:has(i.icon-arrow-right-s-fill),
.button:has(i.icon-arrow-up-s-fill) {
	grid-template-columns: auto 1.8rem;
	grid-template-areas: "button-text button-icon";
}


.button:hover {
	color: var(--btn-hover-color);
}

.button::after {
	content: '';
	background-color: var(--btn-color);
	display: block;
	position: absolute;
	z-index: 1;
	top: 0;
	left: -2.6rem;
	width: calc(100% + 5.2rem);
	height: 100%;
	transform: translateX(100%) skew(-45deg, 0);
	opacity: 0;
	transition: .25s ease-in-out;
}

.button:hover::after {
	transform: translateX(0%) skew(-45deg, 0);
	opacity: 1;
}

.button > span {
	grid-area: button-text;
	position: relative;
	z-index: 2;
}

.button > i {
	grid-area: button-icon;
	margin: 0;
	width: 1.8rem;
	height: 100%;
	position: relative;
	color: currentColor;
	z-index: 2;
}

.button > i::before {
	position: absolute;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
}

.black .button {
	--btn-color: var(--color-primary);
	--btn-hover-color: #fff;
}

.white .button{
	--btn-color: #fff;
	--btn-hover-color: var(--color-primary);
}

.button-white,
.button-light-grey,
.button-grey {
	--btn-color: var(--color-primary);
	--btn-hover-color: #fff;
}

.button-dark-grey,
.button-light-primary,
.button-primary, 
.button-secondary,
.button-black {
	--btn-color: #fff;
	--btn-hover-color: var(--color-primary);
}