payfrit-portal/trophy-case.html
Zara 71855a4701 Add trophy case showcase page with iframe previews of all portal mockups
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-27 22:30:39 +00:00

283 lines
7.8 KiB
HTML

<!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>