/* ───────────────  Transcription page  ─────────────── */
.tx-head { display: flex; flex-wrap: wrap; align-items: flex-start; justify-content: space-between; gap: var(--sp-4); margin-bottom: var(--sp-5); }
.tx-back { font-size: 13px; color: var(--text-violet); font-weight: 600; }
.tx-back:hover { color: var(--violet-alt); }
.tx-head h1 { font-family: var(--font-display); font-weight: 700; font-size: 26px; letter-spacing: -0.02em; margin-top: var(--sp-2); }
.tx-sub { color: var(--text-secondary); font-size: 14px; margin-top: var(--sp-1); }
.tx-actions { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.tx-actions .btn { min-height: 40px; padding: 0 var(--sp-4); font-size: 13px; }

.tx-search { margin-bottom: var(--sp-5); }
.tx-search .input { width: 100%; }

.tx-segments { display: grid; gap: var(--sp-1); }
.tx-seg {
  display: grid;
  grid-template-columns: 64px 1fr auto;
  gap: var(--sp-3);
  align-items: start;
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
}
.tx-seg:hover { background: var(--bg-card); border-color: var(--border-subtle); }
.tx-seg__time { font-family: var(--font-mono); font-size: 12px; color: var(--text-muted); padding-top: 2px; }
.tx-seg.no-time { grid-template-columns: 1fr auto; }
.tx-seg__text { font-size: 14.5px; line-height: 1.6; color: var(--text-primary); }
.tx-seg__text mark { background: rgba(108, 92, 231, 0.35); color: var(--text-primary); border-radius: 3px; padding: 0 2px; }
.tx-seg__tools { display: flex; gap: var(--sp-1); opacity: 0; transition: opacity 0.15s ease; }
.tx-seg:hover .tx-seg__tools, .tx-seg:focus-within .tx-seg__tools { opacity: 1; }
.tx-seg__jump { color: var(--text-violet); }
.tx-seg__jump:hover { color: var(--violet-alt); background: var(--bg-hover); }

/* Picker (no video selected) */
.tx-picker h1 { font-family: var(--font-display); font-weight: 700; font-size: 26px; letter-spacing: -0.02em; margin-bottom: var(--sp-2); }
.tx-picker > p { color: var(--text-secondary); font-size: 14px; margin-bottom: var(--sp-6); }
.picker-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-4); }
.picker-card {
  display: flex; flex-direction: column; gap: var(--sp-2);
  padding: var(--sp-5);
  background: var(--bg-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg);
}
.picker-card:hover { border-color: var(--border); transform: translateY(-2px); box-shadow: var(--violet-glow); }
.picker-card__icon {
  width: 42px; height: 42px; display: grid; place-items: center;
  border-radius: var(--radius-md); background: var(--violet-dim); color: var(--violet-alt);
  margin-bottom: var(--sp-2);
}
.picker-card__name { font-family: var(--font-display); font-weight: 600; font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.picker-card__meta { display: flex; align-items: center; gap: var(--sp-2); font-size: 12.5px; color: var(--text-muted); }
.picker-card__go { margin-top: auto; color: var(--text-violet); font-size: 13px; font-weight: 600; padding-top: var(--sp-2); }

@media (min-width: 481px) { .picker-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 769px) { .picker-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 769px) { .tx-head h1 { font-size: 28px; } }

/* Touch devices have no hover to reveal the per-line tools — always show them. */
@media (hover: none) {
  .tx-seg__tools { opacity: 1; }
}

/* Compact layout on small screens */
@media (max-width: 600px) {
  .tx-head { flex-direction: column; gap: var(--sp-3); margin-bottom: var(--sp-4); }
  .tx-head h1 { font-size: 21px; margin-top: var(--sp-1); }
  .tx-sub { font-size: 12.5px; }
  .tx-actions { width: 100%; gap: var(--sp-2); }
  .tx-actions .btn { flex: 1 1 auto; min-height: 38px; padding: 0 var(--sp-3); font-size: 12.5px; }
  .tx-search { margin-bottom: var(--sp-4); }
  .tx-segments { gap: 2px; }
  .tx-seg { padding: var(--sp-2) var(--sp-3); gap: var(--sp-2); }
  .tx-seg__time { font-size: 11px; padding-top: 1px; }
  .tx-seg__text { font-size: 13.5px; line-height: 1.5; }
  .tx-picker h1 { font-size: 21px; }
  .tx-picker > p { font-size: 13px; margin-bottom: var(--sp-5); }
  .picker-card { padding: var(--sp-4); }
  .picker-card__icon { width: 36px; height: 36px; }
  .picker-card__name { font-size: 14px; }
}

@media (max-width: 480px) {
  .tx-seg { grid-template-columns: 46px 1fr; gap: var(--sp-2); }
  .tx-seg.no-time { grid-template-columns: 1fr; }
  .tx-seg__tools { grid-column: 1 / -1; opacity: 1; justify-content: flex-end; gap: var(--sp-2); margin-top: 2px; }
  .icon-btn { width: 34px; height: 34px; }   /* easier touch targets */
}
