*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden;background:#080c08}.canvas-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;cursor:grab}.canvas-container:active{cursor:grabbing}.canvas-container canvas{display:block}.skip-link{position:fixed;top:-100px;left:16px;z-index:100;padding:8px 16px;background:#080c08;color:#ffffffe6;font-family:Courier Prime,monospace;font-size:12px;border:1px solid rgba(255,255,255,.3);border-radius:3px;text-decoration:none;transition:top .2s ease}.skip-link:focus{top:16px}.ui-top-left{position:fixed;top:40px;left:40px;font-family:Courier Prime,monospace;font-size:10px;letter-spacing:4px;color:#ffffff73;z-index:10;-webkit-user-select:none;user-select:none}.ui-top-center{position:fixed;top:40px;left:50%;transform:translate(-50%);font-family:Playfair Display,serif;font-size:13px;font-variant:small-caps;letter-spacing:3px;color:#ffffff8c;z-index:10;-webkit-user-select:none;user-select:none}.ui-view-toggle{position:fixed;top:68px;left:50%;transform:translate(-50%);display:flex;gap:0;z-index:10;-webkit-user-select:none;user-select:none}.toggle-btn{background:none;border:1px solid rgba(255,255,255,.12);color:#ffffff4d;font-family:Courier Prime,monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;cursor:pointer;transition:color .4s ease,border-color .4s ease,background-color .4s ease}.toggle-btn:first-child{border-radius:3px 0 0 3px}.toggle-btn:last-child{border-radius:0 3px 3px 0;border-left:none}.toggle-btn:hover{color:#ffffff80;border-color:#ffffff40}.toggle-btn.active{background:#ffffff0f}.discovery-hud{position:fixed;top:100px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;z-index:10;-webkit-user-select:none;user-select:none}.discovery-progress-bar{width:120px;height:2px;background:#ffffff14;border-radius:1px;overflow:hidden}.discovery-progress-fill{height:100%;border-radius:1px;transition:width .8s cubic-bezier(.4,0,.2,1),background-color .5s ease,box-shadow .5s ease}.discovery-stats{display:flex;gap:12px;align-items:center}.discovery-count{font-family:Courier Prime,monospace;font-size:9px;letter-spacing:1px;color:#ffffff59}.discovery-xp{font-family:Courier Prime,monospace;font-size:9px;letter-spacing:1px;color:#ffffff40}.ui-right-rail{position:fixed;right:40px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:24px;z-index:10;-webkit-user-select:none;user-select:none}button.rail-item{background:none;border:none;padding:0;font:inherit;text-align:left}.rail-item{display:flex;align-items:center;gap:12px;cursor:pointer}.rail-item:hover .rail-label{opacity:.65}.rail-item:hover .rail-dash{width:18px!important}.rail-dash{display:block;height:1px;transition:width .5s ease,background-color .5s ease}.rail-label{font-family:Courier Prime,monospace;font-size:10px;letter-spacing:2px;text-transform:uppercase;white-space:nowrap;transition:color .5s ease}.ui-depth-line{position:fixed;left:20px;top:10%;bottom:10%;width:1px;background:#ffffff14;z-index:10}.depth-dot{position:absolute;left:-3px;width:7px;height:7px;border-radius:50%;transition:top .6s cubic-bezier(.4,0,.2,1),background-color .5s ease,box-shadow .5s ease}.ui-bottom-left{position:fixed;bottom:48px;left:40px;display:flex;gap:20px;z-index:10;animation:fadeSlideUp .6s ease-out;-webkit-user-select:none;user-select:none}.info-rule{width:2px;align-self:stretch;border-radius:1px;transition:background-color .5s ease}.info-content{display:flex;flex-direction:column;gap:8px}.info-era{font-family:Playfair Display,serif;font-size:30px;font-weight:500;color:#ffffffe0;line-height:1.1}.info-quote{font-family:Playfair Display,serif;font-style:italic;font-size:13px;line-height:1.5;transition:color .5s ease}.info-detail{font-family:Courier Prime,monospace;font-size:11px;color:#ffffff61;letter-spacing:.5px}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ui-bottom-right{position:fixed;bottom:48px;right:40px;font-family:Courier Prime,monospace;font-size:9px;letter-spacing:1px;color:#ffffff4d;z-index:10;-webkit-user-select:none;user-select:none}.artifact-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;background:#080c08b3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.particle-burst-container{position:absolute;top:50%;left:50%;width:0;height:0;pointer-events:none;z-index:21}.burst-particle{position:absolute;border-radius:50%;pointer-events:none}.artifact-card{position:relative;max-width:420px;width:90%;padding:40px 32px 32px;background:#101410f5;border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:hidden}.artifact-close{position:absolute;top:12px;right:16px;background:none;border:none;color:#fff6;font-size:24px;cursor:pointer;line-height:1;padding:4px 8px;transition:color .3s ease;z-index:2}.artifact-close:hover{color:#fffc}.discovery-badge{font-family:Courier Prime,monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;text-align:center;padding:10px 0 0;animation:badgePulse 1.5s ease-in-out infinite}@keyframes badgePulse{0%,to{opacity:1}50%{opacity:.5}}.artifact-viewer{width:100%;height:200px;margin-bottom:16px;border-radius:4px;overflow:hidden;background:radial-gradient(ellipse at center,#1e231ecc,#080c08f2)}.artifact-viewer canvas{display:block;width:100%!important;height:200px!important}.artifact-accent{width:32px;height:2px;border-radius:1px;margin-bottom:16px}.artifact-name{font-family:Playfair Display,serif;font-size:22px;font-weight:500;margin-bottom:12px}.artifact-desc{font-family:Courier Prime,monospace;font-size:12px;line-height:1.7;color:#ffffff8c;letter-spacing:.3px;margin-bottom:16px}.artifact-footer{display:flex;align-items:center;justify-content:space-between}.artifact-layer{font-family:Courier Prime,monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:#ffffff40}.artifact-xp{font-family:Courier Prime,monospace;font-size:11px;font-weight:700;letter-spacing:2px;animation:xpPop .5s ease-out}@keyframes xpPop{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.3);opacity:1}to{transform:scale(1);opacity:1}}.achievement-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);z-index:30;display:flex;align-items:center;gap:14px;padding:14px 24px;background:#101410f2;border:1px solid rgba(255,255,255,.12);border-radius:6px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:toastSlideUp .6s cubic-bezier(.16,1,.3,1),toastFadeOut .5s ease-in 3s forwards}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%) translateY(30px) scale(.9)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes toastFadeOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-10px)}}.achievement-icon{font-size:24px;color:#c8b99a;animation:iconSpin .8s ease-out}@keyframes iconSpin{0%{transform:rotate(-180deg) scale(.3);opacity:0}to{transform:rotate(0) scale(1);opacity:1}}.achievement-text{display:flex;flex-direction:column;gap:2px}.achievement-label{font-family:Courier Prime,monospace;font-size:8px;letter-spacing:3px;text-transform:uppercase;color:#ffffff59}.achievement-name{font-family:Playfair Display,serif;font-size:16px;font-weight:500;color:#ffffffe0}.achievement-desc{font-family:Courier Prime,monospace;font-size:10px;color:#fff6;letter-spacing:.3px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.toggle-btn:focus-visible,.rail-item:focus-visible,.artifact-close:focus-visible{outline:2px solid rgba(255,255,255,.6);outline-offset:2px}@media (prefers-reduced-motion: reduce){.ui-bottom-left,.artifact-card,.artifact-overlay,.achievement-toast,.discovery-badge,.artifact-xp,.achievement-icon{animation:none!important}.rail-dash,.depth-dot,.toggle-btn,.info-rule,.info-quote,.rail-label,.artifact-close,.skip-link,.discovery-progress-fill{transition:none!important}}
