@import"https://fonts.googleapis.com/css2?family=Press+Start+2P&family=MedievalSharp&family=Share+Tech+Mono&display=swap";@import"https://fonts.googleapis.com/css2?family=Press+Start+2P&family=Share+Tech+Mono&display=swap";@property --angle{syntax: "<angle>"; initial-value: 0deg; inherits: false;}:root{--gold: #f0c040;--gold-bright: #ffe566;--gold-dark: #b8860b;--gold-glow: rgba(240, 192, 64, .55);--ember: #ff6b2b;--cyan: #00e5ff;--text-normal: #d4c8f0;--text-dim: #4a3a6a;--fp: "Press Start 2P", monospace;--fm: "Share Tech Mono", monospace}.ts{width:100%;min-height:100vh;background:radial-gradient(ellipse at 50% 45%,#1c0f38,#0d0918 58%,#060610);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:40px 24px 60px;gap:0}.ts-aurora{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.ts-ab{position:absolute;left:-20%;width:140%;height:220px;border-radius:50%;filter:blur(70px);opacity:0;animation:ts-aurora 12s ease-in-out infinite}.ts-ab:nth-child(1){top:5%;background:linear-gradient(90deg,transparent,rgba(100,30,210,.22),rgba(55,15,155,.26),transparent);animation-duration:14s}.ts-ab:nth-child(2){top:30%;background:linear-gradient(90deg,transparent,rgba(240,192,64,.08),rgba(175,55,255,.13),transparent);animation-delay:-5s;animation-duration:11s}.ts-ab:nth-child(3){bottom:5%;background:linear-gradient(90deg,transparent,rgba(255,107,43,.07),rgba(100,40,200,.1),transparent);animation-delay:-9s;animation-duration:17s}@keyframes ts-aurora{0%{opacity:0;transform:translate(-10%) scaleY(.8)}25%{opacity:1}75%{opacity:.85}to{opacity:0;transform:translate(10%) scaleY(1.2)}}.ts-grid{position:absolute;bottom:0;left:-10%;width:120%;height:40%;pointer-events:none;z-index:1;background:linear-gradient(rgba(240,192,64,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(240,192,64,.055) 1px,transparent 1px);background-size:54px 54px;transform:perspective(520px) rotateX(65deg);transform-origin:bottom center;animation:ts-gpulse 4s ease-in-out infinite;mask-image:linear-gradient(to bottom,transparent,rgba(0,0,0,.4) 28%,black);-webkit-mask-image:linear-gradient(to bottom,transparent,rgba(0,0,0,.4) 28%,black)}@keyframes ts-gpulse{0%,to{opacity:.5}50%{opacity:1}}.ts-scanlines{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.055) 3px,rgba(0,0,0,.055) 4px)}.ts-vignette{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:3;background:radial-gradient(ellipse at center,transparent 28%,rgba(0,0,0,.4) 68%,rgba(0,0,0,.88) 100%)}.ts-stars{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1}.ts-star{position:absolute;border-radius:50%;background:#f0f0ff;animation:ts-twinkle var(--td, 3s) steps(3) var(--dl, 0s) infinite}@keyframes ts-twinkle{0%,to{opacity:var(--op, .8);transform:scale(1)}33%{opacity:.05;transform:scale(.5)}66%{opacity:.5;transform:scale(1.2)}}.ts-particle{position:absolute;border-radius:50%;width:3px;height:3px;pointer-events:none;z-index:2;opacity:0;animation:ts-prise var(--pd, 8s) linear var(--pdl, 0s) infinite}@keyframes ts-prise{0%{transform:translate(0) scale(1);opacity:0}8%{opacity:.85}90%{opacity:.2}to{transform:translate(var(--px, 20px),-100vh) scale(.2);opacity:0}}.ts-dragon{position:absolute;top:14px;right:20px;font-size:clamp(60px,8vw,110px);opacity:.07;pointer-events:none;z-index:2;-webkit-user-select:none;user-select:none;filter:sepia(1) hue-rotate(260deg) saturate(2.2) brightness(1.5);animation:ts-dfloat 5.5s ease-in-out infinite}.ts-dragon-2{position:absolute;bottom:80px;left:8px;font-size:clamp(36px,4.5vw,64px);opacity:.04;pointer-events:none;z-index:2;-webkit-user-select:none;user-select:none;filter:sepia(1) hue-rotate(200deg) saturate(3);animation:ts-dfloat2 7s ease-in-out 2s infinite}@keyframes ts-dfloat{0%,to{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-16px) rotate(2deg)}}@keyframes ts-dfloat2{0%,to{transform:scaleX(-1) translateY(0) rotate(3deg)}50%{transform:scaleX(-1) translateY(-12px) rotate(-2deg)}}.ta{opacity:0;animation:ts-fsu .75s cubic-bezier(.22,1,.36,1) forwards}.d1{animation-delay:.1s}.d2{animation-delay:.3s}.d3{animation-delay:.52s}.d4{animation-delay:.72s}.d5{animation-delay:.92s}.d6{animation-delay:1.12s}.d7{animation-delay:1.32s}@keyframes ts-fsu{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.ts-content{display:flex;flex-direction:column;align-items:center;gap:22px;max-width:680px;width:100%;z-index:10;position:relative}.ts-header{font-family:var(--fm);font-size:clamp(7px,1.1vw,10px);letter-spacing:8px;color:var(--gold-dark);text-transform:uppercase}.ts-header em{color:var(--gold);font-style:normal;animation:ts-bkbr 2.8s step-end infinite}@keyframes ts-bkbr{0%,72%,to{opacity:1}76%{opacity:.1}}.ts-logo-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}.ts-title{font-family:var(--fp);font-size:clamp(20px,4.2vw,48px);letter-spacing:2px;line-height:1.25;text-align:center;color:var(--gold);position:relative;image-rendering:pixelated;text-shadow:2px 2px 0 #c8930a,4px 4px 0 #9c6600,6px 6px 0 #6e4200,8px 8px 0 #3e2200,10px 10px 0 #1a0e00,0 0 22px rgba(240,192,64,.3),0 0 55px rgba(240,192,64,.14);animation:ts-titleglow 3.5s ease-in-out infinite}@keyframes ts-titleglow{0%,to{text-shadow:2px 2px 0 #c8930a,4px 4px 0 #9c6600,6px 6px 0 #6e4200,8px 8px 0 #3e2200,10px 10px 0 #1a0e00,0 0 22px rgba(240,192,64,.3),0 0 55px rgba(240,192,64,.14)}50%{text-shadow:2px 2px 0 #c8930a,4px 4px 0 #9c6600,6px 6px 0 #6e4200,8px 8px 0 #3e2200,10px 10px 0 #1a0e00,0 0 32px rgba(240,192,64,.65),0 0 80px rgba(240,192,64,.3),0 0 120px rgba(240,192,64,.1)}}.ts-title:before{content:attr(data-text);position:absolute;top:0;left:0;width:100%;font:inherit;color:var(--cyan);text-shadow:none;clip-path:polygon(0 0,100% 0,100% 36%,0 36%);animation:ts-gtop 8s steps(1) infinite}.ts-title:after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;font:inherit;color:var(--ember);text-shadow:none;clip-path:polygon(0 64%,100% 64%,100% 100%,0 100%);animation:ts-gbot 8s steps(1) .6s infinite}@keyframes ts-gtop{0%,84%,to{opacity:0;transform:translate(0)}85%{opacity:.88;transform:translate(-5px,-2px)}87%{opacity:.88;transform:translate(5px,1px)}89%{opacity:0;transform:translate(0)}}@keyframes ts-gbot{0%,87%,to{opacity:0;transform:translate(0)}88%{opacity:.78;transform:translate(5px,2px)}90%{opacity:.78;transform:translate(-4px,-1px)}92%{opacity:0;transform:translate(0)}}.ts-subtitle{font-family:var(--fp);font-size:clamp(4px,.85vw,7px);letter-spacing:7px;color:var(--text-dim)}.ts-px-line{width:100%;max-width:400px;height:4px;background:linear-gradient(90deg,transparent,var(--gold-dark) 20%,var(--gold) 50%,var(--gold-dark) 80%,transparent);position:relative;animation:ts-lshimmer 3s ease-in-out infinite}.ts-px-line:before,.ts-px-line:after{content:"";position:absolute;top:-4px;width:4px;height:4px;background:var(--gold);box-shadow:0 0 8px var(--gold-glow)}.ts-px-line:before{left:20%}.ts-px-line:after{right:20%}@keyframes ts-lshimmer{0%,to{opacity:.5}50%{opacity:1;box-shadow:0 0 14px var(--gold-glow)}}.ts-divider{display:flex;align-items:center;gap:12px;font-family:var(--fm);font-size:clamp(14px,2.2vw,20px);color:var(--gold-dark);-webkit-user-select:none;user-select:none}.ts-div-line{animation:ts-dlpulse 2.5s ease-in-out infinite}@keyframes ts-dlpulse{0%,to{opacity:.4}50%{opacity:1;text-shadow:0 0 10px var(--gold-glow)}}.ts-gem{color:var(--gold);display:inline-block;animation:ts-gspin 4s steps(4) infinite;filter:drop-shadow(0 0 6px var(--gold-glow))}@keyframes ts-gspin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ts-tagline{font-family:var(--fp);font-size:clamp(5px,1vw,8px);line-height:2.4;letter-spacing:1px;text-align:center;color:var(--text-normal)}.ts-cta-wrap{display:flex;flex-direction:column;align-items:center;gap:16px;min-height:85px}.ts-press{font-family:var(--fp);font-size:clamp(6px,1.1vw,9px);letter-spacing:2px;color:var(--gold);text-shadow:0 0 14px var(--gold-glow);transition:opacity .08s}.ts-btn-wrap{position:relative;display:inline-flex}.ts-btn-glow{position:absolute;top:-5px;right:-5px;bottom:-5px;left:-5px;z-index:0;opacity:.82;background:conic-gradient(from var(--angle),var(--ember),var(--gold),var(--cyan),var(--ember));clip-path:polygon(5px 0%,calc(100% - 5px) 0%,100% 5px,100% calc(100% - 5px),calc(100% - 5px) 100%,5px 100%,0% calc(100% - 5px),0% 5px);animation:ts-brotate 3s linear infinite}@keyframes ts-brotate{to{--angle: 360deg}}.ts-btn{font-family:var(--fp);font-size:clamp(7px,1.2vw,10px);letter-spacing:2px;color:#110900;background:linear-gradient(180deg,var(--gold-bright) 0%,var(--gold) 50%,var(--gold-dark) 100%);border:none;cursor:pointer;position:relative;z-index:1;padding:clamp(13px,2vw,18px) clamp(22px,4vw,42px);clip-path:polygon(4px 0%,calc(100% - 4px) 0%,100% 4px,100% calc(100% - 4px),calc(100% - 4px) 100%,4px 100%,0% calc(100% - 4px),0% 4px);transition:filter .15s,transform .15s,box-shadow .15s;box-shadow:0 5px 0 var(--gold-dark),0 8px 24px #f0c04066;image-rendering:pixelated}.ts-btn:before{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;background:linear-gradient(180deg,rgba(255,255,255,.24) 0%,transparent 55%);clip-path:inherit}.ts-btn:hover{filter:brightness(1.18) saturate(1.2);transform:translateY(-3px);box-shadow:0 8px 0 var(--gold-dark),0 14px 36px #f0c040a6}.ts-btn:active{transform:translateY(3px);box-shadow:0 2px 0 var(--gold-dark),0 4px 10px #f0c0404d}.ts-lore{max-width:580px;text-align:center;background:linear-gradient(135deg,#100820ed,#080412f5);border:1px solid rgba(240,192,64,.16);padding:clamp(14px,2.5vw,22px) clamp(18px,3vw,32px);position:relative;clip-path:polygon(8px 0%,calc(100% - 8px) 0%,100% 8px,100% calc(100% - 8px),calc(100% - 8px) 100%,8px 100%,0% calc(100% - 8px),0% 8px);animation:ts-loreglow 5s ease-in-out infinite}@keyframes ts-loreglow{0%,to{border-color:#f0c04029}50%{border-color:#f0c0405c;box-shadow:0 0 22px #f0c04012}}.ts-lore:before{content:"◆";position:absolute;top:5px;left:9px;color:var(--gold-dark);font-size:7px;opacity:.4}.ts-lore:after{content:"◆";position:absolute;bottom:5px;right:9px;color:var(--gold-dark);font-size:7px;opacity:.4}.ts-lore p{font-family:var(--fp);font-size:clamp(5px,1vw,7px);line-height:2.2;color:var(--text-normal);margin-bottom:10px}.ts-lore p:last-child{color:var(--text-dim);margin-bottom:0}.ts-footer{position:absolute;bottom:14px;left:0;right:0;font-family:var(--fm);font-size:clamp(6px,.9vw,8px);letter-spacing:4px;text-align:center;color:var(--text-dim);z-index:10}@media (max-width: 480px){.ts-title{font-size:clamp(16px,7vw,30px)}.ts-content{gap:16px}}.auth-screen{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#1a1028,#0a0a0f 70%);padding:20px}.auth-container{width:100%;max-width:460px;display:flex;flex-direction:column;gap:24px}.auth-header{text-align:center;display:flex;flex-direction:column;gap:10px}.auth-icon{font-size:48px;line-height:1}.auth-title{font-size:16px}.auth-subtitle{font-size:18px;color:var(--text-dim)}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-label{font-size:9px;letter-spacing:2px}.auth-error,.auth-message{padding:12px 14px}.auth-loading{display:flex;align-items:center;justify-content:center;gap:8px}.auth-toggle{display:flex;flex-direction:column;align-items:center;gap:10px;padding-top:8px;border-top:2px solid var(--pixel-border)}.auth-back{font-size:9px;padding:8px 16px;align-self:center}.avatar-screen{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 30% 70%,#1a1028,#0a0a0f 70%);padding:20px}.avatar-container{width:100%;max-width:680px;display:flex;flex-direction:column;gap:20px}.avatar-header{text-align:center;padding:20px}.avatar-title{font-size:18px;margin-bottom:10px}.avatar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media (max-width: 560px){.avatar-grid{grid-template-columns:repeat(2,1fr)}}.avatar-option{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 10px;cursor:pointer;background-color:var(--pixel-panel);border:4px solid var(--pixel-border);transition:border-color 80ms,box-shadow 80ms}.avatar-option:hover{border-color:var(--ember-gold-dark);background-color:var(--pixel-panel-light)}.avatar-option--selected{border-color:var(--ember-gold);box-shadow:0 0 0 2px var(--ember-gold-dark),0 0 20px #f0c04066;background-color:#2a2215}.avatar-emoji{font-size:40px;line-height:1}.avatar-label{font-size:10px;font-family:var(--font-pixel);color:var(--text-bright)}.avatar-desc{font-size:14px;text-align:center}.avatar-selected-badge{font-size:9px;margin-top:4px;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.avatar-username{display:flex;flex-direction:column;gap:8px}.avatar-lore{animation:fade-in-pixel .3s steps(3) forwards}@keyframes fade-in-pixel{0%{opacity:0}to{opacity:1}}.avatar-confirm-btn{width:100%;font-size:12px;padding:16px}.duel-screen{width:100%;min-height:100vh;background:radial-gradient(ellipse at 10% 90%,#1a0505 0%,transparent 50%),radial-gradient(ellipse at 90% 10%,#0f0a1a 0%,transparent 50%),var(--pixel-black);display:flex;flex-direction:column}.duel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-left:none;border-right:none;border-top:none;background-color:var(--pixel-darker)}.duel-back-btn{font-size:8px;padding:6px 12px}.duel-header-center{display:flex;flex-direction:column;align-items:center;gap:2px}.duel-header-xp{min-width:80px;text-align:right}.duel-toast{padding:10px 20px;text-align:center;border-bottom:2px solid transparent;animation:toast-in .1s step-end}.duel-toast--success{background:#0a1a0a;border-color:var(--dragon-green)}.duel-toast--error{background:#1a0a0a;border-color:var(--corruption-red)}.duel-toast--info{background:#0a0f1a;border-color:var(--arcane-blue)}@keyframes toast-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.duel-tabs{display:flex;border-bottom:2px solid var(--pixel-border);background-color:var(--pixel-darker)}.duel-tab{flex:1;padding:10px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:9px;color:var(--text-dim);transition:color 80ms}.duel-tab:hover{color:var(--text-normal)}.duel-tab--active{color:var(--ember-gold);border-bottom-color:var(--ember-gold)}.duel-content{flex:1;overflow-y:auto;padding:16px}.duel-board{max-width:640px;margin:0 auto;display:flex;flex-direction:column;gap:12px}.duel-post-panel,.duel-my-open{padding:16px}.duel-stake-options{display:flex;gap:8px;flex-wrap:wrap}.duel-stake-btn{flex:1;min-width:60px;padding:8px;background:var(--pixel-panel);border:2px solid var(--pixel-border);cursor:pointer;font-size:10px;color:var(--text-dim);font-family:var(--font-pixel);transition:all 80ms}.duel-stake-btn:hover{border-color:var(--ember-gold);color:var(--ember-gold)}.duel-stake-btn--selected{background:#2a1f00;border-color:var(--ember-gold);color:var(--ember-gold);box-shadow:0 0 8px #f0c04066}.duel-list-header{text-align:center;font-size:9px;letter-spacing:2px;padding:4px 0}.duel-empty{text-align:center;padding:32px 16px}.duel-card{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;gap:12px}.duel-card-left{display:flex;flex-direction:column;gap:2px;flex:1}.duel-card-right{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:80px}.duel-pot-badge{display:flex;flex-direction:column;align-items:center;background:#2a1f00;border:2px solid var(--ember-gold);padding:4px 8px;min-width:60px}.duel-accept-btn{font-size:8px;padding:6px 10px;width:100%}.duel-result-card{padding:10px 14px;display:flex;flex-direction:column;gap:2px;border-left:4px solid var(--pixel-border)}.duel-result-card--win{border-left-color:var(--dragon-green);background:#0a140a}.duel-result-card--lose{border-left-color:var(--corruption-red);background:#140a0a}.duel-active{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:12px;width:100%}.duel-active-info{padding:12px 16px}.duel-versus{display:flex;align-items:center;justify-content:space-between;gap:8px}.duel-player{display:flex;flex-direction:column;gap:2px;flex:1}.duel-player:last-child{text-align:right}.duel-vs-badge{display:flex;flex-direction:column;align-items:center;gap:4px;background:#1a0f00;border:2px solid var(--ember-gold);padding:6px 12px;min-width:80px}.duel-challenge{padding:14px}.duel-challenge-desc{font-family:var(--font-terminal);font-size:13px;color:var(--text-dim);white-space:pre-wrap;line-height:1.6;margin-top:8px}.duel-editor-area{display:flex;flex-direction:column;gap:10px}.duel-editor{min-height:220px;width:100%;box-sizing:border-box}.duel-submit-btn{font-size:10px;padding:10px;width:100%}.duel-result-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px}.duel-result-banner{max-width:480px;width:100%;padding:40px;text-align:center;border:4px solid var(--pixel-border);background:var(--pixel-panel);display:flex;flex-direction:column;align-items:center}.duel-result-banner--win{border-color:var(--ember-gold);background:#1a1000;box-shadow:0 0 40px #f0c04066}.duel-result-banner--lose{border-color:var(--corruption-red);background:#1a0505;box-shadow:0 0 40px #e040404d}.duel-result-icon{font-size:48px;margin-bottom:16px;animation:result-bounce .4s step-end}@keyframes result-bounce{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.duel-xp-change{font-family:var(--font-pixel);font-size:24px;margin-top:16px}.duel-xp-change--win{color:var(--ember-gold)}.duel-xp-change--lose{color:var(--corruption-red)}.duel-leaderboard{max-width:640px;margin:0 auto;display:flex;flex-direction:column;gap:8px;width:100%}.duel-lb-row{display:flex;align-items:center;gap:12px;padding:10px 14px}.duel-lb-row--me{border-color:var(--ember-gold);background:#1a1000}.duel-lb-rank{min-width:28px;text-align:center}.duel-lb-info{display:flex;flex-direction:column;flex:1}.duel-lb-stats{display:flex;flex-direction:column;align-items:flex-end}:root{--fp: "Press Start 2P", monospace;--fm: "Share Tech Mono", monospace;--gold: #f0c040;--gold-bright: #ffe566;--gold-dark: #b8860b;--gold-glow: rgba(240,192,64,.55);--green: #4ade80;--green-dark: #15803d;--ember: #ff6b2b;--cyan: #00e5ff;--stone: #3d3528;--stone-light: #5a4e3a;--stone-dark: #1e1a12;--sky-top: #0d0918;--sky-mid: #1a1035;--sky-low: #2d1a0a;--mist: rgba(200,180,255,.06);--text-normal: #d4c8f0;--text-dim: #6a5a4a;--text-gold: var(--gold)}.map-screen{width:100%;min-height:100vh;background:radial-gradient(ellipse at 50% 0%,#1a1035 0%,transparent 60%),radial-gradient(ellipse at 20% 100%,#0f1a10 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,#1a0f08 0%,transparent 50%),linear-gradient(180deg,#0d0918,#141020 30%,#0e180a 70%,#0d0918);display:flex;flex-direction:column;padding:0 0 60px;overflow-x:hidden;position:relative}.map-screen:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1px 1px at 10% 15%,rgba(255,255,255,.6) 0%,transparent 0%),radial-gradient(1px 1px at 25% 8%,rgba(255,255,255,.4) 0%,transparent 0%),radial-gradient(2px 2px at 40% 20%,rgba(255,255,255,.5) 0%,transparent 0%),radial-gradient(1px 1px at 55% 5%,rgba(255,255,255,.3) 0%,transparent 0%),radial-gradient(1px 1px at 70% 12%,rgba(255,255,255,.6) 0%,transparent 0%),radial-gradient(2px 2px at 85% 7%,rgba(255,255,255,.4) 0%,transparent 0%),radial-gradient(1px 1px at 92% 18%,rgba(255,255,255,.3) 0%,transparent 0%),radial-gradient(1px 1px at 15% 25%,rgba(255,255,255,.2) 0%,transparent 0%),radial-gradient(1px 1px at 60% 22%,rgba(255,255,255,.4) 0%,transparent 0%),radial-gradient(1px 1px at 78% 28%,rgba(255,255,255,.3) 0%,transparent 0%);pointer-events:none;z-index:0}.map-mist{position:fixed;bottom:0;left:-10%;width:120%;height:35%;pointer-events:none;z-index:1;background:linear-gradient(to top,rgba(20,15,40,.7) 0%,rgba(30,20,50,.3) 40%,transparent 100%);animation:mist-drift 20s ease-in-out infinite}@keyframes mist-drift{0%,to{transform:translate(0) scaleY(1)}50%{transform:translate(2%) scaleY(1.05)}}.map-firefly{position:fixed;width:3px;height:3px;border-radius:50%;background:var(--gold);box-shadow:0 0 6px var(--gold);pointer-events:none;z-index:2;animation:firefly var(--ff-dur,8s) ease-in-out var(--ff-del,0s) infinite}@keyframes firefly{0%{transform:translate(0);opacity:0}10%{opacity:.8}50%{transform:translate(var(--ff-x,30px),var(--ff-y,-40px));opacity:.6}90%{opacity:.2}to{transform:translate(var(--ff-x2,60px),var(--ff-y2,-80px));opacity:0}}.map-screen:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.04) 3px,rgba(0,0,0,.04) 4px);pointer-events:none;z-index:50}.map-loading{width:100%;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--sky-top);gap:20px}.map-hud{display:flex;align-items:center;gap:16px;padding:10px 20px;background:linear-gradient(180deg,#0a0618fa,#0e091ef2);border-bottom:2px solid rgba(240,192,64,.25);border-top:none;border-left:none;border-right:none;position:relative;z-index:20;box-shadow:0 4px 24px #0009}.map-hud:after{content:"";position:absolute;bottom:-6px;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,rgba(240,192,64,.15) 20%,rgba(240,192,64,.35) 50%,rgba(240,192,64,.15) 80%,transparent)}.map-hud-left{display:flex;flex-direction:column;gap:2px;min-width:130px}.map-username{font-family:var(--fp);font-size:9px;color:var(--gold)}.map-level{font-family:var(--fp);font-size:8px;color:var(--text-dim)}.map-hud-center{flex:1;max-width:320px;margin:0 auto}.map-hud-right{display:flex;gap:8px;align-items:center}.map-duel-btn{font-size:8px;padding:7px 14px}.map-signout{font-size:7px;padding:6px 10px}.map-title-area{text-align:center;padding:28px 20px 16px;position:relative;z-index:10}.map-title{font-family:var(--fp);font-size:clamp(18px,3vw,28px);color:var(--gold);letter-spacing:3px;text-shadow:2px 2px 0 #9c6600,4px 4px 0 #5a3800,0 0 20px rgba(240,192,64,.4),0 0 50px rgba(240,192,64,.18);animation:title-breathe 3s ease-in-out infinite}@keyframes title-breathe{0%,to{text-shadow:2px 2px 0 #9c6600,4px 4px 0 #5a3800,0 0 20px rgba(240,192,64,.4),0 0 50px rgba(240,192,64,.18)}50%{text-shadow:2px 2px 0 #9c6600,4px 4px 0 #5a3800,0 0 30px rgba(240,192,64,.7),0 0 70px rgba(240,192,64,.3)}}.map-subtitle{font-family:var(--fm);font-size:clamp(10px,1.5vw,13px);color:var(--text-dim);letter-spacing:4px;margin-top:8px}.map-section-label{font-family:var(--fp);font-size:8px;text-align:center;padding:8px 20px;letter-spacing:3px;position:relative;z-index:10;color:var(--text-dim)}.map-section-label.gold{color:var(--gold);text-shadow:0 0 12px var(--gold-glow)}.map-world{flex:1;padding:10px 20px 20px;position:relative;z-index:10;overflow-x:auto}.map-hills{position:absolute;bottom:0;left:0;right:0;height:60%;pointer-events:none;z-index:0}.map-hill{position:absolute;bottom:0;border-radius:50% 50% 0 0;opacity:.5}.map-hill-1{width:280px;height:120px;left:5%;background:radial-gradient(ellipse at 50% 100%,#0f1a10,#0a1208);opacity:.7}.map-hill-2{width:220px;height:90px;left:22%;background:radial-gradient(ellipse at 50% 100%,#141a0e,#0c1108);opacity:.5}.map-hill-3{width:300px;height:130px;right:10%;background:radial-gradient(ellipse at 50% 100%,#0f1a10,#0a1208);opacity:.6}.map-hill-4{width:200px;height:80px;right:28%;background:radial-gradient(ellipse at 50% 100%,#1a1508,#100e04);opacity:.5}.map-nodes-row{display:flex;align-items:flex-end;justify-content:center;gap:0;position:relative;z-index:5;flex-wrap:nowrap;padding:20px 24px 30px;min-width:max-content;margin:0 auto}.map-node-wrapper{display:flex;flex-direction:column;align-items:center;position:relative;flex-shrink:0}.map-path-segment{width:60px;height:32px;flex-shrink:0;margin-bottom:48px;position:relative;display:flex;align-items:center;justify-content:center;gap:0}.map-path-segment:before{content:"";position:absolute;top:50%;left:0;right:0;height:2px;transform:translateY(-50%);background:repeating-linear-gradient(90deg,rgba(90,78,58,.6) 0px,rgba(90,78,58,.6) 6px,transparent 6px,transparent 10px)}.map-path-segment:after{content:"›  ›  ›";font-size:14px;letter-spacing:2px;color:#78643cb3;position:relative;z-index:1;font-family:monospace;line-height:1}.map-path-segment--to-finale{width:72px}.map-path-segment--to-finale:before{background:repeating-linear-gradient(90deg,rgba(240,192,64,.5) 0px,rgba(240,192,64,.5) 5px,transparent 5px,transparent 9px);height:2px;box-shadow:0 0 6px #f0c0404d}.map-path-segment--to-finale:after{content:"›  ›  ›";color:#f0c040d9;text-shadow:0 0 8px rgba(240,192,64,.5);animation:arrow-march 1.2s steps(1) infinite;font-size:15px;letter-spacing:3px}@keyframes arrow-march{0%{opacity:1;letter-spacing:3px}33%{opacity:.6;letter-spacing:4px}66%{opacity:.4;letter-spacing:5px}to{opacity:1;letter-spacing:3px}}.map-node{width:72px;position:relative;cursor:pointer;display:flex;flex-direction:column;align-items:center;background:none;border:none;padding:0;transition:transform .15s;font-family:var(--fp);filter:drop-shadow(0 8px 16px rgba(0,0,0,.8))}.map-node:hover:not(:disabled){transform:translateY(-8px);filter:drop-shadow(0 12px 20px rgba(0,0,0,.9)) drop-shadow(0 0 12px rgba(240,192,64,.3))}.map-node--completed:hover:not(:disabled){filter:drop-shadow(0 12px 20px rgba(0,0,0,.9)) drop-shadow(0 0 12px rgba(74,222,128,.3))}.map-node:disabled{cursor:not-allowed}.castle{width:72px;position:relative;display:flex;flex-direction:column;align-items:center}.castle-top{display:flex;gap:2px;align-items:flex-end;position:relative;z-index:2}.castle-merlon{width:12px;height:14px;border-radius:1px 1px 0 0}.castle-gap{width:6px;height:8px;align-self:flex-end}.castle-body{width:64px;height:56px;position:relative;z-index:2;display:flex;align-items:center;justify-content:center;border-left:4px solid transparent;border-right:4px solid transparent;overflow:hidden}.castle-window{width:16px;height:22px;border-radius:8px 8px 0 0;position:relative;display:flex;align-items:center;justify-content:center}.castle-window-light{position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:6px 6px 0 0;animation:window-flicker 3s step-end infinite}@keyframes window-flicker{0%,90%,to{opacity:1}92%{opacity:.4}95%{opacity:1}97%{opacity:.6}}.castle-base{width:72px;height:20px;position:relative;z-index:2;display:flex;align-items:flex-end;justify-content:center}.castle-gate{width:20px;height:18px;border-radius:8px 8px 0 0;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.castle-number{font-family:var(--fp);font-size:10px;position:absolute;bottom:6px;left:0;right:0;text-align:center;z-index:3}.castle-check{font-size:16px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3}.castle-lock{font-size:14px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;opacity:.5}.map-node--active .castle-merlon,.map-node--active .castle-body,.map-node--active .castle-base{background:linear-gradient(180deg,#3d2800,#2a1800);border-color:var(--gold-dark)}.map-node--active .castle-merlon{border:2px solid var(--gold-dark)}.map-node--active .castle-body{border-left-color:#6a4400;border-right-color:#6a4400;box-shadow:inset 0 0 20px #f0c0401a}.map-node--active .castle-base{background:linear-gradient(180deg,#2a1800,#1a0e00)}.map-node--active .castle-gate{background:#0a0600}.map-node--active .castle-window{background:#0009;border:2px solid var(--gold-dark)}.map-node--active .castle-window-light{background:radial-gradient(ellipse at 50% 80%,#ffcc44,#ff8800 70%,transparent)}.map-node--active .castle-number{color:var(--gold);text-shadow:0 0 8px var(--gold-glow)}.map-node--active .castle-gap{background:#1a0e00}.map-node--active .castle-body{animation:castle-glow 2s ease-in-out infinite}@keyframes castle-glow{0%,to{box-shadow:inset 0 0 20px #f0c0401a,0 0 16px #f0c04059,0 4px #6a4400}50%{box-shadow:inset 0 0 30px #f0c04033,0 0 32px #f0c04099,0 4px #6a4400}}.map-node--completed .castle-merlon,.map-node--completed .castle-body,.map-node--completed .castle-base{background:linear-gradient(180deg,#0d2410,#091609);border-color:var(--green-dark)}.map-node--completed .castle-merlon{border:2px solid var(--green-dark)}.map-node--completed .castle-body{border-left-color:#1a4020;border-right-color:#1a4020}.map-node--completed .castle-base{background:linear-gradient(180deg,#091609,#040e05)}.map-node--completed .castle-gate{background:#020602}.map-node--completed .castle-window{background:#00000080;border:2px solid var(--green-dark)}.map-node--completed .castle-window-light{background:radial-gradient(ellipse at 50% 80%,#88ff88,#22aa44 70%,transparent)}.map-node--completed .castle-number{color:var(--green)}.map-node--completed .castle-gap{background:#040e05}.map-node--completed .castle-body{box-shadow:0 0 14px #4ade804d,0 4px #1a4020}.map-node--locked .castle-merlon,.map-node--locked .castle-body,.map-node--locked .castle-base{background:linear-gradient(180deg,#1e1a12,#141008);border-color:#2a2218}.map-node--locked .castle-merlon{border:2px solid #2a2218}.map-node--locked .castle-body{border-left-color:#1e1a12;border-right-color:#1e1a12}.map-node--locked .castle-base{background:#0e0c08}.map-node--locked .castle-gate{background:#06060a}.map-node--locked .castle-window{background:#000c;border:2px solid #2a2218}.map-node--locked .castle-window-light{background:transparent}.map-node--locked .castle-number{color:#3a3228}.map-node--locked .castle-gap{background:#0e0c08}.map-node--locked{opacity:.55}.map-node-label{margin-top:10px;text-align:center;min-width:80px}.map-node-label-title{font-family:var(--fp);font-size:7px;letter-spacing:1px;display:block;margin-bottom:3px}.map-node-label-sub{font-family:var(--fp);font-size:6px;letter-spacing:1px;display:block;color:var(--text-dim)}.map-node--gate,.map-node--gate-open{cursor:default}.dragon-gate{display:flex;flex-direction:column;align-items:center}.gate-towers{display:flex;gap:4px;align-items:flex-end}.gate-tower{width:24px;display:flex;flex-direction:column;align-items:center}.gate-tower-top{display:flex;gap:2px;align-items:flex-end}.gate-merlon{width:7px;height:10px;border-radius:1px 1px 0 0}.gate-tower-body{width:24px;height:50px;position:relative;display:flex;align-items:center;justify-content:center}.gate-tower-window{width:8px;height:12px;border-radius:4px 4px 0 0;position:relative}.gate-arch{position:absolute;top:0;left:24px;right:24px;height:40px;border-radius:50% 50% 0 0;display:flex;align-items:center;justify-content:center;font-size:22px;z-index:2}.gate-base{width:80px;height:16px;border-radius:2px 2px 0 0}.gate-base-gap{width:32px;height:16px;border-radius:8px 8px 0 0;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.map-node--gate .gate-merlon,.map-node--gate .gate-tower-body,.map-node--gate .gate-base{background:linear-gradient(180deg,#1e1a12,#141008);border:2px solid #2a2218}.map-node--gate .gate-arch{background:#14100acc;border:2px solid #2a2218}.map-node--gate .gate-tower-window{background:#0a0806;border:1px solid #2a2218}.map-node--gate .gate-base-gap{background:#060402}.map-node--gate{opacity:.5}.map-node--gate-open .gate-merlon,.map-node--gate-open .gate-tower-body,.map-node--gate-open .gate-base{background:linear-gradient(180deg,#2a1800,#1a0e00);border:2px solid var(--gold-dark)}.map-node--gate-open .gate-arch{background:#1e1200e6;border:2px solid var(--gold);box-shadow:0 0 20px #f0c04080,inset 0 0 15px #f0c0401a;animation:gate-arch-glow 2s ease-in-out infinite}@keyframes gate-arch-glow{0%,to{box-shadow:0 0 20px #f0c04080,inset 0 0 15px #f0c0401a}50%{box-shadow:0 0 40px #f0c040cc,inset 0 0 25px #f0c04033}}.map-node--gate-open .gate-tower-window{background:#0006;border:1px solid var(--gold-dark)}.map-node--gate-open .gate-tower-window:after{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:4px 4px 0 0;background:radial-gradient(ellipse at 50% 80%,rgba(255,180,0,.7),rgba(255,100,0,.3) 70%,transparent);animation:window-flicker 2.5s step-end infinite}.map-node--gate-open .gate-base-gap{background:#0a0400}.map-node--gate-open .gate-merlon{border-color:var(--gold-dark)}.map-finale-area{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;padding:16px 20px;max-width:960px;margin:0 auto;width:100%;position:relative;z-index:10}.map-finale-node{flex:1;min-width:250px;max-width:300px;padding:0;overflow:hidden;position:relative;background:linear-gradient(180deg,#1e1408,#140e04);border:2px solid var(--gold-dark);clip-path:polygon(8px 0%,calc(100%-8px) 0%,100% 8px,100% calc(100%-8px),calc(100%-8px) 100%,8px 100%,0% calc(100%-8px),0% 8px);animation:trial-card-glow 4s ease-in-out infinite}@keyframes trial-card-glow{0%,to{border-color:var(--gold-dark);box-shadow:0 0 10px #f0c0401a}50%{border-color:var(--gold);box-shadow:0 0 24px #f0c0404d}}.map-finale-node:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold-dark) 30%,var(--gold) 50%,var(--gold-dark) 70%,transparent)}.map-finale-node-inner{padding:16px;display:flex;flex-direction:column;gap:12px}.map-finale-node-header{display:flex;align-items:flex-start;gap:12px}.map-finale-badge{width:44px;height:44px;min-width:44px;background:linear-gradient(180deg,#2a1800,#1a0e00);border:2px solid var(--gold-dark);display:flex;align-items:center;justify-content:center;font-family:var(--fp);font-size:14px;color:var(--gold);clip-path:polygon(4px 0%,calc(100%-4px) 0%,100% 4px,100% calc(100%-4px),calc(100%-4px) 100%,4px 100%,0% calc(100%-4px),0% 4px);position:relative;flex-shrink:0}.map-finale-badge--done{background:linear-gradient(180deg,#0d2410,#091609);border-color:var(--green-dark);color:var(--green)}.map-finale-info{display:flex;flex-direction:column;gap:3px;flex:1}.map-finale-trial-num{font-family:var(--fp);font-size:7px;color:var(--gold-dark);letter-spacing:2px}.map-finale-title{font-family:var(--fp);font-size:10px;color:var(--text-normal);line-height:1.5}.map-finale-xp{font-family:var(--fp);font-size:8px;color:var(--text-dim)}.map-finale-xp.done{color:var(--green-dark)}.map-finale-btn{font-family:var(--fp);font-size:8px;padding:9px 12px;width:100%;letter-spacing:1px}.map-finale-locked{max-width:420px;margin:16px auto 0;padding:24px;width:calc(100% - 40px);text-align:center;background:linear-gradient(135deg,#0e081aed,#080412f5);border:1px solid rgba(240,192,64,.14);position:relative;z-index:10;clip-path:polygon(8px 0%,calc(100%-8px) 0%,100% 8px,100% calc(100%-8px),calc(100%-8px) 100%,8px 100%,0% calc(100%-8px),0% 8px)}.map-finale-locked-title{font-family:var(--fp);font-size:10px;color:var(--gold);margin-top:10px}.map-finale-locked-sub{font-family:var(--fp);font-size:8px;color:var(--text-dim);margin-top:8px;line-height:1.8}.map-finale-progress-bar{height:8px;background:#ffffff0f;margin-top:14px;position:relative;clip-path:polygon(2px 0%,100% 0%,calc(100%-2px) 100%,0% 100%)}.map-finale-progress-fill{height:100%;background:linear-gradient(90deg,var(--gold-dark),var(--gold));box-shadow:0 0 8px var(--gold-glow);transition:width .5s ease}.pixel-btn{font-family:var(--fp);letter-spacing:1px;cursor:pointer;border:none;position:relative;transition:filter .1s,transform .1s;image-rendering:pixelated}.pixel-btn:hover{filter:brightness(1.2);transform:translateY(-2px)}.pixel-btn:active{transform:translateY(1px)}.pixel-btn--gold{background:linear-gradient(180deg,var(--gold-bright) 0%,var(--gold) 50%,var(--gold-dark) 100%);color:#110900;clip-path:polygon(3px 0%,calc(100%-3px) 0%,100% 3px,100% calc(100%-3px),calc(100%-3px) 100%,3px 100%,0% calc(100%-3px),0% 3px);box-shadow:0 3px 0 var(--gold-dark),0 5px 12px #f0c04066}.pixel-btn--ghost{background:#ffffff0d;color:var(--text-dim);border:1px solid rgba(255,255,255,.12);clip-path:polygon(3px 0%,calc(100%-3px) 0%,100% 3px,100% calc(100%-3px),calc(100%-3px) 100%,3px 100%,0% calc(100%-3px),0% 3px)}.pixel-btn--ghost:hover{color:var(--text-normal);border-color:#ffffff40}.pixel-spinner{width:40px;height:40px;border:4px solid rgba(240,192,64,.2);border-top-color:var(--gold);border-radius:0;animation:px-spin .8s steps(8) infinite}@keyframes px-spin{to{transform:rotate(360deg)}}.xp-bar-wrap{width:100%}.xp-bar-label{font-family:var(--fp);font-size:7px;color:var(--text-dim);letter-spacing:2px;margin-bottom:4px;display:flex;justify-content:space-between}.xp-bar-label span{color:var(--gold)}.xp-bar-track{height:8px;background:#ffffff0f;clip-path:polygon(2px 0%,100% 0%,calc(100%-2px) 100%,0% 100%)}.xp-bar-fill{height:100%;background:linear-gradient(90deg,var(--gold-dark),var(--gold));box-shadow:0 0 8px var(--gold-glow);transition:width .6s ease}@media (max-width: 640px){.map-nodes-row{padding:10px 8px 20px}.map-hud{flex-wrap:wrap;gap:8px}.map-hud-center{order:3;width:100%;max-width:100%}.map-path-segment{width:40px}.map-path-segment--to-finale{width:48px}}:root{--fp: "Press Start 2P", monospace;--fm: "Share Tech Mono", monospace}.dh-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#04020ad1;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:dh-backdrop-in .2s ease forwards}@keyframes dh-backdrop-in{0%{opacity:0}to{opacity:1}}.dh-panel{position:relative;width:100%;max-width:560px;background:var(--dh-body-bg, #06090d);border:2px solid var(--dh-border, #3a6a8a);box-shadow:0 0 0 1px #000c,0 0 40px var(--dh-glow, rgba(58,106,138,.4)),0 0 80px var(--dh-glow, rgba(58,106,138,.2)),inset 0 0 60px #00000080;clip-path:polygon(12px 0%,calc(100% - 12px) 0%,100% 12px,100% calc(100% - 12px),calc(100% - 12px) 100%,12px 100%,0% calc(100% - 12px),0% 12px);transform:translateY(24px) scale(.97);opacity:0;transition:transform .28s cubic-bezier(.34,1.4,.64,1),opacity .22s ease}.dh-panel--visible{transform:translateY(0) scale(1);opacity:1}.dh-corner{position:absolute;width:14px;height:14px;border-color:var(--dh-accent, #7ab8d8);border-style:solid;z-index:10}.dh-corner--tl{top:4px;left:4px;border-width:2px 0 0 2px}.dh-corner--tr{top:4px;right:4px;border-width:2px 2px 0 0}.dh-corner--bl{bottom:4px;left:4px;border-width:0 0 2px 2px}.dh-corner--br{bottom:4px;right:4px;border-width:0 2px 2px 0}.dh-top-shimmer,.dh-bottom-shimmer{height:3px;background:linear-gradient(90deg,transparent 0%,var(--dh-border, #3a6a8a) 20%,var(--dh-accent, #7ab8d8) 50%,var(--dh-border, #3a6a8a) 80%,transparent 100%);opacity:.8}.dh-bottom-shimmer{opacity:.4}.dh-rule{height:1px;background:linear-gradient(90deg,transparent,var(--dh-border, #3a6a8a) 20%,var(--dh-border, #3a6a8a) 80%,transparent);opacity:.5;margin:0 16px}.dh-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px 12px;background:var(--dh-header-bg, linear-gradient(135deg, #080e14, #0d1e2c))}.dh-header-left{display:flex;align-items:center;gap:12px}.dh-dragon-avatar{position:relative;width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--dh-accent-dim, rgba(122,184,216,.1));border:2px solid var(--dh-border, #3a6a8a);clip-path:polygon(4px 0%,calc(100%-4px) 0%,100% 4px,100% calc(100%-4px),calc(100%-4px) 100%,4px 100%,0% calc(100%-4px),0% 4px)}.dh-dragon-emoji{font-size:24px;line-height:1;filter:drop-shadow(0 0 6px var(--dh-accent, #7ab8d8))}.dh-avatar-ring{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border:2px solid var(--dh-accent, #7ab8d8);border-radius:50%;animation:dh-ring-spin 1.4s linear infinite;opacity:.6}@keyframes dh-ring-spin{to{transform:rotate(360deg)}}.dh-titles{display:flex;flex-direction:column;gap:3px}.dh-name{font-family:var(--fp);font-size:10px;color:var(--dh-accent, #7ab8d8);letter-spacing:2px;text-shadow:0 0 12px var(--dh-glow, rgba(58,106,138,.6))}.dh-oracle{font-family:var(--fm);font-size:10px;color:#b4a08299;letter-spacing:1px}.dh-header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.dh-depth-meter{display:flex;align-items:center;gap:6px}.dh-depth-label{font-family:var(--fp);font-size:6px;color:#8c785ab3;letter-spacing:1px}.dh-pips{display:flex;gap:3px}.dh-pip{width:8px;height:8px;clip-path:polygon(2px 0%,calc(100%-2px) 0%,100% 2px,100% calc(100%-2px),calc(100%-2px) 100%,2px 100%,0% calc(100%-2px),0% 2px)}.dh-pip--on{background:var(--dh-accent, #7ab8d8);box-shadow:0 0 6px var(--dh-accent, #7ab8d8);animation:dh-pip-pulse 2s ease-in-out infinite}.dh-pip--off{background:#3c322880}@keyframes dh-pip-pulse{0%,to{opacity:1}50%{opacity:.5}}.dh-level-tag{font-family:var(--fp);font-size:6px;letter-spacing:1px;padding:3px 6px;border:1px solid;clip-path:polygon(2px 0%,calc(100%-2px) 0%,100% 2px,100% calc(100%-2px),calc(100%-2px) 100%,2px 100%,0% calc(100%-2px),0% 2px)}.dh-x{font-family:var(--fp);font-size:9px;color:#8c785a99;background:none;border:1px solid rgba(140,120,90,.2);padding:4px 7px;cursor:pointer;transition:color .15s,border-color .15s;clip-path:polygon(2px 0%,calc(100%-2px) 0%,100% 2px,100% calc(100%-2px),calc(100%-2px) 100%,2px 100%,0% calc(100%-2px),0% 2px)}.dh-x:hover{color:#ff7070;border-color:#ff707066}.dh-body{min-height:220px;padding:20px 20px 16px;display:flex;flex-direction:column}.dh-idle{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:10px 0}.dh-idle-rune{position:relative;width:64px;height:64px;display:flex;align-items:center;justify-content:center;font-size:32px}.dh-idle-rune-ring{position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid var(--dh-border, #3a6a8a);border-radius:50%;animation:dh-idle-spin 6s linear infinite;opacity:.4}.dh-idle-rune-ring:after{content:"";position:absolute;top:-3px;left:50%;width:6px;height:6px;background:var(--dh-accent, #7ab8d8);border-radius:50%;transform:translate(-50%);box-shadow:0 0 8px var(--dh-accent, #7ab8d8)}@keyframes dh-idle-spin{to{transform:rotate(360deg)}}.dh-idle-heading{font-family:var(--fp);font-size:9px;color:var(--dh-accent, #7ab8d8);letter-spacing:1px;line-height:1.8}.dh-idle-desc{font-family:var(--fm);font-size:12px;color:#b4a078b3;max-width:380px;line-height:1.6}.dh-idle-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}.dh-meta-chip{font-family:var(--fp);font-size:7px;color:#8c785ab3;padding:3px 7px;border:1px solid rgba(140,120,90,.2);letter-spacing:1px}.dh-meta-sep{color:#8c785a66;font-size:12px}.dh-summoning{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:10px 0}.dh-orb{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.dh-orb-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid var(--dh-accent, #7ab8d8);opacity:0;animation:dh-orb-expand 2s ease-out infinite}.dh-orb-ring--1{animation-delay:0s}.dh-orb-ring--2{animation-delay:.6s}.dh-orb-ring--3{animation-delay:1.2s}@keyframes dh-orb-expand{0%{transform:scale(.4);opacity:.8}to{transform:scale(1.8);opacity:0}}.dh-orb-emoji{font-size:36px;position:relative;z-index:1;animation:dh-orb-float 2s ease-in-out infinite;filter:drop-shadow(0 0 12px var(--dh-accent, #7ab8d8))}@keyframes dh-orb-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.dh-summon-line{font-family:var(--fp);font-size:8px;color:var(--dh-accent, #7ab8d8);letter-spacing:1px;line-height:1.8;text-align:center;max-width:300px;animation:dh-summon-pulse 2s ease-in-out infinite}@keyframes dh-summon-pulse{0%,to{opacity:1}50%{opacity:.5}}.dh-dots{display:flex;gap:6px}.dh-dots span{width:6px;height:6px;background:var(--dh-accent, #7ab8d8);clip-path:polygon(2px 0%,calc(100%-2px) 0%,100% 2px,100% calc(100%-2px),calc(100%-2px) 100%,2px 100%,0% calc(100%-2px),0% 2px);animation:dh-dot-blink 1.2s steps(1) infinite}.dh-dots span:nth-child(2){animation-delay:.4s}.dh-dots span:nth-child(3){animation-delay:.8s}@keyframes dh-dot-blink{0%,to{opacity:1}50%{opacity:.1}}.dh-hint{flex:1;display:flex;flex-direction:column;gap:12px}.dh-dragon-msg{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--dh-accent-dim, rgba(122,184,216,.08));border-left:3px solid var(--dh-accent, #7ab8d8)}.dh-msg-icon{font-size:16px;flex-shrink:0}.dh-msg-text{font-family:var(--fp);font-size:7px;color:var(--dh-accent, #7ab8d8);letter-spacing:1px;line-height:1.8}.dh-scroll{position:relative;flex:1;background:linear-gradient(135deg,#0e0a04,#140e06,#0e0a04);border:1px solid rgba(160,130,60,.3);padding:0}.dh-scroll-tl,.dh-scroll-tr,.dh-scroll-bl,.dh-scroll-br{position:absolute;width:10px;height:10px;background:var(--dh-accent, #7ab8d8);opacity:.25}.dh-scroll-tl{top:0;left:0;clip-path:polygon(0 0,100% 0,0 100%)}.dh-scroll-tr{top:0;right:0;clip-path:polygon(0 0,100% 0,100% 100%)}.dh-scroll-bl{bottom:0;left:0;clip-path:polygon(0 0,0 100%,100% 100%)}.dh-scroll-br{bottom:0;right:0;clip-path:polygon(100% 0,100% 100%,0 100%)}.dh-scroll-body{padding:16px 18px;min-height:100px}.dh-hint-text{font-family:var(--fm);font-size:13px;color:#c8b888;line-height:1.85;letter-spacing:.3px;white-space:pre-wrap}.dh-cursor{display:inline-block;color:var(--dh-accent, #7ab8d8);animation:dh-blink .7s steps(1) infinite;margin-left:1px}@keyframes dh-blink{0%,to{opacity:1}50%{opacity:0}}.dh-hint-sub{display:flex;align-items:center;justify-content:flex-end;gap:8px;min-height:28px}.dh-ghost-btn{font-family:var(--fp);font-size:7px;color:#a08c64b3;background:none;border:1px solid rgba(160,140,100,.2);padding:5px 10px;cursor:pointer;letter-spacing:1px;clip-path:polygon(2px 0%,calc(100%-2px) 0%,100% 2px,100% calc(100%-2px),calc(100%-2px) 100%,2px 100%,0% calc(100%-2px),0% 2px);transition:color .15s,border-color .15s}.dh-ghost-btn:hover{color:var(--dh-accent, #7ab8d8);border-color:var(--dh-border, #3a6a8a)}.dh-max-note{font-family:var(--fp);font-size:7px;color:#ff707099;letter-spacing:1px}.dh-footer{padding:12px 18px 14px;display:flex;align-items:center;justify-content:center;min-height:52px}.dh-summon-btn{font-family:var(--fp);font-size:9px;letter-spacing:2px;color:#0a0600;background:linear-gradient(180deg,#ffe566,#f0c040,#b8860b);border:none;padding:12px 28px;cursor:pointer;display:flex;align-items:center;gap:10px;clip-path:polygon(4px 0%,calc(100%-4px) 0%,100% 4px,100% calc(100%-4px),calc(100%-4px) 100%,4px 100%,0% calc(100%-4px),0% 4px);box-shadow:0 4px #6a4400,0 6px 20px #f0c04059;transition:transform .1s,filter .1s,box-shadow .1s}.dh-summon-btn:hover{filter:brightness(1.15);transform:translateY(-2px);box-shadow:0 6px #6a4400,0 10px 28px #f0c04080}.dh-summon-btn:active{transform:translateY(1px);box-shadow:0 2px #6a4400,0 3px 12px #f0c0404d}.dh-summon-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.dh-return-btn{font-family:var(--fp);font-size:8px;letter-spacing:2px;color:#8c785acc;background:#ffffff0a;border:1px solid rgba(140,120,90,.25);padding:10px 24px;cursor:pointer;clip-path:polygon(3px 0%,calc(100%-3px) 0%,100% 3px,100% calc(100%-3px),calc(100%-3px) 100%,3px 100%,0% calc(100%-3px),0% 3px);transition:color .15s,border-color .15s}.dh-return-btn:hover{color:var(--dh-accent, #7ab8d8);border-color:var(--dh-border, #3a6a8a)}.dh-loading-track{width:100%;height:6px;background:#ffffff0d;clip-path:polygon(2px 0%,100% 0%,calc(100%-2px) 100%,0% 100%);overflow:hidden}.dh-loading-fill{height:100%;width:40%;background:linear-gradient(90deg,transparent,var(--dh-accent, #7ab8d8),transparent);animation:dh-loading-sweep 1.4s ease-in-out infinite}@keyframes dh-loading-sweep{0%{transform:translate(-120%)}to{transform:translate(350%)}}.dh-footer-note{font-family:var(--fp);font-size:7px;color:#8c785a80;letter-spacing:1px;animation:dh-summon-pulse 2s ease-in-out infinite}@media (max-width: 580px){.dh-panel{max-width:100%}.dh-header{flex-wrap:wrap;gap:8px}.dh-depth-meter{display:none}.dh-summon-btn{font-size:7px;padding:10px 18px;letter-spacing:1px}.dh-hint-text{font-size:12px}}.game-screen{width:100%;min-height:100vh;background:var(--pixel-black);display:flex;flex-direction:column}.game-hud{display:flex;align-items:center;gap:16px;padding:10px 16px;border-left:none;border-right:none;border-top:none;background-color:var(--pixel-darker);flex-shrink:0}.game-back-btn{font-size:8px;padding:6px 12px;flex-shrink:0}.game-hud-info{flex:1}.game-hud-xp{width:200px;flex-shrink:0}.game-main{display:grid;grid-template-columns:1fr 1fr;gap:0;flex:1}@media (max-width: 900px){.game-main{grid-template-columns:1fr}}.game-left-panel{display:flex;flex-direction:column;gap:0;border-right:3px solid var(--pixel-border);overflow-y:auto}.game-dialogue{flex-shrink:0;border-left:none;border-right:none;border-radius:0;min-height:100px}.dialogue--success{border-top-color:var(--dragon-green);background-color:#0f1a0f}.dialogue--failure{border-top-color:var(--corruption-red);background-color:#1a0a0a}.hint-popup{margin:0;border-left:none;border-right:none;border-radius:0;flex-shrink:0}.game-right-panel{display:flex;flex-direction:column;gap:0;overflow-y:auto}.game-challenge{border-left:none;border-right:none;border-top:none;border-radius:0;border-bottom-color:var(--pixel-border);flex-shrink:0}.game-editor-header{display:flex;justify-content:space-between;padding:8px 12px;background-color:var(--pixel-darker);border-bottom:2px solid var(--pixel-border);flex-shrink:0}.game-editor{border-left:none;border-right:none;border-top:none;border-radius:0;flex:1;min-height:280px;resize:none}.game-actions{display:flex;gap:8px;padding:12px;background-color:var(--pixel-darker);border-top:3px solid var(--pixel-border);flex-shrink:0;flex-wrap:wrap}.game-submit-btn{flex:1;min-width:140px;font-size:10px;display:flex;align-items:center;justify-content:center;gap:6px}.game-status-bar{border-top:2px solid var(--pixel-border);padding:10px;background-color:var(--pixel-darker);flex-shrink:0}:root{--pixel-black: #0a0a0f;--pixel-dark: #12121a;--pixel-darker: #1a1a28;--pixel-panel: #1e1e30;--pixel-panel-light: #2a2a40;--pixel-border: #3a3a58;--pixel-border-bright: #5555aa;--ember-gold: #f0c040;--ember-gold-dark: #c09020;--ember-light: #ffe080;--dragon-green: #40e040;--dragon-green-dark: #20a020;--corruption-red: #e04040;--corruption-dark: #a02020;--arcane-blue: #4080f0;--arcane-light: #80b0ff;--text-bright: #f0f0ff;--text-normal: #c0c0d8;--text-dim: #808090;--text-gold: #f0c040;--font-pixel: "Press Start 2P", monospace;--font-terminal: "VT323", monospace;--pixel-scale: 1}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;background-color:var(--pixel-black);color:var(--text-normal);font-family:var(--font-pixel);overflow-x:hidden;image-rendering:pixelated;image-rendering:crisp-edges}body{background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.08) 2px,rgba(0,0,0,.08) 4px)}.pixel-panel{background-color:var(--pixel-panel);border:4px solid var(--pixel-border);box-shadow:0 0 0 2px var(--pixel-black),4px 4px 0 0 var(--pixel-black),inset 0 0 0 2px #ffffff0a;padding:16px;image-rendering:pixelated}.pixel-panel--gold{border-color:var(--ember-gold-dark);box-shadow:0 0 0 2px var(--pixel-black),4px 4px 0 0 var(--pixel-black),0 0 16px #f0c04033}.pixel-panel--green{border-color:var(--dragon-green-dark);box-shadow:0 0 0 2px var(--pixel-black),4px 4px 0 0 var(--pixel-black),0 0 16px #40e04026}.pixel-panel--red{border-color:var(--corruption-dark);box-shadow:0 0 0 2px var(--pixel-black),4px 4px 0 0 var(--pixel-black),0 0 16px #e0404033}.pixel-btn{font-family:var(--font-pixel);font-size:10px;color:var(--pixel-black);background-color:var(--ember-gold);border:none;outline:none;cursor:pointer;padding:12px 20px;text-transform:uppercase;letter-spacing:1px;box-shadow:0 4px 0 0 var(--ember-gold-dark),4px 0 0 0 var(--ember-gold-dark),4px 4px #8a6010,0 0 0 2px var(--pixel-black);transition:transform 80ms,box-shadow 80ms;image-rendering:pixelated}.pixel-btn:hover{background-color:var(--ember-light);filter:brightness(1.1)}.pixel-btn:active{transform:translate(2px,2px);box-shadow:0 2px 0 0 var(--ember-gold-dark),2px 0 0 0 var(--ember-gold-dark),2px 2px #8a6010,0 0 0 2px var(--pixel-black)}.pixel-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.pixel-btn--green{background-color:var(--dragon-green);box-shadow:0 4px 0 0 var(--dragon-green-dark),4px 0 0 0 var(--dragon-green-dark),4px 4px #105010,0 0 0 2px var(--pixel-black)}.pixel-btn--green:hover{background-color:#60f060}.pixel-btn--red{background-color:var(--corruption-red);color:var(--text-bright);box-shadow:0 4px 0 0 var(--corruption-dark),4px 0 0 0 var(--corruption-dark),4px 4px #600010,0 0 0 2px var(--pixel-black)}.pixel-btn--ghost{background-color:transparent;color:var(--text-normal);box-shadow:0 4px 0 0 var(--pixel-border),4px 0 0 0 var(--pixel-border),4px 4px 0 0 var(--pixel-black),0 0 0 2px var(--pixel-border)}.pixel-btn--ghost:hover{color:var(--text-bright);background-color:var(--pixel-panel-light)}.pixel-input{font-family:var(--font-terminal);font-size:20px;color:var(--text-bright);background-color:var(--pixel-dark);border:3px solid var(--pixel-border);padding:10px 14px;width:100%;outline:none;resize:vertical;image-rendering:pixelated;transition:border-color .12s}.pixel-input:focus{border-color:var(--ember-gold-dark);box-shadow:0 0 8px #f0c0404d}.pixel-code-editor{font-family:Courier New,Courier,monospace;font-size:15px;line-height:1.6;color:var(--arcane-light);background-color:#0d0d1a;border:3px solid var(--pixel-border);padding:14px;width:100%;min-height:200px;resize:vertical;outline:none;-moz-tab-size:4;tab-size:4;image-rendering:pixelated}.pixel-code-editor:focus{border-color:var(--arcane-blue);box-shadow:0 0 12px #4080f04d}.pixel-title{font-family:var(--font-pixel);color:var(--ember-gold);text-shadow:2px 2px 0 var(--ember-gold-dark),4px 4px 0 rgba(0,0,0,.5);letter-spacing:2px;text-transform:uppercase;line-height:1.4}.pixel-subtitle{font-family:var(--font-terminal);color:var(--text-normal);font-size:22px;letter-spacing:1px}.pixel-text{font-family:var(--font-terminal);font-size:20px;line-height:1.6;color:var(--text-normal)}.pixel-text--gold{color:var(--ember-gold)}.pixel-text--green{color:var(--dragon-green)}.pixel-text--red{color:var(--corruption-red)}.pixel-text--dim{color:var(--text-dim)}.xp-bar-container{width:100%;background-color:var(--pixel-dark);border:3px solid var(--pixel-border);height:20px;position:relative;overflow:hidden}.xp-bar-fill{height:100%;background:linear-gradient(90deg,var(--ember-gold-dark),var(--ember-gold),var(--ember-light));transition:width .6s ease-out;position:relative}.xp-bar-fill:after{content:"";position:absolute;top:4px;left:0;right:0;height:4px;background:#ffffff4d}.dialogue-box{background-color:var(--pixel-dark);border:4px solid var(--ember-gold-dark);padding:16px 20px;position:relative;box-shadow:0 0 0 2px var(--pixel-black),4px 4px 0 0 var(--pixel-black),0 0 20px #f0c04026}.dialogue-box:before{content:"▶";position:absolute;bottom:10px;right:14px;color:var(--ember-gold);font-size:10px;animation:blink-cursor 1s step-end infinite}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.achievement-popup{position:fixed;top:20px;right:20px;z-index:9999;background-color:var(--pixel-darker);border:4px solid var(--ember-gold);padding:16px 20px;min-width:260px;box-shadow:0 0 0 2px var(--pixel-black),4px 4px 0 0 var(--pixel-black),0 0 30px #f0c04066;animation:achievement-slide .3s steps(4) forwards}@keyframes achievement-slide{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}.achievement-popup-exit{animation:achievement-slide-out .3s steps(4) forwards}@keyframes achievement-slide-out{0%{transform:translate(0);opacity:1}to{transform:translate(120%);opacity:0}}.hint-popup{background-color:var(--pixel-darker);border:4px solid var(--arcane-blue);padding:16px 20px;box-shadow:0 0 0 2px var(--pixel-black),4px 4px 0 0 var(--pixel-black),0 0 20px #4080f04d;animation:fade-in-pixel .2s steps(3) forwards}@keyframes fade-in-pixel{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.map-node{width:64px;height:64px;border:4px solid var(--pixel-border);cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;transition:transform 80ms,border-color 80ms;image-rendering:pixelated}.map-node--active{border-color:var(--ember-gold);box-shadow:0 0 16px #f0c04080;animation:node-pulse 2s step-end infinite}.map-node--completed{border-color:var(--dragon-green);box-shadow:0 0 10px #40e0404d}.map-node--locked{border-color:var(--pixel-border);opacity:.4;cursor:not-allowed}@keyframes node-pulse{0%,to{box-shadow:0 0 16px #f0c04080}50%{box-shadow:0 0 30px #f0c040cc}}.avatar-option{border:4px solid var(--pixel-border);cursor:pointer;padding:8px;transition:border-color 80ms,box-shadow 80ms;background-color:var(--pixel-panel);image-rendering:pixelated}.avatar-option:hover{border-color:var(--ember-gold-dark)}.avatar-option--selected{border-color:var(--ember-gold);box-shadow:0 0 0 2px var(--ember-gold-dark),0 0 20px #f0c04066}.pixel-spinner{width:32px;height:32px;border:4px solid var(--pixel-border);border-top-color:var(--ember-gold);animation:pixel-spin .8s steps(8) infinite}@keyframes pixel-spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:var(--pixel-dark);border-left:3px solid var(--pixel-border)}::-webkit-scrollbar-thumb{background:var(--pixel-border);border:none}::-webkit-scrollbar-thumb:hover{background:var(--pixel-border-bright)}.flex-center{display:flex;align-items:center;justify-content:center}.flex-col{display:flex;flex-direction:column}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.gap-32{gap:32px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.w-full{width:100%}.h-full{height:100%}
