/* === YENİ TOKEN PAYLAŞIM MODALI TASARIMI === */
/* ============================================= */

/* Sekme Butonları (İçe Aktar / Dışa Aktar) */
#gistActionTabs {
  display: flex;
  gap: calc(var(--spacing-unit) * 2);
  background-color: var(--bg-content);
  border-radius: var(--radius-md);
  padding: calc(var(--spacing-unit) * 1.5);
  margin-bottom: calc(var(--spacing-unit) * 5);
}

#gistActionTabs button {
  flex: 1;
  padding: calc(var(--spacing-unit) * 2.5) 0;
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  font-weight: 500;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

#gistActionTabs button.active {
  background-color: var(--bg-hover);
  color: var(--text-primary);
  font-weight: 600;
}

.gist-tab-content {
  display: none;
}

.gist-tab-content.active {
  display: block;
  animation: fadeIn_v10 0.3s ease-out;
}

/* Ortak Form Elemanları */
#gistModalContainer label:not(.switch) {
  color: var(--text-secondary);
  margin-bottom: calc(var(--spacing-unit) * 1.5);
}

#gistExportTokenTextarea,
#gistImportTokenInput {
  min-height: 80px;
  font-family: var(--font-monospace);
  font-size: var(--font-size-sm);
  line-height: 1.6;
  word-break: break-all;
  background-color: var(--code-bg);
  border-color: var(--border-color);
  padding: calc(var(--spacing-unit) * 3);
  margin-bottom: calc(var(--spacing-unit) * 3);
}

#gistModalContainer .button {
  margin-bottom: calc(var(--spacing-unit) * 4);
}

/* Dışa Aktarma Sekmesi Özel Elemanları */
#gistExportTab .description {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
  text-align: center;
  margin-top: calc(var(--spacing-unit) * -2);
  margin-bottom: calc(var(--spacing-unit) * 4);
}

#gistExportTab .settings-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: var(--bg-content);
  padding: calc(var(--spacing-unit) * 3) calc(var(--spacing-unit) * 4);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-color);
  margin-bottom: calc(var(--spacing-unit) * 4);
}

#gistExportTab .settings-item label:not(.switch) {
  margin: 0;
  display: flex;
  align-items: center;
  gap: calc(var(--spacing-unit) * 2.5);
  font-weight: 500;
  color: var(--text-primary);
  flex-grow: 1;
  /* Etiketin kalan boşluğu doldurmasını sağlar */
}

#gistExportTab .settings-item label i {
  color: var(--text-secondary);
}

#gistExportTab .settings-item .switch {
  flex-shrink: 0;
  /* Switch'in küçülmesini engeller */
}

#shareTokenStatus {
  text-align: center;
  margin-top: calc(var(--spacing-unit) * 2);
  padding: calc(var(--spacing-unit) * 2);
  border-radius: var(--radius-md);
  background-color: color-mix(in srgb, var(--accent-green) 10%, transparent);
  color: var(--accent-green);
}

/* ============================================= */
/* === YENİ DÜZENLEME MODALI SEKMELERİ (C.AI V2) === */
/* ============================================= */

#personalityFormModalContainer .ai-settings-tab-button-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  /* 2x2 Izgara düzeni */
  gap: calc(var(--spacing-unit) * 2.5);
  margin-bottom: calc(var(--spacing-unit) * 5);
  background-color: transparent;
  /* Arka plan kutusunu kaldır */
  border-radius: 0;
  padding: 0;
  border: none;
}

#personalityFormModalContainer .ai-settings-tab-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(var(--spacing-unit) * 2);
  padding: calc(var(--spacing-unit) * 3) calc(var(--spacing-unit) * 2);
  border: 1px solid var(--border-input);
  background-color: var(--bg-content);
  color: var(--text-secondary);
  font-weight: 500;
  font-size: var(--font-size-sm);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  box-shadow: 0 2px 5px var(--shadow-soft);
}

#personalityFormModalContainer .ai-settings-tab-button i {
  font-size: 1em;
  transition: inherit;
  color: var(--text-tertiary);
}

#personalityFormModalContainer .ai-settings-tab-button:hover {
  transform: translateY(-2px);
  border-color: var(--accent-primary);
  color: var(--text-primary);
  background-color: var(--bg-hover);
}

#personalityFormModalContainer .ai-settings-tab-button:hover i {
  color: var(--accent-primary);
}

#personalityFormModalContainer .ai-settings-tab-button.active {
  background-color: var(--accent-primary);
  color: var(--text-on-accent);
  border-color: var(--accent-primary);
  font-weight: 600;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px color-mix(in srgb, var(--accent-primary) 30%, transparent);
}

#personalityFormModalContainer .ai-settings-tab-button.active i {
  color: var(--text-on-accent);
}

.ai-settings-tab-panel {
  display: none;
  animation: fadeIn_v10 0.3s ease-out;
}

.ai-settings-tab-panel.active {
  display: block;
}

/* Modal içindeki form elemanları için boşluk ayarları */
#personalityFormModalContainer .ai-settings-tab-panel label {
  margin-top: calc(var(--spacing-unit) * 3.5);
  display: block;
}

#personalityFormModalContainer .ai-settings-tab-panel label:first-child {
  margin-top: 0;
}

#personalityFormModalContainer .ai-settings-tab-panel input,
#personalityFormModalContainer .ai-settings-tab-panel textarea,
#personalityFormModalContainer .ai-settings-tab-panel .select-wrapper {
  margin-bottom: 0;
}

.form-header-with-button {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: calc(var(--spacing-unit) * 2);
}

.form-header-with-button label {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

#personalityFormModalContainer .settings-item {
  margin-bottom: calc(var(--spacing-unit) * 4);
}

#personalityFormModalContainer .settings-item:last-child {
  margin-bottom: 0;
}

/* Sohbet Geçmişi Yükleme Animasyonu */
.chat-loading-spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  color: var(--text-tertiary);
}

.chat-loading-spinner .spinner-animation {
  width: 40px;
  height: 40px;
  border: 4px solid var(--border-color);
  border-left-color: var(--accent-primary);
  border-radius: 50%;
  animation: spin_v10 1s linear infinite;
}

.chat-loading-spinner span {
  font-size: var(--font-size-xs);
  font-weight: 500;
}

/* sohbet_loading.css */

/* Chat Loading Overlay */
#chatLoadingOverlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--bg-main);
  /* Ana arkaplan rengiyle eşleşsin */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: calc(var(--spacing-unit) * 4);
  z-index: var(--z-chat-overlay) + 1;
  /* Sohbetin üstünde olsun */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  pointer-events: none;
  /* Üzerindeki elementlere tıklamayı engellemesin */
}

#chatLoadingOverlay.visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  /* Görünürken tıklamaları yakalasın */
}

#chatLoadingOverlay .spinner-animation {
  width: 60px;
  /* Daha büyük spinner */
  height: 60px;
  border: 5px solid var(--border-color);
  border-left-color: var(--accent-primary);
  border-radius: 50%;
  animation: spin_v10 1s linear infinite;
}

#chatLoadingOverlay .loading-text {
  font-size: var(--font-size-md);
  color: var(--text-secondary);
  font-weight: 500;
  text-align: center;
}

#chatLoadingOverlay .loading-subtext {
  font-size: var(--font-size-sm);
  color: var(--text-tertiary);
  text-align: center;
  max-width: 80%;
  line-height: 1.4;
}

/* Chat loading spinner'ın orijinal halini gizle */
.chat-loading-spinner {
  display: none !important;
}

/* BU BLOK YENİ OLARAK EKLENECEK */
/* Sohbet Geçmişi Yükleme Animasyonu */
.chat-loading-spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  color: var(--text-tertiary);
}

.chat-loading-spinner .spinner-animation {
  width: 40px;
  height: 40px;
  border: 4px solid var(--border-color);
  border-left-color: var(--accent-primary);
  border-radius: 50%;
  animation: spin_v10 1s linear infinite;
}

.chat-loading-spinner span {
  font-size: var(--font-size-xs);
  font-weight: 500;
}

/* BU BLOK YENİ OLARAK EKLENECEK */

.personalities-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: calc(var(--spacing-unit) * 4);
  /* Gap biraz artırıldı */
  margin-bottom: calc(var(--spacing-unit) * 5);
  /* Alt boşluk artırıldı */
  padding-bottom: 0;
  /* Artık alt çizgi yok, başlık daha serbest */
  border-bottom: none;
  /* Alt çizgi kaldırıldı */
}

.personalities-header h2 {
  margin-bottom: 0;
  flex-grow: 1;
  font-size: var(--font-size-lg);
  /* Başlık boyutu biraz büyütüldü */
  font-weight: 700;
  /* Daha kalın */
  letter-spacing: -0.5px;
  /* Hafifçe sıkılaştırıldı */
}

/* Ana Grup Kapsayıcısı */
.personalities-header .header-actions-group {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  gap: 8px !important;
  margin-top: 5px !important;
  align-items: stretch !important;
}

/* Üst Satır (Altın/Enerji) */
.header-stats-row {
  display: flex !important;
  flex-direction: row !important;
  justify-content: flex-end !important; /* Sağa yasla */
  width: 100% !important;
  padding-bottom: 5px !important;
}

/* Alt Satır (Arama + Butonlar) */
.header-tools-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  width: 100% !important;
  gap: 8px !important;
}

/* Arama Kutusu Esnekliği */
.search-input-wrapper.new-style-search {
  flex: 1 !important; /* Kalan boşluğu doldur */
  min-width: 0 !important; /* Taşmayı önle */
  max-width: none !important;
}

/* Enerji ve Altın için Üst Satır Konteyneri */
.header-stats-row {
  display: flex;
  width: 100%;
  justify-content: space-between; /* İki uca yasla veya center */
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border-subtle);
}

/* Arama ve Butonlar için Alt Satır */
.header-tools-row {
  display: flex;
  width: 100%;
  gap: 8px;
  align-items: center;
}

.search-input-wrapper.new-style-search {
  flex-grow: 1; /* Kalan boşluğu doldur */
  width: auto; /* Genişliği serbest bırak */
}

/* Yeni Stil Arama Kutusu */
.search-input-wrapper.new-style-search {
  position: relative;
  flex-grow: 1 !important;
  width: auto !important;
  max-width: none !important; /* Sınırlamayı kaldır */
}

.search-input-wrapper.new-style-search i {
  position: absolute;
  left: calc(var(--spacing-unit) * 4);
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-tertiary);
  font-size: 1.05em;
}

.personalities-header .search-input-wrapper.new-style-search input[type="search"] {
  width: 100%;
  margin-bottom: 0;
  padding: calc(var(--spacing-unit) * 2.5) calc(var(--spacing-unit) * 3.5) calc(var(--spacing-unit) * 2.5) calc(var(--spacing-unit) * 10);
  /* İkon için sol padding artırıldı */
  border-radius: var(--radius-full);
  /* Tamamen yuvarlak kenarlar */
  background-color: var(--bg-elevated);
  /* Arka plan rengi değiştirildi */
  border-color: var(--border-input);
  font-size: var(--font-size-sm);
  transition: all var(--transition-fast);
}

.personalities-header .search-input-wrapper.new-style-search input[type="search"]:focus {
  border-color: var(--accent-primary);
  box-shadow: 0 0 0 2.5px color-mix(in srgb, var(--accent-primary) 22%, transparent);
  background-color: var(--bg-main);
  /* Odaklandığında arka planı aç */
}

/* Yeni Stil Butonlar */
.icon-button.new-style-button {
  width: 44px;
  /* Biraz daha büyük butonlar */
  height: 44px;
  font-size: 1.25rem;
  /* İkon boyutu artırıldı */
  background-color: var(--bg-elevated);
  color: var(--text-secondary);
  border: 1px solid var(--border-color);
  /* Hafif bir kenarlık */
  box-shadow: 0 2px 6px var(--shadow-soft);
  /* Hafif bir gölge */
}

.icon-button.new-style-button:hover {
  background-color: var(--bg-hover);
  color: var(--accent-primary);
  /* Vurgu rengi */
  border-color: var(--accent-primary);
}

.icon-button.new-style-button:active {
  transform: scale(0.95);
}

/* Batch Action Toolbar için küçük düzeltmeler (isteğe bağlı) */
#batchActionToolbar .button.small {
  padding: calc(var(--spacing-unit) * 2.5) calc(var(--spacing-unit) * 4);
  /* Batch butonlarının padding'i artırıldı */
  font-size: var(--font-size-sm);
  /* Daha okunaklı */
  gap: calc(var(--spacing-unit) * 1.5);
  /* İkon ve metin arası boşluk */
}

#batchActionToolbar .button.small i {
  font-size: 1em;
  /* İkon boyutu */
}


/* Responsive: Mobil cihazlar için */
@media (max-width: 600px) {
  .personalities-header {
    flex-direction: column;
    align-items: stretch;
    gap: calc(var(--spacing-unit) * 3);
  }

  .personalities-header h2 {
    text-align: center;
  }

  .personalities-header .header-actions-group {
    flex-direction: row;
    /* Mobil'de yatay kalabilir */
    justify-content: center;
    /* Ortala */
    width: 100%;
    gap: calc(var(--spacing-unit) * 2);
  }

  .search-input-wrapper.new-style-search {
    max-width: none;
    /* Mobil'de tam genişlik */
    flex-grow: 1;
  }

  .icon-button.new-style-button {
    flex-shrink: 0;
    /* Küçülmesini engelle */
  }

  #batchActionToolbar {
    padding: calc(var(--spacing-unit) * 2);
    gap: calc(var(--spacing-unit) * 2);
  }
}

/* === YENİ ANILAR (LOREBOOK) MODALI TASARIMI (V3) === */
#csMemoryModal .modal-scrollable-content {
  padding: calc(var(--spacing-unit) * 4);
  padding-top: calc(var(--spacing-unit) * 2);
}

#csLorebookItemsContainer {
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing-unit) * 3);
}

/* Tek bir anı kartı */
.lorebook-item-v2 {
  position: relative;
  background-color: var(--bg-content);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  transition: all var(--transition-fast);
  overflow: hidden;
  /* Animasyonlar için */
}

.lorebook-item-v2:hover {
  border-color: var(--accent-primary);
  background-color: var(--bg-hover);
}

/* Görüntüleme modu içeriği */
.lorebook-item-content {
  padding: calc(var(--spacing-unit) * 3.5) calc(var(--spacing-unit) * 4);
  cursor: pointer;
}

.lorebook-item-key {
  display: block;
  font-weight: 600;
  color: var(--accent-primary);
  font-size: var(--font-size-sm);
  margin-bottom: calc(var(--spacing-unit) * 1.5);
}

.lorebook-item-fact {
  color: var(--text-secondary);
  font-size: var(--font-size-base);
  line-height: 1.5;
}

/* Düzenleme modu içeriği (başlangıçta gizli) */
.lorebook-item-editor {
  display: none;
  flex-direction: column;
  gap: calc(var(--spacing-unit) * 2);
  padding: calc(var(--spacing-unit) * 3);
  background-color: var(--bg-main);
}

.lorebook-item-editor input[type="text"] {
  margin: 0;
}

/* Kart düzenleme modundayken stilleri değiştir */
.lorebook-item-v2.editing .lorebook-item-content {
  display: none;
}

.lorebook-item-v2.editing .lorebook-item-editor {
  display: flex;
}

/* Aksiyon butonları (başlangıçta gizli) */
.lorebook-item-actions {
  position: absolute;
  top: 50%;
  right: calc(var(--spacing-unit) * 2);
  transform: translateY(-50%);
  display: flex;
  gap: calc(var(--spacing-unit) * 1);
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.lorebook-item-v2:hover .lorebook-item-actions {
  opacity: 1;
}

.lorebook-item-v2.editing .lorebook-item-actions {
  display: none;
  /* Düzenleme modunda butonları gizle */
}



/* === GÖRSEL PROMPT GÖSTERİMİ (V3 - Gizli Altyazı Stili) === */
.image-prompt-display {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: calc(var(--spacing-unit) * 3) calc(var(--spacing-unit) * 3.5);
  background-color: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: #FFFFFF;
  font-size: var(--font-size-xs);
  line-height: 1.4;
  font-style: italic;

  /* Başlangıçta gizli ve altta */
  opacity: 0;
  transform: translateY(100%);
  transition: opacity 0.3s ease-out, transform 0.3s ease-out;
  pointer-events: none;
  /* Gizliyken tıklanamaz */

  /* Uzun prompt'ların en fazla 3 satır göstermesini sağlar */
  max-height: 60px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  text-overflow: ellipsis;
}

/* Fare üzerine gelince veya genişletildiğinde göster */
.message-image-wrapper:hover .image-prompt-display,
.message-image-wrapper.prompt-expanded .image-prompt-display {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  /* Görünürken tıklanabilir */
  cursor: pointer;
}

/* Tıklandığında prompt'u tamamen göster */
.message-image-wrapper.prompt-expanded .image-prompt-display {
  max-height: 300px;
  /* Genişletilmiş maksimum yükseklik */
  /* Satır sınırlamasını kaldır */
  overflow-y: auto;
}

/* Silme ve yeniden oluşturma butonlarını, altyazı alanının üstünde tutar */
.visualized-image-actions {
  z-index: 2;
  /* Prompt alanının üstünde kalmasını sağlar */
}

/* --- SOHBET ÖZELLEŞTİRME - DİNAMİK RENKLER === */
/* ============================================= */
/* Kaydedilen özel renkleri uygulamak için bu kurallar kullanılır */
.message.user {
  background-color: var(--dynamic-user-msg-bg, var(--bg-message-user));
  color: var(--dynamic-user-msg-text, var(--text-on-accent));
}

.message.assistant {
  background-color: var(--dynamic-assistant-msg-bg, var(--bg-message-assistant));
}

/* ================================================= */
/* === ADMIN PANEL STYLES (GOD MODE) === */
/* ================================================= */

.admin-badge-profile {
  background: linear-gradient(135deg, #ff0000 0%, #990000 100%);
  color: #fff;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: 0.7rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 1px;
  box-shadow: 0 0 10px rgba(255, 0, 0, 0.4);
  border: 1px solid rgba(255, 255, 255, 0.2);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

#adminHeaderBtn {
  color: #ff4757;
  margin-right: 5px;
  position: relative;
}

#adminHeaderBtn::after {
  content: '';
  position: absolute;
  top: 5px;
  right: 5px;
  width: 6px;
  height: 6px;
  background: #ff4757;
  border-radius: 50%;
  box-shadow: 0 0 5px #ff4757;
}

/* Admin Dashboard Grid */
.admin-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 15px;
  margin-bottom: 20px;
}

.admin-stat-card {
  background: var(--bg-content);
  border: 1px solid var(--border-color);
  border-radius: 16px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.admin-stat-number {
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--text-primary);
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto, sans-serif;
}

.admin-stat-label {
  font-size: 0.75rem;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Admin Action Lists */
.admin-action-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px;
  background: var(--bg-content);
  border-bottom: 1px solid var(--border-color);
}

.admin-action-row:first-child {
  border-top-left-radius: 12px;
  border-top-right-radius: 12px;
}

.admin-action-row:last-child {
  border-bottom: none;
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
}

.admin-section-title {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--accent-primary);
  margin: 20px 0 10px 5px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ============================================================= */
/* === AI GÖRSEL OLUŞTURMA MODALI VE YÜKLEME EFEKTİ === */
/* ============================================================= */

/* Önizleme ekranındaki yükleme efekti */
.cs-preview-loading-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 15px;
  color: var(--text-primary);
  z-index: 10;
  border-radius: var(--radius-lg);
  font-size: var(--font-size-sm);
  font-weight: 500;
}

.cs-preview-loading-overlay i {
  font-size: 1.8rem;
}

/* === YENİ MANUEL OLUŞTURMA FORMU STİLLERİ (CHARACTER.AI TARZI V2) === */

/* Ana Bölüm Ayarları (Kart görünümünden ayrıştırıcı çizgiye) */
#manualCreationTab .data-action-section {
  background-color: transparent;
  border: none;
  border-bottom: 1px solid var(--border-color);
  box-shadow: none;
  padding: calc(var(--spacing-unit) * 6) 0;
  /* Sadece dikey boşluk */
  margin-bottom: 0;
}

#manualCreationTab .data-action-section:last-of-type {
  border-bottom: none;
  /* Son bölümün altında çizgi olmasın */
  padding-bottom: 0;
}

/* Başlık Stili (Daha minimalist ve kategori belirten) */
#manualCreationTab .data-section-title {
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: calc(var(--spacing-unit) * 4);
  padding: 0;
  border-bottom: none;
  gap: calc(var(--spacing-unit) * 2.5);
}

#manualCreationTab .data-section-title i {
  color: var(--text-tertiary);
  font-size: 1.1em;
}

/* Her bir ayar öğesi için daha düzenli yapı */
#manualCreationTab .settings-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: calc(var(--spacing-unit) * 2);
  padding: calc(var(--spacing-unit) * 3) 0;
  border-bottom: 1px solid var(--border-input);
  margin: 0;
}

#manualCreationTab .settings-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

/* Grup içindeki ayarların üst padding'ini kaldır */
#manualCreationTab .data-action-section>.settings-item:first-of-type {
  padding-top: 0;
}


/* Etiket ve Açıklama Stilleri */
#manualCreationTab label:not(.switch) {
  font-size: var(--font-size-base);
  color: var(--text-primary);
  font-weight: 500;
  margin: 0;
}

#manualCreationTab .description {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
  line-height: 1.4;
  margin: 0;
}

/* Switch (toggle) içeren ayar öğeleri için özel hizalama */
#manualCreationTab .settings-item:has(.switch) {
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}

#manualCreationTab .settings-item:has(.switch) .description {
  margin-right: auto;
  padding-right: calc(var(--spacing-unit) * 4);
}

/* Switch'in solundaki metinleri gruplamak için */
#manualCreationTab .settings-item .label-group {
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing-unit) * 1);
}

/* Form elemanlarının altındaki boşlukları ayarla */
#manualCreationTab input,
#manualCreationTab textarea,
#manualCreationTab .select-wrapper {
  margin: 0;
  width: 100%;
}

/* İki sütunlu grup stili */
#manualCreationTab .create-form-group-inline {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: calc(var(--spacing-unit) * 4);
}

#manualCreationTab .create-form-group-inline>.settings-item {
  padding: 0;
  border: none;
}

/* Mobil için iki sütunlu grubu tek sütuna düşür */
@media (max-width: 600px) {
  #manualCreationTab .create-form-group-inline {
    grid-template-columns: 1fr;
  }
}

/* Başlangıç Mesajı Pill Butonları */
#manualCreationTab .settings-item .pills-selector-container {
  display: flex;
  gap: calc(var(--spacing-unit) * 2);
  width: 100%;
}

#manualCreationTab .settings-item .pills-selector-container .pill-button {
  flex: 1;
  text-align: center;
  justify-content: center;
}

/* --- SONSUZ KAYDIRMA YÜKLEYİCİSİ --- */
#infiniteScrollLoader {
  width: 100%;
  height: 50px;
  display: none;
  /* Varsayılan gizli */
  align-items: center;
  justify-content: center;
  color: var(--accent-primary);
  font-size: 1.2rem;
  margin-top: 20px;
  padding-bottom: 80px;
  /* Footer'ın altında kalmaması için */
}

#infiniteScrollLoader.visible {
  display: flex;
}

#infiniteScrollLoader i {
  animation: spin_v10 1s linear infinite;
}

.image-upload-dropzone {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 120px;
  border: 2px dashed var(--border-input);
  border-radius: var(--radius-md);
  background-color: var(--bg-content);
  cursor: pointer;
  transition: all var(--transition-fast);
  padding: var(--spacing-unit);
  overflow: hidden;
  /* Önizleme resminin taşmasını engeller */
}

.image-upload-dropzone:hover {
  border-color: var(--accent-primary);
  background-color: var(--bg-hover);
}

.image-upload-dropzone .dropzone-prompt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(var(--spacing-unit) * 2);
  color: var(--text-tertiary);
  text-align: center;
}

.image-upload-dropzone .dropzone-prompt i {
  font-size: 2rem;
}

.image-upload-dropzone .dropzone-prompt span {
  font-size: var(--font-size-sm);
  font-weight: 500;
}

/* Yüklendikten sonraki önizleme stilleri */
.image-upload-dropzone img {
  width: 100%;
  height: 100%;
  max-height: 150px;
  /* Önizlemenin çok büyümesini engeller */
  object-fit: contain;
  /* Resmin tamamı görünsün */
  border-radius: var(--radius-sm);
}

.image-upload-dropzone .delete-preview {
  position: absolute;
  top: 8px;
  right: 8px;
  background: rgba(0, 0, 0, 0.6);
  color: white;
  border: none;
  border-radius: 50%;
  width: 28px;
  height: 28px;
  font-size: 16px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  backdrop-filter: blur(4px);
  transition: all var(--transition-fast);
}

.image-upload-dropzone .delete-preview:hover {
  background-color: var(--accent-red);
  transform: scale(1.1);
}

/* --- BOŞLUK DÜZELTMESİ (Jilet Gibi Tasarım) --- */

/* Header alt boşluğunu sıfırla */
.personalities-header {
  margin-bottom: 8px !important;
  /* 10px'ten 8px'e düştü */
  padding-bottom: 0 !important;
  border: none !important;
}

/* Arama çubuğunun altındaki görünmez marginleri sil */
.search-input-wrapper.new-style-search {
  margin-bottom: 0 !important;
}

/* Grid (Kartlar) konteynerinin üst boşluğunu al */
.personalities-grid-container {
  gap: 12px !important;
  /* Kartlar arası boşluk */
  margin-top: 0 !important;
}

.personalities-grid {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* --- KALICI EASTER EGG EFEKTLERİ --- */

/* 1. Gökkuşağı Modu (Sürekli Renk Değiştirir) */
.perm-rainbow {
  background: linear-gradient(45deg, #ff0000, #ff7300, #fffb00, #48ff00, #00ffd5, #002bff, #7a00ff, #ff00c8, #ff0000);
  background-size: 400%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: glowing-rainbow 20s linear infinite;
  font-weight: 900 !important;
}

@keyframes glowing-rainbow {
  0% {
    background-position: 0 0;
  }

  50% {
    background-position: 400% 0;
  }

  100% {
    background-position: 0 0;
  }
}

/* 2. Ters Dönmüş Dünya (Kalıcı Ters) */
.perm-flip {
  transform: rotate(180deg);
  display: inline-block;
}

/* 3. Matrix / Glitch (Bozuk Görüntü) */
.perm-glitch {
  animation: glitch-skew 1s cubic-bezier(0.25, 0.46, 0.45, 0.94) infinite both infinite;
  color: #00FF00 !important;
  /* Matrix yeşili */
  font-family: 'Courier New', monospace !important;
  text-shadow: 2px 0 #FF0000, -2px 0 #0000FF;
}

@keyframes glitch-skew {
  0% {
    transform: translate(0)
  }

  20% {
    transform: translate(-2px, 2px)
  }

  40% {
    transform: translate(-2px, -2px)
  }

  60% {
    transform: translate(2px, 2px)
  }

  80% {
    transform: translate(2px, -2px)
  }

  100% {
    transform: translate(0)
  }
}

/* 4. Hayalet Modu (Yarı Saydam ve Uçuşan) */
.perm-ghost {
  opacity: 0.5;
  animation: float-ghost 3s ease-in-out infinite;
  color: #fff !important;
  text-shadow: 0 0 10px #fff;
}

@keyframes float-ghost {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-10px);
  }
}

/* === AYARLAR PANELİ İYİLEŞTİRMELERİ (GÖRSEL SEKMESİ) === */

/* Paneldeki kart yapısını sıkılaştır */
#panel-image-settings .settings-group-card {
  padding: calc(var(--spacing-unit) * 4);
  border: 1px solid var(--border-color);
  background: var(--bg-elevated);
}

/* Başlık ve ikon hizalaması */
#panel-image-settings h3 {
  margin-bottom: calc(var(--spacing-unit) * 2);
  color: var(--text-primary);
  font-size: 1.1rem;
}

/* Grid yapılı hap butonlar (Daha düzgün sıralama) */
.pills-selector-container.grid-pills {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 10px;
  margin-top: 8px;
}

.pills-selector-container.grid-pills .pill-button {
  width: 100%;
  text-align: center;
  justify-content: center;
  padding: 10px 5px;
  font-size: 0.85rem;
  background-color: var(--bg-content);
  border: 1px solid var(--border-input);
  border-radius: 12px;
  /* Daha modern köşeler */
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 6px;
}

.pills-selector-container.grid-pills .pill-button:hover {
  border-color: var(--accent-primary);
  background-color: var(--bg-hover);
}

.pills-selector-container.grid-pills .pill-button.active {
  background-color: var(--accent-primary);
  color: var(--text-on-accent);
  border-color: var(--accent-primary);
  font-weight: 600;
  box-shadow: 0 4px 12px color-mix(in srgb, var(--accent-primary) 30%, transparent);
}

/* Select kutularını güzelleştir */
#panel-image-settings .select-wrapper select {
  padding: 12px 16px;
  border-radius: 12px;
  background-color: var(--bg-content);
  font-size: 0.9rem;
}

/* Açıklama metinleri */
#panel-image-settings .description {
  color: var(--text-secondary);
  font-size: 0.8rem;
  line-height: 1.4;
}

/* === GELİŞMİŞ GÖRÜNÜM MODALI STİLLERİ === */
.style-grid-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.style-option-card {
  background-color: var(--bg-main);
  border: 2px solid var(--border-color);
  border-radius: 12px;
  padding: 10px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  transition: all 0.2s ease;
}

.style-option-card:hover {
  transform: translateY(-2px);
  border-color: var(--text-tertiary);
}

.style-option-card.active {
  border-color: var(--accent-primary);
  background-color: color-mix(in srgb, var(--accent-primary) 10%, var(--bg-main));
  box-shadow: 0 4px 12px color-mix(in srgb, var(--accent-primary) 20%, transparent);
}

.style-name {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-secondary);
}

.style-option-card.active .style-name {
  color: var(--accent-primary);
}

/* Küçük Önizleme Balonları */
.style-preview {
  width: 100%;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  border-radius: 8px;
  background-color: var(--bg-hover);
  /* Varsayılan */
  color: var(--text-primary);
}

/* Önizleme Stilleri (Özel) */
.preview-default {
  border-radius: 8px;
  border-bottom-left-radius: 0;
  background: var(--bg-hover);
}

.preview-book {
  background: transparent;
  font-family: 'Georgia', serif;
  font-style: italic;
  border-bottom: 1px solid var(--text-secondary);
  border-radius: 0;
}

.preview-glass {
  background: var(--bg-hover);
  border: 1px solid var(--border-color);
}

.preview-rounded {
  border-radius: 20px;
  background: var(--bg-hover);
}

.preview-sharp {
  border-radius: 2px;
  background: var(--bg-hover);
}

.preview-ios {
  background: #007AFF;
  color: white;
  border-radius: 12px;
}

.preview-whatsapp {
  background: #dcf8c6;
  color: #000;
  border-radius: 8px;
}

.dark-theme .preview-whatsapp {
  background: #005c4b;
  color: #fff;
}

.preview-neon {
  background: #000;
  border: 1px solid #0ff;
  color: #0ff;
  box-shadow: 0 0 5px #0ff;
}

.preview-terminal {
  background: #000;
  color: #0f0;
  font-family: monospace;
  border: 1px solid #0f0;
}

.preview-minimal {
  background: transparent;
  border-left: 2px solid var(--text-secondary);
  padding-left: 5px;
  justify-content: flex-start;
}

/* === MODERN FONT SEÇİM EKRANI STİLLERİ === */

/* Canlı Önizleme Kutusu */
.font-live-preview-box {
  background-color: var(--bg-main);
  border: 1px solid var(--border-color);
  border-radius: 16px;
  padding: 30px 20px;
  text-align: center;
  margin-bottom: 20px;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 120px;
  box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.05);
}

.preview-text-large {
  font-size: 2rem;
  line-height: 1.2;
  margin-bottom: 10px;
  color: var(--text-primary);
}

.preview-font-name {
  font-size: 0.85rem;
  color: var(--text-secondary);
  background-color: var(--bg-elevated);
  padding: 4px 12px;
  border-radius: 20px;
  border: 1px solid var(--border-color);
}

/* Font Izgarası */
.font-selection-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  /* 2 Sütunlu */
  gap: 12px;
  padding-bottom: 10px;
}

.font-option-card {
  background-color: var(--bg-elevated);
  border: 1px solid var(--border-color);
  border-radius: 14px;
  padding: 15px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  position: relative;
  overflow: hidden;
}

.font-option-card:hover {
  transform: translateY(-2px);
  background-color: var(--bg-hover);
  border-color: var(--text-tertiary);
}

.font-option-card.active {
  border-color: var(--accent-primary);
  background-color: color-mix(in srgb, var(--accent-primary) 8%, var(--bg-elevated));
  box-shadow: 0 4px 12px color-mix(in srgb, var(--accent-primary) 20%, transparent);
}

/* Seçili tik işareti */
.font-option-card.active::after {
  content: '\f00c';
  /* FontAwesome Check */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  top: 5px;
  right: 8px;
  font-size: 0.8rem;
  color: var(--accent-primary);
}

.font-card-preview {
  font-size: 1.4rem;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.font-card-name {
  font-size: 0.75rem;
  color: var(--text-secondary);
  font-weight: 500;
}

.cai-bottom-grid-menu-overlay {
    position: fixed !important;
    inset: 0 !important;
    background-color: rgba(0, 0, 0, 0.7) !important; /* Arka planı biraz daha kararttık */
    z-index: 5000 !important; /* Mesaj kutusunun çok üstüne çıkardık */
    display: none;
    flex-direction: column;
    justify-content: flex-end;
    backdrop-filter: blur(8px) !important; /* Arkadaki mesaj kutusunu bulanıklaştırır */
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease;
}

.cai-bottom-grid-menu-overlay.active {
  display: flex !important;
  opacity: 1;
  visibility: visible;
}

.cai-bottom-grid-menu {
    background-color: #121214 !important; /* Tam mat bir renk ver, saydam olmasın */
    backdrop-filter: blur(25px) saturate(180%) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-top-left-radius: 32px;
    border-top-right-radius: 32px;
    padding: 24px;
    padding-bottom: calc(30px + env(safe-area-inset-bottom));
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    width: 100%;
}

.cai-bottom-grid-menu-overlay.active .cai-bottom-grid-menu {
  transform: translateY(0);
}

.cai-grid-menu-items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.cai-grid-item {
  /* Kartları da hafif şeffaf yaparak derinlik kazandırdık */
  background-color: rgba(255, 255, 255, 0.03) !important;
  border-radius: 20px;
  padding: 16px 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
  
  /* Kenarlıkları temaya uyumlu hale getirdik */
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  min-height: 100px;
  position: relative;
  box-shadow: none;
}

/* Tıklama efekti */
.cai-grid-item:active {
  transform: scale(0.92);
  background-color: rgba(255, 255, 255, 0.08) !important;
}

/* Beyaz Tema Uyumu */
body.light-theme .cai-bottom-grid-menu {
  background-color: rgba(255, 255, 255, 0.8) !important;
  border-top: 1px solid rgba(0, 0, 0, 0.05) !important;
}

body.light-theme .cai-grid-item {
  background-color: rgba(0, 0, 0, 0.03) !important;
  border: 1px solid rgba(0, 0, 0, 0.05) !important;
}

.cai-grid-item:active {
  transform: scale(0.96);
  background-color: var(--bg-hover);
}

.cai-grid-item i {
  font-size: 1.8rem;
  color: var(--accent-primary);
}

.cai-grid-item span {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: center;
}

/* Özel Renklendirmeler (Fotoğraftaki gibi) */
.cai-grid-item.feature-memory i {
  color: #A0C4FF;
}

/* Hafıza - Mavi */
.cai-grid-item.feature-history i {
  color: #BDB2FF;
}

/* Geçmiş - Mor */
.cai-grid-item.feature-voice i {
  color: #FFC6FF;
}

/* Ses - Pembe */
.cai-grid-item.feature-edit i {
  color: #FDFFB6;
}

/* Düzen - Sarı */
.cai-grid-item.feature-wallpaper i {
  color: #CAFFBF;
}

/* Duvar Kağıdı - Yeşil */
.cai-grid-item.feature-persona i {
  color: #FFADAD;
}

/* Kişilik - Kırmızımsı */
.cai-grid-item.feature-imagine i {
  color: #9BF6FF;
}

/* Hayal Et - Cyan */

/* Beyaz Temada Daha Belirgin İkonlar */
body.light-theme .cai-grid-item.feature-memory i {
  color: #0056b3;
}

body.light-theme .cai-grid-item.feature-history i {
  color: #6f42c1;
}

body.light-theme .cai-grid-item.feature-voice i {
  color: #d63384;
}

body.light-theme .cai-grid-item.feature-edit i {
  color: #856404;
}

body.light-theme .cai-grid-item.feature-wallpaper i {
  color: #198754;
}

body.light-theme .cai-grid-item.feature-persona i {
  color: #b21f2d;
}

body.light-theme .cai-grid-item.feature-imagine i {
  color: #087990;
}


/* --- KULLANICI KİŞİLİK (PERSONA) SİSTEMİ CSS --- */
.user-persona-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 10px 0;
}

.user-persona-card {
  display: flex;
  align-items: center;
  background-color: var(--bg-content);
  border: 1px solid var(--border-color);
  border-radius: 16px;
  padding: 12px;
  cursor: pointer;
  transition: all 0.2s;
}

.user-persona-card.selected {
  border-color: var(--accent-primary);
  background-color: color-mix(in srgb, var(--accent-primary) 10%, var(--bg-content));
  box-shadow: 0 0 0 2px var(--accent-primary);
}

.user-persona-avatar {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  object-fit: cover;
  margin-right: 15px;
  background-color: var(--bg-elevated);
}

.user-persona-info {
  flex: 1;
}

.user-persona-name {
  font-weight: 700;
  color: var(--text-primary);
  font-size: 0.95rem;
  margin-bottom: 2px;
}

.user-persona-desc {
  font-size: 0.8rem;
  color: var(--text-secondary);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.user-persona-edit-btn {
  padding: 8px;
  color: var(--text-tertiary);
  background: transparent;
  border: none;
  font-size: 1rem;
}

/* Outfit (Kombin) Grid */
.persona-outfit-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.outfit-item {
  aspect-ratio: 1/1;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  cursor: pointer;
  border: 2px solid transparent;
}

.outfit-item.active {
  border-color: var(--accent-primary);
}

.outfit-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* === MODERN RESPONSIVE CHARACTER SELECTOR UI (V4) === */
#create-initial-selection {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    height: 100%;
    padding: 20px;
    overflow-y: auto; /* Mobilde aşağı kayabilsin */
    background: transparent !important;
    box-sizing: border-box;
}

#create-initial-selection h2 {
    font-size: 1.8rem;
    font-weight: 900;
    color: var(--text-primary);
    margin-bottom: 25px;
    margin-top: 10px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.creation-carousel-container {
    display: flex;
    flex-direction: column; /* Mobilde dikey liste */
    gap: 16px;
    width: 100%;
    max-width: 500px; /* PC'de çok yayılmasın */
    padding-bottom: 20px;
}

@media (min-width: 769px) {
    .creation-carousel-container {
        flex-direction: row; /* Masaüstünde yatay */
        max-width: 1000px;
        justify-content: center;
        padding: 40px 0;
    }
}

.creation-card-v2 {
    width: 100%;
    background: var(--bg-elevated);
    border-radius: 24px;
    display: flex;
    flex-direction: row; /* Mobilde yan yana ikon ve metin */
    align-items: center;
    padding: 20px;
    border: 1px solid var(--border-color);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    position: relative;
}

@media (min-width: 769px) {
    .creation-card-v2 {
        flex-direction: column; /* Masaüstünde dikey kart */
        width: 280px;
        height: 380px;
        text-align: center;
        padding: 40px 20px;
    }
}

.creation-card-v2.active {
    border-color: var(--accent-primary);
    background: color-mix(in srgb, var(--accent-primary) 10%, var(--bg-elevated));
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
    transform: scale(1.02);
}

.creation-card-avatar {
    width: 60px;
    height: 60px;
    border-radius: 16px;
    background: var(--bg-main);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 20px; /* Mobilde metinle arasına boşluk */
    flex-shrink: 0;
    font-size: 1.8rem;
    border: 1px solid var(--border-color);
}

@media (min-width: 769px) {
    .creation-card-avatar {
        width: 100px;
        height: 100px;
        margin-right: 0;
        margin-bottom: 20px;
        border-radius: 50%;
        font-size: 3rem;
    }
}

.creation-card-avatar i { color: var(--text-primary); }

.creation-card-info {
    flex: 1;
    text-align: left;
}

@media (min-width: 769px) {
    .creation-card-info {
        text-align: center;
    }
}

.creation-card-title {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.creation-card-subtitle {
    font-size: 0.8rem;
    color: var(--text-secondary);
    line-height: 1.3;
}

.creation-select-btn-fixed {
    width: 100%;
    max-width: 320px;
    min-height: 56px;
    background: #ffffff;
    color: #000000;
    border-radius: 16px;
    font-size: 1.1rem;
    font-weight: 800;
    border: none;
    margin: 20px 0 40px 0;
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: 0 8px 20px rgba(0,0,0,0.2);
    flex-shrink: 0;
}

.creation-select-btn-fixed:hover {
    background: #f0f0f0;
    transform: translateY(-2px);
}

.creation-select-btn-fixed:active {
    transform: scale(0.96);
}

.create-selection-card:active {
  transform: scale(0.98);
}

.create-selection-card .icon-wrapper {
  width: 50px;
  height: 50px;
  border-radius: 14px;
  background-color: var(--bg-content);
  color: var(--text-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  margin-right: 20px;
  flex-shrink: 0;
  border: 1px solid var(--border-input);
}

/* 2. Form Yapısı (Hizalama Düzeltildi) */
.create-form-container {
  width: 100% !important; /* vw yerine %100 kullanılarak kayma engellendi */
  max-width: 100% !important;
  margin: 0 auto !important;
  height: 100% !important;
  min-height: 100dvh !important;
  padding: 0 20px !important; /* Boşluklar doğrudan buraya eklendi */
  padding-bottom: 140px !important; /* Alt bar için güvenli alan */
  box-sizing: border-box !important; /* Padding'in genişliği bozması engellendi */
  animation: slideUp_v10 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  overflow-x: hidden !important;
  overflow-y: auto !important;
  display: block !important;
  background-color: var(--bg-main) !important;
}

/* Gereksiz wrapper padding'i kaldırıldı */
.create-form-container > div {
    padding-left: 0;
    padding-right: 0;
}

/* Header özel ayarı */
.emochi-header {
    padding: 15px 0 !important; /* Container zaten paddingli olduğu için 0 yapıldı */
    width: 100% !important;
    box-sizing: border-box !important;
}

.emochi-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  padding-top: 5px;
  /* Daha az boşluk */
  position: sticky;
  top: 0;
  background: var(--bg-main);
  z-index: 10;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border-color);
  /* Ayrım çizgisi eklendi */
}

/* ... Diğer stiller ... */

/* 4. Görsel Yükleme (Odak Butonu ve Overlay) */
.visual-upload-box {
  flex: 1;
  aspect-ratio: 3/4;
  background-color: var(--bg-elevated);
  border-radius: 16px;
  position: relative;
  overflow: hidden;
  border: 2px dashed var(--border-color);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.visual-upload-box.has-image {
  border-style: solid;
  border-color: transparent;
}

.visual-upload-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
  z-index: 0;
  display: none;
}

.visual-upload-box.has-image img {
  display: block;
}

/* Resim yüklense bile yazının görünmesi için karartma katmanı */
.visual-upload-box.has-image::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  /* Yarı saydam siyah */
  z-index: 1;
}

.visual-content {
  z-index: 2;
  color: var(--text-tertiary);
  text-align: center;
  pointer-events: none;
  position: relative;
  transition: color 0.2s;
}

/* Resim varsa yazı rengini beyaz yap */
.visual-upload-box.has-image .visual-content {
  color: #fff;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8);
}

.visual-content i {
  font-size: 1.5rem;
  margin-bottom: 5px;
  display: block;
}

.visual-content span {
  font-size: 0.75rem;
  font-weight: 600;
}

/* ODAK BUTONU */
.visual-focus-btn {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.3);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 5;
  cursor: pointer;
  backdrop-filter: blur(4px);
  font-size: 0.9rem;
  transition: transform 0.2s;
}

.visual-focus-btn:hover {
  background: var(--accent-primary);
  border-color: var(--accent-primary);
}

.visual-upload-box.has-image .visual-focus-btn {
  display: flex;
}

/* 6. Kaydet Butonu (Tema Rengi) */
.emochi-submit-btn {
  background-color: var(--accent-primary);
  /* Tema rengi */
  color: var(--text-on-accent);
  width: 100%;
  padding: 16px;
  border-radius: 50px;
  font-size: 1.1rem;
  font-weight: 800;
  border: none;
  cursor: pointer;
  margin-top: 20px;
  box-shadow: 0 4px 15px color-mix(in srgb, var(--accent-primary) 40%, transparent);
}

/* AI Seçim Modalı (Avatar/Background) */
#aiTypeSelectionModal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 85%;
  max-width: 300px;
  background: var(--bg-elevated);
  padding: 20px;
  border-radius: 20px;
  z-index: 10001;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
  display: none;
  border: 1px solid var(--border-color);
  text-align: center;
  animation: popIn_v10 0.2s ease;
}

#aiTypeSelectionModal.active {
  display: block;
}

#aiTypeSelectionModal h3 {
  margin-top: 0;
  margin-bottom: 15px;
  font-size: 1.1rem;
}

.ai-type-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 14px;
  margin-bottom: 10px;
  background: var(--bg-content);
  border: 1px solid var(--border-input);
  border-radius: 12px;
  color: var(--text-primary);
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}

.ai-type-btn:hover {
  background: var(--bg-hover);
  border-color: var(--accent-primary);
}

/* Preview Modal Düzeltme */
#createPreviewModal {
  background: var(--bg-main);
  /* Siyah değil tema rengi */
}

.preview-btn.confirm {
  background: var(--accent-primary);
  color: var(--text-on-accent);
}

.emochi-header h2 {
  font-size: 1.3rem;
  font-weight: 800;
  margin: 0;
}

.emochi-close-btn {
  background: transparent;
  border: none;
  width: 40px;
  height: 40px;
  color: var(--text-primary);
  font-size: 1.4rem;
  cursor: pointer;
}

/* 3. Input Grupleri ve Sayaçlar */
.emochi-input-group {
  margin-bottom: 24px;
  position: relative;
}

.emochi-label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--text-secondary);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.char-counter {
  font-size: 0.75rem;
  color: var(--text-tertiary);
  font-weight: 400;
}

.emochi-input,
.emochi-textarea {
  width: 100%;
  background-color: var(--bg-elevated);
  border: 1px solid transparent;
  border-radius: 16px;
  padding: 16px;
  font-size: 1rem;
  color: var(--text-primary);
  font-family: var(--font-primary);
  transition: all 0.2s;
}

.emochi-textarea {
  resize: none;
  min-height: 120px;
  line-height: 1.5;
}

.emochi-input:focus,
.emochi-textarea:focus {
  background-color: var(--bg-content);
  border-color: var(--accent-primary);
  outline: none;
}

/* Hoş Geldin Mesajı Özel Alanı */
.welcome-msg-wrapper {
  position: relative;
}

.welcome-msg-ai-btn {
  position: absolute;
  top: 12px;
  right: 12px;
  background: var(--bg-content);
  border: 1px solid var(--accent-primary);
  color: var(--accent-primary);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.9rem;
  z-index: 5;
  transition: all 0.2s;
}

.welcome-msg-ai-btn:hover {
  background: var(--accent-primary);
  color: #fff;
}

/* 4. Görsel Yükleme (Yan Yana) */
.emochi-visuals-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.ai-image-trigger-btn {
  font-size: 0.8rem;
  color: var(--accent-primary);
  font-weight: 600;
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
}

.emochi-visuals-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 24px;
  width: 100%;
  box-sizing: border-box;
}

.visual-upload-box {
  width: 100%;
  aspect-ratio: 1 / 1;
  /* Kareye yakın, daha dengeli */
  background-color: var(--bg-elevated);
  border-radius: 16px;
  position: relative;
  overflow: hidden;
  border: 2px dashed var(--border-color);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: border-color 0.2s;
}

.visual-upload-box.has-image {
  border-style: solid;
  border-color: var(--accent-primary);
}

.visual-upload-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
  z-index: 1;
  display: none;
}

.visual-upload-box.has-image img {
  display: block;
}

.visual-content {
  z-index: 2;
  color: var(--text-tertiary);
  text-align: center;
  pointer-events: none;
}

.visual-content i {
  font-size: 1.5rem;
  margin-bottom: 5px;
  display: block;
}

.visual-content span {
  font-size: 0.75rem;
  font-weight: 600;
}

/* 5. Seçim Butonları (Chips - Modernize Edildi) */
.selection-chips-container {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 5px;
}

.selection-chip {
  padding: 12px 20px;
  background-color: #1a1a1a;
  /* Koyu gri */
  border: 1px solid #333;
  border-radius: 50px;
  font-size: 0.9rem;
  font-weight: 500;
  color: #888;
  cursor: pointer;
  transition: all 0.2s;
  user-select: none;
  flex-grow: 1;
  text-align: center;
  min-width: 80px;
}

.selection-chip:hover {
  border-color: #555;
  background-color: #222;
}

.selection-chip.selected {
  background-color: var(--accent-primary);
  /* Vurgu rengi (Mavi/Mor vb.) */
  color: #fff;
  /* Beyaz yazı */
  border-color: var(--accent-primary);
  font-weight: 700;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
}

/* 6. Kaydet Butonu */
.emochi-submit-btn {
  background-color: #FFD700;
  /* Emochi Sarısı */
  color: #000;
  width: 100%;
  padding: 16px;
  border-radius: 50px;
  font-size: 1.1rem;
  font-weight: 800;
  border: none;
  cursor: pointer;
  margin-top: 20px;
  box-shadow: 0 4px 15px rgba(255, 215, 0, 0.3);
}

/* 7. AI Image Popup */
#aiImageMiniPopup {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 350px;
  background: var(--bg-elevated);
  padding: 20px;
  border-radius: 20px;
  z-index: 10000;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
  display: none;
  border: 1px solid var(--border-color);
}

#aiImageMiniPopup.active {
  display: block;
  animation: popIn_v10 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.mini-popup-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 9999;
  display: none;
  backdrop-filter: blur(3px);
}

.mini-popup-overlay.active {
  display: block;
}

/* 8. Preview Modal (Tam Ekran Önizleme) */
#createPreviewModal {
  position: fixed;
  inset: 0;
  background: #000;
  z-index: 11000;
  display: none;
  flex-direction: column;
}

#createPreviewModal.active {
  display: flex;
  animation: fadeIn_v10 0.3s ease;
}

.preview-bg-layer {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0.4;
}

.preview-content-layer {
  position: relative;
  z-index: 1;
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 20px;
  justify-content: flex-end;
  background: linear-gradient(to top, rgba(0, 0, 0, 1) 10%, transparent 80%);
}

.preview-avatar {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid #fff;
  margin-bottom: 15px;
  align-self: flex-start;
}

.preview-bubble {
  background: #2e2e2e;
  color: #fff;
  padding: 15px;
  border-radius: 18px;
  border-bottom-left-radius: 4px;
  margin-bottom: 30px;
  font-size: 0.95rem;
  line-height: 1.5;
  border: 1px solid rgba(255, 255, 255, 0.1);
  max-height: 40vh;
  overflow-y: auto;
}

.preview-name {
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: 5px;
}

.preview-actions {
  display: flex;
  gap: 10px;
  margin-top: auto;
  width: 100%;
}

.preview-btn {
  flex: 1;
  padding: 15px;
  border-radius: 50px;
  font-weight: 700;
  border: none;
  cursor: pointer;
}

.preview-btn.cancel {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

.preview-btn.confirm {
  background: #FFD700;
  color: #000;
}

/* Helper Classes */
.hidden {
  display: none !important;
}


/* ================================================= */
/* === ÖZEL TYPING (YAZIYOR) ANİMASYONLARI === */
/* ================================================= */

/* --- 1. RYUKO TEMASI: ATAN KALPLER --- */
body.ryuko-theme #thinkingIndicator {
  background-color: rgba(45, 20, 30, 0.9) !important;
  border: 1px solid var(--accent-primary) !important;
  box-shadow: 0 0 15px rgba(255, 105, 180, 0.3);
  gap: 8px;
  /* Kalpler arası boşluk */
}

/* Noktaları Kalbe Dönüştür */
body.ryuko-theme #thinkingIndicator>div {
  width: 14px;
  height: 14px;
  background-color: transparent !important;
  /* Eski nokta rengini sil */
  border-radius: 0 !important;
  /* Yuvarlaklığı kaldır */

  /* Kalp İkonu */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23ff4081'%3E%3Cpath d='M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;

  /* Yeni Animasyon */
  animation: ryukoTyping 1s infinite ease-in-out both !important;
}

/* Sıralı Animasyon Gecikmeleri */
body.ryuko-theme #thinkingIndicator>div:nth-child(1) {
  animation-delay: 0s !important;
}

body.ryuko-theme #thinkingIndicator>div:nth-child(2) {
  animation-delay: 0.2s !important;
}

body.ryuko-theme #thinkingIndicator>div:nth-child(3) {
  animation-delay: 0.4s !important;
}

@keyframes ryukoTyping {

  0%,
  100% {
    transform: scale(0.8);
    opacity: 0.5;
  }

  50% {
    transform: scale(1.3);
    opacity: 1;
    filter: drop-shadow(0 0 5px #ff4081);
  }
}

/* --- 2. MOONLIGHT TEMASI: PARLAYAN YILDIZLAR --- */
body.moonlight-theme #thinkingIndicator {
  background-color: rgba(10, 15, 30, 0.9) !important;
  border: 1px solid var(--accent-primary) !important;
  box-shadow: 0 0 15px rgba(100, 100, 255, 0.3);
}

body.moonlight-theme #thinkingIndicator>div {
  background-color: transparent !important;
  width: 16px;
  height: 16px;
  border-radius: 0 !important;

  /* Yıldız İkonu */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23818cf8'%3E%3Cpath d='M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;

  animation: moonlightTyping 1.2s infinite linear !important;
}

/* Moonlight için Gecikmeler */
body.moonlight-theme #thinkingIndicator>div:nth-child(1) {
  animation-delay: 0s !important;
}

body.moonlight-theme #thinkingIndicator>div:nth-child(2) {
  animation-delay: 0.3s !important;
}

body.moonlight-theme #thinkingIndicator>div:nth-child(3) {
  animation-delay: 0.6s !important;
}

@keyframes moonlightTyping {
  0% {
    transform: translateY(0) rotate(0deg);
    opacity: 0.4;
  }

  50% {
    transform: translateY(-5px) rotate(180deg);
    opacity: 1;
  }

  100% {
    transform: translateY(0) rotate(360deg);
    opacity: 0.4;
  }
}

/* ================================================= */
/* === YENİ PREMIUM TEMALAR (V5 PAKETİ) === */
/* ================================================= */

/* 1. LUXURY GOLD (Lüks Altın & Siyah) */
body.luxury-gold-active {
  --bg-main: #080808;
  --bg-content: #121212;
  --bg-elevated: #1c1c1c;
  --bg-elevated-transparent: rgba(20, 20, 20, 0.95);
  --text-primary: #e6c200;
  /* Altın */
  --text-secondary: #b39ddb;
  --text-tertiary: #666;
  --text-on-accent: #000000;
  --accent-primary: #ffd700;
  /* Saf Altın */
  --accent-secondary: #c0c0c0;
  /* Gümüş */
  --border-color: #333;
  --border-input: #2a2a2a;
  --bg-message-user: #b8860b;
  /* Koyu Altın */
  --bg-message-assistant: rgba(28, 28, 28, 0.9);
  --bg-message-assistant-blur: 5px;
  --modal-overlay: rgba(0, 0, 0, 0.9);
  background-image: repeating-linear-gradient(45deg, #111 0, #111 10px, #080808 10px, #080808 20px);
}

/* 2. SUNSET VIBES (Gün Batımı - Turuncu/Mor) */
body.sunset-vibes-active {
  --bg-main: #2d1b4e;
  --bg-content: #432c7a;
  --bg-elevated: #5b3a91;
  --bg-elevated-transparent: rgba(67, 44, 122, 0.85);
  --text-primary: #ffd1dc;
  --text-secondary: #ffadbc;
  --accent-primary: #ff9f1c;
  /* Turuncu */
  --accent-secondary: #ff4081;
  /* Pembe */
  --border-color: #6c4ba8;
  --bg-message-user: #ff6b6b;
  --bg-message-assistant: rgba(80, 50, 130, 0.7);
  background: linear-gradient(to bottom, #2d1b4e, #ff9f1c);
  background-attachment: fixed;
}

/* 3. COFFEE BREAK (Sıcak Kahve Tonları) */
body.coffee-break-active {
  --bg-main: #3e2723;
  --bg-content: #4e342e;
  --bg-elevated: #5d4037;
  --bg-elevated-transparent: rgba(78, 52, 46, 0.9);
  --text-primary: #efebe9;
  --text-secondary: #d7ccc8;
  --accent-primary: #8d6e63;
  /* Sütlü Kahve */
  --accent-secondary: #a1887f;
  --text-on-accent: #fff;
  --border-color: #795548;
  --bg-message-user: #6d4c41;
  --bg-message-assistant: rgba(93, 64, 55, 0.8);
  background-color: #3e2723;
}

/* 4. MIDNIGHT PURPLE (Derin Mor) */
body.midnight-purple-active {
  --bg-main: #10002b;
  --bg-content: #240046;
  --bg-elevated: #3c096c;
  --bg-elevated-transparent: rgba(36, 0, 70, 0.9);
  --text-primary: #e0aaff;
  --text-secondary: #c77dff;
  --accent-primary: #9d4edd;
  --text-on-accent: #fff;
  --border-color: #5a189a;
  --bg-message-user: #7b2cbf;
  --bg-message-assistant: rgba(60, 9, 108, 0.8);
  background: radial-gradient(circle, #240046 0%, #10002b 100%);
}

/* 5. RETRO TERMINAL (Yeşil/Siyah Hacker - Matrix Temasına Alternatif) */
body.retro-terminal-active {
  --bg-main: #000000;
  --bg-content: #0a0a0a;
  --bg-elevated: #111;
  --bg-elevated-transparent: rgba(10, 10, 10, 0.95);
  --text-primary: #33ff00;
  --text-secondary: #22cc00;
  --text-tertiary: #118800;
  --text-placeholder: #004400;
  --text-on-accent: #000;
  --accent-primary: #33ff00;
  --accent-secondary: #00cc00;
  --border-color: #33ff00;
  --border-input: #004400;
  --bg-message-user: #003300;
  --bg-message-assistant: rgba(0, 20, 0, 0.9);
  font-family: 'Courier New', monospace;
}

/* --- TTS (Seslendirme) Animasyonları --- */

/* Yükleniyor Durumu */
.tiny-icon-btn.tts-loading i {
  animation: spin_v10 1s linear infinite;
  color: var(--accent-primary);
}

/* Çalıyor Durumu (Ses Dalgası Efekti) */
.tiny-icon-btn.tts-playing {
  color: var(--accent-green);
  background-color: color-mix(in srgb, var(--accent-green) 15%, transparent);
  position: relative;
  overflow: hidden;
}

/* Basit Ses Dalgası Animasyonu */
.tiny-icon-btn.tts-playing::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234ade80' stroke-width='2'%3E%3Cpath d='M12 3v18M8 8v8M16 8v8M4 11v2M20 11v2' /%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.4;
  animation: ttsWave 1s infinite linear;
}

@keyframes ttsWave {
  0% {
    transform: scaleY(0.8);
    opacity: 0.3;
  }

  50% {
    transform: scaleY(1.2);
    opacity: 0.6;
  }

  100% {
    transform: scaleY(0.8);
    opacity: 0.3;
  }
}

/* === YENİ MARKDOWN STİLLERİ (V4) === */

/* 1. Atmosferik Olay Metni (±...±) */
.event-mode-text {
  display: block;
  margin: 12px 0;
  padding: 12px 16px;
  background: linear-gradient(90deg, rgba(var(--accent-primary-rgb), 0.1) 0%, transparent 100%);
  border-left: 3px solid var(--accent-primary);
  border-radius: 0 8px 8px 0;
  color: var(--text-secondary);
  font-family: 'Georgia', serif;
  /* Daha edebi durması için */
  font-style: italic;
  font-size: 0.95rem;
  line-height: 1.5;
}

/* 2. İçsel Düşünce Butonu ({{...}}) */
.inner-thought-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background-color: rgba(var(--accent-secondary-rgb), 0.2);
  color: var(--accent-secondary);
  border: 1px solid var(--accent-secondary);
  font-size: 12px;
  cursor: pointer;
  margin: 0 4px;
  transition: all 0.2s ease;
  vertical-align: middle;
  position: relative;
}

.inner-thought-btn:hover {
  background-color: var(--accent-secondary);
  color: #fff;
  transform: scale(1.1);
}

.inner-thought-btn i {
  pointer-events: none;
  /* İkona tıklamayı engelle */
}

/* 3. İçsel Düşünce Balonu (Glassmorphism Pop-up) */
.inner-thought-popup {
  position: absolute;
  bottom: 120%;
  /* Butonun üstünde belirsin */
  left: 50%;
  transform: translateX(-50%) translateY(10px);
  width: max-content;
  max-width: 250px;

  /* Buzlu Cam Efekti */
  background-color: rgba(20, 20, 20, 0.65);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.15);
  box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.37);

  color: #e2e2e2;
  padding: 12px 16px;
  border-radius: 16px;
  font-size: 0.9rem;
  font-style: italic;
  text-align: center;

  opacity: 0;
  visibility: hidden;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  z-index: 100;
  pointer-events: none;
}

/* Görünür Olduğunda */
.inner-thought-btn.active .inner-thought-popup {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

/* Ok işareti (Aşağı bakan) */
.inner-thought-popup::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border-width: 6px;
  border-style: solid;
  border-color: rgba(20, 20, 20, 0.65) transparent transparent transparent;
}

/* --- Sohbet Ölçeklendirme Önizleme Kutusu --- */
.chat-scale-preview-box {
  margin-top: 15px;
  background-color: var(--bg-main);
  /* Arka plan tema rengi */
  border: 1px solid var(--border-color);
  border-radius: 16px;
  overflow: hidden;
  transition: all 0.3s ease;
  /* Önizleme kutusunun içindeki zoom'u yönetmek için */
  display: flex;
  flex-direction: column;
}

.preview-header-fake {
  background-color: var(--bg-elevated);
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-color);
  font-size: 0.75rem;
  color: var(--text-tertiary);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.preview-message-content {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  /* Burası JS ile dinamik olarak zoomlanacak */
  transform-origin: top left;
  width: 100%;
}

/* --- GERÇEK SOHBET ALANI ÖLÇEKLENDİRMESİ (GLOBAL FIX) --- */
:root {
  --chat-zoom-level: 1;
}

/* Tüm Sohbet Alanını Ölçekle (Arayüz Dahil) */
#chatSection {
  /* Font boyutunu baz alarak her şeyi (ikonlar, boşluklar, metin) büyütür */
  font-size: calc(var(--font-size-base) * var(--chat-zoom-level));
}

/* Mesaj kutularının iç boşlukları font-size'a göre otomatik ayarlanır, ek hesaplamaya gerek yok */


/* --- YENİ SATIR İÇİ (INLINE) DÜZENLEME STİLLERİ --- */
.message.editing-mode .message-content {
  display: none;
  /* Normal metni gizle */
}

.inline-editor-container {
  width: 100%;
  margin-top: 8px;
  animation: fadeIn_v10 0.2s ease-out;
}

.inline-editor-textarea {
  width: 100%;
  min-height: 80px;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid var(--accent-primary);
  background-color: var(--bg-main);
  color: var(--text-primary);
  font-family: inherit;
  font-size: inherit;
  resize: vertical;
  outline: none;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.inline-editor-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 8px;
}

.inline-editor-btn {
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 0.85em;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: all 0.2s;
}

.inline-editor-btn.save {
  background-color: var(--accent-primary);
  color: var(--text-on-accent);
}

.inline-editor-btn.cancel {
  background-color: var(--bg-elevated);
  color: var(--text-secondary);
  border: 1px solid var(--border-color);
}

.inline-editor-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.1);
}


