*{margin:0;padding:0}html,body{overflow:hidden;background:#171a1c}.webgl{position:fixed;top:0;left:0;outline:none;opacity:0;transition:opacity .8s ease-out}.webgl.loaded{opacity:1}.loader{position:fixed;top:0;left:0;width:100%;height:100%;background:#171a1c;display:flex;align-items:center;justify-content:center;z-index:100;transition:opacity .6s ease-out,visibility .6s ease-out}.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}.loader-content{display:flex;flex-direction:column;align-items:center;gap:40px}.loader-halftone{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(3,1fr);gap:8px;padding:20px}.dot{width:12px;height:12px;border-radius:50%;background:#8a8685;animation:halftoneWave 2s ease-in-out infinite;will-change:transform,opacity}.dot:nth-child(1){animation-delay:0s;background:#5a5857}.dot:nth-child(2){animation-delay:.08s;background:#6a6867}.dot:nth-child(3){animation-delay:.16s;background:#7033ff}.dot:nth-child(4){animation-delay:.24s;background:#6a6867}.dot:nth-child(5){animation-delay:.32s;background:#5a5857}.dot:nth-child(6){animation-delay:.1s;background:#7a7877}.dot:nth-child(7){animation-delay:.18s;background:#7033ff}.dot:nth-child(8){animation-delay:.26s;background:#9055ff}.dot:nth-child(9){animation-delay:.34s;background:#7033ff}.dot:nth-child(10){animation-delay:.42s;background:#7a7877}.dot:nth-child(11){animation-delay:.2s;background:#8a8685}.dot:nth-child(12){animation-delay:.28s;background:#9a9695}.dot:nth-child(13){animation-delay:.36s;background:#c4c4c4}.dot:nth-child(14){animation-delay:.44s;background:#9a9695}.dot:nth-child(15){animation-delay:.52s;background:#8a8685}@keyframes halftoneWave{0%,to{transform:scale(.5);opacity:.3}50%{transform:scale(1.2);opacity:1}}.loader-bottom{display:flex;flex-direction:column;align-items:center;gap:16px}.loader-progress{width:180px;height:3px;background:#ffffff14;border-radius:2px;overflow:hidden}.loader-bar{width:0%;height:100%;background:linear-gradient(90deg,#7033ff,#9055ff,#c4c4c4);border-radius:2px;transition:width .3s ease-out;box-shadow:0 0 10px #7033ff66}.loader-percentage{font-family:SF Mono,Monaco,Inconsolata,Consolas,monospace;font-size:13px;color:#ffffff80;letter-spacing:3px;font-weight:300}.vignette{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;background:radial-gradient(ellipse at center,transparent 40%,rgba(10,12,14,.5) 100%);z-index:1;opacity:0;transition:opacity .8s ease-out}.vignette.visible{opacity:1}.particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2;overflow:hidden}.particle{position:absolute;border-radius:50%;opacity:0;animation:floatUp 12s ease-in-out infinite;will-change:transform,opacity;contain:strict}.particle:nth-child(1){left:8%;width:8px;height:8px;animation-delay:0s;background:#7033ff99}.particle:nth-child(2){left:18%;width:6px;height:6px;animation-delay:1.5s;background:#8a868580}.particle:nth-child(3){left:28%;width:10px;height:10px;animation-delay:3s;background:#7033ff80}.particle:nth-child(4){left:38%;width:5px;height:5px;animation-delay:4.5s;background:#c4c4c499}.particle:nth-child(5){left:48%;width:7px;height:7px;animation-delay:6s;background:#7033ff8c}.particle:nth-child(6){left:58%;width:9px;height:9px;animation-delay:7.5s;background:#8a868580}.particle:nth-child(7){left:68%;width:6px;height:6px;animation-delay:.8s;background:#7033ff99}.particle:nth-child(8){left:78%;width:8px;height:8px;animation-delay:2.3s;background:#c4c4c480}.particle:nth-child(9){left:88%;width:7px;height:7px;animation-delay:3.8s;background:#7033ff8c}.particle:nth-child(10){left:13%;width:5px;height:5px;animation-delay:5.3s;background:#8a868599}.particle:nth-child(11){left:33%;width:8px;height:8px;animation-delay:6.8s;background:#7033ff80}.particle:nth-child(12){left:73%;width:6px;height:6px;animation-delay:8.3s;background:#c4c4c48c}@keyframes floatUp{0%{transform:translateY(100vh) scale(.3);opacity:0}15%{opacity:1}85%{opacity:1}to{transform:translateY(-10vh) scale(1);opacity:0}}.corner-accent{position:fixed;width:100px;height:100px;pointer-events:none;z-index:3;opacity:0;transition:opacity .8s ease-out .5s}.corner-accent.visible{opacity:1}.corner-accent.top-left{top:20px;left:20px;border-top:1px solid rgba(138,134,133,.3);border-left:1px solid rgba(138,134,133,.3)}.corner-accent.top-right{top:20px;right:20px;border-top:1px solid rgba(112,51,255,.3);border-right:1px solid rgba(112,51,255,.3)}.corner-accent.bottom-left{bottom:20px;left:20px;border-bottom:1px solid rgba(196,196,196,.3);border-left:1px solid rgba(196,196,196,.3)}.corner-accent.bottom-right{bottom:20px;right:20px;border-bottom:1px solid rgba(112,51,255,.3);border-right:1px solid rgba(112,51,255,.3)}
