*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f13;--bg-card: #1a1a24;--bg-input: #252535;--text: #e8e8f0;--text-secondary: #8888a0;--accent: #6c5ce7;--accent-hover: #7c6cf7;--danger: #e74c3c;--danger-hover: #c0392b;--success: #2ecc71;--border: #333348;--radius: 12px;--radius-sm: 8px}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}#root{height:100%}.page{min-height:100%;display:flex;align-items:center;justify-content:center;padding:1rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem 2rem;max-width:420px;width:100%;text-align:center}.logo{font-size:3rem;margin-bottom:.5rem}.card h1{font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.subtitle{color:var(--text-secondary);font-size:.95rem;margin-bottom:1.5rem}.hint{color:var(--text-secondary);font-size:.8rem;margin-top:1.25rem}.form-group{margin-bottom:1rem;text-align:left}.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.35rem;color:var(--text-secondary)}.form-group input,.form-group select{width:100%;padding:.65rem .85rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:1rem;outline:none;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:var(--accent)}.form-group select{cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.7rem 1.4rem;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;width:100%;margin-top:.5rem}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-input);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-small{padding:.4rem .8rem;font-size:.85rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:600}.btn-small:hover{background:var(--accent-hover)}.btn-send{padding:.5rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;font-size:.85rem}.btn-send:hover:not(:disabled){background:var(--accent-hover)}.btn-send:disabled{opacity:.4;cursor:not-allowed}.error-message{background:#e74c3c26;border:1px solid rgba(231,76,60,.3);color:#e74c3c;padding:.6rem .85rem;border-radius:var(--radius-sm);font-size:.9rem;margin-bottom:.75rem}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:1rem auto}@keyframes spin{to{transform:rotate(360deg)}}.call-container{position:relative;width:100%;height:100vh;height:100dvh;background:#000;overflow:hidden}.remote-video-container{width:100%;height:100%}.remote-video{width:100%;height:100%;object-fit:contain;background:#000}.remote-video-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg)}.waiting-overlay{text-align:center;padding:2rem}.waiting-overlay h2{font-size:1.3rem;margin-bottom:.5rem}.waiting-overlay p{color:var(--text-secondary);font-size:.95rem}.share-link-box{margin-top:1.5rem;padding:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.share-link-box p{margin-bottom:.5rem;font-size:.85rem}.link-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center}.call-url{background:var(--bg-input);padding:.4rem .7rem;border-radius:var(--radius-sm);font-size:.8rem;word-break:break-all;color:var(--accent)}.local-video-container{position:absolute;top:1rem;right:1rem;width:144px;height:192px;border-radius:var(--radius);overflow:hidden;border:2px solid rgba(255,255,255,.2);background:#111;z-index:10;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;transition:width .3s ease,height .3s ease}.local-video-container.pip-landscape{width:192px;height:144px}.local-video-container.swapped{position:absolute;top:0!important;left:0!important;right:0!important;width:100%!important;height:100%!important;border-radius:0;border:none;z-index:5;cursor:default}.remote-video-container.swapped{position:absolute;top:1rem;right:1rem;width:144px;height:192px;border-radius:var(--radius);overflow:hidden;border:2px solid rgba(255,255,255,.2);background:#111;z-index:10;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.remote-video-container.swapped .remote-video{object-fit:cover}.local-video-container.dragging{cursor:grabbing;opacity:.9}.local-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.call-timer{position:absolute;top:.75rem;left:.75rem;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;padding:.25rem .65rem;border-radius:20px;font-size:.8rem;font-weight:600;font-variant-numeric:tabular-nums;z-index:15;pointer-events:none;letter-spacing:.04em}.connection-banner{position:absolute;top:.75rem;left:50%;transform:translate(-50%);background:#2ecc71e6;color:#fff;padding:.35rem 1rem;border-radius:20px;font-size:.85rem;z-index:10;white-space:nowrap}.recording-warning{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#dc2626e6;color:#fff;padding:1rem 2rem;border-radius:12px;font-size:1.1rem;font-weight:600;z-index:100;text-align:center;max-width:90%;animation:recording-warning-pulse .5s ease-in-out 3;box-shadow:0 4px 24px #dc262666;pointer-events:none}@keyframes recording-warning-pulse{0%,to{opacity:1}50%{opacity:.6}}.media-error{position:absolute;top:3.5rem;left:50%;transform:translate(-50%);background:#e74c3ce6;color:#fff;padding:.35rem 1rem;border-radius:20px;font-size:.85rem;z-index:10}.video-controls{position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;z-index:20;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.6rem 1rem;border-radius:20px}.controls-row{display:flex;gap:.75rem;justify-content:center}.control-btn{display:flex;align-items:center;justify-content:center;background:#ffffff1f;border:none;border-radius:20px;padding:.5rem 1rem;cursor:pointer;transition:background .2s,opacity .2s;color:#fff;font-size:.8rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}.control-btn:hover{background:#ffffff38}.control-btn.active{background:#ffffff40}.control-btn.end-call{background:var(--danger)}.control-btn.end-call:hover{background:var(--danger-hover)}.control-btn.expire-link{background:#8b0000}.control-btn.expire-link:hover{background:#a00000}.chat-overlay{position:absolute;bottom:5.5rem;left:1rem;width:380px;max-height:50vh;display:flex;flex-direction:column;z-index:15;background:transparent;border-radius:var(--radius);overflow:hidden;transition:max-height .3s ease;pointer-events:none}.chat-overlay.expanded{max-height:70vh}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:.4rem .75rem;cursor:pointer;font-size:.8rem;font-weight:600;color:#ffffffb3;-webkit-user-select:none;user-select:none;pointer-events:auto}.chat-toggle{font-size:.7rem}.chat-messages{flex:1;overflow-y:auto;padding:.5rem .75rem;display:flex;flex-direction:column;gap:.4rem;pointer-events:auto}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.chat-bubble{max-width:90%;padding:.2rem 0;border-radius:0;font-size:.95rem;background:transparent}.chat-bubble.own{align-self:flex-end;background:transparent;color:#fff;text-align:right}.chat-bubble.peer{align-self:flex-start;background:transparent;color:#fff;text-align:left}.chat-sender{font-size:.75rem;font-weight:700;color:var(--accent);margin-bottom:.1rem}.chat-bubble.own .chat-sender{color:#ffffffb3}.chat-primary{font-weight:600;line-height:1.3;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.8),0 0 8px rgba(0,0,0,.5)}.chat-secondary{font-size:.85rem;color:#ffffffb3;margin-top:.15rem;line-height:1.3;text-shadow:0 1px 4px rgba(0,0,0,.8),0 0 8px rgba(0,0,0,.5)}.chat-bubble.peer .chat-secondary{color:#ffffffb3}.chat-lang-tag{font-size:.65rem;margin-left:.3rem;opacity:.7}.chat-input-row{display:flex;gap:.4rem;padding:.4rem .5rem;pointer-events:auto}.chat-input{flex:1;background:#0006;border:none;border-radius:20px;padding:.4rem .75rem;color:#fff;font-size:16px;outline:none}.chat-input::placeholder{color:#fff6}@media(max-width:768px){.remote-video{object-fit:cover}.card{padding:1.75rem 1.25rem}.local-video-container{width:120px;height:160px;top:.5rem;right:.5rem}.local-video-container.pip-landscape{width:160px;height:120px}.remote-video-container.swapped{width:120px;height:160px}.chat-overlay{width:calc(100% - 2rem);left:1rem;right:1rem;bottom:5rem;max-height:160px}.chat-overlay.expanded{max-height:50vh}.chat-input-row{padding:.4rem;gap:.3rem}.chat-input{min-width:0;font-size:16px;padding:.4rem .6rem}.btn-send{padding:.4rem .7rem;font-size:.8rem;white-space:nowrap;flex-shrink:0}.video-controls{gap:.3rem;padding:.5rem .75rem}.controls-row{gap:.5rem}.control-btn{padding:.4rem .7rem;font-size:.7rem}.connection-banner{font-size:.75rem;padding:.25rem .75rem}}@media(max-width:480px){.card h1{font-size:1.4rem}.local-video-container{width:96px;height:128px}.local-video-container.pip-landscape{width:128px;height:96px}.remote-video-container.swapped{width:96px;height:128px}.chat-overlay{width:calc(100% - 1rem);left:.5rem;right:.5rem;bottom:4.5rem;max-height:140px}.chat-input-row{padding:.3rem;gap:.25rem}.chat-input{font-size:16px;padding:.35rem .5rem}.btn-send{padding:.35rem .6rem;font-size:.75rem}.video-controls{gap:.2rem;padding:.4rem .5rem;bottom:.75rem}.controls-row{gap:.35rem}.control-btn{padding:.35rem .5rem;font-size:.65rem}.share-link-box{padding:.75rem}.call-url{font-size:.7rem}.link-row{gap:.35rem}}.btn-mic{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background:#ffffff1f;color:#fff;font-size:1.1rem;cursor:pointer;transition:background .2s,box-shadow .2s;flex-shrink:0}.btn-mic:hover{background:#ffffff38}.btn-mic.listening{background:#e74c3ccc;animation:mic-pulse 1.2s ease-in-out infinite;box-shadow:0 0 #e74c3c66}@keyframes mic-pulse{0%{box-shadow:0 0 #e74c3c80}70%{box-shadow:0 0 0 8px #e74c3c00}to{box-shadow:0 0 #e74c3c00}}.speech-interim{padding:.3rem .75rem;color:#fff9;font-size:.8rem;font-style:italic;text-shadow:0 1px 4px rgba(0,0,0,.8);pointer-events:none}.confirm-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100}.confirm-dialog{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 2rem;max-width:360px;width:90%;text-align:center}.confirm-message{color:var(--text);font-size:1rem;line-height:1.5;margin-bottom:1.25rem}.confirm-buttons{display:flex;gap:.75rem;justify-content:center}.confirm-cancel{flex:1}.confirm-end{flex:1;background:var(--danger);color:#fff}.confirm-end:hover{background:var(--danger-hover)}.confirm-expire{flex:1;background:#8b0000;color:#fff}.confirm-expire:hover{background:#a00000}.home-screen-tip{margin-top:1.25rem;padding:.75rem;background:#6c5ce714;border:1px solid rgba(108,92,231,.2);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.75rem;line-height:1.5;text-align:left}@media(max-height:500px)and (orientation:landscape){.call-container{height:100vh;height:100dvh}.local-video-container{width:120px;height:90px;top:.5rem;right:.5rem}.remote-video-container.swapped{width:120px;height:90px}.video-controls{bottom:.5rem;padding:.35rem .6rem;gap:.35rem}.control-btn{padding:.3rem .5rem;font-size:.6rem}.chat-overlay{bottom:3.5rem;max-height:120px}.connection-banner{top:.35rem;font-size:.7rem;padding:.2rem .6rem}.card{padding:1rem;max-width:90%}.card h1{font-size:1.2rem}.page{padding:.5rem}}
