/* 
   cursor.css - Hardware-Accelerated Custom Cursor
*/

/* Hide default cursor on desktop */
@media (pointer: fine) {
  body {
    cursor: none;
  }
  
  a, button, input, .portfolio-card {
    cursor: none !important;
  }
}

.custom-cursor-dot,
.custom-cursor-ring {
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: var(--z-cursor);
  transform: translate(-50%, -50%);
  /* Will-change for hardware acceleration */
  will-change: transform;
}

.custom-cursor-dot {
  width: 8px;
  height: 8px;
  background-color: var(--color-gold-bright);
  border-radius: 50%;
  box-shadow: 0 0 10px var(--color-gold);
}

.custom-cursor-ring {
  width: 40px;
  height: 40px;
  border: 1px solid rgba(201, 168, 76, 0.5);
  border-radius: 50%;
  transition: width var(--trans-fast), height var(--trans-fast), background-color var(--trans-fast);
}

/* Hover States */
body.hovering-interactive .custom-cursor-ring {
  width: 60px;
  height: 60px;
  background-color: rgba(201, 168, 76, 0.1);
  border-color: var(--color-gold-bright);
}

body.hovering-play .custom-cursor-ring {
  width: 80px;
  height: 80px;
  border-color: var(--color-cyan);
  background-color: rgba(0, 210, 255, 0.1);
}

body.hovering-play .custom-cursor-dot {
  background-color: var(--color-cyan);
  box-shadow: 0 0 10px var(--color-cyan);
  /* Make dot look like a play button */
  clip-path: polygon(100% 50%, 0 0, 0 100%);
  border-radius: 0;
  width: 12px; height: 12px;
  margin-left: 2px; /* optical center */
}

/* Mystic Compass Navigation */
.mystic-compass {
  position: fixed;
  right: var(--space-md);
  top: 50%;
  transform: translateY(-50%);
  z-index: var(--z-nav);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
  opacity: 0;
  transition: opacity var(--trans-medium);
}

body.scrolled .mystic-compass {
  opacity: 1;
}

.compass-ring {
  width: 40px;
  height: 40px;
  border: 1px solid var(--color-gold-dark);
  border-radius: 50%;
  position: relative;
  /* Rotate based on scroll */
  transition: transform 0.1s linear;
}

.compass-ring::after {
  content: '';
  position: absolute;
  top: 4px; left: 50%;
  width: 2px; height: 10px;
  background: var(--color-gold-bright);
  transform: translateX(-50%);
}

.compass-depth {
  font-family: var(--font-accent);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  color: var(--color-sand);
  writing-mode: vertical-rl;
  text-orientation: mixed;
}

@media (max-width: 768px) {
  .custom-cursor-dot, .custom-cursor-ring, .mystic-compass {
    display: none;
  }
}

/* Enforce hidden custom cursor on all coarse/touch devices and restore pointer-events */
@media (pointer: coarse), (hover: none) {
  .custom-cursor-dot,
  .custom-cursor-ring {
    display: none !important;
  }
}
