/* ===== Videos page ===== */

.featured-video {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
  align-items: center;
}
.featured-video__player {
  position: relative;
  aspect-ratio: 16/9;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-surface-card);
  cursor: pointer;
}
.featured-video__player::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(20,20,19,0.45) 100%);
  z-index: 1;
}
.featured-video__player image-slot {
  display: block !important;
  width: 100% !important; height: 100% !important;
  aspect-ratio: auto !important;
  --slot-radius: 0;
  --slot-border: 0;
  --slot-bg: var(--color-surface-card);
}
.featured-video__play {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 88px; height: 88px;
  border-radius: 50%;
  background: rgba(250,249,245,0.95);
  color: var(--color-primary);
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
  transition: transform 0.2s var(--ease);
}
.featured-video__player:hover .featured-video__play { transform: translate(-50%, -50%) scale(1.05); }
.featured-video__duration {
  position: absolute;
  bottom: 16px; right: 16px;
  z-index: 2;
  padding: 4px 10px;
  background: rgba(20,20,19,0.75);
  color: var(--color-on-dark);
  border-radius: var(--radius-sm);
  font: var(--type-caption);
}

@media (max-width: 760px) { .featured-video { grid-template-columns: 1fr; } }

/* ===== Featured duo (2 highlight videos side by side) ===== */
.featured-duo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
}
.featured-duo__card {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  background: var(--color-canvas);
  border: 1px solid var(--color-hairline);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  text-decoration: none;
  color: inherit;
  transition: transform 0.25s var(--ease), border-color 0.25s var(--ease), box-shadow 0.25s var(--ease);
}
.featured-duo__card:hover {
  transform: translateY(-3px);
  border-color: var(--color-primary);
  box-shadow: 0 14px 32px rgba(20, 20, 19, 0.08);
}
.featured-duo__player {
  position: relative;
  aspect-ratio: 16/9;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-surface-card);
  cursor: pointer;
}
.featured-duo__player::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(20,20,19,0.5) 100%);
  z-index: 1;
}
.featured-duo__player image-slot {
  display: block !important;
  width: 100% !important; height: 100% !important;
  aspect-ratio: auto !important;
  --slot-radius: 0;
  --slot-border: 0;
  --slot-bg: var(--color-surface-card);
}
.featured-duo__play {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 68px; height: 68px;
  border-radius: 50%;
  background: rgba(250,249,245,0.95);
  color: var(--color-primary);
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
  transition: transform 0.2s var(--ease);
}
.featured-duo__card:hover .featured-duo__play { transform: translate(-50%, -50%) scale(1.08); }
.featured-duo__badge {
  position: absolute;
  top: 14px; left: 14px;
  z-index: 2;
  padding: 5px 12px;
  background: rgba(250,249,245,0.92);
  color: var(--color-primary);
  border-radius: var(--radius-pill);
  font: var(--type-caption);
  letter-spacing: 0.06em;
}
.featured-duo__badge--case {
  background: var(--color-primary);
  color: var(--color-on-primary);
}
.featured-duo__meta {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: var(--space-sm) var(--space-md) var(--space-md);
}
.featured-duo__title {
  font-family: var(--font-display);
  font-size: clamp(22px, 2vw, 26px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--color-ink);
  margin: 6px 0 0;
}
.featured-duo__desc {
  font: var(--type-body-sm);
  color: var(--color-body);
  line-height: 1.55;
  margin: 0;
}

@media (max-width: 760px) {
  .featured-duo { grid-template-columns: 1fr; }
}

/* ===== Filter chips (shared) ===== */
.filter-bar {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-bottom: 32px;
}
.chip {
  padding: 10px 18px;
  border-radius: var(--radius-pill);
  font: var(--type-button);
  color: var(--color-body);
  background: transparent;
  border: 1px solid var(--color-hairline);
  transition: background 0.2s var(--ease), color 0.2s var(--ease), border-color 0.2s var(--ease);
}
.chip:hover { border-color: var(--color-ink); }
.chip.is-active { background: var(--color-ink); color: var(--color-on-dark); border-color: var(--color-ink); }

/* ===== Shorts grid ===== */
.shorts-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
}
.short {
  display: flex; flex-direction: column;
  background: var(--color-canvas);
  border: 1px solid var(--color-hairline);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform 0.25s var(--ease), border-color 0.25s var(--ease);
}
.short:hover { transform: translateY(-2px); border-color: var(--color-surface-card); }
.short__thumb {
  position: relative;
  aspect-ratio: 9/16;
  overflow: hidden;
}
.short__thumb::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(20,20,19,0.55) 100%);
}
.short__thumb image-slot {
  display: block !important;
  width: 100% !important; height: 100% !important;
  aspect-ratio: auto !important;
  --slot-radius: 0;
  --slot-border: 0;
  --slot-bg: var(--color-surface-card);
}
.short:nth-child(3n) .short__thumb image-slot { --slot-bg: var(--color-surface-card); }
.short:nth-child(5n) .short__thumb image-slot { --slot-bg: var(--color-surface-card); }
.short__play {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 48px; height: 48px;
  border-radius: 50%;
  background: rgba(250,249,245,0.92);
  color: var(--color-primary);
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
}
.short__duration {
  position: absolute;
  bottom: 8px; right: 8px;
  z-index: 2;
  padding: 2px 8px;
  background: rgba(20,20,19,0.75);
  color: var(--color-on-dark);
  border-radius: var(--radius-sm);
  font: var(--type-caption);
  font-size: 11px;
}
.short__meta { padding: 14px 16px; display: flex; flex-direction: column; gap: 6px; }
.short__tag { font: var(--type-caption); color: var(--color-muted); }
.short__title { font: var(--type-title-sm); color: var(--color-ink); font-weight: 500; line-height: 1.35; }

@media (max-width: 1100px) { .shorts-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 720px) { .shorts-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .shorts-grid { grid-template-columns: repeat(2, 1fr); } }

/* ===== Videos page: tight 5-col grid (browse-many mode) ===== */
.video-grid--tight {
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}

/* Case cards: more vertical phone-screen aspect (Shorts feel) */
.video-grid--tight .video-card--case .video-card__thumb {
  aspect-ratio: 1 / 2;
}
@media (max-width: 1180px) { .video-grid--tight { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 960px)  { .video-grid--tight { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px)  { .video-grid--tight { grid-template-columns: repeat(2, 1fr); gap: 10px; } }

.video-grid--tight .video-card { border-radius: 12px; }
.video-grid--tight .video-card__meta { padding: 10px 12px 14px; gap: 4px; }
.video-grid--tight .video-card__title {
  font-size: 13.5px;
  line-height: 1.32;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  overflow: hidden;
}
.video-grid--tight .video-card__age { font-size: 11px; letter-spacing: 0.02em; }
.video-grid--tight .video-card__play {
  width: 42px; height: 42px;
}
.video-grid--tight .video-card__play svg { width: 16px; height: 16px; }
.video-grid--tight .video-card__case-num {
  font-size: 11px; padding: 2px 8px;
  top: 8px; left: 8px;
}
.video-grid--tight .video-card__case-tag {
  font-size: 10px; padding: 2px 7px;
  bottom: 8px; left: 8px;
}
.video-grid--tight .video-card__duration {
  font-size: 10px; padding: 2px 6px;
  bottom: 8px; right: 8px;
}

/* tighter section rhythm on videos page */
.videos-section-tight { padding-top: 48px; padding-bottom: 48px; }
.videos-section-tight .section__head { margin-bottom: 20px; }
.videos-section-tight .filter-bar { margin-bottom: 18px; }

/* ===== Filter row: chips on left + top grid nav on right ===== */
.filter-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.filter-row .filter-bar {
  margin-bottom: 0;
  flex: 1 1 auto;
  min-width: 0;
}

/* count pill inside each filter chip */
.chip__count {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 7px;
  border-radius: 999px;
  background: var(--color-surface-card);
  font-size: 11px;
  font-weight: 500;
  color: var(--color-muted);
  vertical-align: 1px;
  transition: background 0.2s var(--ease), color 0.2s var(--ease);
}
.chip.is-active .chip__count {
  background: rgba(250, 249, 245, 0.18);
  color: var(--color-on-dark);
}
.chip.is-empty {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

/* top grid nav: prev / page label / next */
.grid-nav {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  background: var(--color-canvas);
  border: 1px solid var(--color-hairline);
  border-radius: var(--radius-pill);
  padding: 4px;
  flex: 0 0 auto;
}
.grid-nav__btn {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 0;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-ink);
  cursor: pointer;
  transition: background 0.2s var(--ease);
}
.grid-nav__btn:hover:not(:disabled) { background: var(--color-surface-card); }
.grid-nav__btn:disabled { opacity: 0.3; cursor: not-allowed; }
.grid-nav__btn svg { width: 14px; height: 14px; }
.grid-nav__page {
  font: var(--type-caption);
  color: var(--color-body);
  min-width: 56px;
  text-align: center;
  letter-spacing: 0.02em;
  padding: 0 4px;
}

/* count badge next to section h2 */
.section-count {
  display: inline-block;
  vertical-align: middle;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--color-primary);
  background: var(--color-surface-card);
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  margin-left: 12px;
  letter-spacing: 0.02em;
  position: relative;
  top: -4px;
  white-space: nowrap;
}

@media (max-width: 640px) {
  .filter-row { flex-direction: column; align-items: stretch; }
  .grid-nav { align-self: flex-end; }
  .section-count { font-size: 12px; padding: 3px 10px; margin-left: 8px; top: -3px; }
}
