/* =====================================================
   GENERATOR MODE TOGGLE COMPONENT
   Simple/Advanced mode toggle for all generators
   ===================================================== */

.generator-mode-toggle {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
  padding: 0.75rem 1rem;
  background: var(--color-surface-elevated, rgba(30, 41, 59, 0.5));
  border: 1px solid var(--color-border, rgba(148, 163, 184, 0.2));
  border-radius: 0.75rem;
}

.generator-mode-toggle-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-muted, #94a3b8);
  margin-right: 0.5rem;
}

.generator-mode-toggle-buttons {
  display: flex;
  background: var(--color-surface, rgba(15, 23, 42, 0.5));
  border-radius: 0.5rem;
  padding: 0.25rem;
  gap: 0.25rem;
}

.generator-mode-btn {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  border: none;
  border-radius: 0.375rem;
  cursor: pointer;
  transition: all 0.2s ease;
  background: transparent;
  color: var(--color-muted, #94a3b8);
  min-height: auto;
  margin: 0;
}

.generator-mode-btn:hover {
  color: var(--color-text, #e2e8f0);
  background: var(--color-surface-elevated, rgba(30, 41, 59, 0.5));
}

.generator-mode-btn.active {
  background: var(--color-primary, #14b8a6);
  color: var(--color-on-primary, #0f172a);
}

.generator-mode-hint {
  margin-left: auto;
  font-size: 0.75rem;
  color: var(--color-muted, #94a3b8);
  font-style: italic;
}

/* Simple Mode Controls Container */
.generator-simple-controls {
  display: block;
  margin-bottom: 1.5rem;
  padding: 1.25rem;
  background: linear-gradient(135deg, 
    rgba(20, 184, 166, 0.08), 
    rgba(139, 92, 246, 0.08)
  );
  border: 1px solid rgba(20, 184, 166, 0.2);
  border-radius: 0.75rem;
}

.generator-simple-controls.hidden {
  display: none;
}

.generator-simple-controls h3 {
  margin: 0 0 1rem 0;
  font-size: 0.9375rem;
  font-family: var(--font-display, 'Cinzel', serif);
  color: var(--color-primary, #14b8a6);
  letter-spacing: 0.03em;
}

.simple-control-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 0;
}

.simple-control-group {
  flex: 1;
  min-width: 140px;
}

.simple-control-group label {
  display: block;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text, #e2e8f0);
  margin-bottom: 0.375rem;
}

.simple-control-group select,
.simple-control-group input {
  width: 100%;
  padding: 0.625rem 0.75rem;
  font-size: 0.9375rem;
  background: var(--color-surface, #0f172a);
  border: 1px solid var(--color-border, rgba(148, 163, 184, 0.3));
  border-radius: 0.5rem;
  color: var(--color-text, #e2e8f0);
}

.simple-control-group select:focus,
.simple-control-group input:focus {
  outline: none;
  border-color: var(--color-primary, #14b8a6);
  box-shadow: 0 0 0 2px rgba(20, 184, 166, 0.2);
}

/* Advanced Options Container */
.generator-advanced-options {
  display: block;
}

.generator-advanced-options.hidden {
  display: none;
}

.generator-advanced-options h2:first-child {
  margin-top: 0;
}

/* Advanced section divider */
.advanced-section-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin: 1.5rem 0 1rem 0;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--color-border, rgba(148, 163, 184, 0.2));
}

.advanced-section-header h2 {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-muted, #94a3b8);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.advanced-section-icon {
  font-size: 1rem;
  opacity: 0.7;
}

/* Visual indicator for advanced mode */
.generator-mode-toggle[data-mode="advanced"] {
  border-color: rgba(139, 92, 246, 0.3);
  background: linear-gradient(135deg, 
    rgba(139, 92, 246, 0.08), 
    rgba(30, 41, 59, 0.5)
  );
}

/* Quick generate button in simple mode */
.simple-generate-btn {
  width: 100%;
  margin-top: 1rem;
  padding: 1rem;
  font-size: 1.125rem;
  font-weight: 600;
  background: linear-gradient(135deg, var(--color-primary, #14b8a6), #0d9488);
  border: none;
  border-radius: 0.5rem;
  color: white;
  cursor: pointer;
  transition: all 0.2s ease;
}

.simple-generate-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(20, 184, 166, 0.3);
}

/* Responsive adjustments */
@media (max-width: 640px) {
  .generator-mode-toggle {
    flex-wrap: wrap;
  }
  
  .generator-mode-hint {
    width: 100%;
    margin-left: 0;
    margin-top: 0.5rem;
  }
  
  .simple-control-group {
    min-width: 100%;
  }
}

/* =====================================================
   CONTENT PICKER COMPONENT
   For selecting existing rooms/puzzles to include
   ===================================================== */

.content-picker-container {
  margin-top: 0.75rem;
}

.content-picker-section {
  background: var(--color-surface, rgba(15, 23, 42, 0.5));
  border: 1px solid var(--color-border, rgba(148, 163, 184, 0.2));
  border-radius: 0.75rem;
  padding: 1rem;
}

.content-picker-list {
  scrollbar-width: thin;
  scrollbar-color: var(--color-border, #334155) transparent;
}

.content-picker-list::-webkit-scrollbar {
  width: 6px;
}

.content-picker-list::-webkit-scrollbar-track {
  background: transparent;
}

.content-picker-list::-webkit-scrollbar-thumb {
  background: var(--color-border, #334155);
  border-radius: 3px;
}

.content-picker-item {
  transition: background 0.15s ease;
}

.content-picker-item:hover {
  background: var(--color-surface-elevated, rgba(51, 65, 85, 0.5)) !important;
}

.content-picker-item.selected {
  background: rgba(20, 184, 166, 0.15) !important;
  border-left: 3px solid var(--color-primary, #14b8a6);
}

.content-picker-item.selected:hover {
  background: rgba(20, 184, 166, 0.25) !important;
}

.content-picker-item:last-child {
  border-bottom: none !important;
}

/* Light mode adjustments */
[data-theme="light"] .content-picker-section {
  background: var(--color-surface, #f8fafc);
}

[data-theme="light"] .content-picker-item:hover {
  background: var(--color-surface-elevated, #e2e8f0) !important;
}

[data-theme="light"] .content-picker-item.selected {
  background: rgba(20, 184, 166, 0.1) !important;
}

/* =====================================================
   PRESET PICKER COMPONENT
   Scenario preset selector for Simple mode
   ===================================================== */

.preset-picker-container {
  margin-bottom: 1.25rem;
}

.preset-picker-label {
  display: block;
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary, #14b8a6);
  margin-bottom: 0.5rem;
  font-family: var(--font-display, 'Cinzel', serif);
  letter-spacing: 0.02em;
}

.preset-picker-select {
  width: 100%;
  padding: 0.875rem 1rem;
  font-size: 1rem;
  font-weight: 500;
  background: var(--color-surface, #0f172a);
  border: 2px solid var(--color-primary, #14b8a6);
  border-radius: 0.75rem;
  color: var(--color-text, #e2e8f0);
  cursor: pointer;
  transition: all 0.2s ease;
}

.preset-picker-select:hover {
  border-color: #0d9488;
  box-shadow: 0 2px 8px rgba(20, 184, 166, 0.2);
}

.preset-picker-select:focus {
  outline: none;
  border-color: var(--color-primary, #14b8a6);
  box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.25);
}

.preset-picker-description {
  margin-top: 0.625rem;
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  color: var(--color-muted, #94a3b8);
  background: rgba(20, 184, 166, 0.05);
  border-left: 3px solid var(--color-primary, #14b8a6);
  border-radius: 0 0.5rem 0.5rem 0;
  font-style: italic;
  line-height: 1.5;
}

/* Preset card style (alternative) */
.preset-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.preset-card {
  padding: 1rem;
  background: var(--color-surface, rgba(15, 23, 42, 0.8));
  border: 2px solid var(--color-border, rgba(148, 163, 184, 0.2));
  border-radius: 0.75rem;
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: center;
}

.preset-card:hover {
  border-color: rgba(20, 184, 166, 0.5);
  background: rgba(20, 184, 166, 0.05);
  transform: translateY(-2px);
}

.preset-card.selected {
  border-color: var(--color-primary, #14b8a6);
  background: rgba(20, 184, 166, 0.1);
  box-shadow: 0 4px 12px rgba(20, 184, 166, 0.2);
}

.preset-card-icon {
  font-size: 2rem;
  margin-bottom: 0.5rem;
}

.preset-card-label {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text, #e2e8f0);
  line-height: 1.3;
}

/* =====================================================
   RECOMMENDED TAG PACKS SECTION
   Theme-aware tag pack recommendations
   ===================================================== */

.recommended-tags-section {
  margin-bottom: 1rem;
  padding: 0.875rem 1rem;
  background: linear-gradient(135deg, 
    rgba(139, 92, 246, 0.08), 
    rgba(20, 184, 166, 0.05)
  );
  border: 1px solid rgba(139, 92, 246, 0.25);
  border-radius: 0.75rem;
}

.recommended-tags-header {
  margin: 0 0 0.75rem 0;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #a78bfa;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.recommended-tags-header::before {
  content: "★";
  font-size: 0.875rem;
}

.recommended-tags-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.recommended-tag-item {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.5rem 0.875rem;
  background: var(--color-surface, rgba(15, 23, 42, 0.6));
  border: 1px solid var(--color-border, rgba(148, 163, 184, 0.2));
  border-radius: 2rem;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.8125rem;
}

.recommended-tag-item:hover {
  border-color: rgba(139, 92, 246, 0.5);
  background: rgba(139, 92, 246, 0.1);
}

.recommended-tag-item.selected {
  border-color: #a78bfa;
  background: rgba(139, 92, 246, 0.2);
  color: #a78bfa;
}

.recommended-tag-item input[type="checkbox"] {
  width: 1rem;
  height: 1rem;
  margin: 0;
  accent-color: #a78bfa;
}

.recommended-tag-item .tag-name {
  color: var(--color-text, #e2e8f0);
  font-weight: 500;
}

.recommended-tag-item.selected .tag-name {
  color: #a78bfa;
}

/* Light mode adjustments for presets */
[data-theme="light"] .preset-picker-select {
  background: var(--color-surface, #f8fafc);
}

[data-theme="light"] .preset-picker-description {
  background: rgba(20, 184, 166, 0.08);
}

[data-theme="light"] .preset-card {
  background: var(--color-surface, #f8fafc);
}

[data-theme="light"] .recommended-tags-section {
  background: linear-gradient(135deg, 
    rgba(139, 92, 246, 0.05), 
    rgba(20, 184, 166, 0.03)
  );
}

[data-theme="light"] .recommended-tag-item {
  background: var(--color-surface, #f8fafc);
}

/* =====================================================
   SIMPLE MODE DIVIDER
   Visual separator between preset and controls
   ===================================================== */

.simple-mode-divider {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin: 1rem 0;
  color: var(--color-muted, #94a3b8);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.simple-mode-divider::before,
.simple-mode-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, 
    transparent, 
    var(--color-border, rgba(148, 163, 184, 0.3)), 
    transparent
  );
}

/* =====================================================
   GENRE BADGE
   Shows current genre category
   ===================================================== */

.genre-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.75rem;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: 2rem;
  background: rgba(139, 92, 246, 0.15);
  color: #a78bfa;
  border: 1px solid rgba(139, 92, 246, 0.3);
}

.genre-badge.fantasy {
  background: rgba(59, 130, 246, 0.15);
  color: #60a5fa;
  border-color: rgba(59, 130, 246, 0.3);
}

.genre-badge.scifi {
  background: rgba(20, 184, 166, 0.15);
  color: #14b8a6;
  border-color: rgba(20, 184, 166, 0.3);
}

.genre-badge.horror {
  background: rgba(239, 68, 68, 0.15);
  color: #f87171;
  border-color: rgba(239, 68, 68, 0.3);
}

.genre-badge.post_apoc {
  background: rgba(245, 158, 11, 0.15);
  color: #fbbf24;
  border-color: rgba(245, 158, 11, 0.3);
}

.genre-badge.weird_west {
  background: rgba(180, 83, 9, 0.15);
  color: #d97706;
  border-color: rgba(180, 83, 9, 0.3);
}
