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>
259 lines
14 KiB
HTML
259 lines
14 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>ROOT@SOLITAIRE:~ | LEVEL UP</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&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;
|
|
}
|
|
.scanline-overlay {
|
|
background: linear-gradient(rgba(18, 16, 16, 0) 50%, rgba(0, 0, 0, 0.25) 50%), linear-gradient(90deg, rgba(255, 0, 0, 0.06), rgba(0, 255, 0, 0.02), rgba(0, 0, 255, 0.06));
|
|
background-size: 100% 2px, 3px 100%;
|
|
pointer-events: none;
|
|
}
|
|
.card-glow {
|
|
box-shadow: 0 0 24px rgba(225, 163, 238, 0.25);
|
|
}
|
|
</style>
|
|
<script id="tailwind-config">
|
|
tailwind.config = {
|
|
darkMode: "class",
|
|
theme: {
|
|
extend: {
|
|
"colors": {
|
|
"tertiary-fixed": "#fbd7ff",
|
|
"secondary-container": "#435401",
|
|
"on-tertiary-fixed": "#340043",
|
|
"inverse-surface": "#e0e3e6",
|
|
"tertiary-container": "#e1a3ee",
|
|
"background": "#101417",
|
|
"on-primary": "#003549",
|
|
"info": "#12cfc0",
|
|
"surface-container-highest": "#313538",
|
|
"secondary-fixed": "#d5ec8c",
|
|
"secondary-fixed-dim": "#bad073",
|
|
"on-surface-variant": "#bfc8cf",
|
|
"on-secondary": "#293500",
|
|
"on-tertiary-fixed-variant": "#653173",
|
|
"surface-container-low": "#181c1f",
|
|
"surface-container-high": "#272a2d",
|
|
"secondary": "#bad073",
|
|
"outline-variant": "#3f484e",
|
|
"on-surface": "#e0e3e6",
|
|
"surface-tint": "#7ed0fe",
|
|
"on-tertiary": "#4c195b",
|
|
"on-secondary-fixed": "#161e00",
|
|
"primary-fixed": "#c4e7ff",
|
|
"on-tertiary-container": "#683476",
|
|
"on-secondary-container": "#b2c86d",
|
|
"surface-container-lowest": "#0b0f11",
|
|
"inverse-primary": "#00668a",
|
|
"primary-container": "#6fc2ef",
|
|
"surface-container": "#1c2023",
|
|
"on-background": "#e0e3e6",
|
|
"suit-red-cb": "#6fc2ef",
|
|
"surface-dim": "#101417",
|
|
"on-primary-fixed-variant": "#004c69",
|
|
"tertiary": "#f7c3ff",
|
|
"on-secondary-fixed-variant": "#3c4d00",
|
|
"highlight-celebration": "#e1a3ee",
|
|
"on-primary-fixed": "#001e2c",
|
|
"primary-fixed-dim": "#7ed0fe",
|
|
"tertiary-fixed-dim": "#f0b0fc",
|
|
"inverse-on-surface": "#2d3134",
|
|
"error": "#fb9fb1",
|
|
"error-container": "#93000a",
|
|
"surface-bright": "#363a3d",
|
|
"on-primary-container": "#004f6c",
|
|
"warning": "#ddb26f",
|
|
"surface": "#151515",
|
|
"suit-black": "#d0d0d0",
|
|
"highlight-valid": "#acc267",
|
|
"outline": "#505050",
|
|
"surface-variant": "#313538",
|
|
"on-error-container": "#ffdad6",
|
|
"on-error": "#690005",
|
|
"primary": "#a1dcff",
|
|
"suit-red": "#fb9fb1"
|
|
},
|
|
"borderRadius": {
|
|
"DEFAULT": "0.125rem",
|
|
"lg": "0.25rem",
|
|
"xl": "0.5rem",
|
|
"full": "0.75rem"
|
|
},
|
|
"spacing": {
|
|
"gutter-card": "0.375rem",
|
|
"action-bar-height": "64px",
|
|
"stack-overlap": "2rem",
|
|
"margin-edge": "1rem"
|
|
},
|
|
"fontFamily": {
|
|
"card-rank": ["JetBrains Mono"],
|
|
"hud-score": ["JetBrains Mono"],
|
|
"body-md": ["Inter"],
|
|
"headline": ["JetBrains Mono"],
|
|
"label-caps": ["JetBrains Mono"],
|
|
"hud-timer": ["JetBrains Mono"]
|
|
},
|
|
"fontSize": {
|
|
"card-rank": ["18px", {"lineHeight": "18px", "fontWeight": "700"}],
|
|
"hud-score": ["24px", {"lineHeight": "32px", "letterSpacing": "-0.02em", "fontWeight": "700"}],
|
|
"body-md": ["16px", {"lineHeight": "24px", "fontWeight": "400"}],
|
|
"headline": ["28px", {"lineHeight": "32px", "letterSpacing": "-0.01em", "fontWeight": "700"}],
|
|
"label-caps": ["12px", {"lineHeight": "16px", "letterSpacing": "0.08em", "fontWeight": "500"}],
|
|
"hud-timer": ["16px", {"lineHeight": "24px", "fontWeight": "400"}]
|
|
}
|
|
},
|
|
},
|
|
}
|
|
</script>
|
|
<style>
|
|
body {
|
|
min-height: max(884px, 100dvh);
|
|
}
|
|
</style>
|
|
</head>
|
|
<body class="bg-background text-on-background font-body-md overflow-hidden h-screen select-none">
|
|
<!-- Top App Bar -->
|
|
<header class="fixed top-0 w-full z-50 flex justify-between items-center px-margin-edge h-action-bar-height bg-background dark:bg-background border-b border-outline-variant dark:border-outline-variant">
|
|
<div class="font-headline text-headline text-primary dark:text-primary uppercase tracking-tighter">ROOT@SOLITAIRE:~</div>
|
|
<div class="flex gap-4">
|
|
<span class="material-symbols-outlined text-primary" data-icon="memory">memory</span>
|
|
<span class="material-symbols-outlined text-primary" data-icon="settings_ethernet">settings_ethernet</span>
|
|
<span class="material-symbols-outlined text-primary" data-icon="wifi_tethering">wifi_tethering</span>
|
|
</div>
|
|
</header>
|
|
<!-- Main Tableau (Dimmed Background) -->
|
|
<main class="pt-24 px-4 flex flex-col gap-8 opacity-20 filter grayscale">
|
|
<!-- HUD Chips -->
|
|
<div class="flex justify-between items-center">
|
|
<div class="bg-surface-container p-3 flex flex-col">
|
|
<span class="font-label-caps text-label-caps text-on-surface-variant uppercase">SCORE</span>
|
|
<span class="font-hud-score text-hud-score text-primary">04,820</span>
|
|
</div>
|
|
<div class="bg-surface-container p-3 flex flex-col items-end">
|
|
<span class="font-label-caps text-label-caps text-on-surface-variant uppercase">TIMER</span>
|
|
<span class="font-hud-timer text-hud-timer text-on-surface">04:12</span>
|
|
</div>
|
|
</div>
|
|
<!-- Foundation & Stock -->
|
|
<div class="flex gap-gutter-card justify-between">
|
|
<div class="flex gap-gutter-card">
|
|
<div class="w-[64px] h-[88px] border border-dashed border-outline rounded-DEFAULT"></div>
|
|
<div class="w-[64px] h-[88px] bg-surface border border-outline rounded-DEFAULT relative overflow-hidden">
|
|
<div class="absolute inset-0 scanline-overlay"></div>
|
|
<div class="absolute top-2 left-2 w-3 h-4 bg-suit-red-cb"></div>
|
|
<div class="absolute bottom-2 right-2 font-card-rank text-[12px] text-on-surface">▌RS</div>
|
|
</div>
|
|
</div>
|
|
<div class="flex gap-gutter-card">
|
|
<div class="w-[64px] h-[88px] border border-outline rounded-DEFAULT bg-surface"></div>
|
|
<div class="w-[64px] h-[88px] border border-outline rounded-DEFAULT bg-surface"></div>
|
|
<div class="w-[64px] h-[88px] border border-outline rounded-DEFAULT bg-surface"></div>
|
|
<div class="w-[64px] h-[88px] border border-outline rounded-DEFAULT bg-surface"></div>
|
|
</div>
|
|
</div>
|
|
<!-- Cascades -->
|
|
<div class="grid grid-cols-7 gap-gutter-card">
|
|
<div class="h-24 border border-dashed border-outline rounded-DEFAULT"></div>
|
|
<div class="h-24 border border-dashed border-outline rounded-DEFAULT"></div>
|
|
<div class="h-24 border border-dashed border-outline rounded-DEFAULT"></div>
|
|
<div class="h-24 border border-dashed border-outline rounded-DEFAULT"></div>
|
|
<div class="h-24 border border-dashed border-outline rounded-DEFAULT"></div>
|
|
<div class="h-24 border border-dashed border-outline rounded-DEFAULT"></div>
|
|
<div class="h-24 border border-dashed border-outline rounded-DEFAULT"></div>
|
|
</div>
|
|
</main>
|
|
<!-- CELEBRATION OVERLAY SCREEM -->
|
|
<div class="fixed inset-0 z-[100] flex items-center justify-center bg-surface/95 backdrop-blur-sm">
|
|
<!-- Celebration Card -->
|
|
<div class="w-[340px] h-[480px] bg-[#202020] border border-highlight-celebration rounded-xl card-glow flex flex-col overflow-hidden relative">
|
|
<!-- Title Bar -->
|
|
<div class="h-[28px] bg-[#1a1a1a] border-b border-outline flex items-center px-4 shrink-0">
|
|
<span class="text-primary mr-1">▌</span>
|
|
<span class="font-headline text-[12px] text-[#a0a0a0]">level-up.tsx</span>
|
|
</div>
|
|
<!-- Content Area -->
|
|
<div class="flex-grow p-6 flex flex-col">
|
|
<!-- Hero Band -->
|
|
<div class="text-center mb-6">
|
|
<div class="font-headline text-[14px] text-highlight-celebration uppercase tracking-[0.08em] mb-2">▲ LEVEL UP</div>
|
|
<div class="flex items-baseline justify-center gap-2">
|
|
<span class="font-headline font-bold text-[96px] text-suit-black leading-none tracking-tighter">13</span>
|
|
<div class="flex flex-col items-start">
|
|
<span class="font-label-caps text-[11px] text-outline uppercase">FROM 12</span>
|
|
</div>
|
|
</div>
|
|
<div class="mt-2 font-headline font-medium text-[13px] text-highlight-celebration tracking-[0.08em]">█ NEW PERKS UNLOCKED</div>
|
|
</div>
|
|
<!-- Perks List -->
|
|
<div class="space-y-2 mb-6">
|
|
<!-- Item 1 -->
|
|
<div class="h-[48px] bg-[#1a1a1a] rounded-[4px] px-3 flex items-center justify-between">
|
|
<span class="font-headline text-[13px] text-suit-black">▢ +1 daily challenge slot</span>
|
|
<span class="bg-highlight-celebration/10 text-highlight-celebration px-2 py-0.5 rounded-full font-label-caps text-[10px] border border-highlight-celebration/30">NEW</span>
|
|
</div>
|
|
<!-- Item 2 -->
|
|
<div class="h-[48px] bg-[#1a1a1a] rounded-[4px] px-3 flex items-center justify-between">
|
|
<span class="font-headline text-[13px] text-suit-black">▢ Background: Forest</span>
|
|
<span class="bg-highlight-valid/10 text-highlight-valid px-2 py-0.5 rounded-full font-label-caps text-[10px] border border-highlight-valid/30">UNLOCKED</span>
|
|
</div>
|
|
<!-- Item 3 -->
|
|
<div class="h-[48px] bg-[#1a1a1a] rounded-[4px] px-3 flex items-center justify-between">
|
|
<span class="font-headline text-[13px] text-suit-black">▢ Card-back: Stripes</span>
|
|
<span class="bg-highlight-valid/10 text-highlight-valid px-2 py-0.5 rounded-full font-label-caps text-[10px] border border-highlight-valid/30">UNLOCKED</span>
|
|
</div>
|
|
</div>
|
|
<!-- XP Recap -->
|
|
<div class="h-[48px] bg-[#1a1a1a] rounded-[4px] px-4 flex items-center justify-between mt-auto">
|
|
<span class="font-headline text-[12px] text-[#a0a0a0]">XP</span>
|
|
<span class="font-headline font-bold text-[14px] text-highlight-valid uppercase">+200 XP THIS LEVEL</span>
|
|
<div class="w-[60px] h-[4px] bg-outline-variant rounded-full overflow-hidden">
|
|
<div class="w-[0%] h-full bg-suit-red-cb"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- Action Button -->
|
|
<button class="h-[56px] w-full bg-suit-red-cb flex items-center justify-center gap-2 hover:opacity-90 active:opacity-75 transition-opacity">
|
|
<span class="font-headline font-bold text-[14px] text-background tracking-wider">▶ CONTINUE</span>
|
|
</button>
|
|
<!-- Scanline layer inside card -->
|
|
<div class="absolute inset-0 scanline-overlay opacity-20 pointer-events-none"></div>
|
|
</div>
|
|
<!-- Caption -->
|
|
<div class="absolute bottom-8 w-full text-center">
|
|
<span class="font-body-md text-[11px] text-[#a0a0a0] uppercase tracking-widest opacity-60">Tap anywhere to dismiss</span>
|
|
</div>
|
|
</div>
|
|
<!-- Bottom Nav Bar -->
|
|
<nav class="fixed bottom-0 w-full z-50 flex justify-between items-center h-action-bar-height bg-surface-container dark:bg-surface-container border-t border-outline dark:border-outline">
|
|
<div class="flex flex-col items-center justify-center bg-primary text-background p-2 w-1/5 h-full transition-colors font-label-caps text-label-caps uppercase tracking-widest">
|
|
<span class="material-symbols-outlined" data-icon="videogame_asset">videogame_asset</span>
|
|
<span>NORMAL</span>
|
|
</div>
|
|
<div class="flex flex-col items-center justify-center text-on-surface-variant p-2 w-1/5 h-full hover:text-primary transition-colors font-label-caps text-label-caps uppercase tracking-widest">
|
|
<span class="material-symbols-outlined" data-icon="edit">edit</span>
|
|
<span>INSERT</span>
|
|
</div>
|
|
<div class="flex flex-col items-center justify-center text-on-surface-variant p-2 w-1/5 h-full hover:text-primary transition-colors font-label-caps text-label-caps uppercase tracking-widest">
|
|
<span class="material-symbols-outlined" data-icon="visibility">visibility</span>
|
|
<span>VISUAL</span>
|
|
</div>
|
|
<div class="flex flex-col items-center justify-center text-on-surface-variant p-2 w-1/5 h-full hover:text-primary transition-colors font-label-caps text-label-caps uppercase tracking-widest">
|
|
<span class="material-symbols-outlined" data-icon="auto_fix_high">auto_fix_high</span>
|
|
<span>SOLVE</span>
|
|
</div>
|
|
<div class="flex flex-col items-center justify-center text-on-surface-variant p-2 w-1/5 h-full hover:text-primary transition-colors font-label-caps text-label-caps uppercase tracking-widest">
|
|
<span class="material-symbols-outlined" data-icon="power_settings_new">power_settings_new</span>
|
|
<span>QUIT</span>
|
|
</div>
|
|
</nav>
|
|
<!-- Persistent Background Overlay (CRT Effect) -->
|
|
<div class="fixed inset-0 pointer-events-none z-[200] scanline-overlay opacity-30"></div>
|
|
</body></html> |