body, html {
  padding: 0;
  margin: 0;
  background-color: #000;
  box-sizing: border-box;
  font-family: Figtree, Verdana, Arial, sans-serif;
  font-size: 16px;
  line-height: 1;
}

div, p, div:before, div:after {
  box-sizing: border-box;
}

.Clock {
  box-sizing: border-box;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  overflow: hidden;
  background-image: radial-gradient(circle, transparent, transparent 38vw, rgba(255,255,255,.15) 39vw, transparent)
}
.Clock-container {
  position: absolute;
  width: 80vw;
  height: 80vw;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.Clock-gears {
  position: absolute;
  top: 10vw;
  bottom: 10vw;
  left: 10vw;
  right: 10vw;
  border-radius: 50%;
  overflow: hidden;
}

.Clock-constant {
  position: absolute;
  top: 8vw;
  bottom: 8vw;
  left: 8vw;
  right: 8vw;
  border-radius: 50%;
  background-image: linear-gradient(to right, #330, #366 50%, #330);
}
.Clock-constant:after {
  content: "";
  position: absolute;
  top: 0.2vw;
  bottom: 0.2vw;
  left: 0.2vw;
  right: 0.2vw;
  border-radius: 50%;
  background-color: #000;
}
.Clock-constantInner {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}
.Clock-constantInner:before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 1vw;
  height: 1vw;
  background-color: #366;
  transform: translate(-50%, -50%) rotate(45deg);
}
.Clock-constantInner:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1vw;
  height: 1vw;
  background-color: #366;
  transform: translate(-50%, 50%) rotate(45deg);
}

.Clock-second {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border: 3vw solid #333;
  border-radius: 50%;
  transform: rotate(0);
}
.Clock-second:before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 4vw;
  height: 4vw;
  transform: translate(-50%, -50%) rotate(45deg);
  background-color: #333;
}
.Clock-second:after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 2vw;
  height: 2vw;
  transform: translate(-50%, -50%) rotate(45deg);
  background-color: #366;
  background-image: linear-gradient(to top left, #9ff, #366);
}
.Clock-secondTop {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}
.Clock-secondTop:before {
  content: "";
  position: absolute;
  top: -2.6vw;
  left: 23vw;
  width: 12vw;
  height: 3vw;
  transform: skewY(-20deg);
  background-color: #333;
}
.Clock-secondTop:after {
  content: "";
  position: absolute;
  top: -2.6vw;
  right: 23vw;
  width: 12vw;
  height: 3vw;
  transform: skewY(20deg);
  background-color: #333;
}
.Clock-secondBottom {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}
.Clock-secondBottom:before {
  content: "";
  position: absolute;
  bottom: -2.6vw;
  left: 23vw;
  width: 12vw;
  height: 3vw;
  transform: skewY(20deg);
  background-color: #333;
}
.Clock-secondBottom:after {
  content: "";
  position: absolute;
  bottom: -2.6vw;
  right: 23vw;
  width: 12vw;
  height: 3vw;
  transform: skewY(-20deg);
  background-color: #333;
}

.Clock-minute {
  position: absolute;
  top: 10vw;
  bottom: 10vw;
  left: 10vw;
  right: 10vw;
  border: 0.5vw solid #666;
  border-radius: 50%;
  background: radial-gradient(transparent, transparent 50%, rgba(192,224,255,.3));
}
.Clock-minute:before {
  content: "";
  position: absolute;
  top: -.25vw;
  left: 50%;
  width: 2vw;
  height: 2vw;
  transform: translate(-50%, -50%) rotate(45deg);
  background-color: #666;
}
.Clock-minute:after {
  content: "";
  position: absolute;
  top: -.25vw;
  left: 50%;
  width: 1vw;
  height: 1vw;
  transform: translate(-50%, -50%) rotate(45deg);
  background-color: #333;
  background-image: linear-gradient(to top left, #99f, #336);
}
.Clock-minuteHand {
  position: absolute;
  top: 0;
  left: 50%;
  bottom: 55%;
  width: 0.4vw;
  transform: translateX(-50%);
  background: linear-gradient(to bottom, rgba(255,255,255,.15), transparent);
  z-index: -1;
}

.Clock-hour {
  position: absolute;
  top: 13vw;
  bottom: 13vw;
  left: 13vw;
  right: 13vw;
  border: 0.25vw solid #999;
  border-radius: 50%;
}
.Clock-hour:before {
  content: "";
  position: absolute;
  top: -.125vw;
  left: 50%;
  width: 1.5vw;
  height: 1.5vw;
  transform: translate(-50%, -50%) rotate(45deg);
  background-color: #999;
}
.Clock-hour:after {
  content: "";
  position: absolute;
  top: -.125vw;
  left: 50%;
  width: .75vw;
  height: .75vw;
  transform: translate(-50%, -50%) rotate(45deg);
  background-color: #999;
  background-image: linear-gradient(to top left, #c9f, #536);
}
.Clock-hourHand {
  position: absolute;
  top: 0;
  left: 50%;
  bottom: 55%;
  width: 0.6vw;
  transform: translateX(-50%);
  background: linear-gradient(to bottom, rgba(255,255,255,.10), transparent);
  z-index: -1;
}

.Clock-text {
  position: absolute;
  top: 50%;
  right: 16vw;
  text-align: right;
  color: rgba(255,255,255,.3);
  transform: translateY(-50%);
  font-size: 6vw;
}

.ClockGear {
  position: absolute;
  top: -15vw;
  left: -10vw;
  width: 40vw;
  height: 40vw;
  background-color: #fff;
  border-radius: 50%;
  opacity: 0.05;
}
.ClockGear:nth-child(2) {
  top: 1.3vw;
  left: 29vw;
}
.ClockGear:nth-child(3) {
  top: 34.8vw;
  left: 3.2vw;
}
.ClockGear:after {
  content: "";
  position: absolute;
  top: 2vw;
  bottom: 2vw;
  left: 2vw;
  right: 2vw;
  background-color: #000;
  border-radius: 50%;
  z-index: 1;
}
.ClockGear-tooth {
  position: absolute;
  top: -2vw;
  bottom: -2vw;
  left: 17.4vw;
  right: 17.4vw;
  background-color: #fff;
  transform: rotate(0);
}
.ClockGear-tooth:nth-child(2) {
  transform: rotate(30deg);
}
.ClockGear-tooth:nth-child(3) {
  transform: rotate(60deg);
}
.ClockGear-tooth:nth-child(4) {
  transform: rotate(90deg);
}
.ClockGear-tooth:nth-child(5) {
  transform: rotate(120deg);
}
.ClockGear-tooth:nth-child(6) {
  transform: rotate(150deg);
}
