/* Core layout */
.tsvxui-menu a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;text-decoration:none}
.tsvxui-menu a:hover{background:rgba(255,255,255,.06)}
.tsvxui-menu img{width:18px;height:18px}


/* Header block */
.tsvxui-head{display:grid;grid-template-columns:140px 1fr 280px;gap:24px;align-items:center;margin-bottom:16px}
.tsvxui-cover{width:140px;height:140px;border-radius:999px;overflow:hidden}
.tsvxui-cover img{width:100%;height:100%;object-fit:cover}
.tsvxui-title{font-size:28px;font-weight:700}
.tsvxui-artist{opacity:.7;margin-top:4px}
.tsvxui-desc{margin-top:10px}
.tsvxui-desc .more{opacity:.7;cursor:pointer}
.tsvxui-tags{display:flex;flex-wrap:wrap;gap:8px}
.tsvxui-tag{border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:6px 10px;font-size:12px;opacity:.9}


/* Inline player (top half wave) */
.tsvxui-inline{display:flex;align-items:center;gap:12px;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);padding:12px 0;margin:12px 0}
.tsvxui-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.06)}
.tsvxui-btn:hover{background:rgba(255,255,255,.1)}
.tsvxui-time{min-width:48px;text-align:center;opacity:.9}
.tsvxui-wave{flex:1;height:54px;position:relative}
.tsvxui-wave .mask{position:absolute;inset:0;overflow:hidden;}
.tsvxui-wave .mask .inner{height:108px;transform:translateY(-54px);} /* show top half */


/* Volume vertical panel */
.tsvxui-vol{position:relative}
.tsvxui-vol .panel{position:absolute;bottom:44px;left:50%;transform:translateX(-50%);width:42px;height:130px;border-radius:10px;background:rgba(20,20,20,.96);display:none;align-items:center;justify-content:center;padding:8px;border:1px solid rgba(255,255,255,.08)}
.tsvxui-vol input[type=range]{writing-mode:bt-lr;-webkit-appearance:slider-vertical;height:110px}
.tsvxui-vol.open .panel{display:flex}


/* Related grid */
.tsvxui-related{margin-top:8px}
.tsvxui-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.tsvxui-card{padding:12px;border-radius:16px;background:transparent;position:relative}
.tsvxui-card .thumb{width:100px;height:100px;border-radius:999px;overflow:hidden;margin-bottom:10px;position:relative}
.tsvxui-card .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.tsvxui-card .play-overlay{position:absolute;inset:0;display:grid;place-items:center;background:rgba(0,0,0,.0);opacity:0;transition:.2s}
.tsvxui-card:hover .play-overlay{opacity:1;background:rgba(0,0,0,.24)}
.tsvxui-card .glow{box-shadow:0 0 0 0 rgba(246,192,0,.0);transition:.15s}
.tsvxui-card:hover .glow{box-shadow:0 0 0 4px rgba(246,192,0,.25)}


/* Global bottom bar */
.tsvxui-global{position:fixed;left:0;right:0;bottom:0;background:#111;border-top:1px solid rgba(255,255,255,.08);padding:10px;display:flex;align-items:center;gap:12px;z-index:999}
.tsvxui-global .mini{width:36px;height:36px;border-radius:999px;overflow:hidden}
.tsvxui-global .wave{flex:1;height:44px}


/* Mobile */
@media (max-width:1024px){
.tsvxui-wrap{grid-template-columns:1fr}
.tsvxui-left{display:none}
.tsvxui-head{grid-template-columns:100px 1fr;gap:16px}
.tsvxui-grid{grid-template-columns:repeat(2,1fr)}
}


/* Mobile bottom bar */
.tsvxui-mbar{position:fixed;left:0;right:0;bottom:0;background:#111;border-top:1px solid rgba(255,255,255,.08);padding:8px 12px;display:flex;align-items:center;gap:10px;z-index:1000}
.tsvxui-mbar .mini{width:42px;height:42px;border-radius:999px;overflow:hidden}
.tsvxui-mbar .title{font-weight:600}
.tsvxui-mbar .artist{opacity:.7;font-size:12px;margin-top:2px}


/* Mobile panel */
.tsvxui-panel{position:fixed;left:0;right:0;bottom:-100%;background:#141414;border-top-left-radius:18px;border-top-right-radius:18px;padding:18px 16px 90px;z-index:1001;transition:bottom .25s ease}
.tsvxui-panel.open{bottom:0}
.tsvxui-panel .cover{width:180px;height:180px;border-radius:999px;overflow:hidden;margin:0 auto 12px}
.tsvxui-actions{display:flex;flex-direction:column;gap:10px;margin:10px 0}
.tsvxui-actions .item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;background:rgba(255,255,255,.06)}


/* Skeleton (fake downloading) */
.skel{animation:sk 1s linear infinite;background:linear-gradient(90deg, rgba(255,255,255,.06), rgba(255,255,255,.15), rgba(255,255,255,.06));background-size:200% 100%}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}