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>
206 lines
9.4 KiB
HTML
206 lines
9.4 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"/>
|
|
<link href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap" rel="stylesheet"/>
|
|
<link href="https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700;800&family=Inter:wght@400;500&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"/>
|
|
<script src="https://cdn.tailwindcss.com?plugins=forms,container-queries"></script>
|
|
<script id="tailwind-config">
|
|
tailwind.config = {
|
|
darkMode: "class",
|
|
theme: {
|
|
extend: {
|
|
"colors": {
|
|
"tertiary": "#f7c3ff",
|
|
"surface": "#151515",
|
|
"surface-container-lowest": "#0b0f11",
|
|
"surface-variant": "#313538",
|
|
"surface-tint": "#7ed0fe",
|
|
"primary": "#a1dcff",
|
|
"on-tertiary-fixed-variant": "#653173",
|
|
"on-error-container": "#ffdad6",
|
|
"on-tertiary-container": "#683476",
|
|
"secondary": "#bad073",
|
|
"surface-dim": "#101417",
|
|
"inverse-on-surface": "#2d3134",
|
|
"on-tertiary": "#4c195b",
|
|
"surface-container-high": "#272a2d",
|
|
"on-primary-fixed-variant": "#004c69",
|
|
"surface-container": "#202020",
|
|
"highlight-celebration": "#e1a3ee",
|
|
"background": "#101417",
|
|
"suit-red": "#fb9fb1",
|
|
"on-secondary-container": "#b2c86d",
|
|
"inverse-surface": "#e0e3e6",
|
|
"error": "#fb9fb1",
|
|
"on-surface": "#d0d0d0",
|
|
"info": "#12cfc0",
|
|
"secondary-container": "#435401",
|
|
"tertiary-fixed-dim": "#f0b0fc",
|
|
"surface-bright": "#363a3d",
|
|
"outline-variant": "#3f484e",
|
|
"on-secondary-fixed-variant": "#3c4d00",
|
|
"warning": "#ddb26f",
|
|
"surface-container-highest": "#313538",
|
|
"secondary-fixed": "#d5ec8c",
|
|
"highlight-valid": "#acc267",
|
|
"secondary-fixed-dim": "#bad073",
|
|
"tertiary-container": "#e1a3ee",
|
|
"suit-red-cb": "#6fc2ef",
|
|
"on-error": "#690005",
|
|
"on-primary-container": "#004f6c",
|
|
"suit-black": "#d0d0d0",
|
|
"inverse-primary": "#00668a",
|
|
"surface-container-low": "#181c1f",
|
|
"on-primary-fixed": "#001e2c",
|
|
"on-secondary": "#293500",
|
|
"primary-fixed": "#c4e7ff",
|
|
"on-tertiary-fixed": "#340043",
|
|
"outline": "#505050",
|
|
"error-container": "#93000a",
|
|
"tertiary-fixed": "#fbd7ff",
|
|
"primary-container": "#6fc2ef",
|
|
"on-background": "#e0e3e6",
|
|
"on-primary": "#003549",
|
|
"on-surface-variant": "#bfc8cf",
|
|
"on-secondary-fixed": "#161e00",
|
|
"primary-fixed-dim": "#7ed0fe"
|
|
},
|
|
"borderRadius": {
|
|
"DEFAULT": "0.125rem",
|
|
"lg": "0.25rem",
|
|
"xl": "0.5rem",
|
|
"full": "0.75rem"
|
|
},
|
|
"spacing": {
|
|
"margin-edge": "1rem",
|
|
"gutter-card": "0.375rem",
|
|
"touch-target-min": "48dp",
|
|
"stack-overlap": "2rem",
|
|
"action-bar-height": "64px"
|
|
},
|
|
"fontFamily": {
|
|
"card-rank": ["JetBrains Mono"],
|
|
"hud-timer": ["JetBrains Mono"],
|
|
"body-md": ["Inter"],
|
|
"headline": ["JetBrains Mono"],
|
|
"label-caps": ["JetBrains Mono"],
|
|
"hud-score": ["JetBrains Mono"]
|
|
},
|
|
"fontSize": {
|
|
"card-rank": ["18px", {"lineHeight": "18px", "fontWeight": "700"}],
|
|
"hud-timer": ["16px", {"lineHeight": "24px", "fontWeight": "400"}],
|
|
"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-score": ["24px", {"lineHeight": "32px", "letterSpacing": "-0.02em", "fontWeight": "700"}]
|
|
}
|
|
},
|
|
},
|
|
}
|
|
</script>
|
|
<style>
|
|
.material-symbols-outlined {
|
|
font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
|
|
}
|
|
body {
|
|
background-color: #151515;
|
|
color: #d0d0d0;
|
|
-webkit-font-smoothing: antialiased;
|
|
}
|
|
.card-scanline {
|
|
background: linear-gradient(rgba(21, 21, 21, 0) 50%, rgba(26, 26, 26, 1) 50%);
|
|
background-size: 100% 4px;
|
|
}
|
|
</style>
|
|
<style>
|
|
body {
|
|
min-height: max(884px, 100dvh);
|
|
}
|
|
</style>
|
|
</head>
|
|
<body class="flex items-center justify-center min-h-screen">
|
|
<!-- Mobile Canvas (390x844 simulated) -->
|
|
<main class="w-[390px] h-[844px] bg-surface relative overflow-hidden flex flex-col">
|
|
<!-- Status Bar -->
|
|
<header class="h-8 bg-surface-container flex items-center justify-between px-margin-edge border-b border-outline-variant">
|
|
<div class="font-hud-timer text-[11px] text-primary tracking-tight">▌onboard/01-draw.tsx</div>
|
|
<div class="font-hud-timer text-[11px] text-on-surface-variant font-bold">STEP 1 OF 3</div>
|
|
</header>
|
|
<!-- Content Canvas -->
|
|
<div class="flex-1 overflow-y-auto pb-action-bar-height">
|
|
<!-- Hero Section -->
|
|
<section class="h-[140px] flex flex-col items-center justify-center mt-8">
|
|
<div class="w-8 h-12 bg-primary animate-pulse mb-2"></div>
|
|
<h1 class="font-headline text-headline text-on-surface uppercase tracking-tighter">
|
|
WELCOME <span class="text-primary">▌_</span>
|
|
</h1>
|
|
</section>
|
|
<!-- Headline -->
|
|
<section class="px-margin-edge mt-4 text-center">
|
|
<h2 class="font-headline text-[22px] leading-tight text-on-surface mb-1">CHOOSE A DRAW MODE</h2>
|
|
<p class="font-body-md text-[12px] text-on-surface-variant">You can change this any time in Settings.</p>
|
|
</section>
|
|
<!-- Choice Cards -->
|
|
<section class="px-margin-edge mt-8 space-y-4">
|
|
<!-- DRAW-3 Card -->
|
|
<div class="h-[120px] bg-surface-container border border-primary p-4 relative flex items-start gap-4">
|
|
<div class="absolute top-0 right-0 bg-primary px-2 py-0.5">
|
|
<span class="font-label-caps text-[10px] text-surface font-bold">RECOMMENDED</span>
|
|
</div>
|
|
<div class="w-12 h-16 flex items-center justify-center border border-outline-variant bg-surface-dim">
|
|
<span class="material-symbols-outlined text-primary" data-icon="filter_3">filter_3</span>
|
|
</div>
|
|
<div class="flex-1">
|
|
<h3 class="font-headline text-[16px] text-primary mb-1">DRAW-3 (CLASSIC)</h3>
|
|
<p class="font-hud-timer text-[12px] leading-snug text-on-surface-variant">
|
|
Cycle 3 cards at a time. Standard solitaire rules for a tactical challenge.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
<!-- DRAW-1 Card -->
|
|
<div class="h-[120px] bg-surface-container border border-outline-variant p-4 flex items-start gap-4">
|
|
<div class="w-12 h-16 flex items-center justify-center border border-outline-variant bg-surface-dim">
|
|
<span class="material-symbols-outlined text-on-surface-variant" data-icon="filter_1">filter_1</span>
|
|
</div>
|
|
<div class="flex-1">
|
|
<h3 class="font-headline text-[16px] text-on-surface mb-1">DRAW-1 (EASY)</h3>
|
|
<p class="font-hud-timer text-[12px] leading-snug text-on-surface-variant">
|
|
Cycle one card at a time. More winnable, faster pace, perfect for quick sessions.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
<!-- Step Indicator -->
|
|
<section class="mt-12 flex flex-col items-center">
|
|
<div class="flex gap-2 mb-2">
|
|
<div class="w-8 h-1.5 bg-primary"></div>
|
|
<div class="w-8 h-1.5 bg-outline-variant"></div>
|
|
<div class="w-8 h-1.5 bg-outline-variant"></div>
|
|
</div>
|
|
<div class="font-hud-timer text-[12px] flex gap-4">
|
|
<span class="text-primary font-bold">[1]</span>
|
|
<span class="text-outline-variant">[2]</span>
|
|
<span class="text-outline-variant">[3]</span>
|
|
</div>
|
|
</section>
|
|
</div>
|
|
<!-- Bottom Action Bar -->
|
|
<footer class="h-action-bar-height bg-surface-container border-t border-outline flex items-center justify-between px-margin-edge fixed bottom-0 w-[390px] z-50">
|
|
<!-- Back Button (Disabled/Muted) -->
|
|
<button class="w-[48%] h-12 border border-outline-variant flex items-center justify-center gap-2 opacity-40 cursor-not-allowed">
|
|
<span class="material-symbols-outlined text-outline-variant text-[18px]" data-icon="arrow_back">arrow_back</span>
|
|
<span class="font-label-caps text-outline-variant">BACK</span>
|
|
</button>
|
|
<!-- Next Button -->
|
|
<button class="w-[48%] h-12 bg-primary flex items-center justify-center gap-2 active:opacity-80 transition-opacity">
|
|
<span class="font-headline text-[14px] text-surface font-bold uppercase tracking-widest">NEXT</span>
|
|
<span class="material-symbols-outlined text-surface text-[18px]" data-icon="arrow_forward">arrow_forward</span>
|
|
</button>
|
|
</footer>
|
|
<!-- Terminal Overlay (Faint scanlines for atmosphere) -->
|
|
<div class="pointer-events-none absolute inset-0 opacity-[0.03] card-scanline z-[100]"></div>
|
|
</main>
|
|
</body></html> |