/* Meyer reset v2.0 (public domain) */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}
body {
  line-height: 1;
}
ol,
ul {
  list-style: none;
}
blockquote,
q {
  quotes: none;
}
blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* Fonts */
@font-face {
  font-family: "Graphik";
  src: url("/assets/fonts/Graphik-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Cossette";
  src: url("/assets/fonts/cossette.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Cossette";
  src: url("/assets/fonts/cossette.woff2") format("woff2");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}

/* Tokens */
:root {
  --sp-accent: #d4ff33;
  --sp-accent-hover: #caff00;
  --sp-white: #ffffff;
  --sp-back: #17181c;
  --sp-back-plate: #22242a;
  --sp-text-color: #c4c9d4;
  --sp-text-color-secondary: #c4c9d480;
  --sp-text-color-tertiary: #c4c9d44d;
  --sp-divider: #c4c9d426;
  --sp-underline: #c4c9d440;
  --sp-text-color-accent: #eaff99;

  --sp-border-radius-S: 8px;
  --sp-border-radius-M: 12px;

  --sp-space-S1: 2px;
  --sp-space-S2: 4px;
  --sp-space-S3: 6px;
  --sp-space-S4: 8px;
  --sp-space-S5: 10px;
  --sp-space-S6: 12px;
  --sp-space-M1: 16px;
  --sp-space-M2: 20px;
  --sp-space-M3: 24px;
  --sp-space-M4: 28px;
  --sp-space-M5: 32px;
  --sp-space-M6: 40px;
  --sp-space-M7: 48px;
  --sp-space-M8: 56px;
  --sp-space-M9: 64px;
  --sp-space-M10: 72px;
  --sp-space-L1: 80px;
  --sp-space-L2: 96px;
  --sp-space-L3: 112px;
  --sp-space-L4: 128px;
  --sp-space-L5: 144px;
  --sp-space-L6: 160px;
  --sp-space-L7: 192px;
  --sp-space-L8: 224px;
  --sp-space-L9: 256px;

  /* Core typography tokens */
  --sp-font-size-32: 2rem;
  --sp-font-size-28: 1.8rem;
  --sp-font-size-20: 1.25rem;
  --sp-font-size-16: 1rem;
  --sp-font-size-14: 0.88rem;
  --sp-line-height-140: 140%;
  --sp-line-height-120: 120%;
  --sp-line-height-110: 110%;
  --sp-line-height-100: 100%;
  --sp-letter-spacing--02: -0.02em;
  --sp-letter-spacing--08: -0.08em;

  /* Semantic typography tokens */
  --sp-font-h1: var(--sp-font-size-32);
  --sp-line-height-h1: var(--sp-line-height-110);
  --sp-letter-spacing-h1: var(--sp-letter-spacing--02);
  --sp-letter-spacing-h1-numbers: var(--sp-letter-spacing--08);

  --sp-font-h2: var(--sp-font-size-28);
  --sp-line-height-h2: var(--sp-line-height-110);
  --sp-letter-spacing-h2: var(--sp-letter-spacing--02);
  --sp-letter-spacing-h2-numbers: var(--sp-letter-spacing--08);

  --sp-font-primary-text: var(--sp-font-size-16);
  --sp-line-height-primary-text: var(--sp-line-height-140);
  --sp-letter-spacing-primary-text: var(--sp-letter-spacing--02);

  --sp-font-post-text: var(--sp-font-size-20);
  --sp-line-height-post-text: var(--sp-line-height-140);
  --sp-letter-spacing-post-text: var(--sp-letter-spacing--02);

  --sp-font-tertiary-text: var(--sp-font-size-14);
  --sp-line-height-tertiary-text: var(--sp-line-height-140);
  --sp-letter-spacing-tertiary-text: var(--sp-letter-spacing--02);

  /* Cascading text roles */
  --sp-text-body-font: var(--sp-font-primary-text);
  --sp-text-body-line-height: var(--sp-line-height-primary-text);
  --sp-text-body-letter-spacing: var(--sp-letter-spacing-primary-text);

  --sp-layout-gap: 1.2vw;
  --sp-layout-padding: 2.4vw;
  --sp-sidebar-width: 33.333vw;
}

/* Global base */
* {
  box-sizing: border-box;
  transition: all ease-out 0.15s;
}

html {
  font-size: clamp(12px, 1.2vw, 20px);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  background-color: var(--sp-back);
  font-family: "Graphik", "Cossette", sans-serif;
  color: var(--sp-text-color);
}

/* Motion & reveal */
.sp-js [data-reveal],
.sp-js [data-reveal-scope="children"] > * {
  opacity: 0;
  visibility: hidden;
}

@media (prefers-reduced-motion: reduce) {
  .sp-js [data-reveal],
  .sp-js [data-reveal-scope="children"] > * {
    opacity: 1;
    visibility: visible;
  }
}

/* Links */
a {
  color: var(--sp-text-color);
  text-decoration: none;
  transition: transform 0.3s ease-out;
  transform-origin: center;
}

a:hover {
  color: var(--sp-accent-hover);
}

a:active {
  transform: scale(0.98);
}

.sp-work-main a:active,
.sp-note-main a:active {
  transform: none;
}

#content a.sp-brand-link {
  color: var(--sp-accent) !important;
  display: inline;
  padding-bottom: 2px;
  border-bottom: 1px solid var(--sp-underline);
}

#content a.sp-brand-link:hover {
  color: var(--sp-accent-hover) !important;
  border-bottom: 1px solid var(--sp-accent-hover);
}

#content a.sp-secondary-link {
  color: var(--sp-text-color) !important;
  display: inline;
  padding-bottom: 2px;
  border-bottom: 1px solid var(--sp-underline);
}

#content a.sp-secondary-link:hover {
  color: var(--sp-accent-hover) !important;
  border-bottom: 1px solid var(--sp-accent-hover);
}

#content a.sp-nav-link {
  color: var(--sp-text-color) !important;
  display: inline;
}

#content a.sp-nav-link:hover {
  color: var(--sp-accent-hover) !important;
}

.sp-nav-link {
  color: var(--sp-text-color);
  display: inline;
  font-family: "Cossette", sans-serif;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
}

.sp-nav-link--body {
  font-family: inherit;
  font-size: var(--sp-font-primary-text);
  letter-spacing: var(--sp-letter-spacing-primary-text);
  line-height: var(--sp-line-height-primary-text);
}

.sp-nav-link:hover {
  color: var(--sp-accent-hover);
}

.sp-nav-link--active {
  color: var(--sp-accent);
}

.sp-link-primary-text {
  color: var(--sp-text-color);
}

.sp-link-primary-text-underline {
  color: var(--sp-text-color);
  border-bottom: 1px solid var(--sp-underline);
  padding-bottom: 2px;
}

.sp-link-primary-text-underline:hover {
  border-bottom: 1px solid var(--sp-accent-hover);
}

.sp-link-accent-underline {
  color: var(--sp-accent);
  border-bottom: 1px solid var(--sp-underline);
  padding-bottom: 2px;
}

.sp-link-accent-underline:hover {
  border-bottom: 1px solid var(--sp-accent-hover);
}

.sp-link-secondary-underline {
  color: var(--sp-text-color-secondary);
  border-bottom: 1px solid var(--sp-underline);
  padding-bottom: 2px;
}

.sp-link-secondary-underline:hover {
  border-bottom: 1px solid var(--sp-accent-hover);
}

.sp-link-tertiary-underline {
  color: var(--sp-text-color-tertiary);
  border-bottom: 1px solid var(--sp-underline);
  padding-bottom: 2px;
}

.sp-link-tertiary-underline:hover {
  border-bottom: 1px solid var(--sp-accent-hover);
}

.sp-text-secondary {
  color: var(--sp-text-color-secondary);
}

/* Layout: base.njk */
.sp-layout {
  display: flex;
  min-height: 100vh;
}

.sp-sidebar {
  position: fixed;
  left: 0;
  top: 0;
  width: var(--sp-sidebar-width);
  height: 100vh;
  padding: var(--sp-layout-padding) 0 var(--sp-layout-padding)
    var(--sp-layout-padding);
}

.sp-logo {
  display: inline-flex;
  width: 4.5rem;
  height: 4rem;
  align-items: flex-start;
  justify-content: center;
  color: var(--sp-text-color);
  font-size: var(--sp-font-tertiary-text);
  text-transform: uppercase;
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  margin-bottom: 7rem;
}

.sp-logo:hover,
.sp-logo:focus-visible {
  color: var(--sp-accent);
}

.sp-logo svg {
  width: 100%;
  height: auto;
}

/* Aside: home/work/note templates */
.sp-aside {
  /* max-width: 26rem; */

  .sp-work-aside,
  .sp-note-aside {
    padding-right: 0;
  }

  .sp-home-aside {
    padding-right: 2rem;
  }
}

.sp-aside .sp-divider {
  width: 100%;
}

.sp-scrolled .sp-aside .sp-divider {
  width: calc(100% - 2rem);
}

.sp-aside__title {
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  padding-right: 2rem;
  /* display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden; */
}

.sp-aside__text {
  color: var(--sp-text-color);
  margin-bottom: 1rem;
  padding-right: 2rem;
}

.sp-aside__text:last-child {
  margin-bottom: 0;
}

.sp-aside__meta {
  color: var(--sp-text-color-secondary);
  margin-bottom: 1.5rem;
}

/* Main area: base.njk */
.sp-main {
  margin-left: calc(var(--sp-sidebar-width));
  width: calc(100% - var(--sp-sidebar-width));
  padding: var(--sp-layout-padding) var(--sp-layout-padding)
    var(--sp-layout-padding) 0;
}

/* Navigation: base.njk */
.sp-header {
  margin-bottom: 7rem;
}

.sp-nav {
  display: flex;
  justify-content: space-between;
  gap: 2rem;
  height: 4rem;
}

.sp-nav__group {
  display: flex;
  gap: 1.5rem;
}

/* Content area: base.njk */
.sp-content {
  padding-bottom: 4rem;
}

/* Footer: main-footer.njk */
.sp-main-footer {
  position: relative;
  min-height: calc(100dvh - 2 * var(--sp-layout-padding));
  height: calc(100dvh - 2 * var(--sp-layout-padding));
  background: var(--sp-back-plate);
  border-radius: var(--sp-border-radius-S);
  margin-top: var(--sp-space-L2);
  padding: 2rem;
  color: var(--sp-text-color);
  display: grid;
  grid-template-rows: 1fr auto;
  gap: var(--sp-space-M2);
  text-align: left;
}

.sp-main-footer__bottom {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--sp-space-M1);
}

.sp-main-footer__links a,
.sp-main-footer__nav a {
  font-size: var(--sp-font-primary-text);
  line-height: var(--sp-line-height-primary-text);
  letter-spacing: var(--sp-letter-spacing-primary-text);
  color: currentColor;
}

.sp-main-footer__links {
  display: flex;
  gap: var(--sp-space-M1);
  color: var(--sp-text-color);
}

.sp-main-footer__nav {
  display: flex;
  gap: var(--sp-space-M1);
  color: var(--sp-text-color);
}

.sp-main-footer__links a:hover,
.sp-main-footer__nav a:hover {
  color: var(--sp-accent-hover);
}

/* Footer game */
.sp-connect4 {
  display: grid;
  gap: var(--sp-space-M2);
  width: 100%;
  min-height: 0;
  height: 100%;
  grid-template-rows: auto 1fr;
}

.sp-connect4__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-space-M1);
  flex-wrap: wrap;
}

.sp-connect4__status {
  margin: 0;
  font-size: var(--sp-font-primary-text);
  line-height: var(--sp-line-height-primary-text);
  letter-spacing: var(--sp-letter-spacing-primary-text);
}

.sp-connect4__reset {
  border: 1px solid currentColor;
  border-radius: 999px;
  padding: 0.4rem 1rem;
  background: transparent;
  color: currentColor;
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-tertiary-text);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  cursor: pointer;
  transition: transform 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.sp-connect4__reset:hover {
  color: var(--sp-accent-hover);
  border-color: var(--sp-accent-hover);
}

.sp-connect4__stage {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
}

.sp-connect4__board-wrap {
  position: relative;
  width: 100%;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  align-self: center;
  justify-self: center;
  aspect-ratio: 7 / 6;
  overflow: hidden;
}

@supports (width: 1cqw) {
  .sp-connect4__stage {
    container-type: size;
  }

  .sp-connect4__board-wrap {
    width: min(100cqw, calc(100cqh * 7 / 6));
  }
}

.sp-connect4__base,
.sp-connect4__discs,
.sp-connect4__grid,
.sp-connect4__confetti-canvas {
  position: absolute;
  inset: 0;
}

.sp-connect4__base,
.sp-connect4__discs,
.sp-connect4__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  grid-template-rows: repeat(6, 1fr);
  gap: 0;
  border-radius: calc(var(--sp-border-radius-S) * 0.8);
}

.sp-connect4__base {
  padding: 1%;
  z-index: 1;
  pointer-events: none;
}

.sp-connect4__discs {
  padding: 1%;
  z-index: 2;
  pointer-events: none;
}

.sp-connect4__grid {
  padding: 1%;
  z-index: 3;
  background: var(--sp-back-plate);
  -webkit-mask-image: radial-gradient(circle, transparent 62%, #000 64%);
  mask-image: radial-gradient(circle, transparent 62%, #000 64%);
  -webkit-mask-repeat: repeat;
  mask-repeat: repeat;
  -webkit-mask-size: calc((100% - 2%) / 7) calc((100% - 2%) / 6);
  mask-size: calc((100% - 2%) / 7) calc((100% - 2%) / 6);
  -webkit-mask-position: 1% 1%;
  mask-position: 1% 1%;
}

.sp-connect4__cell {
  display: grid;
  place-items: center;
  padding: 3%;
  cursor: pointer;
}

.sp-connect4__grid.is-locked .sp-connect4__cell {
  cursor: default;
}

.sp-connect4__disc {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
}

.sp-connect4__base .sp-connect4__disc {
  background: var(--sp-back);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.08);
}

.sp-connect4__base .sp-connect4__cell.is-hovered .sp-connect4__disc {
  box-shadow: inset 0 0 2px 1px rgba(255, 255, 255, 0.3);
}

.sp-connect4__grid .sp-connect4__disc {
  background: transparent;
  box-shadow: none;
}

.sp-connect4__discs .sp-connect4__disc {
  background: transparent;
  box-shadow: none;
}

.sp-connect4__discs .sp-connect4__cell[data-state="player"] .sp-connect4__disc {
  background: var(--sp-accent);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.1);
}

.sp-connect4__discs
  .sp-connect4__cell[data-state="computer"]
  .sp-connect4__disc {
  background: var(--sp-text-color);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.1);
}

.sp-connect4__cell[data-muted="true"] .sp-connect4__disc {
  background: var(--sp-text-color) !important;
  opacity: 0.2;
}

.sp-connect4__cell[data-winner="true"] .sp-connect4__disc {
  opacity: 1;
}

.sp-connect4.is-ended .sp-connect4__reset {
  background: var(--sp-accent);
  color: var(--sp-back);
  border-color: var(--sp-accent);
}

.sp-connect4__confetti-canvas {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 40;
  width: 100%;
  height: 100%;
}

/* Template text scopes */
.sp-home-main,
.sp-home-aside {
  --sp-text-body-font: var(--sp-font-primary-text);
  --sp-text-body-line-height: var(--sp-line-height-primary-text);
  --sp-text-body-letter-spacing: var(--sp-letter-spacing-primary-text);
}

.sp-work-main,
.sp-note-main {
  --sp-text-body-font: var(--sp-font-post-text);
  --sp-text-body-line-height: var(--sp-line-height-post-text);
  --sp-text-body-letter-spacing: var(--sp-letter-spacing-post-text);
}

.sp-content,
.sp-aside,
.sp-home-main,
.sp-home-aside,
.sp-work-main,
.sp-note-main {
  font-size: var(--sp-text-body-font);
  line-height: var(--sp-text-body-line-height);
  letter-spacing: var(--sp-text-body-letter-spacing);
}

/* Work/Note: post content */
.sp-post-page-content {
  max-width: 100%;
}

.sp-post-page-content > :not(.sp-media):not(.sp-divider):not(hr):not(.sp-case) {
  max-width: 75%;
}

.sp-post-page-content > .sp-media,
.sp-post-page-content > .sp-divider,
.sp-post-page-content > hr,
.sp-post-page-content > .sp-case {
  width: 100%;
  max-width: 100%;
}

.sp-case > :not(.sp-media):not(.sp-divider):not(hr) {
  max-width: 75%;
}

.sp-case > .sp-media,
.sp-case > .sp-divider,
.sp-case > hr {
  width: 100%;
  max-width: 100%;
}

.sp-work-main[data-case-view="short"] .sp-case--long,
.sp-work-main[data-case-view="long"] .sp-case--short {
  display: none;
}

.sp-text-header-numbers {
  letter-spacing: var(--sp-letter-spacing-h1-numbers);
}

/* Typography: shared elements */
p,
h1,
h2,
h3,
h4,
h5,
h6,
ul li,
ol li {
  overflow-wrap: break-word;
  color: var(--sp-text-color);
}

h1,
h2,
h3,
h4,
blockquote {
  font-family: "Cossette", "Graphik", sans-serif;
}

p {
  margin-bottom: 1rem;
}

p:last-child {
  margin-bottom: 0;
}

h5,
h6 {
  font-size: var(--sp-font-primary-text);
  line-height: var(--sp-line-height-primary-text);
}

h1 {
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  margin-bottom: 1.5rem;
}

/* Work: work-main.njk */
.sp-company-title {
  display: block;
  font-family: "Cossette", "Graphik", sans-serif;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  color: var(--sp-text-color-secondary);
  margin-bottom: 1.5rem;
  text-align: right;
}

h2 {
  font-size: var(--sp-font-h2);
  line-height: var(--sp-line-height-h2);
  letter-spacing: var(--sp-letter-spacing-h2);
  margin: 3rem 0 0.75rem 0;
}

h3 {
  font-size: var(--sp-font-post-text);
  line-height: var(--sp-line-height-120);
  letter-spacing: var(--sp-letter-spacing-post-text);
  margin: 1.5rem 0 0.75rem;
}

h4 {
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-120);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  margin: 1rem 0 0.5rem;
}

.sp-post-page-content ul {
  margin-left: 1.5rem;
  list-style-type: disc;
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.sp-post-page-content ol {
  margin-left: 1.5rem;
  list-style-type: decimal;
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.sp-post-page-content ul li,
.sp-post-page-content ol li {
  margin-bottom: 1rem;
  padding-left: 0.75rem;
}

.sp-post-page-content ul li::marker {
  content: "— ";
}

ul li:last-child,
ol li:last-child {
  margin-bottom: 1rem;
}

.sp-listing h1 {
  margin-bottom: 2rem;
}

/* Index pages: work/index.njk + notes/index.njk */
.sp-list {
  display: grid;
  gap: 1.5rem;
}

.sp-list--masonry {
  display: block;
  column-count: 2;
  column-gap: 1.5rem;
}

.sp-list--masonry > li {
  break-inside: avoid;
  margin-bottom: 1.5rem;
}

.sp-list__desc {
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-tertiary-text);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  color: var(--sp-text-color-secondary);
}

/* Notes index: notes-index-main.njk */
.sp-notes-list {
  display: block;
}

.note-card {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-start;
  gap: var(--sp-space-M4);
  padding: var(--sp-space-M5) 0;
  border-bottom: 1px solid var(--sp-divider);
  text-decoration: none;
  color: inherit;
}

.note-card--media {
  gap: var(--sp-space-M4);
}

.note-card:last-child {
  border-bottom: none;
}

.note-card__content {
  flex: 7;
  display: grid;
  gap: var(--sp-space-S6);
}

.note-card__aside {
  flex: 3;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  gap: var(--sp-space-M2);
}

.note-card__media {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-space-M4);
  justify-content: flex-end;
}

.note-card__cover {
  width: 5.7rem;
  aspect-ratio: 2 / 3;
  border-radius: var(--sp-border-radius-S);
  overflow: hidden;
  flex-shrink: 0;
}

.note-card__cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.note-card__cover video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.note-card__badge {
  width: 3rem;
  display: flex;
}

.note-card__badge img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.note-card__date {
  font-family: "Cossette", "Graphik", sans-serif;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  color: var(--sp-text-color-secondary);
  text-align: right;
}

.note-card__title {
  margin: 0;
}

.note-card__description {
  margin: 0;
  font-size: var(--sp-font-post-text);
  line-height: var(--sp-line-height-post-text);
  letter-spacing: var(--sp-letter-spacing-post-text);
  color: var(--sp-text-color-secondary);
}

.note-card:hover .note-card__title {
  color: var(--sp-accent);
}

.note-card:hover .note-card__description {
  color: var(--sp-text-color);
}

.sp-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-tertiary-text);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  color: var(--sp-text-color-secondary);
  margin-bottom: 2rem;
}

/* Work/Note: lead text */
.sp-lead {
  font-size: var(--sp-font-post-text);
  line-height: var(--sp-line-height-post-text);
  letter-spacing: var(--sp-letter-spacing-post-text);
  color: var(--sp-text-color-secondary);
  margin-bottom: 1rem;
}

.sp-note-main .sp-lead {
  display: block;
  font-family: "Cossette", "Graphik", sans-serif;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  color: var(--sp-text-color-secondary);
  margin-bottom: 1.5rem;
  text-align: right;
}

.sp-note-aside .sp-aside__title,
.sp-note-main .sp-lead {
  min-height: var(--sp-note-title-meta-height, auto);
}

/* Media: shortcodes */
.sp-media {
  margin: 3rem 0;
}

.sp-media--content {
  max-width: 75%;
}

.sp-media--full {
  position: relative;
  overflow: visible;
  /* padding-left: var(--sp-layout-padding); */
}

.sp-media--full .sp-media__img,
.sp-media--full .sp-video {
  width: calc(100% + var(--sp-sidebar-width) - var(--sp-layout-padding));
  margin-left: calc((var(--sp-sidebar-width) - var(--sp-layout-padding)) * -1);
  position: relative;
  z-index: 5;
}

.sp-media__img,
.sp-video__el {
  width: 100%;
  display: block;
  border-radius: var(--sp-border-radius-S);
}

.sp-media__caption {
  margin-top: 0.75rem;
  max-width: 75%;
  width: 100%;
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-tertiary-text);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  color: var(--sp-text-color-secondary);
}

.sp-video {
  position: relative;
}

.sp-video__control {
  position: absolute;
  right: 1rem;
  width: 4.3rem;
  bottom: 1rem;
  background: #ffffff10;
  color: var(--sp-text-color);
  border: 1px solid var(--sp-divider);
  border-radius: 999px;
  padding: 0.4rem 0.9rem;
  backdrop-filter: blur(32px);
  cursor: pointer;
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-tertiary-text);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
}

.sp-video-embed iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  border-radius: 8px;
  margin: 3rem 0;
}

.sp-divider {
  border: none;
  height: 1px;
  background: var(--sp-divider);
  transition: width 0.2s ease;
}

hr {
  border: none;
  height: 1px;
  background: var(--sp-divider);
  margin: 5rem 0;
}

.sp-divider--tight {
  margin: 1rem 0;
}

.sp-divider--roomy {
  margin: 2rem 0;
}

.sp-divider--loose {
  margin: 5rem 0;
}

blockquote {
  margin: 3rem 0;
  padding: 2rem 0;
  border-top: 1px solid var(--sp-text-color-accent);
  border-bottom: 1px solid var(--sp-text-color-accent);
}

blockquote p {
  margin: 0;
  font-family: "Cossette", "Graphik", sans-serif;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  font-style: italic;
  color: var(--sp-text-color-accent);
}

blockquote cite {
  display: block;
  margin-top: 1.75rem;
  font-family: "Graphik", sans-serif;
  font-size: var(--sp-font-primary-text);
  line-height: var(--sp-line-height-tertiary-text);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  color: var(--sp-text-color-accent);
  font-style: normal;
}

#content img:not(.sp-media__img) {
  border-radius: var(--sp-border-radius-S);
  width: 100%;
}

/* Home: home-main.njk */
.sp-project-grid {
  column-count: 2;
  column-gap: var(--sp-space-M1);
}

.sp-project-card {
  display: inline-block;
  width: 100%;
  text-decoration: none;
  cursor: pointer;
  break-inside: avoid;
  margin-bottom: var(--sp-space-M5);
}

.sp-project-card__image {
  width: 100%;
  aspect-ratio: 2 / 3;
  background: var(--sp-back-plate);
  border-radius: var(--sp-border-radius-S);
  overflow: hidden;
  margin-bottom: var(--sp-space-M1);
  transition: opacity 0.2s ease-out;
}

.sp-project-card__image--small {
  aspect-ratio: 1 / 1;
}

.sp-project-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.15s ease-out;
}

.sp-project-card__image video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.15s ease-out;
}

.sp-project-card:hover .sp-project-card__image img {
  transform: scale(1.02);
}

.sp-project-card:hover .sp-project-card__image video {
  transform: scale(1.02);
}

.sp-project-card--dimmed .sp-project-card__image {
  opacity: 0.5;
}

.sp-project-card__content {
  display: flex;
  flex-direction: row;
  gap: var(--sp-space-M1);
}

.sp-project-card__header {
  display: flex;
  align-items: baseline;
  gap: var(--sp-space-S4);
  flex-wrap: wrap;
}

.sp-project-card__header p {
  margin: 0;
  transition: color 0.15s ease-out;
}

.sp-project-card:hover .sp-project-card__header p {
  color: var(--sp-accent);
}

.sp-project-card__company {
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-110);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  color: var(--sp-text-color-secondary);
}

.sp-project-card__description {
  color: var(--sp-text-color-secondary);
  margin: 0;
}

@media (hover: hover) and (pointer: fine) {
  .sp-project-card__description {
    display: block;
    opacity: 0;
    transform: translateY(2px);
  }

  .sp-project-card:hover .sp-project-card__description {
    opacity: 1;
    transform: translateY(0);
  }
}

.sp-project-card:hover .sp-project-card__description {
  color: var(--sp-text-color);
}

.sp-significant {
  margin-top: var(--sp-space-L6);
}

.sp-significant h1 {
  margin-bottom: 5rem;
}

.sp-significant__table {
  border-top: none;
}

.sp-significant__row {
  display: grid;
  grid-template-columns: 2fr 1.5fr 1.5fr;
  gap: var(--sp-space-M2);
  padding: 1.25rem 0;
  text-decoration: none;
  border-bottom: 1px solid var(--sp-divider);
}

.sp-significant__row:last-child {
  border-bottom: none;
}

.sp-significant__row--head {
  pointer-events: none;
}

.sp-significant__row--head .sp-significant__title,
.sp-significant__row--head .sp-significant__meta {
  color: var(--sp-text-color-secondary);
}

.sp-significant__title {
  color: var(--sp-text-color);
}

.sp-significant__meta {
  color: var(--sp-text-color-secondary);
}

.sp-significant__row .sp-significant__meta:last-child {
  text-align: right;
}

.sp-significant__row:hover .sp-significant__meta {
  color: var(--sp-text-color);
}

.sp-significant__row:hover .sp-significant__title {
  color: var(--sp-accent);
}

.sp-significant__preview {
  position: fixed;
  top: 0;
  left: 0;
  width: 300px;
  height: 300px;
  border-radius: var(--sp-border-radius-M);
  overflow: hidden;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transform: scale(0.96);
  z-index: 20;
}

.sp-significant__preview-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sp-significant__preview-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: none;
}

/* Responsive */
@media (max-width: 900px) {
  .sp-connect4__base .sp-connect4__cell.is-hovered .sp-connect4__disc {
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.08);
  }

  html {
    font-size: 14px;
  }

  :root {
    --sp-layout-padding: 1.5rem;
    --sp-layout-gap: 1rem;
    --sp-sidebar-width: 100%;
  }

  .sp-layout {
    position: relative;
    flex-direction: column;
  }

  .sp-sidebar {
    position: static;
    width: 100%;
    height: auto;
    padding: var(--sp-layout-padding);
  }

  .sp-main {
    margin-left: 0;
    width: 100%;
    padding: var(--sp-layout-padding);
  }

  .sp-media--full .sp-media__img,
  .sp-media--full .sp-video {
    width: 100%;
    margin-left: 0;
  }

  .sp-media--full {
    padding-left: 0;
  }

  .sp-header {
    position: absolute;
    top: var(--sp-layout-padding);
    right: var(--sp-layout-padding);
    margin-bottom: 0;
  }

  .sp-logo {
    margin-bottom: 10rem;
  }

  .sp-main-footer {
    align-items: stretch;
    text-align: left;
  }

  .sp-main-footer__links,
  .sp-main-footer__nav {
    flex-wrap: wrap;
    row-gap: var(--sp-space-S3);
  }

  .sp-nav {
    align-items: flex-start;
    gap: 1.25rem;
    height: auto;
  }

  .sp-nav__group {
    display: contents;
  }

  .sp-nav-link--body {
    font-family: "Cossette", sans-serif;
    font-size: var(--sp-font-h1);
    line-height: var(--sp-line-height-h1);
    letter-spacing: var(--sp-letter-spacing-h1);
  }

  .sp-nav [data-nav-id="linkedin"],
  .sp-nav [data-nav-id="email"] {
    display: none;
  }

  .sp-list--masonry {
    column-count: 1;
  }

  .sp-project-grid {
    column-count: 1;
  }

  .sp-main-footer {
    height: auto;
    min-height: calc(100dvh - 2 * var(--sp-layout-padding));
    height: calc(100dvh - 2 * var(--sp-layout-padding));
  }

  .sp-main-footer__links {
    margin-top: var(--sp-space-L1);
  }

  .sp-aside__title {
    padding-right: 0;
  }

  .sp-aside__text {
    padding-right: 0;
  }

  .sp-aside .sp-home-aside {
    padding-right: 0;
  }

  .sp-company-title,
  .sp-divider--loose {
    display: none;
  }

  .sp-note-aside .sp-aside__text,
  .sp-note-main .sp-lead {
    display: none;
  }

  .sp-project-card__description {
    display: block;
  }

  .sp-post-page-content
    > :not(.sp-media):not(.sp-divider):not(hr):not(.sp-case) {
    max-width: 100%;
  }

  .sp-media__caption {
    max-width: 100%;
  }

  .sp-case > :not(.sp-media):not(.sp-divider):not(hr) {
    max-width: 100%;
  }

  .sp-significant__row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-space-S3);
  }

  .sp-significant__preview {
    display: none;
  }

  .sp-significant__title {
    flex: 1 1 auto;
    order: 1;
  }

  .sp-significant__row .sp-significant__meta {
    flex: 1 1 100%;
    order: 2;
  }

  .sp-significant__row .sp-significant__meta:last-child {
    flex: 0 0 auto;
    order: 1;
    width: auto;
    margin-left: auto;
    text-align: right;
  }

  .note-card,
  .note-card--media {
    flex-direction: column;
    gap: var(--sp-space-M2);
  }

  .note-card__media {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-space-M3);
    justify-content: flex-start;
  }

  .note-card__cover {
    width: 20%;
  }

  .note-card__badge {
    order: 2;
  }

  .note-card__cover {
    order: 1;
  }

  .note-card__aside {
    width: 100%;
    justify-content: flex-start;
  }

  .note-card__aside--no-cover {
    display: none;
  }

  .note-card__date {
    display: none;
  }
}

@media (max-width: 900px) {
  .sp-scrolled .sp-aside {
    padding-right: 0;
  }
}
