.preloader{align-items:center;background:linear-gradient(180deg,#0c1a2a,#112240 20%,#133051 40%,#1e3d5e 55%,#2e5a6e 68%,#d97843 80%,#e8603c 88%,#c0392b 95%,#922b21);bottom:0;display:flex;justify-content:center;left:0;overflow:hidden;position:fixed;right:0;top:0;z-index:10000}.preloader-bg{bottom:0;height:35%;left:0;position:absolute;right:0}.preloader-wave{border-radius:50% 50% 0 0;bottom:0;height:100%;left:-5%;position:absolute;width:110%}.wave-1{animation:waveMove 4s ease-in-out infinite;background:linear-gradient(180deg,#0891b240,#065f7326);height:55%}.wave-2{animation:waveMove 5s ease-in-out .5s infinite;background:linear-gradient(180deg,#22d3ee26,#0891b21a);height:45%}.wave-3{animation:waveMove 6s ease-in-out 1s infinite;background:linear-gradient(180deg,#38bdf81a,#0891b20d);height:35%}@keyframes waveMove{0%,to{transform:translateX(0) scaleY(1)}50%{transform:translateX(2%) scaleY(1.08)}}.preloader-content{animation:fadeInUp .7s ease-out;padding:0 20px;position:relative;text-align:center;z-index:1}@keyframes fadeInUp{0%{opacity:0;transform:translateY(25px)}to{opacity:1;transform:translateY(0)}}.preloader-logo-container{display:inline-block;margin-bottom:16px;position:relative}.preloader-icon{animation:walkAnimation 1.2s ease-in-out infinite;display:inline-block;font-size:4rem}@keyframes walkAnimation{0%,to{transform:translateX(-8px) rotate(-4deg)}25%{transform:translateX(0) rotate(0deg) translateY(-6px)}50%{transform:translateX(8px) rotate(4deg)}75%{transform:translateX(0) rotate(0deg) translateY(-6px)}}.preloader-compass{animation:compassSpin 3s linear infinite;font-size:1.6rem;position:absolute;right:-24px;top:-8px}@keyframes compassSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.preloader-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e8603c,#fbbf24 50%,#22d3ee);-webkit-background-clip:text;background-clip:text;font-family:Fredoka One,cursive;font-size:2.8rem;letter-spacing:.5px;margin-bottom:6px}.preloader-tagline{color:#ffffff8c;font-family:Nunito,sans-serif;font-size:.95rem;font-weight:600;letter-spacing:2px;margin-bottom:32px;text-transform:uppercase}.preloader-bar-container{align-items:center;display:flex;gap:10px;margin:0 auto 16px;max-width:280px}.preloader-bar{background:#ffffff1a;border-radius:10px;flex:1 1;height:6px;overflow:hidden}.preloader-bar-fill{background:linear-gradient(90deg,#e8603c,#fbbf24,#22d3ee);border-radius:10px;height:100%;position:relative;transition:width .3s ease}.preloader-bar-fill:after{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#ffffff59,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.preloader-percent{color:#fff9;font-family:Fredoka One,cursive;font-size:.85rem;min-width:36px}.preloader-message{animation:messageFade 1.5s ease-in-out infinite;color:#ffffff73;font-size:.82rem;font-weight:600;margin-bottom:24px;min-height:20px}@keyframes messageFade{0%,to{opacity:.4}50%{opacity:.9}}.preloader-landmarks{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.preloader-landmark-icon{animation:popIn .4s ease-out forwards;display:inline-block;font-size:1.5rem;opacity:0}@keyframes popIn{0%{opacity:0;transform:scale(0) translateY(15px)}60%{transform:scale(1.15) translateY(-3px)}to{opacity:1;transform:scale(1) translateY(0)}}.preloader-landmark-icon:nth-child(odd){animation:popIn .4s ease-out forwards,gentleFloat 3.5s ease-in-out .5s infinite}.preloader-landmark-icon:nth-child(2n){animation:popIn .4s ease-out forwards,gentleFloat 3.5s ease-in-out .5s infinite reverse}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@media (max-width:768px){.preloader-title{font-size:2rem}.preloader-icon{font-size:3rem}.preloader-tagline{font-size:.75rem;margin-bottom:24px}.preloader-landmarks{gap:8px}.preloader-landmark-icon{font-size:1.3rem}.preloader-bar-container{max-width:220px}}@media (max-width:380px){.preloader-title{font-size:1.6rem}.preloader-icon{font-size:2.5rem}}:root{--sunset:#e8603c;--sunset-light:#f2845e;--sunset-glow:#ff9e6d;--ocean:#0891b2;--ocean-deep:#065f73;--ocean-light:#22d3ee;--sky:#38bdf8;--sand:#fbbf24;--sand-light:#fde68a;--bush:#34d399;--bush-deep:#059669;--dark:#0c1a2a;--dark2:#112240;--dark3:#1a3355;--card-bg:#112240e0;--glass:#ffffff12;--glass-border:#ffffff1a;--text:#f0f4f8;--text-dim:#94a3b8;--danger:#f43f5e;--success:#34d399;--legendary:#f472b6;--font-display:"Fredoka One",cursive;--font-body:"Nunito",sans-serif}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-overflow-scrolling:touch;overflow-y:scroll;scroll-behavior:smooth}body{background:#0c1a2a;background:var(--dark);color:#f0f4f8;color:var(--text);font-family:Nunito,sans-serif;font-family:var(--font-body);overflow-x:hidden}#root,body{min-height:100vh;overflow-y:auto}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0c1a2a;background:var(--dark)}::-webkit-scrollbar-thumb{background:#0891b2;background:var(--ocean);border-radius:3px}.app-bg{background:linear-gradient(170deg,#0c1a2a,#112240 25%,#133051 45%,#1a3a5c 60%,#1e3d5e 70%,#24445f 80%,#2e4a5e 90%,#3a4f58);bottom:0;left:0;overflow:hidden;position:fixed;right:0;top:0;z-index:0}.app-bg:before{animation:sunsetPulse 12s ease-in-out infinite;background:radial-gradient(ellipse,#e8603c1f 0,#fbbf240f 40%,#0000 70%);bottom:-200px;content:"";height:700px;position:absolute;right:-100px;width:700px}.app-bg:after{animation:oceanWave 18s ease-in-out infinite;background:radial-gradient(ellipse,#0891b214 0,#22d3ee0a 50%,#0000 70%);bottom:-100px;content:"";height:400px;left:-200px;position:absolute;width:800px}@keyframes sunsetPulse{0%,to{opacity:.8;transform:translate(0) scale(1)}50%{opacity:1;transform:translate(-30px,-20px) scale(1.1)}}@keyframes oceanWave{0%,to{transform:translateX(0) scaleY(1)}50%{transform:translateX(40px) scaleY(1.1)}}.stars{height:100%;width:100%}.star,.stars{position:absolute}.star{animation:twinkle 4s ease-in-out infinite;background:#fff;border-radius:50%;height:2px;width:2px}@keyframes twinkle{0%,to{opacity:.15;transform:scale(1)}50%{opacity:.8;transform:scale(1.3)}}.app-container{display:flex;flex-direction:column;min-height:100vh;position:relative;z-index:1}.header{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#0c1a2aeb;border-bottom:1px solid #ffffff1a;border-bottom:1px solid var(--glass-border);gap:8px;justify-content:space-between;padding:10px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header,.header-logo{align-items:center;display:flex}.header-logo{flex-shrink:0;gap:10px}.header-logo h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e8603c,#fbbf24);background:linear-gradient(135deg,var(--sunset),var(--sand));-webkit-background-clip:text;background-clip:text;font-family:Fredoka One,cursive;font-family:var(--font-display);font-size:1.2rem;white-space:nowrap}.logo-icon{animation:walkStep 1.5s ease-in-out infinite;font-size:1.8rem}@keyframes walkStep{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-4px) rotate(3deg)}}.header-stats{flex-wrap:wrap;gap:10px;justify-content:flex-end}.header-stats,.stat-pill{align-items:center;display:flex}.stat-pill{background:#ffffff12;background:var(--glass);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:50px;font-size:.8rem;font-weight:700;gap:5px;padding:5px 12px;white-space:nowrap}.stat-pill .icon{font-size:1rem}.coins-value{color:#fbbf24;color:var(--sand)}.level-value{color:#22d3ee;color:var(--ocean-light)}.nav-bar{-webkit-overflow-scrolling:touch;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#0c1a2ad9;border-bottom:1px solid #ffffff1a;border-bottom:1px solid var(--glass-border);display:flex;gap:6px;justify-content:center;overflow-x:auto;padding:10px 16px;scrollbar-width:none}.nav-bar::-webkit-scrollbar{display:none}.nav-btn{align-items:center;background:#ffffff12;background:var(--glass);border:2px solid #ffffff1a;border:2px solid var(--glass-border);border-radius:50px;color:#94a3b8;color:var(--text-dim);cursor:pointer;display:flex;flex-shrink:0;font-family:Nunito,sans-serif;font-family:var(--font-body);font-size:.82rem;font-weight:700;gap:5px;padding:8px 16px;transition:all .25s ease;white-space:nowrap}.nav-btn:hover{border-color:#0891b2;border-color:var(--ocean);color:#f0f4f8;color:var(--text)}.nav-btn.active{background:linear-gradient(135deg,#e8603c,#f2845e);background:linear-gradient(135deg,var(--sunset),var(--sunset-light));border-color:#0000;box-shadow:0 4px 16px #e8603c59;color:#fff}.main-content{flex:1 1;margin:0 auto;max-width:1400px;overflow-y:visible;padding:20px;width:100%}.glass-card{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#112240e0;background:var(--card-bg);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:16px;padding:20px;transition:all .25s ease}.glass-card:hover{border-color:#0891b240;box-shadow:0 8px 30px #0003}.landmarks-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}.landmark-card{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#112240e0;background:var(--card-bg);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:16px;cursor:pointer;overflow:hidden;padding:20px;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.landmark-card:before{background:linear-gradient(90deg,#e8603c,#0891b2);background:linear-gradient(90deg,var(--sunset),var(--ocean));content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.landmark-card:hover:before{opacity:1}.landmark-card:hover{border-color:#e8603c40;box-shadow:0 12px 40px #e8603c26;transform:translateY(-4px)}.landmark-card.visited{border-color:#34d399;border-color:var(--bush);box-shadow:0 0 16px #34d3991a}.landmark-card.visited:before{background:linear-gradient(90deg,#34d399,#22d3ee);background:linear-gradient(90deg,var(--bush),var(--ocean-light));opacity:1}.landmark-emoji{animation:float 4s ease-in-out infinite;display:inline-block;font-size:2.6rem;margin-bottom:10px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.landmark-name{color:#f0f4f8;color:var(--text);font-family:Fredoka One,cursive;font-family:var(--font-display);font-size:1.05rem;margin-bottom:6px}.landmark-desc{color:#94a3b8;color:var(--text-dim);font-size:.82rem;line-height:1.5;margin-bottom:10px}.landmark-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start}.difficulty-badge{border-radius:50px;font-size:.7rem;font-weight:800;letter-spacing:.5px;padding:3px 10px;text-transform:uppercase}.difficulty-easy{background:#34d39926;color:#34d399;color:var(--bush)}.difficulty-medium{background:#fbbf2426;color:#fbbf24;color:var(--sand)}.difficulty-hard{background:#e8603c26;color:#e8603c;color:var(--sunset)}.difficulty-legendary{background:#f472b626;color:#f472b6;color:var(--legendary)}.points-badge{color:#fbbf24;color:var(--sand);font-size:.85rem;font-weight:800}.points-badge,.visited-badge{align-items:center;display:flex;gap:4px}.visited-badge{background:#34d39926;border-radius:50px;color:#34d399;color:var(--bush);font-size:.75rem;font-weight:700;padding:3px 10px}.modal-overlay{align-items:center;animation:fadeIn .25s ease;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#000000a6;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:16px;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .35s cubic-bezier(.175,.885,.32,1.275);background:linear-gradient(145deg,#112240,#1a3355);background:linear-gradient(145deg,var(--dark2),var(--dark3));border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:24px;max-height:90vh;max-width:460px;overflow:visible;overflow-y:auto;padding:32px 24px;position:relative;text-align:center;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content:before{background:linear-gradient(90deg,#e8603c,#fbbf24,#0891b2);background:linear-gradient(90deg,var(--sunset),var(--sand),var(--ocean));border-radius:24px 24px 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.modal-emoji{animation:celebrateBounce .8s ease-in-out;display:inline-block;font-size:4rem;margin-bottom:12px}@keyframes celebrateBounce{0%{transform:scale(0) rotate(-15deg)}50%{transform:scale(1.2) rotate(5deg)}70%{transform:scale(.95) rotate(-3deg)}to{transform:scale(1) rotate(0deg)}}.modal-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e8603c,#fbbf24);background:linear-gradient(135deg,var(--sunset),var(--sand));-webkit-background-clip:text;background-clip:text;font-family:Fredoka One,cursive;font-family:var(--font-display);font-size:1.5rem;margin-bottom:6px}.modal-subtitle{color:#94a3b8;color:var(--text-dim);font-size:.88rem;line-height:1.5;margin-bottom:16px}.hint-box{background:#fbbf2414;border:1px dashed #fbbf24;border:1px dashed var(--sand);border-radius:12px;color:#fde68a;color:var(--sand-light);font-size:.85rem;font-style:italic}.fun-fact-box,.hint-box{margin-bottom:14px;padding:10px 14px}.fun-fact-box{background:#0891b214;border:1px solid #0891b233;border-radius:12px;color:#22d3ee;color:var(--ocean-light);font-size:.82rem;text-align:left}.fun-fact-box strong{display:block;font-size:.7rem;letter-spacing:1px;margin-bottom:3px;text-transform:uppercase}.btn{align-items:center;border:none;border-radius:50px;cursor:pointer;display:inline-flex;font-family:Nunito,sans-serif;font-family:var(--font-body);font-size:.95rem;font-weight:800;gap:6px;padding:12px 28px;transition:all .25s ease}.btn-primary{background:linear-gradient(135deg,#e8603c,#f2845e);background:linear-gradient(135deg,var(--sunset),var(--sunset-light));box-shadow:0 4px 16px #e8603c59;color:#fff}.btn-primary:hover{box-shadow:0 6px 24px #e8603c73;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#ffffff12;background:var(--glass);border:2px solid #ffffff1a;border:2px solid var(--glass-border);color:#94a3b8;color:var(--text-dim)}.btn-secondary:hover{border-color:#0891b2;border-color:var(--ocean);color:#f0f4f8;color:var(--text)}.btn-success{background:linear-gradient(135deg,#34d399,#0891b2);background:linear-gradient(135deg,var(--bush),var(--ocean));box-shadow:0 4px 16px #34d3994d;color:#fff}.btn-success:hover{box-shadow:0 6px 24px #34d39966;transform:translateY(-2px)}.btn-block{justify-content:center;width:100%}.modal-buttons{display:flex;gap:10px;margin-top:20px}.modal-close{align-items:center;background:#ffffff12;background:var(--glass);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:50%;color:#94a3b8;color:var(--text-dim);cursor:pointer;display:flex;font-size:1.1rem;height:32px;justify-content:center;position:absolute;right:12px;top:12px;transition:all .25s;width:32px;z-index:2}.modal-close:hover{background:#f43f5e;background:var(--danger);border-color:#0000;color:#fff}.reward-overlay{align-items:center;animation:fadeIn .3s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:2000}.reward-content{animation:rewardPop .7s cubic-bezier(.175,.885,.32,1.275);max-width:400px;text-align:center;width:100%}@keyframes rewardPop{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.reward-badge{animation:spinGlow 2.5s ease-in-out infinite;display:inline-block;filter:drop-shadow(0 0 24px rgba(251,191,36,.4));font-size:6rem}@keyframes spinGlow{0%,to{filter:drop-shadow(0 0 24px rgba(251,191,36,.4));transform:rotateY(0deg) scale(1)}50%{filter:drop-shadow(0 0 40px rgba(251,191,36,.7));transform:rotateY(180deg) scale(1.08)}}.reward-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fbbf24,#e8603c);background:linear-gradient(135deg,var(--sand),var(--sunset));-webkit-background-clip:text;background-clip:text;font-family:Fredoka One,cursive;font-family:var(--font-display);font-size:2rem;margin:12px 0 6px}.reward-subtitle{color:#94a3b8;color:var(--text-dim);font-size:1rem;margin-bottom:6px}.reward-coins{align-items:center;color:#fbbf24;color:var(--sand);display:flex;font-size:1.6rem;font-weight:900;gap:8px;justify-content:center;margin:12px 0}.coin-animation{animation:coinSpin 1s ease-in-out infinite;display:inline-block}@keyframes coinSpin{0%,to{transform:rotateY(0)}50%{transform:rotateY(180deg)}}.reward-new-badge{background:linear-gradient(135deg,#fbbf241a,#e8603c1a);border:1px solid #fbbf2440;border-radius:14px;margin:12px 0;padding:14px}.reward-new-badge h4{color:#fbbf24;color:var(--sand);font-family:Fredoka One,cursive;font-family:var(--font-display);margin-bottom:4px}.progress-container{margin-bottom:20px}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.progress-label{color:#94a3b8;color:var(--text-dim);font-size:.85rem;font-weight:700}.progress-value{color:#22d3ee;color:var(--ocean-light);font-weight:800}.progress-bar{background:#ffffff12;background:var(--glass);height:10px;overflow:hidden}.progress-bar,.progress-fill{border-radius:20px;position:relative}.progress-fill{background:linear-gradient(90deg,#e8603c,#fbbf24,#0891b2);background:linear-gradient(90deg,var(--sunset),var(--sand),var(--ocean));height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.progress-fill:after{animation:shimmer 2.5s infinite;background:linear-gradient(90deg,#0000,#ffffff40 50%,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.map-container{border:2px solid #ffffff1a;border:2px solid var(--glass-border);border-radius:16px;height:500px;margin-bottom:20px;overflow:hidden}.map-container .leaflet-container{background:#0c1a2a;background:var(--dark);height:100%}.badges-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.badge-card{background:#ffffff12;background:var(--glass);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:14px;padding:16px 10px;text-align:center;transition:all .25s ease}.badge-card.earned{border-color:#fbbf24;border-color:var(--sand);box-shadow:0 0 16px #fbbf241f}.badge-card.locked{filter:grayscale(100%);opacity:.35}.badge-icon{display:inline-block;font-size:2.2rem;margin-bottom:6px}.badge-card.earned .badge-icon{animation:float 4s ease-in-out infinite}.badge-name{color:#f0f4f8;color:var(--text);font-family:Fredoka One,cursive;font-family:var(--font-display);font-size:.72rem;margin-bottom:3px}.badge-points{color:#fbbf24;color:var(--sand);font-size:.7rem;font-weight:700}.leaderboard-list{display:flex;flex-direction:column;gap:8px}.leaderboard-item{align-items:center;background:#ffffff12;background:var(--glass);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:14px;display:flex;gap:12px;padding:12px 16px;transition:all .25s ease}.leaderboard-item:hover{border-color:#0891b2;border-color:var(--ocean);transform:translateX(3px)}.leaderboard-item.top-1{background:linear-gradient(135deg,#fbbf241f,#e8603c14);border-color:#fbbf2440}.leaderboard-item.top-2{background:linear-gradient(135deg,#c0c0c014,#c8c8c80a);border-color:#c0c0c033}.leaderboard-item.top-3{background:linear-gradient(135deg,#cd7f3214,#c896500a);border-color:#cd7f3233}.rank{font-family:Fredoka One,cursive;font-family:var(--font-display);font-size:1.2rem;min-width:36px;text-align:center}.leaderboard-avatar{font-size:1.8rem}.leaderboard-info{flex:1 1;min-width:0}.leaderboard-name{font-size:.9rem;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leaderboard-title{color:#94a3b8;color:var(--text-dim);font-size:.75rem}.leaderboard-score{flex-shrink:0;text-align:right}.leaderboard-coins{color:#fbbf24;color:var(--sand);font-size:1rem;font-weight:800}.leaderboard-level{color:#22d3ee;color:var(--ocean-light);font-size:.75rem}.chat-container{display:flex;flex-direction:column;height:calc(100vh - 240px);max-height:650px;min-height:400px}.chat-messages{-webkit-overflow-scrolling:touch;display:flex;flex:1 1;flex-direction:column;gap:10px;overflow-y:auto;padding:14px}.chat-message{align-items:flex-start;animation:slideIn .25s ease;display:flex;gap:10px}@keyframes slideIn{0%{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}.chat-avatar{font-size:1.6rem;min-width:36px;text-align:center}.chat-bubble{background:#ffffff12;background:var(--glass);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:14px;border-top-left-radius:4px;max-width:80%;padding:8px 14px}.chat-username{color:#e8603c;color:var(--sunset);font-size:.75rem;font-weight:800;margin-bottom:2px}.chat-text{color:#f0f4f8;color:var(--text);font-size:.85rem;line-height:1.4;word-break:break-word}.chat-time{color:#94a3b8;color:var(--text-dim);font-size:.65rem;margin-top:3px}.chat-input-area{border-top:1px solid #ffffff1a;border-top:1px solid var(--glass-border);display:flex;gap:10px;padding:12px}.chat-input{background:#ffffff12;background:var(--glass);border:2px solid #ffffff1a;border:2px solid var(--glass-border);border-radius:50px;color:#f0f4f8;color:var(--text);flex:1 1;font-family:Nunito,sans-serif;font-family:var(--font-body);font-size:.85rem;min-width:0;outline:none;padding:10px 18px;transition:border-color .25s}.chat-input:focus{border-color:#0891b2;border-color:var(--ocean)}.chat-input::placeholder{color:#94a3b8;color:var(--text-dim)}.login-screen{align-items:center;display:flex;justify-content:center;min-height:100vh;overflow-y:auto;padding:16px;position:relative;z-index:1}.login-card{animation:slideUp .5s cubic-bezier(.175,.885,.32,1.275);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#112240e0;background:var(--card-bg);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:28px;max-width:440px;padding:36px 28px;text-align:center;width:100%}.login-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e8603c,#fbbf24,#0891b2);background:linear-gradient(135deg,var(--sunset),var(--sand),var(--ocean));-webkit-background-clip:text;background-clip:text;font-family:Fredoka One,cursive;font-family:var(--font-display);font-size:2.4rem;line-height:1.2;margin-bottom:6px}.login-subtitle{color:#94a3b8;color:var(--text-dim);font-size:.9rem;line-height:1.6;margin-bottom:28px}.login-emoji{animation:float 4s ease-in-out infinite;display:block;font-size:4rem;margin-bottom:16px}.avatar-picker{flex-wrap:wrap;gap:8px;margin-bottom:20px}.avatar-option,.avatar-picker{display:flex;justify-content:center}.avatar-option{align-items:center;background:#ffffff12;background:var(--glass);border:2px solid #ffffff1a;border:2px solid var(--glass-border);border-radius:50%;cursor:pointer;font-size:1.5rem;height:44px;transition:all .25s ease;width:44px}.avatar-option:hover{transform:scale(1.12)}.avatar-option.selected,.avatar-option:hover{border-color:#e8603c;border-color:var(--sunset)}.avatar-option.selected{background:#e8603c33;box-shadow:0 0 16px #e8603c40;transform:scale(1.08)}.login-input{background:#ffffff12;background:var(--glass);border:2px solid #ffffff1a;border:2px solid var(--glass-border);border-radius:14px;color:#f0f4f8;color:var(--text);font-family:Nunito,sans-serif;font-family:var(--font-body);font-size:1rem;font-weight:600;margin-bottom:16px;outline:none;padding:14px 20px;text-align:left;transition:border-color .25s;width:100%}.login-input:focus{border-color:#0891b2;border-color:var(--ocean)}.login-input::placeholder{color:#94a3b8;color:var(--text-dim)}.section-title{color:#f0f4f8;color:var(--text);font-family:Fredoka One,cursive;font-family:var(--font-display);font-size:1.6rem;margin-bottom:3px}.section-subtitle{color:#94a3b8;color:var(--text-dim);font-size:.85rem}.filter-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.filter-chip{background:#ffffff12;background:var(--glass);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:50px;color:#94a3b8;color:var(--text-dim);cursor:pointer;font-family:Nunito,sans-serif;font-family:var(--font-body);font-size:.75rem;font-weight:700;padding:5px 14px;transition:all .25s}.filter-chip.active,.filter-chip:hover{background:#0891b226;border-color:#0891b2;border-color:var(--ocean);color:#22d3ee;color:var(--ocean-light)}.travelers-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.traveler-card{background:#ffffff12;background:var(--glass);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:14px;padding:16px;text-align:center;transition:all .25s ease}.traveler-card:hover{border-color:#0891b2;border-color:var(--ocean);transform:translateY(-3px)}.traveler-avatar{font-size:2.5rem;margin-bottom:6px}.traveler-name{font-size:.9rem;font-weight:800;margin-bottom:2px}.traveler-title{color:#22d3ee;color:var(--ocean-light);font-size:.75rem;margin-bottom:6px}.traveler-stats{color:#94a3b8;color:var(--text-dim);font-size:.7rem}.level-up-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000d1;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:3000}.level-up-content{animation:levelUpPop .8s cubic-bezier(.175,.885,.32,1.275);text-align:center}@keyframes levelUpPop{0%{opacity:0;transform:scale(0) rotate(-180deg)}60%{transform:scale(1.2) rotate(8deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}.level-up-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fbbf24,#e8603c);background:linear-gradient(135deg,var(--sand),var(--sunset));-webkit-background-clip:text;background-clip:text;font-size:7rem;line-height:1}.level-up-number,.level-up-text{font-family:Fredoka One,cursive;font-family:var(--font-display)}.level-up-text{color:#fbbf24;color:var(--sand);font-size:2.5rem;text-shadow:0 0 24px #fbbf2466}.particle{animation:particleFly 1.5s ease-out forwards;pointer-events:none;position:fixed;z-index:5000}@keyframes particleFly{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-180px) scale(.3)}}.streak-pill{background:linear-gradient(135deg,#e8603c33,#fbbf2433)!important;border-color:#e8603c4d!important}.streak-fire{animation:fireFlicker .5s ease-in-out infinite alternate}.streak-value{color:#e8603c;color:var(--sunset);font-weight:900}@keyframes fireFlicker{0%{transform:scale(1) translateY(0)}to{transform:scale(1.15) translateY(-1px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-40px)}to{opacity:1;transform:translateY(0)}}.frame-ocean{border-color:#22d3ee!important;border-color:var(--ocean-light)!important;box-shadow:0 0 8px #22d3ee80,inset 0 0 4px #22d3ee33!important}.frame-sunset{border-color:#e8603c!important;border-color:var(--sunset)!important;box-shadow:0 0 8px #e8603c80,inset 0 0 4px #e8603c33!important}.frame-gold{animation:goldPulse 3s ease-in-out infinite;border-color:#fbbf24!important;border-color:var(--sand)!important;box-shadow:0 0 10px #fbbf2480,inset 0 0 5px #fbbf2433!important}.frame-legendary{animation:legendaryGlow 2s ease-in-out infinite alternate;border-color:#f472b6!important;border-color:var(--legendary)!important;box-shadow:0 0 12px #f472b680,0 0 24px #fbbf244d!important}@keyframes goldPulse{0%,to{box-shadow:0 0 8px #fbbf2466}50%{box-shadow:0 0 16px #fbbf24b3}}@keyframes legendaryGlow{0%{box-shadow:0 0 8px #f472b680,0 0 16px #fbbf2433}to{box-shadow:0 0 16px #f472b6cc,0 0 32px #fbbf2466}}.flair-ocean{color:#22d3ee!important;color:var(--ocean-light)!important}.flair-sunset{color:#e8603c!important;color:var(--sunset)!important}.flair-gold{color:#fbbf24!important;color:var(--sand)!important}.flair-rainbow{-webkit-text-fill-color:#0000;animation:rainbowShift 3s linear infinite;background:linear-gradient(90deg,#e8603c,#fbbf24,#34d399,#22d3ee,#38bdf8);background:linear-gradient(90deg,var(--sunset),var(--sand),var(--bush),var(--ocean-light),var(--sky));-webkit-background-clip:text;background-clip:text;background-size:200% 100%}@keyframes rainbowShift{0%{background-position:0 50%}to{background-position:200% 50%}}.logout-btn{background:#ffffff12;background:var(--glass);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:50px;color:#94a3b8;color:var(--text-dim);cursor:pointer;flex-shrink:0;font-size:.7rem;font-weight:700;padding:5px 10px;transition:all .25s}.logout-btn:hover{background:#f43f5e26;border-color:#f43f5e;border-color:var(--danger);color:#f43f5e;color:var(--danger)}.user-position-marker div{animation:userPulse 2s ease-in-out infinite!important}@keyframes userPulse{0%,to{box-shadow:0 0 8px #22d3ee66}50%{box-shadow:0 0 20px #22d3eecc}}@media (max-width:1024px){.landmarks-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}@media (max-width:768px){.header{gap:6px;padding:8px 12px}.header-logo{gap:6px}.header-logo h1{font-size:1rem}.logo-icon{font-size:1.4rem}.header-stats{gap:6px}.stat-pill{font-size:.7rem;gap:3px;padding:4px 8px}.stat-pill .icon{font-size:.85rem}.nav-bar{gap:5px;justify-content:flex-start;padding:8px 10px}.nav-btn{font-size:.75rem;gap:4px;padding:6px 12px}.main-content{padding:12px}.section-title{font-size:1.3rem}.section-subtitle{font-size:.8rem}.landmarks-grid{gap:12px;grid-template-columns:1fr}.landmark-card{padding:16px}.landmark-emoji{font-size:2.2rem}.landmark-name{font-size:.95rem}.landmark-desc{font-size:.78rem}.login-card{border-radius:22px;padding:28px 20px}.login-title{font-size:1.8rem}.login-emoji{font-size:3rem}.login-subtitle{font-size:.82rem;margin-bottom:20px}.login-input{font-size:.9rem;padding:12px 16px}.avatar-option{font-size:1.3rem;height:38px;width:38px}.modal-overlay{align-items:flex-start;padding:40px 12px 12px}.modal-content{border-radius:20px;max-height:85vh;padding:24px 18px}.modal-emoji{font-size:3rem}.modal-title{font-size:1.25rem}.modal-buttons{flex-direction:column;gap:8px}.modal-buttons .btn{justify-content:center;width:100%}.reward-content{padding:0 12px}.reward-badge{font-size:4rem}.reward-title{font-size:1.5rem}.reward-coins{font-size:1.3rem}.level-up-number{font-size:4.5rem}.level-up-text{font-size:1.8rem}.map-container{border-radius:14px;height:320px}.badges-grid{gap:8px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.badge-card{padding:12px 6px}.badge-icon{font-size:1.8rem}.badge-name{font-size:.65rem}.chat-container{height:calc(100vh - 200px);min-height:300px}.chat-bubble{max-width:85%;padding:7px 12px}.chat-input-area{gap:8px;padding:10px}.chat-input{font-size:.82rem;padding:8px 14px}.leaderboard-item{gap:10px;padding:10px 12px}.rank{font-size:1rem;min-width:30px}.leaderboard-avatar{font-size:1.5rem}.leaderboard-name{font-size:.82rem}.leaderboard-coins{font-size:.9rem}.travelers-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.traveler-avatar{font-size:2rem}.traveler-name{font-size:.82rem}.filter-chips{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}.filter-chips::-webkit-scrollbar{display:none}.filter-chip{flex-shrink:0}.progress-bar{height:8px}.glass-card{border-radius:14px;padding:16px}}.tab-enter{animation:tabFadeIn .35s ease-out}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.section-header{margin-bottom:20px;padding-bottom:14px;position:relative}.section-header:after{background:linear-gradient(90deg,#e8603c,#fbbf24);background:linear-gradient(90deg,var(--sunset),var(--sand));border-radius:3px;bottom:0;content:"";height:3px;left:0;position:absolute;width:60px}.section-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f0f4f8 60%,#f2845e);background:linear-gradient(135deg,var(--text) 60%,var(--sunset-light));-webkit-background-clip:text;background-clip:text}.nav-btn{overflow:hidden;position:relative}.nav-btn:after{background:#22d3ee;background:var(--ocean-light);bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:all .3s ease;width:0}.nav-btn:hover:after{width:60%}.nav-btn.active:after{background:#fff;box-shadow:0 0 8px #ffffff4d;width:80%}.landmark-card{background:linear-gradient(145deg,#112240e0,#112240bf);background:linear-gradient(145deg,var(--card-bg),#112240bf);position:relative}.landmark-card:after{background:linear-gradient(90deg,#0000,#0891b2,#0000);background:linear-gradient(90deg,#0000,var(--ocean),#0000);bottom:0;content:"";height:2px;left:0;opacity:0;position:absolute;right:0;transition:opacity .3s}.landmark-card:hover:after{opacity:.5}.landmark-card.visited{background:linear-gradient(145deg,#112240e0,#0596690f)}.stat-card-premium{background:linear-gradient(145deg,#112240e0,#112240b3);background:linear-gradient(145deg,var(--card-bg),#112240b3);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:16px;overflow:hidden;padding:16px;position:relative;text-align:center}.stat-card-premium:before{background:linear-gradient(90deg,#e8603c,#fbbf24,#0891b2);background:linear-gradient(90deg,var(--sunset),var(--sand),var(--ocean));content:"";height:2px;left:0;position:absolute;right:0;top:0}.challenge-card{overflow:hidden;position:relative;transition:all .25s ease}.challenge-card:hover{border-color:#0891b240;transform:translateX(3px)}.challenge-card.completed{background:linear-gradient(145deg,#34d3990f,#112240e0);background:linear-gradient(145deg,#34d3990f,var(--card-bg))}.shop-item-card{overflow:hidden;position:relative;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.shop-item-card:hover{box-shadow:0 8px 24px #00000040;transform:translateY(-4px)}.shop-item-card:before{background:linear-gradient(90deg,#0000,#fbbf24,#0000);background:linear-gradient(90deg,#0000,var(--sand),#0000);content:"";height:2px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.shop-item-card:hover:before{opacity:1}.rarity-common{border-color:#94a3b833}.rarity-rare{border-color:#22d3ee40}.rarity-epic{border-color:#e8603c40}.rarity-legendary{border-color:#fbbf244d;box-shadow:0 0 16px #fbbf2414}.balance-display{align-items:center;background:linear-gradient(135deg,#fbbf241a,#e8603c1a);border:1px solid #fbbf2433;border-radius:16px;display:inline-flex;gap:12px;overflow:hidden;padding:14px 24px;position:relative}.balance-display:after{animation:balanceShimmer 4s ease-in-out infinite;background:linear-gradient(90deg,#0000,#fbbf240f,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes balanceShimmer{0%{left:-100%}50%{left:100%}to{left:100%}}.timer-pill{align-items:center;background:linear-gradient(135deg,#0891b214,#38bdf814);border:1px solid #0891b233;border-radius:50px;color:#94a3b8;color:var(--text-dim);display:inline-flex;font-size:.82rem;font-weight:700;gap:8px;padding:8px 18px}.chest-card{overflow:hidden;position:relative}.chest-card.available{background:linear-gradient(145deg,#fbbf240f,#e8603c0f);border-color:#fbbf244d}.chest-card.available:after{animation:chestGlow 3s ease-in-out infinite;background:radial-gradient(ellipse,#fbbf240f 0,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes chestGlow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.gps-indicator{align-items:center;border-radius:14px;display:flex;gap:10px;justify-content:center;margin-bottom:14px;overflow:hidden;padding:12px 16px;position:relative}.gps-indicator.close{background:#34d39914;border:1px solid #34d39940}.gps-indicator.medium{background:#fbbf2414;border:1px solid #fbbf2440}.gps-indicator.far{background:#e8603c14;border:1px solid #e8603c40}@keyframes radarPulse{0%{opacity:1;transform:scale(.8)}to{opacity:0;transform:scale(2)}}.radar-pulse{display:inline-block;position:relative}.radar-pulse:after{animation:radarPulse 1.5s ease-out infinite;border:2px solid #22d3ee;border:2px solid var(--ocean-light);border-radius:50%;content:"";height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}.chat-bubble{position:relative}.chat-message:hover .chat-bubble{border-color:#0891b233}.chat-suggestion{background:#ffffff12;background:var(--glass);border:1px solid #ffffff1a;border:1px solid var(--glass-border);border-radius:50px;color:#94a3b8;color:var(--text-dim);cursor:pointer;font-family:Nunito,sans-serif;font-family:var(--font-body);font-size:.75rem;font-weight:600;padding:6px 14px;transition:all .25s}.chat-suggestion:hover{background:#0891b21a;border-color:#0891b2;border-color:var(--ocean);color:#22d3ee;color:var(--ocean-light);transform:translateY(-1px)}.leaderboard-item.top-1{overflow:hidden;position:relative}.leaderboard-item.top-1:after{background:linear-gradient(90deg,#0000,#fbbf24,#0000);background:linear-gradient(90deg,#0000,var(--sand),#0000);content:"";height:2px;left:0;position:absolute;right:0;top:0}.filter-chip{overflow:hidden;position:relative}.filter-chip.active{box-shadow:0 2px 8px #0891b233}.traveler-card{overflow:hidden;position:relative}.traveler-card:before{background:linear-gradient(90deg,#0891b2,#22d3ee);background:linear-gradient(90deg,var(--ocean),var(--ocean-light));content:"";height:2px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.traveler-card:hover:before{opacity:1}.badge-card.earned{overflow:hidden;position:relative}.badge-card.earned:after{animation:badgeShine 5s ease-in-out infinite;background:radial-gradient(ellipse,#fbbf240a 0,#0000 60%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes badgeShine{0%,to{opacity:.3}50%{opacity:.8}}.btn:active{transform:scale(.97)}.btn-primary:active{box-shadow:0 2px 8px #e8603c33}.header{position:relative}.header:after{background:linear-gradient(90deg,#0000,#e8603c33,#0891b233,#0000);bottom:-1px;content:"";height:1px;left:0;position:absolute;right:0}.skeleton{animation:skeletonLoad 1.5s ease-in-out infinite;background:linear-gradient(90deg,#ffffff12 25%,#ffffff0d 50%,#ffffff12 75%);background:linear-gradient(90deg,var(--glass) 25%,#ffffff0d 50%,var(--glass) 75%);background-size:200% 100%;border-radius:8px}@keyframes skeletonLoad{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{color:#94a3b8;color:var(--text-dim);padding:60px 20px;text-align:center}.empty-state-icon{animation:float 4s ease-in-out infinite;display:block;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2));font-size:3.5rem;margin-bottom:16px}.notification-dot{animation:notifPulse 2s ease-in-out infinite;background:#e8603c;background:var(--sunset);border-radius:50%;height:8px;position:absolute;right:2px;top:2px;width:8px}@keyframes notifPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}.gradient-text-animated{-webkit-text-fill-color:#0000;animation:gradientFlow 6s linear infinite;background:linear-gradient(90deg,#e8603c,#fbbf24,#22d3ee,#34d399,#e8603c);background:linear-gradient(90deg,var(--sunset),var(--sand),var(--ocean-light),var(--bush),var(--sunset));-webkit-background-clip:text;background-clip:text;background-size:300% 100%}@keyframes gradientFlow{0%{background-position:0 50%}to{background-position:300% 50%}}.share-cta{overflow:hidden;position:relative}.share-cta:before{background:linear-gradient(90deg,#34d399,#22d3ee);background:linear-gradient(90deg,var(--bush),var(--ocean-light));content:"";height:2px;left:0;position:absolute;right:0;top:0}.reward-overlay:before{animation:rewardBurst 2s ease-out;background:radial-gradient(circle,#fbbf2414 0,#0000 70%);content:"";height:600px;left:50%;pointer-events:none;position:fixed;top:50%;transform:translate(-50%,-50%);width:600px}@keyframes rewardBurst{0%{opacity:1;transform:translate(-50%,-50%) scale(0)}to{opacity:0;transform:translate(-50%,-50%) scale(1.5)}}.level-up-overlay:before{animation:ringExpand 1.5s ease-out infinite;border:2px solid #fbbf2433;border-radius:50%;content:"";height:400px;left:50%;pointer-events:none;position:fixed;top:50%;transform:translate(-50%,-50%);width:400px}@keyframes ringExpand{0%{opacity:1;transform:translate(-50%,-50%) scale(.5)}to{opacity:0;transform:translate(-50%,-50%) scale(2)}}select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%2394a3b8' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:30px!important}select option{background:#112240;background:var(--dark2);color:#f0f4f8;color:var(--text)}.custom-popup .leaflet-popup-content-wrapper{background:#0000;box-shadow:none;padding:0}.custom-popup .leaflet-popup-tip{background:#112240}.custom-marker{transition:transform .2s}.custom-marker:hover{transform:scale(1.2)!important}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (max-width:380px){.header-logo h1{font-size:.9rem}.stat-pill{font-size:.65rem;padding:3px 6px}.login-title{font-size:1.5rem}.landmarks-grid{gap:10px}.badges-grid{grid-template-columns:repeat(3,1fr)}}
/*# sourceMappingURL=main.05f486ab.css.map*/