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

:root {
  --bg: #ffffff;
  --ink: #000000;
  --rule: #000000;
  --padding: 48px;
}

html, body {
  height: 100%;
}

body {
  background-color: var(--bg);
  color: var(--ink);
  
  /* font-family: 'Iowan Old Style', 'Palatino Linotype', 'URW Palladio L', P052, serif; */

  font-family: "Palatino Linotype", "Book Antiqua", Palatino, serif;
  font-size: 18px;
  line-height: 1.5;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  padding: var(--padding);
  opacity: 0;
  animation: appear 1.2s ease forwards;
  animation-delay: 0.2s;
}

@keyframes appear {
  to { opacity: 1; }
}

/* ── Header ── */

header {
  margin-bottom: 16px;
}

h1 {
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  font-weight: 400;
  letter-spacing: 0.01em;
  line-height: 1.6;
}

h1 span {
  display: block;
  font-style: italic;
}

/*
hr {
  border: none;
  border-top: 1px solid var(--rule);
  margin: 0;
}
*/

/* ── Main ── */

main {
  flex: 1;
  /* padding-top: 48px; */
  margin-top: 16px;
  border: 0.5px solid var(--ink)
}

/* ── Project grid ── */

.projects {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
}

.project {
  display: contents;
}

.project a {
  grid-column: 1;
  color: var(--ink);
  text-decoration: none;
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  padding: 10px 0;
  border-bottom: 1px solid var(--ink);
}

.project a:hover {
  font-style: italic;
}

.project .year {
  grid-column: 2;
  text-align: right;
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  padding: 10px 0;
  border-bottom: 1px solid var(--ink);
  font-variant-numeric: lining-nums tabular-nums;
}

/* ── Placeholder ── */

/*
.placeholder {
  width: 100%;
  height: 100%;
  position: relative;
}

.placeholder::before,
.placeholder::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom right, transparent calc(50% - 0.5px), var(--ink) calc(50% - 0.5px), var(--ink) calc(50% + 0.5px), transparent calc(50% + 0.5px)),
    linear-gradient(to bottom left,  transparent calc(50% - 0.5px), var(--ink) calc(50% - 0.5px), var(--ink) calc(50% + 0.5px), transparent calc(50% + 0.5px));
}
*/

/* ── Footer ── */

footer {
  margin-top: 48px;
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  font-variant-numeric: lining-nums tabular-nums;
}

/* ── Responsive ── */

@media (min-width: 600px) {
  .projects {
    grid-template-columns: repeat(4, 1fr);
  }
  .project a  { grid-column: 1 / 4; }
  .project .year { grid-column: 4; }
}

@media (min-width: 1024px) {
  .projects {
    grid-template-columns: repeat(6, 1fr);
  }
  .project a  { grid-column: 1 / 6; }
  .project .year { grid-column: 6; }
}

@media (max-width: 600px) {
  :root {
    --padding: 32px 28px;
  }
}
