/* Main Stylesheet - Base styles and utilities */

/* Note: Design system components are linked directly in HTML for better browser compatibility */

/* Reset & Base */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  -webkit-tap-highlight-color: transparent;
}

/* Respect user's motion preferences */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

body {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base);
  line-height: var(--line-height-normal);
  color: var(--color-text-white);
  background-color: var(--color-bg-black);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-overflow-scrolling: touch;
  overflow-x: hidden;
  position: relative;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

/* Utility Classes */
.utility-container {
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

.utility-mt-1 { margin-top: var(--spacing-4); }
.utility-mt-2 { margin-top: var(--spacing-6); }
.utility-mt-3 { margin-top: var(--spacing-8); }
.utility-mt-4 { margin-top: var(--spacing-10); }
.utility-mt-5 { margin-top: var(--spacing-12); }
.utility-mt-10 { margin-top: var(--spacing-20); }

.utility-mb-1 { margin-bottom: var(--spacing-4); }
.utility-mb-2 { margin-bottom: var(--spacing-6); }
.utility-mb-3 { margin-bottom: var(--spacing-8); }
.utility-mb-4 { margin-bottom: var(--spacing-10); }
.utility-mb-5 { margin-bottom: var(--spacing-12); }

.utility-text-center { text-align: center; }
.utility-text-left { text-align: left; }
.utility-text-right { text-align: right; }

.utility-max-width-680 { max-width: 680px; }
.utility-max-width-800 { max-width: 800px; }
.utility-max-width-950 { max-width: 950px; }
.utility-max-width-1000 { max-width: 1000px; }
.utility-max-width-1080 { max-width: 1080px; }

/* Animations */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* Smooth scroll behavior */
html {
  scroll-behavior: smooth;
}

/* Profile image animations */
.hero-profile-image {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  cursor: pointer;
}

.hero-profile-image:hover {
  transform: translateY(-10px) scale(1.05);
  box-shadow: 0 10px 30px rgba(236, 72, 153, 0.3);
}

.utility-reveal {
  animation: fadeInUp 0.6s ease-out;
}

.utility-reveal-delay-1 {
  animation: fadeInUp 0.6s ease-out 0.1s both;
}

.utility-reveal-delay-2 {
  animation: fadeInUp 0.6s ease-out 0.2s both;
}

/* Responsive Utilities */
@media (max-width: 768px) {
  .utility-hide-mobile {
    display: none !important;
  }
  
  /* Optimize animations for mobile performance - use prefers-reduced-motion */
  @media (prefers-reduced-motion: no-preference) {
    /* Only optimize if user hasn't requested reduced motion */
    .molecule-floating-contact__item,
    .organism-background__gradient,
    .organism-background__swirl,
    .cosmic-network__node {
      animation-duration: inherit !important;
      animation-iteration-count: infinite !important;
    }
  }
  
  /* Reduce repaints and improve performance */
  .organism-header {
    will-change: auto;
  }
  
  /* Optimize scroll performance */
  html {
    scroll-behavior: auto; /* Disable smooth scroll on mobile for better performance */
  }
  
  /* Reduce transform complexity */
  .organism-hero__title,
  .organism-hero__subtitle {
    transform: none;
  }
}

@media (min-width: 769px) {
  .utility-hide-desktop {
    display: none !important;
  }
}
