:root{--bg-color: #0f172a;--card-bg: #1e293b;--text-primary: #f8fafc;--text-secondary: #94a3b8;--accent-color: #3b82f6;--accent-hover: #2563eb;--danger-color: #ef4444;--success-color: #22c55e;--font-family: "Inter", system-ui, Avenir, Helvetica, Arial, sans-serif}body{margin:0;padding:0;font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}button{cursor:pointer;border:none;border-radius:8px;padding:.6em 1.2em;font-size:1rem;font-weight:600;font-family:inherit;transition:all .25s}button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}button:active{transform:translateY(0)}.btn-primary{background-color:var(--accent-color);color:#fff}.btn-primary:hover{background-color:var(--accent-hover)}.btn-secondary{background-color:var(--card-bg);color:var(--text-primary);border:1px solid #334155}.btn-secondary:hover{border-color:var(--accent-color)}.btn-danger{background-color:var(--danger-color);color:#fff}.container{max-width:1200px;margin:0 auto;padding:2rem;width:100%;box-sizing:border-box}input{background-color:var(--card-bg);border:1px solid #334155;color:var(--text-primary);padding:.8rem;border-radius:8px;font-size:1rem;outline:none;transition:border-color .2s}input:focus{border-color:var(--accent-color)}.card{background-color:var(--card-bg);border-radius:12px;padding:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}@keyframes bounce{0%{transform:translate(-50%,-50%) scale(1)}to{transform:translate(-50%,-60%) scale(1.2)}}.flying-emoji-wrapper{position:fixed;left:0;top:0;z-index:9999;pointer-events:none;width:2rem;height:2rem;font-size:2rem;transform:translate(var(--startX),var(--startY));animation:flyX .6s linear forwards}.flying-emoji-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;animation:flyY .6s forwards}@keyframes flyX{to{transform:translate(var(--endX),var(--startY))}}@keyframes flyY{0%{transform:translateY(0);animation-timing-function:ease-out}50%{transform:translateY(calc((var(--endY) - var(--startY)) * .5 - 50px));animation-timing-function:ease-in}to{transform:translateY(calc(var(--endY) - var(--startY)))}}.home-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;text-align:center}.home-title{font-size:3rem;margin-bottom:1rem;background:linear-gradient(to right,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-description{color:var(--text-secondary);max-width:600px;margin-bottom:3rem;font-size:1.2rem;line-height:1.6}.home-buttons{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}.btn-create-room{font-size:1.2rem;padding:1rem 2rem;min-width:200px}.btn-join-room{font-size:1.2rem;padding:1rem 2rem;min-width:200px;background-color:transparent;border:2px solid #3b82f6;color:#3b82f6;border-radius:8px;cursor:pointer;font-weight:600}.btn-join-room:hover{background-color:#3b82f61a}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:var(--card-bg);border-radius:12px;padding:2rem;max-width:400px;width:90%;box-shadow:0 10px 25px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h3{margin:0;color:var(--text-primary);font-size:1.5rem}.modal-close{background:transparent;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close:hover{color:var(--text-primary);transform:none;box-shadow:none}.modal-form{display:flex;flex-direction:column;gap:1.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.modal-actions button{min-width:100px}.room-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.room-title{margin:0;font-size:1.5rem}.room-title-mobile{font-size:1.2rem}.room-id{opacity:.7}.room-actions{display:flex;gap:.5rem}.btn-invite{background-color:#fdba74;color:#7c2d12;border:1px solid #c2410c;padding:.6em 1.2em;font-size:1rem}.btn-change-name{background-color:#ffedd5;color:#7c2d12;border:1px solid #c2410c;padding:.6em 1.2em;font-size:1rem}.btn-mobile{padding:.4em .8em;font-size:.9rem}.mobile-tabs{display:flex;margin-bottom:1.5rem;border-bottom:1px solid #334155}.mobile-tab{flex:1;text-align:center;padding:1rem;cursor:pointer;color:#94a3b8}.mobile-tab-active{color:#3b82f6;border-bottom:2px solid #3b82f6;font-weight:700}.room-content{display:flex;gap:2rem;align-items:flex-start}.participants-column{flex:1;display:flex;flex-direction:column;gap:2rem}.participants-column.hidden{display:none}.mobile-full-width{width:100%}.participants-card{min-height:300px;display:flex;flex-direction:column;justify-content:space-between}.participants-grid{display:flex;justify-content:center;flex-wrap:wrap;gap:2rem;margin-bottom:2rem}.participant-item{text-align:center;position:relative}.btn-kick{position:absolute;top:-10px;right:-10px;background:red;color:#fff;width:24px;height:24px;border-radius:50%;padding:0;font-size:12px;z-index:10}.reaction-menu-container{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);z-index:20}.btn-react{background:#fff3;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:1.2rem;line-height:1;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-react-open{background:#fff6}.reaction-popover{position:absolute;top:100%;left:50%;transform:translate(-50%);background:#334155;border:1px solid #475569;border-radius:8px;padding:.5rem;display:flex;gap:.3rem;z-index:30;box-shadow:0 4px 6px #0000004d}.btn-emoji{background:transparent;border:none;cursor:pointer;font-size:1.2rem;padding:2px}.vote-card{width:60px;height:90px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;margin:0 auto .5rem;transition:all .3s ease}.vote-card-empty{background-color:#ffffff0d;border:2px dashed #475569}.vote-card-voted{background-color:#3b82f6;border:2px solid #3b82f6;box-shadow:0 4px 6px #0000001a}.vote-card-revealed{background-color:#4d9f60;border:2px solid rgb(48 113 12);box-shadow:0 4px 6px #0000001a}.participant-name{display:block;font-size:.9rem;color:#cbd5e1}.participant-name-me{color:#3b82f6}.no-voters{color:#94a3b8}.admin-controls{display:flex;justify-content:center;gap:1rem;border-top:1px solid #334155;padding-top:1.5rem}.voting-deck-container{overflow-x:auto;padding-bottom:1rem}.voting-deck{display:flex;justify-content:center;gap:.8rem;min-width:min-content;padding:0 1rem}.vote-button{width:50px;height:80px;border-radius:8px;border:1px solid #475569;background-color:#1e293b;color:#fff;font-size:1.2rem;display:flex;align-items:center;justify-content:center}.vote-button-selected{border:2px solid #3b82f6;background-color:#1e40af}.sidebar-column{width:250px;display:flex;flex-direction:column;gap:1rem}.sidebar-column.hidden{display:none}.info-card{padding:1.5rem;text-align:center}.info-title{margin-top:0;font-size:1rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:1.2rem;font-weight:700}.average-score{font-size:3rem;font-weight:700;color:#475569}.average-score-revealed{color:#22c55e}.join-container{display:flex;align-items:center;justify-content:center;min-height:80vh}.join-card{max-width:400px;width:100%;text-align:center}.join-title{margin-bottom:1.5rem;color:#e2e8f0}.join-form{display:flex;flex-direction:column;gap:1rem}.form-label{display:block;margin-bottom:.5rem;color:#94a3b8}.btn-submit{margin-top:1rem}.btn-back{background:transparent;border:none;color:#94a3b8;margin-top:1rem;cursor:pointer;text-decoration:underline}.btn-back:hover{color:#cbd5e1}.create-container{display:flex;align-items:center;justify-content:center;min-height:80vh}.create-card{max-width:400px;width:100%;text-align:center}.create-title{margin-bottom:1.5rem;color:#e2e8f0}.create-form{display:flex;flex-direction:column;gap:1rem}.form-field{text-align:center}.form-field input{width:100%}
