/* Airplay40 — Rows layout (horizontal three-column rows) */

/* Wrapper stacks rows with consistent gaps, centered with max width */
.airplay40 .ap40-rows {
  display: grid;
  gap: var(--ap40-gap, 12px);
  max-width: var(--ap40-rows-max, 800px);
  margin-inline: auto;
}

/* Single row item */
.airplay40 .ap40-row {
  background: var(--ap40-surface, #fff);
  color: var(--ap40-on-surface, #1d1b20);
  border: 1px solid color-mix(in oklab, var(--ap40-outline, #79747E) 40%, transparent);
  border-radius: var(--ap40-radius, 12px);
  box-shadow: var(--ap40-elev-1, 0 1px 2px rgba(0,0,0,.07));
  display: grid;
  grid-template-columns: var(--ap40-thumb, 96px) 1fr auto;
  align-items: center;
  gap: var(--ap40-gap, 12px);
  padding: 8px 12px;
}

/* Column 1 — artwork */
.airplay40 .ap40-row .ap40-media {
  width: var(--ap40-thumb, 96px);
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  overflow: hidden;
}

/* Smaller position pill in rows only (font size unchanged) */
.airplay40 .ap40-row .ap40-pos {
  padding: var(--ap40-row-pos-py, 2px) var(--ap40-row-pos-px, 6px);
  top: 6px;
  left: 6px;
}

/* Column 2 — text/meta */
.airplay40 .ap40-row .ap40-body {
  padding: 0;
  min-width: 0; /* allow shrink to avoid overflow */
}
.airplay40 .ap40-row .ap40-title,
.airplay40 .ap40-row .ap40-artist { overflow-wrap: anywhere; }

/* Column 3 — actions (desktop/tablet: horizontal inline) */
.airplay40 .ap40-row .ap40-actions {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: max-content;
}

/* Inline YouTube button in rows */
.airplay40 .ap40-row .ap40-play {
  position: static;
  width: auto; height: auto; border-radius: 8px;
  border: 0; background: transparent;
  color: var(--ap40-primary, #6750A4);
  padding: 6px;
}
.airplay40 .ap40-row .ap40-play:hover { background: color-mix(in oklab, var(--ap40-primary, #6750A4) 12%, transparent); }
.airplay40 .ap40-row .ap40-play:focus-visible { outline: 2px solid var(--ap40-primary, #6750A4); outline-offset: 2px; }

/* ===== Mobile: stack everything (image, title, artist, meta, icons) and center ===== */
@media (max-width: 640px) {
  .airplay40 .ap40-rows { padding-inline: 8px; }

  .airplay40 .ap40-row {
    /* one column; tight vertical rhythm */
    grid-template-columns: 1fr;
    column-gap: 0;
    row-gap: var(--ap40-row-gap-mobile, 8px);
    grid-auto-flow: row dense;
    text-align: center;
    padding: 12px;
  }

  /* Artwork now on row 1, centered and reasonably sized */
  .airplay40 .ap40-row .ap40-media {
    grid-column: 1; grid-row: 1;
    width: min(60vw, 160px);
    margin-inline: auto;
  }

  /* Let body’s children participate directly in the grid rows */
  .airplay40 .ap40-row .ap40-body { display: contents; }

  /* Row 2: Title */
  .airplay40 .ap40-row .ap40-title {
    grid-column: 1; grid-row: 2;
    font-size: clamp(1rem, 5.2vw, var(--ap40-title-size, 1.25rem));
    line-height: 1.15;
    margin: 2px 0 0;
  }

  /* Row 3: Artist (less spacing than before) */
  .airplay40 .ap40-row .ap40-artist {
    grid-column: 1; grid-row: 3;
    font-size: clamp(.9rem, 4.6vw, var(--ap40-artist-size, 1.1rem));
    line-height: 1.15;
    margin: 0; /* tighten title→artist space */
  }

  /* Row 4: META (LW / WOC / movement), centered and wrapping */
  .airplay40 .ap40-row .ap40-meta {
    grid-column: 1; grid-row: 4;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 12px;
    row-gap: 4px;
    margin-top: 2px;
    font-size: clamp(.85rem, 3.8vw, var(--ap40-meta-size, .95rem));
  }

  /* Row 5: ICONS, centered */
  .airplay40 .ap40-row .ap40-actions {
    grid-column: 1; grid-row: 5;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 14px;
    margin-top: 4px;
    width: 100%;
  }
}

/* Dark mode tweaks for rows */
.airplay40[data-theme="dark"], @media (prefers-color-scheme: dark) {
  .airplay40[data-theme="auto"] .ap40-row {
    background:#1F1B24; color:#ECE6F0;
    border-color: color-mix(in oklab, #BBB 20%, transparent);
  }
}
