-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.html
More file actions
119 lines (117 loc) · 11 KB
/
index.html
File metadata and controls
119 lines (117 loc) · 11 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Echoes in the Code</title>
<script src="https://cdn.tailwindcss.com"></script>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Cinzel:wght@700&family=Major+Mono+Display&family=Roboto+Mono:wght@400;700&family=Source+Serif+4:opsz,wght@8..60,400;700&display=swap" rel="stylesheet">
<style>
body {
font-family: 'Source Serif 4', serif;
}
.font-roboto-mono {
font-family: 'Roboto Mono', monospace;
}
.font-major-mono {
font-family: 'Major Mono Display', monospace;
}
.font-cinzel {
font-family: 'Cinzel', serif;
}
.text-glow {
text-shadow: 0 0 8px rgba(226, 232, 255, 0.3), 0 0 2px rgba(230, 230, 255, 0.5);
}
@keyframes fade-in-up {
from { opacity: 0; transform: translateY(10px); }
to { opacity: 1; transform: translateY(0); }
}
.fade-in-up {
animation: fade-in-up 0.5s ease-out forwards;
}
@keyframes glitch {
0% { transform: translate(0); }
20% { transform: translate(-3px, 3px); }
40% { transform: translate(-3px, -3px); }
60% { transform: translate(3px, 3px); }
80% { transform: translate(3px, -3px); }
100% { transform: translate(0); }
}
.glitch-active {
animation: glitch 0.2s infinite;
}
.glitch-text-shadow {
text-shadow: -1px -1px 0px rgba(255,0,0,0.5), 1px 1px 0px rgba(0,255,0,0.5), -2px -2px 0px rgba(0,0,255,0.5);
}
/* Intro Styles */
@keyframes slide-fade-in {
from { opacity: 0; }
to { opacity: 1; }
}
.slide-active {
display: block;
animation: slide-fade-in 1.5s ease-in-out;
}
.slide-hidden {
display: none;
}
/* Attunement VFX */
@keyframes vfx-flora {
0% { background: radial-gradient(circle, rgba(74, 222, 128, 0.3) 0%, rgba(74, 222, 128, 0) 70%); transform: scale(0); opacity: 0;}
50% { opacity: 1; }
100% { background: radial-gradient(circle, rgba(74, 222, 128, 0.3) 0%, rgba(74, 222, 128, 0) 70%); transform: scale(2); opacity: 0;}
}
@keyframes vfx-materia {
0% { background: radial-gradient(circle, rgba(147, 112, 219, 0.3) 0%, rgba(147, 112, 219, 0) 70%); transform: scale(0); opacity: 0;}
50% { opacity: 1; }
100% { background: radial-gradient(circle, rgba(147, 112, 219, 0.3) 0%, rgba(147, 112, 219, 0) 70%); transform: scale(2); opacity: 0;}
}
@keyframes vfx-aether {
0% { background: radial-gradient(circle, rgba(99, 102, 241, 0.3) 0%, rgba(99, 102, 241, 0) 70%); transform: scale(0); opacity: 0;}
50% { opacity: 1; }
100% { background: radial-gradient(circle, rgba(99, 102, 241, 0.3) 0%, rgba(99, 102, 241, 0) 70%); transform: scale(2); opacity: 0;}
}
.vfx-flora-active { animation: vfx-flora 1.2s ease-out forwards; }
.vfx-materia-active { animation: vfx-materia 1.2s ease-out forwards; }
.vfx-aether-active { animation: vfx-aether 1.2s ease-out forwards; }
/* Reality Strain VFX */
@keyframes static-flicker {
0%, 100% { opacity: 0.05; }
50% { opacity: 0.15; }
}
.reality-strain-effect {
pointer-events: none;
position: fixed;
inset: 0;
z-index: 50;
background: radial-gradient(ellipse at center, rgba(0,0,0,0) 50%, rgba(10, 0, 20, 0.8) 100%);
opacity: 0;
transition: opacity 1s ease-in-out;
}
.reality-strain-effect::after {
content: '';
position: absolute;
inset: 0;
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAMAAAAp4XiDAAAAUVBMVEWFhYWDg4N3d3dtbW17e3t1dXVpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpaWlpAW3yAAAAVklEQVR42tSQRwAIMwzD2f8yQEOJkI2RjN7fud3D5/vLz8f5+X2/f58/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f78/L7/f7...'});
animation: static-flicker 2s infinite steps(1);
}
</style>
<script type="importmap">
{
"imports": {
"react": "https://esm.sh/react@^19.1.1",
"react-dom/": "https://esm.sh/react-dom@^19.1.1/",
"react/": "https://esm.sh/react@^19.1.1/",
"@google/genai": "https://esm.sh/@google/genai@^1.12.0"
}
}
</script>
<link rel="stylesheet" href="/index.css">
</head>
<body class="bg-slate-900 text-slate-200">
<div id="root"></div>
<script type="module" src="/index.tsx"></script>
</body>
</html>