fa7f98ac52
Adds the spec the recent visual-identity port pass referenced: - design-system.md — base16-eighties palette, type scale, spacing scale, motion budget, component library, accessibility notes (color-blind toggle, high-contrast mode, glyph differentiation), and the canonical "Terminal" card-back theme. - 24 Stitch-rendered mockups (HTML + PNG): 12 redesigned existing screens, 1 desktop home variant, 2 onboarding steps, and 9 missing-plugin screens (splash, challenge, time-attack, weekly-goals, leaderboard, sync, level-up, replay, radial-menu). These mockups are the source the engine plugins were ported against in commits0d477acthrough9891ae4(token system, modal scaffold, gameplay-feedback layer, toasts, table chrome, card chrome, splash cursor, hint highlight). Future plugin work should diff against the matching mockup before touching pixels. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
343 lines
16 KiB
HTML
343 lines
16 KiB
HTML
<!DOCTYPE html>
|
|
|
|
<html class="dark" lang="en"><head>
|
|
<meta charset="utf-8"/>
|
|
<meta content="width=device-width, initial-scale=1.0" name="viewport"/>
|
|
<title>RS_TERMINAL_OS - Rusty Solitaire</title>
|
|
<script src="https://cdn.tailwindcss.com?plugins=forms,container-queries"></script>
|
|
<link href="https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700;800&family=Inter:wght@400;500&family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap" rel="stylesheet"/>
|
|
<link href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap" rel="stylesheet"/>
|
|
<style>
|
|
.material-symbols-outlined {
|
|
font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
|
|
font-size: 18px;
|
|
}
|
|
body {
|
|
background-color: #151515;
|
|
color: #d0d0d0;
|
|
font-family: 'JetBrains Mono', monospace;
|
|
overflow: hidden;
|
|
}
|
|
.scanline {
|
|
width: 100%;
|
|
height: 2px;
|
|
background: rgba(26, 26, 26, 0.5);
|
|
position: absolute;
|
|
pointer-events: none;
|
|
}
|
|
.custom-scrollbar::-webkit-scrollbar {
|
|
width: 4px;
|
|
}
|
|
.custom-scrollbar::-webkit-scrollbar-track {
|
|
background: #151515;
|
|
}
|
|
.custom-scrollbar::-webkit-scrollbar-thumb {
|
|
background: #353535;
|
|
}
|
|
</style>
|
|
<script id="tailwind-config">
|
|
tailwind.config = {
|
|
darkMode: "class",
|
|
theme: {
|
|
extend: {
|
|
"colors": {
|
|
"on-tertiary-container": "#683476",
|
|
"surface-dim": "#101417",
|
|
"primary-fixed": "#c4e7ff",
|
|
"on-error": "#690005",
|
|
"on-secondary-fixed": "#161e00",
|
|
"on-tertiary": "#4c195b",
|
|
"primary-fixed-dim": "#7ed0fe",
|
|
"outline-variant": "#3f484e",
|
|
"tertiary": "#f7c3ff",
|
|
"surface": "#151515",
|
|
"tertiary-container": "#e1a3ee",
|
|
"highlight-celebration": "#e1a3ee",
|
|
"background": "#101417",
|
|
"surface-container": "#202020",
|
|
"primary-container": "#6fc2ef",
|
|
"on-secondary-fixed-variant": "#3c4d00",
|
|
"on-surface": "#d0d0d0",
|
|
"inverse-on-surface": "#2d3134",
|
|
"on-error-container": "#ffdad6",
|
|
"surface-container-low": "#181c1f",
|
|
"on-tertiary-fixed": "#340043",
|
|
"on-secondary-container": "#b2c86d",
|
|
"on-background": "#e0e3e6",
|
|
"secondary-container": "#435401",
|
|
"error": "#fb9fb1",
|
|
"info": "#12cfc0",
|
|
"on-surface-variant": "#bfc8cf",
|
|
"warning": "#ddb26f",
|
|
"inverse-primary": "#00668a",
|
|
"tertiary-fixed-dim": "#f0b0fc",
|
|
"surface-tint": "#7ed0fe",
|
|
"suit-black": "#d0d0d0",
|
|
"tertiary-fixed": "#fbd7ff",
|
|
"on-secondary": "#293500",
|
|
"on-primary-fixed": "#001e2c",
|
|
"surface-container-highest": "#313538",
|
|
"error-container": "#93000a",
|
|
"surface-container-high": "#272a2d",
|
|
"on-primary-container": "#004f6c",
|
|
"inverse-surface": "#e0e3e6",
|
|
"on-primary": "#003549",
|
|
"suit-red-cb": "#6fc2ef",
|
|
"on-primary-fixed-variant": "#004c69",
|
|
"on-tertiary-fixed-variant": "#653173",
|
|
"secondary-fixed": "#d5ec8c",
|
|
"highlight-valid": "#acc267",
|
|
"surface-variant": "#313538",
|
|
"secondary": "#bad073",
|
|
"secondary-fixed-dim": "#bad073",
|
|
"outline": "#505050",
|
|
"surface-container-lowest": "#0b0f11",
|
|
"primary": "#a1dcff",
|
|
"surface-bright": "#363a3d",
|
|
"suit-red": "#fb9fb1"
|
|
},
|
|
"borderRadius": {
|
|
"DEFAULT": "0px",
|
|
"lg": "0px",
|
|
"xl": "0px",
|
|
"full": "0px"
|
|
},
|
|
"spacing": {
|
|
"stack-overlap": "2rem",
|
|
"touch-target-min": "48px",
|
|
"margin-edge": "1rem",
|
|
"gutter-card": "0.375rem",
|
|
"action-bar-height": "64px"
|
|
},
|
|
"fontFamily": {
|
|
"card-rank": ["JetBrains Mono"],
|
|
"headline": ["JetBrains Mono"],
|
|
"hud-timer": ["JetBrains Mono"],
|
|
"hud-score": ["JetBrains Mono"],
|
|
"body-md": ["Inter"],
|
|
"label-caps": ["JetBrains Mono"]
|
|
},
|
|
"fontSize": {
|
|
"card-rank": ["18px", {"lineHeight": "18px", "fontWeight": "700"}],
|
|
"headline": ["28px", {"lineHeight": "32px", "letterSpacing": "-0.01em", "fontWeight": "700"}],
|
|
"hud-timer": ["16px", {"lineHeight": "24px", "fontWeight": "400"}],
|
|
"hud-score": ["24px", {"lineHeight": "32px", "letterSpacing": "-0.02em", "fontWeight": "700"}],
|
|
"body-md": ["16px", {"lineHeight": "24px", "fontWeight": "400"}],
|
|
"label-caps": ["12px", {"lineHeight": "16px", "letterSpacing": "0.08em", "fontWeight": "500"}]
|
|
}
|
|
},
|
|
},
|
|
}
|
|
</script>
|
|
</head>
|
|
<body class="bg-surface text-on-surface h-screen flex flex-col antialiased">
|
|
<!-- TOP BAR (32px) -->
|
|
<header class="h-8 bg-surface-container border-b border-outline flex items-center justify-between px-4 z-50">
|
|
<div class="flex items-center gap-2">
|
|
<span class="text-primary-container font-bold">▌</span>
|
|
<h1 class="font-headline text-[14px] font-bold tracking-tight text-on-surface">RS_TERMINAL_OS</h1>
|
|
</div>
|
|
<nav class="flex gap-4 font-label-caps text-[12px] uppercase tracking-widest">
|
|
<span class="text-primary-container">[ HOME ]</span>
|
|
<span class="text-on-surface-variant hover:text-primary transition-colors cursor-pointer">· PLAY</span>
|
|
<span class="text-on-surface-variant hover:text-primary transition-colors cursor-pointer">· STATS</span>
|
|
<span class="text-on-surface-variant hover:text-primary transition-colors cursor-pointer">· SETTINGS</span>
|
|
</nav>
|
|
<div class="flex items-center gap-3 font-label-caps text-[11px] text-on-surface-variant">
|
|
<div class="flex items-center gap-1">
|
|
<span>LV 12</span>
|
|
<span class="text-outline">|</span>
|
|
<div class="flex items-center gap-2">
|
|
<span>XP 320/500</span>
|
|
<div class="w-[60px] h-1 bg-surface-container-highest">
|
|
<div class="h-full bg-primary-container w-[64%]"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<span class="text-outline">|</span>
|
|
<div class="flex items-center gap-1 text-info">
|
|
<span class="w-2 h-2 rounded-full bg-info"></span>
|
|
<span class="uppercase">Synced</span>
|
|
</div>
|
|
<span class="text-outline">|</span>
|
|
<span class="text-outline">v0.20.0</span>
|
|
</div>
|
|
</header>
|
|
<!-- MAIN CONTENT AREA -->
|
|
<main class="flex-1 flex overflow-hidden">
|
|
<!-- LEFT PANE (40%) -->
|
|
<section class="w-[40%] border-r border-outline flex flex-col p-8 gap-8 overflow-y-auto custom-scrollbar">
|
|
<div class="space-y-1">
|
|
<p class="text-outline font-label-caps text-xs">▌play.tsx</p>
|
|
<h2 class="font-headline text-[32px] font-bold text-on-surface leading-none uppercase">Ready to play?</h2>
|
|
<p class="text-on-surface-variant font-label-caps text-sm tracking-wide">RESUME · 12:34 ELAPSED · DRAW-3</p>
|
|
</div>
|
|
<button class="w-full h-24 bg-primary-container text-surface font-headline text-[24px] font-bold flex items-center justify-center gap-4 hover:brightness-110 active:scale-[0.98] transition-all">
|
|
<span class="material-symbols-outlined" style="font-variation-settings: 'FILL' 1;">play_arrow</span>
|
|
CONTINUE GAME
|
|
</button>
|
|
<div class="grid grid-cols-2 gap-4">
|
|
<button class="h-12 border border-outline bg-transparent text-on-surface font-label-caps text-sm hover:border-primary-container hover:text-primary-container transition-all flex items-center justify-center gap-2">
|
|
<span class="material-symbols-outlined">add</span>
|
|
NEW GAME
|
|
</button>
|
|
<button class="h-12 border border-outline bg-transparent text-on-surface font-label-caps text-sm hover:border-primary-container hover:text-primary-container transition-all flex items-center justify-center gap-2">
|
|
<span class="material-symbols-outlined">refresh</span>
|
|
RESTART RUN
|
|
</button>
|
|
</div>
|
|
<div class="space-y-4">
|
|
<p class="text-outline font-label-caps text-xs uppercase tracking-widest">Game Modes</p>
|
|
<div class="grid grid-cols-3 gap-3">
|
|
<!-- Zen -->
|
|
<div class="aspect-square border border-outline flex flex-col items-center justify-center gap-2 hover:bg-surface-container transition-colors cursor-pointer group">
|
|
<span class="material-symbols-outlined text-outline group-hover:text-primary-container">spa</span>
|
|
<span class="font-label-caps text-[10px] uppercase">Zen</span>
|
|
</div>
|
|
<!-- Time Attack -->
|
|
<div class="aspect-square border border-outline flex flex-col items-center justify-center gap-2 hover:bg-surface-container transition-colors cursor-pointer group">
|
|
<span class="material-symbols-outlined text-outline group-hover:text-primary-container">timer</span>
|
|
<span class="font-label-caps text-[10px] uppercase text-center">Time<br/>Attack</span>
|
|
</div>
|
|
<!-- Locked Challenge -->
|
|
<div class="aspect-square bg-[#0d0d0d] border border-outline/30 flex flex-col items-center justify-center gap-2 relative opacity-60">
|
|
<span class="material-symbols-outlined text-outline">lock</span>
|
|
<span class="font-label-caps text-[10px] uppercase">Challenge</span>
|
|
<div class="absolute -top-2 -right-2 bg-warning text-surface px-1 py-0.5 text-[8px] font-bold">LV 5</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- VISUAL DECORATION (IMAGE PLACEHOLDER) -->
|
|
<div class="mt-auto pt-8">
|
|
<div class="w-full h-40 border border-outline overflow-hidden">
|
|
<img class="w-full h-full object-cover opacity-40 grayscale hover:grayscale-0 transition-all duration-700" data-alt="A dark, high-contrast digital art piece showing an abstract terminal interface with glowing cyan scanlines and retro-futuristic grid patterns. The composition is geometric and minimalist, following a synthwave aesthetic with deep black backgrounds and crisp cyan light elements. The lighting is moody and artificial, suggesting a high-performance computer screen in a dimly lit server room. Professional, sharp-edged UI design style." src="https://lh3.googleusercontent.com/aida-public/AB6AXuAet8SrRWSacZfwd8ISRQdDC7CDGixBwRnPAVMmMcjbifq1jnHSzCGWgSSL6YPSRfCkLNWr91BxTzV4zigGjMBLlk7rCLo5I7X7F6ydinDrKJVqZkRbvHJeSo90BPANoQwZtzPvhKXVEA9C2DbBaj8KPR4ObCo24Mj25NXPvGNThOE-3BSpuU6MPC-hrUMPVCPJpZnJdI_OmSz8mT021vjTxFERN12S1PFOzXKmNUDleoTDIat-8UifyKmKg4eKilecrBW6sFqaBw"/>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
<!-- CENTER PANE (30%) -->
|
|
<section class="w-[30%] border-r border-outline flex flex-col p-8 gap-8 overflow-y-auto custom-scrollbar">
|
|
<div class="space-y-1">
|
|
<p class="text-outline font-label-caps text-xs">▌daily.json</p>
|
|
<div class="flex items-center justify-between">
|
|
<h3 class="font-headline text-[18px] font-bold text-on-surface">MAY 07 · 2026</h3>
|
|
<span class="bg-warning/20 text-warning px-2 py-1 text-[10px] font-bold border border-warning/40">EXPIRES 11:42:30</span>
|
|
</div>
|
|
</div>
|
|
<div class="bg-surface-container p-6 border border-outline space-y-4">
|
|
<div class="space-y-1">
|
|
<p class="text-on-surface-variant font-label-caps text-[10px] uppercase tracking-tighter">Current Seed</p>
|
|
<p class="font-headline text-[24px] font-extrabold text-highlight-valid">#2024-127</p>
|
|
</div>
|
|
<button class="w-full py-3 bg-primary-container text-surface font-label-caps text-xs font-bold uppercase tracking-widest hover:brightness-110 active:scale-95 transition-all">
|
|
▶ Attempt Today
|
|
</button>
|
|
</div>
|
|
<div class="space-y-3">
|
|
<p class="text-outline font-label-caps text-xs uppercase tracking-widest">Global Standings</p>
|
|
<div class="space-y-1 text-xs font-label-caps">
|
|
<div class="flex justify-between py-2 border-b border-outline/30 text-highlight-valid">
|
|
<span>01 │ swift_jaguar</span>
|
|
<span>02:47</span>
|
|
</div>
|
|
<div class="flex justify-between py-2 border-b border-outline/30 text-on-surface-variant">
|
|
<span>02 │ pixel_drifter</span>
|
|
<span>03:12</span>
|
|
</div>
|
|
<div class="flex justify-between py-2 border-b border-outline/30 text-on-surface-variant">
|
|
<span>03 │ null_ptr</span>
|
|
<span>03:15</span>
|
|
</div>
|
|
<div class="flex justify-between py-2 border-b border-outline/30 text-on-surface-variant">
|
|
<span>04 │ core_dump_88</span>
|
|
<span>03:44</span>
|
|
</div>
|
|
<div class="flex justify-between py-2 text-primary-container bg-primary-container/10 px-2 -mx-2">
|
|
<span>12 │ YOU (anon)</span>
|
|
<span>--:--</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
<!-- RIGHT PANE (30%) -->
|
|
<section class="w-[30%] flex flex-col p-8 gap-8 overflow-y-auto custom-scrollbar">
|
|
<div class="space-y-1">
|
|
<p class="text-outline font-label-caps text-xs">▌stats.log</p>
|
|
</div>
|
|
<div class="grid grid-cols-2 gap-4">
|
|
<div class="border border-outline p-4 space-y-1">
|
|
<p class="text-on-surface-variant text-[10px] uppercase">Games</p>
|
|
<p class="font-hud-score text-[28px] text-on-surface">247</p>
|
|
</div>
|
|
<div class="border border-outline p-4 space-y-1 text-highlight-valid">
|
|
<p class="text-on-surface-variant text-[10px] uppercase">Win Rate</p>
|
|
<p class="font-hud-score text-[28px]">61%</p>
|
|
</div>
|
|
<div class="border border-outline p-4 space-y-1">
|
|
<p class="text-on-surface-variant text-[10px] uppercase">Best Time</p>
|
|
<p class="font-hud-score text-[28px]">01:54</p>
|
|
</div>
|
|
<div class="border border-outline p-4 space-y-1 text-primary-container">
|
|
<p class="text-on-surface-variant text-[10px] uppercase">Streak</p>
|
|
<p class="font-hud-score text-[28px]">7</p>
|
|
</div>
|
|
</div>
|
|
<div class="space-y-3">
|
|
<p class="text-outline font-label-caps text-xs uppercase tracking-widest">Achievements (8/19)</p>
|
|
<div class="flex flex-wrap gap-2">
|
|
<!-- Filled Cyan Dots -->
|
|
<div class="w-3 h-3 bg-primary-container"></div>
|
|
<div class="w-3 h-3 bg-primary-container"></div>
|
|
<div class="w-3 h-3 bg-primary-container"></div>
|
|
<div class="w-3 h-3 bg-primary-container"></div>
|
|
<div class="w-3 h-3 bg-primary-container"></div>
|
|
<div class="w-3 h-3 bg-primary-container"></div>
|
|
<div class="w-3 h-3 bg-primary-container"></div>
|
|
<div class="w-3 h-3 bg-primary-container"></div>
|
|
<!-- Empty Dots -->
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
<div class="w-3 h-3 border border-outline"></div>
|
|
</div>
|
|
</div>
|
|
<div class="mt-auto border border-outline bg-surface-container p-4 flex items-center justify-between hover:border-primary-container transition-colors cursor-pointer group">
|
|
<div class="flex items-center gap-3">
|
|
<div class="w-10 h-10 bg-primary-container text-surface flex items-center justify-center font-bold text-lg">RS</div>
|
|
<div class="space-y-0.5">
|
|
<p class="text-on-surface font-bold text-xs">anonymous@local</p>
|
|
<p class="text-on-surface-variant text-[10px]">Session: Active</p>
|
|
</div>
|
|
</div>
|
|
<span class="material-symbols-outlined text-primary-container group-hover:translate-x-1 transition-transform">arrow_forward</span>
|
|
</div>
|
|
</section>
|
|
</main>
|
|
<!-- BOTTOM BAR (24px) -->
|
|
<footer class="h-6 bg-surface-container border-t border-outline flex items-center justify-between px-4 text-[10px] font-label-caps">
|
|
<div class="flex items-center gap-2">
|
|
<span class="text-primary-container">▌ NORMAL</span>
|
|
<span class="text-outline">│</span>
|
|
<span class="text-on-surface-variant">~/rusty-solitaire/home</span>
|
|
</div>
|
|
<div class="flex items-center gap-4 text-on-surface-variant">
|
|
<div class="flex items-center gap-1"><span class="text-primary-container">[SPACE]</span> play</div>
|
|
<div class="flex items-center gap-1"><span class="text-primary-container">[D]</span> daily</div>
|
|
<div class="flex items-center gap-1"><span class="text-primary-container">[S]</span> settings</div>
|
|
<div class="flex items-center gap-1"><span class="text-primary-container">[?]</span> help</div>
|
|
</div>
|
|
<div class="text-outline">
|
|
2026-05-07 17:42 EDT
|
|
</div>
|
|
</footer>
|
|
<!-- GLOBAL SCANLINE EFFECT -->
|
|
<div class="fixed inset-0 pointer-events-none z-[100] overflow-hidden opacity-10">
|
|
<div class="absolute inset-0" style="background: repeating-linear-gradient(0deg, #151515, #151515 2px, #202020 4px);"></div>
|
|
</div>
|
|
</body></html> |