/* ============================================================================
   Add Sources Overlay — shared component
   Used by both /studio and the AI Assistant on /. Markup is injected by
   /js/add-sources-overlay.js; this file only carries the styles.

   Depends on the page-level CSS variables already in place
   (styles.gopdf-rebrand.css supplies them on every page that uses Studio's
   visual language): --bg2, --surface, --text, --text2/3/4, --border,
   --border-strong, --gold, --gold-dim, --teal, --teal-dim, --btn-bg,
   --btn-text. No new tokens.
   ============================================================================ */

/* ── Backdrop + modal shell ─────────────────────────────────────────────── */
.overlay-backdrop {
  position: fixed; inset: 0; z-index: 500;
  background: rgba(26, 24, 20, 0.35);
  backdrop-filter: blur(2px);
  display: flex; align-items: center; justify-content: center;
  animation: aso-fade-in 0.2s ease;
}
:root[data-bs-theme="dark"] .overlay-backdrop { background: rgba(0, 0, 0, 0.5); }
@keyframes aso-fade-in { from { opacity: 0; } }

.overlay-wrap { position: relative; }
.overlay-modal {
  width: 600px; max-width: 92vw; border-radius: 20px;
  background: color-mix(in srgb, var(--surface) 97%, transparent);
  border: 1px solid var(--border-strong);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.28), 0 0 0 1px rgba(255, 255, 255, 0.06);
  overflow: hidden;
  animation: aso-slide-up 0.25s ease;
}
:root[data-bs-theme="dark"] .overlay-modal {
  background: color-mix(in srgb, var(--surface) 98%, transparent);
}
@keyframes aso-slide-up { from { opacity: 0; transform: translateY(14px); } }

.overlay-body { padding: 28px 28px 24px; }
.overlay-close {
  position: absolute; top: 20px; right: 20px;
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid var(--border); background: var(--bg2);
  color: var(--text3); font-size: 16px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.15s;
}
.overlay-close:hover { border-color: var(--gold); color: var(--gold); }

.overlay-title {
  font-family: 'Playfair Display', serif;
  font-size: 22px; color: var(--text);
  text-align: center; margin-bottom: 4px;
}
.overlay-title em { color: var(--gold); font-style: italic; }
.overlay-sub {
  font-size: 12.5px; color: var(--text3);
  text-align: center; margin-bottom: 22px;
}

.overlay-panel { display: none; }
.overlay-panel.on { display: block; }

/* ── GoSearch sub-bar ───────────────────────────────────────────────────── */
.overlay-gosearch-wrap { margin-bottom: 18px; }
.overlay-gosearch-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 16px;
  border: 1.5px solid var(--border-strong);
  border-radius: 12px;
  background: var(--bg2);
  transition: border-color 0.15s;
}
.overlay-gosearch-bar:focus-within { border-color: var(--gold); }
.overlay-gosearch-bar input {
  flex: 1; border: none; outline: none; background: transparent;
  font-size: 13px; color: var(--text); font-family: inherit;
}
.overlay-gosearch-bar input::placeholder { color: var(--text4); }
.overlay-gosearch-btn {
  padding: 6px 14px; border-radius: 8px;
  background: var(--btn-bg); border: none; color: var(--btn-text);
  font-size: 12px; font-weight: 600; font-family: inherit;
  cursor: pointer; white-space: nowrap;
  transition: opacity 0.15s; flex-shrink: 0;
}
.overlay-gosearch-btn:hover { opacity: 0.85; }
.overlay-gosearch-results {
  margin-top: 8px; display: flex; flex-direction: column; gap: 5px;
  max-height: 190px; overflow-y: auto;
}
.overlay-gosearch-results::-webkit-scrollbar { width: 3px; }
.overlay-gosearch-results::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 2px; }
.overlay-gsresult {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 9px;
  border: 1px solid var(--border); background: var(--surface);
  transition: all 0.15s;
}
.overlay-gsresult:hover { border-color: var(--gold); background: var(--gold-dim); }
.overlay-gsresult-info { flex: 1; min-width: 0; }
.overlay-gsresult-title {
  font-size: 12px; font-weight: 500; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.overlay-gsresult-url {
  font-size: 10px; color: var(--text4);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.overlay-gsresult-add {
  padding: 3px 9px; border-radius: 6px;
  border: 1px solid var(--gold); background: var(--gold-dim);
  color: var(--gold); font-size: 10.5px; font-weight: 600;
  font-family: inherit; cursor: pointer; flex-shrink: 0; white-space: nowrap;
}

/* ── Drop zone ──────────────────────────────────────────────────────────── */
.overlay-drop {
  border: 1.5px dashed var(--border-strong);
  border-radius: 14px;
  padding: 28px 20px; text-align: center;
  cursor: pointer; transition: all 0.2s;
  background: var(--bg2);
}
.overlay-drop:hover, .overlay-drop.drag-over {
  border-color: var(--gold); background: var(--gold-dim);
}
.overlay-drop-icon { font-size: 26px; margin-bottom: 8px; }
.overlay-drop-title { font-size: 13.5px; color: var(--text); font-weight: 500; margin-bottom: 3px; }
.overlay-drop-sub { font-size: 11.5px; color: var(--text4); margin-bottom: 16px; }
.overlay-btns { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.overlay-action {
  padding: 8px 16px; border-radius: 9px;
  border: 1px solid var(--border); background: var(--surface);
  font-size: 12px; color: var(--text2); cursor: pointer;
  display: flex; align-items: center; gap: 6px;
  transition: all 0.15s; font-family: inherit;
}
.overlay-action:hover { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }
.overlay-action:disabled { opacity: 0.5; cursor: not-allowed; }

/* ── Three source-action buttons row ────────────────────────────────────── */
.overlay-src-actions {
  display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap;
}
.overlay-src-btn {
  flex: 1; min-width: 100px; padding: 12px 10px; border-radius: 12px;
  border: 1.5px solid var(--border-strong); background: var(--surface);
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  cursor: pointer; transition: all 0.18s; font-family: inherit;
}
.overlay-src-btn:hover {
  border-color: var(--gold); background: var(--gold-dim);
  transform: translateY(-1px);
}
.overlay-src-btn-icon {
  width: 34px; height: 34px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
}
.overlay-src-btn-label { font-size: 11.5px; font-weight: 600; color: var(--text2); }
.overlay-src-btn-sub   { font-size: 10px; color: var(--text4); text-align: center; line-height: 1.3; }

/* ── Counter ────────────────────────────────────────────────────────────── */
.overlay-counter {
  display: flex; align-items: center; gap: 10px;
  margin-top: 18px; padding-top: 16px;
  border-top: 1px solid var(--border);
}
.overlay-bar-wrap {
  flex: 1; height: 4px; background: var(--border-strong);
  border-radius: 2px; overflow: hidden;
}
.overlay-bar-fill { height: 100%; background: var(--gold); border-radius: 2px; width: 0%; transition: width 0.2s; }
.overlay-count-label { font-size: 11px; color: var(--text4); white-space: nowrap; }

/* ── Library panel ──────────────────────────────────────────────────────── */
.lib-empty { text-align: center; padding: 40px 20px; color: var(--text4); font-size: 12.5px; }
.lib-empty-icon { font-size: 32px; margin-bottom: 8px; }
.lib-grid { display: flex; flex-direction: column; gap: 6px; max-height: 320px; overflow-y: auto; margin-top: 4px; }
.lib-grid::-webkit-scrollbar { width: 3px; }
.lib-grid::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 2px; }
.lib-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 9px;
  border: 1.5px solid var(--border); background: var(--surface);
  cursor: pointer; transition: all 0.15s;
}
.lib-item:hover { border-color: var(--gold); background: var(--gold-dim); }
.lib-item.selected { border-color: var(--teal); background: var(--teal-dim); }
.lib-item-icon { font-size: 18px; flex-shrink: 0; }
.lib-item-name {
  flex: 1; font-size: 12px; color: var(--text); min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.lib-item-size { font-size: 10px; color: var(--text4); flex-shrink: 0; }
.lib-item-check {
  width: 16px; height: 16px; border-radius: 50%;
  border: 1.5px solid var(--border-strong); background: transparent;
  flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  transition: all 0.15s;
}
.lib-item.selected .lib-item-check { background: var(--teal); border-color: var(--teal); }
.lib-add-btn {
  width: 100%; margin-top: 12px; padding: 9px;
  border-radius: 9px; border: none;
  background: var(--btn-bg); color: var(--btn-text);
  font-size: 12.5px; font-weight: 600;
  font-family: inherit; cursor: pointer;
  transition: opacity 0.15s;
}
.lib-add-btn:hover    { opacity: 0.88; }
.lib-add-btn:disabled { opacity: 0.4; cursor: default; }
.lib-back-btn {
  display: flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 7px;
  border: 1px solid var(--border); background: transparent;
  color: var(--text3); font-size: 11.5px;
  cursor: pointer; margin-bottom: 12px; font-family: inherit;
}

/* ── Copied Text + Websites modals ──────────────────────────────────────── */
.aso-text-modal {
  position: fixed; inset: 0; z-index: 600;
  background: rgba(0, 0, 0, 0.45); backdrop-filter: blur(3px);
  display: flex; align-items: center; justify-content: center;
  animation: aso-fade-in 0.18s ease;
}
.aso-text-box {
  width: 480px; max-width: 90vw; border-radius: 16px;
  padding: 24px;
  background: var(--surface); border: 1px solid var(--border-strong);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  animation: aso-slide-up 0.2s ease;
}
.aso-text-box textarea {
  width: 100%; height: 180px; padding: 12px 14px;
  border-radius: 10px;
  border: 1.5px solid var(--border-strong);
  background: var(--bg2); color: var(--text);
  font-size: 13px; font-family: inherit;
  outline: none; resize: vertical; line-height: 1.6;
  transition: border-color 0.15s; box-sizing: border-box;
}
.aso-text-box textarea:focus { border-color: var(--gold); }
.aso-text-box textarea::placeholder { color: var(--text4); }
.aso-text-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
}
.aso-text-modal-title {
  font-family: 'Playfair Display', serif;
  font-size: 17px; color: var(--text);
}
.aso-text-modal-title em { font-style: italic; }
.aso-text-modal-close {
  width: 28px; height: 28px; border-radius: 50%;
  border: 1px solid var(--border); background: var(--bg2);
  color: var(--text3); cursor: pointer;
  font-size: 15px;
  display: flex; align-items: center; justify-content: center;
}
.aso-text-modal-actions {
  display: flex; gap: 8px; justify-content: flex-end;
}
.aso-btn-secondary {
  padding: 8px 16px; border-radius: 8px;
  border: 1px solid var(--border-strong); background: transparent;
  color: var(--text3); font-size: 12.5px; font-family: inherit; cursor: pointer;
}
.aso-btn-primary {
  padding: 8px 18px; border-radius: 8px;
  background: var(--btn-bg); border: none; color: var(--btn-text);
  font-size: 12.5px; font-weight: 600; font-family: inherit; cursor: pointer;
}
.aso-text-meta { font-size: 10.5px; color: var(--text4); margin: 6px 0 14px; }
.aso-text-hint { font-size: 12px; color: var(--text3); margin-bottom: 10px; }
