:root {
  color-scheme: dark;
  --bg: #111318;
  --sidebar: #17191f;
  --surface: #1d2027;
  --surface-2: #242830;
  --surface-3: #2d323c;
  --input: #12151b;
  --line: #343a46;
  --line-soft: rgba(255, 255, 255, 0.075);
  --text: #f2f3f5;
  --muted: #a7afbd;
  --muted-2: #798394;
  --primary: #5865f2;
  --primary-hover: #4752c4;
  --danger: #fa7770;
  --success: #23a55a;
  --success-hover: #1a8f4b;
  --warning: #f0b232;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html,
body {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
}

button,
input,
select {
  font: inherit;
}

h1,
h2,
h3,
p {
  margin: 0;
}

h1 {
  font-size: 18px;
  line-height: 1.2;
}

h2 {
  font-size: 22px;
  line-height: 1.25;
}

h3 {
  font-size: 15px;
  line-height: 1.25;
}

p {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.topbar {
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 0 22px;
  background: #0c0e12;
  border-bottom: 1px solid var(--line-soft);
}

.brand,
.topbar-actions,
.user-chip {
  display: flex;
  align-items: center;
}

.brand {
  gap: 11px;
  min-width: 0;
}

.brand-copy {
  display: grid;
  gap: 2px;
}

.brand-copy p {
  font-size: 12px;
}

.brand-mark,
.login-icon {
  display: grid;
  place-items: center;
  background: var(--primary);
  color: #fff;
  font-weight: 850;
}

.brand-mark {
  display: block;
  width: 38px;
  height: 38px;
  border-radius: 9px;
  object-fit: cover;
  font-size: 13px;
}

.topbar-actions {
  gap: 10px;
}

.user-chip {
  min-width: 0;
  gap: 8px;
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
}

.user-chip img {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--surface-3);
}

.button {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--surface-2);
  color: var(--text);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  font-weight: 750;
  text-decoration: none;
  white-space: nowrap;
}

.button:hover {
  background: var(--surface-3);
}

.button.primary {
  border-color: var(--primary);
  background: var(--primary);
  color: #fff;
}

.button.primary:hover {
  background: var(--primary-hover);
}

.button.success {
  border-color: var(--success);
  background: var(--success);
  color: #fff;
}

.button.success:hover {
  background: var(--success-hover);
}

.button.subtle {
  background: transparent;
}

.button.small {
  min-height: 32px;
  padding: 0 10px;
  font-size: 12px;
}

.button.wide {
  width: 100%;
}

.button.danger {
  border-color: rgba(250, 119, 112, 0.32);
  background: rgba(250, 119, 112, 0.06);
  color: var(--danger);
}

.button:disabled {
  cursor: not-allowed;
  opacity: 0.48;
}

.login-screen {
  height: calc(100dvh - 68px);
  display: grid;
  place-items: center;
  padding: 22px;
  overflow: auto;
}

.login-box {
  width: min(400px, 100%);
  display: grid;
  justify-items: center;
  gap: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  padding: 28px;
  text-align: center;
  box-shadow: 0 20px 55px rgba(0, 0, 0, 0.32);
}

.login-icon {
  width: 52px;
  height: 52px;
  border-radius: 12px;
}

.login-box > div:not(.login-icon) {
  display: grid;
  gap: 6px;
}

.layout {
  height: calc(100dvh - 68px);
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  overflow: hidden;
}

.sidebar {
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
  border-right: 1px solid var(--line-soft);
  background: var(--sidebar);
  padding: 18px 12px;
  overflow: hidden;
}

.sidebar-section {
  display: grid;
  gap: 8px;
  padding: 0 6px;
}

.field-label,
label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
}

input,
select,
textarea {
  width: 100%;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--input);
  color: var(--text);
  padding: 0 10px;
}

input,
select {
  height: 40px;
}

textarea {
  min-height: 180px;
  padding: 10px;
  resize: vertical;
  font: inherit;
  line-height: 1.45;
}

input:focus,
select:focus,
textarea:focus,
.picker-button:focus-visible {
  border-color: var(--primary);
  outline: 3px solid rgba(88, 101, 242, 0.2);
}

.server-meta {
  min-height: 18px;
  color: var(--muted-2);
  font-size: 11px;
  overflow-wrap: anywhere;
}

.status {
  margin-top: auto;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 10px;
  color: var(--muted);
  background: rgba(0, 0, 0, 0.12);
  font-size: 12px;
  line-height: 1.4;
}

.status.compact {
  width: 100%;
  margin-top: 0;
}

.status.error {
  border-color: rgba(250, 119, 112, 0.38);
  color: var(--danger);
  background: rgba(250, 119, 112, 0.08);
}

.status.ok {
  border-color: rgba(35, 165, 90, 0.38);
  color: #62d68d;
  background: rgba(35, 165, 90, 0.08);
}

.tabs {
  display: grid;
  gap: 3px;
}

.tab {
  width: 100%;
  height: 40px;
  border: 0;
  border-radius: 5px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  padding: 0 12px;
  text-align: left;
  font-weight: 700;
}

.tab:hover {
  background: rgba(255, 255, 255, 0.055);
  color: var(--text);
}

.tab.active {
  background: var(--surface-3);
  color: #fff;
}

.workspace {
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 22px 26px 0;
}

.section-title {
  flex: 0 0 auto;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line-soft);
}

.section-title > div {
  display: grid;
  gap: 4px;
}

.saved-state {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 9px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 750;
  white-space: nowrap;
}

.saved-state.dirty {
  border-color: rgba(240, 178, 50, 0.4);
  color: var(--warning);
  background: rgba(240, 178, 50, 0.08);
}

.config-scroll {
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 18px max(2px, calc((100% - 1120px) / 2)) 110px;
  scrollbar-color: var(--surface-3) transparent;
}

.tab-panel {
  display: none;
}

.tab-panel.active {
  display: block;
}

.mini-tabs {
  position: sticky;
  z-index: 12;
  top: -18px;
  display: flex;
  gap: 4px;
  margin: -18px 0 14px;
  padding: 12px 0 10px;
  border-bottom: 1px solid var(--line-soft);
  background: var(--bg);
}

.mini-tab {
  min-height: 34px;
  border: 0;
  border-radius: 5px;
  padding: 0 12px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  font-weight: 750;
}

.mini-tab:hover {
  color: var(--text);
  background: var(--surface-2);
}

.mini-tab.active {
  color: #fff;
  background: var(--primary);
}

.mini-panel {
  display: none;
}

.mini-panel.active {
  display: block;
}

.panel {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  padding: 18px;
  margin-bottom: 14px;
}

.panel-heading {
  display: grid;
  gap: 5px;
}

.panel > .panel-heading,
.panel > h3 {
  margin-bottom: 16px;
}

.panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.grid,
.settings-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.grid.compact-grid {
  max-width: 760px;
}

.game-rules {
  display: grid;
  gap: 14px;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.mode-setting {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.mode-setting p,
.formula-field > span {
  margin: 5px 0 0;
  color: var(--muted-2);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.45;
}

.segmented-control {
  display: grid;
  grid-template-columns: repeat(2, minmax(90px, 1fr));
  flex: 0 0 210px;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: var(--input);
}

.segmented-control label {
  display: block;
}

.segmented-control input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.segmented-control span {
  display: grid;
  place-items: center;
  min-height: 32px;
  border-radius: 5px;
  color: var(--muted);
  cursor: pointer;
}

.segmented-control input:checked + span {
  color: #fff;
  background: var(--primary);
}

.segmented-control input:focus-visible + span {
  outline: 3px solid rgba(88, 101, 242, 0.25);
}

.formula-field {
  max-width: 760px;
}

.formula-field code {
  color: var(--text);
}

.announcement-basics {
  display: grid;
  grid-template-columns: minmax(180px, 0.8fr) minmax(260px, 1.5fr) minmax(130px, 0.5fr);
  align-items: end;
  gap: 14px;
}

.message-builder {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  align-items: start;
  gap: 14px;
}

.message-builder .panel {
  min-width: 0;
}

.template-tokens {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 14px;
}

.template-tokens button {
  min-height: 28px;
  border: 1px solid var(--line);
  border-radius: 5px;
  padding: 0 8px;
  background: var(--surface-2);
  color: var(--muted);
  cursor: pointer;
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
  font-size: 11px;
}

.template-tokens button:hover {
  border-color: var(--primary);
  color: var(--text);
}

.message-editor textarea {
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
  font-size: 12px;
}

.message-editor input[type="color"] {
  padding: 4px;
  cursor: pointer;
}

.condition-help {
  margin: 12px 0 0;
  color: var(--muted-2);
  font-size: 12px;
  line-height: 1.5;
}

.condition-help code,
.panel-heading code {
  color: var(--text);
}

.preview-panel {
  position: sticky;
  top: 54px;
}

.discord-preview {
  min-height: 260px;
  border-radius: 6px;
  padding: 18px;
  background: #313338;
}

.preview-container {
  position: relative;
  overflow: hidden;
  border-radius: 4px;
  padding: 14px 14px 14px 18px;
  background: #2b2d31;
  color: #dbdee1;
  font-size: 14px;
  line-height: 1.45;
}

.preview-container::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: var(--preview-accent, #57f287);
}

.preview-section {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  overflow-wrap: anywhere;
}

.preview-heading {
  display: block;
  margin-bottom: 3px;
  color: #f2f3f5;
  font-size: 18px;
}

.preview-line,
.preview-subtext,
.preview-quote {
  display: block;
}

.preview-subtext {
  color: #949ba4;
  font-size: 12px;
  line-height: 1.35;
}

.preview-quote {
  margin: 2px 0;
  padding-left: 10px;
  border-left: 3px solid #4e5058;
}

.preview-code {
  margin: 5px 0;
  padding: 8px 10px;
  color: #dbdee1;
  background: #1e1f22;
  border: 1px solid #111214;
  border-radius: 4px;
  overflow-x: auto;
  white-space: pre-wrap;
}

.preview-line code,
.preview-subtext code,
.preview-quote code {
  padding: 1px 4px;
  color: #dbdee1;
  background: #1e1f22;
  border-radius: 3px;
}

.preview-thumbnail {
  width: 72px;
  height: 72px;
  flex: 0 0 72px;
  border-radius: 4px;
  object-fit: cover;
}

.preview-separator {
  height: 1px;
  margin: 12px 0;
  background: #4e5058;
}

.preview-image {
  display: block;
  width: 100%;
  max-height: 280px;
  margin-top: 12px;
  border-radius: 4px;
  object-fit: cover;
}

.preview-image[hidden] {
  display: none;
}

.settings-grid {
  margin-top: 16px;
}

.picker-field {
  display: grid;
  gap: 7px;
  min-width: 0;
}

.picker {
  position: relative;
  min-width: 0;
}

.picker-button {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--input);
  color: var(--text);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 7px 10px;
  text-align: left;
}

.picker-button.open {
  border-color: var(--primary);
}

.selected-wrap {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
  min-width: 0;
}

.placeholder {
  color: var(--muted-2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.chevron {
  color: var(--muted-2);
  font-size: 11px;
}

.token,
.option-main {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.token {
  max-width: 100%;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--surface-2);
  padding: 3px 6px;
  color: var(--text);
  font-size: 12px;
}

.token.role-token {
  border-color: color-mix(in srgb, var(--role-color) 50%, transparent);
  background: color-mix(in srgb, var(--role-color) 16%, transparent);
}

.token span:last-child,
.option-main .token {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tag {
  min-width: 34px;
  height: 18px;
  border-radius: 3px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-3);
  color: var(--muted);
  font-size: 9px;
  font-weight: 850;
}

.tag.category {
  color: var(--warning);
}

.tag.voice {
  color: #78c8f8;
}

.tag.forum {
  color: #d7a6ff;
}

.tag.thread {
  color: #71d9c2;
}

.role-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--role-color);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--role-color) 16%, transparent);
  flex: 0 0 auto;
}

.picker-menu {
  position: absolute;
  z-index: 30;
  top: calc(100% + 5px);
  left: 0;
  right: 0;
  max-height: 340px;
  display: none;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #0e1015;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.48);
  overflow: hidden;
}

.picker-menu.open {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}

.picker-search {
  height: 42px;
  border: 0;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  background: #0b0d11;
}

.option-list {
  max-height: 296px;
  overflow: auto;
  padding: 5px;
}

.option {
  width: 100%;
  min-height: 38px;
  border: 0;
  border-radius: 5px;
  background: transparent;
  color: var(--text);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 6px 8px;
  text-align: left;
}

.option:hover,
.option.selected {
  background: var(--surface-2);
}

.option.role-option.selected {
  background: color-mix(in srgb, var(--role-color) 16%, var(--surface-2));
}

.check-mark {
  color: #62d68d;
  font-size: 10px;
  font-weight: 800;
}

.empty-option,
.empty-state {
  color: var(--muted-2);
  font-size: 12px;
}

.empty-option {
  padding: 12px;
}

.empty-state {
  border: 1px dashed var(--line);
  border-radius: 7px;
  padding: 18px;
  text-align: center;
}

.rows {
  display: grid;
  gap: 10px;
}

.config-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 150px auto;
  gap: 10px;
  align-items: end;
  border: 1px solid var(--line-soft);
  border-radius: 7px;
  background: rgba(0, 0, 0, 0.09);
  padding: 12px;
}

.config-row.xp-group-row {
  grid-template-columns: minmax(300px, 1.5fr) minmax(390px, 1fr) auto;
}

.xp-range {
  display: grid;
  grid-template-columns: repeat(3, minmax(100px, 1fr));
  gap: 9px;
}

.config-row.reward-row {
  grid-template-columns: 130px minmax(220px, 1fr) auto;
}

.checkline {
  min-height: 40px;
  display: flex;
  align-items: center;
  gap: 9px;
  color: var(--text);
}

.checkline input {
  width: 18px;
  height: 18px;
}

.unsaved-bar {
  position: fixed;
  z-index: 100;
  left: calc(250px + ((100vw - 250px) / 2));
  bottom: 20px;
  width: min(720px, calc(100vw - 290px));
  transform: translateX(-50%);
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  border: 1px solid #3c4350;
  border-radius: 8px;
  background: #0b0d11;
  padding: 11px 12px 11px 16px;
  box-shadow: 0 16px 42px rgba(0, 0, 0, 0.52);
  animation: unsavedIn 170ms ease-out;
}

.unsaved-bar > div:first-child {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.unsaved-bar strong {
  font-size: 13px;
}

.unsaved-bar span {
  color: var(--muted);
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.unsaved-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

@keyframes unsavedIn {
  from {
    opacity: 0;
    transform: translate(-50%, 8px);
  }

  to {
    opacity: 1;
    transform: translate(-50%, 0);
  }
}

@media (max-width: 1050px) {
  .message-builder {
    grid-template-columns: 1fr;
  }

  .preview-panel {
    position: static;
  }

  .config-row.xp-group-row {
    grid-template-columns: 1fr auto;
  }

  .config-row.xp-group-row .picker-field {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .topbar {
    height: 62px;
    padding: 0 14px;
  }

  .brand-copy p,
  .user-chip span {
    display: none;
  }

  .layout {
    height: calc(100dvh - 62px);
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr);
  }

  .login-screen {
    height: calc(100dvh - 62px);
  }

  .sidebar {
    gap: 10px;
    border-right: 0;
    border-bottom: 1px solid var(--line-soft);
    padding: 10px 12px;
    overflow: visible;
  }

  .sidebar-section {
    grid-template-columns: 70px minmax(0, 1fr);
    align-items: center;
    padding: 0;
  }

  .server-meta,
  .sidebar .status {
    display: none;
  }

  .tabs {
    display: flex;
    overflow-x: auto;
    padding-bottom: 2px;
  }

  .tab {
    width: auto;
    flex: 0 0 auto;
    padding: 0 11px;
  }

  .workspace {
    padding: 16px 14px 0;
  }

  .section-title {
    align-items: center;
  }

  .section-title p,
  .saved-state {
    display: none;
  }

  .config-scroll {
    padding: 14px 0 105px;
  }

  .panel {
    padding: 15px;
  }

  .panel-head {
    align-items: stretch;
    flex-direction: column;
  }

  .grid,
  .grid.compact-grid,
  .settings-grid,
  .config-row,
  .config-row.xp-group-row,
  .config-row.reward-row,
  .xp-range {
    grid-template-columns: 1fr;
  }

  .announcement-basics {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .mini-tabs {
    overflow-x: auto;
  }

  .mini-tab {
    flex: 0 0 auto;
  }

  .mode-setting {
    align-items: stretch;
    flex-direction: column;
  }

  .segmented-control {
    flex-basis: auto;
  }

  .config-row.xp-group-row .picker-field {
    grid-column: auto;
  }

  .unsaved-bar {
    left: 12px;
    right: 12px;
    bottom: 12px;
    width: auto;
    transform: none;
  }

  .unsaved-bar span {
    display: none;
  }

  @keyframes unsavedIn {
    from {
      opacity: 0;
      transform: translateY(8px);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
}

@media (max-width: 470px) {
  .topbar-actions .button {
    padding: 0 10px;
  }

  .unsaved-bar {
    align-items: stretch;
    flex-direction: column;
    gap: 8px;
  }

  .unsaved-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}

.ticket-main-tabs,
.ticket-type-tabs {
  margin-bottom: 16px;
}

.ticket-main-content,
.ticket-type-section,
.ticket-control-list,
.form-question-list {
  min-width: 0;
  display: grid;
  gap: 14px;
}

#ticketEditorRoot,
.ticket-main-content > *,
.ticket-type-section > *,
.ticket-main-content .panel,
.ticket-type-section .panel {
  min-width: 0;
  max-width: 100%;
}

.ticket-main-content p,
.ticket-type-section p {
  overflow-wrap: anywhere;
}

.ticket-list-head,
.ticket-editor-head,
.ticket-card-toolbar,
.sequence-head,
.form-create-bar,
.ticket-modal-head,
.ticket-modal-actions,
.danger-zone {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.ticket-list-head {
  padding: 4px 2px 2px;
}

.ticket-list-head > div:first-child,
.ticket-editor-head > div,
.ticket-modal-head > div {
  display: grid;
  gap: 4px;
}

.ticket-list-actions,
.permission-buttons {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.ticket-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.ticket-type-card {
  min-width: 0;
  min-height: 84px;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 18px;
  align-items: center;
  gap: 12px;
  padding: 14px;
  color: var(--text);
  text-align: left;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 7px;
  cursor: pointer;
}

.ticket-type-card:hover,
.ticket-type-card:focus-visible {
  background: var(--surface-2);
  border-color: #5c6575;
  outline: none;
}

.ticket-type-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  background: var(--input);
  border: 1px solid var(--line);
  border-radius: 6px;
  font-size: 21px;
}

.ticket-type-copy {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.ticket-type-copy strong,
.ticket-type-copy span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ticket-type-copy span,
.ticket-editor-head p,
.ticket-card-arrow {
  color: var(--muted);
  font-size: 12px;
}

.ticket-card-arrow {
  font-size: 24px;
}

.ticket-editor-head {
  justify-content: flex-start;
  padding: 1px 2px 2px;
}

.icon-button {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  display: grid;
  place-items: center;
  padding: 0;
  color: var(--text);
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 6px;
  cursor: pointer;
}

.icon-button:hover,
.icon-button:focus-visible {
  background: var(--surface-3);
  border-color: #5c6575;
  outline: none;
}

.danger-text {
  color: var(--danger);
}

.ticket-channel-grid,
.ticket-settings-pickers {
  margin-top: 16px;
}

.ticket-segmented button {
  min-height: 36px;
  padding: 0 13px;
  color: var(--muted);
  background: transparent;
  border: 0;
  cursor: pointer;
}

.ticket-segmented button.selected {
  color: #fff;
  background: var(--primary);
}

.span-two {
  grid-column: span 2;
}

.ticket-color-options {
  display: flex;
  gap: 8px;
  padding-top: 8px;
}

.ticket-color {
  width: 34px;
  height: 34px;
  padding: 0;
  border: 2px solid transparent;
  border-radius: 6px;
  cursor: pointer;
}

.ticket-color.primary {
  background: #5865f2;
}

.ticket-color.secondary {
  background: #4e5058;
}

.ticket-color.success {
  background: #248046;
}

.ticket-color.danger {
  background: #da373c;
}

.ticket-color.selected {
  outline: 2px solid #fff;
  outline-offset: 2px;
}

.permission-buttons {
  margin-top: 16px;
}

.permission-buttons .button span {
  display: inline-grid;
  place-items: center;
  min-width: 22px;
  height: 22px;
  margin-left: 6px;
  padding: 0 6px;
  color: var(--text);
  background: var(--surface-3);
  border-radius: 5px;
  font-size: 11px;
}

.danger-zone {
  padding: 14px 16px;
  background: rgba(237, 66, 69, 0.07);
  border: 1px solid rgba(237, 66, 69, 0.35);
  border-radius: 7px;
}

.danger-zone > div {
  display: grid;
  gap: 3px;
}

.danger-zone span {
  color: var(--muted);
  font-size: 12px;
}

.ticket-message-builder {
  align-items: start;
}

.ticket-preview {
  min-height: 150px;
}

.ticket-preview-text {
  color: #dbdee1;
  font-size: 14px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.preview-separator {
  height: 1px;
  margin: 12px 0;
  background: #3f4147;
}

.ticket-preview-media {
  min-height: 90px;
  display: grid;
  place-items: center;
  margin-top: 12px;
  color: var(--muted);
  background: #1e1f22;
  border: 1px dashed #4e5058;
  border-radius: 6px;
  font-size: 12px;
}

.ticket-control-card,
.form-question-card {
  padding: 16px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 7px;
}

.ticket-card-toolbar {
  margin-bottom: 14px;
}

.ticket-card-toolbar > div {
  display: flex;
  align-items: center;
  gap: 7px;
}

.question-order-field {
  width: 110px;
  margin-bottom: 12px;
}

.inline-note {
  align-self: end;
  padding: 10px 12px;
  color: var(--muted);
  background: var(--input);
  border: 1px solid var(--line-soft);
  border-radius: 6px;
  font-size: 12px;
}

.action-sequence,
.form-options {
  display: grid;
  gap: 9px;
  margin-top: 15px;
  padding-top: 15px;
  border-top: 1px solid var(--line-soft);
}

.sequence-head span:last-child,
.form-create-bar > span {
  color: var(--muted);
  font-size: 11px;
}

.sequence-list {
  display: grid;
  gap: 6px;
}

.sequence-item {
  min-height: 44px;
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 5px 7px;
  background: var(--input);
  border: 1px solid var(--line-soft);
  border-radius: 6px;
}

.sequence-item > div {
  display: flex;
  gap: 4px;
}

.sequence-item .icon-button {
  width: 28px;
  height: 28px;
  flex-basis: 28px;
}

.sequence-number,
.question-order {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  color: var(--muted);
  background: var(--surface-3);
  border-radius: 5px;
  font-size: 11px;
  font-weight: 700;
}

.sequence-add,
.form-option-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) auto;
  gap: 8px;
}

.form-phase-switch {
  display: grid;
  gap: 8px;
}

.form-create-bar {
  justify-content: flex-start;
  padding: 12px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 7px;
}

.form-create-bar select {
  min-width: 210px;
}

.form-create-bar > span {
  margin-left: auto;
}

.form-option-row {
  grid-template-columns: minmax(130px, 1fr) 100px minmax(150px, 1fr) 34px;
}

.form-option-row.short-option {
  grid-template-columns: minmax(130px, 1fr) minmax(150px, 1fr) 34px;
}

.form-option-row .emoji-input {
  min-width: 0;
}

.empty-state.compact {
  padding: 10px;
}

.ticket-modal-backdrop {
  position: fixed;
  z-index: 100;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgba(0, 0, 0, 0.72);
}

.ticket-modal {
  width: min(680px, 100%);
  max-height: min(760px, calc(100vh - 40px));
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  background: #202329;
  border: 1px solid #454b57;
  border-radius: 8px;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.5);
  overflow: hidden;
}

.ticket-modal-head,
.ticket-modal-actions {
  padding: 16px;
  border-bottom: 1px solid var(--line);
}

.ticket-modal-actions {
  justify-content: flex-end;
  border-top: 1px solid var(--line);
  border-bottom: 0;
}

.permission-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
  padding: 14px 16px;
  overflow: auto;
}

.permission-item {
  min-height: 42px;
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 10px;
  background: var(--input);
  border: 1px solid var(--line-soft);
  border-radius: 6px;
}

@media (max-width: 820px) {
  .topbar .user-chip {
    display: none;
  }

  #ticketEditorRoot,
  .ticket-main-content,
  .ticket-type-section {
    width: 100%;
    min-width: 0;
    max-width: 100%;
  }

  .ticket-type-tabs,
  .ticket-main-tabs {
    width: 100%;
    max-width: calc(100vw - 28px);
  }

  .form-phase-switch .segmented-control {
    width: 100%;
    min-width: 0;
  }

  .ticket-card-grid,
  .permission-grid {
    grid-template-columns: 1fr;
  }

  .ticket-list-head,
  .danger-zone {
    align-items: stretch;
    flex-direction: column;
  }

  .ticket-list-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .span-two {
    grid-column: auto;
  }

  .form-option-row {
    grid-template-columns: 1fr 90px 34px;
  }

  .form-option-row.string-option input:nth-child(3) {
    grid-column: 1 / -1;
  }
}

@media (max-width: 560px) {
  .ticket-list-actions,
  .sequence-add,
  .form-option-row {
    grid-template-columns: 1fr;
  }

  .form-option-row.string-option input:nth-child(3) {
    grid-column: auto;
  }

  .form-option-row .icon-button {
    justify-self: end;
  }

  .form-create-bar {
    align-items: stretch;
    flex-direction: column;
  }

  .form-create-bar select {
    min-width: 0;
    width: 100%;
  }

  .form-create-bar > span {
    margin-left: 0;
  }
}

/* Merged legacy admin interaction styles */
.mini-tabs,
.message-editor-head {
  z-index: 90 !important;
  isolation: isolate;
}

.tab {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 11px;
  min-height: 48px;
  padding: 7px 10px;
  border: 1px solid transparent;
  background: rgba(255, 255, 255, 0.025);
}

.tab:hover { background: rgba(255, 255, 255, 0.055); }
.tab.active { border-color: rgba(255, 255, 255, 0.08); }
.tab span { min-width: 0; }
.tab:not(:has(.tab-icon))::before { content: ''; width: 34px; height: 34px; }
.tab:not(:has(.tab-icon)) { padding-left: 10px; }

.tab-icon {
  width: 30px;
  height: 30px;
  flex: 0 0 30px;
  box-sizing: border-box;
  padding: 3px;
  border: 2px solid var(--tab-icon-border, rgba(120, 150, 190, 0.72));
  border-radius: 9px;
  object-fit: contain;
  object-position: center;
  image-rendering: auto;
  background: var(--tab-icon-bg, rgba(80, 110, 150, 0.14));
  box-shadow: none;
  filter: none;
  transition: none;
}

.tab:hover .tab-icon,
.tab.active .tab-icon {
  transform: none;
  box-shadow: none;
  filter: none;
}

.tab[data-tab="leveling"] .tab-icon {
  --tab-icon-glow: rgba(93, 255, 151, 0.68);
  --tab-icon-bg: rgba(87, 242, 135, 0.18);
  --tab-icon-border: rgba(87, 242, 135, 0.72);
}

.tab[data-tab="tickets"] .tab-icon {
  --tab-icon-glow: rgba(255, 84, 104, 0.7);
  --tab-icon-bg: rgba(255, 76, 96, 0.18);
  --tab-icon-border: rgba(255, 76, 96, 0.72);
}

.tab[data-tab="messages"] .tab-icon {
  --tab-icon-glow: rgba(99, 184, 255, 0.72);
  --tab-icon-bg: rgba(72, 149, 239, 0.2);
  --tab-icon-border: rgba(99, 184, 255, 0.72);
}

.tab[data-tab="moderator"] .tab-icon {
  --tab-icon-bg: rgba(155, 89, 182, 0.18);
  --tab-icon-border: rgba(188, 120, 255, 0.72);
}

.tab[data-tab="data"] .tab-icon {
  --tab-icon-bg: rgba(185, 195, 210, 0.14);
  --tab-icon-border: rgba(205, 215, 230, 0.72);
}

.message-tab-icon,
.tab-image-icon { display: none !important; }

.config-row, .rows, .panel, .mini-panel, .tab-panel, .picker-field { overflow: visible; }
.picker { position: relative; }
.picker-menu { z-index: 2000; }
.picker-portal-menu {
  position: fixed;
  min-width: 280px;
  max-width: min(720px, calc(100vw - 24px));
  max-height: min(420px, calc(100vh - 24px));
  overflow: hidden;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.42);
}

.word-chain-tools { margin-bottom: 16px; }
.word-chain-tools .picker-field { min-width: 0; }

.ticket-kind-badge {
  display: block;
  width: max-content;
  margin-top: 7px;
  padding: 3px 8px;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 700;
}
.ticket-kind-badge.channel { color: #9db7ff; background: rgba(88, 101, 242, 0.15); }
.ticket-kind-badge.request { color: #ffd37a; background: rgba(240, 178, 50, 0.14); }

.ticket-kind-modal { width: min(620px, calc(100vw - 28px)); }
.ticket-kind-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; padding: 18px; }
.ticket-kind-grid button {
  display: flex;
  min-height: 130px;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 8px;
  padding: 20px;
  color: var(--text, #f2f3f5);
  text-align: left;
  border: 1px solid #3c4350;
  border-radius: 8px;
  background: #171a20;
  cursor: pointer;
}
.ticket-kind-grid button:hover { border-color: #5865f2; background: #1d2028; }
.ticket-kind-grid strong { font-size: 18px; }
.ticket-kind-grid span { color: #aeb4c0; line-height: 1.45; }

.ticket-message-builder,
.ticket-main-content,
.ticket-type-section { min-width: 0; }
.ticket-control-card,
.form-question-card,
.preview-panel,
.message-editor {
  border-color: rgba(116, 128, 255, 0.18);
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.20);
}
.ticket-control-card:hover,
.form-question-card:hover { border-color: rgba(116, 128, 255, 0.32); }
.ticket-card-toolbar {
  gap: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.sequence-item,
.condition-action,
.request-condition-inline {
  border-color: rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.025);
}
.sequence-number,
.question-order {
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08) inset;
}
.preview-container.ticket-preview {
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.22);
}
.template-tokens button,
.ticket-segmented button,
.button,
.icon-button { transition: transform 140ms ease, border-color 140ms ease, background 140ms ease; }
.template-tokens button:hover,
.ticket-segmented button:hover,
.button:hover,
.icon-button:hover { transform: translateY(-1px); }
.inline-note,
.condition-help,
.request-action-note { line-height: 1.45; }

@media (max-width: 740px) {
  .tab { grid-template-columns: 30px minmax(0, 1fr); }
  .tab-icon {
    width: 30px;
    height: 30px;
    flex-basis: 30px;
    padding: 0;
  }
  .tab:not(:has(.tab-icon))::before { width: 30px; height: 30px; }
  .ticket-kind-grid { grid-template-columns: 1fr; }
  .ticket-message-builder { grid-template-columns: 1fr; }
}

.workspace {
  padding-top: 0;
}

.section-title {
  display: none;
}

.config-scroll {
  padding-top: 0;
}

.mini-tabs {
  top: 0;
  margin-top: 0;
}

@media (max-width: 760px) {
  .workspace,
  .config-scroll {
    padding-top: 0;
  }
}

/* Merged preview reset styles */
.preview-thumbnail,
.preview-image,
.message-preview-thumb,
.preview-media-edit img {
  object-fit: contain !important;
  background: #1e1f22;
}

.message-root-content.message-root-empty {
  min-height: 20px !important;
  margin: 0 0 4px !important;
  padding: 0 !important;
}

.message-root-content.message-root-empty::before,
#levelUpPreviewBody:empty::before {
  min-height: 20px !important;
}

.message-preview-container {
  margin-top: 4px !important;
}

/* Lightweight admin polish: no blur, no glow layers, no hover animations. */
:root {
  --bg: #0b0f18;
  --sidebar: #101620;
  --surface: #151b28;
  --surface-2: #1b2332;
  --surface-3: #232d40;
  --input: #080d16;
  --line: #2b354a;
  --line-soft: rgba(255, 255, 255, 0.075);
  --text: #f4f6fb;
  --muted: #b8c0d4;
  --muted-2: #8490a8;
  --primary: #6f79ff;
  --primary-hover: #6f79ff;
  --success: #27b96f;
  --success-hover: #27b96f;
  --danger: #ff7785;
  --warning: #f7c75a;
}

*,
*::before,
*::after {
  transition: none !important;
  animation: none !important;
}

body {
  background: var(--bg) !important;
}

body::before {
  display: none !important;
}

.topbar {
  height: 68px !important;
  padding: 0 22px !important;
  background: #080c14 !important;
  border-bottom: 1px solid var(--line-soft) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.brand-mark,
.login-icon {
  background: var(--primary) !important;
  border: 0 !important;
  box-shadow: none !important;
}

.brand-mark {
  width: 38px !important;
  height: 38px !important;
  border-radius: 11px !important;
  background: transparent !important;
}

.layout,
.login-screen {
  height: calc(100dvh - 68px) !important;
}

.layout {
  grid-template-columns: 260px minmax(0, 1fr) !important;
}

.sidebar {
  gap: 16px !important;
  padding: 18px 12px !important;
  background: var(--sidebar) !important;
  border-right: 1px solid var(--line-soft) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.sidebar-section {
  padding: 0 6px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
}

.tabs {
  gap: 4px !important;
}

.tab {
  min-height: 42px !important;
  border: 0 !important;
  border-radius: 9px !important;
  background: transparent !important;
  color: var(--muted) !important;
  box-shadow: none !important;
}

.tab:hover,
.tab.active {
  background: var(--surface-2) !important;
  color: #fff !important;
  box-shadow: none !important;
}

.tab.active {
  box-shadow: inset 3px 0 0 var(--primary) !important;
}

.workspace {
  padding: 20px 24px 0 !important;
}

.config-scroll {
  padding: 16px max(2px, calc((100% - 1120px) / 2)) 110px !important;
}

.panel,
.ticket-type-card,
.ticket-control-card,
.form-question-card,
.user-data-card,
.data-search-panel,
.ticket-modal,
.login-box,
.message-compose-card,
.message-container-editor,
.message-sticky-preview,
.message-template-card {
  background: var(--surface) !important;
  border: 1px solid var(--line) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.panel:hover,
.ticket-type-card:hover,
.ticket-control-card:hover,
.form-question-card:hover,
.message-template-card:hover {
  background: var(--surface-2) !important;
  border-color: #3a4660 !important;
  box-shadow: none !important;
  transform: none !important;
}

.button,
.icon-button,
.template-tokens button,
.ticket-segmented button,
.mini-tab,
.picker-button,
.segmented-control span,
.option,
.ticket-type-card,
.message-template-card {
  transition: none !important;
  transform: none !important;
}

.button,
.icon-button,
.template-tokens button {
  border-radius: 9px !important;
  box-shadow: none !important;
}

.button:hover,
.icon-button:hover,
.template-tokens button:hover,
.ticket-segmented button:hover,
.mini-tab:hover,
.picker-button:hover,
.option:hover,
.message-template-card:hover {
  transform: none !important;
  box-shadow: none !important;
}

.button.primary,
.button.primary:hover,
.mini-tab.active,
.segmented-control input:checked + span,
.ticket-segmented button.selected {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: #fff !important;
  box-shadow: none !important;
}

.button.success,
.button.success:hover {
  background: var(--success) !important;
  border-color: var(--success) !important;
  color: #fff !important;
}

input,
select,
textarea,
.picker-button,
.segmented-control,
.picker-search {
  border-radius: 10px !important;
  border-color: var(--line) !important;
  background: var(--input) !important;
  box-shadow: none !important;
}

input:focus,
select:focus,
textarea:focus,
.picker-button:focus-visible,
.picker-button.open {
  border-color: var(--primary) !important;
  outline: 2px solid rgba(111, 121, 255, 0.24) !important;
  box-shadow: none !important;
}

.mini-tabs,
.message-editor-tabs {
  gap: 8px !important;
  margin: -16px 0 16px !important;
  padding: 12px 0 !important;
  background: var(--bg) !important;
  border-bottom: 1px solid var(--line-soft) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.mini-tab,
.message-editor-tabs button {
  min-height: 38px !important;
  padding: 0 16px !important;
  border: 1px solid var(--line) !important;
  border-radius: 999px !important;
  background: var(--surface) !important;
  color: var(--muted) !important;
  box-shadow: none !important;
}

.mini-tab:hover,
.message-editor-tabs button:hover {
  background: var(--surface-2) !important;
  border-color: var(--line) !important;
  color: #fff !important;
}

.mini-tab.active,
.message-editor-tabs button.active {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: #fff !important;
}

.status,
.saved-state,
.empty-state,
.inline-note,
.condition-help,
.request-action-note,
.config-row,
.sequence-item,
.condition-action,
.request-condition-inline,
.permission-item,
.form-create-bar,
.danger-zone {
  border-radius: 10px !important;
  box-shadow: none !important;
}

.picker-menu,
.picker-portal-menu,
.message-color-popover,
.message-media-popover {
  background: #0c111c !important;
  border-color: var(--line) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.discord-preview,
.ticket-preview-media,
.message-discord-preview {
  background: #24262d !important;
  border: 1px solid var(--line-soft) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
}

.preview-container,
.preview-container.ticket-preview,
.message-preview-container {
  border-radius: 10px !important;
  box-shadow: none !important;
}

.preview-thumbnail,
.preview-image,
.message-preview-thumb,
.preview-media-edit img {
  border-radius: 8px !important;
}

.unsaved-bar {
  left: calc(260px + ((100vw - 260px) / 2)) !important;
  background: #0b1019 !important;
  border-color: var(--line) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.ticket-modal-backdrop {
  background: rgba(0, 0, 0, 0.72) !important;
  backdrop-filter: none !important;
}

.role-dot {
  box-shadow: none !important;
}

::-webkit-scrollbar-thumb {
  background: #38445c !important;
  border: 3px solid var(--bg) !important;
}

/* Hide legacy/default bot-provided message-template cards in the admin list. */
#messageTemplatesRoot:not([data-message-section="defaults"]) .message-template-card[data-id^="default-"] {
  display: none !important;
}

@media (max-width: 760px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .topbar {
    height: 62px !important;
    gap: 10px !important;
    padding: 0 12px !important;
  }

  .brand {
    gap: 9px !important;
  }

  .brand-copy h1 {
    font-size: 17px !important;
  }

  .topbar-actions {
    gap: 6px !important;
  }

  .topbar-actions .button {
    min-height: 36px !important;
    padding-inline: 11px !important;
  }

  .layout,
  .login-screen {
    height: calc(100dvh - 62px) !important;
  }

  .layout {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto minmax(0, 1fr) !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .sidebar {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    padding: 10px !important;
    border-right: 0 !important;
    border-bottom: 1px solid var(--line-soft) !important;
    overflow: hidden !important;
  }

  .sidebar-section,
  .tabs,
  .workspace,
  .config-scroll,
  .tab-panel,
  .mini-panel {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .sidebar-section {
    grid-template-columns: 64px minmax(0, 1fr) !important;
    padding: 0 2px !important;
  }

  .tabs {
    display: flex !important;
    gap: 4px !important;
    overflow-x: auto !important;
    overscroll-behavior-inline: contain;
    scrollbar-width: none;
  }

  .tabs::-webkit-scrollbar {
    display: none;
  }

  .tab {
    width: auto !important;
    min-height: 40px !important;
    flex: 0 0 auto !important;
    gap: 8px !important;
    padding: 0 10px !important;
  }

  .workspace {
    overflow: hidden !important;
    padding: 12px 10px 0 !important;
  }

  .config-scroll {
    overflow-x: hidden !important;
    padding: 10px 0 105px !important;
  }

  .panel,
  .login-box {
    border-radius: 12px !important;
    padding: 15px !important;
  }

  .mini-tabs,
  .message-editor-tabs {
    margin-top: -14px !important;
    overflow-x: auto !important;
    scrollbar-width: none;
  }

  .mini-tabs::-webkit-scrollbar,
  .message-editor-tabs::-webkit-scrollbar {
    display: none;
  }

  .unsaved-bar {
    left: 12px !important;
    width: auto !important;
  }
}

@media (max-width: 430px) {
  .brand-mark {
    width: 36px !important;
    height: 36px !important;
  }

  .brand-copy h1 {
    font-size: 16px !important;
  }

  .topbar-actions .button {
    padding-inline: 9px !important;
    font-size: 13px !important;
  }

  .panel,
  .login-box {
    padding: 13px !important;
  }

  .mini-tab,
  .message-editor-tabs button {
    min-height: 36px !important;
    padding-inline: 13px !important;
  }
}

/* Merged ticket dashboard styles */
.ticket-modal {
  width: min(640px, 100%);
  min-height: 0;
  max-height: min(720px, calc(100dvh - 40px));
}
.ticket-modal-head,
.ticket-modal-actions { flex: 0 0 auto; background: #202329; }
.ticket-modal-head { min-height: 66px; padding: 14px 18px; }
.ticket-modal-head h3 { font-size: 17px; }
.ticket-modal-actions { position: relative; z-index: 2; min-height: 68px; padding: 12px 18px; box-shadow: 0 -10px 24px rgba(0,0,0,.16); }
.permission-grid { min-height: 0; display: block; padding: 6px 18px 12px; overflow-y: auto; overscroll-behavior: contain; scrollbar-gutter: stable; }
.permission-item { min-height: 52px; display: grid; grid-template-columns: minmax(0,1fr) auto; align-items: center; gap: 16px; padding: 8px 0; color: #dbdee1; background: transparent; border: 0; border-bottom: 1px solid rgba(255,255,255,.075); border-radius: 0; font-size: 14px; font-weight: 600; }
.permission-item:last-child { border-bottom: 0; }
.permission-item > input { display: none; }
.permission-name { min-width: 0; overflow-wrap: anywhere; }
.permission-state { width: 120px; height: 34px; display: grid; grid-template-columns: repeat(3,1fr); overflow: hidden; background: #111318; border: 1px solid #30343c; border-radius: 7px; }
.permission-state button { min-width: 0; height: 32px; display: grid; place-items: center; padding: 0; color: #949ba4; background: transparent; border: 0; border-right: 1px solid #30343c; cursor: pointer; font-size: 17px; font-weight: 750; }
.permission-state button:last-child { border-right: 0; }
.permission-state button:hover:not(:disabled) { background: #2b2d31; color: #f2f3f5; }
.permission-state .permission-deny { color: #da373c; opacity: .38; cursor: not-allowed; }
.permission-state .permission-neutral.active { color: #f2f3f5; background: #3f4147; }
.permission-state .permission-allow { color: #23a55a; }
.permission-state .permission-allow.active { color: #fff; background: #248046; }

.tab[data-tab="leveling"],
.tab[data-tab="tickets"] { display: flex; align-items: center; gap: 12px; }
.tab[data-tab="leveling"]::before,
.tab[data-tab="tickets"]::before { content: none !important; display: none !important; }
.tab[data-tab="leveling"] .tab-icon,
.tab[data-tab="tickets"] .tab-icon {
  width: 30px;
  height: 30px;
  flex: 0 0 30px;
  display: block;
  object-fit: contain;
  object-position: center;
  image-rendering: auto;
  border: 0;
  border-radius: 5px;
}
.tab-image-icon { display: none !important; }

.default-xp-destinations { margin: 2px 0 18px; }
.default-xp-destinations p { margin: 0; color: var(--muted); font-size: 13px; }
.word-chain-controls { display: grid; grid-template-columns: auto minmax(260px,1fr); align-items: end; gap: 24px; margin: 4px 0 20px; }
.switch-control { display: inline-flex; align-items: center; gap: 10px; min-height: 42px; cursor: pointer; user-select: none; }
.switch-control > input { position: absolute; opacity: 0; pointer-events: none; }
.switch-track { width: 44px; height: 24px; position: relative; display: inline-block; border-radius: 12px; background: #4e5058; transition: background .16s ease; }
.switch-thumb { width: 18px; height: 18px; position: absolute; top: 3px; left: 3px; border-radius: 50%; background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.4); transition: transform .16s ease; }
.switch-control > input:checked + .switch-track { background: #248046; }
.switch-control > input:checked + .switch-track .switch-thumb { transform: translateX(20px); }
.switch-control > input:focus-visible + .switch-track { outline: 3px solid rgba(88,101,242,.35); }

.picker-menu { position: fixed; z-index: 1200; inset: auto; width: var(--picker-menu-width,320px); max-width: calc(100vw - 24px); max-height: min(420px,calc(100dvh - 24px)); border-color: #3b3f48; background: #0e1015; box-shadow: 0 18px 40px rgba(0,0,0,.52); }
.picker-menu.open { display: grid; grid-template-rows: auto minmax(0,1fr); }
.picker-menu .option-list { max-height: 376px; }
.picker-menu .option { min-height: 42px; }
.picker-menu .option:hover { background: #5865f2; }
.picker-menu .option:hover .check-mark,
.picker-menu .option:hover .tag { color: #fff; }

.emoji-field { position: relative; display: flex; align-items: center; min-width: 0; }
.emoji-field > input { padding-right: 48px; }
.emoji-picker-button { width: 38px; height: 38px; position: absolute; right: 3px; display: grid; place-items: center; padding: 0; border: 0; border-radius: 6px; background: #292c33; color: #dbdee1; cursor: pointer; font-size: 19px; }
.emoji-picker-button:hover { background: #35383f; }
.emoji-popover { width: min(430px,calc(100vw - 24px)); position: fixed; z-index: 1400; display: none; grid-template-columns: 48px minmax(0,1fr); overflow: hidden; background: #111318; border: 1px solid #3b3f48; border-radius: 8px; box-shadow: 0 18px 45px rgba(0,0,0,.55); }
.emoji-popover.open { display: grid; }
.emoji-categories { min-height: 0; display: flex; flex-direction: column; gap: 3px; padding: 8px 6px; overflow-y: auto; background: #17191f; border-right: 1px solid #30343c; }
.emoji-categories button { width: 34px; height: 34px; flex: 0 0 34px; display: grid; place-items: center; padding: 0; color: #b5bac1; background: transparent; border: 0; border-radius: 6px; cursor: pointer; font-size: 19px; }
.emoji-categories button:hover,
.emoji-categories button.active { color: #fff; background: #35383f; }
.emoji-browser { min-width: 0; min-height: 0; display: grid; grid-template-rows: auto minmax(0,1fr); gap: 10px; padding: 10px; }
.emoji-browser > input { height: 42px; border-color: #5865f2; outline: 2px solid rgba(88,101,242,.18); }
.emoji-grid { min-height: 180px; max-height: 385px; display: grid; grid-template-columns: repeat(7,minmax(36px,1fr)); align-content: start; gap: 3px; overflow-y: auto; padding-right: 3px; }
.emoji-grid button { width: 100%; aspect-ratio: 1; display: grid; place-items: center; padding: 0; border: 0; border-radius: 6px; background: transparent; cursor: pointer; font-size: 25px; }
.emoji-grid button:hover { background: #35383f; transform: scale(1.08); }

@media (max-width: 700px) {
  .word-chain-controls { grid-template-columns: 1fr; gap: 12px; }
  .emoji-popover { grid-template-columns: 44px minmax(0,1fr); }
  .emoji-grid { grid-template-columns: repeat(6,minmax(34px,1fr)); }
  .tab[data-tab="leveling"] .tab-icon,
  .tab[data-tab="tickets"] .tab-icon { width: 26px; height: 26px; flex-basis: 26px; }
}
@media (max-width: 560px) {
  .ticket-modal-backdrop { align-items: stretch; padding: 10px; }
  .ticket-modal { width: 100%; max-height: calc(100dvh - 20px); }
  .permission-grid { padding-inline: 14px; }
  .permission-state { width: 108px; }
  .emoji-grid { grid-template-columns: repeat(5,minmax(32px,1fr)); }
}


/* Moderation hub */
.moderator-shell > .mini-tabs {
  flex-wrap: wrap;
}

.moderator-shell .automod-action-row {
  align-items: end;
}

.moderator-shell [data-case-id] {
  grid-template-columns: minmax(90px, auto) minmax(220px, 1fr);
}

.moderator-shell [data-case-id] label {
  min-width: 160px;
}

@media (max-width: 760px) {
  .moderator-shell > .mini-tabs {
    position: static;
    margin-top: 0;
  }

  .moderator-shell [data-case-id] {
    grid-template-columns: 1fr;
  }
}


/* coinSpriteAiModerationAlertFix */
#messageTemplatesRoot[data-message-section="defaults"] .message-template-card[data-id^="default-"],
#messageTemplatesRoot .message-template-grid .message-default-card[data-id^="default-"] {
  display: grid !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.message-section-tabs {
  position: relative !important;
  z-index: 20 !important;
  pointer-events: auto !important;
}

.message-section-tabs button {
  position: relative !important;
  z-index: 21 !important;
  touch-action: manipulation;
  pointer-events: auto !important;
}

/* __coinSpriteRequestWorkflowEditorStyles */

.request-template-field { display: grid; gap: 7px; margin-top: 12px; }
.workflow-condition-step { flex-wrap: wrap; align-items: flex-start; }
.workflow-condition-step .request-condition-inline { flex: 0 0 100%; width: 100%; }
.request-condition-inline { display: grid; gap: 12px; margin-top: 10px; padding: 14px; border: 1px solid #343943; border-radius: 8px; background: rgba(0,0,0,.12); }
.request-condition-grid, .condition-action { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 10px; align-items: end; }
.condition-actions { display: grid; gap: 9px; }
.condition-actions .sequence-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.condition-action { padding: 10px; border: 1px solid #2d323b; border-radius: 7px; background: #171a20; }
.condition-action > .icon-button { align-self: end; }
@media(max-width:760px){.request-condition-grid,.condition-action{grid-template-columns:1fr}.condition-actions .sequence-head{align-items:flex-start;flex-direction:column}}


.sequence-item.workflow-condition-step {
  align-items: start;
}
.sequence-item.workflow-condition-step > strong {
  min-width: 0;
  padding-top: 7px;
}
.sequence-item.workflow-condition-step > .request-condition-inline {
  display: grid !important;
  grid-column: 1 / -1;
  width: 100%;
  min-width: 0;
  margin-top: 6px;
}
.sequence-item.workflow-condition-step .request-condition-grid,
.sequence-item.workflow-condition-step .condition-action {
  width: 100%;
  min-width: 0;
}
.sequence-item.workflow-condition-step .request-condition-grid > label,
.sequence-item.workflow-condition-step .condition-action > label {
  min-width: 0;
}


.emoji-component-popover {
  width: min(430px, calc(100vw - 24px));
  max-height: none !important;
  grid-template-columns: 1fr;
  padding: 0;
}
.emoji-component-popover.open { display: block; }
.emoji-component-popover emoji-picker {
  width: min(430px, calc(100vw - 24px));
  height: min(420px, calc(100vh - 48px));
  color-scheme: dark;
  --background: #111318;
  --border-color: #303441;
  --input-border-color: #5865f2;
  --input-font-color: #ffffff;
  --input-placeholder-color: #888888;
  --category-font-color: #ffffff;
  --button-hover-background: #222633;
  --button-active-background: #2b3040;
  --indicator-color: #5865f2;
}
 