body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.App{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;text-align:center;color:#fff;border-bottom:1px solid rgba(255,255,255,.2)}.app-header h1{font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.app-header p{font-size:1.1rem;opacity:.9}.main-content{flex:1;display:flex;flex-direction:column;gap:2rem;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.transcription-controls{background:#fffffff2;border-radius:16px;padding:2rem;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.controls-row{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.record-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-width:140px}.record-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.record-button.recording{background:linear-gradient(135deg,#ff6b6b,#ee5a24);animation:pulse 2s infinite}.record-button:disabled{opacity:.6;cursor:not-allowed;transform:none}@keyframes pulse{0%{box-shadow:0 0 #ff6b6bb3}70%{box-shadow:0 0 0 10px #ff6b6b00}to{box-shadow:0 0 #ff6b6b00}}.clear-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;border:2px solid #667eea;border-radius:12px;cursor:pointer;transition:all .3s ease;background:transparent;color:#667eea}.clear-button:hover:not(:disabled){background:#667eea;color:#fff;transform:translateY(-2px)}.clear-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.status-indicator{margin-bottom:1.5rem}.status{display:flex;align-items:center;gap:.5rem;font-weight:600;padding:.75rem 1rem;border-radius:8px;background:#0000000d}.status-dot{width:12px;height:12px;border-radius:50%;animation:blink 2s infinite}.status-dot.connected{background:#00d4aa}.status-dot.reconnecting{background:#ffa726}.status-dot.disconnected{background:#ff6b6b}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.3}}.status.connected{color:#00d4aa}.status.reconnecting{color:#ffa726}.status.disconnected{color:#ff6b6b}.error-message{background:#ffebee;color:#c62828;padding:1rem;border-radius:8px;border-left:4px solid #c62828;margin-bottom:1.5rem;font-weight:500}.export-controls{border-top:1px solid rgba(0,0,0,.1);padding-top:1.5rem}.export-controls h3{margin-bottom:1rem;color:#333;font-size:1.2rem}.export-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.export-button{padding:.75rem 1rem;font-size:.9rem;font-weight:500;border:1px solid #ddd;border-radius:8px;cursor:pointer;transition:all .3s ease;background:#fff;color:#333}.export-button:hover:not(:disabled){background:#f8f9fa;border-color:#667eea;color:#667eea;transform:translateY(-1px)}.export-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.transcript-display{display:grid;grid-template-columns:1fr 1fr;gap:2rem;height:500px;grid-auto-rows:1fr;overflow:hidden}.transcript-section{background:#fffffff2;border-radius:16px;padding:1.5rem;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;height:100%;min-height:0}.transcript-section h3{margin-bottom:1rem;color:#333;font-size:1.2rem;font-weight:600;border-bottom:2px solid #667eea;padding-bottom:.5rem}.transcript-content{flex:1;overflow-y:auto;background:#f8f9fa;border-radius:8px;padding:1rem;border:1px solid #e9ecef;min-height:0}.transcript-text{font-family:Courier New,monospace;font-size:1rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;color:#333}.intermediate-transcript{margin-top:1rem;padding:1rem;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:8px;border-left:4px solid #ffc107}.intermediate-text{font-family:Courier New,monospace;font-size:1rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;color:#856404;font-style:italic;margin:0}.placeholder-text{color:#666;font-style:italic;text-align:center;padding:2rem}.transcript-content::-webkit-scrollbar{width:8px}.transcript-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.transcript-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.transcript-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width: 768px){.app-header h1{font-size:2rem}.main-content{padding:1rem}.transcript-display{grid-template-columns:1fr;height:600px;gap:1rem}.controls-row{flex-direction:column}.export-buttons{grid-template-columns:1fr}}@media (max-width: 480px){.app-header{padding:1rem}.app-header h1{font-size:1.5rem}.transcription-controls{padding:1rem}.record-button,.clear-button{padding:.75rem 1.5rem;font-size:1rem}.transcript-display{height:800px;gap:.75rem}.transcript-section{padding:1rem}.transcript-content{padding:.75rem}}
