:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#111}a:hover{color:#747bff}button{background-color:#f9f9f9}}.context-menu{position:fixed;background:#2a2a2a;border:1px solid #444;border-radius:6px;box-shadow:0 4px 12px #00000080;z-index:1000;min-width:200px;padding:4px 0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.context-menu-header{padding:8px 12px;color:#fff;font-size:14px;border-bottom:1px solid #444;margin-bottom:4px}.context-menu-divider{height:1px;background:#444;margin:4px 0}.context-menu-item{width:100%;padding:10px 12px;background:transparent;border:none;color:#fff;text-align:left;cursor:pointer;font-size:14px;transition:background-color .2s}.context-menu-item:hover:not(.disabled){background:#3a3a3a}.context-menu-item.disabled{color:#888;cursor:not-allowed;opacity:.6}.context-menu-item:focus{outline:none;background:#3a3a3a}.context-menu-item--danger{color:#f44336}.context-menu-item--danger:hover{background:#3a2020}.artist-card-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.4);z-index:499;cursor:default}.artist-card{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:320px;max-height:500px;background:#2a2a2a;border:1px solid #444;border-radius:12px;z-index:500;box-shadow:0 8px 32px #00000080;overflow-y:auto;color:#fff;padding:24px;display:flex;flex-direction:column;gap:16px;cursor:default}.artist-card-close{position:absolute;top:12px;right:12px;background:none;border:none;color:#888;font-size:20px;cursor:pointer;padding:4px 8px;line-height:1;border-radius:4px}.artist-card-close:hover{color:#fff;background:#3a3a3a}.artist-card-avatar{width:80px;height:80px;border-radius:50%;background:#3a3a3a;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600;color:#888;margin:0 auto;flex-shrink:0}.artist-card-avatar--group{background:#3a1a2a;color:#ff69b4}.artist-card-avatar--photo{background:none;overflow:hidden}.artist-card-avatar--photo img{width:100%;height:100%;object-fit:cover}.artist-card-name{font-size:20px;font-weight:600;text-align:center;margin:0}.artist-card-meta{display:flex;justify-content:center;gap:12px;font-size:13px;color:#aaa}.artist-card-section-title{font-size:12px;text-transform:uppercase;color:#666;letter-spacing:.5px;margin:0 0 6px}.artist-card-genres{display:flex;flex-wrap:wrap;gap:6px}.artist-card-genre-tag{background:#333;border:1px solid #555;border-radius:12px;padding:3px 10px;font-size:12px;color:#ccc}.artist-card-groups{display:flex;flex-direction:column;gap:4px}.artist-card-group-item{font-size:14px;color:#ccc;padding:4px 0}.artist-card-former{color:#888;font-size:12px;font-style:italic}.artist-card-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:#888;font-size:14px}.artist-card-error{display:flex;align-items:center;justify-content:center;min-height:200px;color:#f44336;font-size:14px}
