/**
 * Site geneli cyberpunk imleç — tema [data-theme] ile uyumlu.
 * Aktifleştirme: html.site-cursor-active (cursor.js)
 */

:root {
  --cursor-accent: var(--mario-blue);
  --cursor-accent-soft: color-mix(in srgb, var(--mario-blue) 62%, transparent);
  --cursor-hot: var(--mario-yellow-bright);
  --cursor-danger: var(--mario-red);
  --cursor-ring-size: 28px;
  --cursor-dot-size: 6px;
  --cursor-dot-contrast: #ffffff; /* Always-visible contrast ring */
}

[data-theme="neon"] {
  --cursor-accent: #00eaff;
  --cursor-accent-soft: rgba(0, 234, 255, 0.52);
  --cursor-hot: #ff4dc4;
  --cursor-danger: #ff2d55;
  --cursor-dot-contrast: #ffffff;
}

[data-theme="forest"] {
  --cursor-accent: #4cbf72;
  --cursor-accent-soft: rgba(76, 191, 114, 0.58);
  --cursor-hot: #e8f567;
  --cursor-danger: #c0572a;
  --cursor-dot-contrast: #1a2e1a;
}

[data-theme="ice"] {
  --cursor-accent: #52d4ff;
  --cursor-accent-soft: rgba(82, 212, 255, 0.58);
  --cursor-hot: #ffe066;
  --cursor-danger: #f06060;
  --cursor-dot-contrast: #08203a;
}

[data-theme="fire"] {
  --cursor-accent: #ff9933;
  --cursor-accent-soft: rgba(255, 153, 51, 0.58);
  --cursor-hot: #fff3a0;
  --cursor-danger: #ff4500;
  --cursor-dot-contrast: #1a0500;
}

html.site-cursor-active,
html.site-cursor-active body {
  cursor: none !important;
}

html.site-cursor-active * ,
html.site-cursor-active *::before,
html.site-cursor-active *::after {
  cursor: none !important;
}

#site-cursor {
  position: fixed;
  left: 0;
  top: 0;
  width: 0;
  height: 0;
  overflow: visible;
  z-index: 2147483000;
  pointer-events: none;
  contain: layout style;
  opacity: 0;
  transition: opacity 0.2s ease;
  will-change: transform;
}

#site-cursor.is-visible {
  opacity: 1;
}

/* Gecikmeli HUD — köşeler */
.site-cursor__lag {
  position: absolute;
  left: 0;
  top: 0;
  width: var(--cursor-ring-size);
  height: var(--cursor-ring-size);
  transform: translate(-50%, -50%);
  transition: transform 0.12s ease, opacity 0.15s ease;
}

.site-cursor__corner {
  position: absolute;
  width: 10px;
  height: 10px;
  border-style: solid;
  border-color: var(--cursor-accent);
  opacity: 1;
  box-shadow:
    0 0 4px var(--cursor-accent-soft),
    0 0 10px color-mix(in srgb, var(--cursor-accent) 35%, transparent),
    inset 0 0 2px color-mix(in srgb, var(--cursor-accent) 35%, transparent);
}

.site-cursor__corner--tl {
  left: 0;
  top: 0;
  border-width: 1px 0 0 1px;
}

.site-cursor__corner--tr {
  right: 0;
  top: 0;
  border-width: 1px 1px 0 0;
}

.site-cursor__corner--br {
  right: 0;
  bottom: 0;
  border-width: 0 1px 1px 0;
}

.site-cursor__corner--bl {
  left: 0;
  bottom: 0;
  border-width: 0 0 1px 1px;
}

#site-cursor.is-visible .site-cursor__lag {
  animation: site-cursor-hud-pulse 2.8s ease-in-out infinite;
}

@keyframes site-cursor-hud-pulse {
  0%,
  100% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.22);
  }
}

/* Anında tepki veren katman (çekirdek + orbit + metin çubuğu) */
.site-cursor__immediate {
  position: absolute;
  left: 0;
  top: 0;
  width: 0;
  height: 0;
  overflow: visible;
  transform: translate3d(0, 0, 0);
  will-change: transform;
}

.site-cursor__core {
  position: absolute;
  left: 0;
  top: 0;
  width: var(--cursor-dot-size);
  height: var(--cursor-dot-size);
  margin-left: calc(var(--cursor-dot-size) / -2);
  margin-top: calc(var(--cursor-dot-size) / -2);
  background: var(--cursor-hot);
  border-radius: 50%;
  outline: 2px solid var(--cursor-dot-contrast);
  outline-offset: 1px;
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--cursor-hot) 35%, transparent),
    0 0 8px var(--cursor-hot),
    0 0 18px var(--cursor-accent-soft),
    0 0 28px color-mix(in srgb, var(--cursor-accent) 28%, transparent);
  transition:
    opacity 0.12s ease,
    background 0.15s ease,
    box-shadow 0.15s ease,
    transform 0.15s ease;
}

#site-cursor.is-visible .site-cursor__core {
  animation: site-cursor-core-breathe 1.6s ease-in-out infinite;
}

@keyframes site-cursor-core-breathe {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.15);
  }
}

.site-cursor__orbit {
  position: absolute;
  left: 0;
  top: 0;
  width: calc(var(--cursor-ring-size) + 5px);
  height: calc(var(--cursor-ring-size) + 5px);
  margin-left: calc((var(--cursor-ring-size) + 5px) / -2);
  margin-top: calc((var(--cursor-ring-size) + 5px) / -2);
  border-radius: 50%;
  border: 1px dashed color-mix(in srgb, var(--cursor-accent) 72%, transparent);
  opacity: 0.48;
  transition: opacity 0.15s ease;
}

#site-cursor.is-visible .site-cursor__orbit {
  animation: site-cursor-orbit-spin 10s linear infinite;
}

@keyframes site-cursor-orbit-spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* Metin seçimi modu — dikey çubuk */
.site-cursor__textbar {
  position: absolute;
  left: 0;
  top: 0;
  width: 1px;
  height: 15px;
  margin-left: -0.5px;
  margin-top: -7px;
  background: linear-gradient(
    180deg,
    transparent 0%,
    var(--cursor-accent) 18%,
    var(--cursor-hot) 50%,
    var(--cursor-accent) 82%,
    transparent 100%
  );
  box-shadow:
    0 0 6px var(--cursor-accent-soft),
    0 0 12px color-mix(in srgb, var(--cursor-accent) 40%, transparent);
  opacity: 0;
  transform: scaleY(0.6);
  transition: opacity 0.12s ease, transform 0.12s ease;
  pointer-events: none;
}

.site-cursor__textcaps {
  position: absolute;
  left: 0;
  top: 0;
  width: 10px;
  height: 17px;
  margin-left: -5px;
  margin-top: -8px;
  border-left: 1px solid color-mix(in srgb, var(--cursor-accent) 65%, transparent);
  border-right: 1px solid color-mix(in srgb, var(--cursor-accent) 65%, transparent);
  opacity: 0;
  transition: opacity 0.12s ease;
}

/* Pointer / tıklanabilir — köşeler hafif genişler */
#site-cursor.is-pointer .site-cursor__lag {
  transform: translate(-50%, -50%) scale(1.06);
}

#site-cursor.is-pointer .site-cursor__corner {
  border-color: var(--cursor-hot);
  box-shadow:
    0 0 6px color-mix(in srgb, var(--cursor-hot) 70%, transparent),
    0 0 14px color-mix(in srgb, var(--cursor-accent) 38%, transparent),
    inset 0 0 2px color-mix(in srgb, var(--cursor-hot) 35%, transparent);
}

#site-cursor.is-pointer .site-cursor__core {
  background: var(--cursor-accent);
  outline-color: var(--cursor-dot-contrast);
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--cursor-accent) 35%, transparent),
    0 0 10px var(--cursor-accent),
    0 0 20px var(--cursor-accent-soft),
    0 0 30px color-mix(in srgb, var(--cursor-hot) 22%, transparent);
}

#site-cursor.is-pointer .site-cursor__orbit {
  opacity: 0.62;
  border-color: color-mix(in srgb, var(--cursor-hot) 45%, var(--cursor-accent));
}

/* Metin */
#site-cursor.is-text .site-cursor__lag {
  opacity: 0.35;
  transform: translate(-50%, -50%) scale(0.88);
}

#site-cursor.is-text .site-cursor__orbit {
  opacity: 0.35;
}

#site-cursor.is-text .site-cursor__core {
  opacity: 0;
  transform: rotate(45deg) scale(0);
  animation: none;
}

#site-cursor.is-text .site-cursor__textbar {
  opacity: 1;
  transform: scaleY(1);
}

#site-cursor.is-text .site-cursor__textcaps {
  opacity: 0.85;
}

/* Devre dışı / engelli */
#site-cursor.is-disabled .site-cursor__corner {
  border-color: var(--cursor-danger);
  opacity: 0.88;
  box-shadow:
    0 0 6px color-mix(in srgb, var(--cursor-danger) 62%, transparent),
    0 0 12px color-mix(in srgb, var(--cursor-danger) 28%, transparent);
}

#site-cursor.is-disabled .site-cursor__core {
  background: var(--cursor-danger);
  box-shadow:
    0 0 10px color-mix(in srgb, var(--cursor-danger) 75%, transparent),
    0 0 18px color-mix(in srgb, var(--cursor-danger) 35%, transparent);
}

#site-cursor.is-disabled .site-cursor__orbit {
  opacity: 0.25;
  animation: none;
}
