* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { background: #faf7f0; min-height: 100%; }
body {
  font-family: "Times New Roman", Times, serif;
  color: #1a1a1a;
  line-height: 1.65;
  min-height: 100vh;
}
a { color: #7b3f00; }
a:hover { text-decoration: underline; }

.hero {
  background: #1a1a1a;
  color: #faf7f0;
  padding: 80px 24px 72px;
  border-bottom: 6px solid #b8925a;
  text-align: center;
}
.hero-inner { max-width: 820px; margin: 0 auto; }
.eyebrow {
  font-family: "Courier New", monospace;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #b8925a;
  font-size: 13px;
  margin: 0 0 14px;
}
.hero h1 {
  font-size: 72px;
  line-height: 0.95;
  margin: 0 0 22px;
  letter-spacing: -1.5px;
  font-weight: 700;
}
.tag {
  max-width: 600px;
  margin: 0 auto 32px;
  color: #d4cbb3;
  font-size: 18px;
  font-style: italic;
}
.cta-row { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

.btn {
  display: inline-block;
  padding: 14px 30px;
  font-family: "Courier New", monospace;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  text-decoration: none;
  border: 2px solid currentColor;
  transition: transform .15s, background .15s, color .15s;
}
.btn:hover { transform: translateY(-2px); text-decoration: none; }
.btn.primary { background: #b8925a; color: #1a1a1a; border-color: #b8925a; }
.btn.primary:hover { background: #d4ab6a; }
.btn.ghost { background: transparent; color: #faf7f0; }
.btn.ghost:hover { background: #faf7f0; color: #1a1a1a; }
.btn.huge { padding: 20px 40px; font-size: 16px; margin-top: 10px; }

.page { max-width: 780px; margin: 0 auto; padding: 64px 24px; }

.image-block { margin: 0 0 72px; }
.image-block figure { margin: 0; border: 1px solid #e0d9c2; padding: 12px; background: #fff; box-shadow: 0 12px 36px rgba(0,0,0,0.12); }
.image-block img { display: block; width: 100%; height: auto; }
.image-block figcaption { font-size: 13px; font-style: italic; color: #7a7060; padding: 10px 2px 2px; text-align: center; }

.step { margin: 0 0 72px; position: relative; padding-left: 78px; }
.step-num {
  position: absolute;
  left: 0; top: -6px;
  font-family: "Courier New", monospace;
  font-size: 48px;
  color: #b8925a;
  font-weight: 700;
}
.step h2 {
  font-size: 34px;
  margin: 0 0 14px;
  letter-spacing: -0.5px;
}
.step p, .buy-block p { font-size: 18px; color: #2a2520; margin: 0 0 18px; }
.step .quiet { font-size: 15px; color: #7a7060; font-style: italic; }

.list { padding-left: 22px; margin: 0 0 18px; font-size: 18px; }
.list li { margin: 0 0 10px; }

.buy-block {
  text-align: center;
  background: #fff;
  border: 2px solid #1a1a1a;
  padding: 56px 32px;
  margin: 96px 0 48px;
}
.buy-block .eyebrow { color: #1a1a1a; }
.buy-block h2 {
  font-size: 56px;
  margin: 8px 0 18px;
  letter-spacing: -1px;
}
.buy-block p { max-width: 560px; margin: 0 auto 20px; }
.ca {
  font-family: "Courier New", monospace;
  font-size: 13px;
  color: #7a7060;
  margin-top: 22px !important;
}
.ca span { color: #1a1a1a; }

.site-footer {
  background: #1a1a1a;
  color: #b8925a;
  padding: 36px 20px;
  text-align: center;
  font-family: "Courier New", monospace;
}
.site-footer p { margin: 4px 0; font-size: 13px; letter-spacing: 1px; }
.site-footer .tiny { color: #5a503a; font-size: 11px; }

@media (max-width: 720px) {
  .hero { padding: 56px 20px 48px; }
  .hero h1 { font-size: 48px; }
  .page { padding: 44px 20px; }
  .step { padding-left: 0; }
  .step-num { position: static; font-size: 36px; display: block; margin-bottom: 4px; }
  .step h2 { font-size: 28px; }
  .buy-block h2 { font-size: 40px; }
}
