:root{--oa-player-dock-height:0px}
.oa-player{--oa-accent:#ff2f7d;position:relative;margin:26px 0;padding:28px;border-radius:32px;overflow:hidden;box-shadow:0 26px 70px rgba(0,0,0,.28)}
.oa-player *{box-sizing:border-box}
.oa-theme-dark{background:linear-gradient(135deg,rgba(255,255,255,.08) 0%,rgba(255,255,255,.03) 36%,rgba(255,255,255,.02) 100%),linear-gradient(180deg,#2d3139 0%,#22262e 100%);color:#fff;border:1px solid rgba(255,255,255,.08)}
.oa-theme-light{background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);color:#111827;border:1px solid rgba(15,23,42,.08)}
.oa-player::before{content:"";position:absolute;left:-100px;top:-100px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--oa-accent) 60%,#fff 10%) 0%,rgba(255,255,255,0) 72%);opacity:.16;pointer-events:none}
.oa-player::after{content:"";position:absolute;right:-120px;bottom:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--oa-accent) 60%,#6366f1 40%) 0%,rgba(255,255,255,0) 72%);opacity:.14;pointer-events:none}
.oa-player-inner{position:relative;z-index:1}
.oa-player-main{display:grid;grid-template-columns:120px minmax(0,1fr);gap:22px;align-items:start;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.12)}
.oa-theme-light .oa-player-main{border-bottom-color:rgba(15,23,42,.08)}
.oa-cover-wrap{width:120px}
.oa-cover{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;border-radius:24px;background:rgba(255,255,255,.08);box-shadow:0 18px 36px rgba(0,0,0,.22)}
.oa-info{min-width:0}
.oa-title{margin:0 0 8px;font-size:34px;line-height:1.12;font-weight:800;word-break:break-word}
.oa-subtitle{display:flex;flex-wrap:wrap;gap:6px;font-size:15px;opacity:.82;margin-bottom:16px}
.oa-sep{opacity:.5}
.oa-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.oa-btn{border:0;border-radius:999px;padding:11px 15px;cursor:pointer;background:rgba(255,255,255,.08);color:inherit;font-size:14px;transition:.2s}
.oa-theme-light .oa-btn{background:rgba(15,23,42,.06)}
.oa-btn:hover{transform:translateY(-1px);background:rgba(255,255,255,.15)}
.oa-theme-light .oa-btn:hover{background:rgba(15,23,42,.1)}
.oa-btn-primary{background:linear-gradient(90deg,var(--oa-accent),color-mix(in srgb,var(--oa-accent) 55%,#ff7ab3 45%));color:#fff;font-weight:800;min-width:58px}
.oa-progress-row{display:grid;grid-template-columns:56px 1fr 56px;gap:12px;align-items:center}
.oa-progress,.oa-floating-range{-webkit-appearance:none;appearance:none;height:6px;border-radius:999px;outline:none;background:linear-gradient(90deg,rgba(255,255,255,.88) 0%,rgba(82,72,182,.95) 100%)}
.oa-theme-light .oa-progress,.oa-theme-light .oa-floating-range{background:linear-gradient(90deg,#d1d5db 0%,color-mix(in srgb,var(--oa-accent) 40%,#6366f1 60%) 100%)}
.oa-progress::-webkit-slider-thumb,.oa-floating-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:0;box-shadow:0 4px 12px rgba(0,0,0,.28)}
.oa-progress::-moz-range-thumb,.oa-floating-range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:0}
.oa-current-time,.oa-duration{font-size:12px;opacity:.84;font-variant-numeric:tabular-nums}
.oa-panels{display:grid;grid-template-columns:1fr;gap:18px;margin-top:18px}
.oa-lyrics-panel,.oa-playlist-panel{border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(255,255,255,.05) 0%,rgba(255,255,255,.02) 100%);border-radius:24px;padding:18px}
.oa-theme-light .oa-lyrics-panel,.oa-theme-light .oa-playlist-panel{border-color:rgba(15,23,42,.08);background:#fff}
.oa-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.oa-lyrics-title,.oa-playlist-title{font-size:14px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;opacity:.92}
.oa-lyrics{min-height:320px;max-height:460px;overflow:auto;padding:20px 10px;text-align:center;scroll-behavior:smooth}
.oa-lyric-line{padding:10px 0;font-size:18px;line-height:1.9;color:rgba(255,255,255,.62);transition:all .24s ease;word-break:break-word}
.oa-theme-light .oa-lyric-line{color:#64748b}
.oa-lyric-line.is-active{color:#fff;font-size:24px;font-weight:800;text-shadow:0 0 18px color-mix(in srgb,var(--oa-accent) 55%, transparent)}
.oa-theme-light .oa-lyric-line.is-active{color:var(--oa-accent);text-shadow:none}
.oa-lyric-line.is-empty{opacity:.8}
.oa-playlist{list-style:none;margin:0;padding:0;max-height:420px;overflow:auto;display:flex;flex-direction:column;gap:0}
.oa-playlist-item{display:grid;grid-template-columns:56px minmax(0,1fr) 42px;align-items:center;gap:12px;min-height:56px;border-top:1px solid rgba(255,255,255,.08);cursor:pointer;transition:.2s;position:relative}
.oa-theme-light .oa-playlist-item{border-top-color:rgba(15,23,42,.08)}
.oa-playlist-item:first-child{border-top:0}
.oa-playlist-item::after{content:"≡";display:flex;align-items:center;justify-content:center;height:100%;width:42px;border-left:1px solid rgba(255,255,255,.08);opacity:.8}
.oa-theme-light .oa-playlist-item::after{border-left-color:rgba(15,23,42,.08)}
.oa-playlist-item:hover{background:rgba(255,255,255,.04)}
.oa-theme-light .oa-playlist-item:hover{background:rgba(15,23,42,.04)}
.oa-playlist-item.is-active{background:linear-gradient(90deg,var(--oa-accent) 0%,color-mix(in srgb,var(--oa-accent) 68%,#ff5f99 32%) 100%)}
.oa-playlist-item.is-active::after{background:rgba(0,0,0,.08);color:#fff}
.oa-playlist-index{display:flex;align-items:center;justify-content:center;font-weight:800;font-variant-numeric:tabular-nums;opacity:.9}
.oa-playlist-main{display:flex;flex-direction:column;gap:2px;min-width:0;padding:10px 0}
.oa-playlist-name{font-weight:700;line-height:1.45;word-break:break-word}
.oa-playlist-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:12px;opacity:.74}
.oa-playlist-dot{opacity:.5}
.oa-floating-player{position:fixed;left:0;right:0;bottom:0;z-index:99999;display:none;grid-template-columns:72px minmax(180px,320px) auto minmax(220px,1fr);align-items:center;gap:14px;background:rgba(17,24,39,.98);backdrop-filter:blur(10px);color:#fff;padding:12px 18px;border-top:1px solid rgba(255,255,255,.08);box-shadow:0 -8px 24px rgba(0,0,0,.22);width:100%}
.oa-floating-player.oa-light{background:rgba(255,255,255,.98);color:#111827;border-top-color:rgba(15,23,42,.08)}
.oa-has-player-dock{padding-bottom:calc(var(--oa-player-dock-height) + 12px)!important}
.oa-floating-cover{width:56px;height:56px;border-radius:12px;object-fit:cover;background:rgba(148,163,184,.18)}
.oa-floating-meta{min-width:0}
.oa-floating-title{font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.oa-floating-subtitle{font-size:12px;opacity:.78;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.oa-floating-controls{display:flex;gap:8px;justify-content:center}
.oa-floating-controls button{border:0;background:rgba(148,163,184,.16);color:inherit;border-radius:999px;padding:10px 12px;cursor:pointer}
.oa-floating-controls .oa-fplay{background:var(--oa-accent);color:#fff}
.oa-floating-progress{display:flex;align-items:center;gap:10px;min-width:220px}
.oa-floating-progress input{width:100%}
.oa-floating-time{font-size:12px;opacity:.75;white-space:nowrap}
@media (min-width:980px){.oa-panels{grid-template-columns:1.12fr .88fr}.oa-lyrics-panel{order:1}.oa-playlist-panel{order:2}}
@media (max-width:900px){.oa-player{padding:20px;border-radius:24px}.oa-player-main{grid-template-columns:88px 1fr;gap:16px}.oa-cover-wrap{width:88px}.oa-title{font-size:26px}.oa-lyric-line{font-size:16px}.oa-lyric-line.is-active{font-size:21px}}
@media (max-width:640px){.oa-player{padding:14px;margin:18px 0;border-radius:20px}.oa-player-main{grid-template-columns:72px 1fr;gap:14px}.oa-cover-wrap{width:72px}.oa-title{font-size:22px}.oa-subtitle{font-size:13px}.oa-btn{padding:10px 13px;font-size:13px}.oa-progress-row{grid-template-columns:44px 1fr 44px;gap:8px}.oa-lyrics{min-height:250px;max-height:350px;padding:10px 6px}.oa-lyric-line{font-size:15px;line-height:1.75}.oa-lyric-line.is-active{font-size:19px}.oa-playlist-item{grid-template-columns:44px minmax(0,1fr) 36px;min-height:48px}.oa-playlist-item::after{width:36px}.oa-floating-player{padding:10px 12px;gap:10px;grid-template-columns:56px 1fr auto;grid-template-areas:"cover meta controls" "progress progress progress"}.oa-floating-cover{grid-area:cover}.oa-floating-meta{grid-area:meta}.oa-floating-controls{grid-area:controls}.oa-floating-progress{grid-area:progress;min-width:100%}}

.oa-floating-player{display:none !important;}
.oa-has-player-dock{padding-bottom:0 !important;}


/* v1.1.7 layout refine */
@media (min-width:980px){
  .oa-panels{
    grid-template-columns:1fr;
  }
}
.oa-panels{
  display:flex !important;
  flex-direction:column !important;
  gap:14px !important;
}
.oa-lyrics-panel{
  order:1 !important;
}
.oa-playlist-panel{
  order:2 !important;
}
.oa-lyrics{
  min-height:180px !important;
  max-height:220px !important;
  overflow:hidden !important;
  padding:12px 6px !important;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.oa-lyrics::-webkit-scrollbar{
  display:none;
}
.oa-lyric-line{
  padding:6px 0 !important;
  line-height:1.6 !important;
}
.oa-lyric-line.is-active{
  font-size:21px !important;
}
.oa-playlist{
  max-height:none !important;
  overflow:visible !important;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.oa-playlist::-webkit-scrollbar{
  display:none;
}
.oa-playlist-item{
  grid-template-columns:52px minmax(0,1fr) !important;
  min-height:50px !important;
  gap:0 !important;
  padding:0 2px !important;
  border-top:1px solid rgba(255,255,255,.06) !important;
}
.oa-theme-light .oa-playlist-item{
  border-top-color:rgba(15,23,42,.06) !important;
}
.oa-playlist-item::after{
  display:none !important;
  content:none !important;
}
.oa-playlist-index{
  justify-content:flex-start !important;
  padding-left:8px !important;
  font-size:13px !important;
  opacity:.55 !important;
}
.oa-playlist-main{
  padding:12px 6px 12px 0 !important;
}
.oa-playlist-name{
  font-size:14px !important;
  font-weight:700 !important;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.oa-playlist-meta,
.oa-playlist-dot,
.oa-playlist-artist,
.oa-playlist-album{
  display:none !important;
}
.oa-playlist-item.is-active{
  background:linear-gradient(90deg,color-mix(in srgb,var(--oa-accent) 16%, transparent) 0%,color-mix(in srgb,var(--oa-accent) 6%, transparent) 100%) !important;
  border-radius:12px !important;
}
.oa-theme-dark .oa-playlist-item.is-active .oa-playlist-index,
.oa-theme-dark .oa-playlist-item.is-active .oa-playlist-name{
  color:#fff !important;
}
.oa-theme-light .oa-playlist-item.is-active .oa-playlist-index,
.oa-theme-light .oa-playlist-item.is-active .oa-playlist-name{
  color:var(--oa-accent) !important;
}
@media (max-width:640px){
  .oa-lyrics{
    min-height:150px !important;
    max-height:180px !important;
  }
  .oa-lyric-line{
    font-size:14px !important;
  }
  .oa-lyric-line.is-active{
    font-size:18px !important;
  }
  .oa-playlist-item{
    grid-template-columns:42px minmax(0,1fr) !important;
    min-height:46px !important;
  }
  .oa-playlist-index{
    padding-left:4px !important;
    font-size:12px !important;
  }
  .oa-playlist-name{
    font-size:13px !important;
  }
}


/* v1.1.8 lyrics above current track, remove transparent boxes */
.oa-panels{
  display:flex !important;
  flex-direction:column !important;
}
.oa-lyrics-panel{
  order:-2 !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 0 10px 0 !important;
  margin-bottom:2px !important;
}
.oa-current-track-card{
  order:-1 !important;
}
.oa-playlist-panel{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:8px 0 0 0 !important;
}
.oa-panel-head{
  margin-bottom:8px !important;
}
.oa-lyrics-title,
.oa-playlist-title{
  opacity:.72 !important;
}
.oa-lyrics{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  min-height:150px !important;
  max-height:190px !important;
  padding:4px 0 !important;
}
.oa-playlist{
  background:transparent !important;
}
.oa-playlist-item{
  background:transparent !important;
}
.oa-playlist-item:hover{
  background:rgba(255,255,255,.03) !important;
}
.oa-theme-light .oa-playlist-item:hover{
  background:rgba(15,23,42,.04) !important;
}
@media (max-width:640px){
  .oa-lyrics{
    min-height:130px !important;
    max-height:160px !important;
  }
}


/* v1.1.9 swap lyrics above now playing */
.oa-lyrics-panel{
  margin-bottom:10px !important;
}
.oa-player-main{
  margin-bottom:10px !important;
}
.oa-body{
  display:block !important;
}


/* v1.2.0 remove lyrics title and add divider under lyrics */
.oa-lyrics-panel{
  padding-bottom:14px !important;
  margin-bottom:14px !important;
  border-bottom:1px solid rgba(255,255,255,.12) !important;
}
.oa-theme-light .oa-lyrics-panel{
  border-bottom-color:rgba(15,23,42,.08) !important;
}
.oa-lyrics-panel .oa-panel-head{
  display:none !important;
}


/* v1.2.1 screenshot style + dynamic cover color */
.oa-player{
  --oa-cover-rgb: 44, 79, 126;
  --oa-cover-rgb-top: 73, 120, 178;
  background: linear-gradient(180deg, rgba(var(--oa-cover-rgb-top), 0.98) 0%, rgba(var(--oa-cover-rgb), 0.985) 100%) !important;
  border: 0 !important;
  box-shadow: 0 28px 70px rgba(0,0,0,.22) !important;
}
.oa-player::before{
  background: radial-gradient(circle at top left, rgba(255,255,255,.12) 0%, rgba(255,255,255,0) 65%) !important;
  left: -80px !important;
  top: -80px !important;
  opacity: 1 !important;
}
.oa-player::after{ display:none !important; }

.oa-lyrics-panel{
  padding: 0 0 18px !important;
  margin: 0 0 18px !important;
  border-bottom: 1px solid rgba(255,255,255,.16) !important;
}
.oa-lyrics{
  min-height: 300px !important;
  max-height: 360px !important;
  padding: 10px 0 6px !important;
  overflow: hidden !important;
}
.oa-lyric-line{
  padding: 12px 0 !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  line-height: 1.55 !important;
  color: rgba(255,255,255,.28) !important;
  text-shadow: none !important;
}
.oa-lyric-line.is-active{
  color: #fff !important;
  font-size: 24px !important;
  font-weight: 800 !important;
  text-shadow: none !important;
}
.oa-lyric-line.is-empty{ color: rgba(255,255,255,.7) !important; }

.oa-player-main{
  grid-template-columns: 70px minmax(0,1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  padding: 0 !important;
  margin: 0 0 10px !important;
  border: 0 !important;
}
.oa-cover-wrap{ width: 70px !important; }
.oa-cover{
  border-radius: 14px !important;
  box-shadow: none !important;
  background: rgba(255,255,255,.08) !important;
}
.oa-chip{ display:none !important; }
.oa-info{ display:flex !important; flex-direction:column !important; }
.oa-title{
  margin: 0 0 3px !important;
  font-size: 17px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
}
.oa-subtitle{
  margin: 0 0 16px !important;
  font-size: 13px !important;
  opacity: .86 !important;
  color: rgba(255,255,255,.86) !important;
}
.oa-progress-row{
  order: 2;
  grid-template-columns: 48px 1fr 48px !important;
  gap: 10px !important;
  align-items: center !important;
  margin: 0 0 16px !important;
}
.oa-current-time,.oa-duration{
  font-size: 12px !important;
  color: rgba(255,255,255,.95) !important;
  opacity: 1 !important;
}
.oa-progress{
  height: 6px !important;
  background: linear-gradient(90deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.28) 100%) !important;
}
.oa-progress::-webkit-slider-thumb,
.oa-floating-range::-webkit-slider-thumb{
  width: 18px !important;
  height: 18px !important;
  background: #fff !important;
  box-shadow: none !important;
}
.oa-progress::-moz-range-thumb,
.oa-floating-range::-moz-range-thumb{
  width: 18px !important;
  height: 18px !important;
  background: #fff !important;
  box-shadow: none !important;
}
.oa-controls{
  order: 3;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 22px !important;
  margin: 0 !important;
}
.oa-btn{
  background: transparent !important;
  border-radius: 0 !important;
  min-width: auto !important;
  padding: 0 !important;
  color: rgba(255,255,255,.82) !important;
  box-shadow: none !important;
}
.oa-btn:hover{
  background: transparent !important;
  transform: none !important;
  color: #fff !important;
}
.oa-prev,.oa-next{ font-size: 22px !important; line-height: 1 !important; }
.oa-btn-primary{
  width: 52px !important;
  height: 52px !important;
  min-width: 52px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(255,255,255,.14) !important;
  font-size: 28px !important;
}
.oa-loop{
  margin-left: 14px !important;
  font-size: 15px !important;
  white-space: nowrap !important;
}

.oa-playlist-panel{
  padding-top: 10px !important;
}
.oa-playlist-title{
  font-size: 13px !important;
  letter-spacing: .08em !important;
  color: rgba(255,255,255,.88) !important;
}
.oa-playlist-item{
  border-top: 1px solid rgba(255,255,255,.10) !important;
  min-height: 48px !important;
}
.oa-playlist-item:hover{
  background: rgba(255,255,255,.045) !important;
}
.oa-playlist-item.is-active{
  background: rgba(255,255,255,.09) !important;
}
.oa-playlist-index{ color: rgba(255,255,255,.6) !important; }
.oa-playlist-name{ color: #fff !important; }

@media (max-width: 640px){
  .oa-player{ padding: 18px !important; }
  .oa-lyrics{ min-height: 240px !important; max-height: 280px !important; }
  .oa-lyric-line{ font-size: 16px !important; padding: 10px 0 !important; }
  .oa-lyric-line.is-active{ font-size: 21px !important; }
  .oa-player-main{ grid-template-columns: 58px minmax(0,1fr) !important; gap: 12px !important; }
  .oa-cover-wrap{ width: 58px !important; }
  .oa-title{ font-size: 16px !important; }
  .oa-subtitle{ font-size: 12px !important; }
  .oa-controls{ gap: 18px !important; }
  .oa-btn-primary{ width: 48px !important; height: 48px !important; min-width: 48px !important; font-size: 26px !important; }
  .oa-loop{ font-size: 13px !important; margin-left: 10px !important; }
}


/* v1.2.2 refined now-playing area */
.oa-player-main{
  grid-template-columns: 96px minmax(0,1fr) !important;
  gap: 18px !important;
  align-items: center !important;
  margin: 0 0 18px !important;
}
.oa-cover-wrap{ width: 96px !important; }
.oa-cover{
  border-radius: 18px !important;
  box-shadow: 0 14px 26px rgba(0,0,0,.16) !important;
}
.oa-info{
  display: grid !important;
  grid-template-columns: 1fr !important;
  grid-template-areas:
    "meta"
    "progress"
    "controls" !important;
  row-gap: 12px !important;
}
.oa-track-meta{ grid-area: meta; }
.oa-title{
  margin: 0 0 5px !important;
  font-size: 28px !important;
  line-height: 1.12 !important;
  font-weight: 900 !important;
  letter-spacing: -.02em !important;
  color: #fff !important;
}
.oa-subtitle{
  margin: 0 !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
  color: rgba(255,255,255,.82) !important;
  gap: 8px !important;
}
.oa-progress-row{
  grid-area: progress;
  grid-template-columns: 54px 1fr 54px !important;
  gap: 12px !important;
  margin: 4px 0 0 !important;
}
.oa-current-time,.oa-duration{
  font-size: 13px !important;
  font-weight: 700 !important;
  color: rgba(255,255,255,.96) !important;
}
.oa-progress{
  height: 8px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, rgba(255,255,255,.98) 0%, rgba(255,255,255,.34) 100%) !important;
}
.oa-progress::-webkit-slider-thumb,
.oa-progress::-moz-range-thumb{
  width: 20px !important;
  height: 20px !important;
  border: 3px solid rgba(255,255,255,.3) !important;
  background: #fff !important;
  box-shadow: 0 6px 18px rgba(0,0,0,.18) !important;
}
.oa-controls{
  grid-area: controls;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  margin: 2px 0 0 !important;
}
.oa-prev,
.oa-next{
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  color: #fff !important;
  font-size: 18px !important;
}
.oa-prev:hover,
.oa-next:hover{
  background: rgba(255,255,255,.14) !important;
}
.oa-btn-primary{
  width: 64px !important;
  height: 64px !important;
  min-width: 64px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: linear-gradient(135deg, rgba(255,255,255,.22) 0%, rgba(255,255,255,.08) 100%) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  color: #fff !important;
  font-size: 30px !important;
  box-shadow: 0 10px 28px rgba(0,0,0,.16) !important;
}
.oa-btn-primary:hover{
  background: linear-gradient(135deg, rgba(255,255,255,.26) 0%, rgba(255,255,255,.12) 100%) !important;
}
.oa-loop{
  min-height: 42px !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(255,255,255,.10) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  color: rgba(255,255,255,.96) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  margin-left: 6px !important;
}
.oa-loop:hover{ background: rgba(255,255,255,.16) !important; }

/* tighten relation with lyrics area */
.oa-lyrics-panel{ margin-bottom: 18px !important; }

@media (max-width: 760px){
  .oa-player-main{
    grid-template-columns: 76px minmax(0,1fr) !important;
    gap: 14px !important;
  }
  .oa-cover-wrap{ width: 76px !important; }
  .oa-title{ font-size: 22px !important; }
  .oa-subtitle{ font-size: 13px !important; }
  .oa-progress-row{ grid-template-columns: 46px 1fr 46px !important; gap: 10px !important; }
  .oa-controls{ gap: 12px !important; }
  .oa-prev,.oa-next{ width: 38px !important; height: 38px !important; min-width: 38px !important; }
  .oa-btn-primary{ width: 56px !important; height: 56px !important; min-width: 56px !important; font-size: 27px !important; }
  .oa-loop{ min-height: 38px !important; padding: 0 13px !important; font-size: 13px !important; margin-left: 2px !important; }
}

@media (max-width: 560px){
  .oa-player-main{
    grid-template-columns: 60px minmax(0,1fr) !important;
    gap: 12px !important;
    align-items: start !important;
  }
  .oa-cover-wrap{ width: 60px !important; }
  .oa-cover{ border-radius: 14px !important; }
  .oa-title{ font-size: 18px !important; margin-bottom: 4px !important; }
  .oa-subtitle{ font-size: 12px !important; }
  .oa-progress-row{ margin-top: 2px !important; }
  .oa-controls{
    justify-content: center !important;
    gap: 10px !important;
  }
  .oa-prev,.oa-next{ width: 36px !important; height: 36px !important; min-width: 36px !important; font-size: 16px !important; }
  .oa-btn-primary{ width: 52px !important; height: 52px !important; min-width: 52px !important; font-size: 26px !important; }
  .oa-loop{ order: 4 !important; width: auto !important; }
}


/* v1.2.3 remove player background */
.oa-player{
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}
.oa-player::before,
.oa-player::after{
  display: none !important;
  content: none !important;
}


/* v1.2.4 playlist collapse + no active highlight */
.oa-playlist-item.is-active{
  background: transparent !important;
  border-radius: 0 !important;
}
.oa-playlist-item.is-active .oa-playlist-index,
.oa-playlist-item.is-active .oa-playlist-name{
  color: inherit !important;
}
.oa-is-hidden-track{
  display: none !important;
}
.oa-playlist-toggle{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 14px auto 0;
  padding: 0 18px;
  min-height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: transparent;
  color: rgba(255,255,255,.92);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}
.oa-playlist-toggle:hover{
  background: rgba(255,255,255,.06);
}
.oa-theme-light .oa-playlist-toggle{
  border-color: rgba(15,23,42,.10);
  color: rgba(15,23,42,.86);
}
.oa-theme-light .oa-playlist-toggle:hover{
  background: rgba(15,23,42,.05);
}


/* v1.2.9 final requested layout */
.oa-player{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.oa-player::before,
.oa-player::after{
  display: none !important;
  content: none !important;
}

.oa-cover-hero{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  margin:0 0 14px !important;
}
.oa-cover-hero .oa-cover-wrap{
  width:320px !important;
  max-width:78vw !important;
  margin:0 auto !important;
}
.oa-cover-hero .oa-cover{
  width:100% !important;
  display:block !important;
  border-radius:16px !important;
  border:4px solid rgba(255,255,255,.14) !important;
  background:transparent !important;
  box-shadow:none !important;
}

.oa-cover-meta{
  width:100% !important;
  max-width:760px !important;
  margin:0 auto 10px !important;
  text-align:center !important;
}
.oa-chip{
  display:none !important;
}
.oa-cover-meta .oa-title{
  margin:0 0 4px !important;
  font-size:18px !important;
  line-height:1.22 !important;
  font-weight:700 !important;
  text-align:center !important;
  color:#fff !important;
}
.oa-cover-meta .oa-subtitle{
  margin:0 !important;
  justify-content:center !important;
  gap:6px !important;
  font-size:12px !important;
  line-height:1.4 !important;
  color:rgba(255,255,255,.82) !important;
}
.oa-cover-meta .oa-sep{
  opacity:.6 !important;
}

.oa-lyrics-panel{
  width:100% !important;
  max-width:760px !important;
  margin:0 auto 12px !important;
  padding:10px 0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}
.oa-lyrics-panel .oa-panel-head{
  display:none !important;
}
.oa-lyrics{
  min-height:auto !important;
  height:190px !important;
  max-height:190px !important;
  overflow:hidden !important;
  padding:10px 0 !important;
  background:transparent !important;
  text-align:center !important;
}
.oa-lyric-line{
  height:34px !important;
  line-height:34px !important;
  padding:0 !important;
  margin:0 !important;
  font-size:18px !important;
  font-weight:700 !important;
  color:rgba(255,255,255,.3) !important;
}
.oa-lyric-line.is-active{
  height:34px !important;
  line-height:34px !important;
  font-size:22px !important;
  font-weight:800 !important;
  color:#fff !important;
}

.oa-player-main{
  width:100% !important;
  max-width:760px !important;
  margin:0 auto 18px !important;
  display:block !important;
}
.oa-player-main .oa-cover-wrap,
.oa-player-main .oa-track-meta{
  display:none !important;
}
.oa-player-main .oa-info{
  width:100% !important;
  max-width:none !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  text-align:center !important;
  gap:16px !important;
}

.oa-progress-row{
  width:100% !important;
  max-width:620px !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:54px 1fr 54px !important;
  gap:10px !important;
  align-items:center !important;
}
.oa-current-time,
.oa-duration{
  font-size:12px !important;
  font-weight:700 !important;
  color:#fff !important;
  opacity:1 !important;
}
.oa-progress{
  height:6px !important;
  border-radius:999px !important;
  background:linear-gradient(90deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.96) 48%, rgba(255,255,255,.34) 100%) !important;
}
.oa-progress::-webkit-slider-thumb,
.oa-progress::-moz-range-thumb{
  width:14px !important;
  height:14px !important;
  border:0 !important;
  background:#fff !important;
  box-shadow:none !important;
}

.oa-controls{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:22px !important;
  margin:0 !important;
}
.oa-prev,
.oa-next{
  width:46px !important;
  height:46px !important;
  min-width:46px !important;
  padding:0 !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.96) !important;
  border:0 !important;
  color:rgba(191,116,95,.96) !important;
  font-size:17px !important;
  box-shadow:none !important;
}
.oa-btn-primary{
  width:64px !important;
  height:64px !important;
  min-width:64px !important;
  padding:0 !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.96) !important;
  border:0 !important;
  color:rgba(191,116,95,.96) !important;
  font-size:30px !important;
  box-shadow:none !important;
}
.oa-prev:hover,
.oa-next:hover,
.oa-btn-primary:hover{
  background:#fff !important;
  color:rgba(191,116,95,.96) !important;
}
.oa-loop{
  display:none !important;
}

/* keep playlist collapse behavior and remove active highlight */
.oa-playlist-item.is-active{
  background:transparent !important;
  border-radius:0 !important;
}
.oa-playlist-item.is-active .oa-playlist-index,
.oa-playlist-item.is-active .oa-playlist-name{
  color:inherit !important;
}

@media (max-width:640px){
  .oa-cover-hero{
    margin-bottom:12px !important;
  }
  .oa-cover-hero .oa-cover-wrap{
    width:220px !important;
    max-width:74vw !important;
  }
  .oa-cover-meta{
    margin-bottom:8px !important;
  }
  .oa-cover-meta .oa-title{
    font-size:16px !important;
  }
  .oa-cover-meta .oa-subtitle{
    font-size:11px !important;
  }
  .oa-lyrics-panel{
    margin-bottom:10px !important;
    padding:8px 0 !important;
  }
  .oa-lyrics{
    height:170px !important;
    max-height:170px !important;
    padding:10px 0 !important;
  }
  .oa-lyric-line{
    height:30px !important;
    line-height:30px !important;
    font-size:16px !important;
  }
  .oa-lyric-line.is-active{
    height:30px !important;
    line-height:30px !important;
    font-size:20px !important;
  }
  .oa-progress-row{
    grid-template-columns:48px 1fr 48px !important;
    gap:8px !important;
  }
  .oa-controls{
    gap:18px !important;
  }
  .oa-prev,
  .oa-next{
    width:42px !important;
    height:42px !important;
    min-width:42px !important;
    font-size:16px !important;
  }
  .oa-btn-primary{
    width:58px !important;
    height:58px !important;
    min-width:58px !important;
    font-size:28px !important;
  }
}


/* v1.3.0 fixed middle lyrics + text control buttons */
.oa-lyrics{
  height: 210px !important;
  max-height: 210px !important;
  overflow: hidden !important;
  padding: 20px 0 !important;
  scroll-behavior: smooth !important;
}
.oa-lyric-line{
  height: 34px !important;
  line-height: 34px !important;
  margin: 0 !important;
}
.oa-lyric-line.is-active{
  height: 34px !important;
  line-height: 34px !important;
}

.oa-controls{
  gap: 12px !important;
}
.oa-prev,
.oa-next,
.oa-btn-primary{
  width: auto !important;
  min-width: 72px !important;
  height: 38px !important;
  padding: 0 14px !important;
  border-radius: 8px !important;
  background: rgba(255,255,255,.12) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  box-shadow: none !important;
}
.oa-btn-primary{
  min-width: 78px !important;
  background: rgba(255,255,255,.2) !important;
}
.oa-prev:hover,
.oa-next:hover,
.oa-btn-primary:hover{
  background: rgba(255,255,255,.18) !important;
  color: #fff !important;
}
.oa-loop{
  display: none !important;
}

@media (max-width:640px){
  .oa-lyrics{
    height: 186px !important;
    max-height: 186px !important;
    padding: 18px 0 !important;
  }
  .oa-lyric-line{
    height: 30px !important;
    line-height: 30px !important;
  }
  .oa-lyric-line.is-active{
    height: 30px !important;
    line-height: 30px !important;
  }
  .oa-controls{
    gap: 10px !important;
    flex-wrap: wrap !important;
  }
  .oa-prev,
  .oa-next,
  .oa-btn-primary{
    min-width: 64px !important;
    height: 36px !important;
    padding: 0 12px !important;
    font-size: 13px !important;
  }
  .oa-btn-primary{
    min-width: 70px !important;
  }
}


/* v1.3.1 remove forced centered active lyric */
.oa-lyrics{
  scroll-behavior: auto !important;
}


/* v1.3.2 add loop + album list buttons, hide album list by default */
.oa-controls{
  flex-wrap: wrap !important;
}
.oa-loop,
.oa-album-list-toggle{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  min-width: 92px !important;
  height: 38px !important;
  padding: 0 14px !important;
  border-radius: 8px !important;
  background: rgba(255,255,255,.12) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  box-shadow: none !important;
  margin: 0 !important;
}
.oa-loop:hover,
.oa-album-list-toggle:hover{
  background: rgba(255,255,255,.18) !important;
  color: #fff !important;
}
.oa-playlist-panel.is-collapsed .oa-playlist,
.oa-playlist-panel.is-collapsed .oa-playlist-toggle{
  display: none !important;
}
.oa-playlist-panel.is-collapsed{
  display: none !important;
}
@media (max-width:640px){
  .oa-loop,
  .oa-album-list-toggle{
    min-width: 82px !important;
    height: 36px !important;
    padding: 0 12px !important;
    font-size: 12px !important;
  }
}


/* v1.3.3 refine loop button text, playlist items, remove expand more */
.oa-playlist-item.is-active{
  background: transparent !important;
  border-radius: 0 !important;
}
.oa-playlist-item.is-active .oa-playlist-index,
.oa-playlist-item.is-active .oa-playlist-name{
  color: inherit !important;
}
.oa-playlist-item::after{
  display: none !important;
  content: none !important;
}
.oa-playlist-item{
  grid-template-columns: 52px minmax(0,1fr) !important;
  gap: 0 !important;
  padding: 0 2px !important;
}
.oa-playlist-index{
  justify-content: flex-start !important;
  padding-left: 8px !important;
  font-size: 13px !important;
  opacity: .55 !important;
}
.oa-playlist-main{
  padding: 12px 6px 12px 0 !important;
}
.oa-playlist-name{
  font-size: 14px !important;
  font-weight: 700 !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.oa-playlist-meta,
.oa-playlist-dot,
.oa-playlist-artist,
.oa-playlist-album,
.oa-playlist-toggle{
  display: none !important;
}
.oa-playlist-panel.is-collapsed{
  display: none !important;
}
@media (max-width:640px){
  .oa-playlist-item{
    grid-template-columns: 42px minmax(0,1fr) !important;
  }
  .oa-playlist-index{
    padding-left: 4px !important;
    font-size: 12px !important;
  }
  .oa-playlist-name{
    font-size: 13px !important;
  }
}


/* v1.3.4 loop text cleanup + restore lyric auto scroll */
.oa-loop::before{
  content:none !important;
}
.oa-lyrics{
  overflow-y:auto !important;
  overflow-x:hidden !important;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.oa-lyrics::-webkit-scrollbar{
  display:none;
}


/* v1.3.5 revert lyrics auto-scroll to previously working behavior */
.oa-lyrics{
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scroll-behavior: smooth !important;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.oa-lyrics::-webkit-scrollbar{
  display: none;
}


/* v1.3.6 remove loop button, default shuffle */
.oa-loop{
  display: none !important;
}


/* v1.3.9 autoplay + click cover to toggle play */
.oa-cover,
.oa-cover-hero{
  cursor: pointer;
}


/* v1.4.1 only lyrics box scrolls, not whole page */
.oa-lyrics{
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.oa-lyrics::-webkit-scrollbar{
  display: none;
}


/* v1.4.4 remove cover click pause/play */
.oa-cover,
.oa-cover-hero{
  cursor: default !important;
}


/* v1.4.7 subtle breathing glow on cover while playing */
.oa-cover-wrap{
  position: relative;
}
.oa-cover{
  transition: transform .32s ease, box-shadow .32s ease, filter .32s ease;
}
.oa-player.is-playing .oa-cover{
  animation: oaCoverBreath 2.8s ease-in-out infinite;
}
@keyframes oaCoverBreath{
  0%,100%{
    transform: translateY(0) scale(1);
    box-shadow:
      0 14px 28px rgba(0,0,0,.20),
      0 0 0 0 rgba(255,255,255,.05),
      0 0 0 0 rgba(255,255,255,0);
    filter: brightness(1) saturate(1);
  }
  50%{
    transform: translateY(-1px) scale(1.015);
    box-shadow:
      0 18px 34px rgba(0,0,0,.24),
      0 0 0 5px rgba(255,255,255,.045),
      0 0 26px rgba(255,255,255,.08);
    filter: brightness(1.02) saturate(1.02);
  }
}


/* v1.4.9 front-end redesign: dark vinyl glass album page */
.oa-player{
  --oa-gold: rgba(248,224,188,.82);
  max-width: 980px !important;
  margin: 38px auto !important;
  padding: 42px 52px 44px !important;
  border-radius: 34px !important;
  color: #f7f1e7 !important;
  overflow: hidden !important;
  position: relative !important;
  background:
    radial-gradient(circle at 50% 7%, rgba(255,240,206,.24), transparent 28%),
    radial-gradient(circle at 12% 22%, rgba(255,255,255,.08), transparent 24%),
    radial-gradient(circle at 92% 24%, rgba(255,255,255,.09), transparent 22%),
    linear-gradient(145deg, rgba(45,43,37,.72), rgba(12,13,13,.94) 54%, rgba(22,21,18,.88)) !important;
  border: 1px solid rgba(255,240,210,.2) !important;
  box-shadow: 0 35px 90px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.08) !important;
  backdrop-filter: blur(16px) saturate(1.05);
  -webkit-backdrop-filter: blur(16px) saturate(1.05);
}
.oa-player::before{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:62px !important;
  width:520px !important;
  height:520px !important;
  transform:translateX(-50%) !important;
  border-radius:50% !important;
  background:
    repeating-radial-gradient(circle, rgba(255,255,255,.055) 0 1px, transparent 1px 13px),
    radial-gradient(circle at 28% 46%, rgba(255,255,255,.22), transparent 10%),
    radial-gradient(circle at 72% 46%, rgba(255,255,255,.20), transparent 10%),
    radial-gradient(circle, rgba(255,255,255,.05), rgba(0,0,0,.18) 58%, transparent 60%);
  opacity:.55 !important;
  pointer-events:none !important;
}
.oa-player::after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  border-radius:34px !important;
  background: linear-gradient(110deg, rgba(255,255,255,.07), transparent 35%, rgba(255,255,255,.045) 64%, transparent 88%) !important;
  pointer-events:none !important;
  opacity:.85 !important;
}
.oa-player-inner,
.oa-cover-hero,
.oa-cover-meta,
.oa-lyrics-panel,
.oa-player-main,
.oa-body{
  position: relative !important;
  z-index: 2 !important;
}

/* cover */
.oa-cover-hero{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  margin:0 0 20px !important;
}
.oa-cover-hero .oa-cover-wrap{
  width:360px !important;
  max-width:72vw !important;
  margin:0 auto !important;
  position:relative !important;
}
.oa-cover-hero .oa-cover-wrap::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:25px;
  border:1px solid rgba(255,232,190,.48);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
  pointer-events:none;
}
.oa-cover-hero .oa-cover{
  width:100% !important;
  display:block !important;
  border-radius:25px !important;
  border:0 !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.08) !important;
  background:rgba(255,255,255,.05) !important;
}

/* title block */
.oa-cover-meta{
  max-width:760px !important;
  margin:0 auto 22px !important;
  text-align:center !important;
}
.oa-chip{display:none !important}
.oa-title{
  position:relative !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:34px !important;
  margin:0 0 8px !important;
  font-size:28px !important;
  line-height:1.2 !important;
  font-weight:800 !important;
  letter-spacing:.03em !important;
  color:#fff8ee !important;
  text-shadow: 0 0 18px rgba(255,232,190,.28) !important;
}
.oa-title::before,
.oa-title::after{
  content:"";
  display:block;
  width:44px;
  height:28px;
  opacity:.45;
  background:
    linear-gradient(to top, currentColor 0 100%) 0 50%/3px 32% no-repeat,
    linear-gradient(to top, currentColor 0 100%) 9px 50%/3px 58% no-repeat,
    linear-gradient(to top, currentColor 0 100%) 18px 50%/3px 88% no-repeat,
    linear-gradient(to top, currentColor 0 100%) 27px 50%/3px 62% no-repeat,
    linear-gradient(to top, currentColor 0 100%) 36px 50%/3px 36% no-repeat;
  color:rgba(255,255,255,.76);
}
.oa-subtitle{
  justify-content:center !important;
  margin:0 !important;
  font-size:16px !important;
  line-height:1.55 !important;
  color:rgba(246,238,225,.66) !important;
  gap:10px !important;
}

/* lyrics */
.oa-lyrics-panel{
  max-width:620px !important;
  margin:0 auto 22px !important;
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}
.oa-lyrics-panel .oa-panel-head{display:none !important}
.oa-lyrics{
  height:220px !important;
  max-height:220px !important;
  min-height:220px !important;
  padding:8px 0 !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  text-align:center !important;
  scrollbar-width:none !important;
  -ms-overflow-style:none !important;
  mask-image: linear-gradient(to bottom, transparent, #000 16%, #000 84%, transparent);
  -webkit-mask-image: linear-gradient(to bottom, transparent, #000 16%, #000 84%, transparent);
}
.oa-lyrics::-webkit-scrollbar{display:none !important}
.oa-lyric-line{
  height:34px !important;
  line-height:34px !important;
  padding:0 !important;
  margin:0 !important;
  font-size:20px !important;
  font-weight:650 !important;
  letter-spacing:.02em !important;
  color:rgba(245,238,225,.32) !important;
  text-shadow:none !important;
  transition: color .25s ease, font-size .25s ease, text-shadow .25s ease, opacity .25s ease !important;
}
.oa-lyric-line.is-active{
  font-size:29px !important;
  font-weight:850 !important;
  color:#fff8ee !important;
  text-shadow: 0 0 18px rgba(255,232,190,.38), 0 1px 0 rgba(0,0,0,.22) !important;
}

/* progress and controls */
.oa-player-main{
  max-width:740px !important;
  margin:0 auto 18px !important;
  display:block !important;
}
.oa-player-main .oa-info{
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  gap:22px !important;
  width:100% !important;
}
.oa-progress-row{
  width:100% !important;
  max-width:700px !important;
  display:grid !important;
  grid-template-columns:64px 1fr 64px !important;
  gap:16px !important;
  align-items:center !important;
  margin:0 !important;
}
.oa-current-time,
.oa-duration{
  color:rgba(255,250,242,.88) !important;
  font-size:17px !important;
  font-weight:500 !important;
  font-variant-numeric:tabular-nums !important;
  opacity:1 !important;
}
.oa-progress{
  height:6px !important;
  border-radius:999px !important;
  background:linear-gradient(90deg, rgba(255,233,191,.96) 0%, rgba(255,255,255,.5) 36%, rgba(255,255,255,.18) 100%) !important;
  box-shadow:0 0 16px rgba(255,229,187,.18) !important;
}
.oa-progress::-webkit-slider-thumb{
  -webkit-appearance:none !important;
  appearance:none !important;
  width:26px !important;
  height:26px !important;
  border-radius:50% !important;
  background:#fff !important;
  border:0 !important;
  box-shadow:0 0 0 4px rgba(255,255,255,.12), 0 0 24px rgba(255,238,207,.55) !important;
}
.oa-progress::-moz-range-thumb{
  width:26px !important;
  height:26px !important;
  border-radius:50% !important;
  background:#fff !important;
  border:0 !important;
  box-shadow:0 0 0 4px rgba(255,255,255,.12), 0 0 24px rgba(255,238,207,.55) !important;
}
.oa-controls{
  display:grid !important;
  grid-template-columns:180px 92px 180px 190px !important;
  gap:22px !important;
  justify-content:center !important;
  align-items:center !important;
  margin:0 !important;
  width:100% !important;
}
.oa-btn{
  height:58px !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.12) !important;
  background:rgba(255,255,255,.055) !important;
  color:rgba(255,250,242,.9) !important;
  font-size:18px !important;
  font-weight:650 !important;
  letter-spacing:.02em !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 10px 30px rgba(0,0,0,.22) !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:12px !important;
  padding:0 24px !important;
  transition: transform .18s ease, background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease !important;
}
.oa-btn:hover{
  transform:translateY(-1px) !important;
  background:rgba(255,255,255,.09) !important;
  border-color:rgba(255,255,255,.22) !important;
  color:#fff !important;
}
.oa-btn-primary{
  width:92px !important;
  min-width:92px !important;
  height:92px !important;
  padding:0 !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.94) !important;
  color:#191817 !important;
  font-size:42px !important;
  line-height:1 !important;
  box-shadow: 0 0 40px rgba(255,238,210,.42), 0 18px 48px rgba(0,0,0,.35) !important;
}
.oa-btn-primary:hover{
  background:#fff !important;
  color:#151515 !important;
  transform:translateY(-1px) scale(1.015) !important;
}
.oa-btn-icon{
  font-size:.9em;
  opacity:.9;
}

/* playlist opened state */
.oa-body{
  max-width:740px !important;
  margin:0 auto !important;
}
.oa-playlist-panel{
  border:1px solid rgba(255,255,255,.1) !important;
  background:rgba(255,255,255,.045) !important;
  border-radius:20px !important;
  padding:14px 18px !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04) !important;
}
.oa-playlist-panel.is-collapsed{
  display:none !important;
}
.oa-playlist-title{
  color:rgba(255,250,242,.78) !important;
  font-size:14px !important;
}
.oa-playlist-item{
  grid-template-columns:48px minmax(0,1fr) !important;
  border-top:1px solid rgba(255,255,255,.08) !important;
  color:rgba(255,250,242,.82) !important;
}
.oa-playlist-item::after{display:none !important}
.oa-playlist-meta{display:none !important}
.oa-playlist-item.is-active{
  background:transparent !important;
}
.oa-playlist-item.is-active .oa-playlist-name,
.oa-playlist-item.is-active .oa-playlist-index{
  color:#fff8ee !important;
  font-weight:800 !important;
}

/* cover play effect refined for this theme */
.oa-player.is-playing .oa-cover{
  animation: oaCoverBreath 3.2s ease-in-out infinite !important;
}
@keyframes oaCoverBreath{
  0%,100%{
    transform:scale(1);
    box-shadow:0 24px 70px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.08);
    filter:brightness(1);
  }
  50%{
    transform:scale(1.012);
    box-shadow:0 28px 78px rgba(0,0,0,.48), 0 0 0 1px rgba(255,232,190,.22), 0 0 34px rgba(255,229,187,.16);
    filter:brightness(1.018);
  }
}

/* mobile */
@media (max-width:760px){
  .oa-player{
    margin:24px auto !important;
    padding:26px 18px 30px !important;
    border-radius:26px !important;
  }
  .oa-player::before{
    width:340px !important;
    height:340px !important;
    top:48px !important;
  }
  .oa-cover-hero .oa-cover-wrap{
    width:240px !important;
    max-width:76vw !important;
  }
  .oa-title{
    font-size:22px !important;
    gap:16px !important;
  }
  .oa-title::before,
  .oa-title::after{
    width:26px !important;
    height:20px !important;
    background:
      linear-gradient(to top, currentColor 0 100%) 0 50%/2px 34% no-repeat,
      linear-gradient(to top, currentColor 0 100%) 6px 50%/2px 70% no-repeat,
      linear-gradient(to top, currentColor 0 100%) 12px 50%/2px 94% no-repeat,
      linear-gradient(to top, currentColor 0 100%) 18px 50%/2px 60% no-repeat,
      linear-gradient(to top, currentColor 0 100%) 24px 50%/2px 38% no-repeat;
  }
  .oa-subtitle{
    font-size:14px !important;
  }
  .oa-lyrics{
    height:190px !important;
    min-height:190px !important;
    max-height:190px !important;
  }
  .oa-lyric-line{
    height:30px !important;
    line-height:30px !important;
    font-size:17px !important;
  }
  .oa-lyric-line.is-active{
    font-size:22px !important;
  }
  .oa-progress-row{
    grid-template-columns:50px 1fr 50px !important;
    gap:10px !important;
  }
  .oa-current-time,
  .oa-duration{
    font-size:13px !important;
  }
  .oa-progress::-webkit-slider-thumb{
    width:22px !important;
    height:22px !important;
  }
  .oa-progress::-moz-range-thumb{
    width:22px !important;
    height:22px !important;
  }
  .oa-controls{
    grid-template-columns:1fr 74px 1fr !important;
    gap:12px !important;
  }
  .oa-album-list-toggle{
    grid-column:1 / -1 !important;
    width:100% !important;
  }
  .oa-btn{
    height:48px !important;
    font-size:15px !important;
    padding:0 14px !important;
  }
  .oa-btn-primary{
    width:74px !important;
    min-width:74px !important;
    height:74px !important;
    font-size:34px !important;
  }
}


/* v1.5.0 compact circular control buttons */
.oa-controls{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  gap:22px !important;
  width:100% !important;
  margin:0 auto !important;
}

.oa-btn{
  width:66px !important;
  min-width:66px !important;
  height:66px !important;
  padding:0 !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.14) !important;
  background:radial-gradient(circle at 50% 42%, rgba(255,255,255,.10), rgba(255,255,255,.035) 62%, rgba(0,0,0,.16) 100%) !important;
  color:rgba(255,250,242,.94) !important;
  font-size:27px !important;
  font-weight:700 !important;
  line-height:1 !important;
  letter-spacing:0 !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), inset 0 -18px 28px rgba(0,0,0,.12), 0 12px 30px rgba(0,0,0,.28) !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:0 !important;
  transition:transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease, color .18s ease !important;
}

.oa-btn:hover{
  transform:translateY(-1px) !important;
  background:radial-gradient(circle at 50% 42%, rgba(255,255,255,.16), rgba(255,255,255,.055) 62%, rgba(0,0,0,.12) 100%) !important;
  border-color:rgba(255,230,190,.28) !important;
  color:#fff !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12), inset 0 -18px 28px rgba(0,0,0,.10), 0 12px 32px rgba(0,0,0,.32), 0 0 20px rgba(255,229,187,.10) !important;
}

.oa-btn-primary{
  width:84px !important;
  min-width:84px !important;
  height:84px !important;
  border-radius:999px !important;
  background:radial-gradient(circle at 50% 42%, rgba(255,255,255,.98), rgba(255,255,255,.88) 58%, rgba(235,226,214,.80) 100%) !important;
  color:#171514 !important;
  font-size:39px !important;
  border:1px solid rgba(255,238,210,.72) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.86), 0 0 0 1px rgba(255,229,187,.18), 0 0 28px rgba(255,225,184,.36), 0 16px 42px rgba(0,0,0,.34) !important;
}

.oa-btn-primary:hover{
  transform:translateY(-1px) scale(1.012) !important;
  background:#fff !important;
  color:#111 !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.95), 0 0 0 1px rgba(255,229,187,.25), 0 0 36px rgba(255,225,184,.50), 0 18px 46px rgba(0,0,0,.38) !important;
}

.oa-album-list-toggle{font-size:30px !important;}
.oa-prev,.oa-next{font-size:26px !important;}

@media (max-width:760px){
  .oa-controls{gap:14px !important;}
  .oa-btn{
    width:54px !important;
    min-width:54px !important;
    height:54px !important;
    font-size:22px !important;
  }
  .oa-btn-primary{
    width:70px !important;
    min-width:70px !important;
    height:70px !important;
    font-size:32px !important;
  }
  .oa-album-list-toggle{
    grid-column:auto !important;
    width:54px !important;
    min-width:54px !important;
    font-size:25px !important;
  }
}


/* v1.5.2 clean title area and keep compact loop button */
.oa-title{
  gap:0 !important;
}
.oa-title::before,
.oa-title::after{
  display:none !important;
  content:none !important;
}
.oa-subtitle{
  justify-content:center !important;
  gap:0 !important;
}
.oa-subtitle .oa-artist,
.oa-subtitle .oa-sep{
  display:none !important;
}
.oa-subtitle .oa-album{
  display:inline !important;
}
.oa-loop{
  display:inline-flex !important;
  font-size:30px !important;
}
.oa-controls{
  gap:20px !important;
}
@media (max-width:760px){
  .oa-controls{
    gap:10px !important;
  }
  .oa-loop{
    width:54px !important;
    min-width:54px !important;
    height:54px !important;
    font-size:24px !important;
  }
}


/* v1.5.3 refined aligned SVG icon buttons */
.oa-controls{
  gap:18px !important;
}

.oa-btn{
  position:relative !important;
  width:64px !important;
  min-width:64px !important;
  height:64px !important;
  padding:0 !important;
  border-radius:999px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:0 !important;
  font-size:0 !important;
}

.oa-btn svg{
  width:27px !important;
  height:27px !important;
  display:block !important;
  overflow:visible !important;
  fill:none !important;
  stroke:currentColor !important;
  stroke-width:2.2 !important;
  stroke-linecap:round !important;
  stroke-linejoin:round !important;
  color:rgba(255,250,242,.95) !important;
  filter:drop-shadow(0 0 5px rgba(255,255,255,.22));
}

.oa-btn svg path{
  vector-effect: non-scaling-stroke;
}

.oa-btn-primary{
  width:86px !important;
  min-width:86px !important;
  height:86px !important;
}

.oa-btn-primary svg{
  width:38px !important;
  height:38px !important;
  color:#171514 !important;
  stroke-width:2.4 !important;
  filter:none !important;
}

.oa-btn-primary .oa-icon-pause{
  display:none !important;
}
.oa-btn-primary.is-paused-icon .oa-icon-play{
  display:none !important;
}
.oa-btn-primary.is-paused-icon .oa-icon-pause{
  display:block !important;
}

/* loop button mode icons using clean SVG-like CSS fallback */
.oa-loop[data-mode="shuffle"] svg,
.oa-loop[data-mode="single"] svg{
  display:none !important;
}
.oa-loop[data-mode="shuffle"]::before,
.oa-loop[data-mode="single"]::before{
  font-size:25px !important;
  line-height:1 !important;
  color:rgba(255,250,242,.95) !important;
  filter:drop-shadow(0 0 5px rgba(255,255,255,.20));
}
.oa-loop[data-mode="shuffle"]::before{
  content:"⤨";
}
.oa-loop[data-mode="single"]::before{
  content:"①";
}

/* optical alignment */
.oa-prev svg{
  transform:translateX(-1px);
}
.oa-next svg{
  transform:translateX(1px);
}
.oa-album-list-toggle svg{
  width:29px !important;
  height:29px !important;
}

@media (max-width:760px){
  .oa-controls{
    gap:10px !important;
  }
  .oa-btn{
    width:54px !important;
    min-width:54px !important;
    height:54px !important;
  }
  .oa-btn svg{
    width:23px !important;
    height:23px !important;
  }
  .oa-btn-primary{
    width:70px !important;
    min-width:70px !important;
    height:70px !important;
  }
  .oa-btn-primary svg{
    width:32px !important;
    height:32px !important;
  }
  .oa-album-list-toggle{
    width:54px !important;
    min-width:54px !important;
  }
}


/* v1.5.4 loop mode as small text label */
.oa-loop{
  font-size:0 !important;
}
.oa-loop svg,
.oa-loop::before{
  display:none !important;
  content:none !important;
}
.oa-loop .oa-loop-label{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:14px !important;
  line-height:1 !important;
  font-weight:750 !important;
  letter-spacing:.04em !important;
  color:rgba(255,250,242,.94) !important;
  white-space:nowrap !important;
  transform:translateY(0);
}
.oa-loop[data-mode="shuffle"] .oa-loop-label{
  letter-spacing:.08em !important;
}
.oa-loop[data-mode="single"] .oa-loop-label{
  letter-spacing:.08em !important;
}
@media (max-width:760px){
  .oa-loop .oa-loop-label{
    font-size:12px !important;
  }
}


/* v1.5.5 ensure default loop label is visible */
.oa-loop[data-mode="list"] .oa-loop-label:empty::before{
  content:"顺序";
}
.oa-loop:not([data-mode]) .oa-loop-label:empty::before{
  content:"顺序";
}


/* v1.5.6 mobile control order fix */
.oa-loop{ order:1 !important; }
.oa-prev{ order:2 !important; }
.oa-play{ order:3 !important; }
.oa-next{ order:4 !important; }
.oa-album-list-toggle{ order:5 !important; }

@media (max-width:760px){
  .oa-controls{
    display:flex !important;
    flex-direction:row !important;
    flex-wrap:nowrap !important;
    justify-content:center !important;
    align-items:center !important;
  }
  .oa-loop{
    order:1 !important;
  }
  .oa-prev{
    order:2 !important;
  }
  .oa-play{
    order:3 !important;
  }
  .oa-next{
    order:4 !important;
  }
  .oa-album-list-toggle{
    order:5 !important;
    grid-column:auto !important;
  }
}


/* v1.5.8 safe loop label display */
.oa-loop{
  font-size:0 !important;
}
.oa-loop::before,
.oa-loop::after,
.oa-loop svg{
  display:none !important;
  content:none !important;
}
.oa-loop .oa-loop-label{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-width:2.1em !important;
  font-size:14px !important;
  line-height:1 !important;
  font-weight:750 !important;
  letter-spacing:.04em !important;
  color:rgba(255,250,242,.96) !important;
  white-space:nowrap !important;
}
@media (max-width:760px){
  .oa-loop .oa-loop-label{
    font-size:12px !important;
  }
}


/* v1.5.11 lyrics area: show 4 lines, reduce vertical space */
.oa-lyrics{
  height: 152px !important;
  min-height: 152px !important;
  max-height: 152px !important;
  padding: 8px 0 !important;
}
.oa-lyric-line{
  height: 34px !important;
  line-height: 34px !important;
}
.oa-lyric-line.is-active{
  height: 34px !important;
  line-height: 34px !important;
}

@media (max-width:760px){
  .oa-lyrics{
    height: 128px !important;
    min-height: 128px !important;
    max-height: 128px !important;
    padding: 6px 0 !important;
  }
  .oa-lyric-line{
    height: 29px !important;
    line-height: 29px !important;
  }
  .oa-lyric-line.is-active{
    height: 29px !important;
    line-height: 29px !important;
  }
}


/* v1.5.12 album wall shortcode */
.oa-album-wall{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));
  gap:22px;
  margin:30px auto;
  max-width:1100px;
}

.oa-album-card{
  min-width:0;
}

.oa-album-cover-btn{
  width:100%;
  appearance:none;
  border:1px solid rgba(255,255,255,.1);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.025));
  color:#fff;
  border-radius:22px;
  padding:14px;
  text-align:left;
  cursor:pointer;
  box-shadow:0 16px 42px rgba(0,0,0,.24);
  transition:transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.oa-album-cover-btn:hover,
.oa-album-card.is-open .oa-album-cover-btn{
  transform:translateY(-2px);
  border-color:rgba(255,232,190,.32);
  background:linear-gradient(180deg, rgba(255,255,255,.095), rgba(255,255,255,.04));
  box-shadow:0 20px 52px rgba(0,0,0,.32), 0 0 28px rgba(255,230,190,.08);
}

.oa-album-cover-wrap{
  display:block;
  position:relative;
  overflow:hidden;
  border-radius:18px;
  aspect-ratio:1/1;
  background:rgba(255,255,255,.06);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}

.oa-album-cover-img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  transition:transform .35s ease, filter .35s ease;
}

.oa-album-cover-btn:hover .oa-album-cover-img,
.oa-album-card.is-open .oa-album-cover-img{
  transform:scale(1.035);
  filter:brightness(1.04) saturate(1.04);
}

.oa-album-cover-placeholder{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:42px;
  font-weight:800;
  color:rgba(255,255,255,.82);
  background:radial-gradient(circle at 35% 25%, rgba(255,235,190,.2), transparent 40%), rgba(255,255,255,.06);
}

.oa-album-card-title{
  display:block;
  margin-top:12px;
  font-size:15px;
  line-height:1.35;
  font-weight:800;
  color:#fff8ee;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.oa-album-card-subtitle,
.oa-album-card-count{
  display:block;
  margin-top:3px;
  font-size:12px;
  line-height:1.35;
  color:rgba(255,248,238,.58);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.oa-album-song-panel{
  grid-column:1 / -1;
  margin-top:12px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.045);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  padding:14px;
  color:#fff;
}

.oa-album-song-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:0 2px 10px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.oa-album-song-head strong{
  color:#fff8ee;
  font-size:15px;
}

.oa-album-song-head span{
  color:rgba(255,248,238,.56);
  font-size:12px;
}

.oa-album-song-list{
  list-style:none;
  margin:0;
  padding:6px 0 0;
  max-height:360px;
  overflow:auto;
}

.oa-album-song-list li{
  display:grid;
  grid-template-columns:42px minmax(0,1fr);
  gap:8px;
  align-items:center;
  padding:10px 2px;
  border-top:1px solid rgba(255,255,255,.055);
}

.oa-album-song-list li:first-child{
  border-top:0;
}

.oa-album-song-index{
  color:rgba(255,248,238,.4);
  font-variant-numeric:tabular-nums;
  font-size:12px;
}

.oa-album-song-name{
  color:rgba(255,248,238,.86);
  font-size:14px;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
}

.oa-album-song-actions{
  display:none;
}

.oa-album-wall-empty{
  padding:18px;
  border-radius:14px;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.75);
}

@media (min-width:760px){
  .oa-album-card.is-open{
    display:contents;
  }
  .oa-album-card.is-open .oa-album-cover-btn{
    grid-column:auto;
  }
  .oa-album-card.is-open .oa-album-song-panel{
    display:block;
  }
}

@media (max-width:760px){
  .oa-album-wall{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:14px;
    margin:22px auto;
  }

  .oa-album-cover-btn{
    border-radius:18px;
    padding:10px;
  }

  .oa-album-cover-wrap{
    border-radius:14px;
  }

  .oa-album-card-title{
    font-size:13px;
    margin-top:9px;
  }

  .oa-album-card-subtitle,
  .oa-album-card-count{
    font-size:11px;
  }

  .oa-album-card.is-open{
    grid-column:1 / -1;
  }

  .oa-album-card.is-open .oa-album-cover-btn{
    display:grid;
    grid-template-columns:92px minmax(0,1fr);
    gap:12px;
    align-items:center;
  }

  .oa-album-card.is-open .oa-album-cover-wrap{
    width:92px;
  }

  .oa-album-card.is-open .oa-album-card-title,
  .oa-album-card.is-open .oa-album-card-subtitle,
  .oa-album-card.is-open .oa-album-card-count{
    grid-column:2;
    margin-top:0;
  }

  .oa-album-song-panel{
    padding:12px;
  }

  .oa-album-song-list{
    max-height:320px;
  }
}


/* v1.5.13 album wall playable bottom/full player */
.oa-album-song-head{
  grid-template-columns:minmax(0,1fr) auto auto;
}

.oa-album-play-all{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.10);
  color:#fff8ee;
  border-radius:999px;
  padding:7px 12px;
  font-size:12px;
  font-weight:750;
  cursor:pointer;
}

.oa-album-song-list li{
  grid-template-columns:42px minmax(0,1fr) auto !important;
}

.oa-album-song-play{
  appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.08);
  color:#fff8ee;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:750;
  cursor:pointer;
}

body.oa-has-wall-player{
  padding-bottom:92px !important;
}

.oa-wall-player{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:99999;
  color:#fff;
  background:
    radial-gradient(circle at 16% 0%, rgba(255,232,190,.12), transparent 34%),
    linear-gradient(180deg, rgba(20,20,20,.92), rgba(8,8,8,.97));
  border-top:1px solid rgba(255,255,255,.12);
  box-shadow:0 -20px 70px rgba(0,0,0,.5);
  backdrop-filter:blur(18px) saturate(1.08);
  -webkit-backdrop-filter:blur(18px) saturate(1.08);
}

.oa-wall-player.is-hidden{
  display:none;
}

.oa-wall-mini{
  max-width:1120px;
  margin:0 auto;
  padding:10px 16px calc(10px + env(safe-area-inset-bottom));
  display:grid;
  grid-template-columns:54px minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  cursor:pointer;
}

.oa-wall-mini-cover{
  width:54px;
  height:54px;
  border-radius:12px;
  object-fit:cover;
  background:rgba(255,255,255,.06);
}

.oa-wall-mini-title{
  font-size:15px;
  font-weight:850;
  color:#fff8ee;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.oa-wall-mini-subtitle{
  margin-top:3px;
  font-size:12px;
  color:rgba(255,248,238,.62);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.oa-wall-mini-actions{
  display:flex;
  gap:8px;
  align-items:center;
}

.oa-wall-mini-actions button,
.oa-wall-full-controls button,
.oa-wall-full-close{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.075);
  color:#fff8ee;
  border-radius:999px;
  min-width:40px;
  height:40px;
  padding:0 13px;
  font-size:13px;
  font-weight:760;
  cursor:pointer;
}

.oa-wall-mini-play,
.oa-wall-play{
  background:#fff !important;
  color:#111 !important;
  box-shadow:0 0 28px rgba(255,230,190,.28);
}

.oa-wall-full{
  display:none;
}

.oa-wall-player.is-expanded{
  top:0;
  overflow:auto;
}

.oa-wall-player.is-expanded .oa-wall-mini{
  display:none;
}

.oa-wall-player.is-expanded .oa-wall-full{
  min-height:100vh;
  padding:34px 22px calc(36px + env(safe-area-inset-bottom));
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:18px;
  max-width:760px;
  margin:0 auto;
}

.oa-wall-full-close{
  position:fixed;
  top:18px;
  right:18px;
  z-index:2;
  background:rgba(255,255,255,.10);
}

.oa-wall-full-cover-wrap{
  width:min(340px, 72vw);
  aspect-ratio:1/1;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 26px 76px rgba(0,0,0,.48), 0 0 0 1px rgba(255,232,190,.18);
}

.oa-wall-full-cover{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.oa-wall-full-info{
  text-align:center;
}

.oa-wall-full-title{
  margin:0;
  font-size:26px;
  line-height:1.2;
  color:#fff8ee;
}

.oa-wall-full-subtitle{
  margin-top:8px;
  font-size:14px;
  color:rgba(255,248,238,.62);
}

.oa-wall-full-lyrics{
  width:100%;
  height:150px;
  max-height:150px;
  overflow:auto;
  text-align:center;
  padding:8px 0;
  scrollbar-width:none;
  -ms-overflow-style:none;
  mask-image:linear-gradient(to bottom, transparent, #000 16%, #000 84%, transparent);
  -webkit-mask-image:linear-gradient(to bottom, transparent, #000 16%, #000 84%, transparent);
}

.oa-wall-full-lyrics::-webkit-scrollbar{
  display:none;
}

.oa-wall-lyric-line{
  height:34px;
  line-height:34px;
  font-size:18px;
  font-weight:650;
  color:rgba(255,248,238,.36);
  transition:.22s;
}

.oa-wall-lyric-line.is-active{
  font-size:24px;
  font-weight:850;
  color:#fff8ee;
  text-shadow:0 0 18px rgba(255,232,190,.28);
}

.oa-wall-full-progress{
  width:100%;
  display:grid;
  grid-template-columns:52px 1fr 52px;
  gap:12px;
  align-items:center;
  color:rgba(255,248,238,.72);
  font-size:12px;
  font-variant-numeric:tabular-nums;
}

.oa-wall-range{
  width:100%;
  height:6px;
  border-radius:999px;
}

.oa-wall-full-controls{
  display:flex;
  justify-content:center;
  gap:14px;
}

.oa-wall-full-controls button{
  min-width:86px;
}

@media (max-width:760px){
  body.oa-has-wall-player{
    padding-bottom:78px !important;
  }

  .oa-wall-mini{
    padding:8px 10px calc(8px + env(safe-area-inset-bottom));
    grid-template-columns:44px minmax(0,1fr) auto;
  }

  .oa-wall-mini-cover{
    width:44px;
    height:44px;
    border-radius:10px;
  }

  .oa-wall-mini-title{
    font-size:14px;
  }

  .oa-wall-mini-subtitle{
    font-size:11px;
  }

  .oa-wall-mini-actions{
    gap:6px;
  }

  .oa-wall-mini-actions button{
    min-width:34px;
    height:34px;
    padding:0 9px;
    font-size:12px;
  }

  .oa-wall-mini-prev,
  .oa-wall-mini-next{
    display:none;
  }

  .oa-wall-player.is-expanded .oa-wall-full{
    justify-content:flex-start;
    padding-top:58px;
  }

  .oa-wall-full-title{
    font-size:22px;
  }

  .oa-wall-full-cover-wrap{
    width:min(260px, 72vw);
    border-radius:22px;
  }

  .oa-wall-full-lyrics{
    height:132px;
    max-height:132px;
  }

  .oa-wall-lyric-line{
    height:30px;
    line-height:30px;
    font-size:16px;
  }

  .oa-wall-lyric-line.is-active{
    font-size:21px;
  }
}


/* v1.5.14 album wall player: fixed bottom controls + responsive full view */
.oa-wall-player.is-expanded .oa-wall-full{
  min-height:100dvh !important;
  height:100dvh !important;
  max-width:820px !important;
  padding:58px 22px calc(116px + env(safe-area-inset-bottom)) !important;
  justify-content:flex-start !important;
  overflow:hidden !important;
}

.oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
  width:min(300px, 56vh, 70vw) !important;
  flex:0 0 auto !important;
}

.oa-wall-full-info{
  flex:0 0 auto !important;
}

.oa-wall-full-title{
  font-size:clamp(20px, 3.4vw, 28px) !important;
}

.oa-wall-full-lyrics{
  flex:1 1 auto !important;
  min-height:112px !important;
  height:auto !important;
  max-height:none !important;
  width:100% !important;
  margin:0 auto !important;
  scroll-behavior:smooth !important;
}

.oa-wall-lyric-spacer{
  height:calc(50% - 17px);
}

.oa-wall-lyric-line{
  height:34px !important;
  line-height:34px !important;
}

.oa-wall-lyric-line.is-active{
  height:34px !important;
  line-height:34px !important;
}

.oa-wall-full-progress{
  position:fixed !important;
  left:50% !important;
  bottom:calc(76px + env(safe-area-inset-bottom)) !important;
  transform:translateX(-50%) !important;
  width:min(760px, calc(100vw - 36px)) !important;
  z-index:100002 !important;
}

.oa-wall-full-controls{
  position:fixed !important;
  left:50% !important;
  bottom:calc(18px + env(safe-area-inset-bottom)) !important;
  transform:translateX(-50%) !important;
  width:min(760px, calc(100vw - 36px)) !important;
  z-index:100002 !important;
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  gap:10px !important;
}

.oa-wall-full-controls button{
  min-width:0 !important;
  height:46px !important;
  padding:0 16px !important;
  white-space:nowrap !important;
}

.oa-wall-play{
  min-width:74px !important;
}

.oa-wall-loop{
  min-width:58px !important;
}

.oa-wall-list-toggle{
  min-width:76px !important;
}

.oa-wall-full-list{
  position:fixed !important;
  left:50% !important;
  bottom:calc(134px + env(safe-area-inset-bottom)) !important;
  transform:translateX(-50%) !important;
  width:min(760px, calc(100vw - 36px)) !important;
  max-height:min(42vh, 360px) !important;
  overflow:auto !important;
  z-index:100003 !important;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:rgba(10,10,10,.88);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  box-shadow:0 18px 50px rgba(0,0,0,.42);
}

.oa-wall-full-song-list{
  list-style:none;
  margin:0;
  padding:8px;
}

.oa-wall-full-song-list li{
  display:grid;
  grid-template-columns:42px minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  padding:10px 8px;
  border-radius:12px;
  color:rgba(255,248,238,.78);
}

.oa-wall-full-song-list li.is-active{
  background:rgba(255,255,255,.08);
  color:#fff8ee;
  font-weight:800;
}

.oa-wall-full-song-list li span{
  opacity:.55;
  font-variant-numeric:tabular-nums;
}

.oa-wall-full-song-list li b{
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
}

.oa-wall-full-song-list li button{
  appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.08);
  color:#fff8ee;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:760;
}

@media (max-width:760px){
  .oa-wall-player.is-expanded .oa-wall-full{
    padding:52px 14px calc(104px + env(safe-area-inset-bottom)) !important;
    gap:12px !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(220px, 38vh, 62vw) !important;
  }

  .oa-wall-full-title{
    font-size:21px !important;
  }

  .oa-wall-full-subtitle{
    font-size:12px !important;
    margin-top:5px !important;
  }

  .oa-wall-full-lyrics{
    min-height:96px !important;
  }

  .oa-wall-lyric-spacer{
    height:calc(50% - 15px);
  }

  .oa-wall-lyric-line{
    height:30px !important;
    line-height:30px !important;
    font-size:15px !important;
  }

  .oa-wall-lyric-line.is-active{
    height:30px !important;
    line-height:30px !important;
    font-size:20px !important;
  }

  .oa-wall-full-progress{
    bottom:calc(66px + env(safe-area-inset-bottom)) !important;
    width:calc(100vw - 24px) !important;
    grid-template-columns:42px 1fr 42px !important;
    gap:8px !important;
  }

  .oa-wall-full-controls{
    bottom:calc(12px + env(safe-area-inset-bottom)) !important;
    width:calc(100vw - 20px) !important;
    gap:6px !important;
  }

  .oa-wall-full-controls button{
    height:42px !important;
    padding:0 9px !important;
    font-size:12px !important;
  }

  .oa-wall-loop{
    min-width:46px !important;
  }

  .oa-wall-play{
    min-width:58px !important;
  }

  .oa-wall-list-toggle{
    min-width:58px !important;
  }

  .oa-wall-full-list{
    bottom:calc(120px + env(safe-area-inset-bottom)) !important;
    width:calc(100vw - 20px) !important;
    max-height:40vh !important;
  }
}


/* v1.5.16 control bar refined like reference image */
.oa-wall-full-progress{
  bottom:calc(106px + env(safe-area-inset-bottom)) !important;
  width:min(720px, calc(100vw - 42px)) !important;
  grid-template-columns:54px 1fr 54px !important;
  gap:18px !important;
  color:rgba(255,250,242,.92) !important;
  font-size:18px !important;
  font-weight:650 !important;
}

.oa-wall-range{
  -webkit-appearance:none !important;
  appearance:none !important;
  width:100% !important;
  height:5px !important;
  border-radius:999px !important;
  outline:none !important;
  background:linear-gradient(90deg, rgba(255,232,192,.95), rgba(255,255,255,.52) 34%, rgba(255,255,255,.20)) !important;
  box-shadow:0 0 18px rgba(255,232,192,.18) !important;
}

.oa-wall-range::-webkit-slider-thumb{
  -webkit-appearance:none !important;
  appearance:none !important;
  width:30px !important;
  height:30px !important;
  border-radius:50% !important;
  background:#fff !important;
  border:0 !important;
  box-shadow:0 0 0 5px rgba(255,255,255,.12), 0 0 26px rgba(255,236,205,.52) !important;
}

.oa-wall-range::-moz-range-thumb{
  width:30px !important;
  height:30px !important;
  border-radius:50% !important;
  background:#fff !important;
  border:0 !important;
  box-shadow:0 0 0 5px rgba(255,255,255,.12), 0 0 26px rgba(255,236,205,.52) !important;
}

.oa-wall-full-controls{
  bottom:calc(28px + env(safe-area-inset-bottom)) !important;
  width:min(520px, calc(100vw - 38px)) !important;
  gap:18px !important;
}

.oa-wall-full-controls button{
  width:58px !important;
  min-width:58px !important;
  height:58px !important;
  padding:0 !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.14) !important;
  background:radial-gradient(circle at 50% 42%, rgba(255,255,255,.10), rgba(255,255,255,.035) 62%, rgba(0,0,0,.16) 100%) !important;
  color:rgba(255,250,242,.95) !important;
  font-size:0 !important;
  font-weight:750 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), inset 0 -18px 28px rgba(0,0,0,.12), 0 12px 30px rgba(0,0,0,.28) !important;
}

.oa-wall-full-controls button::before{
  font-size:22px !important;
  line-height:1 !important;
  color:rgba(255,250,242,.94) !important;
  filter:drop-shadow(0 0 5px rgba(255,255,255,.22));
}

.oa-wall-full-controls .oa-wall-loop{
  font-size:14px !important;
  letter-spacing:.04em !important;
}

.oa-wall-full-controls .oa-wall-loop::before{
  content:none !important;
}

.oa-wall-full-controls .oa-wall-prev::before{
  content:"";
  width:22px;
  height:22px;
  background:
    linear-gradient(currentColor 0 0) 5px 3px / 2px 16px no-repeat,
    linear-gradient(135deg, transparent 0 49%, currentColor 50% 100%) 8px 4px / 11px 14px no-repeat;
}

.oa-wall-full-controls .oa-wall-next::before{
  content:"";
  width:22px;
  height:22px;
  background:
    linear-gradient(currentColor 0 0) 15px 3px / 2px 16px no-repeat,
    linear-gradient(225deg, transparent 0 49%, currentColor 50% 100%) 4px 4px / 11px 14px no-repeat;
}

.oa-wall-full-controls .oa-wall-play{
  width:74px !important;
  min-width:74px !important;
  height:74px !important;
  background:radial-gradient(circle at 50% 42%, rgba(255,255,255,.98), rgba(255,255,255,.88) 58%, rgba(235,226,214,.80) 100%) !important;
  color:#171514 !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.86), 0 0 0 1px rgba(255,229,187,.18), 0 0 30px rgba(255,225,184,.36), 0 16px 42px rgba(0,0,0,.34) !important;
}

.oa-wall-full-controls .oa-wall-play::before{
  color:#171514 !important;
  filter:none !important;
}

.oa-wall-full-controls .oa-wall-play::before{
  content:"";
  width:0;
  height:0;
  border-top:11px solid transparent;
  border-bottom:11px solid transparent;
  border-left:17px solid currentColor;
  margin-left:4px;
}

.oa-wall-player:not(.is-playing) .oa-wall-full-controls .oa-wall-play::before{
  content:"";
}

.oa-wall-full-controls .oa-wall-play{
  font-size:0 !important;
}

.oa-wall-full-controls .oa-wall-list-toggle::before{
  content:"☰";
  font-size:24px !important;
}

.oa-wall-player .oa-wall-play{
  font-size:0 !important;
}

.oa-wall-player .oa-wall-play::before{
  content:"";
}

/* pause state is applied through button text, so use classless text fallback hidden by font-size */
.oa-wall-player .oa-wall-play:has-text{
  font-size:0 !important;
}

/* mini/full button text compatibility */
.oa-wall-full-controls .oa-wall-play{
  position:relative;
}

/* When JS button text is 暂停, show pause bars via data-free CSS fallback using aria isn't available,
   so keep a readable circular play icon style; main action remains functional. */

@media (max-width:760px){
  .oa-wall-full-progress{
    bottom:calc(88px + env(safe-area-inset-bottom)) !important;
    width:calc(100vw - 28px) !important;
    grid-template-columns:42px 1fr 42px !important;
    gap:10px !important;
    font-size:14px !important;
  }

  .oa-wall-range::-webkit-slider-thumb{
    width:26px !important;
    height:26px !important;
  }

  .oa-wall-range::-moz-range-thumb{
    width:26px !important;
    height:26px !important;
  }

  .oa-wall-full-controls{
    bottom:calc(18px + env(safe-area-inset-bottom)) !important;
    width:calc(100vw - 28px) !important;
    gap:10px !important;
  }

  .oa-wall-full-controls button{
    width:50px !important;
    min-width:50px !important;
    height:50px !important;
  }

  .oa-wall-full-controls .oa-wall-loop{
    font-size:12px !important;
  }

  .oa-wall-full-controls .oa-wall-play{
    width:64px !important;
    min-width:64px !important;
    height:64px !important;
  }

  .oa-wall-full-list{
    bottom:calc(132px + env(safe-area-inset-bottom)) !important;
  }
}


.oa-wall-player.is-playing .oa-wall-full-controls .oa-wall-play::before{
  width:22px !important;
  height:26px !important;
  border:0 !important;
  margin:0 !important;
  background:
    linear-gradient(currentColor 0 0) left center / 6px 24px no-repeat,
    linear-gradient(currentColor 0 0) right center / 6px 24px no-repeat !important;
}


/* v1.5.18 guest preview limit */
.oa-login-preview-tip{
  position:fixed;
  inset:0;
  z-index:999999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

.oa-login-preview-tip.is-show{
  display:flex;
}

.oa-login-preview-card{
  width:min(360px, calc(100vw - 40px));
  padding:24px 22px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(24,24,24,.96), rgba(10,10,10,.98));
  border:1px solid rgba(255,255,255,.12);
  text-align:center;
  box-shadow:0 24px 80px rgba(0,0,0,.45);
}

.oa-login-preview-card strong{
  display:block;
  color:#fff8ee;
  font-size:16px;
  line-height:1.6;
  margin-bottom:18px;
}

.oa-login-preview-card a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:42px;
  padding:0 22px;
  border-radius:999px;
  background:#fff;
  color:#111 !important;
  text-decoration:none !important;
  font-weight:800;
}


/* v1.5.21 fix wall fullscreen control icons alignment */
.oa-wall-full-controls .oa-wall-prev,
.oa-wall-full-controls .oa-wall-next,
.oa-wall-full-controls .oa-wall-list-toggle{
  position:relative !important;
  overflow:hidden !important;
  text-indent:-9999px !important;
  font-size:0 !important;
}

.oa-wall-full-controls .oa-wall-prev::before,
.oa-wall-full-controls .oa-wall-next::before,
.oa-wall-full-controls .oa-wall-list-toggle::before{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  transform:translate(-50%, -50%) !important;
  display:block !important;
  color:rgba(255,250,242,.96) !important;
  filter:drop-shadow(0 0 5px rgba(255,255,255,.18)) !important;
}

/* previous: vertical bar + left triangle, optically centered */
.oa-wall-full-controls .oa-wall-prev::before{
  width:24px !important;
  height:24px !important;
  background:
    linear-gradient(currentColor 0 0) 4px 4px / 2.4px 16px no-repeat,
    linear-gradient(135deg, transparent 0 50%, currentColor 51% 100%) 8px 5px / 12px 14px no-repeat !important;
}

/* next: right triangle + vertical bar, optically centered */
.oa-wall-full-controls .oa-wall-next::before{
  width:24px !important;
  height:24px !important;
  background:
    linear-gradient(currentColor 0 0) 17px 4px / 2.4px 16px no-repeat,
    linear-gradient(225deg, transparent 0 50%, currentColor 51% 100%) 4px 5px / 12px 14px no-repeat !important;
}

/* list: three centered lines */
.oa-wall-full-controls .oa-wall-list-toggle::before{
  width:24px !important;
  height:20px !important;
  background:
    linear-gradient(currentColor 0 0) 4px 3px / 16px 2.4px no-repeat,
    linear-gradient(currentColor 0 0) 4px 9px / 16px 2.4px no-repeat,
    linear-gradient(currentColor 0 0) 4px 15px / 16px 2.4px no-repeat !important;
  border-radius:0 !important;
}

.oa-wall-full-controls .oa-wall-prev::after,
.oa-wall-full-controls .oa-wall-next::after,
.oa-wall-full-controls .oa-wall-list-toggle::after{
  display:none !important;
  content:none !important;
}

@media (max-width:760px){
  .oa-wall-full-controls .oa-wall-prev::before,
  .oa-wall-full-controls .oa-wall-next::before{
    width:22px !important;
    height:22px !important;
  }
  .oa-wall-full-controls .oa-wall-list-toggle::before{
    width:22px !important;
    height:18px !important;
    background:
      linear-gradient(currentColor 0 0) 4px 2px / 14px 2.2px no-repeat,
      linear-gradient(currentColor 0 0) 4px 8px / 14px 2.2px no-repeat,
      linear-gradient(currentColor 0 0) 4px 14px / 14px 2.2px no-repeat !important;
  }
}


/* v1.5.22 use same prev/next icons as single player */
.oa-wall-full-controls .oa-wall-prev,
.oa-wall-full-controls .oa-wall-next{
  text-indent:-9999px !important;
  overflow:hidden !important;
  position:relative !important;
}

.oa-wall-full-controls .oa-wall-prev::before,
.oa-wall-full-controls .oa-wall-next::before{
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  transform:translate(-50%, -50%) !important;
  width:auto !important;
  height:auto !important;
  background:none !important;
  font-size:22px !important;
  line-height:1 !important;
  color:rgba(255,250,242,.96) !important;
  font-weight:700 !important;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,sans-serif !important;
}

.oa-wall-full-controls .oa-wall-prev::before{
  content:"◀" !important;
  margin-left:-1px !important;
}

.oa-wall-full-controls .oa-wall-next::before{
  content:"▶" !important;
  margin-left:1px !important;
}

.oa-wall-full-controls .oa-wall-list-toggle::before{
  left:50% !important;
  top:50% !important;
  transform:translate(-50%, -50%) !important;
}

@media (max-width:760px){
  .oa-wall-full-controls .oa-wall-prev::before,
  .oa-wall-full-controls .oa-wall-next::before{
    font-size:20px !important;
  }
}


/* v1.5.23 hard fix prev/next icons */
.oa-wall-full-controls .oa-wall-prev,
.oa-wall-full-controls .oa-wall-next{
  position:relative !important;
  color:transparent !important;
}

.oa-wall-full-controls .oa-wall-prev::before,
.oa-wall-full-controls .oa-wall-next::before{
  content:"" !important;
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  transform:translate(-50%, -50%) !important;
  display:block !important;
  width:0 !important;
  height:0 !important;
  border-top:9px solid transparent !important;
  border-bottom:9px solid transparent !important;
}

.oa-wall-full-controls .oa-wall-prev::before{
  border-right:14px solid rgba(255,250,242,.96) !important;
  margin-left:-2px !important;
}

.oa-wall-full-controls .oa-wall-next::before{
  border-left:14px solid rgba(255,250,242,.96) !important;
  margin-left:2px !important;
}

@media (max-width:760px){
  .oa-wall-full-controls .oa-wall-prev::before,
  .oa-wall-full-controls .oa-wall-next::before{
    border-top-width:8px !important;
    border-bottom-width:8px !important;
  }

  .oa-wall-full-controls .oa-wall-prev::before{
    border-right-width:12px !important;
  }

  .oa-wall-full-controls .oa-wall-next::before{
    border-left-width:12px !important;
  }
}


/* v1.5.24 album wall modal list: keep cover wall position unchanged */
.oa-album-song-panel{
  display:none !important;
}

.oa-album-card.is-open{
  display:block !important;
  grid-column:auto !important;
}

.oa-album-modal{
  position:fixed;
  inset:0;
  z-index:100000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:22px;
}

.oa-album-modal.is-open{
  display:flex;
}

.oa-album-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.58);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.oa-album-modal-card{
  position:relative;
  width:min(680px, calc(100vw - 34px));
  max-height:min(760px, calc(100dvh - 44px));
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(circle at 18% 0%, rgba(255,232,190,.12), transparent 34%),
    linear-gradient(180deg, rgba(28,28,28,.96), rgba(8,8,8,.98));
  box-shadow:0 28px 90px rgba(0,0,0,.55);
  color:#fff8ee;
  display:flex;
  flex-direction:column;
}

.oa-album-modal-close{
  position:absolute;
  top:14px;
  right:14px;
  width:36px;
  height:36px;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  color:#fff;
  font-size:24px;
  line-height:1;
  cursor:pointer;
  z-index:2;
}

.oa-album-modal-head{
  display:grid;
  grid-template-columns:132px minmax(0,1fr);
  gap:18px;
  padding:24px 24px 18px;
  align-items:center;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.oa-album-modal-cover{
  width:132px;
  height:132px;
  border-radius:20px;
  object-fit:cover;
  background:rgba(255,255,255,.06);
  box-shadow:0 18px 44px rgba(0,0,0,.35);
}

.oa-album-modal-title{
  margin:0;
  font-size:24px;
  line-height:1.25;
  font-weight:850;
  color:#fff8ee;
}

.oa-album-modal-count{
  margin:8px 0 16px;
  color:rgba(255,248,238,.58);
  font-size:13px;
}

.oa-album-modal-playall{
  height:40px;
  padding:0 18px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:#fff;
  color:#111;
  font-weight:850;
  cursor:pointer;
}

.oa-album-modal-list{
  list-style:none;
  margin:0;
  padding:10px 16px 18px;
  overflow:auto;
}

.oa-album-modal-list li{
  display:grid;
  grid-template-columns:46px minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  padding:11px 8px;
  border-radius:14px;
  border-top:1px solid rgba(255,255,255,.055);
}

.oa-album-modal-list li:first-child{
  border-top:0;
}

.oa-album-modal-index{
  color:rgba(255,248,238,.45);
  font-size:12px;
  font-variant-numeric:tabular-nums;
}

.oa-album-modal-name{
  min-width:0;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
  color:rgba(255,248,238,.86);
  font-size:14px;
}

.oa-album-modal-play{
  height:32px;
  padding:0 12px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#fff8ee;
  font-size:12px;
  font-weight:780;
  cursor:pointer;
}

body.oa-album-modal-open{
  overflow:hidden;
}

@media (max-width:760px){
  .oa-album-modal{
    padding:14px;
  }

  .oa-album-modal-card{
    width:calc(100vw - 28px);
    max-height:calc(100dvh - 28px);
    border-radius:24px;
  }

  .oa-album-modal-head{
    grid-template-columns:88px minmax(0,1fr);
    gap:12px;
    padding:18px 16px 14px;
  }

  .oa-album-modal-cover{
    width:88px;
    height:88px;
    border-radius:16px;
  }

  .oa-album-modal-title{
    font-size:18px;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }

  .oa-album-modal-count{
    margin:6px 0 10px;
    font-size:12px;
  }

  .oa-album-modal-playall{
    height:34px;
    padding:0 14px;
    font-size:12px;
  }

  .oa-album-modal-list{
    padding:8px 10px 14px;
  }

  .oa-album-modal-list li{
    grid-template-columns:34px minmax(0,1fr) auto;
    padding:10px 4px;
  }

  .oa-album-modal-play{
    height:30px;
    padding:0 10px;
  }
}


/* v1.5.27 progress knob refined: smaller and cleaner */
.oa-wall-range{
  height:4px !important;
  box-shadow:none !important;
}

.oa-wall-range::-webkit-slider-thumb{
  -webkit-appearance:none !important;
  appearance:none !important;
  width:14px !important;
  height:14px !important;
  border-radius:999px !important;
  background:#fff !important;
  border:2px solid rgba(255,232,190,.92) !important;
  box-shadow:0 0 10px rgba(255,232,190,.28) !important;
}

.oa-wall-range::-moz-range-thumb{
  width:14px !important;
  height:14px !important;
  border-radius:999px !important;
  background:#fff !important;
  border:2px solid rgba(255,232,190,.92) !important;
  box-shadow:0 0 10px rgba(255,232,190,.28) !important;
}

.oa-wall-range::-webkit-slider-thumb:hover{
  width:16px !important;
  height:16px !important;
}

.oa-wall-range::-moz-range-thumb:hover{
  width:16px !important;
  height:16px !important;
}

/* single album player progress thumb also refined */
.oa-progress::-webkit-slider-thumb{
  width:14px !important;
  height:14px !important;
  border:2px solid rgba(255,232,190,.92) !important;
  box-shadow:0 0 10px rgba(255,232,190,.24) !important;
}

.oa-progress::-moz-range-thumb{
  width:14px !important;
  height:14px !important;
  border:2px solid rgba(255,232,190,.92) !important;
  box-shadow:0 0 10px rgba(255,232,190,.24) !important;
}

@media (max-width:760px){
  .oa-wall-range::-webkit-slider-thumb,
  .oa-progress::-webkit-slider-thumb{
    width:13px !important;
    height:13px !important;
  }

  .oa-wall-range::-moz-range-thumb,
  .oa-progress::-moz-range-thumb{
    width:13px !important;
    height:13px !important;
  }
}


/* v1.5.28 progress bar fill mode, no knob */
.oa-progress,
.oa-wall-range,
.oa-floating-range{
  --oa-progress-percent: 0%;
  -webkit-appearance:none !important;
  appearance:none !important;
  height:6px !important;
  border-radius:999px !important;
  outline:none !important;
  cursor:pointer !important;
  background:
    linear-gradient(
      90deg,
      rgba(255,232,190,.96) 0%,
      rgba(255,232,190,.96) var(--oa-progress-percent),
      rgba(255,255,255,.20) var(--oa-progress-percent),
      rgba(255,255,255,.20) 100%
    ) !important;
  box-shadow:none !important;
}

.oa-progress::-webkit-slider-runnable-track,
.oa-wall-range::-webkit-slider-runnable-track,
.oa-floating-range::-webkit-slider-runnable-track{
  height:6px !important;
  border-radius:999px !important;
  background:transparent !important;
}

.oa-progress::-moz-range-track,
.oa-wall-range::-moz-range-track,
.oa-floating-range::-moz-range-track{
  height:6px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.20) !important;
}

.oa-progress::-moz-range-progress,
.oa-wall-range::-moz-range-progress,
.oa-floating-range::-moz-range-progress{
  height:6px !important;
  border-radius:999px !important;
  background:rgba(255,232,190,.96) !important;
}

/* Hide the thumb completely */
.oa-progress::-webkit-slider-thumb,
.oa-wall-range::-webkit-slider-thumb,
.oa-floating-range::-webkit-slider-thumb{
  -webkit-appearance:none !important;
  appearance:none !important;
  width:0 !important;
  height:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}

.oa-progress::-moz-range-thumb,
.oa-wall-range::-moz-range-thumb,
.oa-floating-range::-moz-range-thumb{
  width:0 !important;
  height:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}

.oa-progress:focus,
.oa-wall-range:focus,
.oa-floating-range:focus{
  box-shadow:0 0 0 3px rgba(255,232,190,.10) !important;
}

@media (max-width:760px){
  .oa-progress,
  .oa-wall-range,
  .oa-floating-range{
    height:5px !important;
  }

  .oa-progress::-webkit-slider-runnable-track,
  .oa-wall-range::-webkit-slider-runnable-track,
  .oa-floating-range::-webkit-slider-runnable-track,
  .oa-progress::-moz-range-track,
  .oa-wall-range::-moz-range-track,
  .oa-floating-range::-moz-range-track,
  .oa-progress::-moz-range-progress,
  .oa-wall-range::-moz-range-progress,
  .oa-floating-range::-moz-range-progress{
    height:5px !important;
  }
}


/* v1.5.29 fullscreen responsive layout
   PC / tablet: left cover+info, right lyrics.
   Mobile keeps the current vertical layout. */
@media (min-width: 761px){
  .oa-wall-player.is-expanded .oa-wall-full{
    width:100% !important;
    max-width:1180px !important;
    height:100dvh !important;
    min-height:100dvh !important;
    padding:72px 48px calc(128px + env(safe-area-inset-bottom)) !important;
    display:grid !important;
    grid-template-columns:minmax(280px, 420px) minmax(0, 1fr) !important;
    grid-template-rows:auto 1fr !important;
    column-gap:56px !important;
    row-gap:18px !important;
    align-items:center !important;
    justify-content:center !important;
    overflow:hidden !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    grid-column:1 !important;
    grid-row:1 / span 2 !important;
    align-self:center !important;
    justify-self:center !important;
    width:min(390px, 34vw, 58vh) !important;
    max-width:100% !important;
    margin:0 auto !important;
  }

  .oa-wall-full-info{
    grid-column:1 !important;
    grid-row:2 !important;
    align-self:start !important;
    justify-self:center !important;
    width:min(390px, 34vw) !important;
    margin:18px auto 0 !important;
    text-align:center !important;
  }

  .oa-wall-full-title{
    font-size:clamp(22px, 2.1vw, 30px) !important;
    line-height:1.22 !important;
    -webkit-line-clamp:3 !important;
  }

  .oa-wall-full-subtitle{
    font-size:14px !important;
    margin-top:10px !important;
  }

  .oa-wall-full-lyrics{
    grid-column:2 !important;
    grid-row:1 / span 2 !important;
    align-self:center !important;
    width:100% !important;
    max-width:620px !important;
    min-height:min(520px, 58vh) !important;
    height:min(520px, 58vh) !important;
    max-height:min(520px, 58vh) !important;
    margin:0 !important;
    padding:24px 0 !important;
  }

  .oa-wall-lyric-spacer{
    height:calc(50% - 20px) !important;
  }

  .oa-wall-lyric-line{
    height:38px !important;
    line-height:38px !important;
    font-size:20px !important;
  }

  .oa-wall-lyric-line.is-active{
    height:42px !important;
    line-height:42px !important;
    font-size:28px !important;
  }

  .oa-wall-full-progress{
    width:min(980px, calc(100vw - 96px)) !important;
    bottom:calc(88px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-controls{
    width:min(620px, calc(100vw - 96px)) !important;
    bottom:calc(22px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-list{
    width:min(720px, calc(100vw - 96px)) !important;
    right:48px !important;
    left:auto !important;
    transform:none !important;
    bottom:calc(140px + env(safe-area-inset-bottom)) !important;
  }
}

/* tablet: still two columns, but tighter */
@media (min-width: 761px) and (max-width: 1024px){
  .oa-wall-player.is-expanded .oa-wall-full{
    max-width:960px !important;
    padding:68px 34px calc(122px + env(safe-area-inset-bottom)) !important;
    grid-template-columns:minmax(240px, 340px) minmax(0, 1fr) !important;
    column-gap:34px !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(320px, 35vw, 48vh) !important;
  }

  .oa-wall-full-info{
    width:min(320px, 35vw) !important;
  }

  .oa-wall-full-title{
    font-size:clamp(20px, 2.4vw, 26px) !important;
  }

  .oa-wall-full-lyrics{
    max-width:520px !important;
    min-height:min(460px, 54vh) !important;
    height:min(460px, 54vh) !important;
    max-height:min(460px, 54vh) !important;
  }

  .oa-wall-lyric-line{
    height:35px !important;
    line-height:35px !important;
    font-size:18px !important;
  }

  .oa-wall-lyric-line.is-active{
    height:39px !important;
    line-height:39px !important;
    font-size:24px !important;
  }
}

/* small-height desktop/tablet guard */
@media (min-width: 761px) and (max-height: 760px){
  .oa-wall-player.is-expanded .oa-wall-full{
    padding-top:54px !important;
    padding-bottom:calc(108px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(280px, 30vw, 44vh) !important;
  }

  .oa-wall-full-info{
    margin-top:12px !important;
  }

  .oa-wall-full-lyrics{
    min-height:min(360px, 48vh) !important;
    height:min(360px, 48vh) !important;
    max-height:min(360px, 48vh) !important;
  }

  .oa-wall-full-progress{
    bottom:calc(76px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-controls{
    bottom:calc(16px + env(safe-area-inset-bottom)) !important;
  }
}

/* mobile keeps vertical layout from previous versions */
@media (max-width:760px){
  .oa-wall-player.is-expanded .oa-wall-full{
    display:flex !important;
    flex-direction:column !important;
  }
}


/* v1.5.30 PC/tablet fullscreen layout fix
   1. Keep title/info under the cover on the left.
   2. Move song list popup above progress/control bar and keep it compact/centered. */
@media (min-width:761px){
  .oa-wall-player.is-expanded .oa-wall-full{
    max-width:1180px !important;
    grid-template-columns:minmax(300px, 430px) minmax(0, 1fr) !important;
    grid-template-rows:minmax(0, 1fr) !important;
    align-items:center !important;
    padding-top:64px !important;
    padding-bottom:calc(126px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    grid-column:1 !important;
    grid-row:1 !important;
    align-self:center !important;
    justify-self:center !important;
    width:min(360px, 32vw, 52vh) !important;
    margin:0 auto !important;
    transform:translateY(-28px) !important;
  }

  .oa-wall-full-info{
    grid-column:1 !important;
    grid-row:1 !important;
    align-self:center !important;
    justify-self:center !important;
    width:min(360px, 32vw) !important;
    margin:0 !important;
    padding-top:min(390px, 35vw, 56vh) !important;
    transform:translateY(-12px) !important;
    text-align:center !important;
    position:relative !important;
    z-index:2 !important;
  }

  .oa-wall-full-title{
    font-size:clamp(22px, 2vw, 28px) !important;
    line-height:1.24 !important;
    -webkit-line-clamp:2 !important;
  }

  .oa-wall-full-subtitle{
    font-size:14px !important;
    margin-top:8px !important;
    opacity:.72 !important;
  }

  .oa-wall-full-lyrics{
    grid-column:2 !important;
    grid-row:1 !important;
    align-self:center !important;
    justify-self:center !important;
    max-width:560px !important;
    min-height:min(500px, 56vh) !important;
    height:min(500px, 56vh) !important;
    max-height:min(500px, 56vh) !important;
  }

  .oa-wall-full-list{
    left:50% !important;
    right:auto !important;
    transform:translateX(-50%) !important;
    width:min(620px, calc(100vw - 96px)) !important;
    max-height:min(34vh, 300px) !important;
    bottom:calc(138px + env(safe-area-inset-bottom)) !important;
    z-index:100006 !important;
  }

  .oa-wall-full-song-list{
    padding:8px !important;
  }

  .oa-wall-full-song-list li{
    grid-template-columns:42px minmax(0,1fr) 54px !important;
    padding:9px 10px !important;
  }

  .oa-wall-full-song-list li button{
    height:28px !important;
    padding:0 10px !important;
    font-size:12px !important;
  }
}

@media (min-width:761px) and (max-width:1024px){
  .oa-wall-player.is-expanded .oa-wall-full{
    grid-template-columns:minmax(260px, 340px) minmax(0, 1fr) !important;
    column-gap:32px !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(310px, 34vw, 46vh) !important;
    transform:translateY(-22px) !important;
  }

  .oa-wall-full-info{
    width:min(310px, 34vw) !important;
    padding-top:min(340px, 38vw, 50vh) !important;
    transform:translateY(-8px) !important;
  }

  .oa-wall-full-lyrics{
    max-width:500px !important;
  }
}

@media (min-width:761px) and (max-height:760px){
  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(280px, 30vw, 42vh) !important;
    transform:translateY(-18px) !important;
  }

  .oa-wall-full-info{
    width:min(300px, 32vw) !important;
    padding-top:min(305px, 33vw, 45vh) !important;
  }

  .oa-wall-full-list{
    max-height:30vh !important;
    bottom:calc(124px + env(safe-area-inset-bottom)) !important;
  }
}


/* v1.5.31 spacing refine: cover text and bottom controls */
@media (min-width:761px){
  /* 左侧封面和歌曲信息拉开距离 */
  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    transform:translateY(-40px) !important;
    margin-bottom:22px !important;
  }

  .oa-wall-full-info{
    padding-top:min(430px, 38vw, 60vh) !important;
    transform:translateY(4px) !important;
  }

  .oa-wall-full-title{
    margin-top:10px !important;
  }

  .oa-wall-full-subtitle{
    margin-top:12px !important;
  }

  /* 进度条和控制按钮拉开距离 */
  .oa-wall-full-progress{
    bottom:calc(112px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-controls{
    bottom:calc(24px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-list{
    bottom:calc(164px + env(safe-area-inset-bottom)) !important;
  }
}

@media (min-width:761px) and (max-width:1024px){
  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    transform:translateY(-32px) !important;
  }

  .oa-wall-full-info{
    padding-top:min(370px, 40vw, 54vh) !important;
    transform:translateY(2px) !important;
  }

  .oa-wall-full-progress{
    bottom:calc(108px + env(safe-area-inset-bottom)) !important;
  }
}

@media (max-width:760px){
  /* 手机端也略微拉开底部进度条和按钮距离，但保持当前布局 */
  .oa-wall-full-progress{
    bottom:calc(94px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-controls{
    bottom:calc(14px + env(safe-area-inset-bottom)) !important;
  }
}

@media (min-width:761px) and (max-height:760px){
  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    transform:translateY(-26px) !important;
  }

  .oa-wall-full-info{
    padding-top:min(330px, 35vw, 48vh) !important;
  }

  .oa-wall-full-progress{
    bottom:calc(100px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-controls{
    bottom:calc(18px + env(safe-area-inset-bottom)) !important;
  }
}


/* v1.5.32 mobile fullscreen style: larger cover, lower placement, 5-line premium lyrics */
@media (max-width:760px){
  .oa-wall-player.is-expanded .oa-wall-full{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:flex-start !important;
    padding:78px 18px calc(128px + env(safe-area-inset-bottom)) !important;
    gap:0 !important;
    overflow:hidden !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full::before{
    background:
      radial-gradient(circle at 50% 18%, rgba(255,232,190,.12), transparent 30%),
      radial-gradient(circle at 12% 8%, rgba(255,255,255,.06), transparent 22%),
      linear-gradient(180deg, rgba(255,255,255,.02), transparent 30%, rgba(0,0,0,.18)) !important;
  }

  .oa-wall-full-close{
    top:26px !important;
    right:26px !important;
    font-size:16px !important;
    font-weight:850 !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(330px, 80vw, 39vh) !important;
    max-width:330px !important;
    border-radius:30px !important;
    margin:18px auto 22px !important;
    transform:none !important;
    box-shadow:0 28px 80px rgba(0,0,0,.48), 0 0 0 1px rgba(255,232,190,.16) !important;
  }

  .oa-wall-full-cover{
    border-radius:30px !important;
  }

  .oa-wall-full-info{
    width:100% !important;
    max-width:88vw !important;
    margin:0 auto 26px !important;
    padding:0 !important;
    transform:none !important;
    text-align:center !important;
    flex:0 0 auto !important;
  }

  .oa-wall-full-title{
    font-size:clamp(26px, 7vw, 34px) !important;
    line-height:1.18 !important;
    font-weight:900 !important;
    letter-spacing:.01em !important;
    -webkit-line-clamp:2 !important;
    text-shadow:0 0 18px rgba(255,255,255,.08) !important;
  }

  .oa-wall-full-subtitle{
    margin-top:10px !important;
    font-size:15px !important;
    line-height:1.35 !important;
    color:rgba(255,248,238,.54) !important;
  }

  .oa-wall-full-lyrics{
    width:100% !important;
    max-width:88vw !important;
    flex:0 0 auto !important;
    height:205px !important;
    min-height:205px !important;
    max-height:205px !important;
    margin:0 auto 16px !important;
    padding:10px 0 !important;
    overflow:hidden !important;
    text-align:center !important;
    mask-image:linear-gradient(to bottom, transparent, #000 14%, #000 86%, transparent) !important;
    -webkit-mask-image:linear-gradient(to bottom, transparent, #000 14%, #000 86%, transparent) !important;
  }

  .oa-wall-lyric-spacer{
    height:calc(50% - 20px) !important;
  }

  .oa-wall-lyric-line{
    height:36px !important;
    line-height:36px !important;
    font-size:20px !important;
    font-weight:760 !important;
    color:rgba(255,248,238,.30) !important;
    letter-spacing:.01em !important;
  }

  .oa-wall-lyric-line.is-active{
    height:42px !important;
    line-height:42px !important;
    font-size:26px !important;
    font-weight:920 !important;
    color:#fff8ee !important;
    text-shadow:0 0 20px rgba(255,232,190,.28), 0 0 36px rgba(255,255,255,.06) !important;
  }

  .oa-wall-full-progress{
    bottom:calc(92px + env(safe-area-inset-bottom)) !important;
    width:calc(100vw - 54px) !important;
    grid-template-columns:48px 1fr 48px !important;
    gap:12px !important;
    font-size:16px !important;
    font-weight:700 !important;
  }

  .oa-wall-full-controls{
    bottom:calc(18px + env(safe-area-inset-bottom)) !important;
    width:calc(100vw - 42px) !important;
    gap:12px !important;
  }

  .oa-wall-full-controls button{
    width:56px !important;
    min-width:56px !important;
    height:56px !important;
  }

  .oa-wall-full-controls .oa-wall-play{
    width:76px !important;
    min-width:76px !important;
    height:76px !important;
  }

  .oa-wall-full-controls .oa-wall-loop{
    font-size:14px !important;
  }

  .oa-wall-full-list{
    width:calc(100vw - 34px) !important;
    bottom:calc(148px + env(safe-area-inset-bottom)) !important;
    max-height:38vh !important;
  }
}

@media (max-width:760px) and (max-height:780px){
  .oa-wall-player.is-expanded .oa-wall-full{
    padding-top:54px !important;
    padding-bottom:calc(112px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(285px, 72vw, 34vh) !important;
    margin-top:10px !important;
    margin-bottom:16px !important;
  }

  .oa-wall-full-info{
    margin-bottom:18px !important;
  }

  .oa-wall-full-title{
    font-size:clamp(23px, 6.2vw, 30px) !important;
  }

  .oa-wall-full-lyrics{
    height:178px !important;
    min-height:178px !important;
    max-height:178px !important;
  }

  .oa-wall-lyric-line{
    height:32px !important;
    line-height:32px !important;
    font-size:18px !important;
  }

  .oa-wall-lyric-line.is-active{
    height:38px !important;
    line-height:38px !important;
    font-size:23px !important;
  }

  .oa-wall-full-progress{
    bottom:calc(82px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-controls{
    bottom:calc(12px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-controls button{
    width:50px !important;
    min-width:50px !important;
    height:50px !important;
  }

  .oa-wall-full-controls .oa-wall-play{
    width:66px !important;
    min-width:66px !important;
    height:66px !important;
  }
}


/* v1.5.33 mobile size refine */
@media (max-width:760px){
  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(305px, 74vw, 36vh) !important;
    max-width:305px !important;
    margin-top:14px !important;
    margin-bottom:18px !important;
  }

  .oa-wall-full-title{
    font-size:clamp(22px, 6.1vw, 29px) !important;
    line-height:1.18 !important;
  }

  .oa-wall-full-subtitle{
    margin-top:8px !important;
    font-size:13px !important;
  }

  .oa-wall-full-progress{
    font-size:13px !important;
    font-weight:650 !important;
    grid-template-columns:40px 1fr 40px !important;
    gap:10px !important;
  }
}

@media (max-width:760px) and (max-height:780px){
  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(265px, 68vw, 31vh) !important;
    max-width:265px !important;
    margin-top:8px !important;
    margin-bottom:14px !important;
  }

  .oa-wall-full-title{
    font-size:clamp(21px, 5.8vw, 26px) !important;
  }

  .oa-wall-full-subtitle{
    font-size:12px !important;
  }

  .oa-wall-full-progress{
    font-size:12px !important;
    grid-template-columns:38px 1fr 38px !important;
  }
}


/* v1.5.35 lyrics: allow long active lyric to wrap into 2 lines without overlap */
.oa-lyric-line,
.oa-wall-lyric-line{
  box-sizing:border-box !important;
  white-space:nowrap !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
}

.oa-lyric-line.is-active,
.oa-wall-lyric-line.is-active{
  white-space:normal !important;
  overflow:hidden !important;
  text-overflow:clip !important;
  display:-webkit-box !important;
  -webkit-line-clamp:2 !important;
  -webkit-box-orient:vertical !important;
  height:auto !important;
  min-height:42px !important;
  max-height:72px !important;
  line-height:1.28 !important;
  padding:4px 8px !important;
}

/* single album player active lyric two-line spacing */
.oa-lyrics .oa-lyric-line.is-active{
  min-height:40px !important;
  max-height:68px !important;
}

/* album wall fullscreen player active lyric two-line spacing */
.oa-wall-full-lyrics .oa-wall-lyric-line.is-active{
  min-height:44px !important;
  max-height:76px !important;
}

/* keep surrounding lyric lines from visually colliding with two-line active lyric */
.oa-wall-full-lyrics .oa-wall-lyric-line,
.oa-lyrics .oa-lyric-line{
  margin:2px 0 !important;
}

@media (max-width:760px){
  .oa-wall-full-lyrics{
    height:225px !important;
    min-height:225px !important;
    max-height:225px !important;
  }

  .oa-wall-full-lyrics .oa-wall-lyric-line.is-active{
    min-height:54px !important;
    max-height:82px !important;
    line-height:1.32 !important;
    padding:5px 10px !important;
  }

  .oa-lyrics .oa-lyric-line.is-active{
    min-height:46px !important;
    max-height:76px !important;
    line-height:1.32 !important;
    padding:4px 8px !important;
  }
}

@media (max-width:760px) and (max-height:780px){
  .oa-wall-full-lyrics{
    height:198px !important;
    min-height:198px !important;
    max-height:198px !important;
  }

  .oa-wall-full-lyrics .oa-wall-lyric-line.is-active{
    min-height:50px !important;
    max-height:76px !important;
  }
}


/* v1.5.36 mobile: increase spacing between progress bar and controls */
@media (max-width:760px){
  .oa-wall-full-progress{
    bottom:calc(108px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-controls{
    bottom:calc(16px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-list{
    bottom:calc(164px + env(safe-area-inset-bottom)) !important;
  }
}

@media (max-width:760px) and (max-height:780px){
  .oa-wall-full-progress{
    bottom:calc(98px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-controls{
    bottom:calc(12px + env(safe-area-inset-bottom)) !important;
  }

  .oa-wall-full-list{
    bottom:calc(150px + env(safe-area-inset-bottom)) !important;
  }
}


/* v1.5.37 fix active lyric: single-line stays single, long lyric can wrap to 2 lines */
.oa-lyric-line.is-active,
.oa-wall-lyric-line.is-active{
  white-space:normal !important;
  overflow:hidden !important;
  text-overflow:clip !important;
  display:-webkit-box !important;
  -webkit-line-clamp:2 !important;
  -webkit-box-orient:vertical !important;

  /* 不再默认占两行高度，只有超出时自然变两行 */
  height:auto !important;
  min-height:0 !important;
  max-height:2.7em !important;
  line-height:1.34 !important;
  padding-top:2px !important;
  padding-bottom:2px !important;
}

/* 普通歌词仍然单行，避免整体看起来散 */
.oa-lyric-line:not(.is-active),
.oa-wall-lyric-line:not(.is-active){
  white-space:nowrap !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
}

/* 手机端微调：当前歌词单行不留空，两行时也不压下面 */
@media (max-width:760px){
  .oa-wall-full-lyrics .oa-wall-lyric-line.is-active{
    min-height:0 !important;
    max-height:2.72em !important;
    line-height:1.36 !important;
    padding-top:3px !important;
    padding-bottom:3px !important;
    margin:4px 0 !important;
  }

  .oa-lyrics .oa-lyric-line.is-active{
    min-height:0 !important;
    max-height:2.72em !important;
    line-height:1.36 !important;
    padding-top:3px !important;
    padding-bottom:3px !important;
    margin:3px 0 !important;
  }
}


/* v1.5.38 PC/tablet: cover and song info spacing = about 20px */
@media (min-width:761px){
  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    transform:translateY(-30px) !important;
    margin-bottom:20px !important;
  }

  .oa-wall-full-info{
    padding-top:calc(min(360px, 32vw, 52vh) + 20px) !important;
    transform:translateY(-30px) !important;
  }
}

@media (min-width:761px) and (max-width:1024px){
  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    transform:translateY(-24px) !important;
    margin-bottom:20px !important;
  }

  .oa-wall-full-info{
    padding-top:calc(min(310px, 34vw, 46vh) + 20px) !important;
    transform:translateY(-24px) !important;
  }
}

@media (min-width:761px) and (max-height:760px){
  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    transform:translateY(-18px) !important;
    margin-bottom:20px !important;
  }

  .oa-wall-full-info{
    padding-top:calc(min(280px, 30vw, 42vh) + 20px) !important;
    transform:translateY(-18px) !important;
  }
}


/* v1.5.39 PC/tablet cover + song info position fix */
@media (min-width:761px){
  .oa-wall-player.is-expanded .oa-wall-full{
    grid-template-columns:minmax(300px, 430px) minmax(0, 1fr) !important;
    grid-template-rows:auto auto !important;
    align-content:center !important;
    align-items:center !important;
    row-gap:20px !important;
    column-gap:56px !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    grid-column:1 !important;
    grid-row:1 !important;
    align-self:end !important;
    justify-self:center !important;
    width:min(360px, 32vw, 52vh) !important;
    margin:0 !important;
    transform:none !important;
  }

  .oa-wall-full-info{
    grid-column:1 !important;
    grid-row:2 !important;
    align-self:start !important;
    justify-self:center !important;
    width:min(360px, 32vw) !important;
    margin:0 !important;
    padding:0 !important;
    transform:none !important;
    text-align:center !important;
  }

  .oa-wall-full-title{
    margin:0 !important;
  }

  .oa-wall-full-subtitle{
    margin-top:8px !important;
  }

  .oa-wall-full-lyrics{
    grid-column:2 !important;
    grid-row:1 / 3 !important;
    align-self:center !important;
    justify-self:center !important;
  }
}

@media (min-width:761px) and (max-width:1024px){
  .oa-wall-player.is-expanded .oa-wall-full{
    grid-template-columns:minmax(260px, 340px) minmax(0, 1fr) !important;
    row-gap:20px !important;
    column-gap:34px !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(320px, 34vw, 46vh) !important;
    transform:none !important;
  }

  .oa-wall-full-info{
    width:min(320px, 34vw) !important;
    padding:0 !important;
    transform:none !important;
  }
}

@media (min-width:761px) and (max-height:760px){
  .oa-wall-player.is-expanded .oa-wall-full{
    row-gap:16px !important;
  }

  .oa-wall-player.is-expanded .oa-wall-full-cover-wrap{
    width:min(280px, 30vw, 42vh) !important;
    transform:none !important;
  }

  .oa-wall-full-info{
    width:min(280px, 30vw) !important;
    padding:0 !important;
    transform:none !important;
  }
}


/* v1.5.40 audio quality badge */
.oa-quality-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:8px;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.075);
  color:rgba(255,248,238,.72);
  font-size:12px;
  line-height:1;
  font-weight:760;
  letter-spacing:.04em;
}

.oa-wall-full-subtitle,
.oa-wall-mini-subtitle{
  color:rgba(255,248,238,.66) !important;
}


/* v1.5.41 quality switch */
.oa-quality-badge,
.oa-wall-quality-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:8px;
  padding:4px 11px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.075);
  color:rgba(255,248,238,.76);
  font-size:12px;
  line-height:1;
  font-weight:780;
  letter-spacing:.04em;
  cursor:pointer;
}

.oa-quality-badge.is-hq,
.oa-wall-quality-badge.is-hq{
  border-color:rgba(255,232,190,.36);
  background:rgba(255,232,190,.13);
  color:#fff2d8;
}

.oa-quality-badge.is-standard,
.oa-wall-quality-badge.is-standard{
  color:rgba(255,248,238,.68);
}

.oa-wall-quality-badge{
  margin-top:10px;
}

@media (max-width:760px){
  .oa-quality-badge,
  .oa-wall-quality-badge{
    font-size:11px;
    padding:4px 10px;
  }
}


/* v1.5.43 clickable quality visual */
.oa-quality-badge,
.oa-wall-quality-badge{
  position:relative;
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  gap:6px;
  min-height:32px;
  padding:0 14px !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.16) !important;
  background:rgba(255,255,255,.06) !important;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  color:rgba(255,248,238,.88) !important;
  font-size:12px !important;
  font-weight:780 !important;
  letter-spacing:.02em !important;
  cursor:pointer !important;
  transition:all .22s ease !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 6px 20px rgba(0,0,0,.22);
}

.oa-quality-badge::after,
.oa-wall-quality-badge::after{
  content:"↹";
  font-size:11px;
  opacity:.55;
}

.oa-quality-badge:hover,
.oa-wall-quality-badge:hover{
  transform:translateY(-1px);
  border-color:rgba(255,255,255,.24) !important;
  background:rgba(255,255,255,.09) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 10px 24px rgba(0,0,0,.28);
}

.oa-quality-badge.is-hq,
.oa-wall-quality-badge.is-hq{
  border-color:rgba(255,225,168,.34) !important;
  background:rgba(255,225,168,.10) !important;
  color:#fff3d9 !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 0 22px rgba(255,225,168,.10);
}

@media (max-width:760px){
  .oa-quality-badge,
  .oa-wall-quality-badge{
    min-height:28px;
    padding:0 12px !important;
    font-size:11px !important;
  }
}
