/*=========== Mode =====*/
.mode {
  height: 100%;
  aspect-ratio: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(2vh, 2vw, 2vw);
  position: relative;
}

.sign {
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: conic-gradient(var(--toggle-segment-start) 0deg 62deg,
      var(--toggle-segment-mid) 62deg 298deg,
      var(--toggle-segment-end) 298deg 360deg);
  border: var(--outline-width) solid var(--outline-color);
  box-shadow: var(--hard-shadow);
  display: flex;
  justify-content: space-between;
  padding: 5% 20%;
  box-sizing: border-box;
  z-index: 1;
}

.icon-sun {
  font-size: 50%;
  text-shadow: none;
  z-index: 5;
}

.icon-moon {
  font-size: 50%;
  text-shadow: none;
  z-index: 5;
}

/*=========== Knob =====*/
.theme-knob {
  position: absolute;
  height: 60%;
  aspect-ratio: 1;
  inset: 0;
  margin: auto;
  transform-origin: center center;
  border-radius: 50%;
  background: repeating-conic-gradient(from 0deg,
      var(--knurl-light) 0deg 8deg,
      var(--knurl-dark) 8deg 11deg);
  border: var(--outline-width) solid var(--outline-color);
  z-index: 10;
  transition: rotate 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  transform-style: preserve-3d;
  cursor: pointer;
  rotate: 330deg;
}

.theme-knob.rotated {
  rotate: 390deg;
}

.knob-pointer {
  position: absolute;
  top: -40%;
  height: 100%;
  aspect-ratio: 1;
  background-color: var(--toggle-pointer);
  clip-path: polygon(50% 0%, 65% 80%, 35% 80%);
  transform: translateZ(-1px);
}
