Files
dashcaddy/status/css/themes.css
Sami f1b0ac43d0 fix: Taxi theme accent color now distinct from text
Accent was #0e0e00 (same as --fg), making buttons and interactive
elements invisible. Changed to #7a4a00/#5c3800 dark amber.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-25 22:19:00 -07:00

479 lines
12 KiB
CSS

/*
* DashCaddy Theme Definitions
* ============================
*
* To add a new theme:
* 1. Add a :root.mytheme { ... } block below with all the color variables
* 2. Add 'mytheme' to the THEMES array in js/theme.js
* 3. (Optional) Add per-theme body background and button hover overrides
*
* Variables reference:
* --bg Page background color
* --fg Primary text color
* --muted Secondary/dimmed text
* --fg-muted Very secondary text (lighter than --muted)
* --card-base Card background color
* --card-bg Alias for card-base (used in inline styles)
* --border Border color for cards, buttons, inputs
* --hover Hover background for interactive elements
* --card-hover Card hover background
* --base Subdued background for tags/badges
* --ok-bg/fg Success state background/text (e.g. "ON" badges)
* --bad-bg/fg Error state background/text (e.g. "OFF" badges)
* --dot-ok/bad Status dot colors (green/red indicators)
* --success Green for success states (buttons, labels)
* --error Red for error states
* --warning Orange for warning states
* --accent Brand accent (links, highlights, hover states)
* --accent-strong Stronger accent variant (active states)
*/
/* ===== Dark (default) ===== */
:root {
--accent: #8FD6FF;
--accent-strong: #1F7BFF;
--bg: #0b0f1a;
--fg: #e8ecf5;
--muted: #9aa6bf;
--fg-muted: #6b7a94;
--card-base: #121826;
--card-bg: #121826;
--border: #263552;
--hover: #1a2235;
--card-hover: #161e2e;
--base: #151c2b;
--ok-bg: #0c2430;
--ok-fg: #7ef2ff;
--bad-bg: #2a121a;
--bad-fg: #ff9aa3;
--dot-ok: #35d1ff;
--dot-bad: #ff5f7a;
--uptime: #35d1ff;
--success: #4caf50;
--error: #e74c3c;
--warning: #f39c12;
--brand-min: 100px;
--brand-max: 320px;
--brand-h: clamp(var(--brand-min), 22vw, var(--brand-max));
--radius: 12px;
}
/* ===== Light ===== */
:root.light {
--bg: #f6f7fb;
--fg: #0f1115;
--muted: #5f6b7a;
--fg-muted: #8993a4;
--card-base: #ffffff;
--card-bg: #ffffff;
--border: #e2e7ef;
--hover: #eef1f6;
--card-hover: #f5f6fa;
--base: #ebeef3;
--ok-bg: #eafff1;
--ok-fg: #0a7c3a;
--bad-bg: #ffefef;
--bad-fg: #b00020;
--dot-ok: #0fb15a;
--dot-bad: #d93b3b;
--uptime: #0fb15a;
--success: #0a7c3a;
--error: #b00020;
--warning: #d68a00;
--accent: #4a90d9;
--accent-strong: #2563eb;
}
/* ===== Blue (deep royal) ===== */
:root.blue {
--bg: #1908AC;
--fg: #e8f1ff;
--muted: #d6e2ff;
--fg-muted: #9eafdb;
--card-base: #0d1533;
--card-bg: #0d1533;
--border: #1c2d6a;
--hover: #141f4a;
--card-hover: #111a3e;
--base: #0f1840;
--ok-bg: rgba(255, 255, 255, .14);
--ok-fg: #edffff;
--bad-bg: rgba(0, 0, 0, .18);
--bad-fg: #ffb3c0;
--dot-ok: #c7e5ff;
--dot-bad: #ffd6dc;
--uptime: #7ec8ff;
--success: #7ec8ff;
--error: #ffb3c0;
--warning: #ffd080;
--accent: #9cd4ff;
--accent-strong: #6fb2ff;
}
/* ===== Black (black / white / red accent) ===== */
:root.black {
--bg: #0e0e0e;
--fg: #f5f5f5;
--muted: #999999;
--fg-muted: #666666;
--card-base: #1a1a1a;
--card-bg: #1a1a1a;
--border: #2e2e2e;
--hover: #242424;
--card-hover: #202020;
--base: #161616;
--ok-bg: #0f2a12;
--ok-fg: #66ff7a;
--bad-bg: #2a0f0f;
--bad-fg: #ff6b6b;
--dot-ok: #4caf50;
--dot-bad: #ff4444;
--uptime: #e0e0e0;
--success: #4caf50;
--error: #ff4444;
--warning: #ff9800;
--accent: #E63946;
--accent-strong: #C62828;
}
/* ===== Nord ===== */
:root.nord {
--bg: #2e3440;
--fg: #eceff4;
--muted: #81a1c1;
--fg-muted: #6882a0;
--card-base: #3b4252;
--card-bg: #3b4252;
--border: #4c566a;
--hover: #434c5e;
--card-hover: #3f4858;
--base: #353c4a;
--ok-bg: #2d4f3e;
--ok-fg: #a3be8c;
--bad-bg: #4a2c2a;
--bad-fg: #bf616a;
--dot-ok: #a3be8c;
--dot-bad: #bf616a;
--uptime: #a3be8c;
--success: #a3be8c;
--error: #bf616a;
--warning: #ebcb8b;
--accent: #88c0d0;
--accent-strong: #5e81ac;
}
/* ===== Dracula ===== */
:root.dracula {
--bg: #282a36;
--fg: #f8f8f2;
--muted: #6272a4;
--fg-muted: #515d85;
--card-base: #44475a;
--card-bg: #44475a;
--border: #6272a4;
--hover: #4e5170;
--card-hover: #494c63;
--base: #363848;
--ok-bg: #1e3a2e;
--ok-fg: #50fa7b;
--bad-bg: #3d1a1a;
--bad-fg: #ff5555;
--dot-ok: #50fa7b;
--dot-bad: #ff5555;
--uptime: #50fa7b;
--success: #50fa7b;
--error: #ff5555;
--warning: #f1fa8c;
--accent: #bd93f9;
--accent-strong: #8be9fd;
}
/* ===== Solarized Dark ===== */
:root.solarized-dark {
--bg: #002b36;
--fg: #839496;
--muted: #586e75;
--fg-muted: #4a5f65;
--card-base: #073642;
--card-bg: #073642;
--border: #586e75;
--hover: #0d4050;
--card-hover: #0a3a48;
--base: #053340;
--ok-bg: #0d3d2c;
--ok-fg: #859900;
--bad-bg: #3d1a1a;
--bad-fg: #dc322f;
--dot-ok: #859900;
--dot-bad: #dc322f;
--uptime: #b5bd68;
--success: #859900;
--error: #dc322f;
--warning: #b58900;
--accent: #268bd2;
--accent-strong: #2aa198;
}
/* ===== Solarized Light ===== */
:root.solarized-light {
--bg: #fdf6e3;
--fg: #657b83;
--muted: #93a1a1;
--fg-muted: #adb8b8;
--card-base: #eee8d5;
--card-bg: #eee8d5;
--border: #93a1a1;
--hover: #e6dfcb;
--card-hover: #eae3cf;
--base: #e8e1cd;
--ok-bg: #e8f5e8;
--ok-fg: #859900;
--bad-bg: #fdf2f2;
--bad-fg: #dc322f;
--dot-ok: #859900;
--dot-bad: #dc322f;
--uptime: #859900;
--success: #859900;
--error: #dc322f;
--warning: #b58900;
--accent: #268bd2;
--accent-strong: #2aa198;
}
/* ===== Taxi (black & yellow) ===== */
:root.taxi {
--bg: #f3d321;
--fg: #0e0e00;
--muted: #4a4a10;
--fg-muted: #6b6b30;
--card-base: #ffd700;
--card-bg: #ffd700;
--border: #b8a840;
--hover: #ffe84d;
--card-hover: #ffe033;
--base: #f0d000;
--ok-bg: #d4ffd9;
--ok-fg: #0f2a0f;
--bad-bg: #ffd4d4;
--bad-fg: #2a0f0f;
--dot-ok: #4caf50;
--dot-bad: #ff4444;
--uptime: #0e0e00;
--success: #2e7d32;
--error: #c62828;
--warning: #e65100;
--accent: #7a4a00;
--accent-strong: #5c3800;
}
/* ===== Ocean ===== */
:root.ocean {
--bg: #2060b0;
--fg: #faf5eb;
--muted: #dcd2c0;
--fg-muted: #b0a890;
--card-base: #7a94ed;
--card-bg: #7a94ed;
--border: #deb67a;
--hover: #8aa0f0;
--card-hover: #8298e8;
--base: #6888e0;
--ok-bg: #4f5bb0;
--ok-fg: #c7d7eb;
--bad-bg: #f41a3a;
--bad-fg: #6a1818;
--dot-ok: #30a050;
--dot-bad: #d04040;
--uptime: #2d32f2;
--success: #30a050;
--error: #d04040;
--warning: #e6a030;
--accent: #1860a0;
--accent-strong: #104080;
}
/* ===== Theme transitions ===== */
:root {
transition:
--bg 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--fg 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--muted 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--fg-muted 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--card-base 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--border 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--hover 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--card-hover 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--base 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--ok-bg 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--ok-fg 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--bad-bg 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--bad-fg 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--dot-ok 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--dot-bad 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--uptime 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--success 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--error 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--warning 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--accent 0.3s cubic-bezier(0.4, 0, 0.2, 1),
--accent-strong 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
body, .card, button, .badge, .logo-wrap, .weather-modal-content {
transition:
background 0.3s cubic-bezier(0.4, 0, 0.2, 1),
background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1),
color 0.3s cubic-bezier(0.4, 0, 0.2, 1),
border-color 0.3s cubic-bezier(0.4, 0, 0.2, 1),
box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
/* ===== Per-theme body backgrounds ===== */
:root.light body {
background:
radial-gradient(1200px 800px at 10% -10%, rgba(90, 120, 255, .1), transparent 60%),
radial-gradient(1000px 700px at 110% 10%, rgba(255, 120, 200, .08), transparent 55%),
var(--bg);
}
:root.blue body {
background:
radial-gradient(1200px 820px at 8% -10%, rgba(255, 255, 255, 0.06), transparent 60%),
radial-gradient(1000px 700px at 110% 0%, rgba(0, 0, 0, 0.12), transparent 55%),
radial-gradient(900px 650px at 50% 120%, rgba(15, 0, 60, 0.12), transparent 60%),
#1908AC;
}
:root.black body {
background:
radial-gradient(1200px 820px at 8% -10%, rgba(230, 57, 70, .06), transparent 60%),
radial-gradient(1000px 700px at 110% 0%, rgba(198, 40, 40, .04), transparent 55%),
radial-gradient(900px 650px at 50% 120%, rgba(230, 57, 70, .03), transparent 60%),
#0e0e0e;
}
:root.nord body {
background:
radial-gradient(1200px 900px at 8% -12%, rgba(136, 192, 208, .12), transparent 60%),
radial-gradient(1000px 700px at 110% -10%, rgba(94, 129, 172, .10), transparent 55%),
var(--bg);
}
:root.dracula body {
background:
radial-gradient(1200px 900px at 8% -12%, rgba(189, 147, 249, .10), transparent 60%),
radial-gradient(1000px 700px at 110% -10%, rgba(139, 233, 253, .08), transparent 55%),
var(--bg);
}
:root.solarized-dark body {
background:
radial-gradient(1200px 900px at 8% -12%, rgba(38, 139, 210, .10), transparent 60%),
radial-gradient(1000px 700px at 110% -10%, rgba(42, 161, 152, .08), transparent 55%),
var(--bg);
}
:root.solarized-light body {
background:
radial-gradient(1200px 800px at 10% -10%, rgba(38, 139, 210, .08), transparent 60%),
radial-gradient(1000px 700px at 110% 10%, rgba(42, 161, 152, .06), transparent 55%),
var(--bg);
}
:root.taxi body {
background:
radial-gradient(1200px 800px at 10% -10%, rgba(14, 14, 0, .08), transparent 60%),
radial-gradient(1000px 700px at 110% 10%, rgba(184, 168, 64, .12), transparent 55%),
var(--bg);
}
:root.ocean body {
background:
radial-gradient(1200px 900px at 8% -12%, rgba(122, 148, 237, .18), transparent 60%),
radial-gradient(1000px 700px at 110% -10%, rgba(222, 182, 122, .10), transparent 55%),
radial-gradient(900px 650px at 50% 120%, rgba(16, 64, 128, .15), transparent 60%),
var(--bg);
}
/* ===== Per-theme button hover overrides ===== */
:root.light button:hover {
background: color-mix(in srgb, var(--accent-strong) 12%, white 88%);
border-color: rgba(0, 0, 0, .15);
box-shadow: 0 1px 6px rgba(0, 0, 0, .08), inset 0 1px 0 rgba(255, 255, 255, .8);
}
:root.blue button:hover {
background: color-mix(in srgb, var(--accent) 24%, transparent);
border-color: rgba(255, 255, 255, .35);
box-shadow: 0 0 6px rgba(255, 255, 255, .22), inset 0 1px 0 rgba(255, 255, 255, .18);
}
:root.black button:hover {
background: color-mix(in srgb, var(--accent) 18%, transparent);
border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
}
:root.nord button:hover {
background: color-mix(in srgb, var(--accent) 18%, transparent);
border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
}
:root.dracula button:hover {
background: color-mix(in srgb, var(--accent) 20%, transparent);
border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
}
:root.solarized-dark button:hover {
background: color-mix(in srgb, var(--accent) 18%, transparent);
border-color: color-mix(in srgb, var(--accent) 30%, var(--border));
}
:root.solarized-light button:hover {
background: color-mix(in srgb, var(--accent-strong) 12%, white 88%);
border-color: rgba(0, 0, 0, .12);
box-shadow: 0 1px 6px rgba(0, 0, 0, .06);
}
:root.taxi button:hover {
background: color-mix(in srgb, var(--accent-strong) 15%, var(--card-base) 85%);
border-color: rgba(0, 0, 0, .2);
box-shadow: 0 1px 6px rgba(0, 0, 0, .1);
}
:root.ocean button:hover {
background: color-mix(in srgb, var(--accent) 22%, transparent);
border-color: color-mix(in srgb, var(--border) 60%, white 40%);
box-shadow: 0 0 6px rgba(255, 255, 255, .12);
}