:root{--bg: #0b1e35;--surface: #071322;--text: #ffffff;--muted: #9bb4d1;--accent: #21a1ff;--accent-dark: #1a87d9;--success: #10b981;--danger: #ef4444;--border: #1e3a5f}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:280px}.sidebar bac .games-grid{grid-template-columns:1fr}.sidebar .card .form-group{text-align:left!important}.sidebar .card .form-label{text-align:left!important;margin-bottom:.5rem;display:block}.sidebar .card .form-row{align-items:flex-start!important;text-align:left!important}.sidebar .card .form-row .form-group,.sidebar .card .form-row .form-group .form-label{text-align:left!important}.sidebar .btn{min-height:44px}.sidebar .home-header img{height:8rem!important}.sidebar{width:280px;background-color:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:relative;z-index:10;transition:width .3s ease}.sidebar.collapsed{width:80px}.sidebar-header{padding:1.5rem}.sidebar-header h1{font-size:1.5rem;font-weight:700;color:var(--accent)}.sidebar-toggle{background:none;border:1px solid var(--border);color:var(--text);padding:.5rem;border-radius:4px;cursor:pointer;font-size:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sidebar-toggle:hover{background-color:var(--bg);border-color:var(--accent)}.sidebar-icon{font-size:1.2rem;display:flex;align-items:center;justify-content:center}.sidebar-nav{flex:1;padding:1rem}.sidebar-nav ul{list-style:none}.sidebar-nav li{margin-bottom:.5rem}.sidebar-nav a{display:flex;align-items:center;justify-content:center;padding:.75rem 1rem;color:var(--muted);text-decoration:none;border-radius:8px;transition:all .2s ease;font-weight:500;white-space:nowrap;overflow:hidden}.sidebar.expanded .sidebar-nav a{justify-content:flex-start}.sidebar.collapsed .sidebar-nav a{padding:.75rem;justify-content:center}.sidebar-nav a:hover{background-color:var(--bg);color:var(--text)}.sidebar-nav a.active{background-color:var(--accent);color:#fff}.sidebar-footer{padding:1rem;border-top:1px solid var(--border);font-size:.875rem;color:var(--muted);text-align:center}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.content-area{flex:1;overflow-y:auto;padding:2rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all .2s ease;min-height:44px}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-primary{background-color:var(--accent);color:#fff}.btn-primary:hover{background-color:var(--accent-dark)}.btn-primary:disabled{background-color:var(--muted);cursor:not-allowed}.btn-secondary{background-color:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background-color:var(--bg)}.btn-danger{background-color:var(--danger);color:#fff}.btn-success{background-color:var(--success);color:#fff}.btn-large{padding:1rem 2rem;font-size:1.125rem}.btn-full{width:100%}.form-group{margin-bottom:1.5rem;position:relative}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text)}.input-error{border-color:#ef4444!important;background-color:#ef44441a!important}.error-message{display:block;color:#ef4444;font-size:.875rem;margin-top:.375rem;font-weight:500}.form-input{width:100%;padding:.75rem;background-color:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;min-height:44px}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #21a1ff1a}.form-error{margin-top:.5rem;color:var(--danger);font-size:.875rem}.form-row{display:flex;gap:1rem;align-items:end}.card{background-color:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1rem}.card-header{margin-bottom:1rem}.card-title{font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.card-description{color:var(--muted)}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.game-title{font-size:1.875rem;font-weight:700}.players-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.player-button{padding:1.5rem;background-color:var(--surface);border:2px solid var(--border);border-radius:12px;color:var(--text);font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative;min-height:80px;display:flex;align-items:center;justify-content:center}.player-button:hover:not(:disabled){border-color:var(--accent);background-color:var(--bg)}.player-button:disabled{background-color:var(--success);border-color:var(--success);cursor:not-allowed;opacity:.8}.player-button:disabled:after{content:"✓";position:absolute;top:.5rem;right:.5rem;color:#fff;font-size:1.2rem}.modal-overlay{position:fixed;inset:0;background-color:#000000f7;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background-color:var(--surface);border-radius:16px;padding:2rem;max-width:400px;width:100%;text-align:center;position:relative}.modal-reveal{cursor:pointer;padding:3rem 2rem;border-radius:12px;background-color:var(--bg);border:2px dashed var(--border);margin-bottom:1.5rem;transition:all .2s ease}.modal-reveal:hover{border-color:var(--accent)}.modal-reveal-text{font-size:1.125rem;color:var(--muted);margin-bottom:.5rem}.modal-reveal-hint{font-size:.875rem;color:var(--muted)}.reveal-content{padding:3rem 2rem;margin-bottom:1.5rem}.secret-word{font-size:2rem;font-weight:700;color:var(--accent);margin-bottom:.5rem}.imposter-text{font-size:2rem;font-weight:700;color:var(--danger);margin-bottom:.5rem}.role-label{font-size:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.first-clue-modal{background:linear-gradient(135deg,#6366f11f,#6366f10f);border:2px solid rgba(99,102,241,.18)}.first-clue-title{font-size:1.5rem;font-weight:700;color:var(--accent);margin-bottom:.5rem}.first-clue-sub{color:var(--muted);margin-bottom:1rem}.first-clue-name{font-size:2rem;font-weight:700;color:#fff;margin-bottom:.5rem}.home-container{max-width:800px;margin:0 auto}.home-header{text-align:center;margin-bottom:3rem}.home-title{font-size:3rem;font-weight:700;margin-bottom:1rem;background:linear-gradient(135deg,var(--accent),var(--text));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-subtitle{font-size:1.25rem;color:var(--muted)}.games-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.game-card{background-color:var(--surface);border:1px solid var(--border);border-radius:16px;padding:2rem;text-align:center;transition:all .2s ease}.game-card:hover{border-color:var(--accent);transform:translateY(-2px)}.game-card-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem}.game-card-description{color:var(--muted);margin-bottom:1.5rem;line-height:1.6}@media screen and (max-width:768px){.app-layout{flex-direction:row;position:relative}.card form,.card form *{text-align:left!important}label.form-label{text-align:left!important;display:block!important}.form-group label,.form-row .form-group label{text-align:left!important}#player-count+label,#imposter-count+label,label[for=player-count],label[for=imposter-count]{text-align:left!important}.sidebar.collapsed{width:0!important;position:absolute;z-index:10;background-color:transparent!important;border-right:none;overflow:visible}.sidebar.collapsed .sidebar-header,.sidebar.collapsed .sidebar-nav,.sidebar.collapsed .sidebar-footer{display:none}.sidebar.expanded{width:100vw;height:100vh;position:fixed;top:0;left:0;z-index:1000;background-color:var(--surface);border-right:none}.sidebar.expanded:before{content:"";position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0000004d;z-index:-1}.sidebar.expanded .sidebar-header{padding:1.5rem}.sidebar.expanded .sidebar-nav{padding:2rem 1rem;margin-top:-4rem}.sidebar.expanded .sidebar-nav ul{display:block}.sidebar.expanded .sidebar-nav li{margin-bottom:.75rem}.sidebar.expanded .sidebar-nav a{padding:1rem 1.5rem;font-size:1.25rem;font-weight:500;border-radius:0;text-align:left;justify-content:flex-start}.sidebar.expanded .sidebar-nav a:hover{background-color:#ffffff0d}.sidebar.collapsed+.main-content{margin-left:0!important;width:100%!important;flex:1}.sidebar.collapsed+.main-content .content-area{padding:2rem 1rem;width:100%}.sidebar.expanded+.main-content{display:none}.sidebar-header img{height:10rem!important}.content-area{padding:1rem}.players-grid{grid-template-columns:1fr;gap:.75rem}.player-button{min-height:60px;padding:1rem;font-size:1rem}.home-title{font-size:2rem}.modal-content{margin:1rem;padding:1.5rem}.form-row{flex-direction:column;gap:0}.games-grid{grid-template-columns:1fr}.btn{min-height:44px}.home-header img{height:8rem!important}}@media(max-width:480px){.content-area{padding:.75rem}.btn{padding:.625rem 1.25rem;font-size:.9rem}.btn-large{padding:.875rem 1.5rem;font-size:1rem}.home-title{font-size:1.75rem}.game-header{flex-direction:column;gap:1rem;align-items:stretch;text-align:center}.game-title{font-size:1.5rem}}.text-center{text-align:center}.text-muted{color:var(--muted)}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.hidden{display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media screen and (max-width:768px){.form-group,.form-group *,.form-label,label{text-align:left!important}.form-row{align-items:flex-start!important}.form-row .form-group{text-align:left!important}.form-row .form-group:first-child{margin-top:2rem!important}.form-row .form-group{margin-bottom:1rem!important}}.mode-selection{padding:2rem;max-width:900px;margin:0 auto}.mode-selection h2{text-align:center;margin-bottom:2rem;font-size:2rem}.mode-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.mode-btn{padding:2rem;text-align:center;display:flex;flex-direction:column;gap:1rem;min-height:200px;justify-content:center}.mode-icon{font-size:3rem}.mode-title{font-size:1.5rem;font-weight:600}.mode-description{color:#f0f0f0d9;font-size:.95rem}.online-mode-selection{padding:2rem;max-width:600px;margin:0 auto}.online-mode-selection h2{text-align:center;margin-bottom:2rem;font-size:2rem}.back-btn{margin-bottom:1rem}.online-choice-buttons{display:grid;gap:1.5rem}.choice-btn{padding:2rem;text-align:center;display:flex;flex-direction:column;gap:.75rem;min-height:150px;justify-content:center}.choice-icon{font-size:2.5rem}.choice-title{font-size:1.25rem;font-weight:600}.choice-description{color:#ffffffd9;font-size:.9rem}.lobby-form{display:flex;flex-direction:column;gap:1.5rem}.lobby-form .form-group{display:flex;flex-direction:column;gap:.5rem}.lobby-form label{font-weight:500;color:var(--text)}.lobby-form input{padding:.75rem;border:1px solid var(--border);border-radius:.5rem;background-color:var(--surface);color:var(--text);font-size:1rem}.lobby-form input:focus{outline:none;border-color:var(--accent)}.lobby-error-alert{display:flex;align-items:center;gap:.75rem;padding:1rem;margin-bottom:1rem;background-color:#ef44441a;border:2px solid #ef4444;border-radius:8px;color:#ef4444;font-weight:500;animation:slideIn .3s ease-out}.lobby-error-alert .error-icon{font-size:1.5rem;line-height:1}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.lobby-waiting-room{padding:2rem;max-width:700px;margin:0 auto}.lobby-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.lobby-header h2{font-size:1.75rem}.copy-btn{font-size:.9rem}.lobby-code-display{background-color:var(--surface);border:2px solid var(--accent);border-radius:.5rem;padding:1.5rem;text-align:center;margin-bottom:2rem}.code-label{color:var(--muted);font-size:.9rem;margin-bottom:.5rem}.code-value{font-size:clamp(1.8rem,6vw,2.5rem);font-weight:700;letter-spacing:clamp(.15rem,.5vw,.3rem);color:var(--accent);font-family:monospace;margin-bottom:1rem;word-break:break-all}.copy-buttons{display:flex;gap:1rem;justify-content:center;margin-top:1rem;flex-wrap:wrap}.copy-buttons .btn{flex:0 0 auto;min-width:140px;padding:.75rem 1.5rem;font-size:.95rem}@media(max-width:480px){.lobby-code-display{padding:1rem;margin-bottom:1.5rem}.code-label{font-size:.85rem}.code-value{font-size:1.8rem;letter-spacing:.15rem;margin-bottom:.75rem}.copy-buttons{gap:.5rem;flex-direction:column}.copy-buttons .btn{width:100%;min-width:unset;padding:.875rem 1rem;font-size:1rem}}.players-section{margin-bottom:2rem}.players-section h3{margin-bottom:1rem;font-size:1.25rem}.players-list{background-color:var(--surface);border-radius:.5rem;overflow:hidden}.player-item{padding:1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem}.player-item:last-child{border-bottom:none}.player-name{font-weight:500;flex:1}.host-badge{background-color:var(--accent);color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.85rem;font-weight:500}.you-badge{color:var(--muted);font-size:.9rem;font-style:italic}.lobby-status{margin-bottom:2rem}.waiting-message{background-color:var(--surface);border-left:4px solid var(--accent);padding:1rem;border-radius:.25rem}.waiting-message p{margin:0}.lobby-actions{display:flex;gap:.5rem;flex-wrap:wrap}.lobby-actions .btn{flex:1;min-width:150px}.game-settings-section{margin-bottom:2rem;background-color:var(--surface);border-radius:.5rem;padding:1.5rem}.game-settings-section h3{margin-bottom:1rem;font-size:1.25rem}.game-settings-section .form-group{margin-bottom:0}.game-settings-section label{font-weight:500;color:var(--text);display:block;margin-bottom:.5rem}.how-to-play-list{list-style:none;padding:0;margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.8}.how-to-play-list li{margin-bottom:.5rem;padding-left:1.25rem;position:relative}.how-to-play-list li:before{content:"•";position:absolute;left:0;color:var(--accent);font-weight:700}.setting-item{margin-bottom:1.5rem}.setting-label{display:block;font-weight:700;color:#fff;margin-bottom:1rem;font-size:1rem;letter-spacing:.02em}.time-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.75rem}.time-option{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .5rem;background:var(--bg);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .3s ease;text-align:center;color:#fff}.time-option:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.time-option.selected{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 3px rgba(var(--accent-rgb),.2)}.time-emoji{font-size:1.5rem;line-height:1}.time-label{font-size:.9rem;font-weight:600;white-space:nowrap;color:inherit;letter-spacing:.01em}.time-option.selected .time-label{font-weight:700}.category-count-selector{display:flex;flex-wrap:wrap;gap:.625rem;margin-bottom:1rem}.category-option{padding:.7rem 1.1rem;background:var(--bg);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .3s ease;text-align:center;color:#fff;font-size:.95rem;font-weight:600;white-space:nowrap;letter-spacing:.01em}.category-option:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.category-option.selected{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 3px rgba(var(--accent-rgb),.2);font-weight:700}@media(max-width:768px){.time-selector{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:.5rem}.time-option{padding:.875rem .5rem}.time-emoji{font-size:1.35rem}.time-label{font-size:.85rem}.setting-label{font-size:.95rem}.category-option{font-size:.9rem;padding:.65rem 1rem}}.form-select{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;background-color:var(--bg);color:var(--text);font-size:1rem;cursor:pointer}.imposter-count-display{padding:.75rem;background-color:var(--bg);border:1px solid var(--border);border-radius:.5rem;font-size:1rem;font-weight:600;color:var(--accent);text-align:center}.form-select:focus{outline:none;border-color:var(--accent)}.form-select:disabled{opacity:.5;cursor:not-allowed}.online-gameplay{padding:2rem;max-width:900px;margin:0 auto}.game-header-info{text-align:center;margin-bottom:2rem}.game-header-info h2{margin-bottom:.5rem}.lobby-code-small{color:var(--muted);font-size:.9rem}.imposter-count-badge{display:flex;align-items:center;justify-content:center;gap:1rem;background:linear-gradient(135deg,#dc2626,#991b1b);border-radius:1rem;padding:1.5rem 2rem;margin:0 auto 2rem;max-width:300px;box-shadow:0 4px 20px #dc26264d;border:2px solid rgba(255,255,255,.1)}.imposter-count-icon{font-size:2.5rem;line-height:1;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.imposter-count-text{text-align:center}.imposter-count-number{font-size:3rem;font-weight:800;line-height:1;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3)}.imposter-count-label{font-size:.85rem;font-weight:600;letter-spacing:.15em;color:#ffffffe6;margin-top:.25rem}.online-gameplay .card{margin-bottom:2rem}.online-gameplay .card .players-list{background-color:transparent}.online-gameplay .players-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.online-gameplay .game-actions{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.role-reveal{background:linear-gradient(135deg,var(--surface) 0%,var(--bg) 100%);border-radius:1rem;padding:3rem 2rem;text-align:center;margin-bottom:2rem;border:2px solid var(--border)}.role-reveal.imposter{border-color:var(--danger);background:linear-gradient(135deg,#2d1515 0%,var(--bg) 100%)}.role-reveal.crewmate{border-color:var(--success);background:linear-gradient(135deg,#152d1f 0%,var(--bg) 100%)}.role-icon{font-size:4rem;margin-bottom:1rem}.role-title{font-size:2rem;margin-bottom:1rem}.role-reveal.imposter .role-title{color:var(--danger)}.role-reveal.crewmate .role-title{color:var(--success)}.role-description{color:var(--muted);font-size:1.1rem}.role-description p{margin-bottom:.5rem}.role-description p:last-child{margin-bottom:0}.footballer-reveal{margin:2rem 0 1.5rem;padding:1.5rem;background-color:#ffffff0d;border-radius:.75rem;border:2px solid var(--success)}.footballer-label{font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:.75rem}.footballer-name{font-size:2.5rem;font-weight:700;color:var(--success);text-align:center;line-height:1.2}.players-status{margin-bottom:2rem}.players-status h3{margin-bottom:1rem}.players-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.player-card{background-color:var(--surface);border:1px solid var(--border);border-radius:.5rem;padding:1rem;text-align:center;position:relative}.player-card .player-name{font-weight:500}.player-card .host-indicator{position:absolute;top:.5rem;right:.5rem;font-size:1.25rem}.game-instructions{background-color:var(--surface);border-radius:.5rem;padding:1.5rem;margin-bottom:2rem}.game-instructions h3{margin-bottom:1rem}.game-instructions ol{margin-left:1.5rem;color:var(--muted)}.game-instructions li{margin-bottom:.5rem}.game-actions{display:flex;justify-content:center}.error-banner{background-color:#ef44441a;border:1px solid var(--danger);border-radius:.5rem;padding:1rem;margin-bottom:1rem;color:var(--danger);text-align:center}.connecting-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:3rem 2rem;gap:1.5rem}.football-spinner{font-size:4rem;animation:spin .8s linear infinite,bounce .4s ease-in-out infinite alternate;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%{transform:translateY(0) scale(1)}to{transform:translateY(-10px) scale(1.1)}}.connecting-message{text-align:center;padding:0;color:#ffffffe6;font-size:1.5rem;font-weight:600;letter-spacing:.02em}.error-message{color:var(--danger);font-size:.9rem;margin-top:.5rem}@media(max-width:768px){.mode-buttons{grid-template-columns:1fr}.mode-btn{min-height:150px}.lobby-header{flex-direction:column;gap:1rem;align-items:flex-start}.code-value{font-size:2rem;letter-spacing:.2rem}.lobby-actions{flex-direction:column}.lobby-actions .btn{width:100%}.players-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.role-reveal{padding:2rem 1rem}.role-title{font-size:1.5rem}.footballer-name{font-size:1.75rem}}.game-board{padding:1rem;max-width:100%;margin:0 auto;min-height:100vh}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem;background:var(--surface);border-radius:12px;box-shadow:0 4px 6px #0000001a;gap:1rem;flex-wrap:wrap}.game-header h2{margin:0;color:var(--text);font-size:1.3rem}.timer{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--accent);color:#fff;border-radius:8px;font-size:1.1rem;font-weight:600;box-shadow:0 2px 4px #0003}.timer.time-warning{background:#e67e22;animation:pulse 1s infinite}.timer.time-critical{background:#e74c3c;animation:pulse .5s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.alphabet-game-container{background:var(--surface);border-radius:12px;padding:1rem;box-shadow:0 4px 6px #0000001a}.letter-display{text-align:center;margin-bottom:1.5rem}.letter-display .letter-box{display:inline-block}.letter-display .letter-large{font-size:4rem;color:var(--accent);margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.1);letter-spacing:.1em;font-weight:700}.letter-display .letter-divider{height:3px;background:var(--accent);margin-top:.5rem;border-radius:2px}.categories-grid{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.category-card{background:var(--bg);border:2px solid var(--border);border-radius:8px;padding:.75rem;transition:all .3s ease}.category-card:focus-within{border-color:var(--accent);box-shadow:0 2px 8px #00000026}.category-header h3{margin:0 0 .5rem;color:var(--accent);font-size:.9rem;font-weight:600}.category-input-wrapper{position:relative}.category-input{width:100%;padding:.65rem;border:2px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:1rem;transition:border-color .3s ease}.category-input:focus{outline:none;border-color:var(--accent)}.category-input:disabled{opacity:.6;cursor:not-allowed}.answer-feedback{font-size:.75rem;margin-top:.375rem;font-weight:500}.answer-feedback.valid{color:#27ae60}.answer-feedback.invalid{color:#e74c3c}.game-actions{text-align:center;padding-top:1rem;padding-bottom:2rem}.game-actions .btn-large{width:100%;max-width:500px}.manual-scoring-container{padding:1rem;max-width:100%;margin:0 auto;min-height:100vh}.manual-scoring-header{text-align:center;margin-bottom:1.5rem;padding:1rem;background:var(--surface);border-radius:12px}.manual-scoring-header h2{color:var(--text);margin:0 0 .5rem;font-size:1.5rem}.manual-scoring-header p{color:var(--text-secondary);font-size:.9rem;margin:0}.player-selector-horizontal{margin-bottom:1.5rem}.player-selector-horizontal h3{margin:0 0 1rem;color:#fff;font-size:1.1rem;padding:0 .5rem}.player-tabs{display:flex;gap:.75rem;overflow-x:auto;padding:.5rem;background:var(--surface);border-radius:12px;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.player-tabs::-webkit-scrollbar{height:4px}.player-tabs::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}.player-tab{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .3s ease;min-width:80px;color:#fff}.player-tab:hover{border-color:var(--accent)}.player-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px #0003}.player-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.player-tab.active .player-avatar{background:#fff;color:var(--accent)}.player-tab-name{font-size:.85rem;font-weight:500;text-align:center;color:inherit}.answers-section{background:var(--surface);border-radius:12px;padding:1rem;margin-bottom:1.5rem}.answers-section h3{margin:0 0 1rem;color:var(--text);font-size:1.2rem;padding-bottom:.75rem;border-bottom:2px solid var(--border)}.answers-grid-compact{display:flex;flex-direction:column;gap:.75rem}.answer-item-compact{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.75rem;display:flex;justify-content:space-between;align-items:center;gap:.75rem}.answer-category-label{font-size:.85rem;color:var(--text-secondary);font-weight:600;min-width:80px;flex-shrink:0}.answer-text{font-size:1rem;color:var(--text);font-weight:500;flex:1;text-align:right}.answer-text.no-answer{color:var(--text-secondary);font-style:italic;opacity:.6}.answer-text.invalid{color:#e74c3c}.invalid-badge{display:inline-block;margin-left:.5rem;font-size:.75rem;padding:.125rem .5rem;background:#e74c3c;color:#fff;border-radius:4px}.score-entry-section{background:var(--surface);border-radius:12px;padding:1rem;margin-bottom:1rem}.score-entry-section h3{margin:0 0 1rem;color:var(--accent);font-size:1.2rem;text-align:center}.scoring-guide-top{display:flex;justify-content:center;gap:1rem;margin-bottom:1.5rem;padding:.75rem;background:var(--bg);border-radius:8px;flex-wrap:wrap}.guide-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#fff}.guide-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;font-weight:700;font-size:.9rem;color:#fff}.guide-badge.unique{background:#27ae60}.guide-badge.duplicate{background:#3498db}.guide-badge.invalid{background:#95a5a6}.score-entry-grid{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.score-entry-item{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.75rem}.score-entry-header{margin-bottom:.5rem}.score-category-name{font-size:.9rem;color:var(--text);font-weight:600;margin-bottom:.25rem}.my-answer-display{font-size:.85rem;color:var(--accent);font-weight:500;font-style:italic;padding:.25rem 0}.score-buttons{display:flex;gap:.5rem;justify-content:space-between}.score-btn{flex:1;padding:.75rem;border:2px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s ease;touch-action:manipulation}.score-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.score-btn:active:not(:disabled){transform:translateY(0)}.score-btn:disabled{opacity:.5;cursor:not-allowed}.score-btn.score-0{border-color:#95a5a6}.score-btn.score-0.selected{background:#95a5a6;color:#fff;border-color:#95a5a6;box-shadow:0 0 0 3px #95a5a633}.score-btn.score-1{border-color:#3498db}.score-btn.score-1.selected{background:#3498db;color:#fff;border-color:#3498db;box-shadow:0 0 0 3px #3498db33}.score-btn.score-3{border-color:#27ae60}.score-btn.score-3.selected{background:#27ae60;color:#fff;border-color:#27ae60;box-shadow:0 0 0 3px #27ae6033}.score-total-display{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg);border-radius:8px;margin-bottom:1.5rem;font-size:1.1rem;border:2px solid var(--accent)}.score-total-display strong{color:var(--accent);font-size:1.5rem}.btn-submit{width:100%;margin-bottom:1rem}.submitted-status{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#27ae601a;border:2px solid #27ae60;border-radius:8px;text-align:left}.check-icon{width:48px;height:48px;flex-shrink:0;background:#27ae60;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}.submitted-status strong{display:block;color:var(--text);margin-bottom:.25rem}.submitted-status p{margin:0;color:var(--text-secondary);font-size:.9rem}.scoreboard-container{padding:1rem;max-width:100%;margin:0 auto;min-height:100vh}.scoreboard-header{text-align:center;margin-bottom:1.5rem}.scoreboard-header h2{color:var(--text);margin-bottom:.5rem;font-size:1.8rem}.scoreboard-header p{color:var(--text-secondary);font-size:1rem}.current-leader{background:linear-gradient(135deg,#f39c12,#e67e22);border-radius:12px;padding:.75rem;margin-bottom:1.5rem;box-shadow:0 4px 12px #f39c124d}.leader-content{display:flex;align-items:center;justify-content:center;gap:.75rem}.leader-icon{font-size:1.5rem;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.leader-info{text-align:center;color:#fff}.leader-label{font-size:.7rem;opacity:.9;margin-bottom:.2rem;text-transform:uppercase;letter-spacing:.05em}.leader-name{font-size:1rem;font-weight:700;margin-bottom:.2rem}.leader-points{font-size:.9rem;font-weight:600}.scores-table-wrapper{background:var(--surface);border-radius:12px;padding:.75rem;box-shadow:0 4px 6px #0000001a;overflow-x:auto;margin-bottom:1.5rem;-webkit-overflow-scrolling:touch}.scores-table{width:100%;border-collapse:collapse;min-width:auto}.scores-table thead{background:var(--bg);position:sticky;top:0;z-index:10}.scores-table th{padding:.4rem .2rem;text-align:center;color:var(--text);font-weight:600;border-bottom:2px solid var(--border);font-size:.7rem;min-width:55px}.scores-table th.sticky-col{position:sticky;left:0;background:var(--bg);z-index:11;min-width:45px;max-width:45px;width:45px;padding:.4rem .1rem}.player-header{display:flex;flex-direction:column;align-items:center;gap:.4rem}.player-rank{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;background:var(--accent);color:#fff}.player-rank.rank-1,.player-rank.rank-2,.player-rank.rank-3{background:var(--accent);color:#fff}.player-rank:not(.rank-1):not(.rank-2):not(.rank-3){background:var(--accent);color:#fff}.player-name-small{font-size:.7rem;color:var(--text-secondary);max-width:65px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scores-table tbody tr{border-bottom:1px solid var(--border)}.scores-table tbody tr:hover{background:#ffffff0d}.scores-table td{padding:.4rem .2rem;text-align:center;font-size:.7rem}.scores-table td.sticky-col{position:sticky;left:0;background:var(--surface);z-index:1;font-weight:600;width:45px;min-width:45px;max-width:45px;padding:.4rem .1rem}.scores-table tbody tr:hover td.sticky-col{background:#ffffff0d}.round-cell{font-weight:600}.round-info{display:flex;flex-direction:column;gap:.25rem}.round-letter{font-size:1.2rem;color:var(--accent);font-weight:700}.round-number{font-size:.7rem;color:var(--text-secondary)}.score-cell{color:var(--text)}.score-value{font-size:1.1rem;font-weight:700;color:var(--accent)}.score-value.total{font-size:1.4rem;color:var(--accent)}.score-label{font-size:.65rem;color:var(--text-secondary);text-transform:uppercase;margin-top:.125rem}.total-row{background:var(--bg);font-weight:700;border-top:3px solid var(--accent)}.total-row td{padding:1.5rem 1rem}.scoreboard-actions{text-align:center;margin-bottom:2rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.status-message{background:var(--surface);border:2px solid var(--border);border-radius:8px;padding:1.5rem;text-align:center}.status-message p{margin:0;color:var(--text-secondary);font-size:1.1rem}.scoring-legend{background:var(--surface);border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a}.scoring-legend h3{margin:0 0 1rem;color:var(--text);text-align:center;font-size:1.2rem}.legend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.legend-item{background:var(--bg);border:2px solid var(--border);border-radius:8px;padding:1rem;text-align:center;transition:all .3s ease}.legend-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.legend-item.unique{border-color:#27ae60}.legend-item.duplicate{border-color:#3498db}.legend-item.invalid{border-color:#95a5a6}.legend-points{font-size:2rem;font-weight:700;margin-bottom:.5rem}.legend-item.unique .legend-points{color:#27ae60}.legend-item.duplicate .legend-points{color:#3498db}.legend-item.invalid .legend-points{color:#95a5a6}.legend-label{font-size:.9rem;color:var(--text-secondary)}@media(max-width:768px){.manual-scoring-layout{grid-template-columns:1fr}.player-selector{flex-direction:row;overflow-x:auto}.categories-grid{grid-template-columns:1fr}.game-header{flex-direction:column;gap:1rem}.letter-display h1{font-size:3rem}.scores-table-wrapper{padding:.5rem}.leader-content{flex-direction:column;gap:1rem}.scores-table-wrapper{overflow-x:auto}.scores-table{font-size:.85rem}.player-rank{width:32px;height:32px;font-size:1rem}}@media(max-width:375px){.game-header h2{font-size:1.1rem}.timer{font-size:.95rem;padding:.5rem .75rem}.letter-display .letter-large{font-size:3rem}.category-header h3{font-size:.85rem}.category-input{font-size:.95rem;padding:.6rem}.manual-scoring-header h2{font-size:1.3rem}.player-tab{min-width:70px;padding:.6rem .75rem}.player-avatar{width:32px;height:32px;font-size:1rem}}.hamburger-menu-btn{position:fixed;top:1rem;left:1rem;z-index:1001;display:flex;align-items:center;justify-content:center;width:48px;height:48px;background-color:transparent;border:none;border-radius:8px;color:var(--text);cursor:pointer;transition:all .2s ease}.hamburger-menu-btn:hover{background-color:#ffffff1a}.hamburger-menu-btn:focus{outline:2px solid var(--accent);outline-offset:2px}.hamburger-icon{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:3px;width:20px;height:20px}.hamburger-line{width:16px;height:2px;background-color:currentColor;transition:all .3s ease}.close-icon{font-size:32px;line-height:1;font-weight:300}@media screen and (max-width:768px){.hamburger-menu-btn{font-size:20px}}.sidebar.expanded .hamburger-menu-btn{position:absolute;top:1rem;right:1rem;left:auto;z-index:1002;font-size:24px}.game-header-component{margin-bottom:2rem}.game-header-component.centered{text-align:center}.game-header-icon{font-size:4rem;margin-bottom:.5rem;line-height:1}.game-header-title{font-size:3rem;font-weight:700;color:var(--accent);margin:0 0 .5rem;line-height:1.2}.game-header-subtitle{color:var(--muted);font-size:1.15rem;margin:0;line-height:1.5}@media(max-width:768px){.game-header-component{margin-bottom:1.5rem}.game-header-icon{font-size:3rem}.game-header-title{font-size:2.25rem}.game-header-subtitle{font-size:1.05rem}}@media(max-width:480px){.game-header-icon{font-size:2.5rem}.game-header-title{font-size:2rem}.game-header-subtitle{font-size:1rem}}.mode-selection-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;max-width:900px;margin:0 auto}.mode-btn{padding:2rem;text-align:center;display:flex;flex-direction:column;gap:.5rem;min-height:200px;justify-content:center;transition:all .3s ease}.mode-btn:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0003}.mode-icon{font-size:3rem;line-height:1}.mode-title{font-size:1.5rem;font-weight:600;color:inherit;line-height:1.3}.mode-description{color:#ffffffd9;font-size:1.1rem;line-height:1.4}@media(max-width:768px){.mode-selection-buttons{grid-template-columns:1fr;gap:1rem}.mode-btn{min-height:150px;padding:1.5rem}.mode-icon{font-size:2.5rem}.mode-title{font-size:1.4rem}.mode-description{font-size:1.05rem}}@media(max-width:480px){.mode-btn{padding:1.25rem;min-height:130px}.mode-icon{font-size:2rem}.mode-title{font-size:1.3rem}.mode-description{font-size:1rem}}
