/* Voice Recorder — tool-specific styles */
.vr-top { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }
.vr-device-label { font-size: .85rem; font-weight: 600; color: var(--muted); }
#vrDevice { flex: 1; min-width: 220px; background: var(--bg-soft); color: var(--text); border: 1px solid var(--line);
  border-radius: var(--radius-sm); padding: 10px 12px; font-family: inherit; font-size: .92rem; }

.vr-wave { width: 100%; height: 120px; display: block; background: var(--bg-soft);
  border: 1px solid var(--line); border-radius: var(--radius-sm); }

.vr-controls { display: flex; align-items: center; gap: 14px; margin-top: 18px; flex-wrap: wrap; }
.vr-time { font-variant-numeric: tabular-nums; font-size: 1.8rem; font-weight: 800; min-width: 5ch; }
.vr-recbtn { border-radius: 999px; padding-left: 24px; padding-right: 26px; }
.vr-dot { width: 10px; height: 10px; border-radius: 50%; background: #ff5470; display: inline-block;
  box-shadow: 0 0 0 3px rgba(255,84,112,.25); }
.vr-recbtn.recording .vr-dot { animation: vr-blink 1.1s ease-in-out infinite; }
@keyframes vr-blink { 0%,100% { opacity: 1; } 50% { opacity: .25; } }

.vr-result { margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--line); }
.vr-result audio { width: 100%; }
.vr-dl-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-top: 14px; }
.vr-meta { color: var(--muted-2); font-size: .9rem; font-variant-numeric: tabular-nums; }

@media (max-width: 560px) { .vr-time { font-size: 1.4rem; } }
