v1 review pass: fixed some minor bugs

This commit is contained in:
khannurien
2026-03-16 11:08:39 +00:00
parent e88fed4e98
commit 867e64cb5b
37 changed files with 1228 additions and 400 deletions

View File

@@ -89,7 +89,6 @@
margin-left: auto;
}
/* Forms */
.auth-form {
display: flex;
@@ -139,7 +138,11 @@
.dump-form textarea:hover,
.auth-form input:hover,
.auth-form textarea:hover {
border-color: color-mix(in srgb, var(--color-accent) 45%, var(--color-border) 55%);
border-color: color-mix(
in srgb,
var(--color-accent) 45%,
var(--color-border) 55%
);
}
.dump-form input:focus,
@@ -147,8 +150,13 @@
.auth-form input:focus,
.auth-form textarea:focus {
border-color: var(--color-accent);
background-color: color-mix(in srgb, var(--color-accent) 4%, var(--color-bg) 96%);
box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 18%, transparent);
background-color: color-mix(
in srgb,
var(--color-accent) 4%,
var(--color-bg) 96%
);
box-shadow: 0 0 0 3px
color-mix(in srgb, var(--color-accent) 18%, transparent);
}
/* ── New dump form ── */
@@ -212,7 +220,7 @@
.dump-mode-toggle button.active {
background: var(--color-accent);
color: #fff;
color: var(--color-on-accent);
}
.dump-mode-toggle button:not(.active):hover {
@@ -309,7 +317,7 @@
border-radius: 0;
border: none;
background: linear-gradient(transparent, rgba(0, 0, 0, 0.38));
color: #fff;
color: var(--color-on-accent);
opacity: 0;
pointer-events: none;
transition: opacity 0.25s ease;
@@ -320,14 +328,13 @@
pointer-events: auto;
}
.video-player-controls .audio-player-time {
color: #fff;
color: var(--color-on-accent);
opacity: 0.85;
}
.video-player-controls .audio-player-vol-btn {
color: #fff;
color: var(--color-on-accent);
}
.video-player-controls .audio-player-track {
@@ -350,7 +357,11 @@
flex-wrap: nowrap;
gap: 0.6rem;
padding: 0.75rem 1rem;
background: color-mix(in srgb, var(--color-accent) 8%, var(--color-surface) 92%);
background: color-mix(
in srgb,
var(--color-accent) 8%,
var(--color-surface) 92%
);
border-radius: 0 0 12px 12px;
border: 2px solid var(--color-border);
width: 100%;
@@ -366,7 +377,7 @@
border-radius: 50%;
border: none;
background: var(--color-accent);
color: #fff;
color: var(--color-on-accent);
cursor: pointer;
display: grid;
place-items: center;
@@ -398,7 +409,11 @@
min-width: 48px;
height: 4px;
border-radius: 2px;
background: color-mix(in srgb, var(--color-accent) 20%, var(--color-border) 80%);
background: color-mix(
in srgb,
var(--color-accent) 20%,
var(--color-border) 80%
);
}
.audio-player-track--volume {
@@ -480,7 +495,7 @@
.file-download-link:hover {
background: var(--color-accent);
color: #fff;
color: var(--color-on-accent);
}
.dump-file-notice {
@@ -489,7 +504,6 @@
opacity: 0.8;
}
.rich-content-card {
display: flex;
border: 2px solid var(--color-border);
@@ -505,33 +519,33 @@
}
.rich-content-card--youtube {
border-color: #c00;
border-color: var(--color-youtube);
}
.rich-content-card--youtube:hover {
border-color: #f00;
border-color: var(--color-youtube-hover);
}
.rich-content-card--youtube .rich-content-badge {
background: #c00;
background: var(--color-youtube);
}
.rich-content-card--bandcamp {
border-color: #1da0c3;
border-color: var(--color-bandcamp);
}
.rich-content-card--bandcamp:hover {
border-color: #25c8f0;
border-color: var(--color-bandcamp-hover);
}
.rich-content-card--bandcamp .rich-content-badge {
background: #1da0c3;
background: var(--color-bandcamp);
}
.rich-content-card--soundcloud {
border-color: #f50;
border-color: var(--color-soundcloud);
}
.rich-content-card--soundcloud:hover {
border-color: #f73;
border-color: var(--color-soundcloud-hover);
}
.rich-content-card--soundcloud .rich-content-badge {
background: #f50;
background: var(--color-soundcloud);
}
.rich-content-thumbnail {
@@ -552,8 +566,8 @@
.rich-content-badge {
display: inline-block;
background: #c00;
color: #fff;
background: var(--color-youtube);
color: var(--color-on-accent);
font-size: 0.7rem;
font-weight: 700;
letter-spacing: 0.04em;
@@ -588,7 +602,6 @@
display: block;
}
.dump-card--fading {
opacity: 0.28;
}
@@ -648,7 +661,7 @@
justify-content: center;
border-radius: 50%;
background: var(--color-accent);
color: #fff;
color: var(--color-on-accent);
font-weight: 700;
user-select: none;
flex-shrink: 0;
@@ -682,13 +695,13 @@
.vote-btn--active {
border-color: var(--color-accent);
background: var(--color-accent);
color: #fff;
color: var(--color-on-accent);
}
.vote-btn--active:hover:not(:disabled) {
background: var(--color-accent-hover);
border-color: var(--color-accent-hover);
color: #fff;
color: var(--color-on-accent);
}
.vote-btn:focus {
@@ -696,7 +709,8 @@
}
.vote-btn:focus-visible {
box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 35%, transparent);
box-shadow: 0 0 0 3px
color-mix(in srgb, var(--color-accent) 35%, transparent);
}
.vote-btn:disabled {
@@ -704,7 +718,6 @@
cursor: default;
}
/* Dump OP line */
.dump-op {
display: flex;
@@ -734,8 +747,8 @@
position: absolute;
inset: 0;
border-radius: 50%;
background: rgba(0, 0, 0, 0.45);
color: #fff;
background: var(--color-overlay);
color: var(--color-on-accent);
font-size: 1.1rem;
display: flex;
align-items: center;
@@ -813,6 +826,26 @@
font-weight: 600;
}
.profile-header .logout-btn {
margin-top: 0.5rem;
}
.logout-btn {
padding: 0.3rem 0.9rem;
border: 1.5px solid var(--color-border);
border-radius: 6px;
background: transparent;
color: var(--color-text-muted);
font-size: 0.85rem;
cursor: pointer;
transition: border-color 0.15s, color 0.15s;
}
.logout-btn:hover {
border-color: var(--color-danger);
color: var(--color-danger);
}
.avatar-upload-label {
display: inline-block;
padding: 0.4rem 1rem;
@@ -827,16 +860,15 @@
.avatar-upload-label:hover {
background: var(--color-accent);
color: #fff;
color: var(--color-on-accent);
}
.form-error {
color: #e55;
color: var(--color-danger);
margin: 0;
font-size: 0.9rem;
}
/* ── Shared layout ── */
.page-shell {
min-height: 100vh;
@@ -874,9 +906,15 @@
padding: 2rem 0;
}
.page-error-actions {
display: flex;
align-items: center;
gap: 1rem;
}
.error-banner {
background: #a02b2b;
color: #fff;
background: var(--color-danger-bg);
color: var(--color-on-accent);
padding: 0.6rem 1rem;
border-radius: 8px;
font-size: 0.9rem;
@@ -884,9 +922,6 @@
/* ── Shared header ── */
.app-header {
position: sticky;
top: 0;
z-index: 10;
display: flex;
align-items: center;
gap: 1rem;
@@ -896,6 +931,45 @@
border-bottom: 2px solid var(--color-border);
}
/* ── Floating "+ New" button ── */
.fab-new {
position: fixed;
bottom: 2rem;
right: max(1.5rem, calc((100vw - 860px) / 2 + 1.5rem));
z-index: 20;
background: var(--color-accent);
color: var(--color-on-accent);
border: none;
border-radius: 999px;
padding: 0.6rem 1.4rem;
font-size: 0.95rem;
font-weight: 700;
cursor: pointer;
box-shadow: 0 4px 20px
color-mix(in srgb, var(--color-accent) 50%, transparent);
opacity: 0;
pointer-events: none;
transform: translateY(10px) scale(0.94);
transition:
opacity 0.2s ease,
transform 0.2s ease,
background 0.15s,
box-shadow 0.15s;
}
.fab-new--visible {
opacity: 1;
pointer-events: auto;
transform: none;
}
.fab-new:hover {
background: var(--color-accent-hover);
box-shadow: 0 6px 24px
color-mix(in srgb, var(--color-accent) 60%, transparent);
transform: translateY(-1px);
}
@media (min-width: 740px) {
.app-header--has-center {
display: grid;
@@ -920,7 +994,9 @@
}
@media (min-width: 740px) {
.app-header-center { display: flex; }
.app-header-center {
display: flex;
}
}
.header-center-slot {
@@ -951,12 +1027,12 @@
font-size: 0.95rem;
padding: 0.35rem 0.85rem;
border-radius: 8px;
background: rgba(0, 0, 0, 0.2);
background: var(--color-header-user-bg);
transition: background 0.15s;
}
.app-header-user:hover {
background: rgba(0, 0, 0, 0.32);
background: var(--color-header-user-bg-hover);
}
/* ── Auth card ── */
@@ -988,8 +1064,14 @@
/* ── Form pages (DumpCreate / DumpEdit) ── */
@keyframes page-enter {
from { opacity: 0; transform: translateY(10px); }
to { opacity: 1; transform: none; }
from {
opacity: 0;
transform: translateY(10px);
}
to {
opacity: 1;
transform: none;
}
}
.form-page {
@@ -1004,9 +1086,15 @@
.form-page--two-col {
grid-template-columns: 1fr 1fr;
}
.form-page--two-col .form-page-header { grid-column: 1 / -1; }
.form-page--two-col .dump-edit-preview { border-radius: 0 0 0 12px; }
.form-page--two-col .dump-form { border-radius: 0 0 12px 0; }
.form-page--two-col .form-page-header {
grid-column: 1 / -1;
}
.form-page--two-col .dump-edit-preview {
border-radius: 0 0 0 12px;
}
.form-page--two-col .dump-form {
border-radius: 0 0 12px 0;
}
}
.form-page-header {
@@ -1055,7 +1143,7 @@
align-items: center;
justify-content: space-between;
padding-top: 0.75rem;
border-top: 1px solid rgba(128, 128, 128, 0.18);
border-top: 1px solid var(--color-border-subtle);
margin-top: 0.5rem;
gap: 0.75rem;
}
@@ -1081,15 +1169,15 @@
/* ── Delete button ── */
.btn-danger {
background: #a02b2b;
color: #fff;
background: var(--color-danger-bg);
color: var(--color-on-accent);
border-color: transparent;
font-size: 0.85rem;
padding: 0.4em 0.9em;
}
.btn-danger:hover {
background: #c03030;
background: var(--color-danger-hover);
border-color: transparent;
}
@@ -1115,20 +1203,22 @@
.btn-primary {
background: var(--color-accent);
color: #fff;
color: var(--color-on-accent);
font-weight: 700;
font-size: 0.95rem;
padding: 0.45rem 1.1rem;
border: none;
border-radius: 8px;
cursor: pointer;
box-shadow: 0 2px 8px color-mix(in srgb, var(--color-accent) 40%, transparent);
box-shadow: 0 2px 8px
color-mix(in srgb, var(--color-accent) 40%, transparent);
transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
}
.btn-primary:hover {
background: var(--color-accent-hover);
box-shadow: 0 4px 14px color-mix(in srgb, var(--color-accent) 50%, transparent);
box-shadow: 0 4px 14px
color-mix(in srgb, var(--color-accent) 50%, transparent);
transform: translateY(-1px);
}
@@ -1162,7 +1252,6 @@
z-index: 2;
}
.index-status {
text-align: center;
opacity: 0.6;
@@ -1170,7 +1259,7 @@
}
.index-status--error {
color: #e55;
color: var(--color-danger);
opacity: 1;
}
@@ -1185,7 +1274,9 @@
}
@media (min-width: 740px) {
.index-below-header { display: none; }
.index-below-header {
display: none;
}
}
/* ── Feed sort buttons (shared between header center and below-header) ── */
@@ -1216,7 +1307,7 @@
.feed-sort-btn.active {
border-color: var(--color-accent);
background: var(--color-accent);
color: #fff;
color: var(--color-on-accent);
}
/* ── Dump feed ── */
@@ -1239,7 +1330,10 @@
border: 2px solid var(--color-border);
border-radius: 10px;
background: var(--color-surface);
transition: border-color 0.15s, grid-template-rows 0.32s ease, opacity 0.25s ease;
transition:
border-color 0.15s,
grid-template-rows 0.32s ease,
opacity 0.25s ease;
min-width: 0;
}
@@ -1299,7 +1393,6 @@
line-height: 1.35;
}
.dump-card-inner:hover .dump-card-title {
color: var(--color-accent);
}