@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #22c55e;--primary-dark: #16a34a;--primary-light: #4ade80;--primary-glow: rgba(34, 197, 94, .4);--accent: #a855f7;--accent-glow: rgba(168, 85, 247, .3);--success: #10b981;--warning: #f59e0b;--error: #ef4444;--bg-dark: #0a0f0d;--bg-mid: #0f1a14;--bg-card: rgba(34, 197, 94, .05);--bg-card-hover: rgba(34, 197, 94, .1);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .4);--border: rgba(34, 197, 94, .2);--border-hover: rgba(34, 197, 94, .4)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,var(--bg-dark) 0%,var(--bg-mid) 50%,#0d1f17 100%);min-height:100vh;color:var(--text-primary);line-height:1.5;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background-image:radial-gradient(circle at 20% 80%,var(--primary-glow) 0%,transparent 50%),radial-gradient(circle at 80% 20%,var(--accent-glow) 0%,transparent 50%);pointer-events:none;z-index:-1}.App{min-height:100vh;display:flex;flex-direction:column}.App-header{padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.App-header h1{font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;cursor:pointer}.back-link{color:var(--text-muted);text-decoration:none;font-size:.9rem;padding:.5rem 1rem;border-radius:8px;transition:all .2s ease}.back-link:hover{color:var(--text-primary);background:var(--bg-card)}.header-spacer{width:120px}.error-banner{background:#ef444426;border-bottom:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:.75rem 1.5rem;text-align:center;font-size:.9rem}main{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.connecting-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:2rem;text-align:center;padding:2rem}.connecting-spinner{display:flex;flex-direction:column;align-items:center;gap:1rem}.connecting-spinner .spinner{width:56px;height:56px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.connecting-spinner p{color:var(--text-secondary);font-size:1.1rem}.wake-up-message{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 2rem;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;max-width:400px;animation:fadeInUp .3s ease}.wake-up-text{color:var(--warning);font-size:1rem;font-weight:500;margin:0}.wake-up-subtext{color:var(--text-muted);font-size:.9rem;margin:0}.btn-wake-server{margin-top:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--warning),#d97706);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;animation:pulse 2s infinite}.btn-wake-server:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b66}.btn-wake-server:disabled{opacity:.7;cursor:not-allowed;animation:none}.homepage-selection{text-align:center;max-width:500px;animation:fadeInUp .5s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.homepage-selection h2{font-size:2.5rem;font-weight:800;margin-bottom:.75rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.homepage-selection p{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2.5rem}.homepage-selection button{display:block;width:100%;padding:1.25rem 2rem;margin-bottom:1rem;font-size:1.1rem;font-weight:600;border:none;border-radius:16px;cursor:pointer;transition:all .3s ease}.homepage-selection button:first-of-type{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:0 8px 32px var(--primary-glow)}.homepage-selection button:first-of-type:hover{transform:translateY(-3px);box-shadow:0 12px 40px var(--primary-glow)}.homepage-selection button:last-of-type{background:var(--bg-card);border:2px solid var(--border);color:var(--text-primary)}.homepage-selection button:last-of-type:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.host-setup-container{width:100%;max-width:600px;animation:fadeInUp .5s ease}.host-setup-container h2{font-size:2rem;font-weight:700;text-align:center;margin-bottom:2rem}.host-setup-container form{background:var(--bg-card);border:1px solid var(--border);border-radius:24px;padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.form-group{margin-bottom:2rem}.form-group>label{display:block;font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem}.form-group select{width:100%;padding:1rem 1.25rem;font-size:1.1rem;font-family:inherit;background:#0000004d;border:2px solid var(--border);border-radius:12px;color:var(--text-primary);cursor:pointer;transition:all .2s ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2322c55e' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:1.25rem}.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.form-group select option{background:#1a2e1f;padding:.75rem}.mode-options{display:flex;flex-direction:column;gap:.75rem}.mode-option{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:#0003;border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s ease}.mode-option:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.mode-option.selected{border-color:var(--primary);background:#22c55e1a}.mode-option input[type=radio]{width:20px;height:20px;accent-color:var(--primary);cursor:pointer;flex-shrink:0;margin-top:.25rem}.mode-content{display:flex;align-items:flex-start;gap:.75rem;flex:1}.mode-icon{font-size:1.75rem;flex-shrink:0;line-height:1}.mode-text{display:flex;flex-direction:column;gap:.25rem;text-align:left}.mode-label{font-weight:600;font-size:1rem;color:var(--text-primary)}.mode-description{font-size:.85rem;color:var(--text-muted);line-height:1.4}.host-setup-container button[type=submit]{width:100%;padding:1.25rem;font-size:1.2rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:14px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 32px var(--primary-glow)}.host-setup-container button[type=submit]:hover{transform:translateY(-3px);box-shadow:0 12px 40px var(--primary-glow)}.lobby-container{width:100%;max-width:1000px;display:flex;gap:2rem;animation:fadeInUp .5s ease}.lobby-main{flex:1;text-align:center}.lobby-sidebar{width:280px;flex-shrink:0}.lobby-header-info{display:flex;gap:1rem;justify-content:center;margin-bottom:1.5rem}.category-badge,.mode-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:50px;font-size:.9rem;font-weight:500}.lobby-main h2{font-size:2rem;font-weight:700;margin-bottom:.5rem}.room-code-display{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem}.room-code-display strong{display:inline-block;font-size:2rem;font-weight:800;letter-spacing:.3rem;background:linear-gradient(135deg,var(--primary),var(--primary-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-left:.5rem}.qr-code-container{display:inline-flex;flex-direction:column;align-items:center;gap:1rem;background:#fff;padding:1.5rem;border-radius:20px;margin-bottom:1.5rem;box-shadow:0 20px 60px #0000004d}.qr-code-container p{color:#333;font-weight:500;font-size:.9rem}.join-url-hint{color:var(--text-muted);font-size:.95rem;margin-bottom:2rem}.join-url-hint strong{color:var(--primary-light)}.player-list-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:1.5rem}.player-list-card h3{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:var(--text-secondary)}.player-list-card .no-players{color:var(--text-muted);font-style:italic;text-align:center;padding:1rem 0}.lobby-player-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.lobby-player-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#22c55e1a;border:1px solid var(--border);border-radius:12px}.lobby-player-item .player-icon{font-size:1rem}.lobby-player-item .player-name{flex:1;font-weight:500}.lobby-player-item .kick-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.lobby-player-item .kick-btn:hover{background:#ef444433;border-color:#ef444480}.start-game-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}.start-game-btn{padding:1.5rem 4rem!important;font-size:1.4rem!important;margin-bottom:2rem}.start-letter-picker{margin-top:1.5rem}.start-letter-picker label{display:block;text-align:center;color:var(--text-secondary);margin-bottom:1rem}.letter-grid{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;max-width:400px;margin:0 auto}.letter-btn{width:40px;height:40px;border:2px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.letter-btn:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.letter-btn.selected{border-color:var(--primary);background:#22c55e33;color:var(--primary-light)}.host-controls{display:flex;justify-content:center}.host-controls button{padding:1.25rem 3rem;font-size:1.2rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:14px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 32px var(--primary-glow)}.host-controls button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 40px var(--primary-glow)}.host-controls button:disabled{opacity:.5;cursor:not-allowed}.student-join-container{width:100%;max-width:420px;animation:fadeInUp .5s ease}.student-join-container h2{font-size:2rem;font-weight:700;text-align:center;margin-bottom:2rem;background:linear-gradient(135deg,var(--primary),var(--primary-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.student-join-container form{background:var(--bg-card);border:1px solid var(--border);border-radius:24px;padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.student-join-container .form-group{margin-bottom:1.5rem}.student-join-container .form-group label{display:block;font-size:.9rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.student-join-container input[type=text]{width:100%;padding:1rem 1.25rem;font-size:1.1rem;font-family:inherit;background:#0000004d;border:2px solid var(--border);border-radius:12px;color:var(--text-primary);transition:all .2s ease}.student-join-container input[type=text]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.student-join-container input[type=text]::placeholder{color:var(--text-muted)}.student-join-container input#room-code{text-align:center;font-size:1.5rem;font-weight:700;letter-spacing:.4rem;text-transform:uppercase}.student-join-container button[type=submit]{width:100%;padding:1.15rem;font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:14px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 32px var(--primary-glow);margin-top:.5rem}.student-join-container button[type=submit]:hover{transform:translateY(-3px);box-shadow:0 12px 40px var(--primary-glow)}.player-lobby{display:flex;align-items:center;justify-content:center;min-height:60vh}.player-lobby .waiting-card{text-align:center;padding:3rem;background:var(--bg-card);border:1px solid var(--border);border-radius:24px;max-width:400px}.player-lobby .waiting-icon{font-size:4rem;margin-bottom:1rem}.player-lobby h2{font-size:1.5rem;margin-bottom:1rem}.player-greeting{color:var(--text-secondary);margin-bottom:1rem}.player-greeting strong{color:var(--primary-light)}.player-count{color:var(--text-muted);font-size:.9rem}.host-game{display:grid;grid-template-columns:1fr 280px;grid-template-rows:auto 1fr;gap:1.5rem;min-height:calc(100vh - 100px);padding:1.5rem;width:100%}.game-header{grid-column:1 / -1;display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:16px}.game-info{display:flex;gap:1rem}.room-info{display:flex;align-items:center;gap:1rem}.room-code{color:var(--text-muted);font-size:.9rem}.btn-end{padding:.5rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.btn-end:hover{background:#ef444433}.game-main{display:flex;flex-direction:column;gap:1.5rem}.word-chain-section{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:1.5rem}.chain-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.chain-header h2{font-size:1.2rem;color:var(--text-secondary);margin:0}.chain-header .chain-stats{display:flex;align-items:baseline;gap:.25rem}.chain-header .stat-value{font-size:1.5rem;font-weight:700;color:var(--primary-light)}.chain-header .stat-label{font-size:.85rem;color:var(--text-muted)}.word-chain-display{min-height:80px}.chain-empty{text-align:center;padding:1rem}.chain-empty .start-letter{display:inline-flex;align-items:center;justify-content:center;width:70px;height:70px;font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-radius:14px;margin-bottom:.75rem}.chain-empty p{color:var(--text-muted);font-size:.9rem}.snake-container{padding:1rem 0;display:flex;flex-direction:column;gap:.5rem}.snake-row{display:flex;gap:.5rem;position:relative;align-items:flex-start}.snake-row.reversed{flex-direction:row-reverse}.snake-segment{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.segment-content{display:flex;align-items:center;padding:.5rem .75rem;background:linear-gradient(135deg,#22c55e26,#22c55e14);border:2px solid var(--border);border-radius:10px;transition:all .2s ease}.snake-head .segment-content{background:linear-gradient(135deg,#22c55e4d,#22c55e26);border-color:var(--primary)}.snake-tail .segment-content{background:linear-gradient(135deg,#a855f733,#a855f71a);border-color:#a855f766}.segment-word{font-size:.95rem;font-weight:600;color:var(--text-primary)}.segment-connector{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--primary);color:#fff;border-radius:50%;font-size:.7rem;font-weight:700;margin-left:.5rem;flex-shrink:0}.segment-player{font-size:.65rem;color:var(--text-muted);margin-top:.2rem;max-width:80px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.snake-turn{position:absolute;bottom:-1.5rem;display:flex;align-items:center;color:var(--text-muted);font-size:1.25rem}.snake-turn.turn-right{right:0}.snake-turn.turn-left{left:0}.turn-arrow{opacity:.5}.next-letter-display{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.next-letter-display .label{color:var(--text-muted);font-size:1rem}.next-letter-display .letter{display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-radius:10px;box-shadow:0 6px 20px var(--primary-glow)}.btn-skip{padding:.5rem 1rem;background:linear-gradient(135deg,var(--warning),#d97706);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #f59e0b4d}.btn-skip:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f59e0b66}.control-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:1.5rem}.pending-word-card{text-align:center}.pending-header{color:var(--text-secondary);margin-bottom:.75rem}.pending-player{font-weight:500}.pending-word-card .pending-word{font-size:2.25rem;font-weight:800;color:var(--text-primary);margin-bottom:.75rem;padding:.75rem;background:#a855f71a;border-radius:12px}.pending-check{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.pending-actions{display:flex;gap:1rem;justify-content:center}.btn-approve,.btn-reject{padding:.875rem 1.75rem;font-size:1rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease}.btn-approve{background:linear-gradient(135deg,var(--success),#059669);color:#fff;box-shadow:0 4px 16px #10b9814d}.btn-approve:hover{transform:translateY(-2px)}.btn-reject{background:linear-gradient(135deg,var(--error),#dc2626);color:#fff;box-shadow:0 4px 16px #ef44444d}.btn-reject:hover{transform:translateY(-2px)}.control-panel .waiting-card{display:flex;align-items:center;gap:1rem;padding:1rem}.waiting-info{flex:1}.waiting-name{display:block;font-weight:600;font-size:1.1rem}.waiting-text{color:var(--text-muted);font-size:.9rem}.timer-display{position:relative;width:60px;height:60px}.timer-ring{width:100%;height:100%;transform:rotate(-90deg)}.timer-bg{fill:none;stroke:var(--border);stroke-width:6}.timer-progress{fill:none;stroke:var(--primary);stroke-width:6;stroke-linecap:round;stroke-dasharray:283;transition:stroke-dashoffset 1s linear}.timer-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700}.buzzer-section h3{font-size:1rem;margin-bottom:1rem;color:var(--text-secondary)}.buzzer-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.buzzer-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:12px}.buzzer-position{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#f59e0b4d;border-radius:50%;font-weight:700;font-size:.85rem}.buzzer-name{flex:1;font-weight:500}.btn-select{padding:.5rem 1rem;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-select:hover{transform:scale(1.05)}.waiting-buzz{text-align:center;padding:2rem}.waiting-buzz-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.waiting-buzz p{color:var(--text-muted);margin-bottom:.5rem}.waiting-buzz .hint{font-size:.85rem;opacity:.7}.players-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:1.5rem;height:fit-content}.players-sidebar h3{font-size:1rem;color:var(--text-secondary);margin-bottom:.5rem}.sidebar-hint{font-size:.8rem;color:var(--text-muted);margin-bottom:1rem}.player-stats-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.player-stat-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:#ffffff08;border-radius:10px;border:1px solid transparent;transition:all .2s ease}.player-stat-item.selectable{cursor:pointer}.player-stat-item.selectable:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.player-stat-item.active{background:#22c55e33;border-color:var(--primary)}.player-stat-item.penalty{opacity:.5}.player-stat-item .player-rank{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--border);border-radius:50%;font-size:.75rem;font-weight:600}.player-stat-item .player-name{flex:1;font-weight:500;font-size:.9rem}.player-stat-item .player-words{color:var(--primary-light);font-size:.85rem;font-weight:600}.player-stat-item .player-words.negative{color:#ef4444}.student-game{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 120px);padding:1.5rem;width:100%}.student-game .waiting-content,.student-game .turn-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;max-width:400px;width:100%;text-align:center}.player-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:50px;font-size:.9rem;color:var(--text-secondary)}.letter-display-large{display:flex;flex-direction:column;align-items:center;gap:.5rem}.letter-display-large .letter-label{color:var(--text-muted);font-size:1rem}.letter-display-large .letter-huge{font-size:5rem;font-weight:800;color:var(--primary-light);text-shadow:0 0 50px var(--primary-glow);line-height:1}.watching-section{text-align:center}.watching-section .watching-text{color:var(--text-secondary);font-size:1.1rem;margin-bottom:1rem}.watching-section .watching-text strong{color:var(--primary-light)}.pending-word-display{padding:1rem 1.5rem;background:#a855f71a;border:1px solid rgba(168,85,247,.3);border-radius:12px}.pending-word-display .pending-label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:.25rem}.pending-word-display .pending-text{font-size:1.5rem;font-weight:700;color:var(--accent)}.queue-section{display:flex;flex-direction:column;align-items:center;gap:.25rem}.queue-number{font-size:4rem;font-weight:800;color:var(--warning);line-height:1}.queue-text{color:var(--text-muted);font-size:1rem}.buzz-button{width:160px;height:160px;border-radius:50%;border:none;background:linear-gradient(145deg,#ef4444,#dc2626);color:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 10px 40px #ef444466,inset 0 -6px #0003;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem}.buzz-button:hover{transform:scale(1.05);box-shadow:0 15px 50px #ef444480,inset 0 -6px #0003}.buzz-button:active{transform:scale(.95)}.buzz-icon{font-size:2.5rem}.buzz-label{font-size:1.25rem;font-weight:800;letter-spacing:.1rem}.cooldown-section{display:flex;flex-direction:column;align-items:center;gap:.75rem}.cooldown-circle{width:100px;height:100px;border-radius:50%;background:#f59e0b26;border:4px solid var(--warning);display:flex;align-items:center;justify-content:center;animation:pulse-cooldown 1s ease-in-out infinite}.cooldown-number{font-size:2.5rem;font-weight:800;color:var(--warning)}.cooldown-text{color:var(--text-muted);font-size:1rem}@keyframes pulse-cooldown{0%,to{transform:scale(1);opacity:1}50%{transform:scale(.95);opacity:.8}}.chain-info{color:var(--text-muted);font-size:.9rem}.chain-info .last-word strong{color:var(--primary-light)}.turn-header{display:flex;justify-content:space-between;align-items:center;width:100%}.category-tag{padding:.4rem .8rem;background:var(--bg-card);border:1px solid var(--border);border-radius:50px;font-size:.85rem;color:var(--text-secondary)}.timer-tag{padding:.4rem .8rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;font-size:1rem;font-weight:600}.timer-tag.urgent{background:#ef444433;border-color:#ef444466;color:#f87171}.turn-title{font-size:1.5rem;color:var(--primary-light);margin:0}.letter-box{display:flex;align-items:center;justify-content:center;width:100px;height:100px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:18px;box-shadow:0 10px 35px var(--primary-glow)}.letter-box .letter-big{font-size:3.5rem;font-weight:800;color:#fff}.student-game .word-form{width:100%}.student-game .word-form input{width:100%;padding:1rem 1.25rem;font-size:1.25rem;font-weight:600;background:#0000004d;border:2px solid var(--border);border-radius:14px;color:var(--text-primary);margin-bottom:1rem;text-align:center}.student-game .word-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.student-game .word-form input::placeholder{color:var(--text-muted);font-weight:400}.student-game .word-form button{width:100%;padding:1rem;font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:14px;cursor:pointer;transition:all .2s ease;box-shadow:0 8px 24px var(--primary-glow)}.student-game .word-form button:disabled{opacity:.5;cursor:not-allowed}.student-game .word-form button:not(:disabled):hover{transform:translateY(-2px)}.submitted-state{text-align:center}.submitted-state .submitted-word{font-size:2rem;font-weight:700;color:var(--primary-light);margin-bottom:.5rem}.submitted-state .submitted-text{color:var(--text-muted)}.last-word-hint{color:var(--text-muted);font-size:.9rem}.last-word-hint strong{color:var(--text-secondary)}.student-game.result-screen{min-height:calc(100vh - 120px)}.result-content{text-align:center;padding:3rem}.result-icon{font-size:5rem;margin-bottom:1rem}.result-screen.approved .result-content{animation:celebrateIn .5s ease}.result-screen.rejected .result-content{animation:shakeIn .5s ease}@keyframes celebrateIn{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes shakeIn{0%,to{transform:translate(0)}20%,60%{transform:translate(-10px)}40%,80%{transform:translate(10px)}}@media(max-width:900px){.lobby-container{flex-direction:column}.lobby-sidebar{width:100%;max-width:400px;margin:0 auto}.host-game{grid-template-columns:1fr}.players-sidebar{order:-1}}@media(max-width:640px){.App-header{padding:.75rem 1rem}.App-header h1{font-size:1.4rem}main{padding:1rem}.homepage-selection h2{font-size:2rem}.room-code-display strong{font-size:1.75rem}.game-header{flex-direction:column;gap:1rem}.pending-actions{flex-direction:column}.btn-approve,.btn-reject{width:100%}.buzz-button{width:140px;height:140px}.buzz-icon{font-size:2rem}.letter-display-large .letter-huge{font-size:4rem}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.game-over-screen{text-align:center;max-width:500px;padding:2rem;animation:fadeInUp .5s ease}.game-over-screen h2{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--primary-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1.5rem}.game-over-stats{margin-bottom:2rem}.game-over-stats .stat-big{font-size:1.5rem;color:var(--text-secondary)}.game-over-players{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:1.5rem;margin-bottom:2rem}.game-over-players h3{font-size:1.2rem;color:var(--text-secondary);margin-bottom:1rem}.results-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.result-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#ffffff08;border-radius:12px}.result-item:first-child{background:#22c55e26;border:1px solid var(--border)}.result-rank{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--border);border-radius:50%;font-weight:700;font-size:.9rem}.result-item:first-child .result-rank{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a1a}.result-name{flex:1;font-weight:500;text-align:left}.result-words{color:var(--primary-light);font-weight:600}.game-over-screen button{padding:1.25rem 2rem;font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:14px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 32px var(--primary-glow)}.game-over-screen button:hover{transform:translateY(-3px);box-shadow:0 12px 40px var(--primary-glow)}.floating-error{position:fixed;top:1rem;left:50%;transform:translate(-50%);background:#ef4444e6;color:#fff;padding:.75rem 1.5rem;border-radius:10px;z-index:1000;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.error-message{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:.75rem 1.5rem;border-radius:10px;text-align:center;margin:1rem 0}.tavle-game{min-height:100vh;display:flex;flex-direction:column;width:100%}.tavle-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--bg-card);border-bottom:1px solid var(--border)}.tavle-info,.tavle-actions{display:flex;gap:1rem}.tavle-main{flex:1;display:flex;flex-direction:column;padding:2rem;gap:2rem;max-width:1200px;margin:0 auto;width:100%}.tavle-chain-section{background:var(--bg-card);border:1px solid var(--border);border-radius:24px;padding:2rem;flex:1}.tavle-chain-section .next-letter-display.large{margin-top:2rem;padding-top:2rem}.tavle-chain-section .next-letter-display.large .letter{width:80px;height:80px;font-size:3rem;border-radius:16px}.tavle-input-section{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:1.5rem 2rem}.tavle-form .input-row{display:flex;gap:1rem;align-items:flex-end}.tavle-form .input-group{display:flex;flex-direction:column;gap:.5rem}.tavle-form .input-group.word-input{flex:1}.tavle-form .input-group label{font-size:.85rem;color:var(--text-muted);font-weight:500}.tavle-form .input-group input{padding:1rem 1.25rem;font-size:1.1rem;background:#0000004d;border:2px solid var(--border);border-radius:12px;color:var(--text-primary);transition:all .2s ease;min-width:180px}.tavle-form .input-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.tavle-form .input-group input::placeholder{color:var(--text-muted)}.tavle-form .btn-add{padding:1rem 2rem;font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 6px 20px var(--primary-glow);white-space:nowrap}.tavle-form .btn-add:hover{transform:translateY(-2px);box-shadow:0 8px 25px var(--primary-glow)}.tavle-form .input-error{color:#f87171;font-size:.9rem;margin-top:.75rem;padding:.5rem 1rem;background:#ef44441a;border-radius:8px}.tavle-game .game-over-screen{max-width:700px;margin:2rem auto}.word-list-final{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:1.5rem 2rem;margin-bottom:2rem;text-align:left}.word-list-final h3{font-size:1rem;color:var(--text-secondary);margin-bottom:1rem}.final-words{line-height:2;color:var(--text-primary)}.final-word{display:inline;font-weight:500}.game-over-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.game-over-actions .btn-secondary{background:var(--bg-card);border:2px solid var(--border);color:var(--text-primary);box-shadow:none}.game-over-actions .btn-secondary:hover{border-color:var(--border-hover);background:var(--bg-card-hover);transform:translateY(-2px)}@media(max-width:768px){.tavle-header{padding:1rem;flex-wrap:wrap;gap:1rem}.tavle-main{padding:1rem}.tavle-chain-section{padding:1.5rem}.tavle-form .input-row{flex-direction:column;align-items:stretch}.tavle-form .input-group input{min-width:100%}.tavle-form .btn-add{width:100%}}*,*:before,*:after{box-sizing:border-box}html{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px}#root{min-height:100vh}
