/* Settings — worldbuilding page */

.settings-page {
  max-width: 1100px;
}

/* List page header */
.settings-list-header {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 1rem;
}

/* Detail header */
.settings-detail-header {
  margin-bottom: 1.5rem;
}

.settings-detail-header h2 {
  margin: 0 0 0.25rem;
  color: var(--text-primary);
}

.settings-detail-header .badge {
  margin-top: 0.5rem;
}

/* =============================================================================
   Cosmos Sidebar Navigation (matches campaign-nav / game-system-nav pattern)
   ============================================================================= */

.cosmos-nav {
  background: var(--bg-primary);
  padding: 1.5rem;
  border-radius: 8px;
  border: 1px solid var(--border-primary);
}

.cosmos-nav .nav-header {
  border-bottom: 2px solid var(--accent-red);
  padding-bottom: 0.5rem;
  margin-bottom: 1rem;
}

.cosmos-nav h3 {
  margin: 0 0 0.25rem 0;
  font-size: 1.1rem;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cosmos-nav .nav-status {
  margin-top: 0.25rem;
}

.cosmos-nav .nav-status .badge {
  font-size: 0.6rem;
  padding: 0.15rem 0.35rem;
}

.cosmos-nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.cosmos-nav li {
  margin-bottom: 0.25rem;
}

.cosmos-nav li.nav-divider {
  margin: 0.75rem 0;
  border-top: 1px solid var(--border-primary);
}

.cosmos-nav a {
  display: block;
  padding: 0.6rem 1rem;
  text-decoration: none;
  color: var(--text-secondary);
  border-radius: 4px;
  transition: background 0.2s, color 0.2s;
  font-size: 0.9rem;
  cursor: pointer;
}

.cosmos-nav a:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

.cosmos-nav a.active {
  background: var(--accent-red);
  color: #ffffff;
  font-weight: 500;
}

/* Tab content */
.settings-tab-content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.settings-tab-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.settings-tab-header h3 {
  margin: 0;
  color: var(--text-primary);
}

.settings-tab-header-actions {
  display: flex;
  gap: 0.35rem;
}

/* Card list */
.settings-card-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* Individual card */
.settings-card {
  border: 1px solid var(--border-primary);
  border-radius: 6px;
  background: var(--bg-secondary);
  overflow: hidden;
}

.settings-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  gap: 0.5rem;
}

.settings-card-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1;
  min-width: 0;
}

.settings-card-title strong {
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.settings-card-title a {
  color: var(--accent-red);
  text-decoration: none;
}

.settings-card-title a:hover {
  text-decoration: underline;
}

.settings-card-meta {
  display: flex;
  gap: 0.35rem;
  flex-shrink: 0;
}

.settings-card-actions {
  display: flex;
  gap: 0.35rem;
  flex-shrink: 0;
}

.settings-card-body {
  padding: 0 1rem 1rem;
  border-top: 1px solid var(--border-primary);
}

.settings-card-body h4 {
  color: var(--text-primary);
  font-size: 0.85rem;
  margin: 0.75rem 0 0.35rem;
}

.settings-field-row {
  padding: 0.35rem 0;
  font-size: 0.9rem;
  color: var(--text-secondary);
}

.settings-field-label {
  color: var(--text-muted);
  font-weight: 600;
}

.settings-description {
  color: var(--text-secondary);
  font-size: 0.9rem;
  line-height: 1.5;
  margin: 0.5rem 0;
}

.settings-content {
  margin-top: 0.5rem;
}

.settings-content p,
.settings-gm-notes p {
  color: var(--text-secondary);
  font-size: 0.9rem;
  line-height: 1.5;
  white-space: pre-wrap;
}

.settings-gm-notes {
  margin-top: 0.5rem;
  padding: 0.5rem;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 4px;
}

/* Overview card (list page) */
.settings-overview-card {
  border: 1px solid var(--border-primary);
  border-radius: 6px;
  background: var(--bg-secondary);
  overflow: hidden;
}

.settings-overview-card .settings-card-body {
  border-top: 1px solid var(--border-primary);
}

/* Create form */
.settings-create-form {
  border: 1px solid var(--border-primary);
  border-radius: 6px;
  background: var(--bg-secondary);
  padding: 1rem;
  margin-bottom: 1rem;
}

.settings-create-form h3 {
  margin: 0 0 0.75rem;
  color: var(--text-primary);
  font-size: 1rem;
}

.settings-form-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

/* Search bar */
.settings-search {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.settings-search-input {
  flex: 1;
  padding: 0.5rem 0.75rem;
  background: var(--bg-secondary);
  border: 1px solid var(--border-primary);
  border-radius: 4px;
  color: var(--text-primary);
  font-size: 0.9rem;
}

.settings-search-input::placeholder {
  color: var(--text-disabled);
}

.settings-search-input:focus {
  outline: none;
  border-color: var(--accent-red);
}

.settings-search-clear {
  padding: 0.5rem 0.75rem;
  background: transparent;
  border: 1px solid var(--border-primary);
  border-radius: 4px;
  color: var(--text-secondary);
  cursor: pointer;
  font-size: 0.85rem;
}

.settings-search-clear:hover {
  color: var(--text-primary);
  border-color: var(--text-secondary);
}

/* Edit mode */
.settings-card.editing {
  border-color: var(--accent-red);
}

.settings-edit-body {
  padding-top: 0.75rem;
}

/* Entity type badge */
.entity-type-badge {
  display: inline-block;
  padding: 0.15rem 0.45rem;
  border-radius: 3px;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.entity-type-badge.npcs {
  background: var(--info-bg);
  color: var(--info);
}

.entity-type-badge.locations {
  background: var(--success-bg);
  color: var(--success);
}

.entity-type-badge.factions {
  background: var(--warning-bg);
  color: var(--warning);
}

.entity-type-badge.lore {
  background: rgba(192, 132, 252, 0.2);
  color: #c084fc;
}

.entity-type-badge.events {
  background: rgba(244, 114, 182, 0.2);
  color: #f472b6;
}

/* =============================================================================
   Phase 4 — Maps & Wiki Linking
   ============================================================================= */

/* Map container — holds image + pin overlay */
.settings-map-container {
  position: relative;
  display: inline-block;
  max-width: 100%;
  border: 1px solid var(--border-primary);
  border-radius: 6px;
  overflow: hidden;
  background: var(--bg-secondary);
}

.settings-map-image {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Pin marker — absolute positioned on map */
.settings-map-pin {
  position: absolute;
  transform: translate(-50%, -100%);
  cursor: pointer;
  z-index: 2;
}

.settings-map-pin-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--accent-red);
  border: 2px solid #fff;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
  transition: transform 0.15s;
}

.settings-map-pin:hover .settings-map-pin-dot {
  transform: scale(1.3);
}

.settings-map-pin-label {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  font-size: 0.7rem;
  color: var(--text-primary);
  background: rgba(0, 0, 0, 0.75);
  padding: 0.1rem 0.4rem;
  border-radius: 3px;
  margin-top: 2px;
  pointer-events: none;
}

/* Map detail layout */
.settings-map-detail {
  display: flex;
  gap: 1.5rem;
  padding: 1rem;
  border-top: 1px solid var(--border-primary);
}

.settings-map-detail-main {
  flex: 1;
  min-width: 0;
}

.settings-map-detail-sidebar {
  width: 240px;
  flex-shrink: 0;
}

/* Map info block */
.settings-map-info {
  display: flex;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
  flex-wrap: wrap;
}

.settings-map-dimensions {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.8rem;
  color: var(--text-secondary);
  background: var(--bg-secondary);
  padding: 0.2rem 0.5rem;
  border-radius: 3px;
  border: 1px solid var(--border-primary);
}

/* Pins sidebar within expanded map */
.settings-map-pins-section {
  border-top: 1px solid var(--border-primary);
  padding-top: 0.75rem;
}

.settings-map-pins-section h4 {
  margin: 0 0 0.5rem;
  color: var(--text-primary);
  font-size: 0.9rem;
}

.settings-map-pins-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.settings-map-pin-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.35rem 0.5rem;
  border: 1px solid var(--border-primary);
  border-radius: 4px;
  background: var(--bg-secondary);
  font-size: 0.85rem;
}

.settings-map-pin-item-name {
  color: var(--text-primary);
}

.settings-map-pin-item-coords {
  color: var(--text-muted);
  font-size: 0.75rem;
}

/* Pin create/edit form inside expanded map */
.settings-map-pin-form {
  border: 1px solid var(--border-primary);
  border-radius: 6px;
  background: var(--bg-secondary);
  padding: 0.75rem;
  margin-top: 0.75rem;
}

.settings-map-pin-form h4 {
  margin: 0 0 0.5rem;
  color: var(--text-primary);
  font-size: 0.9rem;
}

.settings-map-pin-form .form-field {
  margin-bottom: 0.5rem;
}

.settings-map-pin-form .form-field label {
  font-size: 0.8rem;
}

/* Wiki link styling */
.wiki-link {
  color: var(--accent-red);
  cursor: pointer;
  text-decoration: none;
  border-bottom: 1px dashed var(--accent-red);
  transition: border-color 0.15s;
}

.wiki-link:hover {
  border-bottom-style: solid;
}

/* Broken wiki link — entity doesn't exist yet */
.wiki-link-broken {
  color: var(--warning);
  cursor: pointer;
  text-decoration: none;
  border-bottom: 1px dashed var(--warning);
  transition: border-color 0.15s;
}

.wiki-link-broken:hover {
  border-bottom-style: solid;
  color: #f59e0b;
}

/* Wiki-create banner */
.wiki-create-banner {
  background: rgba(251, 191, 36, 0.1);
  border: 1px solid rgba(251, 191, 36, 0.3);
  border-radius: 6px;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
}

.wiki-create-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
  color: var(--warning);
  font-weight: 500;
}

.wiki-create-types {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

/* Content text with wiki links */
.settings-content-text {
  color: var(--text-secondary);
  font-size: 0.9rem;
  line-height: 1.5;
  white-space: pre-wrap;
}

/* Entity type badge for maps */
.entity-type-badge.maps {
  background: var(--error-bg);
  color: var(--error);
}

/* Responsive */
@media (max-width: 600px) {
  .settings-map-detail {
    flex-direction: column;
  }

  .settings-map-detail-sidebar {
    width: 100%;
  }
}

/* =============================================================================
   Phase 3 — Publishing & Versioning
   ============================================================================= */

/* Header badges row */
.settings-header-badges {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0.5rem;
}

/* Publish dialog */
.settings-publish-dialog {
  border: 1px solid var(--border-primary);
  border-radius: 6px;
  background: var(--bg-secondary);
  padding: 1rem;
  margin-bottom: 1rem;
}

.settings-publish-dialog h3 {
  margin: 0 0 0.5rem;
  color: var(--text-primary);
  font-size: 1rem;
}

.settings-publish-desc {
  color: var(--text-secondary);
  font-size: 0.9rem;
  margin: 0 0 0.75rem;
  line-height: 1.4;
}

/* Info message box (update available) */
.message-box.info {
  background: rgba(96, 165, 250, 0.1);
  border: 1px solid rgba(96, 165, 250, 0.3);
  border-radius: 6px;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.message-box.info p {
  color: var(--text-primary);
  font-size: 0.9rem;
  margin: 0;
  flex: 1;
}

/* =============================================================================
   Content Import Wizard
   ============================================================================= */

.settings-import-wizard {
  max-width: 900px;
}

.settings-import-wizard h3 {
  margin: 0 0 0.75rem;
  color: var(--text-primary);
}

.settings-import-help {
  color: var(--text-secondary);
  font-size: 0.9rem;
  line-height: 1.5;
  margin: 0 0 1rem;
}

.settings-import-textarea {
  width: 100%;
  min-height: 300px;
  font-family: monospace;
  font-size: 0.85rem;
  padding: 0.75rem;
  background: var(--bg-secondary);
  border: 1px solid var(--border-primary);
  border-radius: 4px;
  color: var(--text-primary);
  resize: vertical;
}

.settings-import-textarea::placeholder {
  color: var(--text-disabled);
}

.settings-import-textarea:focus {
  outline: none;
  border-color: var(--accent-red);
}

.settings-import-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 1rem;
}

.settings-import-summary {
  color: var(--text-secondary);
  font-size: 0.9rem;
  margin: 0 0 0.75rem;
}

.settings-import-bulk-actions {
  display: flex;
  gap: 0.35rem;
  margin-bottom: 1rem;
}

/* Review list */
.settings-import-review-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.settings-import-candidate {
  border: 1px solid var(--border-primary);
  border-radius: 6px;
  background: var(--bg-secondary);
  overflow: hidden;
}

.settings-import-candidate.excluded {
  opacity: 0.5;
}

.settings-import-candidate-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
}

.settings-import-checkbox {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.settings-import-checkbox input {
  width: 16px;
  height: 16px;
  cursor: pointer;
}

.settings-import-name-input {
  flex: 1;
  min-width: 0;
  padding: 0.3rem 0.5rem;
  background: var(--bg-primary);
  border: 1px solid var(--border-primary);
  border-radius: 3px;
  color: var(--text-primary);
  font-size: 0.9rem;
}

.settings-import-name-input:focus {
  outline: none;
  border-color: var(--accent-red);
}

.settings-import-type-select {
  padding: 0.3rem 0.5rem;
  background: var(--bg-primary);
  border: 1px solid var(--border-primary);
  border-radius: 3px;
  color: var(--text-primary);
  font-size: 0.85rem;
  cursor: pointer;
}

/* Preview panel */
.settings-import-preview {
  padding: 0.75rem;
  border-top: 1px solid var(--border-primary);
  font-size: 0.85rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

.settings-import-content-preview {
  background: var(--bg-primary);
  border: 1px solid var(--border-primary);
  border-radius: 4px;
  padding: 0.5rem;
  font-size: 0.8rem;
  color: var(--text-secondary);
  white-space: pre-wrap;
  max-height: 200px;
  overflow-y: auto;
  margin: 0.5rem 0;
}

.settings-import-gm-notes-preview {
  margin-top: 0.5rem;
  padding: 0.5rem;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 4px;
}

/* Progress bar */
.settings-import-progress-bar {
  width: 100%;
  height: 8px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-primary);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 0.5rem;
}

.settings-import-progress-fill {
  height: 100%;
  background: var(--accent-red);
  border-radius: 4px;
  transition: width 0.3s ease;
}

.settings-import-progress-text {
  color: var(--text-secondary);
  font-size: 0.85rem;
  margin: 0 0 1rem;
}

/* Results list */
.settings-import-result-list {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 1rem;
}

.settings-import-result-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.5rem;
  border-radius: 4px;
  font-size: 0.85rem;
}

.settings-import-result-item.success {
  background: var(--success-bg);
}

.settings-import-result-item.error {
  background: var(--error-bg);
}

.settings-import-result-name {
  flex: 1;
  color: var(--text-primary);
}

/* Done summary */
.settings-import-done-summary {
  margin-top: 1rem;
}

.settings-import-done-summary p {
  color: var(--text-primary);
  font-size: 0.9rem;
  margin: 0 0 0.5rem;
}

.settings-import-errors {
  color: var(--error);
}

/* Responsive */
@media (max-width: 600px) {
  .settings-card-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .settings-card-actions {
    width: 100%;
    justify-content: flex-end;
  }

  /* layout.css handles sidebar-left mobile stacking */

  .settings-import-candidate-header {
    flex-wrap: wrap;
  }
}

/* ============================================================================
   Clock Segments Display
   ============================================================================ */

.settings-clock-display {
  margin: 0.5rem 0;
}

.settings-clock-segments {
  display: flex;
  gap: 4px;
  margin: 0.5rem 0;
}

.settings-clock-segment {
  width: 28px;
  height: 28px;
  border: 2px solid var(--border-primary);
  border-radius: 4px;
  background: var(--bg-primary);
  transition: background 0.2s;
}

.settings-clock-segment.filled {
  background: var(--accent-red);
  border-color: var(--accent-red);
}

/* ==========================================================================
   Unified Cosmos List Page
   ========================================================================== */

.settings-page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.settings-page-header h2 {
  margin: 0;
}

.settings-page-header-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.settings-section-label {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-secondary);
  margin: 1.25rem 0 0.5rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.settings-divider {
  border: none;
  border-top: 1px solid var(--border-primary);
  margin: 1.5rem 0 0.5rem;
}

.settings-card-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--border-primary);
}

.settings-public-card {
  border-left: 3px solid var(--info);
}

.settings-visibility-select {
  padding: 0.35rem 0.5rem;
  background: var(--bg-primary);
  border: 1px solid var(--border-primary);
  border-radius: 4px;
  color: var(--text-primary);
  font-size: 0.85rem;
}

/* Mobile */
@media (max-width: 640px) {
  .settings-page-header {
    flex-direction: column;
    align-items: flex-start;
  }
  .settings-page-header-actions {
    width: 100%;
    flex-wrap: wrap;
  }
}
