*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f0f0f;color:#e0e0e0;height:100dvh;overflow:hidden}#root{width:100%;height:100%}.chat-container{width:100%;height:100%;max-width:600px;margin:0 auto;background:#1a1a2e;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #00000080;border-left:1px solid #2a2a4a;border-right:1px solid #2a2a4a}.header{padding:14px 16px;background:#16162a;border-bottom:1px solid #2a2a4a;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0}.header h1{font-size:17px;font-weight:600;color:#e0e0e0;letter-spacing:.5px;white-space:nowrap}.status-badge{font-size:11px;padding:4px 10px;border-radius:12px;font-weight:500;white-space:nowrap}.status-disconnected{background:#2a1a1a;color:#ff6b6b;border:1px solid #4a2020}.status-connecting{background:#2a2a1a;color:#ffd93d;border:1px solid #4a4a20}.status-waiting{background:#1a2a2a;color:#4ecdc4;border:1px solid #204a4a}.status-connected{background:#1a2a1a;color:#51cf66;border:1px solid #204a20}.connection-info{padding:8px 16px;background:#12122a;border-bottom:1px solid #2a2a4a;display:flex;flex-direction:column;gap:5px;flex-shrink:0}.connection-info-row{display:flex;align-items:center;gap:8px;font-size:12px}.connection-label{color:#666;min-width:52px;flex-shrink:0}.connection-value{color:#aaa;word-break:break-all}.connection-path{color:#4ecdc4;font-weight:500}.ice-new,.ice-checking{color:#ffd93d}.ice-connected,.ice-completed{color:#51cf66}.ice-disconnected,.ice-failed,.ice-closed{color:#ff6b6b}.room-section{padding:10px 16px;background:#16162a;border-bottom:1px solid #2a2a4a;display:flex;gap:8px;flex-shrink:0}.room-section input{flex:1;min-width:0;padding:10px 12px;background:#0f0f1f;border:1px solid #2a2a4a;border-radius:8px;color:#e0e0e0;font-size:14px;outline:none;transition:border-color .2s}.room-section input:focus{border-color:#6c5ce7}.room-section input:disabled{opacity:.5;cursor:not-allowed}.room-section button{padding:10px 18px;background:#6c5ce7;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap;min-width:56px}.room-section button:hover:not(:disabled){background:#5a4bd1}.room-section button:disabled{opacity:.5;cursor:not-allowed}.disconnect-btn{background:#e74c3c!important}.disconnect-btn:hover:not(:disabled){background:#c0392b!important}.messages{flex:1;min-height:0;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:6px;-webkit-overflow-scrolling:touch}.messages::-webkit-scrollbar{width:4px}.messages::-webkit-scrollbar-thumb{background:#2a2a4a;border-radius:2px}.message{max-width:85%;padding:8px 12px;border-radius:12px;font-size:14px;line-height:1.5;word-break:break-word}.message-me{align-self:flex-end;background:#6c5ce7;color:#fff;border-bottom-right-radius:4px}.message-peer{align-self:flex-start;background:#2a2a4a;color:#e0e0e0;border-bottom-left-radius:4px}.message-system{align-self:center;background:transparent;color:#666;font-size:12px;padding:3px 0}.message-time{font-size:10px;opacity:.6;margin-top:3px;text-align:right}.input-section{padding:10px 16px;padding-bottom:max(10px,env(safe-area-inset-bottom));background:#16162a;border-top:1px solid #2a2a4a;display:flex;gap:8px;flex-shrink:0}.input-section input{flex:1;min-width:0;padding:11px 14px;background:#0f0f1f;border:1px solid #2a2a4a;border-radius:10px;color:#e0e0e0;font-size:15px;outline:none;transition:border-color .2s}.input-section input:focus{border-color:#6c5ce7}.input-section input:disabled{opacity:.5;cursor:not-allowed}.input-section button{padding:11px 20px;background:#6c5ce7;color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap;min-width:56px}.input-section button:hover:not(:disabled){background:#5a4bd1}.input-section button:disabled{opacity:.5;cursor:not-allowed}.error-banner{padding:8px 16px;background:#2a1a1a;color:#ff6b6b;font-size:13px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.error-banner button{background:none;border:none;color:#ff6b6b;cursor:pointer;font-size:18px;padding:0 4px;line-height:1}@media(min-width:640px){body,#root{display:flex;justify-content:center;align-items:center}.chat-container{height:680px;max-height:90vh;border-radius:16px;border:1px solid #2a2a4a}.header{padding:16px 20px}.header h1{font-size:18px}.status-badge{font-size:12px}.room-section{padding:12px 20px}.connection-info{padding:8px 20px}.messages{padding:16px 20px;gap:8px}.input-section{padding:12px 20px}.message{max-width:80%;padding:10px 14px}.error-banner{padding:8px 20px}}@media(max-width:380px){.header h1{font-size:15px}.status-badge{font-size:10px;padding:3px 8px}.connection-info-row{font-size:11px}.room-section button,.input-section button{padding:10px 14px;font-size:13px;min-width:48px}.room-section input{font-size:13px;padding:9px 10px}.input-section input{font-size:14px;padding:10px 12px}.message{font-size:13px}}.input-left-btns{display:flex;gap:4px;align-items:center}.voice-trigger-btn{width:36px;height:36px;padding:0!important;min-width:36px!important;font-size:18px!important;line-height:36px;border-radius:10px!important;background:#2a2a4a!important;display:flex;align-items:center;justify-content:center;border:1px solid #3a3a5a;cursor:pointer;transition:background .15s}.voice-trigger-btn:hover{background:#3a3a5a!important}.voice-record-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-user-select:none;user-select:none;touch-action:none}.voice-record-overlay.cancelling{background:#b4282880}.voice-record-bubble{background:#1a1a2e;border-radius:20px;padding:24px 32px;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:0 8px 40px #00000080;transition:transform .15s ease;min-width:240px}.voice-record-hint{font-size:13px;color:#999}.voice-record-overlay.cancelling .voice-record-hint{color:#ff6b6b}.voice-record-timer{font-size:24px;font-weight:600;color:#ff6b6b;font-variant-numeric:tabular-nums}.voice-waveform{border-radius:4px;width:200px;height:48px}.voice-record-bar{width:100%;height:3px;background:#ffffff1a;border-radius:2px;overflow:hidden}.voice-record-bar-fill{height:100%;background:#ff6b6b;border-radius:2px;transition:width .3s linear}.voice-hold-btn{padding:12px 48px;border-radius:24px;background:#6c5ce7;color:#fff;border:none;font-size:15px;cursor:pointer;min-width:160px;pointer-events:none}.voice-hold-btn.cancel{background:#e74c3c}.image-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:300;cursor:pointer}.image-preview-img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px}.image-preview-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;border:none;background:#ffffff26;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center}.image-preview-close:hover{background:#ffffff40}.upload-btn{width:36px;height:36px;padding:0!important;min-width:36px!important;font-size:20px!important;line-height:36px;border-radius:10px!important;display:flex;align-items:center;justify-content:center}.media-message{max-width:240px}.message-image{width:100%;max-width:240px;border-radius:8px;cursor:pointer;display:block;transition:opacity .2s}.message-image:hover{opacity:.85}.file-bubble{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.file-icon{font-size:20px}.file-name{font-size:13px;word-break:break-all}.file-size{font-size:11px;color:#888}.download-link{font-size:12px;color:#4ecdc4;text-decoration:none;font-weight:500}.download-link:hover{text-decoration:underline}.progress-bar{width:100%;height:4px;background:#ffffff26;border-radius:2px;overflow:hidden;margin-top:4px}.progress-fill{height:100%;background:#6c5ce7;border-radius:2px;transition:width .15s ease-out}.voice-bubble{display:flex;align-items:center;gap:8px}.play-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:2px;min-width:28px;text-align:center}.play-btn:hover{transform:scale(1.15)}.voice-progress-bar{flex:1;height:4px;background:#ffffff26;border-radius:2px;cursor:pointer;min-width:60px}.voice-progress-fill{height:100%;background:#6c5ce7;border-radius:2px;transition:width .1s linear}.voice-duration{font-size:11px;color:#888;min-width:28px}.unread-dot{width:6px;height:6px;border-radius:50%;background:#ff6b6b;flex-shrink:0}.video-msg-bubble{position:relative;max-width:240px;border-radius:8px;overflow:hidden}.video-thumbnail{width:100%;display:block;border-radius:8px}.video-placeholder{width:200px;height:120px;background:#2a2a4a;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:36px}.video-duration-badge{position:absolute;bottom:6px;right:6px;background:#000000b3;color:#fff;font-size:11px;padding:2px 6px;border-radius:4px}.play-btn-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:none;border:none;font-size:28px;cursor:pointer;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.header-right{display:flex;align-items:center;gap:10px}.call-start-btns{display:flex;gap:6px}.call-start-btn{width:34px;height:34px;border-radius:8px;border:1px solid #3a3a5a;background:#1a1a2e;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .15s}.call-start-btn:hover{background:#2a2a4a}.call-controls-bar{display:flex;align-items:center;justify-content:center;gap:16px;padding:10px 16px;background:#16162a;border-bottom:1px solid #2a2a4a;flex-shrink:0}.call-status-text{font-size:14px;color:#aaa}.call-btn{width:44px;height:44px;border-radius:50%;border:none;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.call-btn-green{background:#51cf66;color:#fff}.call-btn-green:hover{background:#40b855}.call-btn-red{background:#e74c3c;color:#fff}.call-btn-red:hover{background:#c0392b}.call-btn-gray{background:#444;color:#fff}.call-btn-gray:hover{background:#555}.call-overlay{position:fixed;z-index:100;overflow:hidden}.call-overlay.fullscreen{top:0;right:0;bottom:0;left:0;background:#000}.call-overlay.pip{bottom:20px;right:20px;width:200px;height:150px;border-radius:12px;box-shadow:0 4px 20px #00000080;cursor:move}.call-overlay.voice-only{top:0;left:0;right:0;bottom:0;background:#000000f2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px}.call-remote-video{width:100%;height:100%;object-fit:cover}.call-local-pip{position:absolute;bottom:100px;right:16px;width:120px;height:160px;border-radius:12px;overflow:hidden;border:2px solid rgba(255,255,255,.3);box-shadow:0 4px 16px #0006;cursor:pointer}.call-local-pip.hidden{display:none}.call-local-pip video{width:100%;height:100%;object-fit:cover}.call-info{position:absolute;top:60px;left:50%;transform:translate(-50%);text-align:center;color:#fff;transition:opacity .3s}.call-info.hidden{opacity:0}.call-duration{font-size:32px;font-weight:600;font-variant-numeric:tabular-nums;text-shadow:0 2px 8px rgba(0,0,0,.5)}.call-label{font-size:16px;color:#aaa;margin-top:4px}.call-overlay .call-controls{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;gap:20px;transition:opacity .3s}.call-overlay .call-controls.hidden{opacity:0;pointer-events:none}.call-overlay.voice-only .call-info{position:static;transform:none;margin-top:16px}.call-overlay.voice-only .call-controls{position:static;transform:none}
