*{margin:0;padding:0;box-sizing:border-box}body{background:#0a0a1a;color:#e0e0e0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden;height:100vh}#app{display:flex;flex-direction:column;height:100vh}header{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;background:#12122a;border-bottom:2px solid #2a2a5e}header h1{font-size:1.3rem;color:#8af;letter-spacing:2px}.stats{display:flex;gap:20px}.stat{font-size:.95rem}.stat strong{color:#fc4}.difficulty-label{font-weight:700;letter-spacing:1px}.game-area{display:flex;flex:1;overflow:hidden}.sidebar{width:220px;background:#12122a;border-right:2px solid #2a2a5e;padding:12px;display:flex;flex-direction:column;gap:8px;overflow-y:auto}.sidebar h2{font-size:1rem;color:#8af;border-bottom:1px solid #2a2a5e;padding-bottom:6px}.tower-btn{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:8px 10px;background:#1a1a3e;border:2px solid #2a2a5e;border-radius:6px;color:#e0e0e0;cursor:pointer;font-size:.85rem;transition:all .15s}.tower-btn:hover{background:#252550;border-color:#4a4a8e}.tower-btn.active{border-color:#8f8;background:#1a3a1a;box-shadow:0 0 10px #64ff6433}.tower-btn.too-expensive{opacity:.5}.tower-icon{font-size:1.2rem}.tower-name{flex:1;font-weight:600}.tower-cost{color:#fc4;font-size:.8rem}.tower-key{color:#888;font-size:.75rem}#tower-info{background:#1a1a3e;border:1px solid #2a2a5e;border-radius:6px;padding:10px;min-height:80px}#tower-info .hint{color:#666;font-size:.8rem;font-style:italic}.tower-detail h3{font-size:.95rem;margin-bottom:6px}.tower-detail p{font-size:.8rem;margin-bottom:3px}.tower-detail strong{color:#fc4}.max-level{color:#8f8;font-style:italic;margin-top:6px}.action-btn{display:block;width:100%;margin-top:6px;padding:6px 8px;border:none;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:600;transition:all .15s}.action-btn.upgrade{background:#2a6a2a;color:#e0e0e0}.action-btn.upgrade:hover:not(:disabled){background:#3a8a3a}.action-btn.upgrade:disabled{background:#333;color:#666;cursor:not-allowed}.action-btn.sell{background:#6a2a2a;color:#e0e0e0}.action-btn.sell:hover{background:#8a3a3a}.start-btn{padding:10px;background:#2a4a8a;color:#e0e0e0;border:2px solid #4a6aaa;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:700;transition:all .15s;margin-top:auto}.start-btn:hover:not(:disabled){background:#3a5a9a;border-color:#6a8acc}.start-btn:disabled{opacity:.5;cursor:not-allowed}.speed-controls{display:flex;gap:4px}.speed-btn{flex:1;padding:6px 4px;background:#1a1a3e;border:2px solid #2a2a5e;border-radius:4px;color:#e0e0e0;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .15s}.speed-btn:hover{background:#252550;border-color:#4a4a8e}.speed-btn.active{border-color:#fc4;background:#3a3a1a;color:#fc4;box-shadow:0 0 8px #ffc83c33}.quit-btn{padding:8px;background:#4a1a1a;border:2px solid #6a2a2a;border-radius:6px;color:#e0e0e0;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .15s}.quit-btn:hover{background:#6a2a2a;border-color:#8a3a3a}.volume-control{display:flex;flex-direction:column;gap:4px}.volume-control label{font-size:.8rem;color:#aaa}#volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:#2a2a5e;border-radius:3px;outline:none;cursor:pointer}#volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:#8af;border-radius:50%;cursor:pointer}#volume-slider::-moz-range-thumb{width:14px;height:14px;background:#8af;border-radius:50%;border:none;cursor:pointer}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#1a1a3e;border:2px solid #4a4a8e;border-radius:12px;padding:28px 36px;text-align:center;min-width:320px}.modal h2{font-size:1.4rem;color:#f88;margin-bottom:10px}.modal p{font-size:.95rem;color:#aaa;margin-bottom:20px}.modal-actions{display:flex;gap:12px;justify-content:center}.modal-btn{padding:10px 24px;border:2px solid;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:700;transition:all .15s}.modal-btn.confirm{background:#6a2a2a;border-color:#8a3a3a;color:#e0e0e0}.modal-btn.confirm:hover{background:#8a3a3a}.modal-btn.cancel{background:#2a4a8a;border-color:#4a6aaa;color:#e0e0e0}.modal-btn.cancel:hover{background:#3a5a9a}.controls-help{border-top:1px solid #2a2a5e;padding-top:8px;margin-top:8px}.controls-help h3{font-size:.85rem;color:#8af;margin-bottom:4px}.controls-help p{font-size:.75rem;color:#888;margin-bottom:2px}.canvas-wrapper{flex:1;display:flex;align-items:center;justify-content:center;position:relative;background:#0e0e1e}canvas{display:block;cursor:crosshair;image-rendering:pixelated}.message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:900;text-align:center;pointer-events:none;text-shadow:0 0 20px rgba(0,0,0,.8)}.message.won{color:#8f8;animation:pulse 1s ease-in-out infinite}.message.lost{color:#f44;animation:pulse 1s ease-in-out infinite}.message.build-error{color:#fa0;font-size:1.2rem;animation:fadeOut 2s ease-in-out forwards}@keyframes fadeOut{0%{opacity:1}70%{opacity:1}to{opacity:0}}@keyframes pulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.05)}}.difficulty-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:20px}.difficulty-screen h1{font-size:2.5rem;color:#8af;letter-spacing:4px}.difficulty-subtitle{font-size:1.1rem;color:#888}.difficulty-options{display:flex;gap:20px;margin-top:10px}.difficulty-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 32px;background:#1a1a3e;border:2px solid #2a2a5e;border-radius:12px;color:#e0e0e0;cursor:pointer;transition:all .2s;min-width:180px}.difficulty-btn:hover{background:#252550;border-color:#6a6aae;transform:translateY(-4px);box-shadow:0 8px 24px #0006}.diff-icon{font-size:2rem}.diff-name{font-size:1.3rem;font-weight:700}.diff-desc{font-size:.8rem;color:#888;text-align:center}.faction-label{font-size:.9rem;font-weight:700;color:#8fa;text-align:center;padding:4px 0 2px;letter-spacing:1px}.buff-active{color:#8f8;font-weight:700;animation:buffPulse 1s ease-in-out infinite}@keyframes buffPulse{0%,to{opacity:1}50%{opacity:.6}}.faction-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:20px}.faction-screen h1{font-size:2.5rem;color:#8af;letter-spacing:4px}.faction-subtitle{font-size:1.1rem;color:#888}.faction-options{display:flex;gap:20px;margin-top:10px}.faction-btn{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 36px;background:#1a1a3e;border:2px solid #2a5e2a;border-radius:12px;color:#e0e0e0;cursor:pointer;transition:all .2s;min-width:220px;max-width:280px}.faction-btn:hover{background:#1a3a1a;border-color:#4a8a4a;transform:translateY(-4px);box-shadow:0 8px 24px #00500066}.faction-icon{font-size:3rem}.faction-name{font-size:1.4rem;font-weight:700;color:#8fa}.faction-desc{font-size:.85rem;color:#aaa;text-align:center;line-height:1.4}.faction-towers{font-size:.8rem;color:#fc4;text-align:center;font-weight:600}
