start

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
start [2026/06/11 07:47] jumpstartadminstart [2026/06/11 08:33] (current) jumpstartadmin
Line 4: Line 4:
 @font-face { font-family: 'Forevs'; src: url('/wiki/lib/tpl/bootstrap3/fonts/ForevsDemo-Bold.otf') format('opentype'); font-weight: bold; } @font-face { font-family: 'Forevs'; src: url('/wiki/lib/tpl/bootstrap3/fonts/ForevsDemo-Bold.otf') format('opentype'); font-weight: bold; }
  
-.js-wrap { position: fixed; top: 50px; left: 0; width: 100vw; height: calc(100vh - 50px); z-index: 999; display: grid; grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(2, calc(50vh - 25px)); gap: 4px; background: #120F29; }+/* Grid fills full viewport — navbar floats over it */ 
 +.js-wrap { 
 +    position: fixed; 
 +    top: 0; 
 +    left: 0; 
 +    width: 100vw; 
 +    height: 100vh; 
 +    z-index: 999; 
 +    display: grid; 
 +    grid-template-columns: repeat(2, 1fr); 
 +    grid-template-rows: repeat(2, 50vh); 
 +    gap: 4px; 
 +    background: #120F29; 
 +
 + 
 +/* Scanline overlay */ 
 +.js-wrap::after { 
 +    content: ''; 
 +    position: absolute; 
 +    inset: 0; 
 +    z-index: 100; 
 +    pointer-events: none; 
 +    background: repeating-linear-gradient( 
 +        to bottom, 
 +        rgba(0,0,0,0.03) 0px, 
 +        rgba(0,0,0,0.03) 1px, 
 +        transparent 1px, 
 +        transparent 3px 
 +    ); 
 +
 + 
 +/* Edge vignette */ 
 +.js-wrap::before { 
 +    content: ''; 
 +    position: absolute; 
 +    inset: 0; 
 +    z-index: 101; 
 +    pointer-events: none; 
 +    background: 
 +        linear-gradient(to right, rgba(10,6,26,0.7) 0%, transparent 12%, transparent 88%, rgba(10,6,26,0.7) 100%), 
 +        linear-gradient(to bottom, rgba(10,6,26,0.7) 0%, transparent 12%, transparent 88%, rgba(10,6,26,0.7) 100%); 
 +}
  
 .js-card { position: relative; display: block; overflow: hidden; text-decoration: none; } .js-card { position: relative; display: block; overflow: hidden; text-decoration: none; }
Line 20: Line 61:
 .js-card:hover .js-label { top: 88%; transform: translateY(-50%); letter-spacing: 6px; color: #ffffff; } .js-card:hover .js-label { top: 88%; transform: translateY(-50%); letter-spacing: 6px; color: #ffffff; }
  
-/* Title wrapper */ +/* Dark vignette behind title */ 
-.js-title {+.js-title-bg {
     position: fixed;     position: fixed;
-    top: 58px+    top: 50%
-    left: 0+    left: 50%
-    width100%;+    transformtranslate(-50%, -50%); 
 +    width: 600px; 
 +    height: 300px;
     z-index: 1000;     z-index: 1000;
-    text-align: center; 
     pointer-events: none;     pointer-events: none;
-    displayflex; +    backgroundradial-gradient(ellipse at center, rgba(10,6,26,0.92) 0%, rgba(10,6,26,0.6) 45%, transparent 70%)
-    align-items: center; +    animationfadeIn 0.8s ease 0.2s both;
-    justify-content: center; +
-    gap12px;+
 } }
  
-/* Left and right decorative lines */ +/* Title — centered in full viewport */ 
-.js-title-line +.js-title { 
-    height1px+    positionfixed
-    width80px+    top0
-    backgroundlinear-gradient(to right, transparent, rgba(184,173,219,0.6))+    left: 0; 
-    animationexpandLine 1.2s ease both+    width100vw
-} +    height: 100vh; 
- +    z-index: 1002; 
-.js-title-line.right { +    pointer-eventsnone;
-    backgroundlinear-gradient(to left, transparent, rgba(184,173,219,0.6)); +
-+
- +
-/* Main text container */ +
-.js-title-text {+
     display: flex;     display: flex;
     flex-direction: column;     flex-direction: column;
     align-items: center;     align-items: center;
-    gap: 2px;+    justify-content: center; 
 +    gap: 4px; 
 +    animation: floatY 4s ease-in-out infinite;
 } }
  
-/* JUMPSTART — big and bold */ +@keyframes floatY 
-.js-title-top +    0%100% { transform: translateY(0px); } 
-    font-family: 'Forevs'serif; +    50% { transformtranslateY(-8px)}
-    font-weight: bold; +
-    font-size: 1.4em; +
-    letter-spacing: 14px; +
-    text-transform: uppercase; +
-    color: #EDE8F5; +
-    text-shadow: 0 0 30px rgba(107,79,187,0.8), 0 2px 10px rgba(0,0,0,0.9); +
-    animationfadeDown 0.8s ease both, glowPulse 3s 1s ease-in-out infinite;+
 } }
  
-/* MOVEMENT WIKI — smaller and lighter */ +.js-title-sub { font-family: 'Forevs', serif; font-weight: normal; font-size: 0.75em; letter-spacing: 10px; text-transform: uppercase; color: rgba(184,173,219,0.9); text-shadow: 0 2px 10px rgba(0,0,0,0.9); animation: revealUp 0.8s cubic-bezier(0.16,1,0.3,1) 0.6s both; }
-.js-title-bottom { +
-    font-family: 'Forevs', serif; +
-    font-weight: normal; +
-    font-size: 0.75em; +
-    letter-spacing: 8px; +
-    text-transform: uppercase; +
-    color: rgba(184,173,219,0.8); +
-    text-shadow: 0 2px 10px rgba(0,0,0,0.9); +
-    animation: fadeDown 0.8s 0.2s ease both; +
-}+
  
-@keyframes fadeDown { +.js-title-main font-family'Forevs', seriffont-weightbold; font-size: 3.5emletter-spacing8pxtext-transform: uppercase; color: #EDE8F5; line-height: 1; text-shadow: 0 0 60px rgba(107,79,187,0.9), 0 0 20px rgba(107,79,187,0.5), 0 4px 15px rgba(0,0,0,0.9); animation: revealUp 0.9s cubic-bezier(0.16,1,0.3,1) 0.3s both, glowPulse 4s 1.5s ease-in-out infinite; }
-    from { opacity0transformtranslateY(-12px)+
-    to { opacity1; transform: translateY(0); +
-}+
  
-@keyframes expandLine +.js-title-divider display: flex; align-items: center; gap: 10px; margin-top: 4px; animation: fadeIn 0.6s ease 1s both; } 
-    from { width: 0opacity: 0; } +.js-title-divider-line height: 1px; width: 100pxbackgroundlinear-gradient(to right, transparent, rgba(184,173,219,0.6), transparent); } 
-    to { width: 80pxopacity1+.js-title-divider-diamond { width: 5pxheight5px; background: rgba(184,173,219,0.9); transform: rotate(45deg); box-shadow: 0 0 6px rgba(184,173,219,0.8); }
-}+
  
 +/* Particle canvas — full viewport */
 +#js-particles { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; z-index: 1001; pointer-events: none; }
 +
 +@keyframes revealUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
 +@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
 @keyframes glowPulse { @keyframes glowPulse {
-    0%, 100% { text-shadow: 0 0 30px rgba(107,79,187,0.8), 0 2px 10px rgba(0,0,0,0.9);+    0%, 100% { text-shadow: 0 0 60px rgba(107,79,187,0.9), 0 0 20px rgba(107,79,187,0.5), 0 4px 15px rgba(0,0,0,0.9);
-    50% { text-shadow: 0 0 50px rgba(107,79,187,1), 0 0 20px rgba(184,173,219,0.5),2px 10px rgba(0,0,0,0.9); }+    50% { text-shadow: 0 0 90px rgba(107,79,187,1), 0 0 40px rgba(184,173,219,0.5),4px 15px rgba(0,0,0,0.9); }
 } }
- 
 @keyframes fadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } } @keyframes fadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
  
Line 101: Line 121:
 .js-card:nth-child(4) { animation: fadeUp 0.6s 0.45s ease both; } .js-card:nth-child(4) { animation: fadeUp 0.6s 0.45s ease both; }
 </style> </style>
 +
 +<div class="js-title-bg"></div>
  
 <div class="js-title"> <div class="js-title">
-    <div class="js-title-line left"></div> +    <div class="js-title-sub">Movement Wiki</div> 
-    <div class="js-title-text"> +    <div class="js-title-main">JumpStart</div> 
-        <div class="js-title-top">JumpStart</div> +    <div class="js-title-divider"> 
-        <div class="js-title-bottom">Movement Wiki</div>+        <div class="js-title-divider-line"></div> 
 +        <div class="js-title-divider-diamond"></div> 
 +        <div class="js-title-divider-line"></div>
     </div>     </div>
-    <div class="js-title-line right"></div> 
 </div> </div>
 +
 +<canvas id="js-particles"></canvas>
  
 <div class="js-wrap"> <div class="js-wrap">
Line 146: Line 171:
  
 </div> </div>
 +
 +<script>
 +const canvas = document.getElementById('js-particles');
 +const ctx = canvas.getContext('2d');
 +canvas.width = window.innerWidth;
 +canvas.height = window.innerHeight;
 +
 +const cx = canvas.width / 2;
 +const cy = canvas.height / 2;
 +const particles = [];
 +
 +function randomRange(a, b) { return a + Math.random() * (b - a); }
 +
 +for (let i = 0; i < 60; i++) {
 +    particles.push({
 +        x: cx + randomRange(-180, 180),
 +        y: cy + randomRange(-80, 80),
 +        vx: randomRange(-0.3, 0.3),
 +        vy: randomRange(-0.8, -0.2),
 +        size: randomRange(1, 2.5),
 +        alpha: randomRange(0.4, 1),
 +        fade: randomRange(0.003, 0.008),
 +        color: Math.random() > 0.5 ? '184,173,219' : '107,79,187'
 +    });
 +}
 +
 +function resetParticle(p) {
 +    p.x = cx + randomRange(-180, 180);
 +    p.y = cy + randomRange(-80, 80);
 +    p.vx = randomRange(-0.3, 0.3);
 +    p.vy = randomRange(-0.8, -0.2);
 +    p.alpha = randomRange(0.4, 1);
 +    p.size = randomRange(1, 2.5);
 +    p.fade = randomRange(0.003, 0.008);
 +}
 +
 +function draw() {
 +    ctx.clearRect(0, 0, canvas.width, canvas.height);
 +    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, p.y, p.size, 0, Math.PI * 2);
 +        ctx.fillStyle = `rgba(${p.color},${p.alpha})`;
 +        ctx.fill();
 +    });
 +    requestAnimationFrame(draw);
 +}
 +
 +draw();
 +
 +window.addEventListener('resize', () => {
 +    canvas.width = window.innerWidth;
 +    canvas.height = window.innerHeight;
 +});
 +</script>
 </html> </html>
  • start.1781164072.txt.gz
  • Last modified: 2026/06/11 07:47
  • by jumpstartadmin