/* cycle™ — Journal article reader. Ports article.html styles. */
body.cy-article { background: var(--paper); color: var(--black); }
.cy-article .mono { font-family: var(--font-mono); letter-spacing: 0.12em; text-transform: uppercase; }

.ca-header { position: fixed; top: 0; left: 0; right: 0; z-index: 40; display: flex; align-items: center; justify-content: space-between; padding: 18px clamp(20px,5vw,56px); }
.ca-header img { height: 22px; }
.ca-back { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--black); text-decoration: none; }

.ca-head { max-width: 860px; margin: 0 auto; padding: clamp(120px,18vh,200px) clamp(20px,5vw,56px) clamp(36px,6vh,64px); text-align: center; }
.ca-head .ca-ey { font-size: 12px; color: var(--text-muted); }
.ca-head h1 { margin: 20px 0 22px; font-family: var(--font-display); font-weight: 900; font-size: clamp(2.25rem,6vw,4.5rem); line-height: 0.98; letter-spacing: -0.03em; text-wrap: balance; }
.ca-by { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); }
.ca-hint { text-align: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gray-400); padding-bottom: 20px; }

.ca-body { max-width: 680px; margin: 0 auto; padding: clamp(56px,10vh,120px) clamp(20px,5vw,56px); }
.ca-body p { font-size: clamp(1.05rem,1.5vw,1.3rem); line-height: 1.7; color: var(--text-body); margin: 0 0 1.5em; }
.ca-body p:first-child::first-letter { font-family: var(--font-display); font-weight: 900; font-style: italic; font-size: 3.4em; line-height: 0.8; float: left; margin: 6px 14px 0 0; color: var(--black); }

.ca-next { position: relative; height: 56vh; min-height: 340px; overflow: hidden; background: #000; display: block; text-decoration: none; }
.ca-next img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.08); transition: transform var(--d-cine) var(--e-out); }
.ca-next:hover img { transform: scale(1.06); }
.ca-scrim { position: absolute; inset: 0; background: var(--scrim-radial); opacity: 0.72; }
.ca-next-inner { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #fff; text-align: center; padding: 0 24px; }
.ca-next-inner .ca-ey { color: var(--gray-300); font-size: 11px; margin-bottom: 14px; }
.ca-next-inner h3 { margin: 0; font-family: var(--font-display); font-weight: 900; font-size: clamp(1.75rem,5vw,3.5rem); line-height: 1; letter-spacing: -0.03em; max-width: 760px; }

.ca-footer { padding: clamp(40px,7vh,72px) clamp(20px,5vw,56px); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 20px; border-top: 1px solid var(--hairline); }
.ca-footer img { height: 26px; }
.ca-footer .mono { font-size: 11px; color: var(--text-muted); }
.ca-cta { text-decoration: none; border-bottom: 1px solid var(--border); padding-bottom: 4px; }

.ca-mininav { position: fixed; left: 0; right: 0; bottom: 0; z-index: 60; display: none; align-items: center; justify-content: space-between; gap: 12px; padding: 11px 14px calc(11px + env(safe-area-inset-bottom)); background: rgba(10,10,10,0.78); backdrop-filter: blur(18px) saturate(120%); border-top: 1px solid rgba(255,255,255,0.10); }
.ca-mininav a { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: #fff; text-decoration: none; display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; }
.ca-mn-title { font-family: var(--font-display); font-weight: 900; font-style: italic; font-size: 15px; color: #fff; letter-spacing: -0.01em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 38vw; text-align: center; }
.ca-mn-next { border: 1px solid rgba(255,255,255,0.25); border-radius: var(--r-sm); padding: 8px 12px; }
@media (max-width: 760px) {
  .ca-mininav { display: flex; }
  .ca-back { display: none; }
  body.cy-article { padding-bottom: 68px; }
}
