/*
  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: 0;
  padding-top: 80px; /* Top spacing for dot matrix */
  display: flex;
  justify-content: flex-start; /* Top align instead of center */
  align-items: center;
}

.hero-section .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
  padding-top: 0;
}

/* ===== Philosophy Sections ===== */
.philosophy-section {
  min-height: auto;
  text-align: center;
  padding: var(--spacing-xl) 0;
}

.philosophy-section .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
  padding-top: 0;
}

/* ===== 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);
}

/* ===== Graphic Section ===== */
.graphic-section {
  min-height: auto;
  text-align: center;
  padding: var(--spacing-xl) 0;
}

.graphic-section .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
  padding-top: 0;
}

/* ===== Eye Section ===== */
.eye-section {
  min-height: auto;
  text-align: center;
  padding: var(--spacing-xl) 0;
}

.eye-section .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
  padding-top: 0;
}

/* ===== 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;
}
