Migrate design system from ethereal/cool to warm/craft/guild theme

Replace ghost/whisper/sparkle color palettes with guild/candlelight/parchment/ember/earth tokens.
Switch typography from NB Television Pro to Quietism serif. Update all 25 Vue components,
layouts, and pages to new design system. Add circle color tokens, typography scale, prose-guild
class, and warm texture effects. Clean up stale documentation files.
This commit is contained in:
Jennie Robinson Faber 2026-02-24 20:01:11 +00:00
parent d588c49946
commit a62e167876
39 changed files with 1300 additions and 2087 deletions

View file

@ -1,2 +1,43 @@
/* Font declarations are now handled by @nuxt/fonts module */
/* See nuxt.config.ts for font configuration */
/*
* Font declarations for Ghost Guild
*
* Quietism: Display/heading font (serif)
* Place woff2 files in public/fonts/
* Expected files: Quietism-Regular.woff2, Quietism-Medium.woff2,
* Quietism-Bold.woff2, Quietism-Italic.woff2
*
* Inter and Ubuntu Mono are loaded via @nuxt/fonts module.
* See nuxt.config.ts for configuration.
*/
@font-face {
font-family: "Quietism";
src: url("/fonts/Quietism-Regular.woff2") format("woff2");
font-weight: 400;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: "Quietism";
src: url("/fonts/Quietism-Medium.woff2") format("woff2");
font-weight: 500;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: "Quietism";
src: url("/fonts/Quietism-Bold.woff2") format("woff2");
font-weight: 700;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: "Quietism";
src: url("/fonts/Quietism-Italic.woff2") format("woff2");
font-weight: 400;
font-style: italic;
font-display: swap;
}

View file

@ -1,3 +1,43 @@
/*
* Ghost Guild Design System
* ========================
*
* Token naming convention:
* --color-{palette}-{shade} Color palettes (50-950 scale)
* --color-circle-{name}-{variant} Circle-specific tokens
* --font-{role} Font family tokens
* --text-{scale} Typographic scale
* --leading-{role} Line heights
* --tracking-{role} Letter spacing
*
* Palettes:
* guild-* Warm neutral ground (dark hall / workshop)
* candlelight-* Primary warm accent (amber/gold/ochre)
* parchment-* Light content surfaces (cream/vellum)
* ember-* Secondary warm accent (deeper amber/rust)
* earth-* Tertiary muted tones (brown/ochre)
*
* Usage guidelines:
* Backgrounds: guild-900/950 (dark), parchment-50/100 (light surfaces)
* Text primary: guild-100 (dark mode), guild-900 (light mode)
* Text secondary: guild-300/400
* Borders: guild-700 (dark), guild-300 (light)
* Accents: candlelight-* for links, highlights, interactive
* Surfaces: parchment-* for readable content areas
*
* Effect classes:
* .ink-grain Subtle noise overlay (mix-blend-mode: overlay)
* .paper-texture Paper fiber overlay
* .woodcut-border Irregular line border via border-image
* .candlelight-glow Warm box-shadow (replaces .ethereal-glow)
* .warm-text Warm text-shadow (replaces .ethereal-text)
* .guild-stamp Circular decorative double-border frame
* .halftone-texture Dot pattern overlay (updated for warm palette)
* .dithered-bg Cross-hatch dither pattern
* .dithered-warm Amber-tinted dither variant
* .prose-guild Wiki/long-form content styling
*/
@import "./fonts.css";
@import "tailwindcss";
@import "@nuxt/ui";
@ -9,132 +49,229 @@
--font-sans: "Inter", sans-serif;
--font-body: "Inter", sans-serif;
--font-mono: "Ubuntu Mono", monospace;
--font-display: "NB Television Pro", monospace;
--font-display: "Quietism", serif;
--font-serif: "Quietism", serif;
/* Ethereal color palette - light mode (inverted for light backgrounds) */
--color-ghost-50: #0a0a0a;
--color-ghost-100: #1a1a1a;
--color-ghost-200: #2a2a2a;
--color-ghost-300: #3a3a3a;
--color-ghost-400: #4a4a4a;
--color-ghost-500: #6a6a6a;
--color-ghost-600: #8a8a8a;
--color-ghost-700: #b0b0b0;
--color-ghost-800: #d0d0d0;
--color-ghost-900: #f0f0f0;
/* Guild - warm neutral ground (light mode: dark values for text on light bg) */
--color-guild-50: #1a1510;
--color-guild-100: #2a241c;
--color-guild-200: #3a332a;
--color-guild-300: #524939;
--color-guild-400: #6b5f4d;
--color-guild-500: #8a7c68;
--color-guild-600: #a49585;
--color-guild-700: #bfb3a2;
--color-guild-800: #d9d0c3;
--color-guild-900: #f0ebe4;
--color-guild-950: #f8f5f0;
/* Subtle accent - barely visible blue-gray (light mode) */
--color-whisper-50: #0f1419;
--color-whisper-100: #1a1f2e;
--color-whisper-200: #252d40;
--color-whisper-300: #2f3b52;
--color-whisper-400: #3a4964;
--color-whisper-500: #4f5d7a;
--color-whisper-600: #687291;
--color-whisper-700: #8491a8;
--color-whisper-800: #a8b3c7;
--color-whisper-900: #d4dae6;
/* Candlelight - primary warm accent (amber/gold/ochre) */
--color-candlelight-50: #1f1708;
--color-candlelight-100: #3d2c0f;
--color-candlelight-200: #5c4118;
--color-candlelight-300: #7b5822;
--color-candlelight-400: #9a6f2c;
--color-candlelight-500: #b8873a;
--color-candlelight-600: #d09e4e;
--color-candlelight-700: #e0b86e;
--color-candlelight-800: #ecd09a;
--color-candlelight-900: #f5e6c5;
--color-candlelight-950: #faf2e0;
/* Sparkle accent (light mode) */
--color-sparkle-50: #202020;
--color-sparkle-100: #404040;
--color-sparkle-200: #606060;
--color-sparkle-300: #808080;
--color-sparkle-400: #a0a0a0;
--color-sparkle-500: #c0c0c0;
--color-sparkle-600: #d0d0d0;
--color-sparkle-700: #e8e8e8;
--color-sparkle-800: #f0f0f0;
--color-sparkle-900: #fafafa;
/* Parchment - light content surfaces (cream/vellum) */
--color-parchment-50: #1d1a14;
--color-parchment-100: #332e24;
--color-parchment-200: #4a4234;
--color-parchment-300: #635844;
--color-parchment-400: #7d6e56;
--color-parchment-500: #97866c;
--color-parchment-600: #afa088;
--color-parchment-700: #c8baa5;
--color-parchment-800: #ddd3c3;
--color-parchment-900: #f0ebe0;
--color-parchment-950: #f9f6f0;
/* Ember - secondary warm accent (deeper amber/rust) */
--color-ember-50: #1e120b;
--color-ember-100: #3b2215;
--color-ember-200: #58321f;
--color-ember-300: #76432a;
--color-ember-400: #945535;
--color-ember-500: #b26840;
--color-ember-600: #c87e55;
--color-ember-700: #da9a72;
--color-ember-800: #e8b899;
--color-ember-900: #f3d6c0;
--color-ember-950: #f9ebe0;
/* Earth - tertiary muted tones (brown/ochre) */
--color-earth-50: #17140e;
--color-earth-100: #2d271c;
--color-earth-200: #433a2a;
--color-earth-300: #5a4d39;
--color-earth-400: #726148;
--color-earth-500: #8a7658;
--color-earth-600: #a08c6d;
--color-earth-700: #b7a487;
--color-earth-800: #cebda4;
--color-earth-900: #e5d7c2;
--color-earth-950: #f2ece1;
}
.dark {
/* Ethereal color palette - dark mode (original values) */
--color-ghost-50: #f0f0f0;
--color-ghost-100: #d0d0d0;
--color-ghost-200: #b0b0b0;
--color-ghost-300: #8a8a8a;
--color-ghost-400: #6a6a6a;
--color-ghost-500: #4a4a4a;
--color-ghost-600: #3a3a3a;
--color-ghost-700: #2a2a2a;
--color-ghost-800: #1a1a1a;
--color-ghost-900: #0a0a0a;
/* Guild - warm neutral (dark mode: light values) */
--color-guild-50: #f0ebe4;
--color-guild-100: #d9d0c3;
--color-guild-200: #bfb3a2;
--color-guild-300: #a49585;
--color-guild-400: #8a7c68;
--color-guild-500: #6b5f4d;
--color-guild-600: #524939;
--color-guild-700: #3a332a;
--color-guild-800: #2a241c;
--color-guild-900: #1a1510;
--color-guild-950: #110e0a;
/* Subtle accent - barely visible blue-gray (dark mode) */
--color-whisper-50: #d4dae6;
--color-whisper-100: #a8b3c7;
--color-whisper-200: #8491a8;
--color-whisper-300: #687291;
--color-whisper-400: #4f5d7a;
--color-whisper-500: #3a4964;
--color-whisper-600: #2f3b52;
--color-whisper-700: #252d40;
--color-whisper-800: #1a1f2e;
--color-whisper-900: #0f1419;
/* Candlelight - primary warm accent (dark mode) */
--color-candlelight-50: #faf2e0;
--color-candlelight-100: #f5e6c5;
--color-candlelight-200: #ecd09a;
--color-candlelight-300: #e0b86e;
--color-candlelight-400: #d09e4e;
--color-candlelight-500: #b8873a;
--color-candlelight-600: #9a6f2c;
--color-candlelight-700: #7b5822;
--color-candlelight-800: #5c4118;
--color-candlelight-900: #3d2c0f;
--color-candlelight-950: #1f1708;
/* Sparkle accent (dark mode) */
--color-sparkle-50: #fafafa;
--color-sparkle-100: #f0f0f0;
--color-sparkle-200: #e8e8e8;
--color-sparkle-300: #d0d0d0;
--color-sparkle-400: #c0c0c0;
--color-sparkle-500: #a0a0a0;
--color-sparkle-600: #808080;
--color-sparkle-700: #606060;
--color-sparkle-800: #404040;
--color-sparkle-900: #202020;
/* Parchment - light content surfaces (dark mode) */
--color-parchment-50: #f9f6f0;
--color-parchment-100: #f0ebe0;
--color-parchment-200: #ddd3c3;
--color-parchment-300: #c8baa5;
--color-parchment-400: #afa088;
--color-parchment-500: #97866c;
--color-parchment-600: #7d6e56;
--color-parchment-700: #635844;
--color-parchment-800: #4a4234;
--color-parchment-900: #332e24;
--color-parchment-950: #1d1a14;
/* Ember - secondary warm accent (dark mode) */
--color-ember-50: #f9ebe0;
--color-ember-100: #f3d6c0;
--color-ember-200: #e8b899;
--color-ember-300: #da9a72;
--color-ember-400: #c87e55;
--color-ember-500: #b26840;
--color-ember-600: #945535;
--color-ember-700: #76432a;
--color-ember-800: #58321f;
--color-ember-900: #3b2215;
--color-ember-950: #1e120b;
/* Earth - tertiary muted tones (dark mode) */
--color-earth-50: #f2ece1;
--color-earth-100: #e5d7c2;
--color-earth-200: #cebda4;
--color-earth-300: #b7a487;
--color-earth-400: #a08c6d;
--color-earth-500: #8a7658;
--color-earth-600: #726148;
--color-earth-700: #5a4d39;
--color-earth-800: #433a2a;
--color-earth-900: #2d271c;
--color-earth-950: #17140e;
}
/* Global ethereal background - light mode */
/* Circle-specific tokens */
:root {
--ethereal-bg:
/* Community - warm hearth amber */
--color-circle-community: #b8873a;
--color-circle-community-light: #e0b86e;
--color-circle-community-dark: #7b5822;
--color-circle-community-bg: rgba(184, 135, 58, 0.1);
/* Founder - forge copper/orange */
--color-circle-founder: #b26840;
--color-circle-founder-light: #da9a72;
--color-circle-founder-dark: #76432a;
--color-circle-founder-bg: rgba(178, 104, 64, 0.1);
/* Practitioner - deep gold/ochre */
--color-circle-practitioner: #8a7658;
--color-circle-practitioner-light: #b7a487;
--color-circle-practitioner-dark: #5a4d39;
--color-circle-practitioner-bg: rgba(138, 118, 88, 0.1);
/* Typographic scale */
--text-display-xl: 3.5rem;
--text-display-lg: 2.5rem;
--text-display: 2rem;
--text-display-sm: 1.5rem;
--text-body-lg: 1.125rem;
--text-body: 1rem;
--text-body-sm: 0.875rem;
--text-caption: 0.75rem;
--text-overline: 0.6875rem;
/* Line heights */
--leading-display: 1.15;
--leading-body: 1.65;
/* Letter spacing */
--tracking-display: -0.02em;
--tracking-wide: 0.05em;
/* Ambient background - warm radial gradients */
--ambient-bg:
radial-gradient(
circle at 20% 80%,
rgba(40, 40, 40, 0.03) 0%,
rgba(184, 135, 58, 0.03) 0%,
transparent 50%
),
radial-gradient(
circle at 80% 20%,
rgba(40, 40, 40, 0.02) 0%,
rgba(178, 104, 64, 0.02) 0%,
transparent 50%
),
radial-gradient(
circle at 40% 40%,
rgba(40, 40, 40, 0.01) 0%,
rgba(138, 118, 88, 0.01) 0%,
transparent 50%
);
--halftone-pattern: radial-gradient(
circle,
rgba(0, 0, 0, 0.1) 1px,
rgba(42, 36, 28, 0.1) 1px,
transparent 1px
);
--halftone-size: 8px 8px;
}
/* Dark mode background */
/* Dark mode */
.dark:root {
--ethereal-bg:
--ambient-bg:
radial-gradient(
circle at 20% 80%,
rgba(232, 232, 232, 0.03) 0%,
rgba(224, 184, 110, 0.03) 0%,
transparent 50%
),
radial-gradient(
circle at 80% 20%,
rgba(232, 232, 232, 0.02) 0%,
rgba(218, 154, 114, 0.02) 0%,
transparent 50%
),
radial-gradient(
circle at 40% 40%,
rgba(232, 232, 232, 0.01) 0%,
rgba(183, 164, 135, 0.01) 0%,
transparent 50%
);
--halftone-pattern: radial-gradient(
circle,
rgba(255, 255, 255, 0.1) 1px,
rgba(240, 235, 228, 0.1) 1px,
transparent 1px
);
}
@ -144,12 +281,41 @@ html {
}
body {
background: var(--ethereal-bg), #f0f0f0;
background: var(--ambient-bg), #f0ebe4;
background-attachment: fixed;
}
.dark body {
background: var(--ethereal-bg), #0a0a0a;
background: var(--ambient-bg), #1a1510;
}
/* Display typography utilities */
.text-display-xl {
font-family: var(--font-display);
font-size: var(--text-display-xl);
line-height: var(--leading-display);
letter-spacing: var(--tracking-display);
}
.text-display-lg {
font-family: var(--font-display);
font-size: var(--text-display-lg);
line-height: var(--leading-display);
letter-spacing: var(--tracking-display);
}
.text-display {
font-family: var(--font-display);
font-size: var(--text-display);
line-height: var(--leading-display);
letter-spacing: var(--tracking-display);
}
.text-display-sm {
font-family: var(--font-display);
font-size: var(--text-display-sm);
line-height: var(--leading-display);
letter-spacing: var(--tracking-display);
}
/* Halftone texture overlay */
@ -170,106 +336,93 @@ body {
pointer-events: none;
}
/* Sparkle effects */
@keyframes sparkle {
0%,
100% {
opacity: 0.3;
transform: scale(0.8);
}
50% {
opacity: 1;
transform: scale(1.2);
}
/* Craft/Material Effects */
/* Warm box-shadow (replaces .ethereal-glow) */
.candlelight-glow {
box-shadow:
0 0 20px rgba(184, 135, 58, 0.12),
0 0 40px rgba(184, 135, 58, 0.06),
inset 0 1px 0 rgba(240, 235, 228, 0.08);
}
@keyframes twinkle {
0%,
100% {
opacity: 0.2;
}
25% {
opacity: 0.8;
}
75% {
opacity: 0.4;
}
/* Warm text-shadow (replaces .ethereal-text) */
.warm-text {
text-shadow: 0 0 10px rgba(224, 184, 110, 0.25);
}
.sparkle-field {
/* Subtle noise overlay */
.ink-grain {
position: relative;
overflow: hidden;
}
.sparkle-field::after {
.ink-grain::before {
content: "";
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-image:
radial-gradient(
circle at 10% 20%,
var(--color-sparkle-200) 1px,
transparent 1px
),
radial-gradient(
circle at 90% 80%,
var(--color-sparkle-400) 1px,
transparent 1px
),
radial-gradient(
circle at 30% 70%,
var(--color-sparkle-200) 0.5px,
transparent 0.5px
),
radial-gradient(
circle at 70% 30%,
var(--color-sparkle-400) 0.5px,
transparent 0.5px
),
radial-gradient(
circle at 50% 10%,
var(--color-sparkle-200) 1px,
transparent 1px
),
radial-gradient(
circle at 20% 90%,
var(--color-sparkle-400) 0.5px,
transparent 0.5px
);
background-size:
200px 200px,
300px 300px,
150px 150px,
250px 250px,
180px 180px,
220px 220px;
animation: twinkle 4s infinite ease-in-out;
background-image: url("/textures/grain.png");
background-repeat: repeat;
background-size: 128px 128px;
mix-blend-mode: overlay;
opacity: 0.04;
pointer-events: none;
opacity: 0.6;
}
/* Ethereal glow effects */
.ethereal-glow {
box-shadow:
0 0 20px rgba(232, 232, 232, 0.1),
0 0 40px rgba(232, 232, 232, 0.05),
inset 0 1px 0 rgba(255, 255, 255, 0.1);
/* Paper fiber overlay */
.paper-texture {
position: relative;
}
.ethereal-text {
text-shadow: 0 0 10px rgba(232, 232, 232, 0.3);
.paper-texture::before {
content: "";
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-image: url("/textures/paper.png");
background-repeat: repeat;
background-size: 256px 256px;
opacity: 0.04;
pointer-events: none;
}
/* Irregular line border */
.woodcut-border {
border-image: repeating-linear-gradient(
90deg,
var(--color-guild-700) 0px,
var(--color-guild-600) 2px,
var(--color-guild-700) 3px,
transparent 3px,
transparent 6px
) 4;
}
/* Circular decorative frame */
.guild-stamp {
border: 2px solid var(--color-candlelight-600);
outline: 2px solid var(--color-candlelight-700);
outline-offset: 3px;
border-radius: 50%;
}
/* Warm interior feel for content areas */
.guild-interior {
background: var(--ambient-bg);
box-shadow: inset 0 2px 8px rgba(26, 21, 16, 0.06);
}
/* Dithered gradients */
.dithered-bg {
background:
linear-gradient(45deg, var(--color-ghost-800) 25%, transparent 25%),
linear-gradient(-45deg, var(--color-ghost-800) 25%, transparent 25%),
linear-gradient(45deg, transparent 75%, var(--color-ghost-700) 75%),
linear-gradient(-45deg, transparent 75%, var(--color-ghost-700) 75%);
linear-gradient(45deg, var(--color-guild-800) 25%, transparent 25%),
linear-gradient(-45deg, var(--color-guild-800) 25%, transparent 25%),
linear-gradient(45deg, transparent 75%, var(--color-guild-700) 75%),
linear-gradient(-45deg, transparent 75%, var(--color-guild-700) 75%);
background-size: 4px 4px;
background-position:
0 0,
@ -278,6 +431,58 @@ body {
-2px 0px;
}
/* Amber-tinted dither variant */
.dithered-warm {
background:
linear-gradient(45deg, var(--color-candlelight-800) 25%, transparent 25%),
linear-gradient(-45deg, var(--color-candlelight-800) 25%, transparent 25%),
linear-gradient(45deg, transparent 75%, var(--color-candlelight-700) 75%),
linear-gradient(-45deg, transparent 75%, var(--color-candlelight-700) 75%);
background-size: 4px 4px;
background-position:
0 0,
0 2px,
2px -2px,
-2px 0px;
}
/* Prose overrides for guild wiki/long-form content */
.prose-guild {
max-width: 72ch;
}
.prose-guild h1,
.prose-guild h2,
.prose-guild h3,
.prose-guild h4 {
font-family: var(--font-display);
letter-spacing: var(--tracking-display);
}
.prose-guild a {
color: var(--color-candlelight-600);
text-decoration-color: var(--color-candlelight-700);
text-underline-offset: 3px;
}
.prose-guild a:hover {
color: var(--color-candlelight-500);
text-decoration-color: var(--color-candlelight-500);
}
.prose-guild blockquote {
background-color: var(--color-parchment-900);
border-left-color: var(--color-candlelight-600);
border-left-width: 3px;
padding: 1rem 1.5rem;
border-radius: 0 0.5rem 0.5rem 0;
}
.dark .prose-guild blockquote {
background-color: var(--color-parchment-900);
border-left-color: var(--color-candlelight-500);
}
/* Mobile responsive utilities */
@media (max-width: 1023px) {
/* Prevent horizontal scroll on mobile */