/* =========================================================
   SOUL VACATION — Journal article layout
   Shared by the standalone article pages. Full-bleed hero,
   a comfortable single reading column in Jost, a display
   pull-quote, and a footer that points home.
   ========================================================= */

/* --- HERO (full-bleed) --- */
.art-hero {
  position: relative;
  height: clamp(520px, 80vh, 900px);
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  background: var(--c-charcoal);
}
.art-hero__img {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
}
@media (prefers-reduced-motion: no-preference) {
  .art-hero__img { animation: artKen 3000ms var(--ease-out) both; }
  @keyframes artKen { from { transform: scale(1.08); } to { transform: scale(1); } }
}
.art-hero::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(14,22,32,0.80), rgba(14,22,32,0.10) 54%, rgba(14,22,32,0.28));
}
.art-hero__inner {
  position: relative; z-index: 1;
  width: 100%; max-width: 1180px; margin: 0 auto;
  padding: 0 clamp(24px, 8vw, 80px) clamp(46px, 6vw, 86px);
  color: var(--c-snow);
}
.art-hero__crumb {
  font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase;
  color: rgba(255,255,255,0.6); font-weight: 500;
  display: flex; align-items: center; gap: 12px; margin-bottom: 26px;
}
.art-hero__crumb a { color: rgba(255,255,255,0.78); }
.art-hero__crumb .sep { width: 16px; height: 1px; background: rgba(255,255,255,0.3); }
.art-hero__cat {
  font-family: var(--f-body); font-weight: 500; font-size: 11px;
  letter-spacing: 0.24em; text-transform: uppercase; color: var(--c-cool-steel);
}
.art-hero__h {
  font-family: var(--f-display); font-weight: 300;
  font-size: clamp(38px, 6vw, 92px); line-height: 0.98;
  letter-spacing: -0.018em; margin: 18px 0 0; max-width: 18ch;
  text-wrap: balance;
}
.art-hero__h .it { font-style: italic; }
.art-hero__meta {
  margin-top: 28px; display: flex; flex-wrap: wrap; gap: 10px 22px;
  font-family: var(--f-body); font-size: 10px; font-weight: 500;
  letter-spacing: 0.2em; text-transform: uppercase; color: rgba(255,255,255,0.62);
}
.art-hero__meta span { display: inline-flex; align-items: center; gap: 22px; }
.art-hero__meta span + span::before { content: "·"; margin-right: 22px; color: rgba(255,255,255,0.4); }

/* --- BODY --- */
.article { background: var(--c-pearl); padding: clamp(60px, 8vw, 108px) 24px clamp(80px, 10vw, 140px); }
.article__wrap { max-width: 640px; margin: 0 auto; }
.article__stand {
  font-family: var(--f-display); font-style: italic; font-weight: 300;
  font-size: clamp(23px, 2.6vw, 34px); line-height: 1.34;
  letter-spacing: -0.008em; color: var(--c-aegean);
  margin: 0 0 46px; text-wrap: pretty;
}
.article__body { font-family: var(--f-body); }
.article__body > p {
  font-size: 18px; line-height: 1.85; font-weight: 400;
  color: rgba(14,22,32,0.84); margin: 0 0 26px; text-wrap: pretty;
}
.article__body > p:last-child { margin-bottom: 0; }
.article__body em { font-style: italic; }
.article__body strong { font-weight: 500; }
.article__body a { color: var(--c-aegean); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; text-decoration-color: rgba(27,58,92,0.4); transition: text-decoration-color 240ms var(--ease-out); }
.article__body a:hover { text-decoration-color: var(--c-aegean); }
.article__h2 {
  font-family: var(--f-display); font-weight: 300;
  font-size: clamp(26px, 3vw, 38px); line-height: 1.12;
  letter-spacing: -0.012em; color: var(--c-charcoal);
  margin: 48px 0 22px;
}
.article__h2 .it { font-style: italic; }

/* mid-article pull-quote */
.article__pull { margin: 52px 0; }
.article__pull::before { content: ""; display: block; width: 48px; height: 2px; background: var(--c-olive); margin-bottom: 26px; }
.article__pull p {
  font-family: var(--f-display); font-style: italic; font-weight: 300;
  font-size: clamp(26px, 3.4vw, 40px); line-height: 1.26;
  letter-spacing: -0.012em; color: var(--c-aegean); margin: 0;
  text-wrap: balance;
}

/* --- FOOTER / KEEP READING --- */
.article__foot { max-width: 640px; margin: clamp(56px, 7vw, 92px) auto 0; }
.article__cta {
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  padding: 30px 32px; background: var(--c-aegean); color: var(--c-snow);
  text-decoration: none;
}
.article__cta-l { display: flex; flex-direction: column; gap: 8px; }
.article__cta-lab { font-family: var(--f-body); font-weight: 500; font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--c-cool-steel); }
.article__cta-h { font-family: var(--f-display); font-weight: 300; font-size: clamp(22px, 2.2vw, 30px); line-height: 1.1; }
.article__cta-h .it { font-style: italic; }
.article__cta-ar { font-family: var(--f-display); font-style: italic; font-size: 26px; flex: none; transition: transform 360ms var(--ease-out); }
.article__cta:hover .article__cta-ar { transform: translateX(8px); }

.article__more { margin-top: 56px; }
.article__more-lab {
  display: flex; align-items: center; gap: 16px;
  font-family: var(--f-body); font-weight: 500; font-size: 10px;
  letter-spacing: 0.24em; text-transform: uppercase; color: var(--c-olive); margin-bottom: 26px;
}
.article__more-lab::after { content: ""; flex: 1; height: 1px; background: rgba(14,22,32,0.16); }
.article__more-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 3vw, 40px); }
.article__rd { display: block; color: inherit; text-decoration: none; }
.article__rd-img { position: relative; overflow: hidden; background: var(--c-bone); aspect-ratio: 16 / 10; margin-bottom: 16px; }
.article__rd-img .img { position: absolute; inset: 0; background-size: cover; background-position: center; transform: scale(1.04); transition: transform 1400ms var(--ease-in-out); }
@media (hover: hover) and (pointer: fine) { .article__rd:hover .article__rd-img .img { transform: scale(1.09); } }
.article__rd-cat { font-family: var(--f-body); font-weight: 500; font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--c-olive); }
.article__rd-h { font-family: var(--f-display); font-weight: 300; font-size: clamp(19px, 1.7vw, 24px); line-height: 1.16; letter-spacing: -0.008em; color: var(--c-charcoal); margin: 8px 0 0; }
.article__rd-h .it { font-style: italic; }

@media (max-width: 600px) {
  .article__cta { flex-direction: column; align-items: flex-start; gap: 16px; padding: 26px 24px; }
  .article__more-grid { grid-template-columns: 1fr; gap: 28px; }
}
