erynwells.me/content/home.css
2022-09-03 15:30:38 -07:00

134 lines
2.8 KiB
CSS

:root {
--lt-blue: rgb(69, 212, 243);
--mid-blue: rgb(26, 169, 239);
--dk-blue: rgb(63, 46, 231);
--purple: rgb(161, 49, 232);
--lilac: rgb(187, 121, 245);
--font-size-min: 8px;
--font-size-max: 16px;
}
* { box-sizing: border-box; }
a {
color: var(--mid-blue);
text-decoration: none;
}
a:hover {
text-decoration: underline;
text-underline-offset: 0.12em;
}
a:visited { color: none; }
body {
display: flex;
font-size: 2rem;
margin: auto;
justify-content: center;
}
h1 {
font-family: Krungthep, Museo_Slab, Tahoma, sans-serif;
margin: 0;
padding: 0;
}
@media (max-width: 450px) {
h1 { font-size: 4.25rem; }
}
html {
background-color: #fff;
color: #000;
font-family: Verdana, sans-serif;
font-size: clamp(var(--font-size-min), 2.5vw, var(--font-size-max));
}
@media (prefers-color-scheme: dark) {
html {
background-color: #000;
color: #fff;
}
}
main {
align-items: baseline;
display: grid;
grid-template-columns: min-content 3fr;
grid-template-rows: repeat(2, max-content);
grid-template-areas:
"title blurb"
"title nav";
grid-gap: 2rem;
margin-block-start: 10vh;
max-width: 800px;
}
@media (max-width: 450px) {
main {
grid-template-columns: 1fr;
grid-template-rows: repeat(3, max-content);
grid-template-areas:
"title"
"nav"
"blurb";
margin-block-start: 5vh;
text-align: center;
}
}
main h1 {
background:
radial-gradient(circle at 20% 70%, var(--purple), transparent 40%),
radial-gradient(circle at 30% 30%, var(--lt-blue), var(--mid-blue) 20%, transparent 80%),
radial-gradient(ellipse at 95% 20%, var(--dk-blue), var(--mid-blue) 70%, transparent 80%),
radial-gradient(circle at 100% 100%, var(--purple), var(--lilac) 100%),
radial-gradient(circle at 45% 100%, var(--lilac), var(--purple) 60%),
radial-gradient(ellipse at 50% 50%, var(--dk-blue), transparent 80%);
background-clip: text;
color: transparent;
grid-area: title;
letter-spacing: 0.025em;
text-align: end;
}
@media (max-width: 450px) {
main h1 { text-align: center; }
}
main nav {
align-items: center;
display: flex;
font-size: max(1rem, 75%);
font-variant: small-caps;
grid-area: nav;
height: 100%;
justify-content: center;
letter-spacing: 0.12em;
list-style: none;
text-transform: lowercase;
}
main nav li {
display: block;
margin-inline-end: 0.5em;
}
main nav li:first-child::before {
content: "";
}
main nav li::before {
content: "•";
font-size: 60%;
opacity: 80%;
margin-inline-end: 0.5em;
}
main p {
grid-area: blurb;
margin: 0;
padding: 0;
}
p {
letter-spacing: 0.025em;
line-height: 1.25;
}