*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.grow{flex-grow:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.border{border-width:1px}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.drop-shadow{--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / .1)) drop-shadow(0 1px 1px rgb(0 0 0 / .06));filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--color-voxel-dark: #1a1a2e;--color-voxel-primary: #16213e;--color-voxel-secondary: #0f3460;--color-voxel-accent: #e94560;--font-game: "Outfit", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;background-color:var(--color-voxel-dark);font-family:var(--font-game);color:#fff}#root{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}#root>*{pointer-events:auto}#game-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,var(--color-voxel-dark) 0%,var(--color-voxel-primary) 100%)}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-voxel-secondary);border-top-color:var(--color-voxel-accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background:var(--color-voxel-dark);color:var(--color-voxel-accent)}.game-container{width:100%;height:100%;position:relative}.hud{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.hud>*{pointer-events:auto}.click-to-play{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#00000080;backdrop-filter:blur(4px);cursor:pointer}.click-prompt{text-align:center;padding:2rem 3rem;background:#1a1a2ee6;border-radius:12px;border:2px solid var(--color-voxel-accent)}.click-prompt h2{font-size:2rem;margin-bottom:1rem}.click-prompt p{color:#aaa;font-size:.9rem;margin:.5rem 0}.crosshair{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.inventory-hotbar{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:2px;padding:4px;background:#00000080;border-radius:6px;border:2px solid rgba(139,90,43,.6)}.inventory-slot{width:56px;height:56px;background:linear-gradient(135deg,#8b5a2bb3,#5a3c1ecc);border:3px solid rgba(70,45,20,.9);border-radius:4px;display:flex;align-items:center;justify-content:center;position:relative;transition:border-color .15s,transform .15s,box-shadow .15s;box-shadow:inset 0 2px 4px #ffffff1a,inset 0 -2px 4px #0000004d}.inventory-slot:hover{border-color:#c8b48ccc}.inventory-slot.selected{border-color:#f0f0f0;transform:scale(1.05);box-shadow:0 0 12px #fff6,inset 0 2px 4px #fff3,inset 0 -2px 4px #0000004d}.inventory-slot .item-preview,.inventory-slot .block-preview{width:40px;height:40px;border-radius:4px;box-shadow:inset 0 -3px 6px #0006,inset 0 2px 4px #ffffff26;image-rendering:pixelated}.slot-number{position:absolute;top:2px;left:4px;font-size:11px;font-weight:600;color:#ffffffb3;text-shadow:1px 1px 1px rgba(0,0,0,.8)}.quantity-badge{position:absolute;bottom:2px;right:4px;font-size:14px;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.9),-1px -1px 1px rgba(0,0,0,.5);font-family:var(--font-mono)}.item-icon{font-size:24px;filter:drop-shadow(1px 1px 2px rgba(0,0,0,.6))}.durability-bar{position:absolute;bottom:4px;left:6px;right:6px;height:3px;background:#0009;border-radius:2px;overflow:hidden}.durability-fill{height:100%;border-radius:2px;transition:width .2s ease}.inventory-slot.enchanted{animation:enchant-pulse 2s ease-in-out infinite}@keyframes enchant-pulse{0%,to{box-shadow:0 0 6px #a020f066,inset 0 2px 4px #ffffff1a}50%{box-shadow:0 0 14px #a020f0b3,inset 0 2px 4px #ffffff1a}}.enchant-glow{position:absolute;inset:0;background:linear-gradient(135deg,#a020f026,#4b008214,#a020f026);pointer-events:none;border-radius:2px;animation:shimmer-glow 3s ease-in-out infinite}@keyframes shimmer-glow{0%,to{opacity:.5}50%{opacity:1}}.inventory-full{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#1a1a2ef2,#282337f2);padding:20px;border-radius:12px;border:3px solid rgba(139,90,43,.6);box-shadow:0 8px 32px #0009;display:flex;gap:20px}.inventory-panel{display:flex;flex-direction:column;gap:8px}.panel-title{font-size:14px;color:#ccc;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(139,90,43,.4)}.main-inventory{display:grid;grid-template-columns:repeat(9,56px);gap:2px}.hotbar-row{display:grid;grid-template-columns:repeat(9,56px);gap:2px;margin-top:8px;padding-top:8px;border-top:2px solid rgba(139,90,43,.4)}.crafting-panel{display:flex;flex-direction:column;align-items:center;gap:12px;padding-left:16px;border-left:2px solid rgba(139,90,43,.3)}.crafting-grid{display:grid;gap:2px}.crafting-grid.grid-2x2{grid-template-columns:repeat(2,56px)}.crafting-grid.grid-3x3{grid-template-columns:repeat(3,56px)}.craft-arrow{font-size:28px;color:#8b5a2bcc;margin:4px 0}.craft-output .inventory-slot{width:64px;height:64px;background:linear-gradient(135deg,#648c5a80,#466e3c99);border-color:#648c5acc}.craft-output .item-preview{width:48px;height:48px}.inventory-grid{display:grid;grid-template-columns:repeat(9,56px);gap:2px;margin-bottom:20px}.debug-overlay{position:absolute;top:10px;left:10px;background:#000000b3;padding:10px;border-radius:4px;font-family:var(--font-mono);font-size:12px}.debug-section{margin-bottom:8px}.debug-section h4{color:var(--color-voxel-accent);margin-bottom:4px}.debug-section p{margin:2px 0;color:#ccc}.hud-stats{position:absolute;bottom:80px;left:50%;transform:translate(-50%)}.health-hearts{display:flex;gap:2px;justify-content:center}.heart{position:relative;width:18px;height:18px;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.heart-icon{font-size:16px;transition:transform .1s,color .2s}.heart.full .heart-icon{color:#e94560}.heart.half .heart-icon{color:#e94560;opacity:.5;background:linear-gradient(90deg,#e94560 50%,#444 50%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.heart.empty .heart-icon{color:#333;opacity:.7}.heart.low-health .heart-icon{animation:heartbeat .5s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.mana-bar{display:flex;gap:2px;justify-content:center;margin-top:4px}.mana-crystal{position:relative;width:16px;height:16px;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.crystal-icon{font-size:14px;transition:transform .1s,color .2s}.mana-crystal.full .crystal-icon{color:#4a9eff;text-shadow:0 0 8px rgba(74,158,255,.8)}.mana-crystal.partial .crystal-icon{color:#4a9eff;opacity:.5}.mana-crystal.empty .crystal-icon{color:#333;opacity:.5}.mana-crystal.low-mana .crystal-icon{animation:mana-pulse .8s ease-in-out infinite}@keyframes mana-pulse{0%,to{opacity:.5}50%{opacity:1}}.underwater-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse at center,#1450a040,#0a286473 70%,#05143c99);pointer-events:none;z-index:45;animation:underwater-caustics 3s ease-in-out infinite}@keyframes underwater-caustics{0%,to{opacity:1;filter:brightness(1)}50%{opacity:.9;filter:brightness(1.05)}}.air-bubbles{display:flex;gap:2px;justify-content:center;margin-top:4px}.air-bubble{position:relative;width:18px;height:18px;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.bubble-icon{font-size:16px;transition:transform .1s,opacity .2s}.air-bubble.full .bubble-icon{color:#7dd3fc;text-shadow:0 0 6px rgba(125,211,252,.6)}.air-bubble.popping .bubble-icon{color:#7dd3fc;opacity:.5;animation:bubble-pop .3s ease-out}.air-bubble.empty .bubble-icon{color:#333;opacity:.3}.air-bubble.low-air .bubble-icon{animation:bubble-shake .3s ease-in-out infinite}@keyframes bubble-pop{0%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}to{transform:scale(.8);opacity:.5}}@keyframes bubble-shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.spell-bar{position:absolute;bottom:90px;left:50%;transform:translate(-50%);display:flex;gap:2px;padding:3px;background:#0006;border-radius:4px;border:1px solid rgba(74,158,255,.3)}.spell-slot{width:44px;height:44px;background:linear-gradient(135deg,#1e3c7899,#142850b3);border:2px solid rgba(74,158,255,.4);border-radius:4px;display:flex;align-items:center;justify-content:center;position:relative;transition:border-color .15s,box-shadow .15s;cursor:pointer}.spell-slot:hover{border-color:#4a9eff99}.spell-slot.selected{border-color:#4a9eff;box-shadow:0 0 10px #4a9eff80}.spell-slot.no-mana{opacity:.5}.spell-slot .slot-key{position:absolute;top:2px;left:3px;font-size:9px;color:#ffffff80;font-family:var(--font-mono)}.spell-slot .spell-icon{font-size:20px}.spell-slot .mana-cost{position:absolute;bottom:2px;right:3px;font-size:10px;color:#4a9eff;font-weight:700;font-family:var(--font-mono)}.spell-slot .cooldown-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;border-radius:2px}.spell-slot .cooldown-text{font-size:11px;color:#888;font-family:var(--font-mono)}.spell-slot .school-indicator{position:absolute;top:0;left:0;right:0;height:3px;border-radius:2px 2px 0 0;opacity:.8}.spell-bar-container{position:absolute;bottom:90px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:4px}.spell-bar-container .spell-bar{position:static;transform:none}.mastery-indicators{display:flex;gap:8px;padding:3px 6px;background:#00000080;border-radius:4px;border:1px solid rgba(255,255,255,.1)}.mastery-indicator{display:flex;align-items:center;gap:4px;padding:2px 4px}.mastery-indicator .mastery-icon{width:10px;height:10px;border-radius:2px;box-shadow:0 0 4px currentColor}.mastery-indicator .mastery-level{font-size:11px;color:#fff;font-weight:700;font-family:var(--font-mono);min-width:14px;text-align:center}.mastery-indicator .mastery-progress-bar{width:30px;height:4px;background:#0006;border-radius:2px;overflow:hidden}.mastery-indicator .mastery-progress-fill{height:100%;border-radius:2px;transition:width .3s ease}.damage-flash{position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse at center,transparent 30%,rgba(255,0,0,.4) 100%);pointer-events:none;z-index:50;animation:damage-flash-anim .2s ease-out forwards}@keyframes damage-flash-anim{0%{opacity:1}to{opacity:0}}.death-screen-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#640000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:death-fade-in .5s ease-out}@keyframes death-fade-in{0%{opacity:0;background:#ff0000e6}to{opacity:1;background:#640000b3}}.death-screen{text-align:center;padding:40px 60px;background:#000c;border-radius:16px;border:2px solid #e94560;box-shadow:0 0 60px #e9456080}.death-title{font-size:3rem;color:#e94560;margin:0 0 16px;text-shadow:0 0 20px rgba(233,69,96,.8);animation:death-title-pulse 2s ease-in-out infinite}@keyframes death-title-pulse{0%,to{text-shadow:0 0 20px rgba(233,69,96,.8)}50%{text-shadow:0 0 40px rgba(233,69,96,1)}}.death-message{font-size:1.2rem;color:#aaa;margin:0 0 32px}.respawn-button{padding:16px 48px;font-family:var(--font-game);font-size:1.2rem;font-weight:600;background:linear-gradient(135deg,var(--color-voxel-accent) 0%,#c73e54 100%);border:2px solid var(--color-voxel-accent);border-radius:8px;color:#fff;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:2px}.respawn-button:hover{background:linear-gradient(135deg,#ff5a7a 0%,var(--color-voxel-accent) 100%);transform:scale(1.05);box-shadow:0 0 30px #e9456099}.respawn-button:active{transform:scale(.98)}.stat-bar{width:200px;height:8px;background:#00000080;border-radius:4px;overflow:hidden}.stat-fill{height:100%;background:linear-gradient(90deg,#e94560,#ff6b6b);transition:width .3s}.block-highlight{position:absolute;pointer-events:none}.crafting-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(4px)}.crafting-container{background:linear-gradient(135deg,var(--color-voxel-dark) 0%,var(--color-voxel-primary) 100%);border:2px solid var(--color-voxel-secondary);border-radius:12px;padding:20px;min-width:500px;box-shadow:0 8px 32px #00000080}.crafting-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--color-voxel-secondary)}.crafting-header h2{font-size:1.5rem;color:#fff;margin:0}.close-button{background:none;border:none;color:#aaa;font-size:2rem;cursor:pointer;padding:0 8px;line-height:1;transition:color .15s}.close-button:hover{color:var(--color-voxel-accent)}.crafting-content{display:flex;flex-direction:column;gap:20px}.crafting-section{display:flex;align-items:center;justify-content:center;gap:20px}.crafting-grid{display:grid;gap:4px}.crafting-slot{width:50px;height:50px;background:#00000080;border:2px solid rgba(255,255,255,.2);border-radius:4px;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:border-color .15s,background-color .15s}.crafting-slot:hover{border-color:#ffffff80;background:#ffffff1a}.crafting-slot.output-slot{width:60px;height:60px;border-color:var(--color-voxel-secondary)}.crafting-slot.output-slot.highlight{border-color:var(--color-voxel-accent);box-shadow:0 0 10px #e9456080;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 10px #e9456080}50%{box-shadow:0 0 20px #e94560cc}}.slot-block{width:36px;height:36px;border-radius:4px;box-shadow:inset 0 -3px 6px #0000004d,inset 0 3px 6px #ffffff1a}.output-slot .slot-block{width:44px;height:44px}.slot-quantity{position:absolute;bottom:2px;right:4px;font-size:12px;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.8);font-family:var(--font-mono)}.crafting-arrow{font-size:2rem;color:#888}.inventory-section{border-top:1px solid var(--color-voxel-secondary);padding-top:20px}.inventory-section h3{font-size:1rem;color:#aaa;margin-bottom:12px}.inventory-main-grid{display:grid;grid-template-columns:repeat(9,50px);gap:4px;margin-bottom:8px}.inventory-hotbar-grid{display:grid;grid-template-columns:repeat(9,50px);gap:4px;padding-top:8px;border-top:1px dashed rgba(255,255,255,.2)}.cursor-item{position:fixed;pointer-events:none;z-index:200;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.cursor-item .slot-block{width:36px;height:36px}.cursor-item .slot-quantity{bottom:0;right:2px}.milestone-button{position:absolute;top:16px;right:16px;display:flex;align-items:center;gap:8px;padding:8px 14px;background:#0009;border:2px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-family:var(--font-game);font-size:14px;cursor:pointer;transition:all .2s ease;pointer-events:auto}.milestone-button:hover{background:#000c;border-color:#fbbf24;transform:scale(1.05)}.milestone-icon{font-size:18px;color:#fbbf24}.milestone-count{color:#aaa}.milestone-toast-container{position:absolute;top:80px;right:16px;z-index:150;pointer-events:none}.milestone-toast{position:relative;width:320px;padding:16px;background:linear-gradient(135deg,#1a1a2ef2,#16213ef2);border:2px solid var(--rarity-color, #fff);border-radius:12px;box-shadow:0 8px 32px #00000080,0 0 20px color-mix(in srgb,var(--rarity-color) 30%,transparent);pointer-events:auto;cursor:pointer;overflow:hidden;opacity:0;transform:translate(100%);transition:opacity .3s ease,transform .3s ease}.milestone-toast.visible{opacity:1;transform:translate(0)}.milestone-toast.fading{opacity:0;transform:translate(50%)}.toast-glow{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--rarity-color),transparent);animation:shimmer 2s ease-in-out infinite}@keyframes shimmer{0%,to{opacity:.5}50%{opacity:1}}.toast-content{position:relative;z-index:1}.toast-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.toast-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:#888}.toast-points{font-size:14px;font-weight:600;color:var(--rarity-color)}.toast-body{display:flex;align-items:center;gap:12px;margin-bottom:8px}.toast-icon{font-size:28px;flex-shrink:0}.toast-text{display:flex;flex-direction:column;gap:2px}.toast-name{font-size:16px;font-weight:600;color:#fff}.toast-description{font-size:12px;color:#aaa;line-height:1.3}.toast-rarity{font-size:10px;text-transform:uppercase;letter-spacing:1px;text-align:right}.milestone-panel-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center}.milestone-panel{width:90%;max-width:900px;max-height:85vh;background:linear-gradient(135deg,var(--color-voxel-dark) 0%,var(--color-voxel-primary) 100%);border:2px solid var(--color-voxel-secondary);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-voxel-secondary)}.panel-header h2{font-size:1.5rem;margin:0;color:#fff}.panel-close{background:none;border:none;color:#888;font-size:24px;cursor:pointer;padding:4px 8px;transition:color .15s}.panel-close:hover{color:var(--color-voxel-accent)}.panel-summary{display:flex;align-items:center;gap:32px;padding:20px 24px;border-bottom:1px solid var(--color-voxel-secondary);background:#0003}.summary-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.summary-stat .stat-value{font-size:28px;font-weight:700;color:#fff}.summary-stat .stat-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:#888}.summary-progress{flex:1;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.summary-progress .progress-fill{height:100%;background:linear-gradient(90deg,#4ade80,#22c55e);border-radius:4px;transition:width .5s ease}.panel-categories{flex:1;overflow-y:auto;padding:16px 24px}.milestone-category{margin-bottom:24px}.category-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.category-icon{font-size:20px;color:#fbbf24}.category-name{font-size:16px;font-weight:600;color:#fff;flex:1}.category-progress{font-size:14px;color:#888;font-family:var(--font-mono)}.category-milestones{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.milestone-card{display:flex;align-items:flex-start;gap:12px;padding:14px;background:#0000004d;border:2px solid rgba(255,255,255,.1);border-radius:10px;transition:all .2s ease;position:relative}.milestone-card.unlocked{border-color:var(--rarity-color);background:linear-gradient(135deg,#0006,color-mix(in srgb,var(--rarity-color) 10%,transparent))}.milestone-card.locked{opacity:.6}.milestone-card.secret.locked{opacity:.4}.milestone-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.card-icon{font-size:24px;flex-shrink:0;width:36px;text-align:center}.card-content{flex:1;min-width:0}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.card-name{font-size:14px;font-weight:600;color:#fff}.card-points{font-size:12px;font-weight:600;font-family:var(--font-mono)}.card-description{font-size:12px;color:#aaa;line-height:1.4;margin:0}.card-unlock-time{display:block;margin-top:6px;font-size:10px;color:#666;font-style:italic}.card-check{position:absolute;top:10px;right:10px;width:20px;height:20px;background:var(--rarity-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;font-weight:700}.panel-categories::-webkit-scrollbar{width:8px}.panel-categories::-webkit-scrollbar-track{background:#0003;border-radius:4px}.panel-categories::-webkit-scrollbar-thumb{background:var(--color-voxel-secondary);border-radius:4px}.panel-categories::-webkit-scrollbar-thumb:hover{background:var(--color-voxel-accent)}.recipe-book-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(4px)}.recipe-book-container{background:linear-gradient(135deg,var(--color-voxel-dark) 0%,var(--color-voxel-primary) 100%);border:2px solid var(--color-voxel-secondary);border-radius:12px;width:90%;max-width:800px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080}.recipe-book-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-voxel-secondary)}.recipe-book-header h2{font-size:1.5rem;color:#fff;margin:0}.recipe-book-search{padding:12px 20px;border-bottom:1px solid var(--color-voxel-secondary)}.recipe-book-search input{width:100%;padding:10px 14px;border:2px solid rgba(255,255,255,.2);border-radius:6px;background:#0000004d;color:#fff;font-size:14px;font-family:var(--font-game);outline:none;transition:border-color .15s}.recipe-book-search input:focus{border-color:var(--color-voxel-accent)}.recipe-book-search input::-moz-placeholder{color:#888}.recipe-book-search input::placeholder{color:#888}.recipe-book-tabs{display:flex;padding:12px 20px;gap:8px;border-bottom:1px solid var(--color-voxel-secondary);flex-wrap:wrap}.recipe-book-tabs .tab{padding:8px 16px;border:2px solid rgba(255,255,255,.2);border-radius:6px;background:#0000004d;color:#aaa;font-size:13px;font-family:var(--font-game);cursor:pointer;transition:all .15s}.recipe-book-tabs .tab:hover{border-color:#fff6;color:#fff}.recipe-book-tabs .tab.active{border-color:var(--color-voxel-accent);background:#e9456033;color:#fff}.recipe-book-content{flex:1;overflow-y:auto;padding:16px 20px}.recipe-section h3{font-size:1rem;color:#aaa;margin-bottom:12px;padding-bottom:8px;border-bottom:1px dashed rgba(255,255,255,.2)}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-bottom:20px}.recipe-card{background:#0006;border:2px solid rgba(255,255,255,.15);border-radius:8px;padding:12px;cursor:pointer;transition:all .2s}.recipe-card:hover{border-color:#ffffff4d;transform:translateY(-2px)}.recipe-card.expanded{border-color:var(--color-voxel-accent)}.recipe-card-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.recipe-result{display:flex;align-items:center;gap:10px}.recipe-item{width:32px;height:32px;border-radius:4px;box-shadow:inset 0 -2px 4px #0000004d,inset 0 2px 4px #ffffff1a}.recipe-name{font-size:14px;font-weight:500;color:#fff}.recipe-quantity{font-size:12px;color:#888;font-family:var(--font-mono)}.recipe-badges{display:flex;gap:6px}.recipe-badge{padding:3px 8px;border-radius:4px;font-size:10px;text-transform:uppercase;letter-spacing:.5px}.recipe-badge.table-required{background:#ffc10733;color:#ffc107}.recipe-badge.category{background:#6464644d;color:#aaa}.recipe-details{margin-top:12px;padding-top:12px;border-top:1px dashed rgba(255,255,255,.2);display:flex;gap:20px}.recipe-pattern{display:grid;gap:2px;background:#0000004d;padding:4px;border-radius:4px}.pattern-cell{width:32px;height:32px;background:#0006;border:1px solid rgba(255,255,255,.1);border-radius:2px;display:flex;align-items:center;justify-content:center}.pattern-item{width:24px;height:24px;border-radius:2px;box-shadow:inset 0 -2px 3px #0000004d}.recipe-ingredients{flex:1}.recipe-ingredients h4{font-size:12px;color:#aaa;margin-bottom:8px}.recipe-ingredients ul{list-style:none;padding:0;margin:0}.recipe-ingredients li{display:flex;align-items:center;gap:8px;font-size:12px;color:#ccc;margin-bottom:4px}.ingredient-color{width:16px;height:16px;border-radius:2px;box-shadow:inset 0 -1px 2px #0000004d}.recipe-card.smelting .recipe-card-header{flex-wrap:wrap}.smelting-flow{display:flex;align-items:center;gap:8px}.smelting-arrow{font-size:16px;color:#ffc107}.smelting-details{flex-direction:column}.smelting-info p{font-size:12px;color:#ccc;margin:4px 0}.smelting-info strong{color:#aaa}.no-recipes{text-align:center;padding:40px;color:#888}.no-recipes p{margin:8px 0}.recipe-book-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-top:1px solid var(--color-voxel-secondary);color:#888;font-size:12px}.recipe-count{font-family:var(--font-mono);color:#aaa}.furnace-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(4px)}.furnace-container{background:linear-gradient(135deg,var(--color-voxel-dark) 0%,var(--color-voxel-primary) 100%);border:2px solid var(--color-voxel-secondary);border-radius:12px;padding:20px;min-width:500px;box-shadow:0 8px 32px #00000080}.furnace-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--color-voxel-secondary)}.furnace-header h2{font-size:1.5rem;color:#fff;margin:0}.furnace-content{display:flex;flex-direction:column;gap:20px}.furnace-slots{display:flex;align-items:center;justify-content:center;gap:20px;padding:20px;background:#0000004d;border-radius:8px}.furnace-slot{width:50px;height:50px;background:#00000080;border:2px solid rgba(255,255,255,.2);border-radius:4px;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:border-color .15s,background-color .15s}.furnace-slot:hover{border-color:#ffffff80;background:#ffffff1a}.furnace-slot.highlight{border-color:var(--color-voxel-accent);box-shadow:0 0 10px #e9456080}.slot-label{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:10px;color:#888;text-transform:uppercase;white-space:nowrap}.furnace-input-section,.furnace-output-section,.furnace-fuel-section{display:flex;flex-direction:column;align-items:center}.furnace-progress-section{display:flex;flex-direction:column;align-items:center;gap:16px}.fuel-indicator{display:flex;align-items:center;gap:8px}.fuel-flame{font-size:24px;opacity:.3;transition:opacity .3s}.fuel-flame.active{opacity:1;animation:flicker .5s ease-in-out infinite}@keyframes flicker{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.fuel-bar{width:8px;height:40px;background:#00000080;border-radius:4px;overflow:hidden;position:relative}.fuel-fill{position:absolute;bottom:0;left:0;width:100%;background:linear-gradient(0deg,#ff6b35,#ffc107);border-radius:4px;transition:height .1s}.smelt-progress{display:flex;align-items:center;gap:8px}.progress-arrow{font-size:24px;color:#888}.progress-bar{width:60px;height:8px;background:#00000080;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4ade80,#22c55e);border-radius:4px;transition:width .1s}.chest-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(4px)}.chest-container{background:linear-gradient(135deg,var(--color-voxel-dark) 0%,var(--color-voxel-primary) 100%);border:2px solid var(--color-voxel-secondary);border-radius:12px;padding:20px;min-width:500px;box-shadow:0 8px 32px #00000080}.chest-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--color-voxel-secondary)}.chest-header h2{font-size:1.5rem;color:#fff;margin:0}.chest-content{display:flex;flex-direction:column;gap:20px}.chest-section{padding:12px;background:#0000004d;border-radius:8px}.chest-grid{display:grid;grid-template-columns:repeat(9,50px);gap:4px}.minimap-container{position:absolute;top:16px;left:16px;width:180px;height:180px;background:#000000b3;border:2px solid var(--color-voxel-secondary);border-radius:8px;overflow:hidden;pointer-events:auto}.minimap-header{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#00000080;border-bottom:1px solid var(--color-voxel-secondary)}.minimap-header span{font-size:11px;color:#aaa;text-transform:uppercase;letter-spacing:.5px}.minimap-coords{font-size:10px;color:#888;font-family:var(--font-mono)}.minimap-canvas-container{position:relative;width:100%;height:calc(100% - 28px)}.minimap-canvas{width:100%;height:100%;image-rendering:pixelated}.minimap-player-marker{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:var(--color-voxel-accent);border:2px solid white;border-radius:50%;z-index:1}.minimap-direction{position:absolute;top:50%;left:50%;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:12px solid var(--color-voxel-accent);transform-origin:center 8px;z-index:2}.main-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--color-voxel-dark) 0%,var(--color-voxel-primary) 50%,#0a1628 100%);display:flex;align-items:center;justify-content:center;z-index:1000;overflow:hidden}.main-menu-overlay:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle at 20% 80%,rgba(233,69,96,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(15,52,96,.3) 0%,transparent 50%);pointer-events:none}.main-menu-container{position:relative;z-index:1;background:#1a1a2ee6;border:2px solid var(--color-voxel-secondary);border-radius:16px;padding:40px;min-width:400px;max-width:500px;box-shadow:0 20px 60px #00000080,0 0 100px #e945601a;backdrop-filter:blur(10px)}.main-menu-container.wide{min-width:600px;max-width:800px}.menu-logo{text-align:center;margin-bottom:40px}.menu-title{font-size:3.5rem;font-weight:700;background:linear-gradient(135deg,#fff,#e94560,#fff);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;letter-spacing:4px;animation:shimmer-text 3s ease-in-out infinite}@keyframes shimmer-text{0%,to{background-position:0% center}50%{background-position:200% center}}.menu-subtitle{font-size:1rem;color:#888;margin-top:8px;letter-spacing:2px;text-transform:uppercase}.menu-buttons{display:flex;flex-direction:column;gap:12px}.menu-button{padding:16px 32px;font-family:var(--font-game);font-size:1.1rem;font-weight:500;border:2px solid var(--color-voxel-secondary);border-radius:8px;background:#0f346080;color:#fff;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:1px}.menu-button:hover:not(:disabled){background:#0f3460cc;border-color:var(--color-voxel-accent);transform:translateY(-2px);box-shadow:0 4px 20px #e945604d}.menu-button:active:not(:disabled){transform:translateY(0)}.menu-button:disabled{opacity:.5;cursor:not-allowed}.menu-button.primary{background:linear-gradient(135deg,var(--color-voxel-accent) 0%,#c73e54 100%);border-color:var(--color-voxel-accent)}.menu-button.primary:hover:not(:disabled){background:linear-gradient(135deg,#ff5a7a 0%,var(--color-voxel-accent) 100%);box-shadow:0 4px 30px #e9456080}.menu-button.secondary{background:transparent;border-color:#ffffff4d}.menu-button.secondary:hover:not(:disabled){border-color:#fff9;background:#ffffff1a}.menu-footer{margin-top:40px;text-align:center;color:#555;font-size:.85rem}.menu-header{display:flex;align-items:center;gap:16px;margin-bottom:30px;padding-bottom:16px;border-bottom:1px solid var(--color-voxel-secondary)}.menu-header h2{margin:0;font-size:1.5rem;color:#fff}.back-button{background:none;border:none;color:#888;font-size:1.2rem;cursor:pointer;padding:8px;transition:color .2s}.back-button:hover{color:var(--color-voxel-accent)}.mode-selection{display:flex;flex-direction:column;gap:24px}.mode-section h3{font-size:1rem;color:#aaa;margin:0 0 12px;text-transform:uppercase;letter-spacing:1px}.mode-cards{display:flex;gap:16px}.mode-cards.horizontal{flex-wrap:wrap}.mode-card{flex:1;padding:20px;background:#0000004d;border:2px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;transition:all .2s ease;display:flex;align-items:flex-start;gap:16px}.mode-card.small{flex:0 0 calc(50% - 8px);flex-direction:column;align-items:center;text-align:center;padding:16px;gap:8px}.mode-card:hover:not(.disabled){border-color:#ffffff4d;background:#0006}.mode-card.selected{border-color:var(--color-voxel-accent);background:#e9456026}.mode-card.disabled{opacity:.5;cursor:not-allowed}.mode-icon{font-size:2rem;flex-shrink:0}.mode-info h4{margin:0 0 4px;font-size:1.1rem;color:#fff}.mode-info p{margin:0;font-size:.85rem;color:#888}.coming-soon{display:inline-block;margin-top:8px;padding:4px 8px;background:var(--color-voxel-secondary);border-radius:4px;font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:#aaa}.menu-actions{display:flex;gap:12px;margin-top:30px;padding-top:20px;border-top:1px solid var(--color-voxel-secondary)}.menu-actions .menu-button{flex:1}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.settings-section{display:flex;flex-direction:column;gap:8px}.settings-section.full-width{grid-column:1 / -1}.settings-label{font-size:.9rem;color:#aaa;text-transform:uppercase;letter-spacing:1px}.settings-input{padding:12px 16px;background:#0006;border:2px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-family:var(--font-game);font-size:1rem;transition:border-color .2s}.settings-input:focus{outline:none;border-color:var(--color-voxel-accent)}.settings-input::-moz-placeholder{color:#555}.settings-input::placeholder{color:#555}.seed-input-group{display:flex;gap:8px}.seed-input-group .settings-input{flex:1}.seed-random-btn{padding:12px 16px;background:var(--color-voxel-secondary);border:2px solid var(--color-voxel-secondary);border-radius:8px;color:#fff;font-family:var(--font-game);font-size:.85rem;cursor:pointer;transition:all .2s;white-space:nowrap}.seed-random-btn:hover{background:var(--color-voxel-accent);border-color:var(--color-voxel-accent)}.biome-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.biome-card{padding:12px;background:#0000004d;border:2px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s;text-align:center}.biome-card:hover{border-color:#ffffff4d}.biome-card.selected{border-color:var(--color-voxel-accent);background:#e9456026}.biome-card h4{margin:0 0 4px;font-size:.95rem;color:#fff}.biome-card p{margin:0;font-size:.75rem;color:#888}.difficulty-options{display:flex;gap:10px}.difficulty-card{flex:1;padding:12px;background:#0000004d;border:2px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s;text-align:center}.difficulty-card:hover{border-color:#ffffff4d}.difficulty-card.selected{border-color:var(--color-voxel-accent);background:#e9456026}.difficulty-card h4{margin:0 0 4px;font-size:.9rem;color:#fff}.difficulty-card p{margin:0;font-size:.7rem;color:#888}.loading-world-name{margin-top:16px;font-size:1.2rem;color:var(--color-voxel-accent);font-weight:500}.touch-controls{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:50}.joystick-container{position:absolute;bottom:120px;left:30px;width:140px;height:140px;pointer-events:auto;touch-action:none}.joystick-base{width:100%;height:100%;background:radial-gradient(circle,#ffffff1a,#0006);border:3px solid rgba(255,255,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #0000004d,inset 0 2px 10px #ffffff1a}.joystick-container.active .joystick-base{border-color:var(--color-voxel-accent);box-shadow:0 0 20px #e9456066,inset 0 2px 10px #ffffff1a}.joystick-knob{width:60px;height:60px;background:linear-gradient(135deg,#ffffffe6,#c8c8c8cc);border-radius:50%;box-shadow:0 4px 15px #0006,inset 0 2px 5px #ffffff80;transition:transform .05s ease-out}.joystick-container.active .joystick-knob{background:linear-gradient(135deg,var(--color-voxel-accent) 0%,#c73e54 100%)}.touch-look-area{position:absolute;top:0;right:0;width:50%;height:100%;pointer-events:auto;touch-action:none}.touch-action-buttons{position:absolute;bottom:120px;right:30px;display:flex;flex-direction:column;gap:12px;pointer-events:auto}.touch-button{width:70px;height:70px;border-radius:50%;border:3px solid rgba(255,255,255,.4);background:#00000080;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:none;transition:all .1s ease;box-shadow:0 4px 15px #0000004d}.touch-button:active{transform:scale(.9);background:#e9456099;border-color:var(--color-voxel-accent)}.touch-button .button-icon{font-size:28px;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.touch-button.jump-button{width:80px;height:80px;background:#64b46466;border-color:#64b46499}.touch-button.jump-button:active{background:#64b464b3;border-color:#4ade80}.touch-button.attack-button{background:#e9456066;border-color:#e9456099}.touch-button.attack-button:active{background:#e94560b3;border-color:var(--color-voxel-accent)}.touch-button.place-button{background:#3b82f666;border-color:#3b82f699}.touch-button.place-button:active{background:#3b82f6b3;border-color:#3b82f6}.touch-button.cast-spell-button{background:#9333ea66;border-color:#9333ea99}.touch-button.cast-spell-button:active{background:#9333eab3;border-color:#9333ea}.touch-button.inventory-button{position:absolute;top:80px;right:16px;width:50px;height:50px;pointer-events:auto}.touch-button.inventory-button .button-icon{font-size:22px}@media(pointer:coarse),(hover:none){.inventory-hotbar{bottom:10px}.inventory-slot{width:48px;height:48px}.inventory-slot .item-preview,.inventory-slot .block-preview{width:34px;height:34px}.hud-stats{bottom:70px}.minimap-container{inset:auto 16px 140px auto;width:100px;height:100px;opacity:.8}.milestone-button{top:16px;right:80px}.debug-overlay{font-size:10px;padding:6px;max-width:200px}}.world-map-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.world-map-panel{background:var(--color-voxel-primary);border:2px solid var(--color-voxel-secondary);border-radius:12px;padding:16px;max-width:900px;width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080}.world-map-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--color-voxel-secondary)}.world-map-header h2{font-size:1.5rem;font-weight:600;color:#fff;margin:0}.map-controls{display:flex;align-items:center;gap:8px}.zoom-btn{width:28px;height:28px;border:1px solid var(--color-voxel-secondary);background:var(--color-voxel-dark);color:#fff;border-radius:4px;cursor:pointer;font-size:1rem;transition:all .2s}.zoom-btn:hover{background:var(--color-voxel-secondary)}.zoom-level{color:#888;font-size:.875rem;min-width:50px;text-align:center}.world-map-header .close-btn{width:32px;height:32px;border:none;background:transparent;color:#888;font-size:1.25rem;cursor:pointer;transition:color .2s}.world-map-header .close-btn:hover{color:var(--color-voxel-accent)}.world-map-content{display:flex;gap:16px;flex:1;min-height:0}.map-canvas-container{position:relative;flex-shrink:0}.world-map-canvas{border:2px solid var(--color-voxel-secondary);border-radius:8px;display:block}.player-coords{position:absolute;bottom:8px;left:50%;transform:translate(-50%);background:#000000b3;padding:4px 12px;border-radius:4px;font-size:.75rem;font-family:var(--font-mono);color:#00bcd4}.waypoints-panel{flex:1;min-width:250px;display:flex;flex-direction:column;background:var(--color-voxel-dark);border-radius:8px;padding:12px}.waypoints-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.waypoints-header h3{font-size:1rem;font-weight:500;color:#fff;margin:0}.add-waypoint-btn{padding:6px 12px;background:var(--color-voxel-accent);border:none;border-radius:4px;color:#fff;font-size:.875rem;cursor:pointer;transition:opacity .2s}.add-waypoint-btn:hover{opacity:.9}.waypoints-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.waypoint-item{display:flex;align-items:center;gap:10px;padding:10px;background:var(--color-voxel-primary);border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s}.waypoint-item:hover{border-color:var(--color-voxel-secondary)}.waypoint-item.selected{border-color:var(--color-voxel-accent);background:#e945601a}.waypoint-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.waypoint-info{flex:1;min-width:0}.waypoint-name{display:block;font-size:.875rem;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.waypoint-distance{font-size:.75rem;color:#888}.waypoint-actions{display:flex;gap:4px}.waypoint-actions button,.waypoint-item .teleport-btn{width:28px;height:28px;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.edit-btn{background:var(--color-voxel-secondary)}.delete-btn{background:transparent}.delete-btn:hover{background:#e945604d}.teleport-btn{background:#4caf50;color:#fff}.teleport-btn:disabled{background:#666;cursor:not-allowed}.no-waypoints{text-align:center;color:#666;font-size:.875rem;padding:24px}.teleport-cooldown-bar{height:4px;background:var(--color-voxel-secondary);border-radius:2px;margin-top:12px;overflow:hidden}.cooldown-progress{height:100%;background:var(--color-voxel-accent);transition:width .1s linear}.teleport-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001}.teleport-modal{background:var(--color-voxel-primary);border:2px solid var(--color-voxel-secondary);border-radius:12px;padding:20px;min-width:320px}.teleport-modal h3{margin:0 0 16px;color:#fff;font-size:1.25rem}.modal-field{margin-bottom:16px}.modal-field label{display:block;font-size:.875rem;color:#888;margin-bottom:6px}.modal-field input{width:100%;padding:10px 12px;background:var(--color-voxel-dark);border:1px solid var(--color-voxel-secondary);border-radius:6px;color:#fff;font-size:1rem;outline:none}.modal-field input:focus{border-color:var(--color-voxel-accent)}.icon-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.icon-btn{width:36px;height:36px;border:1px solid var(--color-voxel-secondary);background:var(--color-voxel-dark);border-radius:6px;cursor:pointer;font-size:1.25rem;transition:all .2s}.icon-btn:hover{border-color:var(--color-voxel-accent)}.icon-btn.selected{border-color:var(--color-voxel-accent);background:#e9456033}.color-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:6px}.color-btn{width:28px;height:28px;border:2px solid transparent;border-radius:50%;cursor:pointer;transition:all .2s}.color-btn:hover{transform:scale(1.1)}.color-btn.selected{border-color:#fff;box-shadow:0 0 0 2px var(--color-voxel-accent)}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.btn-cancel{padding:10px 20px;background:transparent;border:1px solid var(--color-voxel-secondary);border-radius:6px;color:#fff;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:var(--color-voxel-secondary)}.btn-save{padding:10px 20px;background:var(--color-voxel-accent);border:none;border-radius:6px;color:#fff;cursor:pointer;transition:all .2s}.btn-save:hover:not(:disabled){opacity:.9}.btn-save:disabled{background:#666;cursor:not-allowed}.inventory-controls{display:flex;gap:8px;margin-bottom:8px;padding:8px;background:var(--color-voxel-dark);border-radius:6px}.sort-btn{padding:6px 12px;background:var(--color-voxel-secondary);border:none;border-radius:4px;color:#fff;font-size:.75rem;cursor:pointer;transition:all .2s}.sort-btn:hover{background:var(--color-voxel-accent)}.sort-dropdown{padding:6px 10px;background:var(--color-voxel-dark);border:1px solid var(--color-voxel-secondary);border-radius:4px;color:#fff;font-size:.75rem;cursor:pointer}.auto-tool-toggle{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--color-voxel-dark);border:1px solid var(--color-voxel-secondary);border-radius:4px;cursor:pointer;font-size:.75rem;color:#888;transition:all .2s}.auto-tool-toggle.enabled{border-color:#4caf50;color:#4caf50}.auto-tool-toggle .toggle-indicator{width:12px;height:12px;border-radius:50%;background:#666;transition:background .2s}.auto-tool-toggle.enabled .toggle-indicator{background:#4caf50}.map-button{position:fixed;top:16px;right:16px;width:44px;height:44px;background:#1a1a2ee6;border:2px solid var(--color-voxel-secondary);border-radius:8px;color:#fff;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:100}.map-button:hover{border-color:var(--color-voxel-accent);background:var(--color-voxel-primary)}
