:root {
	--size: 125px;
	--border-width: 5px;
	--fill-factor: 85%;
}
.center {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	margin: auto;
}
.wrapper {
	height: 50vh;
	width: 100vw;
}
.loader {
	margin-top: 50px;
	margin-bottom: 20px;
}
.outer {
	height: var(--size);
	width: var(--size);
	border-left: var(--border-width) solid var(--bs-primary);
	border-right: var(--border-width) solid var(--bs-primary);
	border-top: var(--border-width) solid transparent;
	border-bottom: var(--border-width) solid transparent;
	border-radius: 50%;
	animation: spin 2s linear infinite;
}
.mid {
	height: var(--fill-factor);
	width: var(--fill-factor);
	border-left: var(--border-width) solid var(--bs-secondary);
	border-right: var(--border-width) solid var(--bs-secondary);
	border-top: var(--border-width) solid transparent;
	border-bottom: var(--border-width) solid transparent;
	border-radius: 50%;
	animation: counter 1s linear infinite;
	transform: rotate(45deg);
}
.inner {
	height: var(--fill-factor);
	width: var(--fill-factor);
	border-left: var(--border-width) solid var(--bs-primary);
	border-right: var(--border-width) solid var(--bs-primary);
	border-top: var(--border-width) solid transparent;
	border-bottom: var(--border-width) solid transparent;
	border-radius: 50%;
	transform: rotate(45deg);
	animation: spin 0.8s linear infinite;
}
.break {
	flex-basis: 100%;
	height: 0;
}
.loading-text {
	text-align: center;
	font-weight: 600;
	font-size: large;
}

@keyframes spin {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}

@keyframes counter {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(-360deg);
	}
}
