/**
 * getReport - Component Styles
 * Reusable UI Components
 */

/* ========================================
   BUTTONS
   ======================================== */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  line-height: 1;
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
}

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

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btn-primary {
  background: var(--gradient-primary);
  color: var(--background);
  border-color: transparent;
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 24px hsl(187, 100%, 42%, 0.4), 0 8px 16px -4px rgb(0 0 0 / 0.3);
  filter: brightness(1.1);
}

.btn-secondary {
  background-color: transparent;
  color: var(--foreground);
  border-color: var(--border);
}

.btn-secondary:hover {
  background-color: var(--card);
  border-color: var(--muted-foreground);
}

.btn-ghost {
  background-color: transparent;
  color: var(--muted-foreground);
  border-color: transparent;
}

.btn-ghost:hover {
  background-color: var(--muted);
  color: var(--foreground);
}

.btn-icon {
  padding: var(--space-2);
  width: 40px;
  height: 40px;
}

.btn-sm {
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-xs);
}

.btn-lg {
  padding: var(--space-4) var(--space-8);
  font-size: var(--text-base);
}

/* ========================================
   NAVIGATION / HEADER
   ======================================== */

.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: var(--header-height);
  background-color: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-bottom: 1px solid var(--border);
  z-index: var(--z-fixed);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  max-width: var(--container-xl);
  margin: 0 auto;
  padding: 0 var(--space-6);
}

.logo {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--foreground);
  text-decoration: none;
}

.logo-icon {
  width: 32px;
  height: 32px;
  background: var(--gradient-primary);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
}

.nav {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.nav-link {
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--muted-foreground);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: color var(--transition-fast), background-color var(--transition-fast);
}

.nav-link:hover {
  color: var(--foreground);
  background-color: var(--muted);
}

.nav-link.active {
  color: var(--foreground);
}

.nav-dropdown {
  position: relative;
}

.nav-dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 200px;
  background-color: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-2);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all var(--transition-fast);
  box-shadow: var(--shadow-lg);
}

.nav-dropdown:hover .nav-dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-dropdown-item {
  display: block;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--muted-foreground);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

.nav-dropdown-item:hover {
  background-color: var(--muted);
  color: var(--foreground);
}

.header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.mobile-menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 24px;
  height: 24px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}

.mobile-menu-toggle span {
  display: block;
  width: 100%;
  height: 2px;
  background-color: var(--foreground);
  transition: all var(--transition-fast);
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(2) {
  opacity: 0;
}

.mobile-menu-toggle[aria-expanded="true"] span:nth-child(3) {
  transform: rotate(-45deg) translate(5px, -5px);
}

.mobile-nav {
  display: none;
  position: fixed;
  top: var(--header-height);
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--background);
  padding: var(--space-6);
  overflow-y: auto;
  z-index: var(--z-fixed);
}

.mobile-nav.open {
  display: block;
}

.mobile-nav-link {
  display: block;
  padding: var(--space-4);
  font-size: var(--text-lg);
  color: var(--foreground);
  text-decoration: none;
  border-bottom: 1px solid var(--border);
}

@media (max-width: 1024px) {

  .nav,
  .header-actions .btn {
    display: none;
  }

  .mobile-menu-toggle {
    display: flex;
  }
}

/* ========================================
   LANGUAGE SWITCHER
   ======================================== */

.lang-switcher {
  position: relative;
}

.lang-switcher-btn {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background-color: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--muted-foreground);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.lang-switcher-btn:hover {
  background-color: var(--muted);
  color: var(--foreground);
}

.lang-switcher-dropdown {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  width: 200px;
  max-height: 300px;
  overflow-y: auto;
  background-color: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-2);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all var(--transition-fast);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-dropdown);
}

.lang-switcher.open .lang-switcher-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.lang-option {
  display: block;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  background: none;
  border: none;
  text-align: left;
  font-size: var(--text-sm);
  color: var(--muted-foreground);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

.lang-option:hover {
  background-color: var(--muted);
  color: var(--foreground);
}

.lang-option.active {
  background-color: var(--primary-muted);
  color: var(--primary);
}

/* ========================================
   CARDS
   ======================================== */

.card {
  position: relative;
  background: var(--glass-card-bg);
  border: var(--glass-card-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  transition: all var(--transition-base);
  box-shadow: var(--shadow-premium-sm);
  overflow: hidden;
}

/* Inner shine effect */
.card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--glass-shine);
  opacity: 0.6;
  pointer-events: none;
}

.card:hover {
  border-color: hsl(222, 30%, 25%);
  transform: translateY(-4px);
  box-shadow: var(--shadow-premium);
}

.card-glass {
  background-color: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-color: var(--glass-border);
}

.card-header {
  margin-bottom: var(--space-4);
}

.card-title {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  margin-bottom: var(--space-2);
}

.card-description {
  font-size: var(--text-sm);
  color: var(--muted-foreground);
}

.card-content {
  color: var(--muted-foreground);
}

.card-footer {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
}

.feature-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.feature-icon {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--primary-muted);
  border-radius: var(--radius-lg);
  color: var(--primary);
  transition: all var(--transition-base);
  position: relative;
}

/* Gradient ring on hover */
.feature-icon::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: calc(var(--radius-lg) + 2px);
  background: var(--gradient-primary);
  opacity: 0;
  z-index: -1;
  transition: opacity var(--transition-base);
}

.feature-card:hover .feature-icon::before {
  opacity: 1;
}

.feature-card:hover .feature-icon {
  background: var(--gradient-primary);
  color: var(--background);
  transform: scale(1.05);
}

.integration-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4);
}

.integration-logo {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--muted);
  border-radius: var(--radius-md);
}

.integration-name {
  font-weight: var(--font-semibold);
  margin-bottom: var(--space-1);
}

.integration-type {
  font-size: var(--text-sm);
  color: var(--muted-foreground);
}

/* ========================================
   BADGES
   ======================================== */

.badge {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  border-radius: var(--radius-full);
  background-color: var(--muted);
  color: var(--foreground);
}

.badge-primary {
  background-color: var(--primary-muted);
  color: var(--primary);
}

.badge-accent {
  background-color: var(--accent-muted);
  color: var(--accent);
}

.badge-critical {
  background-color: var(--severity-critical-bg);
  color: var(--severity-critical);
}

.badge-high {
  background-color: var(--severity-high-bg);
  color: var(--severity-high);
}

.badge-medium {
  background-color: var(--severity-medium-bg);
  color: var(--severity-medium);
}

.badge-low {
  background-color: var(--severity-low-bg);
  color: var(--severity-low);
}

.badge-info {
  background-color: var(--severity-info-bg);
  color: var(--severity-info);
}

/* ========================================
   ACCORDION / FAQ
   ======================================== */

.accordion {
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.accordion-item {
  border-bottom: 1px solid var(--border);
}

.accordion-item:last-child {
  border-bottom: none;
}

.accordion-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-5) var(--space-6);
  background-color: transparent;
  border: none;
  text-align: left;
  font-size: var(--text-base);
  font-weight: var(--font-medium);
  color: var(--foreground);
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.accordion-trigger:hover {
  background-color: var(--card);
}

.accordion-icon {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--transition-fast);
}

.accordion-item.open .accordion-icon {
  transform: rotate(180deg);
}

.accordion-content {
  display: none;
  padding: 0 var(--space-6) var(--space-5);
  color: var(--muted-foreground);
}

.accordion-item.open .accordion-content {
  display: block;
}

/* ========================================
   PRICING TABLE
   ======================================== */

.pricing-card {
  display: flex;
  flex-direction: column;
  padding: var(--space-8);
  text-align: center;
  position: relative;
}

/* CRITICAL: Disable ALL ::before and ::after on pricing cards except featured badge */
.pricing-card::after {
  content: none !important;
  display: none !important;
}

.pricing-card.featured {
  border-color: var(--primary);
  position: relative;
  overflow: hidden;
}

/* Featured badge ONLY - no animation, no ellipse */
.pricing-card.featured::before {
  content: attr(data-badge);
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--gradient-primary);
  color: var(--background);
  padding: var(--space-1) var(--space-4);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  border-radius: var(--radius-full);
  width: auto;
  height: auto;
  border: none;
  animation: none !important;
  z-index: 10;
}

/* CRITICAL: Completely kill the ::after pseudo-element on featured card */
.pricing-card.featured::after {
  content: none !important;
  display: none !important;
  animation: none !important;
  width: 0 !important;
  height: 0 !important;
  border: none !important;
  background: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}

/* Kill any pseudo-elements on children too */
.pricing-card *::before,
.pricing-card *::after {
  animation: none !important;
}

/* Prevent card base ::before from affecting pricing cards */
.pricing-card.card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--glass-shine);
  opacity: 0.6;
  pointer-events: none;
  animation: none !important;
}

/* Ensure no orbit animations leak into pricing section */
#pricing .urse-visual,
.pricing-grid .urse-visual {
  display: none !important;
}

.pricing-name {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  margin-bottom: var(--space-2);
}

.pricing-price {
  font-family: var(--font-heading);
  font-size: var(--text-5xl);
  font-weight: var(--font-bold);
  margin-bottom: var(--space-2);
}

.pricing-price span {
  font-size: var(--text-lg);
  font-weight: var(--font-normal);
  color: var(--muted-foreground);
}

.pricing-description {
  font-size: var(--text-sm);
  color: var(--muted-foreground);
  margin-bottom: var(--space-6);
}

.pricing-features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-8);
  text-align: left;
}

.pricing-features li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  font-size: var(--text-sm);
  color: var(--muted-foreground);
}

.pricing-features li::before {
  content: "✓";
  color: var(--primary);
  font-weight: var(--font-bold);
}

.pricing-cta {
  margin-top: auto;
}

/* ========================================
   TESTIMONIAL
   ======================================== */

.testimonial {
  background-color: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
}

.testimonial-content {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-6);
  color: var(--foreground);
}

.testimonial-author {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.testimonial-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background-color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-semibold);
  color: var(--primary);
}

.testimonial-name {
  font-weight: var(--font-semibold);
}

.testimonial-title {
  font-size: var(--text-sm);
  color: var(--muted-foreground);
}

/* ========================================
   FOOTER
   ======================================== */

.footer {
  background-color: var(--card);
  border-top: 1px solid var(--border);
  padding: var(--space-16) 0 var(--space-8);
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr repeat(4, 1fr);
  gap: var(--space-8);
  margin-bottom: var(--space-12);
}

@media (max-width: 1024px) {
  .footer-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 480px) {
  .footer-grid {
    grid-template-columns: 1fr;
  }
}

.footer-brand {
  max-width: 280px;
}

.footer-description {
  font-size: var(--text-sm);
  color: var(--muted-foreground);
  margin-top: var(--space-4);
  margin-bottom: var(--space-4);
}

.footer-social {
  display: flex;
  gap: var(--space-3);
}

.footer-social a {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--muted);
  border-radius: var(--radius-md);
  color: var(--muted-foreground);
  transition: all var(--transition-fast);
}

.footer-social a:hover {
  background-color: var(--primary);
  color: var(--background);
}

.footer-column h4 {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  margin-bottom: var(--space-4);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-links li {
  margin-bottom: var(--space-2);
}

.footer-links a {
  font-size: var(--text-sm);
  color: var(--muted-foreground);
  transition: color var(--transition-fast);
}

.footer-links a:hover {
  color: var(--foreground);
}

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-8);
  border-top: 1px solid var(--border);
  font-size: var(--text-sm);
  color: var(--muted-foreground);
}

@media (max-width: 768px) {
  .footer-bottom {
    flex-direction: column;
    gap: var(--space-4);
    text-align: center;
  }
}

.footer-legal {
  display: flex;
  gap: var(--space-6);
}

.footer-legal a {
  color: var(--muted-foreground);
}

.footer-legal a:hover {
  color: var(--foreground);
}

/* ========================================
   LOADING STATES
   ======================================== */

.skeleton {
  background: linear-gradient(90deg, var(--muted) 25%, var(--card) 50%, var(--muted) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--radius-md);
}

.spinner {
  width: 24px;
  height: 24px;
  border: 2px solid var(--border);
  border-top-color: var(--primary);
  border-radius: var(--radius-full);
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

/* ========================================
   PROGRESS BAR
   ======================================== */

.progress {
  width: 100%;
  height: 8px;
  background-color: var(--muted);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.progress-bar {
  height: 100%;
  background: var(--gradient-primary);
  border-radius: var(--radius-full);
  transition: width var(--transition-slow);
}

/* ========================================
   ENHANCED ANIMATIONS
   ======================================== */

/* Floating Animation */
@keyframes float {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-10px);
  }
}

@keyframes floatSlow {

  0%,
  100% {
    transform: translateY(0) rotate(0deg);
  }

  33% {
    transform: translateY(-8px) rotate(1deg);
  }

  66% {
    transform: translateY(-4px) rotate(-1deg);
  }
}

@keyframes floatHorizontal {

  0%,
  100% {
    transform: translateX(0);
  }

  50% {
    transform: translateX(10px);
  }
}

/* Glow Pulse Animation */
@keyframes glowPulse {

  0%,
  100% {
    box-shadow: 0 0 20px rgba(0, 212, 255, 0.3), 0 0 40px rgba(0, 212, 255, 0.1);
  }

  50% {
    box-shadow: 0 0 30px rgba(0, 212, 255, 0.5), 0 0 60px rgba(0, 212, 255, 0.2);
  }
}

@keyframes borderGlow {

  0%,
  100% {
    border-color: var(--primary);
  }

  50% {
    border-color: var(--accent);
  }
}

/* Typing Animation */
@keyframes blink {

  0%,
  50% {
    opacity: 1;
  }

  51%,
  100% {
    opacity: 0;
  }
}

/* Gradient Shift Animation */
@keyframes gradientShift {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

/* Scale Bounce */
@keyframes scaleBounce {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.05);
  }

  100% {
    transform: scale(1);
  }
}

/* Shake Animation */
@keyframes shake {

  0%,
  100% {
    transform: translateX(0);
  }

  10%,
  30%,
  50%,
  70%,
  90% {
    transform: translateX(-2px);
  }

  20%,
  40%,
  60%,
  80% {
    transform: translateX(2px);
  }
}

/* Ripple Effect */
@keyframes ripple {
  0% {
    transform: scale(0);
    opacity: 1;
  }

  100% {
    transform: scale(4);
    opacity: 0;
  }
}

/* Rotate360 */
@keyframes rotate360 {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

/* ========================================
   ANIMATION UTILITY CLASSES
   ======================================== */

.float {
  animation: float 3s ease-in-out infinite;
}

.float-slow {
  animation: floatSlow 6s ease-in-out infinite;
}

.float-h {
  animation: floatHorizontal 4s ease-in-out infinite;
}

.glow-pulse {
  animation: glowPulse 2s ease-in-out infinite;
}

.gradient-animate {
  background-size: 200% 200%;
  animation: gradientShift 3s ease infinite;
}

/* Stagger Animation Delays */
[data-animate-delay="50"] {
  animation-delay: 50ms;
  transition-delay: 50ms;
}

[data-animate-delay="100"] {
  animation-delay: 100ms;
  transition-delay: 100ms;
}

[data-animate-delay="150"] {
  animation-delay: 150ms;
  transition-delay: 150ms;
}

[data-animate-delay="200"] {
  animation-delay: 200ms;
  transition-delay: 200ms;
}

[data-animate-delay="250"] {
  animation-delay: 250ms;
  transition-delay: 250ms;
}

[data-animate-delay="300"] {
  animation-delay: 300ms;
  transition-delay: 300ms;
}

[data-animate-delay="400"] {
  animation-delay: 400ms;
  transition-delay: 400ms;
}

[data-animate-delay="500"] {
  animation-delay: 500ms;
  transition-delay: 500ms;
}

[data-animate-delay="600"] {
  animation-delay: 600ms;
  transition-delay: 600ms;
}

/* ========================================
   ENHANCED HOVER EFFECTS
   ======================================== */

/* Button Hover Enhancements */
.btn-primary {
  position: relative;
  overflow: hidden;
}

.btn-primary::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
}

.btn-primary:hover::before {
  width: 300px;
  height: 300px;
}

.btn-primary:active {
  transform: scale(0.98);
}

/* Card Hover Enhancements */
.card {
  position: relative;
}

.card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, transparent 40%, var(--primary) 50%, transparent 60%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity var(--transition-base);
  pointer-events: none;
}

.card:hover::before {
  opacity: 1;
}

/* Feature Card Hover */
.feature-card {
  position: relative;
  overflow: hidden;
}

.feature-card::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg,
      transparent,
      rgba(0, 212, 255, 0.05),
      transparent);
  transition: left 0.5s;
}

.feature-card:hover::after {
  left: 100%;
}

.feature-card:hover .feature-icon {
  animation: scaleBounce 0.5s ease;
}

/* Integration Card Hover */
.integration-card:hover {
  background: linear-gradient(135deg, var(--card) 0%, var(--muted) 100%);
}

.integration-card:hover .integration-logo {
  transform: scale(1.1) rotate(5deg);
  transition: transform 0.3s ease;
}

/* Nav Link Hover Animation */
.nav-link {
  position: relative;
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 2px;
  background: var(--gradient-primary);
  transition: width 0.3s ease, left 0.3s ease;
}

.nav-link:hover::after,
.nav-link.active::after {
  width: 100%;
  left: 0;
}

/* Template Card Hover */
.template-card {
  cursor: pointer;
}

.template-card:hover {
  background: var(--gradient-subtle);
}

.template-card:hover .template-icon {
  animation: float 1s ease-in-out;
}

/* Pricing Card Hover */
.pricing-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-xl);
}

.pricing-card.featured:hover {
  box-shadow: var(--shadow-glow);
}

/* Testimonial Hover */
.testimonial:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.testimonial:hover .testimonial-avatar {
  background: var(--gradient-primary);
  color: var(--background);
}

/* Footer Social Hover */
.footer-social a:hover {
  transform: translateY(-3px) rotate(5deg);
}

/* ========================================
   SCROLL-TRIGGERED ANIMATIONS
   ======================================== */

[data-animate] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

[data-animate].visible {
  opacity: 1;
  transform: translateY(0);
}

[data-animate="fade-up"] {
  transform: translateY(40px);
}

[data-animate="fade-down"] {
  transform: translateY(-40px);
}

[data-animate="fade-left"] {
  transform: translateX(40px);
}

[data-animate="fade-right"] {
  transform: translateX(-40px);
}

[data-animate="zoom-in"] {
  transform: scale(0.9);
}

[data-animate="zoom-out"] {
  transform: scale(1.1);
}

[data-animate="fade-up"].visible,
[data-animate="fade-down"].visible,
[data-animate="fade-left"].visible,
[data-animate="fade-right"].visible {
  transform: translate(0);
}

[data-animate="zoom-in"].visible,
[data-animate="zoom-out"].visible {
  transform: scale(1);
}

/* ========================================
   SPECIAL EFFECTS
   ======================================== */

/* Gradient Text Animation */
.gradient-text-animate {
  background: linear-gradient(90deg,
      var(--primary),
      var(--accent),
      var(--primary));
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: gradientShift 3s linear infinite;
}

/* Cursor Glow Effect */
.cursor-glow {
  position: fixed;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(0, 212, 255, 0.15) 0%, transparent 70%);
  pointer-events: none;
  z-index: -1;
  transform: translate(-50%, -50%);
  transition: opacity 0.3s;
}

/* Typewriter Effect */
.typewriter {
  overflow: hidden;
  border-right: 2px solid var(--primary);
  white-space: nowrap;
  animation: blink 0.7s step-end infinite;
}

/* Particle Background Effect */
.particle-bg {
  position: relative;
  overflow: hidden;
}

.particle-bg::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  background-image:
    radial-gradient(circle at 20% 80%, rgba(0, 212, 255, 0.1) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(139, 92, 246, 0.1) 0%, transparent 50%);
  animation: floatSlow 10s ease-in-out infinite;
  pointer-events: none;
}

/* Severity Bar Animation */
.severity-bar {
  overflow: hidden;
}

.severity-segment {
  transition: width 0.8s ease;
}

.severity-segment:hover {
  filter: brightness(1.2);
}

/* Score Circle Pulse */
.score-circle {
  animation: glowPulse 3s ease-in-out infinite;
}

/* URSE Score Display */
.urse-score-display {
  position: relative;
}

.urse-score-display::after {
  content: '';
  position: absolute;
  inset: -5px;
  border-radius: 50%;
  background: var(--gradient-primary);
  opacity: 0.2;
  animation: glowPulse 2s ease-in-out infinite;
  z-index: -1;
}

/* ========================================
   REDUCED MOTION
   ======================================== */

@media (prefers-reduced-motion: reduce) {

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  [data-animate] {
    opacity: 1;
    transform: none;
  }
}