* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	min-height: 100vh;
	display: flex;
	justify-content: center;
	align-items: center;
	background: #0a0a0a;
	overflow: hidden;
}

.main-wrapper {
	display: flex;
	position: absolute;
	transform-style: preserve-3d;
	perspective: 400px;
	left: 0;
	top: 0;
	bottom: 0;
	right: 0;
	align-items: center;
	justify-content: center;
}

.sphere-shape {
	transform-style: preserve-3d;
	width: 300px;
	height: 300px;
	position: relative;
	animation: rotate3d 10s linear infinite;
}

.plane {
	position: absolute;
	transform-style: preserve-3d;
	left: 0;
	top: 0;
	bottom: 0;
	right: 0;
}

.spoke {
	transform-origin: 0 0;
	transform-style: preserve-3d;
	position: absolute;
	left: 50%;
	top: 50%;
	height: 150px;
	width: 0px;
}

.dot {
	position: absolute;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: #fff;
	left: -3px;
	top: 100px;
	transform: rotateX(90deg);
}

.spoke.spoke-1 {
	transform: rotateZ(10deg);
}

.spoke.spoke-2 {
	transform: rotateZ(20deg);
}

.spoke.spoke-3 {
	transform: rotateZ(30deg);
}

.spoke.spoke-4 {
	transform: rotateZ(40deg);
}

.spoke.spoke-5 {
	transform: rotateZ(50deg);
}

.spoke.spoke-6 {
	transform: rotateZ(60deg);
}

.spoke.spoke-7 {
	transform: rotateZ(70deg);
}

.spoke.spoke-8 {
	transform: rotateZ(80deg);
}

.spoke.spoke-9 {
	transform: rotateZ(90deg);
}

.spoke.spoke-10 {
	transform: rotateZ(100deg);
}

.spoke.spoke-11 {
	transform: rotateZ(110deg);
}

.spoke.spoke-12 {
	transform: rotateZ(120deg);
}

.spoke.spoke-13 {
	transform: rotateZ(130deg);
}

.spoke.spoke-14 {
	transform: rotateZ(140deg);
}

.spoke.spoke-15 {
	transform: rotateZ(150deg);
}

.spoke.spoke-16 {
	transform: rotateZ(160deg);
}

.spoke.spoke-17 {
	transform: rotateZ(170deg);
}

.spoke.spoke-18 {
	transform: rotateZ(180deg);
}

.spoke.spoke-19 {
	transform: rotateZ(190deg);
}

.spoke.spoke-20 {
	transform: rotateZ(200deg);
}

.spoke.spoke-21 {
	transform: rotateZ(210deg);
}

.spoke.spoke-22 {
	transform: rotateZ(220deg);
}

.spoke.spoke-23 {
	transform: rotateZ(230deg);
}

.spoke.spoke-24 {
	transform: rotateZ(240deg);
}

.spoke.spoke-25 {
	transform: rotateZ(250deg);
}

.spoke.spoke-26 {
	transform: rotateZ(260deg);
}

.spoke.spoke-27 {
	transform: rotateZ(270deg);
}

.spoke.spoke-28 {
	transform: rotateZ(280deg);
}

.spoke.spoke-29 {
	transform: rotateZ(290deg);
}

.spoke.spoke-30 {
	transform: rotateZ(300deg);
}

.spoke.spoke-31 {
	transform: rotateZ(310deg);
}

.spoke.spoke-32 {
	transform: rotateZ(320deg);
}

.spoke.spoke-33 {
	transform: rotateZ(330deg);
}

.spoke.spoke-34 {
	transform: rotateZ(340deg);
}

.spoke.spoke-35 {
	transform: rotateZ(350deg);
}

.spoke.spoke-36 {
	transform: rotateZ(360deg);
}

.plane.plane-1 {
	transform: rotateY(15deg);
}

.plane.plane-2 {
	transform: rotateY(30deg);
}

.plane.plane-3 {
	transform: rotateY(45deg);
}

.plane.plane-4 {
	transform: rotateY(60deg);
}

.plane.plane-5 {
	transform: rotateY(75deg);
}

.plane.plane-6 {
	transform: rotateY(90deg);
}

.plane.plane-7 {
	transform: rotateY(105deg);
}

.plane.plane-8 {
	transform: rotateY(120deg);
}

.plane.plane-9 {
	transform: rotateY(135deg);
}

.plane.plane-10 {
	transform: rotateY(150deg);
}

.plane.plane-11 {
	transform: rotateY(165deg);
}

.plane.plane-12 {
	transform: rotateY(180deg);
}

@keyframes rotate3d {
	0% {
		transform: rotate3d(1, 1, 1, 0deg);
	}

	25% {
		transform: rotate3d(1, 1, 1, 90deg);
	}

	50% {
		transform: rotate3d(1, 1, 1, 180deg);
	}

	75% {
		transform: rotate3d(1, 1, 1, 270deg);
	}

	100% {
		transform: rotate3d(1, 1, 1, 360deg);
	}
}