.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background-color:var(--color-bg-medium);padding:var(--spacing-lg);text-align:center;border-bottom:4px solid var(--color-lime)}.app-header .subtitle{font-size:.875rem;color:var(--color-lime);margin-bottom:0}.app-main{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.connection-screen{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px;max-width:600px;margin:0 auto}.connection-screen.error{border-color:var(--color-error)}.connection-screen button{margin-top:var(--spacing-md)}.connection-screen .hint{margin-top:var(--spacing-md);font-size:.75rem}.battle-flow{width:100%;max-width:1200px;margin:0 auto}.welcome-state{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px}.welcome-state h2{margin-bottom:var(--spacing-lg)}.welcome-state p{margin-bottom:var(--spacing-lg);font-size:1rem}.welcome-state button{margin-top:var(--spacing-md)}.error-state{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-medium);border:4px solid var(--color-error);border-radius:8px}.battle-info{text-align:center;padding:var(--spacing-xl);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px}.battle-info h2{margin-bottom:var(--spacing-lg)}.battle-info p{margin-bottom:var(--spacing-sm);font-family:var(--font-pixel);font-size:.75rem}.battle-info button{margin-top:var(--spacing-lg)}.game-canvas-container{display:flex;flex-direction:column;align-items:center}.game-canvas{width:256px;height:256px;border:2px solid var(--color-lime);background-color:#5c94fc;image-rendering:pixelated;image-rendering:crisp-edges}.game-canvas-loading,.game-canvas-error{width:256px;height:256px;border:4px solid var(--color-lime);background-color:var(--color-bg-medium);display:flex;align-items:center;justify-content:center;font-family:var(--font-pixel);font-size:.625rem;text-align:center;padding:var(--spacing-md)}.game-canvas-error{border-color:var(--color-error);color:var(--color-error)}.controls-hint{font-family:var(--font-pixel);font-size:.625rem;color:var(--color-lime);text-align:center}.game-status{font-family:var(--font-pixel);font-size:.5rem;color:var(--color-text);text-align:center;margin-top:var(--spacing-xs)}canvas{display:block;width:100%;height:100%;image-rendering:pixelated;image-rendering:crisp-edges}.battle-header{text-align:center;margin-bottom:var(--spacing-lg)}.battle-header h2{margin-bottom:var(--spacing-sm)}.battle-header .controls-hint{font-family:var(--font-pixel);font-size:.625rem}.battle-screen{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.level-panel{background-color:var(--color-bg-medium);border:4px solid var(--color-bg-dark);border-radius:8px;padding:var(--spacing-md);display:flex;flex-direction:column;align-items:center}.level-panel.active{border-color:var(--color-success);box-shadow:0 0 30px #63c64d99}.level-panel.done{border-color:var(--color-lime);opacity:.9}.level-header{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:var(--spacing-sm);font-family:var(--font-pixel);font-size:.75rem}.level-label{background-color:var(--color-lime);color:var(--color-bg-dark);padding:var(--spacing-xs) var(--spacing-sm);font-weight:700}.generator-name{color:var(--color-lime)}.generator-hidden{color:var(--color-text);opacity:.6;font-style:italic}.level-status{margin-top:var(--spacing-sm);font-family:var(--font-pixel);font-size:.625rem;text-align:center}.status-playing{color:var(--color-success);animation:pulse 1s infinite}.status-complete{color:var(--color-lime)}.status-waiting{color:var(--color-text);opacity:.5}.status-next{color:var(--color-text)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.level-summary{background-color:var(--color-bg-dark);padding:var(--spacing-md);border-radius:4px;font-family:var(--font-pixel);font-size:.625rem;min-height:100px;width:256px}.level-summary p{margin-bottom:var(--spacing-xs)}.battle-footer{text-align:center;font-family:var(--font-pixel);font-size:.625rem;color:var(--color-lime)}.results-header{text-align:center;margin-bottom:var(--spacing-lg)}.generator-reveal{display:flex;justify-content:center;gap:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.reveal-panel{background-color:var(--color-bg-medium);padding:var(--spacing-md) var(--spacing-lg);border:4px solid var(--color-lime);border-radius:8px;font-family:var(--font-pixel);text-align:center}.reveal-label{display:block;font-size:.75rem;color:var(--color-text);margin-bottom:var(--spacing-xs)}.reveal-name{display:block;font-size:1rem;color:var(--color-lime)}.submitting-state{text-align:center;padding:var(--spacing-lg);font-family:var(--font-pixel)}.voting-panel{padding:var(--spacing-lg);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px;text-align:center;max-width:600px;margin:var(--spacing-lg) auto}.voting-panel h3{margin-bottom:var(--spacing-lg);font-size:1rem}.vote-buttons{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-md)}.vote-button{padding:var(--spacing-md) var(--spacing-lg);font-size:.75rem;min-width:140px}.vote-button.left{background-color:#4a9eff;color:#fff}.vote-button.right{background-color:#ff6b4a;color:#fff}.vote-button.tie{background-color:#9b59b6;color:#fff}.vote-button.skip{background-color:#666;color:#fff}.skip-section{margin-top:var(--spacing-md)}.skip-section .vote-button{min-width:200px}.leaderboard{padding:var(--spacing-lg);background-color:var(--color-bg-medium);border:4px solid var(--color-lime);border-radius:8px;max-width:800px;margin:0 auto}.leaderboard h2{margin-bottom:var(--spacing-md);text-align:center}.leaderboard-table{width:100%;border-collapse:collapse;font-family:var(--font-pixel);font-size:.625rem;margin-top:var(--spacing-md)}.leaderboard-table th,.leaderboard-table td{padding:var(--spacing-sm);text-align:left;border-bottom:2px solid var(--color-bg-dark)}.leaderboard-table th{color:var(--color-lime);font-weight:400}.leaderboard-table td{color:var(--color-text)}.leaderboard-table .generator-name{color:var(--color-lime)}.leaderboard .timestamp{text-align:center;font-size:.625rem;color:var(--color-lime);opacity:.7;margin-top:var(--spacing-md)}.leaderboard-state{display:flex;flex-direction:column;gap:var(--spacing-lg);align-items:center}.leaderboard-state h2{color:var(--color-success)}.gameplay-state{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.gameplay-state h2{text-align:center;font-size:1.25rem}.status-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-dark);border-bottom:2px solid var(--color-lime);font-family:var(--font-pixel);font-size:.625rem}:root{--color-bg-dark: #0f380f;--color-bg-medium: #306230;--color-lime: #9bbc0f;--color-light: #8bac0f;--color-text: #e0f8d0;--color-error: #e43b44;--color-success: #63c64d;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--font-pixel: "Press Start 2P", cursive;--font-system: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-system);background-color:var(--color-bg-dark);color:var(--color-text);line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-pixel);line-height:1.4;font-weight:400}h1{font-size:1.5rem;margin-bottom:var(--spacing-md)}h2{font-size:1rem;margin-bottom:var(--spacing-sm)}p{margin-bottom:var(--spacing-sm)}button{font-family:var(--font-pixel);font-size:.75rem;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-lime);color:var(--color-bg-dark);border:3px solid var(--color-bg-dark);cursor:pointer;transition:all .1s;text-transform:uppercase}button:hover:not(:disabled){background-color:var(--color-light);transform:translateY(-2px);box-shadow:0 4px 0 var(--color-bg-dark)}button:active:not(:disabled){transform:translateY(0);box-shadow:none}button:disabled{opacity:.5;cursor:not-allowed}button.primary-button{background-color:var(--color-success);color:#fff;padding:var(--spacing-md) var(--spacing-xl);font-size:.875rem}.error-message{color:var(--color-error);font-family:var(--font-pixel);font-size:.75rem}.hint{color:var(--color-lime);font-size:.875rem;opacity:.8}#root{width:100%;min-height:100vh}
