/* shared-transcribe-widget.css — drop-in upload-and-transcribe widget.
 * Mounts into any `<div data-whip-transcribe>` element on any page.
 * All selectors prefixed `wts-` to avoid colliding with host-page CSS. */

.wts {
  /* Aligned to whipscribe.com landing 2026-05-08:
     - Slate ink scale for body/labels (matches landing prose).
     - Lime/chartreuse primary CTA (#c5f44f → #a3dc2d) — same gradient as the
       landing sign-up pill rendered by shared-nav.js (.whip-signup).
     - Forest green text on lime CTA (#14532d), lime border (#8bc220).
     - Card bg neutral so the lime button reads as the only accent. */
  --wts-ink: #0f172a;
  --wts-ink-2: #334155;
  --wts-ink-3: #64748b;
  --wts-bg: #f7fbf3;
  --wts-bg-card: #ffffff;
  --wts-border: #e2e8f0;
  --wts-border-2: #cbd5e1;
  --wts-brand: #c5f44f;
  --wts-brand-deep: #a3dc2d;
  --wts-brand-text: #14532d;
  --wts-brand-border: #8bc220;
  --wts-err: #b8424c;
  --wts-radius: 16px;
  background: var(--wts-bg);
  border: 1px solid var(--wts-border);
  border-radius: var(--wts-radius);
  padding: 22px;
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif;
  color: var(--wts-ink);
  line-height: 1.4;
}

.wts-h {
  display: flex; align-items: center; gap: 10px;
  font-weight: 600; font-size: 15px; margin: 0 0 14px;
}
.wts-h svg { flex: 0 0 18px; opacity: 0.85; }

.wts-form {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: 8px;
  align-items: stretch;
}
@media (max-width: 720px) {
  .wts-form { grid-template-columns: 1fr; }
  .wts-or { text-align: center; }
}

.wts-url {
  font: inherit; color: var(--wts-ink);
  background: var(--wts-bg-card);
  border: 1px solid var(--wts-border-2); border-radius: 10px;
  padding: 10px 12px; min-width: 0; outline: none;
  transition: border-color 0.15s;
}
.wts-url:focus { border-color: var(--wts-brand-deep); box-shadow: 0 0 0 3px rgba(197, 244, 79, 0.30); }

.wts-or {
  align-self: center; color: var(--wts-ink-3); font-size: 13px;
  padding: 0 4px;
}

.wts-file-label {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--wts-bg-card); border: 1px dashed var(--wts-border-2);
  border-radius: 10px; padding: 10px 14px; cursor: pointer;
  font-size: 14px; color: var(--wts-ink-2);
  transition: border-color 0.15s, color 0.15s;
}
.wts-file-label:hover { border-color: var(--wts-brand-deep); color: var(--wts-ink); }
.wts-file { position: absolute; opacity: 0; pointer-events: none; width: 0; height: 0; }
.wts-file-label.is-set { color: var(--wts-ink); border-style: solid; }
.wts-file-text { white-space: nowrap; max-width: 220px; overflow: hidden; text-overflow: ellipsis; }

.wts-go {
  font: inherit; font-weight: 700;
  background: linear-gradient(135deg, var(--wts-brand), var(--wts-brand-deep));
  color: var(--wts-brand-text);
  border: 1px solid var(--wts-brand-border); border-radius: 999px;
  padding: 10px 22px; cursor: pointer;
  box-shadow: 0 1px 0 rgba(20, 83, 45, 0.08);
  transition: filter 0.18s, transform 0.12s, box-shadow 0.18s;
}
.wts-go:not(:disabled):hover {
  filter: brightness(1.05); transform: translateY(-1px);
  box-shadow: 0 3px 10px rgba(139, 194, 32, 0.35);
}
.wts-go:disabled { opacity: 0.45; cursor: not-allowed; }
.wts-go:not(:disabled):hover { transform: translateY(-1px); }
.wts-go:not(:disabled):active { transform: translateY(0); }

.wts-note {
  margin: 12px 0 0; font-size: 13px; color: var(--wts-ink-2);
}
.wts-note a { color: #14532d; text-decoration: underline; }

.wts-rows {
  margin-top: 18px;
  display: grid; gap: 12px;
}
.wts-row {
  display: grid; grid-template-columns: 28px 1fr auto;
  gap: 12px 14px; align-items: center;
  background: var(--wts-bg-card);
  border: 1px solid var(--wts-border);
  border-radius: 12px;
  padding: 14px 16px;
  font-size: 14px;
}
.wts-row-icon {
  width: 28px; height: 28px; border-radius: 8px;
  background: rgba(101, 163, 13, 0.08);
  color: #4d7c0f;
  display: grid; place-items: center;
  grid-row: span 2;
}
.wts-row-icon svg { width: 16px; height: 16px; }
.wts-row-name {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  color: var(--wts-ink); font-weight: 600;
}
.wts-row-link {
  font-weight: 700; color: #14532d;
  text-decoration: underline; text-underline-offset: 3px;
  white-space: nowrap;
}
.wts-row-link:hover { text-decoration: underline; }
.wts-row-status {
  grid-column: 2 / 4;
  color: var(--wts-ink-2); font-size: 13px;
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.wts-row-status.is-error { color: var(--wts-err); }
.wts-row-status .wts-safe {
  font-size: 12px; color: #4d7c0f; font-weight: 500;
  background: rgba(101, 163, 13, 0.08);
  padding: 2px 8px; border-radius: 999px;
  white-space: nowrap;
}

/* Thick green progress bar with shimmer + comets — same visual treatment
   as the home page upload card so the experience is identical across
   surfaces. Mounts inside the row when an upload/transcribe is active. */
.wts-row-progress {
  grid-column: 2 / 4;
  position: relative; overflow: hidden;
  height: 22px; border-radius: 999px;
  background: rgba(20, 83, 45, 0.06);
  border: 1px solid rgba(20, 83, 45, 0.15);
  box-shadow: inset 0 1px 3px rgba(20, 83, 45, 0.10);
  margin-top: 4px;
}
.wts-row-progress > span {
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 0%;
  border-radius: inherit;
  background: linear-gradient(90deg,
    #4d7c0f 0%, #65a30d 25%, #84cc16 55%, #a3dc2d 80%, #c5f44f 100%);
  box-shadow: 0 0 12px rgba(163, 220, 45, 0.65);
  transition: width 0.3s cubic-bezier(0.2, 0.7, 0.3, 1);
}
.wts-row-progress > span::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg,
    transparent 0%, rgba(255,255,255,0.45) 50%, transparent 100%);
  animation: wts-shimmer 1.2s linear infinite;
  pointer-events: none;
}
.wts-row-progress > span::after {
  content: ''; position: absolute;
  right: -10px; top: -7px; bottom: -7px; width: 30px;
  pointer-events: none;
  background: radial-gradient(ellipse at 32% center,
    rgba(254, 252, 191, 0.95) 0%,
    rgba(220, 252, 95, 0.80) 25%,
    rgba(163, 220, 45, 0.45) 50%,
    transparent 100%);
  filter: blur(2.5px);
  animation: wts-flicker 0.45s ease-in-out infinite alternate;
}
.wts-row-progress.is-indeterminate > span {
  width: 35% !important;
  animation: wts-indet 1.6s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}
.wts-row-progress[hidden] { display: none; }
.wts-row-progress-label {
  position: absolute; inset: 0; z-index: 2;
  display: flex; align-items: center; justify-content: center;
  height: 100%; width: 100%;
  font: 800 12px/1 inherit;
  color: #14532d; letter-spacing: 0.04em;
  text-shadow: 0 0 4px rgba(255, 255, 255, 0.7);
}
@keyframes wts-shimmer {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}
@keyframes wts-flicker {
  0%   { opacity: 0.55; transform: scale(0.92, 0.94); }
  100% { opacity: 1.00; transform: scale(1.18, 1.10); }
}
@keyframes wts-indet {
  0%   { left: -40%; }
  100% { left: 105%; }
}

.wts-err {
  margin-top: 10px; padding: 10px 12px;
  background: #fff2f3; border: 1px solid #f1cdd0; border-radius: 8px;
  color: var(--wts-err); font-size: 13px;
}
.wts-err[hidden] { display: none; }

@media (prefers-color-scheme: dark) {
  .wts {
    --wts-ink: #f1f5f9;
    --wts-ink-2: #cbd5e1;
    --wts-ink-3: #94a3b8;
    --wts-bg: #0f172a;
    --wts-bg-card: #1e293b;
    --wts-border: #334155;
    --wts-border-2: #475569;
  }
}
