:root { color-scheme: dark; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: #10151d; color: #edf3f8; }
* { box-sizing: border-box; }
body { min-height: 100vh; margin: 0; background: radial-gradient(circle at top left, #385f65 0, #17232d 38%, #10151d 72%); }
a { color: inherit; }
.site-header, .filters, main { width: min(1180px, calc(100% - 32px)); margin-inline: auto; }
.site-header { padding: 56px 0 26px; }
.site-header h1 { margin: 12px 0 4px; font-size: clamp(2.2rem, 6vw, 4.5rem); letter-spacing: -.05em; }
.site-header p { margin: 0; color: #b8c7d2; font-size: 1.05rem; }
.header-links { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.back-link { color: #91e4d1; font-weight: 700; text-decoration: none; }
.admin-link { color: #8295a3; font-size: .82rem; text-decoration: none; }
.admin-link:hover { color: #cbd7df; }
.filters { display: flex; flex-wrap: wrap; gap: 8px; padding-bottom: 28px; }
.filters a { border: 1px solid #45606e; border-radius: 999px; padding: 9px 14px; color: #c6d4dd; text-decoration: none; }
.filters a:hover, .filters a.active { border-color: #91e4d1; background: #91e4d1; color: #102028; }
.filters .tv-link { position: relative; isolation: isolate; margin-left: auto; overflow: hidden; border-color: #d28aff; background: linear-gradient(105deg, #31194b, #7132a2 55%, #263d72); box-shadow: 0 0 0 1px rgba(210,138,255,.16), 0 0 24px rgba(176,83,255,.28); color: #fff; font-weight: 800; letter-spacing: .02em; }
.filters .tv-link::after { content: ""; position: absolute; z-index: -1; inset: -80% -30%; background: linear-gradient(105deg, transparent 38%, rgba(255,255,255,.28) 50%, transparent 62%); transform: translateX(-60%); animation: tv-scan 4.8s ease-in-out infinite; }
.filters .tv-link span { display: inline-flex; align-items: center; gap: 6px; margin-right: 5px; color: #bfffee; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; }
.filters .tv-link span::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: #6effd6; box-shadow: 0 0 10px #6effd6; animation: tv-pulse 1.8s ease-in-out infinite; }
.filters .tv-link:hover { border-color: #e8c4ff; background: linear-gradient(105deg, #472268, #9550c9 55%, #345293); color: #fff; transform: translateY(-1px); }
main { padding-bottom: 64px; }
main > h2 { margin: 0 0 18px; font-size: 1.15rem; color: #b8c7d2; }
.mix-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr)); gap: 20px; }
.mix-card { overflow: hidden; border: 1px solid #31444f; border-radius: 16px; background: rgba(20, 29, 38, .88); box-shadow: 0 18px 50px rgba(0, 0, 0, .22); }
.mix-card iframe { display: block; width: 100%; height: 180px; border: 0; background: #202b36; }
.mix-details { padding: 18px; }
.mix-details h3 { margin: 0 0 8px; font-size: 1rem; line-height: 1.4; }
.mix-details p { display: flex; justify-content: space-between; gap: 12px; margin: 0; color: #9fb0bc; font-size: .88rem; }
.mix-details span { color: #91e4d1; text-align: right; }
.status { padding: 24px; border: 1px solid #563d45; border-radius: 12px; background: #2b1e25; color: #ffccd7; }
@media (max-width: 560px) { .site-header { padding-top: 34px; } .filters { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 20px; } .filters a { white-space: nowrap; } .filters .tv-link { margin-left: 8px; } }
@keyframes tv-scan { 0%, 55% { transform: translateX(-65%); } 82%, 100% { transform: translateX(65%); } }
@keyframes tv-pulse { 50% { opacity: .42; transform: scale(.78); } }
@media (prefers-reduced-motion: reduce) { .filters .tv-link::after, .filters .tv-link span::before { animation: none; } }
