/* ReactBits-inspired Effects for Sallis Digital */

/* 1. BlurText Hero Effect */
.sd-blur-word {
  display: inline-block;
  filter: blur(10px);
  opacity: 0;
  transform: translateY(-20px);
  transition: filter 0.5s ease, opacity 0.5s ease, transform 0.5s ease;
}
.sd-blur-word.sd-blur-visible {
  filter: blur(0);
  opacity: 1;
  transform: translateY(0);
}

/* 2. Star Border Buttons */
.sd-star-btn {
  position: relative;
  overflow: hidden;
}
.sd-star-btn::before,
.sd-star-btn::after {
  content: '';
  position: absolute;
  width: 300%;
  height: 50%;
  opacity: 0.7;
  border-radius: 50%;
  background: radial-gradient(circle, #fff, transparent 10%);
  pointer-events: none;
}
.sd-star-btn::before {
  top: -10px;
  left: -250%;
  animation: sd-star-top 6s linear infinite alternate;
}
.sd-star-btn::after {
  bottom: -11px;
  right: -250%;
  animation: sd-star-bottom 6s linear infinite alternate;
}
@keyframes sd-star-top {
  0% { transform: translate(0%, 0%); opacity: 1; }
  100% { transform: translate(100%, 0%); opacity: 0; }
}
@keyframes sd-star-bottom {
  0% { transform: translate(0%, 0%); opacity: 1; }
  100% { transform: translate(-100%, 0%); opacity: 0; }
}

/* 3. Click Spark - canvas handled by JS */

/* 4. Stagger Reveal for Section Titles */
.sd-stagger-word {
  display: inline-block;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.sd-stagger-word.sd-stagger-visible {
  opacity: 1;
  transform: translateY(0);
}

/* 5. Animated Gradient Border on Cards */
@property --sd-card-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
.sd-card {
  position: relative;
}
.sd-card::before {
  content: '';
  position: absolute;
  inset: -1px;
  background: conic-gradient(from var(--sd-card-angle, 0deg), transparent 70%, #000 100%);
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.4s;
  z-index: -1;
  pointer-events: none;
}
.sd-card:hover::before {
  opacity: 1;
  animation: sd-card-rotate 3s linear infinite;
}
@keyframes sd-card-rotate {
  to { --sd-card-angle: 360deg; }
}

/* Mobile: disable heavy effects */
@media (hover: none) and (pointer: coarse) {
  .sd-star-btn::before,
  .sd-star-btn::after {
    display: none;
  }
  .sd-card::before {
    display: none;
  }
}

/* Ensure blur-text words are white on dark hero */
.sd-hero-fullscreen .sd-blur-word {
  color: #fff !important;
}
.sd-hero-fullscreen .sd-blur-word.sd-blur-visible {
  color: #fff !important;
  filter: blur(0) !important;
  opacity: 1 !important;
}

/* Preserve cyan accent inside blur words */
.sd-hero-fullscreen .sd-blur-word .sd-hero-cyan,
.sd-hero-fullscreen .sd-blur-word.sd-blur-visible .sd-hero-cyan {
  color: #00e0ff !important;
}
