*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#165b33,#c41e3a);min-height:100vh;color:#333;position:relative}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle at 20% 50%,rgba(255,255,255,.3) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.2) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(255,255,255,.15) 0%,transparent 50%);pointer-events:none;animation:snowfall 20s ease-in-out infinite;z-index:0}@keyframes snowfall{0%,to{opacity:.6}50%{opacity:.9}}.app{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;z-index:1}.game-setup{background:#fff;border-radius:20px;padding:40px 30px;box-shadow:0 20px 40px #0003,0 0 40px #ffd70033;max-width:500px;width:100%;text-align:center;border:3px solid transparent;background-clip:padding-box;position:relative}.game-setup:before{content:"";position:absolute;inset:-3px;background:linear-gradient(135deg,gold,#c41e3a,#0f7a3e);border-radius:20px;z-index:-1;opacity:.5}.setup-header{margin-bottom:40px}.game-title{font-size:3rem;margin-bottom:10px;background:linear-gradient(135deg,#c41e3a,#0f7a3e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.game-subtitle{font-size:1.2rem;color:#666}.player-selection h2{font-size:1.5rem;margin-bottom:20px;color:#333}.player-buttons{display:flex;gap:10px;margin-bottom:30px;justify-content:center;flex-wrap:wrap}.player-button{width:50px;height:50px;border:2px solid #ddd;border-radius:25px;background:#fff;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .2s}.player-button:hover{border-color:#c41e3a;transform:scale(1.1)}.player-button.active{background:linear-gradient(135deg,#c41e3a,#0f7a3e);color:#fff;border-color:#c41e3a}.player-count-group{display:flex;flex-direction:column;align-items:center;gap:15px;margin-bottom:30px}.player-count-label{font-size:1.1rem;color:#555;font-weight:600}.player-count-select{padding:12px 20px;font-size:1.1rem;border:2px solid #ddd;border-radius:10px;background:#fff;color:#333;cursor:pointer;min-width:200px;transition:all .2s;font-weight:600}.player-count-select:hover{border-color:#c41e3a}.player-count-select:focus{outline:none;border-color:#c41e3a;box-shadow:0 0 0 3px #c41e3a26}.game-rules{text-align:left;margin-bottom:30px;background:linear-gradient(135deg,#ffd7001a,#c41e3a0d);padding:20px;border-radius:10px;border:2px solid rgba(255,215,0,.3)}.game-rules h3{margin-bottom:15px;color:#333}.game-rules ol{padding-left:20px;line-height:1.6}.start-button{width:100%;padding:15px;background:linear-gradient(135deg,#c41e3a,#a01729);color:#fff;border:none;border-radius:10px;font-size:1.3rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #c41e3a4d}.start-button:hover{background:linear-gradient(135deg,#a01729,#c41e3a);transform:translateY(-2px);box-shadow:0 6px 20px #c41e3a66}.setup-progress{display:flex;justify-content:center;gap:20px;margin-bottom:30px}.progress-step{padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:600;color:#666;background:#f0f0f0;transition:all .2s}.progress-step.active{background:linear-gradient(135deg,#c41e3a,#0f7a3e);color:#fff}.progress-step.completed{background:gold;color:#165b33;font-weight:700}.setup-step{min-height:300px;display:flex;flex-direction:column;justify-content:space-between}.setup-step h2{margin-bottom:30px;color:#333;font-size:1.5rem}.name-inputs{display:flex;flex-direction:column;gap:15px;margin-bottom:30px}.name-input-group{display:flex;flex-direction:column;text-align:left}.name-input-group label{margin-bottom:5px;font-weight:600;color:#555}.name-input{padding:12px;border:2px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .2s}.name-input:focus{outline:none;border-color:#c41e3a;box-shadow:0 0 0 3px #c41e3a26}.name-input::placeholder{color:#999}.category-selection{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:15px;margin-bottom:30px}.category-card{background:#f8f9fa;border:2px solid #ddd;border-radius:12px;padding:20px 15px;cursor:pointer;transition:all .2s;text-align:center}.category-card:hover{border-color:gold;transform:translateY(-2px);box-shadow:0 4px 12px #ffd70066}.category-card.active{border-color:#c41e3a;background:linear-gradient(135deg,#c41e3a1a,#0f7a3e1a);box-shadow:0 0 20px #ffd7004d}.category-card h3{margin-bottom:10px;color:#333;font-size:1.1rem}.category-card p{color:#666;font-style:italic}.category-preview{display:flex;flex-direction:column;gap:5px}.preview-word{background:#fff;padding:4px 8px;border-radius:4px;font-size:.8rem;color:#555}.more-indicator{font-size:.8rem;color:#999;font-weight:500;margin-top:5px}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.manage-categories-button{background:#6c5ce7;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:.9rem;cursor:pointer;transition:background .2s}.manage-categories-button:hover{background:#5f3dc4}.custom-category{border:2px solid #6c5ce7}.category-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.custom-badge{background:#6c5ce7;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:4px;font-weight:600}.category-management-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.category-management-modal{background:#fff;border-radius:15px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #eee}.modal-header h2{margin:0;color:#333}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-button:hover{color:#333}.modal-content{flex:1;overflow-y:auto;padding:25px}.add-category-section{margin-bottom:40px;padding-bottom:30px;border-bottom:1px solid #eee}.add-category-section h3{margin-bottom:20px;color:#333}.category-name-input,.category-words-input,.edit-name-input,.edit-words-input{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:1rem;margin-bottom:15px}.category-words-input,.edit-words-input{resize:vertical;font-family:inherit}.word-count{font-size:.9rem;color:#666;margin-bottom:15px}.add-button,.save-button,.cancel-button,.edit-button,.delete-button{padding:10px 20px;border:none;border-radius:8px;font-size:.9rem;cursor:pointer;transition:background .2s}.add-button,.save-button{background:linear-gradient(135deg,#0f7a3e,#165b33);color:#fff;box-shadow:0 3px 10px #0f7a3e4d}.add-button:hover:not(:disabled),.save-button:hover:not(:disabled){background:linear-gradient(135deg,#165b33,#0f7a3e);transform:translateY(-1px);box-shadow:0 4px 12px #0f7a3e66}.add-button:disabled,.save-button:disabled{background:#ccc;cursor:not-allowed}.existing-categories-section h3{margin-bottom:20px;color:#333}.no-categories{color:#999;font-style:italic;text-align:center;padding:40px 0}.categories-list{display:flex;flex-direction:column;gap:15px}.category-item{border:1px solid #ddd;border-radius:10px;overflow:hidden}.category-display{padding:20px}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.category-header h4{margin:0;color:#333}.category-words-preview{color:#666;font-size:.9rem;line-height:1.4;margin-bottom:15px}.category-actions{display:flex;gap:10px}.edit-button{background:#2196f3;color:#fff}.edit-button:hover{background:#1976d2}.delete-button{background:#f44336;color:#fff}.delete-button:hover{background:#d32f2f}.cancel-button{background:#f0f0f0;color:#666}.cancel-button:hover{background:#e0e0e0}.edit-form{padding:20px;background:#f8f9fa}.edit-buttons{display:flex;gap:10px}.step-buttons{display:flex;gap:15px;justify-content:center}.next-button,.back-button{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:120px}.next-button{background:linear-gradient(135deg,#c41e3a,#a01729);color:#fff;box-shadow:0 3px 10px #c41e3a4d}.next-button:hover:not(:disabled){background:linear-gradient(135deg,#a01729,#c41e3a);transform:translateY(-2px);box-shadow:0 5px 15px #c41e3a66}.next-button:disabled{background:#ccc;cursor:not-allowed}.back-button{background:#f0f0f0;color:#666}.back-button:hover{background:#e0e0e0}.role-reveal{background:#fff;border-radius:20px;padding:40px 30px;box-shadow:0 20px 40px #0003,0 0 40px #ffd70033;max-width:400px;width:100%;text-align:center;min-height:500px;display:flex;align-items:center;justify-content:center;border:3px solid transparent;background-clip:padding-box;position:relative}.role-reveal:before{content:"";position:absolute;inset:-3px;background:linear-gradient(135deg,gold,#c41e3a,#0f7a3e);border-radius:20px;z-index:-1;opacity:.5}.handoff-content,.role-content{width:100%}.player-name{font-size:2.5rem;margin:20px 0;background:linear-gradient(135deg,#c41e3a,#0f7a3e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}.player-progress{color:#666;margin-bottom:30px;font-size:1.1rem}.reveal-button,.continue-button{width:100%;padding:20px;background:linear-gradient(135deg,#c41e3a,#a01729);color:#fff;border:none;border-radius:15px;font-size:1.5rem;font-weight:700;cursor:pointer;transition:all .3s;min-height:60px;box-shadow:0 5px 20px #c41e3a4d}.reveal-button:hover,.continue-button:hover{background:linear-gradient(135deg,#0f7a3e,#165b33);transform:translateY(-2px);box-shadow:0 7px 25px #0f7a3e66}.chameleon-reveal{padding:20px 0}.chameleon-icon{font-size:4rem;display:block;margin-bottom:20px}.role-title{font-size:2rem;margin-bottom:20px;color:#ff6b35}.chameleon-reveal .role-title{color:#ff6b35}.informed-reveal .role-title{color:#0f7a3e}.secret-word{background:linear-gradient(135deg,#0f7a3e,#165b33);color:#fff;padding:20px;border-radius:15px;font-size:2rem;font-weight:700;margin:20px 0;box-shadow:0 5px 20px #0f7a3e4d;border:3px solid #FFD700}.role-instruction{color:#666;margin:10px 0;line-height:1.6}.discussion{background:#fff;border-radius:20px;padding:40px 30px;box-shadow:0 20px 40px #0003,0 0 40px #ffd70033;max-width:500px;width:100%;text-align:center;border:3px solid transparent;background-clip:padding-box;position:relative}.discussion:before{content:"";position:absolute;inset:-3px;background:linear-gradient(135deg,gold,#c41e3a,#0f7a3e);border-radius:20px;z-index:-1;opacity:.5}.discussion-title{font-size:2.5rem;margin-bottom:30px;background:linear-gradient(135deg,#c41e3a,#0f7a3e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}.discussion-info{background:linear-gradient(135deg,#ffd7001a,#0f7a3e0d);padding:20px;border-radius:10px;margin-bottom:30px;border:2px solid rgba(255,215,0,.3)}.category-info,.player-info{margin:5px 0;font-size:1.1rem}.discussion-instructions{text-align:left;margin-bottom:30px}.discussion-instructions h2{color:#333;margin-bottom:15px;text-align:center}.discussion-instructions ol{padding-left:20px;line-height:1.8}.discussion-tips{text-align:left;background:linear-gradient(135deg,#ffd70033,#c41e3a1a);padding:20px;border-radius:10px;margin-bottom:30px;border:2px solid #FFD700}.discussion-tips h3{margin-bottom:15px;color:#165b33;font-weight:700}.discussion-tips ul{padding-left:20px;line-height:1.6}.final-reveal{background:#fff;border-radius:20px;padding:40px 30px;box-shadow:0 20px 40px #0003,0 0 40px #ffd70033;max-width:600px;width:100%;text-align:center;border:3px solid transparent;background-clip:padding-box;position:relative}.final-reveal:before{content:"";position:absolute;inset:-3px;background:linear-gradient(135deg,gold,#c41e3a,#0f7a3e);border-radius:20px;z-index:-1;opacity:.5}.reveal-title{font-size:2.5rem;margin-bottom:30px;background:linear-gradient(135deg,#c41e3a,#0f7a3e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800}.secret-word-reveal,.chameleon-reveal{margin-bottom:30px}.secret-word-reveal h2,.chameleon-reveal h2{font-size:1.5rem;margin-bottom:15px;color:#333}.final-secret-word{background:linear-gradient(135deg,#0f7a3e,#165b33);color:#fff;padding:20px;border-radius:15px;font-size:2rem;font-weight:700;display:inline-block;margin:10px 0;box-shadow:0 5px 20px #0f7a3e4d;border:3px solid #FFD700}.chameleon-player{background:#ff6b35;color:#fff;padding:15px 20px;border-radius:15px;font-size:1.5rem;font-weight:700;display:inline-block;margin:10px 0}.chameleon-icon{margin-right:10px}.category-words{margin-bottom:30px}.category-words h3{margin-bottom:20px;color:#333}.word-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin:20px 0}.word-item{background:linear-gradient(135deg,#c41e3a0d,#0f7a3e0d);padding:10px;border-radius:8px;font-weight:500;transition:all .2s;border:1px solid rgba(255,215,0,.2)}.word-item.secret-word{background:linear-gradient(135deg,#0f7a3e,#165b33);color:#fff;transform:scale(1.05);border:2px solid #FFD700;box-shadow:0 3px 15px #ffd70080}.new-game-button{width:100%;padding:15px;background:linear-gradient(135deg,#c41e3a,#a01729);color:#fff;border:none;border-radius:10px;font-size:1.3rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #c41e3a4d}.new-game-button:hover{background:linear-gradient(135deg,#a01729,#c41e3a);transform:translateY(-2px);box-shadow:0 6px 20px #c41e3a66}.play-again-button{background:linear-gradient(135deg,#0f7a3e,#165b33);color:#fff;border:none;border-radius:10px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s;padding:15px 24px;margin-right:15px;box-shadow:0 4px 15px #0f7a3e4d}.play-again-button:hover{background:linear-gradient(135deg,#165b33,#0f7a3e);transform:translateY(-2px);box-shadow:0 6px 20px #0f7a3e66}.game-actions{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}.category-selection-page{background:#fff;border-radius:20px;padding:40px 30px;box-shadow:0 20px 40px #0003,0 0 40px #ffd70033;max-width:600px;width:100%;text-align:center;border:3px solid transparent;background-clip:padding-box;position:relative}.category-selection-page:before{content:"";position:absolute;inset:-3px;background:linear-gradient(135deg,gold,#c41e3a,#0f7a3e);border-radius:20px;z-index:-1;opacity:.5}.selection-header{margin-bottom:30px}.players-summary{background:linear-gradient(135deg,#ffd7001a,#0f7a3e0d);padding:20px;border-radius:15px;margin-top:20px;border:2px solid rgba(255,215,0,.3)}.players-summary h2{margin-bottom:15px;color:#333;font-size:1.2rem}.player-names{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.player-chip{background:linear-gradient(135deg,#c41e3a,#0f7a3e);color:#fff;padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:600;box-shadow:0 2px 8px #c41e3a4d}.selection-content h2{margin-bottom:30px;color:#333;font-size:1.5rem}@media (max-width: 480px){.app{padding:10px}.game-setup,.role-reveal,.discussion,.final-reveal,.category-selection-page{padding:30px 20px;margin:0 10px}.game-title{font-size:2.5rem}.player-name{font-size:2rem}.secret-word,.final-secret-word{font-size:1.5rem;padding:15px}.word-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px}.reveal-button,.continue-button{font-size:1.2rem}.setup-progress{gap:10px}.progress-step{font-size:.8rem;padding:6px 12px}.category-selection{grid-template-columns:1fr;gap:12px}.category-card{padding:15px 12px}.step-buttons{flex-direction:column;gap:10px}.next-button,.back-button{width:100%}.name-inputs{gap:12px}.setup-step{min-height:250px}.game-actions{flex-direction:column}.play-again-button,.new-game-button{margin-right:0;width:100%}.player-names{justify-content:center}.player-chip{font-size:.8rem;padding:6px 12px}}@media (hover: none) and (pointer: coarse){.player-button,.reveal-button,.continue-button,.start-button,.new-game-button{min-height:48px;min-width:48px}}
