Add trophy case showcase page with iframe previews of all portal mockups
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
parent
a8a9861d90
commit
71855a4701
1 changed files with 283 additions and 0 deletions
283
trophy-case.html
Normal file
283
trophy-case.html
Normal file
|
|
@ -0,0 +1,283 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>Zara's Trophy Case — Payfrit Portal Mockups</title>
|
||||
<style>
|
||||
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
|
||||
|
||||
:root {
|
||||
--bg: #0f1117;
|
||||
--card: #1a1d27;
|
||||
--border: #2a2e3e;
|
||||
--accent: #6c63ff;
|
||||
--accent2: #00c9a7;
|
||||
--text: #f0f0f5;
|
||||
--muted: #8b8fa8;
|
||||
--font: 'Segoe UI', system-ui, -apple-system, sans-serif;
|
||||
}
|
||||
|
||||
body {
|
||||
background: var(--bg);
|
||||
color: var(--text);
|
||||
font-family: var(--font);
|
||||
min-height: 100vh;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
/* Hero header */
|
||||
.hero {
|
||||
background: linear-gradient(135deg, #1a1d27 0%, #2a1d4e 50%, #1a2d3e 100%);
|
||||
padding: 48px 24px 40px;
|
||||
text-align: center;
|
||||
border-bottom: 1px solid var(--border);
|
||||
}
|
||||
.hero h1 {
|
||||
font-size: 32px;
|
||||
font-weight: 800;
|
||||
letter-spacing: -0.5px;
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
.hero h1 span { color: var(--accent); }
|
||||
.hero p {
|
||||
color: var(--muted);
|
||||
font-size: 16px;
|
||||
max-width: 500px;
|
||||
margin: 0 auto;
|
||||
line-height: 1.5;
|
||||
}
|
||||
.hero .badge {
|
||||
display: inline-block;
|
||||
background: var(--accent);
|
||||
color: #fff;
|
||||
font-size: 12px;
|
||||
font-weight: 700;
|
||||
padding: 4px 12px;
|
||||
border-radius: 20px;
|
||||
margin-bottom: 12px;
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 1px;
|
||||
}
|
||||
|
||||
/* Grid */
|
||||
.grid {
|
||||
display: grid;
|
||||
grid-template-columns: 1fr;
|
||||
gap: 24px;
|
||||
padding: 32px 20px;
|
||||
max-width: 1200px;
|
||||
margin: 0 auto;
|
||||
}
|
||||
@media (min-width: 768px) {
|
||||
.grid { grid-template-columns: 1fr 1fr; }
|
||||
}
|
||||
@media (min-width: 1100px) {
|
||||
.grid { grid-template-columns: 1fr 1fr 1fr; }
|
||||
}
|
||||
|
||||
/* Card */
|
||||
.card {
|
||||
background: var(--card);
|
||||
border: 1px solid var(--border);
|
||||
border-radius: 16px;
|
||||
overflow: hidden;
|
||||
transition: transform 0.2s, box-shadow 0.2s;
|
||||
}
|
||||
.card:hover {
|
||||
transform: translateY(-4px);
|
||||
box-shadow: 0 12px 40px rgba(108, 99, 255, 0.15);
|
||||
}
|
||||
|
||||
.card-preview {
|
||||
width: 100%;
|
||||
height: 280px;
|
||||
border: none;
|
||||
background: #fff;
|
||||
pointer-events: none;
|
||||
transform-origin: top left;
|
||||
}
|
||||
|
||||
.card-info {
|
||||
padding: 16px 20px;
|
||||
border-top: 1px solid var(--border);
|
||||
}
|
||||
.card-info h3 {
|
||||
font-size: 17px;
|
||||
font-weight: 700;
|
||||
margin-bottom: 4px;
|
||||
}
|
||||
.card-info p {
|
||||
color: var(--muted);
|
||||
font-size: 13px;
|
||||
line-height: 1.4;
|
||||
margin-bottom: 12px;
|
||||
}
|
||||
.card-tags {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
gap: 6px;
|
||||
margin-bottom: 12px;
|
||||
}
|
||||
.tag {
|
||||
font-size: 11px;
|
||||
font-weight: 600;
|
||||
padding: 3px 10px;
|
||||
border-radius: 12px;
|
||||
background: rgba(108, 99, 255, 0.15);
|
||||
color: var(--accent);
|
||||
}
|
||||
.tag.green {
|
||||
background: rgba(0, 201, 167, 0.15);
|
||||
color: var(--accent2);
|
||||
}
|
||||
.tag.orange {
|
||||
background: rgba(245, 166, 35, 0.15);
|
||||
color: #f5a623;
|
||||
}
|
||||
|
||||
.card-link {
|
||||
display: inline-block;
|
||||
background: var(--accent);
|
||||
color: #fff;
|
||||
text-decoration: none;
|
||||
font-size: 13px;
|
||||
font-weight: 700;
|
||||
padding: 8px 20px;
|
||||
border-radius: 8px;
|
||||
transition: background 0.15s;
|
||||
}
|
||||
.card-link:hover { background: #5a52e0; }
|
||||
|
||||
/* Iframe wrapper with scale trick for preview */
|
||||
.preview-wrap {
|
||||
width: 100%;
|
||||
height: 280px;
|
||||
overflow: hidden;
|
||||
position: relative;
|
||||
background: #fff;
|
||||
}
|
||||
.preview-wrap iframe {
|
||||
width: 375px;
|
||||
height: 812px;
|
||||
border: none;
|
||||
transform: scale(0.48);
|
||||
transform-origin: top left;
|
||||
pointer-events: none;
|
||||
}
|
||||
|
||||
/* Footer */
|
||||
.footer {
|
||||
text-align: center;
|
||||
padding: 32px 20px;
|
||||
color: var(--muted);
|
||||
font-size: 13px;
|
||||
border-top: 1px solid var(--border);
|
||||
margin-top: 20px;
|
||||
}
|
||||
.footer strong { color: var(--accent); }
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<div class="hero">
|
||||
<div class="badge">@zara's workspace</div>
|
||||
<h1><span>Trophy Case</span> — Portal Mockups</h1>
|
||||
<p>All the consumer-facing mockups I've built for Payfrit. Mobile-first, vanilla HTML/CSS/JS. Click any card to open it full-screen.</p>
|
||||
</div>
|
||||
|
||||
<div class="grid">
|
||||
|
||||
<!-- 1. Barcode Scanner -->
|
||||
<div class="card">
|
||||
<div class="preview-wrap">
|
||||
<iframe src="scan.html" loading="lazy" sandbox></iframe>
|
||||
</div>
|
||||
<div class="card-info">
|
||||
<h3>Barcode Scanner</h3>
|
||||
<p>Camera-powered barcode scanning interface. Tap to scan, get instant product health scores right in the grocery aisle.</p>
|
||||
<div class="card-tags">
|
||||
<span class="tag">Mobile-First</span>
|
||||
<span class="tag green">Camera API</span>
|
||||
<span class="tag">Core Feature</span>
|
||||
</div>
|
||||
<a class="card-link" href="scan.html" target="_blank">Open Full Page →</a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- 2. User Dashboard -->
|
||||
<div class="card">
|
||||
<div class="preview-wrap">
|
||||
<iframe src="dashboard.html" loading="lazy" sandbox></iframe>
|
||||
</div>
|
||||
<div class="card-info">
|
||||
<h3>User Dashboard</h3>
|
||||
<p>Personal health overview with recent scans, health score trends, quick actions, and personalized product recommendations.</p>
|
||||
<div class="card-tags">
|
||||
<span class="tag green">Health Scores</span>
|
||||
<span class="tag">Analytics</span>
|
||||
<span class="tag orange">Personalized</span>
|
||||
</div>
|
||||
<a class="card-link" href="dashboard.html" target="_blank">Open Full Page →</a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- 3. Product Compare -->
|
||||
<div class="card">
|
||||
<div class="preview-wrap">
|
||||
<iframe src="compare.html" loading="lazy" sandbox></iframe>
|
||||
</div>
|
||||
<div class="card-info">
|
||||
<h3>Product Compare</h3>
|
||||
<p>Side-by-side product comparison with health scores, ingredients breakdown, nutritional highlights, and healthier alternatives.</p>
|
||||
<div class="card-tags">
|
||||
<span class="tag">Comparison</span>
|
||||
<span class="tag green">Alternatives</span>
|
||||
<span class="tag orange">Dark Theme</span>
|
||||
</div>
|
||||
<a class="card-link" href="compare.html" target="_blank">Open Full Page →</a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- 4. Messaging Hub -->
|
||||
<div class="card">
|
||||
<div class="preview-wrap">
|
||||
<iframe src="messaging.html" loading="lazy" sandbox></iframe>
|
||||
</div>
|
||||
<div class="card-info">
|
||||
<h3>Messaging Hub</h3>
|
||||
<p>Slack-inspired messaging interface with channels, DMs, @mentions feed, and slide-out navigation. Desktop + mobile responsive.</p>
|
||||
<div class="card-tags">
|
||||
<span class="tag">Messaging</span>
|
||||
<span class="tag green">Channels</span>
|
||||
<span class="tag orange">Responsive</span>
|
||||
</div>
|
||||
<a class="card-link" href="messaging.html" target="_blank">Open Full Page →</a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- 5. Conversation View -->
|
||||
<div class="card">
|
||||
<div class="preview-wrap">
|
||||
<iframe src="messaging-conversation.html" loading="lazy" sandbox></iframe>
|
||||
</div>
|
||||
<div class="card-info">
|
||||
<h3>Conversation View</h3>
|
||||
<p>Full chat thread view with message bubbles, timestamps, typing indicators, and message input. Native mobile app feel.</p>
|
||||
<div class="card-tags">
|
||||
<span class="tag">Chat UI</span>
|
||||
<span class="tag green">Real-time</span>
|
||||
<span class="tag">Mobile Native</span>
|
||||
</div>
|
||||
<a class="card-link" href="messaging-conversation.html" target="_blank">Open Full Page →</a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="footer">
|
||||
Built by <strong>@zara</strong> · Payfrit User Portal · March 2026
|
||||
</div>
|
||||
|
||||
</body>
|
||||
</html>
|
||||
Loading…
Add table
Reference in a new issue