:root { --bg: #0b1020; --panel: #0f1730; --text: #d7e2ff; --muted: #98a2c3; --neon: #00e5ff; --accent: #ff4d9d; --glow: 0 0 12px rgba(0,229,255,.55), 0 0 32px rgba(0,229,255,.25); --radius: 20px; --radius-lg: 24px; --shadow-soft: 0 12px 28px rgba(0,0,0,.55); --gap: 28px; --iframe-h: 440px; --transition: 220ms cubic-bezier(.22,1,.36,1); }
body.theme-light { --bg: #e8c2a8; --panel: #d7b199; --text: #1e222b; --muted: #5f6675; --neon: #00cde6; --accent: #ff4d86; --glow: 0 0 8px rgba(0,205,230,.28), 0 0 18px rgba(0,205,230,.14);
} @media (prefers-reduced-motion: reduce) { * { transition: none !important; animation: none !important; } } * { box-sizing: border-box; } html, body { height: 100%; } body { margin: 0; background: radial-gradient(1200px 800px at 30% -10%, rgba(0,229,255,.08), transparent 60%), radial-gradient(800px 600px at 90% 20%, rgba(255,77,157,.07), transparent 65%), var(--bg); color: var(--text); font: 16px/1.6 system-ui, -apple-system, Segoe UI, Roboto, Inter, Helvetica, Arial, sans-serif; display: grid; grid-template-columns: 320px 1fr; grid-template-rows: 100vh; overflow: visible; } .sidebar { position: sticky; top: 0; height: 100vh; overflow: auto; background: linear-gradient(180deg, color-mix(in oklab, var(--panel) 96%, transparent), color-mix(in oklab, var(--panel) 86%, transparent)); border-right: 1px solid color-mix(in oklab, var(--text) 12%, transparent); padding: 18px 14px; will-change: transform; transition: transform var(--transition);
} .brand { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: var(--radius); background: linear-gradient(180deg, color-mix(in oklab, var(--panel) 95%, transparent), color-mix(in oklab, var(--panel) 90%, transparent)); box-shadow: var(--shadow-soft); } .brand .logo { width: 32px; height: 32px; border-radius: 10px; background: radial-gradient(circle at 30% 30%, var(--neon), transparent 60%), radial-gradient(circle at 70% 70%, var(--accent), transparent 55%), color-mix(in oklab, var(--panel) 80%, transparent); box-shadow: var(--glow); } .brand .title { font-weight: 800; letter-spacing: .3px; } .brand .subtitle { display:block; font-size: 12px; color: var(--muted); margin-top:-4px } .nav { margin-top: 10px; padding: 6px; } .nav h3 { font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin: 10px 6px; } .nav a { display: flex; align-items: center; gap: 10px; padding: 12px 12px; margin: 4px 0; text-decoration: none; color: var(--text); border-radius: 12px; border: 1px solid transparent; transition: transform var(--transition), background var(--transition), border-color var(--transition), box-shadow var(--transition); } .nav a:hover { background: color-mix(in oklab, var(--panel) 92%, transparent); border-color: color-mix(in oklab, var(--text) 12%, transparent); box-shadow: var(--glow); transform: translateY(-1px); } .nav a.active { background: color-mix(in oklab, var(--neon) 24%, transparent); border-color: color-mix(in oklab, var(--neon) 55%, transparent); box-shadow: var(--glow); } .nav .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--neon); box-shadow: var(--glow); } .subnav { margin-left: 10px; padding-left: 8px; border-left: 1px dashed color-mix(in oklab, var(--text) 12%, transparent); display:none; } .subnav.open { display: block; } .subnav a { font-size: 14px; padding: 10px 12px; } main { height: 100vh; overflow: auto; position: relative; } header.topbar { position: sticky; top: 0; z-index: 5; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 20px; backdrop-filter: blur(8px); background: linear-gradient(180deg, color-mix(in oklab, var(--bg) 88%, transparent), color-mix(in oklab, var(--bg) 70%, transparent)); border-bottom: 1px solid color-mix(in oklab, var(--text) 12%, transparent); } .crumb { color: var(--muted); font-size: 14px; } .title-xl { font-size: clamp(24px, 2.5vw, 40px); font-weight: 900; letter-spacing: .1px; } .section-head { grid-column: 1 / -1; display:flex; align-items:center; justify-content: space-between; padding: 6px 4px; color: var(--muted); } .section-head .left { display:flex; align-items:center; gap:10px; } .section-head .badge { font-size:13px; padding:8px 12px; border-radius:999px; border:1px solid color-mix(in oklab,var(--text)12%,transparent); } .grid { padding: 16px 28px 60px; display: grid; gap: var(--gap); grid-template-columns: 1fr; } .card { background: linear-gradient(180deg, color-mix(in oklab, var(--panel) 96%, transparent), color-mix(in oklab, var(--panel) 92%, transparent)); border: 1px solid color-mix(in oklab, var(--text) 10%, transparent); border-radius: var(--radius-lg); overflow: clip; box-shadow: var(--shadow-soft); position: relative; max-width: clamp(1600px, 99.2vw, 2400px); margin-inline: auto; } .card::before { content:''; position:absolute; inset:0; pointer-events:none; border-radius:inherit; background: linear-gradient(120deg, color-mix(in oklab,var(--neon) 20%, transparent), transparent 30%, color-mix(in oklab,var(--accent) 24%, transparent) 70%, transparent 100%); opacity:.25; } .meta { padding: 18px 22px 8px; display: flex; align-items: center; justify-content: space-between; gap: 12px; } .meta .name { font-weight: 900; font-size: 22px; letter-spacing:.1px; } .meta .actions { display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end; } .pill, .btn { font-size: 13px; padding: 8px 10px; border-radius: 999px; border: 1px solid color-mix(in oklab, var(--text) 12%, transparent); color: var(--muted); background: transparent; cursor: pointer; } .btn.primary { color: var(--text); border-color: color-mix(in oklab, var(--neon) 60%, transparent); background: color-mix(in oklab, var(--neon) 18%, transparent); box-shadow: var(--glow); } .player { padding: 0; position: relative; } iframe { width:100%; height: var(--iframe-h); border:0; border-radius:18px; background: color-mix(in oklab, var(--bg) 90%, #000); display:block; margin:0; opacity: 0; translate: 0 10px; transition: opacity var(--transition), translate var(--transition); } .skeleton { position: absolute; inset: 0; border-radius: 18px; overflow: hidden; background: linear-gradient(90deg, color-mix(in oklab, var(--panel) 88%, transparent) 25%, color-mix(in oklab, var(--panel) 96%, transparent) 37%, color-mix(in oklab, var(--panel) 88%, transparent) 63%); background-size: 400% 100%; animation: shimmer 1500ms infinite; box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--text) 8%, transparent); pointer-events: none; } @keyframes shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } } .toggles { display:flex; align-items:center; gap:12px; } .seg { display:inline-flex; border-radius:999px; border:1px solid color-mix(in oklab, var(--text) 12%, transparent); background: color-mix(in oklab, var(--panel) 92%, transparent); } .seg button { border:0; background:transparent; padding:10px 14px; cursor:pointer; color:var(--text); border-radius:999px; font-weight:900; letter-spacing:.2px; transition: box-shadow var(--transition), transform var(--transition); } .seg button.active { background: color-mix(in oklab, var(--neon) 22%, transparent); box-shadow: var(--glow); transform: translateY(-1px); } .randomizer { border:0; background:transparent; padding:10px 14px; cursor:pointer; border-radius:999px; font-weight:900; letter-spacing:.2px; } .randomizer:hover { background: color-mix(in oklab, var(--neon) 18%, transparent); box-shadow: var(--glow); } :focus-visible { outline: 2px solid var(--neon); outline-offset: 2px; border-radius: 8px; } .view-leave { opacity: 1; transform: translateY(0); }
.view-leave.view-leave-active { opacity: 0; transform: translateY(6px); transition: opacity var(--transition), transform var(--transition); }
.view-enter { opacity: 0; transform: translateY(6px); }
.view-enter.view-enter-active { opacity: 1; transform: translateY(0); transition: opacity calc(var(--transition) + 40ms), transform calc(var(--transition) + 40ms); } 
.player .stack { position: relative; height: var(--iframe-h); }
.player .stack iframe { position: absolute; inset: 0; opacity: 0; pointer-events: none; transition: opacity var(--transition), translate var(--transition);
}
.player .stack iframe.active { opacity: 1; pointer-events: auto; translate: 0 0; } .header, header, .topbar, .mast { display: flex; align-items: center; gap: 8px; }
#randMenu, #randomizerBtn { order: 1; }
.platform-toggle, #platformToggle, .platformSwitch { order: 2; } body.theme-dark #randomizerBtn,
body.theme-dark #randToggle { background: #ffffff !important; color: #0b0f14 !important; border-color: #ffffff !important;
}
body.theme-dark #randPopover { background: #111722; border-color: rgba(255,255,255,.18);
} .nav a.has-caret { justify-content: space-between; }
.nav a .label-wrap { display:flex; align-items:center; gap:10px; }
.nav a .caret { margin-left:auto; opacity:.9; font-size:18px; line-height:1; transform: rotate(0deg); transition: transform var(--transition), background var(--transition), box-shadow var(--transition); display:inline-flex; align-items:center; justify-content:center; width:32px; height:32px; border-radius:10px; cursor:pointer;
}
.nav a .caret:hover { background: color-mix(in oklab, var(--panel) 90%, transparent); box-shadow: var(--glow); }
.subnav.open ~ a.has-caret .caret, .nav a.has-caret.open .caret { transform: rotate(90deg); } .subnav { margin: 6px 0 8px 22px; max-height: 52vh; overflow: auto; padding-right: 6px; }
.subnav .group { margin: 8px 0; }
.subnav .group h4 { margin: 8px 8px 4px; font-size: 11px; letter-spacing:.12em; text-transform:uppercase; color: var(--muted); } .subnav a { display:block; border-radius:10px; margin:2px 4px; }
.subnav a.active { background: color-mix(in oklab, var(--neon) 22%, transparent); border:1px solid color-mix(in oklab, var(--neon) 50%, transparent); }
.badge.count { margin-left: auto; } #randomizerBtn, #randToggle { color: #ffffff !important; } .subnav .controls { position: sticky; top: 0; z-index: 2; display:flex; gap:6px; padding:8px; background: color-mix(in oklab, var(--panel) 96%, transparent); border-bottom:1px solid color-mix(in oklab, var(--text) 10%, transparent); }
.subnav .controls .btn { font-size:12px; padding:6px 10px; }
.subnav .vol-list a { display:block; padding:8px 10px; border-radius:8px; margin:2px 4px; line-height:1.2; outline:none; }
.subnav .vol-list a:focus-visible { outline:2px solid var(--neon); outline-offset:2px; } body.theme-light #randomizerBtn,
body.theme-light #randToggle { color: var(--text) !important; border-color: color-mix(in oklab, var(--text) 30%, transparent) !important; background: transparent !important;
} .subnav .vol-list a { display:flex; align-items:center; gap:8px; padding:6px 8px; margin:1px 4px; line-height:1.15; font-size:14px; border-radius:8px;
}
.subnav .vol-list a .chip { margin-left:auto; font-size:11px; padding:4px 8px; border-radius:999px; border:1px solid color-mix(in oklab, var(--neon) 40%, transparent); color: var(--text); display:none;
}
.subnav .vol-list a.active .chip { display:inline-flex; } .hero .panel { max-width: min(1100px, 92vw); margin-inline: auto; } body.platform-apple  body.platform-apple .meta { padding: 6px 10px 4px; }
body.platform-apple .meta .name { font-size: 18px; }
body.platform-apple .meta .actions { display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end; }
body.platform-apple .meta .actions .btn { padding:4px 8px; font-size:12px; border-radius:8px; }
body.platform-apple .card { max-width: clamp(1600px, 99.2vw, 2400px); margin-block: 8px; } @media (min-width: 900px) { } body.platform-apple{ } .player { margin-bottom: 0 !important; }
.player .stack { height: var(--iframe-h) !important; margin: 0 !important; }
.card { padding-bottom: 0 !important; } .home-descriptions ul.cols { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px 20px; list-style: none; margin: 0; padding: 0; }
.home-descriptions li { padding: 0; border: none; background: none; box-shadow: none; }
.home-descriptions li .tile { display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 10px; padding: 14px 16px; border-radius: 14px; text-decoration: none; color: inherit; border: 1px solid color-mix(in oklab, var(--text) 10%, transparent); box-shadow: 0 1px 0 rgba(0,0,0,.04); transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.home-descriptions li .tile:hover { transform: translateY(-1px); box-shadow: 0 0 0 2px color-mix(in oklab, var(--accent, #00eaff) 28%, transparent), 0 6px 18px rgba(0,0,0,.12); border-color: color-mix(in oklab, var(--accent, #00eaff) 35%, transparent);
}
.home-descriptions li::before { content: none; } :root { --cg1: color-mix(in oklab, hsl(0 80% 55%) 16%, var(--panel)); --cg2: color-mix(in oklab, hsl(20 85% 55%) 16%, var(--panel)); --cg3: color-mix(in oklab, hsl(40 85% 55%) 16%, var(--panel)); --cg4: color-mix(in oklab, hsl(60 85% 55%) 16%, var(--panel)); --cg5: color-mix(in oklab, hsl(80 70% 55%) 16%, var(--panel)); --cg6: color-mix(in oklab, hsl(100 70% 55%) 16%, var(--panel)); --cg7: color-mix(in oklab, hsl(130 70% 55%) 16%, var(--panel)); --cg8: color-mix(in oklab, hsl(160 70% 55%) 16%, var(--panel)); --cg9: color-mix(in oklab, hsl(180 70% 55%) 16%, var(--panel)); --cg10: color-mix(in oklab, hsl(200 75% 55%) 16%, var(--panel)); --cg11: color-mix(in oklab, hsl(220 75% 55%) 16%, var(--panel)); --cg12: color-mix(in oklab, hsl(240 75% 55%) 16%, var(--panel)); --cg13: color-mix(in oklab, hsl(260 75% 55%) 16%, var(--panel)); --cg14: color-mix(in oklab, hsl(280 80% 60%) 16%, var(--panel)); --cg15: color-mix(in oklab, hsl(300 80% 60%) 16%, var(--panel)); --cg16: color-mix(in oklab, hsl(320 80% 60%) 16%, var(--panel));
} .home-descriptions li:nth-child(1) .tile { background: var(--cg1); }
.home-descriptions li:nth-child(2) .tile { background: var(--cg2); }
.home-descriptions li:nth-child(3) .tile { background: var(--cg3); }
.home-descriptions li:nth-child(4) .tile { background: var(--cg4); }
.home-descriptions li:nth-child(5) .tile { background: var(--cg5); }
.home-descriptions li:nth-child(6) .tile { background: var(--cg6); }
.home-descriptions li:nth-child(7) .tile { background: var(--cg7); }
.home-descriptions li:nth-child(8) .tile { background: var(--cg8); }
.home-descriptions li:nth-child(9) .tile { background: var(--cg9); }
.home-descriptions li:nth-child(10) .tile { background: var(--cg10); }
.home-descriptions li:nth-child(11) .tile { background: var(--cg11); }
.home-descriptions li:nth-child(12) .tile { background: var(--cg12); }
.home-descriptions li:nth-child(13) .tile { background: var(--cg13); }
.home-descriptions li:nth-child(14) .tile { background: var(--cg14); }
.home-descriptions li:nth-child(15) .tile { background: var(--cg15); }
.home-descriptions li:nth-child(16) .tile { background: var(--cg16); } .home-descriptions { position: relative; max-width: 1280px; margin: 28px auto 44px; padding: 20px 22px; border-radius: 16px; border: 1px solid color-mix(in oklab, var(--text) 10%, transparent); background: radial-gradient(140% 140% at 0% 0%, color-mix(in oklab, var(--bg) 88%, var(--accent, #00eaff) 12%), transparent 58%), radial-gradient(140% 140% at 100% 0%, color-mix(in oklab, var(--bg) 88%, var(--accent, #00eaff) 12%), transparent 58%), linear-gradient(to bottom, color-mix(in oklab, var(--bg) 96%, white 4%), var(--bg)); box-shadow: 0 12px 28px rgba(0,0,0,.10), 0 0 26px color-mix(in oklab, var(--accent, #00eaff) 24%, transparent), inset 0 1px 0 rgba(255,255,255,.03);
} .home-descriptions header h2 { text-align: inherit; text-shadow: 0 0 14px color-mix(in oklab, var(--accent, #00eaff) 28%, transparent); text-align: inherit; margin: 0 0 6px 0; letter-spacing: .3px; font-weight: 700;
}
.home-descriptions header .note { text-align: inherit; color: var(--muted); margin: 0 auto 16px auto; max-width: 62ch;
} .cols { gap: 18px 20px; } .tile { border-radius: 12px; border: 1px solid color-mix(in oklab, var(--text) 12%, transparent); box-shadow: 0 1px 0 rgba(0,0,0,.05);
}
.tile .cat { font-weight: 600; }
.tile .desc { opacity: .92; }
.tile .sep { opacity: .5; margin: 0 .35em; } @media (hover:hover) { .tile:hover { border-color: color-mix(in oklab, var(--accent, #00eaff) 40%, transparent); box-shadow: 0 0 0 2px color-mix(in oklab, var(--accent, #00eaff) 35%, transparent), 0 6px 18px rgba(0,0,0,.14); }
} @keyframes neonOrbit { 0% { transform: rotate(0turn); } 100% { transform: rotate(1turn); }
}
.home-descriptions::before,
.brand::before { content: ""; position: absolute; inset: -2px; border-radius: inherit; pointer-events: none; background: conic-gradient(from 0deg, color-mix(in oklab, #FFD36E 80%, transparent) 0%, color-mix(in oklab, #FF9B6A 80%, transparent) 25%, color-mix(in oklab, #FF6FA1 75%, transparent) 50%, color-mix(in oklab, #EFA1FF 70%, transparent) 75%, color-mix(in oklab, #FFD36E 80%, transparent) 100%) 0%, color-mix(in oklab, #00e5ff 80%, transparent) 20%, color-mix(in oklab, #2d6bff 80%, transparent) 40%, color-mix(in oklab, #6e00ff 80%, transparent) 60%, color-mix(in oklab, #9b00ff 80%, transparent) 80%, color-mix(in oklab, #00ffa8 80%, transparent) 100%) 0%, color-mix(in oklab, #ff00ea 70%, transparent) 25%, color-mix(in oklab, #7afcff 70%, transparent) 50%, color-mix(in oklab, #ff00ea 70%, transparent) 75%, color-mix(in oklab, #00ffff 70%, transparent) 100%) 55%, transparent) 0%, color-mix(in oklab, var(--neon, #00e5ff) 55%, transparent) 25%, color-mix(in oklab, #7afcff 50%, transparent) 50%, color-mix(in oklab, var(--accent, #ff4d9d) 55%, transparent) 75%, color-mix(in oklab, var(--neon, #00e5ff) 55%, transparent) 100% ); filter: blur(18px); opacity: .14; z-index: 0; animation: neonOrbit 45s linear infinite; -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; padding: 2px; box-sizing: border-box;
}
.home-descriptions > * { position: relative; z-index: 1; }
.brand > * { position: relative; z-index: 1; }
.brand { position: relative; border-radius: 14px; } .content { max-width: 980px; margin: 0 auto;
} .content .pill { font-size: clamp(14px, 2.3vw, 18px); padding: 8px 12px; border-radius: 999px; letter-spacing: .4px;
} body.theme-light .home-descriptions .tile { background: color-mix(in oklab, var(--cg1) 52%, white 48%); color: color-mix(in oklab, black 92%, #222 8%); border-color: color-mix(in oklab, black 14%, transparent); box-shadow: 0 1px 0 rgba(0,0,0,.04);
}
body:not(.theme-light) .home-descriptions .tile { background: color-mix(in oklab, var(--cg1) 78%, black 22%); color: color-mix(in oklab, white 92%, var(--text) 8%); border-color: color-mix(in oklab, var(--text) 22%, transparent); box-shadow: 0 1px 0 rgba(0,0,0,.55);
}
.home-descriptions .tile .desc { opacity: .99; } .home-descriptions .cols li:nth-child(1) { --cg1: #2A3448; }
.home-descriptions .cols li:nth-child(2) { --cg1: #3B2D4A; }
.home-descriptions .cols li:nth-child(3) { --cg1: #4A2E2E; }
.home-descriptions .cols li:nth-child(4) { --cg1: #2E3F34; }
.home-descriptions .cols li:nth-child(5) { --cg1: #39425A; }
.home-descriptions .cols li:nth-child(6) { --cg1: #4A3A2F; }
.home-descriptions .cols li:nth-child(7) { --cg1: #2F3E4A; }
.home-descriptions .cols li:nth-child(8) { --cg1: #3A2F46; }
.home-descriptions .cols li:nth-child(9) { --cg1: #40334D; }
.home-descriptions .cols li:nth-child(10) { --cg1: #2F4A43; }
.home-descriptions .cols li:nth-child(11) { --cg1: #4A3A5A; }
.home-descriptions .cols li:nth-child(12) { --cg1: #2E3A4F; }
.home-descriptions .cols li:nth-child(13) { --cg1: #3F2E3A; }
.home-descriptions .cols li:nth-child(14) { --cg1: #33424A; }
.home-descriptions .cols li:nth-child(15) { --cg1: #4A2F39; }
.home-descriptions .cols li:nth-child(16) { --cg1: #2F403E; }
.home-descriptions .cols li:nth-child(17) { --cg1: #3B3B59; }
.home-descriptions .cols li:nth-child(18) { --cg1: #46404D; }
.home-descriptions .cols li:nth-child(19) { --cg1: #2F3A52; }
.home-descriptions .cols li:nth-child(20) { --cg1: #3A4A3A; }
.home-descriptions .cols li:nth-child(21) { --cg1: #324254; }
.home-descriptions .cols li:nth-child(22) { --cg1: #4A3B3B; }
.home-descriptions .cols li:nth-child(23) { --cg1: #38424A; }
.home-descriptions .cols li:nth-child(24) { --cg1: #42354A; } .hero .panel h1 { font-size: clamp(30px, 5vw, 48px); line-height: 1.05; letter-spacing: 0.2px; margin-bottom: 10px; text-shadow: 0 1px 0 rgba(0,0,0,.25), 0 0 18px color-mix(in oklab, var(--neon) 22%, transparent);
}
.hero .panel p.lead { font-size: clamp(15px, 1.5vw, 18px); color: var(--muted); margin-top: 6px;
} .hero .panel .cta-row { display: flex; justify-content: center; gap: 10px; margin-top: 14px;
}
.hero .panel .cta-row .btn.start-exploring { font-size: 15px; padding: 10px 16px; border-radius: 999px; box-shadow: var(--glow);
} .hero .panel .cta-row .btn.browse-categories { display: none !important; } } 

/* Category hero text (landing pages) */
.section-head .head-text{display:flex;flex-direction:column;gap:2px}
.section-head .kicker{font-size:12px;font-weight:800;color:var(--muted);letter-spacing:.3px;text-transform:uppercase}
.section-head .desc{font-size:14px;color:color-mix(in oklab,var(--text)70%,var(--muted))}
@media (max-width: 700px){ .section-head{align-items:flex-start} .section-head .desc{font-size:13px} }


/* Playlist tile grid (category landing) */
.playlist-tiles{width:100%;max-width:var(--home-max);margin:14px auto 0}
.playlist-tiles header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:0 2px 10px}
.playlist-tiles header h2{margin:0;font-size:clamp(18px,1vw+16px,22px);letter-spacing:.2px}
.playlist-tiles header .note{margin:0;color:var(--muted);font-size:13px}
.playlist-tiles ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,180px));justify-content:center;gap:12px;align-items:stretch}
.playlist-tiles a.ptile{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:14px;border-radius:16px;text-decoration:none;color:inherit;border:1px solid color-mix(in oklab, var(--text) 12%, transparent);
background:radial-gradient(120% 120% at 50% 0%, color-mix(in oklab, var(--panel) 92%, transparent), transparent);
box-shadow:0 8px 22px rgba(0,0,0,.14);aspect-ratio:1/1;transition:transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease}

.playlist-tiles a.ptile.has-cover{
  /* Cover tiles should be JUST the image (no base tile chrome) */
  padding: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
  background-image: var(--cover-img);
  background-size: cover;
  background-position: center;
  position: relative;
}

/* Keep title readable without a background; add a pill only for the Vol number */
.playlist-tiles a.ptile.has-cover .name{
  background: transparent;
  border: none;
  padding: 0 10px;
  border-radius: 0;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  text-shadow: 0 2px 12px rgba(0,0,0,.70);
}

.playlist-tiles a.ptile.has-cover .vol{
  position: absolute;
  left: 50%;
  bottom: 10px;
  transform: translateX(-50%);
  background: rgba(0,0,0,.38);
  border: 1px solid rgba(255,255,255,.14);
  padding: 7px 12px;
  border-radius: 999px;
  color: #fff;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  text-shadow: none;
}

/* Glow ring on hover for cover tiles only (no dark drop shadow) */
.playlist-tiles a.ptile.has-cover:hover{
  transform: translateY(-1px);
  box-shadow: 0 0 0 2px color-mix(in oklab,var(--accent,#00eaff) 55%, transparent),
              0 0 22px color-mix(in oklab,var(--accent,#00eaff) 35%, transparent);
}
.playlist-tiles a.ptile.has-cover:active{
  transform: translateY(0) scale(.99);
  box-shadow: 0 0 0 2px color-mix(in oklab,var(--accent,#00eaff) 55%, transparent),
              0 0 22px color-mix(in oklab,var(--accent,#00eaff) 35%, transparent);
}
.playlist-tiles a.ptile:not(.has-cover):hover{transform:translateY(-1px);border-color:color-mix(in oklab,var(--accent,#00eaff) 40%, transparent);
box-shadow:0 10px 28px rgba(0,0,0,.18),0 0 0 2px color-mix(in oklab,var(--accent,#00eaff) 30%, transparent)}
.playlist-tiles a.ptile:not(.has-cover):active{transform:scale(.98)}
.playlist-tiles .vol{font-size:12px;font-weight:900;letter-spacing:.3px;text-transform:uppercase;color:var(--muted)}
.playlist-tiles .name{text-align:center;font-size:14px;font-weight:800;line-height:1.15}
.playlist-tiles.only-vol a.ptile{justify-content:flex-end;align-items:center;gap:0;padding:14px}
.playlist-tiles.only-vol .vol{font-size:14px;font-weight:900;letter-spacing:.2px;text-transform:none;color:var(--text)}
.playlist-tiles.only-vol a.ptile:not(.has-cover) .vol{background:color-mix(in oklab,var(--panel) 86%, transparent);border:1px solid color-mix(in oklab,var(--text) 14%, transparent);padding:8px 12px;border-radius:999px}
@media (max-width: 420px){.playlist-tiles ul{grid-template-columns:repeat(2,minmax(0,1fr))}.playlist-tiles a.ptile{padding:12px;border-radius:14px}.playlist-tiles .name{font-size:13px}}

/* Disco Futures subnav uses same styling as other series */
.subnav-disco{ }

/* ---- extracted from inline <style> blocks ---- */

:root{ --home-max: min(1100px, 92vw); --recent-gap: 12px;
} #Welcome, .welcome, .welcome-box, .welcomePanel, .home-welcome,
.category-guide, #category-guide, .guide, .cat-guide, .categoryGuide, .category-guide-container,
.home-descriptions { max-width: var(--home-max); margin-left: auto; margin-right: auto;
} #recent-plays, .recent-plays, #recently-played, .recently-played { max-width: var(--home-max); margin-left: auto; margin-right: auto;
}

/* ---- extracted from inline <style> blocks ---- */

.brand .title { font-size: clamp(18px, 1vw + 16px, 26px); line-height: 1.08; font-weight: 800; letter-spacing: .15px;
}
.brand .subtitle { font-size: clamp(11px, 0.5vw + 9px, 13px); opacity: .85; font-weight: 600;
} .hero h1 { font-size: clamp(32px, 4.5vw, 54px) !important; line-height: 1.06 !important; letter-spacing: -0.4px !important; margin: 6px 0 10px !important;
}
.hero .pill { font-size: clamp(16px, 2.2vw, 22px) !important; padding: 6px 12px !important; border-radius: 999px !important;
}
.hero p { font-size: clamp(14px, 1.8vw, 18px) !important;
} #homeDescriptions.home-descriptions { max-width: 1240px;
}
#homeDescriptions.home-descriptions ul.cols { list-style: none; margin: 10px 0 2px; padding: 0; display: grid; gap: 12px 12px; align-items: stretch;
} @media (min-width: 1150px) { #homeDescriptions.home-descriptions ul.cols { grid-template-columns: repeat(4, 1fr); }
} #homeDescriptions.home-descriptions .tile { padding: 14px 16px; min-height: 88px; border-radius: 12px; border: 1px solid color-mix(in oklab, var(--text) 12%, transparent); box-shadow: 0 6px 18px rgba(0,0,0,.12);
}
#homeDescriptions.home-descriptions .tile .cat { font-size: clamp(15px, 0.9vw + 13px, 17px); font-weight: 700;
}
#homeDescriptions.home-descriptions .tile .desc { font-size: clamp(12.5px, 0.7vw + 10.5px, 14px); opacity: .95;
} #homeDescriptions.home-descriptions header h2 { font-size: clamp(20px, 1vw + 18px, 24px);
}
#homeDescriptions.home-descriptions header .note { font-size: clamp(12.5px, 0.6vw + 11px, 14px);
} body.theme-light #homeDescriptions.home-descriptions .tile { box-shadow: 0 8px 20px rgba(0,0,0,.10);
} .brand .title { font-size: clamp(20px, 1.2vw + 18px, 30px); line-height: 1.1; font-weight: 800; letter-spacing: .2px;
}
.brand .subtitle { font-size: clamp(12px, 0.6vw + 10px, 14px); opacity: .85; font-weight: 600;
} .hero .content, section.hero .content { max-width: 1100px; margin: 0 auto;
} #homeDescriptions.home-descriptions header { text-align: center; padding: 10px 0 6px;
}
#homeDescriptions.home-descriptions header h2 { font-size: clamp(22px, 1.2vw + 18px, 28px); margin: 0 0 4px; letter-spacing: .2px;
}
#homeDescriptions.home-descriptions header .note { margin: 0 auto 10px; color: var(--muted);
} #homeDescriptions.home-descriptions ul.cols { list-style: none; margin: 12px 0 4px; padding: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 14px 14px; align-items: stretch;
} #homeDescriptions.home-descriptions .tile { display: grid; grid-template-columns: 1fr; gap: 6px; padding: 16px 18px; min-height: 96px; border-radius: 14px; border: 1px solid color-mix(in oklab, var(--text) 12%, transparent); box-shadow: 0 8px 22px rgba(0,0,0,.14); text-decoration: none;
} #homeDescriptions.home-descriptions .tile .cat { font-size: clamp(16px, 1vw + 14px, 18px); font-weight: 700;
}
#homeDescriptions.home-descriptions .tile .desc { font-size: clamp(13px, 0.8vw + 11px, 15px); opacity: .96;
} @media (hover:hover) { #homeDescriptions.home-descriptions .tile:hover { border-color: color-mix(in oklab, var(--accent, #00eaff) 40%, transparent); box-shadow: 0 10px 28px rgba(0,0,0,.18), 0 0 0 2px color-mix(in oklab, var(--accent, #00eaff) 32%, transparent); }
} body.theme-light #homeDescriptions.home-descriptions .tile { box-shadow: 0 10px 26px rgba(0,0,0,.10);
}

/* ---- extracted from inline <style> blocks ---- */

#homeDescriptions.home-descriptions { max-width: 1200px !important; margin-left: auto !important; margin-right: auto !important;
}
#homeDescriptions.home-descriptions ul.cols { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; grid-auto-rows: auto !important; gap: 12px 12px !important; align-items: stretch !important;
}
#homeDescriptions.home-descriptions .tile { padding: 12px 14px !important; min-height: 84px !important; border-radius: 12px !important;
}

/* ---- extracted from inline <style> blocks ---- */

/* === NOVA tweak #1: tighter Apple embed === */
body.platform-apple{ } /* was 450px */
.player { margin-bottom: 0 !important; }
.player .stack { height: var(--iframe-h) !important; margin: 0 !important; }
.player .stack iframe { margin: 0 !important; } /* === NOVA tweak #2: consistent card width === */
@media (min-width: 900px) { .card { width: 60vw !important; max-width: none !important; margin: 8px auto !important; }
} /* === NOVA tweak #3: light-mode tile readability === */
body.theme-light .home-descriptions .tile { background: color-mix(in oklab, var(--cg1) 46%, white 54%) !important; color: color-mix(in oklab, black 90%, #111 10%) !important; border-color: color-mix(in oklab, black 18%, transparent) !important; box-shadow: 0 10px 26px rgba(0,0,0,.10) !important;
} /* === NOVA tweak #5 (part A): iframe ready fade-in === */
iframe { opacity: 0; transition: opacity .25s ease; }
iframe.ready { opacity: 1; }

/* ---- extracted from inline <style> blocks ---- */

/* === The Playlist Archive · Sharp Typography v3.2 + Sidebar width === */
html, body { font-family: "Inter", "Segoe UI", "SF Pro Text", -apple-system, system-ui, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji"; font-weight: 400; line-height: 1.55; letter-spacing: 0.002em; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; font-synthesis: none;
}
input, select, textarea, button, nav, .nav, .menu, .site-nav { font-family: inherit; font-weight: 400; letter-spacing: 0.002em; }
h1 { font-weight: 700; letter-spacing: 0.006em; line-height: 1.15; }
h2 { font-weight: 650; letter-spacing: 0.004em; line-height: 1.2; }
h3, h4 { font-weight: 600; letter-spacing: 0.002em; line-height: 1.25; }
header .site-title, .site-title, .brand, #brand { font-weight: 700; letter-spacing: 0.01em; }
nav a, .site-nav a, .menu a, .nav a { font-weight: 500; letter-spacing: 0.005em; text-decoration: none; }
nav a:hover, .site-nav a:hover, .menu a:hover, .nav a:hover { text-decoration: underline; }
aside, .sidebar, [class*="sidebar"] { font-weight: 400; letter-spacing: 0.002em; }
aside a, .sidebar a, [class*="sidebar"] a { font-weight: 500; }
.small, small, .muted, .help, .note { opacity: 0.9; letter-spacing: 0.002em; }
@supports (font-variation-settings: normal) { :root { font-variation-settings: "opsz" 14, "wght" 430; } h1 { font-variation-settings: "opsz" 28, "wght" 680; } h2 { font-variation-settings: "opsz" 22, "wght" 620; } h3, h4 { font-variation-settings: "opsz" 18, "wght" 560; }
}
/* Sidebar width bump (desktop only) */
@media (min-width: 1024px) { aside, .sidebar, [class*="sidebar"] { width: min(340px, 26vw); max-width: 26vw; flex: 0 0 min(340px, 26vw); }
}

/* ---- extracted from inline <style> blocks ---- */

/* === TPA Mobile Sidebar v1 === */
@media (max-width: 1023px) {
  /* Collapse to single column so mobile doesn't reserve sidebar width */
  body { display:block !important; grid-template-columns: 1fr; grid-template-rows: auto; overflow: auto; width:100%; max-width:100%; }
  main { height: auto; min-height: 100dvh; overflow: visible; width:100%; max-width:100%; margin:0 auto; }

  /* Hide desktop sidebar; mobile drawer/hamburger handles nav */
  #sidebar { display: none !important; }

  /* Hamburger always visible and clickable */
  #tpaMobileBtn { display: inline-flex; position: fixed; top: 10px; left: 10px; z-index: 1200; }

  /* Make room for the hamburger so "Welcome" doesn't sit under it */
  header.topbar { padding: 10px 12px 10px 60px; }

  /* Mobile topbar: wrap + center so nothing renders off-screen */
  header.topbar { flex-wrap: wrap; justify-content: center; align-items: flex-start; gap: 10px; }
  header.topbar { width: 100%; left: 0; right: 0; }

  header.topbar > div:first-child { width: 100%; text-align: center; }
  header.topbar .crumb { text-align: center; width: 100%; }
  .toggles { width: 100%; justify-content: center; flex-wrap: wrap; gap: 8px; }
  .seg button { padding: 8px 10px; font-size: 13px; }
  .randomizer { padding: 8px 10px; font-size: 13px; }
  /* Slightly more zoomed-out feel without viewport scaling */
  body { font-size: 13.5px; }
  .title-xl { font-size: 21px; }

  /* Slightly zoom out on mobile so more fits above the fold */
  body { font-size: 14.5px; }
  .title-xl { font-size: 22px; line-height: 1.15; }
  .crumb { font-size: 12px; }

  /* Give embeds enough height so controls don't get clipped */
  iframe { height: 620px !important; border-radius: 14px; }
}

@media (max-width: 420px) { iframe { height: 660px !important; } }

.tpa-drawer-backdrop{position:fixed; inset:0; background:rgba(0,0,0,.55); opacity:0; pointer-events:none; transition:opacity .18s ease;}
.tpa-drawer{ position:fixed; top:0; left:0; height:100dvh; width:min(88vw,360px); background:#fff; color:#111; border-right:1px solid rgba(0,0,0,.1); box-shadow:0 20px 60px rgba(0,0,0,.3); transform:translateX(-100%); transition:transform .22s ease; display:flex; flex-direction:column; z-index:1000;
}
.tpa-drawer-header { display: flex; align-items: center; justify-content: space-between; padding: 14px; border-bottom: 1px solid rgba(0,0,0,.08); }
  html[data-theme="dark"] .tpa-drawer-header{ border-color: rgba(255,255,255,.08); }
  .tpa-drawer-body { padding: 12px; overflow: auto; -webkit-overflow-scrolling: touch; }

  html.tpa-open .tpa-backdrop { opacity: 1; pointer-events: auto; }
  html.tpa-open .tpa-drawer { transform: translateX(0); }
  body.tpa-lock { overflow: hidden; }
}

/* ---- extracted from inline <style> blocks ---- */

/* === TPA Mobile Layout Fix v6 === */
@media (max-width: 1023px){
  body{
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    overflow: auto !important;
  }
  main{ height:auto !important; min-height:100vh; overflow:auto; }
  header.topbar{
    padding: 12px 12px;
    padding-right: 64px; /* room for hamburger */
    gap: 10px;
    flex-wrap: wrap;
    align-items: flex-start;
  }
  header.topbar .toggles{ width: 100%; display:flex; flex-wrap:wrap; gap:10px; justify-content:flex-start; }
  header.topbar .seg{ width: 100%; }
  header.topbar .randomizer{ flex: 1; }
  #randMenu{ flex: 1; }
  .grid{ padding: 14px 14px 60px; gap: 16px; }
  .card{ width: 100% !important; }
}

/* ---- extracted from inline <style> blocks ---- */

@media (max-width:1023px){
  .tpa-mobile-brand{ padding:6px 2px 10px; border-bottom:1px solid color-mix(in oklab, var(--text) 12%, transparent); }
  .tpa-mobile-nav ul li{ margin-bottom:10px; }
  .tpa-mobile-nav a:active{ transform: scale(.99); }
}

/* ---- extracted from inline <style> blocks ---- */

@media (min-width: 1024px){
  :root{ --iframe-h: 440px; }
  .card{ width: 60vw; }
}

/* ---- extracted from inline <style> blocks ---- */

/* === Five-tweak layer (non-breaking) ==================================== 1) Skeleton removal class + lighter paint cost 2) content-visibility for heavy cards 3) Home hero band + width match with Category Guide 4) Firm 4×4 guide on wide screens 5) Slight tile spacing polish
=========================================================================== */
.skeleton.hidden{opacity:0; visibility:hidden; transition:opacity 200ms ease} .card{content-visibility:auto; contain-intrinsic-size:720px} .home-descriptions{max-width:1100px}
.home-hero{margin:22px auto 8px; padding:18px 22px; border-radius:16px; background:linear-gradient(180deg, color-mix(in oklab,var(--panel)96%, transparent), color-mix(in oklab,var(--panel)90%, transparent)); border:1px solid color-mix(in oklab,var(--text) 10%, transparent); box-shadow:var(--shadow-soft)}
.home-hero h1{margin:0 0 6px; font-size:clamp(26px,2.6vw,40px); letter-spacing:.2px}
.home-hero p.sub{margin:0; opacity:.9} @media (min-width:1100px){ .home-descriptions ul.cols{grid-template-columns:repeat(4,1fr)!important}
} .home-descriptions li .tile{line-height:1.35}

/* Sidebar search */
.nav-search{padding:10px 12px 8px;margin:6px 10px 10px;border-radius:14px;border:1px solid color-mix(in oklab, var(--text) 10%, transparent);background:color-mix(in oklab, var(--panel) 86%, transparent);}
.nav-search input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid color-mix(in oklab, var(--text) 12%, transparent);background:color-mix(in oklab, var(--bg) 92%, transparent);color:var(--text);outline:none;font-weight:700;}
.nav-search input::placeholder{color:color-mix(in oklab, var(--muted) 92%, transparent);font-weight:700;}
.nav-search input:focus{box-shadow:0 0 0 6px color-mix(in oklab,var(--neon)16%, transparent);border-color:color-mix(in oklab,var(--neon)55%, transparent);}

/* Home: recents */

/* Card nav buttons */
.btn.navbtn{padding:8px 10px;font-weight:900;}
.btn.navbtn .arr{opacity:.9;margin:0 2px;}



@media (max-width: 640px){ :root{ --iframe-h: 440px; } }
@media (max-width: 520px){ .meta .actions{gap:8px;} .btn{padding:8px 10px;} }

/* 8‑Bit mode (Zip B): safe, fully scoped UI shell tweaks (buttons + boxes only). */
html[data-theme="8bit"] body{
  /* 8-bit palette: retro green/black */
  --bg: #001400;
  --panel: #001e00;
  --text: #33ff77;
  --muted: #16b85a;
  --neon: #00ff66;
  --accent: #00cc55;
  --glow: 0 0 10px rgba(0,255,102,.45), 0 0 26px rgba(0,255,102,.22);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  background: var(--bg) !important;
  color: var(--text);
}

/* Pixel-ish boxes (cards / tiles) */
html[data-theme="8bit"] .card{
  border-radius: 0;
  box-shadow: none;
  border: 4px solid color-mix(in oklab, var(--text) 70%, transparent);
  background: color-mix(in oklab, var(--panel) 96%, black 4%);
}
html[data-theme="8bit"] .card::before{ opacity: 0; }

html[data-theme="8bit"] .tile,
html[data-theme="8bit"] .home-descriptions .tile,
html[data-theme="8bit"] .playlist-tiles a.ptile{
  border-radius: 0;
  box-shadow: none;
  border-width: 4px;
}

html[data-theme="8bit"] .playlist-tiles a.ptile.has-cover{
  border: 4px solid color-mix(in oklab, var(--text) 70%, transparent);
  border-radius: 0;
}

/* Pixel buttons */
html[data-theme="8bit"] .btn,
html[data-theme="8bit"] .pill,
html[data-theme="8bit"] .seg,
html[data-theme="8bit"] .seg button,
html[data-theme="8bit"] .randomizer{
  border-radius: 0 !important;
  box-shadow: none !important;
}

html[data-theme="8bit"] .btn,
html[data-theme="8bit"] .pill,
html[data-theme="8bit"] .randomizer{
  border: 3px solid color-mix(in oklab, var(--text) 70%, transparent);
  background: color-mix(in oklab, var(--panel) 94%, black 6%);
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: .08em;
}

html[data-theme="8bit"] .btn.primary{
  background: color-mix(in oklab, var(--neon) 55%, var(--panel));
  border-color: color-mix(in oklab, var(--neon) 70%, var(--text));
}

html[data-theme="8bit"] .btn:active,
html[data-theme="8bit"] .randomizer:active,
html[data-theme="8bit"] .seg button:active{
  transform: translateY(1px);
}
html[data-theme="8bit"] .btn:hover,
html[data-theme="8bit"] .randomizer:hover,
html[data-theme="8bit"] .seg button:hover{
  background: color-mix(in oklab, var(--panel) 86%, var(--neon) 14%);
}

/* === 8-bit mode: menu vibe (Zip C) === */
html[data-theme="8bit"] .topbar{
  background: var(--bg) !important;
  border-bottom: 3px solid currentColor !important;
}
html[data-theme="8bit"] .crumb{
  opacity: 1 !important;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 12px;
}
html[data-theme="8bit"] .title-xl{
  text-transform: uppercase;
  letter-spacing: .08em;
}

html[data-theme="8bit"] .sidebar{
  background: var(--bg) !important;
  border-right: 4px solid currentColor !important;
}
html[data-theme="8bit"] .nav h3{
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 11px;
  padding: 8px 8px 6px;
  border: 2px solid currentColor;
  margin: 0 0 8px;
}

html[data-theme="8bit"] .nav a{
  border: 2px solid currentColor;
  border-radius: 0 !important;
  padding: 8px 8px;
  margin: 4px 0;
  position: relative;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 12px;
  box-shadow: none !important;
}
html[data-theme="8bit"] .nav a::before,
html[data-theme="8bit"] .subnav a::before{
  content: "\25B6"; /* ▶ */
  display: inline-block;
  width: 14px;
  margin-right: 6px;
  opacity: 0;
  transform: translateY(-1px);
}
html[data-theme="8bit"] .nav a:hover::before,
html[data-theme="8bit"] .nav a:focus-visible::before,
html[data-theme="8bit"] .nav a.active::before,
html[data-theme="8bit"] .subnav a:hover::before,
html[data-theme="8bit"] .subnav a:focus-visible::before,
html[data-theme="8bit"] .subnav a.active::before{
  opacity: 1;
}
html[data-theme="8bit"] .nav a:hover,
html[data-theme="8bit"] .nav a:focus-visible,
html[data-theme="8bit"] .nav a.active{
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

html[data-theme="8bit"] .subnav{
  margin: 4px 0 8px;
  padding: 6px 8px 8px;
  border-left: 3px solid currentColor;
  background: transparent !important;
}
html[data-theme="8bit"] .subnav a{
  border: 2px solid currentColor;
  border-radius: 0 !important;
  margin: 4px 0;
  padding: 7px 8px;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 12px;
}

html[data-theme="8bit"] .subnav .caret{
  border: 2px solid currentColor;
  border-radius: 0 !important;
  padding: 6px 8px;
}



/* Zip D: 8‑Bit polish — optional pixel font (loaded on-demand) + cartridge frame for embeds */
html[data-theme="8bit"] .topbar,
html[data-theme="8bit"] header,
html[data-theme="8bit"] .sidebar,
html[data-theme="8bit"] .btn,
html[data-theme="8bit"] .pill,
html[data-theme="8bit"] h1,
html[data-theme="8bit"] h2,
html[data-theme="8bit"] h3,
html[data-theme="8bit"] .tile-title,
html[data-theme="8bit"] .crumb,
html[data-theme="8bit"] nav{
  font-family: "Press Start 2P", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  letter-spacing: .6px;
}

/* Cartridge frame around embeds */
html[data-theme="8bit"] .player .stack{
  border-radius: 0;
  border: 4px solid color-mix(in oklab, var(--text) 72%, transparent);
  background: color-mix(in oklab, var(--panel) 92%, black 8%);
  box-shadow: none;
  overflow: hidden;
}
html[data-theme="8bit"] .player .stack iframe{
  inset: 10px;
  border-radius: 0 !important;
}



/* Zip F: 8‑Bit cleanup + retro tile chrome (scoped only) */
html[data-theme="8bit"] .nav h3{
  padding: 6px 8px 4px;
  margin: 0 0 6px;
  border-width: 1px;
}

html[data-theme="8bit"] .nav a{
  border-width: 1px;
  padding: 6px 8px;
  margin: 2px 0;
  font-size: 11px;
  letter-spacing: .02em;
  background: color-mix(in oklab, var(--panel) 88%, black 12%);
}

html[data-theme="8bit"] .nav a:hover,
html[data-theme="8bit"] .nav a:focus-visible,
html[data-theme="8bit"] .nav a.active{
  outline: 1px solid currentColor;
  outline-offset: 1px;
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--neon) 22%, transparent);
}

html[data-theme="8bit"] .nav a::before,
html[data-theme="8bit"] .subnav a::before{
  width: 10px;
  margin-right: 4px;
  opacity: .0;
}

html[data-theme="8bit"] .subnav{
  margin: 2px 0 6px;
  padding: 4px 6px 6px;
  border-left-width: 1px;
}

html[data-theme="8bit"] .subnav a{
  border-width: 1px;
  margin: 2px 0;
  padding: 6px 8px;
  font-size: 11px;
  letter-spacing: .02em;
  background: color-mix(in oklab, var(--panel) 86%, black 14%);
}

html[data-theme="8bit"] .subnav .caret{
  border-width: 1px;
  padding: 4px 6px;
}

html[data-theme="8bit"] .sidebar .brand{
  padding: 12px 10px 10px;
  gap: 10px;
}

/* Category tiles (home guide) inherit the retro green/black look in 8‑Bit mode */
html[data-theme="8bit"] .home-descriptions li .tile{
  background: color-mix(in oklab, var(--panel) 86%, black 14%);
  border-color: color-mix(in oklab, var(--neon) 60%, var(--text));
  box-shadow: none;
}

html[data-theme="8bit"] .home-descriptions li .tile:hover{
  transform: translateY(-1px);
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--neon) 26%, transparent);
}

/* Volume tiles that are NOT cover-image tiles get the same retro chrome */
html[data-theme="8bit"] .playlist-tiles a.ptile:not(.has-cover){
  background: color-mix(in oklab, var(--panel) 86%, black 14%);
  border-color: color-mix(in oklab, var(--neon) 60%, var(--text));
  box-shadow: none;
}

html[data-theme="8bit"] .playlist-tiles a.ptile:not(.has-cover):hover{
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--neon) 26%, transparent);
  transform: translateY(-1px);
}


/* --- 8-bit (Matrix) keyboard + focus polish --- */
html[data-theme="8bit"] :where(a, button, .btn, .pill, .seg, .nav a, .subnav a):focus-visible{
  outline: 2px solid var(--neon);
  outline-offset: 2px;
  box-shadow: none !important;
}
html[data-theme="8bit"] :where(a, button, .btn, .pill, .seg, .nav a, .subnav a){
  transition: none;
}

/* Optional scanlines overlay (toggle with "S" in 8-bit mode) */
html[data-theme="8bit"] body::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  opacity: .42;
  background: repeating-linear-gradient(
    to bottom,
    rgba(0,0,0,0) 0px,
    rgba(0,0,0,0) 1px,
    rgba(0,0,0,.55) 2px
  );
  mix-blend-mode: multiply;
}


/* Mobile centering + prevent sideways layout (safe) */
*, *::before, *::after { box-sizing: border-box; }
html, body { width: 100%; }
/* === Mobile embed height bump (safe) === */
@media (max-width: 560px){
  :root{ --iframe-h: 440px; }
  body.platform-apple{ } }


/* === Mobile layout: collapse sidebar column + off-canvas drawer (safe) === */
@media (max-width: 900px){
  .app{
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    min-height: 100vh;
  }
  /* off-canvas sidebar */
  .sidebar{
    position: fixed !important;
    top: 0; left: 0;
    height: 100vh !important;
    width: min(320px, 86vw);
    transform: translateX(-110%);
    transition: transform .18s ease;
    z-index: 60;
  }
  .sidebar.open{ transform: translateX(0); }

  /* dim overlay when sidebar open */
  body.sidebar-open::before{
    content:"";
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 55;
  }

  /* hamburger always reachable */
  #tpaMobileBtn.tpa-hamburger{
    display: inline-flex;
    position: fixed;
    top: 10px;
    left: 10px;
    z-index: 70;
  }

  /* keep topbar content from sitting under the button */
  .topbar{ padding-left: 56px !important; }

  /* "zoomed out" feel without locking Safari zoom */
  body{ font-size: 15px; }
}



/* === Mobile centering hard override (Safari) === */
@media (max-width: 1023px){
  header.topbar{
    position: sticky;
    top: 0;
    display: flex;
    flex-direction: column;
    align-items: center !important;
    justify-content: flex-start !important;
    text-align: center;
    padding: 12px 12px 10px 60px !important; /* room for fixed hamburger on left */
    gap: 8px !important;
  }
  header.topbar > div:first-child{
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
  }
  header.topbar .crumb{ font-size: 12px; opacity: .85; }
  header.topbar .title-xl{ font-size: 28px; line-height: 1.05; }
  header.topbar .toggles{
    width: 100% !important;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center !important;
    gap: 8px !important;
    min-width: 0;
  }
  header.topbar .seg{
    flex: 0 1 auto;
    min-width: 0;
  }
  header.topbar .seg button,
  header.topbar .randomizer{
    font-size: 13px;
    padding: 10px 12px;
  }
  header.topbar .randomizer{
    max-width: 100%;
    white-space: normal; /* allow wrap instead of overflow */
    text-align: center;
  }
  /* Slightly more "zoomed out" feel without viewport scaling */
  body{ font-size: 15px; }
}



/* === TPA Mobile Welcome Centering v127 (safe) === */
@media (max-width: 1023px){
  /* Center grid items; prevent any child from forcing horizontal overflow */
  #grid{ justify-items: center; }
  #grid > *{ min-width: 0; max-width: 100%; }
  .card{ max-width: 100%; }
  /* Ensure the welcome panel itself is centered and fits within viewport */
  #Welcome, .welcome, .welcome-box, .welcomePanel, .home-welcome{
    width: 100% !important;
    max-width: min(560px, calc(100vw - 28px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  /* The outer card that contains the welcome panel should not stick to the left */
  .welcomePanel{ justify-self: center !important; }
}



/* === Mobile-only: Category Guide grid 3-up (requested) === */
@media (max-width: 1023px){
  #homeDescriptions.home-descriptions ul.cols{
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px 10px !important;
    justify-items: stretch !important;
  }
  #homeDescriptions.home-descriptions{ padding-left: 10px !important; padding-right: 10px !important; }
  #homeDescriptions.home-descriptions .tile{
    padding: 10px 10px !important;
    min-height: 78px !important;
    border-radius: 12px !important;
  }
  #homeDescriptions.home-descriptions .tile .cat{
    font-size: 14px !important;
    line-height: 1.15 !important;
  }
  #homeDescriptions.home-descriptions .tile .desc{
    font-size: 12px !important;
    line-height: 1.2 !important;
  }
}

