*{box-sizing:border-box;margin:0;padding:0}body{font-family:Roboto,sans-serif;background-color:#f5f5f5;color:#333;line-height:1.6;-webkit-tap-highlight-color:transparent}.app{margin:0 auto;padding:20px;min-height:100vh;max-width:100%;overflow-x:hidden}@media (max-width: 768px){.app{padding:10px}}h1{text-align:center;margin-bottom:30px;color:#2c3e50}@media (max-width: 768px){h1{font-size:24px;margin-bottom:20px}}button{background-color:#3498db;color:#fff;border:none;padding:10px 15px;border-radius:4px;cursor:pointer;font-size:16px;transition:background-color .3s;touch-action:manipulation}button:hover{background-color:#2980b9}button:disabled{background-color:#95a5a6;cursor:not-allowed}input{padding:10px;border:1px solid #ddd;border-radius:4px;font-size:16px;width:100%;margin-bottom:15px}.loading,.error{text-align:center;margin-top:50px}.error{color:#e74c3c}.error button{margin-top:20px;background-color:#e74c3c}.error button:hover{background-color:#c0392b}.player-name-form{max-width:400px;margin:0 auto;background-color:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 10px #0000001a}.player-name-form h2{text-align:center;margin-bottom:20px;color:#2c3e50}.form-group{margin-bottom:20px}.error-message{color:#e74c3c;font-size:14px;margin-top:5px}.player-name-form button{width:100%;margin-top:10px}.game-lobby{max-width:800px;margin:0 auto}.player-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px;background-color:#fff;padding:15px 20px;border-radius:8px;box-shadow:0 2px 10px #0000001a}.edit-name-btn{background-color:#7f8c8d;font-size:14px;padding:8px 12px}.lobby-sections{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}.create-game-section,.join-game-section{background-color:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 10px #0000001a}.create-game-section h3,.join-game-section h3{margin-bottom:15px;color:#2c3e50}@media (max-width: 768px){.lobby-sections{grid-template-columns:1fr}}.game-board-container{padding:20px;height:100%;display:flex;flex-direction:column}.game-main{display:flex;gap:20px;flex:1;min-height:0}.game-board{flex:1;overflow-y:auto}.game-board-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:15px;padding:15px}.game-sidebar{width:300px;display:flex;flex-direction:column;gap:20px}@media (max-width: 768px){.game-main{flex-direction:column}.game-sidebar{width:100%;order:-1}.game-board-grid{grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:10px;padding:10px}.game-controls{flex-direction:row;flex-wrap:wrap;justify-content:center}.game-controls button{flex:1 1 calc(50% - 10px);min-width:120px;padding:10px;font-size:14px}}.game-info{margin-bottom:20px;position:relative}.game-stats{display:flex;gap:20px;margin-top:10px}@media (max-width: 768px){.game-stats{flex-direction:column;gap:5px}}.game-message{position:absolute;left:0;right:0;top:100%;padding:10px;background-color:#f8f9faf2;border-radius:4px;text-align:center;box-shadow:0 2px 8px #0000001a;z-index:10;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.scoreboard{background-color:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.scoreboard h3{margin-top:0;margin-bottom:15px}.scoreboard ul{list-style:none;padding:0;margin:0}.scoreboard li{padding:8px 0;border-bottom:1px solid #eee}.scoreboard li:last-child{border-bottom:none}.scoreboard .current-player{font-weight:700;color:#3498db}.player-entry{cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;justify-content:space-between}.player-entry:hover{background-color:#f5f5f5}.player-info{flex:1}.player-icons{display:flex;gap:4px;align-items:center}.viewing-sets-icon{font-size:16px;opacity:.8;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:.8}50%{opacity:1}to{opacity:.8}}.game-controls{display:flex;flex-direction:column;gap:10px}.game-controls button{padding:12px 20px;border:none;border-radius:4px;font-size:16px;cursor:pointer;transition:all .2s ease}.game-controls button:disabled{opacity:.5;cursor:not-allowed}.start-game-btn{background-color:#2ecc71;color:#fff}.start-game-btn:hover:not(:disabled){background-color:#27ae60}.claim-set-btn{background-color:#3498db;color:#fff}.claim-set-btn:hover:not(:disabled){background-color:#2980b9}.verify-set-btn{background-color:#f1c40f;color:#fff}.verify-set-btn:hover:not(:disabled){background-color:#f39c12}.leave-game-btn{background-color:#e74c3c;color:#fff}.leave-game-btn:hover:not(:disabled){background-color:#c0392b}.show-sets-btn{background-color:#9b59b6;color:#fff}.show-sets-btn:hover:not(:disabled){background-color:#8e44ad}.add-card-btn{background-color:#16a085;color:#fff}.add-card-btn:hover:not(:disabled){background-color:#1abc9c}.loading-board{display:flex;justify-content:center;align-items:center;height:100%;font-size:20px;color:#666}.waiting-board{display:flex;justify-content:center;align-items:center;height:100%;min-height:300px}.waiting-message{text-align:center;padding:40px;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;border:2px dashed #ddd}.waiting-message h3{margin-top:0;margin-bottom:15px;color:#666;font-size:24px}.waiting-message p{margin:0;color:#999;font-size:16px}.verification-controls{display:flex;gap:10px}.verification-controls button{flex:1}.cancel-btn{background-color:#95a5a6;color:#fff}.cancel-btn:hover:not(:disabled){background-color:#7f8c8d}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;padding:20px;border-radius:8px;max-width:90%;max-height:90vh;overflow-y:auto;position:relative}.modal-content h2{margin-top:0;margin-bottom:20px}.captured-sets{display:flex;flex-direction:column;gap:20px}.captured-set{border:1px solid #eee;padding:15px;border-radius:4px}.captured-set h3{margin-top:0;margin-bottom:10px;font-size:16px;color:#666}.captured-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media (max-width: 768px){.captured-cards{grid-template-columns:repeat(3,1fr);gap:5px}.modal-content{padding:15px;max-width:95%}}.close-modal-btn{margin-top:20px;padding:10px 20px;background-color:#95a5a6;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.close-modal-btn:hover{background-color:#7f8c8d}.card{width:100%;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;display:flex;justify-content:center;align-items:center;padding:10px}.card:hover{transform:translateY(-5px);box-shadow:0 5px 15px #0003}@media (max-width: 768px){.card:hover{transform:none}}.card.selected{border:3px solid #3498db;box-shadow:0 0 15px #3498db80}.card.disabled{cursor:not-allowed;opacity:.7}.card-content{width:100%;height:100%;display:flex;justify-content:center;align-items:center}.card-image{width:100%;height:100%;object-fit:contain;max-height:100%}.card-highlight-container{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.highlight-border{position:absolute;top:0;left:0;right:0;bottom:0;border:3px solid transparent;border-radius:8px;opacity:.5}.highlight-0{border-color:red}.highlight-1{border-color:#0f0}.highlight-2{border-color:#00f}.highlight-3{border-color:#f0f}.highlight-4{border-color:#0ff}.highlight-5{border-color:#ff0}.highlight-6{border-color:#ff8000}.highlight-7{border-color:#8000ff}.highlight-8{border-color:#00ff80}.highlight-9{border-color:#ff0080}
