feat: add 6 more skins (PS1, PS3, Wii, NDS, Dreamcast, JV2002)

Brings the catalog to nine. Each is a single scoped [data-theme="..."]
CSS file plus a registry entry — no markup changes.

- ps1: charcoal BIOS, gray panels, uppercase letterspacing
- ps3: animated XMB sky gradient + drifting wave, black glass
- wii: white channels, rounded pills, soft blue glow
- nds: silver shell with content framed as the touch screen
- dreamcast: cream BIOS, conic-gradient orange swirl, lowercase blue
- jv2002: dense boxy portal, Verdana 11px, red masthead, blue nav tabs

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
2026-06-07 00:49:52 +02:00
parent 37ba9b3e19
commit 91244a5a2b
32 changed files with 3093 additions and 29 deletions
+232
View File
@@ -0,0 +1,232 @@
/* ============================================================
Theme: Nintendo DS — scoped to [data-theme="nds"]
The DS firmware menu: brushed silver shell, glossy cyan
gradients, dual-screen bezel framing, chunky rounded touch
targets.
============================================================ */
[data-theme="nds"] {
--d-cyan: #1ba1c4;
--d-cyan-lt: #7fd6ec;
--d-silver: #c9d2d8;
--d-silver-dk: #9aa6ae;
--d-ink: #2b3a42;
font-family: "Trebuchet MS", "Segoe UI", Tahoma, sans-serif;
font-size: 14px;
color: var(--d-ink);
}
[data-theme="nds"] body {
background: linear-gradient(160deg, #aeb9c0 0%, #7e8b93 100%) fixed;
}
/* the window is the silver shell; content is the touch screen */
[data-theme="nds"] .rb-window {
background: linear-gradient(180deg, #e7edf0, var(--d-silver));
border: 1px solid #fff;
border-radius: 14px;
padding: 6px;
box-shadow: 0 12px 34px rgba(0, 0, 0, 0.4),
inset 0 0 0 1px var(--d-silver-dk);
}
[data-theme="nds"] .rb-titlebar {
height: 38px;
padding: 0 16px;
border-radius: 10px 10px 0 0;
background: linear-gradient(180deg, #2fb6d8, var(--d-cyan));
color: #fff;
font-weight: bold;
letter-spacing: 0.5px;
text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
}
[data-theme="nds"] .rb-titlebar-icon {
width: 15px;
height: 15px;
border-radius: 4px;
background: linear-gradient(180deg, #fff, var(--d-cyan-lt));
box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.15);
}
[data-theme="nds"] .rb-titlebar-buttons {
display: none;
}
[data-theme="nds"] .rb-menubar {
padding: 8px 10px;
background: linear-gradient(180deg, #eef3f5, var(--d-silver));
}
[data-theme="nds"] .rb-menu-link {
text-decoration: none;
padding: 5px 14px;
border-radius: 16px;
color: var(--d-ink);
font-weight: bold;
background: linear-gradient(180deg, #ffffff, #dde5e9);
border: 1px solid var(--d-silver-dk);
transition: all 0.15s;
}
[data-theme="nds"] .rb-menu-link:hover {
background: linear-gradient(180deg, #2fb6d8, var(--d-cyan));
color: #fff;
border-color: var(--d-cyan);
}
[data-theme="nds"] .rb-switcher-label {
font-weight: bold;
font-size: 12px;
color: var(--d-cyan);
}
[data-theme="nds"] .rb-switcher-select {
font: 13px "Trebuchet MS", sans-serif;
border: 1px solid var(--d-silver-dk);
border-radius: 14px;
padding: 4px 10px;
background: #fff;
}
/* the lower touch screen */
[data-theme="nds"] .rb-content {
background: #f7fbfc;
margin: 6px 2px;
padding: 22px 24px;
border-radius: 10px;
border: 3px solid #2b3a42;
box-shadow: inset 0 0 18px rgba(27, 161, 196, 0.12);
}
[data-theme="nds"] .rb-statusbar {
padding: 5px 12px;
font-size: 11px;
color: #5a6a72;
}
[data-theme="nds"] .rb-taskbar {
height: 38px;
background: linear-gradient(180deg, #b9c4cb, #8e9aa2);
border-top: 1px solid #fff;
}
[data-theme="nds"] .rb-start {
display: flex;
align-items: center;
gap: 7px;
height: 28px;
padding: 0 16px;
border: 1px solid var(--d-silver-dk);
border-radius: 16px;
background: linear-gradient(180deg, #2fb6d8, var(--d-cyan));
color: #fff;
font: bold 13px "Trebuchet MS", sans-serif;
cursor: pointer;
text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
}
[data-theme="nds"] .rb-start-logo {
width: 13px;
height: 13px;
border-radius: 4px;
background: linear-gradient(180deg, #fff, var(--d-cyan-lt));
}
[data-theme="nds"] .rb-task {
display: flex;
align-items: center;
gap: 7px;
height: 28px;
padding: 0 14px;
border: 1px solid var(--d-silver-dk);
border-radius: 16px;
background: linear-gradient(180deg, #ffffff, #dde5e9);
color: var(--d-ink);
font-weight: bold;
font-size: 13px;
cursor: default;
}
[data-theme="nds"] .rb-task-active {
background: linear-gradient(180deg, #2fb6d8, var(--d-cyan));
color: #fff;
}
[data-theme="nds"] .rb-task-icon {
width: 11px;
height: 11px;
border-radius: 3px;
background: var(--d-cyan-lt);
}
[data-theme="nds"] .rb-clock {
color: var(--d-ink);
font-weight: bold;
font-size: 13px;
padding: 0 14px;
}
[data-theme="nds"] .rb-page-title {
margin: 0 0 4px;
font-size: 26px;
font-weight: bold;
color: var(--d-cyan);
}
[data-theme="nds"] .rb-page-sub {
margin: 0 0 18px;
color: #5a6a72;
}
[data-theme="nds"] .rb-post-card {
border: 1px solid var(--d-silver-dk);
border-radius: 12px;
padding: 16px 18px;
background: linear-gradient(180deg, #ffffff, #eef4f6);
transition: box-shadow 0.2s, transform 0.2s;
}
[data-theme="nds"] .rb-post-card:hover {
box-shadow: 0 5px 16px rgba(27, 161, 196, 0.25);
transform: translateY(-2px);
}
[data-theme="nds"] .rb-post-card-title a {
color: var(--d-cyan);
text-decoration: none;
font-weight: bold;
}
[data-theme="nds"] .rb-post-date {
font-size: 12px;
color: #8a98a0;
}
[data-theme="nds"] .rb-tag {
font-size: 11px;
background: #e4f4f9;
border: 1px solid var(--d-cyan-lt);
border-radius: 12px;
padding: 1px 9px;
color: var(--d-cyan);
font-weight: bold;
}
[data-theme="nds"] .rb-readmore,
[data-theme="nds"] .rb-back {
color: var(--d-cyan);
text-decoration: none;
font-weight: bold;
font-size: 13px;
}
[data-theme="nds"] .rb-back {
display: inline-block;
margin-bottom: 12px;
}
[data-theme="nds"] .rb-article-title {
color: var(--d-cyan);
font-weight: bold;
margin: 0 0 8px;
}
[data-theme="nds"] .rb-prose {
line-height: 1.7;
}
[data-theme="nds"] .rb-prose a {
color: var(--d-cyan);
}
[data-theme="nds"] .rb-prose code {
background: #e4f4f9;
border: 1px solid var(--d-cyan-lt);
border-radius: 6px;
padding: 0 5px;
font-family: "Courier New", monospace;
}
[data-theme="nds"] .rb-prose blockquote {
border-left: 4px solid var(--d-cyan);
margin: 12px 0;
padding: 6px 14px;
background: #eef7fa;
border-radius: 0 8px 8px 0;
}