:root {
  --blue: #00add8;
  --blue-light: #5dc9e2;
  --pink: #ce3262;
  --yellow: #fddd00;
  --teal: #00a29c;
  --ink: #080808;
  --paper: #f7f4eb;
  --white: #fffdf7;
  --line: rgba(8, 8, 8, 0.22);
  --page: min(92vw, 1440px);
  --code-bg: var(--ink);
  --code-fg: var(--white);
  --code-shadow: var(--blue);
  --inline-code-bg: rgba(8, 8, 8, 0.08);
}

.packages-body[data-theme="dark"] {
  --ink: #f7f4eb;
  --paper: #111;
  --white: #1b1b1b;
  --line: rgba(247, 244, 235, 0.26);
  --code-bg: #050505;
  --code-fg: #f7f4eb;
  --code-shadow: var(--pink);
  --inline-code-bg: rgba(247, 244, 235, 0.12);
}

@media (prefers-color-scheme: dark) {
  .packages-body:not([data-theme]) {
    --ink: #f7f4eb;
    --paper: #111;
    --white: #1b1b1b;
    --line: rgba(247, 244, 235, 0.26);
    --code-bg: #050505;
    --code-fg: #f7f4eb;
    --code-shadow: var(--pink);
    --inline-code-bg: rgba(247, 244, 235, 0.12);
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

html.packages-html {
  scroll-behavior: auto;
}

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: "Arial Black", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-synthesis: none;
}

a {
  color: inherit;
}

.skip-link {
  background: var(--white);
  left: 1rem;
  padding: 0.75rem 1rem;
  position: fixed;
  top: -5rem;
  z-index: 20;
}

.skip-link:focus {
  top: 1rem;
}

.announcement {
  align-items: center;
  background: var(--yellow);
  display: flex;
  justify-content: center;
  min-height: 42px;
  padding: 0.6rem 1.25rem;
  text-align: center;
}

.announcement p {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin: 0;
}

.announcement a {
  font-weight: 900;
  margin-left: 0.6rem;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
  white-space: nowrap;
}

.site-header {
  align-items: center;
  background: var(--paper);
  border-bottom: 2px solid var(--ink);
  display: flex;
  justify-content: space-between;
  min-height: 96px;
  padding: 1rem max(4vw, calc((100vw - 1440px) / 2));
  position: relative;
  z-index: 10;
}

.brand img,
.footer-brand img {
  display: block;
  height: auto;
  width: 176px;
}

.site-header nav {
  align-items: center;
  display: flex;
  gap: clamp(1rem, 2.5vw, 2.75rem);
}

.site-header nav a {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-decoration: none;
  text-transform: uppercase;
}

.theme-toggle {
  background: transparent;
  border: 2px solid currentColor;
  color: inherit;
  cursor: pointer;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  min-height: 38px;
  padding: 0.45rem 0.75rem;
  text-transform: uppercase;
}

.theme-toggle:hover,
.theme-toggle:focus-visible {
  background: var(--yellow);
  color: #080808;
}

.site-header nav a:hover {
  text-decoration: underline;
  text-decoration-thickness: 3px;
  text-underline-offset: 6px;
}

.site-header .nav-source {
  background: var(--ink);
  color: var(--white);
  padding: 0.8rem 1.1rem;
}

.manual-page {
  margin: 0 auto;
  max-width: 1100px;
  padding: clamp(3rem, 7vw, 7rem) max(4vw, 2rem);
}

.manual-hero {
  border-bottom: 4px solid var(--ink);
  margin-bottom: clamp(2rem, 5vw, 4rem);
  padding-bottom: clamp(1.5rem, 4vw, 3rem);
}

.manual-hero h1 {
  font-size: clamp(3rem, 10vw, 7rem);
  line-height: 0.9;
  margin: 0;
}

.manual-hero p:not(.section-number),
.manual-body p {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: clamp(1rem, 1.4vw, 1.18rem);
  line-height: 1.65;
}

.manual-body {
  display: grid;
  gap: clamp(1.5rem, 3vw, 2.5rem);
}

.manual-body section {
  border-bottom: 2px solid var(--line);
  padding-bottom: clamp(1.25rem, 3vw, 2rem);
}

.manual-body h2 {
  font-size: clamp(1.1rem, 2vw, 1.7rem);
  margin: 0 0 0.85rem;
  text-transform: uppercase;
}

.manual-body code {
  background: var(--inline-code-bg);
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  font-size: 0.95em;
  padding: 0.12rem 0.32rem;
}

.manual-body pre {
  background: var(--ink);
  color: var(--paper);
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  overflow-x: auto;
  padding: 1.25rem;
}

.manual-body pre code {
  background: transparent;
  color: inherit;
  padding: 0;
}

.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  margin: 0 auto;
  max-width: 1600px;
  min-height: 760px;
  overflow: clip;
}

.hero-copy {
  background: var(--blue);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(4rem, 8vw, 9rem) clamp(2rem, 7vw, 8rem);
}

.eyebrow,
.section-number {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.15em;
  margin: 0 0 2.25rem;
  text-transform: uppercase;
}

.hero h1 {
  font-size: clamp(4.2rem, 8.2vw, 8.8rem);
  letter-spacing: -0.095em;
  line-height: 0.78;
  margin: 0;
  max-width: 8ch;
}

.hero h1 span {
  color: var(--white);
}

.hero-intro {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: clamp(1.1rem, 1.5vw, 1.35rem);
  font-weight: 600;
  line-height: 1.55;
  margin: 3.5rem 0 0;
  max-width: 36rem;
}

.hero-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  margin-top: 2.5rem;
}

.button {
  display: inline-block;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.09em;
  padding: 1rem 1.4rem;
  text-decoration: none;
  text-transform: uppercase;
}

.button-dark {
  background: var(--ink);
  color: var(--white);
}

.button-light {
  background: var(--white);
  color: var(--ink);
}

.company-tagline {
  text-transform: none;
}

.text-link {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.85rem;
  font-weight: 800;
  text-decoration-thickness: 2px;
  text-underline-offset: 5px;
}

.hero-code {
  align-items: center;
  background: var(--pink);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  padding: clamp(2rem, 5vw, 5rem);
}

.code-window,
.terminal {
  background: var(--code-bg);
  box-shadow: 18px 18px 0 rgba(8, 8, 8, 0.2);
  color: var(--code-fg);
  max-width: min(100%, 600px);
  min-width: 0;
  width: 100%;
}

.code-bar,
.terminal-bar {
  align-items: center;
  border-bottom: 1px solid rgba(255, 255, 255, 0.25);
  display: flex;
  gap: 0.5rem;
  min-height: 48px;
  padding: 0 1.1rem;
}

.code-bar span,
.terminal-bar span {
  background: var(--blue);
  border-radius: 50%;
  display: block;
  height: 9px;
  width: 9px;
}

.code-bar span:nth-child(2),
.terminal-bar span:nth-child(2) {
  background: var(--yellow);
}

.code-bar span:nth-child(3),
.terminal-bar span:nth-child(3) {
  background: var(--pink);
}

.code-bar p {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.72rem;
  margin: 0 0 0 auto;
  opacity: 0.6;
}

pre {
  margin: 0;
  overflow-x: auto;
}

.code-window pre {
  font-size: clamp(0.68rem, 0.78vw, 0.82rem);
  line-height: 1.65;
  padding: clamp(1.4rem, 3vw, 2.5rem);
}

code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

.hljs-keyword,
.hljs-built_in,
.hljs-type {
  color: #ff7aa8;
}

.hljs-title,
.hljs-title.function_,
.hljs-title.class_ {
  color: #5dc9e2;
}

.hljs-string,
.hljs-quote {
  color: #fddd00;
}

.hljs-comment {
  color: rgba(255, 255, 255, 0.58);
}

.packages-body[data-theme="dark"] .hljs-comment {
  color: rgba(247, 244, 235, 0.56);
}

.hljs-number,
.hljs-literal {
  color: #00d2c9;
}

.code-pink {
  color: #ff6f9b;
}

.code-blue {
  color: var(--blue-light);
}

.code-yellow {
  color: var(--yellow);
}

.code-muted {
  color: rgba(255, 255, 255, 0.55);
}

.code-note {
  align-self: flex-end;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.8rem;
  font-weight: 800;
  margin: 2rem 0 0;
}

.promise {
  display: grid;
  gap: 4rem;
  grid-template-columns: 0.45fr 1fr;
  margin: 0 auto;
  padding: clamp(6rem, 10vw, 10rem) max(4vw, calc((100vw - 1440px) / 2));
}

.promise h2,
.inside h2,
.flow h2,
.start h2,
.thanks-hero h1,
.closing h2 {
  font-size: clamp(3.4rem, 7vw, 7.5rem);
  letter-spacing: -0.075em;
  line-height: 0.88;
  margin: 0;
}

.promise > div > p {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.35rem, 2.1vw, 2rem);
  line-height: 1.5;
  margin: 3rem 0 0;
  max-width: 42rem;
}

.principles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.principle {
  min-height: 560px;
  padding: clamp(2.5rem, 5vw, 5rem);
}

.principle span {
  border: 2px solid currentColor;
  border-radius: 50%;
  display: grid;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 900;
  height: 42px;
  place-items: center;
  width: 42px;
}

.principle h3 {
  font-size: clamp(2.5rem, 4.2vw, 4.6rem);
  letter-spacing: -0.065em;
  line-height: 0.95;
  margin: 8rem 0 2rem;
}

.principle p,
.stack article > p:last-child,
.flow-steps,
.start-copy > p,
.thanks-hero > p,
.thanks-section > p,
.closing-copy > p {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.6;
}

.principle-yellow {
  background: var(--yellow);
}

.principle-blue {
  background: var(--blue-light);
}

.principle-pink {
  background: var(--pink);
  color: var(--white);
}

.inside {
  background: var(--ink);
  color: var(--white);
  padding: clamp(6rem, 10vw, 10rem) max(4vw, calc((100vw - 1440px) / 2));
}

.inside-heading {
  display: grid;
  gap: 3rem;
  grid-template-columns: 0.42fr 1fr;
}

.stack {
  border-top: 1px solid rgba(255, 255, 255, 0.32);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 8rem;
}

.stack article {
  border-bottom: 1px solid rgba(255, 255, 255, 0.32);
  min-height: 360px;
  padding: 3rem 4rem 3rem 0;
}

.stack article:nth-child(odd) {
  border-right: 1px solid rgba(255, 255, 255, 0.32);
}

.stack article:nth-child(even) {
  padding-left: 4rem;
}

.stack-path {
  color: var(--blue-light);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.82rem;
  margin: 0 0 4rem;
}

.stack h3 {
  font-size: clamp(2rem, 3.4vw, 3.7rem);
  letter-spacing: -0.055em;
  line-height: 1;
  margin: 0 0 1.5rem;
}

.stack article > p:last-child {
  color: rgba(255, 255, 255, 0.72);
  max-width: 35rem;
}

.flow {
  background: var(--teal);
  display: grid;
  gap: 6rem;
  grid-template-columns: 0.8fr 1fr;
  padding: clamp(6rem, 10vw, 10rem) max(4vw, calc((100vw - 1440px) / 2));
}

.flow-steps {
  list-style: none;
  margin: 0;
  padding: 0;
}

.flow-steps li {
  align-items: baseline;
  border-top: 2px solid var(--ink);
  display: grid;
  gap: 2rem;
  grid-template-columns: 7rem 1fr;
  padding: 1.7rem 0;
}

.flow-steps li:last-child {
  border-bottom: 2px solid var(--ink);
}

.flow-steps span {
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.flow-steps strong {
  font-size: clamp(1.3rem, 2.2vw, 2rem);
}

.start {
  background: var(--yellow);
  display: grid;
  gap: clamp(4rem, 8vw, 9rem);
  grid-template-columns: 0.85fr 1fr;
  padding: clamp(6rem, 10vw, 10rem) max(4vw, calc((100vw - 1440px) / 2));
}

.start-copy > p {
  max-width: 33rem;
}

.terminal {
  align-self: center;
  box-shadow: 18px 18px 0 var(--pink);
  position: relative;
}

.terminal pre {
  font-size: clamp(0.85rem, 1.5vw, 1.2rem);
  line-height: 1.8;
  padding: 3rem;
}

.terminal code span {
  color: var(--blue-light);
}

.copy-button {
  background: var(--blue);
  border: 0;
  bottom: 1rem;
  color: var(--ink);
  cursor: pointer;
  font: 900 0.7rem/1 "Helvetica Neue", Helvetica, Arial, sans-serif;
  letter-spacing: 0.08em;
  padding: 0.8rem 1rem;
  position: absolute;
  right: 1rem;
  text-transform: uppercase;
}

.copy-button:hover,
.copy-button:focus-visible {
  background: var(--yellow);
}

.thanks-page {
  background: var(--white);
}

.thanks-hero {
  background: var(--blue-light);
  padding: clamp(6rem, 10vw, 10rem) max(4vw, calc((100vw - 1440px) / 2));
}

.thanks-hero h1 {
  max-width: 9ch;
}

.thanks-hero > p {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.35rem, 2.1vw, 2rem);
  line-height: 1.5;
  margin: 3rem 0 0;
  max-width: 46rem;
}

.thanks-sections {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}

.thanks-section {
  border-top: 2px solid var(--ink);
  min-height: 520px;
  padding: clamp(3rem, 6vw, 6rem);
}

.thanks-section:nth-child(odd) {
  border-right: 2px solid var(--ink);
}

.thanks-section h2 {
  font-size: clamp(2.5rem, 4.4vw, 5rem);
  letter-spacing: -0.065em;
  line-height: 0.95;
  margin: 0;
  max-width: 12ch;
}

.thanks-section > p {
  font-size: clamp(1.1rem, 1.55vw, 1.35rem);
  margin: 2.5rem 0 0;
  max-width: 45rem;
}

.thanks-section .thanks-label {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.15em;
  margin: 0 0 5rem;
  text-transform: uppercase;
}

.thanks-section code {
  background: var(--yellow);
  color: var(--ink);
  font-size: 0.86em;
  padding: 0.1rem 0.3rem;
}

.thanks-section a {
  display: inline-block;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.09em;
  margin-top: 2rem;
  text-decoration-thickness: 2px;
  text-transform: uppercase;
  text-underline-offset: 5px;
}

.thanks-section-gorilla {
  background: var(--white);
}

.thanks-section-rails {
  background: var(--yellow);
}

.thanks-section-activesupport {
  background: var(--blue);
  color: var(--ink);
}

.thanks-section-go {
  background: var(--ink);
  color: var(--white);
}

.thanks-section-browser {
  background: var(--pink);
  color: var(--white);
}

.thanks-section-serverless {
  background: var(--teal);
  border-right: 0;
  grid-column: 1 / -1;
}

.closing {
  background: var(--pink);
  color: var(--white);
  display: grid;
  grid-template-columns: 0.75fr 1.25fr;
  min-height: 720px;
}

.closing-visual {
  align-items: center;
  background: var(--yellow);
  display: flex;
  justify-content: center;
  padding: clamp(3rem, 7vw, 7rem);
}

.closing-window {
  background: var(--ink);
  box-shadow: 18px 18px 0 var(--blue);
  max-width: 470px;
  transform: rotate(-2deg);
  width: 100%;
}

.closing-window-bar {
  align-items: center;
  border-bottom: 1px solid rgba(255, 255, 255, 0.25);
  display: flex;
  gap: 0.5rem;
  min-height: 48px;
  padding: 0 1.1rem;
}

.closing-window-bar span {
  background: var(--blue);
  border-radius: 50%;
  height: 9px;
  width: 9px;
}

.closing-window-bar span:nth-child(2) {
  background: var(--yellow);
}

.closing-window-bar span:nth-child(3) {
  background: var(--pink);
}

.closing-flow {
  align-items: center;
  display: flex;
  flex-direction: column;
  padding: clamp(2rem, 5vw, 4rem);
}

.closing-node {
  border: 2px solid var(--white);
  color: var(--white);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: clamp(0.78rem, 1.2vw, 0.95rem);
  font-weight: 800;
  letter-spacing: 0.08em;
  padding: 0.9rem 1.2rem;
  text-align: center;
  text-transform: uppercase;
  width: min(100%, 15rem);
}

.closing-node-route {
  border-color: var(--blue-light);
  color: var(--blue-light);
}

.closing-node-controller {
  border-color: var(--pink);
  color: #ff6f9b;
}

.closing-controller-services {
  align-items: center;
  display: flex;
  justify-content: center;
  width: 100%;
}

.closing-controller-services .closing-node {
  flex: 1 1 0;
  min-width: 0;
  padding-left: 0.65rem;
  padding-right: 0.65rem;
  width: auto;
}

.closing-node-services {
  border-color: var(--teal);
  color: var(--blue-light);
}

.closing-service-arrow {
  color: var(--white);
  flex: 0 0 auto;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 1.35rem;
  line-height: 1;
  padding: 0 0.55rem;
}

.closing-node-view {
  border-color: var(--yellow);
  color: var(--yellow);
}

.closing-node-response {
  background: var(--white);
  color: var(--ink);
}

.closing-arrow {
  color: var(--white);
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 1.35rem;
  line-height: 1;
  padding: 0.55rem 0;
}

.closing-copy {
  align-self: center;
  padding: clamp(4rem, 8vw, 9rem);
}

.closing-copy > p {
  margin: 2.5rem 0;
  max-width: 38rem;
}

footer {
  align-items: center;
  background: var(--paper);
  display: grid;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 800;
  gap: 2rem;
  grid-template-columns: 1fr auto 1fr;
  letter-spacing: 0.06em;
  min-height: 130px;
  padding: 2rem max(4vw, calc((100vw - 1440px) / 2));
  text-transform: uppercase;
}

footer.site-footer nav {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem 1.25rem;
  justify-content: center;
}

footer.site-footer {
  text-transform: none;
}

footer.site-footer nav a {
  color: inherit;
  display: inline-flex;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

footer.site-footer nav a[aria-current="page"] {
  color: var(--pink);
}

.footer-github svg {
  display: block;
  fill: currentColor;
  height: 1.1rem;
  width: 1.1rem;
}

footer p {
  margin: 0;
}

footer p:last-child {
  text-align: right;
}

.legal-page {
  background: var(--white);
  min-height: 58vh;
  padding: clamp(4rem, 8vw, 8rem) max(1.25rem, calc((100vw - 860px) / 2));
}

.legal-page article {
  max-width: 760px;
}

.legal-page h1 {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: clamp(3rem, 8vw, 6rem);
  letter-spacing: 0;
  line-height: 0.95;
  margin: 0 0 2rem;
}

.legal-page p {
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  line-height: 1.7;
  margin: 1.25rem 0;
}

.legal-page a {
  font-weight: 800;
}

@media (max-width: 1050px) {
  .hero {
    grid-template-columns: 1fr;
  }

  .hero-code {
    min-height: 560px;
  }

  .principles {
    grid-template-columns: 1fr;
  }

  .principle {
    min-height: 450px;
  }

  .principle h3 {
    margin-top: 5rem;
  }

  .promise,
  .inside-heading,
  .flow,
  .start,
  .thanks-sections {
    grid-template-columns: 1fr;
  }

  .thanks-section:nth-child(odd) {
    border-right: 0;
  }

  .promise {
    gap: 1rem;
  }
}

@media (max-width: 720px) {
  .site-header {
    align-items: flex-start;
    flex-direction: column;
    gap: 1.5rem;
    padding: 1.4rem 1.25rem;
  }

  .brand img {
    width: 142px;
  }

  .site-header nav {
    flex-wrap: wrap;
    gap: 1rem 1.5rem;
  }

  .site-header nav a {
    font-size: 0.7rem;
  }

  .hero {
    min-height: auto;
  }

  .hero-copy,
  .hero-code {
    padding: 4.5rem 1.25rem;
  }

  .hero h1 {
    font-size: clamp(4rem, 21vw, 6.5rem);
  }

  .hero-code {
    min-height: 460px;
    overflow: hidden;
  }

  .code-window pre {
    font-size: 0.62rem;
  }

  .promise,
  .inside,
  .flow,
  .start,
  .thanks-hero,
  .thanks-section {
    padding: 5.5rem 1.25rem;
  }

  .promise h2,
  .inside h2,
  .flow h2,
  .start h2,
  .thanks-hero h1,
  .closing h2 {
    font-size: clamp(3.2rem, 16vw, 5.2rem);
  }

  .thanks-section h2 {
    font-size: clamp(2.6rem, 13vw, 4.4rem);
  }

  .principle {
    padding: 3.5rem 1.25rem;
  }

  .stack {
    display: block;
    margin-top: 5rem;
  }

  .stack article,
  .stack article:nth-child(even) {
    border-right: 0;
    min-height: auto;
    padding: 3rem 0;
  }

  .flow-steps li {
    gap: 0.7rem;
    grid-template-columns: 1fr;
  }

  .terminal pre {
    padding: 2rem 1.25rem 5rem;
  }

  .closing {
    grid-template-columns: 1fr;
  }

  .closing-visual {
    min-height: 420px;
  }

  .closing-copy {
    padding: 5rem 1.25rem;
  }

  footer {
    align-items: flex-start;
    grid-template-columns: 1fr;
    padding: 2.5rem 1.25rem;
  }

  footer p:last-child {
    text-align: left;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}
