125 lines
2.9 KiB
CSS
125 lines
2.9 KiB
CSS
.theme-li {
|
|
height: 50px;
|
|
padding: 15px 8px;
|
|
}
|
|
.theme-li:hover {
|
|
background-color: rgba(0, 0, 0, 0.02);
|
|
}
|
|
body.darktheme .theme-li:hover {
|
|
background-color: #262626;
|
|
}
|
|
.theme-toggle {
|
|
--ease-3: cubic-bezier(0.25, 0, 0.3, 1);
|
|
--ease-out-5: cubic-bezier(0, 0, 0, 1);
|
|
--ease-elastic-3: cubic-bezier(0.5, 1.25, 0.75, 1.25);
|
|
--ease-elastic-4: cubic-bezier(0.5, 1.5, 0.75, 1.25);
|
|
--size: 2rem;
|
|
--icon-fill: #abb3ba;
|
|
--icon-fill-hover: #e2e6e9;
|
|
-webkit-tap-highlight-color: transparent;
|
|
aspect-ratio: 1;
|
|
background: none;
|
|
block-size: var(--size);
|
|
border: none;
|
|
border-radius: 50%;
|
|
cursor: pointer;
|
|
inline-size: var(--size);
|
|
outline-offset: 5px;
|
|
padding: 0;
|
|
touch-action: manipulation;
|
|
}
|
|
.theme-toggle > svg {
|
|
stroke-linecap: round;
|
|
block-size: 100%;
|
|
inline-size: 100%;
|
|
}
|
|
[data-mode=dark].theme-toggle {
|
|
--icon-fill: #454d54;
|
|
--icon-fill-hover: #22262a;
|
|
}
|
|
@media (hover: none) {
|
|
.theme-toggle {
|
|
--size: 48px;
|
|
}
|
|
}
|
|
@media (max-width: 767px) {
|
|
.theme-toggle {
|
|
--size: 24px;
|
|
}
|
|
[data-mode=dark].theme-toggle {
|
|
--icon-fill: #abb3ba;
|
|
--icon-fill-hover: #e2e6e9;
|
|
}
|
|
}
|
|
.sun-and-moon > .moon,
|
|
.sun-and-moon > .sun,
|
|
.sun-and-moon > .sun-beams {
|
|
transform-origin: center center;
|
|
}
|
|
.sun-and-moon > .moon,
|
|
.sun-and-moon > .sun {
|
|
fill: var(--icon-fill);
|
|
}
|
|
.sun-and-moon > .sun-beams {
|
|
stroke: var(--icon-fill);
|
|
stroke-width: 2px;
|
|
}
|
|
.theme-toggle:hover > .sun-and-moon > .moon,
|
|
.theme-toggle:hover > .sun-and-moon > .sun {
|
|
fill: var(--icon-fill-hover);
|
|
}
|
|
.theme-toggle:hover > .sun-and-moon > .sun-beams {
|
|
stroke: var(--icon-fill-hover);
|
|
}
|
|
.theme-toggle:focus-visible > .sun-and-moon > .moon,
|
|
.theme-toggle:focus-visible > .sun-and-moon > .sun {
|
|
fill: var(--icon-fill-hover);
|
|
}
|
|
.theme-toggle:focus-visible > .sun-and-moon > .sun-beams {
|
|
stroke: var(--icon-fill-hover);
|
|
}
|
|
[data-mode=light] .sun-and-moon > .sun {
|
|
transform: scale(1.75);
|
|
}
|
|
[data-mode=light] .sun-and-moon > .sun-beams {
|
|
opacity: 0;
|
|
}
|
|
[data-mode=light] .sun-and-moon > .moon > circle {
|
|
transform: translate(-7px);
|
|
}
|
|
@supports (cx:1) {
|
|
[data-mode=light] .sun-and-moon > .moon > circle {
|
|
cx: 17;
|
|
transform: translate(0);
|
|
}
|
|
}
|
|
@media (prefers-reduced-motion: no-preference) {
|
|
.sun-and-moon > .sun {
|
|
transition: transform 0.5s var(--ease-elastic-3);
|
|
}
|
|
.sun-and-moon > .sun-beams {
|
|
transition: transform 0.5s var(--ease-elastic-4), opacity 0.5s var(--ease-3);
|
|
}
|
|
.sun-and-moon .moon > circle {
|
|
transition: transform 0.25s var(--ease-out-5);
|
|
}
|
|
@supports (cx:1) {
|
|
.sun-and-moon .moon > circle {
|
|
transition: cx 0.25s var(--ease-out-5);
|
|
}
|
|
}
|
|
[data-mode=light] .sun-and-moon > .sun {
|
|
transform: scale(1.75);
|
|
transition-duration: 0.25s;
|
|
transition-timing-function: var(--ease-3);
|
|
}
|
|
[data-mode=light] .sun-and-moon > .sun-beams {
|
|
transform: rotate(-25deg);
|
|
transition-duration: 0.15s;
|
|
}
|
|
[data-mode=light] .sun-and-moon > .moon > circle {
|
|
transition-delay: 0.25s;
|
|
transition-duration: 0.5s;
|
|
}
|
|
}
|