/* =========================================================================
   WOLF — Journal (index + article)
   Layered on top of wolf-b.css — tokens & nav/footer come from there.
   ========================================================================= */

/* ---- index: featured + meta ---- */
.j-featured { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(28px,4vw,64px); align-items: center; margin-bottom: clamp(44px,7vh,80px); }
.j-featured .ph { aspect-ratio: 16/10; }
.j-featured a.media { display: block; }
.j-featured .cat { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--amber); display: flex; gap: 12px; }
.j-featured .cat span { color: var(--muted); }
.j-featured h2 { font-family: var(--display); font-weight: 300; font-size: clamp(30px,3.6vw,48px); line-height: 1.05; letter-spacing: -0.02em; margin: 18px 0 0; }
.j-featured h2 a { transition: color .25s; }
.j-featured h2 a:hover { color: var(--amber); }
.j-featured .dek { font-size: 16px; line-height: 1.62; color: var(--ink-2); margin: 20px 0 0; max-width: 44ch; }
.j-featured .by { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); margin-top: 26px; }

.j-cat-bar { display: flex; flex-wrap: wrap; gap: 10px; margin-top: clamp(30px,4.5vh,52px); }
.j-cat { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-2); border: 1px solid var(--line-2); padding: 10px 17px; border-radius: 999px; transition: background .2s, color .2s, border-color .2s; }
.j-cat:hover, .j-cat.active { background: var(--amber); color: var(--bg); border-color: var(--amber); }

.jrnl-card h4 a { transition: color .25s; }
.jrnl-card:hover h4 a { color: var(--amber); }
.jrnl-card .by { font-family: var(--mono); font-size: 11px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--muted); margin-top: 10px; }

@media (max-width: 860px) {
  .j-featured { grid-template-columns: 1fr; gap: 26px; }
}

/* =========================================================================
   ARTICLE
   ========================================================================= */
.art-head { padding-top: calc(var(--nav-h) + clamp(46px,8vh,96px)); position: relative; overflow: hidden; }
.art-head::before { content:""; position:absolute; inset:0; pointer-events:none; background: radial-gradient(54% 60% at 82% 6%, rgba(214,158,107,0.18), rgba(214,158,107,0) 60%); }
.art-head .wrap { position: relative; z-index: 2; }
.art-crumb { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); display: inline-flex; gap: 10px; align-items: center; }
.art-crumb a { color: var(--amber); }
.art-cat { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--amber); display: flex; gap: 14px; margin-top: 30px; }
.art-cat span { color: var(--muted); }
.art-head h1 { font-family: var(--display); font-weight: 300; font-size: clamp(36px,5.4vw,72px); line-height: 1.02; letter-spacing: -0.025em; margin: 20px 0 0; max-width: 20ch; }
.art-dek { font-size: clamp(17px,1.4vw,21px); line-height: 1.55; color: var(--ink-2); margin: 28px 0 0; max-width: 54ch; }
.art-byline { display: flex; flex-wrap: wrap; gap: 26px; align-items: center; margin: 36px 0 0; padding-top: 26px; border-top: 1px solid var(--line); }
.art-byline .who { font-family: var(--display); font-size: 17px; color: var(--ink); }
.art-byline .meta { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); }

.art-hero { margin: clamp(40px,6vh,72px) 0 0; }
.art-hero .ph { aspect-ratio: 16/9; }
.art-hero .cap { display: block; font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em; color: var(--muted); margin-top: 14px; text-transform: uppercase; }

.article { padding-top: clamp(48px,7vh,80px); padding-bottom: clamp(60px,9vh,120px); }
.article-wrap { max-width: 740px; margin: 0 auto; }
.article-wrap > * { grid-column: auto; }
.article p { font-size: clamp(17px,1.25vw,19px); line-height: 1.74; color: var(--ink-2); margin: 0 0 26px; }
.article p.lead { font-size: clamp(19px,1.5vw,23px); line-height: 1.6; color: var(--ink); margin-bottom: 30px; }
.article p strong { color: var(--ink); font-weight: 600; }
.article a.in { color: var(--amber); border-bottom: 1px solid rgba(214,158,107,0.4); transition: border-color .2s; }
.article a.in:hover { border-bottom-color: var(--amber); }
.article h2 { font-family: var(--display); font-weight: 400; font-size: clamp(25px,2.7vw,34px); line-height: 1.14; letter-spacing: -0.015em; color: var(--ink); margin: clamp(40px,6vh,60px) 0 18px; }
.article h3 { font-family: var(--display); font-weight: 400; font-size: clamp(20px,2vw,24px); color: var(--ink); margin: 36px 0 14px; }
.article ul { margin: 0 0 26px; padding: 0; list-style: none; }
.article ul li { position: relative; padding-left: 26px; font-size: clamp(16px,1.2vw,18px); line-height: 1.66; color: var(--ink-2); margin-bottom: 13px; }
.article ul li::before { content:""; position: absolute; left: 2px; top: 12px; width: 7px; height: 1px; background: var(--amber); }
.article blockquote { margin: clamp(40px,6vh,60px) 0; padding: 0 0 0 28px; border-left: 2px solid var(--amber); }
.article blockquote p { font-family: var(--display); font-weight: 300; font-size: clamp(22px,2.4vw,30px); line-height: 1.34; color: var(--ink); margin: 0; }
.article hr { border: none; border-top: 1px solid var(--line); margin: clamp(44px,6vh,64px) 0; }

/* related systems — internal linking block */
.art-related { max-width: 740px; margin: clamp(20px,3vh,36px) auto 0; padding-top: clamp(30px,4vh,44px); border-top: 1px solid var(--line); }
.art-related .lbl { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }
.art-related .links { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.art-related a { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.07em; text-transform: uppercase; color: var(--ink-2); border: 1px solid var(--line-2); padding: 10px 17px; border-radius: 999px; display: inline-flex; gap: 9px; align-items: center; transition: background .2s, color .2s, border-color .2s; }
.art-related a:hover { background: var(--amber); color: var(--bg); border-color: var(--amber); }

/* more from journal */
.art-more { border-top: 1px solid var(--line); }
.art-more .wrap { padding-top: clamp(60px,9vh,110px); padding-bottom: clamp(60px,9vh,110px); }
.art-more .head { font-family: var(--display); font-weight: 300; font-size: clamp(26px,3vw,40px); letter-spacing: -0.02em; text-transform: lowercase; margin: 0 0 clamp(34px,5vh,52px); }

@media (max-width: 560px) {
  .art-byline { gap: 8px 20px; }
}
