.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;position:relative;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-header{margin-bottom:20px}.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)}}@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}}@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.45d6a577.css.map*/