:root{color:#0f0e09;background:radial-gradient(circle at top,#f1d78d,#e1c26e 22%,#ae8e49 54%,#5b4623);font-family:Trebuchet MS,Segoe UI,sans-serif;font-synthesis:none;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body{margin:0;width:100%;height:100%;overflow:hidden}body{width:100vw;height:100vh}#root{width:100%;height:100%}.app-root{position:relative;width:100%;height:100%;display:flex;align-items:stretch;justify-content:stretch}.mobile-controls{display:none;position:absolute;bottom:0;left:0;right:0;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;padding:6px;padding-bottom:max(6px,env(safe-area-inset-bottom,6px));z-index:10;grid-template-columns:repeat(3,1fr);gap:4px;background:#00000080;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}@media(hover:none)and (pointer:coarse){.mobile-controls{display:grid}}.mobile-btn{pointer-events:auto;width:100%;height:54px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);border-radius:10px;color:#ffffffe6;font-size:26px;font-family:inherit;font-weight:600;line-height:1;cursor:pointer;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;transition:background 60ms,border-color 60ms}.mobile-btn.active{background:#ffffff47;border-color:#ffffff80}.game-canvas{width:100%;height:100%;max-width:none;max-height:none;display:block;image-rendering:pixelated;background:#fff;touch-action:none}.mod-picker-overlay{position:fixed;inset:0;background:#000000bf;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;touch-action:none}.mod-picker-btn{background:#f1d78d;color:#0f0e09;padding:1rem 2rem;border-radius:8px;font-size:1.125rem;font-family:inherit;cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;text-align:center}.mod-picker-btn input[type=file]{position:absolute;top:-9999px;left:-9999px;opacity:0;width:1px;height:1px}.seed-input{background:#f1d78d;color:#0f0e09;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1.25rem;font-family:inherit;text-align:center;width:220px;margin-bottom:.75rem;-moz-appearance:textfield}.seed-input::-webkit-outer-spin-button,.seed-input::-webkit-inner-spin-button{-webkit-appearance:none}.mod-picker-cancel{margin-top:1.25rem;background:transparent;color:#fffc;border:1px solid rgba(255,255,255,.3);padding:.5rem 1.5rem;border-radius:4px;font-size:1rem;font-family:inherit;cursor:pointer;user-select:none;-webkit-user-select:none}.joystick-zone{display:none;position:absolute;bottom:0;left:0;right:0;height:190px;padding-bottom:max(16px,env(safe-area-inset-bottom,16px));align-items:center;justify-content:center;z-index:10;background:#00000080;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);touch-action:none;user-select:none;-webkit-user-select:none}@media(hover:none)and (pointer:coarse){.mode-joystick .mobile-controls{display:none}.mode-joystick .joystick-zone{display:flex}}.joystick-outer{width:150px;height:150px;border-radius:50%;background:#ffffff14;border:1px solid rgba(255,255,255,.18);position:relative;flex-shrink:0;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.joystick-nub{position:absolute;width:60px;height:60px;border-radius:50%;background:#ffffff47;border:1px solid rgba(255,255,255,.5);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.joystick-menu-btn{position:absolute;bottom:max(16px,env(safe-area-inset-bottom,16px));right:16px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);border-radius:8px;color:#ffffffb3;font-size:13px;font-family:inherit;font-weight:600;padding:8px 14px;cursor:pointer;touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.error-view{width:min(100%,760px);padding:20px 24px;white-space:pre-wrap;color:#fff6dc;background:#1f1007e0;border:2px solid rgba(255,235,183,.65);box-shadow:0 18px 48px #00000047}
