/* ============================================================
   style.css — Işığını Bul ✨ · Premium wellbeing teması
   Gece mavisi / mor zemin · altın & lila vurgular · yumuşak glow
   Başlık: Playfair Display · Gövde: Inter
   ============================================================ */

:root {
  /* Zemin */
  --bg-0: #0c0a1c;
  --bg-1: #161033;
  --bg-2: #211743;

  /* Cam kartlar */
  --card-bg: rgba(255, 255, 255, 0.055);
  --card-bg-soft: rgba(255, 255, 255, 0.04);
  --card-border: rgba(179, 140, 255, 0.18);
  --blur: 10px;

  /* Metin — yüksek kontrast */
  --metin: #f4f0ff;
  --metin-soft: #c9c2e6;
  --metin-faint: #948db6;

  /* Vurgular */
  --accent: #b38cff;
  --accent-2: #8b6fd6;
  --accent-soft: rgba(179, 140, 255, 0.14);
  --gold: #e9c46a;
  --gold-soft: #f3d98c;
  --basari: #6fe0a8;
  --uyari: #ff7a9c;

  /* Fontlar */
  --font-baslik: "Playfair Display", Georgia, "Times New Roman", serif;
  --font-govde: "Inter", -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* Spacing ölçeği */
  --sp-1: 0.4rem;
  --sp-2: 0.7rem;
  --sp-3: 1rem;
  --sp-4: 1.5rem;
  --sp-5: 2rem;
  --sp-6: 3rem;

  --radius: 20px;
  --radius-sm: 14px;
  --shadow: 0 18px 50px rgba(0, 0, 0, 0.42);
  --glow-mor: 0 0 28px rgba(179, 140, 255, 0.35);
  --glow-gold: 0 0 28px rgba(233, 196, 106, 0.32);
  --gecis: 0.45s cubic-bezier(.21, .61, .35, 1);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
  font-family: var(--font-govde);
  color: var(--metin);
  min-height: 100vh;
  line-height: 1.6;
  letter-spacing: 0.1px;
  padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px));
  background:
    radial-gradient(1200px 800px at 50% -10%, #2a1d52 0%, transparent 60%),
    linear-gradient(165deg, var(--bg-0) 0%, var(--bg-1) 55%, var(--bg-2) 100%);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
}

/* ---------- Arka plan glow blob'ları ---------- */
.aura { position: fixed; inset: 0; z-index: -1; overflow: hidden; pointer-events: none; }
.aura .blob { position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.5; }
.blob-1 { width: 420px; height: 420px; top: -120px; left: -100px; background: #7c3aed; animation: yuz 22s ease-in-out infinite; }
.blob-2 { width: 380px; height: 380px; bottom: -140px; right: -80px; background: #b38cff; opacity: 0.32; animation: yuz 28s ease-in-out infinite reverse; }
.blob-3 { width: 300px; height: 300px; top: 40%; left: 55%; background: #e9c46a; opacity: 0.1; animation: yuz 26s ease-in-out infinite; }
@keyframes yuz { 0%, 100% { transform: translate(0, 0) scale(1); } 50% { transform: translate(40px, -30px) scale(1.12); } }

/* ---------- Gece Kozmik Modu ---------- */
.kozmik-katman { position: fixed; inset: 0; z-index: -1; overflow: hidden; pointer-events: none; display: none; }
.kz-nebula {
  position: absolute; inset: -12%;
  background:
    radial-gradient(38% 34% at 24% 30%, rgba(124, 58, 237, 0.38), transparent 60%),
    radial-gradient(34% 30% at 76% 24%, rgba(179, 140, 255, 0.3), transparent 60%),
    radial-gradient(46% 42% at 60% 82%, rgba(233, 196, 106, 0.12), transparent 62%);
  filter: blur(42px); will-change: transform;
  animation: nebulaKay 42s ease-in-out infinite alternate;
}
@keyframes nebulaKay { 0% { transform: translate(0, 0) scale(1); } 100% { transform: translate(-4%, 3%) scale(1.08); } }
.kz-yildizlar { position: absolute; inset: -5%; will-change: transform; }
.kz-yildiz { position: absolute; border-radius: 50%; background: #fff; opacity: 0.5; animation-name: yildizParla; animation-iteration-count: infinite; animation-timing-function: ease-in-out; }
.kz-yildiz.altin { background: var(--gold); }
.kz-yildiz.buyuk { box-shadow: 0 0 6px 1px rgba(255, 255, 255, 0.5); }
.kz-yildiz.buyuk.altin { box-shadow: 0 0 6px 1px rgba(233, 196, 106, 0.6); }
@keyframes yildizParla { 0%, 100% { opacity: 0.2; transform: scale(0.8); } 50% { opacity: 0.95; transform: scale(1.15); } }
.kz-parcaciklar { position: absolute; inset: 0; }
.kz-parcacik {
  position: absolute; width: 3px; height: 3px; border-radius: 50%;
  background: radial-gradient(circle, #fff4d6, rgba(233, 196, 106, 0.5));
  box-shadow: 0 0 8px 2px rgba(233, 196, 106, 0.4);
  opacity: 0; animation-name: parcacikAk; animation-iteration-count: infinite; animation-timing-function: linear;
}
@keyframes parcacikAk {
  0% { opacity: 0; transform: translate(0, 0); }
  12% { opacity: 1; }
  88% { opacity: 0.6; }
  100% { opacity: 0; transform: translate(46px, -130px); }
}

/* Kozmik mod aktifken genel atmosfer */
body.kozmik {
  background:
    radial-gradient(1200px 800px at 50% -10%, #34216b 0%, transparent 60%),
    linear-gradient(165deg, #080615 0%, #120b2e 55%, #1c123f 100%);
  background-attachment: fixed;
}
body.kozmik .aura { opacity: 0.45; }
body.kozmik .card { box-shadow: var(--shadow), 0 0 30px rgba(124, 58, 237, 0.2); border-color: rgba(179, 140, 255, 0.32); }
body.kozmik .card::before { opacity: 0.9; }
body.kozmik .bottom-nav { background: rgba(9, 7, 24, 0.8); }
body.kozmik .btn { box-shadow: 0 6px 18px rgba(124, 58, 237, 0.45), 0 0 18px rgba(179, 140, 255, 0.25); }

/* ---------- Bildirimler ---------- */
.bildirim-izin { margin-bottom: var(--sp-2); }
.bld-izinli { color: var(--basari); font-size: 0.85rem; }
.bld-detay { margin-top: var(--sp-2); }
.bld-satir { display: flex; align-items: center; justify-content: space-between; gap: 0.8rem; margin: var(--sp-2) 0; color: var(--metin); flex-wrap: wrap; }
.bld-baslik { margin: var(--sp-3) 0 0.5rem; }
.bld-aralik { display: inline-flex; align-items: center; gap: 0.4rem; color: var(--metin-soft); }
.bld-kategoriler { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.bld-cip {
  background: rgba(255, 255, 255, 0.05); border: 1px solid rgba(179, 140, 255, 0.18);
  color: var(--metin-soft); border-radius: 999px; padding: 0.45rem 0.9rem;
  font-family: inherit; font-size: 0.8rem; cursor: pointer; transition: all 0.2s;
}
.bld-cip:hover { color: var(--metin); border-color: var(--accent-2); }
.bld-cip.aktif { background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: #fff; border-color: transparent; box-shadow: var(--glow-mor); }
#bld-dene { margin-top: var(--sp-3); }

/* time input — koyu tema uyumu */
input[type="time"] {
  font-family: inherit; font-size: 0.9rem; color: var(--metin);
  background: rgba(8, 6, 20, 0.55); border: 1px solid rgba(179, 140, 255, 0.25);
  border-radius: 12px; padding: 0.4rem 0.7rem;
}
input[type="time"]:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(233, 196, 106, 0.18); }
input[type="time"]::-webkit-calendar-picker-indicator { filter: invert(1) sepia(1) saturate(2) hue-rotate(10deg); opacity: 0.7; cursor: pointer; }

/* In-app bildirim toast */
.bildirim-toast {
  position: fixed; left: 50%; top: calc(14px + env(safe-area-inset-top, 0px)); z-index: 200;
  max-width: min(92%, 420px);
  transform: translateX(-50%) translateY(-24px);
  display: flex; gap: 0.7rem; align-items: center;
  background: rgba(20, 14, 44, 0.92); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--card-border); border-radius: 16px;
  padding: 0.85rem 1.1rem; color: var(--metin);
  box-shadow: var(--shadow), var(--glow-mor);
  opacity: 0; pointer-events: none; transition: opacity 0.4s, transform 0.4s;
}
.bildirim-toast.gor { opacity: 1; transform: translateX(-50%) translateY(0); }
.bildirim-toast .bt-ikon { font-size: 1.2rem; filter: drop-shadow(0 0 6px rgba(233, 196, 106, 0.6)); }
.bildirim-toast .bt-metin { font-size: 0.92rem; line-height: 1.45; }

/* Ayar satırı + switch */
.ayar-satir { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.ayar-ad { color: var(--metin); font-weight: 500; }
.ayar-aciklama { margin-top: 0.15rem; }
.switch { position: relative; display: inline-block; width: 52px; height: 30px; flex-shrink: 0; cursor: pointer; }
.switch input { opacity: 0; width: 0; height: 0; }
.switch-yuva { position: absolute; inset: 0; background: rgba(255, 255, 255, 0.12); border: 1px solid rgba(179, 140, 255, 0.3); border-radius: 999px; transition: 0.3s; }
.switch-yuva::before { content: ""; position: absolute; left: 3px; top: 2px; width: 23px; height: 23px; border-radius: 50%; background: var(--metin-soft); transition: 0.3s; }
.switch input:checked + .switch-yuva { background: linear-gradient(135deg, var(--accent), var(--gold)); border-color: transparent; box-shadow: var(--glow-mor); }
.switch input:checked + .switch-yuva::before { transform: translateX(22px); background: #fff; }

/* ---------- Başlık & alt bilgi ---------- */
.site-header { text-align: center; padding: var(--sp-5) 1rem var(--sp-3); }
.logo-ay { width: 46px; height: 46px; margin: 0 auto 0.6rem; color: var(--gold); filter: drop-shadow(var(--glow-gold)); }
.logo-ay svg { width: 100%; height: 100%; }
.site-header h1 {
  margin: 0;
  font-family: var(--font-baslik);
  font-size: 2.3rem;
  font-weight: 600;
  letter-spacing: 1px;
  background: linear-gradient(100deg, var(--gold-soft), var(--accent) 70%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.site-header h1 span { color: var(--gold); -webkit-text-fill-color: var(--gold); font-style: italic; }
/* Marka kıvılcımı (✨) — gradient/clip metinden etkilenmesin, kendi parıltısı olsun */
.kivilcim { -webkit-text-fill-color: initial; color: initial; font-style: normal; filter: drop-shadow(0 0 8px rgba(233, 196, 106, 0.55)); }
.tarih { margin: 0.3rem 0 0; color: var(--metin-soft); text-transform: capitalize; font-size: 0.95rem; }
.karsilama { margin: 0.5rem 0 0.1rem; font-family: var(--font-baslik); font-style: italic; color: var(--gold-soft); font-size: 1.1rem; text-shadow: 0 0 20px rgba(233,196,106,0.25); }
.site-footer { text-align: center; padding: var(--sp-5) 1rem var(--sp-3); color: var(--metin-faint); font-size: 0.92rem; }

/* ---------- Karşılama / Onboarding ---------- */
.onboarding {
  position: fixed; inset: 0; z-index: 100;
  display: flex; align-items: center; justify-content: center;
  padding: 1.6rem; overflow: hidden;
  background:
    radial-gradient(900px 600px at 50% 18%, #2a1d52 0%, transparent 60%),
    linear-gradient(165deg, #0c0a1c 0%, #161033 60%, #211743 100%);
  animation: obFade 0.6s ease both;
}
.onboarding[hidden] { display: none; }
.onboarding.kapaniyor { animation: obOut 0.5s ease forwards; }
@keyframes obFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes obOut { to { opacity: 0; visibility: hidden; } }

.ob-gokyuzu { position: absolute; inset: 0; pointer-events: none; }
.ob-yildiz {
  position: absolute; width: 4px; height: 4px; border-radius: 50%;
  background: #fff; box-shadow: 0 0 8px 2px rgba(255, 255, 255, 0.6);
  opacity: 0.5; animation: parla 3.2s ease-in-out infinite;
}
.ob-yildiz.y1 { top: 16%; left: 20%; animation-delay: 0s; }
.ob-yildiz.y2 { top: 26%; right: 18%; animation-delay: 0.6s; background: var(--gold); box-shadow: 0 0 8px 2px rgba(233,196,106,0.7); }
.ob-yildiz.y3 { top: 70%; left: 14%; animation-delay: 1.2s; }
.ob-yildiz.y4 { bottom: 18%; right: 24%; animation-delay: 1.8s; background: var(--accent); box-shadow: 0 0 8px 2px rgba(179,140,255,0.7); }
.ob-yildiz.y5 { top: 44%; left: 8%; animation-delay: 2.4s; }
.ob-yildiz.y6 { bottom: 30%; right: 10%; animation-delay: 0.9s; }
@keyframes parla { 0%, 100% { opacity: 0.25; transform: scale(0.8); } 50% { opacity: 0.95; transform: scale(1.25); } }

.ob-kart {
  position: relative; z-index: 2;
  max-width: 380px; width: 100%; text-align: center;
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--card-border);
  border-radius: 26px;
  padding: 2.4rem 1.7rem;
  box-shadow: var(--shadow), var(--glow-mor);
  animation: obKart 0.8s cubic-bezier(.18, .7, .3, 1) both;
}
@keyframes obKart { from { opacity: 0; transform: translateY(24px) scale(0.96); } to { opacity: 1; transform: none; } }
.ob-logo { width: 64px; height: 64px; margin: 0 auto 1rem; color: var(--gold); filter: drop-shadow(var(--glow-gold)); animation: suzul 5s ease-in-out infinite; }
.ob-logo svg { width: 100%; height: 100%; }
@keyframes suzul { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
.ob-kart h2 {
  font-family: var(--font-baslik); font-size: 1.95rem; font-weight: 600; margin: 0 0 0.4rem; letter-spacing: 0.5px;
  background: linear-gradient(100deg, var(--gold-soft), var(--accent) 70%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.ob-kart h2 span { color: var(--gold); -webkit-text-fill-color: var(--gold); font-style: italic; }
.ob-alt { color: var(--metin-soft); margin: 0 0 1.4rem; }
.ob-kart input { margin-bottom: 1rem; text-align: center; font-size: 1.05rem; padding: 0.85rem; }
.ob-basla { width: 100%; padding: 0.9rem; font-size: 1rem; }
.ob-not { font-size: 0.75rem; color: var(--metin-faint); margin: 1.1rem 0 0; }
.ob-hesap-btnlar { display: flex; gap: 0.5rem; }
.ob-hesap-btnlar .btn { flex: 1; padding: 0.85rem; }
.ob-hesap-bilgi { display: block; min-height: 1.1em; font-size: 0.82rem; margin-top: 0.6rem; }
.sifre-goster { display: flex; align-items: center; gap: 0.4rem; font-size: 0.82rem; color: var(--metin-soft); cursor: pointer; margin: -0.4rem 0 0.6rem; justify-content: flex-start; }
.sifre-goster input { width: auto !important; margin: 0 !important; accent-color: var(--accent); }
@media (max-width: 640px) {
  .ob-kart { padding: 2rem 1.3rem; border-radius: 22px; }
  .ob-kart h2 { font-size: 1.7rem; }
}

/* ---------- Görünüm (view) sistemi ---------- */
.app { max-width: 1100px; margin: 0 auto; }
.view { display: none; }
.view.active { display: block; animation: viewIn 0.4s ease both; }
@keyframes viewIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* ---------- Grid düzeni — tutarlı spacing ---------- */
.grid {
  padding: var(--sp-3) var(--sp-4) var(--sp-5);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--sp-4);
  align-items: start;
}
.card-wide { grid-column: 1 / -1; }

/* ---------- Kart ---------- */
.card {
  position: relative;
  background: var(--card-bg);
  border-radius: var(--radius);
  padding: var(--sp-4);
  box-shadow: var(--shadow);
  backdrop-filter: blur(var(--blur));
  -webkit-backdrop-filter: blur(var(--blur));
  border: 1px solid var(--card-border);
  transition: transform var(--gecis), box-shadow var(--gecis), border-color var(--gecis);
}
.card::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(140deg, rgba(233,196,106,0.4), transparent 42%, rgba(179,140,255,0.3));
  -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.7;
}
/* Görünüm açıldığında kartlar yumuşak ve sıralı belirir */
.view.active .grid > .card { animation: kartBelir 0.55s var(--gecis) both; }
.view.active .grid > .card:nth-child(2) { animation-delay: 0.05s; }
.view.active .grid > .card:nth-child(3) { animation-delay: 0.1s; }
.view.active .grid > .card:nth-child(4) { animation-delay: 0.15s; }
.view.active .grid > .card:nth-child(5) { animation-delay: 0.2s; }
.view.active .grid > .card:nth-child(n+6) { animation-delay: 0.25s; }
@keyframes kartBelir { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }

/* Desktop hover — yükselme + glow artışı */
@media (hover: hover) and (pointer: fine) {
  .card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow), var(--glow-mor);
    border-color: rgba(179, 140, 255, 0.4);
  }
}

.card h2 {
  margin: 0 0 var(--sp-3);
  font-family: var(--font-baslik);
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: 0.3px;
  color: var(--gold-soft);
}
.card-motivasyon blockquote {
  margin: 0;
  font-family: var(--font-baslik);
  font-size: 1.5rem;
  font-style: italic;
  line-height: 1.5;
  color: var(--metin);
  text-shadow: 0 0 24px rgba(179, 140, 255, 0.2);
}

/* ---------- Butonlar (ışık animasyonlu) ---------- */
.btn {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 0.7rem 1.5rem;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0.3px;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(124, 58, 237, 0.35);
  transition: transform 0.15s, box-shadow var(--gecis), filter 0.25s;
}
.btn::after {
  content: "";
  position: absolute; top: 0; left: -130%;
  width: 60%; height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,0.4), transparent);
  transform: skewX(-20deg);
  transition: left 0.7s ease;
}
.btn:hover { filter: brightness(1.08); box-shadow: var(--glow-mor), 0 6px 18px rgba(124,58,237,0.4); }
.btn:hover::after { left: 140%; }
.btn:active { transform: scale(0.97); }
.btn.ghost { background: transparent; color: var(--accent); border: 1px solid var(--accent-2); box-shadow: none; }
.btn.ghost:hover { background: var(--accent-soft); box-shadow: var(--glow-mor); }
.btn.sm { padding: 0.45rem 1rem; font-size: 0.85rem; }
.file-label { display: inline-block; }

/* ---------- Form öğeleri (net, blur'suz) ---------- */
input[type="text"], textarea {
  width: 100%;
  font-family: inherit;
  font-size: 0.95rem;
  padding: 0.75rem 0.9rem;
  border: 1px solid rgba(179, 140, 255, 0.25);
  border-radius: var(--radius-sm);
  background: rgba(8, 6, 20, 0.55);
  color: var(--metin);
  resize: vertical;
  transition: border-color 0.2s, box-shadow 0.2s;
}
input::placeholder, textarea::placeholder { color: var(--metin-faint); }
input:focus, textarea:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(233, 196, 106, 0.18);
}
.ekle-satir { display: flex; gap: var(--sp-1); margin-bottom: var(--sp-3); }
.ekle-satir input { flex: 1; }
.satir-arasi { display: flex; align-items: center; gap: var(--sp-2); margin-top: var(--sp-2); flex-wrap: wrap; }
.kayit-bilgi { color: var(--basari); font-size: 0.85rem; }
.muted { color: var(--metin-soft); }
.small { font-size: 0.85rem; }
code { background: rgba(255,255,255,0.08); padding: 1px 5px; border-radius: 6px; font-size: 0.85em; }

/* ---------- İstikrar Serisi (Streak) ---------- */
.card-streak .streak-ust { display: flex; align-items: center; gap: var(--sp-3); }
.streak-alev {
  position: relative; flex-shrink: 0;
  width: 64px; height: 64px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 140, 50, 0.22), transparent 70%);
  animation: streakPulse 2.8s ease-in-out infinite;
}
.alev-svg { width: 50px; height: 50px; filter: drop-shadow(0 0 10px rgba(255, 140, 50, 0.55)); transition: filter 0.4s, transform 0.3s; }
@keyframes streakPulse {
  0%, 100% { box-shadow: 0 0 14px rgba(255, 140, 50, 0.3); }
  50%      { box-shadow: 0 0 28px rgba(255, 140, 50, 0.6); }
}
.streak-bilgi { flex: 1; min-width: 0; }
.streak-baslik { font-family: var(--font-baslik); font-size: 1.15rem; color: var(--gold-soft); }
.streak-sayi { font-size: 1.8rem; font-weight: 600; color: var(--gold); margin-right: 0.2rem; }
.streak-mesaj { color: var(--metin-soft); font-size: 0.92rem; margin-top: 0.15rem; }
.streak-bonus { margin-top: 0.35rem; font-size: 0.78rem; color: var(--gold); letter-spacing: 0.2px; }

.card-streak .streak-bar { height: 8px; background: rgba(255, 255, 255, 0.09); border-radius: 99px; overflow: hidden; margin-top: var(--sp-3); }
.card-streak .streak-bar span { display: block; height: 100%; border-radius: 99px; background: linear-gradient(90deg, #ff8a3a, var(--gold)); transition: width 0.6s; }
.streak-seviye-bilgi { font-size: 0.8rem; color: var(--metin-soft); margin-top: 0.4rem; }

.streak-tier-serit { display: flex; gap: 0.4rem; margin-top: var(--sp-2); }
.streak-tier {
  flex: 1; min-width: 0; text-align: center;
  font-size: 0.68rem; color: var(--metin-faint);
  background: var(--card-bg-soft);
  border: 1px solid rgba(179, 140, 255, 0.12);
  border-radius: 12px; padding: 0.45rem 0.2rem;
  transition: border-color 0.3s, box-shadow 0.3s, color 0.3s;
}
.streak-tier b { display: block; font-family: var(--font-baslik); font-size: 1.05rem; color: var(--metin-soft); margin-bottom: 1px; }
.streak-tier.kazanildi { border-color: var(--gold); color: var(--gold); box-shadow: var(--glow-gold); }
.streak-tier.kazanildi b { color: var(--gold); }

/* Görev tamamlandıysa alev daha güçlü; ruh hali kaydı bonus halkası */
.card-streak.gorev-tamam .alev-svg { filter: drop-shadow(0 0 20px rgba(255, 130, 40, 0.85)) drop-shadow(0 0 6px rgba(243, 217, 140, 0.7)); transform: scale(1.08); }
.card-streak.mood-bonus .streak-alev::after {
  content: ""; position: absolute; inset: -5px; border-radius: 50%;
  border: 1.5px solid rgba(233, 196, 106, 0.5);
  animation: streakPulse 2.8s ease-in-out infinite;
}
@media (max-width: 480px) {
  .streak-tier { font-size: 0.62rem; }
  .streak-tier b { font-size: 0.95rem; }
}

/* ---------- Ritüel (Günün Ritüeli) ---------- */
.rituel-bar { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; margin-bottom: var(--sp-3); }
.rituel-bar h2 { margin: 0; }
.rituel-xp { display: flex; align-items: center; gap: 0.4rem; }
.xp-rozet { font-size: 0.7rem; font-weight: 600; color: #1a1233; background: linear-gradient(135deg, var(--gold), var(--gold-soft)); padding: 0.2rem 0.55rem; border-radius: 999px; box-shadow: var(--glow-gold); }
.xp-deg { font-size: 0.78rem; color: var(--metin-faint); }

.rituel-kart {
  position: relative; text-align: center; overflow: hidden;
  background: radial-gradient(120% 80% at 50% 0%, rgba(124,58,237,0.22), transparent 65%), rgba(255,255,255,0.04);
  border: 1px solid rgba(233, 196, 106, 0.28); border-radius: 20px;
  padding: var(--sp-5) var(--sp-4);
  box-shadow: inset 0 0 30px rgba(124,58,237,0.12);
  animation: rituelGlow 4s ease-in-out infinite;
}
@keyframes rituelGlow { 0%,100% { box-shadow: inset 0 0 26px rgba(124,58,237,0.1); } 50% { box-shadow: inset 0 0 40px rgba(179,140,255,0.22); } }
.rituel-kart.flip { animation: kartFlip 0.5s ease; }
@keyframes kartFlip { 0% { transform: perspective(900px) rotateY(0); } 50% { transform: perspective(900px) rotateY(90deg); } 100% { transform: perspective(900px) rotateY(0); } }
.rituel-kart.done { border-color: var(--gold); box-shadow: var(--glow-gold), inset 0 0 30px rgba(233,196,106,0.12); }
.rk-ikon { font-size: 3rem; filter: drop-shadow(0 0 12px rgba(233,196,106,0.5)); }
.rk-kategori { font-family: var(--font-baslik); color: var(--gold-soft); font-size: 1.05rem; margin-top: 0.3rem; letter-spacing: 0.5px; }
.rk-zorluk { display: inline-block; font-size: 0.68rem; text-transform: uppercase; letter-spacing: 1px; border-radius: 999px; padding: 0.2rem 0.7rem; margin: 0.5rem 0; }
.rk-zorluk.hafif { color: var(--basari); background: rgba(111,224,168,0.12); border: 1px solid rgba(111,224,168,0.35); }
.rk-zorluk.orta { color: var(--accent); background: var(--accent-soft); border: 1px solid rgba(179,140,255,0.4); }
.rk-zorluk.derin { color: var(--gold); background: rgba(233,196,106,0.12); border: 1px solid rgba(233,196,106,0.45); }
.rk-metin { font-family: var(--font-baslik); font-style: italic; font-size: 1.3rem; line-height: 1.5; color: var(--metin); margin: 0.4rem 0 0; }

/* Yıldız parçacıkları (tamamlanınca) */
.rituel-parcacik { position: absolute; left: 50%; top: 42%; width: 0; height: 0; pointer-events: none; }
.rituel-parcacik span {
  position: absolute; width: 7px; height: 7px; border-radius: 50%;
  background: radial-gradient(circle, #fff4d6, var(--gold));
  box-shadow: 0 0 8px 2px rgba(233,196,106,0.6);
  animation: rituelParca 0.95s ease-out forwards;
}
@keyframes rituelParca { 0% { transform: translate(0,0) scale(1); opacity: 1; } 100% { transform: translate(var(--x), var(--y)) scale(0.3); opacity: 0; } }

.rituel-aksiyon { display: flex; align-items: center; gap: 0.6rem; margin-top: var(--sp-3); flex-wrap: wrap; }
#rituel-tamam.tamamlandi { background: linear-gradient(135deg, var(--gold), #c79a3a); color: #1a1233; cursor: default; }
.rituel-fav { width: 44px; height: 44px; border-radius: 50%; cursor: pointer; background: transparent; border: 1px solid rgba(179,140,255,0.25); color: var(--metin-soft); display: flex; align-items: center; justify-content: center; transition: all 0.2s; margin-left: auto; }
.rituel-fav svg { width: 20px; height: 20px; }
.rituel-fav.aktif { color: var(--gold); border-color: var(--gold); box-shadow: var(--glow-gold); }
.rituel-fav.aktif svg { fill: var(--gold); }
.rituel-rozet-serit { margin-top: var(--sp-3); }

/* ---------- Çift Saat Anlamları ---------- */
.cs-canli { font-family: var(--font-baslik); font-size: 2.2rem; color: var(--gold-soft); letter-spacing: 2px; text-shadow: 0 0 20px rgba(233, 196, 106, 0.3); margin-bottom: 0.2rem; }
.cs-grid { display: flex; flex-wrap: wrap; gap: 0.45rem; margin-top: var(--sp-2); }
.cs-cip {
  background: rgba(255, 255, 255, 0.05); border: 1px solid rgba(179, 140, 255, 0.2);
  color: var(--metin-soft); border-radius: 12px; padding: 0.5rem 0.7rem;
  font-family: var(--font-baslik); font-size: 0.95rem; cursor: pointer; transition: all 0.2s;
}
.cs-cip:hover { color: var(--metin); border-color: var(--accent); transform: translateY(-2px); }
.cs-cip.fav { color: var(--gold); border-color: rgba(233, 196, 106, 0.5); box-shadow: var(--glow-gold); }
.cs-detay { margin-top: var(--sp-3); }
.cs-alt-baslik { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 1px; color: var(--accent); margin: 0.6rem 0 0.4rem; }
.cs-mini-grid { display: flex; flex-wrap: wrap; gap: 0.4rem; }

/* Kozmik popup */
.cs-popup {
  position: fixed; inset: 0; z-index: 150;
  display: flex; align-items: center; justify-content: center; padding: 1.5rem;
  background: rgba(8, 6, 20, 0.72); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  opacity: 0; transition: opacity 0.35s;
}
.cs-popup.gor { opacity: 1; }
.cs-popup[hidden] { display: none; }
.cs-pop-ic {
  position: relative; max-width: 360px; width: 100%; text-align: center; overflow: hidden;
  background: radial-gradient(120% 90% at 50% 0%, rgba(124,58,237,0.25), transparent 65%), rgba(20, 14, 44, 0.96);
  border: 1px solid rgba(233, 196, 106, 0.3); border-radius: 24px; padding: 2.2rem 1.6rem 1.8rem;
  box-shadow: var(--shadow), var(--glow-gold), var(--glow-mor);
  transform: translateY(18px) scale(0.96); transition: transform 0.45s cubic-bezier(.18,.7,.3,1);
}
.cs-popup.gor .cs-pop-ic { transform: none; }
.cs-pop-yildiz span { position: absolute; width: 4px; height: 4px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 8px 1px rgba(233,196,106,0.7); opacity: 0.5; animation: yildizParla 3s ease-in-out infinite; }
.cs-pop-yildiz span:nth-child(1) { top: 18px; left: 24px; animation-delay: 0s; }
.cs-pop-yildiz span:nth-child(2) { top: 30px; right: 30px; animation-delay: 0.8s; background: #fff; box-shadow: 0 0 8px 1px rgba(255,255,255,0.7); }
.cs-pop-yildiz span:nth-child(3) { bottom: 40px; left: 30px; animation-delay: 1.6s; background: var(--accent); box-shadow: 0 0 8px 1px rgba(179,140,255,0.7); }
.cs-pop-yildiz span:nth-child(4) { bottom: 26px; right: 26px; animation-delay: 2.2s; }
.cs-kapat { position: absolute; top: 10px; right: 14px; background: transparent; border: none; color: var(--metin-faint); font-size: 1.2rem; cursor: pointer; line-height: 1; }
.cs-kapat:hover { color: var(--metin); }
.cs-saat {
  font-family: var(--font-baslik); font-size: 3rem; font-weight: 600; letter-spacing: 3px;
  background: linear-gradient(100deg, var(--gold-soft), var(--accent) 75%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: 0 0 30px rgba(233, 196, 106, 0.4);
  animation: csNabiz 2.6s ease-in-out infinite;
}
@keyframes csNabiz { 0%, 100% { filter: brightness(1); } 50% { filter: brightness(1.25); } }
.cs-mesaj { font-family: var(--font-baslik); font-style: italic; font-size: 1.15rem; color: var(--metin); margin: 0.6rem 0 0.4rem; }
.cs-yorum { color: var(--metin-soft); font-size: 0.92rem; margin: 0 0 0.3rem; }
.cs-olumlama-et { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--gold); }
.cs-olumlama { color: var(--gold-soft); font-style: italic; margin: 0.3rem 0 1rem; }
.cs-fav {
  width: 46px; height: 46px; border-radius: 50%; cursor: pointer;
  background: transparent; border: 1px solid rgba(179, 140, 255, 0.3); color: var(--metin-soft);
  display: inline-flex; align-items: center; justify-content: center; transition: all 0.2s;
}
.cs-fav svg { width: 22px; height: 22px; }
.cs-fav.aktif { color: var(--gold); border-color: var(--gold); box-shadow: var(--glow-gold); }
.cs-fav.aktif svg { fill: var(--gold); }

/* ---------- Sesli Olumlama ---------- */
.olumlama-bar { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; margin-bottom: var(--sp-3); }
.olumlama-bar h2 { margin: 0; }
.ses-toggle {
  flex-shrink: 0; width: 42px; height: 42px; border-radius: 50%;
  background: transparent; border: 1px solid rgba(179, 140, 255, 0.25); color: var(--metin-soft);
  cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.2s;
}
.ses-toggle svg { width: 20px; height: 20px; }
.ses-toggle:hover { color: var(--metin); border-color: var(--accent); }
.ses-toggle.kapali { color: var(--metin-faint); border-color: rgba(255,255,255,0.12); }

.olumlama-kutu {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(233, 196, 106, 0.18);
  border-radius: var(--radius-sm);
  padding: var(--sp-4);
  transition: box-shadow 0.6s;
}
.card-olumlama.calar .olumlama-kutu { box-shadow: 0 0 30px rgba(179, 140, 255, 0.3), inset 0 0 24px rgba(233, 196, 106, 0.08); }
.olumlama-etiket { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--accent); }
.olumlama-metin {
  font-family: var(--font-baslik); font-size: 1.4rem; font-style: italic; line-height: 1.5;
  color: var(--metin); margin: 0.4rem 0 var(--sp-4); transition: opacity 0.6s;
}

.olumlama-player { display: flex; align-items: center; gap: 0.8rem; }
.olumlama-play {
  flex-shrink: 0; width: 58px; height: 58px; border-radius: 50%; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center; color: #1a1233;
  background: linear-gradient(135deg, var(--gold), var(--accent));
  box-shadow: 0 6px 20px rgba(124, 58, 237, 0.4);
  transition: transform 0.15s, box-shadow 0.3s;
}
.olumlama-play svg { width: 26px; height: 26px; }
.olumlama-play:hover { box-shadow: var(--glow-gold), var(--glow-mor); }
.olumlama-play:active { transform: scale(0.94); }
.olumlama-play:disabled { opacity: 0.5; cursor: not-allowed; }
.card-olumlama.calar .olumlama-play { animation: olumlamaPulse 1.8s ease-in-out infinite; }
@keyframes olumlamaPulse { 0%, 100% { box-shadow: 0 0 16px rgba(233,196,106,0.3); } 50% { box-shadow: var(--glow-gold), var(--glow-mor); } }

/* Ses dalgası */
.olumlama-wave { display: inline-flex; align-items: center; gap: 3px; height: 30px; opacity: 0.35; transition: opacity 0.5s; }
.olumlama-wave i { width: 4px; height: 7px; border-radius: 2px; background: linear-gradient(180deg, var(--gold), var(--accent)); }
.card-olumlama.calar .olumlama-wave { opacity: 1; }
.card-olumlama.calar .olumlama-wave i { animation: dalga 1s ease-in-out infinite; }
.olumlama-wave i:nth-child(2) { animation-delay: 0.12s; }
.olumlama-wave i:nth-child(3) { animation-delay: 0.24s; }
.olumlama-wave i:nth-child(4) { animation-delay: 0.36s; }
.olumlama-wave i:nth-child(5) { animation-delay: 0.48s; }
@keyframes dalga { 0%, 100% { height: 7px; } 50% { height: 26px; } }

.olumlama-aksiyon { margin-left: auto; display: flex; gap: 0.5rem; }
.olumlama-fav, .olumlama-rast {
  width: 44px; height: 44px; border-radius: 50%; cursor: pointer;
  background: transparent; border: 1px solid rgba(179, 140, 255, 0.25); color: var(--metin-soft);
  display: flex; align-items: center; justify-content: center; transition: all 0.2s;
}
.olumlama-fav svg, .olumlama-rast svg { width: 20px; height: 20px; }
.olumlama-fav:hover, .olumlama-rast:hover { color: var(--metin); border-color: var(--accent); }
.olumlama-fav.aktif { color: var(--gold); border-color: var(--gold); box-shadow: var(--glow-gold); }
.olumlama-fav.aktif svg { fill: var(--gold); }

.olumlama-favori .liste li { align-items: center; }
.fav-dinle { background: transparent; border: none; color: var(--gold); cursor: pointer; padding: 0.1rem 0.3rem; display: flex; }
.fav-dinle svg { width: 18px; height: 18px; }

@media (max-width: 480px) {
  .olumlama-metin { font-size: 1.2rem; }
  .olumlama-aksiyon { margin-left: 0; }
  .olumlama-player { flex-wrap: wrap; }
}

/* ---------- Günün Enerji Seviyesi ---------- */
.enerji-ust { display: flex; align-items: center; gap: var(--sp-4); flex-wrap: wrap; }
.enerji-gosterge {
  position: relative; width: 144px; height: 144px; flex-shrink: 0; border-radius: 50%;
  animation: enerjiPulse 3.2s ease-in-out infinite;
}
.enerji-gosterge.dusuk { animation-duration: 5s; }       /* düşük enerjide sakin nabız */
.enerji-svg { width: 100%; height: 100%; display: block; }
.e-track { fill: none; stroke: rgba(255, 255, 255, 0.08); stroke-width: 10; }
.e-ilerleme {
  fill: none; stroke: url(#enerjiG); stroke-width: 10; stroke-linecap: round;
  stroke-dasharray: 327; stroke-dashoffset: 327;
  transition: stroke-dashoffset 0.9s cubic-bezier(.2, .7, .3, 1);
  filter: drop-shadow(0 0 6px rgba(233, 196, 106, 0.6));
}
.enerji-yuzde {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-baslik); font-size: 2rem; color: var(--gold-soft);
  text-shadow: 0 0 18px rgba(233, 196, 106, 0.4);
}
@keyframes enerjiPulse {
  0%, 100% { box-shadow: 0 0 18px rgba(233, 196, 106, 0.18); }
  50%      { box-shadow: 0 0 36px rgba(233, 196, 106, 0.42); }
}
.enerji-bilgi { flex: 1; min-width: 160px; }
.enerji-seviye { font-family: var(--font-baslik); font-size: 1.25rem; color: var(--gold-soft); }
.enerji-mesaj { color: var(--metin-soft); margin-top: 0.35rem; }

.enerji-graf-baslik { margin: var(--sp-4) 0 0.5rem; }
.enerji-grafik { display: flex; gap: 0.4rem; align-items: flex-end; height: 130px; }
.e-bar { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 0.2rem; height: 100%; justify-content: flex-end; }
.e-bar-yuva { width: 100%; flex: 1; display: flex; align-items: flex-end; background: rgba(255, 255, 255, 0.04); border-radius: 8px; overflow: hidden; }
.e-bar-dolu { width: 100%; min-height: 3px; border-radius: 8px; background: linear-gradient(180deg, var(--gold), var(--accent)); transition: height 0.7s; }
.e-bar.bugun .e-bar-dolu { box-shadow: 0 0 12px rgba(233, 196, 106, 0.6); }
.e-bar-deg { font-size: 0.62rem; color: var(--metin-faint); }
.e-bar-ad { font-size: 0.6rem; color: var(--metin-faint); text-transform: capitalize; }

.e-rozet-serit { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: var(--sp-3); }
.e-rozet { font-size: 0.7rem; color: var(--metin-faint); background: var(--card-bg-soft); border: 1px solid rgba(179, 140, 255, 0.15); border-radius: 999px; padding: 0.35rem 0.7rem; }
.e-rozet.kazanildi { color: var(--gold); border-color: var(--gold); box-shadow: var(--glow-gold); }

@media (max-width: 480px) {
  .enerji-ust { justify-content: center; text-align: center; }
  .enerji-bilgi { min-width: 0; }
}

/* ---------- Ay Evresi ---------- */
.card-ay .ay-icerik { display: flex; align-items: center; gap: var(--sp-4); }
.ay-gorsel {
  flex-shrink: 0; width: 104px; height: 104px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 40%, rgba(233, 196, 106, 0.16), transparent 70%);
  animation: ayPulse 4.5s ease-in-out infinite;
}
.ay-svg { width: 84px; height: 84px; display: block; filter: drop-shadow(0 0 10px rgba(233, 196, 106, 0.45)); }
.ay-bilgi { flex: 1; min-width: 0; }
.ay-ad { font-family: var(--font-baslik); font-size: 1.3rem; color: var(--gold-soft); letter-spacing: 0.3px; }
.ay-aciklama { margin: 0.35rem 0 0.5rem; color: var(--metin-soft); font-style: italic; }
.ay-aydinlanma { font-size: 0.8rem; color: var(--metin-faint); letter-spacing: 0.3px; }
@keyframes ayPulse {
  0%, 100% { box-shadow: 0 0 18px rgba(233, 196, 106, 0.22), 0 0 30px rgba(179, 140, 255, 0.16); }
  50%      { box-shadow: 0 0 34px rgba(233, 196, 106, 0.45), 0 0 50px rgba(179, 140, 255, 0.3); }
}
@media (max-width: 480px) {
  .card-ay .ay-icerik { flex-direction: column; text-align: center; gap: var(--sp-3); }
}

/* ---------- AI Ruh Rehberi (sohbet) ---------- */
.rehber-baslik { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; margin-bottom: var(--sp-3); }
.rehber-baslik h2 { margin: 0; }
.rehber-temizle {
  background: transparent; border: 1px solid rgba(179,140,255,0.25); color: var(--metin-soft);
  border-radius: 999px; padding: 0.35rem 0.8rem; font-family: inherit; font-size: 0.75rem; cursor: pointer;
  transition: color 0.2s, border-color 0.2s;
}
.rehber-temizle:hover { color: var(--metin); border-color: var(--accent); }

.sohbet {
  display: flex; flex-direction: column; gap: 0.6rem;
  max-height: 420px; overflow-y: auto;
  padding: 0.3rem 0.2rem var(--sp-3);
  margin-bottom: var(--sp-2);
}
.balon {
  max-width: 86%; padding: 0.75rem 0.95rem; border-radius: 18px;
  font-size: 0.92rem; line-height: 1.55;
  animation: balonGir 0.45s ease both;
}
@keyframes balonGir { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.balon.kullanici {
  align-self: flex-end;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff; border-bottom-right-radius: 6px;
  box-shadow: 0 4px 16px rgba(124, 58, 237, 0.35);
}
.balon.ai {
  align-self: flex-start;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(233, 196, 106, 0.22);
  border-bottom-left-radius: 6px;
  box-shadow: 0 0 24px rgba(179, 140, 255, 0.18);
}
.balon.ai .ai-destek { color: var(--metin); }
.ai-oneri { margin-top: 0.65rem; padding-top: 0.6rem; border-top: 1px solid rgba(255, 255, 255, 0.08); }
.ai-oneri .et { display: block; font-size: 0.66rem; text-transform: uppercase; letter-spacing: 1px; color: var(--gold); margin-bottom: 0.25rem; }
.ai-oneri p { margin: 0 0 0.5rem; color: var(--metin-soft); font-size: 0.9rem; }
.ai-oneri:last-child p { margin-bottom: 0; }
.ai-oneri.olumlama p { font-style: italic; color: var(--metin); margin-bottom: 0; }
.ai-kart-mini { display: flex; gap: 0.6rem; align-items: center; }
.ai-kart-mini img { width: 50px; height: 50px; object-fit: cover; border-radius: 10px; box-shadow: var(--glow-gold); flex-shrink: 0; }
.ai-kart-mini strong { color: var(--metin); display: block; }
.ai-kart-mini p { margin: 0.1rem 0 0; }

/* Loading (yazıyor) noktaları */
.yaziyor { display: flex; gap: 5px; align-items: center; padding: 0.15rem 0; }
.yaziyor span { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); animation: yaziyorNabiz 1.2s infinite ease-in-out; }
.yaziyor span:nth-child(2) { animation-delay: 0.18s; }
.yaziyor span:nth-child(3) { animation-delay: 0.36s; }
@keyframes yaziyorNabiz { 0%, 60%, 100% { opacity: 0.3; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-5px); } }

/* Giriş alanı */
.sohbet-giris { display: flex; gap: 0.5rem; align-items: flex-end; }
.sohbet-giris textarea { flex: 1; min-height: 46px; max-height: 120px; border-radius: 18px; }
.rehber-gonder {
  flex-shrink: 0; width: 46px; height: 46px;
  display: flex; align-items: center; justify-content: center;
  border: none; border-radius: 50%; cursor: pointer; color: #fff;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: 0 4px 16px rgba(124, 58, 237, 0.4);
  transition: transform 0.15s, box-shadow 0.25s, filter 0.2s;
}
.rehber-gonder svg { width: 22px; height: 22px; }
.rehber-gonder:hover { filter: brightness(1.1); box-shadow: var(--glow-mor); }
.rehber-gonder:active { transform: scale(0.93); }

/* ---------- Meditasyon ---------- */
.kategori-sekme { display: flex; flex-wrap: wrap; gap: var(--sp-1); margin-bottom: var(--sp-3); }
.kat-btn {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid transparent;
  color: var(--metin-soft);
  border-radius: 999px;
  padding: 0.45rem 1rem;
  font-family: inherit;
  font-size: 0.85rem;
  cursor: pointer;
  transition: all 0.25s;
}
.kat-btn:hover { color: var(--metin); border-color: var(--accent-2); }
.kat-btn.aktif { background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: #fff; box-shadow: var(--glow-mor); }
.ses-listesi { list-style: none; margin: 0 0 var(--sp-3); padding: 0; display: flex; flex-direction: column; gap: var(--sp-1); }
.ses-btn {
  width: 100%; display: flex; align-items: center; gap: 0.6rem;
  text-align: left;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(179, 140, 255, 0.12);
  border-radius: var(--radius-sm);
  padding: 0.8rem 1rem;
  cursor: pointer; color: var(--metin); font-size: 0.95rem; font-family: inherit;
  transition: background 0.25s, border-color 0.25s, box-shadow 0.25s, transform 0.15s;
}
.ses-btn:hover { background: rgba(255,255,255,0.09); border-color: var(--accent-2); transform: translateX(3px); }
.ses-btn.aktif { background: linear-gradient(135deg, rgba(179,140,255,0.25), rgba(139,111,214,0.2)); border-color: var(--gold); box-shadow: var(--glow-gold); }
.ses-ikon { color: var(--gold); flex-shrink: 0; display: flex; }
.ses-ikon svg { width: 18px; height: 18px; }
.ses-btn.aktif .ses-ikon { animation: nabiz 1.6s ease-in-out infinite; }
@keyframes nabiz { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }
#ses-player { width: 100%; margin-top: 0.3rem; border-radius: 12px; }

/* ---------- Spiritüel Müzik & Frekans ---------- */
.card-muzik .muzik-liste { list-style: none; margin: 0 0 var(--sp-3); padding: 0; display: flex; flex-direction: column; gap: 0.4rem; }
.muzik-sat { display: flex; align-items: center; gap: 0.7rem; background: rgba(255,255,255,0.04); border: 1px solid rgba(179,140,255,0.12); border-radius: 14px; padding: 0.55rem 0.8rem; transition: all 0.2s; }
.muzik-sat:hover { border-color: var(--accent-2); }
.muzik-sat.caliyor { border-color: var(--gold); box-shadow: var(--glow-gold); background: linear-gradient(135deg, rgba(179,140,255,0.18), rgba(139,111,214,0.12)); }
.ms-cal { flex-shrink: 0; width: 40px; height: 40px; border-radius: 50%; border: none; cursor: pointer; background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; box-shadow: 0 4px 12px rgba(124,58,237,0.35); }
.muzik-sat.caliyor .ms-cal { background: linear-gradient(135deg, var(--gold), var(--accent)); animation: olumlamaPulse 1.8s ease-in-out infinite; }
.ms-ad { flex: 1; cursor: pointer; color: var(--metin); font-size: 0.95rem; }
.ms-fav { background: transparent; border: none; color: var(--metin-faint); cursor: pointer; padding: 0.2rem; display: flex; flex-shrink: 0; }
.ms-fav svg { width: 18px; height: 18px; }
.ms-fav.aktif { color: var(--gold); }
.ms-fav.aktif svg { fill: var(--gold); }

.muzik-oneri { background: rgba(233,196,106,0.08); border: 1px solid rgba(233,196,106,0.2); border-radius: var(--radius-sm); padding: 0.8rem 1rem; margin-bottom: var(--sp-3); }
.mo-et { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--gold); margin-bottom: 0.4rem; }
.mo-sat { display: flex; align-items: center; gap: 0.6rem; }
.mo-ikon { font-size: 1.3rem; }
.mo-ad { flex: 1; font-family: var(--font-baslik); font-style: italic; color: var(--metin); }

.muzik-player { background: radial-gradient(120% 90% at 50% 0%, rgba(124,58,237,0.2), transparent 65%), rgba(255,255,255,0.04); border: 1px solid rgba(233,196,106,0.25); border-radius: var(--radius); padding: var(--sp-4); text-align: center; animation: rituelGlow 4s ease-in-out infinite; }
.mp-wave { display: flex; align-items: flex-end; justify-content: center; gap: 4px; height: 34px; margin-bottom: 0.6rem; opacity: 0.4; transition: opacity 0.4s; }
.mp-wave i { width: 4px; height: 8px; border-radius: 2px; background: linear-gradient(180deg, var(--gold), var(--accent)); }
.muzik-player.calityor .mp-wave { opacity: 1; }
.muzik-player.calityor .mp-wave i { animation: dalga 1s ease-in-out infinite; }
.mp-wave i:nth-child(2){animation-delay:.1s}.mp-wave i:nth-child(3){animation-delay:.2s}.mp-wave i:nth-child(4){animation-delay:.3s}.mp-wave i:nth-child(5){animation-delay:.15s}.mp-wave i:nth-child(6){animation-delay:.25s}.mp-wave i:nth-child(7){animation-delay:.05s}
.mp-ad { font-family: var(--font-baslik); font-size: 1.2rem; color: var(--gold-soft); }
.mp-kat { font-size: 0.8rem; color: var(--metin-faint); margin-bottom: 0.6rem; }
.mp-ilerleme { height: 6px; background: rgba(255,255,255,0.1); border-radius: 99px; overflow: hidden; }
.mp-ilerleme span { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--accent), var(--gold)); border-radius: 99px; transition: width 0.5s linear; }
.mp-sure { display: flex; justify-content: space-between; font-size: 0.72rem; color: var(--metin-faint); margin-top: 0.3rem; }
.mp-kontrol { display: flex; align-items: center; justify-content: center; gap: 0.8rem; margin-top: 0.8rem; }
.mp-yan { background: transparent; border: none; color: var(--metin-soft); cursor: pointer; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border-radius: 50%; transition: color 0.2s; }
.mp-yan:hover { color: var(--metin); }
.mp-yan svg { width: 22px; height: 22px; }
.mp-play { width: 60px; height: 60px; border-radius: 50%; border: none; cursor: pointer; background: linear-gradient(135deg, var(--gold), var(--accent)); color: #1a1233; display: flex; align-items: center; justify-content: center; box-shadow: 0 6px 20px rgba(124,58,237,0.4); transition: transform 0.15s, box-shadow 0.3s; }
.mp-play svg { width: 28px; height: 28px; }
.mp-play:hover { box-shadow: var(--glow-gold), var(--glow-mor); }
.mp-play:active { transform: scale(0.94); }
.muzik-player.calityor .mp-play { animation: olumlamaPulse 1.8s ease-in-out infinite; }
.mp-fav { background: transparent; border: 1px solid rgba(179,140,255,0.25); color: var(--metin-soft); width: 40px; height: 40px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.mp-fav svg { width: 18px; height: 18px; }
.mp-fav.aktif { color: var(--gold); border-color: var(--gold); box-shadow: var(--glow-gold); }
.mp-fav.aktif svg { fill: var(--gold); }
.mp-volume { display: flex; align-items: center; gap: 0.6rem; margin-top: 0.9rem; color: var(--metin-faint); }
.mp-volume svg { width: 18px; height: 18px; flex-shrink: 0; }
.mp-volume input[type="range"] { flex: 1; accent-color: var(--gold); height: 4px; }

/* ---------- Ruh hali ---------- */
.mood-butonlar { display: flex; gap: var(--sp-1); justify-content: space-between; margin-bottom: var(--sp-3); }
.mood {
  flex: 1;
  display: flex; flex-direction: column; align-items: center; gap: 0.3rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1.5px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer; padding: 0.6rem 0.2rem;
  color: var(--metin-soft); font-family: inherit;
  transition: transform 0.18s, border-color 0.25s, color 0.25s, box-shadow 0.3s, background 0.25s;
}
.mood svg { width: 26px; height: 26px; display: block; }
.mood-ad { font-size: 0.62rem; letter-spacing: 0.2px; }
.mood:hover { transform: translateY(-3px); color: var(--metin); background: rgba(255,255,255,0.07); }
.mood.aktif { border-color: var(--gold); color: var(--gold); background: rgba(233, 196, 106, 0.12); box-shadow: var(--glow-gold); }
.mood.aktif svg { filter: drop-shadow(0 0 6px rgba(233,196,106,0.6)); animation: nabiz 2s ease-in-out infinite; }

.mood-baslik { margin: var(--sp-3) 0 0.5rem; }
/* Son 7 gün — yatay mini kartlar */
.mood-serit { display: flex; gap: 0.4rem; overflow-x: auto; padding-bottom: 0.2rem; }
.mood-gun {
  flex: 1 0 auto; min-width: 44px;
  display: flex; flex-direction: column; align-items: center; gap: 0.3rem;
  color: var(--accent);
  background: var(--card-bg-soft);
  border: 1px solid rgba(179, 140, 255, 0.12);
  border-radius: 14px;
  padding: 0.55rem 0.25rem;
  transition: border-color 0.25s, box-shadow 0.25s;
}
.mood-gun .gun-ad { font-size: 0.62rem; color: var(--metin-faint); text-transform: capitalize; }
.mood-gun svg { width: 22px; height: 22px; }
.mood-gun .gun-bos { color: var(--metin-faint); font-size: 1.1rem; line-height: 22px; }
.mood-gun.bos { color: var(--metin-faint); }
.mood-gun.bugun { border-color: var(--gold); box-shadow: var(--glow-gold); }

/* Haftalık istatistik paneli */
.mood-istatistik {
  margin-top: var(--sp-3);
  background: rgba(233, 196, 106, 0.07);
  border: 1px solid rgba(233, 196, 106, 0.2);
  border-radius: var(--radius-sm);
  padding: 0.85rem 1rem;
}
.mood-ist-mesaj { font-family: var(--font-baslik); color: var(--gold-soft); font-size: 1.08rem; }
.mood-ist-mesaj strong { color: var(--gold); }
.mood-ist-alt { font-size: 0.82rem; color: var(--metin-soft); margin-top: 0.3rem; }
.mood-ist-alt strong { color: var(--metin); }

/* ---------- Kart çekme ---------- */
.kart-alani { min-height: 130px; display: flex; align-items: center; justify-content: center; margin-bottom: var(--sp-3); }
.kart-placeholder { color: var(--metin-faint); font-style: italic; text-align: center; }
.kart-icerik { text-align: center; animation: kartGir 0.7s cubic-bezier(.18,.7,.3,1) both; }
.kart-gorsel-cerceve {
  position: relative; display: inline-block; border-radius: 18px; padding: 4px;
  background: linear-gradient(140deg, var(--gold), var(--accent));
  box-shadow: var(--glow-gold), var(--glow-mor);
  animation: glowNabiz 3.5s ease-in-out infinite;
}
.kart-icerik img { display: block; max-width: 100%; max-height: 280px; border-radius: 15px; }
.kart-icerik h3 { margin: 0.9rem 0 0.25rem; font-family: var(--font-baslik); font-size: 1.35rem; letter-spacing: 0.5px; color: var(--gold-soft); }
.kart-icerik p { margin: 0; color: var(--metin-soft); }
@keyframes kartGir {
  0% { opacity: 0; transform: translateY(22px) scale(0.94); filter: blur(6px); }
  60% { opacity: 1; filter: blur(0); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes glowNabiz {
  0%, 100% { box-shadow: 0 0 22px rgba(233,196,106,0.3), 0 0 30px rgba(179,140,255,0.25); }
  50% { box-shadow: 0 0 40px rgba(233,196,106,0.5), 0 0 50px rgba(179,140,255,0.4); }
}

/* ---------- Geçmiş (kart) ---------- */
.gecmis-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: var(--sp-2); }
.gecmis-kart { background: var(--card-bg-soft); border: 1px solid rgba(179,140,255,0.12); border-radius: var(--radius-sm); overflow: hidden; transition: transform 0.2s, box-shadow 0.25s; }
.gecmis-kart:hover { transform: translateY(-3px); box-shadow: var(--glow-mor); }
.gecmis-kart img { width: 100%; height: 110px; object-fit: cover; display: block; }
.gecmis-kart-bilgi { padding: 0.5rem 0.7rem; }
.gecmis-kart-bilgi strong { display: block; font-size: 0.92rem; color: var(--metin); }
.gecmis-kart-bilgi small { color: var(--metin-faint); font-size: 0.78rem; }

/* ---------- Check ---------- */
.check { display: inline-flex; align-items: center; gap: 0.6rem; cursor: pointer; margin-top: 0.4rem; color: var(--metin); }
.check input { width: 20px; height: 20px; accent-color: var(--gold); }
.soru-metin { font-weight: 600; margin-bottom: var(--sp-2); color: var(--metin); }

/* ---------- Listeler ---------- */
.liste { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--sp-1); }
.liste li {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 0.6rem;
  background: var(--card-bg-soft);
  border: 1px solid rgba(179, 140, 255, 0.1);
  border-radius: var(--radius-sm);
  padding: 0.7rem 0.9rem;
}
.liste-metin { flex: 1; word-break: break-word; color: var(--metin); }
.liste-metin small { color: var(--metin-faint); }
#hedef-listesi .liste-metin { cursor: pointer; }
.liste li.tamam .liste-metin { text-decoration: line-through; opacity: 0.55; }
.sil { background: transparent; border: none; color: var(--uyari); cursor: pointer; font-size: 1.05rem; line-height: 1; padding: 0.1rem 0.35rem; opacity: 0.7; transition: opacity 0.2s; }
.sil:hover { opacity: 1; }
.gecmis { margin-top: var(--sp-3); }
.gecmis summary { cursor: pointer; color: var(--accent); }
.gecmis ul { margin-top: 0.7rem; }

/* ---------- Spiritüel Günlük ---------- */
.altin-divider { height: 1px; background: linear-gradient(90deg, transparent, rgba(233, 196, 106, 0.5), transparent); margin: var(--sp-3) 0; }
.altin-divider.ince { margin: 0.6rem 0; opacity: 0.6; }

.card-gunluk { position: relative; }
.card-gunluk.ceviriliyor { animation: sayfaCevir 0.7s ease; }
@keyframes sayfaCevir {
  0% { transform: perspective(1200px) rotateY(0); }
  45% { transform: perspective(1200px) rotateY(-7deg); }
  100% { transform: perspective(1200px) rotateY(0); }
}
.gunluk-yildiz span { position: absolute; border-radius: 50%; background: var(--gold); box-shadow: 0 0 8px 1px rgba(233, 196, 106, 0.6); opacity: 0.5; animation: yildizParla 3s ease-in-out infinite; pointer-events: none; }
.gunluk-yildiz span:nth-child(1) { top: 16px; right: 18px; width: 4px; height: 4px; animation-delay: 0s; }
.gunluk-yildiz span:nth-child(2) { top: 32px; right: 42px; width: 3px; height: 3px; animation-delay: 1s; }
.gunluk-yildiz span:nth-child(3) { top: 52px; right: 26px; width: 2px; height: 2px; animation-delay: 2s; }

.gunluk-ust { display: flex; align-items: center; justify-content: space-between; gap: 0.8rem; flex-wrap: wrap; }
.gunluk-tarih { font-family: var(--font-baslik); font-style: italic; color: var(--gold-soft); font-size: 0.95rem; text-transform: capitalize; }
.gunluk-mood-sec { display: flex; gap: 0.3rem; }
.gunluk-mood { width: 34px; height: 34px; border-radius: 10px; border: 1.5px solid transparent; background: rgba(255, 255, 255, 0.04); color: var(--metin-faint); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.2s; }
.gunluk-mood svg { width: 20px; height: 20px; }
.gunluk-mood:hover { color: var(--metin-soft); }
.gunluk-mood.aktif { border-color: var(--gold); color: var(--gold); background: rgba(233, 196, 106, 0.12); box-shadow: var(--glow-gold); }

.gunluk-yaz-alan { position: relative; }
.gunluk-yaz-alan textarea { min-height: 170px; line-height: 1.7; font-size: 1rem; background: rgba(8, 6, 20, 0.45); }
.gunluk-yaz-alan textarea:focus { box-shadow: 0 0 0 3px rgba(233, 196, 106, 0.18), 0 0 26px rgba(233, 196, 106, 0.16); }
.gunluk-alt { justify-content: space-between; }

.gunluk-analiz { margin-top: var(--sp-3); background: rgba(179, 140, 255, 0.08); border: 1px solid rgba(233, 196, 106, 0.2); border-radius: var(--radius-sm); padding: var(--sp-3); animation: balonGir 0.5s ease both; }
.ga-et { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--gold); }
.ga-analiz { font-family: var(--font-baslik); font-style: italic; font-size: 1.1rem; color: var(--metin); margin: 0.3rem 0; }
.ga-mesaj { color: var(--metin-soft); margin: 0.3rem 0; }
.ga-olumlama { color: var(--gold-soft); font-style: italic; margin: 0.3rem 0 0; }

/* Geçmiş */
.gunluk-gecmis-ust { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; margin-bottom: var(--sp-2); }
.gunluk-gecmis-ust h2 { margin: 0; }
.gunluk-fav-filtre { width: 42px; height: 42px; border-radius: 50%; background: transparent; border: 1px solid rgba(179, 140, 255, 0.25); color: var(--metin-soft); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.2s; flex-shrink: 0; }
.gunluk-fav-filtre svg { width: 20px; height: 20px; }
.gunluk-fav-filtre.aktif { color: var(--gold); border-color: var(--gold); box-shadow: var(--glow-gold); }
.gunluk-fav-filtre.aktif svg { fill: var(--gold); }
.gunluk-arama { position: relative; margin-bottom: var(--sp-3); }
.gunluk-arama .ara-ikon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); width: 18px; height: 18px; color: var(--metin-faint); pointer-events: none; }
.gunluk-arama input { padding-left: 38px; }
.gunluk-liste { display: flex; flex-direction: column; gap: var(--sp-2); }
.gk { background: var(--card-bg-soft); border: 1px solid rgba(179, 140, 255, 0.12); border-radius: var(--radius-sm); padding: var(--sp-3); transition: border-color 0.25s, box-shadow 0.25s; animation: balonGir 0.4s ease both; }
.gk:hover { border-color: var(--accent-2); }
.gk-bas { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; }
.gk-meta { display: flex; align-items: center; gap: 0.5rem; color: var(--gold-soft); font-size: 0.85rem; font-family: var(--font-baslik); font-style: italic; }
.gk-mood svg { width: 18px; height: 18px; color: var(--accent); }
.gk-aksiyon { display: flex; gap: 0.2rem; align-items: center; flex-shrink: 0; }
.gk-fav { background: transparent; border: none; color: var(--metin-faint); cursor: pointer; padding: 0.2rem; display: flex; }
.gk-fav svg { width: 18px; height: 18px; }
.gk-fav.aktif { color: var(--gold); }
.gk-fav.aktif svg { fill: var(--gold); }
.gk-sil { background: transparent; border: none; color: var(--uyari); cursor: pointer; font-size: 1rem; opacity: 0.6; padding: 0.2rem 0.3rem; }
.gk-sil:hover { opacity: 1; }
.gk-metin { color: var(--metin); margin: 0.5rem 0 0; line-height: 1.6; cursor: pointer; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.gk.acik .gk-metin { -webkit-line-clamp: unset; overflow: visible; }
.gk-analiz { margin-top: 0.6rem; border-top: 1px solid rgba(255, 255, 255, 0.07); padding-top: 0.5rem; }
.gk-analiz .ga-analiz { font-size: 0.98rem; margin: 0.2rem 0 0; }

/* ---------- Profil ---------- */
.profil-ust { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
/* Avatar + seviye çerçevesi */
.profil-avatar-sar {
  position: relative; flex-shrink: 0;
  width: 84px; height: 84px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  padding: 4px;
  background: linear-gradient(135deg, var(--accent-2), var(--accent));
}
.profil-avatar-sar.sv-1 { background: linear-gradient(135deg, var(--accent), #8b6fd6); box-shadow: 0 0 16px rgba(179,140,255,0.4); }
.profil-avatar-sar.sv-2 { background: linear-gradient(135deg, #8b6fd6, var(--accent)); box-shadow: 0 0 20px rgba(179,140,255,0.5); }
.profil-avatar-sar.sv-3 { background: linear-gradient(135deg, var(--accent), var(--gold)); box-shadow: 0 0 22px rgba(233,196,106,0.4), 0 0 22px rgba(179,140,255,0.4); }
.profil-avatar-sar.sv-4 { background: linear-gradient(135deg, var(--gold), var(--accent)); box-shadow: var(--glow-gold), var(--glow-mor); }
.profil-avatar-sar.sv-5 { background: linear-gradient(135deg, #fff4d6, var(--gold), var(--accent)); box-shadow: 0 0 28px rgba(233,196,106,0.7), 0 0 28px rgba(179,140,255,0.6); animation: cerceveNabiz 3s ease-in-out infinite; }
@keyframes cerceveNabiz { 0%,100% { filter: brightness(1); } 50% { filter: brightness(1.18); } }
.profil-avatar-sar.level-up { animation: levelUp 0.9s ease; }
@keyframes levelUp { 0% { transform: scale(1); } 30% { transform: scale(1.18); box-shadow: 0 0 40px rgba(233,196,106,0.9); } 100% { transform: scale(1); } }

.profil-avatar {
  width: 100%; height: 100%; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-baslik); font-size: 1.9rem; color: #1a1233;
  background: linear-gradient(135deg, var(--gold), var(--accent));
  background-size: cover; background-position: center;
}
.profil-avatar.foto { color: transparent; }
.profil-foto-btn {
  position: absolute; right: -2px; bottom: -2px;
  width: 28px; height: 28px; border-radius: 50%; cursor: pointer;
  border: 2px solid var(--bg-1); color: #1a1233;
  background: linear-gradient(135deg, var(--gold), var(--gold-soft));
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--glow-gold); transition: transform 0.15s;
}
.profil-foto-btn:hover { transform: scale(1.1); }
.profil-foto-btn svg { width: 15px; height: 15px; }

/* Seviye rozeti (shine) */
.profil-seviye { margin: 0.25rem 0; }
.seviye-rozet {
  position: relative; overflow: hidden;
  display: inline-block; font-family: var(--font-baslik); font-size: 0.95rem;
  color: var(--gold); padding: 0.25rem 0.8rem; border-radius: 999px;
  background: rgba(233, 196, 106, 0.12); border: 1px solid rgba(233, 196, 106, 0.4);
  box-shadow: 0 0 14px rgba(233, 196, 106, 0.25);
}
.seviye-rozet::after {
  content: ""; position: absolute; top: 0; left: -130%; width: 60%; height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,0.5), transparent);
  transform: skewX(-20deg); animation: shine 4s ease-in-out infinite;
}
@keyframes shine { 0%, 70% { left: -130%; } 85%, 100% { left: 140%; } }

/* Seviye ilerleme */
.profil-seviye-bar { height: 8px; background: rgba(255, 255, 255, 0.09); border-radius: 99px; overflow: hidden; margin-top: var(--sp-3); }
.profil-seviye-bar span { display: block; height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--accent), var(--gold)); transition: width 0.7s; }
.profil-seviye-bilgi { font-size: 0.78rem; color: var(--metin-faint); margin-top: 0.4rem; text-align: center; }

/* Profil alt sekmeleri */
.profil-sekme { display: flex; gap: 0.5rem; }
.psek-btn { flex: 1; background: rgba(255,255,255,0.05); border: 1px solid rgba(179,140,255,0.18); color: var(--metin-soft); border-radius: 12px; padding: 0.6rem 0.4rem; font-family: inherit; font-size: 0.85rem; cursor: pointer; transition: all 0.2s; }
.psek-btn:hover { color: var(--metin); border-color: var(--accent-2); }
.psek-btn.aktif { background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: #fff; border-color: transparent; box-shadow: var(--glow-mor); }
.profil-gizli { display: none !important; }

/* 30 günlük gelişim grafiği */
.profil-graf-baslik { margin: 0 0 0.5rem; }
.profil-grafik { display: flex; gap: 2px; align-items: flex-end; height: 70px; }
.pg-bar { flex: 1; min-height: 3px; border-radius: 3px; background: linear-gradient(180deg, var(--gold), var(--accent)); opacity: 0.85; transition: height 0.6s; }
.profil-ozet { font-size: 0.85rem; color: var(--metin-soft); margin-top: var(--sp-2); line-height: 1.5; }
.profil-ozet strong { color: var(--gold-soft); }

/* Rozet shine (Başarımlar) */
.rozet.kazanildi .rozet-madalya { position: relative; overflow: hidden; }
.rozet.kazanildi .rozet-madalya::after {
  content: ""; position: absolute; top: 0; left: -130%; width: 50%; height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,0.6), transparent);
  transform: skewX(-20deg); animation: shine 4.5s ease-in-out infinite;
}
.profil-bilgi { flex: 1; min-width: 0; }
.profil-bilgi h2 { margin: 0; font-family: var(--font-baslik); color: var(--metin); font-size: 1.4rem; }
.profil-bilgi p { margin: 0.2rem 0 0; }
.profil-duzenle { flex-shrink: 0; }
.profil-form { margin-top: var(--sp-3); }
.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: var(--sp-2); margin-top: var(--sp-4); }
.stat { background: var(--card-bg-soft); border: 1px solid rgba(179,140,255,0.12); border-radius: var(--radius-sm); padding: var(--sp-3); text-align: center; }
.stat-deger { font-family: var(--font-baslik); font-size: 1.8rem; color: var(--gold-soft); line-height: 1; }
.stat-deger small { font-family: var(--font-govde); font-size: 0.7rem; color: var(--metin-faint); margin-left: 3px; }
.stat-etiket { font-size: 0.78rem; color: var(--metin-soft); margin-top: 0.4rem; }
.stat-metin .stat-deger { font-size: 1.05rem; line-height: 1.3; }

/* gün rozet şeridi (meditasyon geçmişi) */
.gun-rozet-serit { display: flex; flex-wrap: wrap; gap: var(--sp-1); }
.gun-rozet { font-size: 0.8rem; color: var(--metin-soft); background: var(--card-bg-soft); border: 1px solid rgba(179,140,255,0.15); border-radius: 999px; padding: 0.3rem 0.7rem; }

/* ---------- Başarımlar ---------- */
.rozet-grid { display: flex; flex-direction: column; gap: var(--sp-2); }
.rozet {
  display: flex; align-items: center; gap: 0.9rem;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(179, 140, 255, 0.1);
  border-radius: var(--radius-sm);
  padding: 0.9rem 1rem;
  opacity: 0.62;
  transition: opacity var(--gecis), box-shadow var(--gecis), border-color var(--gecis);
}
.rozet.kazanildi { opacity: 1; border-color: var(--gold); box-shadow: var(--glow-gold); }
.rozet-madalya {
  flex-shrink: 0; width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: rgba(255, 255, 255, 0.06);
  border: 1.5px solid var(--accent-2); color: var(--metin-faint);
}
.rozet-madalya svg { width: 24px; height: 24px; }
.rozet.kazanildi .rozet-madalya { background: linear-gradient(135deg, var(--gold), #c79a3a); border-color: var(--gold); color: #1a1233; }
.rozet-govde { flex: 1; min-width: 0; }
.rozet-ad { font-weight: 600; color: var(--metin); font-size: 0.98rem; }
.rozet-aciklama { font-size: 0.8rem; color: var(--metin-soft); margin-top: 1px; }
.rozet-bar { height: 6px; background: rgba(255,255,255,0.1); border-radius: 99px; margin-top: 0.5rem; overflow: hidden; }
.rozet-bar span { display: block; height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--accent), var(--gold)); transition: width 0.6s; }
.rozet-sayi { font-size: 0.78rem; color: var(--metin-faint); margin-top: 0.3rem; }

/* ---------- Ürünler (premium kartlar) ---------- */
.urun-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: var(--sp-3); }
.urun {
  display: flex; flex-direction: column;
  text-decoration: none; color: var(--metin);
  background: var(--card-bg-soft);
  border: 1px solid rgba(179, 140, 255, 0.12);
  border-radius: var(--radius); overflow: hidden;
  transition: transform var(--gecis), box-shadow var(--gecis), border-color var(--gecis);
}
.urun:hover { transform: translateY(-6px); box-shadow: var(--glow-mor); border-color: var(--gold); }
.urun-gorsel { position: relative; height: 120px; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.85); }
.urun-gorsel svg { width: 46px; height: 46px; filter: drop-shadow(0 0 10px rgba(233,196,106,0.4)); }
.urun-govde { padding: var(--sp-3); }
.urun h4 { margin: 0 0 0.35rem; color: var(--metin); font-size: 1.02rem; }
.urun p { margin: 0 0 0.7rem; font-size: 0.85rem; color: var(--metin-soft); }
.urun-link { color: var(--gold); font-weight: 600; font-size: 0.9rem; }

/* ---------- Aura & Çakra Dengesi ---------- */
.card-cakra { text-align: center; }
.aura-sahne { position: relative; height: 170px; display: flex; align-items: center; justify-content: center; margin: var(--sp-2) 0 var(--sp-3); }
.aura-orb { position: relative; width: 104px; height: 104px; border-radius: 50%; background: radial-gradient(circle at 38% 32%, #c2a0ff, #4a2a8a); box-shadow: 0 0 40px rgba(179,140,255,0.5), inset 0 0 26px rgba(255,255,255,0.18); animation: auraNefes 4s ease-in-out infinite; }
@keyframes auraNefes { 0%,100% { transform: scale(1); } 50% { transform: scale(1.08); } }
.aura-cember { position: absolute; border-radius: 50%; border: 1px solid rgba(179,140,255,0.35); pointer-events: none; }
.aura-cember.c1 { width: 134px; height: 134px; border-style: dashed; animation: auraDon 18s linear infinite; }
.aura-cember.c2 { width: 164px; height: 164px; border-color: rgba(233,196,106,0.25); animation: auraDon 26s linear infinite reverse; }
@keyframes auraDon { to { transform: rotate(360deg); } }
.aura-ad { font-family: var(--font-baslik); font-size: 1.3rem; color: var(--gold-soft); }
.aura-aciklama { color: var(--metin-soft); margin: 0.3rem 0 0.6rem; line-height: 1.5; }
.cakra-headline { font-family: var(--font-baslik); font-style: italic; color: var(--metin); margin-bottom: var(--sp-3); }

.cakra-liste { display: flex; flex-direction: column; gap: 0.4rem; text-align: left; }
.cakra-sat { width: 100%; display: flex; align-items: center; gap: 0.7rem; background: rgba(255,255,255,0.04); border: 1px solid rgba(179,140,255,0.12); border-radius: 14px; padding: 0.6rem 0.8rem; cursor: pointer; font-family: inherit; transition: border-color 0.2s; }
.cakra-sat:hover { border-color: var(--accent-2); }
.ck-ikon { font-size: 1.3rem; flex-shrink: 0; }
.ck-bilgi { flex: 1; min-width: 0; }
.ck-ust { display: flex; justify-content: space-between; font-size: 0.88rem; color: var(--metin); margin-bottom: 0.3rem; }
.ck-yuzde { color: var(--gold-soft); }
.ck-bar { height: 7px; background: rgba(255,255,255,0.08); border-radius: 99px; overflow: hidden; }
.ck-bar span { display: block; height: 100%; border-radius: 99px; transition: width 0.6s; }
.ck-ok { color: var(--metin-faint); transition: transform 0.3s; flex-shrink: 0; }
.cakra-blok.acik .ck-ok { transform: rotate(180deg); }
.ck-detay { padding: 0.6rem 0.9rem 0.2rem; animation: balonGir 0.3s ease both; }
.ck-aciklama { color: var(--metin-soft); font-size: 0.9rem; margin: 0.2rem 0 0.5rem; }
.ck-oneri { margin-bottom: 0.5rem; }
.ck-et { display: block; font-size: 0.64rem; text-transform: uppercase; letter-spacing: 1px; color: var(--gold); margin-bottom: 0.2rem; }
.ck-oneri p { margin: 0; color: var(--metin-soft); }
.ck-oneri:first-of-type p { font-style: italic; color: var(--metin); }
.cakra-gorev { text-align: left; background: rgba(233,196,106,0.08); border: 1px solid rgba(233,196,106,0.2); border-radius: var(--radius-sm); padding: 0.8rem 1rem; margin-top: var(--sp-3); }
.cakra-gorev p { margin: 0.2rem 0 0; color: var(--metin-soft); }
.aura-gecmis-cipler { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.aura-cip { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.76rem; color: var(--metin-soft); background: var(--card-bg-soft); border: 1px solid rgba(179,140,255,0.15); border-radius: 999px; padding: 0.25rem 0.6rem; }
.aura-nokta { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }

/* ---------- Ruh Eşleşmesi / Enerji Tipi ---------- */
.card-enerjitipi { text-align: center; }
.et-aura { position: relative; height: 140px; display: flex; align-items: center; justify-content: center; margin: var(--sp-2) 0 var(--sp-3); }
.et-orb {
  position: relative; width: 96px; height: 96px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(circle at 35% 30%, #8b6fd6, #3a3a6d);
  box-shadow: 0 0 36px rgba(179,140,255,0.5), inset 0 0 24px rgba(255,255,255,0.15);
  animation: auraPulse 3.4s ease-in-out infinite;
}
.et-orb .et-ikon { font-size: 2.4rem; filter: drop-shadow(0 2px 8px rgba(0,0,0,0.4)); }
@keyframes auraPulse { 0%,100% { transform: scale(1); box-shadow: 0 0 30px rgba(179,140,255,0.4), inset 0 0 20px rgba(255,255,255,0.12); } 50% { transform: scale(1.06); box-shadow: 0 0 50px rgba(179,140,255,0.65), inset 0 0 26px rgba(255,255,255,0.2); } }
/* enerji dalgası halkaları */
.et-aura::before, .et-aura::after {
  content: ""; position: absolute; width: 96px; height: 96px; border-radius: 50%;
  border: 1px solid rgba(179,140,255,0.4); animation: enerjiDalga 3.4s ease-out infinite;
}
.et-aura::after { animation-delay: 1.7s; }
@keyframes enerjiDalga { 0% { transform: scale(1); opacity: 0.6; } 100% { transform: scale(2.1); opacity: 0; } }
.et-parcacik { position: absolute; left: 50%; top: 50%; width: 0; height: 0; pointer-events: none; }
.et-parcacik span { position: absolute; width: 6px; height: 6px; border-radius: 50%; background: radial-gradient(circle, #fff4d6, var(--gold)); box-shadow: 0 0 8px 2px rgba(233,196,106,0.6); animation: rituelParca 1s ease-out forwards; }
.et-ad { font-family: var(--font-baslik); font-size: 1.2rem; color: var(--metin); }
.et-ad strong { color: var(--gold-soft); }
.et-analiz { color: var(--metin-soft); margin: 0.4rem 0; line-height: 1.55; }
.et-gunluk { font-family: var(--font-baslik); font-style: italic; color: var(--gold-soft); margin: 0.5rem 0; }
.et-uyum { font-size: 0.9rem; color: var(--metin-soft); margin-bottom: var(--sp-3); }
.et-uyum strong { color: var(--accent); }
#et-med { margin-bottom: var(--sp-2); }

/* ---------- Kader Haritası / Günlük Rehber ---------- */
.kader-flip { perspective: 1000px; }
.kader-flip.flip .kader-kapali, .kader-flip.flip .kader-acik { animation: kartFlip 0.5s ease; }
.kader-kapali {
  position: relative; width: 100%; cursor: pointer; overflow: hidden;
  border: 1px solid rgba(233,196,106,0.3); border-radius: var(--radius);
  background: radial-gradient(130% 100% at 50% 0%, rgba(124,58,237,0.3), transparent 60%), linear-gradient(160deg, #1a1338, #0f0a24);
  padding: 2.4rem 1.4rem; display: flex; flex-direction: column; align-items: center; gap: 0.6rem;
  color: var(--gold-soft); box-shadow: inset 0 0 30px rgba(124,58,237,0.2);
  animation: rituelGlow 4s ease-in-out infinite;
}
.kader-kapali:hover { box-shadow: var(--glow-gold), var(--glow-mor); }
.kk-ay { font-size: 2.6rem; filter: drop-shadow(0 0 14px rgba(233,196,106,0.6)); animation: suzul 5s ease-in-out infinite; }
.kk-yazi { font-family: var(--font-baslik); font-size: 1.1rem; }
.kader-yildiz span { position: absolute; width: 4px; height: 4px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 8px 1px rgba(233,196,106,0.6); opacity: 0.5; animation: yildizParla 3s ease-in-out infinite; }
.kader-yildiz span:nth-child(1){top:16px;left:24px}.kader-yildiz span:nth-child(2){top:26px;right:30px;animation-delay:.8s;background:#fff}.kader-yildiz span:nth-child(3){bottom:24px;left:34px;animation-delay:1.6s;background:var(--accent)}.kader-yildiz span:nth-child(4){bottom:30px;right:26px;animation-delay:2.2s}

.kader-acik { position: relative; background: radial-gradient(120% 80% at 50% 0%, rgba(124,58,237,0.18), transparent 60%), rgba(255,255,255,0.04); border: 1px solid rgba(233,196,106,0.25); border-radius: var(--radius); padding: var(--sp-4); }
.kd-tema { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--accent); }
.kd-enerji { font-family: var(--font-baslik); font-style: italic; font-size: 1.25rem; color: var(--gold-soft); margin: 0.3rem 0; line-height: 1.4; }
.kd-oneri { text-align: left; margin-top: 0.7rem; }
.kd-et { display: block; font-size: 0.66rem; text-transform: uppercase; letter-spacing: 1px; color: var(--gold); margin-bottom: 0.2rem; }
.kd-oneri p { margin: 0; color: var(--metin-soft); }
.kd-oneri.olumlama p { font-style: italic; color: var(--metin); }
.kd-oneri.dikkat p { color: var(--gold-soft); }
.kd-kart { display: flex; gap: 0.6rem; align-items: center; }
.kd-kart img { width: 50px; height: 50px; border-radius: 10px; object-fit: cover; box-shadow: var(--glow-gold); flex-shrink: 0; }
.kd-kart strong { color: var(--metin); }
.kd-aksiyon { display: flex; gap: 0.6rem; align-items: center; margin-top: 1rem; }
.kd-fav { width: 42px; height: 42px; border-radius: 50%; border: 1px solid rgba(179,140,255,0.3); background: transparent; color: var(--metin-soft); cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.kd-fav svg { width: 20px; height: 20px; }
.kd-fav.aktif { color: var(--gold); border-color: var(--gold); box-shadow: var(--glow-gold); }
.kd-fav.aktif svg { fill: var(--gold); }
.kader-parcacik { position: absolute; left: 50%; top: 18%; width: 0; height: 0; pointer-events: none; }
.kader-parcacik span { position: absolute; width: 7px; height: 7px; border-radius: 50%; background: radial-gradient(circle, #fff4d6, var(--gold)); box-shadow: 0 0 8px 2px rgba(233,196,106,0.6); animation: rituelParca 1s ease-out forwards; }
.kader-detay { margin-top: var(--sp-3); }
.kader-mini { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 0.4rem; }
.kader-cip { font-size: 0.78rem; color: var(--gold); background: rgba(233,196,106,0.1); border: 1px solid rgba(233,196,106,0.3); border-radius: 999px; padding: 0.25rem 0.7rem; }

/* ---------- Hayal Panosu (Vision Board) ---------- */
.card-vision-giris .vis-ikon { font-size: 1.9rem; filter: drop-shadow(0 0 12px rgba(233,196,106,0.6)); animation: gunesPulse 4s ease-in-out infinite; }

.vision-overlay {
  position: fixed; inset: 0; z-index: 175; overflow-y: auto; padding: 1.5rem 1.2rem 3rem;
  background: radial-gradient(900px 700px at 50% 12%, #241a52 0%, transparent 60%), linear-gradient(170deg, #0a0820, #120b2e 60%, #0f0a24);
  opacity: 0; transition: opacity 0.5s;
}
.vision-overlay.gor { opacity: 1; }
.vision-overlay[hidden] { display: none; }
.vision-ic { position: relative; max-width: 560px; margin: 0 auto; }
.vision-baslik { font-family: var(--font-baslik); color: var(--gold-soft); font-size: 1.5rem; text-align: center; margin: 0.2rem 0 var(--sp-3); }

.vb-kat-chips { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 0.6rem; }
.vb-kat-chip { background: rgba(255,255,255,0.05); border: 1px solid var(--kat, rgba(179,140,255,0.3)); color: var(--metin-soft); border-radius: 999px; padding: 0.35rem 0.8rem; font-family: inherit; font-size: 0.8rem; cursor: pointer; transition: all 0.2s; }
.vb-kat-chip.aktif { background: var(--kat); color: #1a1233; border-color: transparent; box-shadow: 0 0 14px rgba(233,196,106,0.3); }
.vb-ekle-satir { display: flex; gap: 0.4rem; margin-bottom: 0.6rem; flex-wrap: wrap; }
.vb-ekle-satir input { flex: 1; min-width: 140px; }
.vb-gorsel-label { display: inline-flex; align-items: center; cursor: pointer; }
.vb-stickerlar { display: flex; flex-wrap: wrap; gap: 0.3rem; }
.vb-sticker-btn { background: rgba(255,255,255,0.05); border: 1px solid rgba(179,140,255,0.2); border-radius: 10px; width: 38px; height: 38px; font-size: 1.2rem; cursor: pointer; transition: all 0.2s; }
.vb-sticker-btn:hover { border-color: var(--gold); box-shadow: var(--glow-gold); transform: translateY(-2px); }
.vb-bolum-baslik { margin: 0.6rem 0 0.3rem; }
/* hazır ilham galerisi */
.vb-galeri { display: flex; gap: 0.45rem; overflow-x: auto; padding-bottom: 0.3rem; scrollbar-width: thin; }
.vb-galeri-thumb { position: relative; flex: 0 0 auto; width: 70px; height: 70px; padding: 0; border: 1px solid rgba(179,140,255,0.25); border-radius: 12px; overflow: hidden; cursor: pointer; background: rgba(255,255,255,0.04); transition: all 0.2s; }
.vb-galeri-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vb-galeri-thumb:hover { border-color: var(--gold); box-shadow: var(--glow-gold); transform: translateY(-2px); }
.vb-galeri-arti { position: absolute; right: 3px; bottom: 2px; width: 18px; height: 18px; border-radius: 50%; background: rgba(20,14,44,0.8); color: var(--gold, #e9c46a); font-size: 0.8rem; line-height: 18px; text-align: center; pointer-events: none; }

.vb-canvas { position: relative; width: 100%; height: 380px; border-radius: var(--radius); overflow: hidden; margin-top: var(--sp-2); touch-action: none; background: radial-gradient(120% 90% at 50% 0%, rgba(124,58,237,0.18), transparent 60%), rgba(255,255,255,0.03); border: 1px solid rgba(233,196,106,0.22); box-shadow: inset 0 0 40px rgba(124,58,237,0.12); }
.vb-canvas-ipucu { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; text-align: center; color: var(--metin-faint); font-size: 0.9rem; padding: 1rem; line-height: 1.6; }
.vb-canvas:not(.bos) .vb-canvas-ipucu { display: none; }
.vb-item { position: absolute; transform: translate(-50%, -50%); cursor: grab; touch-action: none; border-radius: 14px; border: 1.5px solid var(--kat, var(--gold)); box-shadow: 0 4px 16px rgba(0,0,0,0.4); transition: box-shadow 0.2s; }
.vb-item:hover { box-shadow: 0 6px 22px rgba(0,0,0,0.5), 0 0 18px rgba(179,140,255,0.5); }
.vb-item.suru { cursor: grabbing; z-index: 10; box-shadow: 0 8px 28px rgba(0,0,0,0.5), 0 0 24px rgba(233,196,106,0.5); }
.vb-gorsel { width: 110px; height: 110px; }
.vb-gorsel img { width: 100%; height: 100%; object-fit: cover; border-radius: 13px; display: block; pointer-events: none; }
.vb-resize { position: absolute; right: -7px; bottom: -7px; width: 18px; height: 18px; border-radius: 50%; background: var(--gold, #e9c46a); border: 2px solid rgba(20,14,44,0.9); cursor: nwse-resize; display: none; touch-action: none; z-index: 3; box-shadow: 0 0 8px rgba(233,196,106,0.7); }
.vb-item.vb-gorsel:hover .vb-resize, .vb-item.vb-gorsel.suru .vb-resize { display: block; }
.vb-metin { background: rgba(20,14,44,0.85); backdrop-filter: blur(6px); padding: 0.5rem 0.8rem; max-width: 170px; }
.vb-metin-ic { font-family: var(--font-baslik); font-style: italic; color: var(--metin); font-size: 0.92rem; }
.vb-item.vb-sticker { border: none; box-shadow: none; background: transparent; }
.vb-item.vb-sticker:hover { box-shadow: none; }
.vb-sticker-ic { font-size: 2.4rem; filter: drop-shadow(0 0 10px rgba(233,196,106,0.6)); display: block; }
.vb-sil { position: absolute; top: -8px; right: -8px; width: 22px; height: 22px; border-radius: 50%; border: none; background: var(--uyari); color: #fff; font-size: 0.7rem; cursor: pointer; display: none; line-height: 1; z-index: 2; }
.vb-item:hover .vb-sil, .vb-item.suru .vb-sil { display: block; }

.vb-niyet-kart { padding: 1rem; margin-top: var(--sp-3); text-align: left; }
.vb-ai { background: rgba(233,196,106,0.08); border: 1px solid rgba(233,196,106,0.2); border-radius: var(--radius-sm); padding: 0.9rem 1rem; margin-top: var(--sp-3); text-align: left; }
.vb-ai-mesaj { font-family: var(--font-baslik); font-style: italic; color: var(--gold-soft); margin-bottom: 0.5rem; }
.vb-ai-sat { margin-top: 0.4rem; }
.vb-ai-et { display: block; font-size: 0.64rem; text-transform: uppercase; letter-spacing: 1px; color: var(--gold); }
.vb-ai-sat p { margin: 0.1rem 0 0; color: var(--metin-soft); }
.vb-aksiyon { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-top: var(--sp-3); justify-content: center; }
.vb-yukle { background: transparent; border: 1px solid var(--accent-2); color: var(--accent); border-radius: 8px; padding: 0.2rem 0.6rem; cursor: pointer; font-size: 0.78rem; margin-left: 0.4rem; }

/* ---------- Ritüeller & Araçlar ızgarası ---------- */
.card-araclar .araclar-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 0.7rem; margin-top: var(--sp-3); }
.arac-tile { display: flex; flex-direction: column; align-items: center; gap: 0.3rem; text-align: center; cursor: pointer; background: var(--card-bg-soft); border: 1px solid rgba(179,140,255,0.14); border-radius: 18px; padding: 1rem 0.7rem; font-family: inherit; color: var(--metin); transition: transform var(--gecis), box-shadow var(--gecis), border-color var(--gecis); }
.arac-tile:hover { transform: translateY(-4px); border-color: var(--gold); box-shadow: var(--glow-gold), var(--glow-mor); }
.arac-tile:active { transform: scale(0.97); }
.at-ikon { font-size: 1.9rem; filter: drop-shadow(0 0 10px rgba(233,196,106,0.45)); }
.at-ad { font-family: var(--font-baslik); font-size: 0.92rem; color: var(--gold-soft); line-height: 1.2; }
.at-alt { font-size: 0.7rem; color: var(--metin-faint); min-height: 0.9em; }
.arac-tile.oneri-aktif { border-color: var(--gold); box-shadow: var(--glow-gold); }
.arac-tile.oneri-aktif .at-alt { color: var(--gold-soft); }
.arac-tile.oneri-aktif .at-ikon { animation: auraNefes 3s ease-in-out infinite; }

/* ---------- Ayna Modu / Kendinle Konuş ---------- */
.card-ayna-giris .am-ikon { font-size: 1.9rem; filter: drop-shadow(0 0 12px rgba(179,140,255,0.6)); animation: auraNefes 5s ease-in-out infinite; }

.ayna-overlay {
  position: fixed; inset: 0; z-index: 175; overflow-y: auto; padding: 1.5rem 1.2rem 3rem;
  display: flex; align-items: flex-start; justify-content: center;
  background: radial-gradient(900px 700px at 50% 20%, #221a4a 0%, transparent 60%), linear-gradient(170deg, #0a0820, #120b2e 60%, #0f0a24);
  opacity: 0; transition: opacity 0.5s;
}
.ayna-overlay.gor { opacity: 1; }
.ayna-overlay[hidden] { display: none; }
.ayna-parcaciklar { position: fixed; inset: 0; pointer-events: none; overflow: hidden; }
.ayna-parcaciklar span { position: absolute; width: 4px; height: 4px; border-radius: 50%; background: radial-gradient(circle, #fff4d6, rgba(179,140,255,0.5)); box-shadow: 0 0 8px 2px rgba(179,140,255,0.4); opacity: 0; animation-name: parcacikAk; animation-iteration-count: infinite; animation-timing-function: linear; }
.ayna-ic { position: relative; max-width: 440px; width: 100%; text-align: center; }
.ayna-puan { font-size: 0.85rem; color: var(--gold); margin-bottom: 0.6rem; }
.ayna-puan strong { color: var(--gold-soft); }

.ayna-glass {
  position: relative; width: 100%; max-width: 340px; margin: 0 auto; aspect-ratio: 3 / 4;
  border-radius: 26px; overflow: hidden; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(160deg, rgba(179,140,255,0.18), rgba(20,14,44,0.5) 40%, rgba(91,80,160,0.18));
  border: 1px solid rgba(233,196,106,0.3);
  box-shadow: 0 0 50px rgba(179,140,255,0.35), inset 0 0 40px rgba(255,255,255,0.06);
  animation: aynaNefes 5s ease-in-out infinite;
}
@keyframes aynaNefes { 0%,100% { box-shadow: 0 0 40px rgba(179,140,255,0.3), inset 0 0 36px rgba(255,255,255,0.05); } 50% { box-shadow: 0 0 64px rgba(179,140,255,0.5), inset 0 0 44px rgba(255,255,255,0.1); } }
.ayna-glass video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transform: scaleX(-1); }
.ayna-glass.kamerali .ayna-yansima { display: none; }
.ayna-shine { position: absolute; top: 0; left: -60%; width: 50%; height: 100%; background: linear-gradient(120deg, transparent, rgba(255,255,255,0.18), transparent); transform: skewX(-20deg); animation: aynaShine 6s ease-in-out infinite; pointer-events: none; }
@keyframes aynaShine { 0%,75% { left: -60%; } 90%,100% { left: 120%; } }
.ayna-yansima { width: 96px; height: 96px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-baslik); font-size: 2.4rem; color: rgba(255,255,255,0.85); background: radial-gradient(circle at 40% 35%, rgba(179,140,255,0.5), rgba(58,42,109,0.5)); background-size: cover; background-position: center; box-shadow: 0 0 30px rgba(179,140,255,0.5); opacity: 0.85; }
.ayna-yansima.foto { font-size: 0; }
.ayna-olumlama { position: absolute; bottom: 18px; left: 16px; right: 16px; font-family: var(--font-baslik); font-style: italic; font-size: 1.15rem; color: #fff; text-shadow: 0 2px 12px rgba(0,0,0,0.6); margin: 0; }

.ayna-cam-satir { display: flex; gap: 0.5rem; justify-content: center; align-items: center; flex-wrap: wrap; margin-top: var(--sp-3); }
.ayna-fav-btn { width: 40px; height: 40px; border-radius: 50%; border: 1px solid rgba(179,140,255,0.3); background: transparent; color: var(--metin-soft); cursor: pointer; display: flex; align-items: center; justify-content: center; }
.ayna-fav-btn svg { width: 18px; height: 18px; }
.ayna-fav-btn.aktif { color: var(--gold); border-color: var(--gold); box-shadow: var(--glow-gold); }
.ayna-fav-btn.aktif svg { fill: var(--gold); }
.ayna-cam-not { margin-top: 0.4rem; }
.ayna-kart { padding: 1rem; margin-top: 0.6rem; text-align: left; }
.ayna-dinle-mini { background: transparent; border: none; color: var(--gold); cursor: pointer; font-size: 1rem; flex-shrink: 0; }
.ayna-bitir { width: 100%; margin-top: var(--sp-3); }

/* ---------- Nefes & Sakinleşme ---------- */
.card-nefes-giris .nf-ikon { font-size: 1.9rem; filter: drop-shadow(0 0 12px rgba(179,140,255,0.6)); animation: auraNefes 5s ease-in-out infinite; }
.card-nefes-giris.oneri-aktif { border-color: var(--gold); box-shadow: var(--shadow), var(--glow-gold); }
.card-nefes-giris.oneri-aktif #nf-oneri { color: var(--gold-soft); }

.nefes-overlay {
  position: fixed; inset: 0; z-index: 175; overflow-y: auto; padding: 1.5rem 1.2rem 3rem;
  display: flex; align-items: flex-start; justify-content: center;
  background: radial-gradient(900px 700px at 50% 30%, #241a52 0%, transparent 60%), linear-gradient(170deg, #0a0820, #120b2e 60%, #0f0a24);
  opacity: 0; transition: opacity 0.5s;
}
.nefes-overlay.gor { opacity: 1; }
.nefes-overlay[hidden] { display: none; }
.nefes-parcaciklar { position: fixed; inset: 0; pointer-events: none; overflow: hidden; }
.nefes-parcaciklar span { position: absolute; width: 4px; height: 4px; border-radius: 50%; background: radial-gradient(circle, #fff4d6, rgba(179,140,255,0.5)); box-shadow: 0 0 8px 2px rgba(179,140,255,0.4); opacity: 0; animation-name: parcacikAk; animation-iteration-count: infinite; animation-timing-function: linear; }
.nefes-ic { position: relative; max-width: 440px; width: 100%; text-align: center; }
.nefes-ay { font-size: 2.6rem; filter: drop-shadow(0 0 16px rgba(179,140,255,0.6)); animation: suzul 5s ease-in-out infinite; }
.nefes-baslik { font-family: var(--font-baslik); font-size: 1.6rem; color: var(--gold-soft); margin: 0.3rem 0 0.2rem; }
.nefes-alt-baslik { margin: var(--sp-3) 0 0.4rem; }
.nefes-turler { display: flex; flex-direction: column; gap: 0.5rem; text-align: left; }
.nefes-tur-btn { display: flex; flex-direction: column; gap: 0.1rem; position: relative; background: rgba(255,255,255,0.04); border: 1px solid rgba(179,140,255,0.18); border-radius: 14px; padding: 0.7rem 0.9rem; cursor: pointer; font-family: inherit; color: var(--metin); transition: all 0.2s; }
.nefes-tur-btn strong { color: var(--metin); }
.nefes-tur-btn span { font-size: 0.8rem; color: var(--metin-soft); }
.nefes-tur-btn small { position: absolute; top: 0.7rem; right: 0.9rem; color: var(--gold-soft); font-size: 0.78rem; }
.nefes-tur-btn:hover { border-color: var(--accent-2); }
.nefes-tur-btn.aktif { border-color: var(--gold); box-shadow: var(--glow-gold); background: rgba(233,196,106,0.08); }
.nefes-sureler { display: flex; gap: 0.5rem; }
.nefes-sure-btn { flex: 1; background: rgba(255,255,255,0.05); border: 1px solid rgba(179,140,255,0.2); color: var(--metin); border-radius: 12px; padding: 0.5rem; cursor: pointer; font-family: inherit; transition: all 0.2s; }
.nefes-sure-btn.aktif { border-color: var(--gold); color: var(--gold); box-shadow: var(--glow-gold); }
.nefes-ayarlar { display: flex; flex-direction: column; gap: 0.5rem; margin: var(--sp-3) 0; }
.nefes-ayar { display: flex; align-items: center; justify-content: space-between; color: var(--metin); }
.nefes-basla { width: 100%; }
#nefes-gecmis { margin-top: var(--sp-3); text-align: left; }

.nefes-seans { padding-top: var(--sp-3); }
.nefes-tur-ad { font-family: var(--font-baslik); color: var(--gold-soft); font-size: 1.1rem; margin-bottom: var(--sp-4); }
.nefes-kure-sar { height: 300px; display: flex; align-items: center; justify-content: center; position: relative; }
.nefes-kure {
  width: 160px; height: 160px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  color: #fff; font-family: var(--font-baslik); font-size: 1.1rem;
  background: radial-gradient(circle at 38% 32%, #b38cff, #3a2a6d); box-shadow: 0 0 40px rgba(179,140,255,0.5);
  transform: scale(0.65); transition: transform 4s ease, box-shadow 4s ease;
}
.nefes-kure.genis, .nefes-kure.tut { transform: scale(1.15); box-shadow: 0 0 70px rgba(179,140,255,0.85); }
.nefes-kure.dar { transform: scale(0.65); box-shadow: 0 0 24px rgba(179,140,255,0.35); }
.nefes-sayac { color: var(--metin-soft); margin: var(--sp-3) 0; }

.nefes-bitti { padding-top: var(--sp-4); }
.nefes-bitti-ay { font-size: 2.4rem; filter: drop-shadow(0 0 14px rgba(233,196,106,0.5)); }
.nefes-bitti-mesaj { font-family: var(--font-baslik); font-size: 1.3rem; color: var(--gold-soft); margin: 0.4rem 0; }
.nefes-bitti-btns { display: flex; gap: 0.6rem; justify-content: center; margin-top: var(--sp-3); }

/* ---------- Sabah Ritüeli & Güne Başlangıç ---------- */
.card-sabah-giris .sg-gunes { font-size: 2rem; filter: drop-shadow(0 0 14px rgba(233,196,106,0.6)); animation: gunesPulse 4s ease-in-out infinite; }
@keyframes gunesPulse { 0%,100% { filter: drop-shadow(0 0 10px rgba(233,196,106,0.45)) brightness(1); } 50% { filter: drop-shadow(0 0 22px rgba(255,200,80,0.8)) brightness(1.15); } }

.sabah-overlay {
  position: fixed; inset: 0; z-index: 170; overflow-y: auto; padding: 1.5rem 1.2rem 3rem;
  background: linear-gradient(180deg, #1a1240 0%, #3a2a5a 35%, #8a5a4a 70%, #e9a86a 100%);
  opacity: 0; transition: opacity 0.6s;
}
.sabah-overlay.gor { opacity: 1; }
.sabah-overlay[hidden] { display: none; }
.sabah-gok { position: fixed; inset: 0; pointer-events: none; overflow: hidden; }
.sabah-gunes-glow { position: absolute; left: 50%; top: -30%; width: 140%; height: 80%; transform: translateX(-50%); background: radial-gradient(ellipse at 50% 100%, rgba(255,200,90,0.5), rgba(233,196,106,0.2) 40%, transparent 70%); animation: gunDogumu 6s ease-in-out infinite; }
@keyframes gunDogumu { 0%,100% { opacity: 0.6; } 50% { opacity: 1; } }
.sabah-parcaciklar span { position: absolute; width: 5px; height: 5px; border-radius: 50%; background: radial-gradient(circle, #fff4d6, rgba(233,196,106,0.5)); box-shadow: 0 0 8px 2px rgba(233,196,106,0.4); opacity: 0; animation-name: sabahParca; animation-iteration-count: infinite; animation-timing-function: ease-in-out; }
@keyframes sabahParca { 0% { opacity: 0; transform: translateY(0); } 20% { opacity: 0.9; } 100% { opacity: 0; transform: translateY(-120px); } }
.sabah-ic { position: relative; }
.sabah-gunes { font-size: 3rem; filter: drop-shadow(0 0 20px rgba(255,200,90,0.7)); animation: gunesPulse 4s ease-in-out infinite; margin-top: 0.5rem; }
.sabah-overlay .gece-baslik { color: #fff3d6; }
.sabah-overlay .gece-mesaj { color: rgba(255,255,255,0.85); }
.sabah-overlay .gece-streak { color: #ffe2a0; }
.sabah-overlay .gece-kart { background: rgba(20,14,40,0.4); border-color: rgba(255,220,150,0.25); }
.sabah-overlay .gece-rutin-kart.yapildi { border-color: var(--gold); box-shadow: var(--glow-gold); }
.nefes-orb.sabah { background: radial-gradient(circle at 40% 35%, #ffd98a, #c77a3a); box-shadow: 0 0 30px rgba(255,200,90,0.6); }
.sr-enerji { font-family: var(--font-baslik); font-style: italic; color: var(--gold-soft); margin: 0.2rem 0 0.6rem; }
.sr-kart-alan { margin-top: 0.6rem; }
.sr-kart-ic { display: flex; gap: 0.6rem; align-items: center; }
.sr-kart-ic img { width: 54px; height: 54px; border-radius: 10px; object-fit: cover; box-shadow: var(--glow-gold); flex-shrink: 0; }
.sr-kart-ic strong { color: var(--metin); }
.sabah-bitir { width: 100%; margin-top: var(--sp-3); }

/* ---------- Uyku & Gece Rutini ---------- */
.card-gece-giris .gg-ic { display: flex; align-items: center; gap: 0.9rem; flex-wrap: wrap; }
.gg-ay { font-size: 2rem; filter: drop-shadow(0 0 12px rgba(233,196,106,0.5)); animation: suzul 5s ease-in-out infinite; }
.gg-bilgi { flex: 1; min-width: 120px; }
.gg-baslik { font-family: var(--font-baslik); color: var(--gold-soft); font-size: 1.1rem; }
.gg-btn { flex-shrink: 0; }

.gece-overlay {
  position: fixed; inset: 0; z-index: 170; overflow-y: auto; padding: 1.5rem 1.2rem 3rem;
  background: radial-gradient(1000px 700px at 50% 8%, #1a1240 0%, transparent 60%), linear-gradient(180deg, #05040f, #0a0820 60%, #0f0a24);
  opacity: 0; transition: opacity 0.5s;
}
.gece-overlay.gor { opacity: 1; }
.gece-overlay[hidden] { display: none; }
.gece-gok { position: fixed; inset: 0; pointer-events: none; overflow: hidden; }
.gece-neb { position: absolute; inset: -10%; background: radial-gradient(40% 30% at 30% 20%, rgba(124,58,237,0.3), transparent 60%), radial-gradient(35% 30% at 75% 30%, rgba(91,80,180,0.25), transparent 60%); filter: blur(50px); animation: nebulaKay 40s ease-in-out infinite alternate; }
.gece-yildizlar span { position: absolute; border-radius: 50%; background: #fff; box-shadow: 0 0 6px 1px rgba(255,255,255,0.5); opacity: 0.5; animation: yildizParla 3.5s ease-in-out infinite; }
.gece-ic { position: relative; max-width: 480px; margin: 0 auto; text-align: center; }
.gece-kapat { position: absolute; top: -4px; right: 0; background: transparent; border: none; color: var(--metin-faint); font-size: 1.3rem; cursor: pointer; }
.gece-ay { font-size: 3rem; filter: drop-shadow(0 0 18px rgba(233,196,106,0.6)); animation: suzul 5s ease-in-out infinite; margin-top: 0.5rem; }
.gece-baslik { font-family: var(--font-baslik); font-size: 1.7rem; color: var(--gold-soft); margin: 0.4rem 0 0.2rem; }
.gece-mesaj { font-family: var(--font-baslik); font-style: italic; color: var(--metin-soft); margin: 0 0 0.6rem; }
.gece-streak { font-size: 0.85rem; color: var(--gold); margin-bottom: 0.8rem; }
.gece-ilerleme { height: 6px; background: rgba(255,255,255,0.08); border-radius: 99px; overflow: hidden; margin-bottom: var(--sp-3); }
.gece-ilerleme span { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--accent), var(--gold)); transition: width 0.5s; }
.gece-rutin { display: flex; flex-direction: column; gap: 0.5rem; text-align: left; }
.gece-kart { background: rgba(255,255,255,0.04); border: 1px solid rgba(179,140,255,0.14); border-radius: 16px; }
.gece-rutin-kart.yapildi { border-color: var(--gold); box-shadow: var(--glow-gold); }
.gr-bas { width: 100%; display: flex; align-items: center; gap: 0.7rem; background: transparent; border: none; color: var(--metin); cursor: pointer; font-family: inherit; padding: 0.8rem 1rem; }
.gr-ikon { font-size: 1.3rem; }
.gr-ad { flex: 1; text-align: left; font-size: 0.98rem; }
.gr-check { color: var(--metin-faint); font-size: 1.05rem; }
.gece-rutin-kart.yapildi .gr-check { color: var(--gold); }
.gr-icerik { padding: 0 1rem 1rem; animation: balonGir 0.3s ease both; }
.gr-olumlama { font-family: var(--font-baslik); font-style: italic; color: var(--metin); margin: 0.2rem 0 0.6rem; }
.gr-cal.aktif { border-color: var(--gold); color: var(--gold); box-shadow: var(--glow-gold); }
.gr-frek-btns { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.gr-mood { display: flex; gap: 0.4rem; }
.gr-mood-btn { width: 40px; height: 40px; border-radius: 12px; border: 1.5px solid transparent; background: rgba(255,255,255,0.05); color: var(--metin-soft); cursor: pointer; display: flex; align-items: center; justify-content: center; }
.gr-mood-btn svg { width: 22px; height: 22px; }
.gr-mood-btn.aktif { border-color: var(--gold); color: var(--gold); box-shadow: var(--glow-gold); }
.nefes-orb {
  width: 120px; height: 120px; border-radius: 50%; margin: 0.5rem auto 1rem;
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(circle at 40% 35%, #b38cff, #3a2a6d);
  box-shadow: 0 0 30px rgba(179,140,255,0.5); color: #fff; font-size: 0.9rem;
  transition: transform 4s ease, box-shadow 4s ease;
}
.nefes-orb.al { transform: scale(1.35); box-shadow: 0 0 50px rgba(179,140,255,0.8); }
.nefes-orb.tut { transform: scale(1.35); }
.nefes-orb.ver { transform: scale(0.85); box-shadow: 0 0 20px rgba(179,140,255,0.4); }
.gece-soru-kart, .gece-sayac-kart { padding: 1rem; margin-top: 0.6rem; text-align: left; }
.gece-soru-baslik, .gece-sayac-baslik { display: block; font-family: var(--font-baslik); color: var(--gold-soft); margin-bottom: 0.5rem; }
.gece-sayac-btns { display: flex; gap: 0.5rem; }
.gece-sayac-btns button { flex: 1; background: rgba(255,255,255,0.05); border: 1px solid rgba(179,140,255,0.2); color: var(--metin); border-radius: 12px; padding: 0.5rem; cursor: pointer; font-family: inherit; transition: all 0.2s; }
.gece-sayac-btns button:hover { border-color: var(--gold); color: var(--gold); }
.gece-sayac-durum { font-size: 0.82rem; color: var(--metin-soft); margin-top: 0.5rem; text-align: center; }
.gece-bitir { width: 100%; margin-top: var(--sp-3); }
.gece-tamam { margin-top: var(--sp-3); background: rgba(233,196,106,0.1); border: 1px solid var(--gold); border-radius: var(--radius-sm); padding: 1rem; color: var(--gold-soft); font-family: var(--font-baslik); box-shadow: var(--glow-gold); animation: balonGir 0.5s ease both; }

/* ---------- Spiritüel Başlangıç Testi ---------- */
.test-overlay {
  position: fixed; inset: 0; z-index: 160;
  display: flex; align-items: center; justify-content: center; padding: 1.4rem; overflow-y: auto;
  background: radial-gradient(900px 600px at 50% 12%, #2a1d52 0%, transparent 60%), linear-gradient(165deg, #0c0a1c, #161033 60%, #211743);
  opacity: 0; transition: opacity 0.4s;
}
.test-overlay.gor { opacity: 1; }
.test-overlay[hidden] { display: none; }
.test-kart { position: relative; max-width: 420px; width: 100%; background: rgba(255,255,255,0.05); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); border: 1px solid var(--card-border); border-radius: 24px; padding: 2rem 1.6rem; box-shadow: var(--shadow), var(--glow-mor); }
.test-kart.gecis .test-secenekler, .test-kart.gecis .test-soru { animation: testGecis 0.4s ease; }
@keyframes testGecis { from { opacity: 0; transform: translateX(16px); } to { opacity: 1; transform: none; } }
.test-yildiz span { position: absolute; width: 4px; height: 4px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 8px 1px rgba(233,196,106,0.6); opacity: 0.5; animation: yildizParla 3s ease-in-out infinite; }
.test-yildiz span:nth-child(1){top:16px;left:20px}.test-yildiz span:nth-child(2){top:24px;right:26px;animation-delay:.8s;background:#fff;box-shadow:0 0 8px 1px rgba(255,255,255,.6)}.test-yildiz span:nth-child(3){bottom:30px;left:26px;animation-delay:1.6s;background:var(--accent)}.test-yildiz span:nth-child(4){bottom:20px;right:22px;animation-delay:2.2s}
.test-ust { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.6rem; }
.test-mini { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 1px; color: var(--accent); }
.test-adim { font-size: 0.78rem; color: var(--gold-soft); }
.test-ilerleme { height: 6px; background: rgba(255,255,255,0.1); border-radius: 99px; overflow: hidden; margin-bottom: 1.2rem; }
.test-ilerleme span { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--accent), var(--gold)); transition: width 0.5s; }
.test-soru { font-family: var(--font-baslik); font-size: 1.4rem; color: var(--metin); margin: 0 0 1.2rem; line-height: 1.45; }
.test-secenekler { display: flex; flex-direction: column; gap: 0.6rem; }
.test-secenek { text-align: left; background: rgba(255,255,255,0.05); border: 1px solid rgba(179,140,255,0.22); color: var(--metin); border-radius: 14px; padding: 0.85rem 1rem; font-family: inherit; font-size: 0.98rem; cursor: pointer; transition: all 0.2s; }
.test-secenek:hover { border-color: var(--gold); box-shadow: var(--glow-gold); transform: translateY(-2px); background: rgba(233,196,106,0.08); }

.test-sonuc-alan { position: relative; text-align: center; animation: balonGir 0.5s ease both; }
.ts-parcacik { position: absolute; left: 50%; top: 28%; width: 0; height: 0; pointer-events: none; }
.ts-parcacik span { position: absolute; width: 7px; height: 7px; border-radius: 50%; background: radial-gradient(circle, #fff4d6, var(--gold)); box-shadow: 0 0 8px 2px rgba(233,196,106,0.6); animation: rituelParca 1s ease-out forwards; }
.ts-rozet { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--accent); }
.ts-ad { font-family: var(--font-baslik); font-size: 1.7rem; color: var(--gold-soft); margin: 0.3rem 0; text-shadow: 0 0 24px rgba(233,196,106,0.3); }
.ts-analiz { font-family: var(--font-baslik); font-style: italic; color: var(--metin); font-size: 1.1rem; margin: 0.4rem 0 0.2rem; }
.ts-oneri { text-align: left; margin-top: 0.7rem; }
.ts-et { display: block; font-size: 0.66rem; text-transform: uppercase; letter-spacing: 1px; color: var(--gold); margin-bottom: 0.2rem; }
.ts-oneri p { margin: 0; color: var(--metin-soft); }
.ts-kart { display: flex; gap: 0.6rem; align-items: center; }
.ts-kart img { width: 50px; height: 50px; border-radius: 10px; object-fit: cover; box-shadow: var(--glow-gold); flex-shrink: 0; }
.ts-kart strong { color: var(--metin); }
.ts-bitir { width: 100%; margin-top: 1.2rem; }

/* Profil test rozeti */
.profil-test { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; margin: 0.3rem 0; }
.profil-test-rozet { font-size: 0.8rem; color: var(--gold); background: rgba(233,196,106,0.12); border: 1px solid rgba(233,196,106,0.35); border-radius: 999px; padding: 0.2rem 0.7rem; }
.profil-test-btn { background: transparent; border: none; color: var(--accent); font-family: inherit; font-size: 0.78rem; cursor: pointer; text-decoration: underline; padding: 0; }

@media (max-width: 480px) { .test-soru { font-size: 1.2rem; } .ts-ad { font-size: 1.4rem; } }

/* ---------- Alt navigasyon ---------- */
.bottom-nav {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 50;
  display: flex; justify-content: space-around; align-items: stretch;
  padding: 0.4rem 0.3rem calc(0.4rem + env(safe-area-inset-bottom, 0px));
  background: rgba(14, 11, 30, 0.82);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  border-top: 1px solid var(--card-border);
  box-shadow: 0 -10px 30px rgba(0, 0, 0, 0.4);
}
.nav-btn {
  flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px;
  background: transparent; border: none; cursor: pointer;
  color: var(--metin-faint); font-family: inherit; font-size: 0.68rem; letter-spacing: 0.2px;
  padding: 0.4rem 0.2rem; border-radius: 12px;
  transition: color 0.25s, transform 0.2s;
}
.nav-btn svg { width: 24px; height: 24px; transition: transform 0.25s, filter 0.25s; }
.nav-btn:hover { color: var(--metin-soft); }
.nav-btn.active { color: var(--gold); }
.nav-btn.active svg { transform: translateY(-2px); filter: drop-shadow(0 0 8px rgba(233,196,106,0.55)); }

/* ---------- Responsive ---------- */
/* Tablet: rehber önerileri / gridler rahat akar (auto-fill zaten uyumlu) */
@media (max-width: 900px) {
  .app { max-width: 720px; }
}
/* Mobil */
@media (max-width: 640px) {
  .grid { grid-template-columns: 1fr; padding: var(--sp-2) var(--sp-3) var(--sp-4); gap: var(--sp-3); }
  .site-header { padding: var(--sp-4) 1rem var(--sp-2); }
  .site-header h1 { font-size: 1.9rem; }
  .card { padding: var(--sp-3); }
  .card h2 { font-size: 1.2rem; }
  .card-motivasyon blockquote { font-size: 1.25rem; }
  .nav-btn span { font-size: 0.58rem; }
  .nav-btn { padding: 0.4rem 0.1rem; }
  .nav-btn svg { width: 22px; height: 22px; }
}
/* Desktop: daha ferah grid */
@media (min-width: 1000px) {
  .grid { grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); }
}

/* ---------- Performans: animasyon duraklatma ---------- */
/* Sekme arka plandayken tüm animasyonları durdur (pil/CPU tasarrufu) */
body.sayfa-gizli *, body.sayfa-gizli *::before, body.sayfa-gizli *::after { animation-play-state: paused !important; }
/* Ekran dışı öğelerin animasyonlarını durdur (js/perf.js) */
.anim-duraklat, .anim-duraklat *, .anim-duraklat::before, .anim-duraklat::after { animation-play-state: paused !important; }

/* ---------- Erişilebilirlik: hareketi azalt ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
}

/* ============================================================
   Spiritüel Takvim 📅 — kozmik takvim overlay
   ============================================================ */
.takvim-overlay {
  position: fixed; inset: 0; z-index: 175; overflow-y: auto; padding: 1.5rem 1.1rem 3rem;
  background: radial-gradient(900px 700px at 50% 8%, #241a52 0%, transparent 60%), linear-gradient(170deg, #0a0820, #120b2e 60%, #0f0a24);
  opacity: 0; transition: opacity 0.5s;
}
.takvim-overlay.gor { opacity: 1; }
.takvim-overlay[hidden] { display: none; }
.takvim-ic { position: relative; max-width: 560px; margin: 0 auto; }
.tk-baslik { font-family: var(--font-baslik); color: var(--gold-soft); font-size: 1.5rem; text-align: center; margin: 0.2rem 0 0.2rem; }
.tk-ust-not { text-align: center; margin: 0 0 var(--sp-3); }

/* floating yıldız parçacıkları */
.tk-yildizlar { position: fixed; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.tk-yildizlar span { position: absolute; width: 4px; height: 4px; border-radius: 50%; background: radial-gradient(circle, #fff4d6, rgba(179,140,255,0.5)); box-shadow: 0 0 8px 2px rgba(179,140,255,0.4); opacity: 0; animation: tkYildiz 7s ease-in-out infinite; }
.tk-yildizlar span:nth-child(1){left:8%;top:14%;animation-delay:0s} .tk-yildizlar span:nth-child(2){left:22%;top:60%;animation-delay:1s;width:3px;height:3px} .tk-yildizlar span:nth-child(3){left:40%;top:24%;animation-delay:2.2s} .tk-yildizlar span:nth-child(4){left:58%;top:72%;animation-delay:0.6s;width:5px;height:5px} .tk-yildizlar span:nth-child(5){left:74%;top:18%;animation-delay:3s} .tk-yildizlar span:nth-child(6){left:88%;top:54%;animation-delay:1.7s} .tk-yildizlar span:nth-child(7){left:15%;top:84%;animation-delay:2.6s;width:3px;height:3px} .tk-yildizlar span:nth-child(8){left:66%;top:40%;animation-delay:4s} .tk-yildizlar span:nth-child(9){left:48%;top:90%;animation-delay:1.2s}
@keyframes tkYildiz { 0%,100% { opacity: 0; transform: translateY(0) scale(0.8); } 50% { opacity: 0.9; transform: translateY(-12px) scale(1.2); } }

.takvim-ic > *:not(.tk-yildizlar) { position: relative; z-index: 1; }

/* ay gezinme */
.tk-ay-gez-bar { display: flex; align-items: center; justify-content: center; gap: var(--sp-3); margin-bottom: var(--sp-3); }
.tk-ay-gez { width: 38px; height: 38px; border-radius: 50%; border: 1px solid rgba(179,140,255,0.3); background: var(--card-bg-soft); color: var(--gold-soft); font-size: 1.3rem; line-height: 1; cursor: pointer; transition: all 0.2s; }
.tk-ay-gez:hover { border-color: var(--gold); box-shadow: var(--glow-gold); }
.tk-ay-ad { font-family: var(--font-baslik); font-size: 1.2rem; color: var(--metin); min-width: 150px; text-align: center; }

/* haftalık + ızgara */
.tk-haftalik { display: grid; grid-template-columns: repeat(7, 1fr); gap: 0.3rem; margin-bottom: 0.4rem; }
.tk-haftalik span { text-align: center; font-size: 0.7rem; color: var(--metin-faint); text-transform: uppercase; letter-spacing: 0.5px; }
.tk-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 0.3rem; }
.tk-bos { aspect-ratio: 1; }
.tk-gun {
  position: relative; aspect-ratio: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  border-radius: 13px; border: 1px solid rgba(179,140,255,0.12); background: var(--card-bg-soft);
  color: var(--metin-soft); cursor: pointer; font-family: inherit; padding: 2px; transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}
.tk-gun:hover { transform: translateY(-2px); border-color: var(--accent-2); box-shadow: var(--glow-mor); }
.tk-gun-no { font-size: 0.86rem; font-weight: 600; }
.tk-gun-ikon { display: flex; gap: 1px; font-size: 0.62rem; line-height: 1; min-height: 0.7em; }
.tk-gun.olayli { border-color: color-mix(in srgb, var(--renk, var(--accent)) 55%, transparent); background: color-mix(in srgb, var(--renk, var(--accent)) 12%, var(--card-bg-soft)); }
.tk-gun.olayli .tk-gun-no { color: var(--metin); }
.tk-gun.secili { border-color: var(--gold); box-shadow: var(--glow-gold); }
.tk-gun.bugun { border-color: var(--gold); color: var(--metin); }
.tk-gun.bugun::before { content: ""; position: absolute; inset: -3px; border-radius: 15px; border: 1.5px solid var(--gold); animation: tkPulse 2.2s ease-in-out infinite; pointer-events: none; }
@keyframes tkPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(233,196,106,0.5); opacity: 1; } 50% { box-shadow: 0 0 14px 3px rgba(233,196,106,0.45); opacity: 0.65; } }

/* açıklama (legend) */
.tk-aciklama { display: flex; flex-wrap: wrap; gap: 0.5rem 0.9rem; justify-content: center; margin: var(--sp-3) 0; }
.tk-lg { display: inline-flex; align-items: center; gap: 0.25rem; font-size: 0.72rem; color: var(--metin-faint); }
.tk-lg-ikon { font-size: 0.95rem; }

/* gün detayı */
.tk-detay { margin-top: var(--sp-2); }
.tk-detay.tk-fade { animation: tkFade 0.45s ease; }
@keyframes tkFade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.tk-detay-tarih { font-family: var(--font-baslik); color: var(--gold-soft); font-size: 1.1rem; margin: 0 0 0.6rem; text-transform: capitalize; }
.tk-enerji { display: block; width: 100%; text-align: left; background: rgba(179,140,255,0.1); border: 1px solid rgba(179,140,255,0.25); border-radius: var(--radius-sm); padding: 0.6rem 0.9rem; color: var(--metin-soft); cursor: pointer; margin-bottom: 0.7rem; font-family: inherit; }
.tk-enerji b { color: var(--gold-soft); }
.tk-olay { border: 1px solid color-mix(in srgb, var(--renk) 40%, transparent); background: color-mix(in srgb, var(--renk) 9%, var(--card-bg-soft)); border-left: 3px solid var(--renk); border-radius: var(--radius-sm); padding: 0.8rem 1rem; margin-bottom: 0.7rem; }
.tk-olay-bas { display: flex; align-items: center; gap: 0.5rem; }
.tk-olay-bas b { font-family: var(--font-baslik); color: var(--metin); flex: 1; }
.tk-olay-ikon { font-size: 1.3rem; filter: drop-shadow(0 0 8px color-mix(in srgb, var(--renk) 60%, transparent)); }
.tk-olay-mesaj { margin: 0.4rem 0 0.5rem; color: var(--metin-soft); font-size: 0.92rem; }
.tk-sat { display: flex; gap: 0.5rem; font-size: 0.86rem; color: var(--metin-soft); margin-top: 0.3rem; }
.tk-et { flex: 0 0 auto; font-size: 0.62rem; text-transform: uppercase; letter-spacing: 1px; color: var(--gold); padding-top: 0.15rem; min-width: 72px; }
.tk-olumlama { font-family: var(--font-baslik); font-style: italic; color: var(--gold-soft); margin-top: 0.5rem; }
.tk-sil { background: transparent; border: none; color: var(--uyari); cursor: pointer; font-size: 0.85rem; padding: 0.1rem 0.3rem; }
.tk-bos-mesaj { text-align: center; padding: 0.8rem 0; }

/* özel gün ekleme */
.tk-ekle-detay { margin-top: var(--sp-3); }
.tk-ekle { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.6rem; }
.tk-ekle-satir { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; }
.tk-ekle-satir select, .tk-ekle input, .tk-ekle textarea, .tk-ekle-satir input[type="time"] {
  background: rgba(255,255,255,0.05); border: 1px solid rgba(179,140,255,0.25); color: var(--metin); border-radius: 10px; padding: 0.55rem 0.7rem; font-family: inherit; font-size: 0.9rem;
}
.tk-ekle input, .tk-ekle textarea { width: 100%; }
.tk-hatirlat { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.85rem; color: var(--metin-soft); }

@media (max-width: 480px) {
  .tk-gun-no { font-size: 0.78rem; }
  .tk-ay-ad { min-width: 120px; font-size: 1.05rem; }
  .tk-grid, .tk-haftalik { gap: 0.22rem; }
}

/* ============================================================
   Günün Kapısı 🚪 — sinematik spiritüel portal
   ============================================================ */
.kapi-overlay {
  --kapi-1: #7c5cbf; --kapi-2: #241247; --kapi-glow: #b38cff;
  position: fixed; inset: 0; z-index: 200; overflow: hidden;
  display: flex; align-items: center; justify-content: center; padding: 1.5rem 1.2rem;
  background: radial-gradient(1100px 800px at 50% 30%, color-mix(in srgb, var(--kapi-2) 90%, #000), #07050f 75%);
  opacity: 0; transition: opacity 0.7s ease;
}
.kapi-overlay.gor { opacity: 1; }
.kapi-overlay[hidden] { display: none; }

/* mor nebula + altın glow zemin */
.kapi-nebula {
  position: absolute; inset: -20%; pointer-events: none;
  background:
    radial-gradient(40% 35% at 30% 28%, color-mix(in srgb, var(--kapi-1) 55%, transparent), transparent 70%),
    radial-gradient(45% 40% at 72% 66%, color-mix(in srgb, var(--kapi-glow) 35%, transparent), transparent 70%),
    radial-gradient(30% 26% at 60% 20%, rgba(233,196,106,0.18), transparent 70%);
  filter: blur(14px); animation: kapiNebula 18s ease-in-out infinite alternate;
}
@keyframes kapiNebula { 0% { transform: scale(1) translateY(0); opacity: 0.8; } 100% { transform: scale(1.12) translateY(-2%); opacity: 1; } }

/* sis / fog */
.kapi-sis { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.kapi-sis span { position: absolute; width: 60vmax; height: 60vmax; border-radius: 50%; background: radial-gradient(circle, color-mix(in srgb, var(--kapi-1) 30%, transparent), transparent 60%); filter: blur(40px); opacity: 0.5; }
.kapi-sis span:nth-child(1) { left: -20%; top: 20%; animation: kapiSis 26s ease-in-out infinite; }
.kapi-sis span:nth-child(2) { right: -20%; bottom: 10%; animation: kapiSis 32s ease-in-out infinite reverse; }
@keyframes kapiSis { 0%,100% { transform: translateX(0) translateY(0); } 50% { transform: translateX(8%) translateY(-6%); } }

/* kozmik parçacıklar */
.kapi-parcaciklar { position: absolute; inset: 0; pointer-events: none; }
.kapi-parcaciklar span { position: absolute; border-radius: 50%; background: radial-gradient(circle, #fff7e0, var(--kapi-glow)); box-shadow: 0 0 8px 2px color-mix(in srgb, var(--kapi-glow) 60%, transparent); animation: kapiParca var(--gec, 7s) ease-in-out infinite; }
@keyframes kapiParca { 0%,100% { transform: translateY(0) scale(0.9); opacity: 0.25; } 50% { transform: translateY(-16px) scale(1.25); opacity: 0.95; } }

.kapi-sahne { position: relative; z-index: 2; width: 100%; max-width: 420px; text-align: center; }

/* ---- kapalı kapı sahnesi ---- */
.kapi-kapali { transition: opacity 0.7s ease, transform 0.7s ease; }
.kapi-kapali.aciliyor { opacity: 0; transform: scale(1.04); pointer-events: none; }

.kapi-portal {
  position: relative; width: min(72vw, 280px); aspect-ratio: 0.62; margin: 0 auto var(--sp-4);
  border-radius: 140px 140px 26px 26px; perspective: 900px;
  border: 2px solid color-mix(in srgb, var(--kapi-glow) 70%, var(--gold));
  box-shadow: 0 0 50px color-mix(in srgb, var(--kapi-glow) 55%, transparent), inset 0 0 40px rgba(0,0,0,0.6);
  background: linear-gradient(160deg, color-mix(in srgb, var(--kapi-1) 30%, #0a0820), #0a0820);
  overflow: hidden;
}
.kapi-isik {
  position: absolute; left: 50%; top: 50%; width: 70%; height: 70%; transform: translate(-50%,-50%) scale(0.2);
  border-radius: 50%; background: radial-gradient(circle, #fff7e0, var(--kapi-glow) 40%, transparent 70%);
  opacity: 0; z-index: 1;
}
.kapi-portal.aciliyor .kapi-isik { animation: kapiIsik 1.5s ease forwards; }
@keyframes kapiIsik { 0% { opacity: 0; transform: translate(-50%,-50%) scale(0.2); } 55% { opacity: 1; } 100% { opacity: 0.9; transform: translate(-50%,-50%) scale(2.4); } }

.kapi-kanat {
  position: absolute; top: 0; width: 50%; height: 100%; z-index: 2; backface-visibility: hidden;
  background:
    repeating-linear-gradient(0deg, transparent 0 26px, rgba(0,0,0,0.18) 26px 28px),
    linear-gradient(160deg, color-mix(in srgb, var(--kapi-1) 55%, #1a1230), #120c26);
  transition: transform 1.4s cubic-bezier(.6,.05,.2,1), opacity 1.4s ease;
}
.kapi-kanat.sol { left: 0; transform-origin: left center; border-right: 1.5px solid color-mix(in srgb, var(--gold) 70%, transparent); border-radius: 140px 0 0 26px; }
.kapi-kanat.sag { right: 0; transform-origin: right center; border-left: 1.5px solid color-mix(in srgb, var(--gold) 70%, transparent); border-radius: 0 140px 26px 0; }
.kanat-susleme { position: absolute; top: 26%; width: 26px; height: 26px; border-radius: 50%; border: 1.5px solid color-mix(in srgb, var(--gold) 65%, transparent); box-shadow: 0 0 10px color-mix(in srgb, var(--kapi-glow) 50%, transparent); }
.kapi-kanat.sol .kanat-susleme { right: 14px; }
.kapi-kanat.sag .kanat-susleme { left: 14px; }
.kapi-portal.aciliyor .kapi-kanat.sol { transform: rotateY(-108deg); opacity: 0.85; }
.kapi-portal.aciliyor .kapi-kanat.sag { transform: rotateY(108deg); opacity: 0.85; }

.kapi-sembol { position: absolute; left: 50%; top: 30%; transform: translateX(-50%); z-index: 3; font-size: 2.6rem; filter: drop-shadow(0 0 16px var(--kapi-glow)); transition: opacity 0.6s ease; animation: kapiSembol 4s ease-in-out infinite; }
.kapi-portal.aciliyor .kapi-sembol { opacity: 0; }
@keyframes kapiSembol { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(-6px); } }

.kapi-soru { font-family: var(--font-baslik); font-style: italic; color: var(--metin); font-size: 1.22rem; line-height: 1.5; margin: 0 auto var(--sp-4); max-width: 320px; text-shadow: 0 2px 16px rgba(0,0,0,0.6); }
.kapi-ac-btn { font-size: 1.02rem; padding: 0.7rem 1.7rem; background: linear-gradient(135deg, var(--gold), var(--kapi-glow)); color: #1a1230; font-weight: 600; border: none; animation: kapiBtn 2.6s ease-in-out infinite; }
@keyframes kapiBtn { 0%,100% { box-shadow: 0 0 18px color-mix(in srgb, var(--gold) 55%, transparent); } 50% { box-shadow: 0 0 34px color-mix(in srgb, var(--kapi-glow) 70%, transparent); } }

/* ---- açılan içerik ---- */
.kapi-icerik { opacity: 0; transform: translateY(14px); transition: opacity 0.9s ease, transform 0.9s ease; }
.kapi-icerik.gor { opacity: 1; transform: none; }
.kapi-icerik[hidden] { display: none; }
.ki-mesaj { font-family: var(--font-baslik); font-style: italic; font-size: 1.35rem; line-height: 1.5; color: var(--gold-soft); text-shadow: 0 2px 20px color-mix(in srgb, var(--kapi-glow) 50%, transparent); margin: 0 0 var(--sp-4); }
.ki-enerji { display: inline-flex; flex-direction: column; gap: 0.1rem; padding: 0.7rem 1.4rem; border-radius: 16px; background: color-mix(in srgb, var(--kapi-glow) 12%, transparent); border: 1px solid color-mix(in srgb, var(--kapi-glow) 35%, transparent); margin-bottom: var(--sp-3); }
.ki-en-yuzde { font-family: var(--font-baslik); font-size: 1.6rem; color: var(--gold-soft); }
.ki-en-ad { font-size: 0.8rem; color: var(--metin-soft); }
.ki-sat { margin: var(--sp-2) auto; max-width: 340px; }
.ki-et { display: block; font-size: 0.64rem; text-transform: uppercase; letter-spacing: 1.5px; color: var(--gold); margin-bottom: 0.2rem; }
.ki-sat p { margin: 0; color: var(--metin-soft); }
.ki-olumlama { font-family: var(--font-baslik); font-style: italic; color: var(--metin); margin: var(--sp-3) auto var(--sp-4); max-width: 340px; }
.kapi-gir { margin-bottom: var(--sp-3); }
.kapi-gecmis-det { max-width: 360px; margin: 0 auto; text-align: left; }
.kg-sat { display: flex; gap: 0.6rem; padding: 0.4rem 0; border-bottom: 1px solid rgba(179,140,255,0.1); font-size: 0.85rem; }
.kg-tarih { flex: 0 0 auto; color: var(--gold); min-width: 52px; }
.kg-mesaj { color: var(--metin-soft); }

@media (max-width: 480px) {
  .kapi-portal { width: min(76vw, 250px); }
  .ki-mesaj { font-size: 1.18rem; }
  .kapi-soru { font-size: 1.08rem; }
}

/* ============================================================
   Günün Görevleri 🌿🌙🧠 — 3 kategori
   ============================================================ */
.card-gorevler { position: relative; overflow: hidden; }
.gorev-progress { display: flex; align-items: center; gap: 0.7rem; margin: var(--sp-3) 0; }
.gp-yuva { flex: 1; height: 8px; border-radius: 99px; background: rgba(255,255,255,0.08); overflow: hidden; }
.gp-yuva span { display: block; height: 100%; width: 0; border-radius: 99px; background: linear-gradient(90deg, var(--basari), var(--accent) 55%, var(--gold)); box-shadow: 0 0 12px rgba(233,196,106,0.5); transition: width 0.6s cubic-bezier(.21,.61,.35,1); }
.gp-yuzde { font-family: var(--font-baslik); color: var(--gold-soft); font-size: 0.95rem; min-width: 42px; text-align: right; }

.gorev-kartlar { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 0.7rem; }
.gorev-kart {
  --renk: var(--accent);
  position: relative; display: flex; flex-direction: column; gap: 0.5rem;
  background: color-mix(in srgb, var(--renk) 8%, var(--card-bg-soft));
  border: 1px solid color-mix(in srgb, var(--renk) 30%, transparent);
  border-radius: var(--radius-sm); padding: 0.9rem 0.9rem 1rem;
  transition: border-color var(--gecis), box-shadow var(--gecis), transform var(--gecis);
}
.g-fiziksel { --renk: #6fe0a8; }
.g-ruhsal   { --renk: #8b9cff; }
.g-zihinsel { --renk: #e9c46a; }
.gorev-kart:hover { transform: translateY(-2px); border-color: color-mix(in srgb, var(--renk) 55%, transparent); }
.gk-bas { display: flex; align-items: center; gap: 0.4rem; }
.gk-ikon { font-size: 1.2rem; filter: drop-shadow(0 0 8px color-mix(in srgb, var(--renk) 60%, transparent)); }
.gk-ad { font-family: var(--font-baslik); font-size: 0.95rem; color: color-mix(in srgb, var(--renk) 70%, var(--metin)); }
.gk-gorev { margin: 0; flex: 1; font-size: 0.92rem; color: var(--metin-soft); line-height: 1.45; }
.gk-check {
  align-self: flex-end; width: 34px; height: 34px; border-radius: 50%;
  border: 1.5px solid color-mix(in srgb, var(--renk) 55%, transparent); background: transparent;
  color: transparent; cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all 0.25s; padding: 0;
}
.gk-check svg { width: 18px; height: 18px; }
.gorev-kart.tamam { border-color: var(--renk); box-shadow: 0 0 18px color-mix(in srgb, var(--renk) 35%, transparent); }
.gorev-kart.tamam .gk-gorev { opacity: 0.6; text-decoration: line-through; }
.gorev-kart.tamam .gk-check { background: var(--renk); color: #14112c; border-color: var(--renk); box-shadow: 0 0 16px color-mix(in srgb, var(--renk) 70%, transparent); }
.gorev-kart.glow { animation: gorevGlow 0.7s ease; }
@keyframes gorevGlow { 0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--renk) 60%, transparent); } 50% { box-shadow: 0 0 26px 4px color-mix(in srgb, var(--renk) 55%, transparent); transform: translateY(-3px); } 100% { box-shadow: 0 0 18px color-mix(in srgb, var(--renk) 35%, transparent); } }
.gorev-kart.tamam .gk-check svg { animation: gorevCek 0.4s ease; }
@keyframes gorevCek { 0% { transform: scale(0.3); opacity: 0; } 60% { transform: scale(1.25); } 100% { transform: scale(1); opacity: 1; } }

/* tüm görevler bitince kutlama */
.gorev-kutlama {
  position: absolute; inset: 0; z-index: 5; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.4rem;
  background: radial-gradient(circle at 50% 45%, rgba(124,58,237,0.35), rgba(12,10,28,0.92) 70%);
  backdrop-filter: blur(3px); opacity: 0; transition: opacity 0.6s ease; text-align: center; padding: 1rem;
}
.gorev-kutlama.gor { opacity: 1; }
.gorev-kutlama[hidden] { display: none; }
.gkut-ikon { font-size: 2.6rem; animation: gkutIkon 1.8s ease-in-out infinite; filter: drop-shadow(0 0 16px var(--gold)); }
@keyframes gkutIkon { 0%,100% { transform: scale(1) rotate(-4deg); } 50% { transform: scale(1.15) rotate(4deg); } }
.gkut-mesaj { font-family: var(--font-baslik); font-style: italic; font-size: 1.2rem; color: var(--gold-soft); text-shadow: 0 2px 16px rgba(0,0,0,0.6); margin: 0; max-width: 280px; }
.gkut-yildizlar { position: absolute; inset: 0; pointer-events: none; }
.gkut-yildizlar span { position: absolute; width: 5px; height: 5px; border-radius: 50%; background: radial-gradient(circle, #fff7e0, var(--gold)); box-shadow: 0 0 8px 2px rgba(233,196,106,0.6); opacity: 0; animation: gkutYildiz 1.6s ease-out forwards; }
@keyframes gkutYildiz { 0% { opacity: 0; transform: translateY(10px) scale(0.4); } 40% { opacity: 1; } 100% { opacity: 0; transform: translateY(-26px) scale(1.3); } }

/* ============================================================
   Haftalık Kendini Değerlendirme 📊 — analiz ekranı
   ============================================================ */
.hafta-overlay {
  position: fixed; inset: 0; z-index: 185; overflow-y: auto; padding: 1.5rem 1.2rem 3rem;
  background: radial-gradient(900px 700px at 50% 6%, #241a52 0%, transparent 60%), linear-gradient(170deg, #0a0820, #120b2e 60%, #0f0a24);
  opacity: 0; transition: opacity 0.6s ease;
}
.hafta-overlay.gor { opacity: 1; }
.hafta-overlay[hidden] { display: none; }
.hafta-yildizlar { position: fixed; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.hafta-yildizlar span { position: absolute; width: 4px; height: 4px; border-radius: 50%; background: radial-gradient(circle, #fff4d6, rgba(179,140,255,0.5)); box-shadow: 0 0 8px 2px rgba(179,140,255,0.4); opacity: 0; animation: tkYildiz 7s ease-in-out infinite; }
.hafta-yildizlar span:nth-child(1){left:10%;top:16%} .hafta-yildizlar span:nth-child(2){left:26%;top:62%;animation-delay:1.1s} .hafta-yildizlar span:nth-child(3){left:44%;top:22%;animation-delay:2.3s} .hafta-yildizlar span:nth-child(4){left:62%;top:70%;animation-delay:.6s} .hafta-yildizlar span:nth-child(5){left:80%;top:18%;animation-delay:3s} .hafta-yildizlar span:nth-child(6){left:88%;top:52%;animation-delay:1.7s} .hafta-yildizlar span:nth-child(7){left:16%;top:84%;animation-delay:2.6s} .hafta-yildizlar span:nth-child(8){left:70%;top:40%;animation-delay:4s}
.hafta-ic { position: relative; z-index: 1; max-width: 560px; margin: 0 auto; }
.hafta-baslik { font-family: var(--font-baslik); color: var(--gold-soft); font-size: 1.5rem; text-align: center; margin: 0.2rem 0 0.2rem; }
.hafta-tarih { text-align: center; color: var(--metin-faint); font-size: 0.85rem; margin: 0 0 var(--sp-3); }

.hafta-rozet { display: flex; align-items: center; gap: 0.6rem; justify-content: center; background: rgba(233,196,106,0.1); border: 1px solid rgba(233,196,106,0.3); border-radius: 999px; padding: 0.6rem 1.1rem; margin: 0 auto var(--sp-4); max-width: 90%; box-shadow: var(--glow-gold); animation: hrPulse 3s ease-in-out infinite; }
@keyframes hrPulse { 0%,100% { box-shadow: 0 0 16px rgba(233,196,106,0.25); } 50% { box-shadow: 0 0 30px rgba(233,196,106,0.45); } }
.hr-ikon { font-size: 1.4rem; }
.hr-metin { font-family: var(--font-baslik); font-style: italic; color: var(--gold-soft); }

.hafta-kategoriler { display: flex; flex-direction: column; gap: 0.8rem; }
.hk-kart { --renk: var(--accent); background: var(--card-bg); backdrop-filter: blur(var(--blur)); border: 1px solid color-mix(in srgb, var(--renk) 28%, transparent); border-radius: var(--radius-sm); padding: 1rem 1.1rem; box-shadow: var(--shadow); animation: hkFade 0.6s ease both; }
@keyframes hkFade { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
.h-fiziksel { --renk: #6fe0a8; } .h-ruhsal { --renk: #8b9cff; } .h-zihinsel { --renk: #e9c46a; }
.hk-bas { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.6rem; }
.hk-ikon { font-size: 1.3rem; filter: drop-shadow(0 0 8px color-mix(in srgb, var(--renk) 60%, transparent)); }
.hk-ad { font-family: var(--font-baslik); color: var(--metin); flex: 1; }
.hk-yuzde { font-family: var(--font-baslik); font-size: 1.2rem; color: color-mix(in srgb, var(--renk) 75%, var(--metin)); }
.hk-yuva { height: 10px; border-radius: 99px; background: rgba(255,255,255,0.07); overflow: hidden; }
.hk-bar { display: block; height: 100%; width: 0; border-radius: 99px; background: linear-gradient(90deg, color-mix(in srgb, var(--renk) 60%, #fff2), var(--renk)); box-shadow: 0 0 14px color-mix(in srgb, var(--renk) 70%, transparent); transition: width 1.1s cubic-bezier(.21,.61,.35,1); animation: hkBarGlow 2.6s ease-in-out infinite; }
@keyframes hkBarGlow { 0%,100% { filter: brightness(1); } 50% { filter: brightness(1.2); } }
.hk-yorum { margin: 0.7rem 0 0.5rem; color: var(--metin-soft); font-size: 0.92rem; line-height: 1.5; }
.hk-oneri { font-size: 0.86rem; color: var(--metin-soft); background: color-mix(in srgb, var(--renk) 8%, transparent); border-left: 2px solid var(--renk); border-radius: 0 10px 10px 0; padding: 0.5rem 0.7rem; }
.hk-et { display: block; font-size: 0.62rem; text-transform: uppercase; letter-spacing: 1px; color: var(--renk); margin-bottom: 0.15rem; }

.hafta-ozet { display: flex; flex-direction: column; gap: 0.5rem; margin: var(--sp-4) 0; }
.ho-sat { display: flex; justify-content: space-between; align-items: center; gap: 0.6rem; background: var(--card-bg-soft); border-radius: 12px; padding: 0.6rem 0.9rem; font-size: 0.9rem; }
.ho-guclu { border: 1px solid rgba(111,224,168,0.3); }
.ho-zayif { border: 1px solid rgba(255,122,156,0.3); }
.ho-et { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 1px; color: var(--metin-faint); }

.hafta-graf-baslik { font-family: var(--font-baslik); color: var(--gold-soft); font-size: 1rem; text-align: center; margin: var(--sp-4) 0 var(--sp-2); }
.hafta-grafik { display: flex; align-items: flex-end; justify-content: space-between; gap: 0.3rem; height: 130px; padding: 0 0.2rem; }
.hg-bar { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 0.25rem; height: 100%; justify-content: flex-end; }
.hg-deg { font-size: 0.68rem; color: var(--metin-faint); }
.hg-yuva { width: 100%; max-width: 26px; height: 88px; background: rgba(255,255,255,0.05); border-radius: 8px; display: flex; align-items: flex-end; overflow: hidden; }
.hg-dolu { width: 100%; height: var(--h); border-radius: 8px; background: linear-gradient(180deg, var(--gold-soft), var(--accent)); transform-origin: bottom; animation: hgGrow 0.9s ease both; }
@keyframes hgGrow { from { transform: scaleY(0); } to { transform: scaleY(1); } }
.hg-bar.bugun .hg-dolu { background: linear-gradient(180deg, #fff4d6, var(--gold)); box-shadow: 0 0 12px rgba(233,196,106,0.6); }
.hg-bar.bugun .hg-ad { color: var(--gold-soft); }
.hg-ad { font-size: 0.66rem; color: var(--metin-faint); text-transform: capitalize; }

/* ============================================================
   Hesap & Bulut Senkron ☁️
   ============================================================ */
.card-hesap h2 { color: var(--gold-soft); }
.hesap-form { display: flex; flex-direction: column; gap: 0.5rem; margin-top: var(--sp-2); }
.hesap-form[hidden] { display: none; }
.hesap-form input { width: 100%; background: rgba(255,255,255,0.05); border: 1px solid rgba(179,140,255,0.22); color: var(--metin); border-radius: 11px; padding: 0.6rem 0.8rem; font-family: inherit; font-size: 0.95rem; }
.hesap-form input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.hesap-btnlar { display: flex; gap: 0.5rem; }
.hesap-btnlar .btn { flex: 1; }
.hesap-girisli { display: flex; flex-direction: column; gap: 0.5rem; align-items: flex-start; }
.hesap-rozet { display: inline-block; font-size: 0.74rem; color: #14112c; background: linear-gradient(120deg, var(--basari), #9be8c4); border-radius: 999px; padding: 0.15rem 0.6rem; }
#hesap-durum code { background: rgba(255,255,255,0.06); padding: 0.1rem 0.35rem; border-radius: 6px; font-size: 0.85em; color: var(--gold-soft); }
.hesap-rozet.offline { background: linear-gradient(120deg, var(--uyari), #ffb3c5); }
.hesap-link { background: none; border: none; color: var(--accent); text-decoration: underline; cursor: pointer; font-size: 0.8rem; padding: 0.25rem 0 0; font-family: inherit; }
.hesap-link:hover { color: var(--gold-soft); }
.hesap-girisli input { width: 100%; background: rgba(255,255,255,0.05); border: 1px solid rgba(179,140,255,0.22); color: var(--metin); border-radius: 11px; padding: 0.6rem 0.8rem; font-family: inherit; font-size: 0.95rem; }
.hesap-girisli input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }

