/* FuMeet — واجهة العميل والغرفة. هوية فيودكس: داكن + بنفسجي #6A5BFF. RTL. */
@font-face{font-family:'Lato';src:url('/static/fonts/lato-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Lato';src:url('/static/fonts/lato-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Lato';src:url('/static/fonts/lato-900.woff2') format('woff2');font-weight:900;font-display:swap}
:root{
  --bg:#0d0d16; --bg2:#15151f; --panel:#1b1b27; --panel2:#222232;
  --line:#2c2c3d; --tx:#e7e7f2; --tx2:#9a9ab4; --accent:#6A5BFF; --accent2:#8b7dff;
  --ok:#2EE56B; --warn:#ffb020; --bad:#ff5470; --r:14px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:var(--bg);color:var(--tx);
  font-family:'Lato',sans-serif;-webkit-font-smoothing:antialiased}
body{direction:rtl}
button{font-family:inherit;cursor:pointer;border:0}
a{color:var(--accent2);text-decoration:none}
.hidden{display:none!important}

/* خلفية متوهّجة */
.glow{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(1100px 600px at 80% -10%,rgba(106,91,255,.18),transparent 60%),
             radial-gradient(900px 500px at 10% 110%,rgba(106,91,255,.12),transparent 60%)}

/* ─── صفحة الترحيب ─── */
#welcome{position:relative;z-index:1;min-height:100%;display:flex;align-items:center;
  justify-content:center;padding:28px}
.wcard{width:min(960px,100%);background:linear-gradient(180deg,var(--panel),var(--bg2));
  border:1px solid var(--line);border-radius:22px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5);display:grid;grid-template-columns:1.05fr .95fr}
@media(max-width:760px){.wcard{grid-template-columns:1fr}}
.wleft{padding:34px 34px 30px}
.wbrand{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.wbrand img{height:30px}
.wbrand .nm{font-weight:900;font-size:22px;letter-spacing:.3px}
.wbrand .nm span{color:var(--accent2)}
.wtitle{font-size:26px;font-weight:900;margin:4px 0 6px;line-height:1.25}
.wsub{color:var(--tx2);font-size:15px;line-height:1.7;margin-bottom:20px}
.minfo{background:var(--panel2);border:1px solid var(--line);border-radius:var(--r);
  padding:14px 16px;margin-bottom:18px;font-size:14px}
.minfo .row{display:flex;justify-content:space-between;padding:5px 0;color:var(--tx2)}
.minfo .row b{color:var(--tx);font-weight:700}
.recbadge{display:inline-flex;align-items:center;gap:7px;background:rgba(255,84,112,.12);
  color:#ff9bb0;border:1px solid rgba(255,84,112,.3);border-radius:10px;padding:8px 12px;
  font-size:13px;margin-bottom:16px}
.recbadge .dot{width:9px;height:9px;border-radius:50%;background:var(--bad);
  box-shadow:0 0 0 0 rgba(255,84,112,.6);animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,84,112,.5)}70%{box-shadow:0 0 0 9px rgba(255,84,112,0)}100%{box-shadow:0 0 0 0 rgba(255,84,112,0)}}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--tx2);
  margin:6px 0 18px;line-height:1.6}
.consent input{margin-top:3px;width:17px;height:17px;accent-color:var(--accent)}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;color:var(--tx2);margin-bottom:6px}
.field input{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--tx);
  border-radius:11px;padding:13px 14px;font-size:15px;outline:none}
.field input:focus{border-color:var(--accent)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;width:100%;
  background:var(--accent);color:#fff;font-weight:700;font-size:16px;border-radius:12px;
  padding:14px;transition:.15s;box-shadow:0 8px 24px rgba(106,91,255,.35)}
.btn:hover{background:var(--accent2)}
.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--tx);box-shadow:none}
.btn.ghost:hover{background:var(--panel2)}
.gbtn{background:#fff;color:#111;font-weight:700;margin-bottom:12px}
.gbtn:hover{background:#f0f0f0}
.orsep{display:flex;align-items:center;gap:12px;color:var(--tx2);font-size:12px;margin:14px 0}
.orsep::before,.orsep::after{content:'';flex:1;height:1px;background:var(--line)}
.legal{margin-top:18px;font-size:12px;color:var(--tx2);text-align:center}
/* معاينة الجهاز */
.wright{background:#0a0a12;display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:26px;gap:14px}
.preview{width:100%;aspect-ratio:4/3;background:#000;border-radius:16px;overflow:hidden;
  position:relative;border:1px solid var(--line)}
.preview video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}
.preview .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:8px;color:var(--tx2);font-size:13px}
.preview .avi{width:74px;height:74px;border-radius:50%;background:var(--accent);
  display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:900;color:#fff}
.devrow{display:flex;gap:10px;width:100%}
.devbtn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--panel2);border:1px solid var(--line);color:var(--tx);border-radius:11px;
  padding:11px;font-size:13px}
.devbtn.off{background:rgba(255,84,112,.12);border-color:rgba(255,84,112,.3);color:#ff9bb0}
.devbtn svg{width:18px;height:18px}

/* ─── الغرفة ─── */
#room{position:fixed;inset:0;z-index:2;background:#0a0a12;display:none;flex-direction:column}
#room.on{display:flex}
.rtop{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#0d0d16;
  border-bottom:1px solid var(--line)}
.rtop .rt-logo{height:22px;width:auto}
.rtop .rt-title{font-weight:700;font-size:14px}
.rtop .rt-sp{flex:1}
.rt-btn{display:inline-flex;align-items:center;gap:6px;background:var(--panel2);border:1px solid var(--line);
  color:var(--tx);border-radius:10px;padding:7px 12px;font-size:12.5px;font-weight:700;cursor:pointer;font-family:inherit}
.rt-btn:hover{background:#2a2a3d}
.rt-btn.ghost{background:transparent}
.rt-btn .rdot{width:9px;height:9px;border-radius:50%;background:var(--bad);flex:0 0 auto}
.rt-btn.rec{background:rgba(255,84,112,.16);border-color:rgba(255,84,112,.4);color:#ff9bb0}
.rt-btn.rec .rdot{animation:pulse 1.4s infinite}
.rec-ind{display:none;align-items:center;gap:7px;background:rgba(255,84,112,.14);
  color:#ff9bb0;border-radius:9px;padding:6px 11px;font-size:12px}
.rec-ind.on{display:inline-flex}
.rec-ind .dot{width:8px;height:8px;border-radius:50%;background:var(--bad);animation:pulse 1.4s infinite}
.rt-time{color:var(--tx2);font-size:13px;font-variant-numeric:tabular-nums}

/* المسرح: خلفية مكتب فيوسبيس + منصة كبيرة وسط + شريط صور سفلي */
.stage{flex:1;display:flex;min-height:0;
  background:linear-gradient(rgba(10,10,18,.70),rgba(10,10,18,.85)),url('/static/room-bg.jpg') center/cover no-repeat}
.stagewrap{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0}
#r-stage{flex:1;position:relative;display:flex;align-items:center;justify-content:center;padding:16px;min-height:0}
#r-stage video{max-width:100%;max-height:100%;border-radius:16px;object-fit:contain;background:#000;box-shadow:0 20px 60px rgba(0,0,0,.55)}
#r-stage.local video{transform:scaleX(-1)}
#r-stage .snm{position:absolute;bottom:24px;right:24px;background:rgba(13,13,20,.8);color:#fff;
  font-size:13px;padding:6px 14px;border-radius:10px;display:flex;align-items:center;gap:7px}
.stage-ph{display:flex;flex-direction:column;align-items:center;gap:14px;color:var(--tx2);font-size:14px;text-align:center}
.stage-ph img{height:40px;opacity:.85}
.grid{display:flex;gap:10px;padding:12px 14px;overflow-x:auto;overflow-y:hidden;align-items:center;
  justify-content:center;flex-wrap:wrap;max-height:40%;flex:0 0 auto}
.tile{position:relative;background:#11111c;border-radius:12px;overflow:hidden;cursor:pointer;
  border:2px solid transparent;width:152px;height:96px;flex:0 0 auto;transition:.12s}
.tile:hover{transform:translateY(-2px)}
.tile.speaking{border-color:var(--ok)}
.tile.onstage{border-color:var(--accent)}
.tile video{width:100%;height:100%;object-fit:cover;background:#000}
.tile.local video{transform:scaleX(-1)}
.tile .nm{position:absolute;bottom:5px;right:5px;background:rgba(13,13,20,.8);
  color:#fff;font-size:11px;padding:3px 8px;border-radius:7px;display:flex;align-items:center;gap:5px;max-width:92%}
.tile .nm .who{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tile .mic-off{color:var(--bad)}
.tile .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.tile .ph .avi{width:46px;height:46px;border-radius:50%;background:var(--accent);
  display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;color:#fff}
.tile .hand{position:absolute;top:5px;left:5px;font-size:15px;animation:wave 1s infinite}
@keyframes wave{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}
.tile .react{position:absolute;top:5px;right:5px;font-size:22px;animation:fly 2.4s ease-out forwards}
@keyframes fly{0%{transform:translateY(0);opacity:1}100%{transform:translateY(-60px);opacity:0}}
/* بطاقة معلومات المشارك عند النقر على صورته */
.pinfo{position:fixed;z-index:11;background:var(--panel);border:1px solid var(--line);border-radius:14px;
  padding:18px;min-width:230px;box-shadow:0 16px 44px rgba(0,0,0,.55)}
.pinfo .pi-av{width:60px;height:60px;border-radius:50%;background:var(--accent);display:flex;align-items:center;
  justify-content:center;font-size:24px;font-weight:900;color:#fff;margin:0 auto 10px}
.pinfo .pi-nm{font-weight:800;font-size:16px;text-align:center}
.pinfo .pi-rl{color:var(--tx2);font-size:13px;text-align:center;margin-top:3px}
.pinfo .pi-x{position:absolute;top:8px;left:10px;color:var(--tx2);cursor:pointer;font-size:18px}

/* لوحة جانبية (شات/مشاركون) */
.side{width:320px;background:#0d0d16;border-right:1px solid var(--line);
  display:none;flex-direction:column}
.side.on{display:flex}
.side .sh{display:flex;border-bottom:1px solid var(--line)}
.side .sh button{flex:1;background:transparent;color:var(--tx2);padding:13px;font-size:13px;
  font-weight:700;border-bottom:2px solid transparent}
.side .sh button.act{color:var(--tx);border-bottom-color:var(--accent)}
.side .sbody{flex:1;overflow-y:auto;padding:12px}
.cmsg{margin-bottom:12px;font-size:13px;line-height:1.55}
.cmsg .who{font-weight:700;color:var(--accent2);font-size:12px}
.cmsg .bd{color:var(--tx);word-break:break-word}
.cmsg.sys{color:var(--tx2);font-style:italic;font-size:12px}
.pli{display:flex;align-items:center;gap:10px;padding:8px 4px;font-size:13px}
.pli .avi{width:30px;height:30px;border-radius:50%;background:var(--accent2);display:flex;
  align-items:center;justify-content:center;font-weight:900;color:#fff;font-size:13px}
.pli .pr{font-size:11px;color:var(--tx2);margin-right:auto}
.cinput{display:flex;gap:8px;padding:10px;border-top:1px solid var(--line)}
.cinput input{flex:1;background:var(--bg);border:1px solid var(--line);color:var(--tx);
  border-radius:10px;padding:10px;font-size:14px;outline:none}
.cinput button{background:var(--accent);color:#fff;border-radius:10px;padding:0 14px;font-weight:700}

/* شريط التحكم السفلي */
.controls{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;
  background:#0d0d16;border-top:1px solid var(--line);flex-wrap:wrap}
.cbtn{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--panel2);
  border:1px solid var(--line);color:var(--tx);border-radius:13px;padding:10px 14px;
  min-width:62px;font-size:11px;transition:.12s}
.cbtn:hover{background:#2a2a3d}
.cbtn svg{width:22px;height:22px}
.cbtn.off{background:rgba(255,84,112,.14);border-color:rgba(255,84,112,.35);color:#ff9bb0}
.cbtn.active{background:rgba(106,91,255,.18);border-color:var(--accent);color:var(--accent2)}
.cbtn.leave{background:var(--bad);border-color:var(--bad);color:#fff}
.cbtn.leave:hover{background:#e0405e}
.reactbar{position:absolute;bottom:80px;left:50%;transform:translateX(-50%);display:none;
  gap:6px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:8px 10px;
  box-shadow:0 10px 30px rgba(0,0,0,.5)}
.reactbar.on{display:flex}
.reactbar button{background:transparent;font-size:24px;padding:4px 6px;border-radius:8px}
.reactbar button:hover{background:var(--panel2)}
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);z-index:9;
  background:var(--panel);border:1px solid var(--line);color:var(--tx);border-radius:12px;
  padding:12px 18px;font-size:14px;box-shadow:0 10px 30px rgba(0,0,0,.5);display:none}
.toast.on{display:block}
/* شاشة الانتظار للضيف قبل قبول المضيف (منطقة الانتظار) */
.waitwrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--tx2)}
.spin{width:42px;height:42px;border:3px solid var(--line);border-top-color:var(--accent);
  border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
