:root{font-family:Inter,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}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;width:100vw;height:100vh;overflow:hidden}#app{width:100%;height:100%;margin:0;padding:0;overflow:hidden}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}button{background-color:#f9f9f9}}.floating-toolbar{position:fixed;left:20px;top:120px;background:#1a1a1af2;border:2px solid #444;border-radius:12px;padding:1rem;z-index:1000;box-shadow:0 4px 20px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;gap:1.5rem;min-width:80px}.toolbar-section{display:flex;flex-direction:column;gap:.5rem;align-items:center}.toolbar-section h4{margin:0;font-size:.9rem;color:#888;text-align:center}.grid-container{width:100%;height:100vh;overflow:hidden;padding:120px 1rem 60px 140px;-webkit-user-select:none;user-select:none;position:relative}.tools{display:flex;flex-direction:column;gap:.5rem;align-items:center}.tools button{width:50px;height:50px;padding:0;background-color:#333;color:#fff;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;font-size:1.5rem;display:flex;align-items:center;justify-content:center}.tools button:hover{border-color:#646cff;transform:scale(1.05)}.tools button.active{border-color:#646cff;background-color:#1a1a2e;box-shadow:0 0 10px #646cff80}.tools button.disabled{background-color:#1a1a1a;color:#555;cursor:not-allowed;opacity:.5}.tools button.disabled:hover{border-color:transparent;transform:none}.factory-rotation{display:flex;flex-direction:column;gap:.3rem;align-items:stretch}.rotate-btn{padding:.5rem;background-color:#333;color:#fff;border:2px solid #555;border-radius:6px;cursor:pointer;transition:all .2s;font-size:.9rem;white-space:nowrap}.rotate-btn:hover{border-color:#646cff;background-color:#404040}.controls{display:flex;flex-direction:column;gap:.5rem;align-items:center}.controls button{width:50px;height:50px;padding:0;background-color:#333;color:#fff;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;font-size:1.5rem;display:flex;align-items:center;justify-content:center}.controls button:hover{border-color:#646cff;transform:scale(1.05)}.clear-btn{background-color:#d32f2f!important}.clear-btn:hover{background-color:#b71c1c!important}.belt-speeds{display:flex;flex-direction:column;gap:.5rem;align-items:center}.belt-speeds button{width:50px;height:50px;padding:0;color:#fff;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;text-shadow:0 1px 2px rgba(0,0,0,.5)}.belt-speeds button:hover{transform:scale(1.05);box-shadow:0 0 10px #ffffff4d}.belt-speeds button.active{border-color:#fff;box-shadow:0 0 15px #ffffff80;transform:scale(1.1)}.stats{display:flex;flex-direction:column;gap:.75rem;width:100%}.stat-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem;background:#ffffff0d;border-radius:6px;border:1px solid rgba(255,255,255,.1)}.stat-item.total{background:#ffd7001a;border-color:#ffd7004d}.stat-item.resource-count{background:#4caf501a;border-color:#4caf504d}.stat-item.insufficient{background:#f4433626;border-color:#f4433666;animation:pulse-warning 1s ease-in-out infinite}@keyframes pulse-warning{0%,to{border-color:#f4433666}50%{border-color:#f44336cc}}.factory-cost{text-align:center;color:#888;font-size:.85rem;padding:.25rem;background:#0000004d;border-radius:4px}.stat-icon{font-size:1.2rem}.stat-value{font-size:1rem;font-weight:700;color:gold}.debug-toggle{width:50px;height:50px;padding:0;background-color:#333;color:#fff;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;font-size:1.5rem;display:flex;align-items:center;justify-content:center}.debug-toggle:hover{border-color:#646cff;transform:scale(1.05)}.debug-panel{position:fixed;right:20px;top:120px;background:#1a1a1af2;border:2px solid #444;border-radius:12px;padding:1rem;z-index:1000;min-width:250px;box-shadow:0 4px 20px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.debug-panel h4{margin:0 0 1rem;color:#646cff;font-size:1rem}.debug-stats{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.debug-item{display:flex;justify-content:space-between;padding:.25rem .5rem;background:#ffffff0d;border-radius:4px;font-size:.9rem}.debug-item span:first-child{color:#888}.debug-item span:last-child{font-weight:700;color:gold}.debug-item .warning{color:#ff9800!important}.debug-item .good{color:#4caf50!important}.debug-help{border-top:1px solid #444;padding-top:.75rem;font-size:.85rem;color:#888}.debug-help p{margin:0 0 .5rem;color:#aaa}.debug-help ul{margin:0;padding-left:1.25rem;list-style-type:disc}.debug-help li{margin-bottom:.25rem;color:#888}.grid{display:grid;gap:0px;background-color:transparent;border:none;padding:0;transition:transform .1s ease-out;position:absolute;left:50%;top:50%;transform-origin:center center;image-rendering:pixelated;image-rendering:crisp-edges;backface-visibility:hidden;-webkit-backface-visibility:hidden;will-change:transform}.cell{border:none;cursor:pointer;transition:opacity .1s;position:relative;overflow:visible;pointer-events:all;background-size:cover;background-position:center;background-repeat:no-repeat;outline:1px solid transparent;transform:translateZ(0);-webkit-transform:translateZ(0)}.cell:has(.factory-input-indicator),.cell:has(.factory-output-indicator){z-index:5}.cell.empty-tile{background-image:url(/factorio-like/assets/ground-tile.png);background-size:100% 100%}.cell.wall-tile{background-image:url(/factorio-like/assets/rock-tile.png);background-size:100% 100%}.cell.metal-tile{background-image:url(/factorio-like/assets/metal-rock-tile.png);background-size:100% 100%}.cell.silver-tile{background-image:url(/factorio-like/assets/silver-rock-tile.svg);background-size:100% 100%}.cell.belt-tile-1-h{background-image:url(/factorio-like/assets/belt-tile-1-h.png)!important;background-size:100% 100%!important}.cell.belt-tile-1-v{background-image:url(/factorio-like/assets/belt-tile-1-v.png)!important;background-size:100% 100%!important}.cell.belt-tile-2-h{background-image:url(/factorio-like/assets/belt-tile-2-h.png)!important;background-size:100% 100%!important}.cell.belt-tile-2-v{background-image:url(/factorio-like/assets/belt-tile-2-v.png)!important;background-size:100% 100%!important}.cell.belt-tile-3-h{background-image:url(/factorio-like/assets/belt-tile-3-h.png)!important;background-size:100% 100%!important}.cell.belt-tile-3-v{background-image:url(/factorio-like/assets/belt-tile-3-v.png)!important;background-size:100% 100%!important}.cell.belt-tile-4-h{background-image:url(/factorio-like/assets/belt-tile-4-h.png)!important;background-size:100% 100%!important}.cell.belt-tile-4-v{background-image:url(/factorio-like/assets/belt-tile-4-v.png)!important;background-size:100% 100%!important}.cell.belt-tile-5-h{background-image:url(/factorio-like/assets/belt-tile-5-h.png)!important;background-size:100% 100%!important}.cell.belt-tile-5-v{background-image:url(/factorio-like/assets/belt-tile-5-v.png)!important;background-size:100% 100%!important}.cell.belt-curve-up-right{background-image:url(/factorio-like/assets/belt-tile-1-curve-up-right.png)!important;background-size:100% 100%!important}.cell.belt-curve-right-down{background-image:url(/factorio-like/assets/belt-tile-1-curve-right-down.png)!important;background-size:100% 100%!important}.cell.belt-curve-down-left{background-image:url(/factorio-like/assets/belt-tile-1-curve-down-left.png)!important;background-size:100% 100%!important}.cell.belt-curve-left-up{background-image:url(/factorio-like/assets/belt-tile-1-curve-left-up.png)!important;background-size:100% 100%!important}.cell:hover{opacity:.8}.cell-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;pointer-events:none;z-index:1;-webkit-user-select:none;user-select:none}.belt-full{border:2px solid #f44336!important;box-shadow:inset 0 0 5px #f4433680}.factory-stored-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;pointer-events:none;z-index:7;background-size:cover;background-position:center;image-rendering:pixelated;image-rendering:crisp-edges;filter:drop-shadow(0 0 2px rgba(255,215,0,.8));animation:pulse-star 2s ease-in-out infinite}.factory-resource-count{position:absolute;top:2px;right:2px;background-color:#4caf50e6;color:#fff;font-size:9px;padding:2px 4px;border-radius:3px;font-weight:700;pointer-events:none;z-index:8;border:1px solid rgba(255,255,255,.3)}@keyframes pulse-star{0%,to{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1.15);opacity:.8}}.factory-input-indicator,.factory-output-indicator{position:absolute;pointer-events:none;z-index:20}.factory-input-indicator{background:linear-gradient(to right,#4caf5000,#4caf50,#4caf5000);box-shadow:0 0 6px #4caf50cc}.factory-output-indicator{background:linear-gradient(to right,#f4433600,#f44336,#f4433600);box-shadow:0 0 6px #f44336cc}.factory-input-up{top:-3px;left:2px;right:2px;height:3px;background:linear-gradient(to bottom,#4caf5000,#4caf50)}.factory-output-up{bottom:-3px;left:2px;right:2px;height:3px;background:linear-gradient(to top,#f4433600,#f44336)}.factory-input-right{right:-3px;top:2px;bottom:2px;width:3px;background:linear-gradient(to left,#4caf5000,#4caf50)}.factory-output-right{left:-3px;top:2px;bottom:2px;width:3px;background:linear-gradient(to right,#f4433600,#f44336)}.factory-input-down{bottom:-3px;left:2px;right:2px;height:3px;background:linear-gradient(to top,#4caf5000,#4caf50)}.factory-output-down{top:-3px;left:2px;right:2px;height:3px;background:linear-gradient(to bottom,#f4433600,#f44336)}.factory-input-left{left:-3px;top:2px;bottom:2px;width:3px;background:linear-gradient(to right,#4caf5000,#4caf50)}.factory-output-left{right:-3px;top:2px;bottom:2px;width:3px;background:linear-gradient(to left,#f4433600,#f44336)}.item{position:absolute;width:12px;height:12px;background-color:transparent;border-radius:0;transform:translate(-50%,-50%);box-shadow:none;border:none;pointer-events:none;z-index:10;transition:left var(--tick-rate, 16ms) ease-out,top var(--tick-rate, 16ms) ease-out;will-change:left,top;image-rendering:pixelated;image-rendering:crisp-edges}.item.blocked{filter:brightness(.7) saturate(1.5) hue-rotate(-20deg);transition:none;animation:pulse-blocked 1s ease-in-out infinite}@keyframes pulse-blocked{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.1)}}@media (max-width: 768px){.grid-container{padding:.5rem}.tools{font-size:.9rem}}.landing.svelte-1d3ylk5{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:2rem}.container.svelte-1d3ylk5{max-width:600px;width:100%}.header.svelte-1d3ylk5{text-align:center;margin-bottom:3rem}h1.svelte-1d3ylk5{font-size:3rem;margin:0;background:linear-gradient(135deg,#646cff,#00d4ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.subtitle.svelte-1d3ylk5{font-size:1.2rem;color:#888;margin:0}.menu.svelte-1d3ylk5{display:flex;flex-direction:column;gap:1rem;margin-bottom:3rem}.menu-button.svelte-1d3ylk5{display:flex;flex-direction:column;align-items:center;padding:2rem;border:2px solid transparent;border-radius:12px;background:#ffffff0d;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.menu-button.svelte-1d3ylk5:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.menu-button.svelte-1d3ylk5:hover:before{left:100%}.menu-button.svelte-1d3ylk5:hover{transform:translateY(-4px);box-shadow:0 8px 24px #646cff4d}.menu-button.primary.svelte-1d3ylk5{border-color:#646cff}.menu-button.primary.svelte-1d3ylk5:hover{background:#646cff1a;border-color:#747bff}.menu-button.continue.svelte-1d3ylk5{border-color:#4caf50}.menu-button.continue.svelte-1d3ylk5:hover{background:#4caf501a;border-color:#66bb6a;box-shadow:0 8px 24px #4caf504d}.menu-button.secondary.svelte-1d3ylk5{border-color:#00d4ff}.menu-button.secondary.svelte-1d3ylk5:hover{background:#00d4ff1a;border-color:#3df}.icon.svelte-1d3ylk5{font-size:3rem;margin-bottom:.5rem}.text.svelte-1d3ylk5{font-size:1.5rem;font-weight:600;color:#fff;margin-bottom:.5rem}.description.svelte-1d3ylk5{font-size:.9rem;color:#888;text-align:center}.features.svelte-1d3ylk5{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.feature.svelte-1d3ylk5{display:flex;align-items:center;gap:.5rem;color:#888;font-size:.9rem}.feature-icon.svelte-1d3ylk5{font-size:1.2rem}@media (max-width: 768px){h1.svelte-1d3ylk5{font-size:2rem}.subtitle.svelte-1d3ylk5{font-size:1rem}.menu-button.svelte-1d3ylk5{padding:1.5rem}.text.svelte-1d3ylk5{font-size:1.2rem}.features.svelte-1d3ylk5{flex-direction:column;align-items:center;gap:.5rem}}main.svelte-159wxr0.svelte-159wxr0{max-width:100%;margin:0;padding:0;display:flex;flex-direction:column;height:100vh;overflow:hidden}.game-header.svelte-159wxr0.svelte-159wxr0{position:fixed;top:0;left:0;right:0;z-index:900;background:#1a1a1af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid #444;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;flex-wrap:wrap;gap:1rem;box-shadow:0 2px 10px #0000004d}.title-section.svelte-159wxr0.svelte-159wxr0{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.mode-badge.svelte-159wxr0.svelte-159wxr0{background:#646cff33;border:1px solid #646cff;padding:.25rem .75rem;border-radius:12px;font-size:.9rem;color:#646cff;font-weight:500}.back-button.svelte-159wxr0.svelte-159wxr0{padding:.5rem 1rem;background:#ffffff1a;border:1px solid #444;border-radius:8px;color:#fff;cursor:pointer;transition:all .2s}.back-button.svelte-159wxr0.svelte-159wxr0:hover{background:#ffffff26;border-color:#646cff}h1.svelte-159wxr0.svelte-159wxr0{color:#646cff;margin-bottom:.5rem}.controls.svelte-159wxr0.svelte-159wxr0{position:fixed;top:60px;right:20px;z-index:899}.settings-panel.svelte-159wxr0.svelte-159wxr0{background-color:#2a2a2a;border:2px solid #444;border-radius:8px;padding:1.5rem;margin-bottom:2rem;max-width:500px;margin-left:auto;margin-right:auto}.settings-panel.svelte-159wxr0 h3.svelte-159wxr0{margin-top:0;margin-bottom:1rem}.settings-group.svelte-159wxr0.svelte-159wxr0{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.settings-group.svelte-159wxr0 label.svelte-159wxr0{display:flex;justify-content:space-between;align-items:center;gap:1rem}.settings-group.svelte-159wxr0 input.svelte-159wxr0{width:100px;padding:.5rem;background-color:#1a1a1a;border:1px solid #444;border-radius:4px;color:#fff}.settings-buttons.svelte-159wxr0.svelte-159wxr0{display:flex;gap:.5rem;justify-content:center}.warning.svelte-159wxr0.svelte-159wxr0{margin-top:1rem;margin-bottom:0;color:#ff9800;font-size:.9rem;text-align:center}.fps-hint.svelte-159wxr0.svelte-159wxr0{font-size:.8rem;color:#888;margin-left:.5rem}footer.svelte-159wxr0.svelte-159wxr0{position:fixed;bottom:0;left:0;right:0;z-index:900;background:#1a1a1af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:2px solid #444;padding:.5rem 1rem;box-shadow:0 -2px 10px #0000004d}footer.svelte-159wxr0 p.svelte-159wxr0{color:#888;font-size:.9rem;margin:0;text-align:center}@media (prefers-color-scheme: light){.settings-panel.svelte-159wxr0.svelte-159wxr0{background-color:#f5f5f5;border-color:#ddd}.settings-group.svelte-159wxr0 input.svelte-159wxr0{background-color:#fff;color:#213547}.mode-badge.svelte-159wxr0.svelte-159wxr0{background:#646cff1a}.back-button.svelte-159wxr0.svelte-159wxr0{background:#0000000d;color:#213547}}
