*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}h1,h2,h3,h4,h5,h6{margin:0;font-weight:inherit}p{margin:0}ul,ol{list-style:none;padding:0;margin:0}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit;padding:0}input,textarea{border:none;outline:none;font:inherit;color:inherit;background:none}a{color:inherit;text-decoration:none}img,svg{display:block;max-width:100%;height:auto}:root{--color-primary: #00d4ff;--color-secondary: #b794f4;--color-accent: #00f593;--color-danger: #ff3864;--color-warning: #ff9500;--bg-primary: #0a0f1c;--bg-secondary: #0f1628;--bg-accent: #141d33;--glass-bg: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .1);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .4);--text-primary: #e0e6f0;--text-secondary: #a8b2c7;--text-muted: #6b7890;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--font-primary: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease}h1{font-size:2.5rem;font-weight:700;line-height:1.2}h2{font-size:2rem;font-weight:600;line-height:1.3}h3{font-size:1.5rem;font-weight:600;line-height:1.4}h4{font-size:1.25rem;font-weight:500;line-height:1.5}p{font-size:1rem;line-height:1.6}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.font-mono{font-family:var(--font-mono)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:500;transition:all var(--transition-fast);cursor:pointer;position:relative;overflow:hidden;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--bg-primary)}.btn-primary:hover:not(:disabled){background:var(--color-accent);transform:translateY(-1px);box-shadow:0 4px 12px #00d4ff4d}.btn-secondary{background:var(--glass-bg);color:var(--text-primary);border:1px solid var(--glass-border)}.btn-secondary:hover:not(:disabled){background:#ffffff1a;border-color:#fff3}.btn-ghost{background:transparent;color:var(--text-primary)}.btn-ghost:hover:not(:disabled){background:var(--glass-bg)}.btn-small{padding:var(--spacing-xs) var(--spacing-md);font-size:.875rem}.btn-medium{padding:var(--spacing-sm) var(--spacing-lg);font-size:1rem}.btn-large{padding:var(--spacing-md) var(--spacing-xl);font-size:1.125rem}.btn-full-width{width:100%}.btn-loading{color:transparent}.btn-spinner{position:absolute;width:1.25rem;height:1.25rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.form-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.input-container{position:relative;display:flex;align-items:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.input-container:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #00d4ff1a}.input-container.has-error{border-color:var(--color-danger)}.input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:transparent;color:var(--text-primary);font-size:1rem;width:100%}.input-icon{padding-left:var(--spacing-md);font-size:1.25rem}.input-error{font-size:.75rem;color:var(--color-danger);margin-top:var(--spacing-xs)}.lobby-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.background-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(0,212,255,.1) 0%,transparent 70%);animation:pulse 4s ease-in-out infinite}.lobby-content{width:100%;max-width:768px;padding:var(--spacing-xl);z-index:1}.lobby-header{text-align:center;margin-bottom:var(--spacing-2xl)}.game-title{font-size:4rem;font-weight:700;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:var(--spacing-sm)}.game-subtitle{font-size:1.25rem;color:var(--text-secondary)}.lobby-actions{display:flex;flex-direction:column;gap:var(--spacing-md)}.lobby-button{padding:var(--spacing-lg) var(--spacing-2xl);font-size:1.125rem}.lobby-form{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);padding:var(--spacing-2xl);box-shadow:var(--glass-shadow)}.how-to-play-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);background:#b794f41a;border:1px solid rgba(183,148,244,.3);transition:all var(--transition-normal)}.how-to-play-button:hover{background:#b794f433;border-color:var(--color-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #b794f44d}.how-to-play-button span{font-size:1.25rem}.game-mode-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-top:var(--spacing-sm)}.game-mode-option{padding:var(--spacing-lg);background:var(--glass-bg);border:2px solid var(--glass-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);text-align:center}.game-mode-option:hover{background:#ffffff14;border-color:var(--color-primary);transform:translateY(-2px)}.game-mode-option.selected{background:#00d4ff1a;border-color:var(--color-primary);box-shadow:0 0 20px #00d4ff4d}.game-mode-option h4{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.game-mode-option p{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.player-requirement{display:inline-block;font-size:.75rem;color:var(--color-primary);background:#00d4ff1a;padding:2px 8px;border-radius:var(--radius-sm)}.game-room{height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.game-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-xl);margin:var(--spacing-md)}.header-left{display:flex;align-items:center;gap:var(--spacing-lg)}.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.room-code{font-size:.875rem;color:var(--text-secondary)}.room-code span{font-family:var(--font-mono);color:var(--color-primary);font-weight:600}.game-main{flex:1;display:flex;gap:var(--spacing-md);padding:0 var(--spacing-md) var(--spacing-md);overflow:hidden;min-height:0}.game-sidebar{width:320px;display:flex;flex-direction:column;gap:var(--spacing-md);transition:all var(--transition-normal);min-height:0}.game-sidebar.collapsed{width:0;opacity:0;overflow:hidden}.game-center{flex:1;display:flex;flex-direction:column;min-width:0;justify-content:center;align-items:center}.spectrum-area{padding:var(--spacing-md);display:flex;flex-direction:column;min-height:0}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.panel-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.player-count{font-size:.875rem;color:var(--text-secondary);font-weight:500}.player-list{padding:var(--spacing-lg);flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.players-container{display:flex;flex-direction:column;gap:var(--spacing-sm);overflow-y:auto;padding-right:var(--spacing-xs);flex-shrink:0;max-height:40%}.player-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);background:var(--glass-bg)}.player-item:hover{background:#ffffff14}.player-item.current-player{background:#00d4ff1a;border:1px solid rgba(0,212,255,.3)}.player-item.clue-giver{background:#b794f41a;border:1px solid rgba(183,148,244,.3)}.player-item.has-guessed{opacity:.7}.player-item.disconnected{opacity:.6;background:#ff38640d;border:1px dashed rgba(255,56,100,.3);position:relative}.player-item.disconnected:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(255,56,100,.05) 10px,rgba(255,56,100,.05) 20px);border-radius:var(--radius-md);pointer-events:none}.player-avatar{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.125rem;color:#fff;flex-shrink:0}.player-1{background:linear-gradient(135deg,#00d4ff,#0096ff)}.player-2{background:linear-gradient(135deg,#b794f4,#9f7aea)}.player-3{background:linear-gradient(135deg,#00f593,#00c773)}.player-4{background:linear-gradient(135deg,#ff9500,#ff6b00)}.player-5{background:linear-gradient(135deg,#ff3864,#ff1744)}.player-6{background:linear-gradient(135deg,#ffd93d,#ffc107)}.player-7{background:linear-gradient(135deg,#6bcf7f,#4caf50)}.player-8{background:linear-gradient(135deg,#e91e63,#c2185b)}.player-info{flex:1;min-width:0}.player-name{font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.host-badge,.clue-giver-badge{font-size:.875rem;flex-shrink:0}.player-status{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.status-disconnected{color:var(--color-danger);display:flex;align-items:center;gap:4px;animation:pulse 1.5s ease-in-out infinite}.disconnected-icon{font-size:.875rem}.status-clue-giver{color:var(--color-secondary)}.status-guessed{color:var(--color-accent)}.status-thinking{color:var(--color-warning)}.status-ready{color:var(--text-secondary)}.player-score{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.score-value{font-size:1.25rem;font-weight:600;color:var(--color-primary);line-height:1}.score-label{font-size:.625rem;color:var(--text-muted);text-transform:uppercase}.leaderboard-section{flex:1;display:flex;flex-direction:column;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--glass-border);min-height:0}.leaderboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.leaderboard-header h4{font-size:1rem;font-weight:600;color:var(--text-primary)}.round-indicator{font-size:.75rem;color:var(--text-secondary);background:var(--glass-bg);padding:2px 8px;border-radius:var(--radius-sm)}.leaderboard-container{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs);overflow-y:auto;padding-right:var(--spacing-xs)}.leaderboard-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--glass-bg);border-radius:var(--radius-sm);transition:all var(--transition-fast);border:1px solid transparent}.leaderboard-item:hover{background:#ffffff14;transform:translate(2px)}.leaderboard-item.leader{background:linear-gradient(135deg,#00f5931a,#00d4ff1a);border-color:#00f5934d}.leaderboard-item.current-player{border-color:var(--color-primary)}.leaderboard-item.disconnected{opacity:.6;background:#ff38640d;border:1px dashed rgba(255,56,100,.3)}.leaderboard-rank{width:32px;text-align:center;font-weight:600;color:var(--text-secondary);flex-shrink:0}.leaderboard-player{flex:1;display:flex;align-items:center;gap:var(--spacing-xs);min-width:0}.leaderboard-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.you-indicator{font-size:.75rem;color:var(--color-primary);flex-shrink:0}.leaderboard-score{font-weight:600;font-size:1.125rem;color:var(--text-primary);min-width:40px;text-align:right}.empty-leaderboard{text-align:center;color:var(--text-muted);padding:var(--spacing-lg);font-size:.875rem}.notification-panel{padding:var(--spacing-lg);display:flex;flex-direction:column;flex-shrink:0}.game-control-container{margin-top:var(--spacing-md);flex:1;display:flex;flex-direction:column}.control-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.control-hint{text-align:center;color:var(--text-secondary);font-size:.875rem}.waiting-message{text-align:center;color:var(--text-secondary);padding:var(--spacing-lg)}.input-group{display:flex;gap:var(--spacing-sm);align-items:flex-start}.input-group .input-wrapper{flex:1;min-width:0}.input-group .btn{flex-shrink:0}.timer-display{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--glass-bg);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border:1px solid var(--glass-border);transition:all var(--transition-fast)}.timer-display.danger{background:#ff38641a;border-color:#ff386480;animation:pulse 1s ease-in-out infinite}.timer-label{color:var(--text-secondary);font-size:.875rem}.timer-value{font-family:var(--font-mono);font-size:1.25rem;font-weight:600;color:var(--text-primary)}.results-overlay{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:600px;max-height:90vh;background:#0000006e;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;border-radius:var(--radius-lg);box-shadow:0 0 20px #00000080}.results-container{width:100%;height:100%;overflow-y:auto;padding:var(--spacing-2xl);border-radius:var(--radius-lg)}.results-container h2{text-align:center;margin-bottom:var(--spacing-xl);color:var(--color-primary)}.results-content{margin:var(--spacing-xl) 0;display:flex;flex-direction:column;gap:var(--spacing-lg)}.target-info{text-align:center;padding:var(--spacing-lg);background:#00f5931a;border:1px solid rgba(0,245,147,.3);border-radius:var(--radius-md)}.target-info h3{margin-bottom:var(--spacing-sm);color:var(--color-accent)}.target-info p{font-family:var(--font-mono);font-size:1.25rem;color:var(--text-primary)}.guesses-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.guesses-list h3{margin-bottom:var(--spacing-sm);color:var(--text-primary)}.guess-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--glass-bg);border-radius:var(--radius-md);gap:var(--spacing-md)}.guess-distance{color:var(--text-secondary);font-size:.875rem}.guess-score{color:var(--color-accent);font-weight:600}.winner-announcement{text-align:center;padding:var(--spacing-xl);background:linear-gradient(135deg,#00d4ff1a,#b794f41a);border:2px solid var(--color-primary);border-radius:var(--radius-lg);animation:pulse 2s ease-in-out infinite}.winner-announcement h3{font-size:1.5rem;margin-bottom:var(--spacing-sm);color:var(--color-primary)}.results-actions{display:flex;justify-content:center;margin-top:var(--spacing-xl);gap:var(--spacing-md)}.mobile-overlay,.mobile-tabs{display:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.game-mode-indicator{font-size:.875rem;color:var(--color-secondary);text-align:center;margin:var(--spacing-sm) 0;padding:4px 12px;background:#b794f41a;border-radius:var(--radius-sm);display:inline-block}.selected-prompt{margin-top:var(--spacing-md);padding:var(--spacing-md);background:linear-gradient(135deg,#00d4ff1a,#b794f41a);border:1px solid var(--color-primary);border-radius:var(--radius-md);text-align:center}.prompt-label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.prompt-text{display:block;font-size:1.125rem;font-weight:500;color:var(--text-primary)}.selected-card-text{font-size:1.125rem;color:var(--color-secondary);font-style:italic;margin-top:var(--spacing-sm)}.target-setter-hint{font-size:1.125rem;font-weight:600;color:var(--color-primary);text-align:center;padding:var(--spacing-md);background:#00d4ff1a;border:1px solid rgba(0,212,255,.3);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.target-setter-info{text-align:center;padding:var(--spacing-lg);background:#b794f41a;border:1px solid rgba(183,148,244,.3);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.target-setter-info h3{margin-bottom:var(--spacing-sm);color:var(--color-secondary)}.target-setter-info p{font-size:1.125rem;color:var(--text-primary);font-weight:500}.target-setter-result{background:#b794f40d;border:1px solid rgba(183,148,244,.3)}@media (max-width: 768px){.game-mode-selector{grid-template-columns:1fr}}@media (min-width: 769px){.game-mode-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}}.spectrum-container{flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg);min-height:0}.clue-display{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-xl);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.clue-icon{font-size:1.5rem;animation:pulse 2s ease-in-out infinite}.clue-text{font-size:1.125rem;font-weight:500;color:var(--text-primary)}.spectrum-grid-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);min-height:0}.spectrum-grid-container{position:relative;width:100%;height:100%;aspect-ratio:1}.spectrum-canvas{width:100%;height:100%;border:2px solid var(--glass-border);border-radius:var(--radius-md);cursor:crosshair;background:#0000004d;transition:all var(--transition-fast)}.spectrum-canvas.interactive:hover{box-shadow:0 0 30px #00d4ff4d;border-color:#00d4ff80}.axis-label{position:absolute;font-size:.875rem;font-weight:500;color:var(--text-primary);background:var(--bg-secondary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 16px;white-space:nowrap;border:1px solid var(--glass-border);border-radius:var(--radius-sm);z-index:2}.axis-label.top{bottom:100%;left:50%;transform:translate(-50%);margin-bottom:var(--spacing-sm)}.axis-label.bottom{top:100%;left:50%;transform:translate(-50%);margin-top:var(--spacing-sm)}.axis-label.left{right:100%;top:50%;margin-right:var(--spacing-sm);writing-mode:vertical-lr;transform:translateY(-50%) rotate(180deg);padding:16px 6px}.axis-label.right{left:100%;top:50%;margin-left:var(--spacing-sm);writing-mode:vertical-lr;transform:translateY(-50%);padding:16px 6px}.axis-name{position:absolute;font-size:1.125rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#ffffff4d;pointer-events:none;z-index:3}.axis-name-x{left:20px;top:50%;transform:translateY(-50%) rotate(-90deg);transform-origin:center}.axis-name-y{bottom:20px;left:50%;transform:translate(-50%)}.hover-tooltip{position:absolute;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-primary);border:1px solid var(--color-primary);border-radius:var(--radius-sm);font-size:.75rem;font-family:var(--font-mono);color:var(--text-primary);pointer-events:none;transform:translate(-50%,-150%);white-space:nowrap;z-index:10;box-shadow:0 2px 8px #0000004d}.hover-tooltip:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid var(--color-primary)}.spectrum-canvas.results-phase{cursor:default}.game-logo{font-size:1.5rem;font-weight:700;letter-spacing:-.5px}.copy-code-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;margin-left:var(--spacing-sm);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);font-size:.875rem;transition:all var(--transition-fast);cursor:pointer}.copy-code-btn:hover{background:#ffffff1a;border-color:var(--color-primary)}.icon-button{position:relative;transition:all var(--transition-fast)}.icon-button.active{color:var(--color-primary)}.notification-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--color-danger);border-radius:50%;animation:pulse 2s ease-in-out infinite}.leave-room-btn{min-width:100px}@media (max-width: 768px){.spectrum-grid-wrapper{padding:var(--spacing-md)}.axis-name{font-size:1rem}.axis-label{font-size:.75rem;padding:2px 6px}.axis-label.left,.axis-label.right{padding:6px 2px}.clue-display{padding:var(--spacing-sm) var(--spacing-md)}.clue-icon{font-size:1.25rem}.clue-text{font-size:1rem}.show-mobile{display:inline!important}.hide-mobile{display:none!important}.leave-room-btn{min-width:auto}}@media (max-width: 480px){.spectrum-grid-wrapper{padding:var(--spacing-sm)}.axis-name{font-size:.875rem}.axis-name-x{bottom:15px}.axis-name-y{left:15px}.axis-label{font-size:.625rem;padding:3px 8px}}@media (max-height: 500px) and (orientation: landscape){.spectrum-grid-wrapper{padding:var(--spacing-xs)}.axis-name{font-size:.875rem}.axis-name-x{bottom:10px}.axis-name-y{left:10px}}.spectrum-gradient-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.1;border-radius:var(--radius-md)}.results-close-btn{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);font-size:1.25rem;color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer}.results-close-btn:hover{color:var(--text-primary);border-color:var(--color-primary);background:#ffffff1a}.results-footer{margin-top:var(--spacing-lg);text-align:center}.results-hint{font-size:.875rem;color:var(--text-secondary);font-style:italic}.chat-panel{display:flex;flex-direction:column;height:100%}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--glass-border)}.toggle-chat{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);font-size:1.25rem;color:var(--text-secondary);transition:all var(--transition-fast)}.toggle-chat:hover{color:var(--text-primary);border-color:var(--color-primary)}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.chat-message{padding:var(--spacing-sm) var(--spacing-md);background:var(--glass-bg);border-radius:var(--radius-md)}.chat-message.system{background:#b794f41a;text-align:center;font-size:.875rem;color:var(--text-secondary)}.message-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xs)}.message-author{font-weight:500;color:var(--color-primary);font-size:.875rem}.message-time{font-size:.75rem;color:var(--text-muted)}.message-content{color:var(--text-primary);word-wrap:break-word}.chat-input-container{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--glass-border)}.chat-input-container .input-wrapper{flex:1;min-width:0}.chat-input-container .btn{flex-shrink:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;z-index:999}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:500px;max-height:90vh;z-index:1000;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--glass-border)}.modal-content{flex:1;padding:var(--spacing-lg);overflow-y:auto}.loading-spinner-container{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl)}.loading-spinner-container.fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);z-index:9999}.loading-spinner{position:relative}.spinner-ring{width:40px;height:40px;border:3px solid var(--glass-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.spinner-small .spinner-ring{width:24px;height:24px;border-width:2px}.spinner-large .spinner-ring{width:60px;height:60px;border-width:4px}.notification{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.notification-info{border-color:var(--color-primary)}.notification-success{border-color:var(--color-accent);background:#00f5931a}.notification-warning{border-color:var(--color-warning);background:#ff95001a}.notification-error{border-color:var(--color-danger);background:#ff38641a}.notification-close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.notification-close:hover{color:var(--text-primary)}.modal{position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;margin:0!important;right:auto!important;bottom:auto!important}.modal.glass-panel{max-width:min(800px,90vw);max-height:90vh;display:flex;flex-direction:column}.modal-content{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0}.modal-header+.modal-content:has(.how-to-play-content){padding-bottom:0}@media (max-width: 900px){.modal{width:95%!important;max-width:none!important}}@media (max-height: 700px){.modal{max-height:95vh!important}.modal-content{padding:var(--spacing-md)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.animate-slide-up{animation:slideUp .3s ease-out}.animate-scale-in{animation:scaleIn .3s ease-out}.animate-spin{animation:spin 1s linear infinite}.hover-lift{transition:transform var(--transition-fast)}.hover-lift:hover{transform:translateY(-2px)}.hover-glow{transition:box-shadow var(--transition-fast)}.hover-glow:hover{box-shadow:0 0 20px #00d4ff4d}.skeleton{background:linear-gradient(90deg,var(--glass-bg) 0%,rgba(255,255,255,.1) 50%,var(--glass-bg) 100%);background-size:1000px 100%;animation:shimmer 2s infinite}.card-voting-container{display:flex;flex-direction:column;height:100%;max-height:100%;overflow:hidden}.voting-header{display:flex;justify-content:space-between;align-items:center;padding:0 0 var(--spacing-md) 0;flex-shrink:0}.voting-header h3{font-size:1.25rem;color:var(--text-primary);margin:0}.voting-timer{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:.875rem}.voting-timer.danger{background:#ff38641a;border-color:#ff386480;animation:pulse 1s ease-in-out infinite}.voting-cards-scroll{flex:1;overflow-y:auto;overflow-x:hidden;margin:0 calc(-1 * var(--spacing-sm));padding:0 var(--spacing-sm);min-height:0}.voting-cards-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-sm);padding-bottom:var(--spacing-sm)}.voting-card{background:var(--glass-bg);border:2px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--spacing-md);cursor:pointer;transition:all var(--transition-normal);position:relative;min-height:60px;display:flex;align-items:center;justify-content:center}.voting-card:hover:not(.disabled){background:#ffffff14;border-color:var(--color-primary);box-shadow:0 2px 8px #00d4ff33}.voting-card.selected{background:#00d4ff1a;border-color:var(--color-primary);box-shadow:0 0 12px #00d4ff4d}.voting-card.disabled{cursor:not-allowed;opacity:.7}.voting-card.has-votes{background:#b794f40d}.card-content{text-align:center;width:100%;padding:0 var(--spacing-sm)}.card-text{font-size:1rem;font-weight:500;color:var(--text-primary);line-height:1.3;margin:0}.vote-count{margin-top:var(--spacing-xs);font-size:.75rem;color:var(--color-secondary);font-weight:600;padding:2px 6px;background:#b794f433;border-radius:var(--radius-sm);display:inline-block}.selection-indicator{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs);width:24px;height:24px;background:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--bg-primary);animation:scaleIn .3s ease-out}.voting-actions{padding-top:var(--spacing-md);flex-shrink:0}.voting-results{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-lg);text-align:center;height:100%}.voting-results h3{font-size:1.125rem;color:var(--text-secondary);margin:0}.selected-card-display{background:linear-gradient(135deg,#00d4ff1a,#b794f41a);border:2px solid var(--color-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:0 0 20px #00d4ff4d;animation:pulse 2s ease-in-out infinite}.selected-card-display .card-text{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.voting-hint{font-size:.875rem;color:var(--text-secondary);font-style:italic;margin:0}.voting-cards-scroll::-webkit-scrollbar{width:4px}.voting-cards-scroll::-webkit-scrollbar-track{background:var(--glass-bg);border-radius:var(--radius-full)}.voting-cards-scroll::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:var(--radius-full)}.voting-cards-scroll::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}@media (max-width: 768px){.voting-card{min-height:50px;padding:var(--spacing-sm)}.card-text{font-size:.9rem}.voting-header h3{font-size:1.125rem}}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.centroid-marker{position:absolute;width:24px;height:24px;margin-left:-12px;margin-bottom:-12px;background:radial-gradient(circle,gold,#ff8c00);border:3px solid #fff;border-radius:50%;box-shadow:0 0 20px #ffd70099;z-index:10;animation:pulse 2s ease-in-out infinite}.centroid-label{position:absolute;padding:4px 8px;background:var(--bg-primary);border:1px solid #ffd700;border-radius:var(--radius-sm);font-size:.75rem;color:gold;font-weight:600;white-space:nowrap;transform:translate(-50%,-150%);z-index:11}.voting-info{display:flex;align-items:center;gap:var(--spacing-md)}.vote-counter{padding:var(--spacing-xs) var(--spacing-sm);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-secondary)}@media (max-width: 1400px){.game-sidebar{width:300px}}@media (max-width: 1200px){.game-sidebar{width:280px}.spectrum-area{padding:var(--spacing-lg)}}@media (max-width: 1024px){.game-main{gap:var(--spacing-sm)}.game-sidebar{width:260px}.game-sidebar-left{display:flex;flex-direction:column;height:100%}.player-list{flex:1;min-height:300px}.notification-panel{flex-shrink:0}}@media (max-width: 990px){.game-room{position:relative}.game-header{padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-sm)}.game-main{position:relative;height:calc(100vh - 80px)}.game-sidebar{position:fixed;top:0;bottom:0;z-index:150;width:320px;max-width:85vw;background:var(--bg-secondary);box-shadow:4px 0 20px #00000080;transition:transform var(--transition-normal);display:flex;flex-direction:column;height:100vh;overflow:hidden}.game-sidebar-left{left:0;transform:translate(-100%)}.game-sidebar-left.mobile-open{transform:translate(0)}.game-sidebar-right{right:0;transform:translate(100%)}.game-sidebar-right.mobile-open{transform:translate(0)}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:140}.mobile-overlay.active{display:block}.game-center{width:100%;margin:0}.spectrum-area{height:100%;padding:var(--spacing-md)}.mobile-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--glass-border);z-index:130;padding:var(--spacing-sm);gap:var(--spacing-sm)}.mobile-tab{flex:1;padding:var(--spacing-sm);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);text-align:center;font-size:.875rem;transition:all var(--transition-fast)}.mobile-tab.active{background:var(--color-primary);color:var(--bg-primary);border-color:var(--color-primary)}}@media (max-width: 768px){.game-header{flex-wrap:wrap;gap:var(--spacing-sm)}.header-left{flex:1;min-width:150px}.header-right{flex-wrap:wrap}.room-code{font-size:.75rem}.spectrum-container{gap:var(--spacing-sm)}.clue-display{padding:var(--spacing-sm) var(--spacing-md);font-size:1rem}.spectrum-area{height:70%;padding:var(--spacing-sm)}.game-center{display:block}.spectrum-grid-container{padding:var(--spacing-md)}.axis-label{font-size:.75rem;padding:2px 6px}.axis-label.top{top:-24px}.axis-label.bottom{bottom:-24px}.axis-label.left{left:-60px}.axis-label.right{right:-60px}.axis-name{font-size:.875rem}.axis-name.x-axis{bottom:-48px}.axis-name.y-axis{left:-90px}.notification-panel{height:auto;max-height:40vh;overflow-y:auto}.timer-display{padding:var(--spacing-sm)}.player-list{height:auto;max-height:50vh;overflow-y:auto}.player-item{padding:var(--spacing-xs)}.player-avatar{width:32px;height:32px;font-size:1rem}.chat-panel{height:100%}.chat-messages{max-height:calc(100vh - 200px)}.hide-mobile{display:none!important}.show-mobile{display:block!important}}@media (max-width: 480px){.game-title{font-size:2.5rem}.lobby-content{padding:var(--spacing-md)}.lobby-form{padding:var(--spacing-lg)}.axis-label{font-size:.625rem}.axis-name{display:none}.btn-small{padding:6px 12px;font-size:.75rem}.results-container{padding:var(--spacing-lg);max-height:90vh;overflow-y:auto}.guess-item{flex-wrap:wrap;gap:var(--spacing-xs);padding:var(--spacing-sm)}}@media (max-width: 360px){.game-sidebar{width:100vw;max-width:100vw}.mobile-tabs{padding:4px;gap:4px}.mobile-tab{font-size:.75rem;padding:6px}}@media (max-height: 500px) and (orientation: landscape){.game-header{padding:4px var(--spacing-md);margin:4px}.game-main{height:calc(100vh - 40px)}.spectrum-area{padding:var(--spacing-sm)}.mobile-tabs{display:none}}@media (hover: hover){.interactive:hover{transform:translateY(-1px)}.mobile-tab:hover{background:#ffffff1a}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){.glass-panel{border-width:2px}.btn{border:2px solid currentColor}.input-container{border-width:2px}}@media print{.game-sidebar,.mobile-tabs,.chat-panel,.header-right{display:none!important}.game-center{width:100%!important;margin:0!important}}.hidden{display:none!important}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.flex-1{flex:1}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.m-0{margin:0}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.p-0{padding:0}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.bg-primary{background:var(--bg-primary)}.bg-secondary{background:var(--bg-secondary)}.bg-accent{background:var(--bg-accent)}.border{border:1px solid var(--glass-border)}.border-0{border:0}.border-primary{border-color:var(--color-primary)}.border-secondary{border-color:var(--color-secondary)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:0 1px 2px #0000001a}.shadow-md{box-shadow:0 4px 6px #0000001a}.shadow-lg{box-shadow:0 10px 15px #0000001a}.transition-all{transition:all var(--transition-normal)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.w-full{width:100%}.h-full{height:100%}.w-screen{width:100vw}.h-screen{height:100vh}.max-w-sm{max-width:384px}.max-w-md{max-width:448px}.max-w-lg{max-width:512px}.max-w-xl{max-width:576px}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.visible{visibility:visible}.invisible{visibility:hidden}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.select-none{-webkit-user-select:none;user-select:none}.select-text{-webkit-user-select:text;user-select:text}.select-all{-webkit-user-select:all;user-select:all}.how-to-play-content{display:flex;flex-direction:column;gap:var(--spacing-lg);max-height:calc(80vh - 100px);overflow-y:auto;overflow-x:hidden;padding-right:var(--spacing-sm)}.tutorial-progress{display:flex;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0}.progress-dot{width:10px;height:10px;border-radius:50%;background:var(--glass-border);border:none;cursor:pointer;transition:all var(--transition-fast);position:relative}.progress-dot:hover{transform:scale(1.2);background:var(--text-secondary)}.progress-dot.active{background:var(--color-primary);width:24px;border-radius:12px}.progress-dot.completed{background:var(--color-accent)}.tutorial-step{display:flex;flex-direction:column;gap:var(--spacing-md)}.step-title{font-size:1.25rem;font-weight:600;color:var(--color-primary);text-align:center}.step-image-container{width:100%;height:auto;max-height:350px;overflow:hidden;border-radius:var(--radius-lg);border:2px solid var(--glass-border);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;position:relative}.step-image{width:100%;height:auto;max-height:350px;object-fit:contain;display:block}.step-description{font-size:1rem;line-height:1.6;color:var(--text-primary);text-align:center;padding:0 var(--spacing-md)}.step-tip{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);background:#00f5931a;border:1px solid rgba(0,245,147,.3);border-radius:var(--radius-md);margin:0 var(--spacing-md)}.tip-icon{font-size:1.25rem;flex-shrink:0}.tip-text{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.tutorial-navigation{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--glass-border)}.step-counter{font-size:.875rem;color:var(--text-secondary);font-weight:500}@media (max-width: 768px){.how-to-play-content{max-height:80vh}.step-image-container,.step-image{max-height:300px}.step-description{padding:0;font-size:.9rem}.step-tip{margin:0;padding:var(--spacing-sm)}.tip-text{font-size:.8rem}.tutorial-navigation{flex-wrap:wrap;justify-content:center}.step-counter{order:-1;width:100%;text-align:center;margin-bottom:var(--spacing-sm)}}@media (max-width: 480px){.step-title{font-size:1.1rem}.step-image-container{max-height:250px}.progress-dot{width:8px;height:8px}.progress-dot.active{width:20px}}.modal:has(.how-to-play-content){max-width:800px;width:90%;max-height:90vh;overflow:hidden}.modal-backdrop+.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);margin:0}.modal-content:has(.how-to-play-content){overflow:hidden;max-height:calc(90vh - 80px)}.how-to-play-content::-webkit-scrollbar{width:6px}.how-to-play-content::-webkit-scrollbar-track{background:var(--glass-bg);border-radius:var(--radius-full)}.how-to-play-content::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:var(--radius-full)}.how-to-play-content::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}body{font-family:var(--font-primary);color:var(--text-primary);background:var(--bg-primary);overflow:hidden;height:100vh}#root{height:100%;position:relative;z-index:1}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 80%,rgba(0,212,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(183,148,244,.1) 0%,transparent 50%),radial-gradient(circle at 40% 40%,rgba(0,150,255,.05) 0%,transparent 50%);pointer-events:none;z-index:0}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-2xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-slide-in{animation:slideIn .3s ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--glass-bg);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent-teal)}
