/* JenniNexus Landing Page - Custom Styles */
/* Based on JenniNexus Unified Theme System */

/* ===================================
   Google Fonts Import
   =================================== */
@import url('https://fonts.googleapis.com/css2?family=Parisienne&family=Montserrat:wght@400;600;700;900&display=swap');

/* ===================================
   CSS Variables - Light Theme
   =================================== */
:root,
:root[data-bs-theme="light"] {
  /* JenniNexus Brand Colors */
  --jenni-primary: #FF2E88;
  --jenni-secondary: #A563D1;
  --jenni-accent: #FF6EC4;
  --jenni-success: #00D4AA;
  --jenni-warning: #FFB020;
  --jenni-error: #FF4757;
  --jenni-info: #5352ED;
  
  /* Core Theme Colors */
  --primary: #6750A4;
  --primary-hover: #553D8F;
  --primary-active: #462F7A;
  --primary-rgb: 103, 80, 164;
  
  --secondary: #E91E63;
  --secondary-hover: #D81B60;
  --secondary-active: #C2185B;
  --secondary-rgb: 233, 30, 99;
  
  --accent: #F06292;
  --accent-hover: #EC407A;
  --accent-active: #E91E63;
  --accent-rgb: 240, 98, 146;
  
  /* Functional Colors */
  --success: #00D4AA;
  --warning: #FFB020;
  --error: #FF4757;
  --info: #5352ED;
  
  /* Background System */
  --background: #FFFFFF;
  --background-secondary: #F8F9FA;
  --background-tertiary: #F1F3F4;
  --background-elevated: #FFFFFF;
  --background-rgb: 255, 255, 255;
  
  /* Surface System */
  --surface: #FFFFFF;
  --surface-secondary: #F8F9FA;
  --surface-tertiary: #F1F3F4;
  --surface-elevated: #FFFFFF;
  --surface-hover: #F8F9FA;
  --surface-active: #E9ECEF;
  --surface-rgb: 255, 255, 255;
  
  /* Text System */
  --text: #212529;
  --text-secondary: #495057;
  --text-tertiary: #6C757D;
  --text-muted: #ADB5BD;
  --text-inverse: #FFFFFF;
  --text-rgb: 33, 37, 41;
  
  /* Border System */
  --border: #DEE2E6;
  --border-light: #E9ECEF;
  --border-strong: #ADB5BD;
  --border-primary: rgba(103, 80, 164, 0.3);
  --border-secondary: rgba(233, 30, 99, 0.3);
  --border-rgb: 222, 226, 230;
  
  /* Glass Morphism */
  --glass-bg: rgba(255, 255, 255, 0.8);
  --glass-border: rgba(0, 0, 0, 0.1);
  --glass-backdrop-blur: 8px;
  
  /* Glow Effects */
  --glow: rgba(103, 80, 164, 0.3);
  --glow-primary: 0 0 15px rgba(103, 80, 164, 0.3);
  --glow-secondary: 0 0 15px rgba(233, 30, 99, 0.3);
  --glow-accent: 0 0 15px rgba(240, 98, 146, 0.3);
  
  /* Shadow System */
  --shadow: rgba(0, 0, 0, 0.1);
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 8px 0 rgba(0, 0, 0, 0.12);
  --shadow-lg: 0 8px 16px 0 rgba(0, 0, 0, 0.15);
  --shadow-xl: 0 16px 32px 0 rgba(0, 0, 0, 0.18);
  
  /* Bootstrap overrides */
  --bs-primary: #6750A4;
  --bs-primary-rgb: 103, 80, 164;
  --bs-secondary: #E91E63;
  --bs-secondary-rgb: 233, 30, 99;
  --bs-success: #00D4AA;
  --bs-warning: #FFB020;
  --bs-danger: #FF4757;
  --bs-info: #5352ED;
  --bs-body-color: #212529;
  --bs-body-bg: #FFFFFF;
  --bs-border-color: #DEE2E6;
}

/* ===================================
   CSS Variables - Dark Theme (Default)
   =================================== */
:root[data-bs-theme="dark"] {
  /* JenniNexus Brand Colors - Enhanced for Dark */
  --jenni-primary: #FF2E88;
  --jenni-secondary: #A563D1;
  --jenni-accent: #FF6EC4;
  --jenni-success: #00D4AA;
  --jenni-warning: #FFB020;
  --jenni-error: #FF4757;
  --jenni-info: #5352ED;
  
  /* Core Theme Colors */
  --primary: #FF2E88;
  --primary-hover: #FF4D9F;
  --primary-active: #FF6DB6;
  --primary-rgb: 255, 46, 136;
  
  --secondary: #A563D1;
  --secondary-hover: #B579DA;
  --secondary-active: #C590E3;
  --secondary-rgb: 165, 99, 209;
  
  --accent: #FF6EC4;
  --accent-hover: #FF88D0;
  --accent-active: #FFA2DC;
  --accent-rgb: 255, 110, 196;
  
  /* Functional Colors */
  --success: #00D4AA;
  --warning: #FFB020;
  --error: #FF4757;
  --info: #5352ED;
  
  /* Background System */
  --background: #0D1117;
  --background-secondary: #161B22;
  --background-tertiary: #21262D;
  --background-elevated: #161B22;
  --background-rgb: 13, 17, 23;
  
  /* Surface System */
  --surface: #161B22;
  --surface-secondary: #21262D;
  --surface-tertiary: #30363D;
  --surface-elevated: #21262D;
  --surface-hover: #21262D;
  --surface-active: #30363D;
  --surface-rgb: 22, 27, 34;
  
  /* Text System */
  --text: #F0F6FC;
  --text-secondary: #C9D1D9;
  --text-tertiary: #8B949E;
  --text-muted: #6E7681;
  --text-inverse: #0D1117;
  --text-rgb: 240, 246, 252;
  
  /* Border System */
  --border: #30363D;
  --border-light: #21262D;
  --border-strong: #484F58;
  --border-primary: rgba(255, 46, 136, 0.5);
  --border-secondary: rgba(165, 99, 209, 0.5);
  --border-rgb: 48, 54, 61;
  
  /* Glass Morphism */
  --glass-bg: rgba(22, 27, 34, 0.8);
  --glass-border: rgba(255, 46, 136, 0.3);
  --glass-backdrop-blur: 12px;
  
  /* Glow Effects */
  --glow: rgba(255, 46, 136, 0.4);
  --glow-primary: 0 0 20px rgba(255, 46, 136, 0.4);
  --glow-secondary: 0 0 20px rgba(165, 99, 209, 0.4);
  --glow-accent: 0 0 20px rgba(255, 110, 196, 0.4);
  
  /* Shadow System */
  --shadow: rgba(0, 0, 0, 0.5);
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 8px 0 rgba(0, 0, 0, 0.5);
  --shadow-lg: 0 8px 16px 0 rgba(0, 0, 0, 0.6);
  --shadow-xl: 0 16px 32px 0 rgba(0, 0, 0, 0.7);
  
  /* Bootstrap overrides */
  --bs-primary: #FF2E88;
  --bs-primary-rgb: 255, 46, 136;
  --bs-secondary: #A563D1;
  --bs-secondary-rgb: 165, 99, 209;
  --bs-success: #00D4AA;
  --bs-warning: #FFB020;
  --bs-danger: #FF4757;
  --bs-info: #5352ED;
  --bs-body-color: #F0F6FC;
  --bs-body-bg: #0D1117;
  --bs-border-color: #30363D;
}

/* ===================================
   Global Styles
   =================================== */
body {
  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  background-color: var(--background);
  color: var(--text);
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* ===================================
   Typography - Logo Fonts
   =================================== */
.jenni-text {
  font-family: 'Parisienne', cursive;
  font-weight: 400;
  color: var(--jenni-primary);
  transition: color 0.3s ease, text-shadow 0.3s ease;
}

.jenni-text:hover {
  text-shadow: var(--glow-primary);
}

.nexus-text,
.diy-text {
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  color: var(--jenni-secondary);
  letter-spacing: 0.05em;
  margin-left: 0.25em; /* Space between Jenni and NEXUS */
  text-transform: uppercase; /* Force uppercase display */
  transition: color 0.3s ease, text-shadow 0.3s ease;
}

.nexus-text:hover,
.diy-text:hover {
  text-shadow: var(--glow-secondary);
}

.with-text {
  font-family: 'Parisienne', cursive;
  font-weight: 400;
  color: var(--jenni-primary);
  margin: 0 0.15em; /* Space around "w/" */
}

.logo-brand {
  font-size: 1.5rem;
  text-decoration: none;
}

.logo-brand:hover {
  text-decoration: none;
}

.hero-title .jenni-text {
  font-size: 1em;
}

.hero-title .nexus-text {
  font-size: 1em;
}

/* ===================================
   Navigation
   =================================== */
.navbar {
  backdrop-filter: blur(10px);
  background-color: var(--glass-bg) !important;
  border-bottom: 1px solid var(--border);
}

.navbar-dark .navbar-nav .nav-link {
  color: var(--text-secondary);
  transition: color 0.3s ease;
}

.navbar-dark .navbar-nav .nav-link:hover,
.navbar-dark .navbar-nav .nav-link:focus {
  color: var(--primary);
}

#themeToggle {
  cursor: pointer;
  transition: transform 0.3s ease;
}

#themeToggle:hover {
  transform: rotate(20deg);
}

/* ===================================
   Hero Section
   =================================== */
.hero-section {
  background: linear-gradient(135deg, var(--background) 0%, var(--background) 100%);
  position: relative;
  overflow: hidden;
  padding-top: 80px;
}

.hero-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(circle at 50% 50%, var(--glow) 0%, transparent 70%);
  opacity: 0.5;
  pointer-events: none;
}

.hero-section .container {
  position: relative;
  z-index: 1;
}

.hero-title {
  font-size: clamp(3rem, 8vw, 6rem);
  margin-bottom: 1.5rem;
  animation: fadeInUp 1s ease-out;
}

.social-links {
  margin-top: 2rem;
}

.social-links .btn {
  border-radius: 50%;
  width: 40px;
  height: 40px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}

.social-links .btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 5px 15px var(--shadow);
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ===================================
   Feature Cards
   =================================== */
.feature-card {
  transition: all 0.3s ease;
  background-color: var(--surface);
  border: 1px solid var(--border);
}

.feature-card:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: var(--shadow-xl);
  border-color: var(--jenni-primary);
  background-color: var(--surface-hover);
}

[data-bs-theme="dark"] .feature-card:hover {
  box-shadow: var(--glow-primary);
}

.feature-icon {
  color: var(--jenni-primary);
  transition: all 0.3s ease;
}

.feature-card:hover .feature-icon {
  animation: pulse 1s ease-in-out;
  color: var(--jenni-secondary);
  filter: drop-shadow(var(--glow-primary));
}

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.15);
  }
}

/* ===================================
   Content Cards
   =================================== */
.content-card {
  background-color: var(--bs-body-bg);
  border: 1px solid var(--border);
  transition: all 0.3s ease;
}

.content-card:hover {
  border-color: var(--primary);
  box-shadow: 0 5px 20px var(--shadow);
}

.content-card ul li {
  padding-left: 1.5rem;
  position: relative;
}

.content-card ul li i {
  position: absolute;
  left: 0;
  top: 0.25rem;
}

/* ===================================
   Project Cards
   =================================== */
.project-card {
  transition: all 0.3s ease;
  background-color: var(--bs-body-bg);
  border: 1px solid var(--border);
}

.project-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 25px var(--shadow);
  border-color: var(--accent);
}

.project-icon {
  transition: transform 0.3s ease;
}

.project-card:hover .project-icon {
  transform: scale(1.2);
}

/* ===================================
   Channel Cards
   =================================== */
.channel-card {
  transition: all 0.3s ease;
  background-color: var(--bs-body-bg);
  border: 1px solid var(--border);
}

.channel-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px var(--shadow);
  border-color: #FF0000;
}

.channel-icon {
  transition: transform 0.3s ease;
}

.channel-card:hover .channel-icon {
  transform: scale(1.15);
}

/* ===================================
   Badges
   =================================== */
.badge {
  font-weight: 600;
  padding: 0.5rem 0.75rem;
  border-radius: 0.375rem;
}

/* ===================================
   Buttons
   =================================== */
.btn {
  transition: all 0.3s ease;
  font-weight: 600;
  border-radius: 0.5rem;
  font-family: 'Montserrat', sans-serif;
}

.btn-primary {
  background-color: var(--jenni-primary);
  border-color: var(--jenni-primary);
  color: white;
}

.btn-primary:hover {
  background-color: var(--primary-hover);
  border-color: var(--primary-hover);
  transform: translateY(-2px);
  box-shadow: var(--glow-primary);
}

.btn-primary:active {
  background-color: var(--primary-active);
  border-color: var(--primary-active);
}

.btn-secondary {
  background-color: var(--jenni-secondary);
  border-color: var(--jenni-secondary);
  color: white;
}

.btn-secondary:hover {
  background-color: var(--secondary-hover);
  border-color: var(--secondary-hover);
  transform: translateY(-2px);
  box-shadow: var(--glow-secondary);
}

.btn-outline-secondary {
  border-color: var(--jenni-secondary);
  color: var(--jenni-secondary);
}

.btn-outline-secondary:hover {
  background-color: var(--jenni-secondary);
  border-color: var(--jenni-secondary);
  color: white;
  box-shadow: var(--glow-secondary);
}

.btn-outline-primary {
  border-color: var(--jenni-primary);
  color: var(--jenni-primary);
}

.btn-outline-primary:hover {
  background-color: var(--jenni-primary);
  border-color: var(--jenni-primary);
  color: white;
  box-shadow: var(--glow-primary);
}

.btn-outline-danger:hover {
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(255, 0, 0, 0.3);
}

.btn-outline-success {
  border-color: var(--jenni-success);
  color: var(--jenni-success);
}

.btn-outline-success:hover {
  background-color: var(--jenni-success);
  border-color: var(--jenni-success);
  color: white;
}

.btn-outline-warning {
  border-color: var(--jenni-warning);
  color: var(--jenni-warning);
}

.btn-outline-warning:hover {
  background-color: var(--jenni-warning);
  border-color: var(--jenni-warning);
  color: white;
}

/* ===================================
   Sections
   =================================== */
section {
  padding: 80px 0;
}

.bg-body-secondary {
  background-color: var(--bs-secondary-bg) !important;
}

/* ===================================
   Footer
   =================================== */
footer {
  background-color: #000 !important;
}

footer a:hover {
  color: var(--primary) !important;
}

/* ===================================
   Smooth Scrolling
   =================================== */
html {
  scroll-behavior: smooth;
}

/* ===================================
   Responsive Adjustments
   =================================== */
@media (max-width: 768px) {
  .hero-title {
    font-size: clamp(2rem, 10vw, 4rem);
  }
  
  section {
    padding: 60px 0;
  }
  
  .logo-brand {
    font-size: 1.25rem;
  }
}

/* ===================================
   Dark Mode Specific Adjustments
   =================================== */
[data-bs-theme="dark"] .card {
  background-color: rgba(255, 255, 255, 0.05);
}

[data-bs-theme="dark"] .feature-card,
[data-bs-theme="dark"] .content-card,
[data-bs-theme="dark"] .project-card,
[data-bs-theme="dark"] .channel-card {
  background-color: rgba(255, 255, 255, 0.05);
}

[data-bs-theme="dark"] .feature-card:hover,
[data-bs-theme="dark"] .content-card:hover,
[data-bs-theme="dark"] .project-card:hover,
[data-bs-theme="dark"] .channel-card:hover {
  background-color: rgba(255, 255, 255, 0.08);
}

[data-bs-theme="dark"] .text-secondary {
  color: var(--text-secondary) !important;
}

[data-bs-theme="dark"] .text-muted {
  color: var(--text-muted) !important;
}

/* ===================================
   Accessibility
   =================================== */
.btn:focus,
.nav-link:focus {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

/* ===================================
   Tag System Styles
   =================================== */
.tag-badge {
  transition: all 0.2s ease;
  border: 1px solid var(--primary);
}

.tag-badge:hover {
  transform: scale(1.05);
  box-shadow: 0 2px 8px var(--shadow);
}

.tag-badge.active,
.bg-outline-primary {
  background-color: transparent !important;
  color: var(--primary) !important;
  border: 1px solid var(--primary);
}

.offcanvas {
  backdrop-filter: blur(10px);
}

[data-bs-theme="dark"] .offcanvas {
  background-color: rgba(10, 10, 10, 0.95);
}

.accordion-button:not(.collapsed) {
  background-color: var(--primary);
  color: white;
}

.accordion-button:focus {
  box-shadow: 0 0 0 0.25rem var(--glow);
}

/* ===================================
   Video Grid Styles
   =================================== */
.video-grid {
  display: grid;
  gap: 1rem;
}

.video-card .card {
  transition: all 0.3s ease;
  background-color: var(--bs-body-bg);
}

.video-card:hover .card {
  box-shadow: 0 8px 20px var(--shadow);
  border-color: var(--primary);
}

.ratio {
  position: relative;
  overflow: hidden;
  border-radius: 0.375rem 0.375rem 0 0;
}

/* ===================================
   Content Filter Pills
   =================================== */
.btn[data-filter] {
  transition: all 0.3s ease;
}

.btn[data-filter]:hover {
  transform: translateY(-2px);
}

.btn[data-filter].active {
  box-shadow: 0 4px 12px var(--shadow);
}

/* ===================================
   Community Discord Cards
   =================================== */
.card:hover .bi-controller,
.card:hover .bi-scissors,
.card:hover .bi-music-note-beamed {
  animation: bounce 0.6s ease;
}

@keyframes bounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}

/* ===================================
   Modal Enhancements
   =================================== */
.modal-content {
  border: 1px solid var(--border);
  background-color: var(--bs-body-bg);
}

[data-bs-theme="dark"] .modal-content {
  background-color: rgba(10, 10, 10, 0.98);
}

.modal-header {
  border-bottom-color: var(--border);
}

/* ===================================
   Animations
   =================================== */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ===================================
   Professional Hover Effects
   =================================== */

/* Button Hover Effects */
.btn {
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

.btn::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
}

.btn:hover::before {
  width: 300px;
  height: 300px;
}

.btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(var(--primary-rgb), 0.4);
}

.btn:active {
  transform: translateY(0);
}

/* Card Hover Effects */
.card {
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  border: 1px solid var(--border);
}

.card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 35px rgba(0, 0, 0, 0.15);
  border-color: var(--primary);
}

[data-bs-theme="dark"] .card:hover {
  box-shadow: 0 12px 35px rgba(255, 46, 136, 0.3);
}

/* Card Image Zoom Effect */
.card-img-top,
.card img {
  transition: transform 0.5s ease;
}

.card:hover .card-img-top,
.card:hover img {
  transform: scale(1.05);
}

/* Link Hover Effects */
a:not(.btn):not(.nav-link):not(.navbar-brand):not(.logo-brand) {
  position: relative;
  text-decoration: none;
  transition: color 0.3s ease;
}

a:not(.btn):not(.nav-link):not(.navbar-brand):not(.logo-brand):hover {
  text-decoration: none;
  color: var(--jenni-primary);
}

/* Nav Pills Hover */
.nav-pills .nav-link {
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.nav-pills .nav-link::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 3px;
  background: var(--jenni-primary);
  transform: translateX(-50%);
  transition: width 0.3s ease;
}

.nav-pills .nav-link:hover::before,
.nav-pills .nav-link.active::before {
  width: 80%;
}

.nav-pills .nav-link:hover {
  transform: translateY(-2px);
  background-color: rgba(var(--primary-rgb), 0.1);
}

/* Badge Hover Effects */
.badge {
  transition: all 0.3s ease;
  cursor: pointer;
}

.badge:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* Icon Hover Effects */
.bi,
i {
  transition: all 0.3s ease;
}

a:hover .bi,
button:hover .bi,
a:hover i,
button:hover i {
  transform: scale(1.15);
}

/* Navbar Brand Hover */
.navbar-brand {
  transition: all 0.3s ease;
}

.navbar-brand:hover {
  transform: scale(1.05);
  filter: brightness(1.2);
}

/* Video Thumbnail Hover */
.ratio::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(255, 46, 136, 0.3), rgba(165, 99, 209, 0.3));
  opacity: 0;
  transition: opacity 0.4s ease;
}

.video-card:hover .ratio::after {
  opacity: 1;
}

/* Play Button Effect on Video Cards */
.video-card::before {
  content: '▶';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 3rem;
  color: white;
  opacity: 0;
  transition: all 0.3s ease;
  z-index: 10;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
  pointer-events: none;
}

.video-card:hover::before {
  opacity: 0.9;
  transform: translate(-50%, -50%) scale(1.2);
}

/* Form Input Hover/Focus Effects */
.form-control,
.form-select {
  transition: all 0.3s ease;
  border: 2px solid var(--border);
}

.form-control:hover,
.form-select:hover {
  border-color: var(--jenni-accent);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--jenni-primary);
  box-shadow: 0 0 0 0.25rem rgba(255, 46, 136, 0.25);
}

/* List Group Item Hover */
.list-group-item {
  transition: all 0.3s ease;
}

.list-group-item:hover {
  background-color: rgba(var(--primary-rgb), 0.1);
  transform: translateX(5px);
  border-left: 3px solid var(--jenni-primary);
}

/* Accordion Hover Effects */
.accordion-button {
  transition: all 0.3s ease;
}

.accordion-button:hover {
  background-color: rgba(var(--primary-rgb), 0.1);
}

/* Table Row Hover */
.table-hover tbody tr {
  transition: all 0.2s ease;
}

.table-hover tbody tr:hover {
  background-color: rgba(var(--jenni-primary), 0.08);
  transform: scale(1.01);
}

/* Glow Effect for Primary Elements */
.btn-primary:hover,
.bg-primary:hover {
  box-shadow: 0 0 20px rgba(255, 46, 136, 0.6);
}

/* Smooth Scroll Behavior */
html {
  scroll-behavior: smooth;
}

/* Page Transition Effect */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fade-in-up {
  animation: fadeInUp 0.6s ease-out;
}

/* Pulse Animation for Important Elements */
@keyframes pulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
}

.pulse {
  animation: pulse 2s infinite;
}

/* Shimmer Effect for Loading States */
@keyframes shimmer {
  0% {
    background-position: -1000px 0;
  }
  100% {
    background-position: 1000px 0;
  }
}

.shimmer {
  background: linear-gradient(
    to right,
    var(--background) 0%,
    var(--surface-hover) 50%,
    var(--background) 100%
  );
  background-size: 1000px 100%;
  animation: shimmer 2s infinite;
}
