/* ============================================================
   Resource detail — world page styles
   ============================================================ */

/* ---------- Prose ---------- */
.prose {
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  color: var(--text);
  overflow-wrap: break-word;
  word-break: break-word;
  min-width: 0;
}

.prose p { margin-bottom: var(--space-4); }
.prose h2, .prose h3 { font-weight: 700; line-height: var(--lh-snug); margin-bottom: var(--space-3); margin-top: var(--space-6); }
.prose h2 { font-size: var(--fs-xl); }
.prose h3 { font-size: var(--fs-lg); }
.prose a { color: var(--accent); }
.prose a:hover { color: var(--accent-hover); }
.prose ul, .prose ol { padding-left: var(--space-5); margin-bottom: var(--space-4); }
.prose li { margin-bottom: var(--space-2); }

/* ---------- Text utility ---------- */
.text-muted {
  color: var(--text-muted);
}

/* ---------- World detail layout ---------- */
.world-detail {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  margin-top: var(--space-6);
}

.world-detail__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.world-detail__title {
  font-size: var(--fs-3xl);
  font-weight: 700;
  line-height: var(--lh-tight);
  color: var(--text);
}

.world-detail__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

.world-detail__cover-wrap {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--r-xl);
  background: var(--surface-2);
  max-height: 480px;
}

.world-detail__cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.world-detail__tabs {
  margin-bottom: var(--space-5);
}

.world-detail__panel {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.world-detail__body {
  max-width: 72ch;
}

/* ---------- World gallery / carousel ---------- */
.world-gallery {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.world-gallery__main {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--r-lg);
  background: var(--surface-2);
}

.world-gallery__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.world-gallery__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-full);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--shadow-md);
  transition: background var(--dur) var(--ease-standard);
}

.world-gallery__btn:hover { background: var(--surface-3); }
.world-gallery__btn:disabled { opacity: 0.35; cursor: default; }
.world-gallery__btn--prev { left: var(--space-3); }
.world-gallery__btn--next { right: var(--space-3); }

.world-gallery__thumbs {
  display: flex;
  gap: var(--space-2);
  overflow-x: auto;
  padding-bottom: var(--space-1);
}

.world-gallery__thumb {
  flex: 0 0 80px;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--r-sm);
  background: var(--surface-2);
  border: 2px solid transparent;
  cursor: pointer;
  padding: 0;
  transition: border-color var(--dur) var(--ease-standard);
}

.world-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.world-gallery__thumb--active {
  border-color: var(--accent);
}

/* ---------- Save card ---------- */
.save-card {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
}

.save-card__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-2);
  border-radius: var(--r-md);
  color: var(--text-muted);
}

.save-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
  min-width: 0;
}

.save-card__title {
  font-size: var(--fs-base);
  font-weight: 600;
  color: var(--text);
}

.save-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.save-card__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-1);
}
