:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;justify-content:center;align-items:center;min-width:320px;min-height:100vh;background-color:#0a0a0f}.game-wrapper{display:flex;justify-content:center;align-items:center;width:100%;height:100vh;padding:0;box-sizing:border-box}.game-container{width:100vw;height:100vh;max-width:100vw;max-height:100vh;display:flex;flex-direction:column;background-color:#1a1a1a;border-radius:0;overflow:hidden}.game-header{background:linear-gradient(135deg,#7f1d1d,#14532d);color:#fef2f2;padding:10px 16px;text-align:center;font-size:14px;display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;position:relative;z-index:20}.game-header .game-title{font-weight:700;font-size:16px;color:#fef2f2}.game-header .game-hint{color:#fecaca;font-size:13px}@media(max-width:600px){.game-header{padding:8px 12px;flex-direction:column;gap:4px}.game-header .game-title{font-size:14px}.game-header .game-hint{font-size:11px}}.game-canvas{flex:1;position:relative;overflow:hidden}.canvas-container{position:absolute;inset:0;overflow:hidden}.map-overlay{position:absolute;top:20px;left:50%;transform:translate(-50%) perspective(800px) rotateX(8deg);transform-origin:center center;border-radius:8px;overflow:hidden;z-index:10}.fps-counter{position:absolute;top:16px;left:16px;background:#0009;color:#4ade80;padding:6px 12px;border-radius:6px;font-family:monospace;font-size:14px;font-weight:700}.debug-panel{position:absolute;top:80px;left:16px;background:#000c;color:#fff;padding:12px 16px;border-radius:8px;font-family:monospace;font-size:12px;min-width:180px;border:1px solid rgba(255,255,255,.2)}.debug-header{color:#888;font-size:10px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.1)}.debug-row{display:flex;justify-content:space-between;padding:2px 0}.debug-row span:first-child{color:#aaa}.debug-row .warn{color:#f59e0b}.map-controls{position:absolute;bottom:16px;left:16px;background:#0009;color:#dcfce7;padding:8px 12px;border-radius:6px;font-size:14px;display:flex;align-items:center;gap:8px}.map-key{background:#15803d;color:#dcfce7;padding:2px 8px;border-radius:4px;font-weight:700;font-family:monospace}.map-hint{color:#9ca3af;font-size:12px;margin-left:8px}.compass-container{position:absolute;bottom:16px;left:calc(50% - 380px);transform:translate(-50%);z-index:15;animation:compass-fade-in .3s ease-out}.compass-canvas{display:block;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}@keyframes compass-fade-in{0%{opacity:0;transform:translate(-50%) scale(.8)}to{opacity:1;transform:translate(-50%) scale(1)}}.loader-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#1a2f1a,#0d1f0d);display:flex;align-items:center;justify-content:center;z-index:100}.loader{display:flex;flex-direction:column;align-items:center;gap:20px}.loader-spinner{position:relative;width:80px;height:80px}.spinner-ring{position:absolute;inset:0;border-radius:50%;border:3px solid transparent}.spinner-ring:nth-child(1){border-top-color:#4caf50;animation:spin 1.2s linear infinite}.spinner-ring:nth-child(2){inset:8px;border-right-color:#81c784;animation:spin 1.5s linear infinite reverse}.spinner-ring:nth-child(3){inset:16px;border-bottom-color:#2e7d32;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loader-text{color:#81c784;font-size:16px;letter-spacing:1px;font-weight:500;min-height:24px;transition:opacity .2s ease}.loader-title{color:#f0f0f0;font-size:28px;font-weight:700;letter-spacing:2px;margin-top:16px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.loader-hint{color:#a0d0a0;font-size:14px;letter-spacing:1px;margin-top:8px}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}@media(max-width:768px),(pointer:coarse){html,body{overflow:hidden;position:fixed;width:100%;height:100%;margin:0;padding:0}#root{width:100%;height:100%;overflow:hidden}.game-wrapper{padding:0;width:100%;height:100%;width:100dvw;height:100dvh;overflow:hidden}.game-container{width:100%;height:100%;max-width:100dvw;max-height:100dvh;border-radius:0;overflow:hidden}.fps-counter{top:8px;bottom:auto;left:8px;transform:none;font-size:10px;padding:2px 6px;opacity:.6}.debug-panel,.compass-container,.map-controls{display:none}}@media(pointer:coarse)and (orientation:portrait){.rotate-device-warning{display:flex!important}}.rotate-device-warning{display:none;position:fixed;inset:0;background:linear-gradient(135deg,#1a2f1a,#0d1f0d);z-index:1000;flex-direction:column;align-items:center;justify-content:center;color:#fff;text-align:center;padding:20px}.rotate-device-warning svg{width:80px;height:80px;margin-bottom:20px;animation:rotate-hint 2s ease-in-out infinite}.rotate-device-warning h2{font-size:24px;margin-bottom:10px}.rotate-device-warning p{font-size:16px;opacity:.8}@keyframes rotate-hint{0%,to{transform:rotate(0)}50%{transform:rotate(90deg)}}.tap-to-start-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#1a2f1a,#0d1f0d);z-index:150;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:manipulation}.tap-to-start-content{text-align:center;color:#fff}.tap-to-start-title{font-size:28px;font-weight:700;letter-spacing:2px;margin-bottom:40px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.tap-to-start-icon{font-size:64px;margin-bottom:20px;animation:tap-pulse 1.5s ease-in-out infinite}.tap-to-start-text{font-size:24px;font-weight:700;color:#81c784;margin-bottom:12px}.tap-to-start-hint{font-size:14px;color:#fff9}@keyframes tap-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.control-interaction{position:absolute;bottom:120px;left:50%;transform:translate(-50%);z-index:100;pointer-events:none}.control-prompt{background:#000000bf;border:2px solid rgba(255,255,255,.3);border-radius:8px;padding:12px 20px;text-align:center;color:#fff;font-family:Segoe UI,sans-serif;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:transform .1s ease}.control-prompt.stamping{transform:scale(1.1)}.control-code{font-size:18px;font-weight:700;margin-bottom:8px;color:#f93}.control-action{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px}.stamp-key{background:#fff3;border:1px solid rgba(255,255,255,.4);border-radius:4px;padding:4px 10px;font-weight:700;font-size:13px;min-width:20px}.control-stamped{display:flex;align-items:center;justify-content:center;gap:6px;font-size:14px;color:#6f6}.stamp-check{font-size:16px}.stamp-effect{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.stamp-punch{width:60px;height:60px;background:radial-gradient(circle,rgba(204,51,51,.8) 0%,transparent 70%);border-radius:50%;animation:punchEffect .5s ease-out forwards}@keyframes punchEffect{0%{transform:scale(.5);opacity:1}50%{transform:scale(1.5);opacity:.8}to{transform:scale(2);opacity:0}}.mobile-controls{display:none;pointer-events:none;position:fixed;inset:0;z-index:50}@media(pointer:coarse),(max-width:768px){.mobile-controls{display:block;pointer-events:none}}.turn-joystick{position:absolute;bottom:max(20px,env(safe-area-inset-bottom,20px));left:max(15px,env(safe-area-inset-left,15px));width:160px;height:70px;display:flex;flex-direction:column;align-items:center;z-index:50;pointer-events:auto}.joystick-track{width:140px;height:46px;background:#00000080;border-radius:23px;border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;position:relative;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.joystick-stick{width:46px;height:46px;background:radial-gradient(circle at 30% 30%,#fff,#aaa);border-radius:50%;box-shadow:0 4px 8px #0006;transition:transform .05s ease-out;touch-action:none}.joystick-label{color:#ffffffb3;font-size:12px;font-weight:700;margin-top:4px;letter-spacing:2px}.mobile-buttons{position:absolute;bottom:max(20px,env(safe-area-inset-bottom,20px));right:max(15px,env(safe-area-inset-right,15px));display:flex;flex-direction:row;gap:10px;z-index:50;pointer-events:auto}.mobile-btn{width:60px;height:60px;border-radius:50%;border:2px solid rgba(255,255,255,.4);background:#00000080;color:#fff;font-size:12px;font-weight:700;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);touch-action:manipulation;user-select:none;-webkit-user-select:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-btn:active{background:#ffffff4d;transform:scale(.95)}.forward-btn{width:80px;height:80px;background:#228b22cc;border-color:#90ee9099;font-size:18px}.forward-btn:active{background:#32cd32e6}.map-btn{background:#15803db3}.map-btn:active{background:#15803de6}.interact-btn{background:#cc3333b3}.interact-btn:active{background:#cc3333e6}.interact-btn.stamped{background:#228b22b3}.interact-btn:disabled{opacity:.8}.fullscreen-map-overlay{position:fixed;inset:0;background:#f5f0e6;z-index:200;display:flex;flex-direction:column}.fullscreen-map-canvas{flex:1;width:100%;height:100%;touch-action:none}.fullscreen-map-close{position:absolute;top:16px;right:16px;width:50px;height:50px;border-radius:50%;border:2px solid rgba(0,0,0,.3);background:#ffffffe6;color:#333;font-size:24px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:210;box-shadow:0 2px 8px #0003}.fullscreen-map-close:active{background:#c8c8c8e6;transform:scale(.95)}.fullscreen-map-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:#0009;color:#fff;padding:8px 16px;border-radius:20px;font-size:12px;white-space:nowrap;z-index:210}
