/* buy.quillborne.app — dark "ink & parchment" theme. */
:root {
  --bg: #14120f;
  --bg-raised: #1d1a16;
  --ink: #ece5d8;
  --ink-muted: #a89f8e;
  --accent: #d4a437;
  --accent-ink: #1a1505;
  --line: #2e2922;
  --error: #e06c5a;
  --ok: #7fb069;
}

* { box-sizing: border-box; }
html { color-scheme: dark; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font: 16px/1.6 "Segoe UI", system-ui, -apple-system, sans-serif;
}
h1, h2, h3 { font-family: Georgia, "Iowan Old Style", "Times New Roman", serif; line-height: 1.15; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.nav {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px clamp(20px, 6vw, 72px);
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: center; gap: 10px; color: var(--ink); font-weight: 600; font-size: 18px; }
.brand img { border-radius: 6px; }

main { padding: 0 clamp(20px, 6vw, 72px); }
main.narrow { max-width: 640px; margin: 48px auto 80px; padding: 0 20px; }

.hero {
  display: grid; grid-template-columns: minmax(320px, 1fr) minmax(320px, 1fr);
  gap: 48px; align-items: center; padding: clamp(40px, 8vh, 96px) 0 64px;
}
@media (max-width: 900px) { .hero { grid-template-columns: 1fr; } }
.hero h1 { font-size: clamp(34px, 5vw, 56px); margin: 0 0 16px; }
.hero .sub { color: var(--ink-muted); font-size: 18px; max-width: 46ch; }

.cta-card {
  margin-top: 28px; padding: 24px 28px; max-width: 460px;
  background: var(--bg-raised); border: 1px solid var(--line); border-radius: 14px;
}
.cta-card h3 { margin: 0 0 6px; font-size: 22px; }
.price { margin: 0 0 14px; color: var(--ink-muted); }
.price strong { color: var(--ink); font-size: 30px; }
.price.coming-soon { color: var(--accent); font-size: 20px; }
.cta-card form { display: flex; flex-direction: column; gap: 10px; }
.cta-card label { font-size: 13px; color: var(--ink-muted); }
.cta-card input {
  padding: 12px 14px; border-radius: 8px; border: 1px solid var(--line);
  background: var(--bg); color: var(--ink); font-size: 16px;
}
.cta-card button, .button-link {
  display: inline-block; padding: 12px 22px; border: 0; border-radius: 8px;
  background: var(--accent); color: var(--accent-ink); font-weight: 700; font-size: 16px;
  cursor: pointer; text-align: center;
}
.cta-card button:hover, .button-link:hover { filter: brightness(1.08); text-decoration: none; }
.fine { font-size: 13px; color: var(--ink-muted); margin-bottom: 0; }
.alt-platform { font-size: 14px; margin-top: 14px; }
.notice { padding: 10px 14px; border-radius: 8px; background: #243024; color: var(--ok); font-size: 14px; }
.notice.error { background: #332019; color: var(--error); }

/* CSS mockup of the editor until real screenshots land in buy/public/images. */
.window-frame { border: 1px solid var(--line); border-radius: 12px; overflow: hidden; background: var(--bg-raised); box-shadow: 0 24px 60px rgba(0,0,0,.45); }
.window-bar { display: flex; gap: 7px; padding: 11px 14px; border-bottom: 1px solid var(--line); }
.window-bar span { width: 11px; height: 11px; border-radius: 50%; background: #3a352d; }
.window-body { display: grid; grid-template-columns: 170px 1fr; min-height: 330px; }
.mock-tree { border-right: 1px solid var(--line); padding: 14px 0; font-size: 12.5px; color: var(--ink-muted); }
.mock-node { padding: 5px 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mock-node.strong { color: var(--ink); font-weight: 600; }
.mock-node.indent { padding-left: 26px; }
.mock-node.indent2 { padding-left: 40px; }
.mock-node.active { color: var(--accent); background: rgba(212,164,55,.08); }
.mock-page { padding: 28px 32px; background: #181511; }
.mock-line { height: 9px; border-radius: 4px; background: #2c2820; margin: 0 0 11px; }
.mock-line.gap { margin-top: 22px; }
.w100 { width: 100%; } .w95 { width: 95%; } .w92 { width: 92%; } .w90 { width: 90%; }
.w85 { width: 85%; } .w60 { width: 60%; } .w40 { width: 40%; }

.features { padding: 48px 0 24px; }
.features h2, .pricing h2 { font-size: clamp(26px, 3.4vw, 36px); }
.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 18px; }
.feature { background: var(--bg-raised); border: 1px solid var(--line); border-radius: 12px; padding: 18px 20px; }
.feature h4 { margin: 0 0 8px; font-size: 16px; color: var(--accent); }
.feature p { margin: 0; color: var(--ink-muted); font-size: 14.5px; }

.pricing { text-align: center; padding: 56px 0 80px; }
.pricing .sub { color: var(--ink-muted); }

.license-box {
  display: flex; align-items: center; gap: 14px; margin: 22px 0;
  padding: 18px 20px; background: var(--bg-raised); border: 1px solid var(--accent); border-radius: 12px;
}
.license-box code { font-size: 19px; letter-spacing: 1.5px; word-break: break-all; color: var(--accent); }
.license-box.compact { border-color: var(--line); }
.license-box.compact code { font-size: 15px; }
.license-box button {
  padding: 8px 16px; border: 1px solid var(--accent); border-radius: 8px;
  background: transparent; color: var(--accent); cursor: pointer; flex-shrink: 0;
}
.status { margin-left: auto; font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--ink-muted); }
.status.active { color: var(--ok); }
.status.expired, .status.canceled { color: var(--error); }

.steps { color: var(--ink-muted); }
.steps li { margin-bottom: 8px; }
.recover-form { display: flex; gap: 10px; margin: 20px 0; }
.recover-form input { flex: 1; padding: 12px 14px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg-raised); color: var(--ink); font-size: 16px; }
.recover-form button { padding: 12px 22px; border: 0; border-radius: 8px; background: var(--accent); color: var(--accent-ink); font-weight: 700; cursor: pointer; }

.spinner { width: 28px; height: 28px; margin: 28px 0; border: 3px solid var(--line); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.9s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

.footer { border-top: 1px solid var(--line); margin-top: 40px; padding: 22px clamp(20px, 6vw, 72px); color: var(--ink-muted); font-size: 13.5px; }
