diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
new file mode 100644
index 00000000..184b651f
--- /dev/null
+++ b/CONTRIBUTING.md
@@ -0,0 +1,141 @@
+# Contributing
+
+Thanks for taking interest in helping us develop Grackle! If you want to contribute to the project, you can find some
+helpful information here.
+
+We welcome all kinds of contribution, including but not limited to,
+
+- documentation improvements, explanatory images/diagrams, fixes in typos, useful links
+- refactorings of messy code, build structure, increasing test coverage or quality
+- new features and bugfixes (including [bug reports and feature requests][grackle-issues]).
+
+Writing documentation is valuable for learning, so if you find some explanation insufficient, overly complicated or
+incorrect, it's a perfect opportunity to make a change to it!
+
+If at any point you run into problems, you can always ask a question on the **#grackle** channel on the Typelevel
+[discord server][grackle-dev].
+
+## How to submit a change
+
+If you see something worth adding, make the relevant changes in a fork of the source code and submit a [pull
+request][grackle-pulls] to the project. If you don't know what you could help with, take a look at [the issues marked
+as "good first issue"][first-issues] or ask on [discord][grackle-dev].
+
+Any contributions are expected to be made in the form of pull requests to the Grackle [repository][grackle-pulls].
+Usually it takes one approval for a change to be merged. If it takes too long to get it approved, feel free to ask on
+[Discord][grackle-dev].
+
+Grackle is licensed under the Apache Software License 2.0. Opening a pull request is to be considered affirmative
+consent to incorporate your changes into the project, granting an unrestricted license to Typelevel to distribute and
+derive new work from your changes, as per the contribution terms of ASL 2.0. You also affirm that you own the rights
+to the code you are contributing. All contributors retain the copyright to their own work.
+
+Remember to follow the [code of conduct][coc] in online and offline discourse.
+
+## Building the project locally
+
+### Prerequisites
+
+You'll need JDK 11+, [sbt][sbt], [Docker][docker] (for running DB tests) and [Node.js][node] (for running Scala.js
+tests).
+
+We use several sbt plugins to build and check the project, including [MiMa (Migration Manager)][mima] and. The
+[sbt-typelevel](https://typelevel.org/sbt-typelevel/) plugin does the bulk of the SBT configuration.
+
+### Build process
+
+To compile the code for the whole repository, you can start an interactive sbt shell:
+
+```bash
+% sbt
+[info] welcome to sbt 1.9.7 (GraalVM Community Java 17.0.8)
+[info] loading settings for project global-plugins from sbt-updates.sbt ...
+[info] loading global plugins from /home/miles/.sbt/1.0/plugins
+[info] loading settings for project grackle-build-build-build-build from metals.sbt ...
+[info] loading project definition from /home/miles/projects/grackle/project/project/project/project
+[info] loading settings for project grackle-build-build-build from metals.sbt ...
+[info] loading project definition from /home/miles/projects/grackle/project/project/project
+[success] Generated .bloop/grackle-build-build-build.json
+[success] Total time: 2 s, completed 25 Oct 2023, 12:55:45
+[info] loading settings for project grackle-build-build from metals.sbt,plugins.sbt ...
+[info] loading project definition from /home/miles/projects/grackle/project/project
+[success] Generated .bloop/grackle-build-build.json
+[success] Total time: 1 s, completed 25 Oct 2023, 12:55:46
+[info] loading settings for project grackle-build from metals.sbt,plugins.sbt ...
+[info] loading project definition from /home/miles/projects/grackle/project
+[info] loading settings for project root from build.sbt ...
+[info] resolving key references (29638 settings) ...
+[info] set scmInfo to https://github.com/typelevel/grackle
+[info] set current project to root (in build file:/home/miles/projects/grackle/)
+[info] sbt server started at local:///home/miles/.sbt/1.0/server/9b2532ef9aeebb6c666d/sock
+[info] started sbt server
+sbt:root>
+```
+
+Inside the shell, you can compile the sources for the currently selected Scala version using the `compile` command. To
+compile the code for all Scala versions enabled in the build, use `+compile`. To include tests, `Test/compile` or
+`+Test/compile`, accordingly.
+
+
+### Testing
+
+To test the code, you can run the `test` command in sbt. If you want the tests on a single platform, you can use
+`rootJVM/test`, `rootJS/test`, or `rootNative/test` instead.
+
+It is possible to run a single test suite from a project on a single platform by [executing a more specific
+task](https://www.scala-sbt.org/1.x/docs/Testing.html#testOnly), like `coreJVM/testOnly compiler.ScalarsSuite`.
+
+You can list all available projects by executing the `projects` task:
+
+```sbt
+sbt:root> projects
+[info] In file:/home/miles/projects/grackle/
+[info] benchmarks
+[info] buildInfoJS
+[info] buildInfoJVM
+[info] buildInfoNative
+[info] circeJS
+[info] circeJVM
+[info] circeNative
+[info] coreJS
+[info] coreJVM
+[info] coreNative
+[info] demo
+[info] docs
+[info] doobie
+[info] genericJS
+[info] genericJVM
+[info] genericNative
+[info] profile
+[info] * root
+[info] rootJS
+[info] rootJVM
+[info] rootNative
+[info] skunkJS
+[info] skunkJVM
+[info] skunkNative
+[info] sqlJS
+[info] sqlJVM
+[info] sqlNative
+[info] unidocs
+```
+
+Before submitting a change for review, it's worth running some extra checks that will be triggered in Continuous
+Integration:
+
+```sbt
+sbt:root> prePR
+```
+
+If you run into any problems with tests, binary compatibility or other issues, feel free to ask questions on
+[discord][grackle-dev].
+
+[grackle-issues]: https://github.com/typelevel/grackle/issues
+[grackle-pulls]: https://github.com/typelevel/grackle/pulls
+[grackle-dev]: https://discord.gg/GYD4J9w8EK
+[coc]: https://github.com/typelevel/grackle/blob/main/CODE_OF_CONDUCT.md
+[sbt]: https://www.scala-sbt.org
+[mima]: https://github.com/lightbend/mima
+[first-issues]: https://github.com/typelevel/grackle/issues?q=is%3Aopen+is%3Aissue+label%3A%22good+first+issue%22
+[docker]: https://www.docker.com/
+[node]: https://nodejs.org/en/
diff --git a/README.md b/README.md
index e098fa20..219bf34f 100644
--- a/README.md
+++ b/README.md
@@ -1,31 +1,92 @@
-# Grackle - Functional GraphQL for the Typelevel stack
+# Grackle - GraphQL for the Typelevel stack
[![Build Status](https://github.com/typelevel/grackle/workflows/Continuous%20Integration/badge.svg?branch=main)](https://github.com/typelevel/grackle/actions?query=branch%3Amain+workflow%3A%22Continuous+Integration%22)
[![Maven Central](https://img.shields.io/maven-central/v/org.typelevel/grackle-core_2.13?versionPrefix=0)](https://img.shields.io/maven-central/v/org.typelevel/grackle-core_2.13?versionPrefix=0)
[![javadoc](https://javadoc.io/badge2/org.typelevel/grackle-core_2.13/javadoc.svg)](https://javadoc.io/doc/org.typelevel/grackle-core_2.13)
[![Typelevel library](https://img.shields.io/badge/typelevel-library-green.svg)](https://typelevel.org/projects/#grackle)
-[![Discord](https://img.shields.io/discord/632277896739946517.svg?label=&logo=discord&logoColor=ffffff&color=404244&labelColor=6A7EC2)](https://discord.gg/GYD4J9w8EK)
-
+[![Discord](https://img.shields.io/discord/632277896739946517.svg?label=&logo=discord&logoColor=ffffff&color=404244&labelColor=6A7EC2)][grackle-dev]
## Overview
-* Grackle is a [GraphQL](https://graphql.org/) server implementation for [Scala](https://www.scala-lang.org).
-* Grackle is powered by [cats](http://typelevel.org/cats/), [cats-effect](https://typelevel.org/cats-effect/), and
- [circe](https://circe.github.io/circe/).
+Grackle is a [GraphQL](https://graphql.org) server written in functional [Scala](https://www.scala-lang.org), built on
+the [Typelevel](https://typelevel.org) stack.
-## How to Learn
+It's powered by [cats](https://typelevel.org/cats), [cats-effect](https://typelevel.org/cats-effect/),
+[fs2](https://github.com/typelevel/fs2) and [http4s](https://http4s.org/), and supports GraphQL queries, mutations and
+subscriptions.
-* See the [tutorial](https://typelevel.org/grackle)
+It has an abstract model of data sources implemented in terms of declarative mappings between GraphQL schemas and
+backing data, and cursors into that data. It supports in-memory, DB-backed, and effectful data sources.
-## How to Contribute
+Grackle is structured as a compiler/interpreter. Queries are type-checked against a GraphQL schema and compiled into
+an internal query algebra. The query algebra may be further compiled in a backend-specific way to materialize data. In
+particular it can be compiled to efficient SQL and in that regard currently supports Postgres via
+[Doobie](https://tpolecat.github.io/doobie/) or [Skunk](https://typelevel.org/skunk/).
-- Test it out!
-- If you find a bug, open an issue (or fix it and open a PR) at our [GitHub
- Repository](https://github.com/typelevel/grackle).
-- If you want to make a larger contribution please open an issue first so we can discuss.
+Grackle is an [Apache 2.0 licensed](https://www.apache.org/licenses/LICENSE-2.0) Typelevel project and is available
+for Scala 2/3 and for [Scala.js](https://www.scala-js.org/) and [Scala Native](https://scala-native.org/en/stable/).
-## Code of Conduct
+Work has been generously sponsored by
+[Aura/Gemini](https://www.aura-astronomy.org/centers/nsfs-oir-lab/gemini-observatory/) and [ITV](https://itv.com) over
+the last four years.
+
+## Getting Started
+
++ See the [tutorial](https://typelevel.org/grackle) and accompanying [demo](https://github.com/typelevel/grackle/tree/main/demo/src/main).
++ Online Scaladoc is available [here](https://javadoc.io/doc/org.typelevel/grackle-core_2.13).
++ Ask us anything the in **#grackle** channel on the Typelevel [discord server][grackle-dev].
+
+To add Grackle to your project you should add the following to your `build.sbt`,
+
+```scala
+// Required: Scala 2.13/3.3+
+libraryDependencies += "org.typelevel" %% "grackle-core" % "0.15.0"
+
+// Optional: support for in-memory Json backend using circe
+libraryDependencies += "org.typelevel" %% "grackle-circe" % "0.15.0"
+
+// Optional: support for in-memory generic Scala backend using shapeless
+libraryDependencies += "org.typelevel" %% "grackle-generic" % "0.15.0"
+
+// Optional: support for Postgres backend via Doobie (JVM only)
+libraryDependencies += "org.typelevel" %% "grackle-doobie-pg" % "0.15.0"
+
+// Optional: support for Postgres backend via Skunk
+libraryDependencies += "org.typelevel" %% "grackle-skunk" % "0.15.0"
+```
+
+## Community
Grackle is proud to be a [Typelevel](https://typelevel.org/) project. We are committed to providing a friendly, safe
and welcoming environment for all, and ask that the community adhere to the [Scala Code of
-Conduct](https://www.scala-lang.org/conduct/).
+Conduct](https://www.scala-lang.org/conduct/) in all venues.
+
+Conversations around Grackle are currently happening on [GitHub issues][grackle-issues], [PR
+discussions][grackle-pulls], and [discord][grackle-dev].
+
+The Typelevel [discord][grackle-dev] has a **#grackle** channel, as well as channels for related
+projects channels such as **#cats**, **#cats-effect**, **#fs2**, **#doobie** and **#skunk**. If you're new to the Typelevel
+ecosystem the **#beginners** channel might also be useful. Please join us!
+
+## Contributing
+
+This project exists thanks to [all the people who
+contribute](https://github.com/typelevel/grackle/graphs/contributors).
+
+We welcome all kinds of contribution, including but not limited to,
+
+- documentation improvements, explanatory images/diagrams, fixes in typos, useful links
+- refactorings of messy code, build structure, increasing test coverage or quality
+- new features and bugfixes (including [bug reports and feature requests][grackle-issues]).
+
+Writing documentation is valuable for learning, so if you find some explanation insufficient, overly complicated or
+incorrect, it's a perfect opportunity to make a change to it!
+
+If at any point you run into problems, you can always ask a question on the **#grackle** channel on the Typelevel
+[discord server][grackle-dev].
+
+More information, including on how to build locally and submit pull requests, can be found [here](CONTRIBUTING.md).
+
+[grackle-issues]: https://github.com/typelevel/grackle/issues
+[grackle-pulls]: https://github.com/typelevel/grackle/pulls
+[grackle-dev]: https://discord.gg/GYD4J9w8EK
diff --git a/docs/CONTRIBUTING.md b/docs/CONTRIBUTING.md
new file mode 120000
index 00000000..44fcc634
--- /dev/null
+++ b/docs/CONTRIBUTING.md
@@ -0,0 +1 @@
+../CONTRIBUTING.md
\ No newline at end of file
diff --git a/docs/directory.conf b/docs/directory.conf
new file mode 100644
index 00000000..d5dc14e8
--- /dev/null
+++ b/docs/directory.conf
@@ -0,0 +1,4 @@
+laika.navigationOrder = [
+ index.md
+ CONTRIBUTING.md
+]
diff --git a/docs/index.md b/docs/index.md
index 3ba92272..5bb18ce5 100644
--- a/docs/index.md
+++ b/docs/index.md
@@ -2,23 +2,85 @@
## Overview
-* Grackle is a [GraphQL](https://graphql.org/) server implementation for [Scala](https://www.scala-lang.org).
-* Grackle is powered by [cats](http://typelevel.org/cats/), [cats-effect](https://typelevel.org/cats-effect/), and
- [circe](https://circe.github.io/circe/).
+Grackle is a [GraphQL](https://graphql.org) server written in functional [Scala](https://www.scala-lang.org), built on
+the [Typelevel](https://typelevel.org) stack.
-## How to Learn
+It's powered by [cats](https://typelevel.org/cats), [cats-effect](https://typelevel.org/cats-effect/),
+[fs2](https://github.com/typelevel/fs2) and [http4s](https://http4s.org/), and supports GraphQL queries, mutations and
+subscriptions.
-* See the [tutorial](tutorial/intro.md)
+It has an abstract model of data sources implemented in terms of declarative mappings between GraphQL schemas and
+backing data, and cursors into that data. It supports in-memory, DB-backed, and effectful data sources.
-## How to Contribute
+Grackle is structured as a compiler/interpreter. Queries are type-checked against a GraphQL schema and compiled into
+an internal query algebra. The query algebra may be further compiled in a backend-specific way to materialize data. In
+particular it can be compiled to efficient SQL and in that regard currently supports Postgres via
+[Doobie](https://tpolecat.github.io/doobie/) or [Skunk](https://typelevel.org/skunk/).
-- Test it out!
-- If you find a bug, open an issue (or fix it and open a PR) at our [GitHub
- Repository](https://github.com/typelevel/grackle).
-- If you want to make a larger contribution please open an issue first so we can discuss.
+Grackle is an [Apache 2.0 licensed](https://www.apache.org/licenses/LICENSE-2.0) Typelevel project and is available
+for Scala 2/3 and for [Scala.js](https://www.scala-js.org/) and [Scala Native](https://scala-native.org/en/stable/).
-## Code of Conduct
+Work has been generously sponsored by
+[Aura/Gemini](https://www.aura-astronomy.org/centers/nsfs-oir-lab/gemini-observatory/) and [ITV](https://itv.com) over
+the last four years.
+
+## Getting Started
+
++ See the [tutorial](https://typelevel.org/grackle) and accompanying [demo](https://github.com/typelevel/grackle/tree/main/demo/src/main).
++ Online Scaladoc is available [here](https://javadoc.io/doc/org.typelevel/grackle-core_2.13).
++ Ask us anything the in **#grackle** channel on the Typelevel [discord server][grackle-dev].
+
+To add Grackle to your project you should add the following to your `build.sbt`,
+
+```scala
+// Required: Scala 2.13/3.3+
+libraryDependencies += "org.typelevel" %% "grackle-core" % "0.15.0"
+
+// Optional: support for in-memory Json backend using circe
+libraryDependencies += "org.typelevel" %% "grackle-circe" % "0.15.0"
+
+// Optional: support for in-memory generic Scala backend using shapeless
+libraryDependencies += "org.typelevel" %% "grackle-generic" % "0.15.0"
+
+// Optional: support for Postgres backend via Doobie (JVM only)
+libraryDependencies += "org.typelevel" %% "grackle-doobie-pg" % "0.15.0"
+
+// Optional: support for Postgres backend via Skunk
+libraryDependencies += "org.typelevel" %% "grackle-skunk" % "0.15.0"
+```
+
+## Community
Grackle is proud to be a [Typelevel](https://typelevel.org/) project. We are committed to providing a friendly, safe
and welcoming environment for all, and ask that the community adhere to the [Scala Code of
-Conduct](https://www.scala-lang.org/conduct/).
+Conduct](https://www.scala-lang.org/conduct/) in all venues.
+
+Conversations around Grackle are currently happening on [GitHub issues][grackle-issues], [PR
+discussions][grackle-pulls], and [discord][grackle-dev].
+
+The Typelevel [discord][grackle-dev] has a **#grackle** channel, as well as channels for related
+projects channels such as **#cats**, **#cats-effect**, **#fs2**, **#doobie** and **#skunk**. If you're new to the Typelevel
+ecosystem the **#beginners** channel might also be useful. Please join us!
+
+## Contributing
+
+This project exists thanks to [all the people who
+contribute](https://github.com/typelevel/grackle/graphs/contributors).
+
+We welcome all kinds of contribution, including but not limited to,
+
+- documentation improvements, explanatory images/diagrams, fixes in typos, useful links
+- refactorings of messy code, build structure, increasing test coverage or quality
+- new features and bugfixes (including [bug reports and feature requests][grackle-issues]).
+
+Writing documentation is valuable for learning, so if you find some explanation insufficient, overly complicated or
+incorrect, it's a perfect opportunity to make a change to it!
+
+If at any point you run into problems, you can always ask a question on the **#grackle** channel on the Typelevel
+[discord server][grackle-dev].
+
+More information, including on how to build locally and submit pull requests, can be found [here](CONTRIBUTING.md).
+
+[grackle-issues]: https://github.com/typelevel/grackle/issues
+[grackle-pulls]: https://github.com/typelevel/grackle/pulls
+[grackle-dev]: https://discord.gg/GYD4J9w8EK