*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w: 340px;--header-h: 0px;--radius: 10px;--shadow: 0 2px 12px rgba(0,0,0,.15);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}html,body,#root{height:100%;overflow:hidden}.app-layout{display:flex;height:100vh;position:relative}.map-container{flex:1;position:relative;overflow:hidden}.map-canvas{width:100%;height:100%}.map-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#fff9;font-size:1rem;color:#333;gap:8px;pointer-events:none}.map-spinner{display:inline-block;width:18px;height:18px;border:3px solid #ccc;border-top-color:#3182ce;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.map-toast{position:absolute;bottom:70px;left:50%;transform:translate(-50%);padding:8px 16px;border-radius:20px;font-size:.875rem;font-weight:500;white-space:nowrap;pointer-events:none;animation:fadeInUp .2s ease;box-shadow:var(--shadow)}.map-toast--info{background:#2d3748;color:#fff}.map-toast--warn{background:#d69e2e;color:#fff}.map-toast--error{background:#e53e3e;color:#fff}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.map-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:#0000008c;color:#fff;padding:6px 14px;border-radius:20px;font-size:.8rem;pointer-events:none}.map-marker{width:38px;height:38px;border-radius:50%;background:var(--c, #666);border:3px solid #fff;box-shadow:0 2px 8px #00000059;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;cursor:pointer;transition:transform .15s}.map-marker:hover{transform:scale(1.15)}.map-marker__img{width:100%;height:100%;border-radius:50%;object-fit:cover}.map-marker--gold{border-color:#d4af37;box-shadow:0 2px 8px #b48c0073}.map-marker--silver{border-color:#a8b2bb;box-shadow:0 2px 8px #6b7d8d66}.sidebar{width:var(--sidebar-w);flex-shrink:0;display:flex;flex-direction:column;background:#f7fafc;border-left:1px solid #E2E8F0;overflow-y:auto}.sidebar__header{background:linear-gradient(135deg,#2d3748,#1a202c);color:#fff;padding:16px 16px 12px;flex-shrink:0}.sidebar__title{font-size:1.15rem;font-weight:700}.sidebar__sub{font-size:.8rem;opacity:.7;margin-top:2px;margin-bottom:10px}.sidebar__progress{background:#fff3;border-radius:4px;height:6px;overflow:hidden}.sidebar__progress-bar{height:100%;background:#68d391;transition:width .5s ease;border-radius:4px}.sidebar__progress-label{font-size:.72rem;opacity:.6;margin-top:4px}.sidebar__friends{padding:8px;display:flex;flex-direction:column;gap:6px}.user-card{display:flex;align-items:flex-start;gap:10px;background:#fff;border-radius:var(--radius);padding:10px 12px;box-shadow:0 1px 3px #00000014;border:2px solid transparent;transition:border-color .2s}.user-card--me{border-color:#bee3f8}.user-card__avatar{flex-shrink:0;position:relative;width:44px;height:44px;border-radius:50%;border:3px solid;overflow:hidden}.user-card__avatar img{width:100%;height:100%;object-fit:cover}.user-card__avatar span{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#fff;font-weight:700;font-size:14px}.user-card__you-badge{position:absolute;bottom:-2px;right:-2px;background:#3182ce;color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:4px}.user-card__info{flex:1;min-width:0}.user-card__name{font-weight:600;font-size:.9rem;margin-bottom:5px}.user-card__pins{display:flex;flex-direction:column;gap:4px}.pin-slot{display:flex;align-items:center;gap:6px;font-size:.78rem;border-radius:6px;padding:4px 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.pin-slot--empty{color:#a0aec0;background:#f7fafc;border:1px dashed #CBD5E0}.pin-slot__dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;opacity:.5}.pin-slot--filled{background:#ebf8ff;border:1px solid #BEE3F8;cursor:pointer;color:#2d3748;border-left:3px solid var(--pin-color, #3182CE)}.pin-slot--filled:hover{background:#bee3f8}.pin-slot__flag{font-size:1rem}.pin-slot__place{flex:1;overflow:hidden;text-overflow:ellipsis;font-weight:500}.pin-slot__remove{flex-shrink:0;color:#e53e3e;font-size:10px;font-weight:700;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fed7d7;cursor:pointer;opacity:.7}.pin-slot__remove:hover{opacity:1}.pin-slot--filled.pin-slot--gold{border:2px solid #D4AF37;border-left:3px solid #9B7A1C;background:#fffef0;box-shadow:0 1px 6px #b48c0033}.pin-slot--filled.pin-slot--gold:hover{background:#fff9d6}.pin-slot--filled.pin-slot--silver{border:2px solid #A8B2BB;border-left:3px solid #6B7D8D;background:#f7f8fa;box-shadow:0 1px 6px #6b7d8d2e}.pin-slot--filled.pin-slot--silver:hover{background:#edf1f4}.pin-slot--empty.pin-slot--gold{border-color:#d4af37}.pin-slot--empty.pin-slot--silver{border-color:#a8b2bb}.tally{margin:4px 8px 12px;background:#fff;border-radius:var(--radius);padding:12px;box-shadow:0 1px 3px #00000014}.tally__title{font-weight:700;font-size:.8rem;color:#4a5568;margin-bottom:8px}.tally__row{display:flex;align-items:center;gap:6px;margin-bottom:5px;font-size:.78rem}.tally__name{width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.tally__bar-wrap{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.tally__bar{height:100%;background:#4299e1;border-radius:3px;transition:width .4s ease}.tally__count{width:16px;text-align:right;color:#718096;font-weight:600}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;border-radius:16px;padding:40px 36px;text-align:center;box-shadow:0 20px 60px #0003;max-width:380px;width:90%}.login-emoji{font-size:4rem;margin-bottom:12px}.login-card h1{font-size:1.6rem;font-weight:800;color:#2d3748;margin-bottom:8px}.login-card p{color:#718096;margin-bottom:6px}.login-sub{font-size:.875rem}.login-btn-wrap{margin-top:24px;display:flex;justify-content:center}.dev-login{margin-top:24px;padding-top:20px;border-top:1px dashed #E2E8F0}.dev-label{font-size:.72rem;color:#a0aec0;margin-bottom:10px}.dev-friend-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.dev-friend-btn{padding:6px 2px;border-radius:6px;border:2px solid;background:none;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .15s}.dev-friend-btn:hover{opacity:.75}.masquerade-panel{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;background:#1a202ceb;color:#fff;padding:6px 10px;border-radius:24px;box-shadow:var(--shadow);z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.masq-label{font-size:.72rem;opacity:.6;white-space:nowrap;margin-right:4px}.masq-friends{display:flex;gap:4px}.masq-btn{padding:4px 10px;border-radius:12px;border:2px solid var(--c, #fff);background:transparent;color:var(--c, #fff);font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s}.masq-btn:hover,.masq-btn.masq-active{background:var(--c, #fff);color:#1a202c}.masq-signout{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:12px;padding:2px 4px}.masq-signout:hover{color:#fff}@media (max-width: 640px){:root{--sidebar-w: 100vw}.app-layout{flex-direction:column}.map-container{height:55vh;flex:none}.sidebar{height:45vh;border-left:none;border-top:1px solid #E2E8F0}}
