/* ─── MEDIA ARCHIVE ─── */
.media-page { max-width: 1280px; margin: 0 auto; padding: 72px 24px 120px; }
.media-intro { display: flex; align-items: flex-end; justify-content: space-between; gap: 32px; margin-bottom: 36px; }
.media-intro h2 { font-family: var(--font-serif); font-size: clamp(28px, 4vw, 44px); color: var(--blue-deep); line-height: 1.1; }
.media-intro p { max-width: 560px; font-size: 14px; color: var(--text-secondary); line-height: 1.7; }
.media-switcher { display: inline-flex; gap: 4px; padding: 4px; margin-bottom: 36px; background: var(--surface); border: 1px solid var(--border-light); border-radius: 12px; }
.media-switch { min-width: 170px; padding: 11px 18px; border-radius: 8px; color: var(--text-secondary); font-size: 13px; font-weight: 700; transition: all var(--transition-fast); }
.media-switch span { display: inline-flex; min-width: 24px; justify-content: center; margin-left: 7px; padding: 2px 7px; border-radius: 100px; background: rgba(148,163,184,0.15); color: var(--text-muted); font-size: 10px; }
.media-switch:hover { color: var(--blue); }
.media-switch.active { background: var(--white); color: var(--blue-deep); box-shadow: var(--shadow-sm); }
.media-switch.active span { background: var(--blue-light); color: var(--blue); }
.media-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 28px; }
.media-grid > :not(.media-card) { display: none; }
.media-card { display: block; width: 100%; text-align: left; background: var(--white); border-radius: var(--radius-md); overflow: hidden; border: 1px solid var(--border-light); box-shadow: var(--shadow-sm); transition: transform var(--transition-base), box-shadow var(--transition-base); }
.media-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.media-card.filtered-out { display: none; }
.media-cover { aspect-ratio: 16/10; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; background-color: var(--blue-deep); }
.media-cover::after { content: ''; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(10,31,68,0.72) 0%, rgba(10,31,68,0.04) 65%); transition: background var(--transition-base); }
.media-card:hover .media-cover::after { background: linear-gradient(0deg, rgba(10,31,68,0.82) 0%, rgba(10,31,68,0.08) 70%); }
.media-type-badge, .media-count { position: absolute; z-index: 2; top: 14px; padding: 6px 11px; border-radius: 100px; background: rgba(255,255,255,0.92); backdrop-filter: blur(10px); color: var(--blue-deep); font-size: 9px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; }
.media-type-badge { left: 14px; display: flex; align-items: center; gap: 6px; }
.media-type-badge svg { width: 13px; height: 13px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.media-type-badge.video svg { fill: currentColor; stroke: none; }
.media-count { right: 14px; }
.media-open-icon, .media-play-icon { position: relative; z-index: 2; width: 56px; height: 56px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--white); background: rgba(10,31,68,0.65); border: 1px solid rgba(255,255,255,0.3); backdrop-filter: blur(10px); transform: scale(0.88); opacity: 0; transition: all var(--transition-base); }
.media-play-icon { opacity: 1; transform: scale(1); background: rgba(0,57,166,0.82); }
.media-card:hover .media-open-icon, .media-card:hover .media-play-icon { opacity: 1; transform: scale(1.06); background: var(--blue); }
.media-open-icon svg, .media-play-icon svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.media-play-icon svg { fill: currentColor; stroke: none; margin-left: 2px; }
.media-info { padding: 22px 24px 25px; position: relative; }
.media-info::before { content:''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--white), var(--blue), var(--red)); transform: scaleX(0); transform-origin: left; transition: transform 0.4s ease; }
.media-card:hover .media-info::before { transform: scaleX(1); }
.media-date { font-size: 10px; font-weight: 700; letter-spacing: 0.12em; color: var(--blue); margin-bottom: 8px; text-transform: uppercase; }
.media-title { font-family: var(--font-serif); font-size: 19px; font-weight: 700; color: var(--blue-deep); line-height: 1.3; margin-bottom: 7px; }
.media-desc { font-size: 13px; color: var(--text-secondary); line-height: 1.6; }

/* Media viewer */
.media-modal { display: none; position: fixed; inset: 0; z-index: 1100; padding: 32px; background: radial-gradient(circle at 82% 16%, rgba(0,57,166,0.22), transparent 34%), linear-gradient(145deg, rgba(4,12,28,0.98), rgba(9,31,66,0.98)); align-items: center; justify-content: center; flex-direction: column; gap: 14px; }
.media-modal.open { display: flex; }
.media-modal-close { position: absolute; top: 20px; right: 24px; width: 44px; height: 44px; border-radius: 50%; color: rgba(255,255,255,0.65); background: rgba(255,255,255,0.07); font-size: 28px; line-height: 1; transition: all var(--transition-fast); }
.media-modal-close:hover { color: var(--white); background: rgba(255,255,255,0.14); }
.media-modal-back { display: none; position: absolute; top: 22px; left: 24px; align-items: center; gap: 8px; min-height: 42px; padding: 0 15px; border-radius: 100px; color: rgba(255,255,255,0.78); background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.08); font-size: 12px; font-weight: 700; transition: all var(--transition-fast); }
.media-modal-back.visible { display: inline-flex; }
.media-modal-back:hover { color: var(--white); background: rgba(255,255,255,0.14); }
.media-modal-back svg { width: 15px; height: 15px; fill: none; stroke: currentColor; stroke-width: 2; }
.media-modal-stage { width: min(1080px, 94vw); height: min(72vh, 720px); display: flex; align-items: center; justify-content: center; overflow: hidden; border-radius: var(--radius-md); background: #030711; box-shadow: 0 28px 90px rgba(0,0,0,0.34); }
.media-modal-stage > img, .media-modal-stage > video, .media-modal-stage > iframe { width: 100%; height: 100%; border: 0; object-fit: contain; background: #030711; }
.media-modal-stage.album-overview { width: min(1180px, 94vw); height: min(76vh, 800px); align-items: stretch; justify-content: stretch; overflow-y: auto; padding: 14px; background: #eef3f9; }
.album-collage { width: 100%; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); grid-auto-rows: minmax(180px, 24vh); gap: 12px; }
.album-collage-item { position: relative; min-height: 0; overflow: hidden; border-radius: 10px; background: var(--blue-soft); box-shadow: 0 1px 0 rgba(255,255,255,0.5) inset; }
.album-collage-item:focus-visible { outline: 3px solid var(--blue); outline-offset: 2px; }
.album-collage-item:first-child { grid-column: span 2; grid-row: span 2; }
.album-collage-item img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-base), filter var(--transition-base); }
.album-collage-item::after { content: ''; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(10,31,68,0.56), transparent 55%); opacity: 0.55; transition: opacity var(--transition-fast); }
.album-collage-item:hover img { transform: scale(1.035); filter: brightness(0.92); }
.album-collage-item:hover::after { opacity: 0.82; }
.album-collage-number { position: absolute; z-index: 2; left: 12px; bottom: 10px; color: var(--white); font-size: 10px; font-weight: 800; letter-spacing: 0.12em; }
.album-collage-open { position: absolute; z-index: 2; right: 12px; bottom: 10px; width: 34px; height: 34px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--white); background: rgba(10,31,68,0.62); backdrop-filter: blur(8px); opacity: 0; transform: translateY(5px); transition: all var(--transition-fast); }
.album-collage-item:hover .album-collage-open { opacity: 1; transform: translateY(0); }
.album-collage-open svg { width: 15px; height: 15px; fill: none; stroke: currentColor; stroke-width: 2; }
.media-modal-caption { max-width: min(900px, 90vw); text-align: center; color: var(--white); font-family: var(--font-serif); font-size: 18px; line-height: 1.4; }
.media-modal-meta { color: rgba(255,255,255,0.4); font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; }
.media-modal-nav { display: flex; align-items: center; gap: 14px; }
.media-modal-nav.hidden { display: none; }
.media-modal-nav button { width: 42px; height: 42px; border: 1px solid rgba(255,255,255,0.12); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--white); transition: all var(--transition-fast); }
.media-modal-nav button:hover { background: var(--blue); border-color: var(--blue); }
.media-modal-nav button:disabled { opacity: 0.25; cursor: default; background: transparent; border-color: rgba(255,255,255,0.12); }
.media-modal-nav svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; }

/* ─── REVEAL ─── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.8s cubic-bezier(0.16,1,0.3,1), transform 0.8s cubic-bezier(0.16,1,0.3,1); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.08s; }
.reveal-delay-2 { transition-delay: 0.16s; }

/* ─── RESPONSIVE ─── */
@media (max-width: 1024px) {
  .media-grid { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
}
@media (max-width: 768px) {
  .media-page { padding: 48px 20px 80px; }
  .media-intro { flex-direction: column; align-items: flex-start; margin-bottom: 28px; }
  .media-switcher { display: grid; grid-template-columns: 1fr 1fr; width: 100%; }
  .media-switch { min-width: 0; padding: 10px 8px; }
  .media-grid { grid-template-columns: 1fr; }
  .media-modal { padding: 20px 12px; }
  .media-modal-stage, .media-modal-stage.album-overview { width: 100%; height: 68vh; }
  .media-modal-back { top: 14px; left: 12px; }
  .media-modal-close { top: 12px; right: 12px; }
  .album-collage { grid-template-columns: repeat(2, minmax(0, 1fr)); grid-auto-rows: minmax(130px, 22vh); gap: 8px; }
  .album-collage-item:first-child { grid-column: span 2; grid-row: span 1; }
  .media-modal-caption { font-size: 16px; }
  .inner-hero { padding: 120px 20px 60px; }
  .reveal, .reveal-delay-1, .reveal-delay-2, .reveal-delay-3, .reveal-delay-4 { opacity: 1 !important; transform: none !important; transition: none !important; }
}
