/* ============================================================
   KAAHIN2 — CINEMATIC LAYER (v41)
   ─────────────────────────────────────────────────────────────
   Tek tasarım kaynağı. Minimal · sinematik · mistik · havada.

   v41 değişiklikleri:
     • Sol panel TAMAMEN şeffaf (havada kalır)
     • Input %50 daha büyük, geniş
     • Mistik fontlar (Cinzel · Cormorant italic)
     • Mesaj meta etiketleri (terminal-style) gizlendi
     • Mesaj animasyonu: blur + scale + glow → mistik buhar
     • Taşlar: yazılar her zaman görünür (kompakt mod)
     • Toggle butonu: taşları büyütüp belirginleştirir
   ============================================================ */

/* ──────────────────────────────────────────────────────────
   1. DESIGN TOKENS
────────────────────────────────────────────────────────── */
:root {
  --k-bg-deep:    #050507;
  --k-bg-soft:    #0a0a0d;
  --k-ink:        #f5f5f7;
  --k-ink-dim:    rgba(245,245,247,.62);
  --k-ink-mute:   rgba(245,245,247,.32);
  --k-line:       rgba(245,245,247,.06);
  --k-line-soft:  rgba(245,245,247,.10);

  /* Accent: INTERDI kırmızısı */
  --k-accent:      #E92038;
  --k-accent-2:    #c8102e;
  --k-accent-dim:  rgba(233,32,56,.22);
  --k-accent-glow: rgba(233,32,56,.45);
  --k-accent-soft: rgba(233,32,56,.12);

  /* Motion */
  --k-ease:       cubic-bezier(.22,.61,.36,1);
  --k-ease-out:   cubic-bezier(.16,1,.3,1);
  --k-ease-mystic:cubic-bezier(.34,1.56,.64,1);
  --k-dur-fast:   .35s;
  --k-dur-med:    .9s;
  --k-dur-slow:   1.6s;
  --k-dur-mystic: 1.8s;
  --k-dur-breath: 6s;

  /* Spacing */
  --k-s1: 8px;
  --k-s2: 16px;
  --k-s3: 24px;
  --k-s4: 32px;
  --k-s5: 48px;

  /* Mistik fontlar — v51: Türkçe karakter fallback zinciri eklendi.
     Cinzel/Cormorant yüklenmediği glyph'lerde tarayıcı sıradaki fonta düşer. */
  /* v68.6 — TR Fallback Serif/Mono önce gelir (unicode-range ile sadece
     Türkçe glifler için devreye girer); ardından primary font'lar ve
     sistem fallback'leri. Bu sayede ç/ğ/ı/İ/ö/ş/ü asla "kutu" görünmez. */
  /* v68.9 — Marcellus (Cinzel benzeri) + EB Garamond (Cormorant benzeri),
     ikisi de latin-ext (Türkçe) FULL destekler. */
  --k-font-mystic: 'Marcellus', 'EB Garamond', 'Palatino Linotype', Palatino, Georgia, serif;
  --k-font-script: 'EB Garamond', 'Palatino Linotype', Palatino, Georgia, serif;
  --k-font-mono:   'JetBrains Mono', 'Consolas', 'Menlo', monospace;
}

/* ──────────────────────────────────────────────────────────
   2. KEYFRAMES — mistik motion vocabulary
────────────────────────────────────────────────────────── */
@keyframes k-fade-in {
  from { opacity: 0; transform: translateY(8px); filter: blur(4px); }
  to   { opacity: 1; transform: translateY(0);   filter: blur(0); }
}
@keyframes k-fade-out {
  from { opacity: 1; transform: translateY(0);   filter: blur(0); }
  to   { opacity: 0; transform: translateY(-8px); filter: blur(6px); }
}
@keyframes k-breathe {
  0%, 100% { opacity: .55; transform: scale(1); }
  50%      { opacity: 1;   transform: scale(1.04); }
}
@keyframes k-shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}

/* Mesaj girişi: mistik buhar — blur'dan netliğe, alttan yukarı */
@keyframes k-msg-summon {
  0% {
    opacity: 0;
    transform: translateY(40px) scale(.94);
    filter: blur(16px);
    letter-spacing: .1em;
  }
  60% {
    opacity: .85;
    filter: blur(4px);
    letter-spacing: .02em;
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
    letter-spacing: .005em;
  }
}

/* Mesaj çıkışı: mistik kayboluş — buhar olur, yukarı süzülür */
@keyframes k-msg-vanish {
  0% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-60px) scale(.96);
    filter: blur(20px);
    margin-top: -1.6em;
    letter-spacing: .15em;
  }
}

/* Input border'ın hafif kırmızı pulse */
@keyframes k-pulse-red {
  0%, 100% {
    box-shadow:
      0 0 0 1px rgba(233,32,56,.08),
      0 0 24px rgba(233,32,56,.18),
      0 12px 40px rgba(0,0,0,.5),
      inset 0 1px 0 rgba(255,255,255,.04);
  }
  50% {
    box-shadow:
      0 0 0 1px rgba(233,32,56,.2),
      0 0 36px rgba(233,32,56,.3),
      0 12px 40px rgba(0,0,0,.5),
      inset 0 1px 0 rgba(255,255,255,.04);
  }
}

/* ──────────────────────────────────────────────────────────
   3. RESET — eski yapıyı sterilize
────────────────────────────────────────────────────────── */
.or-shaper,
#kModules,
.or-quicks,
.or-stones[aria-label="Fal Taşları"]:not(.k2-stones) {
  display: none !important;
}

/* v42 — CANVAS TAM EKRAN: grid'i bırakıp block layout'a geç
   Stage tüm ekranı kapsar, sol panel üzerinde yüzer */
.or-app {
  display: block !important;
  grid-template-columns: none !important;
  position: relative;
  background: var(--k-bg-deep) !important;
  width: 100vw;
  height: 100vh;
  height: 100dvh;
  overflow: hidden;
}

/* Body radial — kırmızı ipuçları */
body::before {
  background-image: none !important;
  background:
    radial-gradient(ellipse at 25% 30%, rgba(233,32,56,.045) 0%, transparent 50%),
    radial-gradient(ellipse at 75% 70%, rgba(80,30,40,.06) 0%, transparent 55%) !important;
}

/* Sayfa vignette: sahnenin doğal kararması */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,.55) 100%);
  mix-blend-mode: multiply;
}

/* ──────────────────────────────────────────────────────────
   4. LEFT — CHAT (canvas üstünde yüzen overlay · sol alt)
────────────────────────────────────────────────────────── */
.or-term,
.k2-term {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: none !important;
  /* v50 — Panel sadece HEADER için container görevi görür.
     Mesaj alanı (.or-term-body) ve input ayrı fixed konumda. */
  position: fixed !important;
  left: 0;
  top: 0;
  bottom: 0;
  width: min(560px, 46vw);
  z-index: 10;
  padding: 0 !important;
  overflow: visible !important;
  pointer-events: none;
  display: block !important;
}
.or-term > *,
.k2-term > * {
  pointer-events: auto;
}

/* Input ve popover'\u0131n y\u00fcksekli\u011fini tek de\u011fi\u015fkenle kontrol et */
:root {
  /* ⭐ TEK GERÇEK: Input'un ekranın alt kenarına olan mesafesi.
     ⬆️ Artır = input YUKARI kayar   ⬇️ Azalt = input AŞAĞIYA iner
     Mesaj alanı + buton grubu + popover hepsi bu değere göre hizalanır
     v72 — Input artık HUD'un tam 20px üstüne oturur (HUD=82px → 102px) */
  --k-input-bottom: calc(var(--or-hud, 82px) + 20px);
}

/* v75 — GLASSMORPHIC ORTADA INPUT (Çözüm 3).
   - Yatay olarak ekran ortasında (left: 50% + translateX)
   - Cam efekti: yarı şeffaf + heavy blur + saturate → kâhin küresi arkadan belli belirsiz
   - Ritüel/şekil açıldığında otomatik gizlenir (#ritualStage.is-open, .k2-shape-drawer.is-open) */
.or-term-input,
.k2-input-row {
  position: fixed !important;
  left: 50% !important;
  right: auto !important;
  bottom: calc(var(--or-hud, 82px) + 24px) !important;
  width: min(640px, 56vw) !important;
  transform: translateX(-50%) !important;
  z-index: 12 !important;
  margin: 0 !important;
  transition:
    opacity 320ms var(--k-ease),
    transform 380ms cubic-bezier(.2, .8, .2, 1),
    filter 320ms var(--k-ease) !important;
}

/* v75 — Ritüel veya şekil drawer'ı açıldığında input gizlenir.
   #ritualStage tek-sahne, .k2-shape-drawer alt-çekmece. */
body:has(#ritualStage.is-open) .or-term-input,
body:has(#ritualStage.is-open) .k2-input-row,
body:has(.k2-shape-drawer.is-open) .or-term-input,
body:has(.k2-shape-drawer.is-open) .k2-input-row {
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translateX(-50%) translateY(20px) !important;
  filter: blur(6px) !important;
}
/* Aynı durumda dış buton ve stones list de gizlensin */
body:has(#ritualStage.is-open) .k2-stones-trigger,
body:has(.k2-shape-drawer.is-open) .k2-stones-trigger {
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translateY(20px) !important;
}
body:has(#ritualStage.is-open) .k2-stones-list,
body:has(.k2-shape-drawer.is-open) .k2-stones-list {
  opacity: 0 !important;
  pointer-events: none !important;
  visibility: hidden !important;
}

/* — Status bar: minimal · sol üst — */
.or-term-head,
.k2-head {
  background: transparent !important;
  border: none !important;
  position: absolute !important;
  top: var(--k-s3);
  left: var(--k-s4);
  right: var(--k-s4);
  padding: 0 !important;
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  font-family: var(--k-font-mono);
  font-size: 9px;
  letter-spacing: .22em;
  color: var(--k-ink-mute);
  text-transform: uppercase;
  z-index: 4;
}
.or-chat-status { display: inline-flex; align-items: center; gap: var(--k-s1); }
.or-chat-status-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--k-accent);
  box-shadow: 0 0 10px var(--k-accent-glow);
  animation: k-breathe var(--k-dur-breath) var(--k-ease) infinite;
}
/* Chat sayacı, header ikonları gizle (sağdaki "2", trash ikonu fazlalık) */
.or-chat-meta,
.or-chat-time,
#orChatMsgCount {
  display: none !important;
}
.or-chat-action,
#orChatClear {
  width: 26px; height: 26px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--k-ink-mute);
  border-radius: 50%;
  transition: all var(--k-dur-fast) var(--k-ease);
  font-size: 11px;
  background: transparent;
}
.or-chat-action:hover,
#orChatClear:hover {
  color: var(--k-accent);
  background: var(--k-accent-soft);
}

/* ──────────────────────────────────────────────────────────
   5. MESSAGES — mistik · taşların üstünde · binmesin
────────────────────────────────────────────────────────── */
/* v50 — k2-stream-zone wrapper artık akışı etkilemez.
   Çocuk .or-term-body kendi fixed konumunda durur. */
.k2-stream-zone {
  display: contents !important;
}
/* v75 — Mesaj akışı: input'un üstünde, AYNI MERKEZDE hizalı.
   Input ile aynı genislik (min 640px / 56vw), yatayda ortalanmış.
   Yeni mesaj en altta (input'un üstünde) belirir, eskiler yukarı kayar + fade-out. */
.or-term-body,
.k2-stream {
  position: fixed !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  bottom: calc(var(--or-hud, 82px) + 24px + 64px + 16px) !important;  /* HUD + input gap + input height + breath */
  top: 60px !important;
  width: min(640px, 56vw) !important;

  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  align-items: center !important;          /* v75 — satırlar yatayda da ortalı */
  gap: var(--k-s2);
  padding: 0;
  background: transparent !important;
  overflow: hidden !important;
  scrollbar-width: none;

  /* Üst tarafta yumuşak fade — eski mesajlar görsel olarak silinir */
  mask-image: linear-gradient(180deg,
                transparent 0%,
                rgba(0,0,0,.3) 14%,
                #000 40%,
                #000 100%);
  -webkit-mask-image: linear-gradient(180deg,
                transparent 0%,
                rgba(0,0,0,.3) 14%,
                #000 40%,
                #000 100%);
  pointer-events: auto;
  z-index: 11;
  transition: opacity 320ms var(--k-ease), filter 320ms var(--k-ease);
}
/* v75 — Ritüel açıldığında chat akışı da hafif solar (input gibi tamamen kaybolmaz, sahneye saygı) */
body:has(#ritualStage.is-open) .or-term-body,
body:has(#ritualStage.is-open) .k2-stream,
body:has(.k2-shape-drawer.is-open) .or-term-body,
body:has(.k2-shape-drawer.is-open) .k2-stream {
  opacity: 0.18 !important;
  filter: blur(3px) !important;
  pointer-events: none !important;
}
.or-term-body::-webkit-scrollbar { display: none !important; }

/* — kâhin'in JS'i .or-line üretiyor; o yapıyı mistikleştir — */
.or-term-body .or-line,
.k2-stream .or-line {
  font-family: var(--k-font-script) !important;
  font-size: 19px !important;
  line-height: 1.55 !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  animation: k-msg-summon var(--k-dur-mystic) var(--k-ease-out) both !important;
  position: relative;
  text-shadow: 0 0 24px rgba(233,32,56,.08);
}

/* Terminal-style meta (\$ user 21:32, > oracle 21:36) → GİZLE */
.or-term-body .or-line .meta,
.k2-stream .or-line .meta {
  display: none !important;
}
.or-term-body .or-line .time,
.k2-stream .or-line .time {
  display: none !important;
}

/* Mesaj gövdesi — saf metin, çizgisiz */
.or-term-body .or-line .body,
.k2-stream .or-line .body {
  padding: 0 !important;
  margin: 0 !important;
  color: var(--k-ink) !important;
  font-family: inherit !important;
  font-size: inherit !important;
  position: relative;
}
/* Sol kırmızı dikey çizgi → KALDIR */
.or-term-body .or-line .body::before,
.k2-stream .or-line .body::before,
.or-term-body .or-line::before,
.k2-stream .or-line::before {
  display: none !important;
  content: none !important;
}

/* Kullanıcı mesajı: italik DEĞİL, dim, sağa hizalı — boyut Kâhin cevabıyla eşit */
.or-term-body .or-line.user,
.k2-stream .or-line.user {
  text-align: right;
}
.or-term-body .or-line.user .body,
.k2-stream .or-line.user .body {
  color: var(--k-ink-dim) !important;
  font-style: normal !important;
  /* v69.07 — Mobilde responsive */
  font-size: clamp(14px, 2.6vw, 21px) !important;
  line-height: 1.5;
}
.or-term-body .or-line.user .body::after {
  content: ' ·';
  color: var(--k-accent);
  opacity: .5;
}

/* Kâhin mesajı: Cinzel başlangıç + Cormorant gövde — mistik */
.or-term-body .or-line.ai,
.k2-stream .or-line.ai {
  text-align: left;
}
.or-term-body .or-line.ai .body,
.k2-stream .or-line.ai .body {
  color: var(--k-ink) !important;
  font-weight: 500 !important;
  /* v69.07 — Mobilde responsive: 14px (mobil) → 21px (desktop) */
  font-size: clamp(14px, 2.6vw, 21px) !important;
  letter-spacing: .005em;
  line-height: 1.5;
}
.or-term-body .or-line.ai .body::first-letter {
  font-family: var(--k-font-mystic) !important;
  color: var(--k-accent) !important;
  font-size: 1.6em;
  font-weight: 600;
  text-shadow: 0 0 16px var(--k-accent-glow);
  margin-right: 2px;
}

/* fade-out: en eski mesaj buhar olur, yukarı süzülür */
.or-term-body .or-line.is-fading,
.k2-stream .or-line.is-fading {
  animation: k-msg-vanish var(--k-dur-mystic) var(--k-ease) forwards !important;
}

/* Streaming cursor (yazıyor efekti) */
.or-cursor::after {
  content: '|';
  color: var(--k-accent);
  margin-left: 2px;
  animation: k-breathe 1s var(--k-ease) infinite;
}

/* ──────────────────────────────────────────────────────────
   6. FLOATING INPUT — büyük · alta yakın · kırmızı pulse
────────────────────────────────────────────────────────── */
.or-term-input,
.k2-input-row {
  position: relative;
  display: flex !important;
  align-items: center;
  gap: 10px;
  /* v68.30 — Input %20 daha yüksek: padding büyütüldü, min-height 64→77 */
  padding: calc(var(--k-s1) * 1.6) var(--k-s2) calc(var(--k-s1) * 1.6) var(--k-s2) !important;
  margin: 0 !important;
  min-height: 64px;
  /* v75 — GLASS: yarı şeffaf, heavy blur + saturate, kâhin küresi arkadan görünür */
  background: rgba(10, 8, 12, 0.32) !important;
  border: 1px solid rgba(233, 32, 56, 0.22) !important;
  border-radius: 18px !important;
  backdrop-filter: blur(22px) saturate(150%) !important;
  -webkit-backdrop-filter: blur(22px) saturate(150%) !important;
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: all var(--k-dur-med) var(--k-ease);
  flex: 0 0 auto;
  animation: k-pulse-red 4s var(--k-ease) infinite;
}
.or-term-input::before,
.k2-input-row::before {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: inherit;
  background: linear-gradient(120deg,
                transparent 25%,
                var(--k-accent-glow) 50%,
                transparent 75%);
  background-size: 200% 100%;
  opacity: 0;
  z-index: -1;
  transition: opacity var(--k-dur-med) var(--k-ease);
  filter: blur(12px);
}
.or-term-input:focus-within,
.k2-input-row:focus-within {
  border-color: var(--k-accent) !important;
  background: rgba(15,8,10,.65) !important;
  transform: translateY(-1px);
  box-shadow:
    0 0 0 1px rgba(233,32,56,.3),
    0 0 40px rgba(233,32,56,.4),
    0 16px 48px rgba(233,32,56,.2),
    inset 0 1px 0 rgba(255,255,255,.06);
}
.or-term-input:focus-within::before,
.k2-input-row:focus-within::before {
  opacity: 1;
  animation: k-shimmer 3s linear infinite;
}

#orInput {
  flex: 1;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  color: var(--k-ink) !important;
  font-family: var(--k-font-script) !important;
  font-size: 21px !important;
  font-style: normal !important;
  padding: 8px var(--k-s1) !important;
  letter-spacing: .01em;
  caret-color: var(--k-accent);
}
#orInput::placeholder {
  color: var(--k-ink-mute);
  font-style: normal;
  opacity: .8;
}

.or-iconbtn,
.k2-iconbtn {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  background: transparent !important;
  color: var(--k-ink-dim) !important;
  font-size: 13px !important;
  transition: all var(--k-dur-fast) var(--k-ease);
  flex: 0 0 auto;
}
.or-iconbtn:hover,
.k2-iconbtn:hover {
  color: var(--k-accent) !important;
  background: var(--k-accent-soft) !important;
}
/* v58 — MİSTİK GÖNDER BUTONU (SIGIL EDITION)
   - Buton: koyu obsidyen küre (kırmızı değil, gizemli karanlık)
   - İçinde: kâhin sigili (üçgen + göz)
   - Animasyon: konsantrik kırmızı dalga atımları (sonar gibi)
                + sigil yavaşça pulse + göz bebeği parlama
   - Hover: dalgalar hızlanır, sigil hafif döner, göz bebeği büyür  */
.or-send,
.k2-send {
  position: relative;
  width: 46px !important;
  height: 46px !important;
  border-radius: 50% !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  /* Obsidyen küre — kırmızı tonlu derin koyu */
  background:
    radial-gradient(circle at 38% 32%,
      rgba(80, 14, 24, .9) 0%,
      rgba(30, 6, 10, .98) 55%,
      #0a0306 100%) !important;
  color: var(--k-accent) !important;
  border: 1px solid rgba(233, 32, 56, .35) !important;
  box-shadow:
    0 0 0 1px rgba(255, 80, 100, .15),
    0 4px 18px rgba(0, 0, 0, .55),
    0 0 18px rgba(233, 32, 56, .22),
    inset 0 1px 1px rgba(255, 180, 195, .12),
    inset 0 -6px 12px rgba(0, 0, 0, .6) !important;
  transition:
    transform 280ms var(--k-ease),
    box-shadow 320ms var(--k-ease),
    border-color 320ms var(--k-ease),
    color 320ms var(--k-ease);
  flex: 0 0 auto;
  overflow: visible;
  cursor: pointer;
  padding: 0 !important;
}

/* v68.10 — Küçük, dar pulse halkaları (eski sonar geri, ama yayılma az) */
.or-send::before,
.k2-send::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid var(--k-accent);
  opacity: 0;
  pointer-events: none;
  animation: k-send-pulse 2.4s var(--k-ease-out) infinite;
}
.or-send::after,
.k2-send::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid var(--k-accent);
  opacity: 0;
  pointer-events: none;
  animation: k-send-pulse 2.4s var(--k-ease-out) 1.2s infinite;
}

/* OK İKONU — v68.4: YUKARI bakan ince ok (SVG -90° döndürülmüş) + mistik glow */
.or-send-arrow {
  position: relative;
  z-index: 2;
  width: 22px;
  height: 22px;
  color: var(--k-accent);
  filter: drop-shadow(0 0 5px rgba(233, 32, 56, .6));
  /* SVG yatay çizilmiş; -90° ile yukarı bakar */
  transform: rotate(-90deg) translateX(0) translateY(0);
  transition:
    transform 320ms var(--k-ease),
    filter 320ms var(--k-ease),
    color 320ms var(--k-ease);
  animation: k-send-arrow-float 3s var(--k-ease) infinite;
  overflow: visible;
}

/* HOVER — buton uyanıyor */
.or-send:hover,
.k2-send:hover {
  transform: scale(1.06);
  background:
    radial-gradient(circle at 38% 32%,
      rgba(140, 24, 40, .95) 0%,
      rgba(50, 8, 14, .98) 55%,
      #15050a 100%) !important;
  border-color: var(--k-accent) !important;
  color: #ff7088 !important;
  box-shadow:
    0 0 0 1px rgba(255, 100, 120, .5),
    0 6px 28px rgba(0, 0, 0, .6),
    0 0 36px rgba(233, 32, 56, .55),
    inset 0 1px 1px rgba(255, 200, 210, .2),
    inset 0 -6px 12px rgba(0, 0, 0, .6) !important;
}
.or-send:hover::before,
.k2-send:hover::before { animation-duration: 1.8s; }
.or-send:hover::after,
.k2-send:hover::after  { animation-duration: 1.8s; animation-delay: .9s; }

/* v68.10 — TYPING modu: pulse daha hızlı + beyaz tonlu (uyanma hissi) */
.or-send.is-typing::before,
.or-send.is-typing::after,
.k2-send.is-typing::before,
.k2-send.is-typing::after {
  border-color: #ffe0e6;
  box-shadow: 0 0 6px rgba(255, 220, 230, .8);
  animation-duration: 1.1s !important;
}
.or-send:hover .or-send-arrow {
  /* v68.11 — SADECE renk değişimi, hareket animasyonu YOK */
  color: #ffd0d6 !important;
  filter: drop-shadow(0 0 10px rgba(255, 120, 140, .9));
  transition: color 180ms ease, filter 180ms ease;
  animation: none !important;
}

/* ACTIVE — basıldığında çekilir + dalga patlar */
.or-send:active,
.k2-send:active {
  transform: scale(0.92);
}

/* ──────── KEYFRAMES ──────── */

/* v68.10 — Küçük pulse: 1.0 → 1.35 (sadece %35 yayılır), yumuşak fade */
@keyframes k-send-pulse {
  0%   { transform: scale(1);    opacity: 0; }
  20%  { opacity: .55; }
  100% { transform: scale(1.35); opacity: 0; }
}

/* v68.4 — Ok YUKARI bakar (SVG -90° döndürülmüş).
   Sakin uçuş: hafifçe yukarı-aşağı nefes alır */
@keyframes k-send-arrow-float {
  0%, 100% {
    transform: rotate(-90deg) translateX(0) translateY(0);
    opacity: .9;
  }
  50% {
    /* SVG rotate(-90) durumunda Y ekseni X gibi davranır: 
       gerçek yukarı hareket için translateX(-1px) kullanırız */
    transform: rotate(-90deg) translateX(-1px) translateY(0);
    opacity: 1;
  }
}

/* v68.4 — Hover'da fırlatma: ok DAHA YUKARI atılır, geri döner.
   Döndürülmüş eksende translateX(negatif) = ekranda yukarı */
@keyframes k-send-arrow-launch-up {
  0%   { transform: rotate(-90deg) translateX(0)    translateY(0); opacity: 1; }
  35%  { transform: rotate(-90deg) translateX(-5px) translateY(0); opacity: .9; }
  60%  { transform: rotate(-90deg) translateX(1px)  translateY(0); opacity: 1; }
  100% { transform: rotate(-90deg) translateX(0)    translateY(0); opacity: 1; }
}

/* ──────────────────────────────────────────────────────────
   7. STONES LIST — v53: KUTUSUZ minimalist liste.
   💎 butonuna basınca input'un ALTINDA aşağı doğru açılır.
   Taşlar tek tek sıralı (stagger) belirir — küçük font, italik.
────────────────────────────────────────────────────────── */
/* ──────────────────────────────────────────────────────────
   v75 — FAL TAŞLARI TETİKLEYİCİSİ (dış buton, ortadaki input'un sağında)
   Input merkezde olduğu için: left = 50% + (input genişliği / 2) + 12px gap
────────────────────────────────────────────────────────── */
.k2-stones-trigger {
  position: fixed !important;
  left: calc(50% + (min(640px, 56vw) / 2) + 12px) !important;
  /* Input dikey ortası: bottom (HUD+24) + (input height 64 / 2) - (button height 40 / 2) */
  bottom: calc(var(--or-hud, 82px) + 24px + 32px - 20px) !important;

  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  /* v75 — Glass uyumlu */
  background: rgba(10, 8, 12, 0.32);
  color: var(--k-ink-dim);
  border: 1px solid rgba(233, 32, 56, 0.22);
  font-size: 14px;
  cursor: pointer;
  backdrop-filter: blur(22px) saturate(150%);
  -webkit-backdrop-filter: blur(22px) saturate(150%);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.30);
  transition:
    opacity 320ms var(--k-ease),
    transform 380ms cubic-bezier(.2, .8, .2, 1),
    background 200ms var(--k-ease),
    border-color 200ms var(--k-ease),
    color 200ms var(--k-ease),
    box-shadow 200ms var(--k-ease);
  z-index: 12;
}
.k2-stones-trigger:hover {
  color: var(--k-accent);
  background: var(--k-accent-soft);
  border-color: var(--k-accent);
  transform: translateY(-1px);
  box-shadow: 0 0 14px var(--k-accent-glow);
}
.k2-stones-trigger.is-active {
  color: var(--k-accent);
  background: var(--k-accent-soft);
  border-color: var(--k-accent);
  box-shadow: 0 0 14px var(--k-accent-glow);
}
.k2-stones-trigger:hover::after {
  content: attr(title);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--k-font-mono);
  font-size: 9px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--k-ink);
  background: rgba(0,0,0,.92);
  border: 1px solid var(--k-accent-dim);
  padding: 5px 9px;
  border-radius: 5px;
  white-space: nowrap;
  pointer-events: none;
  z-index: 25;
}

/* ──────────────────────────────────────────────────────────
   v74 — FAL TAŞLARI LİSTESİ: TERS DROPDOWN
   - Butonun ÜSTÜNE doğru açılır (alttan yukarı)
   - Dikey kolon, minimalist tipografi (sadece metin satırları)
   - Buton ile sağ kenarı hizalı
────────────────────────────────────────────────────────── */
.k2-stones-list {
  position: fixed !important;
  /* v75 — Buton merkez+input/2+12px konumunda; liste buton sol kenarından (40-240=-200) sola hizalı,
     yani sağ kenarı buton sağıyla aynı (40px buton genişliği - 240px liste genişliği). */
  left: calc(50% + (min(640px, 56vw) / 2) + 12px + 40px - 240px) !important;
  right: auto !important;
  width: 240px !important;
  /* Buton üst kenarı + 8px gap. Buton bottom = HUD+24+32-20 = HUD+36; üst kenar = bottom+40. */
  bottom: calc(var(--or-hud, 82px) + 24px + 32px - 20px + 40px + 8px) !important;
  top: auto !important;
  max-height: 260px !important;
  transform-origin: bottom right;

  z-index: 11 !important;

  list-style: none;
  margin: 0;
  padding: 6px;
  background: rgba(8, 6, 10, 0.92);
  border: 1px solid var(--k-accent-dim);
  border-radius: 10px;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow:
    0 12px 32px rgba(0, 0, 0, .55),
    0 0 24px rgba(233, 32, 56, .10);
  display: flex;
  flex-direction: column;          /* v74 — DİKEY kolon (ters dropdown) */
  align-items: stretch;
  gap: 1px;
  overflow: hidden;

  opacity: 0;
  transform: translateY(8px) scale(.98);
  pointer-events: none;
  visibility: hidden;
  transition:
    opacity 220ms var(--k-ease),
    transform 240ms cubic-bezier(.2, .8, .2, 1),
    visibility 0s linear 240ms;
}
.k2-stones-list[data-open="true"] {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
  visibility: visible;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--k-accent-dim) transparent;
  transition:
    opacity 220ms var(--k-ease),
    transform 280ms cubic-bezier(.2, .8, .2, 1),
    visibility 0s linear 0s;
}
.k2-stones-list::-webkit-scrollbar { width: 3px; }
.k2-stones-list::-webkit-scrollbar-thumb { background: var(--k-accent-dim); border-radius: 2px; }

/* ──────────────────────────────────────────────────────────
   v74 — MİNİMAL KART: çerçevesiz tek satır metin, sadece hover'da accent.
────────────────────────────────────────────────────────── */
.k2-stones-list .or-stone {
  flex: 0 0 auto;
  display: block !important;
  /* Stagger reveal: alttan yukarı sırayla (ters dropdown hissi) */
  opacity: 0 !important;
  transform: translateY(4px) !important;
  clip-path: none !important;
  transition:
    opacity 220ms linear,
    transform 280ms cubic-bezier(.2, .8, .2, 1) !important;
}
.k2-stones-list[data-open="true"] .or-stone {
  opacity: 1 !important;
  transform: translateY(0) !important;
  /* En alttaki taş önce belirsin (ters dropdown) → si tersten saymak yerine
     basit 35ms artan stagger yeter */
  transition-delay: calc(var(--si, 0) * 35ms) !important;
}
.k2-stones-list .or-stone-btn {
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  min-height: 24px !important;
  padding: 5px 8px !important;
  border-radius: 4px !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  white-space: nowrap !important;
  text-align: left !important;
  cursor: pointer;
  transition: background 160ms var(--k-ease), color 160ms var(--k-ease);
}
.k2-stones-list .or-stone-btn::before,
.k2-stones-list .or-stone-btn::after {
  display: none !important;               /* braketler kapalı (minimal mod) */
}
.k2-stones-list .or-stone-btn:hover {
  padding-left: 8px !important;
  background: rgba(233, 32, 56, 0.08) !important;
  border: none !important;
}
.k2-stones-list .or-stone-num,
.k2-stones-list .or-stone-glyph {
  display: none !important;
}
.k2-stones-list .or-stone-text {
  display: block !important;
  -webkit-line-clamp: unset !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis;
  width: 100%;
  max-width: 100%;
  font-family: var(--k-font-mono) !important;
  font-size: 10px !important;
  font-style: normal !important;
  font-weight: 400 !important;
  line-height: 1.4 !important;
  letter-spacing: .04em !important;
  color: rgba(255, 255, 255, .72) !important;
  text-transform: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
  transition: color 160ms var(--k-ease);
}
.k2-stones-list .or-stone-btn:hover .or-stone-text {
  color: var(--k-ink) !important;
}

/* ──────────────────────────────────────────────────────────
   INPUT ACTIONS — v44: input'un solunda düz sıra (💎 🎴)
────────────────────────────────────────────────────────── */
.k2-input-actions {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  flex: 0 0 auto;
  padding-right: 6px;
  border-right: 1px solid var(--k-line);
}
.k2-input-action {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: transparent;
  color: var(--k-ink-dim);
  border: 1px solid transparent;
  font-size: 13px;
  cursor: pointer;
  transition: all var(--k-dur-fast) var(--k-ease);
  flex: 0 0 auto;
  position: relative;
}
.k2-input-action:hover {
  color: var(--k-accent);
  background: var(--k-accent-soft);
  border-color: var(--k-accent-dim);
  transform: translateY(-1px);
}
.k2-input-action.is-active {
  color: var(--k-accent);
  background: var(--k-accent-soft);
  border-color: var(--k-accent);
  box-shadow: 0 0 14px var(--k-accent-glow);
  /* v51 — aktif buton da input ile aynı ritimde nefes alır */
  animation: k-pulse-red 4s var(--k-ease) infinite;
}
.k2-input-action:hover::after {
  content: attr(title);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--k-font-mono);
  font-size: 9px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--k-ink);
  background: rgba(0,0,0,.92);
  border: 1px solid var(--k-accent-dim);
  padding: 5px 9px;
  border-radius: 5px;
  white-space: nowrap;
  pointer-events: none;
  z-index: 25;
}

/* Eski daily/card script'in chat header'a eklemeye çalıştığı buton → görünmesin
   (kart trigger'ı artık input'un yanında) */
#kcTriggerBtn { display: none !important; }

/* Eski .k2-stones başka herhangi bir yerde varsa sterilize */
.k2-stones:not(.k2-stones-inline):not(.k2-stones-grid) {
  display: none !important;
}
/* Eski .k2-stones-grid base'i — şimdi sadece selector compatibility için */
.k2-stones-grid {
  list-style: none;
  margin: 0;
  padding: 0;
}
.k2-stones-grid::-webkit-scrollbar { display: none; }

.k2-stones-grid .or-stone {
  flex: 0 0 auto;       /* Cümle kısa-uzun ölçüsüne göre doğal */
  animation: k-fade-in var(--k-dur-med) var(--k-ease-out) both;
  animation-delay: calc(var(--si, 0) * 70ms);
}
.k2-stones-grid .or-stone.is-used {
  animation: k-fade-out var(--k-dur-fast) var(--k-ease) forwards;
}

/* — PILL MOD: yatay tek-satır tam cümle butonu — */
.k2-stones-grid .or-stone-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background:
    linear-gradient(90deg, rgba(233,32,56,.08) 0%, rgba(18,12,15,.85) 80%);
  border: 1px solid rgba(233,32,56,.28);
  border-radius: 999px;          /* Pill shape */
  color: var(--k-ink);
  position: relative;
  cursor: pointer;
  transition: all var(--k-dur-med) var(--k-ease);
  overflow: hidden;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  white-space: nowrap;
  box-shadow:
    0 0 0 1px rgba(233,32,56,.06),
    0 4px 14px rgba(0,0,0,.4),
    inset 0 1px 0 rgba(255,255,255,.05);
}
.k2-stones-grid .or-stone-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 50%,
                var(--k-accent-glow) 0%,
                transparent 70%);
  opacity: 0;
  transition: opacity var(--k-dur-med) var(--k-ease);
  pointer-events: none;
}
.k2-stones-grid .or-stone-btn:hover {
  border-color: var(--k-accent);
  transform: translateY(-2px);
  background:
    linear-gradient(90deg, rgba(233,32,56,.18) 0%, rgba(22,14,18,.92) 80%);
  box-shadow:
    0 0 0 1px rgba(233,32,56,.4),
    0 10px 24px rgba(233,32,56,.25),
    0 0 28px rgba(233,32,56,.18);
}
.k2-stones-grid .or-stone-btn:hover::before { opacity: 1; }

/* Glyph — cümlenin solunda */
.k2-stones-grid .or-stone-glyph {
  position: relative;
  z-index: 1;
  font-family: var(--k-font-script);
  font-size: 14px;
  color: var(--k-accent);
  text-shadow: 0 0 8px rgba(233,32,56,.4);
  transition: transform var(--k-dur-med) var(--k-ease);
  line-height: 1;
  flex: 0 0 auto;
}
.k2-stones-grid .or-stone-btn:hover .or-stone-glyph {
  transform: scale(1.2) rotate(12deg);
  text-shadow: 0 0 16px var(--k-accent-glow);
}

/* Soru metni — TAM CÜMLE · tek satır */
.k2-stones-grid .or-stone-text {
  position: relative;
  display: inline-block;
  overflow: visible;
  font-family: var(--k-font-script);
  font-size: 13px;
  font-style: italic;
  font-weight: 500;
  line-height: 1;
  letter-spacing: .005em;
  color: var(--k-ink-dim);
  text-transform: none;
  text-align: left;
  padding: 0;
  opacity: 1;
  pointer-events: none;
  background: transparent;
  border: none;
  z-index: 1;
  transition: color var(--k-dur-fast) var(--k-ease);
  white-space: nowrap;
  /* Reset eski tooltip pozisyonlamalarını */
  transform: none !important;
  bottom: auto !important;
  left: auto !important;
  box-shadow: none !important;
  top: auto !important;
}
.k2-stones-grid .or-stone-btn:hover .or-stone-text {
  color: var(--k-ink);
}
.k2-stones-grid .or-stone-cat { display: none; }

/* ──────────────────────────────────────────────────────────
   v67 — STONES: TERMINAL SATIRLARI · 2 SÜTUN · KIRMIZISIZ
   - 2 sıralı grid (mobilde 1 sütun)
   - Çift fade fix: container opacity transition'ı yok, sadece kart-level reveal
   - Kutu: ince braket'li monolitik satır ("[ ]" köşe işaretleri), kırmızı border YOK
   - Açılış: clip-path soldan sağa açılır + hafif translateX (rotate/scale yok)
   - Font: var(--k-font-mono) — modern oracle/terminal
────────────────────────────────────────────────────────── */
.k2-stones-list[data-open="true"] {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 6px !important;
  padding: 8px 4px !important;
  align-content: start !important;
}

.k2-stones-list .or-stone {
  display: block;
  list-style: none;
  position: relative;
  /* Yeni açılış — clip-path reveal + soldan kayma (rotate/scale YOK) */
  opacity: 0;
  transform: translateX(-12px);
  clip-path: inset(0 100% 0 0);
  transition:
    opacity 280ms linear,
    transform 420ms cubic-bezier(.2, .8, .2, 1),
    clip-path 520ms cubic-bezier(.2, .8, .2, 1);
}
.k2-stones-list[data-open="true"] .or-stone {
  opacity: 1;
  transform: translateX(0);
  clip-path: inset(0 0 0 0);
  transition-delay: calc(var(--si, 0) * 55ms);
}
.k2-stones-list .or-stone.is-used {
  opacity: 0;
  transform: translateX(24px);
  clip-path: inset(0 0 0 100%);
  transition: all 320ms var(--k-ease) !important;
}

/* KUTU — terminal satırı: ince nötr çerçeve, köşelerde "[ ]" braketleri (KIRMIZI YOK) */
.k2-stones-list .or-stone-btn {
  width: 100%;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  padding: 9px 14px 9px 16px !important;
  background: rgba(8, 6, 10, 0.55) !important;
  border: 1px solid rgba(255, 255, 255, 0.07) !important;   /* tamamen nötr */
  border-radius: 2px !important;
  min-height: 40px;
  white-space: normal !important;
  text-align: left !important;
  box-shadow: none !important;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  position: relative;
  cursor: pointer;
  transition:
    background 220ms var(--k-ease),
    border-color 220ms var(--k-ease),
    padding-left 220ms var(--k-ease) !important;
  overflow: hidden;
}

/* Sol braket "[" — beyaz/gri ton */
.k2-stones-list .or-stone-btn::before {
  content: '';
  position: absolute;
  left: 4px;
  top: 6px;
  bottom: 6px;
  width: 6px;
  border-left: 1px solid rgba(255, 255, 255, .22);
  border-top: 1px solid rgba(255, 255, 255, .22);
  border-bottom: 1px solid rgba(255, 255, 255, .22);
  opacity: .75;
  transition: all 220ms var(--k-ease);
}
/* Sağ braket "]" — beyaz/gri ton */
.k2-stones-list .or-stone-btn::after {
  content: '';
  position: absolute;
  right: 4px;
  top: 6px;
  bottom: 6px;
  width: 6px;
  border-right: 1px solid rgba(255, 255, 255, .15);
  border-top: 1px solid rgba(255, 255, 255, .15);
  border-bottom: 1px solid rgba(255, 255, 255, .15);
  opacity: .55;
  transition: all 220ms var(--k-ease);
}

.k2-stones-list .or-stone-btn:hover {
  background: rgba(18, 14, 16, 0.82) !important;
  border-color: rgba(255, 255, 255, 0.18) !important;        /* hover'da da beyaz */
  padding-left: 20px !important;
}
.k2-stones-list .or-stone-btn:hover::before {
  border-color: rgba(255, 255, 255, .55);
  opacity: 1;
}
.k2-stones-list .or-stone-btn:hover::after {
  border-color: rgba(255, 255, 255, .35);
  opacity: 1;
}

/* Numara ve glyph kaldırıldı — gizle */
.k2-stones-list .or-stone-num,
.k2-stones-list .or-stone-glyph {
  display: none !important;
}

/* SORU metni — terminal mono font */
.k2-stones-list .or-stone-text {
  font-family: var(--k-font-mono) !important;
  font-size: 11px !important;
  font-style: normal !important;
  font-weight: 400 !important;
  line-height: 1.45 !important;
  letter-spacing: .04em !important;
  color: rgba(255, 255, 255, .82) !important;
  white-space: normal !important;
  text-align: left !important;
  text-transform: none !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  transform: none !important;
  bottom: auto !important;
  left: auto !important;
  top: auto !important;
  position: relative;
  z-index: 1;
  flex: 1 1 auto;
  transition: color 220ms var(--k-ease), letter-spacing 220ms var(--k-ease);
}
.k2-stones-list .or-stone-btn:hover .or-stone-text {
  color: #fff !important;
  letter-spacing: .055em !important;
}

/* Mobil — dar ekranda tek sütun */
@media (max-width: 640px) {
  .k2-stones-list[data-open="true"] {
    grid-template-columns: 1fr !important;
    gap: 4px !important;
  }
  .k2-stones-list .or-stone-btn {
    min-height: 36px;
    padding: 7px 12px 7px 14px !important;
  }
  .k2-stones-list .or-stone-text { font-size: 10.5px !important; -webkit-line-clamp: 2; }
}

/* Eski stones-shuffle / actions / toggle hepsi gizli */
.k2-stones-shuffle,
.k2-stones-actions,
.k2-stones-toggle { display: none !important; }

/* ──────────────────────────────────────────────────────────
   8. STAGE — v42: TAM EKRAN canvas · başka herşey üzerine yüzer
────────────────────────────────────────────────────────── */
.or-stage {
  position: absolute !important;
  inset: 0;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100% !important;
  height: 100% !important;
  background:
    radial-gradient(ellipse at center,
      rgba(30,15,20,.35) 0%,
      var(--k-bg-deep) 80%) !important;
  overflow: hidden;
  border: none !important;
  z-index: 1;
}
.or-stage canvas,
#orCanvas {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
}
.or-stage-meta {
  position: absolute;
  font-family: var(--k-font-mono);
  font-size: 9px;
  letter-spacing: .22em;
  color: var(--k-ink-mute);
  text-transform: uppercase;
  display: flex;
  gap: var(--k-s3);
  z-index: 3;
  padding: var(--k-s3);
  pointer-events: none;
}
/* v68.12 — MOOD · CALM tam sağ üstte, sol köşe sigil ile BİREBİR aynı hizada
   Sol sigil: position: fixed; top: calc(52px + .85rem); left: 1rem
   Burada da fixed kullanıyoruz (.or-app top:52px nedeniyle absolute fazla ofset yaratıyordu) */
.or-stage-meta:not(.or-stage-meta--bot) {
  position: fixed !important;
  top: calc(52px + .85rem) !important;
  right: 1rem !important;
  left: auto !important;
  bottom: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  flex-direction: column;
  gap: var(--k-s1);
  align-items: flex-end;
  z-index: 9201;
}
.or-stage-meta--bot { bottom: var(--or-hud, 82px); right: 0; }
.or-stage-meta span {
  position: relative;
  padding-left: 12px;
}
.or-stage-meta span::before {
  content: '';
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 4px; height: 4px;
  background: var(--k-accent);
  border-radius: 50%;
  box-shadow: 0 0 6px var(--k-accent-glow);
  animation: k-breathe var(--k-dur-breath) var(--k-ease) infinite;
}
.or-stage::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at center, transparent 35%, rgba(0,0,0,.45) 90%);
  z-index: 2;
}
.or-stage::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
  opacity: .04;
  mix-blend-mode: overlay;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
}

/* ──────────────────────────────────────────────────────────
   9. HUD + DRAWER
────────────────────────────────────────────────────────── */
#orHud {
  background: linear-gradient(180deg,
                transparent 0%,
                rgba(5,5,7,.85) 60%) !important;
  border-top: 1px solid var(--k-line) !important;
  backdrop-filter: blur(20px);
  z-index: 5;
}
/* v68.8 — Shape drawer GERİ AÇIK (HUD form butonundan çağrılır) */
.shape-drawer {
  background: rgba(8,8,11,.95) !important;
  backdrop-filter: blur(30px);
  border-top: 1px solid var(--k-line) !important;
}

/* v68.8 — HUD butonları: kıpkırmızı yerine yumuşak gümüşi/karbon ton.
   Hover/active'de hafif kırmızı parıltı, dolgu YOK. */
/* v68.35 — HUD butonları ŞİMDİ TEK SELECTOR: SES, MÜZİK ve FORM ÇAĞIRICI aynı stil */
.inlab-hud__info-btn,
.hud-seg.seg-sound .hud-sound-btn--info,
.hud-seg.seg-music .hud-sound-btn--info,
.hud-shape-btn {
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  color: rgba(245, 230, 232, 0.65) !important;
  box-shadow: none !important;
  transition: all .22s var(--k-ease) !important;
}
.inlab-hud__info-btn:hover,
.hud-seg.seg-sound .hud-sound-btn--info:hover,
.hud-seg.seg-music .hud-sound-btn--info:hover,
.hud-shape-btn:hover {
  background: rgba(233, 32, 56, 0.08) !important;
  border-color: rgba(233, 32, 56, 0.40) !important;
  color: #ff7a8c !important;
  box-shadow: 0 0 10px rgba(233, 32, 56, 0.20) !important;
}
.inlab-hud__info-btn.active,
.hud-seg.seg-sound .hud-sound-btn--info.is-active,
.hud-seg.seg-music .hud-sound-btn--info.is-active,
.hud-shape-btn.is-active {
  background: rgba(233, 32, 56, 0.10) !important;
  border-color: rgba(233, 32, 56, 0.45) !important;
  color: #ff7a8c !important;
  box-shadow: inset 0 0 12px rgba(233, 32, 56, 0.10) !important;
}

/* ──────────────────────────────────────────────────────────
   10. SHAPE RAIL — v53: Sağ kenarda dikey şekil menüsü
   Görseldeki tasarım: koyu kart + ortalanmış icon + alt label.
   Aktif kart: kırmızı neon kenar + glow.
   ŞU AN SADECE GÖRSEL — tıklamalar henüz şekil dönüşümü yapmıyor.
────────────────────────────────────────────────────────── */
/* v56 — Şape Rail: SAĞ KENARDA DİKEY PANEL.
   Panel ekranın TAM dikey ortasında, tüm şekiller içinde dikey dizilir.
   Panel kendisi shrink-to-fit, içerik blok-merkez. */
.k2-shape-rail {
  position: fixed;
  top: 50%;
  right: 14px;
  /* v71.9 — Rail %20 küçültüldü (scale 0.8). transform-origin: right
     ile sağ kenar sabit, sol tarafa doğru daralır. */
  --k-rail-scale: 0.8;
  transform: translateY(-50%) scale(var(--k-rail-scale));
  transform-origin: right center;
  z-index: 12;

  /* Panel boyutu: viewport'a göre auto, içerik kadar yer kaplar */
  max-height: calc(100vh - var(--or-hud, 82px) - 24px);

  /* v68.4 — MİSTİK PANEL: kırmızı border yerine ince gümüşi-duman çift kenar.
     Dış: yarı saydam beyaz hairline + iç: ince koyu ayraç.
     Aşağıda ::before pseudo ile rünik üst/alt köşe işaretleri eklenir. */
  /* v68.25 — GLOWING BUTTON: kutu %90 siyah, sabit; sadece arka glow renk değişir */
  background: rgba(6, 6, 9, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  padding: 10px 8px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.025),
    0 8px 28px rgba(0, 0, 0, 0.55);
  /* v68.6 — Hafif animatif border: 6s'lik nefes alma — opacity ve aura dalgalanır.
     Border-color ve box-shadow'un son katmanı animasyonlu (k-rail-breathe). */

  /* İçeriği panel kutusu içinde dikey ortala */
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  pointer-events: auto;

  /* v68.18 — fade-in + mistik nefes (border-color animasyonu KALDIRILDI)
     ÖNEMLİ: overflow: hidden YOK — yoksa hover tooltip'ler kesilir. */
  opacity: 0;
  animation: k-rail-panel-in 800ms var(--k-ease-out) 400ms forwards;
}

/* v68.22 — KÂHİN DÜŞÜNÜYOR ANIMASYONU
   Kullanıcı soru gönderince transcript'e geçici thinking line eklenir,
   cevap streaming başlayana kadar 3 nokta dalga halinde yanıp söner. */
.or-line--thinking {
  opacity: 0;
  animation: k-think-line-in 280ms ease-out forwards;
}
@keyframes k-think-line-in {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
/* v68.31 — MİSTİK DÜŞÜNME ANİMASYONU
   3 nokta yerine: nefes alan halka + nefes alan iç halka + dönen sigil
   + ince fısıltı yazısı. Kâhin'in sezgiye daldığı an. */
.or-think-mystic {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 6px 4px;
  min-height: 36px;
}

/* Dış halka — kâhin'in aurası, nefes alır */
.or-think-ring {
  position: relative;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(233, 32, 56, 0.45);
  box-shadow:
    0 0 14px rgba(233, 32, 56, 0.35),
    inset 0 0 10px rgba(233, 32, 56, 0.2);
  animation: k-mystic-breathe 2.6s ease-in-out infinite;
}

/* İç halka — ters fazda nefes alır, derinlik hissi */
.or-think-ring--mid {
  position: absolute;
  left: 4px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border-color: rgba(255, 110, 130, 0.32);
  box-shadow:
    0 0 8px rgba(255, 110, 130, 0.28),
    inset 0 0 6px rgba(255, 110, 130, 0.18);
  animation: k-mystic-breathe-rev 2.6s ease-in-out infinite;
}

/* Merkez sigil — yavaşça döner, ışıldar */
.or-think-sigil {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translate(-50%, -50%);
  font-family: 'Cormorant Garamond', 'Cinzel', serif;
  font-size: 14px;
  color: rgba(255, 200, 210, 0.95);
  text-shadow:
    0 0 6px rgba(233, 32, 56, 0.85),
    0 0 14px rgba(233, 32, 56, 0.5);
  animation:
    k-mystic-spin 7s linear infinite,
    k-mystic-shine 2.6s ease-in-out infinite;
  pointer-events: none;
}

/* İz — sigil'in sağına doğru ince yatay parıltı çizgisi */
.or-think-trail {
  width: 36px;
  height: 1px;
  background: linear-gradient(90deg,
    rgba(233, 32, 56, 0.0) 0%,
    rgba(233, 32, 56, 0.55) 35%,
    rgba(255, 140, 150, 0.85) 60%,
    rgba(233, 32, 56, 0.0) 100%);
  background-size: 200% 100%;
  animation: k-mystic-trail 2.2s linear infinite;
  opacity: 0.85;
}

/* Fısıltı yazısı */
.or-think-whisper {
  font-family: 'Cormorant Garamond', 'Cinzel', serif;
  font-style: italic;
  font-size: 14px;
  letter-spacing: 0.06em;
  color: rgba(255, 220, 226, 0.65);
  text-shadow: 0 0 8px rgba(233, 32, 56, 0.35);
  animation: k-mystic-whisper 2.6s ease-in-out infinite;
  white-space: nowrap;
}

@keyframes k-mystic-breathe {
  0%, 100% {
    transform: scale(0.85);
    opacity: 0.55;
    box-shadow:
      0 0 8px rgba(233, 32, 56, 0.25),
      inset 0 0 6px rgba(233, 32, 56, 0.15);
  }
  50% {
    transform: scale(1.08);
    opacity: 1;
    box-shadow:
      0 0 18px rgba(233, 32, 56, 0.5),
      inset 0 0 14px rgba(233, 32, 56, 0.28);
  }
}
@keyframes k-mystic-breathe-rev {
  0%, 100% {
    transform: translateY(-50%) scale(1.08);
    opacity: 0.85;
  }
  50% {
    transform: translateY(-50%) scale(0.78);
    opacity: 0.35;
  }
}
@keyframes k-mystic-spin {
  0%   { transform: translate(-50%, -50%) rotate(0deg);   }
  100% { transform: translate(-50%, -50%) rotate(360deg); }
}
@keyframes k-mystic-shine {
  0%, 100% { opacity: 0.65; filter: brightness(0.95); }
  50%      { opacity: 1;    filter: brightness(1.25); }
}
@keyframes k-mystic-trail {
  0%   { background-position: -100% 0; }
  100% { background-position:  100% 0; }
}
@keyframes k-mystic-whisper {
  0%, 100% { opacity: 0.45; letter-spacing: 0.06em; }
  50%      { opacity: 0.85; letter-spacing: 0.10em; }
}

/* Eski dots yapısı — uyumluluk için minimum stil (artık kullanılmıyor) */
.or-think-dots {
  display: inline-flex;
  gap: 6px;
  align-items: center;
  padding: 4px 2px;
}
.or-think-dots > span {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255, 100, 120, 0.75);
  animation: k-mystic-shine 1.3s ease-in-out infinite;
}

/* v68.28 — GLOWING BUTTON: TREN BORDER + SENKRON GLOW
   - Kutu rengi %90 siyah, sabit.
   - Border'da bir ışık bandı 4 kenar boyunca TAM TUR atar (conic-gradient mask).
   - Arka glow (box-shadow), tren bandının rengiyle EŞZAMANLI değişir.
   - Parlama büyüklüğü küçültüldü (daha kompakt aura). */

.k2-shape-rail {
  animation:
    k-rail-panel-in 800ms var(--k-ease-out) 400ms forwards,
    k-rail-glow-cycle 7s linear infinite;
}

@keyframes k-rail-glow-cycle {
  /* v68.35 — Site temasına uygun: KIRMIZI · KARBON GRİ · BEYAZ tonları
     Glow %50 azaltıldı. */
  /* CRIMSON — bant üstte */
  0%, 100% {
    border-color: rgba(233, 32, 56, 0.20);
    box-shadow:
      inset 0 0 0 1px rgba(255, 255, 255, 0.025),
      0 6px 18px rgba(0, 0, 0, 0.5),
      0 0 8px rgba(233, 32, 56, 0.28),
      0 0 20px rgba(233, 32, 56, 0.14);
  }
  /* EMBER (sıcak turuncu-kırmızı) — sağda */
  25% {
    border-color: rgba(255, 110, 90, 0.18);
    box-shadow:
      inset 0 0 0 1px rgba(255, 255, 255, 0.025),
      0 6px 18px rgba(0, 0, 0, 0.5),
      0 0 8px rgba(255, 110, 90, 0.26),
      0 0 20px rgba(255, 110, 90, 0.12);
  }
  /* KARBON BEYAZ — altta (mistik gümüşi) */
  50% {
    border-color: rgba(220, 220, 225, 0.18);
    box-shadow:
      inset 0 0 0 1px rgba(255, 255, 255, 0.025),
      0 6px 18px rgba(0, 0, 0, 0.5),
      0 0 8px rgba(220, 220, 225, 0.22),
      0 0 20px rgba(220, 220, 225, 0.10);
  }
  /* KOYU KIZIL — solda */
  75% {
    border-color: rgba(170, 20, 45, 0.20);
    box-shadow:
      inset 0 0 0 1px rgba(255, 255, 255, 0.025),
      0 6px 18px rgba(0, 0, 0, 0.5),
      0 0 8px rgba(170, 20, 45, 0.28),
      0 0 20px rgba(170, 20, 45, 0.14);
  }
}

/* v68.28 — BORDER "TREN" EFEKTİ — TAM TUR
   Kutu sabit, dönmez. Border'ın üzerinde bir ışık bandı conic-gradient ile
   yazılır; conic'in başlangıç AÇISI 0°→360° animatif değişir → bant 4 kenar
   boyunca tam tur döner. Süre 6s, glow ile birebir senkron. */
@property --rail-angle {
  syntax: '<angle>';
  inherits: false;
  initial-value: 0deg;
}

.k2-shape-rail::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 16px;
  padding: 1px;            /* border kalınlığı */
  /* v68.35 — Site temasına uygun: kırmızı → ember → karbon beyaz → koyu kızıl */
  background: conic-gradient(
    from var(--rail-angle, 0deg) at 50% 50%,
    rgba(233, 32, 56, 0.0)   0%,
    rgba(233, 32, 56, 0.0)   7%,
    rgba(233, 32, 56, 0.75)  13%,
    rgba(255, 110, 90, 0.95) 18%,
    rgba(220, 220, 225, 0.85) 22%,
    rgba(170, 20, 45, 0.7)   26%,
    rgba(170, 20, 45, 0.0)   32%,
    rgba(170, 20, 45, 0.0)  100%
  );
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
  opacity: 0.92;
  animation: k-rail-border-train 7s linear infinite;
}

@keyframes k-rail-border-train {
  0%   { --rail-angle: 0deg; }
  100% { --rail-angle: 360deg; }
}

/* @property desteklemeyen tarayıcılar için fallback:
   Tüm pseudo'yu çok hafif rotate ederek aynı etkiyi taklit eder. */
@supports not (background: conic-gradient(from var(--x, 0deg), red, blue)) {
  .k2-shape-rail::before {
    animation: k-rail-border-spin-fb 6s linear infinite;
  }
  @keyframes k-rail-border-spin-fb {
    to { transform: rotate(360deg); }
  }
}

.k2-shape-rail::after {
  content: none;
}

/* v68.23 — PARTİKÜL FIRLATMA — JS ile rail içine eklenen 8 sprite
   Her partikül rail kenarından dışarı doğru fırlar, soluk bir iz bırakır */
.k2-rail-spark {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(255, 120, 140, 1);
  box-shadow:
    0 0 5px rgba(255, 80, 100, 0.95),
    0 0 12px rgba(233, 32, 56, 0.6),
    0 0 20px rgba(255, 80, 120, 0.3);
  pointer-events: none;
  opacity: 0;
  z-index: 13;
  --spark-dx: -80px;
  --spark-dy: 0px;
  animation: k-rail-spark-fly 2.8s ease-out infinite;
}
.k2-rail-spark.k2-rs--purple {
  background: rgba(220, 140, 255, 1);
  box-shadow:
    0 0 5px rgba(180, 60, 220, 0.95),
    0 0 12px rgba(180, 60, 220, 0.6),
    0 0 20px rgba(180, 100, 255, 0.3);
}
.k2-rail-spark.k2-rs--cyan {
  background: rgba(160, 220, 255, 1);
  box-shadow:
    0 0 5px rgba(120, 180, 255, 0.95),
    0 0 12px rgba(120, 180, 255, 0.6),
    0 0 20px rgba(120, 200, 255, 0.3);
}
@keyframes k-rail-spark-fly {
  0%   { opacity: 0; transform: translate(0, 0) scale(0.4); }
  10%  { opacity: 1; transform: translate(calc(var(--spark-dx) * 0.15), calc(var(--spark-dy) * 0.15)) scale(1.2); }
  60%  { opacity: 0.6; }
  100% { opacity: 0; transform: translate(var(--spark-dx), var(--spark-dy)) scale(0.2); }
}

/* ──────────────────────────────────────────────────────────
   v68.6 — CANVAS FULL VIEWPORT FIX
   Sorun: .or-app { top: var(--or-top); bottom: var(--or-hud) }
          → .or-stage (canvas container) topbar ve HUD arasına sıkışıyordu,
          dolayısıyla canvas yukarı/aşağı kesiliyor, dalga animasyonları
          topbar/HUD'un ARKASINA gidemiyordu.
   Çözüm: #orCanvas'ı .or-stage'den koparıp fixed full viewport yap.
          z-index 0 → topbar (9200) ve HUD (8000) üstünde GÖRÜNÜR kalır.
   ────────────────────────────────────────────────────────── */
#orCanvas {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  z-index: 0 !important;
  pointer-events: auto;
}

/* .or-stage artık sadece overlay container'ı (meta yazıları için).
   Canvas'ı içermediği için yine de kendi alanını kapsasın ama
   tıklamaları canvas'a geçirsin. */
.or-stage {
  position: relative;
  z-index: 1;
  background: transparent !important;
  pointer-events: none;
}
.or-stage > * { pointer-events: auto; }

/* v68.11 — KÂHİN TEPKİ KATMANI (GÜÇLENDİRİLMİŞ):
   Mix-blend-mode kaldırıldı, doğrudan parlak overlay kullanılıyor.
   Gradient'lar büyütüldü, opacity artırıldı, süre uzatıldı.
   Gözler ~47%/53% yatay, ~42% dikey civarında. */
.kaahin-pulse {
  position: fixed;
  inset: 0;
  z-index: 4;                /* canvas (0) ve or-app (5) arası — UI gizlenmesin */
  pointer-events: none;
  opacity: 0;
  background:
    /* Sol göz */
    radial-gradient(circle 110px at 47% 42%,
      rgba(255, 140, 160, 1) 0%,
      rgba(255, 60, 90, 0.85) 18%,
      rgba(233, 32, 56, 0.45) 45%,
      rgba(233, 32, 56, 0) 75%),
    /* Sağ göz */
    radial-gradient(circle 110px at 53% 42%,
      rgba(255, 140, 160, 1) 0%,
      rgba(255, 60, 90, 0.85) 18%,
      rgba(233, 32, 56, 0.45) 45%,
      rgba(233, 32, 56, 0) 75%);
  transition: opacity 220ms ease-out, transform 220ms ease-out;
  will-change: opacity, transform;
}
/* Her tuş darbesi — gözler güçlü kırmızı flash + hafif pulse */
body.kaahin-tap .kaahin-pulse {
  opacity: 1;
  animation: k-kaahin-tap-pulse 360ms ease-out;
}
@keyframes k-kaahin-tap-pulse {
  0%   { opacity: 0;   transform: scale(0.85); }
  35%  { opacity: 1;   transform: scale(1.08); }
  100% { opacity: 0.6; transform: scale(1);    }
}

/* Çok hızlı yazma — kâhin tüm yüzü kırmızıya bürünür */
.kaahin-storm-veil {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0;
  background: radial-gradient(
    ellipse 50% 45% at center 45%,
    rgba(255, 40, 60, 0.55) 0%,
    rgba(180, 10, 30, 0.38) 35%,
    rgba(80, 0, 10, 0.20) 65%,
    transparent 90%);
  mix-blend-mode: screen;
  transition: opacity 380ms ease-out;
}
body.kaahin-storm .kaahin-storm-veil {
  opacity: 1;
  animation: k-kaahin-storm 1.4s ease-in-out infinite;
}
@keyframes k-kaahin-storm {
  0%, 100% { opacity: .8; }
  50%      { opacity: 1; }
}

/* v85.7 — KÂHİN DENY (HAYIR kırmızı tint) KALDIRILDI — kullanıcı talebi.
   body.kaahin-deny class artık tetiklenmiyor, tüm efekt no-op.
   Stiller geri eklenmek istenirse v85.3 backup'tan alınabilir. */

/* v68.7 — UI elemanları canvas'ın üstünde kalsın (sadece z-index, position'a dokunma) */
.or-app          { z-index: 5; }
.or-term         { z-index: 6; }
.k2-input-row    { z-index: 7; }
.shape-drawer    { z-index: 11; }
.k2-stones-list  { z-index: 11; }
.k2-shape-rail   { z-index: 12; }
/* .or-app'ı kendi grid layout'u içinde tut; sadece terminal solunu
   topbar arkasında bırakma — top/bottom değerleri kalmalı çünkü
   panel ve input bunları kullanıyor. */

@keyframes k-rail-panel-in {
  /* v71.9 — scale(0.8) animasyon boyunca korunmalı */
  from { opacity: 0; transform: translateY(-50%) translateX(12px) scale(var(--k-rail-scale, 0.8)); }
  to   { opacity: 1; transform: translateY(-50%) translateX(0)    scale(var(--k-rail-scale, 0.8)); }
}

.k2-shape-rail-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;             /* itemları yatayda ortala */
  gap: clamp(4px, 0.8vh, 10px);

  width: 100%;
  max-height: 100%;
  /* v68.5 — Tooltip sola taşabilsin diye overflow KAPALI değil.
     8-9 item zaten viewport'a sığıyor, scroll gerekmez. */
  overflow: visible;
  scrollbar-width: none;
  justify-content: center;         /* dikey eksende ortala */
}
.k2-shape-rail-list::-webkit-scrollbar { display: none; }

.k2-shape-rail-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 2px 2px 0 2px;
  cursor: pointer;
  transition: transform 220ms var(--k-ease);
  flex: 0 0 auto;
  width: 100%;
  /* Stagger girişi — sadece opacity, transform kullanma (panel ortalamasını bozmasın) */
  opacity: 0;
  animation: rail-enter 520ms var(--k-ease-out) forwards;
}
.k2-shape-rail-item:nth-child(1) { animation-delay: 450ms; }
.k2-shape-rail-item:nth-child(2) { animation-delay: 520ms; }
.k2-shape-rail-item:nth-child(3) { animation-delay: 590ms; }
.k2-shape-rail-item:nth-child(4) { animation-delay: 660ms; }
.k2-shape-rail-item:nth-child(5) { animation-delay: 730ms; }
.k2-shape-rail-item:nth-child(6) { animation-delay: 800ms; }
.k2-shape-rail-item:nth-child(7) { animation-delay: 870ms; }
.k2-shape-rail-item:nth-child(8) { animation-delay: 940ms; }
.k2-shape-rail-item:nth-child(9) { animation-delay: 1010ms; }

@keyframes rail-enter {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.k2-shape-rail-icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  /* v68.30 — Şekiller %20 daha geniş: 51→61, 69→83 */
  width: clamp(61px, 7.2vh, 83px);
  height: clamp(61px, 7.2vh, 83px);
  border-radius: 10px;
  background: rgba(8,6,10,.85);
  border: 1px solid rgba(255,255,255,.06);
  overflow: hidden;
  transition:
    border-color 280ms var(--k-ease),
    box-shadow 280ms var(--k-ease),
    transform 280ms var(--k-ease);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.03),
    0 4px 12px rgba(0,0,0,.5);
}
.k2-shape-rail-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .75;
  filter: contrast(1.1) brightness(.92);
  transition: opacity 280ms var(--k-ease), filter 280ms var(--k-ease);
}

.k2-shape-rail-label {
  font-family: var(--k-font-mono);
  font-size: clamp(7px, 0.85vh, 9px);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--k-ink-mute);
  font-weight: 500;
  transition: color 280ms var(--k-ease);
  white-space: nowrap;
  line-height: 1;
}

/* v68.9 — Hover'da içerideki şekil HAREKET ETMEZ; sadece kenar parlar */
.k2-shape-rail-item:hover .k2-shape-rail-icon {
  border-color: rgba(233,32,56,.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    0 6px 20px rgba(0,0,0,.6),
    0 0 18px rgba(233,32,56,.25);
}
.k2-shape-rail-item:hover .k2-shape-rail-icon img {
  opacity: 1;
  filter: contrast(1.15) brightness(1);
}
.k2-shape-rail-item:hover .k2-shape-rail-label {
  color: var(--k-ink-dim);
}

/* v68.4 — Active state: KIRMIZI BORDER KALDIRILDI.
   Sadece içsel parıltı + alt-üst aurası — daha mistik, daha sessiz seçim. */
.k2-shape-rail-item.is-active .k2-shape-rail-icon {
  border-color: rgba(220, 210, 230, 0.18);   /* gümüşi hairline */
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    inset 0 0 18px rgba(233, 32, 56, 0.18),  /* içten yumuşak kırmızı sızıntı */
    0 8px 24px rgba(0, 0, 0, 0.6),
    0 0 24px rgba(233, 32, 56, 0.12);        /* dışta hafif aura, border yok */
  animation: k-pulse-red 4s var(--k-ease) infinite;
}
.k2-shape-rail-item.is-active .k2-shape-rail-icon img {
  opacity: 1;
  filter: contrast(1.2) brightness(1.05);
}
.k2-shape-rail-item.is-active .k2-shape-rail-label {
  color: var(--k-ink);
  text-shadow: 0 0 10px rgba(233, 32, 56, .35);
}

/* ──────────────────────────────────────────────────────────
   v68.4 — RAIL TOOLTIP: ikona hover'da sol tarafa modül adı çıkar.
   Sayfa diline uyumlu: koyu cam + gümüşi hairline + mono uppercase.
────────────────────────────────────────────────────────── */
.k2-shape-rail-item {
  position: relative;  /* tooltip için ankor */
}
.k2-shape-rail-item::before {
  content: attr(data-tip);
  position: absolute;
  right: calc(100% + 12px);          /* item'in soluna konumlan */
  /* v68.6 — Tooltip yüksekliği şekil ile aynı: ikon kutusu ile aynı top hizası,
     yüksekliği clamp(51px, 6vh, 69px) — flex ile içerik dikey ortalı. */
  top: 6px;                          /* ikonun üst kenarı item içinde 6px (padding-üstü) */
  height: clamp(51px, 6vh, 69px);    /* ikon yüksekliği ile birebir */
  display: flex;
  align-items: center;
  white-space: nowrap;
  font-family: var(--k-font-mono);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: rgba(245, 230, 232, 0.94);
  padding: 0 16px;
  /* v68.8 — Siyah yoğun arkaplan, kırmızı sadece hairline'da */
  background: rgba(0, 0, 0, 0.96);
  border: 1px solid rgba(233, 32, 56, 0.28);
  border-radius: 3px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 8px 24px rgba(0, 0, 0, 0.85),
    0 0 14px rgba(233, 32, 56, 0.12);
  opacity: 0;
  pointer-events: none;
  transform: translateX(6px);
  transition:
    opacity 220ms var(--k-ease),
    transform 280ms var(--k-ease);
  z-index: 20;
}
/* Tooltip kuyruğu — sağ tarafa küçük chevron (kırmızı tonlu) */
.k2-shape-rail-item::after {
  content: '';
  position: absolute;
  right: calc(100% + 7px);
  top: 50%;
  width: 6px;
  height: 6px;
  background: rgba(0, 0, 0, 0.96);
  border-right: 1px solid rgba(233, 32, 56, 0.28);
  border-top: 1px solid rgba(233, 32, 56, 0.28);
  transform: translateY(-50%) rotate(45deg) translateX(6px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 200ms var(--k-ease), transform 260ms var(--k-ease);
  z-index: 20;
}
.k2-shape-rail-item:hover::before {
  opacity: 1;
  transform: translateX(0);
}
.k2-shape-rail-item:hover::after {
  opacity: 1;
  transform: translateY(-50%) rotate(45deg) translateX(0);
}
/* data-tip yoksa tooltip görünmesin */
.k2-shape-rail-item:not([data-tip])::before,
.k2-shape-rail-item:not([data-tip])::after { display: none; }

/* ══════════════════════════════════════════════════════════════════════
   v68.6 — HUD INFO POPUP — Kâhin'e özel mistik yeniden tasarım
   Bu CSS sadece kaahin2.html tarafından yüklendiği için doğrudan
   .inlab-info-* sınıflarını burada override etmek güvenli.
   Tasarım dili: ritüel ekranlarıyla uyumlu — siyah/kırmızı/krem,
   Cinzel başlık + Cormorant açıklama + JetBrains Mono etiket.
═══════════════════════════════════════════════════════════════════════ */

/* Backdrop — daha mistik: koyu vinyet + ince kırmızı sızıntı */
.inlab-info-overlay {
  background:
    radial-gradient(ellipse at center,
      rgba(20, 6, 10, 0.78) 0%,
      rgba(0, 0, 0, 0.92) 80%) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
}

/* Card — kâğıt / taş hissi: koyu zemin + ince kırmızı hairline +
   üst köşede sigil + alt köşede rünik */
.inlab-info-popup {
  background:
    radial-gradient(ellipse at top,
      rgba(28, 10, 16, 0.55) 0%,
      rgba(8, 6, 10, 0.98) 70%),
    #060306 !important;
  border: 1px solid rgba(233, 32, 56, 0.18) !important;
  border-radius: 2px !important;
  max-width: 520px !important;
  padding: 0 !important;
  overflow: visible !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    inset 0 0 60px rgba(233, 32, 56, 0.05),
    0 24px 60px rgba(0, 0, 0, 0.7),
    0 0 80px rgba(233, 32, 56, 0.10) !important;
  position: relative;
  animation: k-info-card-in 520ms var(--k-ease-out) both;
}
@keyframes k-info-card-in {
  from { opacity: 0; transform: translateY(8px) scale(0.985); }
  to   { opacity: 1; transform: translateY(0)   scale(1); }
}

/* Kart üst+alt köşelerine ince rünik çentikler */
.inlab-info-popup::before,
.inlab-info-popup::after {
  content: '';
  position: absolute;
  left: 50%;
  width: 36px;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(233, 32, 56, 0.55) 50%,
    transparent 100%);
  transform: translateX(-50%);
  pointer-events: none;
}
.inlab-info-popup::before { top: -1px; }
.inlab-info-popup::after  { bottom: -1px; }

/* Head — Cinzel başlık + üstte küçük mono etiket */
.inlab-info-popup__head {
  position: relative;
  padding: 40px 36px 18px !important;
  margin: 0 !important;
  border-bottom: 1px solid rgba(233, 32, 56, 0.12);
  text-align: center;
}
/* Başlığın üzerinde küçük etiket: "KÂHIN · SÖZLER" */
.inlab-info-popup__head::before {
  content: 'KAAHIN · SÖZLER';
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: .5em;
  text-transform: uppercase;
  color: rgba(233, 32, 56, 0.7);
  margin-bottom: 14px;
  padding-left: .5em;  /* letter-spacing optical düzeltme */
}

.inlab-info-popup__title {
  font-family: 'Marcellus', 'EB Garamond', serif !important;
  font-size: 2.2rem !important;
  font-weight: 500 !important;
  letter-spacing: .08em !important;
  color: #f3e9d8 !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}
.inlab-info-popup__title em {
  font-style: normal !important;
  color: #e92038 !important;
  text-shadow: 0 0 18px rgba(233, 32, 56, 0.45);
}

/* Close button — sağ üst minimal X */
.inlab-info-popup__close {
  top: 12px !important;
  right: 12px !important;
  width: 32px !important;
  height: 32px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  background: transparent !important;
  border: 1px solid rgba(233, 32, 56, 0.18) !important;
  color: rgba(245, 230, 232, 0.55) !important;
  font-size: 0.85rem !important;
  border-radius: 0 !important;
  transition: all 220ms var(--k-ease) !important;
}
.inlab-info-popup__close:hover {
  color: #e92038 !important;
  border-color: rgba(233, 32, 56, 0.55) !important;
  background: rgba(233, 32, 56, 0.08) !important;
  transform: rotate(90deg);
}

/* Body — satırlar dikey listeli, italik Cormorant açıklama */
.inlab-info-popup__body {
  padding: 22px 36px 36px !important;
  gap: 14px !important;
}

/* Her satır: sol ikon + sağ metin, ince ayraçlı */
.inlab-info-row {
  display: grid !important;
  grid-template-columns: 28px 1fr !important;
  gap: 16px !important;
  align-items: start !important;
  padding: 14px 0 !important;
  border-bottom: 1px dashed rgba(233, 32, 56, 0.10) !important;
  border-left: none !important;
  background: transparent !important;
}
.inlab-info-row:last-child {
  border-bottom: none !important;
}

.inlab-info-row__icon {
  font-size: 0.95rem !important;
  color: rgba(233, 32, 56, 0.72) !important;
  margin-top: 0.18rem !important;
  text-align: center !important;
  width: 28px !important;
  filter: drop-shadow(0 0 6px rgba(233, 32, 56, 0.25));
}

.inlab-info-row__text {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

/* Label — mono uppercase, kırmızı tonlu */
.inlab-info-row__label {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 9px !important;
  font-weight: 500 !important;
  letter-spacing: .34em !important;
  text-transform: uppercase !important;
  color: rgba(245, 230, 232, 0.92) !important;
  line-height: 1 !important;
}

/* Desc — italic Cormorant, kâhin sözü gibi */
.inlab-info-row__desc {
  font-family: 'EB Garamond', Georgia, serif !important;
  font-size: 1.05rem !important;
  font-style: italic !important;
  font-weight: 400 !important;
  letter-spacing: .01em !important;
  color: rgba(230, 220, 225, 0.78) !important;
  line-height: 1.45 !important;
}

/* Highlight satırı (varsa) — kahin tonunda */
.inlab-info-row--highlight {
  background: linear-gradient(135deg,
    rgba(233, 32, 56, 0.10) 0%,
    rgba(28, 10, 16, 0.50) 100%) !important;
  border: 1px solid rgba(233, 32, 56, 0.30) !important;
  border-left: 2px solid rgba(233, 32, 56, 0.55) !important;
  padding: 14px 16px !important;
  margin-top: 6px !important;
}
.inlab-info-row--highlight .inlab-info-row__desc {
  color: rgba(245, 230, 232, 0.92) !important;
}

/* Section header — küçük etiket */
.inlab-info-section {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 8px !important;
  letter-spacing: .4em !important;
  color: rgba(233, 32, 56, 0.55) !important;
  border-bottom: 1px solid rgba(233, 32, 56, 0.12) !important;
  padding: 8px 0 4px !important;
  margin-top: 6px !important;
}

/* Mobil */
@media (max-width: 600px) {
  .inlab-info-popup { max-width: calc(100vw - 24px) !important; }
  .inlab-info-popup__head { padding: 32px 22px 14px !important; }
  .inlab-info-popup__title { font-size: 1.7rem !important; }
  .inlab-info-popup__body { padding: 18px 22px 28px !important; }
  .inlab-info-row__desc { font-size: 0.96rem !important; }
}

.shape-drawer.is-open { animation: k-fade-in var(--k-dur-med) var(--k-ease-out); }
.shape-card { transition: all var(--k-dur-med) var(--k-ease) !important; }
.shape-card:hover { filter: brightness(1.06) !important; }
.shape-card.is-active .shape-card-art {
  box-shadow: 0 0 24px var(--k-accent-glow) !important;
}

/* ──────────────────────────────────────────────────────────
   11. CORNER SIGIL — v63: SADE ÇİZGİSEL versiyon.
       Dönen halka + latince yazılar yerine: ince yatay çizgi,
       hafif kayan dikey çizgiler ve tek küçük nokta.
────────────────────────────────────────────────────────── */
.k2-corner-sigil {
  position: fixed;
  /* v65 — Topbar 52px yüksekliğinde, z-index 9200.
     Sağ üstteki MOOD · CALM, .or-stage içinde olduğu için topbar altına geliyor:
     topbar(52px) + .or-stage-meta top(.85rem ≈ 14px) = ~66px
     Yani sol üstü de topbar'ın hemen altına yerleştir. */
  top: calc(52px + .85rem);   /* topbar yüksekliği + sağ üst ile aynı dahili top */
  left: 1rem;                  /* sağ üstün padding'i ile eşle (.or-stage-meta padding: 0 1rem) */
  z-index: 9201;               /* topbar'ın üstünde olsun ki gizlenmesin */
  width: auto;
  height: auto;
  pointer-events: none;
  opacity: 0;
  animation: k-fade-in 1200ms var(--k-ease-out) 600ms forwards;

  /* v68.37 — Sa\u011f \u00fcst MOOD \u00b7 CALM ile birebir ayn\u0131 stil:
     mono font, 9px, harf aral\u0131kl\u0131, uppercase, k-ink-mute renkli */
  font-family: var(--k-font-mono);
  font-size: 9px;
  font-weight: 400;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--k-ink-mute);
  line-height: 1;
  white-space: nowrap;
}

/* v68.10 — Akan çizgi KALDIRILDI */
@keyframes k-corner-flow {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Eski SVG ring/codex/spark elementlerini gizle */
.k2-corner-sigil .k2-sigil-ring,
.k2-corner-sigil .k2-sigil-codex,
.k2-corner-sigil .k2-sigil-spark { display: none; }

/* v64 — Tek satır yatay layout: [● nokta] KAAHIN · LIVE  [|||||] */
.k2-corner-sigil .k2-corner-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  /* Sağ üstle aynı text stili — parent'tan miras */
  color: inherit;
  font: inherit;
  letter-spacing: inherit;
  vertical-align: middle;
}
.k2-corner-sigil .k2-corner-label .k2-cl-accent {
  color: var(--k-accent);
  font-size: .9em;
  /* Nokta nefes alır */
  animation: k-corner-dot 3.4s var(--k-ease) infinite;
  display: inline-block;
  line-height: 1;
}

/* v68.9 — Tick'ler büyütüldü (animasyon vurgusu artırıldı) */
.k2-corner-sigil .k2-corner-ticks {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  margin-left: 12px;
  vertical-align: middle;
  padding-left: 12px;
  border-left: 1px solid rgba(255,255,255,.10);
  height: 18px;
}
.k2-corner-sigil .k2-corner-ticks .tk {
  width: 2px;
  height: 8px;
  background: rgba(233,32,56,.55);
  animation: k-corner-tick 1.8s var(--k-ease) infinite;
  transform-origin: bottom;
  box-shadow: 0 0 3px rgba(233, 32, 56, .4);
}
.k2-corner-sigil .k2-corner-ticks .tk:nth-child(2) { animation-delay: .2s; height: 14px; }
.k2-corner-sigil .k2-corner-ticks .tk:nth-child(3) { animation-delay: .4s; height: 10px; }
.k2-corner-sigil .k2-corner-ticks .tk:nth-child(4) { animation-delay: .6s; height: 16px; }
.k2-corner-sigil .k2-corner-ticks .tk:nth-child(5) { animation-delay: .8s; height: 8px; }

@keyframes k-corner-dot {
  0%, 100% { opacity: 1;   text-shadow: 0 0 6px var(--k-accent-glow); }
  50%      { opacity: .45; text-shadow: 0 0 14px var(--k-accent-glow); }
}
@keyframes k-corner-tick {
  0%, 100% { opacity: .25; transform: scaleY(.5); }
  50%      { opacity: 1;   transform: scaleY(1.15); }
}

/* Mobil — küçült (topbar mobilde de 52px varsayıyoruz) */
@media (max-width: 640px) {
  .k2-corner-sigil {
    top: calc(52px + .65rem);
    left: .7rem;
    font-size: 9px;
  }
  .k2-corner-sigil .k2-corner-ticks {
    margin-left: 6px;
    padding-left: 6px;
    gap: 1.5px;
  }
}

/* ──────────────────────────────────────────────────────────
   12. HUD CANVAS ÖLÇEK + BREATH BOX — v63
   Voice/Heart canvasları büyütüldü; Breath canvas kaldırıldı,
   yerine yukarı-aşağı hareketli kutu kondu (mood-reactive).
────────────────────────────────────────────────────────── */
:root {
  --or-hud: 96px;   /* 82 → 96: daha büyük dalgalara yer */
}

/* HUD canvas container: yeni canvas yüksekliklerine yer */
#orHud .hud-canvas-row {
  align-items: center;
}
#orHud .hud-canvas-row canvas#bmVoice {
  height: 46px !important;
  width: 220px !important;
}
#orHud .hud-canvas-row canvas#bmHeart {
  height: 38px !important;
  width: 130px !important;
}

/* Voice segment biraz daha geniş */
#orHud .seg-canvas { min-width: 130px !important; }

/* v66 — BREATH: ÇİZGİSEL KÖŞELİ ANİMASYON.
   6 dikey çubuk yan yana, her biri sıralı yukarı-aşağı zıplayarak köşeli grafik etkisi yaratır.
   Voice/Heart canvas dalgalarıyla görsel tutarlılık. Mood'a göre renk/tempo değişir. */
.seg-breath-box .hud-canvas-row {
  gap: 0;
  justify-content: center;
}
/* v68.41 — Breath konteyneri: v68.40'a göre %50 küçültüldü, çubuklar daha ince.
   Yükseklikler ~yarıya indi (max 32→16), genişlik 220→110px, çubuk max 6→3px. */
.hud-breath-bars {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2px;
  height: 20px;            /* 38 → 20 (~yarı) */
  width: 100%;
  max-width: 110px;        /* 220 → 110 (yarı) */
  padding: 0 1px;
  margin: 0 auto;
}
.hud-br-bar {
  display: inline-block;
  flex: 1 1 0;
  min-width: 1px;          /* daha ince */
  max-width: 3px;          /* 6 → 3 (yarı) */
  background: linear-gradient(180deg,
                var(--k-accent) 0%,
                rgba(180, 20, 40, .85) 45%,
                rgba(40, 6, 10, .95) 100%);
  border-radius: 1px;
  transform-origin: center bottom;
  box-shadow: 0 0 3px rgba(233,32,56,.40);
  animation: k-br-bar 1.4s cubic-bezier(.5,0,.5,1) infinite;
}
/* 14 çubuk — yükseklikler yarıya indirildi (32→16, 30→15, vb.) */
.hud-br-bar.b-1  { height:  4px; animation-delay: 0s;    }
.hud-br-bar.b-2  { height:  7px; animation-delay: .06s; }
.hud-br-bar.b-3  { height: 11px; animation-delay: .12s; }
.hud-br-bar.b-4  { height: 15px; animation-delay: .18s; }
.hud-br-bar.b-5  { height: 13px; animation-delay: .24s; }
.hud-br-bar.b-6  { height:  9px; animation-delay: .30s; }
.hud-br-bar.b-7  { height:  6px; animation-delay: .36s; }
.hud-br-bar.b-8  { height:  5px; animation-delay: .42s; }
.hud-br-bar.b-9  { height:  9px; animation-delay: .48s; }
.hud-br-bar.b-10 { height: 13px; animation-delay: .54s; }
.hud-br-bar.b-11 { height: 16px; animation-delay: .60s; }
.hud-br-bar.b-12 { height: 12px; animation-delay: .66s; }
.hud-br-bar.b-13 { height:  7px; animation-delay: .72s; }
.hud-br-bar.b-14 { height:  4px; animation-delay: .78s; }

/* MOOD-REACTIVE — TÜMÜ SİYAH + KIRMIZI TONLARI, sadece tempo/yoğunluk değişir */
.seg-breath-box[data-mood="calm"] .hud-br-bar {
  background: linear-gradient(180deg,
                rgba(200, 30, 50, .85) 0%,
                rgba(120, 16, 28, .80) 50%,
                rgba(20, 4, 8, .9) 100%);
  box-shadow: 0 0 3px rgba(233,32,56,.30);
  animation-duration: 2.2s;
  opacity: .85;
}
.seg-breath-box[data-mood="happy"] .hud-br-bar {
  background: linear-gradient(180deg,
                #ff4a5e 0%,
                var(--k-accent) 50%,
                rgba(30, 4, 8, .95) 100%);
  box-shadow: 0 0 6px rgba(255,80,100,.55);
  animation-duration: 1s;
}
.seg-breath-box[data-mood="sad"] .hud-br-bar {
  background: linear-gradient(180deg,
                rgba(140, 20, 36, .65) 0%,
                rgba(70, 10, 18, .70) 50%,
                rgba(10, 2, 4, .9) 100%);
  box-shadow: 0 0 2px rgba(180,30,46,.25);
  animation-duration: 3s;
  opacity: .65;
}
.seg-breath-box[data-mood="angry"] .hud-br-bar {
  background: linear-gradient(180deg,
                #ff2a44 0%,
                var(--k-accent) 40%,
                rgba(50, 6, 10, 1) 100%);
  box-shadow: 0 0 10px rgba(233,32,56,.85);
  animation-duration: .65s;
}
.seg-breath-box[data-mood="thinking"] .hud-br-bar {
  background: linear-gradient(180deg,
                rgba(220, 40, 60, .9) 0%,
                rgba(110, 14, 24, .9) 55%,
                rgba(8, 2, 4, .95) 100%);
  box-shadow: 0 0 4px rgba(233,32,56,.4);
  animation-duration: 1.6s;
}

/* ──────────────────────────────────────────────────────────
   v67 — HUD SES BUTONU: belirgin açık/kapalı görünüm
   - Açık: kırmızı border + kırmızı ikon (mevcut)
   - Kapalı (.is-muted): dim border, gri ikon, hafif diagonal slash
────────────────────────────────────────────────────────── */
/* v68.50 — MÜZİK butonu da aynı .is-muted dilini kullanır (beyaz ikon + diagonal slash) */
.hud-seg.seg-sound .hud-sound-btn--info.is-muted,
.hud-seg.seg-music .hud-sound-btn--info.is-muted {
  background: rgba(0, 0, 0, .35) !important;
  border-color: rgba(255, 255, 255, .35) !important;
  color: #ffffff !important;
  box-shadow: none !important;
  position: relative;
}
.hud-seg.seg-sound .hud-sound-btn--info.is-muted::after,
.hud-seg.seg-music .hud-sound-btn--info.is-muted::after {
  /* Diagonal slash — net "kapalı" işareti */
  content: '';
  position: absolute;
  left: 4px;
  right: 4px;
  top: 50%;
  height: 1.5px;
  background: #ffffff;
  transform: rotate(-30deg);
  pointer-events: none;
  border-radius: 1px;
  box-shadow: 0 0 4px rgba(255, 255, 255, .4);
}
.hud-seg.seg-sound .hud-sound-btn--info.is-muted:hover,
.hud-seg.seg-music .hud-sound-btn--info.is-muted:hover {
  background: rgba(20, 12, 16, .65) !important;
  color: #ffffff !important;
  border-color: rgba(255, 255, 255, .55) !important;
}

/* KEYFRAME — köşeli step animasyon (sinüs değil, sert geçişli) */
@keyframes k-br-bar {
  0%, 100% { transform: scaleY(.4); opacity: .55; }
  50%      { transform: scaleY(1);  opacity: 1;   }
}

/* ──────────────────────────────────────────────────────────
   10. RESPONSIVE — v57: Mobil tam yeniden düzenleme
────────────────────────────────────────────────────────── */

/* TABLET (≤ 900px) — input genişler, taşlar grid yerine inline kalır */
@media (max-width: 900px) {
  .or-term, .k2-term {
    width: 100vw !important;
    padding: var(--k-s2) !important;
  }
  /* Input + mesaj alanı + taşlar listesi: viewport genişliğinin neredeyse tamamı */
  .or-term-input,
  .k2-input-row,
  .or-term-body,
  .k2-stream,
  .k2-stones-list {
    width: calc(100vw - var(--k-s4, 24px) * 2) !important;
    max-width: calc(100vw - 32px) !important;
  }
  .k2-stones-grid .or-stone-text { font-size: 12px; }
  /* v68.52 — Input + mesajlar (user & kahin) aynı boyutta tutar (tablet) */
  #orInput { font-size: 18px !important; }
  .or-term-body .or-line.user .body,
  .k2-stream .or-line.user .body,
  .or-term-body .or-line.ai .body,
  .k2-stream .or-line.ai .body {
    font-size: 18px !important;
  }
}

/* MOBİL (≤ 640px) — kompakt yerleşim:
   - Input padding/font/min-height küçülür
   - Mikrofon + gönder buton boyutu uygun küçülür
   - Sol action group sıkıştırılır
   - Şekil paneli yatay→dikey kompakt kalır (gizlenmez)
   - --k-input-bottom düşürülür ki klavye açıldığında input görünür kalsın */
@media (max-width: 640px) {
  :root {
    --k-input-bottom: 110px;     /* Mobilde input alta yakın */
  }

  /* INPUT — kompakt + flex-wrap yok, item'lar küçülerek sığar */
  .or-term-input,
  .k2-input-row {
    left: 10px !important;
    right: 10px !important;
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    min-height: 52px !important;
    gap: 4px !important;
    padding: 4px 6px !important;
    flex-wrap: nowrap !important;
    overflow: visible !important;
  }

  /* Input alanı esnek — butonlara yer açar */
  /* v68.52 — Input + mesajlar (user & kahin) aynı boyutta tutar (mobil 640) */
  #orInput {
    font-size: 17px !important;
    padding: 4px 6px !important;
    min-width: 0 !important;       /* ⚠️ KRİTİK: flex item taşmasın */
    flex: 1 1 0% !important;
    width: 0 !important;            /* flex shrink garantisi */
  }
  .or-term-body .or-line.user .body,
  .k2-stream .or-line.user .body,
  .or-term-body .or-line.ai .body,
  .k2-stream .or-line.ai .body {
    font-size: 17px !important;
  }

  /* Sol action group: 💎 🎴 → daha küçük */
  .k2-input-actions {
    gap: 2px !important;
    padding-right: 4px !important;
  }
  .k2-input-action {
    width: 30px !important;
    height: 30px !important;
    font-size: 11px !important;
    flex: 0 0 30px !important;
  }
  .k2-input-action:hover::after { display: none; }   /* Tooltip mobilde kapat */

  /* Mikrofon butonu */
  .or-iconbtn,
  .k2-iconbtn {
    width: 34px !important;
    height: 34px !important;
    font-size: 12px !important;
    flex: 0 0 34px !important;
  }

  /* Gönder butonu — kompakt ama mistik animasyon korunur */
  .or-send,
  .k2-send {
    width: 40px !important;
    height: 40px !important;
    flex: 0 0 40px !important;
  }
  .or-send-arrow { width: 18px; height: 18px; }
  .or-send::before,
  .k2-send::before { inset: -4px; }
  .or-send::after,
  .k2-send::after { inset: -8px; }

  /* Mesaj alanı — input üstünde tüm genişlik */
  .or-term-body,
  .k2-stream {
    left: 10px !important;
    width: calc(100vw - 20px) !important;
    bottom: calc(var(--k-input-bottom, 110px) + 64px) !important;
    top: 50px !important;
  }

  /* Fal taşları — input altında, viewport full width */
  .k2-stones-list {
    left: 10px !important;
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    top: calc(100vh - var(--k-input-bottom, 110px) + 10px) !important;
    bottom: 8px !important;
    z-index: 11 !important;
  }
  .k2-stones-list .or-stone-btn {
    padding: 7px 8px !important;
    gap: 8px !important;
    grid-template-columns: 22px 16px 1fr !important;
  }
  .k2-stones-list .or-stone-text {
    font-size: 12px !important;
    -webkit-line-clamp: 2;
  }
  .k2-stones-list .or-stone-num { font-size: 9px; }

  /* ŞEKİL PANELİ — mobilde GİZLENMEZ, kompakt versiyon görünür */
  .k2-shape-rail {
    right: 6px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    max-height: calc(100vh - var(--or-hud, 82px) - 100px) !important;
    padding: 6px 4px !important;
    border-radius: 10px !important;
    z-index: 13 !important;        /* Stones'dan üstte */
  }
  .k2-shape-rail-list {
    gap: 4px !important;
  }
  .k2-shape-rail-icon {
    width: 34px !important;
    height: 34px !important;
    border-radius: 8px !important;
  }
  .k2-shape-rail-label {
    font-size: 6.5px !important;
    letter-spacing: .14em !important;
  }

  /* HUD küçük ekranda alçalt */
  #orHud {
    min-height: 56px !important;
  }
}

/* DAR MOBİL (≤ 380px) — iPhone SE / küçük cihazlar */
@media (max-width: 380px) {
  .or-term-input,
  .k2-input-row {
    gap: 2px !important;
    padding: 3px 4px !important;
    min-height: 48px !important;
  }
  /* v68.52 — Input + mesajlar aynı boyutta (küçük mobil) */
  #orInput { font-size: 16px !important; }
  .or-term-body .or-line.user .body,
  .k2-stream .or-line.user .body,
  .or-term-body .or-line.ai .body,
  .k2-stream .or-line.ai .body {
    font-size: 16px !important;
  }
  .k2-input-action {
    width: 26px !important;
    height: 26px !important;
    flex: 0 0 26px !important;
  }
  .or-iconbtn,
  .k2-iconbtn {
    width: 30px !important;
    height: 30px !important;
    flex: 0 0 30px !important;
  }
  .or-send,
  .k2-send {
    width: 36px !important;
    height: 36px !important;
    flex: 0 0 36px !important;
  }
  .k2-shape-rail-icon {
    width: 28px !important;
    height: 28px !important;
  }
  .k2-shape-rail-label { display: none; }   /* En dar ekranda label kaldır */
}

/* ──────────────────────────────────────────────────────────
   11. ACCESSIBILITY
────────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   v68.36 — ORTAM PARTİKÜLLERİ
   Three.js yüz canvas'ının ÜSTÜNDE, UI'nin ALTINDA dolaşan az sayıda
   gri/beyaz/kırmızı zerre. Tıklama almaz, sadece atmosfer.
═══════════════════════════════════════════════════════════════════════ */
.kaahin-ambient-particles {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  z-index: 1;          /* canvas (0) üstünde, topbar/HUD (8000+) altında */
  pointer-events: none;
  opacity: 0;
  animation: k-ambient-fade-in 1800ms ease-out 600ms forwards;
  mix-blend-mode: screen;
}
@keyframes k-ambient-fade-in {
  to { opacity: 0.72; }
}
@media (prefers-reduced-motion: reduce) {
  .kaahin-ambient-particles { display: none; }
}

/* ══════════════════════════════════════════════════════════════════════
   v68.29 — INPUT BOX: TREN BORDER + SENKRON KIRMIZI GLOW
   Rail box ile birebir aynı mantık (kırmızı tonlarda).
   - Kutu rengi sabit (mevcut koyu cam), dönmez.
   - ::before üzerinde conic-gradient bandı 4 kenarda tam tur döner
     (@property --input-angle: 0→360deg).
   - Arka glow (box-shadow), tren'in o anki rengiyle aynı 6s döngüde
     kırmızı ↔ koyu kızıl ↔ ember tonları arasında senkron geçer.
   - Mevcut shimmer ::before override edilir; focus state korunur.
   - Eski k-pulse-red animasyonu kapatılır (yerine senkron glow).
═══════════════════════════════════════════════════════════════════════ */

@property --input-angle {
  syntax: '<angle>';
  inherits: false;
  initial-value: 0deg;
}

.or-term-input,
.k2-input-row {
  /* Kırmızı pulse yerine: rail ile aynı senkron glow */
  animation: k-input-glow-cycle 6s linear infinite !important;
}

@keyframes k-input-glow-cycle {
  /* KIRMIZI — bant üstte */
  0%, 100% {
    border-color: rgba(233, 32, 56, 0.20) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.04),
      0 6px 18px rgba(0, 0, 0, 0.5),
      0 0 12px rgba(233, 32, 56, 0.38),
      0 0 28px rgba(233, 32, 56, 0.18);
  }
  /* EMBER — sağ kenar */
  25% {
    border-color: rgba(255, 95, 70, 0.20) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.04),
      0 6px 18px rgba(0, 0, 0, 0.5),
      0 0 12px rgba(255, 95, 70, 0.38),
      0 0 28px rgba(255, 95, 70, 0.18);
  }
  /* KOYU KIZIL — alt */
  50% {
    border-color: rgba(170, 20, 45, 0.20) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.04),
      0 6px 18px rgba(0, 0, 0, 0.5),
      0 0 12px rgba(170, 20, 45, 0.40),
      0 0 28px rgba(170, 20, 45, 0.20);
  }
  /* CRIMSON — sol */
  75% {
    border-color: rgba(210, 30, 60, 0.20) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.04),
      0 6px 18px rgba(0, 0, 0, 0.5),
      0 0 12px rgba(210, 30, 60, 0.38),
      0 0 28px rgba(210, 30, 60, 0.18);
  }
}

/* TREN BANDI — eski shimmer ::before tamamen override edilir */
.or-term-input::before,
.k2-input-row::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: inherit !important;
  padding: 1px !important;           /* border kalınlığı */
  background: conic-gradient(
    from var(--input-angle, 0deg) at 50% 50%,
    rgba(233, 32, 56, 0.0)   0%,
    rgba(233, 32, 56, 0.0)   6%,
    rgba(255, 90, 70, 0.85) 14%,
    rgba(255, 60, 60, 1)    20%,
    rgba(170, 20, 45, 0.85) 26%,
    rgba(170, 20, 45, 0.0)  34%,
    rgba(233, 32, 56, 0.0) 100%
  ) !important;
  background-size: auto !important;
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0) !important;
  -webkit-mask-composite: xor !important;
          mask-composite: exclude !important;
  pointer-events: none !important;
  opacity: 1 !important;
  z-index: 1 !important;
  filter: none !important;
  animation: k-input-border-train 6s linear infinite !important;
}

@keyframes k-input-border-train {
  0%   { --input-angle: 0deg; }
  100% { --input-angle: 360deg; }
}

/* @property desteklemeyen tarayıcılar: fallback */
@supports not (background: conic-gradient(from var(--x, 0deg), red, blue)) {
  .or-term-input::before,
  .k2-input-row::before {
    animation: k-input-border-spin-fb 6s linear infinite !important;
  }
  @keyframes k-input-border-spin-fb {
    to { transform: rotate(360deg); }
  }
}

/* Focus state — glow biraz güçlenir, tren devam eder */
.or-term-input:focus-within,
.k2-input-row:focus-within {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 6px 22px rgba(0, 0, 0, 0.55),
    0 0 16px rgba(233, 32, 56, 0.50),
    0 0 36px rgba(233, 32, 56, 0.25) !important;
}
.or-term-input:focus-within::before,
.k2-input-row:focus-within::before {
  /* tren animasyonu focus'ta da aynı şekilde devam eder */
  animation: k-input-border-train 6s linear infinite !important;
}

/* ══════════════════════════════════════════════════════════════════════
   v68.39 — HUD CENTER: VOICE / HEART / BREATH EŞİT GENİŞLİK + YENİDEN SIRA
   ─────────────────────────────────────────────────────────────────────
   • Üç canvas segmenti aynı genişlikte (flex: 1, equal share).
   • Sıra: BREATH (sol) → VOICE (orta) → HEART (sağ).
   • HTML'deki doğal sıra Voice/Heart/Breath; CSS `order` ile yeniden dizilir.
══════════════════════════════════════════════════════════════════════ */
#orHud .hud-center {
  /* Merkez şerit içinde 3 canvas eşit pay alsın */
  justify-content: center !important;
}

/* Sadece üç canvas segmentini hedefle (action butonları taşındı → kalmadı) */
#orHud .hud-center .hud-seg.seg-canvas {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  max-width: 260px !important;          /* Voice canvas 220px + padding */
  padding: 0 .5rem !important;
}

/* Canvas / breath bars segment içinde tam ortalansın */
#orHud .hud-center .hud-seg.seg-canvas .hud-canvas-row {
  width: 100% !important;
  justify-content: center !important;
}

/* Voice canvas: eşit genişlik içinde sınırlı kalsın (240px'i geçmesin) */
#orHud .hud-canvas-row canvas#bmVoice {
  max-width: 100% !important;
}

/* SIRA: HTML doğal sırası Voice(1) → Heart(2) → Breath(3)
   İstenen: Breath sol → Voice orta → Heart sağ */
#orHud .hud-center .seg-breath-box { order: 1 !important; }    /* sol */
#orHud .hud-center #bmVoiceSeg     { order: 2 !important; }    /* orta */
#orHud .hud-center .hud-seg.seg-canvas:not(#bmVoiceSeg):not(.seg-breath-box) {
  order: 3 !important;                                          /* sağ → Heart */
}

/* ══════════════════════════════════════════════════════════════════════
   v68.38 — HUD ACTION SLOT TAŞIMA
   SES / MÜZİK / ŞEKİL butonları artık sağ .inlab-hud__actions
   içine taşınıyor. Hepsi INFO ile aynı yükseklikte (38px) — uzunluk
   içeriğe göre. MÜZİK butonu icon + "MÜZİK" label birlikte gösterir.
══════════════════════════════════════════════════════════════════════ */

/* Henüz taşınmamış segmentler (FOUC önleme): görünmesin */
#orHud .hud-center [data-hud-move="actions"] {
  visibility: hidden !important;
  width: 0 !important;
  padding: 0 !important;
  border: none !important;
  overflow: hidden !important;
}

/* Action slot: dikey ortalı, esnek genişlik */
#orHud .inlab-hud__actions {
  display: flex !important;
  align-items: center !important;
  gap: .4rem !important;
  padding: 0 1.1rem !important;
  border-left: 1px solid rgba(255, 255, 255, .07) !important;
  flex-shrink: 0 !important;
}

/* Taşınmış segment wrapper'ları: kendi padding / border'larını sıfırla,
   böylece action slot'unda tek bir buton gibi davransınlar */
#orHud .inlab-hud__actions .hud-seg.hud-seg--in-actions {
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  display: inline-flex !important;
  align-items: center !important;
  height: auto !important;
}

/* Üç buton da INFO ile aynı yükseklik (38px); genişlik içeriğe göre auto.
   v68.39 — flex-direction: row !important (legacy .set-tg column override'ını ezer)
   → ikon SOLDA, label SAĞDA garantili */
#orHud .inlab-hud__actions .hud-action-btn {
  height: 38px !important;
  width: auto !important;
  min-width: 38px !important;
  padding: 0 .7rem !important;
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .45rem !important;
  border-radius: 0 !important;
  font-family: var(--k-font-mono) !important;
  font-size: .68rem !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
}

/* Sadece icon olan butonlar (SES, ŞEKİL): kare 38×38, label gizli */
#orHud .inlab-hud__actions .hud-action-btn:not(.hud-action-btn--with-label) {
  width: 38px !important;
  padding: 0 !important;
}
#orHud .inlab-hud__actions .hud-action-btn:not(.hud-action-btn--with-label) .set-tg-k {
  display: none !important;
}

/* MÜZİK butonu: icon + "MÜZİK" yazısı yan yana görünür */
#orHud .inlab-hud__actions .hud-action-btn--with-label .set-tg-k {
  display: inline-block !important;
  font-family: var(--k-font-mono) !important;
  font-size: .65rem !important;
  letter-spacing: .16em !important;
  line-height: 1 !important;
  color: inherit !important;
}

/* İkon boyut tutarlılığı */
#orHud .inlab-hud__actions .hud-action-btn i {
  font-size: .92rem !important;
  line-height: 1 !important;
}

/* INFO da aynı 38px yükseklikte kalsın (zaten 38×38 idi, garantili tut) */
#orHud .inlab-hud__actions .inlab-hud__info-btn {
  height: 38px !important;
  width: 38px !important;
}

/* Mobil: butonları biraz daralt */
@media (max-width: 640px) {
  #orHud .inlab-hud__actions {
    gap: .28rem !important;
    padding: 0 .5rem !important;
  }
  #orHud .inlab-hud__actions .hud-action-btn,
  #orHud .inlab-hud__actions .inlab-hud__info-btn {
    height: 34px !important;
  }
  #orHud .inlab-hud__actions .hud-action-btn:not(.hud-action-btn--with-label) {
    width: 34px !important;
  }
  #orHud .inlab-hud__actions .hud-action-btn--with-label .set-tg-k {
    font-size: .58rem !important;
    letter-spacing: .12em !important;
  }
  #orHud .inlab-hud__actions .hud-action-btn--with-label {
    padding: 0 .55rem !important;
  }
}

/* ════════════════════════════════════════════════════════════════════
   v68.48 — TEST: Günlük ritüel limit reset butonu (DEV)
   ════════════════════════════════════════════════════════════════════ */
#orHud .inlab-hud__actions .hud-reset-btn {
  position: relative;
  color: rgba(255, 200, 160, 0.78) !important;
  border-left: 1px dashed rgba(255, 180, 120, 0.25) !important;
}
#orHud .inlab-hud__actions .hud-reset-btn:hover {
  color: #ffe2b0 !important;
  background: rgba(255, 180, 120, 0.08) !important;
}
#orHud .inlab-hud__actions .hud-reset-btn .hud-reset-badge {
  position: absolute;
  top: 2px;
  right: 2px;
  display: inline-block !important;
  padding: 1px 3px;
  font: 700 7px/1 "JetBrains Mono", ui-monospace, monospace;
  letter-spacing: 0.12em;
  background: #e6b070;
  color: #1a0a05;
  border-radius: 2px;
  pointer-events: none;
}
#orHud .inlab-hud__actions .hud-reset-btn.is-flash {
  animation: hud-reset-flash 480ms ease-out;
}
@keyframes hud-reset-flash {
  0%   { background: rgba(255, 200, 120, 0.55); color: #fff; box-shadow: 0 0 24px rgba(255, 200, 120, 0.55); }
  100% { background: transparent;                color: rgba(255, 200, 160, 0.78); box-shadow: none; }
}
#orHud .inlab-hud__actions .hud-reset-btn i {
  transition: transform 360ms cubic-bezier(.22, 1, .36, 1);
}
#orHud .inlab-hud__actions .hud-reset-btn.is-flash i {
  transform: rotate(-360deg);
}

/* Toast — sıfırlama bildirimi */
.ritual-reset-toast {
  position: fixed;
  top: 70px;
  left: 50%;
  transform: translate(-50%, -10px);
  z-index: 9999;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  background: rgba(20, 12, 8, 0.92);
  border: 1px solid rgba(255, 200, 120, 0.4);
  border-radius: 999px;
  color: #ffe2b0;
  font: 600 11px/1 "JetBrains Mono", ui-monospace, monospace;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0;
  pointer-events: none;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.55);
  transition: opacity 280ms ease, transform 380ms cubic-bezier(.22, 1, .36, 1);
}
.ritual-reset-toast.is-show {
  opacity: 1;
  transform: translate(-50%, 0);
}
.ritual-reset-toast i { color: #e6b070; }
.ritual-reset-toast span { opacity: 0.6; font-weight: 500; }
