/* cycle™ — Journal index. Ports Articles.jsx layout. */
.cj-hero { position: relative; background: #0a0a0a; color: #fff; padding: clamp(128px,20vh,210px) clamp(20px,5vw,56px) clamp(44px,7vh,84px); overflow: hidden; }
.cj-hero__bg { position: absolute; inset: 0; background-size: 260px; opacity: 0.16; pointer-events: none; }
.cj-hero__scrim { position: absolute; inset: 0; background: var(--scrim-bottom); opacity: 0.5; pointer-events: none; }
.cj-hero__wrap { position: relative; max-width: 1180px; margin: 0 auto; }
.cj-hero__title { margin: 18px 0 0; font-family: var(--font-display); font-weight: 900; font-size: clamp(2.8rem,8vw,6.5rem); line-height: 0.9; letter-spacing: -0.04em; }
.cj-hero__lede { margin: 22px 0 0; max-width: 560px; color: var(--gray-300); font-size: clamp(15px,1.6vw,18px); line-height: 1.5; }
.cj-filter { display: flex; flex-wrap: wrap; gap: 10px; margin-top: clamp(30px,4vw,46px); }
.cj-filter__btn { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; padding: 10px 16px; border-radius: var(--r-sm); border: 1px solid rgba(255,255,255,0.25); background: transparent; color: var(--gray-200); transition: var(--t-base); }
.cj-filter__btn:hover { border-color: rgba(255,255,255,0.6); color: #fff; }
.cj-filter__btn.is-on { border-color: #fff; background: #fff; color: #000; }

.cj-grid-sec { background: var(--paper); color: var(--black); padding: clamp(40px,7vh,80px) clamp(20px,5vw,56px) clamp(80px,13vh,150px); }
.cj-grid-sec__wrap { max-width: 1180px; margin: 0 auto; }

.cj-featured { margin-bottom: clamp(44px,6vw,78px); }
.cj-featured__kicker { display: block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-faint); margin-bottom: 4px; }
.cj-feat-row { display: grid; grid-template-columns: auto minmax(0,1.05fr) minmax(0,0.95fr) auto; align-items: center; gap: clamp(20px,3vw,48px); padding: 26px 14px; border-top: 1px solid var(--hairline); color: var(--black); }
.cj-feat-row:last-child { border-bottom: 1px solid var(--hairline); }
.cj-feat-row__n { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; color: var(--text-faint); }
.cj-feat-row__meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); }
.cj-feat-row__title { margin: 8px 0 0; font-family: var(--font-display); font-weight: 900; font-size: clamp(1.5rem,3.4vw,2.6rem); line-height: 1.0; letter-spacing: -0.03em; }
.cj-feat-row__excerpt { margin: 0; font-size: 15px; line-height: 1.55; color: var(--text-muted); }
.cj-feat-row__arrow { display: inline-flex; color: var(--black); transition: transform var(--d-base) var(--e-out); }
.cj-feat-row:hover .cj-feat-row__arrow { transform: translateX(6px); }

.cj-gridhead { display: flex; align-items: baseline; gap: 16px; margin-bottom: clamp(24px,4vw,40px); border-bottom: 1px solid var(--hairline); padding-bottom: 18px; }
.cj-gridhead span { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-faint); }

.cj-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: clamp(22px,2.6vw,36px); }
.cj-card { display: flex; flex-direction: column; color: var(--black); }
.cj-card__media { position: relative; overflow: hidden; border-radius: var(--r-md); border: 1px solid var(--border); aspect-ratio: 4 / 3; background: #0a0a0a; box-shadow: var(--gloss-edge-dark); }
.cj-card__img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.08); transform: scale(1.03); transition: transform var(--d-slow) var(--e-out), filter var(--d-slow) var(--e-out); }
.cj-card:hover .cj-card__img { transform: scale(1.1); filter: grayscale(1) contrast(1.12) brightness(1.05); }
.cj-card__scrim { position: absolute; inset: 0; background: var(--scrim-bottom); opacity: 0.42; pointer-events: none; }
.cj-card__cat { position: absolute; top: 14px; left: 14px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: #fff; border: 1px solid rgba(255,255,255,0.4); padding: 5px 9px; border-radius: var(--r-sm); background: rgba(0,0,0,0.35); backdrop-filter: blur(4px); }
.cj-card__body { padding-top: 16px; display: flex; flex-direction: column; flex: 1; }
.cj-card__meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); }
.cj-card__title { margin: 10px 0 8px; font-family: var(--font-display); font-weight: 900; font-size: clamp(1.25rem,2vw,1.6rem); line-height: 1.05; letter-spacing: -0.02em; }
.cj-card__excerpt { margin: 0 0 16px; font-size: 15px; line-height: 1.55; color: var(--text-muted); }
.cj-card__read { margin-top: auto; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--black); display: inline-flex; align-items: center; gap: 8px; }

@media (max-width: 640px) {
  .cj-feat-row { grid-template-columns: auto 1fr; gap: 14px; padding: 20px 6px; }
  .cj-feat-row__excerpt, .cj-feat-row__arrow { display: none; }
  .cj-grid { grid-template-columns: 1fr; }
}
