207 lines
8.7 KiB
HTML
207 lines
8.7 KiB
HTML
<!doctype html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
<title>Lull · Mobile onboarding</title>
|
|
<style>
|
|
:root {
|
|
--canvas: #efece4;
|
|
--ink: #232118;
|
|
--muted: #76715f;
|
|
--accent: #c66e3a;
|
|
--warm: #e8a76e;
|
|
--display: 'Iowan Old Style', 'Charter', Georgia, serif;
|
|
--body: -apple-system, BlinkMacSystemFont, 'Segoe UI', Inter, sans-serif;
|
|
}
|
|
* { box-sizing: border-box; }
|
|
body { margin: 0; background: var(--canvas); font-family: var(--body); color: var(--ink); }
|
|
.stage {
|
|
min-height: 100vh;
|
|
padding: 56px 32px;
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
gap: 32px;
|
|
background:
|
|
radial-gradient(ellipse 80% 60% at 50% -10%, rgba(232,167,110,0.35), transparent 70%),
|
|
radial-gradient(ellipse 80% 50% at 50% 110%, rgba(198,110,58,0.16), transparent 70%),
|
|
var(--canvas);
|
|
}
|
|
.stage h1 {
|
|
font-family: var(--display);
|
|
font-size: 28px;
|
|
margin: 0;
|
|
letter-spacing: -0.005em;
|
|
}
|
|
.stage p.lede { color: var(--muted); margin: 0; max-width: 50ch; text-align: center; }
|
|
|
|
.phones {
|
|
display: grid;
|
|
grid-template-columns: repeat(3, auto);
|
|
gap: 36px;
|
|
align-items: center;
|
|
}
|
|
.phone {
|
|
width: 320px;
|
|
aspect-ratio: 9 / 19.5;
|
|
background: #fff;
|
|
border-radius: 44px;
|
|
border: 8px solid #1a1814;
|
|
overflow: hidden;
|
|
position: relative;
|
|
box-shadow:
|
|
0 32px 60px rgba(28,27,26,0.18),
|
|
0 12px 18px rgba(28,27,26,0.08);
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
.phone .notch {
|
|
position: absolute; top: 0; left: 50%; transform: translateX(-50%);
|
|
width: 100px; height: 22px;
|
|
background: #1a1814;
|
|
border-bottom-left-radius: 14px;
|
|
border-bottom-right-radius: 14px;
|
|
z-index: 5;
|
|
}
|
|
.statusbar {
|
|
display: flex; justify-content: space-between; align-items: center;
|
|
padding: 14px 24px 4px;
|
|
font-size: 12.5px; font-weight: 600; color: var(--ink);
|
|
}
|
|
.statusbar .right { display: flex; gap: 6px; align-items: center; font-size: 11px; }
|
|
.status-icon { display: inline-block; width: 14px; height: 8px; background: var(--ink); border-radius: 2px; }
|
|
|
|
.phone-body {
|
|
flex: 1;
|
|
padding: 18px 24px 24px;
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
.phone-top { display: flex; justify-content: flex-end; align-items: center; }
|
|
.skip { font-size: 13px; color: var(--muted); }
|
|
|
|
.hero { flex: 1; display: flex; align-items: center; justify-content: center; padding: 24px 0; }
|
|
.hero .art { width: 220px; height: 220px; }
|
|
|
|
.copy { display: flex; flex-direction: column; gap: 10px; padding: 14px 4px; }
|
|
.copy h2 { font-family: var(--display); font-size: 30px; line-height: 1.1; margin: 0; letter-spacing: -0.01em; font-weight: 700; }
|
|
.copy p { color: var(--muted); margin: 0; font-size: 15px; line-height: 1.5; }
|
|
|
|
.pager { display: flex; justify-content: center; gap: 6px; padding: 14px 0 8px; }
|
|
.pager span { width: 6px; height: 6px; border-radius: 50%; background: rgba(35,33,24,0.18); }
|
|
.pager span.active { width: 22px; background: var(--accent); border-radius: 999px; }
|
|
|
|
.cta {
|
|
background: var(--ink); color: #fef9ee;
|
|
padding: 16px 22px; border-radius: 999px;
|
|
text-align: center; font-weight: 600; font-size: 15px;
|
|
}
|
|
.alt { text-align: center; color: var(--muted); padding-top: 12px; font-size: 13px; }
|
|
.alt a { color: var(--accent); font-weight: 600; }
|
|
|
|
/* Phone 3 — sign-in */
|
|
.signin-options { display: flex; flex-direction: column; gap: 10px; }
|
|
.opt { display: flex; align-items: center; gap: 12px; padding: 14px 18px; border: 1px solid rgba(35,33,24,0.12); border-radius: 14px; font-weight: 500; font-size: 14.5px; }
|
|
.opt .glyph { width: 22px; height: 22px; border-radius: 50%; background: var(--ink); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; }
|
|
.opt.apple .glyph { background: #000; }
|
|
.opt.google .glyph { background: linear-gradient(135deg, #ea4335, #fbbc05, #34a853, #4285f4); }
|
|
.opt.email .glyph { background: var(--accent); }
|
|
|
|
.terms { font-size: 11px; color: var(--muted); text-align: center; padding-top: 14px; line-height: 1.5; }
|
|
.terms a { color: var(--accent); }
|
|
|
|
@media (max-width: 1100px) {
|
|
.phones { grid-template-columns: 1fr; }
|
|
.phone { width: 92vw; max-width: 360px; }
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<div class="stage">
|
|
<h1>Lull · onboarding flow</h1>
|
|
<p class="lede">Three screens, one tone of voice. Designed in the Lull design system — warm canvas, serif headings, single accent.</p>
|
|
|
|
<div class="phones">
|
|
<!-- Screen 1: welcome -->
|
|
<div class="phone">
|
|
<div class="notch"></div>
|
|
<div class="statusbar"><span>9:41</span><div class="right"><span>5G</span><span class="status-icon"></span></div></div>
|
|
<div class="phone-body">
|
|
<div class="phone-top"><span class="skip">Skip</span></div>
|
|
<div class="hero">
|
|
<svg class="art" viewBox="0 0 220 220">
|
|
<defs>
|
|
<radialGradient id="moon1" cx="50%" cy="40%" r="60%">
|
|
<stop offset="0%" stop-color="#fcebd0"/>
|
|
<stop offset="100%" stop-color="#e8a76e"/>
|
|
</radialGradient>
|
|
</defs>
|
|
<circle cx="110" cy="110" r="78" fill="url(#moon1)"/>
|
|
<circle cx="146" cy="92" r="14" fill="#fff" opacity="0.6"/>
|
|
<circle cx="78" cy="74" r="3" fill="#c66e3a" opacity="0.7"/>
|
|
<circle cx="60" cy="120" r="2" fill="#c66e3a" opacity="0.5"/>
|
|
<circle cx="170" cy="140" r="2.5" fill="#c66e3a" opacity="0.6"/>
|
|
<path d="M 30 200 Q 110 170 200 200 L 200 220 L 30 220 Z" fill="#c66e3a" opacity="0.18"/>
|
|
</svg>
|
|
</div>
|
|
<div class="copy">
|
|
<h2>Quiet beats noise.</h2>
|
|
<p>Twelve minutes a day. A practice that fits in a coffee break. No streaks, no badges — just a calmer evening.</p>
|
|
</div>
|
|
<div class="pager"><span class="active"></span><span></span><span></span></div>
|
|
<div class="cta">Continue</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Screen 2: value props -->
|
|
<div class="phone">
|
|
<div class="notch"></div>
|
|
<div class="statusbar"><span>9:41</span><div class="right"><span>5G</span><span class="status-icon"></span></div></div>
|
|
<div class="phone-body">
|
|
<div class="phone-top"><span class="skip">Skip</span></div>
|
|
<div class="hero">
|
|
<svg class="art" viewBox="0 0 220 220">
|
|
<rect x="38" y="48" width="144" height="100" rx="14" fill="#fff" stroke="#c66e3a" stroke-width="1.5"/>
|
|
<rect x="56" y="68" width="56" height="6" rx="3" fill="#c66e3a"/>
|
|
<rect x="56" y="84" width="100" height="4" rx="2" fill="#76715f" opacity="0.4"/>
|
|
<rect x="56" y="96" width="80" height="4" rx="2" fill="#76715f" opacity="0.4"/>
|
|
<rect x="56" y="116" width="40" height="20" rx="10" fill="#c66e3a"/>
|
|
<circle cx="170" cy="160" r="22" fill="#e8a76e"/>
|
|
<path d="M 162 160 L 168 166 L 178 154" stroke="#fff" stroke-width="3" fill="none" stroke-linecap="round" stroke-linejoin="round"/>
|
|
</svg>
|
|
</div>
|
|
<div class="copy">
|
|
<h2>Practice that meets you where you are.</h2>
|
|
<p>Adaptive sessions that get shorter on busy days, deeper on quiet ones. The kind of routine that survives a Wednesday.</p>
|
|
</div>
|
|
<div class="pager"><span></span><span class="active"></span><span></span></div>
|
|
<div class="cta">Continue</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Screen 3: sign in -->
|
|
<div class="phone">
|
|
<div class="notch"></div>
|
|
<div class="statusbar"><span>9:41</span><div class="right"><span>5G</span><span class="status-icon"></span></div></div>
|
|
<div class="phone-body">
|
|
<div class="phone-top"><span class="skip">Help</span></div>
|
|
<div style="padding: 24px 0;">
|
|
<h2 style="font-family: var(--display); font-size: 32px; margin: 0 0 8px; letter-spacing: -0.01em; line-height: 1.05; font-weight: 700;">Make a place for it.</h2>
|
|
<p style="margin: 0; color: var(--muted); font-size: 15px;">Save your sessions across devices. We don't email, we don't share.</p>
|
|
</div>
|
|
<div class="signin-options">
|
|
<div class="opt apple"><span class="glyph"></span>Continue with Apple</div>
|
|
<div class="opt google"><span class="glyph"></span>Continue with Google</div>
|
|
<div class="opt email"><span class="glyph">@</span>Continue with email</div>
|
|
</div>
|
|
<div style="flex: 1;"></div>
|
|
<div class="terms">By continuing, you agree to Lull's <a>Terms</a> and <a>Privacy Policy</a>.</div>
|
|
<div class="pager"><span></span><span></span><span class="active"></span></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</body>
|
|
</html>
|