@import url('https://fonts.googleapis.com/css2?family=Anton&family=Inter:wght@400;700;900&family=JetBrains+Mono:wght@400;700&display=swap');

*, *::before, *::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: #18181b;
  color: #f8fafc;
  font-family: 'Inter', ui-sans-serif, system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img, picture, svg, video {
  max-width: 100%;
  display: block;
}

.hero-section h1 {
  font-size: clamp(3rem, 9vw, 7.5rem);
  line-height: 0.95;
  word-break: break-word;
}

.whatsapp-link.fixed {
  border-radius: 9999px;
}

#main-nav .nav-links {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  pointer-events: none;
  transform: translateY(-10px);
  transition: max-height 0.35s ease, opacity 0.25s ease, transform 0.25s ease;
}

#main-nav .nav-links.show {
  max-height: 240px;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

@media (min-width: 768px) {
  #main-nav .nav-links {
    display: flex;
    flex-direction: row;
    max-height: none;
    opacity: 1;
    overflow: visible;
    pointer-events: auto;
    transform: none;
  }

  #main-nav .nav-links a {
    min-width: 7rem;
  }
}

#mobile-menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.25s ease;
}

#mobile-menu-toggle.open {
  transform: rotate(90deg);
}

@media (min-width: 768px) {
  #mobile-menu-toggle {
    display: none;
  }
}

.catalog-grid {
  border: 1px solid #27272a;
  border-radius: 2rem;
  overflow: hidden;
}

/* Texto Vertical */
.vertical-text {
  writing-mode: vertical-rl;
  text-orientation: mixed;
}

/* Utilidades de Animación */
.reveal-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1), transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.reveal-up.active {
  opacity: 1;
  transform: translateY(0);
}

.reveal-scale {
  opacity: 0;
  transform: scale(0.9);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.reveal-scale.active {
  opacity: 1;
  transform: scale(1);
}

.reveal-left {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1s cubic-bezier(0.16, 1, 0.3, 1);
}

.reveal-left.active {
  clip-path: inset(0 0% 0 0);
}

.stagger-item {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.stagger-item.active {
  opacity: 1;
  transform: translateY(0);
}

/* Scrollbar Personalizada */
::-webkit-scrollbar {
  width: 8px;
}
::-webkit-scrollbar-track {
  background-color: #18181b;
}
::-webkit-scrollbar-thumb {
  background-color: #27272a;
}
::-webkit-scrollbar-thumb:hover {
  background-color: #ff4d00;
}

#main-nav.nav-scrolled {
  background-color: rgba(15, 23, 42, 0.96);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.32);
  backdrop-filter: blur(16px);
}

.hero-section {
  min-height: 100vh;
  padding-bottom: 7rem;
}

.hero-section h1 {
  font-size: clamp(2.8rem, 8vw, 5.5rem);
  line-height: 1;
}

.hero-section .relative.z-10 {
  max-width: 92vw;
  margin: 0 auto;
}

.hero-section .absolute.inset-x-0.bottom-10 {
  bottom: 1.25rem;
}

@media (max-width: 768px) {
  .hero-section {
    padding-top: 5rem;
    padding-bottom: 5.5rem;
  }

  .hero-section h1 {
    font-size: clamp(2.4rem, 10vw, 4.5rem);
    line-height: 1.05;
  }

  .hero-section .overflow-hidden.mb-8 {
    max-width: 100%;
  }

  #main-nav {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }

  #main-nav .nav-links {
    gap: 0.5rem;
  }
}

@media (max-width: 480px) {
  .hero-section {
    padding-top: 6rem;
    padding-bottom: 5rem;
  }

  .hero-section h1 {
    font-size: clamp(2rem, 12vw, 3.8rem);
    letter-spacing: -0.03em;
  }

  .hero-section .overflow-hidden.mb-8 {
    max-width: 100%;
  }

  .hero-section .absolute.inset-x-0.bottom-10 {
    bottom: 0.75rem;
  }

  #main-nav {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }

  #main-nav .nav-links {
    flex-direction: column;
    gap: 0.75rem;
  }

  #main-nav .nav-links a {
    min-width: auto;
  }

  #main-nav > div:nth-child(3) {
    justify-content: center;
  }
}