/* ========================================
   LAYOUT COMPONENTS
   ======================================== */

/* ========================================
   MAIN LAYOUT
   ======================================== */

.main {
  min-height: 100vh;
  position: relative;
  z-index: var(--z-base);
}

/* ========================================
   SECTIONS
   ======================================== */

.section {
  padding: var(--space-4xl) 0;
  position: relative;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.section.active {
  opacity: 1;
  transform: translateY(0);
}

.section--home {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: var(--space-5xl) 0;
}

.section__header {
  text-align: center;
  margin-bottom: var(--space-4xl);
}

.section__title {
  font-size: var(--font-size-5xl);
  font-weight: var(--font-weight-black);
  letter-spacing: 0.05em;
  margin-bottom: var(--space-lg);
  color: var(--color-text-primary);
  font-family: 'MedievalSharp', serif;
}

.section__subtitle {
  font-size: var(--font-size-xl);
  color: var(--color-text-secondary);
  max-width: 600px;
  margin: 0 auto;
}

/* ========================================
   HERO SECTION
   ======================================== */

 .hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4xl);
  align-items: center;
  min-height: 80vh;
  /* Background now handled globally on body; keep positioning only */
  position: relative;
  isolation: isolate;
}

.hero__content {
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.hero__visual {
  position: relative;
  z-index: 2;
}

.hero__title {
  font-family: 'Wooden Log', serif;
  font-size: var(--font-size-6xl);
  font-weight: normal;
  line-height: var(--line-height-tight);
  margin-bottom: var(--space-xl);
  color: #F7E3C0;
}

.hero__title-line { display:block; opacity:0; transform:translateY(30px); animation: slideInUp 0.7s ease-out forwards; animation-delay: calc(var(--i,1)*120ms + 80ms); will-change:transform,opacity; }
.hero__title-line:nth-child(1){ --i:0; }
.hero__title-line:nth-child(2){ --i:1; }
.hero__title-line:nth-child(3){ --i:2; }

.hero__title-line--accent {
  color: var(--color-primary);
}

.hero__subtitle {
  font-size: var(--font-size-xl);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2xl);
  opacity: 0;
  animation: fadeInUp 0.8s ease-out 0.8s forwards;
}

.hero__actions {
  display: flex;
  gap: var(--space-lg);
  justify-content: center;
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeInUp 0.8s ease-out 1s forwards;
}

.hero__visual {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

.hero__snail {
  position: relative;
  max-width: 400px;
  width: 100%;
}

.hero__snail-img {
  width: 100%;
  height: auto;
  filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.1));
  opacity: 0;
  transform: scale(0.8) rotate(-10deg);
  animation: snailEntrance 1.2s ease-out 1.2s forwards;
}

/* ========================================
   LORE SECTION
   ======================================== */

.lore {
  padding: var(--space-5xl) 0;
  background: var(--color-bg-secondary);
  border-top: 1px solid var(--color-border);
}

.lore__content {
  max-width: 1000px;
  margin: 0 auto;
}

.lore__story {
  margin-bottom: var(--space-4xl);
}

.lore__chapter {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-xl);
  margin-bottom: var(--space-3xl);
  padding: var(--space-2xl);
  background: var(--color-bg-tertiary);
  border-radius: var(--radius-2xl);
  border: 1px solid var(--color-border);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.lore__chapter:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.lore__chapter-icon {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-full);
  background: var(--color-bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--color-border-light);
  flex-shrink: 0;
}

.lore__icon {
  width: 60px;
  height: 60px;
  object-fit: contain;
}

.lore__chapter-content {
  min-width: 0;
}

.lore__chapter-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-md);
  color: var(--color-text-primary);
}

.lore__chapter-text {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
  color: var(--color-text-secondary);
  margin: 0;
}

.lore__wisdom {
  background: var(--color-bg-primary);
  border-radius: var(--radius-2xl);
  padding: var(--space-3xl);
  border: 1px solid var(--color-border);
  text-align: center;
}

.lore__quote {
  margin: 0;
}

.lore__quote p {
  font-size: var(--font-size-xl);
  font-style: italic;
  line-height: var(--line-height-relaxed);
  color: var(--color-text-primary);
  margin-bottom: var(--space-lg);
  position: relative;
}

.lore__quote p::before {
  content: '"';
  font-size: var(--font-size-4xl);
  color: var(--color-primary);
  position: absolute;
  left: -0.5em;
  top: -0.2em;
  font-family: serif;
}

.lore__quote cite {
  font-size: var(--font-size-lg);
  color: var(--color-accent);
  font-weight: var(--font-weight-medium);
  font-style: normal;
}

/* Mission Section */
.mission {
  margin-top: var(--space-5xl);
  padding: var(--space-4xl) 0 var(--space-2xl);
  border-top: 1px solid var(--color-border);
}

.mission__inner {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.mission__title {
  font-size: var(--font-size-3xl);
  margin-bottom: var(--space-lg);
  letter-spacing: 0.02em;
}

.mission__text {
  font-size: var(--font-size-lg);
  color: var(--color-text-secondary);
  margin: 0 auto var(--space-xl);
  max-width: 720px;
}

.mission__pillars {
  list-style: none;
  display: grid;
  gap: var(--space-md);
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  padding: 0;
  margin: 0 0 var(--space-xl);
}

.mission__pillars li {
  background: var(--color-bg-secondary);
  padding: var(--space-md) var(--space-sm);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-sm);
  border: 1px solid var(--color-border);
}

.mission__actions {
  display: flex;
  gap: var(--space-lg);
  flex-wrap: wrap;
  justify-content: center;
}

/* Reduced motion explicit class */
body.motion-reduced * {
  animation: none !important;
  transition: none !important;
}

/* ========================================
   RESPONSIVE DESIGN
   ======================================== */

/* Mobile layout - gambar di atas text */
@media (max-width: 767px) {
  .hero {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-2xl);
    text-align: center;
    align-items: center;
  }

  .hero__visual {
    order: -1 !important; /* Pindahkan gambar ke atas */
    margin-bottom: var(--space-lg);
    width: 100%;
    display: flex;
    justify-content: center;
  }

  .hero__content {
    order: 1 !important;
    margin: 0 auto;
    text-align: center;
    width: 100%;
  }

  .hero__actions {
    justify-content: center;
  }

  /* Reset any desktop grid layouts */
  .section--home .hero {
    display: flex !important;
    flex-direction: column !important;
  }
}

@media (min-width: 480px) and (max-width: 767px) {
  .section__title {
    font-size: var(--font-size-7xl);
  }

  .hero__title {
    font-size: var(--font-size-8xl);
  }

  .lore__chapter {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
    text-align: center;
  }

  .lore__chapter-icon {
    justify-self: center;
  }
}

@media (min-width: 768px) {
  .section {
    padding: var(--space-5xl) 0;
  }

  .hero {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-5xl);
  }

  .hero__content { text-align:left; margin-left: clamp(1rem,6vw,6rem); margin-right:auto; }
  .hero.centered .hero__content { text-align:center; margin:0 auto; }
  .hero__title { font-size: var(--font-size-7xl); }

  .hero__actions {
    justify-content: flex-start;
  }

  .lore__chapter {
    grid-template-columns: auto 1fr;
    gap: var(--space-2xl);
  }

  .lore__chapter-icon {
    width: 100px;
    height: 100px;
  }

  .lore__icon {
    width: 80px;
    height: 80px;
  }
}

@media (min-width: 1024px) {
  .hero__snail { max-width: 500px; }
  .hero__title { font-size: var(--font-size-8xl); }
}

/* Utility */
.center-shift { margin-left: clamp(0rem,3vw,3rem); margin-right:auto; }

/* ========================================
   ANIMATIONS
   ======================================== */

@keyframes slideInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes snailEntrance {
  from {
    opacity: 0;
    transform: scale(0.8) rotate(-10deg);
  }
  to {
    opacity: 1;
    transform: scale(1) rotate(0deg);
  }
}
