css refactor :]

This commit is contained in:
ari melody 2026-03-23 21:32:25 +00:00
parent 81ab7856c6
commit 6e5aad77dd
Signed by: ari
GPG key ID: 60B5F0386E3DDB7E
5 changed files with 146 additions and 158 deletions

View file

@ -16,7 +16,6 @@
<link rel="stylesheet" type="text/css" href="/style/main.css">
<link rel="stylesheet" type="text/css" href="/style/index.css">
<script type="module" src="/script/index.js" defer></script>
</head>
<body>
<header>
@ -52,67 +51,63 @@
<div id="crew-list">
<div class="crew-item">
<img src="/img/avatars/arispacegirl.avif" alt="ari melody photo" class="avatar" width=64 height=64>
<div class="crew-avatar">
<img src="/img/avatars/arispacegirl.avif"
alt="ari melody photo"
class="avatar"
width=128 height=128>
</div>
<div class="crew-info">
<h3>ari</h3>
<p><a href="https://arimelody.space" class="handle">@arispacegirl</a></p>
<div class="crew-tags">
<span class="crew-tag">she/her</span>
<span class="crew-tag">developer</span>
<span class="crew-tag">musician</span>
<span class="crew-tag">artist</span>
</div>
</div>
</div>
<div class="crew-item">
<img src="/img/avatars/vimae.avif" alt="vimae photo" class="avatar" width=64 height=64>
<div class="crew-avatar">
<img src="/img/avatars/vimae.avif"
alt="vimae photo"
class="avatar"
width=128 height=128>
</div>
<div class="crew-info">
<h3>mae</h3>
<p><a href="https://mae.wtf" class="handle">@vimae</a></p>
<div class="crew-tags">
<span class="crew-tag">she/they</span>
<span class="crew-tag">musician</span>
<span class="crew-tag">artist</span>
<span class="crew-tag">developer</span>
</div>
</div>
</div>
<div class="crew-item">
<img src="/img/avatars/zaire.avif" alt="claire photo" class="avatar" width=64 height=64>
<div class="crew-avatar">
<img src="/img/avatars/zaire.avif"
alt="claire photo"
class="avatar"
width=128 height=128>
</div>
<div class="crew-info">
<h3>claire</h3>
<p><a href="https://supitszaire.com" class="handle">@zaire</a></p>
<div class="crew-tags">
<span class="crew-tag">she/her</span>
<span class="crew-tag">musician</span>
<span class="crew-tag">artist</span>
<span class="crew-tag">developer</span>
</div>
</div>
</div>
<div class="crew-item">
<img src="/img/avatars/karakara.avif" alt="julia photo" class="avatar" width=64 height=64>
<div class="crew-avatar">
<img src="/img/avatars/karakara.avif"
alt="julia photo"
class="avatar"
width=128 height=128>
</div>
<div class="crew-info">
<h3>julia</h3>
<p><a href="https://insertdomain.name" class="handle">@karakara</a></p>
<div class="crew-tags">
<span class="crew-tag">she/her</span>
<span class="crew-tag">developer</span>
<span class="crew-tag">artist</span>
</div>
</div>
</div>
<div class="crew-item">
<img src="/img/avatars/loudar.avif" alt="alex photo" class="avatar" width=64 height=64>
<div class="crew-avatar">
<img src="/img/avatars/loudar.avif"
alt="alex photo"
class="avatar"
width=128 height=128>
</div>
<div class="crew-info">
<h3>alex</h3>
<p><a href="https://illegal.trading" class="handle">@loudar</a></p>
<div class="crew-tags">
<span class="crew-tag">he/they</span>
<span class="crew-tag">developer</span>
<span class="crew-tag">musician</span>
<span class="crew-tag">artist</span>
</div>
</div>
</div>
</div>
@ -129,9 +124,12 @@
<img src="/img/projects/campfire.avif" alt="screenshot of the campfire timeline" width=256>
</div>
<div class="project-info">
<h3>campfire</h3>
<h3>
<a href="https://campfire.bliss.town" class="col-on-primary">
campfire
</a>
</h3>
<p>a pretty, modern web client for the fediverse!</p>
<a href="https://campfire.bliss.town" class="col-on-primary">campfire.bliss.town</a>
</div>
</div>
</div>
@ -142,5 +140,7 @@
made with <span role="img" aria-label="love"></span> by <a href="https://arimelody.space">ari</a>, 2025.
</p>
</footer>
<script type="module" src="/script/index.js" defer></script>
</body>
</html>

View file

@ -1,13 +1,8 @@
import { hijackClickEvent } from './main.js';
import { hijackClickEvent } from "./main.js";
document.addEventListener('readystatechange', () => {
document.querySelectorAll("#project-list .project-item").forEach(projectItem => {
const link = projectItem.querySelector('a');
hijackClickEvent(projectItem, link);
});
document.querySelectorAll("#crew-list .crew-item .crew-info").forEach(crewItem => {
const link = crewItem.querySelector('a.handle');
hijackClickEvent(crewItem, link);
document.addEventListener("readystatechange", () => {
document.querySelectorAll(".project-item").forEach(container => {
const link = container.querySelector("a");
hijackClickEvent(container, link);
});
});

View file

@ -1,4 +1,4 @@
export function hijackClickEvent(container, link) {
export function hijackClickEvent(container, link) {
container.addEventListener('click', event => {
if (event.target.tagName.toLowerCase() === 'a') return;
event.preventDefault();

View file

@ -8,116 +8,113 @@
border-radius: 8px;
overflow: clip;
background-color: var(--primary);
transition: background-color .2s linear;
box-shadow: 2px 2px 2px #0004;
box-shadow: 4px 4px 0 color-mix(in srgb, var(--background), #0008 50%);
cursor: pointer;
}
.project-item:hover {
outline: 1px solid var(--on-primary);
}
.project-item-banner {
.project-item-banner {
width: 256px;
height: 128px;
}
.project-item-banner img {
img {
width: 100%;
height: 100%;
object-fit: cover;
}
}
}
.project-info {
.project-info {
padding: .4em .5em;
}
.project-info h3 {
margin: 0;
}
.project-info p {
font-size: .8em;
margin: 0;
}
.project-info a {
font-style: italic;
font-size: .8em;
h3 {
margin: 0 0 .2em 0;
a {
color: var(--on-background);
opacity: .75;
transition: color .2s linear;
text-decoration: none;
}
}
p {
font-size: .8em;
margin: 0;
}
}
&:hover {
outline: 1px solid var(--on-primary);
}
}
#crew-list {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 1em;
}
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 2em 4em;
.crew-item {
.crew-item {
width: 10em;
display: grid;
grid-template-columns: 64px 1fr;
grid-template-rows: 8em 4em;
gap: .5em;
}
text-align: center;
transform: rotate(2deg);
.crew-item img.avatar {
width: 64px;
height: 64px;
&:nth-child(even) {
transform: rotate(-2deg);
&:hover .crew-avatar img.avatar {
transform: rotate(-4deg);
}
}
.crew-avatar img.avatar, .crew-info {
box-shadow: 4px 4px 0 color-mix(in srgb, var(--background), #0008 50%);
}
&:hover .crew-avatar img.avatar {
transform: rotate(2deg);
}
}
.crew-avatar {
img.avatar {
width: 8em;
height: 8em;
aspect-ratio: 1;
object-fit: cover;
border-radius: 8px;
background-color: #101010;
}
background-color: var(--primary);
}
}
.crew-item:nth-child(even) .crew-avatar img.avatar {
transform: rotate(-2deg);
}
.crew-item .crew-info {
.crew-info {
padding: .5em;
display: flex;
flex-direction: column;
background-color: var(--primary);
border-radius: 8px;
box-shadow: 2px 2px 2px #0004;
transition: background-color .2s linear;
cursor: pointer;
}
.crew-info:hover {
outline: 1px solid var(--on-primary);
}
.crew-item h3 {
display: block;
margin: 0 0 -.2em 0;
transition: inherit;
}
.crew-item h3 a {
display: block;
color: inherit;
}
h3, p {
margin: 0;
}
.crew-item a.handle {
display: block;
font-style: italic;
h3 {
font-size: 1.5em;
}
p {
font-size: .8em;
color: var(--on-background);
opacity: .75;
transition: color .2s linear;
text-decoration: none;
}
.crew-item p {
margin: .2em 0;
}
.crew-item .crew-tags {
margin: .5em 0 0 0;
display: flex;
gap: .2em;
}
.crew-item .crew-tag {
font-size: .75em;
padding: .2em .5em;
border-radius: 4px;
text-wrap: nowrap;
color: var(--on-primary);
border: 1px solid var(--on-primary);
}
@media screen and (max-width: 500px) {
.crew-tags {
flex-wrap: wrap;
}
}
.crew-item:nth-child(odd) .crew-info:before {
transform: skew(0, 2deg) translate(1.3em, -.2em);
}
}
@media screen and (max-width: 900px) {
#crew-list {
#grid-template-columns: repeat(2, 1fr);
}
}

View file

@ -25,8 +25,11 @@ body {
color: var(--on-background);
background-color: var(--background);
}
transition: color .2s linear, background-color .2s linear;
*, *::before, *::after {
transition-property: background-color, color, box-shadow, border-color, opacity;
transition-duration: .2s;
}
header {
@ -38,7 +41,6 @@ header {
border-bottom: 1px solid var(--primary);
background-color: var(--background);
z-index: 1000;
transition: background-color .2s linear, box-shadow .2s linear, border-color .2s linear;
}
header nav {
@ -78,12 +80,10 @@ main {
.only-light {
opacity: 1;
transition: opacity .2s linear;
}
.only-dark {
opacity: 0;
transition: opacity .2s linear;
}
hr {
@ -99,14 +99,12 @@ hr::after {
padding: 5px;
color: var(--on-background);
background: var(--background);
transition: color .2s linear, background-color .2s linear;
}
a {
color: var(--on-primary);
text-decoration: none;
font-weight: bold;
transition: color .2s linear;
}
a:hover {
@ -123,7 +121,6 @@ button {
border: none;
border-radius: 2em;
cursor: pointer;
transition: color .2s linear, background-color .2s linear, transform .1s ease-out;
}
button:hover {
@ -140,7 +137,6 @@ footer {
padding: 1em 0;
text-align: center;
opacity: .5;
transition: opacity .1s ease-out;
}
footer:hover {