:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color:#333;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{margin:0;padding:0;width:100%;height:100%}body{background-color:#fff}a{font-weight:500;color:#667eea;text-decoration:inherit}a:hover{color:#764ba2}button{cursor:pointer;transition:all .3s ease;font-family:inherit}h1,h2,h3{line-height:1.1}h1{font-size:2.5rem}h2{font-size:1.8rem}h3{font-size:1.2rem}input,textarea,select{font-family:inherit;font-size:1rem}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-box h1{text-align:center;color:#333;margin-bottom:.5rem;font-size:2rem}.subtitle{text-align:center;color:#666;margin-bottom:2rem;font-size:.9rem}.form-group{margin-bottom:1rem}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s}.form-group input::placeholder{font-size:.9rem}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.submit-button{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-bottom:1rem}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}.submit-button:disabled{opacity:.7;cursor:not-allowed}.toggle-form{text-align:center;color:#666;font-size:.9rem;margin-bottom:1rem}.toggle-button{background:none;border:none;color:#667eea;cursor:pointer;font-weight:600;text-decoration:underline;padding:0}.toggle-button:hover{color:#764ba2}.demo-info{background-color:#f0f4ff;padding:.75rem;border-radius:6px;border-left:4px solid #667eea}.small-text{margin:.25rem 0;font-size:.8rem;color:#666}.divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0;color:#999;font-size:.9rem}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid #ddd}.divider span{padding:0 1rem}.guest-button{width:100%;padding:.75rem;background:linear-gradient(135deg,#34d399,#10b981);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-bottom:.5rem}.guest-button:hover{transform:translateY(-2px);box-shadow:0 5px 20px #10b98166}.guest-info{text-align:center;color:#666;font-size:.85rem;margin-bottom:1.5rem;font-style:italic}.lobby-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.lobby-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;max-width:600px;margin-left:auto;margin-right:auto}.lobby-header h1{color:#fff;font-size:2.5rem;margin:0}.user-info{color:#fff;display:flex;align-items:center;gap:1rem}.logout-button{background:#fff3;border:1px solid white;color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s}.logout-button:hover{background:#ffffff4d}.lobby-content{background:#fff;border-radius:12px;padding:2rem;max-width:600px;margin:0 auto;box-shadow:0 10px 40px #0003}.lobby-content h2{text-align:center;color:#333;margin-top:0}.mode-selection{text-align:center}.button-group{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem}.mode-button{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:1rem;transition:all .3s}.mode-button:hover{transform:translateY(-4px);box-shadow:0 5px 20px #0000001a}.mode-button.create-button:hover{border-color:#667eea}.mode-button.join-button:hover{border-color:#764ba2}.mode-button .icon{font-size:2rem}.mode-button .text{font-weight:600;color:#333}.create-game,.join-game,.game-created{text-align:center}.form-group{margin:1.5rem 0}.form-group label{display:block;color:#333;font-weight:600;margin-bottom:.5rem}.form-group input{width:100%;padding:.75rem;font-size:1.5rem;text-align:center;letter-spacing:.2rem;border:2px solid #ddd;border-radius:6px;font-weight:600;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#764ba2}.action-button{width:100%;padding:.75rem;font-size:1rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .3s;margin-bottom:1rem}.action-button.create-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-button.create-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}.action-button.join-button{background:linear-gradient(135deg,#764ba2,#667eea);color:#fff}.action-button.join-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #764ba266}.action-button:disabled{opacity:.5;cursor:not-allowed}.back-button{background:#f0f0f0;border:none;color:#666;padding:.75rem 1rem;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s}.back-button:hover{background:#e0e0e0;color:#333}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem;border-left:4px solid #c33}.join-code-display{font-size:3rem;font-weight:900;letter-spacing:.2rem;color:#667eea;padding:2rem;background:#f0f4ff;border-radius:8px;margin:1rem 0;font-family:Courier New,monospace}.small-text{color:#999;font-size:.9rem;margin-top:1rem}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-weight:600;text-decoration:underline;padding:0;font-size:inherit}.link-button:hover{color:#764ba2}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s}.login-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.info-text{text-align:center;color:#666;font-size:.95rem;margin-top:1rem}.game-map-section{position:absolute;inset:0;width:100%;height:100%;background:#aad3df}.map-container{position:absolute;inset:0;width:100%;height:100%}.loading-spinner{display:flex;align-items:center;justify-content:center;height:100%;color:#666;font-size:1.1rem;background:linear-gradient(135deg,#667eea15,#764ba215)}.game-controls{position:absolute;bottom:20px;left:20px;right:360px;z-index:1000;display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:500px;margin:0 auto;pointer-events:auto}@media(max-width:1024px){.game-controls{right:20px}}@media(max-width:768px){.game-controls{bottom:250px;left:.5rem;right:.5rem;max-width:none}.button-group{flex-direction:row;width:100%}.confirm-button,.skip-button{max-width:none;flex:1}.hint-text{font-size:.85rem;padding:.75rem}}.street-display{background:#fff;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 4px 15px #0003;text-align:center;color:#333;font-size:1.1rem;width:100%}.street-display strong{color:#667eea;font-size:1.4rem}.button-group{display:flex;gap:1rem;width:100%;justify-content:center}.confirm-button,.skip-button{flex:1;max-width:200px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s;color:#fff}.confirm-button{background:linear-gradient(135deg,#34d399,#10b981)}.confirm-button:hover{transform:translateY(-2px);box-shadow:0 5px 20px #34d39966}.skip-button{background:linear-gradient(135deg,#a0aec0,#718096)}.skip-button:hover{transform:translateY(-2px);box-shadow:0 5px 20px #a0aec066}.hint-text{background:#fffffff2;padding:1rem;border-radius:8px;text-align:center;color:#666;font-size:.95rem;box-shadow:0 4px 15px #0000001a}.popup-content{font-family:Arial,sans-serif;font-size:.85rem;color:#333;padding:.5rem}.popup-content strong{display:block;margin-bottom:.5rem;color:#667eea}.popup-content br{display:block;margin:.25rem 0}.guess-marker,.revealed-marker{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.leaflet-container{background:#aad3df}.leaflet-attribution{font-size:.7rem;background:#fffc}.player-name-tooltip{background:#fffffff2;border:1px solid #ddd;border-radius:4px;padding:4px 8px;font-weight:600;font-size:.75rem;color:#333;box-shadow:0 2px 6px #0003}.player-name-tooltip:before{border-top-color:#fffffff2}.scoreboard{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 4px 15px #0000001a;height:100%;display:flex;flex-direction:column}.scoreboard h3{margin:0 0 1rem;color:#333;font-size:1.1rem;border-bottom:2px solid #667eea;padding-bottom:.5rem}.player-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.player-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f8f9fa;border-radius:8px;transition:all .3s;border-left:4px solid transparent}.player-item:hover{background:#f0f4ff;transform:translate(4px)}.player-item.current-user{background:#e8f4ff;border-left-color:#667eea;font-weight:600}.player-rank{min-width:2rem;text-align:center;font-size:1.2rem;font-weight:600;color:#667eea}.player-info{flex:1;min-width:0}.player-name{font-weight:600;color:#333;display:flex;align-items:center;gap:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.guessed-badge{display:inline-block;background:#34d399;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;flex-shrink:0}.player-score{display:flex;align-items:center;gap:.5rem;text-align:right}.total-score{font-size:1.2rem;font-weight:900;color:#667eea;min-width:3rem}.round-points{font-size:.85rem;color:#34d399;font-weight:600;background:#ecfdf5;padding:.25rem .5rem;border-radius:4px;white-space:nowrap}.player-list::-webkit-scrollbar{width:6px}.player-list::-webkit-scrollbar-track{background:#f0f0f0;border-radius:3px}.player-list::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.player-list::-webkit-scrollbar-thumb:hover{background:#bbb}.host-controls{background:linear-gradient(135deg,#fff5e6,#ffe8cc);border-left:4px solid #fbbf24;border-radius:12px;padding:1rem;box-shadow:0 4px 15px #fbbf2433;height:100%;display:flex;flex-direction:column}.host-controls h3{margin:0 0 1rem;color:#92400e;font-size:1.1rem}.control-section{flex:1;display:flex;flex-direction:column;gap:1rem}.info-text{color:#92400e;font-weight:600;margin:0;font-size:.95rem}.guess-status{flex:1;display:flex;flex-direction:column;gap:.75rem}.status-text{color:#92400e;font-weight:600;margin:0;font-size:.95rem}.player-status{background:#fff;border-radius:8px;padding:.75rem;max-height:150px;overflow-y:auto;border:1px solid #fed7aa}.status-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;border-bottom:1px solid #fef3c7;font-size:.9rem}.status-item:last-child{border-bottom:none}.status-name{color:#333;font-weight:500}.status-check{color:#34d399;font-weight:900;font-size:1.1rem}.status-waiting{color:#f59e0b;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.control-button{padding:.75rem 1rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s;color:#fff}.start-button{background:linear-gradient(135deg,#667eea,#764ba2)}.start-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}.reveal-button{background:linear-gradient(135deg,#f59e0b,#d97706)}.reveal-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #f59e0b66}.reveal-button:disabled{opacity:.5;cursor:not-allowed;background:linear-gradient(135deg,#ccc,#999)}.next-button{background:linear-gradient(135deg,#10b981,#059669)}.next-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #10b98166}.hint-text{color:#92400e;font-size:.85rem;font-style:italic;margin:0}.player-status::-webkit-scrollbar{width:4px}.player-status::-webkit-scrollbar-track{background:#fef3c7;border-radius:2px}.player-status::-webkit-scrollbar-thumb{background:#fbbf24;border-radius:2px}.player-status::-webkit-scrollbar-thumb:hover{background:#f59e0b}.management-section{margin-top:1rem;padding-top:1rem;border-top:2px solid #fed7aa;flex:0}.section-title{margin:0 0 .75rem;color:#92400e;font-size:.95rem;font-weight:600}.skip-round-button{background:linear-gradient(135deg,#a78bfa,#8b5cf6);font-size:.9rem;padding:.65rem .85rem}.skip-round-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #8b5cf666}.reset-scores-button{background:linear-gradient(135deg,#3b82f6,#2563eb);font-size:.9rem;padding:.65rem .85rem}.reset-scores-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #3b82f666}.restart-button{background:linear-gradient(135deg,#f97316,#ea580c);font-size:.9rem;padding:.65rem .85rem}.restart-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #f9731666}.end-game-button{background:linear-gradient(135deg,#ef4444,#dc2626);font-size:.9rem;padding:.65rem .85rem}.end-game-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #ef444466}.game-fullscreen{position:relative;height:100vh;width:100vw;overflow:hidden}.map-background{position:absolute;inset:0;z-index:0}.top-right-controls{position:fixed;top:1rem;right:1rem;z-index:1000;display:flex;gap:.5rem}.back-button-overlay{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid #e5e7eb;color:#667eea;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s;box-shadow:0 4px 6px #0000001a}.back-button-overlay:hover{background:#fff;transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.top-left-info{position:fixed;top:1rem;left:1rem;z-index:1000;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 1.5rem;border-radius:12px;box-shadow:0 4px 15px #0000001a;border:2px solid #e5e7eb}.game-title{font-size:1.2rem;font-weight:700;color:#667eea;margin-bottom:.5rem}.game-metadata{display:flex;gap:.5rem;font-size:.9rem;color:#666;align-items:center}.game-metadata span{white-space:nowrap}.host-badge{background:#ffd70033;color:#d97706;padding:.25rem .5rem;border-radius:4px;font-weight:600;font-size:.85rem}.players-list{font-size:.85rem;color:#555;margin-top:.5rem;line-height:1.3}.right-sidebar-overlay{position:fixed;top:5rem;right:1rem;bottom:1rem;width:320px;z-index:1000;display:flex;flex-direction:column;gap:1rem;overflow-y:auto;pointer-events:auto}.right-sidebar-overlay::-webkit-scrollbar{width:6px}.right-sidebar-overlay::-webkit-scrollbar-track{background:#0000001a;border-radius:3px}.right-sidebar-overlay::-webkit-scrollbar-thumb{background:#0000004d;border-radius:3px}.right-sidebar-overlay::-webkit-scrollbar-thumb:hover{background:#00000080}.waiting-panel-overlay{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1.5rem;box-shadow:0 4px 15px #0000001a;border:2px solid #e5e7eb}.waiting-panel-overlay h3{margin:0 0 1rem;color:#667eea;font-size:1.1rem}.waiting-panel-overlay p{color:#666;font-size:.95rem;margin:0;line-height:1.5}.guest-points-badge{position:fixed;top:130px;right:1rem;background:linear-gradient(135deg,#34d399,#10b981);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:1.1rem;font-weight:700;box-shadow:0 4px 15px #10b98166;z-index:1001}@media(max-width:768px){.guest-points-badge{top:auto;bottom:80px;right:1rem;font-size:1rem}}.game-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#667eea15,#764ba215);color:#333}.spinner{width:50px;height:50px;border:4px solid #ddd;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.game-loading p{font-size:1.1rem;color:#666}.game-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#667eea15,#764ba215);text-align:center}.game-error h2{color:#c33;margin-bottom:1rem}.game-error p{color:#666;margin-bottom:1.5rem;max-width:400px}.game-error button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s}.game-error button:hover{transform:translateY(-2px);box-shadow:0 5px 20px #667eea66}@media(max-width:1024px){.right-sidebar-overlay{width:280px}.top-left-info{font-size:.9rem}.game-title{font-size:1rem}}@media(max-width:768px){.top-left-info{left:.5rem;right:.5rem;top:.5rem;padding:.75rem 1rem}.top-right-controls{top:.5rem;right:.5rem}.back-button-overlay{padding:.5rem 1rem;font-size:.9rem}.right-sidebar-overlay{left:.5rem;right:.5rem;top:auto;bottom:0;width:auto;max-height:30vh;border-radius:12px 12px 0 0;box-shadow:0 -4px 15px #0000001a}.game-title{font-size:.95rem}.game-metadata{font-size:.8rem;flex-wrap:wrap}.players-list{font-size:.75rem;margin-top:.25rem}.status-badge{padding:.6rem 1.2rem;font-size:.9rem}}.game-ended-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game-ended-modal{background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:20px;padding:2.5rem;max-width:500px;width:90%;box-shadow:0 20px 60px #00000080;animation:slideUp .4s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.game-ended-title{text-align:center;font-size:2rem;margin:0 0 2rem;color:#333;font-weight:700}.final-standings{margin-bottom:2rem}.final-standings h3{text-align:center;color:#666;font-size:1.2rem;margin:0 0 1.5rem;font-weight:600}.standing-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:12px;margin-bottom:.75rem;border:2px solid #e5e7eb;transition:all .3s}.standing-item.winner{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fbbf24;transform:scale(1.02);box-shadow:0 8px 20px #fbbf244d}.standing-item.current-user{border-color:#667eea;background:linear-gradient(135deg,#ede9fe,#ddd6fe)}.standing-rank{font-size:1.5rem;min-width:40px;text-align:center}.trophy{font-size:2rem;animation:bounce 1s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.medal{font-size:1.5rem}.position{font-size:1.2rem;color:#666;font-weight:600}.standing-name{flex:1;font-size:1.1rem;font-weight:600;color:#333}.standing-score{font-size:1.2rem;font-weight:700;color:#667eea}.game-ended-actions{display:flex;gap:1rem;justify-content:center}.lobby-button,.play-again-button{flex:1;padding:.9rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .3s;color:#fff}.lobby-button{background:linear-gradient(135deg,#64748b,#475569)}.lobby-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #64748b66}.play-again-button{background:linear-gradient(135deg,#34d399,#10b981)}.play-again-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #10b98166}.guest-minimal-ui{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:1000}.status-badge{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50px;padding:.75rem 1.5rem;font-weight:600;font-size:1rem;box-shadow:0 4px 15px #0003;border:2px solid #e5e7eb;white-space:nowrap}.status-badge.status-waiting{border-color:#fbbf24;color:#d97706}.status-badge.status-playing{border-color:#667eea;color:#667eea}.status-badge.status-revealed{border-color:#34d399;color:#10b981}.street-name-display{position:fixed;top:15%;left:50%;transform:translate(-50%,-50%);background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:2rem;box-shadow:0 10px 40px #0003;border:3px solid #667eea;z-index:999;text-align:center;max-width:90%;pointer-events:none}.street-name-label{font-size:.95rem;color:#666;font-weight:500;margin-bottom:.5rem}.street-name-value{font-size:1.8rem;color:#667eea;font-weight:700;line-height:1.3}@media(max-width:768px){.street-name-display{top:130px;transform:translate(-50%);padding:.75rem 1rem}.street-name-label{font-size:.7rem;margin-bottom:.25rem}.street-name-value{font-size:1.1rem}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;transition:all .3s ease}button:disabled{opacity:.5;cursor:not-allowed}input,textarea,select{font-family:inherit}.leaflet-container{font-family:inherit;background:#aad3df}.leaflet-control-attribution{background-color:#fffc;font-size:.7rem}
