/* ═══════════════════════════════════════════════════════
   DCSHOT — Styles
   Tokeny: design-tokens-v2.css (importovať pred týmto súborom)
   Zdroj: cosmos.html
═══════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { height: 100%; }
body {
  min-height: 100%;
  background: var(--bg);
  color: var(--t1);
  font-family: var(--font);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
}

/* ── PARTICLES ── */
#canvas {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: var(--z-base);
  opacity: var(--canvas-op);
}

/* ── NAV ── */
.nav {
  position: sticky; top: 0; z-index: var(--z-float);
  display: flex; align-items: center;
  padding: var(--sp-2) var(--sp-3); gap: var(--sp-0);
  border-bottom: var(--bw) solid var(--ln);
  background: var(--bg-overlay);
  backdrop-filter: blur(var(--sp-3));
  flex-shrink: 0;
}

.logo {
  display: flex; align-items: center; gap: var(--sp-2);
  margin-right: var(--sp-3); cursor: pointer;
  transition: opacity var(--dur-base);
}
.logo:hover { opacity: var(--op-8); }
.logo-img {
  width: var(--sz-lg); height: var(--sz-lg);
  filter: drop-shadow(0 0 var(--glow-sm) rgba(var(--_a2),var(--op-5)));
  transition: transform var(--dur-slow);
}
.logo:hover .logo-img { transform: scale(1.05); }
.logo-gem {
  width: var(--sz-lg); height: var(--sz-lg);
  border-radius: var(--r-lg);
  background: linear-gradient(135deg, var(--p2), var(--p), var(--cy));
  box-shadow: 0 0 var(--glow-md) rgba(var(--_a2),var(--op-5)), 0 0 var(--glow-lg) rgba(var(--_a2),var(--op-1));
  display: flex; align-items: center; justify-content: center;
  position: relative;
  transition: box-shadow var(--dur-slow), transform var(--dur-slow);
}
.logo:hover .logo-gem {
  box-shadow: 0 0 var(--glow-md) rgba(var(--_a2),var(--op-8)), 0 0 var(--glow-xl) rgba(var(--_a2),var(--op-3));
  transform: scale(1.05);
}
.logo-gem::after {
  content: '';
  position: absolute; inset: var(--bw);
  border-radius: var(--r-md);
  background: linear-gradient(135deg, rgba(var(--_white-rgb),var(--op-3)) 0%, transparent 60%);
}
.logo-gem svg { position: relative; z-index: var(--z-base); }
.logo-name {
  font-size: var(--fs-lg); font-weight: 800; letter-spacing: var(--ls-tight);
  background: linear-gradient(90deg, var(--logo-from) 30%, var(--p) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}

.tabs { display: flex; align-items: center; gap: var(--sp-0); }
.tab {
  padding: var(--sp-1) var(--sp-3);
  font-size: var(--fs-base); font-weight: 500;
  color: var(--t2);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: color var(--dur-base), background var(--dur-base);
  user-select: none; position: relative;
}
.tab:hover { color: var(--t1); background: var(--s1); }
.tab.on { color: var(--t1); font-weight: 600; background: var(--px); }
.tab.on::after {
  content: '';
  position: absolute; bottom: var(--tab-underline); left: var(--sp-3); right: var(--sp-3);
  height: var(--bw); background: var(--p);
  box-shadow: 0 0 var(--glow-sm) var(--p);
}

.nav-r { margin-left: auto; display: flex; align-items: center; gap: var(--sp-2); }
.bot-pill {
  display: flex; align-items: center; gap: var(--sp-2);
  font-size: var(--fs-sm); color: var(--gr);
  background: var(--grd);
  border: var(--bw) solid rgba(var(--_gr-rgb),var(--op-3));
  padding: 0 var(--sp-2); border-radius: var(--r-md);
  font-weight: 600; height: var(--h-control);
}
.bot-pill.offline {
  color: var(--t3);
  background: var(--s2);
  border-color: var(--ln);
}
.blink {
  width: var(--sp-1); height: var(--sp-1); border-radius: 50%;
  background: var(--gr);
  animation: bl var(--dur-4) ease-in-out infinite;
}
@keyframes bl { 0%,100%{opacity:1;box-shadow:0 0 var(--glow-sm) var(--gr)}50%{opacity:var(--op-3);box-shadow:none} }

.guild-btn {
  background: var(--s1); border: var(--bw) solid var(--ln);
  border-radius: var(--r-md); padding: 0 var(--sp-3);
  font-size: var(--fs-base); font-weight: 500; color: var(--t1);
  cursor: pointer; transition: border-color var(--dur-base), background var(--dur-base);
  height: var(--h-control); display: flex; align-items: center;
}
.guild-btn:hover { border-color: var(--lnh); background: var(--s2); }

.user-btn {
  display: flex; align-items: center; gap: var(--sp-2);
  background: var(--s1); border: var(--bw) solid var(--ln);
  border-radius: var(--r-md); padding: 0 var(--sp-3) 0 var(--sp-2);
  cursor: pointer; font-size: var(--fs-base); font-weight: 600;
  transition: border-color var(--dur-base), background var(--dur-base);
  height: var(--h-control);
}
.user-btn:hover { border-color: var(--lnh); background: var(--s2); }
.av {
  width: var(--sz-md); height: var(--sz-md); border-radius: 50%;
  background: linear-gradient(135deg, var(--p2), var(--cy));
  display: flex; align-items: center; justify-content: center;
  font-size: var(--fs-sm); font-weight: 800; color: var(--white);
  box-shadow: 0 0 var(--glow-sm) rgba(var(--_a2),var(--op-3));
}

/* ── PAGE ── */
.page {
  flex: 1; position: relative; z-index: var(--z-base);
  padding: var(--sp-3) var(--sp-3);
  display: flex; flex-direction: column; gap: var(--sp-3);
}

/* ── ACTIVE SESSION CARD ── */
.session {
  background: linear-gradient(135deg, rgba(var(--_a2),var(--op-1)), rgba(var(--_a),var(--op-1)));
  border-radius: var(--r-lg);
  border: var(--bw) solid rgba(var(--_a),var(--op-3));
  box-shadow: 0 0 var(--glow-md) rgba(var(--_a2),var(--op-1)), 0 0 var(--glow-xl) rgba(var(--_cy-rgb),var(--op-1));
  overflow: hidden;
}
.session-top {
  display: flex; align-items: center;
  padding: var(--sp-2) var(--sp-3); gap: var(--sp-2);
  border-bottom: var(--bw) solid rgba(var(--_a),var(--op-1));
  background: rgba(var(--_white-rgb),var(--op-1));
}
.live-chip {
  display: flex; align-items: center; gap: var(--sp-2);
  background: rgba(var(--_a),var(--op-1));
  border: var(--bw) solid rgba(var(--_a),var(--op-3));
  border-radius: var(--r-md); padding: 0 var(--sp-2); height: var(--h-control);
  font-size: var(--fs-sm); font-weight: 800;
  color: var(--p); text-transform: uppercase; letter-spacing: var(--ls-lg);
}
.lp {
  width: var(--sp-1); height: var(--sp-1); border-radius: 50%; background: var(--p);
  animation: lpa var(--dur-2) ease-in-out infinite;
}
@keyframes lpa {
  0%,100% { opacity: 1; box-shadow: 0 0 0 0 var(--pg); }
  60% { opacity: var(--op-5); box-shadow: 0 0 0 var(--glow-sm) transparent; }
}

.timer {
  font-size: var(--fs-base); font-weight: 700; color: var(--t2);
  font-variant-numeric: tabular-nums; letter-spacing: var(--ls-md);
}
.s-btns { margin-left: auto; display: flex; gap: var(--sp-2); }

.session-body { padding: var(--sp-3); }

.meta-row {
  display: flex;
  margin-bottom: var(--sp-3);
  border: var(--bw) solid var(--ln); border-radius: var(--r-md); overflow: hidden;
}
.mc2 { flex: 1; padding: var(--sp-2) var(--sp-3); border-right: var(--bw) solid var(--ln); }
.mc2:last-child { border-right: none; }
.ml { font-size: var(--fs-xs); font-weight: 700; color: var(--t2); text-transform: uppercase; letter-spacing: var(--ls-lg); margin-bottom: var(--sp-1); }
.mv { font-size: var(--fs-base); font-weight: 700; }
.mv-p { color: var(--p); }
.mv-g { color: var(--gr); }
.mv-c { color: var(--cy); }

/* caller audio bars */
.caller-cell { display: flex; align-items: center; gap: var(--sp-2); }
.audio-bars {
  display: flex; align-items: flex-end; gap: var(--sp-0);
}
.bar {
  width: var(--sp-0); border-radius: var(--sp-1);
  background: var(--p);
  box-shadow: 0 0 var(--glow-sm) var(--p);
  animation: audiobar 0.7s ease-in-out infinite alternate;
}
.bar:nth-child(1) { animation-duration: 0.5s; }
.bar:nth-child(2) { animation-duration: 0.7s; animation-delay: 0.1s; }
.bar:nth-child(3) { animation-duration: 0.4s; animation-delay: 0.2s; }
.bar:nth-child(4) { animation-duration: 0.8s; animation-delay: 0.05s; }
.bar:nth-child(5) { animation-duration: 0.55s; animation-delay: 0.15s; }
@keyframes audiobar {
  from { height: var(--sp-0); opacity: var(--op-3); }
  to { height: var(--sp-3); opacity: 1; }
}

/* ── ROOMS ── */
.rooms { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--sp-2); }
.room {
  border: var(--bw) solid var(--ln);
  border-radius: var(--r-lg);
  background: var(--bg-float);
  overflow: hidden;
  cursor: grab;
  transition: border-color var(--dur-base), box-shadow var(--dur-base), opacity var(--dur-base);
  will-change: transform;
}
.room-ghost { opacity: 0 !important; }
.room-chosen { cursor: grabbing !important; }
.room-drag {
  opacity: var(--op-8) !important;
  transform: scale(1.05) rotateZ(1.5deg) !important;
  box-shadow: 0 var(--glow-md) var(--glow-lg) rgba(var(--_black-rgb),var(--op-8)), 0 0 var(--glow-md) var(--pg) !important;
  border-color: rgba(var(--_a),var(--op-5)) !important;
  z-index: var(--z-drag); cursor: grabbing !important;
}
.room:hover { border-color: var(--lnh); }
.room.r-mc {
  border-color: rgba(var(--_a),var(--op-3));
  box-shadow: inset 0 var(--bw) 0 rgba(var(--_a),var(--op-1));
}
.room.r-mc:hover { box-shadow: 0 0 var(--glow-md) rgba(var(--_a2),var(--op-3)), inset 0 var(--bw) 0 rgba(var(--_a),var(--op-1)); }
.room.r-pc {
  border-color: rgba(var(--_gr-rgb),var(--op-3));
}
.room.r-pc:hover { box-shadow: 0 0 var(--glow-md) rgba(var(--_gr-rgb),var(--op-3)); }

.room-top {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-1) var(--sp-2) 0;
}
.rname { font-size: var(--fs-xs); font-weight: 800; color: var(--t2); text-transform: uppercase; letter-spacing: var(--ls-lg); }
.rtag {
  font-size: var(--fs-xs); font-weight: 800;
  border-radius: var(--r-sm);
  text-transform: uppercase; letter-spacing: var(--ls-md);
}
.rtag-mc { background: var(--px); color: var(--p); }
.rtag-pc { background: var(--grd); color: var(--gr); }

.room-users { padding: var(--sp-1) var(--sp-2) var(--sp-2); display: flex; flex-direction: column; gap: var(--sp-1); }
.ru {
  display: flex; align-items: center; gap: var(--sp-1);
  transition: opacity var(--dur-base);
}
.ru:hover { opacity: var(--op-8); }
.rav {
  width: var(--sp-2); height: var(--sp-2); border-radius: 50%;
  background: var(--t3);
  flex-shrink: 0; transition: box-shadow var(--dur-base);
}
.rav.mc { background: var(--p); box-shadow: 0 0 var(--glow-sm) var(--pg); }
.rav.pc { background: var(--gr); box-shadow: 0 0 var(--glow-sm) rgba(var(--_gr-rgb),var(--op-5)); }
.runame { font-size: var(--fs-base); color: var(--t1); }

/* ── BOTTOM ── */
.row2 { display: grid; grid-template-columns: 1fr auto; gap: var(--sp-3); }
.sh { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-2); }
.sh-t { font-size: var(--fs-base); font-weight: 700; }

.glass {
  background: var(--s1); border: var(--bw) solid var(--ln);
  border-radius: var(--r-lg); backdrop-filter: blur(var(--sp-2));
  transition: border-color var(--dur-base), box-shadow var(--dur-base);
}
.glass:hover { border-color: var(--lnh); box-shadow: 0 var(--glow-sm) var(--glow-md) rgba(var(--_black-rgb),var(--op-3)); }

/* TABLE */
.tbl { width: 100%; border-collapse: collapse; }
.tbl th {
  font-size: var(--fs-xs); font-weight: 700; color: var(--t2);
  text-transform: uppercase; letter-spacing: var(--ls-lg);
  padding: var(--sp-2) var(--sp-3); border-bottom: var(--bw) solid var(--ln); text-align: left;
}
.tbl td {
  padding: var(--sp-2) var(--sp-3); font-size: var(--fs-base);
  border-bottom: var(--bw) solid var(--s1);
  transition: background var(--dur-instant);
}
.tbl tr:last-child td { border-bottom: none; }
.tbl tr:hover td { background: rgba(var(--_white-rgb),var(--op-1)); }
.tc { color: var(--p); font-weight: 600; }
.td-m { color: var(--t2); }

/* CONTROL */
.ctrl-body { padding: var(--sp-3); display: flex; flex-direction: column; gap: var(--sp-3); }
.field { display: flex; flex-direction: column; gap: var(--sp-1); }
.field label {
  font-size: var(--fs-xs); font-weight: 700;
  color: var(--t2); text-transform: uppercase; letter-spacing: var(--ls-lg);
}

.toggles { display: flex; flex-direction: column; gap: var(--sp-2); border-top: var(--bw) solid var(--ln); padding-top: var(--sp-3); }
.trow { display: flex; align-items: center; gap: var(--sp-2); }
.tog {
  width: var(--tog-w); height: var(--tog-h); border-radius: var(--r-lg);
  background: var(--tog-off);
  position: relative; cursor: pointer; flex-shrink: 0;
  transition: background var(--dur-base), box-shadow var(--dur-base);
  border: var(--bw) solid rgba(var(--_white-rgb),var(--op-1));
}
.tog.on { background: var(--p2); box-shadow: 0 0 var(--glow-sm) rgba(var(--_a2),var(--op-5)); border-color: transparent; }
.tog::after {
  content: ''; width: var(--tog-thumb); height: var(--tog-thumb); background: var(--white);
  border-radius: 50%; position: absolute; top: var(--sp-0); left: var(--sp-0);
  transition: transform var(--dur-base) var(--ease);
  box-shadow: 0 var(--glow-sm) var(--glow-sm) rgba(var(--_black-rgb),var(--op-5));
}
.tog.on::after { transform: translateX(var(--tog-thumb)); }
.trow.disabled { opacity: var(--op-5); pointer-events: none; }
.tog-txt { display: flex; flex-direction: column; gap: var(--sp-0); }
.tog-l { font-size: var(--fs-base); font-weight: 500; }
.tog-d { font-size: var(--fs-sm); color: var(--t2); }

/* BUTTONS */
.btn {
  display: inline-flex; align-items: center; gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-2); border-radius: var(--r-md);
  font-size: var(--fs-base); font-weight: 600; cursor: pointer; border: var(--bw) solid transparent;
  font-family: var(--font);
  transition: transform var(--dur-instant), box-shadow var(--dur-base), opacity var(--dur-base);
}
.btn:active { transform: var(--btn-press); }
.btn-p {
  background: linear-gradient(135deg, var(--p2), var(--p));
  color: var(--white); box-shadow: 0 var(--glow-sm) var(--glow-md) rgba(var(--_a2),var(--op-3));
}
.btn-p:hover { box-shadow: 0 var(--glow-sm) var(--glow-md) rgba(var(--_a2),var(--op-5)); opacity: var(--op-8); }
.btn-g {
  background: var(--s2); color: var(--t2); border: var(--bw) solid var(--ln);
}
.btn-g:hover { border-color: var(--lnh); color: var(--t1); background: var(--ln); }
.btn-r {
  background: transparent; color: var(--re);
  border: var(--bw) solid rgba(var(--_re-rgb),var(--op-3));
}
.btn-r:hover { background: rgba(var(--_re-rgb),var(--op-1)); }
.btn-danger {
  background: linear-gradient(135deg, var(--re2), var(--re));
  color: var(--white); box-shadow: 0 var(--glow-sm) var(--glow-md) rgba(var(--_re-rgb),var(--op-3));
}
.btn-danger:hover { box-shadow: 0 var(--glow-sm) var(--glow-md) rgba(var(--_re-rgb),var(--op-5)); opacity: var(--op-8); }
.sm { padding: 0 var(--sp-2); font-size: var(--fs-sm); height: var(--h-control); }

/* ── CHECKBOXY ── */
.check-wrap {
  display: flex; align-items: center; gap: var(--sp-2);
  cursor: pointer; user-select: none; padding: var(--sp-2) 0;
}
.check-wrap:hover .check-box { border-color: var(--p); }
.check-wrap.disabled { opacity: var(--op-5); pointer-events: none; }
.check-box {
  width: var(--sz-sm); height: var(--sz-sm); border-radius: var(--r-sm);
  border: var(--sp-0) solid var(--t3); background: var(--s2);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; position: relative;
  transition: border-color var(--dur-base), background var(--dur-base), box-shadow var(--dur-base);
}
.check-box.checked {
  background: var(--p2); border-color: var(--p);
  box-shadow: 0 0 var(--glow-sm) rgba(var(--_a2),var(--op-3));
}
.check-box.checked::after {
  content: '';
  width: var(--sp-2); height: var(--sp-1);
  border-left: var(--sp-0) solid var(--white); border-bottom: var(--sp-0) solid var(--white);
  transform: rotate(var(--check-angle)) translateY(-1px); display: block;
}
.check-box.indeterminate::after {
  content: ''; width: var(--sp-2); height: var(--sp-1);
  background: var(--t2); border-radius: var(--sp-1); display: block;
}
.check-label { font-size: var(--fs-base); color: var(--t1); font-weight: 500; }
.check-desc { font-size: var(--fs-sm); color: var(--t2); }
.check-info { display: flex; flex-direction: column; gap: var(--sp-0); }

/* ── RADIO ── */
.radio-wrap {
  display: flex; align-items: center; gap: var(--sp-2);
  cursor: pointer; user-select: none; padding: var(--sp-2) 0;
}
.radio-wrap:hover .radio-box { border-color: var(--p); }
.radio-box {
  width: var(--sz-sm); height: var(--sz-sm); border-radius: 50%;
  border: var(--sp-0) solid var(--t3); background: var(--s2);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: border-color var(--dur-base), box-shadow var(--dur-base);
}
.radio-box.checked { border-color: var(--p); box-shadow: 0 0 var(--glow-sm) rgba(var(--_a2),var(--op-3)); }
.radio-box.checked::after {
  content: ''; width: var(--sp-2); height: var(--sp-2); border-radius: 50%;
  background: var(--p); box-shadow: 0 0 var(--glow-sm) var(--p); display: block;
}
.radio-label { font-size: var(--fs-base); color: var(--t1); font-weight: 500; }

/* ── CUSTOM DROPDOWN ── */
.custom-select { position: relative; min-width: var(--w-sm); }
.sel-trigger {
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-1);
  background: var(--s2); border: var(--bw) solid var(--ln); border-radius: var(--r-md);
  padding: var(--sp-1) var(--sp-2); cursor: pointer; font-size: var(--fs-base); color: var(--t1);
  transition: border-color var(--dur-base), box-shadow var(--dur-base); user-select: none;
}
.sel-trigger:hover { border-color: var(--lnh); }
.sel-trigger.open { border-color: rgba(var(--_a),var(--op-5)); box-shadow: 0 0 0 var(--sp-0) var(--px); }
.sel-arrow { color: var(--t3); font-size: var(--fs-xs); transition: transform var(--dur-base); }
.sel-trigger.open .sel-arrow { transform: var(--arrow-rotate); }
.sel-dropdown {
  position: absolute; top: calc(100% + var(--sp-1)); left: 0; right: 0;
  background: var(--bg-float); border: var(--bw) solid rgba(var(--_a),var(--op-3));
  border-radius: var(--r-md); overflow: hidden; z-index: var(--z-float);
  box-shadow: 0 var(--glow-sm) var(--glow-lg) rgba(var(--_black-rgb),var(--op-5)), 0 0 0 var(--bw) rgba(var(--_white-rgb),var(--op-1));
  display: none;
}
.sel-dropdown.open { display: block; animation: dropIn var(--dur-base) ease; }
@keyframes dropIn {
  from { opacity: 0; transform: translateY(calc(var(--sp-1) * -1)); }
  to   { opacity: 1; transform: translateY(0); }
}
.sel-option {
  display: flex; align-items: center; gap: var(--sp-1);
  padding: var(--sp-1); cursor: pointer;
  font-size: var(--fs-base); color: var(--t2);
  transition: background var(--dur-instant), color var(--dur-instant);
  border-bottom: var(--bw) solid var(--ln);
}
.sel-option:last-child { border-bottom: none; }
.sel-option:hover { background: var(--px); color: var(--t1); }
.sel-option.selected { color: var(--p); font-weight: 600; }
.sel-option.selected::after { content: '\2713'; margin-left: auto; font-size: var(--fs-sm); color: var(--p); }
.sel-dot { width: var(--sp-2); height: var(--sp-2); border-radius: 50%; flex-shrink: 0; }

/* ── INPUT ── */
.input {
  width: var(--w-md);
  background: var(--s2); border: var(--bw) solid var(--ln);
  border-radius: var(--r-md); color: var(--t1);
  font-size: var(--fs-base); font-family: var(--font);
  padding: var(--sp-1) var(--sp-2); outline: none;
  transition: border-color var(--dur-base), box-shadow var(--dur-base);
}
.input:focus { border-color: rgba(var(--_a),var(--op-5)); box-shadow: 0 0 0 var(--sp-0) var(--px); }
.input::placeholder { color: var(--t3); }

/* ── MODÁLNE OKNO ── */
.modal-overlay {
  position: fixed; inset: 0;
  background: var(--bg-overlay); backdrop-filter: blur(var(--sp-2));
  z-index: var(--z-modal); display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity var(--dur-base);
}
.modal-overlay.open { opacity: 1; pointer-events: auto; }
.modal {
  width: var(--modal-sm);
  background: var(--bg-float); border: var(--bw) solid rgba(var(--_a),var(--op-1));
  border-radius: var(--r-xl);
  box-shadow: 0 var(--glow-md) var(--glow-xl) rgba(var(--_black-rgb),var(--op-8)), 0 0 var(--glow-lg) rgba(var(--_a2),var(--op-1));
  transform: var(--btn-press) translateY(var(--sp-2));
  transition: transform var(--dur-base) var(--ease); overflow: hidden;
}
.modal-overlay.open .modal { transform: scale(1) translateY(0); }
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-3) var(--sp-3); border-bottom: var(--bw) solid var(--ln);
}
.modal-title { font-size: var(--fs-base); font-weight: 700; }
.modal-close {
  width: var(--sz-lg); height: var(--sz-lg); border-radius: var(--r-md);
  background: var(--s1); border: var(--bw) solid var(--ln);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--t3); font-size: var(--fs-base);
  transition: background var(--dur-base), color var(--dur-base), border-color var(--dur-base);
}
.modal-close:hover { background: var(--s2); color: var(--t1); border-color: var(--lnh); }
.modal-body { padding: var(--sp-3); display: flex; flex-direction: column; align-items: center; gap: var(--sp-3); }
.modal-footer {
  display: flex; align-items: center; justify-content: flex-end; gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-3); border-top: var(--bw) solid var(--ln);
  background: rgba(var(--_white-rgb),var(--op-1));
}
.modal.danger {
  border-color: rgba(var(--_re-rgb),var(--op-3));
  box-shadow: 0 var(--glow-md) var(--glow-xl) rgba(var(--_black-rgb),var(--op-8)), 0 0 var(--glow-lg) rgba(var(--_re-rgb),var(--op-1));
}
.modal-icon {
  width: var(--sz-xl); height: var(--sz-xl); border-radius: var(--r-lg);
  display: flex; align-items: center; justify-content: center;
  font-size: var(--fs-lg); margin-bottom: var(--sp-1);
}
.modal-icon.danger-icon { background: rgba(var(--_re-rgb),var(--op-1)); }
.modal-text { font-size: var(--fs-base); color: var(--t2); line-height: var(--lh-relaxed); }
.modal-text strong { color: var(--t1); }

/* ── THEME SWITCHER ── */
.theme-sw {
  position: fixed; bottom: var(--sp-3); right: var(--sp-3); z-index: var(--z-top);
  display: flex; gap: var(--sp-2); align-items: center;
  background: var(--bg-float); border: var(--bw) solid var(--ln);
  border-radius: var(--r-xl); padding: var(--sp-2) var(--sp-3);
}
.theme-sw-label { font-size: var(--fs-xs); color: var(--t3); font-weight: 700; text-transform: uppercase; letter-spacing: var(--ls-lg); }
.tdot {
  width: var(--sp-3); height: var(--sp-3); border-radius: 50%;
  cursor: pointer; transition: transform var(--dur-base), box-shadow var(--dur-base);
  border: var(--sp-0) solid transparent; flex-shrink: 0;
}
.tdot:hover { transform: scale(1.25); }
.tdot.on { border-color: var(--white); box-shadow: 0 0 var(--glow-sm) currentColor; }
.theme-sep { width: var(--bw); height: var(--sp-3); background: var(--ln); }
.mode-btn {
  background: none; border: none; cursor: pointer;
  font-size: var(--fs-base); padding: 0; line-height: 1;
  transition: transform var(--dur-slow);
}
.mode-btn:hover { transform: scale(1.2) rotate(20deg); }

/* ── SESSION LAYOUT ── */
.session-layout {
  display: grid; grid-template-columns: auto auto; gap: var(--sp-3);
  align-items: start; justify-content: center;
}

/* Voice channels panel */
.channels-panel { display: flex; flex-direction: column; gap: var(--sp-2); width: var(--w-md); }

.channel {
  background: var(--s1); border: var(--bw) solid var(--ln);
  border-radius: var(--r-lg); overflow: hidden;
  transition: border-color var(--dur-base), box-shadow var(--dur-base);
}
.channel.has-bot {
  border-width: 2px;
  border-color: rgba(var(--_gr-rgb), var(--op-3));
  box-shadow: inset 0 var(--bw) 0 rgba(var(--_gr-rgb), var(--op-1));
}
.channel.has-bot.paused {
  border-color: var(--ln);
  box-shadow: none;
  opacity: var(--op-5);
}
.channel.drop-over {
  border-color: var(--gr) !important;
  box-shadow: 0 0 var(--glow-md) rgba(var(--_gr-rgb), var(--op-3)),
              inset 0 0 var(--glow-md) rgba(var(--_gr-rgb), var(--op-1)) !important;
}
.channel-header {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border-bottom: var(--bw) solid var(--ln);
}
.channel-icon { color: var(--t3); font-size: var(--fs-sm); }
.channel-name { font-size: var(--fs-base); font-weight: 700; color: var(--t1); flex: 1; }
.channel-bot-tag {
  font-size: var(--fs-xs); font-weight: 800; text-transform: uppercase;
  letter-spacing: var(--ls-md);
  background: var(--grd); color: var(--gr);
  padding: 0 var(--sp-1); border-radius: var(--r-sm);
}

.channel-users { padding: var(--sp-1) var(--sp-3) var(--sp-2); display: flex; flex-direction: column; gap: var(--sp-0); }

.ch-user {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-0) var(--sp-2); border-radius: var(--r-md);
  transition: background var(--dur-instant);
  position: relative;
}
.ch-user:hover { background: var(--s1); }
.ch-user[draggable="true"] { cursor: grab; }
.ch-user[draggable="true"]:active { cursor: grabbing; }
.ch-user.drop-over { background: var(--s2); }

.ch-user-dot {
  width: var(--sp-2); height: var(--sp-2); border-radius: 50%;
  background: var(--gr); flex-shrink: 0;
}
.ch-user-name { font-size: var(--fs-sm); color: var(--t1); flex: 1; }

/* Role badges on users */
.ch-user-role {
  font-size: var(--fs-xs); font-weight: 800; text-transform: uppercase;
  letter-spacing: var(--ls-md); padding: 0 var(--sp-1);
  border-radius: var(--r-sm); cursor: grab;
}
.ch-user-role:active { cursor: grabbing; }
.ch-user-role.role-mc {
  background: rgba(249, 115, 22, 0.15); color: #f97316;
}
.ch-user:has(.role-mc) .ch-user-name { color: #f97316; font-weight: 600; }
.ch-user-role.role-pc {
  background: rgba(14, 165, 233, 0.15); color: #0ea5e9;
}
.ch-user:has(.role-pc) .ch-user-name { color: #0ea5e9; font-weight: 600; }

/* Bot user in channel */
.ch-user.is-bot .ch-user-dot { background: var(--p); box-shadow: 0 0 var(--glow-sm) var(--pg); }
.ch-user.is-bot .ch-user-name { color: var(--p); font-weight: 600; }

/* Empty channel drop zone */
.channel-empty {
  padding: var(--sp-2) var(--sp-3);
  color: var(--t3); font-size: var(--fs-xs);
  text-align: center; font-style: italic;
}

/* ── SIDEBAR: BOTS + ROLES ── */
.sidebar-panel {
  width: var(--w-sm); display: flex; flex-direction: column; gap: var(--sp-3);
  position: sticky; top: 60px;
}

.sidebar-section {
  background: var(--s1); border: var(--bw) solid var(--ln);
  border-radius: var(--r-lg); overflow: hidden;
}
.sidebar-title {
  font-size: var(--fs-xs); font-weight: 700; color: var(--t2);
  text-transform: uppercase; letter-spacing: var(--ls-lg);
  padding: var(--sp-2) var(--sp-3);
  border-bottom: var(--bw) solid var(--ln);
}

.sidebar-items { padding: var(--sp-2); display: flex; flex-direction: column; gap: var(--sp-1); }

/* Draggable bot card */
.bot-card {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-1) var(--sp-2); border-radius: var(--r-md);
  background: var(--s2); border: var(--bw) solid var(--ln);
  cursor: grab; user-select: none;
  transition: border-color var(--dur-base), box-shadow var(--dur-base), transform var(--dur-instant), opacity var(--dur-base);
}
.bot-card:hover { border-color: var(--lnh); background: var(--ln); }
.bot-card:active { cursor: grabbing; transform: var(--btn-press); }
.bot-card.assigned { opacity: var(--op-3); pointer-events: none; }
.bot-card.dragging {
  opacity: var(--op-8); transform: scale(1.05);
  box-shadow: 0 var(--glow-sm) var(--glow-md) rgba(var(--_black-rgb), var(--op-5));
  z-index: var(--z-drag);
}

.bot-card-dot {
  width: var(--sp-2); height: var(--sp-2); border-radius: 50%;
  background: var(--p); box-shadow: 0 0 var(--glow-sm) var(--pg);
  flex-shrink: 0;
}
.bot-card-name { font-size: var(--fs-sm); font-weight: 600; color: var(--t1); flex: 1; }
.bot-card-grip { color: var(--t3); font-size: var(--fs-xs); }

/* Draggable role badge */
.role-badge {
  display: inline-flex; align-items: center; gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-2); border-radius: var(--r-md);
  font-size: var(--fs-xs); font-weight: 800; text-transform: uppercase;
  letter-spacing: var(--ls-md);
  cursor: grab; user-select: none;
  transition: transform var(--dur-instant), box-shadow var(--dur-base);
}
.role-badge:active { cursor: grabbing; transform: var(--btn-press); }
.role-badge.dragging {
  transform: scale(1.1);
  box-shadow: 0 var(--glow-sm) var(--glow-md) rgba(var(--_black-rgb), var(--op-5));
  z-index: var(--z-drag);
}

.role-badge-mc {
  background: rgba(249, 115, 22, 0.15); color: #f97316;
  border: var(--bw) solid rgba(249, 115, 22, 0.3);
}
.role-badge-mc:hover { box-shadow: 0 0 var(--glow-sm) rgba(249, 115, 22, 0.3); }

.role-badge-pc {
  background: rgba(14, 165, 233, 0.15); color: #0ea5e9;
  border: var(--bw) solid rgba(14, 165, 233, 0.3);
}
.role-badge-pc:hover { box-shadow: 0 0 var(--glow-sm) rgba(14, 165, 233, 0.3); }

/* Assigned roles list */
.assigned-roles { padding: var(--sp-1) var(--sp-3) var(--sp-2); display: flex; flex-direction: column; gap: var(--sp-1); }
.assigned-role {
  display: flex; align-items: center; gap: var(--sp-2);
  font-size: var(--fs-sm); padding: var(--sp-1) 0;
}
.assigned-role-name { flex: 1; }
.assigned-role-remove {
  color: var(--t3); cursor: pointer; font-size: var(--fs-xs);
  transition: color var(--dur-base);
}
.assigned-role-remove:hover { color: var(--re); }

/* ── USERS ── */
.users-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-2);
}
.users-filters {
  display: flex; gap: var(--sp-1); flex-wrap: wrap;
}
.users-list {
  display: flex; flex-direction: column;
  background: var(--s1); border: var(--bw) solid var(--ln);
  border-radius: var(--r-lg); overflow: hidden;
}
.user-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-2) var(--sp-3); gap: var(--sp-2);
  border-bottom: var(--bw) solid var(--ln);
  transition: background var(--dur-instant);
}
.user-row:last-child { border-bottom: none; }
.user-row:hover { background: var(--s2); }
.user-row-left { display: flex; align-items: center; gap: var(--sp-2); flex: 1; min-width: 0; }
.user-row-avatar {
  width: var(--sz-md); height: var(--sz-md); border-radius: 50%;
  background: linear-gradient(135deg, var(--p2), var(--cy));
  display: flex; align-items: center; justify-content: center;
  font-size: var(--fs-sm); font-weight: 800; color: var(--white);
  flex-shrink: 0;
}
.user-row-info { display: flex; flex-direction: column; gap: var(--sp-0); min-width: 0; }
.user-row-name {
  font-size: var(--fs-sm); font-weight: 600; color: var(--t1);
  display: flex; align-items: center; gap: var(--sp-1);
}
.user-row-meta { font-size: var(--fs-xs); color: var(--t3); display: flex; align-items: center; gap: var(--sp-1); }
.user-row-actions { display: flex; gap: var(--sp-1); flex-shrink: 0; }
.edit-role-options { display: flex; gap: var(--sp-1); flex-wrap: wrap; }

/* ── SESSION HEADER ── */
.session-header {
  display: flex; align-items: center; gap: var(--sp-2);
  margin-bottom: var(--sp-3);
}
.session-header .t-title { flex: 1; }

/* ── MOBILE ── */
@media (max-width: 768px) {
  .nav { gap: 0; padding: 0 var(--sp-3); }
  .logo { margin-right: var(--sp-3); }
  .tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-shrink: 1; scrollbar-width: none; }
  .tabs::-webkit-scrollbar { display: none; }
  .guild-btn { display: none; }
  .bot-pill { font-size: 0; gap: 0; padding: var(--sp-1) var(--sp-2); }
  .blink { width: var(--sp-2); height: var(--sp-2); }
  .user-btn span { display: none; }
  .user-btn { padding: var(--sp-1); }
  .page { padding: var(--sp-3); gap: var(--sp-2); }
  .rooms { grid-template-columns: 1fr 1fr; }
  .row2 { grid-template-columns: 1fr; }
  .meta-row { flex-wrap: wrap; }
  .mc2 { flex: 1 1 45%; }
}
