changed font style, added journey summary, changed card ui

This commit is contained in:
haerikimmm
2026-06-11 13:21:09 +09:00
parent 6b13522d6d
commit 0848418453
17 changed files with 1955 additions and 430 deletions

View File

@@ -1,296 +1,128 @@
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,200;12..96,300;12..96,400&display=swap');
/* ── Color tokens ─────────────────────────────────────────── */
:root {
--text: #6b6375;
--text-h: #08060d;
--bg: #fff;
--border: #e5e4e7;
--code-bg: #f4f3ec;
--accent: #aa3bff;
--accent-bg: rgba(170, 59, 255, 0.1);
--accent-border: rgba(170, 59, 255, 0.5);
--social-bg: rgba(244, 243, 236, 0.5);
--shadow:
rgba(0, 0, 0, 0.1) 0 10px 15px -3px, rgba(0, 0, 0, 0.05) 0 4px 6px -2px;
/* Indigo & Lavender palette */
--accent: #6366f1; /* indigo-500 */
--accent-dark: #4f46e5; /* indigo-600 */
--accent-light: #818cf8; /* indigo-400 */
--accent-bg: rgba(99, 102, 241, 0.08);
--accent-border: rgba(99, 102, 241, 0.35);
--sans: system-ui, 'Segoe UI', Roboto, sans-serif;
--heading: system-ui, 'Segoe UI', Roboto, sans-serif;
--mono: ui-monospace, Consolas, monospace;
--lavender: #c4b5fd; /* violet-300 — lavender highlight */
--lavender-bg: rgba(196, 181, 253, 0.15);
font: 18px/145% var(--sans);
letter-spacing: 0.18px;
color-scheme: light dark;
/* Neutrals */
--text: #6b7280; /* body copy */
--text-h: #1e1b4b; /* headings — deep indigo-950 */
--text-sub: #9ca3af; /* captions / secondary */
--bg: #fafafe; /* faint indigo tint on white */
--bg-raised: #ffffff;
--border: #e0e7ff; /* indigo-100 */
--shadow: rgba(99, 102, 241, 0.12) 0 4px 24px -4px;
/* Typography */
--sans: 'Bricolage Grotesque', system-ui, sans-serif;
--heading: 'Bricolage Grotesque', system-ui, sans-serif;
--mono: ui-monospace, Consolas, monospace;
/* Type scale */
--text-xs: 11px;
--text-sm: 13px;
--text-base: 14px;
--text-md: 16px;
--text-lg: 20px;
--text-xl: 26px;
--text-2xl: 32px;
font-family: var(--sans);
font-size: var(--text-base);
line-height: 1.6;
font-weight: 400;
letter-spacing: 0.01em;
color: var(--text);
background: var(--bg);
font-synthesis: none;
text-rendering: optimizeLegibility;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
@media (max-width: 1024px) {
font-size: 16px;
}
}
/* ── Dark mode ────────────────────────────────────────────── */
@media (prefers-color-scheme: dark) {
:root {
--text: #9ca3af;
--text-h: #f3f4f6;
--bg: #16171d;
--border: #2e303a;
--code-bg: #1f2028;
--accent: #c084fc;
--accent-bg: rgba(192, 132, 252, 0.15);
--accent-border: rgba(192, 132, 252, 0.5);
--social-bg: rgba(47, 48, 58, 0.5);
--shadow:
rgba(0, 0, 0, 0.4) 0 10px 15px -3px, rgba(0, 0, 0, 0.25) 0 4px 6px -2px;
}
--accent: #818cf8;
--accent-dark: #6366f1;
--accent-light: #a5b4fc;
--accent-bg: rgba(129, 140, 248, 0.12);
--accent-border: rgba(129, 140, 248, 0.35);
#social .button-icon {
filter: invert(1) brightness(2);
--lavender: #a78bfa;
--lavender-bg: rgba(167, 139, 250, 0.12);
--text: #9ca3af;
--text-h: #e0e7ff;
--text-sub: #6b7280;
--bg: #0f0e1a;
--bg-raised: #16152a;
--border: #2e2a5e;
--shadow: rgba(0, 0, 0, 0.5) 0 4px 24px -4px;
}
}
body {
/* ── Reset ────────────────────────────────────────────────── */
*, *::before, *::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
h1,
h2 {
font-family: var(--heading);
font-weight: 500;
html, body, #app {
width: 100%;
height: 100%;
overflow: hidden;
}
/* ── Text hierarchy ───────────────────────────────────────── */
h1 {
font-size: var(--text-2xl);
font-weight: 400;
line-height: 1.15;
letter-spacing: -0.6px;
color: var(--text-h);
}
h1 {
font-size: 56px;
letter-spacing: -1.68px;
margin: 32px 0;
@media (max-width: 1024px) {
font-size: 36px;
margin: 20px 0;
}
}
h2 {
font-size: 24px;
line-height: 118%;
letter-spacing: -0.24px;
margin: 0 0 8px;
@media (max-width: 1024px) {
font-size: 20px;
}
font-size: var(--text-xl);
font-weight: 400;
line-height: 1.2;
letter-spacing: -0.4px;
color: var(--text-h);
}
h3 {
font-size: var(--text-lg);
font-weight: 300;
line-height: 1.3;
color: var(--text-h);
}
h4, h5, h6 {
font-size: var(--text-md);
font-weight: 300;
color: var(--text-h);
}
p {
margin: 0;
color: var(--text);
}
code,
.counter {
font-family: var(--mono);
display: inline-flex;
border-radius: 4px;
color: var(--text-h);
}
code {
font-size: 15px;
line-height: 135%;
padding: 4px 8px;
background: var(--code-bg);
}
.counter {
font-size: 16px;
padding: 5px 10px;
border-radius: 5px;
/* Eyebrow / label style */
.label-xs {
font-size: var(--text-xs);
font-weight: 600;
letter-spacing: 0.1em;
text-transform: uppercase;
color: var(--accent);
background: var(--accent-bg);
border: 2px solid transparent;
transition: border-color 0.3s;
margin-bottom: 24px;
&:hover {
border-color: var(--accent-border);
}
&:focus-visible {
outline: 2px solid var(--accent);
outline-offset: 2px;
}
}
.hero {
position: relative;
.base,
.framework,
.vite {
inset-inline: 0;
margin: 0 auto;
}
.base {
width: 170px;
position: relative;
z-index: 0;
}
.framework,
.vite {
position: absolute;
}
.framework {
z-index: 1;
top: 34px;
height: 28px;
transform: perspective(2000px) rotateZ(300deg) rotateX(44deg) rotateY(39deg)
scale(1.4);
}
.vite {
z-index: 0;
top: 107px;
height: 26px;
width: auto;
transform: perspective(2000px) rotateZ(300deg) rotateX(40deg) rotateY(39deg)
scale(0.8);
}
}
#app {
width: 1126px;
max-width: 100%;
margin: 0 auto;
text-align: center;
border-inline: 1px solid var(--border);
min-height: 100svh;
display: flex;
flex-direction: column;
box-sizing: border-box;
}
#center {
display: flex;
flex-direction: column;
gap: 25px;
place-content: center;
place-items: center;
flex-grow: 1;
@media (max-width: 1024px) {
padding: 32px 20px 24px;
gap: 18px;
}
}
#next-steps {
display: flex;
border-top: 1px solid var(--border);
text-align: left;
& > div {
flex: 1 1 0;
padding: 32px;
@media (max-width: 1024px) {
padding: 24px 20px;
}
}
.icon {
margin-bottom: 16px;
width: 22px;
height: 22px;
}
@media (max-width: 1024px) {
flex-direction: column;
text-align: center;
}
}
#docs {
border-right: 1px solid var(--border);
@media (max-width: 1024px) {
border-right: none;
border-bottom: 1px solid var(--border);
}
}
#next-steps ul {
list-style: none;
padding: 0;
display: flex;
gap: 8px;
margin: 32px 0 0;
.logo {
height: 18px;
}
a {
color: var(--text-h);
font-size: 16px;
border-radius: 6px;
background: var(--social-bg);
display: flex;
padding: 6px 12px;
align-items: center;
gap: 8px;
text-decoration: none;
transition: box-shadow 0.3s;
&:hover {
box-shadow: var(--shadow);
}
.button-icon {
height: 18px;
width: 18px;
}
}
@media (max-width: 1024px) {
margin-top: 20px;
flex-wrap: wrap;
justify-content: center;
li {
flex: 1 1 calc(50% - 8px);
}
a {
width: 100%;
justify-content: center;
box-sizing: border-box;
}
}
}
#spacer {
height: 88px;
border-top: 1px solid var(--border);
@media (max-width: 1024px) {
height: 48px;
}
}
.ticks {
position: relative;
width: 100%;
&::before,
&::after {
content: '';
position: absolute;
top: -4.5px;
border: 5px solid transparent;
}
&::before {
left: 0;
border-left-color: var(--border);
}
&::after {
right: 0;
border-right-color: var(--border);
}
}