/*
  Layout Styles
  Section structure, containers, grid
*/

/* ===== Global Layout ===== */
body {
  font-family: var(--font-family);
  background-color: var(--color-bg);
  color: var(--color-text-primary);
  overflow-x: hidden;
}

/* Container - Max width wrapper */
.container {
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: 0 var(--spacing-md);
}

/* ===== Section Base Styles ===== */
section {
  min-height: var(--section-padding);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl) 0;
  position: relative;
}

/* ===== Hero Section ===== */
.hero-section {
  min-height: 100vh;
  text-align: center;
  padding: var(--spacing-xl) 0;
}

.hero-section .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-md);
}

/* Scroll Hint */
.scroll-hint {
  position: absolute;
  bottom: var(--spacing-lg);
  left: 50%;
  transform: translateX(-50%);
  font-size: 2rem;
  color: var(--color-text-secondary);
  animation: bounce 2s infinite ease-in-out;
}

@keyframes bounce {
  0%, 100% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(-10px);
  }
}

/* ===== Philosophy Sections ===== */
.philosophy-section {
  min-height: 80vh;
  text-align: center;
}

/* ===== Product Section ===== */
.product-section {
  min-height: 90vh;
  text-align: center;
}

/* ===== Tech Section ===== */
.tech-section {
  min-height: 90vh;
  text-align: center;
}

/* ===== CTA Section ===== */
.cta-section {
  min-height: 60vh;
  text-align: center;
}

.cta-section .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-md);
}

/* ===== Scroll Animation States ===== */
[data-animate] {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity var(--transition-slow), transform var(--transition-slow);
}

[data-animate].animate-in {
  opacity: 1;
  transform: translateY(0);
}

/* ===== Footer ===== */
.footer {
  margin-top: var(--spacing-lg);
  padding-top: var(--spacing-md);
  border-top: 1px solid var(--color-border);
  text-align: center;
}
