/* =========================
   friend.tv.it — MAGIC PACK
   ========================= */

:root{
  --magic-pink:#ff5ccf;
  --magic-mint:#76ffd2;
  --magic-sky:#71d7ff;
  --magic-lemon:#ffe66e;
  --magic-lav:#c9b3ff;
}

/* testo “magico” (marker + bordino + shine) */
.magic{
  position: relative;
  display: inline;
  padding: 0 .18em;
  border-radius: .55em;
  border: 1px dashed rgba(0,0,0,.35);
  background:
    linear-gradient(90deg,
      rgba(255,92,207,.20),
      rgba(118,255,210,.20),
      rgba(113,215,255,.20),
      rgba(255,230,110,.20));
  box-shadow: 0 1px 0 rgba(255,255,255,.85) inset;
  transition: transform .12s ease, filter .18s ease;
}

.magic:hover{
  transform: translateY(-1px);
  filter: saturate(1.15);
}

/* underline arcobaleno che “si disegna” */
.magic-underline{
  background-image: linear-gradient(90deg, var(--magic-mint), var(--magic-pink), var(--magic-sky), var(--magic-lemon));
  background-repeat: no-repeat;
  background-size: 0% 2px;
  background-position: 0 100%;
  padding-bottom: 2px;
  transition: background-size .22s ease;
}
.magic-underline:hover{ background-size: 100% 2px; }

/* glitter overlay on hover (solo quando passi) */
.glitter-hover{
  position: relative;
}
.glitter-hover::after{
  content:"";
  position:absolute;
  inset:-6px;
  pointer-events:none;
  opacity:0;
  border-radius: 12px;
  mix-blend-mode: screen;
  background:
    radial-gradient(2px 2px at 12% 35%, rgba(255,255,255,.95), transparent 60%),
    radial-gradient(2px 2px at 40% 20%, rgba(255,255,255,.75), transparent 60%),
    radial-gradient(2px 2px at 65% 60%, rgba(255,255,255,.75), transparent 60%),
    radial-gradient(2px 2px at 85% 30%, rgba(255,255,255,.85), transparent 60%),
    radial-gradient(3px 3px at 22% 80%, rgba(255,230,110,.75), transparent 60%),
    radial-gradient(3px 3px at 78% 78%, rgba(113,215,255,.75), transparent 60%);
  filter: blur(.2px);
  transition: opacity .18s ease;
  animation: twinkle 1.3s linear infinite;
}
.glitter-hover:hover::after{ opacity:.9; }

@keyframes twinkle{
  0%{ transform: translate3d(0,0,0); opacity:.35; }
  50%{ transform: translate3d(0,-1px,0); opacity:.95; }
  100%{ transform: translate3d(0,0,0); opacity:.35; }
}

/* glitch hover soft (testo che “frigge”) */
.glitch-hover{
  transition: filter .15s ease, text-shadow .15s ease;
}
.glitch-hover:hover{
  filter: saturate(1.2) contrast(1.05);
  text-shadow:
    1px 0 0 rgba(255,92,207,.65),
   -1px 0 0 rgba(118,255,210,.55),
    0 1px 0 rgba(113,215,255,.45);
}

/* sparkle particle (JS le crea al volo) */
.sparkle-particle{
  position: fixed;
  width: 10px;
  height: 10px;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  filter: drop-shadow(0 2px 0 rgba(0,0,0,.25));
  animation: sparkle-pop .55s ease-out forwards;
  opacity: .95;
}

.sparkle-particle::before{
  content:"✦";
  display:block;
  font-size: 12px;
  line-height: 10px;
}

@keyframes sparkle-pop{
  0%{ transform: translate(-50%,-50%) scale(.6) rotate(0deg); opacity:0; }
  20%{ opacity:1; }
  100%{ transform: translate(calc(-50% + var(--dx)), calc(-50% + var(--dy))) scale(1.25) rotate(18deg); opacity:0; }
}

/* riduci animazioni per chi lo chiede */
@media (prefers-reduced-motion: reduce){
  .glitter-hover::after,
  .sparkle-particle{ animation:none !important; }
  .magic, .magic-underline, .glitch-hover{ transition:none !important; }
}
