.controls{position:relative;left:auto;bottom:auto;z-index:120;width:auto;min-height:56px;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 0 0;transform:none;border:none;border-radius:0;background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.control-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;position:relative;width:56px;height:56px;min-width:56px;min-height:56px;border:none;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;flex-direction:column;gap:0;background:#f2f4f7;color:#111827;box-shadow:0 10px 24px #1018281f;transition:transform .15s ease,opacity .15s ease,background-color .15s ease}.control-btn.is-on{background:#eef2f6}.control-btn.is-off{background:#fee4e2}.control-btn img{width:28px;height:28px}.control-btn span:not(.control-btn__chat-icon):not(.control-btn__badge){position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.control-btn--chat{background:#e8f7ef}.control-btn__chat-icon{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center}.control-btn__chat-icon svg{width:28px;height:28px}.control-btn__badge{position:absolute;top:-5px;right:-5px;min-width:22px;height:22px;padding:0 6px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#f0c05a;color:#1d1710;border:2px solid #ffffff;box-shadow:0 8px 18px #00000029;font-size:11px;font-weight:900;line-height:1}.control-btn.end{background:#f04438}.control-btn:active{transform:scale(.96)}.control-btn:focus-visible{outline:2px solid #1c8d66;outline-offset:3px}.control-btn:disabled{opacity:.5}@media (max-width: 380px){.controls{min-height:52px;gap:7px}.control-btn{width:52px;height:52px;min-width:52px;min-height:52px}.control-btn img,.control-btn__chat-icon,.control-btn__chat-icon svg{width:25px;height:25px}}.call-timer{position:absolute;top:20px;left:50%;transform:translate(-50%);background:#0009;color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-variant-numeric:tabular-nums;letter-spacing:.5px}*{box-sizing:border-box}html,body,#root{margin:0;width:100%;min-height:100%;background:#fff;color:#111827;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea{font:inherit}.mobile-call{position:relative;width:100vw;min-height:100vh;min-height:100dvh;--call-side-space: 24px;--call-gap: 8px;--video-panel-height: min(395px, calc((100dvh - 158px)/2) );display:flex;flex-direction:column;align-items:center;gap:var(--call-gap);padding:24px 0 calc(env(safe-area-inset-bottom,0px) + 38px);background:#fff;border-radius:32px;overflow:hidden;touch-action:manipulation}.remote-container{position:relative;width:calc(100% - (var(--call-side-space) * 2));max-width:430px;height:var(--video-panel-height);min-height:220px;display:flex;align-items:stretch;justify-content:center;padding:0;overflow:hidden;border-radius:8px;background:linear-gradient(180deg,#090b0b0d,#090b0b42),#111716}.remote{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:#050606;overflow:hidden}.remote video{width:100%;height:100%;object-fit:contain;display:block}.remote-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;z-index:8;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:72px 24px 28px;text-align:center;background:linear-gradient(180deg,#0c100f94,#080a0af0),#101614}.remote-placeholder__avatar{width:72px;height:72px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:#dff7ec;color:#14352b;font-size:28px;font-weight:800;box-shadow:0 20px 70px #00000057}.remote-placeholder__label{margin:22px 0 8px;color:#75d6b1;font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.remote-placeholder h2{margin:0;max-width:320px;color:#fff;font-size:22px;line-height:1.12}.remote-placeholder__hint{max-width:320px;margin:12px 0 0;color:#f7fbfab8;font-size:15px;line-height:1.5}.call-topbar{position:absolute;top:10px;left:10px;right:10px;z-index:40;min-height:52px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 10px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:#080a0ab8;box-shadow:0 14px 42px #00000047;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.call-topbar .call-timer{position:static;transform:none;flex:0 0 auto;min-width:60px;padding:7px 8px;border-radius:8px;background:#ffffff14;color:#fff;font-size:13px;font-weight:800;text-align:center;letter-spacing:0;font-variant-numeric:tabular-nums;z-index:auto}.call-topbar__eyebrow{margin:0 0 3px;color:#f7fbfa99;font-size:9px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.call-topbar__title{margin:0;color:#fff;font-size:13px;line-height:1.15}.call-status{flex:0 0 auto;min-width:68px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:7px 8px;border-radius:8px;background:#ffffff14;color:#f7fbfa;font-size:10px;font-weight:800}.call-status span{width:8px;height:8px;border-radius:999px;background:#cbd5d1}.call-status--live span{background:#23c979;box-shadow:0 0 0 5px #23c97929}.call-status--reconnecting span,.call-status--connecting span,.call-status--joining span{background:#f0c05a}.call-status--disconnected span,.call-status--room-full span{background:#f15d5d}.status-overlay{position:absolute;top:72px;right:10px;z-index:50;display:flex;flex-direction:column;gap:10px}.remote-media-card{position:relative;z-index:55;display:flex;align-items:center;gap:6px;padding:6px;border-radius:8px;border:1px solid rgba(255,255,255,.16);background:#080a0ab8;box-shadow:0 12px 28px #00000047;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.remote-media-icon{width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.12)}.remote-media-icon.is-on{background:#23c97933}.remote-media-icon.is-off{background:#d64242d1}.remote-media-icon img{width:18px;height:18px}.status-icon{position:relative;z-index:35;min-height:42px;max-width:190px;padding:9px 11px;border-radius:8px;display:flex;align-items:center;gap:8px;justify-content:center;border:1px solid rgba(255,255,255,.16);box-shadow:0 12px 28px #00000047;color:#fff;font-size:12px;font-weight:800;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.status-icon--muted,.status-icon--video-off{background:#080a0ab8}.status-icon img{width:22px;height:22px;flex:0 0 auto}.status-icon span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-off-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:82px 24px 28px;background:#101614;color:#fff;font-size:18px;font-weight:800;text-align:center}.video-off-placeholder__icon{width:34px;height:34px;padding:7px;border-radius:8px;background:#ffffff1a}.local-container{position:relative;right:auto;bottom:auto;z-index:90;width:calc(100% - (var(--call-side-space) * 2));max-width:430px;height:var(--video-panel-height);min-height:220px;overflow:hidden;border-radius:8px;border:none;background:#151b1a;box-shadow:none}.local{width:100%;height:100%;display:block;overflow:hidden}.local video{width:100%;height:100%;display:block;object-fit:cover}.local-video-off{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#0e1211c7,#090b0be6),#151b1a}.local-video-off img{width:32px;height:32px;padding:7px;border-radius:8px;background:#ffffff1f}.local-container__label{position:absolute;left:8px;border-radius:8px;background:#080a0ab3;color:#fff;font-size:11px;font-weight:800;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.local-container__label{bottom:8px;padding:5px 8px}.local-media-badges{position:absolute;top:8px;left:8px;display:flex;gap:6px}.local-media-badge{width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:#080a0ab8;border:1px solid rgba(255,255,255,.14);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.local-media-badge img{width:17px;height:17px}.mobile-call--chat-open .local-container{top:auto;bottom:auto}.chat-drawer{position:fixed;left:10px;right:10px;bottom:calc(env(safe-area-inset-bottom,0px) + 112px);z-index:150;height:min(48vh,430px);display:flex;flex-direction:column;overflow:hidden;border-radius:8px;border:1px solid rgba(255,255,255,.16);background:#0d111061;color:#fff;box-shadow:0 24px 70px #00000085;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.chat-drawer__header{min-height:70px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 14px 12px;background:#080a0a47;border-bottom:1px solid rgba(255,255,255,.12)}.chat-drawer__eyebrow{color:#75d6b1;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.chat-drawer__title{margin-top:2px;font-size:19px;font-weight:800}.chat-drawer__close{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:42px;height:42px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:#ffffff14;color:#fff;font-size:18px;font-weight:800}.chat-drawer__body{flex:1;min-height:0;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px}.chat-drawer__empty{margin:auto 0;padding:16px;border-radius:8px;background:#080a0a57;color:#f7fbfab8;text-align:center;line-height:1.5}.chat-drawer__message{display:flex;flex-direction:column;gap:6px;max-width:84%}.chat-drawer__message.mine{align-self:flex-end;text-align:right}.chat-drawer__message.theirs{align-self:flex-start}.chat-drawer__bubble{padding:11px 13px;border-radius:8px;line-height:1.45;word-break:break-word}.chat-drawer__message.mine .chat-drawer__bubble{background:#1c8d66c7}.chat-drawer__message.theirs .chat-drawer__bubble{background:#080a0a7a}.chat-drawer__time{color:#f7fbfa94;font-size:11px}.chat-drawer__input{display:flex;gap:10px;padding:12px;background:#080a0a4d;border-top:1px solid rgba(255,255,255,.12)}.chat-drawer__input input{flex:1;min-width:0;min-height:46px;border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:12px 13px;background:#080a0a70;color:#fff;font-size:15px;outline:none}.chat-drawer__input input:focus{border-color:#75d6b1}.chat-drawer__input input::placeholder{color:#f7fbfa73}.chat-drawer__input button{-webkit-appearance:none;-moz-appearance:none;appearance:none;min-height:46px;border:none;border-radius:8px;padding:0 16px;background:#1c8d66;color:#fff;font-weight:800}.call-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:170;display:flex;align-items:center;justify-content:center;padding:18px;background:#060808b8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.call-sheet{width:min(100%,420px);overflow:hidden;border-radius:8px;border:1px solid rgba(255,255,255,.14);background:#111716;color:#fff;box-shadow:0 26px 90px #0000006b}.call-sheet--notice{width:min(100%,380px)}.call-sheet__header{padding:22px 20px 12px}.call-sheet__eyebrow{color:#75d6b1;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.call-sheet__title{margin:5px 0 0;font-size:24px;line-height:1.15}.call-sheet__description{margin:9px 0 0;color:#f7fbfab8;line-height:1.55}.call-sheet__rating{display:flex;justify-content:center;gap:8px;padding:8px 20px 18px}.call-sheet__star{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:46px;height:46px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff0f;color:#ffffff57;font-size:28px;line-height:1;font-weight:800}.call-sheet__star.active{color:#f0c05a;border-color:#f0c05a61;background:#f0c05a1f}.call-sheet__body{display:flex;flex-direction:column;gap:12px;padding:0 20px 18px}.call-sheet__body input,.call-sheet__body textarea{width:100%;border:1px solid rgba(255,255,255,.16);border-radius:8px;background:#ffffff14;color:#fff;padding:12px 14px;font-size:14px;outline:none}.call-sheet__body input:focus,.call-sheet__body textarea:focus{border-color:#75d6b1}.call-sheet__body textarea{resize:none}.call-sheet__actions{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px 22px}.call-sheet__ghost,.call-sheet__primary{-webkit-appearance:none;-moz-appearance:none;appearance:none;min-height:44px;border-radius:8px;padding:12px 16px;color:#fff;font-weight:800}.call-sheet__ghost{border:1px solid rgba(255,255,255,.18);background:#ffffff14}.call-sheet__primary{border:none;background:#1c8d66}.call-sheet__primary:disabled{opacity:.45}.mobile-call--ended{display:flex;min-height:100vh;min-height:100dvh;align-items:center;justify-content:center;padding:24px;color:#fff}.mobile-call__ended-card{width:min(92vw,380px);border-radius:8px;padding:28px;background:#111716;border:1px solid rgba(255,255,255,.12);text-align:center;box-shadow:0 28px 80px #0000006b}.mobile-call__ended-icon{width:58px;height:58px;margin:0 auto 16px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:#23c979;color:#072015;font-size:24px;font-weight:900}.mobile-call__ended-card h1{margin:0 0 8px;font-size:26px}.mobile-call__ended-card p{margin:0 0 20px;color:#f7fbfab8}.mobile-call__ended-card button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;border-radius:8px;padding:14px 18px;background:#1c8d66;color:#fff;font-weight:800}.no-scroll{overflow:hidden!important;height:100vh!important;height:100dvh!important;touch-action:none!important}@media (min-width: 720px){.mobile-call{--video-panel-height: min(395px, calc((100dvh - 158px)/2) )}.chat-drawer{left:50%;right:auto;width:min(460px,calc(100vw - 20px));transform:translate(-50%)}}@media (max-width: 380px){.mobile-call{--call-side-space: 18px;--video-panel-height: min(395px, calc((100dvh - 144px)/2) );padding-top:18px}.call-topbar{min-height:58px;padding:10px}.call-topbar__title{font-size:15px}.call-status{min-width:74px;padding:8px;font-size:11px}.call-topbar .call-timer{min-width:58px;padding:8px;font-size:12px}.remote-placeholder h2{font-size:24px}.chat-drawer{bottom:calc(env(safe-area-inset-bottom,0px) + 104px)}}
