:root {
  --cursor-size: 20px;
  --cursor-color: rgba(243, 93, 0, 0.85);
  --cursor-hover-scale: 2;
  --cursor-move-speed: 0s;       /* instant follow */
  --cursor-transition: 0.12s;    /* scaling speed */
}

body:not(.no-custom-cursor) {
  cursor: none;
}

#custom-cursor {
  position: fixed;
  top: 0;
  left: 0;
  width: var(--cursor-size);
  height: var(--cursor-size);
  border-radius: 50%;
  background: var(--cursor-color);
  pointer-events: none;
  transform: translate3d(-50%, -50%, 0);
  transition: 
    width var(--cursor-transition) ease,
    height var(--cursor-transition) ease,
    transform var(--cursor-move-speed) linear; /* instant movement */
  z-index: 9999;
  mix-blend-mode: normal;
}

/* Hover state */
#custom-cursor.hovered {
  transform: translate3d(-50%, -50%, 0) scale(var(--cursor-hover-scale));
  transition: transform var(--cursor-transition) ease; /* smooth scaling */
}

/* Hide on touch devices */
@media (hover: none), (pointer: coarse) {
  body:not(.no-custom-cursor) { cursor: auto; }
  #custom-cursor { display: none !important; }
}

