.karaoke-producer {
  max-width: 1500px;
  margin: 0 auto;
  padding: 20px 24px 44px;
  color: #17212f;
}

.kp-header h1 {
  margin: 0;
  font-size: clamp(1.55rem, 2.1vw, 2.1rem);
}

.kp-nav {
  margin: 8px 0 0;
  font-size: 0.94rem;
  color: #365178;
}

.kp-nav a {
  color: #1e3a8a;
  text-decoration: none;
}

.kp-nav a:hover,
.kp-nav a:focus-visible {
  text-decoration: underline;
}

.kp-status {
  margin: 12px 0 0;
  font-size: 0.95rem;
  color: #20314b;
}

.kp-compile-progress {
  margin: 10px 0 0;
  font-size: 0.86rem;
  color: #304968;
}

.kp-compile-progress[data-state="working"] {
  color: #1f4e95;
}

.kp-compile-progress[data-state="done"] {
  color: #1f6a2a;
}

.kp-compile-progress[data-state="error"] {
  color: #8e1d1d;
}

.kp-compile-banner {
  margin-top: 10px;
  border: 1px solid #8fc8a0;
  border-radius: 10px;
  background: #effcf3;
  padding: 10px 12px;
}

.kp-compile-banner__title {
  margin: 0;
  color: #1f6a2a;
  font-size: 0.9rem;
  font-weight: 700;
}

.kp-compile-banner__message {
  margin: 4px 0 0;
  color: #245a2d;
  font-size: 0.84rem;
}

.kp-toast-stack {
  position: fixed;
  right: 14px;
  bottom: 14px;
  z-index: 70;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}

.kp-toast {
  min-width: 240px;
  max-width: min(460px, calc(100vw - 28px));
  border: 1px solid #afc2df;
  border-radius: 10px;
  background: #f7faff;
  color: #1f3555;
  padding: 8px 10px;
  font-size: 0.84rem;
  box-shadow: 0 12px 28px rgba(17, 34, 62, 0.2);
}

.kp-toast--success {
  border-color: #8fc8a0;
  background: #effcf3;
  color: #245a2d;
}

.kp-toast--error {
  border-color: #e2a8a8;
  background: #fff3f3;
  color: #8e1d1d;
}

.kp-toast--warning {
  border-color: #d6bd75;
  background: #fff9e7;
  color: #5f4612;
}

.kp-operation-report {
  margin: 12px 0;
  border: 1px solid #d6b36b;
  border-radius: 8px;
  background: #fff9eb;
  padding: 10px 12px;
}

.kp-operation-report__title {
  color: #725217;
  font-size: 0.88rem;
  font-weight: 700;
}

.kp-operation-report__summary {
  margin-top: 4px;
  color: #725217;
  font-size: 0.84rem;
}

.kp-operation-report__body {
  max-height: 220px;
  margin: 8px 0 0;
  overflow: auto;
  color: #4a3710;
  font-size: 0.78rem;
  line-height: 1.35;
  white-space: pre-wrap;
}

.kp-card {
  margin-top: 18px;
  border: 1px solid #d8e2f0;
  border-radius: 14px;
  background: #f7faff;
  padding: 16px;
}

.kp-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px 14px;
}

.kp-card__head h2 {
  margin: 0;
  font-size: 1.08rem;
}

.kp-recents {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.kp-recents label {
  font-size: 0.84rem;
  font-weight: 700;
  color: #253a58;
}

.kp-recents select {
  min-width: 250px;
  border: 1px solid #afc2df;
  border-radius: 8px;
  background: #ffffff;
  color: #17212f;
  padding: 7px 9px;
  font: inherit;
}

.kp-help {
  margin: 6px 0 0;
  color: #48658c;
  font-size: 0.9rem;
}

.kp-source-grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr;
  gap: 14px;
}

.kp-upload-col {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

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

.kp-master-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(240px, 1fr));
  gap: 12px;
  margin-top: 10px;
}

.kp-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.kp-field span {
  font-size: 0.84rem;
  font-weight: 700;
  color: #253a58;
}

.kp-field input,
.kp-field select,
.kp-field textarea {
  border: 1px solid #adc0dd;
  border-radius: 8px;
  background: #ffffff;
  color: #17212f;
  font: inherit;
  padding: 8px 10px;
}

.kp-field textarea {
  resize: vertical;
  min-height: 136px;
}

.kp-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
}

.kp-btn {
  border: 1px solid #94aacb;
  border-radius: 8px;
  background: #ffffff;
  color: #1b2f4b;
  padding: 7px 12px;
  font: inherit;
  font-size: 0.9rem;
  cursor: pointer;
}

.kp-btn:hover,
.kp-btn:focus-visible {
  border-color: #5f7fb0;
  background: #eef4ff;
}

.kp-btn--primary {
  border-color: #315ea5;
  background: #315ea5;
  color: #ffffff;
}

.kp-btn--primary:hover,
.kp-btn--primary:focus-visible {
  border-color: #274d8a;
  background: #274d8a;
}

.kp-btn--danger {
  border-color: #8c2f2f;
  color: #8c2f2f;
}

.kp-btn--danger:hover,
.kp-btn--danger:focus-visible {
  border-color: #742424;
  background: #fdecec;
}

.kp-btn--busy {
  border-color: #b42318 !important;
  background: #b42318 !important;
  color: #ffffff !important;
}

.kp-table-wrap {
  margin-top: 10px;
  overflow-x: auto;
}

.kp-table {
  width: 100%;
  min-width: 1960px;
  border-collapse: collapse;
  table-layout: fixed;
}

.kp-col--index {
  width: 56px;
}

.kp-col--sentence {
  width: 16.8%;
}

.kp-col--pause {
  width: 66px;
}

.kp-col--asset {
  width: 10.5%;
}

.kp-col--actions {
  width: 17%;
}

.kp-table th,
.kp-table td {
  border: 1px solid #d4dfef;
  padding: 9px 8px;
  vertical-align: top;
  background: #ffffff;
}

.kp-table th {
  background: #ebf2ff;
  font-size: 0.85rem;
  text-align: left;
}

.kp-th-stack {
  display: grid;
  gap: 6px;
}

.kp-th-renew {
  justify-self: start;
  border: 1px solid #96aed1;
  border-radius: 5px;
  background: #ffffff;
  color: #1f3555;
  font: inherit;
  font-size: 0.68rem;
  line-height: 1.1;
  padding: 3px 7px;
  cursor: pointer;
}

.kp-row-index {
  font-weight: 700;
  color: #304968;
  text-align: center;
}

.kp-paragraph-toggle {
  width: 26px;
  height: 26px;
  margin: 7px auto 0;
  border: 1px solid currentColor;
  border-radius: 7px;
  display: grid;
  place-items: center;
  font: 700 18px/1 Georgia, serif;
  cursor: pointer;
}

.kp-paragraph-toggle--on {
  color: #00851f;
  background: #dcffe5;
  border-color: #00851f;
}

.kp-paragraph-toggle--off {
  color: #d00000;
  background: #ffe1e1;
  border-color: #d00000;
}

.kp-paragraph-toggle:disabled {
  cursor: not-allowed;
  opacity: 0.78;
}

.kp-title-toggle {
  width: 26px;
  height: 26px;
  margin: 6px auto 0;
  border: 1px solid currentColor;
  border-radius: 7px;
  display: grid;
  place-items: center;
  font: 800 15px/1 Aptos, "Segoe UI", sans-serif;
  cursor: pointer;
}

.kp-title-toggle--on {
  color: #00851f;
  background: #dcffe5;
  border-color: #00851f;
}

.kp-title-toggle--off {
  color: #d00000;
  background: #ffe1e1;
  border-color: #d00000;
}

.kp-row-id-input,
.kp-row-pause-input {
  width: 100%;
  min-width: 0;
  border: 1px solid #afc2df;
  border-radius: 6px;
  padding: 6px 8px;
  font: inherit;
}

.kp-row-id-input {
  min-height: 5.4em;
  resize: vertical;
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.25;
}

.kp-row-pause-input {
  padding-inline: 4px;
  font-size: 0.82rem;
}

.kp-row-sentence {
  margin-top: 6px;
  color: #4a678f;
  font-size: 0.8rem;
  line-height: 1.35;
}

.kp-row-sentence--error {
  color: #8e1d1d;
  font-weight: 600;
}

.kp-row-sentence-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.kp-drop {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: stretch;
  min-height: 76px;
  border: 1px dashed #8aa5cc;
  border-radius: 8px;
  background: #f8fbff;
  padding: 7px;
}

.kp-drop--lockable {
  padding-right: 34px;
  padding-bottom: 30px;
}

.kp-drop--locked {
  border-color: #d66a61;
  background: #fff7f6;
}

.kp-drop.kp-drop--active {
  border-color: #2e5b9d;
  background: #edf4ff;
}

.kp-drop__meta {
  font-size: 0.78rem;
  color: #304968;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.kp-drop__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.kp-drop__btn {
  border: 1px solid #96aed1;
  border-radius: 6px;
  background: #ffffff;
  color: #1f3555;
  font: inherit;
  font-size: 0.78rem;
  padding: 4px 8px;
  cursor: pointer;
}

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

.kp-drop__stamp {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1px;
  margin-top: 2px;
  color: #5e7698;
  line-height: 1.15;
}

.kp-drop__stamp-date {
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.kp-drop__stamp-date-row {
  display: flex;
  align-items: flex-start;
  gap: 6px;
}

.kp-drop__stamp-controls {
  display: grid;
  gap: 3px;
}

.kp-drop__stamp-renew,
.kp-drop__stamp-view {
  border: 1px solid #96aed1;
  border-radius: 5px;
  background: #ffffff;
  color: #1f3555;
  font: inherit;
  font-size: 0.65rem;
  line-height: 1.1;
  padding: 2px 6px;
  cursor: pointer;
}

.kp-drop__stamp-view:disabled {
  cursor: not-allowed;
  opacity: 0.48;
}

.kp-drop__stamp-renew:disabled {
  cursor: not-allowed;
  opacity: 0.48;
}

.kp-drop__stamp-time {
  font-size: 0.66rem;
  font-variant-numeric: tabular-nums;
}

.kp-drop__lock {
  position: absolute;
  right: 7px;
  bottom: 7px;
  width: 22px;
  height: 22px;
  border: 1px solid #96aed1;
  border-radius: 6px;
  background: #ffffff;
  color: #45607f;
  cursor: pointer;
}

.kp-drop__lock:hover,
.kp-drop__lock:focus-visible {
  border-color: #5f7fb0;
  background: #edf4ff;
}

.kp-drop__lock--locked {
  border-color: #b42318;
  background: #fff0ed;
  color: #b42318;
}

.kp-lock-icon {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 11px;
  height: 9px;
  transform: translate(-50%, -32%);
  border: 2px solid currentColor;
  border-radius: 2px;
  box-sizing: border-box;
}

.kp-lock-icon::before {
  content: "";
  position: absolute;
  left: 2px;
  top: -10px;
  width: 8px;
  height: 9px;
  border: 2px solid currentColor;
  border-bottom: 0;
  border-radius: 8px 8px 0 0;
  box-sizing: border-box;
  transform: translate(4px, 1px) rotate(28deg);
  transform-origin: left bottom;
}

.kp-drop__lock--locked .kp-lock-icon::before {
  transform: translate(0, 0) rotate(0deg);
}

.kp-row-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(80px, 1fr));
  gap: 6px;
}

.kp-row-btn {
  border: 1px solid #96aed1;
  border-radius: 6px;
  background: #ffffff;
  color: #1f3555;
  font: inherit;
  font-size: 0.78rem;
  padding: 4px 8px;
  cursor: pointer;
}

.kp-row-btn:hover,
.kp-row-btn:focus-visible,
.kp-drop__btn:hover,
.kp-drop__btn:focus-visible,
.kp-th-renew:hover,
.kp-th-renew:focus-visible,
.kp-drop__stamp-renew:hover,
.kp-drop__stamp-renew:focus-visible,
.kp-drop__stamp-view:hover,
.kp-drop__stamp-view:focus-visible {
  border-color: #5f7fb0;
  background: #edf4ff;
}

.kp-drop__stamp-renew--busy {
  border-color: #b42318 !important;
  background: #b42318 !important;
  color: #ffffff !important;
}

.kp-modal {
  position: fixed;
  inset: 0;
  z-index: 60;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
}

.kp-modal[hidden] {
  display: none;
}

.kp-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(23, 33, 47, 0.55);
}

.kp-modal__panel {
  position: relative;
  width: min(1200px, calc(100vw - 32px));
  max-height: calc(100vh - 36px);
  overflow: auto;
  background: #ffffff;
  border: 1px solid #c8d9f2;
  border-radius: 12px;
  padding: 14px;
  box-shadow: 0 24px 64px rgba(15, 30, 60, 0.32);
}

.kp-modal__panel--wide {
  width: min(1500px, calc(100vw - 32px));
}

.kp-modal__panel h2 {
  margin: 0;
  font-size: 1.08rem;
}

.kp-paragraph-preview__viewport {
  margin-top: 10px;
  height: min(72vh, 760px);
  overflow: auto;
  border: 1px solid #d8e2f0;
  border-radius: 10px;
  background: #f7faff;
  padding: 14px;
}

.kp-paragraph-preview__image {
  display: block;
  max-width: none;
  background: #ffffff;
  border: 1px solid #e3eaf5;
  box-shadow: 0 8px 28px rgba(28, 48, 78, 0.12);
}

.kp-asset-preview__body {
  margin-top: 10px;
}

.kp-asset-preview__stage {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: min(68vh, 720px);
  overflow: auto;
  border: 1px solid #d8e2f0;
  border-radius: 10px;
  background: #ffffff;
  padding: 18px;
}

.kp-asset-preview__image {
  display: block;
  max-width: 100%;
  max-height: min(66vh, 700px);
  object-fit: contain;
  background: #ffffff;
  border: 1px solid #e3eaf5;
  box-shadow: 0 8px 28px rgba(28, 48, 78, 0.12);
}

.kp-asset-preview__code {
  max-height: min(70vh, 760px);
  overflow: auto;
  margin: 0;
  border: 1px solid #d8e2f0;
  border-radius: 10px;
  background: #0f172a;
  color: #e5edf8;
  padding: 14px;
  font: 0.82rem/1.45 "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  white-space: pre;
}

.kp-modal__table-wrap {
  margin-top: 10px;
  overflow: auto;
  border: 1px solid #d8e2f0;
  border-radius: 8px;
}

.kp-modal-tools {
  margin-top: 8px;
}

.kp-modal-tools__toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #243a5a;
  font-size: 0.88rem;
  user-select: none;
}

.kp-modal-tools__toggle input {
  accent-color: #315ea5;
}

.kp-modal-table {
  width: 100%;
  min-width: 1380px;
  border-collapse: collapse;
}

.kp-modal-table th,
.kp-modal-table td {
  border: 1px solid #d4dfef;
  padding: 8px;
  vertical-align: top;
  background: #ffffff;
  font-size: 0.85rem;
}

.kp-modal-table th {
  background: #ebf2ff;
  text-align: left;
}

.kp-modal-select {
  width: 100%;
  border: 1px solid #afc2df;
  border-radius: 6px;
  background: #ffffff;
  color: #17212f;
  font: inherit;
  font-size: 0.83rem;
  padding: 6px 8px;
}

.kp-timing-adjust__toolbar {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 96px auto;
  gap: 12px;
  align-items: center;
  margin-top: 10px;
}

.kp-timing-adjust__toolbar audio {
  width: 100%;
}

.kp-timing-adjust__zoom {
  display: flex;
  align-items: end;
  gap: 8px;
}

.kp-timing-adjust__zoom .kp-field {
  min-width: 180px;
}

.kp-timing-adjust__speed select {
  width: 100%;
}

.kp-timing-adjust__viewport {
  margin-top: 12px;
  height: min(46vh, 420px);
  overflow: auto;
  border: 1px solid #d8e2f0;
  border-radius: 10px;
  background: #f8fbff;
}

.kp-timing-adjust__canvas {
  display: block;
  min-width: 100%;
  height: 320px;
  background: #ffffff;
  cursor: crosshair;
  touch-action: none;
}

.kp-timing-adjust__prosody {
  display: flex;
  align-items: end;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
  padding: 8px 10px;
  border: 1px solid #d8e2f0;
  border-radius: 8px;
  background: #f8fbff;
}

.kp-timing-adjust__prosody[hidden] {
  display: none;
}

.kp-timing-adjust__prosody-field {
  min-width: 180px;
}

.kp-timing-adjust__prosody-word,
.kp-timing-adjust__prosody-summary {
  color: #405a7d;
  font-size: 0.84rem;
}

.kp-timing-adjust__prosody-word {
  font-weight: 700;
}

.kp-timing-adjust__status {
  margin: 8px 0 0;
  color: #48658c;
  font-size: 0.84rem;
}

.kp-timing-lesson-status {
  display: grid;
  gap: 6px;
  margin-top: 10px;
  padding: 10px 12px;
  border: 1px solid #d8e2f0;
  border-radius: 8px;
  background: #f8fbff;
  color: #24364d;
  font-size: 0.84rem;
}

.kp-timing-lesson-status[hidden] {
  display: none;
}

.kp-timing-lesson-status__line {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  align-items: baseline;
}

.kp-timing-lesson-status__label {
  color: #48658c;
  font-weight: 700;
}

.kp-timing-lesson-status__sentence {
  font-weight: 700;
}

.kp-timing-lesson-status__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.kp-timing-lesson-status__chip {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 2px 7px;
  border: 1px solid #c8d6ea;
  border-radius: 999px;
  background: #ffffff;
  color: #2a405c;
  white-space: nowrap;
}

.kp-exp-placement-modal-open {
  overflow: hidden;
}

.kp-exp-placement-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  background: #f5f7fb;
  color: #17212f;
}

.kp-exp-placement-modal[hidden] {
  display: none;
}

.kp-exp-placement-modal__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid #c8d9f2;
  background: #ffffff;
  padding: 12px 16px;
}

.kp-exp-placement-modal__copy h2 {
  margin: 0;
  font-size: 1.05rem;
}

.kp-exp-placement-modal__copy p {
  margin: 4px 0 0;
  color: #48658c;
  font-size: 0.86rem;
}

.kp-exp-placement-modal__actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: end;
}

.kp-exp-placement-modal__label-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  color: #334155;
  font-size: 0.78rem;
  font-weight: 800;
  white-space: nowrap;
}

.kp-exp-placement-modal__label-toggle input {
  width: 16px;
  height: 16px;
  accent-color: #0f766e;
}

.kp-exp-placement-modal__label-toggle select {
  min-height: 34px;
  border: 1px solid #b9c9e6;
  border-radius: 8px;
  background: #ffffff;
  color: #17212f;
  font: inherit;
  font-weight: 700;
  padding: 4px 8px;
}

.kp-exp-placement-modal__leg-nav {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  padding: 3px 6px;
  border: 1px solid #c8d9f2;
  border-radius: 999px;
  background: #f8fbff;
  color: #17212f;
  font-size: 0.78rem;
  font-weight: 900;
  white-space: nowrap;
}

.kp-exp-placement-modal__leg-nav[hidden] {
  display: none;
}

.kp-exp-placement-modal__leg-nav span {
  min-width: 54px;
  text-align: center;
}

.kp-exp-placement-modal__recalc-status {
  min-height: 1rem;
  color: #64748b;
  font-size: 0.78rem;
  font-weight: 800;
}

.kp-exp-placement-modal__recalc-status.is-success {
  color: #15803d;
}

.kp-exp-placement-modal__recalc-status.is-warning {
  color: #a16207;
}

.kp-exp-placement-modal__viewport {
  min-height: 0;
  overflow: auto;
  display: grid;
  place-items: center;
  padding: 16px;
  background: #eef3fb;
}

.kp-exp-placement-stage {
  position: relative;
  display: inline-block;
  max-width: calc(100vw - 32px);
  max-height: calc(100vh - 98px);
  background: #ffffff;
  box-shadow: 0 18px 54px rgba(18, 35, 66, 0.2);
}

.kp-exp-placement-stage img {
  display: block;
  max-width: calc(100vw - 32px);
  max-height: calc(100vh - 98px);
  width: auto;
  height: auto;
  object-fit: contain;
  user-select: none;
  -webkit-user-drag: none;
}

.kp-exp-placement-stage__dots {
  position: absolute;
  inset: 0;
  touch-action: none;
  z-index: 2;
}

.kp-exp-placement-modal--previewing.kp-exp-placement-modal--labels-hidden .kp-exp-placement-stage__dots {
  opacity: 0;
  pointer-events: none;
}

.kp-exp-placement-stage__preview {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}

.kp-exp-placement-dot {
  position: absolute;
  transform: translate(-50%, -50%);
  min-width: 20px;
  min-height: 20px;
  max-width: 150px;
  border: 2px solid #ffffff;
  border-radius: 999px;
  background: #dc2626;
  color: #ffffff;
  box-shadow: 0 2px 8px rgba(74, 10, 10, 0.45);
  cursor: grab;
  font: 700 11px/1.1 Aptos, "Segoe UI", sans-serif;
  padding: 4px 7px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  touch-action: none;
  z-index: 1;
}

.kp-exp-placement-dot:active {
  cursor: grabbing;
}

.kp-exp-placement-dot--dragging {
  cursor: grabbing;
  opacity: 0.5;
}

.kp-exp-placement-dot--unassigned {
  border-color: #dc2626;
  background: #ffffff;
  color: #b91c1c;
}

.kp-exp-placement-dot--manual {
  background: #991b1b;
}

.kp-exp-placement-dot--recalculated {
  box-shadow:
    0 0 0 5px rgba(250, 204, 21, 0.66),
    0 0 18px rgba(234, 179, 8, 0.58),
    0 2px 8px rgba(74, 10, 10, 0.45);
}

@media (max-width: 1100px) {
  .kp-source-grid {
    grid-template-columns: 1fr;
  }
  .kp-settings-grid {
    grid-template-columns: repeat(2, minmax(190px, 1fr));
  }
  .kp-master-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .karaoke-producer {
    padding: 14px 12px 28px;
  }
  .kp-settings-grid {
    grid-template-columns: 1fr;
  }
  .kp-timing-adjust__toolbar {
    grid-template-columns: 1fr;
  }
  .kp-timing-adjust__zoom {
    align-items: stretch;
    flex-wrap: wrap;
  }
}
