/* Speech to Text Tool Styles */
.tool-main.main-tool-bordered { border: 2px solid var(--primary-color); border-radius: 12px; box-shadow: 0 2px 12px 0 rgba(220,38,38,0.04); padding: 2rem; background: var(--surface-color); }
.input-label { font-weight: 600; color: var(--text-secondary); margin-bottom: 0.3rem; }
.stt-controls { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; margin-bottom: 1.2rem; }
.stt-controls label { margin-bottom: 0; }
.stt-controls select { padding: 0.5rem 1rem; border-radius: 6px; border: 1px solid var(--border-color); font-size: 1rem; background: #fff; color: var(--text-primary); }
#sttOutput { width: 100%; min-height: 120px; font-size: 1.1rem; padding: 0.75rem; border-radius: 8px; border: 1px solid #e2e8f0; background: #fff; color: var(--text-primary); margin-bottom: 1rem; resize: vertical; }
#sttOutput:focus { border: 1.5px solid var(--primary-color); outline: none; }
.stt-actions { display: flex; gap: 1rem; margin-bottom: 1.2rem; }
.tool-button { background: var(--primary-color); color: #fff; border: none; border-radius: 8px; padding: 0.75rem 1.2rem; font-size: 1.1rem; font-weight: 600; cursor: pointer; margin-right: 0.5rem; margin-bottom: 0.5rem; transition: background 0.2s; }
.tool-button:hover, .tool-button:focus { background: var(--accent-color); }
.stt-status { font-size: 1.05em; min-height: 1.5em; }
@media (max-width: 900px) { .tool-main.main-tool-bordered { padding: 1rem; } }
@media (max-width: 600px) { .tool-main.main-tool-bordered { padding: 0.5rem; } .stt-controls, .stt-actions { flex-direction: column; gap: 0.5rem; } } 