/* Shared A/B comparison row component.
   Used on /demos (dark default) and product pages /foxfire and /autocatalysis
   (add `.is-light` modifier for the cream theme).

   Multi-take rows use `.ab-toggle button[data-src]` for Dry / Wet 1 / Wet 2.
   Single-take rows omit `.ab-toggle` and put `data-src` on the row itself --
   layout collapses to 4 columns and the take-caption row is hidden. */

.ab-row {
  /* Dark theme defaults */
  --ab-bg: rgba(255, 255, 255, 0.022);
  --ab-bg-hover: rgba(255, 255, 255, 0.035);
  --ab-bg-playing: color-mix(in srgb, var(--product-accent) 5%, transparent);
  --ab-border: rgba(206, 234, 228, 0.08);
  --ab-border-hover: rgba(206, 234, 228, 0.16);
  --ab-border-playing: color-mix(in srgb, var(--product-accent) 42%, transparent);
  --ab-label: hsl(180 14% 91% / 0.92);
  --ab-label-playing: var(--product-accent);
  --ab-source: hsl(187 3% 55%);
  --ab-take-cap: hsl(180 14% 91% / 0.55);
  --ab-take-cap-active: hsl(180 14% 91% / 0.78);
  --ab-play-ring: rgba(255, 255, 255, 0.2);
  --ab-play-fg: hsl(180 14% 91% / 0.85);
  --ab-play-active-bg: color-mix(in srgb, var(--product-accent) 14%, transparent);
  --ab-toggle-ring: rgba(255, 255, 255, 0.14);
  --ab-toggle-bg: rgba(255, 255, 255, 0.025);
  --ab-toggle-text: hsl(180 14% 91% / 0.55);
  --ab-toggle-text-hover: hsl(180 14% 91% / 0.9);
  --ab-toggle-active-text: hsl(190 12% 8%);
  --ab-track: rgba(255, 255, 255, 0.1);
  --ab-time: hsl(187 3% 55%);
  --product-accent: #3DD7B3;

  display: grid;
  grid-template-columns: minmax(220px, 1.2fr) 56px auto minmax(140px, 1fr) 96px;
  grid-template-rows: auto auto;
  column-gap: 20px;
  row-gap: 8px;
  align-items: center;
  padding: 18px 18px 16px;
  margin: 0 0 12px;
  background: var(--ab-bg);
  border: 1px solid var(--ab-border);
  border-radius: 12px;
  transition: background 220ms ease, border-color 220ms ease;
}

.ab-row[data-product="foxfire"]       { --product-accent: #3DD7B3; }
.ab-row[data-product="autocatalysis"] { --product-accent: #E56A3E; }
.ab-row[data-product="soliton"]       { --product-accent: #75CEE0; }

.ab-row:hover {
  background: var(--ab-bg-hover);
  border-color: var(--ab-border-hover);
}
.ab-row[data-state="playing"] {
  background: var(--ab-bg-playing);
  border-color: var(--ab-border-playing);
}
.ab-row[data-state="missing"] { opacity: 0.55; }

/* Single-take rows -- no toggle column, no take caption */
.ab-row.is-single {
  grid-template-columns: minmax(220px, 1.2fr) 56px minmax(160px, 1fr) 96px;
  grid-template-rows: auto;
  padding: 18px 18px;
}
.ab-row.is-single .ab-progress { grid-column: 3; }
.ab-row.is-single .ab-time { grid-column: 4; }
.ab-row.is-single .ab-take-caption { display: none; }

/* Compact rows -- used on the homepage demo section where space is tight */
.ab-row.is-compact {
  grid-template-columns: minmax(180px, 1.1fr) 38px auto minmax(120px, 1fr) 64px;
  grid-template-rows: auto;
  column-gap: 14px;
  padding: 10px 14px;
  margin-bottom: 8px;
  border-radius: 10px;
}
.ab-row.is-compact .ab-take-caption { display: none; }
.ab-row.is-compact .ab-meta-label {
  font-size: 11px;
  margin-bottom: 1px;
}
.ab-row.is-compact .ab-meta-source { font-size: 11px; }
.ab-row.is-compact .ab-play { width: 36px; height: 36px; }
.ab-row.is-compact .ab-play svg { width: 14px; height: 14px; }
.ab-row.is-compact .ab-toggle { padding: 2px; }
.ab-row.is-compact .ab-toggle button {
  padding: 4px 9px;
  font-size: 10px;
  letter-spacing: 0.12em;
}
.ab-row.is-compact .ab-time { font-size: 11px; }

.ab-meta { grid-column: 1; grid-row: 1; min-width: 0; }
.ab-meta-label {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ab-label);
  margin-bottom: 4px;
  transition: color 200ms ease;
}
.ab-row[data-state="playing"] .ab-meta-label { color: var(--ab-label-playing); }
.ab-meta-source { font-size: 13px; color: var(--ab-source); }

.ab-play {
  grid-column: 2; grid-row: 1;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid var(--ab-play-ring);
  background: transparent;
  color: var(--ab-play-fg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 200ms ease, border-color 200ms ease, color 200ms ease, transform 180ms ease;
}
.ab-play:hover:not(:disabled) {
  background: var(--ab-play-active-bg);
  border-color: var(--product-accent);
  color: var(--product-accent);
  transform: scale(1.04);
}
.ab-play:disabled { cursor: not-allowed; opacity: 0.45; }
.ab-play svg { width: 16px; height: 16px; display: block; }
.ab-play .icon-pause { display: none; }
.ab-row[data-state="playing"] .ab-play {
  background: var(--ab-play-active-bg);
  border-color: var(--product-accent);
  color: var(--product-accent);
}
.ab-row[data-state="playing"] .ab-play .icon-play { display: none; }
.ab-row[data-state="playing"] .ab-play .icon-pause { display: block; }

.ab-toggle {
  grid-column: 3; grid-row: 1;
  display: inline-flex;
  padding: 3px;
  border: 1px solid var(--ab-toggle-ring);
  border-radius: 999px;
  background: var(--ab-toggle-bg);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.ab-toggle button {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--ab-toggle-text);
  padding: 6px 12px;
  border-radius: 999px;
  cursor: pointer;
  font-family: inherit;
  font-size: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  transition: background 180ms ease, color 180ms ease;
  white-space: nowrap;
}
.ab-toggle button:hover { color: var(--ab-toggle-text-hover); }
.ab-toggle button[aria-pressed="true"] {
  background: var(--product-accent);
  color: var(--ab-toggle-active-text);
  font-weight: 500;
}

.ab-progress {
  grid-column: 4; grid-row: 1;
  position: relative;
  height: 24px;
  display: flex;
  align-items: center;
  cursor: pointer;
  min-width: 140px;
}
.ab-progress-track {
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--ab-track);
  border-radius: 1px;
}
.ab-progress-fill {
  position: absolute;
  left: 0;
  top: 50%;
  height: 2px;
  margin-top: -1px;
  width: 0%;
  background: var(--product-accent);
  border-radius: 1px;
  transition: width 80ms linear;
}
.ab-progress-thumb {
  position: absolute;
  left: 0%;
  top: 50%;
  width: 10px;
  height: 10px;
  margin-top: -5px;
  margin-left: -5px;
  border-radius: 999px;
  background: var(--product-accent);
  box-shadow: 0 0 10px color-mix(in srgb, var(--product-accent) 50%, transparent);
  transition: left 80ms linear, opacity 200ms ease;
  opacity: 0;
}
.ab-row[data-state="playing"] .ab-progress-thumb,
.ab-row[data-state="paused"] .ab-progress-thumb { opacity: 1; }

.ab-time {
  grid-column: 5; grid-row: 1;
  font-family: var(--font-mono);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
  color: var(--ab-time);
  text-align: right;
  white-space: nowrap;
}

.ab-take-caption {
  grid-column: 1 / -1; grid-row: 2;
  font-family: var(--font-body);
  font-size: 13px;
  font-style: italic;
  color: var(--ab-take-cap);
  margin: 4px 0 0;
  min-height: 18px;
  transition: color 220ms ease, opacity 220ms ease;
}
.ab-row[data-state="playing"] .ab-take-caption { color: var(--ab-take-cap-active); }

/* Light theme (cream/paper backgrounds, used on product pages) */
.ab-row.is-light {
  --ab-bg: transparent;
  --ab-bg-hover: rgba(0, 0, 0, 0.025);
  --ab-bg-playing: color-mix(in srgb, var(--product-accent) 7%, transparent);
  --ab-border: rgba(0, 0, 0, 0.10);
  --ab-border-hover: rgba(0, 0, 0, 0.20);
  --ab-border-playing: color-mix(in srgb, var(--product-accent) 50%, transparent);
  --ab-label: hsl(190 16% 12%);
  --ab-label-playing: hsl(190 16% 12%);
  --ab-source: hsl(190 6% 36%);
  --ab-take-cap: hsl(190 6% 36% / 0.85);
  --ab-take-cap-active: hsl(190 16% 12%);
  --ab-play-ring: hsl(190 16% 12% / 0.3);
  --ab-play-fg: hsl(190 16% 12%);
  --ab-play-active-bg: color-mix(in srgb, var(--product-accent) 18%, transparent);
  --ab-toggle-ring: hsl(190 16% 12% / 0.18);
  --ab-toggle-bg: rgba(0, 0, 0, 0.025);
  --ab-toggle-text: hsl(190 6% 36%);
  --ab-toggle-text-hover: hsl(190 16% 12%);
  --ab-toggle-active-text: hsl(0 0% 100%);
  --ab-track: hsl(190 16% 12% / 0.16);
  --ab-time: hsl(190 6% 36%);
}

@media (max-width: 800px) {
  .ab-row {
    grid-template-columns: 1fr 44px;
    grid-template-areas:
      "meta play"
      "toggle toggle"
      "progress progress"
      "time time"
      "caption caption";
    column-gap: 12px;
    row-gap: 10px;
  }
  .ab-meta { grid-area: meta; }
  .ab-play { grid-area: play; }
  .ab-toggle { grid-area: toggle; justify-self: stretch; }
  .ab-toggle button { flex: 1; text-align: center; }
  .ab-progress { grid-area: progress; }
  .ab-time { grid-area: time; text-align: left; }
  .ab-take-caption { grid-area: caption; margin-top: 0; }

  .ab-row.is-single {
    grid-template-columns: 1fr 44px;
    grid-template-areas:
      "meta play"
      "progress progress"
      "time time";
  }

  .ab-row.is-compact {
    grid-template-columns: 1fr 36px;
    grid-template-areas:
      "meta play"
      "toggle toggle"
      "progress progress"
      "time time";
    column-gap: 10px;
    row-gap: 8px;
    padding: 12px 12px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ab-progress-fill, .ab-progress-thumb { transition: none; }
}
