Differences
This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision Next revision | Previous revision | ||
| start [2026/06/11 07:47] – jumpstartadmin | start [2026/06/11 08:33] (current) – jumpstartadmin | ||
|---|---|---|---|
| Line 4: | Line 4: | ||
| @font-face { font-family: | @font-face { font-family: | ||
| - | .js-wrap { position: fixed; top: 50px; left: 0; width: 100vw; height: | + | /* Grid fills full viewport — navbar floats over it */ |
| + | .js-wrap { | ||
| + | | ||
| + | | ||
| + | | ||
| + | | ||
| + | | ||
| + | | ||
| + | | ||
| + | | ||
| + | | ||
| + | | ||
| + | | ||
| + | } | ||
| + | |||
| + | /* Scanline overlay */ | ||
| + | .js-wrap:: | ||
| + | content: ''; | ||
| + | position: absolute; | ||
| + | inset: 0; | ||
| + | z-index: 100; | ||
| + | pointer-events: | ||
| + | background: repeating-linear-gradient( | ||
| + | to bottom, | ||
| + | rgba(0, | ||
| + | rgba(0, | ||
| + | transparent 1px, | ||
| + | transparent 3px | ||
| + | ); | ||
| + | } | ||
| + | |||
| + | /* Edge vignette */ | ||
| + | .js-wrap:: | ||
| + | content: ''; | ||
| + | position: absolute; | ||
| + | inset: 0; | ||
| + | z-index: 101; | ||
| + | pointer-events: | ||
| + | background: | ||
| + | linear-gradient(to right, rgba(10, | ||
| + | linear-gradient(to bottom, rgba(10, | ||
| + | } | ||
| .js-card { position: relative; display: block; overflow: hidden; text-decoration: | .js-card { position: relative; display: block; overflow: hidden; text-decoration: | ||
| Line 20: | Line 61: | ||
| .js-card: | .js-card: | ||
| - | /* Title wrapper | + | /* Dark vignette behind title */ |
| - | .js-title { | + | .js-title-bg { |
| position: fixed; | position: fixed; | ||
| - | top: 58px; | + | top: 50%; |
| - | left: 0; | + | left: 50%; |
| - | | + | |
| + | width: 600px; | ||
| + | height: 300px; | ||
| z-index: 1000; | z-index: 1000; | ||
| - | text-align: center; | ||
| pointer-events: | pointer-events: | ||
| - | | + | |
| - | align-items: center; | + | |
| - | justify-content: | + | |
| - | | + | |
| } | } | ||
| - | /* Left and right decorative lines */ | + | /* Title — centered in full viewport |
| - | .js-title-line { | + | .js-title { |
| - | | + | |
| - | | + | |
| - | | + | |
| - | | + | |
| - | } | + | |
| - | + | z-index: 1002; | |
| - | .js-title-line.right { | + | |
| - | | + | |
| - | } | + | |
| - | + | ||
| - | /* Main text container */ | + | |
| - | .js-title-text { | + | |
| display: flex; | display: flex; | ||
| flex-direction: | flex-direction: | ||
| align-items: | align-items: | ||
| - | gap: 2px; | + | |
| + | | ||
| + | animation: floatY 4s ease-in-out infinite; | ||
| } | } | ||
| - | /* JUMPSTART — big and bold */ | + | @keyframes floatY |
| - | .js-title-top | + | |
| - | | + | |
| - | font-weight: | + | |
| - | font-size: 1.4em; | + | |
| - | letter-spacing: | + | |
| - | text-transform: | + | |
| - | color: #EDE8F5; | + | |
| - | text-shadow: | + | |
| - | | + | |
| } | } | ||
| - | /* MOVEMENT WIKI — smaller and lighter */ | + | .js-title-sub { font-family: |
| - | .js-title-bottom | + | |
| - | | + | |
| - | | + | |
| - | | + | |
| - | | + | |
| - | | + | |
| - | | + | |
| - | | + | |
| - | | + | |
| - | } | + | |
| - | @keyframes fadeDown | + | .js-title-main |
| - | from { opacity: 0; transform: translateY(-12px); } | + | |
| - | to { opacity: 1; transform: | + | |
| - | } | + | |
| - | @keyframes expandLine | + | .js-title-divider |
| - | | + | .js-title-divider-line |
| - | | + | .js-title-divider-diamond |
| - | } | + | |
| + | /* Particle canvas — full viewport */ | ||
| + | # | ||
| + | |||
| + | @keyframes revealUp { from { opacity: 0; transform: translateY(20px); | ||
| + | @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } } | ||
| @keyframes glowPulse { | @keyframes glowPulse { | ||
| - | 0%, 100% { text-shadow: | + | 0%, 100% { text-shadow: |
| - | 50% { text-shadow: | + | 50% { text-shadow: |
| } | } | ||
| - | |||
| @keyframes fadeUp { from { opacity: 0; transform: translateY(24px); | @keyframes fadeUp { from { opacity: 0; transform: translateY(24px); | ||
| Line 101: | Line 121: | ||
| .js-card: | .js-card: | ||
| </ | </ | ||
| + | |||
| + | <div class=" | ||
| <div class=" | <div class=" | ||
| - | <div class=" | + | <div class=" |
| - | <div class=" | + | <div class=" |
| - | <div class=" | + | <div class=" |
| - | <div class=" | + | <div class=" |
| + | <div class=" | ||
| + | <div class=" | ||
| </ | </ | ||
| - | <div class=" | ||
| </ | </ | ||
| + | |||
| + | <canvas id=" | ||
| <div class=" | <div class=" | ||
| Line 146: | Line 171: | ||
| </ | </ | ||
| + | |||
| + | < | ||
| + | const canvas = document.getElementById(' | ||
| + | const ctx = canvas.getContext(' | ||
| + | canvas.width = window.innerWidth; | ||
| + | canvas.height = window.innerHeight; | ||
| + | |||
| + | const cx = canvas.width / 2; | ||
| + | const cy = canvas.height / 2; | ||
| + | const particles = []; | ||
| + | |||
| + | function randomRange(a, | ||
| + | |||
| + | for (let i = 0; i < 60; i++) { | ||
| + | particles.push({ | ||
| + | x: cx + randomRange(-180, | ||
| + | y: cy + randomRange(-80, | ||
| + | vx: randomRange(-0.3, | ||
| + | vy: randomRange(-0.8, | ||
| + | size: randomRange(1, | ||
| + | alpha: randomRange(0.4, | ||
| + | fade: randomRange(0.003, | ||
| + | color: Math.random() > 0.5 ? ' | ||
| + | }); | ||
| + | } | ||
| + | |||
| + | function resetParticle(p) { | ||
| + | p.x = cx + randomRange(-180, | ||
| + | p.y = cy + randomRange(-80, | ||
| + | p.vx = randomRange(-0.3, | ||
| + | p.vy = randomRange(-0.8, | ||
| + | p.alpha = randomRange(0.4, | ||
| + | p.size = randomRange(1, | ||
| + | p.fade = randomRange(0.003, | ||
| + | } | ||
| + | |||
| + | function draw() { | ||
| + | ctx.clearRect(0, | ||
| + | particles.forEach(p => { | ||
| + | p.x += p.vx; | ||
| + | p.y += p.vy; | ||
| + | p.alpha -= p.fade; | ||
| + | if (p.alpha <= 0) resetParticle(p); | ||
| + | ctx.beginPath(); | ||
| + | ctx.arc(p.x, | ||
| + | ctx.fillStyle = `rgba(${p.color}, | ||
| + | ctx.fill(); | ||
| + | }); | ||
| + | requestAnimationFrame(draw); | ||
| + | } | ||
| + | |||
| + | draw(); | ||
| + | |||
| + | window.addEventListener(' | ||
| + | canvas.width = window.innerWidth; | ||
| + | canvas.height = window.innerHeight; | ||
| + | }); | ||
| + | </ | ||
| </ | </ | ||