111 lines
2.1 KiB
CSS
111 lines
2.1 KiB
CSS
:root {
|
|
color-scheme: light dark;
|
|
|
|
--dark-background-color: hsl(250, 50%, 8%);
|
|
--dark-foreground: hsl(250, 10%, 90%);
|
|
--dark-foreground-dim: hsl(250, 10%, 70%);
|
|
|
|
--light-background-color: hsl(250, 50%, 92%);
|
|
--light-foreground: hsl(250, 10%, 10%);
|
|
--light-foreground-dim: hsl(250, 10%, 30%);
|
|
|
|
--dark-accent-color: hsl(150, 70%, 50%);
|
|
--dark-strong-color: hsl(50, 70%, 50%);
|
|
--dark-error-color: hsl(50, 70%, 50%);
|
|
|
|
--light-accent-color: hsl(230, 70%, 50%);
|
|
--light-strong-color: hsl(210, 70%, 50%);
|
|
--light-error-color: hsl(210, 70%, 50%);
|
|
|
|
--font-family-text: "Inter", sans-serif;
|
|
}
|
|
|
|
* {
|
|
box-sizing: border-box;
|
|
font-family: var(--font-family-text);
|
|
}
|
|
|
|
html, body {
|
|
margin: 0;
|
|
padding: 0;
|
|
}
|
|
|
|
body {
|
|
min-height: 100dvh;
|
|
display: grid;
|
|
grid-template-rows: auto 1fr auto;
|
|
background-color: light-dark(
|
|
var(--light-background-color),
|
|
var(--dark-background-color)
|
|
);
|
|
color: light-dark(var(--light-foreground), var(--dark-foreground));
|
|
font-weight: 300;
|
|
}
|
|
|
|
header {
|
|
padding: 0em 2em;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
border-bottom: 1px solid
|
|
color-mix(
|
|
in srgb,
|
|
light-dark(
|
|
var(--light-foreground-dim),
|
|
var(--dark-foreground-dim)
|
|
) 30%,
|
|
transparent
|
|
);
|
|
|
|
font-weight: 700;
|
|
}
|
|
|
|
header > h1 {
|
|
font-size: large;
|
|
}
|
|
|
|
header > nav {
|
|
display: flex;
|
|
gap: 1em;
|
|
}
|
|
|
|
footer {
|
|
padding: 0.5em;
|
|
display: flex;
|
|
justify-content: center;
|
|
color: light-dark(var(--light-foreground-dim), var(--dark-foreground-dim));
|
|
font-style: italic;
|
|
font-size: small;
|
|
}
|
|
|
|
section {
|
|
padding: 0.5em 2em;
|
|
}
|
|
|
|
a {
|
|
position: relative;
|
|
text-decoration: none;
|
|
color: light-dark(var(--light-accent-color), var(--dark-accent-color));
|
|
}
|
|
|
|
a::before {
|
|
content: "";
|
|
position: absolute;
|
|
left: 0;
|
|
right: 0;
|
|
bottom: 0;
|
|
height: 2px;
|
|
background-color: light-dark(
|
|
var(--light-accent-color),
|
|
var(--dark-accent-color)
|
|
);
|
|
transform-origin: right;
|
|
transform: scaleX(0);
|
|
transition: transform 100ms ease-in-out;
|
|
}
|
|
|
|
a:focus::before, a:hover::before {
|
|
transform-origin: left;
|
|
transform: scaleX(1);
|
|
}
|