/* Media page specific styles – minimal, building on base.css */

.page-hero {
  padding: 3rem 0 2rem;
  background: linear-gradient(135deg, rgba(255,153,102,.08), rgba(255,204,0,.08));
}
.hero-inner { max-width: 72rem; margin: 0 auto; }
.page-title { font-weight: 800; letter-spacing: -.02em; }
.page-lead { margin-top: .5rem; color: var(--text-muted, #444); }

.in-page-nav { margin-top: 1rem; }
.in-page-list { display: flex; flex-wrap: wrap; gap: .5rem .75rem; padding: 0; list-style: none; }
.in-page-list a { display: inline-block; padding: .4rem .7rem; border-radius: 999px; background: var(--surface-2, #f3f4f6); text-decoration: none; }
.in-page-list a:focus-visible { outline: 2px solid var(--focus, #111); outline-offset: 2px; }

.media-section { padding: 2.5rem 0; }
.media-section.alt { background: var(--surface-1, #fafafa); }
.section-header { max-width: 60rem; margin: 0 auto 1.25rem; }
.section-header p { color: var(--text-muted, #555); }

.media-grid { display: grid; gap: 1rem; grid-template-columns: repeat(12, 1fr); }
.media-grid.single > .media-item { grid-column: span 12; }
.media-grid.videos > .media-item { grid-column: span 12; }
.media-grid > .media-item { background: var(--surface-0, #fff); border-radius: .75rem; overflow: hidden; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.media-item.image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.media-item figcaption { font-size: .95rem; padding: .75rem 1rem; color: var(--text-muted, #555); }

/* Responsive columns */
@media (min-width: 640px) {
  .media-grid > .media-item { grid-column: span 6; }
  .media-grid.videos > .media-item { grid-column: span 6; }
}
@media (min-width: 1024px) {
  .media-grid > .media-item { grid-column: span 4; }
  .media-grid.single > .media-item { grid-column: span 8; justify-self: center; }
}

/* Video wrapper */
.video-embed { position: relative; width: 100%; aspect-ratio: 16 / 9; background: radial-gradient(circle at 30% 20%, rgba(255,204,0,.25), transparent 50%), radial-gradient(circle at 70% 80%, rgba(255,153,102,.25), transparent 50%), var(--surface-2, #f3f4f6); }
.video-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; border-radius: .5rem; }

/* Cards */
.card-list { display: grid; grid-template-columns: 1fr; gap: 1rem; padding: 0; list-style: none; }
.card { background: var(--surface-0, #fff); border-radius: .75rem; padding: 1rem; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.card h3 { margin: 0 0 .5rem; }
.card p { margin: 0 0 .75rem; color: var(--text-muted, #555); }

/* Buttons (assuming base.css defines .button; provide light variant if not) */
.button { display: inline-block; padding: .6rem 1rem; border-radius: .5rem; text-decoration: none; background: var(--accent, #ff9f1c); color: #111; font-weight: 700; }
.button.ghost { background: transparent; border: 2px solid var(--surface-3, #e5e7eb); color: inherit; }

.prose { max-width: 60rem; margin: 0 auto; }
.hint { margin-top: .75rem; color: var(--text-muted, #666); }

.back-to-top { padding: 2rem 0; text-align: center; }
