.published-app {
  max-width: 1280px;
  margin-inline: auto;
}

.published-layout {
  display: grid;
  grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.published-app .file-label {
  text-decoration: none;
}

.published-app .header-actions #openFullscreenBtn.fullscreen-cta {
  font-weight: 700;
  border-color: var(--primary-2);
  box-shadow: var(--shadow);
}

.published-catalog-controls {
  margin-top: 6px;
  margin-bottom: 12px;
}

.published-catalog-controls label {
  min-width: 72px;
}

.published-catalog-controls select {
  max-width: 320px;
}

.published-player-controls {
  margin-top: 4px;
}

.published-layout .card:first-child {
  position: sticky;
  top: 12px;
}

#catalogView {
  height: calc(100vh - 190px);
  max-height: calc(100vh - 190px);
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 4px;
}

.compact-view {
  min-height: 48vh;
  max-height: 62vh;
}

.remote-song-item {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: rgba(11, 18, 32, 0.55);
}

.remote-song-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.remote-cat-title {
  margin: 4px 0 0;
  font-size: 0.95rem;
  color: var(--text);
  border-left: 3px solid var(--primary);
  padding-left: 8px;
}

@media (max-width: 960px) {
  .published-app {
    max-width: 100%;
  }

  .published-layout {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .published-layout .card:first-child {
    position: static;
  }

  #catalogView {
    height: auto;
    max-height: none;
    overflow: visible;
    padding-right: 0;
  }

  .compact-view {
    min-height: 36vh;
    max-height: 50vh;
  }

  .published-player-controls button {
    flex: 1 1 calc(50% - 10px);
    min-height: 42px;
  }

}

@media (max-width: 640px) {
  .published-catalog-controls {
    align-items: stretch;
  }

  .published-catalog-controls label {
    min-width: 0;
  }

  .published-catalog-controls select {
    max-width: none;
  }

  .published-player-controls {
    gap: 8px;
  }

  .published-player-controls button {
    flex: 1 1 100%;
  }

  .published-player-controls #progress {
    width: fit-content;
  }
}
