/* =========================================== */
/* TEMPLATE-VISUAL-EFFECTS-2026-BUNDLE */
/* Generated: 2025-12-12T21:47:52.845Z */
/* Combines 6 CSS files for optimized loading */
/* =========================================== */

/* =========================================== */
/* 1. template/shared/css/magnetic-interactions-2026.css */
/* =========================================== */

/* =========================================== */
/* MAGNETIC INTERACTIONS 2026 */
/* Award-winning cursor-following effects */
/* =========================================== */

:root {
  --magnetic-strength: 0.3;
  --magnetic-distance: 20px;
  --magnetic-transition: 0.3s cubic-bezier(0.23, 1, 0.32, 1);
  --parallax-intensity: 0.5;
}

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

#main-content-section .card {
  position: relative;
  transition: transform var(--magnetic-transition),
              box-shadow var(--magnetic-transition);
  will-change: transform;
}

#main-content-section .card.magnetic {
  cursor: pointer;
}

#main-content-section .card.magnetic:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15),
              0 0 0 1px rgba(99, 102, 241, 0.1);
}

/* Magnetic effect on mouse move */
#main-content-section .card.magnetic.magnetic-active {
  transition: transform 0.1s ease-out,
              box-shadow var(--magnetic-transition);
}

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

#main-content-section .btn,
#main-content-section button:not([type="submit"]):not([type="reset"]),
#main-content-section .badge {
  position: relative;
  transition: transform var(--magnetic-transition),
              box-shadow var(--magnetic-transition);
  will-change: transform;
  cursor: pointer;
}

#main-content-section .btn.magnetic:hover,
#main-content-section button.magnetic:hover,
#main-content-section .badge.magnetic:hover {
  transform: translateY(-2px) scale(1.05);
  box-shadow: 0 8px 16px rgba(99, 102, 241, 0.3);
}

#main-content-section .btn.magnetic.magnetic-active,
#main-content-section button.magnetic.magnetic-active,
#main-content-section .badge.magnetic.magnetic-active {
  transition: transform 0.1s ease-out,
              box-shadow var(--magnetic-transition);
}

/* =========================================== */
/* MAGNETIC LINKS */
/* =========================================== */

#main-content-section a.magnetic {
  position: relative;
  display: inline-block;
  transition: transform var(--magnetic-transition);
  will-change: transform;
}

#main-content-section a.magnetic:hover {
  transform: translateX(4px);
}

#main-content-section a.magnetic.magnetic-active {
  transition: transform 0.1s ease-out;
}

/* =========================================== */
/* PARALLAX SCROLL EFFECTS */
/* =========================================== */

#main-content-section .section.parallax {
  will-change: transform;
}

#main-content-section .section.parallax-slow {
  transition: transform 0.1s ease-out;
}

#main-content-section .section.parallax-fast {
  transition: transform 0.05s ease-out;
}

/* Parallax on scroll */
#main-content-section .parallax-element {
  will-change: transform;
  transition: transform 0.1s ease-out;
}

/* =========================================== */
/* INTERACTIVE ELEMENT ANIMATIONS */
/* =========================================== */

#main-content-section .interactive-element {
  position: relative;
  transition: all var(--magnetic-transition);
  cursor: pointer;
}

#main-content-section .interactive-element::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(99, 102, 241, 0.1);
  transform: translate(-50%, -50%);
  transition: width 0.4s ease, height 0.4s ease, opacity 0.4s ease;
  opacity: 0;
  pointer-events: none;
  z-index: -1;
}

#main-content-section .interactive-element:hover::before {
  width: 300px;
  height: 300px;
  opacity: 1;
}

#main-content-section .interactive-element:hover {
  transform: scale(1.05);
}

/* =========================================== */
/* CURSOR FOLLOW EFFECT */
/* =========================================== */

.magnetic-cursor {
  position: fixed;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(99, 102, 241, 0.3);
  pointer-events: none;
  z-index: 999999;
  transform: translate(-50%, -50%);
  transition: width 0.2s ease, height 0.2s ease, opacity 0.2s ease;
  opacity: 0;
  mix-blend-mode: difference;
}

.magnetic-cursor.active {
  width: 40px;
  height: 40px;
  opacity: 1;
}

.magnetic-cursor.hover {
  width: 60px;
  height: 60px;
  background: rgba(99, 102, 241, 0.2);
}

/* =========================================== */
/* SMOOTH SCROLL ANIMATIONS */
/* =========================================== */

#main-content-section .section {
  scroll-margin-top: 100px; /* Account for fixed navbar */
}

/* Smooth reveal on scroll */
#main-content-section .section.scroll-reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

#main-content-section .section.scroll-reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger children animation */
#main-content-section .stagger-children > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}

#main-content-section .stagger-children.revealed > *:nth-child(1) {
  transition-delay: 0.1s;
}

#main-content-section .stagger-children.revealed > *:nth-child(2) {
  transition-delay: 0.2s;
}

#main-content-section .stagger-children.revealed > *:nth-child(3) {
  transition-delay: 0.3s;
}

#main-content-section .stagger-children.revealed > *:nth-child(4) {
  transition-delay: 0.4s;
}

#main-content-section .stagger-children.revealed > *:nth-child(5) {
  transition-delay: 0.5s;
}

#main-content-section .stagger-children.revealed > * {
  opacity: 1;
  transform: translateY(0);
}

/* =========================================== */
/* RESPONSIVE ADJUSTMENTS */
/* =========================================== */

@media (max-width: 768px) {
  /* Reduce magnetic effects on mobile */
  #main-content-section .card.magnetic:hover {
    transform: translateY(-4px) scale(1.01);
  }
  
  #main-content-section .btn.magnetic:hover,
  #main-content-section button.magnetic:hover {
    transform: translateY(-1px) scale(1.02);
  }
  
  /* Hide custom cursor on mobile */
  .magnetic-cursor {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  #main-content-section .card,
  #main-content-section .btn,
  #main-content-section button,
  #main-content-section a.magnetic,
  #main-content-section .section.scroll-reveal,
  #main-content-section .stagger-children > * {
    transition: none !important;
    transform: none !important;
  }
  
  .magnetic-cursor {
    display: none;
  }
}

/* =========================================== */
/* PERFORMANCE OPTIMIZATIONS */
/* =========================================== */

#main-content-section .card,
#main-content-section .btn,
#main-content-section .interactive-element {
  backface-visibility: hidden;
  perspective: 1000px;
}



/* =========================================== */
/* 2. template/shared/css/content-previews-2026.css */
/* =========================================== */

/* =========================================== */
/* CONTENT PREVIEWS 2026 */
/* Award-winning hover card previews */
/* =========================================== */

:root {
  --preview-transition: 0.4s cubic-bezier(0.23, 1, 0.32, 1);
  --preview-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
  --preview-backdrop: rgba(255, 255, 255, 0.95);
}

/* =========================================== */
/* PREVIEW CARD BASE */
/* =========================================== */

#main-content-section .card.preview-enabled {
  position: relative;
  overflow: visible;
  transition: transform var(--preview-transition),
              box-shadow var(--preview-transition);
}

#main-content-section .card.preview-enabled::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-10px);
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 10px solid var(--preview-backdrop);
  opacity: 0;
  transition: opacity var(--preview-transition),
              transform var(--preview-transition);
  pointer-events: none;
  z-index: 1000;
}

#main-content-section .card.preview-enabled:hover::after {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* =========================================== */
/* PREVIEW PANEL */
/* =========================================== */

.content-preview-panel {
  position: absolute;
  top: calc(100% + 20px);
  left: 50%;
  transform: translateX(-50%) translateY(-20px);
  width: 400px;
  max-width: 90vw;
  background: var(--preview-backdrop);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: 16px;
  padding: 1.5rem;
  box-shadow: var(--preview-shadow),
              0 0 0 1px rgba(0, 0, 0, 0.05);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 1000;
  transition: opacity var(--preview-transition),
              visibility var(--preview-transition),
              transform var(--preview-transition);
}

.content-preview-panel.active {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

.content-preview-panel::before {
  content: '';
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 10px solid var(--preview-backdrop);
}

/* =========================================== */
/* PREVIEW CONTENT */
/* =========================================== */

.preview-header {
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.preview-title {
  font-size: 1.25rem;
  font-weight: 700;
  margin: 0 0 0.5rem 0;
  color: #1a202c;
  line-height: 1.3;
}

.preview-meta {
  font-size: 0.875rem;
  color: #718096;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.preview-meta-item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.preview-body {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: #4a5568;
  margin-bottom: 1rem;
}

.preview-body p {
  margin: 0 0 0.75rem 0;
}

.preview-body p:last-child {
  margin-bottom: 0;
}

.preview-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 1rem;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.preview-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.preview-tag {
  font-size: 0.75rem;
  padding: 0.25rem 0.75rem;
  background: rgba(99, 102, 241, 0.1);
  color: #6366f1;
  border-radius: 12px;
  font-weight: 500;
}

.preview-link {
  font-size: 0.875rem;
  font-weight: 600;
  color: #6366f1;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: color 0.2s ease;
}

.preview-link:hover {
  color: #4f46e5;
}

.preview-link::after {
  content: '→';
  transition: transform 0.2s ease;
}

.preview-link:hover::after {
  transform: translateX(4px);
}

/* =========================================== */
/* PREVIEW IMAGE */
/* =========================================== */

.preview-image {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: 12px;
  margin-bottom: 1rem;
}

/* =========================================== */
/* PREVIEW POSITIONING */
/* =========================================== */

.content-preview-panel.preview-left {
  left: 0;
  transform: translateX(0) translateY(-20px);
}

.content-preview-panel.preview-left.active {
  transform: translateX(0) translateY(0);
}

.content-preview-panel.preview-left::before {
  left: 2rem;
  transform: translateX(0);
}

.content-preview-panel.preview-right {
  left: auto;
  right: 0;
  transform: translateX(0) translateY(-20px);
}

.content-preview-panel.preview-right.active {
  transform: translateX(0) translateY(0);
}

.content-preview-panel.preview-right::before {
  left: auto;
  right: 2rem;
  transform: translateX(0);
}

/* =========================================== */
/* CARD HOVER EFFECTS */
/* =========================================== */

#main-content-section .card.preview-enabled:hover {
  transform: translateY(-8px);
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.15),
              0 0 0 1px rgba(99, 102, 241, 0.1);
  z-index: 999;
}

/* =========================================== */
/* RESPONSIVE ADJUSTMENTS */
/* =========================================== */

@media (max-width: 768px) {
  .content-preview-panel {
    width: calc(100vw - 2rem);
    max-width: none;
    left: 1rem;
    right: 1rem;
    transform: translateX(0) translateY(-20px);
  }
  
  .content-preview-panel.active {
    transform: translateX(0) translateY(0);
  }
  
  .content-preview-panel::before {
    left: 2rem;
    transform: translateX(0);
  }
  
  .preview-image {
    height: 150px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .content-preview-panel,
  #main-content-section .card.preview-enabled,
  #main-content-section .card.preview-enabled::after {
    transition: none;
  }
  
  .content-preview-panel {
    opacity: 0;
    visibility: hidden;
  }
}

/* =========================================== */
/* ACCESSIBILITY */
/* =========================================== */

.content-preview-panel[aria-hidden="true"] {
  display: none;
}

.preview-link:focus-visible {
  outline: 2px solid #6366f1;
  outline-offset: 2px;
  border-radius: 4px;
}



/* =========================================== */
/* 3. template/shared/css/enhanced-scroll-animations-2026.css */
/* =========================================== */

/* =========================================== */
/* ENHANCED SCROLL ANIMATIONS 2026 */
/* Award-winning scroll-triggered effects */
/* =========================================== */

:root {
  --scroll-animation-duration: 0.8s;
  --scroll-animation-easing: cubic-bezier(0.23, 1, 0.32, 1);
  --scroll-reveal-distance: 60px;
  --scroll-parallax-intensity: 0.3;
}

/* =========================================== */
/* SCROLL REVEAL BASE */
/* =========================================== */

#main-content-section .scroll-reveal-element {
  opacity: 0;
  will-change: opacity, transform;
}

/* =========================================== */
/* FADE IN ANIMATIONS */
/* =========================================== */

#main-content-section .fade-in-up {
  opacity: 0;
  transform: translateY(var(--scroll-reveal-distance));
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .fade-in-up.revealed {
  opacity: 1;
  transform: translateY(0);
}

#main-content-section .fade-in-down {
  opacity: 0;
  transform: translateY(calc(-1 * var(--scroll-reveal-distance)));
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .fade-in-down.revealed {
  opacity: 1;
  transform: translateY(0);
}

#main-content-section .fade-in-left {
  opacity: 0;
  transform: translateX(var(--scroll-reveal-distance));
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .fade-in-left.revealed {
  opacity: 1;
  transform: translateX(0);
}

#main-content-section .fade-in-right {
  opacity: 0;
  transform: translateX(calc(-1 * var(--scroll-reveal-distance)));
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .fade-in-right.revealed {
  opacity: 1;
  transform: translateX(0);
}

#main-content-section .fade-in {
  opacity: 0;
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .fade-in.revealed {
  opacity: 1;
}

/* =========================================== */
/* SCALE ANIMATIONS */
/* =========================================== */

#main-content-section .scale-in {
  opacity: 0;
  transform: scale(0.8);
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .scale-in.revealed {
  opacity: 1;
  transform: scale(1);
}

#main-content-section .scale-in-up {
  opacity: 0;
  transform: scale(0.8) translateY(var(--scroll-reveal-distance));
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .scale-in-up.revealed {
  opacity: 1;
  transform: scale(1) translateY(0);
}

/* =========================================== */
/* ROTATE ANIMATIONS */
/* =========================================== */

#main-content-section .rotate-in {
  opacity: 0;
  transform: rotate(-10deg) scale(0.9);
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .rotate-in.revealed {
  opacity: 1;
  transform: rotate(0deg) scale(1);
}

#main-content-section .rotate-in-left {
  opacity: 0;
  transform: rotate(-15deg) translateX(-30px);
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .rotate-in-left.revealed {
  opacity: 1;
  transform: rotate(0deg) translateX(0);
}

#main-content-section .rotate-in-right {
  opacity: 0;
  transform: rotate(15deg) translateX(30px);
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .rotate-in-right.revealed {
  opacity: 1;
  transform: rotate(0deg) translateX(0);
}

/* =========================================== */
/* BLUR ANIMATIONS */
/* =========================================== */

#main-content-section .blur-in {
  opacity: 0;
  filter: blur(20px);
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              filter var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .blur-in.revealed {
  opacity: 1;
  filter: blur(0);
}

#main-content-section .blur-in-up {
  opacity: 0;
  filter: blur(20px);
  transform: translateY(var(--scroll-reveal-distance));
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              filter var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .blur-in-up.revealed {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

/* =========================================== */
/* STAGGER ANIMATIONS */
/* =========================================== */

#main-content-section .stagger-container > * {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity var(--scroll-animation-duration) var(--scroll-animation-easing),
              transform var(--scroll-animation-duration) var(--scroll-animation-easing);
}

#main-content-section .stagger-container.revealed > *:nth-child(1) {
  transition-delay: 0.1s;
}

#main-content-section .stagger-container.revealed > *:nth-child(2) {
  transition-delay: 0.2s;
}

#main-content-section .stagger-container.revealed > *:nth-child(3) {
  transition-delay: 0.3s;
}

#main-content-section .stagger-container.revealed > *:nth-child(4) {
  transition-delay: 0.4s;
}

#main-content-section .stagger-container.revealed > *:nth-child(5) {
  transition-delay: 0.5s;
}

#main-content-section .stagger-container.revealed > *:nth-child(6) {
  transition-delay: 0.6s;
}

#main-content-section .stagger-container.revealed > *:nth-child(7) {
  transition-delay: 0.7s;
}

#main-content-section .stagger-container.revealed > *:nth-child(8) {
  transition-delay: 0.8s;
}

#main-content-section .stagger-container.revealed > * {
  opacity: 1;
  transform: translateY(0);
}

/* =========================================== */
/* PARALLAX DEPTH LAYERS */
/* =========================================== */

#main-content-section .parallax-layer {
  will-change: transform;
}

#main-content-section .parallax-layer-1 {
  transition: transform 0.1s ease-out;
}

#main-content-section .parallax-layer-2 {
  transition: transform 0.15s ease-out;
}

#main-content-section .parallax-layer-3 {
  transition: transform 0.2s ease-out;
}

#main-content-section .parallax-layer-4 {
  transition: transform 0.25s ease-out;
}

/* =========================================== */
/* SCROLL PROGRESS ANIMATIONS */
/* =========================================== */

#main-content-section .progress-reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

#main-content-section .progress-reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Progress-based opacity */
#main-content-section .progress-fade {
  opacity: 0;
  transition: opacity 0.8s ease-out;
}

#main-content-section .progress-fade.revealed {
  opacity: 1;
}

/* =========================================== */
/* INTERSECTION ANIMATIONS */
/* =========================================== */

#main-content-section .intersection-fade {
  opacity: 0;
  transition: opacity 0.6s ease-out;
}

#main-content-section .intersection-fade.intersected {
  opacity: 1;
}

#main-content-section .intersection-slide-up {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

#main-content-section .intersection-slide-up.intersected {
  opacity: 1;
  transform: translateY(0);
}

/* =========================================== */
/* ANIMATION DELAYS */
/* =========================================== */

#main-content-section .animation-delay-1 {
  transition-delay: 0.1s;
}

#main-content-section .animation-delay-2 {
  transition-delay: 0.2s;
}

#main-content-section .animation-delay-3 {
  transition-delay: 0.3s;
}

#main-content-section .animation-delay-4 {
  transition-delay: 0.4s;
}

#main-content-section .animation-delay-5 {
  transition-delay: 0.5s;
}

/* =========================================== */
/* PERFORMANCE OPTIMIZATIONS */
/* =========================================== */

#main-content-section .scroll-reveal-element,
#main-content-section .fade-in-up,
#main-content-section .fade-in-down,
#main-content-section .fade-in-left,
#main-content-section .fade-in-right,
#main-content-section .scale-in,
#main-content-section .rotate-in,
#main-content-section .blur-in {
  backface-visibility: hidden;
  perspective: 1000px;
}

/* =========================================== */
/* RESPONSIVE ADJUSTMENTS */
/* =========================================== */

@media (max-width: 768px) {
  :root {
    --scroll-reveal-distance: 40px;
  }
  
  #main-content-section .stagger-container.revealed > * {
    transition-delay: 0.05s !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  #main-content-section .scroll-reveal-element,
  #main-content-section .fade-in-up,
  #main-content-section .fade-in-down,
  #main-content-section .fade-in-left,
  #main-content-section .fade-in-right,
  #main-content-section .scale-in,
  #main-content-section .rotate-in,
  #main-content-section .blur-in,
  #main-content-section .stagger-container > *,
  #main-content-section .parallax-layer {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
    filter: none !important;
  }
  
  #main-content-section .scroll-reveal-element.revealed,
  #main-content-section .fade-in-up.revealed,
  #main-content-section .fade-in-down.revealed,
  #main-content-section .fade-in-left.revealed,
  #main-content-section .fade-in-right.revealed,
  #main-content-section .scale-in.revealed,
  #main-content-section .rotate-in.revealed,
  #main-content-section .blur-in.revealed {
    opacity: 1;
    transform: none;
    filter: none;
  }
}



/* =========================================== */
/* 4. template/shared/css/gradient-overlays-2026.css */
/* =========================================== */

/* =========================================== */
/* GRADIENT OVERLAYS 2026 */
/* Award-winning subtle gradients for depth */
/* =========================================== */

:root {
  --gradient-opacity: 0.15;
  --gradient-opacity-strong: 0.25;
  --gradient-opacity-subtle: 0.08;
  --gradient-blend-mode: overlay;
}

/* =========================================== */
/* GRADIENT OVERLAY BASE */
/* =========================================== */

#main-content-section .section {
  position: relative;
}

#main-content-section .section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity 0.6s ease;
}

#main-content-section .section.gradient-overlay::before {
  opacity: 1;
}

/* =========================================== */
/* PRIMARY GRADIENT OVERLAYS */
/* =========================================== */

/* Top to bottom gradient */
#main-content-section .section.gradient-top-bottom::before {
  background: linear-gradient(
    to bottom,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 50%,
    rgba(139, 92, 246, var(--gradient-opacity)) 100%
  );
}

/* Bottom to top gradient */
#main-content-section .section.gradient-bottom-top::before {
  background: linear-gradient(
    to top,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 50%,
    rgba(139, 92, 246, var(--gradient-opacity)) 100%
  );
}

/* Left to right gradient */
#main-content-section .section.gradient-left-right::before {
  background: linear-gradient(
    to right,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 50%,
    rgba(139, 92, 246, var(--gradient-opacity)) 100%
  );
}

/* Right to left gradient */
#main-content-section .section.gradient-right-left::before {
  background: linear-gradient(
    to left,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 50%,
    rgba(139, 92, 246, var(--gradient-opacity)) 100%
  );
}

/* =========================================== */
/* DIAGONAL GRADIENTS */
/* =========================================== */

/* Top-left to bottom-right */
#main-content-section .section.gradient-diagonal-tl-br::before {
  background: linear-gradient(
    135deg,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 50%,
    rgba(139, 92, 246, var(--gradient-opacity)) 100%
  );
}

/* Top-right to bottom-left */
#main-content-section .section.gradient-diagonal-tr-bl::before {
  background: linear-gradient(
    225deg,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 50%,
    rgba(139, 92, 246, var(--gradient-opacity)) 100%
  );
}

/* =========================================== */
/* RADIAL GRADIENTS */
/* =========================================== */

/* Radial from center */
#main-content-section .section.gradient-radial-center::before {
  background: radial-gradient(
    circle at center,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 70%
  );
}

/* Radial from top */
#main-content-section .section.gradient-radial-top::before {
  background: radial-gradient(
    ellipse at top,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 70%
  );
}

/* Radial from bottom */
#main-content-section .section.gradient-radial-bottom::before {
  background: radial-gradient(
    ellipse at bottom,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 70%
  );
}

/* =========================================== */
/* CORNER GRADIENTS */
/* =========================================== */

/* Top-left corner */
#main-content-section .section.gradient-corner-tl::before {
  background: radial-gradient(
    circle at top left,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 50%
  );
}

/* Top-right corner */
#main-content-section .section.gradient-corner-tr::before {
  background: radial-gradient(
    circle at top right,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    transparent 50%
  );
}

/* Bottom-left corner */
#main-content-section .section.gradient-corner-bl::before {
  background: radial-gradient(
    circle at bottom left,
    rgba(139, 92, 246, var(--gradient-opacity)) 0%,
    transparent 50%
  );
}

/* Bottom-right corner */
#main-content-section .section.gradient-corner-br::before {
  background: radial-gradient(
    circle at bottom right,
    rgba(139, 92, 246, var(--gradient-opacity)) 0%,
    transparent 50%
  );
}

/* =========================================== */
/* MULTI-COLOR GRADIENTS */
/* =========================================== */

/* Purple to pink */
#main-content-section .section.gradient-purple-pink::before {
  background: linear-gradient(
    135deg,
    rgba(99, 102, 241, var(--gradient-opacity)) 0%,
    rgba(139, 92, 246, var(--gradient-opacity)) 50%,
    rgba(236, 72, 153, var(--gradient-opacity)) 100%
  );
}

/* Blue to purple */
#main-content-section .section.gradient-blue-purple::before {
  background: linear-gradient(
    135deg,
    rgba(59, 130, 246, var(--gradient-opacity)) 0%,
    rgba(99, 102, 241, var(--gradient-opacity)) 50%,
    rgba(139, 92, 246, var(--gradient-opacity)) 100%
  );
}

/* Warm gradient */
#main-content-section .section.gradient-warm::before {
  background: linear-gradient(
    135deg,
    rgba(251, 146, 60, var(--gradient-opacity)) 0%,
    rgba(236, 72, 153, var(--gradient-opacity)) 50%,
    rgba(139, 92, 246, var(--gradient-opacity)) 100%
  );
}

/* Cool gradient */
#main-content-section .section.gradient-cool::before {
  background: linear-gradient(
    135deg,
    rgba(59, 130, 246, var(--gradient-opacity)) 0%,
    rgba(99, 102, 241, var(--gradient-opacity)) 50%,
    rgba(14, 165, 233, var(--gradient-opacity)) 100%
  );
}

/* =========================================== */
/* OPACITY VARIANTS */
/* =========================================== */

/* Strong gradient */
#main-content-section .section.gradient-strong::before {
  opacity: 1;
  background: linear-gradient(
    135deg,
    rgba(99, 102, 241, var(--gradient-opacity-strong)) 0%,
    rgba(139, 92, 246, var(--gradient-opacity-strong)) 100%
  );
}

/* Subtle gradient */
#main-content-section .section.gradient-subtle::before {
  opacity: 1;
  background: linear-gradient(
    135deg,
    rgba(99, 102, 241, var(--gradient-opacity-subtle)) 0%,
    rgba(139, 92, 246, var(--gradient-opacity-subtle)) 100%
  );
}

/* =========================================== */
/* BLEND MODES */
/* =========================================== */

#main-content-section .section.gradient-blend-overlay::before {
  mix-blend-mode: overlay;
}

#main-content-section .section.gradient-blend-soft-light::before {
  mix-blend-mode: soft-light;
}

#main-content-section .section.gradient-blend-multiply::before {
  mix-blend-mode: multiply;
}

#main-content-section .section.gradient-blend-screen::before {
  mix-blend-mode: screen;
}

/* =========================================== */
/* CONTENT POSITIONING */
/* =========================================== */

/* Ensure content is above gradient */
#main-content-section .section.gradient-overlay > * {
  position: relative;
  z-index: 1;
}

/* =========================================== */
/* ANIMATED GRADIENTS */
/* =========================================== */

#main-content-section .section.gradient-animated::before {
  background-size: 200% 200%;
  animation: gradientShift 8s ease infinite;
}

@keyframes gradientShift {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

/* =========================================== */
/* SECTION PATTERN COMBINATIONS */
/* =========================================== */

/* Apply gradient to section-pattern sections */
#main-content-section .section.section-pattern.gradient-overlay::before {
  opacity: 0.2; /* Slightly stronger for pattern sections */
}

/* =========================================== */
/* RESPONSIVE ADJUSTMENTS */
/* =========================================== */

@media (max-width: 768px) {
  /* Reduce gradient opacity on mobile */
  :root {
    --gradient-opacity: 0.1;
    --gradient-opacity-strong: 0.15;
    --gradient-opacity-subtle: 0.05;
  }
  
  /* Disable animated gradients on mobile for performance */
  #main-content-section .section.gradient-animated::before {
    animation: none;
  }
}

/* =========================================== */
/* ACCESSIBILITY */
/* =========================================== */

@media (prefers-contrast: high) {
  /* Reduce gradient opacity for high contrast */
  :root {
    --gradient-opacity: 0.05;
    --gradient-opacity-strong: 0.08;
    --gradient-opacity-subtle: 0.02;
  }
}

@media (prefers-reduced-motion: reduce) {
  #main-content-section .section.gradient-animated::before {
    animation: none;
  }
  
  #main-content-section .section::before {
    transition: none;
  }
}

/* =========================================== */
/* PRINT STYLES */
/* =========================================== */

@media print {
  #main-content-section .section::before {
    display: none;
  }
}



/* =========================================== */
/* 5. template/shared/css/enhanced-card-depth-2026.css */
/* =========================================== */

/* =========================================== */
/* ENHANCED CARD DEPTH 2026 */
/* Award-winning 3D card transformations */
/* =========================================== */

:root {
  --card-depth-intensity: 20px;
  --card-tilt-max: 15deg;
  --card-scale-hover: 1.02;
  --card-shadow-depth: 0 20px 60px rgba(0, 0, 0, 0.15);
  --card-shadow-hover: 0 30px 80px rgba(0, 0, 0, 0.2);
  --card-transition: 0.4s cubic-bezier(0.23, 1, 0.32, 1);
}

/* =========================================== */
/* CARD DEPTH BASE */
/* =========================================== */

#main-content-section .card {
  position: relative;
  transform-style: preserve-3d;
  perspective: 1000px;
  transition: transform var(--card-transition),
              box-shadow var(--card-transition);
  will-change: transform;
}

#main-content-section .card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: inherit;
  border-radius: inherit;
  opacity: 0;
  transition: opacity var(--card-transition);
  z-index: -1;
  filter: blur(20px);
  transform: translateZ(-20px);
}

/* =========================================== */
/* 3D TILT EFFECTS */
/* =========================================== */

#main-content-section .card.card-3d {
  transform-style: preserve-3d;
}

#main-content-section .card.card-3d:hover {
  transform: translateY(calc(-1 * var(--card-depth-intensity))) 
             scale(var(--card-scale-hover));
  box-shadow: var(--card-shadow-hover),
              0 0 0 1px rgba(99, 102, 241, 0.1);
}

/* Tilt on mouse move */
#main-content-section .card.card-3d-tilt {
  transform-style: preserve-3d;
}

#main-content-section .card.card-3d-tilt:hover {
  transform: translateY(calc(-1 * var(--card-depth-intensity))) 
             scale(var(--card-scale-hover));
}

/* =========================================== */
/* CARD LIFT EFFECTS */
/* =========================================== */

#main-content-section .card.card-lift {
  transition: transform var(--card-transition),
              box-shadow var(--card-transition);
}

#main-content-section .card.card-lift:hover {
  transform: translateY(calc(-1 * var(--card-depth-intensity)));
  box-shadow: var(--card-shadow-hover);
}

/* Strong lift */
#main-content-section .card.card-lift-strong:hover {
  transform: translateY(calc(-1 * var(--card-depth-intensity) * 1.5));
  box-shadow: 0 40px 100px rgba(0, 0, 0, 0.25);
}

/* Subtle lift */
#main-content-section .card.card-lift-subtle:hover {
  transform: translateY(calc(-1 * var(--card-depth-intensity) * 0.5));
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.12);
}

/* =========================================== */
/* CARD SCALE EFFECTS */
/* =========================================== */

#main-content-section .card.card-scale {
  transition: transform var(--card-transition),
              box-shadow var(--card-transition);
}

#main-content-section .card.card-scale:hover {
  transform: scale(var(--card-scale-hover));
  box-shadow: var(--card-shadow-hover);
}

/* Strong scale */
#main-content-section .card.card-scale-strong:hover {
  transform: scale(1.05);
  box-shadow: 0 35px 90px rgba(0, 0, 0, 0.22);
}

/* Subtle scale */
#main-content-section .card.card-scale-subtle:hover {
  transform: scale(1.01);
  box-shadow: 0 12px 35px rgba(0, 0, 0, 0.1);
}

/* =========================================== */
/* CARD ROTATE EFFECTS */
/* =========================================== */

#main-content-section .card.card-rotate {
  transition: transform var(--card-transition),
              box-shadow var(--card-transition);
}

#main-content-section .card.card-rotate:hover {
  transform: rotateY(5deg) rotateX(-5deg) 
             translateY(calc(-1 * var(--card-depth-intensity)));
  box-shadow: var(--card-shadow-hover);
}

/* Strong rotate */
#main-content-section .card.card-rotate-strong:hover {
  transform: rotateY(10deg) rotateX(-10deg) 
             translateY(calc(-1 * var(--card-depth-intensity) * 1.2));
  box-shadow: 0 40px 100px rgba(0, 0, 0, 0.25);
}

/* =========================================== */
/* CARD PERSPECTIVE EFFECTS */
/* =========================================== */

#main-content-section .card.card-perspective {
  transform-style: preserve-3d;
  perspective: 1000px;
}

#main-content-section .card.card-perspective .card-body {
  transform-style: preserve-3d;
  transition: transform var(--card-transition);
}

#main-content-section .card.card-perspective:hover .card-body {
  transform: translateZ(20px);
}

/* =========================================== */
/* CARD DEPTH SHADOWS */
/* =========================================== */

#main-content-section .card.card-depth-shadow {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08),
              0 8px 24px rgba(0, 0, 0, 0.06);
  transition: box-shadow var(--card-transition);
}

#main-content-section .card.card-depth-shadow:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12),
              0 16px 48px rgba(0, 0, 0, 0.1),
              0 0 0 1px rgba(99, 102, 241, 0.1);
}

/* Strong depth shadow */
#main-content-section .card.card-depth-shadow-strong {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12),
              0 16px 48px rgba(0, 0, 0, 0.1);
}

#main-content-section .card.card-depth-shadow-strong:hover {
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.15),
              0 24px 72px rgba(0, 0, 0, 0.12),
              0 0 0 1px rgba(99, 102, 241, 0.15);
}

/* =========================================== */
/* CARD GLOW EFFECTS */
/* =========================================== */

#main-content-section .card.card-glow {
  position: relative;
}

#main-content-section .card.card-glow::after {
  content: '';
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  border-radius: inherit;
  opacity: 0;
  z-index: -1;
  filter: blur(10px);
  transition: opacity var(--card-transition);
}

#main-content-section .card.card-glow:hover::after {
  opacity: 0.6;
}

#main-content-section .card.card-glow:hover {
  box-shadow: 0 0 30px rgba(99, 102, 241, 0.4),
              var(--card-shadow-hover);
}

/* =========================================== */
/* CARD BORDER EFFECTS */
/* =========================================== */

#main-content-section .card.card-border-glow {
  border: 1px solid transparent;
  background-clip: padding-box;
  position: relative;
}

#main-content-section .card.card-border-glow::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  -webkit-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(--card-transition);
  z-index: -1;
}

#main-content-section .card.card-border-glow:hover::before {
  opacity: 1;
}

/* =========================================== */
/* CARD CONTENT LAYERING */
/* =========================================== */

#main-content-section .card .card-body {
  position: relative;
  z-index: 1;
}

#main-content-section .card .card-header {
  position: relative;
  z-index: 2;
}

#main-content-section .card .card-footer {
  position: relative;
  z-index: 2;
}

/* =========================================== */
/* CARD STACK EFFECT */
/* =========================================== */

#main-content-section .card.card-stack {
  position: relative;
}

#main-content-section .card.card-stack::before,
#main-content-section .card.card-stack::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: inherit;
  border-radius: inherit;
  z-index: -1;
  opacity: 0.5;
  transition: transform var(--card-transition),
              opacity var(--card-transition);
}

#main-content-section .card.card-stack::before {
  transform: translateY(4px) scale(0.98);
}

#main-content-section .card.card-stack::after {
  transform: translateY(8px) scale(0.96);
  opacity: 0.3;
}

#main-content-section .card.card-stack:hover::before {
  transform: translateY(8px) scale(0.96);
}

#main-content-section .card.card-stack:hover::after {
  transform: translateY(12px) scale(0.94);
}

/* =========================================== */
/* RESPONSIVE ADJUSTMENTS */
/* =========================================== */

@media (max-width: 768px) {
  :root {
    --card-depth-intensity: 10px;
    --card-scale-hover: 1.01;
  }
  
  /* Reduce 3D effects on mobile */
  #main-content-section .card.card-rotate:hover,
  #main-content-section .card.card-rotate-strong:hover {
    transform: translateY(calc(-1 * var(--card-depth-intensity)));
  }
  
  /* Simplify stack effect on mobile */
  #main-content-section .card.card-stack::before,
  #main-content-section .card.card-stack::after {
    display: none;
  }
}

/* =========================================== */
/* ACCESSIBILITY */
/* =========================================== */

@media (prefers-reduced-motion: reduce) {
  #main-content-section .card {
    transition: none !important;
    transform: none !important;
  }
  
  #main-content-section .card:hover {
    transform: none !important;
  }
  
  #main-content-section .card::before,
  #main-content-section .card::after {
    display: none;
  }
}

/* =========================================== */
/* PERFORMANCE OPTIMIZATIONS */
/* =========================================== */

#main-content-section .card {
  backface-visibility: hidden;
  -webkit-font-smoothing: antialiased;
}

#main-content-section .card.card-3d,
#main-content-section .card.card-3d-tilt,
#main-content-section .card.card-perspective {
  will-change: transform;
}



/* =========================================== */
/* 6. template/shared/css/content-connectors-2026.css */
/* =========================================== */

/* =========================================== */
/* CONTENT CONNECTORS 2026 */
/* Award-winning visual lines connecting content */
/* =========================================== */

:root {
  --connector-width: 2px;
  --connector-color: rgba(99, 102, 241, 0.3);
  --connector-color-active: rgba(99, 102, 241, 0.6);
  --connector-animation-duration: 1s;
  --connector-dot-size: 8px;
}

/* =========================================== */
/* CONNECTOR BASE */
/* =========================================== */

.content-connector {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity var(--connector-animation-duration) ease;
}

.content-connector.active {
  opacity: 1;
}

/* =========================================== */
/* VERTICAL CONNECTORS */
/* =========================================== */

.content-connector-vertical {
  width: var(--connector-width);
  background: linear-gradient(
    to bottom,
    transparent 0%,
    var(--connector-color) 20%,
    var(--connector-color) 80%,
    transparent 100%
  );
  left: 50%;
  transform: translateX(-50%);
}

.content-connector-vertical.active {
  background: linear-gradient(
    to bottom,
    transparent 0%,
    var(--connector-color-active) 20%,
    var(--connector-color-active) 80%,
    transparent 100%
  );
}

/* =========================================== */
/* HORIZONTAL CONNECTORS */
/* =========================================== */

.content-connector-horizontal {
  height: var(--connector-width);
  background: linear-gradient(
    to right,
    transparent 0%,
    var(--connector-color) 20%,
    var(--connector-color) 80%,
    transparent 100%
  );
  top: 50%;
  transform: translateY(-50%);
}

.content-connector-horizontal.active {
  background: linear-gradient(
    to right,
    transparent 0%,
    var(--connector-color-active) 20%,
    var(--connector-color-active) 80%,
    transparent 100%
  );
}

/* =========================================== */
/* DIAGONAL CONNECTORS */
/* =========================================== */

.content-connector-diagonal {
  width: var(--connector-width);
  background: linear-gradient(
    135deg,
    transparent 0%,
    var(--connector-color) 20%,
    var(--connector-color) 80%,
    transparent 100%
  );
}

.content-connector-diagonal.active {
  background: linear-gradient(
    135deg,
    transparent 0%,
    var(--connector-color-active) 20%,
    var(--connector-color-active) 80%,
    transparent 100%
  );
}

/* =========================================== */
/* CONNECTOR DOTS */
/* =========================================== */

.content-connector-dot {
  position: absolute;
  width: var(--connector-dot-size);
  height: var(--connector-dot-size);
  border-radius: 50%;
  background: var(--connector-color);
  transform: translate(-50%, -50%);
  transition: background var(--connector-animation-duration) ease,
              transform var(--connector-animation-duration) ease,
              box-shadow var(--connector-animation-duration) ease;
}

.content-connector-dot.active {
  background: var(--connector-color-active);
  transform: translate(-50%, -50%) scale(1.3);
  box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.2);
}

/* =========================================== */
/* ANIMATED CONNECTORS */
/* =========================================== */

.content-connector-animated {
  background-size: 200% 100%;
  animation: connectorFlow var(--connector-animation-duration) ease infinite;
}

@keyframes connectorFlow {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 200% 50%;
  }
}

/* Pulse animation */
.content-connector-pulse {
  animation: connectorPulse 2s ease infinite;
}

@keyframes connectorPulse {
  0%, 100% {
    opacity: 0.3;
  }
  50% {
    opacity: 1;
  }
}

/* =========================================== */
/* SECTION CONNECTORS */
/* =========================================== */

#main-content-section .section {
  position: relative;
}

#main-content-section .section::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: var(--connector-width);
  height: 60px;
  background: linear-gradient(
    to bottom,
    var(--connector-color) 0%,
    transparent 100%
  );
  opacity: 0;
  transition: opacity 0.6s ease;
  z-index: 0;
}

#main-content-section .section.scroll-reveal.revealed::after,
#main-content-section .section.scroll-fade.revealed::after {
  opacity: 1;
}

/* Hide connector on last section */
#main-content-section .section:last-child::after {
  display: none;
}

/* =========================================== */
/* CARD CONNECTORS */
/* =========================================== */

#main-content-section .card-connector-group {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}

#main-content-section .card-connector-group .card {
  position: relative;
}

/* Horizontal connector between cards */
#main-content-section .card-connector-group .card:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(-1 * 1rem);
  width: 2rem;
  height: var(--connector-width);
  background: linear-gradient(
    to right,
    var(--connector-color) 0%,
    transparent 100%
  );
  opacity: 0;
  transition: opacity 0.6s ease;
  z-index: 1;
}

#main-content-section .card-connector-group .card:hover::after {
  opacity: 1;
}

/* =========================================== */
/* RELATED CONTENT CONNECTORS */
/* =========================================== */

.related-content-connector {
  position: relative;
  padding: 2rem 0;
}

.related-content-connector::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: var(--connector-width);
  height: 100%;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    var(--connector-color) 20%,
    var(--connector-color) 80%,
    transparent 100%
  );
  opacity: 0;
  transition: opacity 0.6s ease;
  z-index: 0;
}

.related-content-connector.active::before {
  opacity: 1;
}

/* =========================================== */
/* CONNECTOR LABELS */
/* =========================================== */

.connector-label {
  position: absolute;
  background: rgba(99, 102, 241, 0.1);
  backdrop-filter: blur(10px);
  padding: 0.25rem 0.75rem;
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 600;
  color: #6366f1;
  white-space: nowrap;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  z-index: 10;
}

.content-connector:hover + .connector-label,
.content-connector.active + .connector-label {
  opacity: 1;
}

/* =========================================== */
/* RESPONSIVE ADJUSTMENTS */
/* =========================================== */

@media (max-width: 768px) {
  :root {
    --connector-width: 1px;
    --connector-dot-size: 6px;
  }
  
  /* Hide connectors on mobile for cleaner look */
  #main-content-section .section::after {
    display: none;
  }
  
  #main-content-section .card-connector-group .card::after {
    display: none;
  }
  
  /* Simplify animated connectors */
  .content-connector-animated {
    animation: none;
  }
}

/* =========================================== */
/* ACCESSIBILITY */
/* =========================================== */

@media (prefers-reduced-motion: reduce) {
  .content-connector-animated,
  .content-connector-pulse {
    animation: none;
  }
  
  .content-connector,
  .content-connector-dot {
    transition: none;
  }
}

/* =========================================== */
/* PRINT STYLES */
/* =========================================== */

@media print {
  .content-connector,
  #main-content-section .section::after,
  #main-content-section .card-connector-group .card::after {
    display: none;
  }
}



