Refined themes

This commit is contained in:
2026-06-07 01:49:30 +02:00
parent b0664dd562
commit b465233f71
3 changed files with 410 additions and 236 deletions
+102 -72
View File
@@ -1,108 +1,128 @@
/* ============================================================
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.
The original DS firmware menu: pale grid "graph paper"
backdrop, white tiles with thick rounded charcoal borders,
glossy cyan selection, and calendar pastels (red Sunday,
blue Saturday).
============================================================ */
[data-theme="nds"] {
--d-cyan: #1ba1c4;
--d-cyan-lt: #7fd6ec;
--d-silver: #c9d2d8;
--d-silver-dk: #9aa6ae;
--d-ink: #2b3a42;
--d-cyan-lt: #8fdcef;
--d-cyan-dk: #1685a3;
--d-ink: #3a4750;
--d-line: #4a565e; /* thick tile border */
--d-paper: #eef1f3; /* grid backdrop */
--d-grid: #dbe1e5; /* grid lines */
--d-red: #d4506a; /* Sunday */
--d-blue: #3f7fd0; /* Saturday */
font-family: "Trebuchet MS", "Segoe UI", Tahoma, sans-serif;
font-size: 14px;
color: var(--d-ink);
}
/* pale graph-paper background like the DS menu canvas */
[data-theme="nds"] body {
background: linear-gradient(160deg, #aeb9c0 0%, #7e8b93 100%) fixed;
background-color: var(--d-paper);
background-image: linear-gradient(var(--d-grid) 1px, transparent 1px),
linear-gradient(90deg, var(--d-grid) 1px, transparent 1px);
background-size: 22px 22px;
background-attachment: fixed;
}
/* the window is the silver shell; content is the touch screen */
/* the window is the menu canvas */
[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);
background: transparent;
border: none;
border-radius: 0;
padding: 8px;
box-shadow: none;
}
/* top status strip: User name, clock, date, battery */
[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;
height: 34px;
padding: 0 14px;
border-radius: 12px;
background: linear-gradient(180deg, #fbfdfe, #e6ecef);
border: 2px solid var(--d-line);
color: var(--d-ink);
font-weight: bold;
letter-spacing: 0.5px;
text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
letter-spacing: 0.3px;
text-shadow: none;
}
[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);
width: 16px;
height: 12px;
border-radius: 2px;
background: linear-gradient(180deg, #b7f0a0, #7fc964);
box-shadow: inset 0 0 0 1.5px var(--d-line);
}
[data-theme="nds"] .rb-titlebar-buttons {
display: none;
}
/* menubar = white rounded tile holding the chunky touch buttons */
[data-theme="nds"] .rb-menubar {
padding: 8px 10px;
background: linear-gradient(180deg, #eef3f5, var(--d-silver));
margin-top: 8px;
padding: 10px 12px;
border-radius: 14px;
background: #ffffff;
border: 2px solid var(--d-line);
}
[data-theme="nds"] .rb-menu-link {
text-decoration: none;
padding: 5px 14px;
border-radius: 16px;
padding: 6px 16px;
border-radius: 18px;
color: var(--d-ink);
font-weight: bold;
background: linear-gradient(180deg, #ffffff, #dde5e9);
border: 1px solid var(--d-silver-dk);
transition: all 0.15s;
background: linear-gradient(180deg, #ffffff, #e3ebef);
border: 2px solid var(--d-line);
transition: all 0.12s;
}
[data-theme="nds"] .rb-menu-link:hover {
background: linear-gradient(180deg, #2fb6d8, var(--d-cyan));
background: linear-gradient(180deg, #6fd0e8, var(--d-cyan));
color: #fff;
border-color: var(--d-cyan);
border-color: var(--d-cyan-dk);
text-shadow: 0 1px 1px rgba(0, 0, 0, 0.25);
}
[data-theme="nds"] .rb-switcher-label {
font-weight: bold;
font-size: 12px;
color: var(--d-cyan);
color: var(--d-cyan-dk);
}
[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;
border: 2px solid var(--d-line);
border-radius: 16px;
padding: 4px 12px;
background: #fff;
color: var(--d-ink);
}
/* the lower touch screen */
/* the main content = big white touch-screen tile */
[data-theme="nds"] .rb-content {
background: #f7fbfc;
margin: 6px 2px;
background: #ffffff;
margin: 8px 0;
padding: 22px 24px;
border-radius: 10px;
border: 3px solid #2b3a42;
box-shadow: inset 0 0 18px rgba(27, 161, 196, 0.12);
border-radius: 16px;
border: 2px solid var(--d-line);
box-shadow: inset 0 0 0 4px #f3f7f9;
}
[data-theme="nds"] .rb-statusbar {
padding: 5px 12px;
padding: 6px 12px;
font-size: 11px;
color: #5a6a72;
color: #71808a;
}
/* bottom strip = rounded tile dock holding the launch buttons */
[data-theme="nds"] .rb-taskbar {
height: 38px;
background: linear-gradient(180deg, #b9c4cb, #8e9aa2);
border-top: 1px solid #fff;
height: 40px;
margin-top: 8px;
border-radius: 14px;
background: linear-gradient(180deg, #fbfdfe, #e6ecef);
border: 2px solid var(--d-line);
}
[data-theme="nds"] .rb-start {
display: flex;
@@ -110,13 +130,13 @@
gap: 7px;
height: 28px;
padding: 0 16px;
border: 1px solid var(--d-silver-dk);
border: 2px solid var(--d-cyan-dk);
border-radius: 16px;
background: linear-gradient(180deg, #2fb6d8, var(--d-cyan));
background: linear-gradient(180deg, #6fd0e8, 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);
text-shadow: 0 1px 1px rgba(0, 0, 0, 0.25);
}
[data-theme="nds"] .rb-start-logo {
width: 13px;
@@ -130,17 +150,18 @@
gap: 7px;
height: 28px;
padding: 0 14px;
border: 1px solid var(--d-silver-dk);
border: 2px solid var(--d-line);
border-radius: 16px;
background: linear-gradient(180deg, #ffffff, #dde5e9);
background: linear-gradient(180deg, #ffffff, #e3ebef);
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));
background: linear-gradient(180deg, #6fd0e8, var(--d-cyan));
color: #fff;
border-color: var(--d-cyan-dk);
}
[data-theme="nds"] .rb-task-icon {
width: 11px;
@@ -159,44 +180,48 @@
margin: 0 0 4px;
font-size: 26px;
font-weight: bold;
color: var(--d-cyan);
color: var(--d-cyan-dk);
}
[data-theme="nds"] .rb-page-sub {
margin: 0 0 18px;
color: #5a6a72;
color: #71808a;
}
/* post cards = white menu tiles with the signature thick border */
[data-theme="nds"] .rb-post-card {
border: 1px solid var(--d-silver-dk);
border-radius: 12px;
border: 2px solid var(--d-line);
border-radius: 14px;
padding: 16px 18px;
background: linear-gradient(180deg, #ffffff, #eef4f6);
transition: box-shadow 0.2s, transform 0.2s;
background: #ffffff;
box-shadow: inset 0 0 0 3px #f3f7f9;
transition: box-shadow 0.18s, transform 0.18s;
}
[data-theme="nds"] .rb-post-card:hover {
box-shadow: 0 5px 16px rgba(27, 161, 196, 0.25);
box-shadow: inset 0 0 0 3px #e0f3f9, 0 5px 16px rgba(27, 161, 196, 0.28);
transform: translateY(-2px);
border-color: var(--d-cyan-dk);
}
[data-theme="nds"] .rb-post-card-title a {
color: var(--d-cyan);
color: var(--d-cyan-dk);
text-decoration: none;
font-weight: bold;
}
[data-theme="nds"] .rb-post-date {
font-size: 12px;
color: #8a98a0;
color: #93a0a8;
}
[data-theme="nds"] .rb-tag {
font-size: 11px;
background: #e4f4f9;
border: 1px solid var(--d-cyan-lt);
border: 1.5px solid var(--d-cyan-lt);
border-radius: 12px;
padding: 1px 9px;
color: var(--d-cyan);
color: var(--d-cyan-dk);
font-weight: bold;
}
[data-theme="nds"] .rb-readmore,
[data-theme="nds"] .rb-back {
color: var(--d-cyan);
color: var(--d-cyan-dk);
text-decoration: none;
font-weight: bold;
font-size: 13px;
@@ -206,7 +231,7 @@
margin-bottom: 12px;
}
[data-theme="nds"] .rb-article-title {
color: var(--d-cyan);
color: var(--d-cyan-dk);
font-weight: bold;
margin: 0 0 8px;
}
@@ -214,7 +239,7 @@
line-height: 1.7;
}
[data-theme="nds"] .rb-prose a {
color: var(--d-cyan);
color: var(--d-cyan-dk);
}
[data-theme="nds"] .rb-prose code {
background: #e4f4f9;
@@ -228,5 +253,10 @@
margin: 12px 0;
padding: 6px 14px;
background: #eef7fa;
border-radius: 0 8px 8px 0;
border-radius: 0 10px 10px 0;
}
[data-theme="nds"] .rb-prose h1,
[data-theme="nds"] .rb-prose h2,
[data-theme="nds"] .rb-prose h3 {
color: var(--d-cyan-dk);
}