* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--shadow);
  color: var(--ink);
  font-family: 'Crimson Pro', Georgia, serif;
  font-size: 18px;
  overflow-x: hidden;
}

.btn {
  font-family: 'Cinzel', serif; font-size: 0.9rem; letter-spacing: 0.15em;
  text-transform: uppercase; padding: 0.9rem 2rem; border: none; cursor: pointer;
  text-decoration: none; display: inline-block; transition: all 0.3s ease;
  position: relative; overflow: hidden;
}
.btn-primary {
  background: linear-gradient(135deg, var(--blood), #6b1414);
  color: var(--gold-light);
  clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
  box-shadow: 0 4px 20px rgba(139,26,26,0.4);
}
.btn-primary:hover {
  background: linear-gradient(135deg, #a02020, var(--blood));
  box-shadow: 0 4px 30px rgba(139,26,26,0.7); transform: translateY(-2px);
}
.btn-secondary {
  background: transparent; color: var(--gold);
  border: 1px solid rgba(201,146,42,0.4);
  clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
}
.btn-secondary:hover {
  background: rgba(201,146,42,0.1); border-color: var(--gold); transform: translateY(-2px);
}

/* Scroll Reveal Animations */
.reveal-element {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}
.reveal-element.revealed {
  opacity: 1;
  transform: translateY(0);
}
.reveal-element:nth-child(2) { transition-delay: 0.1s; }
.reveal-element:nth-child(3) { transition-delay: 0.2s; }
.reveal-element:nth-child(4) { transition-delay: 0.3s; }

/* Section animations */
.section-parchment .section-header,
.section-dark .section-header {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.section-parchment .section-header.revealed,
.section-dark .section-header.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Lore block animation */
.lore-block {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.lore-block.revealed {
  opacity: 1;
  transform: translateY(0);
}
