/* 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);

  /* Фоновые свечения страницы (управляются темой) */
  --glow-1: oklch(46% 0.16 200 / 0.20);
  --glow-2: oklch(42% 0.2 292 / 0.22);
  --glow-center: oklch(20% 0.03 282 / 0.4);
  --page-base: var(--bg-0);
}

/* ======================================================================
   ТЕМЫ — переключаются атрибутом data-theme на <html>.
   Каждая переопределяет палитру; иконки/тени наследуют через currentColor
   и токены, поэтому достаточно сменить переменные.
   ====================================================================== */

/* Aurora — изумруд/бирюза, тёмная */
[data-theme="aurora"] {
  --bg-0: oklch(13% 0.02 165); --bg-1: oklch(17% 0.028 168); --bg-2: oklch(22% 0.04 168);
  --surface: oklch(20% 0.035 168 / 0.55); --surface-2: oklch(26% 0.05 170 / 0.45);
  --surface-line: oklch(62% 0.07 168 / 0.16); --surface-hi: oklch(95% 0.03 168 / 0.06);
  --text: oklch(96% 0.01 168); --text-dim: oklch(72% 0.03 168);
  --accent: oklch(80% 0.16 165); --accent-strong: oklch(72% 0.18 162);
  --accent-2: oklch(70% 0.17 195); --accent-2-strong: oklch(63% 0.19 198);
  --speak: oklch(84% 0.17 160);
  --glow-1: oklch(50% 0.17 165 / 0.20); --glow-2: oklch(46% 0.16 195 / 0.20); --glow-center: oklch(22% 0.04 168 / 0.4);
}
/* Sunset — янтарь/коралл/розовый, тёмная */
[data-theme="sunset"] {
  --bg-0: oklch(13% 0.022 30); --bg-1: oklch(17% 0.03 28); --bg-2: oklch(22% 0.045 26);
  --surface: oklch(20% 0.04 28 / 0.55); --surface-2: oklch(26% 0.055 24 / 0.45);
  --surface-line: oklch(64% 0.08 32 / 0.18); --surface-hi: oklch(96% 0.03 40 / 0.06);
  --text: oklch(96% 0.012 40); --text-dim: oklch(74% 0.035 36);
  --accent: oklch(80% 0.15 55); --accent-strong: oklch(73% 0.17 48);
  --accent-2: oklch(70% 0.2 18); --accent-2-strong: oklch(63% 0.22 14);
  --speak: oklch(82% 0.16 60);
  --glow-1: oklch(60% 0.16 55 / 0.22); --glow-2: oklch(55% 0.2 18 / 0.22); --glow-center: oklch(22% 0.04 30 / 0.4);
}
/* Grape — фуксия/фиолет, тёмная */
[data-theme="grape"] {
  --bg-0: oklch(13% 0.025 310); --bg-1: oklch(16% 0.035 308); --bg-2: oklch(22% 0.05 306);
  --surface: oklch(20% 0.045 308 / 0.55); --surface-2: oklch(26% 0.06 306 / 0.45);
  --surface-line: oklch(64% 0.08 312 / 0.18); --surface-hi: oklch(96% 0.03 312 / 0.06);
  --text: oklch(96% 0.012 312); --text-dim: oklch(74% 0.035 312);
  --accent: oklch(74% 0.2 330); --accent-strong: oklch(66% 0.23 332);
  --accent-2: oklch(66% 0.21 288); --accent-2-strong: oklch(58% 0.24 290);
  --speak: oklch(78% 0.2 330);
  --glow-1: oklch(55% 0.22 330 / 0.22); --glow-2: oklch(50% 0.22 288 / 0.22); --glow-center: oklch(22% 0.05 308 / 0.4);
}
/* Nord — холодный синий/сталь, тёмная */
[data-theme="nord"] {
  --bg-0: oklch(16% 0.018 250); --bg-1: oklch(20% 0.025 250); --bg-2: oklch(26% 0.035 252);
  --surface: oklch(24% 0.03 250 / 0.55); --surface-2: oklch(30% 0.04 252 / 0.45);
  --surface-line: oklch(66% 0.05 250 / 0.18); --surface-hi: oklch(96% 0.02 250 / 0.07);
  --text: oklch(95% 0.01 250); --text-dim: oklch(74% 0.025 250);
  --accent: oklch(78% 0.11 230); --accent-strong: oklch(70% 0.13 232);
  --accent-2: oklch(72% 0.1 200); --accent-2-strong: oklch(64% 0.12 202);
  --speak: oklch(82% 0.12 220);
  --glow-1: oklch(50% 0.12 230 / 0.18); --glow-2: oklch(48% 0.1 200 / 0.18); --glow-center: oklch(26% 0.03 250 / 0.4);
}
/* Graphite — нейтральная монохромная, тёмная (минимализм) */
[data-theme="graphite"] {
  --bg-0: oklch(14% 0.004 270); --bg-1: oklch(18% 0.005 270); --bg-2: oklch(24% 0.006 270);
  --surface: oklch(22% 0.006 270 / 0.55); --surface-2: oklch(28% 0.008 270 / 0.45);
  --surface-line: oklch(70% 0.01 270 / 0.16); --surface-hi: oklch(96% 0.006 270 / 0.06);
  --text: oklch(95% 0.004 270); --text-dim: oklch(72% 0.008 270);
  --accent: oklch(82% 0.03 250); --accent-strong: oklch(74% 0.04 250);
  --accent-2: oklch(70% 0.03 250); --accent-2-strong: oklch(62% 0.04 250);
  --speak: oklch(85% 0.04 250);
  --glow-1: oklch(50% 0.02 270 / 0.14); --glow-2: oklch(45% 0.02 270 / 0.14); --glow-center: oklch(24% 0.006 270 / 0.4);
}
/* Daylight — чистый светлый люкс */
[data-theme="daylight"] {
  --bg-0: oklch(97% 0.004 250); --bg-1: oklch(99% 0.003 250); --bg-2: oklch(94% 0.006 250);
  --surface: oklch(100% 0 0 / 0.7); --surface-2: oklch(96% 0.006 250 / 0.7);
  --surface-line: oklch(45% 0.03 250 / 0.16); --surface-hi: oklch(100% 0 0 / 0.7);
  --text: oklch(22% 0.02 270); --text-dim: oklch(46% 0.02 270);
  --accent: oklch(58% 0.16 250); --accent-strong: oklch(52% 0.18 252);
  --accent-2: oklch(56% 0.2 295); --accent-2-strong: oklch(50% 0.22 296);
  --speak: oklch(60% 0.16 230);
  --glow-1: oklch(70% 0.12 250 / 0.16); --glow-2: oklch(68% 0.14 295 / 0.16); --glow-center: oklch(96% 0.006 250 / 0.5);
}
/* Rosé — тёплый светлый */
[data-theme="rose"] {
  --bg-0: oklch(97% 0.008 30); --bg-1: oklch(99% 0.006 30); --bg-2: oklch(95% 0.012 28);
  --surface: oklch(100% 0 0 / 0.72); --surface-2: oklch(97% 0.01 30 / 0.7);
  --surface-line: oklch(50% 0.05 20 / 0.16); --surface-hi: oklch(100% 0 0 / 0.7);
  --text: oklch(26% 0.03 20); --text-dim: oklch(50% 0.04 20);
  --accent: oklch(60% 0.18 12); --accent-strong: oklch(54% 0.2 10);
  --accent-2: oklch(64% 0.16 350); --accent-2-strong: oklch(57% 0.18 348);
  --speak: oklch(64% 0.18 12);
  --glow-1: oklch(75% 0.13 20 / 0.18); --glow-2: oklch(72% 0.12 350 / 0.18); --glow-center: oklch(97% 0.01 30 / 0.5);
}

* { box-sizing: border-box; }

/* ---------- Иконки (line-SVG спрайт) ---------- */
.ic {
  width: 1.35em; height: 1.35em; flex: none;
  display: inline-block; vertical-align: -0.28em;
  stroke: currentColor; fill: none;
  pointer-events: none;
}
.ic--sm { width: 1.1em; height: 1.1em; vertical-align: -0.2em; }

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.78rem; color: var(--text); opacity: 0.92; }
.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); }

/* ---------- Сегментированный переключатель (Голос / Рация) ---------- */
.seg {
  display: inline-flex; gap: 4px; padding: 4px;
  background: var(--bg-1); border: 1px solid var(--surface-line);
  border-radius: var(--radius-sm);
}
.seg__btn {
  appearance: none; cursor: pointer;
  padding: 0.5rem 0.95rem; border: 0; border-radius: calc(var(--radius-sm) - 5px);
  background: transparent; color: var(--text-dim);
  font: inherit; font-size: 0.9rem; line-height: 1;
  transition: color 150ms ease, background 150ms ease;
}
.seg__btn:hover { color: var(--text); }
.seg__btn--active {
  color: oklch(15% 0.018 278);
  background: var(--accent);
  box-shadow: 0 1px 6px oklch(82% 0.15 195 / 0.35);
}
.seg__btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ---------- 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;
  height: 100dvh;
}

/* ---------- Рейл серверов ---------- */
.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; position: relative; }
.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:
    radial-gradient(130% 90% at 50% 0%, oklch(22% 0.035 260 / 0.6), transparent 62%),
    radial-gradient(80% 70% at 50% 120%, oklch(30% 0.06 250 / 0.28), transparent 70%),
    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 {
  position: relative;
  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__avatar::after {
  content: ""; position: absolute; inset: -14px; border-radius: 50%; z-index: -1;
  background: radial-gradient(closest-side, oklch(70% 0.18 250 / 0.22), transparent 78%);
  pointer-events: none;
}
.tile--speaking .tile__avatar { box-shadow: 0 0 0 4px var(--speak), 0 10px 28px oklch(0% 0 0 / 0.45); }

/* Когда тайл показывает видео (камера/демка) — кружок аватарки и его ореол скрыты,
   чтобы не перекрывать содержимое стрима. Восстанавливается автоматически, как только
   .tile--has-video снимается (видео отключилось). */
.tile--has-video .tile__avatar,
.tile--has-video .tile__avatar::after { display: none; }

/* ---------- Solo-состояние (в канале один) ---------- */
.solo {
  position: absolute; inset-inline: 0;
  /* Над панелью контролов, чтобы не перекрывать подписи кнопок */
  bottom: calc(6.4rem + env(safe-area-inset-bottom)); z-index: 2;
  display: flex; align-items: center; justify-content: center; gap: 0.7rem;
  padding: 0 1.5rem; pointer-events: none; text-align: center;
}
.solo[hidden] { display: none; }
.solo__pulse {
  position: relative; flex: none; width: 9px; height: 9px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 10px var(--accent);
}
.solo__pulse::before {
  content: ""; position: absolute; inset: -3px; border-radius: 50%;
  border: 1.5px solid var(--accent); opacity: 0;
  animation: soloRing 2.4s var(--ease) infinite;
}
@keyframes soloRing {
  0% { transform: scale(1); opacity: 0.6; }
  100% { transform: scale(3.4); opacity: 0; }
}
.solo__text {
  color: var(--text-dim); font-size: 0.86rem; line-height: 1.4;
  padding: 0.5rem 1rem; border-radius: 999px;
  background: oklch(16% 0.02 260 / 0.7); border: 1px solid var(--surface-line);
  backdrop-filter: blur(8px);
}

/* ---------- Спотлайт демонстрации экрана ----------
   Презентер занимает всю верхнюю область, остальные сжимаются в ленту снизу. */
.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);
  padding-bottom: calc(1rem + env(safe-area-inset-bottom));
  background: oklch(14% 0.015 260 / 0.7); backdrop-filter: blur(10px);
}

/* ---------- Тост, скрим, бейджи (общие) ---------- */
.toast {
  position: fixed; left: 50%; bottom: calc(1.2rem + env(safe-area-inset-bottom));
  transform: translate(-50%, 1rem); z-index: 60;
  max-width: min(90vw, 420px); padding: 0.7rem 1rem;
  background: oklch(22% 0.03 260 / 0.96); color: var(--text);
  border: 1px solid var(--surface-line); border-radius: var(--radius-sm);
  box-shadow: 0 8px 30px oklch(0% 0 0 / 0.45);
  font-size: 0.86rem; line-height: 1.35; text-align: center;
  opacity: 0; transition: opacity 220ms ease, transform 220ms ease;
  pointer-events: none;
}
.toast--show { opacity: 1; transform: translate(-50%, 0); }

.scrim {
  position: fixed; inset: 0; z-index: 35;
  background: oklch(0% 0 0 / 0.55); backdrop-filter: blur(2px);
}

.chat-toggle__badge {
  position: absolute; top: -4px; right: -4px;
  min-width: 16px; height: 16px; padding: 0 4px;
  display: grid; place-items: center;
  font-size: 0.64rem; font-weight: 700; line-height: 1;
  background: var(--accent); color: oklch(15% 0.018 278);
  border-radius: 999px;
}

/* Зажатая кнопка рации (hold-to-talk) — яркая подсветка «эфир открыт». */
.ctrl--talking {
  background: var(--accent) !important; color: oklch(15% 0.018 278) !important;
  box-shadow: 0 0 0 3px oklch(82% 0.15 195 / 0.35);
}
/* Демонстрация недоступна (мобильный браузер) — кнопка приглушена. */
body.no-screenshare #shareBtn { opacity: 0.45; }

/* Кнопка «участники» — только на узком экране (медиа-запрос ниже включает). */
#membersToggle { display: none; }

@media (max-width: 760px) {
  /* Одна колонка: контент во всю ширину; рейл скрыт, сайдбар и чат — оверлеи.
     .room.room--chat-hidden нужен с повышенной специфичностью — иначе глобальное
     десктопное правило .room--chat-hidden (3-колоночный grid) перебивает мобилу. */
  .room,
  .room.room--chat-hidden,
  .room.room--members-open { grid-template-columns: 1fr; }
  .rail { display: none; }

  /* Шапка канала компактнее и без переполнения. */
  .main__bar { gap: 0.5rem; padding: 0.6rem 0.7rem; flex-wrap: nowrap; }
  .main__bar .main__count,
  .main__bar .mastervol { display: none; }
  .main__channel {
    font-size: 0.95rem; min-width: 0;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  }
  #membersToggle { display: inline-flex; }

  /* Приглашение — компактно, без выпадания за экран. */
  .invitebar { flex-wrap: wrap; padding: 0.5rem 0.7rem; gap: 0.4rem; }
  .invitebar__field { min-width: 0; flex: 1; }

  /* Сцена участников — одна колонка во всю ширину. */
  .stage { padding: 0.8rem; grid-template-columns: 1fr; gap: 0.8rem; }

  /* Сайдбар и чат — выезжающие панели поверх контента. */
  .sidebar, .chat {
    position: fixed; top: 0; bottom: 0; z-index: 40; width: min(86vw, 340px);
    transition: transform 260ms cubic-bezier(0.16, 1, 0.3, 1);
    padding-top: env(safe-area-inset-top);
  }
  .sidebar { left: 0; transform: translateX(-100%); border-right: 1px solid var(--surface-line); }
  .chat { right: 0; left: auto; transform: translateX(100%); border-left: 1px solid var(--surface-line); }
  .room--members-open .sidebar { transform: translateX(0); }
  /* Чат показан, когда НЕ скрыт (JS тогглит .room--chat-hidden). */
  .room:not(.room--chat-hidden) .chat { transform: translateX(0); }

  /* Крупные тап-таргеты в панели управления. */
  .controls { gap: 0.4rem; padding: 0.7rem 0.5rem; padding-bottom: calc(0.7rem + env(safe-area-inset-bottom)); }
  .ctrl { width: auto; flex: 1; min-width: 0; max-width: 92px; min-height: 56px; }

  /* Модалка настроек — лист почти во весь экран снизу. */
  .modal { align-items: flex-end; }
  .modal__card {
    width: 100%; max-width: 100%; max-height: 90dvh;
    border-radius: var(--radius) var(--radius) 0 0;
  }

  /* Лобби под «живой» вьюпорт мобилы. */
  .lobby { min-height: 100dvh; }
}

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

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

.auth {
  margin: 0 0 1.4rem;
  padding: 0.9rem;
  /* Утопленный «колодец»: темнее карты + внутренняя тень → интегрирован, а не «карта на карте» */
  background:
    linear-gradient(180deg, oklch(0% 0 0 / 0.18), transparent 36%),
    oklch(9% 0.012 280 / 0.55);
  border: 1px solid oklch(0% 0 0 / 0.35);
  border-radius: var(--radius);
  box-shadow:
    inset 0 2px 10px oklch(0% 0 0 / 0.45),
    inset 0 0 0 1px var(--surface-hi);
}
.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);
}
.auth__check .ic { width: 0.85rem; height: 0.85rem; vertical-align: 0; }
.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;
}
/* Пустое состояние — пока в чате ни одного сообщения (гаснет, как только JS добавит .msg) */
.chat__log:empty {
  align-items: center; justify-content: center; gap: 0.55rem;
  text-align: center; padding: 1.5rem 1.3rem;
}
.chat__log:empty::before {
  content: "";
  width: 44px; height: 44px; border-radius: 14px;
  background:
    radial-gradient(120% 120% at 28% 18%, var(--accent-2) 0%, transparent 58%),
    radial-gradient(120% 120% at 82% 88%, var(--accent) 0%, transparent 58%),
    var(--bg-1);
  box-shadow: 0 10px 30px oklch(64% 0.21 292 / 0.3), inset 0 1px 0 var(--surface-hi);
  opacity: 0.95;
}
.chat__log:empty::after {
  content: "Здесь пока тихо. Напиши первым — собеседники увидят сразу.";
  max-width: 22ch; font-size: 0.82rem; line-height: 1.45; color: var(--text-dim);
}

.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); }

/* ====================================================================
   Тулбар тайла: громкость демонстрации + во весь экран
   ==================================================================== */
.tile__tools {
  position: absolute; top: 0.5rem; inset-inline-end: 0.5rem; z-index: 4;
  display: none; align-items: center; gap: 0.45rem;
  opacity: 0; transform: translateY(-4px);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
/* Инструменты — только у тайла с видео; проявляются на hover/focus/в фуллскрине. */
.tile--has-video .tile__tools { display: flex; }
.tile--has-video:hover .tile__tools,
.tile:focus-within .tile__tools,
.tile:fullscreen .tile__tools { opacity: 1; transform: none; }

.tile__vol {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.3rem 0.6rem; border-radius: 999px;
  background: oklch(14% 0.02 270 / 0.78); border: 1px solid var(--surface-line);
  backdrop-filter: blur(8px);
}
.tile__vol[hidden] { display: none; }
.tile__vol-ic { font-size: 0.9rem; }
.tile__vol-range {
  -webkit-appearance: none; appearance: none;
  width: 92px; height: 5px; border-radius: 999px; cursor: pointer; background: transparent;
}
.tile__vol-range::-webkit-slider-runnable-track {
  height: 5px; border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2)) 0/ 100% 100% no-repeat, var(--bg-0);
}
.tile__vol-range::-moz-range-track { height: 5px; border-radius: 999px; background: var(--bg-0); }
.tile__vol-range::-moz-range-progress { height: 5px; border-radius: 999px; background: linear-gradient(90deg, var(--accent), var(--accent-2)); }
.tile__vol-range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none; margin-top: -5px;
  width: 14px; height: 14px; border-radius: 50%; border: 0; 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);
}
.tile__vol-range::-moz-range-thumb {
  width: 14px; height: 14px; 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);
}
.tile__vol-val { font-size: 0.7rem; font-weight: 700; color: var(--accent); font-variant-numeric: tabular-nums; min-width: 2.4rem; text-align: end; }

.tile__fs {
  flex: none; display: grid; place-items: center;
  width: 2rem; height: 2rem; cursor: pointer;
  border: 1px solid var(--surface-line); border-radius: 9px;
  background: oklch(14% 0.02 270 / 0.78); color: var(--text); font-size: 1rem;
  backdrop-filter: blur(8px);
  transition: background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.tile__fs:hover { background: oklch(22% 0.04 270 / 0.9); box-shadow: var(--glow-accent); }

/* Тайл во весь экран: убираем рамку/радиус, видео по центру на чёрном. */
.tile:fullscreen { border-radius: 0; aspect-ratio: auto; border: 0; background: #000; }
.tile:fullscreen .tile__video { object-fit: contain; }
.tile:fullscreen .tile__avatar { width: 160px; height: 160px; font-size: 4rem; }

/* ====================================================================
   Индикатор «печатает…» + многострочный ввод
   ==================================================================== */
.chat__typing {
  display: flex; align-items: center; gap: 0.45rem;
  padding: 0.25rem 0.95rem 0.4rem;
  font-size: 0.78rem; color: var(--text-dim); font-style: italic;
  min-height: 1.1rem;
}
.chat__typing[hidden] { display: none; }
.chat__typing-dots { display: inline-flex; gap: 3px; }
.chat__typing-dots i {
  width: 5px; height: 5px; border-radius: 50%; background: var(--accent);
  animation: typingBlink 1.2s var(--ease) infinite;
}
.chat__typing-dots i:nth-child(2) { animation-delay: 0.2s; }
.chat__typing-dots i:nth-child(3) { animation-delay: 0.4s; }
@keyframes typingBlink {
  0%, 60%, 100% { opacity: 0.25; transform: translateY(0); }
  30% { opacity: 1; transform: translateY(-2px); }
}

/* textarea чата: авто-рост задаётся из JS, тут — базовый вид. */
.chat__form { align-items: flex-end; }
textarea.chat__input {
  resize: none; overflow-y: auto; max-height: 132px; line-height: 1.4;
  font-family: var(--font-body); min-height: 2.4rem;
}

/* ====================================================================
   Тумблер в настройках (шумоподавление)
   ==================================================================== */
.toggle {
  display: flex; align-items: center; gap: 0.6rem;
  margin-top: 0.9rem; cursor: pointer; user-select: none;
}
.toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.toggle__track {
  flex: none; position: relative; width: 40px; height: 22px; border-radius: 999px;
  background: var(--bg-0); border: 1px solid var(--surface-line);
  transition: background var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.toggle__thumb {
  position: absolute; top: 2px; inset-inline-start: 2px;
  width: 16px; height: 16px; border-radius: 50%; background: var(--text-dim);
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease);
}
.toggle input:checked + .toggle__track {
  background: var(--grad-brand); border-color: transparent; box-shadow: var(--glow-accent);
}
.toggle input:checked + .toggle__track .toggle__thumb { transform: translateX(18px); background: oklch(99% 0.01 285); }
.toggle input:focus-visible + .toggle__track { outline: 2px solid var(--accent); outline-offset: 2px; }
.toggle__label { font-size: 0.88rem; color: var(--text); }

/* select настроек — единый вид с полями ввода */
select.field__input { cursor: pointer; appearance: none; -webkit-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--text-dim) 50%), linear-gradient(135deg, var(--text-dim) 50%, transparent 50%);
  background-position: calc(100% - 18px) 1.15rem, calc(100% - 13px) 1.15rem;
  background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; padding-inline-end: 2rem;
}
select.field__input option { background: var(--bg-1); color: var(--text); }

/* ====================================================================
   Модалка настроек в комнате
   ==================================================================== */
.modal {
  position: fixed; inset: 0; z-index: 50;
  display: grid; place-items: center; padding: var(--space);
  background: oklch(8% 0.01 280 / 0.62); backdrop-filter: blur(6px);
  animation: modalFade var(--dur) var(--ease);
}
.modal[hidden] { display: none; }
@keyframes modalFade { from { opacity: 0; } to { opacity: 1; } }

.modal__card {
  width: min(440px, 100%);
  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);
  animation: modalRise var(--dur) var(--ease);
}
@keyframes modalRise { from { transform: translateY(12px) scale(0.98); } to { transform: none; } }

.modal__head {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 1rem 1.2rem; border-bottom: 1px solid var(--surface-line);
}
.modal__title { font-family: var(--font-display); font-weight: 800; letter-spacing: -0.02em; font-size: 1.05rem; }
.modal__close {
  margin-inline-start: auto; flex: none;
  width: 2rem; height: 2rem; display: grid; place-items: center; cursor: pointer;
  border: 1px solid var(--surface-line); border-radius: 9px;
  background: var(--bg-1); color: var(--text-dim); font-size: 0.9rem;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.modal__close:hover { background: oklch(30% 0.12 25); color: var(--text); border-color: var(--danger); }
.modal__body { padding: 1.1rem 1.2rem 1.4rem; display: grid; gap: 0.2rem; }
.modal__body .field + .toggle { margin-top: 1.1rem; }

/* ====================================================================
   ICON POLISH — переход с эмодзи на line-SVG. Контейнеры, что раньше
   держали эмодзи через font-size, теперь центрируют <svg class="ic">.
   ==================================================================== */

/* Кнопки-иконки в контролах: убираем «текстовый» сдвиг, центрируем иконку. */
.ctrl__icon {
  display: grid; place-items: center; height: 1.5rem;
}
.ctrl__icon .ic { width: 1.5rem; height: 1.5rem; vertical-align: 0; }

/* Иконки в шапке/инлайн-метках — выравниваем по тексту без «прыжка» базлайна. */
.main__channel .ic, .invitebar__label .ic, .chat__title .ic,
.mastervol__ic .ic, .selfvol__ic .ic, .chan__ic .ic, .seg__btn .ic {
  vertical-align: -0.18em; opacity: 0.92;
}
.main__channel, .invitebar__label, .chat__title { display: inline-flex; align-items: center; gap: 0.45rem; }
.main__channel .ic { color: var(--accent); opacity: 1; }
.seg__btn { display: inline-flex; align-items: center; gap: 0.4rem; }

/* Квадратные кнопки-иконки: микро/мьют/наушники/закрыть/тоггл — центрируем. */
.userbar__mic, .member__mute, .modal__close, .chat-toggle, .chat__send, .rail__item, .rail__leave {
  display: grid; place-items: center;
}
.userbar__mic .ic, .member__mute .ic, .modal__close .ic, .chat__send .ic,
.rail__item .ic, .rail__leave .ic { vertical-align: 0; }
.chat-toggle__ic { display: grid; place-items: center; }
.chat-toggle__ic .ic { width: 1.25rem; height: 1.25rem; vertical-align: 0; }
.rail__item .ic { width: 1.5rem; height: 1.5rem; }

/* Галочка подтверждённого аккаунта — иконка вместо символа. */
.auth__check .ic { width: 0.95rem; height: 0.95rem; vertical-align: 0; stroke-width: 2.6; }
.msg__check { display: inline-grid; place-items: center; }
.msg__check .ic { width: 0.78rem; height: 0.78rem; vertical-align: 0; }

/* ====================================================================
   DEPTH & STATE POLISH — делаем поверхности «дороже»: мягкие тени,
   живые hover/active, тактильная отдача без новой логики.
   ==================================================================== */

/* Контролы: реальная глубина в покое + явный лифт и неон-ободок на hover. */
.ctrl {
  background:
    linear-gradient(180deg, var(--surface-hi), transparent 42%),
    oklch(16% 0.018 262);
  box-shadow: 0 1px 0 var(--surface-hi) inset, 0 6px 16px oklch(0% 0 0 / 0.32);
}
.ctrl:hover {
  transform: translateY(-2px);
  border-color: oklch(82% 0.15 195 / 0.4);
  box-shadow: 0 1px 0 var(--surface-hi) inset, 0 12px 30px oklch(0% 0 0 / 0.42), 0 0 22px oklch(64% 0.21 292 / 0.18);
}
.ctrl:active { transform: translateY(0); box-shadow: 0 2px 8px oklch(0% 0 0 / 0.4) inset; }
.ctrl[data-on="true"] .ctrl__icon { color: var(--accent); }
.ctrl[data-on="false"] .ctrl__icon { color: var(--text-dim); }
.ctrl--danger:hover .ctrl__icon { color: var(--danger); }
#shareBtn[data-on="true"] .ctrl__icon { color: var(--accent); }

/* Кнопки-иконки в шапке: единый «дорогой» отклик. */
.chat-toggle:hover { transform: translateY(-1px); box-shadow: inset 0 1px 0 var(--surface-hi), 0 8px 20px oklch(0% 0 0 / 0.35); }
.chat-toggle[aria-pressed="true"] .chat-toggle__ic { color: var(--accent); }

/* Аватары — фирменный двухцветный градиент + кольцо, не плоский кружок. */
.tile__avatar, .member__avatar, .userbar__avatar {
  background:
    radial-gradient(120% 120% at 30% 22%, var(--accent-2) 0%, transparent 60%),
    radial-gradient(120% 120% at 78% 84%, var(--accent) 0%, transparent 58%),
    oklch(22% 0.04 262);
  box-shadow: inset 0 0 0 1px var(--surface-hi), 0 8px 22px oklch(0% 0 0 / 0.4);
  color: oklch(98% 0.01 285);
}
.userbar__avatar { box-shadow: inset 0 0 0 1px var(--surface-hi), 0 4px 12px oklch(0% 0 0 / 0.4); }
.member__avatar { box-shadow: inset 0 0 0 1px var(--surface-hi); }

/* Рейл: активный сервер с фирменным свечением, прочие — мягкий лифт. */
.rail__item:hover { box-shadow: 0 6px 16px oklch(0% 0 0 / 0.35); }

/* Кнопка отправки/инвайта: glow при наведении (премиальный CTA). */
.chat__send:hover, .invitebar__btn:hover { box-shadow: 0 6px 18px oklch(64% 0.21 292 / 0.4); }
.chat__send .ic { color: oklch(16% 0.02 260); }

/* Карточка лобби и модалка — чуть глубже сажаем в фон. */
.lobby__card, .modal__card { box-shadow: 0 40px 110px oklch(0% 0 0 / 0.62), 0 2px 0 var(--surface-hi) inset; }

/* ====================================================================
   EMOJI PICKER — мини-палитра для чата (оживляет кнопку 🙂 → ic-smile).
   ==================================================================== */
.emoji-pop {
  position: absolute; z-index: 70;
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 2px;
  padding: 8px; width: max-content;
  background: oklch(18% 0.022 280 / 0.97); backdrop-filter: blur(16px);
  border: 1px solid var(--surface-line); border-radius: var(--radius);
  box-shadow: 0 18px 50px oklch(0% 0 0 / 0.55), inset 0 1px 0 var(--surface-hi);
  animation: modalRise 160ms var(--ease);
}
.emoji-pop[hidden] { display: none; }
.emoji-pop button {
  width: 2.1rem; height: 2.1rem; border: 0; cursor: pointer;
  background: transparent; border-radius: 9px; font-size: 1.2rem; line-height: 1;
  transition: transform 120ms var(--ease), background 120ms var(--ease);
}
.emoji-pop button:hover { background: var(--bg-2); transform: scale(1.18); }

/* ======================================================================
   MusicX — кнопка в футере, панель, плеер, очередь
   ====================================================================== */
.ctrl { position: relative; }
.ctrl__dot {
  position: absolute; top: 7px; right: 9px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 2px var(--bg-1), 0 0 10px var(--accent);
  animation: musicPulse 1.6s ease-in-out infinite;
}
@keyframes musicPulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.45; transform: scale(0.7); } }

/* Панель — right-docked sheet (десктоп), снизу (мобила) */
.music {
  position: fixed; inset: 0; z-index: 60;
  display: flex; justify-content: flex-end;
  background: oklch(8% 0.01 280 / 0.5); backdrop-filter: blur(5px);
}
.music[hidden] { display: none; }
.music__card {
  width: min(420px, 100%); height: 100%;
  display: flex; flex-direction: column;
  background:
    radial-gradient(120% 60% at 100% 0%, oklch(64% 0.21 292 / 0.16), transparent 60%),
    linear-gradient(180deg, var(--surface-hi), transparent 38%),
    oklch(13% 0.02 282 / 0.86);
  border-left: 1px solid var(--surface-line);
  backdrop-filter: blur(26px) saturate(1.3);
  box-shadow: -40px 0 120px oklch(0% 0 0 / 0.55);
  transform: translateX(100%);
  transition: transform var(--dur) var(--ease);
}
.music--open .music__card { transform: translateX(0); }

.music__head {
  display: flex; align-items: center; gap: 0.7rem;
  padding: 1.1rem 1.2rem; border-bottom: 1px solid var(--surface-line);
}
.music__title {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--font-display); font-weight: 800; letter-spacing: -0.02em; font-size: 1.1rem;
}
.music__title .ic { color: var(--accent); }
.music__host {
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.02em; text-transform: uppercase;
  color: var(--accent); opacity: 0.85; margin-left: auto;
}

/* Сейчас играет */
.now {
  display: flex; gap: 0.9rem; align-items: center;
  padding: 1.1rem 1.2rem 0.6rem;
}
.now__art {
  flex: 0 0 auto; width: 72px; height: 72px; border-radius: var(--radius);
  display: grid; place-items: center;
  background: linear-gradient(140deg, var(--bg-2), oklch(30% 0.08 285));
  box-shadow: inset 0 0 0 1px var(--surface-line);
  background-size: cover; background-position: center;
  color: var(--text-dim);
}
.now__art--img { color: transparent; }
.now[data-empty="true"] .now__art .ic { opacity: 0.4; }
.now__meta { min-width: 0; flex: 1; }
.now__title {
  font-weight: 700; font-size: 1rem; letter-spacing: -0.01em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.now__artist {
  font-size: 0.82rem; color: var(--text-dim); margin-top: 0.1rem;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.now__bar {
  margin-top: 0.6rem; height: 4px; border-radius: 99px;
  background: var(--surface-line); overflow: hidden;
}
.now__fill { height: 100%; width: 0%; border-radius: 99px; background: var(--grad-brand); transition: width 240ms linear; }
.now__time { display: flex; justify-content: space-between; font-size: 0.68rem; color: var(--text-dim); margin-top: 0.3rem; font-variant-numeric: tabular-nums; }

/* Управление */
.music__controls {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.4rem 1.2rem 1rem;
}
.mctrl {
  width: 42px; height: 42px; border-radius: 50%;
  display: grid; place-items: center; cursor: pointer;
  background: var(--bg-2); color: var(--text);
  border: 1px solid var(--surface-line);
  transition: transform 120ms var(--ease), background 120ms var(--ease), box-shadow 120ms var(--ease);
}
.mctrl:hover { transform: translateY(-2px); background: var(--surface-2); }
.mctrl:active { transform: translateY(0); }
.mctrl--play {
  width: 54px; height: 54px;
  background: var(--grad-brand); color: oklch(15% 0.02 280); border: 0;
  box-shadow: 0 8px 24px oklch(64% 0.21 292 / 0.4);
}
.mctrl--play:hover { box-shadow: 0 10px 30px oklch(64% 0.21 292 / 0.55); }
.mctrl--play .ic { width: 1.5rem; height: 1.5rem; }
.music__vol { display: flex; align-items: center; gap: 0.45rem; margin-left: auto; color: var(--text-dim); flex: 1; max-width: 140px; }
.music__vol input[type="range"] { width: 100%; accent-color: var(--accent); height: 4px; cursor: pointer; }

/* Добавить */
.music__add { display: flex; gap: 0.5rem; padding: 0 1.2rem; }
.music__input {
  flex: 1; min-width: 0;
  background: var(--bg-1); color: var(--text);
  border: 1px solid var(--surface-line); border-radius: var(--radius-sm);
  padding: 0.7rem 0.85rem; font-size: 0.9rem; outline: none;
  transition: border-color 120ms var(--ease), box-shadow 120ms var(--ease);
}
.music__input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px oklch(82% 0.15 195 / 0.15); }
.music__input:disabled { opacity: 0.5; }
.music__addbtn {
  flex: 0 0 auto; width: 44px; border: 0; border-radius: var(--radius-sm); cursor: pointer;
  background: var(--grad-brand); color: oklch(15% 0.02 280);
  display: grid; place-items: center;
  transition: transform 120ms var(--ease), filter 120ms var(--ease);
}
.music__addbtn:hover { transform: translateY(-1px); filter: brightness(1.08); }
.music__addbtn:disabled { opacity: 0.5; cursor: progress; }
.music__hint { padding: 0.5rem 1.2rem 0.4rem; font-size: 0.74rem; color: var(--text-dim); line-height: 1.45; }

/* Очередь */
.queue { flex: 1; min-height: 0; display: flex; flex-direction: column; padding-top: 0.4rem; }
.queue__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.5rem 1.2rem; font-size: 0.72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-dim);
  border-top: 1px solid var(--surface-line);
}
.queue__clear { background: transparent; border: 0; color: var(--text-dim); cursor: pointer; padding: 0.25rem; border-radius: 8px; }
.queue__clear:hover { color: var(--danger); background: oklch(30% 0.12 25 / 0.3); }
.queue__list { list-style: none; margin: 0; padding: 0 0.6rem 1rem; overflow-y: auto; flex: 1; }
.queue__item {
  display: flex; align-items: center; gap: 0.7rem;
  padding: 0.5rem 0.6rem; border-radius: var(--radius-sm); cursor: pointer;
  transition: background 120ms var(--ease);
}
.queue__item:hover { background: var(--surface-2); }
.queue__item:hover .queue__del { opacity: 1; }
.queue__item--active { background: oklch(82% 0.15 195 / 0.1); box-shadow: inset 0 0 0 1px oklch(82% 0.15 195 / 0.25); }
.queue__art {
  flex: 0 0 auto; width: 38px; height: 38px; border-radius: 9px;
  background-size: cover; background-position: center; background-color: var(--bg-2);
  display: grid; place-items: center; color: var(--text-dim);
}
.queue__art--ph { box-shadow: inset 0 0 0 1px var(--surface-line); }
.queue__meta { min-width: 0; flex: 1; }
.queue__t { display: block; font-size: 0.86rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.queue__a { display: block; font-size: 0.74rem; color: var(--text-dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.queue__dur { font-size: 0.74rem; color: var(--text-dim); font-variant-numeric: tabular-nums; }
.queue__del {
  flex: 0 0 auto; background: transparent; border: 0; cursor: pointer;
  color: var(--text-dim); padding: 0.3rem; border-radius: 7px; opacity: 0; transition: opacity 120ms, color 120ms, background 120ms;
}
.queue__del:hover { color: var(--danger); background: oklch(30% 0.12 25 / 0.3); }

@media (max-width: 640px) {
  .music { justify-content: stretch; }
  .music__card {
    width: 100%; height: 88%; margin-top: auto; border-left: 0;
    border-top-left-radius: var(--radius-lg); border-top-right-radius: var(--radius-lg);
    transform: translateY(100%);
  }
  .music--open .music__card { transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .music__card { transition: none; }
  .ctrl__dot { animation: none; }
  .now__fill { transition: none; }
}
