*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}body{background:#1a1a2e;color:#eee}:root{--ui-focus-ring: #4ecca3;--map-ui-edge: 22px;--map-ui-edge-mobile: 22px;--map-ui-stack-gap: 10px;--map-banner-offset: 28px;--sidebar-mobile-height: 40%;--sidebar-mobile-min-height: 12%}.app{display:flex;height:100vh;padding-top:constant(safe-area-inset-top);padding-top:env(safe-area-inset-top,0px)}.map-container{flex:1;position:relative}.sidebar{width:320px;background:#16213e;display:flex;flex-direction:column;border-left:1px solid #0f3460;overflow-y:auto}.sidebar-header{padding:16px;background:#0f3460;font-size:18px;font-weight:600;display:flex;justify-content:space-between;align-items:center}.member-list{flex:1;overflow-y:auto}.member-item{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid #0f3460;cursor:pointer;transition:background .2s}.member-item:hover{background:#1a1a3e}.member-item.focused{background:#1a1a3e;box-shadow:inset 3px 0 #4ecca3}.member-item[role=button]:focus-visible{outline:2px solid var(--ui-focus-ring);outline-offset:-2px}.btn-sort{background:none;border:1px solid #4ecca3;color:#4ecca3;border-radius:4px;padding:2px 8px;font-size:11px;cursor:pointer;white-space:nowrap;transition:all .2s;display:inline-flex;align-items:center;gap:6px}.btn-sort:hover{background:#4ecca3;color:#fff}.member-mic.speaking{display:inline-flex;align-items:center;color:#4ecca3;animation:mic-pulse .8s ease-in-out infinite}@keyframes mic-pulse{0%,to{filter:drop-shadow(0 0 2px #4ecca3);transform:scale(1)}50%{filter:drop-shadow(0 0 8px #4ecca3) drop-shadow(0 0 16px #4ecca355);transform:scale(1.15)}}.member-avatar{width:36px;height:36px;border-radius:50%;background:#e94560;display:flex;align-items:center;justify-content:center;font-weight:700;margin-right:12px;flex-shrink:0}.member-info{flex:1}.member-name{font-size:14px;font-weight:500}.member-status{font-size:11px;color:#888}.member-actions{display:flex;gap:8px}.member-actions button{background:none;border:1px solid #e94560;color:#e94560;border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}.member-actions button:hover{background:#e94560;color:#fff}.member-actions button.direction{border-color:#4ecca3;color:#4ecca3}.member-actions button.direction:hover{background:#4ecca3;color:#fff}.online-dot{width:8px;height:8px;border-radius:50%;background:#4ecca3;margin-left:8px;flex-shrink:0}.offline-dot{width:8px;height:8px;border-radius:50%;background:#666;margin-left:8px;flex-shrink:0}.auth-page{display:flex;align-items:center;justify-content:center;height:100vh;background:#1a1a2e}.auth-card{background:#16213e;padding:40px;border-radius:12px;width:380px;max-width:90vw}.auth-card h2{margin-bottom:24px;text-align:center;color:#e94560;display:flex;align-items:center;justify-content:center;gap:8px}.auth-card input{width:100%;padding:12px;margin-bottom:12px;border:1px solid #0f3460;border-radius:8px;background:#1a1a2e;color:#eee;font-size:14px;outline:none}.auth-card input:focus{border-color:#e94560}.auth-card button{width:100%;padding:12px;background:#e94560;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;margin-top:4px}.auth-card button:hover{background:#c73e54}.auth-card .link{text-align:center;margin-top:16px;font-size:13px;color:#888}.auth-card .link a{color:#4ecca3;cursor:pointer;text-decoration:none}.auth-card .error{color:#e94560;font-size:13px;margin-bottom:8px;text-align:center}.session-bar{padding:12px 16px;background:#0f3460;display:flex;gap:8px;align-items:center}.session-bar input{flex:1;padding:8px 12px;border:1px solid #1a1a2e;border-radius:6px;background:#1a1a2e;color:#eee;font-size:13px}.session-bar button,.btn{padding:8px 16px;background:#e94560;color:#fff;border:none;border-radius:6px;font-size:13px;cursor:pointer;white-space:nowrap}.btn-secondary{background:#4ecca3}.btn-sm{padding:4px 10px;font-size:12px}.sidebar-minimize-btn{display:none}button:focus-visible,.auth-card .link a:focus-visible{outline:2px solid var(--ui-focus-ring);outline-offset:2px}button:disabled{cursor:not-allowed;opacity:.55;filter:saturate(.65)}.member-actions button:disabled,.member-actions button:disabled:hover{border-color:#59657a;color:#7c8798;background:transparent}.call-overlay{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#16213e;border:1px solid #0f3460;border-radius:16px;padding:16px 24px;display:flex;align-items:center;gap:16px;z-index:1000;box-shadow:0 8px 32px #0006}.call-overlay .call-info{font-size:14px;display:inline-flex;align-items:center;gap:8px}.call-overlay button{padding:8px 16px;border:none;border-radius:8px;cursor:pointer;font-weight:600}.call-overlay.call-ended-banner{background:#2b1922;border-color:#e94560;padding:14px 18px;gap:8px;flex-direction:column;align-items:flex-start;min-width:min(92vw,420px)}.call-ended-info{color:#ffe6ec;font-weight:700}.call-ended-message{color:#f6bac4;font-size:13px;line-height:1.35}.call-btn-end{background:#e94560;color:#fff}.call-btn-mute{background:#333;color:#fff}.call-btn-mute.active{background:#e94560}.call-btn-mic{background:#333;color:#fff;position:relative}.call-btn-mic.muted{background:#e94560}.call-btn-mic .mic-slash{display:none}.call-btn-mic.muted .mic-slash{display:block}.call-btn-speaker{background:#333;color:#fff}.call-btn-speaker.off{background:#e94560}.call-controls{display:flex;gap:8px}.call-btn-accept{background:#4ecca3;color:#fff}.incoming-call{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#16213e;border:2px solid #e94560;border-radius:16px;padding:32px;text-align:center;z-index:1001;box-shadow:0 8px 32px #0009}.incoming-call h3{margin-bottom:16px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.incoming-call.incoming-group-call{border-color:#4ecca3;width:min(92vw,380px)}.incoming-call.incoming-direct-call{border-color:#e94560;width:min(92vw,380px)}.incoming-call-subtitle{margin-top:8px;color:#b7becb;font-size:14px;line-height:1.45}.incoming-call-caller{display:block;margin-bottom:4px;color:#fff;font-weight:700;font-size:15px}.incoming-call .actions{display:flex;gap:16px;justify-content:center;margin-top:16px}.incoming-call .actions button{padding:10px 18px;border:none;border-radius:10px;font-size:14px;font-weight:700;min-width:120px;cursor:pointer}.incoming-call .actions .call-btn-accept:hover{background:#3db892}.incoming-call .actions .call-btn-end:hover{background:#c73e54}.map-controls{position:absolute;top:var(--map-ui-edge);left:50%;transform:translate(-50%);z-index:650;display:inline-flex;align-items:center;gap:var(--map-ui-stack-gap)}.connection-banner+.map-controls{top:calc(var(--map-ui-edge) + var(--map-banner-offset))}.map-control-btn{width:44px;height:44px;background:#fff;color:#555;border:none;border-radius:10px;box-shadow:0 1px 4px #0000004d;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.map-control-btn:hover{background:#f2f2f2}.map-locate-btn{position:absolute;right:var(--map-ui-edge);bottom:calc(var(--map-ui-edge) + env(safe-area-inset-bottom,0px) + 155px);z-index:650}.group-call-btn{position:static;padding:10px 14px;background:#e94560;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 14px #0000004d}.group-call-btn:hover{background:#c73e54}.connection-banner{position:absolute;top:0;left:0;right:0;background:#e94560;color:#fff;text-align:center;padding:6px;font-size:13px;font-weight:500;z-index:600;animation:pulse 1.5s ease-in-out infinite;display:flex;align-items:center;justify-content:center;gap:6px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@media (max-width: 768px){.sidebar{width:100%;position:fixed;bottom:0;height:calc(var(--sidebar-mobile-height) + env(safe-area-inset-bottom,0px));z-index:500;border-left:none;border-top:1px solid #0f3460;padding-bottom:env(safe-area-inset-bottom,0px)}.app.app-member-list-minimized .sidebar{height:calc(var(--sidebar-mobile-min-height) + env(safe-area-inset-bottom,0px))}.map-container{height:calc(100% - var(--sidebar-mobile-height))}.app.app-member-list-minimized .map-container{height:calc(100% - var(--sidebar-mobile-min-height))}.sidebar-header{min-height:56px}.sidebar-minimize-btn{display:inline-flex;align-items:center;justify-content:center}.map-controls{top:var(--map-ui-edge-mobile);left:50%;transform:translate(-50%);gap:8px}.connection-banner+.map-controls{top:calc(var(--map-ui-edge-mobile) + var(--map-banner-offset))}.group-call-btn{padding:9px 12px;font-size:13px}.map-locate-btn{right:var(--map-ui-edge-mobile);bottom:calc(var(--map-ui-edge-mobile) + env(safe-area-inset-bottom,0px) + 155px)}}.install-cta{position:fixed;bottom:0;left:0;right:320px;background:#0f3460;border-top:1px solid #4ecca3;padding:12px 16px;display:flex;align-items:center;gap:12px;z-index:700;animation:slideUp .3s ease-out}.install-cta-text{flex:1;font-size:14px;color:#eee}.install-cta-btn{padding:8px 20px;background:#4ecca3;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}.install-cta-btn:hover{background:#3db892}.install-cta-dismiss{background:none;border:none;color:#888;font-size:18px;cursor:pointer;padding:4px;line-height:1}.install-cta-dismiss:hover{color:#eee}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.install-cta{right:0;bottom:calc(var(--sidebar-mobile-height) + env(safe-area-inset-bottom,0px))}.app.app-member-list-minimized .install-cta{bottom:calc(var(--sidebar-mobile-min-height) + env(safe-area-inset-bottom,0px))}}.install-help{margin-top:16px;border:1px solid #0f3460;border-radius:8px;overflow:hidden}.install-help-toggle{width:100%;display:flex;align-items:center;gap:8px;padding:10px 14px;background:#1a1a2e;border:none;color:#ccc;font-size:13px;cursor:pointer;text-align:left;transition:background .2s}.install-help-toggle:hover{background:#1a1a3e}.install-help-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.install-help-chevron{margin-left:auto;color:#888;display:inline-flex;align-items:center;flex-shrink:0}.install-help-content{padding:12px 14px;background:#16213e;border-top:1px solid #0f3460}.install-help-intro{font-size:13px;color:#ccc;margin-bottom:8px}.install-help-steps{padding-left:20px;margin-bottom:10px}.install-help-steps li{font-size:13px;color:#aaa;margin-bottom:6px;line-height:1.4}.install-help-browser-title{font-size:13px;font-weight:600;color:#4ecca3;margin-top:10px;margin-bottom:4px}.install-help-note{font-size:12px;color:#888;font-style:italic}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog-content{background:#16213e;border-radius:12px;padding:24px;width:90%;max-width:400px;color:#eee}.dialog-content h3{margin:0 0 16px;text-align:center;font-size:18px}.dialog-content textarea{width:100%;background:#1a1a2e;border:1px solid #333;border-radius:8px;color:#eee;padding:10px 12px;font-family:inherit;font-size:14px;box-sizing:border-box}.dialog-content textarea:focus{outline:none;border-color:#4ecca3}.dialog-content input{width:100%;background:#1a1a2e;border:1px solid #333;border-radius:8px;color:#eee;padding:10px 12px;font-family:inherit;font-size:14px;box-sizing:border-box;margin-bottom:10px}.dialog-content input:focus{outline:none;border-color:#4ecca3}.dialog-content button{width:100%;padding:12px;background:#e94560;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;margin-top:8px}.dialog-content button:hover{background:#d63851}.dialog-content button:disabled{opacity:.6;cursor:not-allowed}
