    /* Светлая карточная тема по макету: белые карточки на сером фоне,
       бежевые плитки-акценты, зелёный/красный/лавандовый/голубой для действий. */
    :root {
      --bg: #eef0f4;
      --card: #ffffff;
      --card-tint: #f6f7f9;
      --beige: #f7f1e4;
      --beige-border: #eadfc8;
      --border: #e4e6eb;
      --text: #1d1f24;
      --muted: #6f7683;
      --green: #33a35c;
      --red: #e2574b;
      --lav-bg: #edeafb;
      --lav-text: #6558c9;
      --shadow: 0 1px 2px rgba(23, 25, 29, .06), 0 4px 14px rgba(23, 25, 29, .05);
    }
    html.dark {
      color-scheme: dark;
      --bg: #0f1218;
      --card: #171b23;
      --card-tint: #202632;
      --beige: #252331;
      --beige-border: #3b3748;
      --border: #2c3340;
      --text: #f1f4f8;
      --muted: #9da6b4;
      --green: #58d27d;
      --red: #ff7066;
      --lav-bg: #2b2742;
      --lav-text: #c3b8ff;
      --shadow: 0 1px 2px rgba(0, 0, 0, .28), 0 8px 22px rgba(0, 0, 0, .24);
    }
    * { box-sizing: border-box; }
    body { font-family: -apple-system, system-ui, "Segoe UI", Roboto, sans-serif;
           max-width: 720px; margin: 0 auto; padding: 20px 14px 48px;
           color: var(--text); background: var(--bg); text-align: left;
           transition: background .18s ease, color .18s ease; }

    /* Шапка */
    #topBar { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; margin-bottom: 4px; }
    #appIcon { width: 56px; height: 56px; border-radius: 16px; background: var(--beige);
               border: 1px solid var(--beige-border); display: flex; align-items: center;
               justify-content: center; font-size: 26px; flex: none; }
    #titleBox { flex: 1 1 150px; min-width: 0; }
    h1 { font-size: 24px; margin: 0; line-height: 1.2; }
    #subTitle { font-size: 13px; color: var(--muted); margin-top: 2px; }
    .pill { background: var(--card); border: 1px solid var(--border); border-radius: 999px;
            padding: 6px 12px; font-size: 14px; font-weight: 600; white-space: nowrap; }
    #themeBtn { width: 42px; height: 42px; border-radius: 50%; padding: 0; flex: none;
                display: flex; align-items: center; justify-content: center;
                background: var(--card); color: var(--text); border: 1px solid var(--border);
                font-size: 19px; line-height: 1; box-shadow: var(--shadow); }
    #themeBtn:active { transform: scale(.96); }
    #themeBtn:focus-visible { outline: 2px solid #b9d8c5; outline-offset: 2px; }
    #langSelect { height: 42px; border-radius: 999px; padding: 0 12px;
                  flex: none; background: var(--card); color: var(--text);
                  border: 1px solid var(--border); box-shadow: var(--shadow);
                  font-size: 14px; font-weight: 700; cursor: pointer; }
    #langSelect:focus-visible { outline: 2px solid #b9d8c5; outline-offset: 2px; }

    /* Карточки */
    .card { background: var(--card); border: 1px solid var(--border); border-radius: 16px;
            padding: 14px; margin: 12px 0; box-shadow: var(--shadow);
            transition: background .18s ease, border-color .18s ease; }
    .cardHead { display: flex; align-items: center; justify-content: space-between;
                gap: 8px; margin-bottom: 10px; }
    .cardHead b { font-size: 16px; }
    .cardHead .pill { padding: 3px 10px; font-size: 12px; background: var(--card-tint); }
    .cardNote { font-size: 12px; color: var(--muted); }
    .iconCircle { width: 44px; height: 44px; border-radius: 50%; flex: none; display: flex;
                  align-items: center; justify-content: center; font-size: 20px;
                  background: #e8f4ec; }
    .row { display: flex; align-items: center; gap: 12px; }
    html.dark .iconCircle { background: #1f3429; }
    html.dark #inviteCard .iconCircle { background: #232d3d; }
    html.dark #chatEmpty .iconCircle { background: #222733; }

    #statusCard .statusText { min-width: 0; }
    #status b { display: block; font-size: 16px; }
    #status span { color: var(--muted); font-size: 14px; }
    #meetTimer { font-size: 13px; color: var(--muted); margin-top: 2px; }

    #nickRow { margin: 12px 0; }
    #nickInput { font-size: 16px; padding: 12px 14px; border: 1px solid var(--border);
                 border-radius: 12px; background: var(--card); color: var(--text); width: 100%; }
    #nickInput:focus { outline: 2px solid #b9d8c5; border-color: var(--green); }

    /* Кнопки — сетка 2 колонки, широкие действия на всю ширину */
    #controls { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
    button { font-size: 15px; font-weight: 600; padding: 14px 10px; border: 0;
             border-radius: 14px; cursor: pointer; color: #fff; box-shadow: var(--shadow); }
    button:disabled { opacity: .45; cursor: default; box-shadow: none; }
    #joinBtn  { background: var(--green); }
    #leaveBtn { background: var(--red); }
    #camBtn, #switchCamBtn { background: var(--lav-bg); color: var(--lav-text); }
    #camBtn.on { background: #ffe9d2; color: #b4691e; }
    #screenBtn { grid-column: 1 / -1; background: linear-gradient(90deg, #79b6d6, #4f94ba); }
    #screenBtn.on { background: #ffe9d2; color: #b4691e; }
    #micBtn { grid-column: 1 / -1; background: #e6f0ef; color: #33726d; }
    #micBtn.off { background: #ffe9d2; color: #b4691e; }
    #soundBtn { grid-column: 1 / -1; background: #4e7fa8; display: none; }

    /* Пригласительная ссылка */
    #inviteCard { color: inherit; display: flex; width: 100%; text-align: left; align-items: center;
                  font: inherit; cursor: pointer; }
    #inviteCard:focus-visible { outline: 2px solid #b9d8c5; outline-offset: 2px; }
    #inviteCard .iconCircle { background: #e9eef8; }
    .invTitle { font-weight: 600; font-size: 15px; }
    .invSub { font-size: 13px; color: var(--muted); margin-top: 2px; }
    #inviteCard .chev { margin-left: auto; color: var(--muted); font-size: 22px; flex: none; }

    /* Участники */
    #people { list-style: none; padding: 0; margin: 0; }
    #people li { padding: 10px 12px; margin: 8px 0; border-radius: 12px; background: var(--card-tint);
                 border: 1px solid var(--border); font-size: 15px; display: flex; flex-wrap: wrap;
                 align-items: center; justify-content: space-between; gap: 4px 8px; }
    .speakIcon { visibility: hidden; margin-left: 6px; }
    #people li.speaking .speakIcon { visibility: visible; }
    #people li.speaking { border-color: var(--green); box-shadow: 0 0 0 2px rgba(51, 163, 92, .25); }
    .muteBtn { background: #aab0bd; font-size: 12px; padding: 7px 12px; border-radius: 10px; }
    .muteBtn.on { background: #e09c3f; }
    .netStat { flex-basis: 100%; font-size: 11px; color: var(--muted); }
    /* Личная громкость участника (скрыта на iOS — там audio.volume не работает) */
    .volSlider { flex-basis: 100%; width: 100%; margin: 2px 0 0; accent-color: var(--green); }
    .emptyBox { display: flex; gap: 12px; align-items: center; }
    .emptyBox .iconCircle { background: var(--card-tint); }
    .ebTitle { font-weight: 600; font-size: 15px; }
    .ebSub { font-size: 13px; color: var(--muted); margin-top: 2px; }

    /* Видео */
    #videos { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin: 12px 0 0; }
    .peerVideo { width: clamp(150px, 28vw, 230px); aspect-ratio: 4 / 3; background: #22252b;
                 border: 1px solid var(--border); border-radius: 14px; object-fit: cover;
                 cursor: zoom-in; }
    /* Динамическая сетка: 1-2 видимых видео — крупно, 5+ — плиткой. */
    #videos.solo .peerVideo:not(.zoomed) { width: clamp(240px, 44%, 460px); }
    #videos.many .peerVideo:not(.zoomed) { width: clamp(110px, 22%, 170px); }
    /* Клик/тап по видео — закрепить: оно крупно сверху, остальные маленькие внизу. */
    .peerVideo.zoomed { order: -1; width: 100%; max-width: 100%; max-height: 72vh;
                        object-fit: contain; cursor: zoom-out; }
    #videos.hasPinned .peerVideo:not(.zoomed) { width: clamp(72px, 17vw, 120px); }
    /* Подсветка рамки у говорящего (по уровню голоса) */
    .peerVideo.talk { box-shadow: 0 0 0 3px var(--green), 0 0 14px rgba(51, 163, 92, .5); }
    #localPreview { outline: 2px solid #8a7ddb; }
    #localPreview.selfie { transform: scaleX(-1); } /* зеркалим только селфи-превью */
    .peerVideo.mirrored { transform: scaleX(-1); }  /* селфи пира — зеркалим и у зрителей */
    #localScreenPreview { outline: 2px solid #4f94ba; } /* превью экрана — без зеркала */

    /* Устройства и статус */
    #devTiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
    .tile { background: var(--beige); border: 1px solid var(--beige-border); border-radius: 12px;
            padding: 10px; display: flex; gap: 8px; align-items: center; min-width: 0;
            transition: background .18s ease, border-color .18s ease, color .18s ease; }
    .tile.ok { background: #e4f5ea; border-color: #abd9ba; }
    .tile.warn { background: #fff3da; border-color: #f0c77f; }
    .tile.bad { background: #fdebea; border-color: #f1b6b1; }
    .tile.off { background: #f1f2f5; border-color: #dee2e8; }
    .tile.ok .tIcon, .tile.ok .tName, .tile.ok .tVal { color: var(--green); }
    .tile.warn .tIcon, .tile.warn .tName, .tile.warn .tVal { color: #b4691e; }
    .tile.bad .tIcon, .tile.bad .tName, .tile.bad .tVal { color: var(--red); }
    .tile.off .tIcon, .tile.off .tName, .tile.off .tVal { color: var(--muted); }
    .tIcon { font-size: 18px; flex: none; }
    .tName { font-weight: 600; font-size: 13px; display: block; }
    .tVal { color: var(--muted); font-size: 12px; display: block; }

    /* Временный чат */
    #chatEmpty { background: var(--beige); border: 1px solid var(--beige-border);
                 border-radius: 12px; padding: 12px; }
    #chatEmpty .iconCircle { background: #fff; }
    #messages { max-height: min(50vh, 460px); max-height: min(50dvh, 460px);
                overflow-y: auto; padding: 4px 2px; display: flex;
                flex-direction: column; gap: 8px; }
    .msg { max-width: 82%; padding: 8px 10px; border-radius: 12px; background: var(--card-tint);
           border: 1px solid var(--border); align-self: flex-start; word-wrap: break-word;
           overflow-wrap: anywhere; }
    .msg.mine { align-self: flex-end; background: #e3f2e8; border-color: #cfe6d8; }
    .msg .meta { font-size: 11px; color: var(--muted); margin-bottom: 3px; }
    .replyQuote { border-left: 3px solid var(--green); margin: 2px 0 6px; padding: 5px 8px;
                  border-radius: 8px; background: rgba(51, 163, 92, .08); cursor: pointer; }
    .replyQuote .rqName { font-size: 11px; font-weight: 700; color: var(--green); margin-bottom: 2px; }
    .replyQuote .rqText { font-size: 12px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .msg .text { font-size: 15px; white-space: pre-wrap; }
    .msg .photo { max-width: 100%; border-radius: 8px; margin-top: 4px; cursor: pointer; display: block; }
    /* Системные сообщения («X зашёл», «Y выключил микрофон») — по центру, приглушённо */
    .sysMsg { align-self: center; font-size: 12px; color: var(--muted); }
    .msg .text.encLocked { font-style: italic; color: var(--muted); }
    /* Реакции-эмодзи под сообщением */
    .reactBar { display: flex; gap: 6px; margin-top: 4px; }
    .reactBtn { background: transparent; border: 1px solid var(--border); border-radius: 999px;
                font-size: 12px; padding: 2px 8px; color: var(--text); box-shadow: none; font-weight: 400; }
    .reactBtn.on { background: #e3f2e8; border-color: var(--green); }
    .replyBtn { background: transparent; border: 1px solid var(--border); border-radius: 999px;
                font-size: 12px; padding: 2px 8px; color: var(--muted); box-shadow: none; font-weight: 600; }
    #replyDraft { display: none; margin-top: 8px; padding: 8px 10px; border: 1px solid var(--border);
                  border-left: 3px solid var(--green); border-radius: 12px; background: var(--card-tint);
                  align-items: center; gap: 8px; }
    #replyDraft.show { display: flex; }
    #replyDraftText { flex: 1; min-width: 0; }
    #replyDraftText b { display: block; font-size: 12px; color: var(--green); }
    #replyDraftText span { display: block; font-size: 12px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    #replyCancelBtn { flex: none; background: transparent; color: var(--muted); border: 1px solid var(--border);
                      box-shadow: none; border-radius: 50%; width: 30px; height: 30px; padding: 0; }
    /* min-height резервирует строку, чтобы чат не «прыгал» при появлении индикатора */
    #typing { min-height: 18px; margin: 4px 2px 0; color: var(--muted);
              font-size: 12px; font-style: italic; }
    #chatForm { display: flex; gap: 8px; margin-top: 8px; align-items: center; }
    #chatMeta { display: flex; justify-content: flex-end; margin: 4px 2px 0;
                font-size: 12px; color: var(--muted); }
    #chatCount.warn { color: #b4691e; }
    #chatCount.limit { color: var(--red); }
    #chatInputWrap { position: relative; flex: 1; min-width: 0; }
    #chatInputWrap .emo { position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
                          font-size: 16px; opacity: .55; pointer-events: none; }
    /* ≥16px обязательно: при меньшем шрифте iOS Safari сам зумит страницу на фокусе поля. */
    #chatText { width: 100%; font-size: 16px; padding: 12px 12px 12px 38px;
                border: 1px solid var(--border); border-radius: 12px; background: var(--card);
                color: var(--text); }
    #photoBtn, #sendBtn { font-size: 17px; padding: 12px 14px; border-radius: 12px; flex: none; }
    #photoBtn { background: var(--card-tint); color: var(--text); border: 1px solid var(--border); }
    html.dark #photoBtn { background: var(--card-tint); color: var(--text); }
    #sendBtn { background: var(--green); }

    html.dark #nickInput,
    html.dark #chatText { background: #12161d; color: var(--text); border-color: #333d4a; }
    html.dark #joinBtn,
    html.dark #sendBtn { background: #23864b; color: #fff; }
    html.dark #leaveBtn { background: #b9473f; color: #fff; }
    html.dark #camBtn,
    html.dark #switchCamBtn { background: #282344; color: #d8d1ff; }
    html.dark #camBtn.on,
    html.dark #screenBtn.on,
    html.dark #micBtn.off { background: #4a3421; color: #ffd3a3; }
    html.dark #screenBtn { background: linear-gradient(90deg, #256989, #19536f); color: #fff; }
    html.dark #micBtn { background: #193c36; color: #9af1d7; }
    html.dark #soundBtn { background: #285f88; color: #fff; }
    html.dark .muteBtn { background: #384251; color: #eef3f8; }
    html.dark .muteBtn.on { background: #6b4822; color: #ffe1b6; }
    html.dark .tile.ok { background: #173426; border-color: #2f6b46; }
    html.dark .tile.warn { background: #3d2f17; border-color: #705021; }
    html.dark .tile.bad { background: #3a2022; border-color: #773c3d; }
    html.dark .tile.off { background: #202631; border-color: #333c4a; }
    html.dark .tile.warn .tIcon,
    html.dark .tile.warn .tName,
    html.dark .tile.warn .tVal { color: #ffd190; }
    html.dark #chatEmpty { background: var(--beige); border-color: var(--beige-border); }
    html.dark .msg.mine { background: #173b2a; border-color: #2b6b47; color: #edf8f0; }
    html.dark .msg.mine .meta { color: #b6c4bd; }
    html.dark .reactBtn.on { background: #173b2a; border-color: var(--green); color: #edf8f0; }
    html.dark .replyQuote { background: rgba(88, 210, 125, .10); }
    html.dark #replyDraft { background: var(--card-tint); }
    html.dark #chatCount.warn { color: #ffd190; }

    .hint { color: var(--muted); font-size: 13px; margin-top: 20px; line-height: 1.5; text-align: center; }

    /* --- Предпросмотр камеры перед включением --- */
    #camModal { position: fixed; inset: 0; z-index: 50; background: rgba(20, 22, 26, .5);
                display: flex; align-items: center; justify-content: center; padding: 16px; }
    #camModalBox { background: var(--card); border: 1px solid var(--border); border-radius: 16px;
                   padding: 16px; width: min(100%, 420px); box-shadow: 0 10px 34px rgba(20, 22, 26, .35); }
    #camModalBox p { margin: 0 0 10px; font-size: 14px; }
    #camModalPreview { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 12px;
                       background: #22252b; }
    #camModalPreview.selfie { transform: scaleX(-1); }
    #camModalBtns { display: flex; gap: 8px; justify-content: center; margin-top: 12px; }
    #camOkBtn { background: var(--green); }
    #camCancelBtn { background: #aab0bd; }
    html.dark #camOkBtn { background: #23864b; color: #fff; }
    html.dark #camCancelBtn { background: #384251; color: #eef3f8; }

    /* --- Телефоны: компактнее отступы, видео крупнее --- */
    @media (max-width: 480px) {
      body { padding: 12px 10px 32px; }
      .peerVideo { width: clamp(130px, 44vw, 220px); }
      #messages { max-height: 50vh; max-height: 50dvh; }
    }
