/* averyx — dark gamer-luxury. Токены в :root, без хардкода палитры по месту. */

/* ====================================================================
   Шрифты — self-hosted (работают в РФ без внешних CDN).
   Display: Unbounded (характерный гео-гротеск, бренд/заголовки).
   Body: Onest (чистая современная кириллица).
   ==================================================================== */
@font-face { font-family:"Unbounded"; font-weight:700; font-display:swap;
  src:url("fonts/unbounded-cyr-700.woff2") format("woff2");
  unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116; }
@font-face { font-family:"Unbounded"; font-weight:700; font-display:swap;
  src:url("fonts/unbounded-latin-700.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+FEFF,U+FFFD; }
@font-face { font-family:"Unbounded"; font-weight:800; font-display:swap;
  src:url("fonts/unbounded-cyr-800.woff2") format("woff2");
  unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116; }
@font-face { font-family:"Unbounded"; font-weight:800; font-display:swap;
  src:url("fonts/unbounded-latin-800.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+FEFF,U+FFFD; }
@font-face { font-family:"Onest"; font-weight:400; font-display:swap;
  src:url("fonts/onest-cyr-400.woff2") format("woff2");
  unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116; }
@font-face { font-family:"Onest"; font-weight:400; font-display:swap;
  src:url("fonts/onest-latin-400.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+FEFF,U+FFFD; }
@font-face { font-family:"Onest"; font-weight:500; font-display:swap;
  src:url("fonts/onest-cyr-500.woff2") format("woff2");
  unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116; }
@font-face { font-family:"Onest"; font-weight:500; font-display:swap;
  src:url("fonts/onest-latin-500.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+FEFF,U+FFFD; }
@font-face { font-family:"Onest"; font-weight:600; font-display:swap;
  src:url("fonts/onest-cyr-600.woff2") format("woff2");
  unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116; }
@font-face { font-family:"Onest"; font-weight:600; font-display:swap;
  src:url("fonts/onest-latin-600.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+FEFF,U+FFFD; }
@font-face { font-family:"Onest"; font-weight:700; font-display:swap;
  src:url("fonts/onest-cyr-700.woff2") format("woff2");
  unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116; }
@font-face { font-family:"Onest"; font-weight:700; font-display:swap;
  src:url("fonts/onest-latin-700.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2212,U+FEFF,U+FFFD; }

:root {
  /* Шрифтовые токены */
  --font-display: "Unbounded", "Segoe UI", system-ui, sans-serif;
  --font-body: "Onest", "Segoe UI", system-ui, -apple-system, sans-serif;

  /* Палитра — «тёмный люкс / неон-глоу»: near-black #0A0A0F + двойной акцент cyan↔violet. */
  --bg-0: oklch(11% 0.012 280);   /* near #0A0A0F */
  --bg-1: oklch(15% 0.018 278);
  --bg-2: oklch(20% 0.028 280);
  --surface: oklch(18% 0.03 282 / 0.55);          /* стекло */
  --surface-2: oklch(24% 0.04 285 / 0.45);
  --surface-line: oklch(60% 0.06 285 / 0.16);
  --surface-hi: oklch(95% 0.02 285 / 0.06);        /* верхний внутренний блик стекла */
  --text: oklch(96% 0.008 285);
  --text-dim: oklch(70% 0.025 285);

  --accent: oklch(82% 0.15 195);                   /* cyan */
  --accent-strong: oklch(74% 0.17 200);
  --accent-2: oklch(64% 0.21 292);                 /* violet */
  --accent-2-strong: oklch(58% 0.24 295);
  --speak: oklch(85% 0.16 188);                    /* неон при речи */
  --danger: oklch(64% 0.21 25);

  --radius-sm: 11px;
  --radius: 16px;
  --radius-lg: 24px;

  --space: clamp(1rem, 0.7rem + 1.2vw, 2rem);

  --text-hero: clamp(2.6rem, 1.4rem + 4.5vw, 4.3rem);

  --dur: 220ms;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);

  /* Двухцветное свечение — фирменная подпись неон-люкса */
  --grad-brand: linear-gradient(105deg, var(--accent), var(--accent-2));
  --glow-accent: 0 0 0 1px oklch(82% 0.15 195 / 0.35), 0 10px 34px oklch(64% 0.21 292 / 0.28);
  --glow-speak: 0 0 0 2px var(--speak), 0 0 22px oklch(85% 0.16 188 / 0.5), 0 0 46px oklch(64% 0.21 292 / 0.3);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  height: 100%;
}

body {
  font-family: var(--font-body);
  color: var(--text);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  background:
    radial-gradient(1100px 680px at 82% -12%, oklch(46% 0.16 200 / 0.20), transparent 58%),
    radial-gradient(950px 640px at 6% 112%, oklch(42% 0.2 292 / 0.22), transparent 56%),
    radial-gradient(700px 500px at 50% 50%, oklch(20% 0.03 282 / 0.4), transparent 70%),
    var(--bg-0);
  min-height: 100%;
  overflow: hidden;
}

/* Атрибут hidden должен побеждать display из классов (.lobby/.room и т.п.) */
[hidden] { display: none !important; }

/* ---------- Brand ---------- */

.brand { display: flex; align-items: center; gap: 0.6rem; }
.brand__mark {
  width: 1.6rem; height: 1.6rem; border-radius: 7px;
  background: conic-gradient(from 210deg, var(--accent), var(--accent-2), var(--accent-2-strong), var(--accent));
  box-shadow: var(--glow-accent);
}
.brand__name {
  font-family: var(--font-display);
  font-weight: 800; letter-spacing: -0.04em; margin: 0;
  background: linear-gradient(100deg, var(--text) 30%, var(--accent) 70%, var(--accent-2));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.brand--sm .brand__mark { width: 1.2rem; height: 1.2rem; }
.brand--sm .brand__name { font-size: 1.1rem; }

/* ---------- Lobby ---------- */

.lobby {
  display: grid; place-items: center;
  min-height: 100vh; padding: var(--space);
}
.lobby__card {
  position: relative;
  width: min(440px, 100%);
  padding: clamp(1.5rem, 1rem + 2vw, 2.75rem);
  background:
    linear-gradient(180deg, var(--surface-hi), transparent 40%),
    var(--surface);
  border: 1px solid var(--surface-line);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(22px) saturate(1.2);
  box-shadow:
    0 40px 100px oklch(0% 0 0 / 0.6),
    inset 0 1px 0 var(--surface-hi);
}
/* Неоновый ободок-подсветка по краю карты */
.lobby__card::before {
  content: ""; position: absolute; inset: -1px; border-radius: inherit; z-index: -1;
  padding: 1px; pointer-events: none;
  background: linear-gradient(135deg, oklch(82% 0.15 195 / 0.5), transparent 40%, oklch(64% 0.21 292 / 0.45));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
}
.lobby__card .brand__name { font-size: var(--text-hero); line-height: 1; }
.lobby__tag {
  color: var(--text-dim); font-size: 1.02rem; line-height: 1.5;
  margin: 0.9rem 0 1.8rem;
}
.lobby__tag strong { color: var(--text); }
.lobby__form { display: grid; gap: 1rem; }
.lobby__hint {
  margin: 1.4rem 0 0; font-size: 0.82rem; color: var(--text-dim);
  border-top: 1px solid var(--surface-line); padding-top: 1rem;
}

.field { display: grid; gap: 0.4rem; }
.field__label {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--text-dim); font-weight: 600;
}
.field__input {
  width: 100%; padding: 0.8rem 1rem;
  background: var(--bg-1); color: var(--text);
  border: 1px solid var(--surface-line); border-radius: var(--radius-sm);
  font-size: 1rem; transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.field__input:focus {
  outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 3px oklch(78% 0.16 200 / 0.18);
}

/* ---------- Buttons ---------- */

.btn {
  border: 0; border-radius: var(--radius-sm); cursor: pointer;
  font-size: 1rem; font-weight: 700; padding: 0.9rem 1.2rem;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), filter var(--dur) var(--ease);
}
.btn--primary {
  color: oklch(99% 0.01 285);
  background: var(--grad-brand);
  box-shadow: var(--glow-accent);
  text-shadow: 0 1px 8px oklch(20% 0.1 290 / 0.5);
}
.btn--primary:hover { transform: translateY(-2px); filter: brightness(1.08) saturate(1.1); box-shadow: 0 0 0 1px oklch(82% 0.15 195 / 0.5), 0 14px 44px oklch(64% 0.21 292 / 0.4); }
.btn--primary:active { transform: translateY(0); }
.btn--primary:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }

/* ---------- Room ---------- */

.room { display: flex; flex-direction: column; height: 100vh; }

.room__bar {
  display: flex; align-items: center; gap: var(--space);
  padding: 0.8rem var(--space);
  border-bottom: 1px solid var(--surface-line);
  background: oklch(18% 0.02 260 / 0.6); backdrop-filter: blur(12px);
}
.room__meta { margin-inline-start: auto; display: flex; align-items: center; gap: 0.6rem; }
.room__name { font-weight: 700; }
.room__count {
  display: inline-grid; place-items: center; min-width: 1.6rem; height: 1.6rem;
  padding: 0 0.4rem; border-radius: 999px;
  background: var(--bg-2); color: var(--text-dim); font-size: 0.82rem; font-weight: 700;
}
.room__status {
  font-size: 0.78rem; padding: 0.3rem 0.7rem; border-radius: 999px;
  background: var(--bg-1); color: var(--text-dim);
}
.room__status[data-state="connected"] { color: var(--speak); }
.room__status[data-state="connecting"] { color: var(--accent); }

/* ---------- Stage (bento tiles) ---------- */

.stage {
  flex: 1; min-height: 0; padding: var(--space);
  display: grid; gap: 0.9rem; align-content: center; justify-content: center;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  overflow: auto;
}

.tile {
  position: relative; aspect-ratio: 16 / 9; min-width: 280px;
  background: var(--bg-1); border: 1px solid var(--surface-line);
  border-radius: var(--radius); overflow: hidden;
  display: grid; place-items: center;
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.tile--speaking { box-shadow: var(--glow-speak); }
.tile--self { border-color: oklch(78% 0.16 200 / 0.5); }

.tile__video {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; background: #000;
}
.tile__video[hidden] { display: none; }

.tile__avatar {
  display: grid; place-items: center;
  width: 84px; height: 84px; border-radius: 50%;
  font-size: 2rem; font-weight: 800; color: var(--text);
  background: linear-gradient(140deg, var(--bg-2), oklch(30% 0.06 230));
  box-shadow: inset 0 0 0 1px var(--surface-line);
}

.tile__footer {
  position: absolute; inset-inline: 0; bottom: 0;
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.5rem 0.7rem;
  background: linear-gradient(transparent, oklch(0% 0 0 / 0.65));
}
.tile__name { font-weight: 600; font-size: 0.9rem; }
.tile__badges { margin-inline-start: auto; display: flex; gap: 0.3rem; }
.badge {
  font-size: 0.72rem; line-height: 1; padding: 0.25rem 0.45rem;
  border-radius: 999px; background: oklch(0% 0 0 / 0.5);
}
.badge--muted { color: var(--danger); }
.badge--share { color: var(--accent); }
.badge--speak { color: var(--speak); }
.badge[hidden] { display: none; }

/* ---------- Controls ---------- */

.controls {
  display: flex; justify-content: center; gap: 0.8rem;
  padding: var(--space);
  border-top: 1px solid var(--surface-line);
  background: oklch(18% 0.02 260 / 0.6); backdrop-filter: blur(12px);
}
.ctrl {
  display: grid; gap: 0.25rem; place-items: center;
  min-width: 76px; padding: 0.7rem 1rem; cursor: pointer;
  background: var(--bg-1); color: var(--text);
  border: 1px solid var(--surface-line); border-radius: var(--radius-sm);
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.ctrl:hover { transform: translateY(-2px); }
.ctrl:active { transform: translateY(0); }
.ctrl__icon { font-size: 1.3rem; }
.ctrl__label { font-size: 0.72rem; color: var(--text-dim); }
.ctrl[data-on="true"] { box-shadow: inset 0 0 0 1px var(--accent); }
.ctrl[data-on="false"] { opacity: 0.6; }
#shareBtn[data-on="true"] { box-shadow: inset 0 0 0 1px var(--accent); opacity: 1; }
.ctrl--danger:hover { background: oklch(30% 0.12 25); box-shadow: inset 0 0 0 1px var(--danger); }

/* ---------- Lobby error + settings ---------- */

.lobby__error {
  margin: 1rem 0 0; padding: 0.7rem 0.9rem;
  background: oklch(30% 0.1 25 / 0.35); border: 1px solid var(--danger);
  border-radius: var(--radius-sm); color: oklch(86% 0.08 25);
  font-size: 0.86rem; line-height: 1.4;
}

.settings { margin-top: 1.2rem; }
.settings__summary {
  cursor: pointer; font-size: 0.82rem; color: var(--text-dim);
  user-select: none; padding: 0.3rem 0;
}
.settings__summary:hover { color: var(--text); }
.settings .field { margin-top: 0.7rem; }
.settings__hint { margin: 0.5rem 0 0; font-size: 0.76rem; color: var(--text-dim); }

/* ---------- Mode pill (видимый режим голоса) ---------- */

.mode-pill {
  display: inline-flex; align-items: center; gap: 0.45rem;
  padding: 0.35rem 0.75rem; border-radius: 999px;
  background: var(--bg-1); border: 1px solid var(--surface-line);
  font-size: 0.8rem; font-weight: 700;
  transition: box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.mode-pill__dot {
  width: 0.6rem; height: 0.6rem; border-radius: 50%;
  background: var(--accent); transition: background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.mode-pill[data-mode="vad"] .mode-pill__dot { background: var(--speak); box-shadow: 0 0 8px var(--speak); }
.mode-pill[data-mode="ptt"] .mode-pill__dot { background: var(--text-dim); }
.mode-pill--live { border-color: var(--speak); box-shadow: var(--glow-speak); }
.mode-pill--live .mode-pill__dot { background: var(--speak); box-shadow: 0 0 10px var(--speak); }

/* ---------- PTT hint ---------- */

.ptt-hint {
  position: fixed; inset-inline: 0; bottom: 6.5rem;
  margin: 0 auto; width: max-content; max-width: 90vw;
  padding: 0.55rem 1.1rem; border-radius: 999px;
  background: oklch(20% 0.02 260 / 0.85); border: 1px solid var(--surface-line);
  backdrop-filter: blur(10px); color: var(--text-dim); font-size: 0.85rem;
  box-shadow: 0 10px 30px oklch(0% 0 0 / 0.4);
}
.ptt-hint kbd {
  padding: 0.15rem 0.5rem; border-radius: 6px;
  background: var(--bg-2); border: 1px solid var(--surface-line);
  color: var(--text); font-family: inherit; font-weight: 700;
}

/* ====================================================================
   Дискорд-подобная комната: сайдбар + основная зона
   ==================================================================== */

.room {
  display: grid;
  grid-template-columns: 72px 248px 1fr minmax(280px, 340px);
  height: 100vh;
}

/* ---------- Рейл серверов ---------- */
.rail {
  display: flex; flex-direction: column; align-items: center; gap: 0.6rem;
  padding: 0.8rem 0; background: oklch(11% 0.012 262);
  border-inline-end: 1px solid var(--surface-line);
}
.rail__item {
  display: grid; place-items: center;
  width: 48px; height: 48px; border-radius: 16px; cursor: pointer;
  background: var(--bg-1); color: var(--text); font-size: 1.2rem; border: 0;
  transition: border-radius var(--dur) var(--ease), background var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.rail__item:hover { border-radius: 14px; transform: translateY(-1px); }
.rail__item--logo { background: transparent; }
.rail__item--logo .brand__mark { width: 44px; height: 44px; border-radius: 15px; }
.rail__item--active { background: linear-gradient(140deg, var(--accent), var(--accent-strong)); color: oklch(18% 0.02 260); border-radius: 14px; }
.rail__sep { width: 28px; height: 2px; border-radius: 2px; background: var(--surface-line); }
.rail__leave { margin-top: auto; color: var(--danger); }
.rail__leave:hover { background: oklch(30% 0.12 25); border-radius: 14px; }

/* ---------- Каналы ---------- */
.sidebar__scroll { flex: 1; min-height: 0; overflow: auto; padding: 0.6rem 0.5rem; }
.chan-group {
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.09em;
  color: var(--text-dim); font-weight: 700; padding: 0.4rem 0.6rem 0.3rem;
}
.chan {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.5rem 0.6rem; border-radius: 8px; cursor: default;
  color: var(--text-dim); font-weight: 600;
}
.chan--active { background: oklch(28% 0.04 230 / 0.6); color: var(--text); }
.chan__ic { opacity: 0.8; }
.chan__name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ---------- Плашка пользователя ---------- */
.userbar {
  display: flex; align-items: center; gap: 0.55rem;
  padding: 0.6rem 0.7rem; border-top: 1px solid var(--surface-line);
  background: oklch(13% 0.015 262);
}
.userbar__avatar {
  display: grid; place-items: center; flex: none;
  width: 34px; height: 34px; border-radius: 50%;
  font-weight: 800; color: var(--text);
  background: linear-gradient(140deg, var(--bg-2), oklch(34% 0.07 235));
}
.userbar__info { flex: 1; min-width: 0; display: flex; flex-direction: column; line-height: 1.25; }
.userbar__name { font-weight: 700; font-size: 0.9rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.userbar__state { display: flex; align-items: center; gap: 0.35rem; font-size: 0.72rem; color: var(--text-dim); }
.userbar__mic {
  flex: none; width: 34px; height: 34px; border-radius: 9px; cursor: pointer;
  background: var(--bg-1); border: 1px solid var(--surface-line); font-size: 1rem;
  transition: background var(--dur) var(--ease);
}
.userbar__mic:hover { background: var(--bg-2); }
.userbar__mic[data-on="false"] { background: oklch(30% 0.12 25); border-color: var(--danger); }

/* ---------- Бар приглашения ---------- */
.invitebar {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.6rem 1.2rem; border-bottom: 1px solid var(--surface-line);
  background: oklch(16% 0.02 250 / 0.5);
}
.invitebar__label { font-size: 0.8rem; font-weight: 700; color: var(--text-dim); white-space: nowrap; }
.invitebar__field {
  flex: 1; min-width: 0; padding: 0.5rem 0.8rem;
  background: var(--bg-0); color: var(--accent);
  border: 1px solid var(--surface-line); border-radius: var(--radius-sm);
  font-family: ui-monospace, monospace; font-size: 0.82rem;
}
.invitebar__btn {
  flex: none; padding: 0.5rem 1rem; border: 0; border-radius: var(--radius-sm); cursor: pointer;
  font-weight: 700; color: oklch(18% 0.02 260);
  background: linear-gradient(100deg, var(--accent), var(--accent-strong));
  transition: transform var(--dur) var(--ease), filter var(--dur) var(--ease);
}
.invitebar__btn:hover { transform: translateY(-1px); filter: brightness(1.07); }
.invitebar__btn--ok { background: linear-gradient(100deg, var(--speak), oklch(72% 0.16 150)); }

.main__count { font-size: 0.82rem; color: var(--text-dim); }
.main__bar .mode-pill { margin-inline-start: auto; }

/* ---------- Сайдбар ---------- */
.sidebar {
  display: flex; flex-direction: column; min-height: 0;
  background: oklch(16% 0.018 262 / 0.94);
  border-inline-end: 1px solid var(--surface-line);
}
.sidebar__head {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.85rem 1rem; border-bottom: 1px solid var(--surface-line);
}
.sidebar__head .brand__mark { width: 1.7rem; height: 1.7rem; flex: none; }
.sidebar__titles { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; }
.sidebar__server { font-weight: 800; letter-spacing: -0.02em; }
.sidebar__room { font-size: 0.76rem; color: var(--text-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.sidebar__voice {
  display: flex; align-items: center; gap: 0.55rem;
  margin: 0.7rem 0.5rem 0.3rem; padding: 0.55rem 0.8rem;
  border-radius: var(--radius-sm);
  background: oklch(24% 0.035 230 / 0.55);
  font-size: 0.82rem; font-weight: 700; color: var(--text);
}
.sidebar__voice-ic { opacity: 0.85; }
.sidebar__voice-name { flex: 1; }

.members { list-style: none; margin: 0; padding: 0.2rem 0.45rem; flex: 1; min-height: 0; overflow: auto; }
.member {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.4rem 0.55rem; border-radius: 8px;
  transition: background var(--dur) var(--ease);
}
.member:hover { background: oklch(32% 0.02 260 / 0.5); }
.member__avatar {
  display: grid; place-items: center; flex: none;
  width: 34px; height: 34px; border-radius: 50%;
  font-size: 0.9rem; font-weight: 800; color: var(--text);
  background: linear-gradient(140deg, var(--bg-2), oklch(34% 0.07 235));
  transition: box-shadow var(--dur) var(--ease);
}
.member--speaking .member__avatar { box-shadow: 0 0 0 2px var(--speak); }
.member--speaking .member__name { color: var(--speak); }
.member__name { flex: 1; font-size: 0.9rem; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.member__icons { display: flex; gap: 0.3rem; }
.member__ic { font-size: 0.82rem; }
.member__ic[hidden] { display: none; }

.sidebar__foot {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.7rem 1rem; border-top: 1px solid var(--surface-line);
  font-size: 0.76rem; color: var(--text-dim);
}
.dot-state { width: 0.55rem; height: 0.55rem; border-radius: 50%; background: var(--accent); flex: none; }
.dot-state[data-state="connected"] { background: var(--speak); box-shadow: 0 0 8px var(--speak); }

/* ---------- Основная зона ---------- */
.main { display: flex; flex-direction: column; min-width: 0; min-height: 0; }
.main__bar {
  display: flex; align-items: center; gap: 1rem;
  padding: 0.8rem 1.2rem; border-bottom: 1px solid var(--surface-line);
  background: oklch(14% 0.015 260 / 0.6); backdrop-filter: blur(10px);
}
.main__channel { font-weight: 700; color: var(--text-dim); }
.main__channel strong { color: var(--text); }
.main__bar .mode-pill { margin-inline-start: auto; }

/* ---------- Плитки звонка ---------- */
.stage {
  flex: 1; min-height: 0; padding: 1.3rem;
  display: grid; gap: 1rem; align-content: center; justify-content: center;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  grid-auto-rows: minmax(180px, 1fr);
  overflow: auto;
  background: radial-gradient(900px 520px at 50% -5%, oklch(22% 0.03 250 / 0.45), transparent 70%);
}
.tile {
  position: relative; min-width: 240px; aspect-ratio: 16 / 10;
  background: oklch(12% 0.012 260); border: 1px solid var(--surface-line);
  border-radius: 18px; overflow: hidden; display: grid; place-items: center;
  transition: box-shadow var(--dur) var(--ease);
}
.tile--self { border-color: oklch(78% 0.16 200 / 0.45); }
.tile--speaking { box-shadow: inset 0 0 0 2px var(--speak), 0 0 26px oklch(82% 0.18 150 / 0.22); }
.tile__avatar {
  width: 100px; height: 100px; border-radius: 50%;
  font-size: 2.6rem; font-weight: 800; color: var(--text);
  display: grid; place-items: center;
  background: linear-gradient(140deg, var(--bg-2), oklch(34% 0.07 235));
  box-shadow: 0 10px 28px oklch(0% 0 0 / 0.45);
  transition: box-shadow var(--dur) var(--ease);
}
.tile--speaking .tile__avatar { box-shadow: 0 0 0 4px var(--speak), 0 10px 28px oklch(0% 0 0 / 0.45); }

/* ---------- Спотлайт демонстрации экрана ----------
   Презентер занимает всю верхнюю область, остальные сжимаются в ленту снизу. */
.stage--spotlight {
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  grid-template-rows: minmax(0, 1fr) auto;
  align-content: stretch;
  gap: 0.7rem;
}
.stage--spotlight .tile { aspect-ratio: auto; min-width: 0; }
.stage--spotlight .tile--spotlight {
  grid-column: 1 / -1;
  grid-row: 1;
  min-height: 0;
  box-shadow: 0 0 0 1px var(--accent), 0 18px 50px oklch(0% 0 0 / 0.5);
}
.stage--spotlight .tile:not(.tile--spotlight) {
  grid-row: 2;
  height: 104px;
}
.stage--spotlight .tile:not(.tile--spotlight) .tile__avatar {
  width: 52px; height: 52px; font-size: 1.3rem;
}

/* ---------- Панель управления ---------- */
.controls {
  display: flex; justify-content: center; gap: 0.7rem;
  padding: 1rem; border-top: 1px solid var(--surface-line);
  background: oklch(14% 0.015 260 / 0.7); backdrop-filter: blur(10px);
}

@media (max-width: 760px) {
  .room { grid-template-columns: 1fr; }
  .sidebar { display: none; }
  .chat { display: none; }
  .room--chat-open .chat {
    display: flex; position: fixed; inset: 0; z-index: 30;
  }
}

@media (prefers-reduced-motion: reduce) {
  * { transition-duration: 1ms !important; }
}

/* ====================================================================
   Аккаунт в лобби (опционально: постоянное имя + значок ✓)
   ==================================================================== */

.auth {
  margin: 0 0 1.4rem;
  padding: 0.9rem;
  background: oklch(20% 0.02 260 / 0.5);
  border: 1px solid var(--surface-line);
  border-radius: var(--radius);
}
.auth__tabs {
  display: flex; gap: 0.3rem; margin-bottom: 0.7rem;
  background: var(--bg-0); border-radius: var(--radius-sm); padding: 0.25rem;
}
.auth__tab {
  flex: 1; padding: 0.45rem 0.6rem; border: 0; cursor: pointer;
  background: transparent; color: var(--text-dim);
  font-size: 0.82rem; font-weight: 700; border-radius: 7px;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.auth__tab--active { background: var(--bg-2); color: var(--text); }
.auth__form { display: grid; gap: 0.55rem; }
.field__input--sm { padding: 0.6rem 0.8rem; font-size: 0.92rem; }
.field__input--locked { opacity: 0.7; cursor: not-allowed; }

.btn--ghost {
  background: var(--bg-1); color: var(--text);
  border: 1px solid var(--surface-line); box-shadow: none;
}
.btn--ghost:hover { transform: translateY(-1px); border-color: var(--accent); }

.auth__error {
  margin: 0.6rem 0 0; padding: 0.5rem 0.7rem;
  background: oklch(30% 0.1 25 / 0.3); border: 1px solid var(--danger);
  border-radius: var(--radius-sm); color: oklch(86% 0.08 25);
  font-size: 0.8rem; line-height: 1.35;
}

.auth__signed {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.9rem; color: var(--text);
}
.auth__check {
  display: grid; place-items: center; flex: none;
  width: 1.4rem; height: 1.4rem; border-radius: 50%;
  background: var(--speak); color: oklch(18% 0.02 260); font-weight: 900; font-size: 0.8rem;
}
.auth__as { flex: 1; color: var(--text-dim); }
.auth__as strong { color: var(--text); }
.auth__logout {
  border: 0; cursor: pointer; background: transparent;
  color: var(--danger); font-weight: 700; font-size: 0.82rem; padding: 0.3rem 0.4rem;
}
.auth__logout:hover { text-decoration: underline; }

/* ====================================================================
   Чат (4-я колонка комнаты)
   ==================================================================== */

.room--chat-hidden { grid-template-columns: 72px 248px 1fr; }
.room--chat-hidden .chat { display: none; }

.chat {
  display: flex; flex-direction: column; min-height: 0;
  background: oklch(15% 0.016 262 / 0.94);
  border-inline-start: 1px solid var(--surface-line);
}
.chat__head {
  display: flex; align-items: baseline; gap: 0.5rem;
  padding: 0.85rem 1rem; border-bottom: 1px solid var(--surface-line);
}
.chat__title { font-weight: 800; letter-spacing: -0.01em; }
.chat__room {
  font-size: 0.76rem; color: var(--text-dim);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.chat__log {
  flex: 1; min-height: 0; overflow-y: auto;
  padding: 0.8rem 0.9rem; display: flex; flex-direction: column; gap: 0.7rem;
}

.msg { display: grid; gap: 0.15rem; }
.msg__head { display: flex; align-items: baseline; gap: 0.4rem; }
.msg__name { font-weight: 700; font-size: 0.85rem; color: var(--accent); }
.msg__name--guest { color: var(--text-dim); }
.msg__check { color: var(--speak); font-size: 0.72rem; font-weight: 900; }
.msg__time { margin-inline-start: auto; font-size: 0.68rem; color: var(--text-dim); }
.msg__text { font-size: 0.9rem; line-height: 1.4; color: var(--text); word-break: break-word; }
.msg--system .msg__text { color: var(--text-dim); font-style: italic; }

.chat__form {
  display: flex; gap: 0.5rem; padding: 0.7rem 0.8rem;
  border-top: 1px solid var(--surface-line); background: oklch(13% 0.015 262);
}
.chat__input {
  flex: 1; min-width: 0; padding: 0.6rem 0.8rem;
  background: var(--bg-1); color: var(--text);
  border: 1px solid var(--surface-line); border-radius: var(--radius-sm);
  font-size: 0.9rem; transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.chat__input:focus {
  outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 3px oklch(78% 0.16 200 / 0.18);
}
.chat__send {
  flex: none; width: 2.6rem; border: 0; cursor: pointer; border-radius: var(--radius-sm);
  color: oklch(18% 0.02 260); font-size: 1rem;
  background: linear-gradient(100deg, var(--accent), var(--accent-strong));
  transition: transform var(--dur) var(--ease), filter var(--dur) var(--ease);
}
.chat__send:hover { transform: translateY(-1px); filter: brightness(1.07); }

/* Тоггл чата в шапке */
.chat-toggle {
  position: relative; flex: none;
  display: grid; place-items: center; width: 2.4rem; height: 2.4rem;
  background: var(--bg-1); color: var(--text);
  border: 1px solid var(--surface-line); border-radius: var(--radius-sm); cursor: pointer;
  transition: background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.chat-toggle:hover { background: var(--bg-2); }
.chat-toggle[aria-pressed="true"] { box-shadow: inset 0 0 0 1px var(--accent); }
.chat-toggle__ic { font-size: 1.1rem; }
.chat-toggle__unread {
  position: absolute; top: -4px; inset-inline-end: -4px;
  min-width: 1.1rem; height: 1.1rem; padding: 0 0.25rem;
  display: grid; place-items: center; border-radius: 999px;
  background: var(--danger); color: var(--text);
  font-size: 0.66rem; font-weight: 800; line-height: 1;
}
.chat-toggle__unread[hidden] { display: none; }

/* ====================================================================
   Типографика и полировка (применение дисплей-шрифта + детали)
   ==================================================================== */
.sidebar__server,
.chat__title,
.brand--sm .brand__name { font-family: var(--font-display); letter-spacing: -0.03em; }

.lobby__tag { font-weight: 400; }
.lobby__tag strong { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.02em; }

.chan-group,
.field__label { font-family: var(--font-body); }

/* Кнопки и лейблы контролов — чуть характернее */
.btn { font-family: var(--font-body); letter-spacing: -0.01em; }
.ctrl__label { font-weight: 600; letter-spacing: 0.01em; }

/* Аватары — дисплей-шрифт даёт инициалам характер */
.tile__avatar, .member__avatar, .userbar__avatar, .auth__check { font-family: var(--font-display); }

/* Тонкое зерно поверх фона лобби — глубина без нагрузки */
.lobby::after {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: -1;
  opacity: 0.035; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ====================================================================
   НЕОН-ЛЮКС: пульс речи, кастомные слайдеры, новые контролы
   ==================================================================== */

/* --- Неоновое «дыхание» при речи (живее плоского ring) --- */
@keyframes speakPulse {
  0%, 100% { box-shadow: 0 0 0 3px oklch(85% 0.16 188 / 0.9), 0 0 18px oklch(85% 0.16 188 / 0.5), 0 10px 28px oklch(0% 0 0 / 0.45); }
  50%      { box-shadow: 0 0 0 4px oklch(85% 0.16 188 / 1), 0 0 30px oklch(85% 0.16 188 / 0.7), 0 0 52px oklch(64% 0.21 292 / 0.5), 0 10px 28px oklch(0% 0 0 / 0.45); }
}
.tile--speaking .tile__avatar { animation: speakPulse 1.6s var(--ease) infinite; }
.tile--speaking { box-shadow: inset 0 0 0 2px var(--speak), 0 0 30px oklch(85% 0.16 188 / 0.28), 0 0 60px oklch(64% 0.21 292 / 0.2); }
.member--speaking .member__avatar { box-shadow: 0 0 0 2px var(--speak), 0 0 14px oklch(85% 0.16 188 / 0.6); }

/* Стеклянные панели комнаты — добавляем верхний внутренний блик */
.main__bar, .controls, .userbar, .chat__head { box-shadow: inset 0 1px 0 var(--surface-hi); }

/* Активный канал/рейл — двухцветный фирменный градиент */
.rail__item--active { background: var(--grad-brand); color: oklch(99% 0.01 285); box-shadow: var(--glow-accent); }
.chan--active { background: linear-gradient(100deg, oklch(40% 0.08 200 / 0.5), oklch(36% 0.1 292 / 0.45)); color: var(--text); box-shadow: inset 0 0 0 1px var(--surface-line); }

/* Поля ввода — фокус с двойным неон-кольцом */
.field__input:focus, .chat__input:focus {
  outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 3px oklch(82% 0.15 195 / 0.2), 0 0 22px oklch(64% 0.21 292 / 0.25);
}
.btn--ghost:hover { border-color: var(--accent); box-shadow: 0 0 0 1px oklch(82% 0.15 195 / 0.4); }

/* --- Кнопка «Продолжить в #room» (вход в 1 клик) --- */
.quickjoin {
  display: flex; align-items: center; gap: 0.55rem;
  width: 100%; margin: 0 0 1rem; padding: 0.85rem 1.1rem;
  cursor: pointer; border: 1px solid var(--surface-line); border-radius: var(--radius-sm);
  background: linear-gradient(100deg, oklch(30% 0.08 200 / 0.4), oklch(28% 0.1 292 / 0.4));
  color: var(--text); font-family: var(--font-body); font-weight: 700; font-size: 0.95rem;
  box-shadow: inset 0 1px 0 var(--surface-hi);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), filter var(--dur) var(--ease);
}
.quickjoin:hover { transform: translateY(-2px); filter: brightness(1.08); box-shadow: var(--glow-accent); }
.quickjoin__label { color: var(--text-dim); font-weight: 600; }
.quickjoin__room { font-family: var(--font-display); letter-spacing: -0.02em; color: var(--accent); }
.quickjoin__arrow { margin-inline-start: auto; font-size: 1.1rem; color: var(--accent); transition: transform var(--dur) var(--ease); }
.quickjoin:hover .quickjoin__arrow { transform: translateX(4px); }

/* --- Кастомные слайдеры громкости (range) — убираем дефолтный вид --- */
input[type="range"].selfvol__range,
input[type="range"].mastervol__range,
input[type="range"].member__range {
  -webkit-appearance: none; appearance: none;
  height: 5px; border-radius: 999px; cursor: pointer; background: transparent;
}
.selfvol__range::-webkit-slider-runnable-track,
.mastervol__range::-webkit-slider-runnable-track,
.member__range::-webkit-slider-runnable-track {
  height: 5px; border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2)) 0/ var(--fill, 100%) 100% no-repeat, var(--bg-0);
}
.selfvol__range::-moz-range-track, .mastervol__range::-moz-range-track, .member__range::-moz-range-track {
  height: 5px; border-radius: 999px; background: var(--bg-0);
}
.selfvol__range::-moz-range-progress, .mastervol__range::-moz-range-progress, .member__range::-moz-range-progress {
  height: 5px; border-radius: 999px; background: linear-gradient(90deg, var(--accent), var(--accent-2));
}
.selfvol__range::-webkit-slider-thumb,
.mastervol__range::-webkit-slider-thumb,
.member__range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none; margin-top: -5px;
  width: 15px; height: 15px; border-radius: 50%;
  background: oklch(98% 0.01 285); border: 0;
  box-shadow: 0 0 0 1px oklch(82% 0.15 195 / 0.6), 0 0 12px oklch(64% 0.21 292 / 0.6);
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.selfvol__range:hover::-webkit-slider-thumb, .member__range:hover::-webkit-slider-thumb, .mastervol__range:hover::-webkit-slider-thumb { transform: scale(1.15); }
.selfvol__range::-moz-range-thumb, .mastervol__range::-moz-range-thumb, .member__range::-moz-range-thumb {
  width: 15px; height: 15px; border: 0; border-radius: 50%;
  background: oklch(98% 0.01 285); box-shadow: 0 0 0 1px oklch(82% 0.15 195 / 0.6), 0 0 12px oklch(64% 0.21 292 / 0.6);
}
input[type="range"]:focus-visible { outline: 2px solid var(--accent); outline-offset: 4px; }

/* --- Громкость своего микрофона (в сайдбаре под плашкой) --- */
.selfvol {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 0.5rem 0.6rem;
  padding: 0.6rem 0.8rem; border-top: 1px solid var(--surface-line);
  background: oklch(12% 0.014 280);
}
.selfvol__ic { font-size: 0.95rem; }
.selfvol__label { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-dim); }
.selfvol__range { grid-column: 1 / 3; }
.selfvol__val { font-size: 0.74rem; font-weight: 700; color: var(--accent); font-variant-numeric: tabular-nums; min-width: 2.6rem; text-align: end; }

/* --- Мастер-громкость (в шапке основной зоны) --- */
.mastervol {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.3rem 0.7rem; border-radius: 999px;
  background: oklch(18% 0.022 280 / 0.7); border: 1px solid var(--surface-line);
}
.mastervol__ic { font-size: 0.9rem; }
.mastervol__range { width: 96px; }
.mastervol__val { font-size: 0.74rem; font-weight: 700; color: var(--text-dim); font-variant-numeric: tabular-nums; min-width: 2.6rem; text-align: end; }
.main__bar .mastervol { margin-inline-start: auto; }
.main__bar .mode-pill { margin-inline-start: 0; }

/* --- Per-peer громкость в списке участников --- */
.member { flex-direction: column; align-items: stretch; gap: 0.35rem; }
.member__top { display: flex; align-items: center; gap: 0.6rem; }
.member__vol { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 0.5rem; padding-inline-start: 2.55rem; }
.member__mute {
  flex: none; width: 1.6rem; height: 1.6rem; display: grid; place-items: center;
  border: 0; border-radius: 7px; cursor: pointer; font-size: 0.8rem;
  background: var(--bg-1); color: var(--text);
  transition: background var(--dur) var(--ease);
}
.member__mute:hover { background: var(--bg-2); }
.member__mute[data-muted="true"] { background: oklch(30% 0.12 25); box-shadow: inset 0 0 0 1px var(--danger); }
.member__volval { font-size: 0.7rem; font-weight: 700; color: var(--text-dim); font-variant-numeric: tabular-nums; min-width: 2.4rem; text-align: end; }
.member:hover { background: oklch(28% 0.03 282 / 0.5); }
