.switch { position: relative; height: 2em; width: 5em; cursor: pointer; } .switch-outer { position: absolute; height: 100%; width: 100%; border-radius: 2em; transition: background-color 0.3s ease-out; } .switch.dark .switch-outer { background-color: #22272E; } .switch.light .switch-outer { background-color: #3f61d9; } .switch-inner { width: 95%; top: 50%; border-radius: 2em; transition: background-color 0.2s ease-out; } .switch.light .switch-inner { background-color: #7289da; } .switch.dark .switch-inner { background-color: #1b2137; } .knob { position: absolute; height: 75%; width: 37.5%; top: 50%; transform: translate(0%, -65%); border-radius: 10em; transition: all 0.5s ease-out; } .knob.dark { background-color: #586282; margin: 6% auto auto 8%; } .knob.light { background-color: #364c94; margin: 6% auto auto 56%; } .theme-icon { position: absolute !important; color: white; --ggs: 1; opacity: 100%; transition: opacity 0.3s ease-out; bottom: auto; } .theme-icon.light { left: 15%; top: 20% } .theme-icon.dark { right: 15%; top: 20% } .switch.dark .theme-icon.light { opacity: 0; } .switch.light .theme-icon.dark { opacity: 0; }