/* ===========================================================================
   Dailies · Audio / Track Review  —  C-level Feed extension
   ---------------------------------------------------------------------------
   A Web Audio track over a decoded waveform that doubles as the timeline.
   The wave is the comment surface: click a moment or drag a range and a note
   anchors to that point/span in time, showing as a marker on the wave so the
   reviewer sees at a glance where feedback lands. The played portion of the
   wave fills gold behind the playhead. A span note can loop on repeat (A-B).
   Threads open in the right rail (a bottom sheet on mobile), mirroring the reel
   review. Self-contained, themed entirely from bsp-tokens.css / dailies-theme.css
   and loaded AFTER feed-styles.css so the .review--audio layout wins the cascade.
   =========================================================================== */

/* --- Shell: force a flex column so the desktop `.review { display:grid }`
   asset layout never imposes itself on the player. ------------------------- */
.review--audio { display: flex; flex-direction: column; }

.aud-body {
  flex: 1; min-height: 0;
  display: flex; flex-direction: column;
  position: relative;            /* anchor the mobile bottom sheet + backdrop */
}

/* --- The player column ---------------------------------------------------- */
.aud-main {
  flex: 1; min-height: 0;
  display: flex; flex-direction: column;
  padding: 8px 14px 12px;
  overflow: visible;             /* let marker tooltips escape upward */
}

.aud-ctx {
  flex-shrink: 0;
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  font-size: 12px; color: var(--bsp-fg-dim);
  margin-bottom: 12px;
}
.aud-ctx .ip {
  font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bsp-yellow);
  padding: 3px 8px;
  border: 1px solid var(--bsp-border-gold);
  border-radius: var(--bsp-radius-pill);
  font-size: 10px;
}
.aud-ctx .who strong { color: var(--bsp-fg-muted); font-weight: 500; }
.aud-ctx .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--bsp-fg-dim); }

/* --- Deck: cover tile (the play control) + track meta --------------------- */
.aud-deck {
  flex-shrink: 0;
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 16px;
}
.aud-cover {
  position: relative; flex: none;
  width: 108px; height: 108px;
  display: grid; place-items: center;
  border: 1px solid var(--bsp-border-hi);
  background: radial-gradient(ellipse at 32% 28%, var(--bsp-bg-elev) 0%, var(--bsp-bg-deep) 78%);
  cursor: pointer; overflow: hidden;
  box-shadow: var(--bsp-shadow-card);
  transition: border-color var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-cover:hover { border-color: var(--bsp-border-gold); }
.aud-cover-mono {
  font-family: var(--bsp-font-display);
  font-size: 30px; line-height: 1; letter-spacing: 0.04em;
  color: rgba(255, 210, 0, 0.16);
  text-align: center; padding: 0 6px;
  transition: opacity var(--bsp-dur-base) var(--bsp-ease-out);
}
.aud-cover.playing .aud-cover-mono { opacity: 0.4; }
.aud-cover-btn {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 46px; height: 46px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--bsp-yellow); color: var(--bsp-accent-on);
  box-shadow: var(--bsp-shadow-gold);
  transition: transform var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-cover-btn svg { transform: translateX(1px); }  /* optical center the play glyph */
.aud-cover.playing .aud-cover-btn svg { transform: none; }
.aud-cover:hover .aud-cover-btn { transform: translate(-50%, -50%) scale(1.06); }
/* Now-playing equalizer: animates only while the track runs */
.aud-eq {
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 22px; display: flex; align-items: flex-end; justify-content: center; gap: 3px;
  padding-bottom: 7px; opacity: 0; pointer-events: none;
  transition: opacity var(--bsp-dur-base) var(--bsp-ease-out);
}
.aud-cover.playing .aud-eq { opacity: 0.9; }
.aud-eq i { width: 3px; height: 5px; background: var(--bsp-yellow); border-radius: 999px; }
.aud-cover.playing .aud-eq i { animation: aud-eq 0.9s var(--bsp-ease-out) infinite; }
.aud-cover.playing .aud-eq i:nth-child(2) { animation-duration: 0.7s; animation-delay: 0.1s; }
.aud-cover.playing .aud-eq i:nth-child(3) { animation-duration: 1.05s; animation-delay: 0.05s; }
.aud-cover.playing .aud-eq i:nth-child(4) { animation-duration: 0.8s; animation-delay: 0.15s; }
@keyframes aud-eq { 0%, 100% { height: 5px; } 50% { height: 15px; } }

.aud-deck-meta { min-width: 0; display: flex; flex-direction: column; gap: 5px; }
.aud-deck-eyebrow {
  font-size: 9.5px; font-weight: 600; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--bsp-yellow);
}
.aud-deck-title {
  font-family: var(--bsp-font-display);
  font-size: clamp(22px, 3vw, 30px); line-height: 0.98; letter-spacing: 0.01em;
  color: var(--bsp-fg);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%;
}
.aud-deck-sub { font-size: 12px; color: var(--bsp-fg-dim); }

/* --- Stage: the waveform hero (the comment surface) ----------------------- */
.aud-stage { flex: 1; min-height: 0; display: flex; align-items: center; }
.aud-timeline {
  position: relative; width: 100%;
  padding: 20px 0 8px;           /* tooltips + point dots escape upward */
  overflow: visible;
}
.aud-wave {
  position: relative; width: 100%; height: 136px;
  background: var(--bsp-bg-deep);
  border: 1px solid var(--bsp-border);
  cursor: crosshair; touch-action: none; overflow: visible;
  --aud-wave: rgba(244, 246, 247, 0.20);
  --aud-wave-played: #FFD200;
}
.aud-wave-base { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: block; pointer-events: none; }
.aud-wave-fill {
  position: absolute; left: 0; top: 0; height: 100%; width: 0;
  overflow: hidden; pointer-events: none;
}
.aud-wave-fill canvas { position: absolute; left: 0; top: 0; height: 100%; display: block; }
.aud-wave-load {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-family: var(--bsp-font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--bsp-fg-dim); pointer-events: none;
  animation: aud-pulse 1.4s var(--bsp-ease-out) infinite;
}
@keyframes aud-pulse { 0%, 100% { opacity: 0.4; } 50% { opacity: 0.85; } }

/* --- Scrub strip + playhead span the wave + scrub one shared width --------- */
.aud-scrub {
  position: relative; height: 8px; margin-top: 8px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: var(--bsp-radius-pill);
  cursor: ew-resize; touch-action: none; overflow: hidden;
}
.aud-played {
  position: absolute; left: 0; top: 0; bottom: 0; width: 0;
  background: var(--bsp-yellow);
  border-radius: var(--bsp-radius-pill);
}
.aud-playhead {
  position: absolute; top: 20px; bottom: 8px; left: 0;
  width: 2px; background: var(--bsp-yellow);
  transform: translateX(-50%);
  pointer-events: auto; cursor: ew-resize; touch-action: none; z-index: 8;
  outline: none;
}
.aud-playhead::before {
  content: ""; position: absolute; left: 50%; top: 0; bottom: -14px;
  width: 28px; transform: translateX(-50%);
}
.aud-playhead::after {
  content: ""; position: absolute; left: 50%; bottom: -1px;
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--bsp-yellow);
  transform: translate(-50%, 30%);
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.55);
}
.aud-playhead:focus-visible::after {
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.55), 0 0 0 3px rgba(255, 210, 0, 0.32);
}
/* Live range painted while dragging the wave */
.aud-drag-band {
  position: absolute; top: 0; bottom: 0; left: 0; width: 0;
  display: none;
  background: rgba(255, 210, 0, 0.14);
  border: 1px dashed var(--bsp-yellow);
  pointer-events: none; z-index: 4;
}

/* --- Markers: a pin per moment, a band per range, sitting on the wave ------ */
.aud-mk {
  position: absolute; top: 0; bottom: 0;
  background: none; border: none; padding: 0; margin: 0;
  cursor: pointer; z-index: 5;
}
.aud-mk.point { width: 16px; transform: translateX(-50%); }
.aud-mk.point .aud-mk-stem {
  position: absolute; left: 50%; top: 0; bottom: 0; width: 2px;
  transform: translateX(-50%); background: var(--bsp-yellow); opacity: 0.55;
  transition: opacity var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-mk.point .aud-mk-dot {
  position: absolute; top: -1px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 10px; height: 10px; border-radius: 2px; background: var(--bsp-yellow);
  box-shadow: 0 0 0 3px var(--bsp-bg-deep);
  transition: box-shadow var(--bsp-dur-fast) var(--bsp-ease-out), background var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-mk.span {
  top: 0; bottom: 0;
  background: rgba(255, 210, 0, 0.14);
  border: 1px solid var(--bsp-border-gold);
  transition: background var(--bsp-dur-fast) var(--bsp-ease-out), border-color var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-mk.span .aud-mk-stem, .aud-mk.span .aud-mk-dot { display: none; }

/* resolved → drop to neutral so open notes keep the gold */
.aud-mk.resolved.point .aud-mk-dot { background: var(--bsp-fg-dim); }
.aud-mk.resolved.point .aud-mk-stem { background: var(--bsp-fg-dim); opacity: 0.4; }
.aud-mk.resolved.span { background: rgba(255, 255, 255, 0.05); border-color: var(--bsp-border-hi); }

/* draft → outlined, not filled */
.aud-mk.draft.point .aud-mk-dot { background: transparent; box-shadow: inset 0 0 0 1.5px var(--bsp-yellow), 0 0 0 3px var(--bsp-bg-deep); }
.aud-mk.draft.span { border-style: dashed; }

/* active / hover → emphasize */
.aud-mk:hover.point .aud-mk-dot,
.aud-mk.active.point .aud-mk-dot { box-shadow: 0 0 0 4px rgba(255, 210, 0, 0.26), 0 0 0 7px var(--bsp-bg-deep); }
.aud-mk:hover.point .aud-mk-stem,
.aud-mk.active.point .aud-mk-stem { opacity: 0.85; }
.aud-mk:hover.span,
.aud-mk.active.span { background: rgba(255, 210, 0, 0.26); border-color: var(--bsp-yellow); }

/* tooltip: timecode + first note, on hover or while focused */
.aud-mk-tip {
  position: absolute; bottom: calc(100% + 7px); left: 50%;
  transform: translateX(-50%) translateY(4px);
  width: max-content; max-width: 230px;
  background: var(--bsp-bg-elev);
  border: 1px solid var(--bsp-border-hi);
  border-radius: 9px; padding: 8px 11px;
  box-shadow: var(--bsp-shadow-card);
  text-align: left; opacity: 0; pointer-events: none; z-index: 30;
  transition: opacity var(--bsp-dur-fast) var(--bsp-ease-out), transform var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-mk.span .aud-mk-tip { left: 0; transform: translateX(0) translateY(4px); }
.aud-mk:hover .aud-mk-tip,
.aud-mk.active .aud-mk-tip { opacity: 1; transform: translateX(-50%) translateY(0); }
.aud-mk.span:hover .aud-mk-tip,
.aud-mk.span.active .aud-mk-tip { transform: translateX(0) translateY(0); }
.aud-mk-tip b { display: block; font-size: 11px; color: var(--bsp-yellow); font-variant-numeric: tabular-nums; letter-spacing: 0.04em; }
.aud-mk-tip .who { display: block; font-size: 10px; color: var(--bsp-fg-dim); margin-top: 3px; }
.aud-mk-tip em {
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  font-style: normal; font-size: 11.5px; line-height: 1.4; color: var(--bsp-fg-muted); margin-top: 3px; font-weight: 300;
}

/* --- Transport: play · clock · loop · comment ----------------------------- */
.aud-transport {
  flex-shrink: 0;
  display: flex; align-items: center; gap: 12px;
  padding-top: 14px;
}
.aud-play-sm {
  flex: none; width: 38px; height: 38px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--bsp-yellow); border: 1px solid var(--bsp-yellow); color: var(--bsp-accent-on);
  cursor: pointer; transition: background var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-play-sm:hover { background: var(--bsp-yellow-hi); border-color: var(--bsp-yellow-hi); }
.aud-play-sm svg { transform: translateX(1px); }
.aud-time {
  flex: none; min-width: 92px;
  font-family: var(--bsp-font-mono); font-size: 12px; color: var(--bsp-fg-dim);
  font-variant-numeric: tabular-nums; letter-spacing: 0.02em;
}
.aud-time span { color: var(--bsp-yellow); font-weight: 500; }
.aud-time i { font-style: normal; color: var(--bsp-fg-faint); margin: 0 3px; }
.aud-transport-gap { flex: 1; }

.aud-loop-btn, .aud-moment-btn {
  flex: none;
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--bsp-bg-card); border: 1px solid var(--bsp-border-hi);
  color: var(--bsp-fg); border-radius: var(--bsp-radius-pill);
  padding: 9px 15px; cursor: pointer;
  font-family: var(--bsp-font-body); font-size: 12px; font-weight: 600; letter-spacing: 0.04em;
  transition: border-color var(--bsp-dur-fast) var(--bsp-ease-out), background var(--bsp-dur-fast) var(--bsp-ease-out),
              color var(--bsp-dur-fast) var(--bsp-ease-out), transform var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-loop-btn svg, .aud-moment-btn svg { stroke: var(--bsp-yellow); fill: none; stroke-width: 2; }
.aud-moment-btn { border-color: var(--bsp-border-gold); }
.aud-loop-btn:hover:not(:disabled), .aud-moment-btn:hover { border-color: var(--bsp-yellow); transform: translateY(-1px); }
.aud-loop-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.aud-loop-btn.on {
  background: var(--bsp-yellow); border-color: var(--bsp-yellow); color: var(--bsp-accent-on);
}
.aud-loop-btn.on svg { stroke: var(--bsp-accent-on); }

.aud-hint {
  flex-shrink: 0;
  margin-top: 9px; font-size: 11px; color: var(--bsp-fg-dim); font-weight: 300; letter-spacing: 0.01em;
}

/* --- The notes rail (mirrors the reel rail) ------------------------------- */
.aud-rail {
  display: flex; flex-direction: column; min-height: 0;
  background: var(--bsp-bg-deep);
}
.aud-sheet-handle { display: none; }
.aud-rail-head {
  flex-shrink: 0; display: flex; align-items: center; gap: 10px;
  padding: 16px 18px 14px;
  border-bottom: 1px solid var(--bsp-border);
}
.aud-rail-lbl {
  font-size: 9.5px; font-weight: 600; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--bsp-yellow);
}
.aud-rail-count { font-size: 11px; color: var(--bsp-fg-dim); letter-spacing: 0.02em; }
.aud-sheet-close {
  margin-left: auto; display: none;
  background: none; border: none; color: var(--bsp-fg-dim);
  font-size: 22px; line-height: 1; cursor: pointer; padding: 0 4px;
}
.aud-rail-scroll {
  flex: 1; min-height: 0; overflow-y: auto;
  padding: 14px; display: flex; flex-direction: column; gap: 12px;
}
.aud-rail-empty {
  font-size: 13px; line-height: 1.55; color: var(--bsp-fg-dim);
  font-weight: 300; padding: 8px 4px;
}

/* --- Thread card ---------------------------------------------------------- */
.aud-card {
  background: var(--bsp-bg-elev);
  border: 1px solid var(--bsp-border);
  border-radius: var(--bsp-radius-1);
  padding: 13px 14px; cursor: pointer;
  transition: border-color var(--bsp-dur-fast) var(--bsp-ease-out),
              box-shadow var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-card:hover { border-color: var(--bsp-border-hi); }
.aud-card.active {
  border-color: var(--bsp-border-gold);
  box-shadow: 0 0 0 1px var(--bsp-border-gold), var(--bsp-shadow-card);
  cursor: default;
}
.aud-card.resolved { opacity: 0.72; }
.aud-card.resolved.active { opacity: 1; }

.aud-card-tc {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 11px;
  font-family: var(--bsp-font-mono);
  font-size: 12.5px; font-weight: 600; color: var(--bsp-yellow);
  font-variant-numeric: tabular-nums; letter-spacing: 0.03em;
}
.aud-tc-glyph { flex: none; width: 9px; height: 9px; background: var(--bsp-yellow); }
.aud-tc-glyph.point { transform: rotate(45deg); border-radius: 2px; }
.aud-tc-glyph.span { width: 16px; height: 7px; border-radius: 2px; }
.aud-tc-time { letter-spacing: 0.04em; }
.aud-tc-kind {
  margin-left: auto; font-size: 9px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bsp-fg-dim); font-family: var(--bsp-font-body);
}
.aud-card.resolved .aud-card-tc { color: var(--bsp-fg-dim); }
.aud-card.resolved .aud-tc-glyph { background: var(--bsp-fg-dim); }

.aud-resolved-tag {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 9.5px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase;
  color: #7fd1a8; margin-bottom: 10px;
}
.aud-resolved-tag svg { width: 11px; height: 11px; stroke: currentColor; fill: none; stroke-width: 2.4; }

.aud-c { display: flex; gap: 10px; margin-bottom: 11px; }
.aud-c:last-child { margin-bottom: 0; }
.aud-c-av {
  width: 27px; height: 27px; flex-shrink: 0;
  border-radius: var(--bsp-radius-pill);
  background: var(--bsp-navy-light); border: 1px solid var(--bsp-border-hi);
  color: var(--bsp-fg-muted);
  display: flex; align-items: center; justify-content: center;
  font-size: 9.5px; font-weight: 600; letter-spacing: 0.04em;
}
.aud-c-av.me { background: var(--bsp-yellow); color: var(--bsp-accent-on); border-color: var(--bsp-yellow); }
.aud-c-body { min-width: 0; flex: 1; }
.aud-c-head { display: flex; align-items: baseline; gap: 7px; flex-wrap: wrap; margin-bottom: 2px; }
.aud-c-head .n { font-size: 12px; font-weight: 500; color: var(--bsp-fg); }
.aud-c-head .r { font-size: 10px; color: var(--bsp-fg-dim); }
.aud-c-head .w { font-size: 10px; color: var(--bsp-fg-dim); margin-left: auto; }
.aud-c-text { font-size: 13px; line-height: 1.5; color: var(--bsp-fg-muted); font-weight: 300; }

/* --- Composer ------------------------------------------------------------- */
.aud-composer {
  display: flex; align-items: flex-end; gap: 7px;
  margin-top: 11px; padding-top: 11px;
  border-top: 1px solid var(--bsp-border);
}
.aud-input {
  flex: 1; min-width: 0;
  background: var(--bsp-bg-card); border: 1px solid var(--bsp-border-hi);
  border-radius: 11px; color: var(--bsp-fg);
  font-family: var(--bsp-font-body); font-size: 13px; line-height: 1.45;
  padding: 8px 11px; resize: none; min-height: 38px; max-height: 140px;
  outline: none; transition: border-color var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-input:focus { border-color: var(--bsp-border-gold); }
.aud-input::placeholder { color: var(--bsp-fg-dim); }
.aud-mic, .aud-send-c, .aud-cancel {
  flex-shrink: 0; width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; border: 1px solid var(--bsp-border-hi); background: var(--bsp-bg-card);
  color: var(--bsp-fg-muted); transition: all var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-mic:hover, .aud-cancel:hover { border-color: var(--bsp-border-hi); color: var(--bsp-fg); transform: translateY(-1px); }
.aud-mic svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 2; }
.aud-send-c { background: var(--bsp-yellow); border-color: var(--bsp-yellow); color: var(--bsp-accent-on); }
.aud-send-c svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 2; }
.aud-send-c:hover { background: var(--bsp-yellow-hi); border-color: var(--bsp-yellow-hi); transform: translateY(-1px); }
.aud-send-c:disabled { opacity: 0.4; cursor: not-allowed; transform: none; }
.aud-cancel { width: 34px; height: 34px; font-size: 18px; line-height: 1; }

/* --- Card footer (resolve / reopen) --------------------------------------- */
.aud-card-foot { display: flex; align-items: center; gap: 12px; margin-top: 11px; }
.aud-resolve, .aud-reopen {
  display: inline-flex; align-items: center; gap: 6px;
  background: none; border: none; cursor: pointer; padding: 2px 0;
  font-family: var(--bsp-font-body); font-size: 11px; font-weight: 600;
  letter-spacing: 0.04em; color: var(--bsp-fg-dim);
  transition: color var(--bsp-dur-fast) var(--bsp-ease-out);
}
.aud-resolve:hover { color: #7fd1a8; }
.aud-reopen:hover { color: var(--bsp-yellow); }
.aud-resolve svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2.2; }

/* --- Footer action bar ---------------------------------------------------- */
.aud-foot {
  flex-shrink: 0; display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 14px 18px calc(env(safe-area-inset-bottom, 0px) + 16px);
  border-top: 1px solid var(--bsp-border);
}
.aud-foot-meta { font-size: 12px; color: var(--bsp-fg-dim); display: flex; align-items: center; gap: 10px; }
.aud-foot-meta strong { color: var(--bsp-fg-muted); font-weight: 600; }
.aud-foot-open { color: var(--bsp-yellow); font-weight: 500; }
.aud-foot-actions { display: flex; align-items: center; gap: 10px; }
.aud-notes-toggle {
  background: var(--bsp-bg-card); border: 1px solid var(--bsp-border-hi);
  color: var(--bsp-fg-muted); border-radius: var(--bsp-radius-pill);
  padding: 9px 16px; cursor: pointer;
  font-family: var(--bsp-font-body); font-size: 12px; font-weight: 600; letter-spacing: 0.04em;
}

/* --- Mobile bottom sheet + backdrop --------------------------------------- */
.aud-sheet-backdrop {
  position: absolute; inset: 0; z-index: 18;
  background: rgba(0, 0, 0, 0.5);
  animation: aud-fade 0.25s var(--bsp-ease-out);
}
@keyframes aud-fade { from { opacity: 0; } }

@media (max-width: 1099px) {
  /* The feed frame grows with its content; pin the review to the viewport so
     the sheet and footer stay on-screen. */
  .review--audio { position: fixed; inset: 0; height: 100dvh; }
  .aud-stage { flex: none; }
  .aud-wave { height: 104px; }
  .aud-notes-toggle { display: inline-flex; align-items: center; }
  .aud-rail {
    position: absolute; left: 0; right: 0; bottom: 0; z-index: 20;
    max-height: 76%;
    background: var(--bsp-bg-elev);
    border-top: 1px solid var(--bsp-border-hi);
    border-radius: 18px 18px 0 0;
    box-shadow: 0 -20px 50px -20px rgba(0, 0, 0, 0.7);
    transform: translateY(101%);
    transition: transform var(--bsp-dur-base) var(--bsp-ease-out);
    pointer-events: none;
  }
  .aud-rail.sheet-open { transform: translateY(0); pointer-events: auto; }
  .aud-sheet-handle {
    display: block; width: 40px; height: 4px; border-radius: 999px;
    background: var(--bsp-border-hi); margin: 9px auto 2px;
  }
  .aud-sheet-close { display: block; }
  .aud-rail-head { padding-top: 8px; }
}

@media (max-width: 480px) {
  .aud-loop-btn span, .aud-moment-btn span { display: none; }  /* icon-only on the narrowest screens */
  .aud-loop-btn, .aud-moment-btn { padding: 9px 11px; }
  .aud-time { min-width: 0; }
  .aud-cover { width: 88px; height: 88px; }
  .aud-cover-mono { font-size: 24px; }
}

@media (min-width: 1100px) {
  .aud-notes-toggle { display: none; }
  .aud-sheet-backdrop { display: none; }
  .aud-body {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 384px;
    grid-template-rows: minmax(0, 1fr);
  }
  .aud-rail { border-left: 1px solid var(--bsp-border); }
  .aud-main { padding: 22px 28px; }
  .aud-foot { padding: 16px 40px; }
}

/* --- Reduced motion: keep it instant -------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .aud-mk, .aud-mk-tip, .aud-mk-dot, .aud-mk-stem, .aud-loop-btn, .aud-moment-btn,
  .aud-play-sm, .aud-cover, .aud-cover-btn, .aud-cover-mono, .aud-card, .aud-rail { transition: none; }
  .aud-cover.playing .aud-eq i { animation: none; }
  .aud-eq i { height: 9px; }
  .aud-wave-load { animation: none; }
  .aud-sheet-backdrop { animation: none; }
}
