/* Pastor Hub — clean blue/gray, pro pastor feel. Nunito font. No emojis. */

.pastor-hub-page {
  --pastor-blue: #3b82f6;
  --pastor-blue-dim: rgba(59, 130, 246, 0.15);
  --pastor-gray: #64748b;
  --pastor-gray-light: #94a3b8;
  --pastor-bg: #0f172a;
  --pastor-card: rgba(15, 23, 42, 0.95);
}

.pastor-hub-page .app-shell {
  grid-template-columns: 1fr;
  grid-template-areas:
    "topbar"
    "content"
    "footer";
}

.pastor-hub-header {
  border-bottom: 1px solid var(--pastor-blue-dim);
}

.pastor-hub-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 1rem;
  font-family: 'Nunito', sans-serif;
  font-weight: 600;
  font-size: 0.9rem;
}

.pastor-hub-nav a {
  color: var(--pastor-gray-light);
  text-decoration: none;
  padding: 0.4rem 0.75rem;
  border-radius: 8px;
  transition: background 0.2s, color 0.2s;
}

.pastor-hub-nav a:hover {
  background: var(--pastor-blue-dim);
  color: var(--pastor-blue);
}

.pastor-hub-nav a[aria-current="page"] {
  background: var(--pastor-blue-dim);
  color: var(--pastor-blue);
}

@media (max-width: 768px) {
  .pastor-hub-nav { display: none; }
}

.pastor-hub-subtitle {
  color: var(--pastor-gray-light) !important;
}

/* Daily section */
.pastor-daily-hero {
  text-align: center;
  margin-bottom: 1.5rem;
}

.pastor-daily-hero h1 {
  font-family: 'Nunito', sans-serif;
  font-size: 1.5rem;
  color: var(--text-dark);
  margin-bottom: 0.25rem;
}

.pastor-daily-hero .pastor-daily-ref {
  color: var(--pastor-blue);
  font-weight: 700;
}

.pastor-dub-card {
  background-color: var(--tdb-surface-panel-bg, var(--pastor-card));
  background-image: var(--tdb-surface-veil-subtle, none);
  border: 1px solid color-mix(in srgb, var(--tdb-surface-panel-border, var(--pastor-blue-dim)) 72%, var(--pastor-blue-dim));
  border-radius: var(--tdb-surface-radius, 12px);
  box-shadow: var(--tdb-surface-panel-shadow, none);
  padding: 1.25rem;
  margin-bottom: 1rem;
}

.pastor-dub-card strong {
  display: block;
  color: var(--pastor-blue);
  margin-bottom: 0.5rem;
  font-family: 'Nunito', sans-serif;
}

.pastor-dub-card p {
  color: var(--text-dark);
  line-height: 1.6;
  margin: 0;
}

.pastor-reflection-wrap {
  margin-top: 1rem;
}

.pastor-reflection-wrap label {
  display: block;
  font-family: 'Nunito', sans-serif;
  font-weight: 600;
  color: var(--pastor-gray-light);
  margin-bottom: 0.35rem;
  font-size: 0.9rem;
}

.pastor-reflection-input {
  width: 100%;
  min-height: 80px;
  padding: 0.75rem;
  border: 1px solid var(--pastor-blue-dim);
  border-radius: 8px;
  background-color: color-mix(in srgb, var(--tdb-surface-panel-bg, rgba(15, 23, 42, 0.9)) 92%, #0f172a);
  color: var(--text-dark);
  font-family: inherit;
  font-size: 0.95rem;
  resize: vertical;
}

.pastor-reflection-input:focus {
  outline: none;
  border-color: var(--pastor-blue);
}

.pastor-reflection-saved {
  font-size: 0.8rem;
  color: var(--pastor-blue);
  margin-top: 0.35rem;
}

.pastor-reflection-saved.hidden { display: none; }

/* Library grid */
.pastor-library-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
}

.pastor-library-card {
  background-color: var(--tdb-surface-card-bg, var(--pastor-card));
  background-image: var(--tdb-surface-veil-subtle, none);
  border: 1px solid color-mix(in srgb, var(--tdb-surface-card-border, var(--pastor-blue-dim)) 70%, var(--pastor-blue-dim));
  border-radius: var(--tdb-surface-radius, 10px);
  box-shadow: var(--tdb-surface-card-shadow, none);
  padding: 1rem;
  cursor: pointer;
  transition: border-color 0.2s, transform 0.15s, box-shadow 0.2s;
}

.pastor-library-card:hover {
  border-color: var(--pastor-blue);
  transform: translateY(-2px);
  box-shadow: var(--tdb-surface-card-shadow-hover, none);
}

.pastor-library-card h3 {
  font-family: 'Nunito', sans-serif;
  font-size: 1rem;
  color: var(--text-dark);
  margin: 0 0 0.35rem 0;
  line-height: 1.3;
}

.pastor-library-card .pastor-card-verse {
  font-size: 0.8rem;
  color: var(--pastor-blue);
  margin-bottom: 0.75rem;
}

.pastor-library-card .pastor-use-btn {
  display: block;
  width: 100%;
  padding: 0.5rem;
  font-family: 'Nunito', sans-serif;
  font-weight: 600;
  font-size: 0.85rem;
  background: var(--pastor-blue);
  color: #fff;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.2s, opacity 0.2s;
}

.pastor-library-card .pastor-use-btn:hover {
  background: #2563eb;
}

.pastor-library-card .pastor-use-btn:active {
  opacity: 0.9;
}

/* Weekly tease carousel */
.pastor-weekly-tease {
  background-color: var(--tdb-surface-panel-bg, var(--pastor-card));
  background-image: var(--tdb-surface-veil-subtle, none);
  border: 1px solid color-mix(in srgb, var(--tdb-surface-panel-border, var(--pastor-blue-dim)) 75%, var(--pastor-blue-dim));
  border-radius: var(--tdb-surface-radius, 10px);
  box-shadow: var(--tdb-surface-panel-shadow, none);
  padding: 1rem;
  margin-bottom: 1.5rem;
  text-align: center;
}

.pastor-weekly-tease h3 {
  font-family: 'Nunito', sans-serif;
  font-size: 1rem;
  color: var(--pastor-gray-light);
  margin: 0 0 0.5rem 0;
}

.pastor-weekly-tease p {
  font-size: 0.9rem;
  color: var(--text-dark);
  margin: 0;
}

/* Builder */
.pastor-builder-section {
  margin-bottom: 1rem;
}

.pastor-builder-section label {
  display: block;
  font-family: 'Nunito', sans-serif;
  font-weight: 600;
  color: var(--pastor-gray-light);
  margin-bottom: 0.35rem;
  font-size: 0.9rem;
}

.pastor-builder-section input,
.pastor-builder-section textarea {
  width: 100%;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--pastor-blue-dim);
  border-radius: 8px;
  background-color: color-mix(in srgb, var(--tdb-surface-panel-bg, rgba(15, 23, 42, 0.9)) 92%, #0f172a);
  color: var(--text-dark);
  font-family: inherit;
  font-size: 0.95rem;
}

.pastor-builder-section textarea {
  min-height: 80px;
  resize: vertical;
}

.pastor-builder-section input:focus,
.pastor-builder-section textarea:focus {
  outline: none;
  border-color: var(--pastor-blue);
}

.pastor-builder-sections {
  margin-top: 1rem;
}

.pastor-builder-block {
  background-color: var(--tdb-surface-panel-bg, var(--pastor-card));
  background-image: var(--tdb-surface-veil-subtle, none);
  border: 1px solid color-mix(in srgb, var(--tdb-surface-panel-border, var(--pastor-blue-dim)) 75%, var(--pastor-blue-dim));
  border-radius: var(--tdb-surface-radius, 8px);
  box-shadow: var(--tdb-surface-panel-shadow, none);
  padding: 1rem;
  margin-bottom: 0.75rem;
  cursor: grab;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.pastor-builder-block:active {
  cursor: grabbing;
}

.pastor-builder-block .pastor-drag-handle {
  color: var(--pastor-gray);
  font-size: 1.2rem;
  cursor: grab;
  flex-shrink: 0;
}

.pastor-builder-block .pastor-block-content {
  flex: 1;
}

.pastor-builder-block .pastor-block-type {
  font-size: 0.75rem;
  color: var(--pastor-blue);
  text-transform: uppercase;
  margin-bottom: 0.25rem;
}

.pastor-builder-block.pastor-dragging {
  opacity: 0.6;
}

.pastor-builder-block.pastor-drag-over {
  border-color: var(--pastor-blue);
  background: var(--pastor-blue-dim);
}

.pastor-builder-block .pastor-block-text {
  width: 100%;
  min-height: 60px;
  padding: 0.5rem;
  border: 1px solid var(--pastor-blue-dim);
  border-radius: 6px;
  background-color: color-mix(in srgb, var(--tdb-surface-panel-bg, rgba(15, 23, 42, 0.75)) 88%, #0f172a);
  color: var(--text-dark);
  font-family: inherit;
  font-size: 0.9rem;
  resize: vertical;
}

.pastor-builder-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}

.pastor-builder-actions button {
  padding: 0.5rem 1rem;
  font-family: 'Nunito', sans-serif;
  font-weight: 600;
  font-size: 0.9rem;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.2s, opacity 0.2s;
}

.pastor-btn-primary {
  background: var(--pastor-blue);
  color: #fff;
  border: none;
}

.pastor-btn-primary:hover {
  background: #2563eb;
}

.pastor-btn-secondary {
  background: transparent;
  color: var(--pastor-gray-light);
  border: 1px solid var(--pastor-blue-dim);
}

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

/* Tools */
.pastor-tools-search {
  margin-bottom: 1rem;
}

.pastor-tools-search input {
  width: 100%;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--pastor-blue-dim);
  border-radius: 8px;
  background-color: color-mix(in srgb, var(--tdb-surface-panel-bg, rgba(15, 23, 42, 0.9)) 92%, #0f172a);
  color: var(--text-dark);
  font-size: 0.95rem;
}

.pastor-tools-search input:focus {
  outline: none;
  border-color: var(--pastor-blue);
}

.pastor-verse-result {
  background-color: var(--tdb-surface-panel-bg, var(--pastor-card));
  background-image: var(--tdb-surface-veil-subtle, none);
  border: 1px solid color-mix(in srgb, var(--tdb-surface-panel-border, var(--pastor-blue-dim)) 72%, var(--pastor-blue-dim));
  border-radius: var(--tdb-surface-radius, 8px);
  box-shadow: var(--tdb-surface-panel-shadow, none);
  padding: 0.75rem 1rem;
  margin-bottom: 0.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
}

.pastor-verse-result strong {
  color: var(--pastor-blue);
  font-size: 0.9rem;
}

.pastor-verse-result p {
  margin: 0.25rem 0 0 0;
  font-size: 0.9rem;
  color: var(--text-dark);
  line-height: 1.4;
}

.pastor-insert-btn {
  padding: 0.35rem 0.6rem;
  font-size: 0.8rem;
  background: var(--pastor-blue);
  color: #fff;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  flex-shrink: 0;
}

.pastor-insert-btn:hover {
  background: #2563eb;
}

.pastor-refs-list {
  margin-top: 1rem;
}

.pastor-ref-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.pastor-ref-item input {
  flex: 1;
  padding: 0.4rem 0.6rem;
  font-size: 0.9rem;
  border: 1px solid var(--pastor-blue-dim);
  border-radius: 6px;
  background-color: color-mix(in srgb, var(--tdb-surface-panel-bg, rgba(15, 23, 42, 0.9)) 92%, #0f172a);
  color: var(--text-dark);
}

.pastor-ai-suggest {
  margin-top: 1rem;
  padding: 0.75rem;
  background: var(--pastor-blue-dim);
  border: 1px dashed var(--pastor-blue);
  border-radius: 8px;
}

.pastor-ai-suggest button {
  padding: 0.4rem 0.75rem;
  font-size: 0.85rem;
  background: transparent;
  color: var(--pastor-blue);
  border: 1px solid var(--pastor-blue);
  border-radius: 6px;
  cursor: pointer;
}

.pastor-ai-suggest button:hover {
  background: var(--pastor-blue-dim);
}

/* Bottom nav */
.pastor-bottom-nav {
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 0.6rem 0;
  background: var(--pastor-bg);
  border-top: 1px solid var(--pastor-blue-dim);
  position: sticky;
  bottom: 0;
  z-index: 100;
}

.pastor-bottom-nav a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--pastor-gray);
  text-decoration: none;
  font-family: 'Nunito', sans-serif;
  font-size: 0.8rem;
  font-weight: 600;
  padding: 0.35rem 0.6rem;
  border-radius: 6px;
  transition: color 0.2s, background 0.2s;
}

.pastor-bottom-nav a:hover {
  color: var(--pastor-blue);
}

.pastor-bottom-nav a[aria-current="page"] {
  color: var(--pastor-blue);
  background: var(--pastor-blue-dim);
}

/* Inner content */
.pastor-hub-inner {
  padding-bottom: 4rem;
}

.pastor-section-title {
  font-family: 'Nunito', sans-serif;
  font-size: 1.1rem;
  color: var(--pastor-gray-light);
  margin: 0 0 0.75rem 0;
}

/* Export Full Notes — gold pill */
.pastor-btn-notes {
  background: linear-gradient(135deg, #d4af37, #b8860b);
  color: #0f172a;
  border: none;
  padding: 0.5rem 1rem;
  font-family: 'Nunito', sans-serif;
  font-weight: 600;
  font-size: 0.9rem;
  border-radius: 999px;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.pastor-btn-notes:hover {
  opacity: 0.95;
  transform: translateY(-1px);
}

.pastor-btn-notes:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

/* Loading spinner (shared) */
.pastor-btn-spinner {
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: pastor-spin 0.6s linear infinite;
}

.pastor-btn-notes .pastor-btn-spinner {
  border-color: rgba(15,23,42,0.3);
  border-top-color: #0f172a;
}

.pastor-btn-spinner.hidden {
  display: none;
}

@keyframes pastor-spin {
  to { transform: rotate(360deg); }
}

/* Share Draft button with spinner */
.pastor-share-label:empty + .pastor-btn-spinner { margin-left: 0; }

/* Builder toast */
.pastor-builder-toast {
  position: fixed;
  bottom: 5rem;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.75rem 1.25rem;
  background-color: var(--tdb-surface-card-bg, var(--pastor-card));
  background-image: var(--tdb-surface-veil-subtle, none);
  border: 1px solid var(--pastor-blue);
  border-radius: var(--tdb-surface-radius, 8px);
  color: var(--text-dark);
  font-size: 0.9rem;
  font-family: 'Nunito', sans-serif;
  z-index: 1000;
  box-shadow: var(--tdb-surface-card-shadow-hover, 0 4px 12px rgba(0,0,0,0.3));
  max-width: 90vw;
}

.pastor-builder-toast.hidden {
  display: none;
}

/* Layout utilities (replace inline styles) */
.pastor-section-title-spaced {
  margin-top: 1.25rem;
}
.pastor-btn-mt-half {
  margin-top: 0.5rem;
}
.pastor-builder-actions-spaced {
  margin-top: 1.25rem;
}
.pastor-verse-search-link {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}
.pastor-ai-suggest-note {
  margin: 0.5rem 0 0;
  font-size: 0.88rem;
  color: var(--text-muted, #94a3b8);
  max-width: 36rem;
  line-height: 1.45;
}

/* Focus-visible (keyboard / a11y) */
.pastor-hub-nav a:focus-visible {
  outline: 2px solid var(--pastor-blue);
  outline-offset: 2px;
}
.pastor-reflection-input:focus-visible,
.pastor-builder-section input:focus-visible,
.pastor-builder-section textarea:focus-visible,
.pastor-tools-search input:focus-visible,
.pastor-builder-block .pastor-block-text:focus-visible,
.pastor-ref-item input:focus-visible {
  outline: 2px solid var(--pastor-blue);
  outline-offset: 2px;
}
.pastor-btn-primary:focus-visible,
.pastor-btn-secondary:focus-visible,
.pastor-use-btn:focus-visible,
.pastor-insert-btn:focus-visible,
.pastor-ai-suggest button:focus-visible,
.pastor-btn-notes:focus-visible {
  outline: 2px solid var(--pastor-blue);
  outline-offset: 2px;
}
.pastor-bottom-nav a:focus-visible {
  outline: 2px solid var(--pastor-blue);
  outline-offset: 2px;
}

@media (max-width: 480px) {
  .pastor-hub-page .app-content {
    padding-top: var(--space-lg, 1.25rem);
    padding-left: 0.85rem;
    padding-right: 0.85rem;
  }
  .pastor-hub-page .content-inner {
    gap: var(--space-xl, 1.5rem);
  }
  .pastor-dub-card,
  .pastor-weekly-tease {
    padding: 1rem;
  }
  .pastor-daily-hero {
    margin-bottom: 1.1rem;
  }
}
