/* cycle™ — Case study page. Ports case-study.html styles. */
body.cy-case { background: var(--paper); color: var(--black); }
.cy-case .mono { font-family: var(--font-mono); letter-spacing: 0.12em; text-transform: uppercase; }
.cc-wrap { max-width: 1180px; margin: 0 auto; padding: 0 clamp(20px,5vw,56px); }

.cc-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); mix-blend-mode: difference; }
.cc-header img { height: 22px; }
.cc-header a { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: #fff; text-decoration: none; }

.cc-intro { background: #000; color: #fff; padding: clamp(110px,18vh,200px) clamp(20px,5vw,56px) clamp(40px,7vh,72px); }
.cc-intro .cc-ey { color: var(--gray-300); font-size: 12px; }
.cc-intro h1 { margin: 16px 0 18px; font-family: var(--font-display); font-weight: 900; font-style: italic; font-size: clamp(3rem,11vw,9rem); line-height: 0.86; letter-spacing: -0.04em; }
.cc-intro p { max-width: 640px; margin: 0; color: var(--gray-200); font-size: clamp(1rem,1.6vw,1.35rem); line-height: 1.5; }
.cc-hint { margin-top: 28px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gray-500); display: flex; align-items: center; gap: 10px; }
.cc-hint::before { content: ""; width: 26px; height: 1px; background: var(--gray-500); }

.cc-meta { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; padding: clamp(48px,8vh,90px) 0; border-bottom: 1px solid var(--hairline); }
.cc-k { font-size: 11px; color: var(--text-faint); margin-bottom: 10px; }
.cc-v { font-family: var(--font-display); font-weight: 700; font-size: clamp(1rem,1.4vw,1.25rem); letter-spacing: -0.01em; }
.cc-v small { display: block; font-family: var(--font-mono); font-weight: 400; font-size: 12px; letter-spacing: 0.04em; text-transform: none; color: var(--text-muted); margin-top: 4px; }

.cc-overview { display: grid; grid-template-columns: 0.8fr 1.6fr; gap: clamp(24px,5vw,72px); padding: clamp(56px,10vh,120px) 0; }
.cc-lab { font-size: 11px; color: var(--text-muted); }
.cc-overview h2 { margin: 0; font-family: var(--font-display); font-weight: 900; font-size: clamp(1.6rem,3vw,2.6rem); line-height: 1.08; letter-spacing: -0.02em; text-wrap: balance; }
.cc-overview h2 + p { margin: 24px 0 0; max-width: 640px; font-size: 1.05rem; line-height: 1.65; color: var(--text-body); }

.cc-next { position: relative; height: 60vh; min-height: 380px; overflow: hidden; background: #000; display: block; text-decoration: none; }
.cc-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); }
.cc-next:hover img { transform: scale(1.06); }
.cc-scrim { position: absolute; inset: 0; background: var(--scrim-radial); opacity: 0.7; }
.cc-next-inner { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #fff; text-align: center; }
.cc-next-inner .cc-ey { color: var(--gray-300); font-size: 11px; margin-bottom: 14px; }
.cc-next-inner h3 { margin: 0; font-family: var(--font-display); font-weight: 900; font-style: italic; font-size: clamp(2.5rem,8vw,6rem); letter-spacing: -0.03em; }

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

.cc-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.74); backdrop-filter: blur(18px) saturate(120%); border-top: 1px solid rgba(255,255,255,0.10); }
.cc-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; }
.cc-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; }
.cc-mn-next { border: 1px solid rgba(255,255,255,0.25); border-radius: var(--r-sm); padding: 8px 12px; }

@media (max-width: 720px) {
  .cc-meta { grid-template-columns: repeat(2,1fr); }
  .cc-overview { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .cc-mininav { display: flex; }
  .cc-header a:last-child { display: none; }
  body.cy-case { padding-bottom: 68px; }
}
