.loader{width:50px;aspect-ratio:1;--c: no-repeat linear-gradient(#ffffff 0 0);background:var(--c) 0 0,var(--c) 100% 0,var(--c) 100% 100%,var(--c) 0 100%;animation:l2-1 2s infinite,l2-2 2s infinite;position:relative}.loader img{position:absolute;top:10px;left:10px;width:30px;height:30px;object-fit:contain}@keyframes l2-1{0%{background-size:0 3px,3px 0,0 3px,3px 0}12.5%{background-size:100% 3px,3px 0,0 3px,3px 0}25%{background-size:100% 3px,3px 100%,0 3px,3px 0}37.5%{background-size:100% 3px,3px 100%,100% 3px,3px 0}45%,55%{background-size:100% 3px,3px 100%,100% 3px,3px 100%}62.5%{background-size:0 3px,3px 100%,100% 3px,3px 100%}75%{background-size:0 3px,3px 0,100% 3px,3px 100%}87.5%{background-size:0 3px,3px 0,0 3px,3px 100%}to{background-size:0 3px,3px 0,0 3px,3px 0}}@keyframes l2-2{0%,49.9%{background-position:0 0,100% 0,100% 100%,0 100%}50%,to{background-position:100% 0,100% 100%,0 100%,0 0}}.btn-primary{font-family:inherit;font-size:1rem;font-weight:700;padding:1rem 1.5rem;border:none;border-radius:24px;cursor:pointer;transition:all .2s ease;background:#ab9100;color:#fff;box-shadow:0 4px 12px #09090966}.btn-primary.btn-full-width{width:100%}.btn-primary:hover:not(:disabled){background:#ffed4e;transform:translateY(-1px);box-shadow:0 4px 12px #ab910066}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:focus,.btn-primary:focus-visible{outline:3px solid #ab9100;outline-offset:2px}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{font-family:inherit;font-size:1rem;font-weight:500;padding:1rem 1.5rem;border:2px solid #ab9100;border-radius:24px;cursor:pointer;transition:all .2s ease;background:#333;color:#fff;box-shadow:0 4px 12px #09090966}.btn-secondary.btn-full-width{width:100%}.btn-secondary:hover:not(:disabled){background:#3d3d3d}.btn-secondary:active:not(:disabled){background:#393939}.btn-secondary:focus,.btn-secondary:focus-visible{outline:3px solid #ab9100;outline-offset:2px}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.room-container{width:100%;max-width:600px;display:flex;flex-direction:column;align-items:center;gap:1rem}.match-found-title{font-size:2rem;font-weight:600;color:#fff;margin:0;text-align:center}.players-count{font-size:1rem;color:#fff;margin:0;text-align:center}.players-slots{width:100%;display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.player-slot{background:#333;border-radius:12px;padding:.5rem 1rem;display:flex;align-items:center;gap:1rem;min-height:60px}.player-slot.filled{border:1px solid rgba(255,255,255,.1)}.player-slot.empty{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);opacity:.7}.player-slot.current-player{border:2px solid #ab9100;background:#ab91001a}.player-slot-avatar{width:48px;height:48px;border-radius:50%;background:#ab9100;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.player-slot.empty .player-slot-avatar{background:#666}.player-slot-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.player-slot-avatar-placeholder{width:32px;height:32px;background:#ffffff4d;border-radius:50%;position:relative}.player-slot-avatar-placeholder:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background:#ffffff80;border-radius:50%;clip-path:polygon(50% 0%,50% 30%,30% 30%,30% 50%,70% 50%,70% 30%,50% 30%,50% 100%,30% 100%,30% 70%,70% 70%,70% 100%,50% 100%)}.player-slot-name{font-size:1rem;color:#fff;font-weight:500}.timer-circle{width:120px;height:120px;border:8px solid #ab9100;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:2rem auto;background:transparent}.timer-circle-value{font-size:3rem;font-weight:700;color:#fff}.auto-start-text{font-size:1rem;color:#fff;text-align:center;margin:0}.room-card{color:#fff;padding:2.5rem 2rem;border-radius:16px;width:100%;display:flex;flex-direction:column;gap:1rem}.room-title-container{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem}.room-title{font-size:1.5rem;font-weight:600;color:#fff;margin:0}.leave-room-button{padding:.5rem 1rem;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease;white-space:nowrap}.leave-room-button:hover:not(:disabled){background:#ffffff26;border-color:#ffffff4d}.leave-room-button:disabled{opacity:.6;cursor:not-allowed}.leave-room-button:focus{outline:2px solid #ab9100;outline-offset:2px}.room-status{font-size:1rem;color:#fff;margin:0}.room-status code{background:#ffffff1a;padding:.25rem .5rem;border-radius:8px;font-family:Courier New,monospace;color:#ab9100}.expiry-timer{font-size:1rem;font-weight:500;margin:0}.expiry-timer.expiry-warning{color:#f44}.expiry-timer.expiry-normal{color:#ab9100}.share-section{margin-top:1rem;padding:1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.share-label{margin-bottom:.5rem;font-weight:600;color:#fff}.share-input-container{display:flex;gap:.5rem;align-items:center}.share-input{flex:1;padding:.5rem;background:#222c;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:.9em;font-family:inherit}.share-input:focus{outline:2px solid #ab9100;outline-offset:2px;border-color:#ab9100}.copy-button{padding:.5rem 1rem;background:#ab9100;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease;white-space:nowrap}.copy-button:hover:not(:disabled){background:#ffed4e}.copy-button.copied{background:#4caf50}.copy-button:focus{outline:2px solid #ab9100;outline-offset:2px}.players-section{margin-top:2rem}.players-title{font-size:1.2rem;font-weight:600;color:#fff;margin:0 0 1rem}.players-list{text-align:left;list-style:none;padding:0;margin:0}.player-item{padding:.5rem;margin:.5rem 0;background:#ffffff0d;border-radius:8px;display:flex;align-items:center;gap:.5rem;transition:background .2s ease}.player-item.current-player{background:#ab910033;border:1px solid rgba(171,145,0,.3)}.player-item:hover{background:#ffffff14}.player-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.player-name{flex:1;color:#fff}.player-meta{font-size:.8em;color:#ccc;margin-left:.25rem}.error-message{color:#f44;font-weight:500;margin:0}.waiting-countdown{margin-top:2rem;font-size:1rem;color:#fff}.game-starting{margin-top:2rem;font-size:1rem;color:#ab9100;font-weight:500}.actions-section{margin-top:2rem}@media (max-width: 768px){.room-card{padding:2rem 1.5rem}.share-input-container{flex-direction:column;align-items:stretch}.copy-button{width:100%}}.round-details-container{color:#fff;width:100%;display:flex;flex-direction:column}.round-header{display:flex;justify-content:space-between;background:#1e1e1e;padding:.5rem 1rem;border-radius:10px}.round-index{color:#ab9100;font-weight:700}.countdown-section{margin-top:0;text-align:center}.countdown-message{margin:0}.task-question{margin-top:1rem;text-align:center;color:#fff;font-size:1.25rem}.round-content,.old-flow-container{margin-top:2rem}.origin-section{position:relative}.origin-label{font-size:.825em;line-height:2.2;color:#fff}.origin-name{font-size:1.5em;color:#fff}.arrow-line{position:absolute;top:10px;left:55px}.destination-point{text-align:right;position:relative}.destination-label{font-size:.825em;line-height:2.2;color:#fff}.destination-name{font-size:1.5em;position:relative;color:#fff}.arrow-line-2{position:absolute;bottom:-40px;right:40px}.traveller-by{margin-top:2rem}.traveller-label{font-size:.825em;line-height:2.2;color:#fff}.traveller-name{font-size:1.5em;color:#fff}.new-flow-container{margin-top:1rem;text-align:center}.location-section{position:relative}.location-label{font-size:.825em;line-height:2.2;color:#fff}.location-content{font-size:1.5em;position:relative;justify-content:center;gap:.5rem;color:#fff;background:#333;border-radius:12px;padding:.5rem 1rem;display:flex;align-items:center;gap:1rem;min-height:60px;border:1px solid rgba(255,255,255,.1);border:1px solid #ab9100}.location-marker{width:30px;height:30px}.traveller-section{margin-top:1rem}.traveller-content{font-size:1.5em;position:relative;color:#fff}.traveller-image{margin-top:.5rem;max-width:100%;height:auto;border-radius:12px}.loading-container{background:#333;color:#fff;padding:2.5rem 2rem;border-radius:16px;width:100%;display:flex;flex-direction:column;gap:1rem}.loading-text{color:#fff;margin:0}.vote-splash{margin-bottom:1rem}.vote-splash-text{font-size:2rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#ab9100;text-shadow:0 2px 8px rgba(0,0,0,.3)}.round-voting-container{color:#fff;width:100%;display:flex;flex-direction:column;gap:1rem}.round-voting-header{display:flex;justify-content:space-between;background:#1e1e1e;padding:.5rem 1rem;border-radius:10px}.round-voting-index{color:#ab9100;font-weight:700}.waiting-message{margin:0;color:#fff}.route-info{display:flex;justify-content:space-between;align-items:center;background-color:#ffffff1a;border-radius:8px;padding:1rem;gap:1rem;border:1px solid rgba(255,255,255,.2)}.route-location{display:flex;flex-direction:column;flex:1;min-width:0}.route-origin{text-align:left}.route-destination{text-align:right}.route-city{font-size:1.1rem;font-weight:700;color:#fff;line-height:1.3;margin-bottom:.2rem}.route-country{font-size:.7rem;color:#ccc;line-height:1.2}.route-arrow{font-size:1.8rem;color:#ab9100;font-weight:700;flex-shrink:0;padding:0 .5rem;line-height:1}.route-traveller-section{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.5rem;padding:.5rem;flex-shrink:0}.route-traveller-image{width:45px;height:45px;object-fit:cover;border-radius:50%;border:2px solid #ab9100;background:#333;flex-shrink:0}.route-traveller{font-size:.85rem;color:#ab9100;font-weight:600;text-transform:uppercase;text-align:center;white-space:nowrap}.duration-picker-section{margin-top:.5rem}.duration-picker-container{display:flex;flex-direction:column;gap:1rem;max-width:400px;margin:0 auto}.submit-section{margin-top:2rem;text-align:center;width:100%}.submit-button{padding:1rem 6rem;font-size:1rem;font-weight:600;background-color:#ab9100;color:#fff;border:none;border-radius:8px;cursor:pointer;box-shadow:0 4px 8px #00000026;min-width:120px;text-transform:uppercase;transition:all .2s ease}.submit-button:hover:not(:disabled){background-color:#ffed4e;box-shadow:0 8px 16px #0003}.submit-button:disabled{background-color:#666;cursor:not-allowed;opacity:.6}.submit-button:focus{outline:2px solid #ab9100;outline-offset:2px}.waiting-for-players{margin-top:2rem;color:#fff;text-align:center}@media (max-width: 768px){.vote-splash-text{font-size:2rem}.submit-button{padding:1rem 2rem;width:100%}.duration-picker-container{max-width:100%}.route-info{padding:.5rem;gap:.25rem}.route-city{font-size:.95rem}.route-country{font-size:.65rem}.route-arrow{font-size:1.4rem;padding:0 .25rem}.route-traveller-section{flex-direction:column;gap:.25rem}.route-traveller-image{width:35px;height:35px}.route-traveller{font-size:.7rem}}.round-result-container{color:#fff;width:100%;display:flex;flex-direction:column;gap:.5rem}.round-result-header{display:flex;justify-content:space-between;background:#1e1e1e;padding:.5rem 1rem;border-radius:10px;margin-bottom:.5rem}.round-result-title{color:#ab9100;font-weight:700;margin:0;padding:0}.countdown-section{display:flex;flex-direction:row;text-align:center}.correct-answer-section{margin-top:.5rem;margin-bottom:.5rem;text-align:left;padding:.5rem 1rem;background-color:#ab910026;border:1px solid rgba(171,145,0,.3);border-radius:8px}.correct-answer-label{color:#fff;margin:0;font-size:.9rem}.correct-answer-value{color:#ab9100;font-weight:700;font-size:1.1em}.winner-message,.loser-message{margin-top:.5rem;margin-bottom:.5rem;text-align:center;padding:.5rem 1rem;border-radius:8px;color:#fff;font-size:1rem;line-height:1.5}.results-section{margin-top:.5rem}.results-list{text-align:left;list-style:none;padding:0;margin:0}.result-item{padding:.5rem 1rem;margin:.25rem 0;background-color:#333;border-radius:8px;border:1px solid rgba(255,255,255,.2);transition:all .2s ease}.result-item:hover{border-color:#ffffff4d;box-shadow:0 4px 8px #00000026}.result-item-header{display:flex;align-items:center;gap:.5rem}.result-item-player{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:space-between}.player-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.2)}.player-name{color:#fff;font-weight:600}.player-answer{color:#fff}.player-score{font-weight:700;font-size:1em;color:#ab9100;margin-left:.25rem}.result-item-details{margin-top:.25rem;font-size:.85rem;color:#ccc}.result-detail-row{margin:.25rem 0;display:flex;align-items:center;gap:.25rem}.result-detail-label{font-weight:600;color:#ccc}.result-detail-value{font-weight:700}.precision-value.best{color:#4caf50}.precision-value.not-best{color:#f44}.answer-time-value.best{color:#4caf50}.answer-time-value.not-best{color:#f44}.banner-section{display:flex;justify-content:center;margin-top:1rem}.banner-container{width:300px;height:250px;background-color:#333;position:relative;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.banner-placeholder{position:absolute;top:20px;left:20px;color:#ccc;font-size:.9rem}.countdown-text{font-weight:700;color:#ab9100;margin:0}.waiting-message{color:#fff;margin:0}.itinerary-map-container{text-align:center;padding:1rem}.itinerary-map-header{margin-bottom:.5rem;color:#fff}.itinerary-map-title{font-size:1.5em;font-weight:700;color:#ab9100}.itinerary-map-image-container{margin-top:2rem}.itinerary-map-image{max-width:100%;height:auto;border:1px solid #ab9100;border-radius:8px;box-shadow:0 4px 8px #00000026}@media (max-width: 768px){.correct-answer-section{text-align:left;width:100%}.player-score{font-size:1.1em}.banner-container{width:100%;max-width:300px;height:200px}.itinerary-map-title{font-size:1.2em}}.game-results-container{color:#fff;width:100%;display:flex;flex-direction:column;gap:1rem}.victory-section{margin-top:2rem;text-align:center}.victory-title{font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.victory-title.winner{color:#ab9100}.victory-title.loser{color:#f44}.victory-message{color:#fff;margin:.5rem 0;font-size:1rem}.final-scores-section{margin-top:.5rem}.final-scores-title{text-align:center;color:#fff;font-size:1.2rem;font-weight:700;margin:0 0 1rem}.final-scores-list{text-align:left;list-style:none;padding:0;margin:0}.final-score-item{padding:.5rem 1rem;margin:.25rem 0;background-color:#333;border-radius:8px;border:1px solid rgba(255,255,255,.2);display:flex;justify-content:space-between;align-items:center;transition:all .2s ease}.final-score-item.current-player{background-color:#ab910033;border-color:#ab910066}.final-score-item:hover{border-color:#ffffff4d;box-shadow:0 4px 8px #00000026}.final-score-player{display:flex;align-items:center;gap:.5rem}.final-score-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.2)}.final-score-name{color:#fff;font-weight:600}.final-score-value{color:#ab9100;font-weight:700;font-size:1.1em}.action-buttons-section{margin-top:2rem;display:flex;justify-content:center;gap:1rem}.action-button{padding:1rem 1.5rem;font-size:1rem;font-weight:600;background-color:#ab9100;color:#fff;border:none;border-radius:8px;cursor:pointer;width:48%;transition:all .2s ease;text-transform:uppercase}.action-button:hover{background-color:#ffed4e;box-shadow:0 8px 16px #0003}.action-button:focus{outline:2px solid #ab9100;outline-offset:2px}.final-map-section{margin-top:2rem}.final-map-title{text-align:center;color:#fff;font-size:1.2rem;font-weight:700;margin:0 0 1rem}.final-map-image{width:100%;height:auto;border-radius:12px;box-shadow:0 4px 8px #00000026}@media (max-width: 768px){.victory-title{font-size:1.2rem}.final-scores-title{font-size:1.1rem}.action-button{width:100%}.final-score-item{padding:.5rem}}.App{min-height:100vh;background:#222c;background-image:url(/assets/bg_in1-cp6eT7il.svg);background-size:cover;background-position:center;background-repeat:no-repeat;color:#fff;align-items:center;justify-content:center;padding:.5rem;position:relative}.App:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-color:#191919fa;z-index:0}.App>*{position:relative;z-index:1}.App-header{width:100%;max-width:500px;display:flex;flex-direction:column;align-items:center;gap:1rem;position:relative;min-height:100vh}.logo-section{display:flex;flex-direction:column;align-items:center;gap:1rem}.logo-container{width:100px;height:100px;border:10px solid #ab9100;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:20px;background:transparent;box-shadow:0 4px 12px #09090966;margin-top:2rem}.logo{width:70px;height:70px;object-fit:contain}.game-title{font-size:2.5rem;font-weight:600;color:#fff;margin:0;letter-spacing:-.02em}.card{background:#333;color:#fff;padding:2.5rem 2rem;border-radius:16px;width:100%;display:flex;flex-direction:column;gap:1rem}.welcome-message{font-size:1.1rem;font-weight:500;color:#fff;margin:0}.guest-user{font-size:1rem;color:#fff;margin:0;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.guest-user button{width:auto}.dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#666}.create-account-link{background:none;border:none;color:#ab9100;font-size:1rem;font-weight:500;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px;transition:color .2s ease}.create-account-link:hover{color:#ffed4e}.create-account-link:focus{outline:2px solid #ab9100;outline-offset:2px;border-radius:.25rem}.online-players{font-size:1rem;color:#fff;margin:0}.online-players strong{font-weight:600}.online-count{color:#ab9100;font-weight:700;font-size:1.1rem}.error-message{color:#f44;font-size:.95rem;margin:0;padding:1rem;background:#ff44441a;border-radius:8px;border:1px solid rgba(255,68,68,.3)}.button-container{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}@media (max-width: 768px){.card{padding:2rem 1.5rem}.game-title{font-size:2rem}.logo-container{width:140px;height:140px}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}.arrow-line path{stroke-dasharray:700;stroke-dashoffset:700;animation:drawLine 1s ease-out forwards}.arrow-line-2 path{stroke-dasharray:700;stroke-dashoffset:700;animation:drawLine 1s ease-out forwards}@keyframes drawLine{to{stroke-dashoffset:0}}.destination-point,.traveller-by{opacity:0;animation:fadeIn .2s ease-in forwards}@keyframes fadeIn{to{opacity:1}}.traveller-image{border-radius:10px;width:200px;height:200px}.skeleton-row{width:100%;height:20px;background:#eee;border-radius:4px;animation:pulse 1.6s ease-in-out infinite}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}
