/* Bookselecta base styles */
:root { color-scheme: light; }
html,body { font-family: "Literata", serif; }
body { margin:0; padding:20px; background:#fafafa; }
h1 { color:#0b57d0; margin:0 0 8px; }
.header { display:flex; align-items:center; gap:16px; margin-bottom:16px; }
.header img { width:64px; height:64px; border-radius:8px; }
#status { font:12px/1.4 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; color:#555; margin:6px 0 12px; }
#frame { height:480px; width:100%; max-width:960px; border:1px solid #ddd; border-radius:8px; background:#fff; overflow:auto; box-shadow:0 4px 10px rgba(0,0,0,.08); padding:12px; }
form#chat { display:flex; gap:8px; margin:12px 0 0; max-width:960px; }
form#chat input { flex:1; padding:10px 12px; font-size:16px; border:1px solid #ddd; border-radius:8px; }
form#chat button { padding:10px 16px; font-size:16px; border:0; border-radius:8px; background:#0b57d0; color:#fff; cursor:pointer; }
pre#out { white-space:pre-wrap; margin:0; font:14px/1.5 system-ui, -apple-system, Segoe UI, Roboto, sans-serif; }

.user-actions { margin-left: auto; }

.modal {
    position: fixed;
    z-index: 1;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgb(0,0,0);
    background-color: rgba(0,0,0,0.4);
}

.modal-content {
    background-color: #fefefe;
    margin: 15% auto;
    padding: 20px;
    border: 1px solid #888;
    width: 80%;
    max-width: 400px;
    border-radius: 10px;
}

.close-btn {
    color: #aaa;
    float: right;
    font-size: 28px;
    font-weight: bold;
}

.close-btn:hover,
.close-btn:focus {
    color: black;
    text-decoration: none;
    cursor: pointer;
}

#signup-form {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

#signup-form input {
    padding: 10px;
    border-radius: 5px;
    border: 1px solid #ccc;
}

.cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
}

.card {
    border: 1px solid #eee;
    border-radius: 10px;
    padding: 12px;
    margin: 10px 0;
    background: #fff;
}

.card h3 {
    margin: 0 0 6px;
    font-size: 18px;
}

.card p {
    margin: 0 0 8px;
    color: #444;
}

.card a {
    color: #0b57d0;
    text-decoration: none;
}

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

.btn {
    padding: 8px 12px;
    border: 0;
    border-radius: 8px;
    background: #0b57d0;
    color: #fff;
    cursor: pointer;
}

.note {
    font-size: 12px;
    color: #777;
}

.btn-primary {
  background-color: #0b57d0;
  color: #fff;
}

.btn-secondary {
  background-color: #e0e0e0;
  color: #000;
}

#your-list {
  margin-top: 24px;
}

#btn-publish-list:disabled {
  background-color: #e0e0e0;
  color: #9e9e9e;
  cursor: not-allowed;
}

/* Modern UI Refresh */
:root {
  --bg-color-light: #f7f7f7;
  --text-color-light: #333;
  --card-bg-light: #fff;
  --border-color-light: #e0e0e0;
  --primary-color: #0b57d0;
  --primary-hover: #0a4cb5;
  --secondary-color: #e0e0e0;
  --secondary-hover: #d5d5d5;

  --bg-color-dark: #202123;
  --text-color-dark: #ececec;
  --card-bg-dark: #343541;
  --border-color-dark: #444654;
}

.theme-light {
  background-color: var(--bg-color-light);
  color: var(--text-color-light);
}

.theme-dark {
  background-color: var(--bg-color-dark);
  color: var(--text-color-dark);
}

@media (prefers-color-scheme: dark) {
  .theme-light {
    background-color: var(--bg-color-dark);
    color: var(--text-color-dark);
  }
  .theme-light .card {
    background-color: var(--card-bg-dark);
    border-color: var(--border-color-dark);
  }
  .theme-light .btn-secondary {
    background-color: var(--border-color-dark);
    color: var(--text-color-dark);
  }
}

.container {
  max-width: 800px;
  margin: 0 auto;
  padding: 20px;
}

.card {
  border: 1px solid var(--border-color-light);
  border-radius: 12px;
  padding: 16px;
  margin: 10px 0;
  background: var(--card-bg-light);
  box-shadow: 0 4px 6px rgba(0,0,0,0.05);
  transition: box-shadow 0.2s ease-in-out, transform 0.2s ease-in-out;
}

.card:hover {
  box-shadow: 0 8px 12px rgba(0,0,0,0.1);
  transform: translateY(-2px);
}

.btn {
  padding: 10px 16px;
  border: 0;
  border-radius: 8px;
  cursor: pointer;
  transition: background-color 0.2s ease-in-out;
}

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

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

.btn-secondary {
  background-color: var(--secondary-color);
  color: #333;
}

.btn-secondary:hover {
  background-color: var(--secondary-hover);
}

.cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
}

#composer {
    display: flex;
    gap: 10px;
    margin-top: 20px;
}

#q {
    flex: 1;
    padding: 12px;
    border-radius: 8px;
    border: 1px solid var(--border-color-light);
    font-size: 16px;
}

#go {
    padding: 12px 20px;
    border-radius: 8px;
    border: 0;
    background-color: var(--primary-color);
    color: #fff;
    font-size: 16px;
    cursor: pointer;
}

#go:hover {
    background-color: var(--primary-hover);
}

.row {
    margin-bottom: 10px;
}

.msg {
    padding: 12px;
    border-radius: 12px;
    max-width: 80%;
}

.row.a .msg {
    background-color: #f0f0f0;
}

.row.u .msg {
    background-color: var(--primary-color);
    color: #fff;
    margin-left: auto;
}

.tile {
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 12px;
    align-items: start;
}

.tile-thumb {
    width: 72px;
    height: 72px;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid var(--border-color-light);
    background: var(--card-bg-light);
    box-shadow: 0 6px 16px rgba(0,0,0,.08);
}

@media (max-width: 480px) {
    .tile {
        grid-template-columns: 56px 1fr;
    }
    .tile-thumb {
        width: 56px;
        height: 56px;
    }
}

.row.a.json-response {
  display: none;
}

.genres {
  display: flex;
  gap: 6px;
  margin-top: 8px;
}

.genre {
  background-color: #eee;
  color: #333;
  padding: 4px 8px;
  border-radius: 12px;
  font-size: 12px;
}
