:root{font-family: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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}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}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#eee;min-height:100vh}.app{max-width:1000px;margin:0 auto;padding:20px}header{text-align:center;margin-bottom:30px}header h1{color:#00d4ff;font-size:2.5rem;text-shadow:0 0 20px rgba(0,212,255,.5)}.status.disconnected{background:#ff4757;padding:5px 15px;border-radius:20px;font-size:.8rem;margin-left:10px}.error{background:#ff4757;color:#fff;padding:10px 20px;border-radius:8px;margin-bottom:20px;text-align:center;animation:shake .5s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.home{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px}.home input{padding:15px 25px;font-size:1.2rem;border:2px solid #333;border-radius:10px;background:#16213e;color:#fff;width:300px;text-align:center}.home input:focus{outline:none;border-color:#00d4ff}.buttons{display:flex;flex-direction:column;gap:15px}.join-section{display:flex;gap:10px}.join-section input{width:120px;text-transform:uppercase;letter-spacing:3px}button{padding:15px 30px;font-size:1rem;border:none;border-radius:10px;background:linear-gradient(135deg,#00d4ff,#09c);color:#fff;cursor:pointer;font-weight:700;transition:transform .2s,box-shadow .2s}button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #00d4ff66}button:disabled{opacity:.5;cursor:not-allowed}.lobby{text-align:center}.room-info{margin-bottom:30px}.room-code{color:#00d4ff;font-size:2rem;letter-spacing:5px;background:#16213e;padding:10px 20px;border-radius:10px;font-family:monospace}.players-list{background:#16213e;border-radius:15px;padding:20px;margin-bottom:30px}.players-list h3{margin-bottom:15px;color:#888}.player{padding:10px;border-bottom:1px solid #333}.player:last-child{border-bottom:none}.player.host{color:gold}.start-btn{font-size:1.3rem;padding:20px 50px}.waiting{color:#888;font-style:italic}.game{display:flex;flex-direction:column;gap:20px}.game-header{display:flex;justify-content:space-between;align-items:center;background:#16213e;padding:15px 25px;border-radius:10px}.round{font-size:1.2rem;color:#888}.timer{font-size:2rem;color:#00d4ff;font-weight:700;font-family:monospace}.game-content{display:grid;grid-template-columns:1fr 300px;gap:20px}.main-area{background:#16213e;border-radius:15px;padding:30px}.describer-panel h2,.guesser-panel h2{margin-bottom:20px;color:#00d4ff}.word{font-size:3rem;color:gold;margin:30px 0;letter-spacing:5px;text-transform:uppercase;font-weight:700}.describer-panel p{color:#888;margin-bottom:20px}.hints-list{text-align:left;margin-bottom:20px;min-height:150px}.hints-list h3{color:#888;margin-bottom:10px}.hint-item{background:#0f3460;padding:10px 15px;border-radius:8px;margin-bottom:8px;border-left:3px solid #00d4ff}.no-hints{color:#666;font-style:italic}form{display:flex;gap:10px}form input{flex:1;padding:15px;font-size:1rem;border:2px solid #333;border-radius:10px;background:#0f3460;color:#fff}form input:focus{outline:none;border-color:#00d4ff}form button{white-space:nowrap}.sidebar{display:flex;flex-direction:column;gap:20px}.scoreboard,.message-log{background:#16213e;border-radius:15px;padding:20px}.scoreboard h3,.message-log h3{color:#888;margin-bottom:15px;font-size:.9rem;text-transform:uppercase}.score-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #333}.score-item:last-child{border-bottom:none}.score-item.describing{color:gold}.message-log{flex:1}.messages{max-height:200px;overflow-y:auto;font-size:.85rem}.message{padding:5px 0;border-bottom:1px solid #222}.message.system{color:#888}.message.hint{color:#00d4ff}.message.correct{color:#2ed573;font-weight:700}.message.guess{color:#ffa502}@media(max-width:768px){.game-content{grid-template-columns:1fr}.sidebar{flex-direction:row}.scoreboard,.message-log{flex:1}.home input,.join-section{width:100%}.join-section{flex-direction:column}.join-section input{width:100%}}
