/* Common Animations CSS for Revelion */

/* Card Hover Animation */
.card-hover {
  background: var(--panel);
  border: 1px solid var(--panel);
  transition: all 260ms var(--easing);
  position: relative;
  overflow: hidden;
}

.card-hover:hover {
  transform: translateY(-8px);
  border-color: var(--cyan);
  box-shadow: 0 10px 30px rgba(60,192,255,.1);
  border-top-color:var(--accent);
}
.section-glow{position:relative}
.section-glow::before{content:"";position:absolute;top:-150px;left:50%;transform:translateX(-50%);width:60%;height:150px;background:radial-gradient(circle,rgba(60,192,255,.08) 0,rgba(60,192,255,0) 70%);pointer-events:none}

/* Header Shrink */
header { transition: height 0.3s var(--easing), background-color 0.3s var(--easing); }
header.shrink { height: 80px; background-color: rgba(18, 27, 43, 0.8); border-bottom: 1px solid var(--cyan); }
.header-bg{background-image: linear-gradient(to bottom, rgba(10,14,20,.80), rgba(10,14,20,.90)), url('../img/Subtle Background Texture.jpg');}

.card-hover::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--accent);
  transform: translateX(-100%);
  transition: transform 0.3s var(--easing);
}

.card-hover:hover::after {
  transform: translateX(0);
}

/* Section Divider Animation */
.section-divider {
  width: 100%;
  height: 1px;
  position: relative;
  overflow: hidden;
  background-color: rgba(255, 255, 255, 0.1);
}

.section-divider .line {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0%;
  background: var(--cyan);
  transition: width 1.5s var(--easing);
}

.section-divider .spark {
  position: absolute;
  top: 50%;
  left: 0;
  width: 10px;
  height: 10px;
  background: var(--accent);
  border-radius: 50%;
  transform: translateY(-50%) scale(0);
  box-shadow: 0 0 10px var(--accent);
  animation: spark-travel 1.5s var(--easing) forwards;
  animation-play-state: paused;
}

.section-divider.animate .line {
  width: 100%;
}

.section-divider.animate .spark {
  animation-play-state: running;
}

@keyframes spark-travel {
  0% { left: 0; transform: translateY(-50%) scale(0.5); }
  50% { transform: translateY(-50%) scale(1.5); }
  100% { left: 100%; transform: translateY(-50%) scale(0.5); }
}

/* Button Animations */
.btn {
  display: inline-block;
  font-weight: 600;
  padding: .75rem 1.5rem;
  border-radius: 9999px;
  transition: transform .26s var(--easing), box-shadow .26s var(--easing);
  text-align: center;
}

.btn:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 2px;
}

.btn-primary {
  background: var(--grad-primary);
  color: #06111E;
}

.btn-primary:hover {
  box-shadow: var(--ring);
  transform: translateY(-2px);
}

.btn-ghost {
  border: 1px solid var(--cyan);
  color: var(--cyan);
}

.btn-ghost:hover {
  background: var(--cyan);
  color: #06111E;
}

.btn-ghost-red {
  border: 1px solid var(--accent);
  color: var(--accent);
}

.btn-ghost-red:hover {
  background: var(--accent);
  color: var(--text);
}

/* Background Slider */
.bg-slider {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}

.bg-slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.bg-slide.active {
  opacity: 1;
}

/* Card Transition Animation */
.card-transition {
  transition: all 260ms var(--easing);
  position: relative;
  overflow: hidden;
}

.card-transition:hover {
  transform: translateY(-5px);
  border-color: var(--cyan);
  box-shadow: 0 10px 30px rgba(60,192,255,.1);
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
  .bg-slide {
    transition: none !important;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
.space-x-8 > :not([hidden]) ~ :not([hidden]){
  margin-right:10px !important;
  margin-left:10px !important;
}
  .px-6{
    padding-left: 1rem;
    padding-right: 1rem;
  }
}
