html,
body {
overflow-x: hidden;
}
.visually-hidden {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
white-space: nowrap;
border: 0;
clip-path: inset(50%);
}
main {
max-width: 72ch;
}
h1,
h2,
h3 {
margin: 0;
font-weight: 700;
}
.wordmark::after {
animation: idle-double-blink 11s steps(1) infinite;
}
.meta {
margin: 0.75rem 0 0;
font-size: 0.875rem;
color: var(--dim);
}
footer a,
.meta a {
color: var(--dim);
}
.meta a:hover {
color: var(--bg);
}
hr.rule {
margin: 3rem 0 2rem;
border: 0;
border-top: 1px solid var(--rule);
}
.section-tag {
display: block;
margin: 0 0 0.75rem;
font-size: var(--text-xs);
color: var(--dim);
text-transform: uppercase;
letter-spacing: var(--ls-caps);
}
.install {
display: grid;
grid-template-columns: 1fr;
gap: 0.625rem;
margin: 0.75rem 0 0;
}
.copy {
position: relative;
min-width: 0;
max-width: 100%;
padding: 0.85rem 1rem;
font: inherit;
color: var(--ink);
text-align: left;
cursor: pointer;
background: transparent;
border: 1px solid var(--ink);
border-radius: var(--radius-sm);
transition: background var(--dur-fast) linear, color var(--dur-fast) linear;
}
.copy:hover {
color: var(--bg);
background: var(--ink);
}
.copy:focus-visible {
outline: var(--ring-width) solid var(--tomato);
outline-offset: var(--ring-offset);
}
.copy.pri {
border-color: var(--tomato);
}
.copy.pri:hover {
color: var(--bg);
background: var(--tomato);
border-color: var(--tomato);
}
.copy .label {
display: block;
margin-bottom: 0.25rem;
font-size: var(--text-micro);
color: var(--dim);
text-transform: uppercase;
letter-spacing: var(--ls-caps);
}
.copy:hover .label {
color: inherit;
opacity: 0.7;
}
.copy .cmd {
display: block;
overflow: hidden;
font-size: 0.95rem;
text-overflow: ellipsis;
white-space: nowrap;
}
.copy .cmd-split {
display: flex;
}
.copy .cmd-split::before {
content: "$\00a0";
}
.copy .cmd-split .cmd-shrink {
overflow: hidden;
text-overflow: ellipsis;
min-width: 0;
}
.copy .cmd::before {
content: "$\00a0";
opacity: 0.5;
}
.copy .toast {
position: absolute;
top: 0.4rem;
right: 0.55rem;
visibility: hidden;
font-size: var(--text-micro);
color: var(--moss);
text-transform: uppercase;
letter-spacing: var(--ls-caps);
pointer-events: none;
opacity: 0;
transform: translateY(-2px);
transition:
opacity var(--dur-base) linear,
transform var(--dur-base) linear,
visibility 0s linear var(--dur-base);
}
.copy.copied .toast {
visibility: visible;
opacity: 1;
transform: translateY(0);
transition:
opacity var(--dur-base) linear,
transform var(--dur-base) linear,
visibility 0s linear 0s;
}
.copy:hover .toast {
color: var(--bg);
}
.install + .term {
margin-top: 1.25rem;
}
.term .prompt {
color: var(--term-dim);
}
.term .bold {
font-weight: 700;
color: var(--term-bold);
}
.term .green {
font-weight: 700;
color: var(--term-green);
}
.term .link {
color: var(--term-fg);
text-decoration: underline;
text-underline-offset: 0.2em;
background: transparent;
}
.term .link:hover {
color: var(--term-bold);
background: transparent;
}
.term .arrow {
color: var(--term-dim);
}
.term .cursor {
display: inline-block;
width: 0.6em;
color: transparent;
background: var(--term-fg);
animation: blink 1.05s steps(1) 5;
}
@keyframes blink {
50% {
opacity: 0;
}
}
@keyframes idle-double-blink {
0%,
90% {
opacity: 1;
}
91% {
opacity: 0;
}
92% {
opacity: 1;
}
93% {
opacity: 0;
}
94%,
100% {
opacity: 1;
}
}
@media (prefers-reduced-motion: reduce) {
.wordmark::after,
.term .cursor {
animation: none;
}
}
.matrix {
display: grid;
grid-template-columns: 1fr;
gap: 1.75rem;
margin: 0.5rem 0 0;
}
@media (min-width: 44rem) {
.matrix {
grid-template-columns: 1.4fr 1fr 1.4fr;
gap: 2rem;
}
}
.matrix h3 {
margin-bottom: 0.5rem;
font-size: var(--text-xs);
color: var(--dim);
text-transform: uppercase;
letter-spacing: var(--ls-caps);
}
.matrix ul {
margin: 0;
padding: 0;
list-style: none;
columns: 2;
column-gap: 1.25rem;
}
.matrix .single ul {
columns: 1;
}
.matrix li {
padding: 0.05rem 0;
break-inside: avoid;
}
.why {
padding: 0;
margin: 0.5rem 0 0;
list-style: none;
counter-reset: why;
}
.why li {
position: relative;
padding: 0.5rem 0 0.5rem 3.25rem;
counter-increment: why;
border-top: 1px dashed var(--rule);
}
.why li:first-child {
padding-top: 0.25rem;
border-top: 0;
}
.why li:last-child {
padding-bottom: 0.25rem;
}
.why li::before {
position: absolute;
top: 0.55rem;
left: 0;
font-size: 0.78rem;
color: var(--dim);
letter-spacing: 0.06em;
content: counter(why, decimal-leading-zero);
}
.why li:first-child::before {
top: 0.3rem;
}
footer {
padding-top: 1.25rem;
margin-top: 4rem;
font-size: 0.85rem;
color: var(--dim);
border-top: 1px solid var(--ink);
}
@media (max-width: 40rem) {
.matrix ul {
columns: auto;
display: flex;
flex-wrap: wrap;
align-items: baseline;
font-size: 0.9rem;
}
.matrix li {
padding: 0;
}
.matrix li + li::before {
padding: 0 0.5rem;
color: var(--dim);
content: "ยท";
opacity: 0.7;
}
.copy {
padding: 0.7rem 0.85rem;
}
.copy .cmd {
overflow-x: visible;
font-size: 0.85rem;
overflow-wrap: anywhere;
white-space: normal;
}
.copy .cmd-split {
display: block;
}
.copy .label {
white-space: normal;
}
hr.rule {
margin: 2rem 0 1.25rem;
}
}