@import url('https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;600&family=Press+Start+2P&family=Playfair+Display:ital,wght@0,600;1,400&family=Noto+Serif+SC:wght@400;700&family=Noto+Sans+SC:wght@300;500;800&display=swap');

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  transition: background-color 0.4s ease, border-color 0.4s ease, color 0.3s ease, box-shadow 0.4s ease, transform 0.2s ease;
}

#dynamic-bg-canvas {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

#loader {
  position: fixed;
  inset: 0;
  z-index: 100;
  background-color: #f5efe2;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
  transition: opacity 0.3s ease;
}

#loader.hidden {
  opacity: 0;
  pointer-events: none;
}

.loader-spinner {
  width: 48px;
  height: 48px;
  border: 2px solid #92400e;
  border-top-color: transparent;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin-bottom: 16px;
}

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

@media (max-width: 640px) {
  #navbar {
    flex-direction: column;
    gap: 0.5rem;
  }
  
  #style-selector-container {
    flex-wrap: wrap;
    justify-content: center;
  }
}

@media (hover: none) {
  .project-card:hover {
    transform: none;
  }
  
  .pixel-btn:active {
    transform: translate(2px, 2px);
  }
}

.no-canvas #dynamic-bg-canvas {
  display: none;
}