*{box-sizing:border-box}html,body{height:100%;margin:0;padding:0}#root{height:100%}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}.theme-dark{--bg-primary:#000;--bg-secondary:#0a0a0a;--bg-tertiary:#141414;--bg-card:#1a1a1a;--bg-hover:#222;--bg-input:#0a0a0a;--border-primary:#222;--border-secondary:#333;--border-hover:#444;--text-primary:#fff;--text-secondary:#e0e0e0;--text-muted:#888;--text-faint:#555;--accent:#4a9eff;--accent-hover:#3a8eef;--accent-bg:#4a9eff1a;--danger:#f44;--danger-bg:#ff444414;--success:#22c55e;--success-hover:#16a34a;--warning:#f80;--warning-bg:#2a1a00;--map-fill:#2a2a2a;--map-stroke:#444;--map-hover:#3a3a3a;--modal-bg:#000000d9;--shadow:#0009;--glass-bg:#0a0a0a8c;--glass-border:#ffffff14;--glass-shadow:#0006}.theme-light{--bg-primary:#f5f5f5;--bg-secondary:#fff;--bg-tertiary:#f0f0f0;--bg-card:#fff;--bg-hover:#e8e8e8;--bg-input:#fff;--border-primary:#ddd;--border-secondary:#ccc;--border-hover:#999;--text-primary:#111;--text-secondary:#333;--text-muted:#666;--text-faint:#999;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-bg:#2563eb14;--danger:#dc2626;--danger-bg:#dc26260f;--success:#16a34a;--success-hover:#15803d;--warning:#d97706;--warning-bg:#fef3c7;--map-fill:#e0e0e0;--map-stroke:#bbb;--map-hover:#d0d0d0;--modal-bg:#00000080;--shadow:#00000026;--glass-bg:#ffffff8c;--glass-border:#00000014;--glass-shadow:#0000000f}body{background:var(--bg-primary);color:var(--text-secondary);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,sans-serif}button{cursor:pointer;font-family:inherit}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.app{background:var(--bg-primary);height:100dvh;color:var(--text-secondary);flex-direction:column;transition:background .3s,color .3s;display:flex}.app-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(18px)saturate(180%);border-bottom:1px solid var(--glass-border);box-shadow:0 2px 12px var(--glass-shadow);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:10px 24px;transition:background .3s,box-shadow .3s;display:flex;position:relative}.header-left{align-items:center;display:flex}.site-title{color:var(--text-primary);cursor:pointer;letter-spacing:1px;font-size:1.3rem;font-weight:700}.header-right{align-items:center;gap:12px;display:flex}.lang-switcher{gap:4px;display:flex}.lang-switcher button{border:1px solid var(--border-hover);color:var(--text-muted);background:0 0;border-radius:4px;padding:5px 10px;font-size:12px;font-weight:500;transition:all .2s}.lang-switcher button:hover{border-color:var(--text-primary);color:var(--text-primary)}.lang-switcher button.active{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.auth-buttons{gap:8px;display:flex}.btn-login{border:1px solid var(--border-hover);color:var(--text-secondary);background:0 0;border-radius:4px;padding:7px 16px;font-size:13px;transition:all .2s}.btn-login:hover{border-color:var(--text-primary);color:var(--text-primary)}.btn-register{background:var(--accent);color:#fff;border:none;border-radius:4px;padding:7px 16px;font-size:13px;font-weight:600;transition:all .2s}.btn-register:hover{background:var(--accent-hover)}.user-info{align-items:center;gap:10px;display:flex}.username-display{color:var(--accent);font-size:13px;font-weight:500}.btn-logout{border:1px solid var(--danger);color:var(--danger);background:0 0;border-radius:4px;padding:6px 14px;font-size:12px;transition:all .2s}.btn-logout:hover{background:var(--danger-bg)}.app-main{flex:1;position:relative;overflow:hidden}.homepage{background:var(--bg-primary);width:100%;height:100%;position:relative}.map-container{width:100%;height:100%}.map-container svg{width:100%;height:100%;display:block}@keyframes pulse-ring{0%{r:5px;opacity:1}to{r:22px;opacity:0}}.pulse-dot{cursor:pointer;animation:1.5s ease-out infinite pulse-ring}.community-overlay{background:linear-gradient(transparent, var(--bg-primary) 30%);max-height:70vh;padding:60px 24px 24px;position:absolute;bottom:0;left:0;right:0;overflow-y:auto}.community-panel{max-width:800px;margin:0 auto}.btn-back{border:1px solid var(--border-hover);background:var(--bg-secondary);color:var(--text-secondary);border-radius:4px;margin-bottom:12px;padding:6px 14px;font-size:13px;transition:all .2s}.btn-back:hover{border-color:var(--text-primary);color:var(--text-primary)}.community-panel h3{color:var(--text-primary);margin-bottom:16px;font-size:1.1rem;font-weight:600}.no-communities{color:var(--text-muted);font-size:14px}.metro-group{margin-bottom:16px}.metro-group-title{color:var(--accent);border-bottom:1px solid var(--border-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-bottom:4px;font-size:13px;font-weight:700}.community-list{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.community-card{background:var(--bg-card);border:1px solid var(--border-secondary);cursor:pointer;text-align:left;border-radius:8px;flex-direction:column;gap:4px;padding:14px 16px;transition:all .2s;display:flex}.community-card:hover{border-color:var(--accent);background:var(--bg-hover);box-shadow:0 4px 12px var(--shadow);transform:translateY(-2px)}.community-name{color:var(--text-primary);font-size:15px;font-weight:600}.community-distance{color:var(--text-muted);font-size:12px}.loading-overlay{pointer-events:none;background:#0006;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner{border:3px solid var(--border-secondary);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.modal-overlay{background:var(--modal-bg);z-index:1000;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:12px;width:100%;max-width:380px;padding:32px 28px}.modal-content h2{color:var(--text-primary);text-align:center;margin-bottom:20px;font-size:1.2rem}.pending-info{color:var(--accent);text-align:center;margin-bottom:16px;font-size:13px}.form-group{margin-bottom:14px}.form-group label{color:var(--text-muted);margin-bottom:5px;font-size:12px;font-weight:500;display:block}.form-group input{border:1px solid var(--border-secondary);background:var(--bg-input);width:100%;color:var(--text-primary);border-radius:6px;outline:none;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-group input:focus{border-color:var(--accent)}.error-msg{color:var(--danger);background:var(--danger-bg);border-radius:4px;margin-bottom:10px;padding:6px 10px;font-size:12px}.btn-submit{background:var(--accent);color:#fff;border:none;border-radius:6px;width:100%;margin-bottom:12px;padding:11px;font-size:14px;font-weight:600;transition:background .2s}.btn-submit:hover{background:var(--accent-hover)}.toggle-mode{text-align:center;color:var(--text-muted);margin-bottom:10px;font-size:13px}.btn-cancel{border:1px solid var(--border-secondary);width:100%;color:var(--text-muted);background:0 0;border-radius:6px;padding:9px;font-size:13px;transition:all .2s}.btn-cancel:hover{border-color:var(--border-hover);color:var(--text-secondary)}.social-login-section{margin-bottom:16px}.social-label{color:var(--text-muted);text-align:center;margin-bottom:10px;font-size:12px}.social-btn-grid{justify-content:center;gap:8px;display:flex}.social-btn{border:1px solid var(--border-secondary);background:var(--bg-card);color:var(--text-secondary);border-radius:6px;justify-content:center;align-items:center;gap:8px;padding:11px 32px;font-size:14px;transition:all .2s;display:flex}.social-btn:hover{border-color:var(--social-color,var(--accent));background:var(--bg-hover);box-shadow:0 2px 8px var(--shadow);transform:translateY(-1px)}.social-icon{background:var(--social-color,var(--accent));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;font-weight:700;display:flex}.social-name{white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.auth-divider{color:var(--text-faint);align-items:center;gap:12px;margin:14px 0;font-size:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-primary);flex:1;height:1px}.bind-hint{color:var(--text-muted);text-align:center;margin-bottom:16px;font-size:13px;line-height:1.5}.reply-quote{border-left:3px solid var(--accent);background:var(--bg-tertiary);border-radius:0 4px 4px 0;margin-bottom:6px;padding:4px 8px}.reply-quote-user{color:var(--accent);font-size:10px;font-weight:600}.reply-quote-text{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-size:11px;overflow:hidden}.reply-bar{background:var(--bg-tertiary);border-top:1px solid var(--border-primary);justify-content:space-between;align-items:center;padding:6px 12px;font-size:12px;display:flex}.reply-bar-content{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.reply-bar-label{color:var(--text-muted)}.reply-bar-user{color:var(--accent);font-weight:600}.reply-bar-text{color:var(--text-muted)}.reply-bar-cancel{color:var(--text-muted);background:0 0;border:none;flex-shrink:0;padding:2px 6px;font-size:14px;transition:color .2s}.reply-bar-cancel:hover{color:var(--danger)}.load-more-btn{border:1px dashed var(--border-secondary);width:100%;color:var(--accent);background:0 0;border-radius:6px;margin-bottom:8px;padding:8px;font-size:13px;transition:all .2s;display:block}.load-more-btn:hover{border-color:var(--accent);background:var(--accent-bg)}.no-more-msg{text-align:center;color:var(--text-faint);margin-bottom:4px;padding:6px 0;font-size:12px}.btn-skip{width:100%;color:var(--accent);background:0 0;border:none;margin-bottom:8px;padding:9px;font-size:13px;font-weight:500;transition:color .2s}.btn-skip:hover{color:var(--accent-hover);text-decoration:underline}.auth-security-link{text-align:center;margin:14px 0 10px;font-size:12px}.auth-security-link a{color:var(--text-muted);transition:color .2s}.auth-security-link a:hover{color:var(--accent)}.security-info-list{flex-direction:column;gap:14px;margin-bottom:18px;display:flex}.security-item{align-items:flex-start;gap:12px;display:flex}.security-item .security-icon{flex-shrink:0;margin-top:2px;font-size:20px}.security-item strong{color:var(--text-primary);margin-bottom:3px;font-size:13px;display:block}.security-item p{color:var(--text-muted);font-size:12px;line-height:1.4}.redirecting-modal{text-align:center;padding:40px 28px}.redirecting-icon{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;font-size:28px;font-weight:700;animation:1.2s ease-in-out infinite redirect-pulse;display:flex}@keyframes redirect-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.redirecting-modal h2{color:var(--text-primary);margin-bottom:20px;font-size:16px}.redirecting-spinner{border:3px solid var(--border-secondary);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;margin:0 auto 16px;animation:.8s linear infinite spin}.redirecting-hint{color:var(--text-muted);margin-bottom:6px;font-size:13px}.redirecting-url{color:var(--text-faint);margin-bottom:20px;font-family:Courier New,monospace;font-size:12px}.popup-blocked-icon{text-align:center;margin-bottom:12px;font-size:40px}.popup-blocked-text{color:var(--text-secondary);text-align:center;margin-bottom:8px;font-size:14px;line-height:1.5}.popup-blocked-hint{color:var(--text-muted);text-align:center;margin-bottom:20px;font-size:12px;line-height:1.4}.chat-room{background:var(--bg-primary);flex-direction:column;height:100%;display:flex}.chat-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:8px 16px;display:flex}.chat-header-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.chat-header-left h3{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.chat-header-right{flex-shrink:0;gap:6px;display:flex}.btn-leave{border:1px solid var(--danger);color:var(--danger);background:0 0;border-radius:4px;padding:5px 12px;font-size:12px;transition:all .2s}.btn-leave:hover{background:var(--danger-bg)}.btn-switch{border:1px solid var(--accent);color:var(--accent);background:0 0;border-radius:4px;padding:5px 12px;font-size:12px;transition:all .2s}.btn-switch:hover{background:var(--accent-bg)}.chat-main{flex:1;grid-template-rows:1fr;grid-template-columns:1fr 200px;display:grid;position:relative;overflow:hidden}.messages-area{flex-direction:column;display:flex;overflow:hidden}.messages-list{flex-direction:column;flex:1;gap:8px;padding:16px;display:flex;overflow-y:auto}.messages-list::-webkit-scrollbar{width:4px}.messages-list::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:2px}.message{background:var(--bg-card);border:1px solid var(--border-primary);word-break:break-word;cursor:pointer;border-radius:10px;max-width:75%;padding:8px 12px;transition:background .15s}.message:hover{background:var(--bg-hover)}.message.own{background:var(--accent-bg);border-color:var(--accent);align-self:flex-end}.msg-username{color:var(--accent);margin-bottom:3px;font-size:11px;font-weight:500}.msg-content{color:var(--text-secondary);font-size:14px;line-height:1.5}.msg-time{color:var(--text-faint);text-align:right;margin-top:4px;font-size:10px}.input-section{background:var(--bg-secondary);border-top:1px solid var(--border-primary);flex-shrink:0;padding:10px 12px}.input-row{align-items:center;gap:8px;display:flex}.emoji-wrapper{flex-shrink:0;position:relative}.emoji-btn{border:1px solid var(--border-secondary);background:var(--bg-input);border-radius:6px;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;transition:border-color .2s;display:flex}.emoji-btn:hover{border-color:var(--border-hover)}.emoji-picker{background:var(--bg-tertiary);border:1px solid var(--border-secondary);z-index:200;box-shadow:0 8px 24px var(--shadow);border-radius:10px;min-width:240px;padding:10px;position:absolute;bottom:46px;left:0}.emoji-grid{grid-template-columns:repeat(8,1fr);gap:4px;max-height:180px;display:grid;overflow-y:auto}.emoji-item{background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:background .15s;display:flex}.emoji-item:hover{background:var(--bg-hover)}.msg-input{background:var(--bg-input);border:1px solid var(--border-secondary);color:var(--text-primary);border-radius:6px;outline:none;flex:1;min-width:0;padding:8px 12px;font-size:14px;transition:border-color .2s}.msg-input:focus{border-color:var(--accent)}.msg-input:disabled{opacity:.4;cursor:not-allowed}.msg-input::placeholder{color:var(--text-faint)}.send-btn{background:var(--success);color:#fff;border:none;border-radius:6px;flex-shrink:0;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s}.send-btn:hover:not(:disabled){background:var(--success-hover)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.input-info{justify-content:space-between;padding-top:6px;font-size:11px;display:flex}.char-counter{color:var(--text-muted)}.char-counter.warn{color:var(--warning)}.msg-counter{color:var(--text-muted)}.users-panel{background:var(--bg-secondary);border-left:1px solid var(--border-primary);padding:14px 12px;overflow-y:auto}.users-panel h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:12px;font-weight:600}.user-list{flex-direction:column;gap:6px;display:flex}.user-item{background:var(--bg-card);color:var(--text-secondary);border-radius:6px;align-items:center;gap:8px;padding:6px 8px;font-size:12px;display:flex}.online-dot{background:var(--success);border-radius:50%;flex-shrink:0;width:7px;height:7px}.current-user{color:var(--accent);font-weight:500}.user-toggle{background:var(--bg-card);border:1px solid var(--border-secondary);color:var(--text-muted);z-index:50;border-radius:6px;padding:5px 10px;font-size:12px;transition:all .2s;display:none;position:absolute;top:8px;right:8px}.user-toggle:hover{border-color:var(--border-hover);color:var(--text-primary)}@media (width<=768px){.app-header{height:50px;padding:8px 14px}.site-title{font-size:1.1rem}.community-list{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.chat-main{grid-template-columns:1fr 160px}.emoji-grid{grid-template-columns:repeat(7,1fr)}}@media (width<=480px){.app-header{gap:6px;height:46px;padding:6px 10px}.site-title{font-size:.95rem}.lang-switcher button{padding:4px 7px;font-size:11px}.btn-login,.btn-register{padding:5px 10px;font-size:12px}.username-display{display:none}.community-overlay{padding:40px 12px 16px}.community-list{grid-template-columns:1fr 1fr;gap:8px}.community-card{padding:10px 12px}.community-name{font-size:13px}.chat-header{padding:6px 10px}.chat-header-left h3{font-size:13px}.btn-leave,.btn-switch{padding:4px 8px;font-size:11px}.chat-main{grid-template-columns:1fr}.users-panel{z-index:300;background:var(--bg-secondary);border-left:1px solid var(--border-primary);width:200px;padding:14px 12px;transition:transform .25s;position:fixed;top:46px;bottom:0;right:0;transform:translate(100%)}.users-panel.show{transform:translate(0)}.user-toggle{display:block}.emoji-picker{min-width:200px}.emoji-grid{grid-template-columns:repeat(6,1fr)}.send-btn{padding:8px 12px;font-size:13px}.msg-input{font-size:16px}}@media (width<=360px){.community-list{grid-template-columns:1fr}.lang-switcher{gap:2px}.lang-switcher button{padding:3px 5px;font-size:10px}}@media (height<=500px) and (width<=800px){.emoji-grid{max-height:100px}.messages-list{gap:4px;padding:8px}.message{padding:6px 10px}.input-section{padding:6px 8px}}.mock-location-panel{z-index:60;position:absolute;bottom:16px;left:16px}.mock-toggle{background:var(--bg-secondary);border:1px solid var(--border-hover);color:var(--text-secondary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:.9;border-radius:8px;align-items:center;gap:4px;padding:8px 14px;font-size:13px;transition:all .2s;display:flex}.mock-toggle:hover{border-color:var(--warning);color:var(--text-primary);opacity:1}.mock-cities{background:var(--bg-secondary);border:1px solid var(--border-secondary);min-width:200px;box-shadow:0 8px 24px var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:10px;padding:12px;position:absolute;bottom:44px;left:0}.mock-hint{color:var(--text-muted);margin-bottom:10px;font-size:11px}.mock-city-grid{grid-template-columns:1fr 1fr;gap:6px;max-height:260px;display:grid;overflow-y:auto}.mock-city-btn{background:var(--bg-card);border:1px solid var(--border-secondary);color:var(--text-secondary);text-align:center;border-radius:6px;padding:8px 10px;font-size:13px;transition:all .2s}.mock-city-btn:hover{border-color:var(--warning);background:var(--warning-bg);color:var(--warning);transform:translateY(-1px)}.theme-toggle{border:1px solid var(--border-hover);background:0 0;border-radius:6px;padding:6px 10px;font-size:16px;line-height:1;transition:all .2s}.theme-toggle:hover{border-color:var(--accent);background:var(--accent-bg)}.site-footer{z-index:50;background:0 0;border:none;justify-content:center;align-items:center;gap:16px;padding:14px 20px;font-size:13px;display:flex;position:relative}.footer-copy{color:var(--text-muted,#888);background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border-radius:12px;padding:4px 10px;font-size:12px}.contact-btn{border:1px solid var(--glass-border,#ffffff1f);background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);color:var(--text-primary,#eee);cursor:pointer;border-radius:20px;align-items:center;gap:6px;padding:6px 16px;font-size:13px;transition:all .25s;display:inline-flex}.contact-btn:hover{border-color:var(--accent,#60a5fa);color:var(--accent,#60a5fa);background:var(--accent-bg,#60a5fa14);transform:translateY(-1px);box-shadow:0 2px 8px #60a5fa26}.contact-btn:active{transform:translateY(0)}.contact-btn:disabled{opacity:.6;cursor:wait}.contact-email-link{border:1px solid var(--accent,#60a5fa);color:var(--accent,#60a5fa);background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border-radius:20px;align-items:center;gap:6px;padding:6px 16px;font-size:13px;text-decoration:none;transition:all .25s;animation:.3s fadeInEmail;display:inline-flex}.contact-email-link:hover{background:var(--accent,#60a5fa);color:#fff;box-shadow:0 2px 12px #60a5fa40}@keyframes fadeInEmail{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
