/* =============================================================================
   article.css — pagina articolo
   Layout editoriale left-aligned, con body a measure controllata e chrome
   tipografico sobrio.
   ============================================================================= */

.article {
  padding-block: var(--space-8);
}

.article-header {
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-5);
  border-bottom: 2px solid var(--ink);
}

.article-eyebrow {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
  margin-bottom: var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--step--1);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  line-height: 1.3;
  text-transform: uppercase;
  color: var(--ink);
}

.article-eyebrow-category {
  color: var(--ink);
}

.article-eyebrow>*+*::before {
  content: "·";
  color: var(--ink-subtle);
  margin-right: var(--space-3);
}

.article-title {
  max-width: 28ch;
  margin: 0 0 var(--space-4);
  font-family: var(--font-serif);
  font-size: var(--step-5);
  font-weight: var(--fw-bold);
  font-variation-settings: "opsz" 60;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-wrap: balance;
}

.article-cover {
  margin: 0 0 var(--space-5);
}

.article-cover img {
  display: block;
  width: 100%;
  height: auto;
  border: 1px solid var(--rule);
}

.article-dek {
  max-width: 56ch;
  margin: 0 0 var(--space-5);
  font-family: var(--font-serif);
  font-size: var(--step-1);
  font-weight: var(--fw-regular);
  font-style: italic;
  line-height: var(--lh-snug);
  color: var(--ink);
  text-wrap: pretty;
}

.article-byline {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
  padding-top: var(--space-3);
  border-top: 1px solid var(--rule);
  font-family: var(--font-sans);
  font-size: var(--step--1);
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink-muted);
}

.article-byline-author {
  color: var(--ink);
  font-weight: var(--fw-semibold);
}

.article-byline>*+*::before {
  content: "·";
  color: var(--ink-subtle);
  margin-right: var(--space-3);
}

.article-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-7);
}

@media (min-width: 900px) {
  .article-layout {
    grid-template-columns: minmax(0, 1fr) 18rem;
    gap: var(--space-8);
  }
}

@media (min-width: 1200px) {
  .article-layout {
    grid-template-columns: minmax(0, 1fr) 20rem;
    gap: var(--space-9);
  }
}

.article-body {
  max-width: 62ch;
  min-width: 0;
}

.article-body>h2:first-child,
.article-body>h3:first-child {
  margin-top: 0;
}

.article-body h2 {
  margin: var(--space-8) 0 var(--space-4);
  padding-top: var(--space-5);
  border-top: 1px solid var(--ink);
  font-family: var(--font-serif);
  font-size: var(--step-3);
  font-weight: var(--fw-bold);
  line-height: 1.2;
  letter-spacing: -0.015em;
  scroll-margin-top: 7rem;
}

.article-body h3 {
  margin: var(--space-6) 0 var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--rule);
  font-family: var(--font-serif);
  font-size: var(--step-2);
  font-weight: var(--fw-semibold);
  line-height: 1.25;
  scroll-margin-top: 7rem;
}

.article-body h4 {
  margin: var(--space-5) 0 var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--step-0);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--ink);
  scroll-margin-top: 7rem;
}

.article-body--dropcap>p:first-of-type::first-letter {
  float: left;
  padding: 0.1em 0.15em 0 0;
  margin-top: 0.05em;
  font-family: var(--font-serif);
  font-size: 4.2em;
  font-weight: var(--fw-bold);
  line-height: 0.9;
  color: var(--ink);
}

.article-body>p:first-of-type {
  margin-bottom: var(--space-5);
  font-size: var(--step-1);
  line-height: var(--lh-snug);
  color: var(--ink);
}

.article-body figure {
  margin: var(--space-7) 0;
}

.article-body>.article-cover:first-child {
  margin-top: 0;
  margin-bottom: var(--space-6);
}

.article-body figure img {
  display: block;
  width: 100%;
  height: auto;
  border: 1px solid var(--rule);
}

.project-detail .article-body figure img {
  cursor: zoom-in;
  transition:
    border-color var(--dur-fast) var(--ease),
    filter var(--dur-fast) var(--ease);
}

.project-detail .article-body figure img:hover {
  border-color: var(--ink);
  filter: contrast(1.02);
}

.article-body figcaption {
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px solid var(--rule);
  font-family: var(--font-sans);
  font-size: var(--step--1);
  line-height: var(--lh-snug);
  color: var(--ink-muted);
}

.article-body figcaption strong {
  display: inline-block;
  margin-right: var(--space-2);
  font-size: var(--step--1);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--ink);
}

@media (min-width: 900px) {
  .article-body .figure-wide {
    width: calc(100% + 18rem + var(--space-8));
    max-width: calc(100% + 18rem + var(--space-8));
  }
}

@media (min-width: 1200px) {
  .article-body .figure-wide {
    width: calc(100% + 20rem + var(--space-9));
    max-width: calc(100% + 20rem + var(--space-9));
  }
}

.article-body .pullquote {
  max-width: none;
}

.image-lightbox {
  width: min(calc(100vw - var(--space-5) * 2), 96rem);
  max-width: none;
  max-height: calc(100vh - var(--space-5) * 2);
  padding: 0;
  background: var(--paper);
  border: 1px solid var(--ink);
  color: var(--ink);
}

.image-lightbox::backdrop {
  background: rgb(10 10 10 / 78%);
}

.image-lightbox-close {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  z-index: 1;
  width: 2.5rem;
  height: 2.5rem;
  display: grid;
  place-items: center;
  padding: 0;
  background: var(--paper);
  border: 1px solid var(--ink);
  border-radius: var(--radius-1);
  color: var(--ink);
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: var(--step--1);
  font-weight: var(--fw-semibold);
  line-height: 1;
}

.image-lightbox-close:hover {
  background: var(--ink);
  color: var(--paper);
}

.image-lightbox-close:focus-visible {
  outline: var(--focus-ring-width) solid var(--focus-ring-color);
  outline-offset: var(--focus-ring-offset);
}

.image-lightbox-close-icon {
  width: 1.25rem;
  height: 1.25rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.image-lightbox-figure {
  margin: 0;
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin-inline: auto;
}

.image-lightbox-figure img {
  display: block;
  width: auto;
  max-width: 100%;
  max-height: calc(100vh - 11rem);
  object-fit: contain;
}

.image-lightbox-figure figcaption {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--rule);
  font-family: var(--font-sans);
  font-size: var(--step--1);
  line-height: var(--lh-snug);
  align-self: stretch;
  text-align: left;
  color: var(--ink-muted);
}

@media (max-width: 640px) {
  .image-lightbox {
    width: calc(100vw - var(--space-3) * 2);
    max-height: calc(100vh - var(--space-3) * 2);
  }

  .image-lightbox-figure {
    padding: var(--space-3);
    padding-top: var(--space-7);
  }

  .image-lightbox-figure img {
    max-height: calc(100vh - 10rem);
  }
}

.pullquote--inverse {
  padding: var(--space-6);
  background: var(--ink);
  border: 0;
  font-style: normal;
  font-weight: var(--fw-regular);
  color: var(--paper);
}

.pullquote--inverse cite {
  display: block;
  margin-top: var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--step--1);
  font-style: normal;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--ink-subtle);
}

.article-aside {
  align-self: start;
  font-family: var(--font-sans);
  font-size: var(--step--1);
  line-height: var(--lh-snug);
  color: var(--ink);
}

@media (min-width: 900px) {
  .article-aside {
    position: sticky;
    top: var(--space-5);
    max-height: calc(100vh - var(--space-7));
    overflow-y: auto;
  }
}

.article-aside-block {
  padding-block: var(--space-5);
  border-top: 2px solid var(--ink);
}

.article-aside-block:first-child {
  padding-top: 0;
  border-top: 0;
}

.article-aside-label {
  margin-bottom: var(--space-3);
  font-size: var(--step--1);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--ink);
}

.article-aside-toc {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: toc;
}

.article-aside-toc li {
  counter-increment: toc;
  padding-block: var(--space-2);
  border-bottom: 1px solid var(--rule);
}

.article-aside-toc li:last-child {
  border-bottom: 0;
}

.article-aside-toc li::before {
  content: counter(toc, decimal-leading-zero);
  display: inline-block;
  width: 2.2em;
  font-family: var(--font-mono);
  font-size: 0.85em;
  color: var(--ink-subtle);
}

.article-aside-toc a {
  color: var(--ink);
  text-decoration: none;
}

.article-aside-toc a:hover {
  background: var(--selection);
  text-decoration: underline;
  text-decoration-thickness: 2px;
}

.article-aside-related {
  list-style: none;
  padding: 0;
  margin: 0;
}

.article-aside-related li {
  padding-block: var(--space-3);
  border-bottom: 1px solid var(--rule);
}

.article-aside-related li:last-child {
  border-bottom: 0;
}

.article-aside-related-meta {
  margin-bottom: var(--space-1);
  font-size: calc(var(--step--1) * 0.9);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--ink-muted);
}

.article-aside-related a {
  font-family: var(--font-serif);
  font-size: var(--step-0);
  font-weight: var(--fw-semibold);
  line-height: 1.3;
  color: var(--ink);
  text-decoration: none;
  text-wrap: balance;
}

.article-aside-related a:hover {
  background: var(--selection);
  text-decoration: underline;
  text-decoration-thickness: 2px;
}

.article-aside-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.article-aside-tag {
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--rule);
  border-radius: var(--radius-1);
  font-size: var(--step--1);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
}

.article-aside-tag:hover {
  background: var(--selection);
  border-color: var(--ink);
  text-decoration: none;
}

.article-footer {
  margin-top: var(--space-9);
  padding-top: var(--space-6);
  border-top: 2px solid var(--ink);
  font-family: var(--font-sans);
  font-size: var(--step--1);
  color: var(--ink-muted);
}

.article-footer-author {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  max-width: 60ch;
  margin-bottom: var(--space-6);
}

.article-footer-author-label {
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--ink);
}

.article-footer-author-bio {
  margin: 0;
  font-family: var(--font-serif);
  font-size: var(--step-0);
  line-height: var(--lh-snug);
  color: var(--ink);
}

.article-footer-author-bio a {
  color: var(--ink);
  font-weight: var(--fw-semibold);
}

.article-nav {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px solid var(--rule);
}

@media (min-width: 640px) {
  .article-nav {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
  }
}

.article-nav-item {
  display: block;
  padding: var(--space-4) 0;
  text-decoration: none;
  color: var(--ink);
}

.article-nav-item-label {
  margin-bottom: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--step--1);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--ink-muted);
}

.article-nav-item-title {
  font-family: var(--font-serif);
  font-size: var(--step-1);
  font-weight: var(--fw-semibold);
  line-height: 1.3;
  color: var(--ink);
  text-wrap: balance;
}

.article-nav-item:hover .article-nav-item-title {
  background: var(--selection);
  text-decoration: underline;
  text-decoration-thickness: 2px;
}

.article-nav-item--next {
  text-align: right;
}
