:root {
  --bg-color: hsl(30, 1%, 84%);
  --text-color: hsl(30, 1%, 16%);
  --header-color: black;
  --font-family: futura-pt, sans-serif;
}

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

body {
  background-color: var(--bg-color);
  font-family: var(--font-family);
}

header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem;
  background-color: var(--header-color);
  color: var(--bg-color);
}

.section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  padding: 1rem;
  background-color: var(--bg-color);
  color: var(--text-color);
}

.wordmark {
  max-width: 400px;
  margin: 1rem 2rem;
}

h3 {
  font-size: 2rem;
  margin-bottom: 1rem;
  margin-left: 2rem;
}

p {
  font-size: 1.2rem;
  line-height: 1.5;
  max-width: 400px;
  margin: 1rem 2rem;
}

.product-image,
.product-packaging {
  max-width: 100%;
  max-height: 800px;
}

.product-image {
  margin-top: -1rem;
}

.product-packaging {
  align-self: end;
}

#two {
  min-height: 800px;
}

#waitlist {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 2rem;
  text-align: center;
  /* justify-content: center; */
}

#waitlist input {
  width: 80%;
  padding: 1rem;
  border: 1px solid var(--text-color);
  border-radius: 0.5rem;
}

#waitlist button {
  padding: 0.6rem 2rem;
  background-color: var(--text-color);
  color: var(--bg-color);
  border: 1px solid var(--text-color);
  border-radius: 0.5rem;
  margin-top: 1rem;
  align-self: center;
}
/* Reviews Carousel Styles */
.reviews {
  padding: 4rem 0;
  text-align: center;
  background-color: var(--bg-color);
}

.reviews h2 {
  font-size: 2.5rem;
  margin-bottom: 1rem;
  color: var(--text-color);
}

.reviews > .container > p {
  font-size: 1.2rem;
  color: var(--text-color);
  margin-bottom: 3rem;
}

.carousel-container {
  width: 100%;
  overflow: hidden;
  position: relative;
  padding: 2rem 0;
}

.carousel {
  display: flex;
  animation: scroll 30s linear infinite;
  gap: 2rem;
  width: calc(350px * 12); /* Width to accommodate all cards plus duplicates */
}

.review-card,
.join-container {
  min-width: 350px;
  max-width: 350px;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(10px);
  border-radius: 1rem;
  padding: 2rem;
  color: white;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition: transform 0.3s ease;
}

.join-container {
  align-self: center;
}

.join-container h2 {
  text-align: center;
}

.review-card:hover {
  transform: translateY(-5px);
}

.review-content p {
  font-size: 1.1rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
  font-style: italic;
  color: white;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

.reviewer {
  text-align: left;
}

.reviewer strong {
  display: block;
  font-size: 1.1rem;
  margin-bottom: 0.25rem;
  color: white;
}

.reviewer span {
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.7);
}

@keyframes scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(
      calc(-350px * 6 - 12rem)
    ); /* Move by 6 cards + gaps */
  }
}

/* Pause animation on hover */
.carousel-container:hover .carousel {
  animation-play-state: paused;
}

footer {
  padding: 1rem;
  text-align: center;
  background-color: var(--header-color);
  color: var(--bg-color);
}

/* Responsive Design */
@media (max-width: 768px) {
  /* Collapse main grid sections to single column */
  .section {
    grid-template-columns: 1fr;
    gap: 2rem;
    padding: 2rem 1rem;
  }

  /* Adjust images for mobile */
  .wordmark {
    max-width: 300px;
    margin: 1rem auto;
    display: block;
  }

  .product-image,
  .product-packaging {
    max-height: 400px;
    width: 100%;
    object-fit: contain;
  }

  /* Stack waitlist content vertically */
  #waitlist {
    gap: 1rem;
  }

  #waitlist .copy {
    text-align: center;
  }

  /* Adjust text sizes for mobile */
  h2 {
    font-size: 2rem;
  }

  h3 {
    font-size: 1.5rem;
    margin-left: 0;
    text-align: center;
  }

  p {
    font-size: 1rem;
    margin: 1rem auto;
    text-align: center;
    max-width: 100%;
  }

  /* Mobile carousel adjustments */
  .reviews {
    padding: 2rem 0;
  }

  .reviews h2 {
    font-size: 2rem;
  }

  .carousel-container {
    padding: 1rem 0;
  }

  .review-card,
  .join-container {
    min-width: 280px;
    max-width: 280px;
    padding: 1.5rem;
  }

  .review-content p {
    font-size: 1rem;
    line-height: 1.5;
  }

  .reviewer strong {
    font-size: 1rem;
  }

  .reviewer span {
    font-size: 0.85rem;
  }

  /* Adjust carousel animation for smaller cards */
  @keyframes scroll {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(calc(-280px * 6 - 12rem));
    }
  }

  /* Form adjustments for mobile */
  #waitlist input {
    width: 80%;
    margin-bottom: 1rem;
  }

  #waitlist button {
    width: 100%;
    padding: 1rem 2rem;
  }

  /* Header adjustments */
  header {
    padding: 0.5rem 1rem;
  }

  /* Footer adjustments */
  footer {
    padding: 1.5rem 1rem;
  }

  footer span {
    font-size: 0.9rem;
  }
}

/* Extra small devices */
@media (max-width: 480px) {
  .section {
    padding: 1.5rem 0.5rem;
  }

  .wordmark {
    max-width: 250px;
  }

  .review-card,
  .join-container {
    min-width: 250px;
    max-width: 250px;
    padding: 1.25rem;
  }

  .reviews h2 {
    font-size: 1.75rem;
  }

  h2 {
    font-size: 1.75rem;
  }

  h3 {
    font-size: 1.25rem;
  }

  /* Adjust carousel animation for extra small screens */
  @keyframes scroll {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(calc(-250px * 6 - 12rem));
    }
  }
}
