.p1lp-shell{
  box-sizing: border-box;
  width: 100%;
  padding-inline: clamp(12px, 2.2vw, 28px);
}

.p1lp, .p1lp *{ box-sizing: border-box; }

.p1lp-card{
  overflow: hidden;
  background: var(--bs-body-bg, #fff);
  color: var(--bs-body-color, #111);
  border: 1px solid rgba(0,0,0,0.10);
}

@media (prefers-color-scheme: dark){
  .p1lp-card{
    background: var(--bs-body-bg, #000000);
    color: var(--bs-body-color, rgba(255,255,255,0.92));
  }
}

.p1lp-head{
  font-weight: 850;
  margin-bottom: 36px;
}

.p1lp-empty{
  font-size: 1rem;
  opacity: .80;
}

.p1lp-list .p1lp-row{
  display:flex;
  gap: 14px;
  align-items:flex-start;
  padding-top: 16px;
  padding-bottom: 16px;
  background: transparent;
  color: inherit;
}

.p1lp-list .p1lp-row + .p1lp-row{
  border-top: 1px solid rgba(0,0,0,0.08);
}

@media (prefers-color-scheme: dark){
  .p1lp-list .p1lp-row + .p1lp-row{
    border-top-color: rgba(255,255,255,0.10);
  }
}

.p1lp.is-compact .p1lp-list .p1lp-row{
  padding-top: 12px;
  padding-bottom: 12px;
}

.p1lp-plain{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap: 10px;
}

.p1lp-plain-row{
  display:flex;
  gap: 14px;
  align-items:flex-start;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(0,0,0,0.04);
}

@media (prefers-color-scheme: dark){
  .p1lp-plain-row{ background: rgba(255,255,255,0.06); }
}

.p1lp-art{
  width:40px;
  height:40px;
  border-radius: 12px;
  flex: 0 0 auto;
}

.p1lp.is-compact .p1lp-art{
  width:32px;
  height:32px;
  border-radius: 11px;
}

.p1lp-main{ flex: 1; min-width: 0; }

.p1lp-line{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
}

.p1lp-title{
  min-width: 0;
  line-height: 1.35;
  font-weight: 650;
  overflow-wrap:anywhere;
  color: inherit;
}

.p1lp-artist{
  font-weight: 900;
  margin-right: 10px;
}

.p1lp-track{
  font-weight: 650;
}

.p1lp-time{
  flex: 0 0 auto;
  white-space: nowrap;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(0,0,0,0.08);
  color: inherit;
}

@media (prefers-color-scheme: dark){
  .p1lp-time{ background: rgba(255,255,255,0.12); }
}

@media (max-width: 520px){
  .p1lp-line{ flex-direction: column; align-items:flex-start; }
  .p1lp-time{ margin-top: 10px; }
}
