/* HERO Block Frontend Styles - Mobile First Design with Design System */

/* Mobile-first base styles (up to 768px) */
.hero-section {
  position: relative;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  height: 655px; /* Mobile height */
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: var(--spacing-16, 2.5rem); /* 40px */
  padding: var(--spacing-16, 5rem) var(--spacing-6, 1.75rem) var(--spacing-6, 1.75rem); /* 80px 28px 28px */
}
 /* Background overlay */
.hero-background-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 0%, rgba(0,0,0,0.4) 50%, rgba(0,0,0,0.7) 100%);
  pointer-events: none;
  z-index: 1;
}

/* Content container */
.hero-content-container {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  gap: 7.75rem; /* 124px - gap between copy section and button */
}

/* Copy section */
.hero-copy-section {
  display: flex;
  flex-direction: column;
  gap: 0.625rem; /* 10px */
}

/* Button container visibility control */
.hero-button-container {
  display: block; /* Show on desktop */
}

.hero-button-mobile {
  display: none; /* Hide on desktop */
}

/* Hero Typography - Using design system */
.hero-heading {
  font-family: var(--font-heading, "Sora") !important;
  font-size: 2.25rem !important; /* 36px mobile */
  font-weight: var(--font-weight-extrabold, 800) !important;
  line-height: 0.8888888888888888em !important;
  text-transform: uppercase !important;
  color: var(--color-yellow-200, #FBEB8F) !important;
  margin: 0 !important;
}

.hero-subheading {
  font-family: var(--font-subheading, "Apolline Std") !important;
  font-size: var(--font-size-xl, 1.25rem) !important; /* 20px */
  font-weight: 700 !important;
  line-height: 1.2em !important;
  letter-spacing: 0.02em !important;
  color: var(--color-green-100, var(--color-green-200)) !important;
  text-shadow: var(--text-shadow-sm) !important;
  margin: 0 !important;
  font-style: italic !important;
}

/* Hero Button - Using design system */
.hero-button {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important; /* Full width on mobile */
  padding: 1rem !important; /* 16px */
  gap: 0.5rem !important; /* 8px */
  background-color: var(--color-yellow-200, #FBEB8F) !important;
  color: var(--color-green-950) !important;
  border: 1px solid var(--color-green-400, #D4D2C4) !important;
  border-radius: 0 !important;
  text-decoration: none !important;
  transition: all 0.2s ease !important;
}

.hero-button:hover {
  background-color: var(--color-brown-900) !important;
  color: var(--color-yellow-200, #FBEB8F) !important ;
}

.hero-button:focus {
  outline: 2px solid var(--color-blue-focus, #4F85FD);
  outline-offset: 2px;
}

.hero-button-text {
  font-family: var(--font-body, "Azo Sans") !important;
  font-size: 0.875rem !important; /* 14px */
  font-weight: 500 !important;
  line-height: 1.15em !important;
  letter-spacing: 0.057142857em !important;
  text-transform: uppercase !important;
  color: inherit !important;
}

.hero-button-icon {
  width: 1.5rem; /* 24px */
  height: 1.5rem; /* 24px */
  transition: transform 0.2s ease;
}

.hero-button:hover .hero-button-icon {
  transform: translateX(0.25rem);
}

/* Actions container */
.hero-actions-container {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  gap: 1rem; /* 16px */
  align-self: stretch;
  width: 100%;
}

/* Pagination container */
.hero-pagination-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem; /* 16px */
  padding: 0.5rem; /* 8px */
  background-color: rgba(55, 58, 25, 0.56) !important;
  border-radius: var(--border-radius-base, 0.25rem);
  width: 100%;
}

.hero-pagination-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem; /* 8px */
  padding: 0.5rem; /* 8px */
  border: 2px solid var(--color-yellow-200, #FBEB8F) !important;
  background-color: transparent !important;
  color: var(--color-yellow-200, #FBEB8F) !important;
  cursor: pointer;
  transition: all 0.2s ease;
  border-radius: 0;
}

.hero-pagination-btn:hover:not(:disabled) {
  background-color: var(--color-yellow-200, #FBEB8F) !important;
  color: var(var(--color-green-950), #000000) !important;
}

.hero-pagination-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.hero-pagination-btn:disabled:hover {
  background-color: transparent !important;
  color: var(--color-yellow-200, #FBEB8F) !important;
}

.hero-pagination-icon {
  width: 1.5rem; /* 24px */
  height: 1.5rem; /* 24px */
}

.hero-pagination-indicator-container {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem; /* 40px */
}

.hero-pagination-indicator {
  font-family: var(--font-heading, "Sora") !important;
  font-size: var(--font-size-2xl, 1.5rem) !important; /* 24px */
  font-weight: 400 !important;
  line-height: 1em !important;
  text-transform: uppercase !important;
  color: var(--color-yellow-200, #FBEB8F) !important;
  text-align: center !important;
}

.hero-current-page {
  font-weight: var(--font-weight-extrabold, 800) !important;
}

/* Mobile Styles - Frame 37 specs */
@media (max-width: 767px) {
  /* Mobile: Hide desktop button, show mobile button */
  .hero-button-container {
    display: none !important;
  }
  
  .hero-button-mobile {
    display: block !important;
  }

  /* Mobile: Content container shows only copy */
  .hero-content-container {
    gap: 0 !important;
  }

  /* Mobile: Ensure full width button */
  .hero-button {
    width: 100% !important;
    max-width: none !important;
    align-self: stretch !important;
  }
}

/* Desktop/Tablet styles (768px and up) */
@media (min-width: 768px) {
  .hero-section {
    min-height: 544px; /* Desktop height */
    height: auto;
    gap: var(--spacing-16, 2.5rem); /* 40px */
    justify-content: space-between;
  }

  /* Desktop: Content container - Copy + Button together */
  .hero-content-container {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--spacing-16, 2.5rem); /* 40px */
  }

  /* Desktop: Force hide mobile button completely */
  .hero-button-mobile {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    position: absolute !important;
    left: -9999px !important;
  }

  /* Desktop: Actions container - pagination only positioned at flex-end */
  .hero-actions-container {
    display: flex !important;
    flex-direction: row !important;
    justify-content: flex-end !important;
    align-items: flex-end !important;
    width: 100% !important;
  }

  /* Desktop: Button has fixed width */
  .hero-button {
    width: 348px !important; /* Fixed width */
    height: 72px !important; /* Fixed height */
    max-width: 348px !important;
    padding: 1.5rem !important; /* 24px */
    gap: 0.75rem !important; /* 12px */
    flex-shrink: 0 !important;
  }

  /* Desktop: Pagination has natural compact width */
  .hero-pagination-container {
    width: auto !important;
    flex-shrink: 0 !important;
    justify-content: center !important;
  }

  .hero-heading {
    font-size: var(--font-size-7xl, 4.5rem) !important; /* 72px desktop */
    max-width: 738px !important;
  }

  .hero-subheading {
    max-width: 437px !important;
  }
}

/* Large desktop styles (1024px and up) */
@media (min-width: 1024px) {
  .hero-section {
    padding: var(--spacing-16, 5rem) var(--spacing-6, 1.75rem) var(--spacing-6, 1.75rem);
  }
} 