.reader-page {
  width: min(960px, calc(100vw - 40px));
  backdrop-filter: blur(2px);
}

.reader-app {
  min-height: 60vh;
}

.reader-overlay,
.reader-view {
  border: 2px solid white;
  border-radius: 15px;
  padding: 16px;
  margin-bottom: 12px;
  background-color: rgba(0, 0, 0, 0.92);
}

#epub-file-input {
  margin: 6px 0 10px;
  width: 100%;
}

.book-list,
.bookmark-list {
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
}

.book-item {
  display: grid;
  grid-template-columns: auto auto 1fr;
  gap: 8px;
  align-items: center;
  padding: 8px;
  border-bottom: 1px solid #555;
}

.book-title {
  font-weight: bold;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.book-meta {
  grid-column: 3;
  font-size: 0.9rem;
  color: #b5b5b5;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.reader-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 12px;
}

.reading-progress {
  margin-left: auto;
}

.bookmarks-panel {
  border: 1px solid #666;
  border-radius: 10px;
  padding: 8px;
  margin-bottom: 10px;
}

.reader-container {
  min-height: 55vh;
  border: 1px solid #666;
  border-radius: 10px;
  padding: 10px;
  background: #050505;
}

.reader-placeholder,
.reader-error,
.empty {
  color: #d4d4d4;
}

@media (max-width: 700px) {
  .book-item {
    grid-template-columns: 1fr 1fr;
  }

  .book-title,
  .book-meta {
    grid-column: 1 / -1;
  }

  .reading-progress {
    margin-left: 0;
  }
}
