:root {
  --bg: #0f1115;
  --panel: #151821;
  --panel-soft: #1a1f2a;
  --text: #e7eaf0;
  --muted: #8b93a7;
  --border: rgba(255, 255, 255, 0.07);
  --accent: #7cff8a;
  --accent-soft: rgba(124, 255, 138, 0.14);
  --danger: #ff7b7b;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(124, 255, 138, 0.08), transparent 32rem),
    var(--bg);
  color: var(--text);
  font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

a {
  color: inherit;
}

code {
  color: var(--accent);
}

.page-shell {
  min-height: 100vh;
  padding: 28px;
}

.hero-card {
  width: min(760px, 100%);
  margin: 8vh auto 0;
  background: rgba(21, 24, 33, 0.88);
  border: 1px solid var(--border);
  border-radius: 28px;
  padding: 34px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.34);
}

.narrow-card {
  width: min(520px, 100%);
}

.eyebrow {
  color: var(--accent);
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 12px;
}

h1 {
  margin: 0 0 14px;
  font-size: clamp(34px, 5vw, 64px);
  line-height: 0.98;
  letter-spacing: -0.055em;
}

h2 {
  margin: 0 0 10px;
  font-size: 22px;
}

p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.6;
}

.muted {
  color: var(--muted);
  font-size: 14px;
}

.status-grid,
.topbar-actions,
.project-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.status-grid {
  margin-top: 24px;
}

.soft-button,
.primary-button,
.ghost-button {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px 16px;
  font: inherit;
  text-decoration: none;
  cursor: pointer;
  transition: 160ms ease;
}

.soft-button,
.ghost-button {
  color: var(--text);
  background: var(--panel-soft);
}

.primary-button {
  color: #061008;
  background: var(--accent);
  border-color: rgba(124, 255, 138, 0.5);
  font-weight: 700;
}

.soft-button:hover,
.ghost-button:hover {
  background: var(--accent-soft);
  border-color: rgba(124, 255, 138, 0.35);
}

.admin-shell {
  width: min(1180px, 100%);
  margin: 0 auto;
}

.topbar {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 22px;
}

.project-list {
  display: grid;
  gap: 12px;
}

.project-row,
.success-card,
.result-card,
.empty-state {
  background: rgba(21, 24, 33, 0.86);
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 20px;
}

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

.project-row h2 {
  margin-bottom: 8px;
}

.token-line,
.copy-box {
  margin-top: 10px;
  color: var(--accent);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 13px;
  word-break: break-all;
}

.stack-form {
  display: grid;
  gap: 16px;
  margin-top: 20px;
}

.stack-form label {
  display: grid;
  gap: 8px;
  color: var(--muted);
}

.text-input,
.raw-textarea,
.result-textarea {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(10, 12, 17, 0.72);
  color: var(--text);
  font: inherit;
  outline: none;
}

.text-input {
  padding: 14px 15px;
}

.raw-textarea {
  min-height: 460px;
  resize: vertical;
  padding: 16px;
  line-height: 1.55;
}

.result-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.result-textarea {
  min-height: 420px;
  resize: vertical;
  padding: 16px;
  line-height: 1.55;
}

.alert {
  margin-top: 18px;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(255, 123, 123, 0.12);
  border: 1px solid rgba(255, 123, 123, 0.3);
  color: #ffd0d0;
}

.work-shell {
  display: grid;
  grid-template-columns: minmax(420px, 1fr) minmax(420px, 0.88fr);
  gap: 18px;
  height: calc(100vh - 56px);
}

.reader-panel,
.song-panel {
  background: rgba(21, 24, 33, 0.72);
  border: 1px solid var(--border);
  border-radius: 24px;
  overflow: hidden;
}

.reader-panel {
  display: flex;
  flex-direction: column;
}

.song-panel {
  position: sticky;
  top: 28px;
  height: calc(100vh - 56px);
  padding: 22px;
}

.reader-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  padding: 22px 22px 14px;
}

.reader-head h1 {
  font-size: 30px;
  letter-spacing: -0.04em;
}

.search-placeholder {
  margin: 0 22px 12px;
  padding: 12px 14px;
  border-radius: 14px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
}

.comment-list {
  overflow-y: auto;
  padding: 4px 14px 22px;
}

.comment-row {
  padding: 7px 10px;
  border-radius: 10px;
  background: transparent;
  line-height: 1.45;
  color: var(--text);
}

.comment-row:hover {
  background: rgba(255, 255, 255, 0.045);
}

.empty-song {
  margin-top: 14px;
  min-height: 260px;
  border-radius: 18px;
  border: 1px dashed var(--border);
  display: grid;
  place-items: center;
  color: var(--muted);
  text-align: center;
  padding: 18px;
}

@media (max-width: 900px) {
  .topbar,
  .project-row {
    flex-direction: column;
    align-items: stretch;
  }

  .result-grid,
  .work-shell {
    grid-template-columns: 1fr;
    height: auto;
  }

  .song-panel {
    position: static;
    height: auto;
  }
}


/* PATCH 4 WORK PAGE */

.search-box {
  margin: 0 22px 12px;
  display: grid;
  gap: 8px;
}

.search-row {
  display: grid;
  grid-template-columns: 1fr 42px 42px auto;
  gap: 8px;
  align-items: center;
}

.search-input {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(10, 12, 17, 0.72);
  color: var(--text);
  font: inherit;
  outline: none;
  padding: 12px 14px;
}

.search-input:focus {
  border-color: rgba(124, 255, 138, 0.35);
  box-shadow: 0 0 0 3px rgba(124, 255, 138, 0.08);
}

.mini-button {
  height: 42px;
  border: 1px solid var(--border);
  border-radius: 13px;
  background: var(--panel-soft);
  color: var(--text);
  font: inherit;
  cursor: pointer;
}

.mini-button:hover {
  background: var(--accent-soft);
}

.match-counter {
  min-width: 54px;
  color: var(--muted);
  font-size: 13px;
  text-align: right;
}

.rhyme-suggestions {
  min-height: 30px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 7px;
}

.suggestions-label {
  color: var(--muted);
  font-size: 13px;
}

.suggestion-chip {
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.035);
  color: var(--text);
  font-size: 13px;
  padding: 6px 9px;
  cursor: pointer;
}

.suggestion-chip:hover {
  background: var(--accent-soft);
  border-color: rgba(124, 255, 138, 0.35);
}

.comment-row,
.song-token {
  user-select: none;
  cursor: grab;
}

.comment-row:active,
.song-token:active {
  cursor: grabbing;
}

.comment-row.dragging,
.song-token.dragging {
  opacity: 0.42;
}

.comment-row mark {
  color: var(--text);
  background: rgba(124, 255, 138, 0.34);
  border-radius: 5px;
  padding: 0 2px;
}

.comment-row.active-match {
  background: rgba(124, 255, 138, 0.12);
  outline: 1px solid rgba(124, 255, 138, 0.28);
}

.song-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.save-status {
  color: var(--muted);
  font-size: 13px;
  padding-top: 4px;
}

.save-status.save-error {
  color: var(--danger);
}

.song-help {
  margin: 8px 0 16px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

.song-lines {
  display: grid;
  gap: 10px;
}

.song-line {
  min-height: 44px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 8px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.045);
}

.song-line:empty::before {
  content: "перетащи комментарий в эту строку";
  color: rgba(139, 147, 167, 0.58);
  font-size: 14px;
}

.song-line.line-over {
  background: rgba(124, 255, 138, 0.075);
  border-color: rgba(124, 255, 138, 0.28);
}

.song-token {
  padding: 7px 10px;
  border-radius: 11px;
  color: var(--text);
  background: transparent;
  line-height: 1.35;
}

.song-token:hover {
  background: rgba(255, 255, 255, 0.055);
}

.line-button {
  margin-top: 12px;
  width: 100%;
  border: 1px dashed var(--border);
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.025);
  color: var(--muted);
  padding: 12px;
  cursor: pointer;
  font: inherit;
}

.line-button:hover {
  color: var(--text);
  background: var(--accent-soft);
  border-color: rgba(124, 255, 138, 0.28);
}

.drop-left {
  min-height: 260px;
}

/* === PATCH_7_IPHONE_LIVE_REORDER_CANVAS_START === */

.work-shell {
  color: #e7eaf0 !important;
}

.work-shell .reader-panel,
.work-shell .song-panel {
  background: #151821 !important;
  color: #e7eaf0 !important;
}

.work-shell h1,
.work-shell h2,
.work-shell h3 {
  color: #e7eaf0 !important;
}

.work-shell .eyebrow {
  color: #7cff8a !important;
}

.work-shell .muted,
.work-shell .hint,
.work-shell .counter,
#matchCounter,
#saveStatus {
  color: #8b93a7 !important;
}

#commentSearch {
  background: #0f1115 !important;
  color: #e7eaf0 !important;
  border: 1px solid rgba(255,255,255,.12) !important;
}

#commentSearch::placeholder {
  color: #8b93a7 !important;
}

#prevMatch,
#nextMatch {
  background: #1a1f2a !important;
  color: #e7eaf0 !important;
  border: 1px solid rgba(255,255,255,.12) !important;
}

.comment-scale-controls {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 8px 0 7px !important;
  color: #8b93a7 !important;
  font-size: 12px !important;
  user-select: none !important;
}

.comment-scale-controls button {
  min-width: 28px !important;
  height: 26px !important;
  padding: 0 8px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  background: #1a1f2a !important;
  color: #e7eaf0 !important;
  cursor: pointer !important;
}

.comment-scale-controls strong {
  min-width: 42px !important;
  color: #e7eaf0 !important;
  font-weight: 600 !important;
}

/* Левая область */
#availableComments {
  --comment-scale: .80;
  background: #ffffff !important;
  color: #111827 !important;
  border: 1px solid #dfe4ec !important;
  border-radius: 14px !important;
  padding: 6px 7px !important;
  overflow-y: auto !important;
  overscroll-behavior: contain !important;
  scroll-behavior: auto !important;
  box-shadow: inset 0 1px 0 rgba(0,0,0,.025) !important;
  touch-action: pan-y !important;
}

#availableComments .comment-row,
.comment-row {
  color: #111827 !important;
  background: transparent !important;
  font-size: calc(15px * var(--comment-scale, .80)) !important;
  line-height: 1.08 !important;
  padding: calc(3px * var(--comment-scale, .80)) 6px !important;
  margin: 0 !important;
  border-radius: 6px !important;
  cursor: grab !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  touch-action: none !important;
}

#availableComments .comment-row:hover,
.comment-row:hover {
  background: #edf2f7 !important;
}

#availableComments .comment-row.dragging-source {
  opacity: .52 !important;
  background: #eaf4ff !important;
}

.comment-row[hidden] {
  display: none !important;
}

/* Правая область: белый лист с невидимой строковой сеткой */
#songLines {
  --song-row-height: 34px;
  --song-row-gap: 4px;

  display: block !important;
  position: relative !important;
  background: #ffffff !important;
  color: #111827 !important;
  border: 1px solid #dfe4ec !important;
  border-radius: 14px !important;
  min-height: 66vh !important;
  padding: 14px 16px 18px !important;
  overflow-y: auto !important;
  scroll-behavior: auto !important;
  box-shadow: inset 0 1px 0 rgba(0,0,0,.025) !important;
  touch-action: none !important;
  cursor: default !important;
}

/* Строка существует логически, но не рисуется как зона */
#songLines > .song-line {
  display: flex !important;
  align-items: center !important;
  position: relative !important;
  height: var(--song-row-height) !important;
  min-height: var(--song-row-height) !important;
  margin: 0 0 var(--song-row-gap) 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#songLines > .song-line > .line-content {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 6px !important;
  min-height: var(--song-row-height) !important;
  height: var(--song-row-height) !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Пустая строка невидимая, но занимает ровно одну строку сетки */
#songLines > .song-line-empty-grid {
  background: transparent !important;
}

/* Комментарий = цельная иконка */
.song-token {
  display: inline-flex !important;
  align-items: center !important;
  flex: 0 0 auto !important;
  max-width: 100% !important;
  padding: 4px 7px !important;
  margin: 0 !important;
  border-radius: 8px !important;
  background: #f1f4f8 !important;
  color: #111827 !important;
  border: 1px solid #d6dde8 !important;
  box-shadow: 0 1px 2px rgba(12,18,28,.04) !important;
  font-size: 15px !important;
  line-height: 1.12 !important;
  cursor: grab !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  white-space: nowrap !important;
  touch-action: none !important;
  will-change: transform !important;
}

.song-token:hover {
  background: #e8eef6 !important;
}

/* Placeholder технический: он не подсвечивается, просто освобождает место */
.song-placeholder {
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

/* Плашка, которая летит под мышью */
.song-floating-token {
  position: fixed !important;
  z-index: 999999 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 4px 7px !important;
  margin: 0 !important;
  border-radius: 9px !important;
  background: #ffffff !important;
  color: #111827 !important;
  border: 1px solid rgba(17,24,39,.14) !important;
  box-shadow:
    0 14px 34px rgba(0,0,0,.22),
    0 3px 9px rgba(0,0,0,.12) !important;
  font-size: 15px !important;
  line-height: 1.12 !important;
  white-space: nowrap !important;
  pointer-events: none !important;
  user-select: none !important;
  transform: scale(1.045) rotate(-.4deg) !important;
  transform-origin: center !important;
}

/* Когда что-то тащим, не выделяем текст и не запускаем системный drag */
body.song-pointer-dragging,
body.song-pointer-dragging * {
  user-select: none !important;
  -webkit-user-select: none !important;
}

body.song-pointer-dragging #songLines {
  cursor: grabbing !important;
}

/* Возврат вправо -> влево */
.drop-left-active {
  outline: none !important;
  background: #f7fbff !important;
}

/* Поиск */
mark {
  background: #bfffc8 !important;
  color: #111827 !important;
  border-radius: 4px !important;
  padding: 0 2px !important;
}

.comment-row.active-match {
  background: #dcffe3 !important;
  color: #111827 !important;
}

/* Старые визуальные подсветки запрещены */
.song-line-target,
.song-line-before,
.song-line-after,
.song-canvas-active,
.song-canvas-empty-target {
  outline: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

.song-line-target::before,
.song-line-target::after,
.song-line-before::before,
.song-line-before::after,
.song-line-after::before,
.song-line-after::after {
  display: none !important;
  content: none !important;
}

/* === PATCH_7_IPHONE_LIVE_REORDER_CANVAS_END === */

/* === PATCH_7A_DOUBLE_CLICK_LEFT_TO_NEW_ROW_START === */

/* Микро-анимация после быстрого добавления */
#songLines > .song-line:last-child .song-token {
  animation: songTokenSoftPop .18s ease-out;
}

@keyframes songTokenSoftPop {
  from {
    transform: scale(.96);
    opacity: .72;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}

/* === PATCH_7A_DOUBLE_CLICK_LEFT_TO_NEW_ROW_END === */

/* === PATCH_7B_RHYME_HIGHLIGHT_INTERNAL_START === */

/* Рифмы не показываются отдельными плашками: только цвет в левом списке */
#availableComments .comment-row.rhyme-hit-1 {
  background: #fff8d7 !important;
}

#availableComments .comment-row.rhyme-hit-2 {
  background: #e7ffe8 !important;
}

#availableComments .comment-row.rhyme-hit-3 {
  background: #bfffc8 !important;
  box-shadow: inset 3px 0 0 rgba(22,163,74,.55) !important;
}

#availableComments .comment-row.rhyme-hit-1:hover,
#availableComments .comment-row.rhyme-hit-2:hover,
#availableComments .comment-row.rhyme-hit-3:hover {
  filter: saturate(1.05) !important;
}

.song-token.rhyme-source-token {
  background: #e9fff0 !important;
  border-color: rgba(22,163,74,.42) !important;
}

/* Никаких отдельных панелей и видимых ударений */
.work-shell.rhyme-mode-active #rhymeSuggestions {
  display: none !important;
}

/* === PATCH_7B_RHYME_HIGHLIGHT_INTERNAL_END === */

/* === PATCH_7C_MOBILE_TABS_NO_DESKTOP_TOUCH_START === */

/* По умолчанию десктоп не трогаем */
.mobile-work-tabs {
  display: none;
}

/* Только телефон / узкий экран */
@media (max-width: 760px) {
  html,
  body {
    overflow-x: hidden !important;
  }

  body {
    padding-bottom: 74px !important;
  }

  .work-shell.mobile-work-mode {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 10px 10px 84px !important;
    margin: 0 !important;
  }

  .work-shell.mobile-work-mode .reader-panel,
  .work-shell.mobile-work-mode .song-panel {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    border-radius: 16px !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments .song-panel {
    display: none !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song .reader-panel {
    display: none !important;
  }

  .work-shell.mobile-work-mode .reader-panel {
    padding: 12px !important;
  }

  .work-shell.mobile-work-mode .song-panel {
    padding: 12px !important;
  }

  .work-shell.mobile-work-mode h1 {
    font-size: 20px !important;
    line-height: 1.15 !important;
  }

  .work-shell.mobile-work-mode h2,
  .work-shell.mobile-work-mode h3 {
    font-size: 16px !important;
  }

  .work-shell.mobile-work-mode .reader-toolbar,
  .work-shell.mobile-work-mode .song-toolbar {
    gap: 8px !important;
    flex-wrap: wrap !important;
  }

  .work-shell.mobile-work-mode #commentSearch {
    width: 100% !important;
    min-height: 42px !important;
    font-size: 16px !important;
  }

  .work-shell.mobile-work-mode #availableComments {
    height: calc(100vh - 220px) !important;
    min-height: 420px !important;
    max-height: none !important;
    border-radius: 14px !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .work-shell.mobile-work-mode #availableComments .comment-row,
  .work-shell.mobile-work-mode .comment-row {
    font-size: 15px !important;
    line-height: 1.16 !important;
    padding: 8px 7px !important;
    border-radius: 8px !important;
  }

  .work-shell.mobile-work-mode #songLines {
    min-height: calc(100vh - 190px) !important;
    height: calc(100vh - 190px) !important;
    padding: 14px 12px 24px !important;
    border-radius: 14px !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .work-shell.mobile-work-mode #songLines > .song-line {
    height: 38px !important;
    min-height: 38px !important;
    margin-bottom: 5px !important;
  }

  .work-shell.mobile-work-mode #songLines > .song-line > .line-content {
    height: 38px !important;
    min-height: 38px !important;
    gap: 6px !important;
  }

  .work-shell.mobile-work-mode .song-token {
    font-size: 15px !important;
    padding: 6px 8px !important;
    border-radius: 9px !important;
  }

  .song-floating-token {
    font-size: 15px !important;
    padding: 6px 8px !important;
    border-radius: 10px !important;
  }

  .mobile-work-tabs {
    position: fixed !important;
    left: 10px !important;
    right: 10px !important;
    bottom: 10px !important;
    z-index: 99999 !important;

    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;

    padding: 8px !important;
    border-radius: 18px !important;
    background: rgba(16, 18, 24, .92) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    box-shadow: 0 16px 44px rgba(0,0,0,.35) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
  }

  .mobile-work-tabs[hidden] {
    display: none !important;
  }

  .mobile-work-tabs button {
    height: 46px !important;
    border: 0 !important;
    border-radius: 13px !important;
    background: rgba(255,255,255,.08) !important;
    color: #e7eaf0 !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    letter-spacing: .01em !important;
  }

  .mobile-work-tabs button.is-active {
    background: #ffffff !important;
    color: #111827 !important;
  }
}

/* === PATCH_7C_MOBILE_TABS_NO_DESKTOP_TOUCH_END === */

/* === PATCH_7D_NATIVE_FLOATING_CARD_ANCHOR_START === */

/* Летящая карточка должна ощущаться как взятая карточка, а не как центрированный блок */
.song-floating-token {
  justify-content: flex-start !important;
  text-align: left !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  box-sizing: border-box !important;
  max-width: min(520px, calc(100vw - 28px)) !important;
  padding-left: 8px !important;
  padding-right: 8px !important;
}

/* Временный измеритель ширины, пользователь его не видит */
.song-floating-probe {
  visibility: hidden !important;
  pointer-events: none !important;
  transform: none !important;
  box-shadow: none !important;
}

/* При захвате слева строка остаётся на месте до успешного переноса, но видно что её взяли */
#availableComments .comment-row.dragging-source {
  opacity: .42 !important;
  background: #eef6ff !important;
}

/* === PATCH_7D_NATIVE_FLOATING_CARD_ANCHOR_END === */

/* === PATCH_7E_MOBILE_LONG_PRESS_SCROLL_START === */

/* Только телефон: обычный палец должен листать, а не сразу хватать слово */
@media (max-width: 760px) {
  .work-shell.mobile-work-mode #availableComments {
    touch-action: pan-y !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .work-shell.mobile-work-mode #availableComments .comment-row,
  .work-shell.mobile-work-mode .comment-row {
    touch-action: pan-y !important;
    cursor: default !important;
  }

  .work-shell.mobile-work-mode #songLines {
    touch-action: pan-y !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .work-shell.mobile-work-mode #songLines .song-token {
    touch-action: pan-y !important;
    cursor: default !important;
  }

  body.song-pointer-dragging #availableComments,
  body.song-pointer-dragging #songLines,
  body.song-pointer-dragging .comment-row,
  body.song-pointer-dragging .song-token {
    touch-action: none !important;
  }

  body.song-pointer-dragging .song-floating-token {
    cursor: grabbing !important;
  }
}

/* === PATCH_7E_MOBILE_LONG_PRESS_SCROLL_END === */

/* === PATCH_7G_MOBILE_COMMENTS_FULLSCREEN_START === */

/* Только телефон. Десктоп не трогаем. */
@media (max-width: 760px) {
  html,
  body {
    width: 100% !important;
    height: 100% !important;
    min-height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    background: #10151f !important;
  }

  body {
    padding-bottom: 0 !important;
  }

  /* Общая страница по размеру окна смартфона */
  .work-shell.mobile-work-mode {
    width: 100vw !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    max-height: 100dvh !important;
    max-width: none !important;

    display: block !important;
    margin: 0 !important;
    padding: 8px 8px 76px !important;

    overflow: hidden !important;
    border-radius: 0 !important;
    box-sizing: border-box !important;
  }

  /* Убираем ощущение "окна внутри окна" */
  .work-shell.mobile-work-mode .reader-panel,
  .work-shell.mobile-work-mode .song-panel {
    width: 100% !important;
    height: calc(100dvh - 92px) !important;
    min-height: 0 !important;
    max-height: calc(100dvh - 92px) !important;

    margin: 0 !important;
    padding: 8px !important;

    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  /* На вкладке комментариев прячем лишнюю шапку проекта */
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel .eyebrow,
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel h1,
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel .stats,
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel .muted,
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel .hint,
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel .counter {
    display: none !important;
  }

  /* Панель поиска делаем компактной сверху */
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-toolbar {
    display: grid !important;
    grid-template-columns: 1fr 44px 44px auto !important;
    gap: 8px !important;
    align-items: center !important;

    margin: 0 0 8px 0 !important;
    padding: 0 !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #commentSearch {
    width: 100% !important;
    min-width: 0 !important;
    height: 44px !important;
    min-height: 44px !important;
    padding: 0 14px !important;

    font-size: 16px !important;
    border-radius: 14px !important;
    box-sizing: border-box !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #prevMatch,
  .work-shell.mobile-work-mode.mobile-tab-comments #nextMatch {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    border-radius: 14px !important;
    padding: 0 !important;
    font-size: 22px !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #matchCounter {
    min-width: 46px !important;
    font-size: 14px !important;
    text-align: center !important;
  }

  /* Масштаб на телефоне не должен съедать много места */
  .work-shell.mobile-work-mode.mobile-tab-comments .comment-scale-controls {
    height: 34px !important;
    margin: 0 0 8px 0 !important;
    gap: 8px !important;
    font-size: 13px !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments .comment-scale-controls button {
    height: 30px !important;
    min-width: 34px !important;
    border-radius: 11px !important;
  }

  /* Главное: белый список почти на весь экран, листается только он */
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments {
    width: 100% !important;
    height: calc(100dvh - 8px - 44px - 8px - 34px - 8px - 76px) !important;
    min-height: 0 !important;
    max-height: none !important;

    margin: 0 !important;
    padding: 10px 12px !important;

    border: 0 !important;
    border-radius: 16px !important;
    background: #ffffff !important;
    box-shadow: none !important;

    overflow-x: hidden !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    touch-action: pan-y !important;

    box-sizing: border-box !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row,
  .work-shell.mobile-work-mode.mobile-tab-comments .comment-row {
    width: 100% !important;
    display: block !important;

    padding: 9px 2px !important;
    margin: 0 !important;

    border-radius: 0 !important;
    background: transparent !important;
    color: #111827 !important;

    font-size: 18px !important;
    line-height: 1.24 !important;

    touch-action: pan-y !important;
    cursor: default !important;
    box-sizing: border-box !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row + .comment-row {
    border-top: 1px solid rgba(17,24,39,.06) !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row:hover {
    background: transparent !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row.rhyme-hit-1,
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row.rhyme-hit-2,
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row.rhyme-hit-3,
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row.active-match {
    border-radius: 9px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  /* Вкладка песни тоже в полный экран, но отдельно */
  .work-shell.mobile-work-mode.mobile-tab-song .song-panel {
    padding: 8px !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song .song-panel .eyebrow,
  .work-shell.mobile-work-mode.mobile-tab-song .song-panel h2,
  .work-shell.mobile-work-mode.mobile-tab-song .song-panel .hint {
    display: none !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song .song-toolbar {
    height: 32px !important;
    margin: 0 0 8px 0 !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song #songLines {
    width: 100% !important;
    height: calc(100dvh - 8px - 32px - 8px - 76px) !important;
    min-height: 0 !important;

    margin: 0 !important;
    padding: 12px !important;

    border: 0 !important;
    border-radius: 16px !important;
    box-shadow: none !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  /* Нижние вкладки компактнее и не перекрывают слишком много */
  .mobile-work-tabs {
    left: 8px !important;
    right: 8px !important;
    bottom: 8px !important;

    height: 58px !important;
    padding: 7px !important;
    border-radius: 18px !important;
    box-sizing: border-box !important;
  }

  .mobile-work-tabs button {
    height: 44px !important;
    border-radius: 13px !important;
    font-size: 16px !important;
  }
}

/* === PATCH_7G_MOBILE_COMMENTS_FULLSCREEN_END === */

/* === PATCH_7H_MOBILE_TRUE_APP_COMMENTS_VIEW_START === */

/* Только телефон. Десктоп не трогаем. */
@media (max-width: 760px) {
  html,
  body {
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    background: #10151f !important;
  }

  body {
    min-height: 100dvh !important;
    padding: 0 !important;
  }

  /* Убираем внешний "контейнер сайта": режим приложения */
  .work-shell.mobile-work-mode {
    position: fixed !important;
    inset: 0 !important;

    width: 100vw !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    max-height: 100dvh !important;
    max-width: none !important;

    margin: 0 !important;
    padding: 8px 8px 72px !important;

    display: block !important;
    overflow: hidden !important;
    box-sizing: border-box !important;

    background: #10151f !important;
    border: 0 !important;
    border-radius: 0 !important;
  }

  .work-shell.mobile-work-mode .reader-panel,
  .work-shell.mobile-work-mode .song-panel {
    position: relative !important;

    width: 100% !important;
    height: calc(100dvh - 80px) !important;
    min-height: 0 !important;
    max-height: calc(100dvh - 80px) !important;

    margin: 0 !important;
    padding: 0 !important;

    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;

    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  /* На комментариях оставляем только поиск + список */
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel .eyebrow,
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel h1,
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel .stats,
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel .muted,
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel .hint,
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-panel .counter,
  .work-shell.mobile-work-mode.mobile-tab-comments .comment-scale-controls,
  .work-shell.mobile-work-mode.mobile-tab-comments #rhymeSuggestions {
    display: none !important;
  }

  /* Поиск сразу сверху, без огромных отступов */
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-toolbar {
    display: grid !important;
    grid-template-columns: 1fr 42px 42px 42px !important;
    gap: 7px !important;
    align-items: center !important;

    width: 100% !important;
    height: 46px !important;

    margin: 0 0 8px 0 !important;
    padding: 0 !important;

    box-sizing: border-box !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #commentSearch {
    width: 100% !important;
    min-width: 0 !important;
    height: 46px !important;
    min-height: 46px !important;

    padding: 0 14px !important;
    margin: 0 !important;

    border-radius: 15px !important;
    font-size: 16px !important;
    line-height: 46px !important;

    box-sizing: border-box !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #prevMatch,
  .work-shell.mobile-work-mode.mobile-tab-comments #nextMatch {
    width: 42px !important;
    height: 46px !important;
    min-width: 42px !important;

    padding: 0 !important;
    margin: 0 !important;

    border-radius: 15px !important;
    font-size: 22px !important;
    line-height: 46px !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #matchCounter {
    width: 42px !important;
    min-width: 42px !important;

    font-size: 13px !important;
    text-align: center !important;
    color: #8b93a7 !important;
  }

  /* Белый список почти во весь экран */
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments {
    position: relative !important;

    width: 100% !important;
    height: calc(100dvh - 8px - 46px - 8px - 72px) !important;
    min-height: 0 !important;
    max-height: none !important;

    margin: 0 !important;
    padding: 8px 12px 18px !important;

    background: #ffffff !important;
    color: #111827 !important;

    border: 0 !important;
    border-radius: 16px !important;
    box-shadow: none !important;

    overflow-x: hidden !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    touch-action: pan-y !important;

    box-sizing: border-box !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row,
  .work-shell.mobile-work-mode.mobile-tab-comments .comment-row {
    display: block !important;
    width: 100% !important;

    padding: 10px 0 !important;
    margin: 0 !important;

    color: #111827 !important;
    background: transparent !important;
    border-radius: 0 !important;

    font-size: 19px !important;
    line-height: 1.22 !important;
    font-weight: 400 !important;

    cursor: default !important;
    touch-action: pan-y !important;
    box-sizing: border-box !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row + .comment-row {
    border-top: 1px solid rgba(17,24,39,.065) !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row:hover {
    background: transparent !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row.rhyme-hit-1,
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row.rhyme-hit-2,
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row.rhyme-hit-3,
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row.active-match {
    border-radius: 10px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  /* Песня на телефоне тоже без шапки, только рабочее поле */
  .work-shell.mobile-work-mode.mobile-tab-song .song-panel .eyebrow,
  .work-shell.mobile-work-mode.mobile-tab-song .song-panel h2,
  .work-shell.mobile-work-mode.mobile-tab-song .song-panel .hint {
    display: none !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song .song-toolbar {
    height: 32px !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song #songLines {
    width: 100% !important;
    height: calc(100dvh - 8px - 32px - 8px - 72px) !important;
    min-height: 0 !important;

    margin: 0 !important;
    padding: 12px !important;

    border: 0 !important;
    border-radius: 16px !important;
    box-shadow: none !important;

    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    box-sizing: border-box !important;
  }

  /* Нижняя навигация */
  .mobile-work-tabs {
    left: 8px !important;
    right: 8px !important;
    bottom: 8px !important;

    height: 58px !important;
    padding: 7px !important;

    border-radius: 18px !important;
    box-sizing: border-box !important;
  }

  .mobile-work-tabs button {
    height: 44px !important;
    border-radius: 13px !important;
    font-size: 16px !important;
  }
}

/* === PATCH_7H_MOBILE_TRUE_APP_COMMENTS_VIEW_END === */

/* === PATCH_7I_MOBILE_DENSITY_NO_AUTOSWITCH_SONG_SCROLL_START === */

/* Только телефон. Десктоп не трогаем. */
@media (max-width: 760px) {
  /* Чуть компактнее вся мобильная страница */
  .work-shell.mobile-work-mode {
    padding: 6px 6px 68px !important;
  }

  /* Поиск ниже по высоте и плотнее */
  .work-shell.mobile-work-mode.mobile-tab-comments .reader-toolbar {
    height: 40px !important;
    grid-template-columns: 1fr 38px 38px 38px !important;
    gap: 6px !important;
    margin-bottom: 6px !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #commentSearch {
    height: 40px !important;
    min-height: 40px !important;
    line-height: 40px !important;
    font-size: 15px !important;
    border-radius: 13px !important;
    padding: 0 12px !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #prevMatch,
  .work-shell.mobile-work-mode.mobile-tab-comments #nextMatch {
    width: 38px !important;
    height: 40px !important;
    min-width: 38px !important;
    line-height: 40px !important;
    font-size: 20px !important;
    border-radius: 13px !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #matchCounter {
    width: 38px !important;
    min-width: 38px !important;
    font-size: 13px !important;
  }

  /* Список выше и плотнее */
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments {
    height: calc(100dvh - 6px - 40px - 6px - 68px) !important;
    padding: 6px 10px 14px !important;
    border-radius: 14px !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row,
  .work-shell.mobile-work-mode.mobile-tab-comments .comment-row {
    padding: 7px 0 !important;
    font-size: 16px !important;
    line-height: 1.18 !important;
  }

  /* Нижняя навигация немного компактнее */
  .mobile-work-tabs {
    left: 6px !important;
    right: 6px !important;
    bottom: 6px !important;
    height: 54px !important;
    padding: 6px !important;
    border-radius: 16px !important;
  }

  .mobile-work-tabs button {
    height: 42px !important;
    border-radius: 12px !important;
    font-size: 15px !important;
  }

  /* Вкладка "Песня": рабочая область обязана листаться */
  .work-shell.mobile-work-mode.mobile-tab-song .song-panel {
    height: calc(100dvh - 74px) !important;
    max-height: calc(100dvh - 74px) !important;
    overflow: hidden !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song .song-toolbar {
    height: 28px !important;
    margin: 0 0 6px 0 !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song #songLines {
    height: calc(100dvh - 6px - 28px - 6px - 68px) !important;
    min-height: 0 !important;
    max-height: calc(100dvh - 6px - 28px - 6px - 68px) !important;

    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    touch-action: pan-y !important;

    padding: 10px !important;
    border-radius: 14px !important;
    box-sizing: border-box !important;
  }

  /* Строки в песне на телефоне чуть выше, но без горизонтального вылета */
  .work-shell.mobile-work-mode.mobile-tab-song #songLines > .song-line {
    height: 36px !important;
    min-height: 36px !important;
    margin-bottom: 4px !important;
    max-width: 100% !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song #songLines > .song-line > .line-content {
    height: 36px !important;
    min-height: 36px !important;
    max-width: 100% !important;
    overflow: hidden !important;
    gap: 5px !important;
  }

  /* Длинные комментарии не уходят за край экрана */
  .work-shell.mobile-work-mode.mobile-tab-song .song-token {
    max-width: calc(100vw - 44px) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;

    font-size: 14px !important;
    padding: 5px 7px !important;
    border-radius: 8px !important;

    touch-action: pan-y !important;
  }

  /* Летящая карточка тоже не должна вылезать за экран */
  .song-floating-token {
    max-width: calc(100vw - 24px) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
}

/* === PATCH_7I_MOBILE_DENSITY_NO_AUTOSWITCH_SONG_SCROLL_END === */

/* === PATCH_7K_MOBILE_SCROLL_AND_SONG_FULLSCREEN_FIX_START === */

@media (max-width: 760px) {
  /* Комментарии: только список скроллится, карточки не хватаются пальцем */
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments,
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row {
    touch-action: pan-y !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row {
    -webkit-user-select: none !important;
    user-select: none !important;
  }

  /* Песня: убираем вообще весь верх, оставляем только белое рабочее поле */
  .work-shell.mobile-work-mode.mobile-tab-song .song-panel > *:not(#songLines) {
    display: none !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song .song-panel {
    height: calc(100dvh - 68px) !important;
    max-height: calc(100dvh - 68px) !important;
    padding: 6px !important;
    overflow: hidden !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song #songLines {
    display: block !important;

    width: 100% !important;
    height: calc(100dvh - 6px - 68px) !important;
    min-height: 0 !important;
    max-height: calc(100dvh - 6px - 68px) !important;

    margin: 0 !important;
    padding: 10px !important;

    border-radius: 14px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    touch-action: pan-y !important;
    box-sizing: border-box !important;
  }

  /* Пока просто листаем песню — скролл разрешён */
  .work-shell.mobile-work-mode.mobile-tab-song #songLines .song-token {
    touch-action: pan-y !important;
    max-width: calc(100vw - 42px) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  /* Когда long press уже включил перенос — скролл полностью блокируется */
  body.song-pointer-dragging,
  body.song-pointer-dragging * {
    touch-action: none !important;
    overscroll-behavior: none !important;
  }

  body.song-pointer-dragging #songLines {
    overflow: hidden !important;
  }

  /* Плотность списка комментариев ещё чуть компактнее */
  .work-shell.mobile-work-mode.mobile-tab-comments #availableComments .comment-row,
  .work-shell.mobile-work-mode.mobile-tab-comments .comment-row {
    font-size: 15px !important;
    line-height: 1.16 !important;
    padding-top: 6px !important;
    padding-bottom: 6px !important;
  }
}

/* === PATCH_7K_MOBILE_SCROLL_AND_SONG_FULLSCREEN_FIX_END === */

/* === PATCH_7M_NUMBER_RHYME_HINT_LABELS_START === */

/* Серая внутренняя подсказка: как рифмо-движок слышит цифру */
.number-rhyme-hint {
  float: right !important;
  display: inline-flex !important;
  align-items: center !important;

  max-width: 46% !important;
  margin-left: 10px !important;

  color: #9ca3af !important;
  font-size: .76em !important;
  font-weight: 400 !important;
  line-height: 1.2 !important;

  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  pointer-events: none !important;
  user-select: none !important;
}

/* На телефоне подсказка компактная, справа, не ломает список */
@media (max-width: 760px) {
  .work-shell.mobile-work-mode #availableComments .comment-row {
    position: relative !important;
    padding-right: 8px !important;
  }

  .work-shell.mobile-work-mode #availableComments .number-rhyme-hint {
    max-width: 42% !important;
    margin-left: 8px !important;
    font-size: .68em !important;
    color: #9aa3af !important;
  }
}

/* === PATCH_7M_NUMBER_RHYME_HINT_LABELS_END === */

/* === PATCH_7N_CONTEXTUAL_NUMBER_RHYME_HINTS_START === */

/* Серый текст теперь появляется только в режиме рифм и только у подсвеченных строк */
.number-rhyme-hint {
  float: right !important;
  display: inline-flex !important;
  align-items: center !important;

  max-width: 42% !important;
  margin-left: 10px !important;

  color: #9ca3af !important;
  font-size: .72em !important;
  font-weight: 400 !important;
  line-height: 1.2 !important;

  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;

  pointer-events: none !important;
  user-select: none !important;
}

@media (max-width: 760px) {
  .work-shell.mobile-work-mode #availableComments .number-rhyme-hint {
    max-width: 38% !important;
    font-size: .66em !important;
    color: #9aa3af !important;
  }
}

/* === PATCH_7N_CONTEXTUAL_NUMBER_RHYME_HINTS_END === */

/* === PATCH_7N_FIX_CONTEXTUAL_NUMBER_RHYME_HINTS_START === */

/* Серый текст появляется только когда JS добавил .number-rhyme-hint в режиме рифм */
.number-rhyme-hint {
  float: right !important;
  display: inline-flex !important;
  align-items: center !important;

  max-width: 42% !important;
  margin-left: 10px !important;

  color: #9ca3af !important;
  font-size: .72em !important;
  font-weight: 400 !important;
  line-height: 1.2 !important;

  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;

  pointer-events: none !important;
  user-select: none !important;
}

@media (max-width: 760px) {
  .work-shell.mobile-work-mode #availableComments .number-rhyme-hint {
    max-width: 38% !important;
    font-size: .66em !important;
    color: #9aa3af !important;
  }
}

/* === PATCH_7N_FIX_CONTEXTUAL_NUMBER_RHYME_HINTS_END === */


/* PATCH_7W5_MINIMAL_RHYME_ARROWS */
.comment-row.rhyme-arrow-current {
  outline: 2px solid rgba(59, 130, 246, 0.8);
  outline-offset: 2px;
}



/* PATCH_7X_DESKTOP_SONG_CANVAS_SCROLL
   Desktop: правая область песни должна прокручиваться внутри панели,
   а не уходить вниз и обрезаться за пределами экрана. */
@media (min-width: 901px) {
  .work-shell {
    min-height: 0 !important;
    overflow: hidden !important;
  }

  .song-panel {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  .song-head,
  .song-help,
  .song-toolbar,
  .save-status {
    flex: 0 0 auto !important;
  }

  #songLines {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: none !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    padding-bottom: 80px !important;
  }
}



/* PATCH_7Y_RIGHT_SONG_SCALE_CONTROLS */
.song-scale-controls {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 10px 0 8px;
  color: var(--muted);
  font-size: 13px;
}

.song-scale-controls button {
  min-width: 34px;
  height: 26px;
  border: 1px solid var(--border);
  border-radius: 9px;
  background: var(--panel-soft);
  color: var(--text);
  font: inherit;
  cursor: pointer;
}

.song-scale-controls button:hover {
  background: var(--accent-soft);
}

.song-scale-controls strong {
  min-width: 44px;
  text-align: center;
  color: var(--text);
  font-size: 13px;
}

#songLines {
  --song-scale: 1;
}

#songLines .song-token {
  font-size: calc(15px * var(--song-scale, 1)) !important;
  padding:
    calc(6px * var(--song-scale, 1))
    calc(8px * var(--song-scale, 1)) !important;
  border-radius: calc(9px * var(--song-scale, 1)) !important;
}



@media (max-width: 760px) {
  .work-shell.mobile-work-mode.mobile-tab-comments .song-scale-controls {
    display: none !important;
  }

  .work-shell.mobile-work-mode.mobile-tab-song .song-scale-controls {
    display: inline-flex !important;
    margin: 0 0 8px 0 !important;
  }
}



/* PATCH_7ZC_NATIVE_DOM_DRAG_FIXED
   Масштаб справа меняет плашки/текст, но не должен ломать drag-сетку. */
#songLines .song-token {
  font-size: calc(15px * var(--song-scale, 1)) !important;
  padding:
    calc(6px * var(--song-scale, 1))
    calc(8px * var(--song-scale, 1)) !important;
  border-radius: calc(9px * var(--song-scale, 1)) !important;
  line-height: 1.12 !important;
}

#songLines > .song-line {
  height: auto !important;
  min-height: var(--song-row-height, 34px) !important;
}

#songLines > .song-line > .line-content {
  height: auto !important;
  min-height: var(--song-row-height, 34px) !important;
}



/* PATCH_7ZD_SCALE_ROW_SPACING_AFTER_DOM_DRAG
   После DOM-based drag можно безопасно сжимать вертикальные ряды вместе с масштабом. */
#songLines {
  gap: max(3px, calc(10px * var(--song-scale, 1))) !important;
}

#songLines > .song-line {
  height: auto !important;
  min-height: max(22px, calc(var(--song-row-height, 34px) * var(--song-scale, 1))) !important;
}

#songLines > .song-line > .line-content {
  height: auto !important;
  min-height: max(22px, calc(var(--song-row-height, 34px) * var(--song-scale, 1))) !important;
  align-items: center !important;
}



/* PATCH_7ZE_CLEAN_LAYOUT_AND_STOP_LEFT_JITTER */

/* Подсказка справа больше не нужна: освобождаем место под рабочую область. */
.song-help {
  display: none !important;
}

/* Левый масштаб визуально делаем таким же ровным, как правый. */
.comment-scale-controls {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 10px 0 8px 0 !important;
  color: var(--muted) !important;
  font-size: 13px !important;
  line-height: 26px !important;
  user-select: none !important;
}

.comment-scale-controls button {
  min-width: 34px !important;
  height: 26px !important;
  padding: 0 10px !important;
  border: 1px solid var(--border) !important;
  border-radius: 9px !important;
  background: var(--panel-soft) !important;
  color: var(--text) !important;
  font: inherit !important;
  cursor: pointer !important;
}

.comment-scale-controls button:hover {
  background: var(--accent-soft) !important;
}

.comment-scale-controls strong {
  min-width: 44px !important;
  text-align: center !important;
  color: var(--text) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

/* Стабилизируем левое окно: drag справа не должен провоцировать layout/repaint слева. */
.reader-panel {
  contain: layout paint !important;
}

#availableComments {
  scrollbar-gutter: stable !important;
  will-change: scroll-position !important;
  transform: translateZ(0) !important;
}

body.song-pointer-dragging #availableComments {
  scroll-behavior: auto !important;
}



/* PATCH_7ZF_SEARCH_CLEAR_BUTTON */
.search-row {
  position: relative !important;
}

#commentSearch {
  padding-right: 44px !important;
}

.search-clear-button {
  position: absolute !important;
  right: 178px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 28px !important;
  height: 28px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: #8b93a7 !important;
  font-size: 22px !important;
  line-height: 28px !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 3 !important;
}

.search-clear-button:hover {
  background: rgba(255,255,255,.08) !important;
  color: #e7eaf0 !important;
}

.search-clear-button[hidden] {
  display: none !important;
}

@media (max-width: 760px) {
  .search-clear-button {
    right: 112px !important;
  }

  #commentSearch {
    padding-right: 38px !important;
  }
}


/* PATCH_7ZG_ALIGN_LEFT_SCALE_CONTROLS */
.reader-panel .comment-scale-controls {
  margin-left: 18px !important;
  margin-top: 10px !important;
  margin-bottom: 12px !important;
}

.reader-panel .comment-scale-controls span,
.reader-panel .comment-scale-controls strong,
.reader-panel .comment-scale-controls button {
  vertical-align: middle;
}

@media (max-width: 760px) {
  .reader-panel .comment-scale-controls {
    margin-left: 0 !important;
  }
}



/* PATCH_7ZI_STRICT_SOUND_ENDING_SUGGESTIONS */
.rhyme-suggestions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 10px !important;
  min-height: 0 !important;
}

.rhyme-suggestions[hidden] {
  display: none !important;
}

.sound-ending-chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  height: 28px !important;
  padding: 0 10px !important;
  border-radius: 7px !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  background: rgba(255,255,255,.92) !important;
  color: #111827 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}

.sound-ending-chip em {
  color: #4b5563 !important;
  font-style: normal !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

.sound-ending-chip:hover {
  background: #ffffff !important;
  transform: translateY(-1px) !important;
}



/* PATCH_7ZJ_TYPED_RHYME_LIST_AND_SOUND_ALIASES */
.rhyme-suggestions {
  display: block !important;
  margin-top: 10px !important;
}

.rhyme-suggestions[hidden] {
  display: none !important;
}

.typed-rhyme-box {
  display: grid !important;
  gap: 8px !important;
  max-width: 100% !important;
}

.typed-rhyme-title {
  color: #8b93a7 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  margin-top: 2px !important;
}

.typed-rhyme-chips {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

.sound-ending-chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  height: 28px !important;
  padding: 0 10px !important;
  border-radius: 7px !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  background: rgba(255,255,255,.92) !important;
  color: #111827 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}

.sound-ending-chip em {
  color: #4b5563 !important;
  font-style: normal !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

.typed-rhyme-list {
  display: grid !important;
  gap: 6px !important;
  max-height: 180px !important;
  overflow-y: auto !important;
  padding-right: 4px !important;
}

.typed-rhyme-row {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 10px !important;
  background: rgba(255,255,255,.06) !important;
  color: #e7eaf0 !important;
  padding: 7px 10px !important;
  cursor: pointer !important;
  text-align: left !important;
}

.typed-rhyme-row span {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.typed-rhyme-row em {
  color: #8b93a7 !important;
  font-style: normal !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

.typed-rhyme-row:hover {
  background: rgba(255,255,255,.1) !important;
}



/* PATCH_7ZK_YO_AWARE_TYPED_RHYME */
.yo-ending-chip {
  border-color: rgba(250, 204, 21, .38) !important;
  background: rgba(250, 204, 21, .12) !important;
  color: #facc15 !important;
}

.yo-ending-chip em {
  color: #fde68a !important;
}

.typed-rhyme-row.yo-rhyme-row {
  border-color: rgba(250, 204, 21, .25) !important;
  background: rgba(250, 204, 21, .08) !important;
}

.typed-rhyme-row.yo-rhyme-row em {
  color: #fde68a !important;
}



/* PATCH_7ZL_HIDE_TYPED_RHYME_RESULT_LIST */
.typed-rhyme-list {
  display: none !important;
}
