/* LymeScribe — transcribe.lymestack.com
   Aesthetic: "off-grid study" — warm near-black, paper text, lime accent.
   Type: Fraunces (display serif) / Archivo (body) / IBM Plex Mono (machine voice). */

:root {
  --ink: #0e100a;          /* page ground — near-black with a green undertone */
  --ink-2: #14170e;        /* raised panels */
  --ink-3: #1b1f12;        /* hover / inset */
  --paper: #ece8da;        /* primary text — warm paper */
  --paper-dim: #98987f;    /* secondary text */
  --lime: #c6f04d;         /* the accent. used sparingly, lands hard */
  --lime-dim: #8aa83a;
  --rule: #2a2e1d;         /* hairlines */
  --max: 1120px;
  --font-display: "Fraunces", "Iowan Old Style", Georgia, serif;
  --font-body: "Archivo", "Helvetica Neue", sans-serif;
  --font-mono: "IBM Plex Mono", "SF Mono", Menlo, monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}

/* film grain over everything */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 999;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
}

::selection { background: var(--lime); color: var(--ink); }

a { color: inherit; }

/* ---------- shared layout ---------- */

.wrap { max-width: var(--max); margin: 0 auto; padding: 0 28px; }

.mono {
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--paper-dim);
}

.kicker {
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--lime);
  display: block;
  margin-bottom: 18px;
}

h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(34px, 4.6vw, 54px);
  line-height: 1.06;
  letter-spacing: -0.015em;
}

h2 em, h1 em {
  font-style: italic;
  color: var(--lime);
}

section { padding: 110px 0; border-top: 1px solid var(--rule); }

/* ---------- header ---------- */

header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--ink) 88%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--rule);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}

.wordmark {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 600;
  font-size: 23px;
  text-decoration: none;
  letter-spacing: -0.01em;
}

.wordmark .dot { color: var(--lime); font-style: normal; }

.wordmark small {
  font-family: var(--font-mono);
  font-style: normal;
  font-weight: 400;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--paper-dim);
  margin-left: 10px;
  vertical-align: 2px;
}

.nav-links { display: flex; align-items: center; gap: 30px; }

.nav-links a {
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--paper-dim);
  transition: color 0.15s;
}

.nav-links a:hover { color: var(--paper); }

.btn {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 13px 26px;
  border: 1px solid var(--lime);
  color: var(--lime);
  background: transparent;
  transition: background 0.15s, color 0.15s, transform 0.15s;
  cursor: pointer;
}

.btn:hover { background: var(--lime); color: var(--ink); transform: translateY(-1px); }

.btn-solid { background: var(--lime); color: var(--ink) !important; }

.btn-solid:hover { background: #d8ff63; }

.nav-links .btn { padding: 9px 18px; font-size: 12px; }

/* ---------- hero ---------- */

.hero { padding: 96px 0 80px; border-top: none; position: relative; }

/* faint topographic rings behind the hero */
.hero::before {
  content: "";
  position: absolute;
  top: -340px;
  right: -280px;
  width: 900px;
  height: 900px;
  border-radius: 50%;
  background: repeating-radial-gradient(circle at center,
    transparent 0 70px,
    color-mix(in srgb, var(--lime) 7%, transparent) 70px 71px);
  pointer-events: none;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 64px;
  align-items: center;
  position: relative;
}

.badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--paper-dim);
  border: 1px solid var(--rule);
  padding: 7px 14px;
  border-radius: 99px;
  margin-bottom: 30px;
}

.badge::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 10px var(--lime);
  animation: pulse 2.2s ease-in-out infinite;
}

@keyframes pulse { 50% { opacity: 0.35; } }

h1 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(42px, 5.4vw, 68px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin-bottom: 26px;
}

.hero p.lede {
  font-size: 19px;
  color: var(--paper-dim);
  max-width: 30em;
  margin-bottom: 38px;
}

.hero p.lede strong { color: var(--paper); font-weight: 600; }

.hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }

.hero-fineprint {
  margin-top: 22px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--paper-dim);
  letter-spacing: 0.04em;
}

/* the app window */
.appwin {
  background: var(--ink-2);
  border: 1px solid var(--rule);
  border-radius: 10px;
  box-shadow: 0 40px 80px -30px rgba(0, 0, 0, 0.7),
              0 0 0 1px rgba(0, 0, 0, 0.4);
  overflow: hidden;
  transform: rotate(0.6deg);
}

.appwin-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 14px;
  border-bottom: 1px solid var(--rule);
}

.appwin-bar i {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--ink-3);
  border: 1px solid var(--rule);
}

.appwin-bar span {
  margin-left: 8px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  color: var(--paper-dim);
}

.appwin-body { padding: 26px 24px 22px; }

.wave {
  display: flex;
  align-items: center;
  gap: 4px;
  height: 44px;
  margin-bottom: 22px;
}

.wave b {
  width: 4px;
  border-radius: 2px;
  background: var(--lime);
  height: 100%;
  animation: wave 0.9s ease-in-out infinite alternate;
}

@keyframes wave {
  from { transform: scaleY(0.15); opacity: 0.55; }
  to   { transform: scaleY(1);    opacity: 1; }
}

.typeline {
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--paper);
  white-space: nowrap;
  overflow: hidden;
  border-right: 2px solid var(--lime);
  width: 38ch;
  max-width: 100%;
  animation: type 4s steps(38) 0.8s both, caret 0.9s step-end infinite;
  margin-bottom: 26px;
}

@keyframes type { from { width: 0; } to { width: 38ch; } }
@keyframes caret { 50% { border-color: transparent; } }

.appwin-stats {
  border-top: 1px dashed var(--rule);
  padding-top: 16px;
  display: grid;
  gap: 7px;
}

.appwin-stats div {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--paper-dim);
}

.appwin-stats div b { font-weight: 400; color: var(--paper); }

.appwin-stats .zero b {
  color: var(--lime);
  text-shadow: 0 0 14px color-mix(in srgb, var(--lime) 50%, transparent);
}

/* ---------- ticker ---------- */

.ticker {
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  overflow: hidden;
  padding: 13px 0;
  background: var(--ink-2);
}

.ticker-track {
  display: flex;
  width: max-content;
  animation: tick 36s linear infinite;
}

.ticker-track span {
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--paper-dim);
  white-space: nowrap;
  padding-right: 3.5em;
}

.ticker-track span i { color: var(--lime); font-style: normal; }

@keyframes tick { to { transform: translateX(-50%); } }

/* ---------- two doors ---------- */

.doors-lede {
  font-size: 18px;
  color: var(--paper-dim);
  max-width: 46em;
  margin-top: 22px;
}

.doors-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-top: 56px;
}

.door {
  border: 1px solid var(--rule);
  background: var(--ink-2);
  padding: 34px 32px 36px;
  display: flex;
  flex-direction: column;
  position: relative;
}

.door-tag {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--lime);
  display: block;
  margin-bottom: 18px;
}

.door h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 27px;
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin-bottom: 12px;
}

.door-one {
  font-size: 16px;
  color: var(--paper);
  margin-bottom: 24px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--rule);
}

.door ul { list-style: none; margin-bottom: 30px; flex: 1; }

.door li {
  font-size: 14.5px;
  color: var(--paper-dim);
  padding: 7px 0 7px 24px;
  position: relative;
}

.door li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--lime);
  font-family: var(--font-mono);
  font-size: 13px;
}

.door .btn { align-self: flex-start; }

/* ---------- cloud problem / ledger ---------- */

.split {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 70px;
  align-items: start;
}

.split .prose p { color: var(--paper-dim); margin-top: 22px; max-width: 32em; }

.split .prose p strong { color: var(--paper); }

.ledger {
  border: 1px solid var(--rule);
  background: var(--ink-2);
}

.ledger-head, .ledger-row {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  border-bottom: 1px solid var(--rule);
}

.ledger-row:last-child { border-bottom: none; }

.ledger-head div {
  padding: 14px 18px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--paper-dim);
}

.ledger-head div:last-child { color: var(--lime); }

.ledger-row div {
  padding: 17px 18px;
  font-size: 15px;
  border-left: 1px solid var(--rule);
}

.ledger-row div:first-child {
  border-left: none;
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--paper-dim);
  display: flex;
  align-items: center;
}

.ledger-row .them { color: var(--paper-dim); }
.ledger-row .us { color: var(--paper); background: color-mix(in srgb, var(--lime) 4%, transparent); }

.ledger-head div { border-left: 1px solid var(--rule); }
.ledger-head div:first-child { border-left: none; }

/* ---------- features ---------- */

.feat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
  margin-top: 60px;
}

.feat {
  background: var(--ink);
  padding: 34px 28px 38px;
  transition: background 0.2s;
}

.feat:hover { background: var(--ink-3); }

.feat .num {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--lime);
  letter-spacing: 0.1em;
  display: block;
  margin-bottom: 40px;
}

.feat h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.01em;
  margin-bottom: 12px;
}

.feat p { font-size: 15px; color: var(--paper-dim); }

/* ---------- pricing ---------- */

.price-lede {
  font-size: 18px;
  color: var(--paper-dim);
  max-width: 44em;
  margin-top: 22px;
}

.price-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 56px;
  align-items: stretch;
}

.plan-line {
  font-size: 14px;
  color: var(--paper);
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--rule);
  min-height: 3.4em;
}

.plan {
  border: 1px solid var(--rule);
  background: var(--ink-2);
  padding: 36px 30px;
  display: flex;
  flex-direction: column;
  position: relative;
}

.plan.hot {
  border-color: var(--lime);
  box-shadow: 0 0 0 1px var(--lime), 0 30px 60px -30px color-mix(in srgb, var(--lime) 25%, transparent);
}

.plan .tag {
  position: absolute;
  top: -11px;
  left: 28px;
  background: var(--lime);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 10px;
  font-weight: 600;
}

.plan h3 {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 400;
  color: var(--paper-dim);
  margin-bottom: 14px;
}

.plan .price {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 52px;
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}

.plan .price s {
  font-size: 24px;
  color: var(--paper-dim);
  text-decoration-color: color-mix(in srgb, var(--lime) 70%, transparent);
  text-decoration-thickness: 2px;
  margin-right: 10px;
  vertical-align: 14px;
}

.plan .per {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--paper-dim);
  margin-bottom: 28px;
}

.plan ul { list-style: none; margin-bottom: 32px; flex: 1; }

.plan li {
  font-size: 14.5px;
  color: var(--paper-dim);
  padding: 8px 0 8px 24px;
  border-bottom: 1px dashed var(--rule);
  position: relative;
}

.plan li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--lime);
  font-family: var(--font-mono);
  font-size: 13px;
}

.plan li strong { color: var(--paper); font-weight: 500; }

.plan .btn { text-align: center; }

.price-note {
  margin-top: 26px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--paper-dim);
  letter-spacing: 0.04em;
  text-align: center;
}

.price-note a { color: var(--paper-dim); }

/* ---------- download ---------- */

.dl-panel {
  border: 1px solid var(--rule);
  background:
    radial-gradient(ellipse 70% 120% at 50% -20%, color-mix(in srgb, var(--lime) 8%, transparent), transparent),
    var(--ink-2);
  padding: 70px 40px;
  text-align: center;
  margin-top: 54px;
}

.dl-panel h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 34px;
  letter-spacing: -0.015em;
  margin-bottom: 12px;
}

.dl-panel > p { color: var(--paper-dim); margin-bottom: 34px; }

.dl-ctas {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 26px;
}

.btn-ghost {
  border-color: var(--rule);
  color: var(--paper-dim);
  cursor: default;
}

.btn-ghost:hover { background: transparent; color: var(--paper-dim); transform: none; }

.dl-meta {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--paper-dim);
  letter-spacing: 0.05em;
  display: flex;
  gap: 26px;
  justify-content: center;
  flex-wrap: wrap;
}

.dl-meta span::before { content: "· "; color: var(--lime); }

/* ---------- faq ---------- */

.faq { max-width: 760px; margin: 54px auto 0; }

details {
  border-bottom: 1px solid var(--rule);
}

details summary {
  cursor: pointer;
  list-style: none;
  padding: 24px 40px 24px 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 21px;
  letter-spacing: -0.01em;
  position: relative;
  transition: color 0.15s;
}

details summary::-webkit-details-marker { display: none; }

details summary::after {
  content: "+";
  position: absolute;
  right: 4px;
  top: 22px;
  font-family: var(--font-mono);
  font-size: 22px;
  color: var(--lime);
  transition: transform 0.2s;
}

details[open] summary::after { transform: rotate(45deg); }

details summary:hover { color: var(--lime); }

details p {
  padding: 0 40px 26px 0;
  color: var(--paper-dim);
  font-size: 15.5px;
}

details p a { color: var(--paper); }

/* ---------- footer ---------- */

footer {
  border-top: 1px solid var(--rule);
  padding: 60px 0 50px;
  background: var(--ink-2);
}

.foot-grid {
  display: flex;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
  align-items: flex-start;
}

.foot-grid .wordmark { font-size: 20px; }

.foot-links {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
}

.foot-links a {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--paper-dim);
  text-decoration: none;
}

.foot-links a:hover { color: var(--paper); }

.foot-fine {
  margin-top: 36px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--paper-dim);
  letter-spacing: 0.04em;
  line-height: 2;
}

/* ---------- legal pages ---------- */

.legal {
  max-width: 720px;
  margin: 0 auto;
  padding: 80px 28px 110px;
}

.legal h1 { font-size: clamp(34px, 4.5vw, 48px); margin-bottom: 10px; }

.legal .updated {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--paper-dim);
  display: block;
  margin-bottom: 44px;
}

.legal h2 {
  font-size: 24px;
  margin: 44px 0 14px;
}

.legal h3 {
  font-size: 18px;
  color: var(--paper);
  margin: 26px 0 10px;
}

.legal p, .legal li { color: var(--paper-dim); font-size: 16px; margin-bottom: 14px; }

.legal ul { padding-left: 22px; margin-bottom: 14px; }

.legal strong { color: var(--paper); }

.legal a { color: var(--paper); }

/* ---------- reveal on scroll ---------- */

[data-reveal] {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity 0.7s cubic-bezier(0.2, 0.7, 0.2, 1), transform 0.7s cubic-bezier(0.2, 0.7, 0.2, 1);
}

[data-reveal].in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  [data-reveal] { opacity: 1; transform: none; }
  .typeline { width: 38ch; }
}

/* ---------- responsive ---------- */

@media (max-width: 960px) {
  .hero-grid, .split { grid-template-columns: 1fr; gap: 48px; }
  .feat-grid { grid-template-columns: 1fr; }
  .price-grid { grid-template-columns: 1fr; }
  .doors-grid { grid-template-columns: 1fr; }
  .plan-line { min-height: 0; }
  .nav-links a:not(.btn) { display: none; }
  section { padding: 80px 0; }
  .appwin { transform: none; }
  .ledger-head div, .ledger-row div { padding: 12px 12px; font-size: 13.5px; }
}
