:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.audio-transcription{display:flex;flex-direction:column;gap:20px;padding:20px;max-width:800px;margin:0 auto}.controls{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap}.controls button{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-size:16px;transition:all .3s ease}.controls button:disabled{opacity:.5;cursor:not-allowed}.controls button.start{background-color:#4caf50;color:#fff}.controls button.stop{background-color:#f44336;color:#fff}.controls button:hover:not(:disabled){opacity:.9}.connection-status{color:#666;font-size:14px;padding:5px 10px;background-color:#f5f5f5;border-radius:4px}.transcription-container{background-color:#f5f5f5;padding:20px;border-radius:8px;min-height:200px}.transcription-container h3{margin-top:0;color:#333}.transcription-text{white-space:pre-wrap;line-height:1.5;color:#666}.error{color:#f44336;margin-bottom:10px;padding:10px;background-color:#ffebee;border-radius:4px}.error-message{color:#dc3545;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;padding:10px;margin:10px 0;font-size:14px}.session-info{background-color:#e8f4fd;color:#06c;padding:8px 12px;border-radius:4px;margin:10px 0;border:1px solid #b3d9ff;font-size:14px}.word-timestamps{margin-top:20px;padding:15px;background-color:#f8f9fa;border-radius:4px;border:1px solid #dee2e6}.word-timestamps h4{margin:0 0 10px;color:#495057;font-size:16px}.words-list{display:flex;flex-wrap:wrap;gap:8px}.word-item{display:inline-flex;align-items:center;background-color:#e9ecef;padding:4px 8px;border-radius:4px;font-size:14px}.word-item .word{font-weight:500;margin-right:6px;color:#000}.word-item .timestamp{color:#6c757d;font-size:12px}.word-item .confidence{color:#28a745;font-size:11px;margin-left:8px;font-weight:500}.audio-files{margin:20px 0;padding:15px;background-color:#f5f5f5;border-radius:8px}.audio-files h4{margin:0 0 10px;color:#333}.download-links{display:flex;gap:15px}.download-link{display:inline-block;padding:8px 16px;background-color:#007bff;color:#fff;text-decoration:none;border-radius:4px;transition:background-color .2s}.download-link:hover{background-color:#0056b3}.text-to-speech{display:flex;flex-direction:column;gap:20px;padding:20px;max-width:800px;margin:0 auto;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.text-to-speech .sign-in-container{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin-bottom:20px}.text-to-speech .sign-in-container h3{margin-top:0;color:#495057}.text-to-speech .sign-in-form{display:flex;flex-direction:column;gap:15px}.text-to-speech .form-group{display:flex;flex-direction:column;gap:5px}.text-to-speech .form-group label{font-weight:500;color:#495057}.text-to-speech .form-group input{padding:10px;border:1px solid #ced4da;border-radius:4px;font-size:14px}.text-to-speech .form-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.text-to-speech .sign-in-button{background:#007bff;color:#fff;border:none;padding:12px;border-radius:4px;font-size:16px;cursor:pointer;transition:background-color .2s}.text-to-speech .sign-in-button:hover:not(:disabled){background:#0056b3}.text-to-speech .sign-in-button:disabled{background:#6c757d;cursor:not-allowed}.text-to-speech .user-info{text-align:center}.text-to-speech .user-info h3{color:#28a745;margin-bottom:10px}.text-to-speech .user-info p{color:#6c757d;margin-bottom:15px}.text-to-speech .sign-out-button{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background-color .2s}.text-to-speech .sign-out-button:hover{background:#c82333}.text-input-container{width:100%}.text-input-container textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-size:16px;resize:vertical;min-height:100px;font-family:inherit}.text-input-container textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.language-label{color:#000;margin-right:10px}.voice-selector{display:flex;align-items:center;gap:10px;min-width:200px}.voice-selector label{white-space:nowrap;color:#333;font-weight:500}.voice-selector select{flex:1;padding:8px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#fff;min-width:120px;background-color:#000}.voice-selector select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.controls button.convert{background-color:#007bff;color:#fff;padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-size:16px;transition:all .3s ease}.controls button.convert:hover:not(:disabled){background-color:#0056b3}.controls button.convert:disabled{opacity:.5;cursor:not-allowed}.audio-player{margin-top:20px;padding:15px;background-color:#f8f9fa;border-radius:8px;border:1px solid #dee2e6}.audio-player h4{margin:0 0 10px;color:#495057}.audio-player audio{width:100%;margin-bottom:10px}@media (max-width: 768px){.controls{flex-direction:column;align-items:stretch}.voice-selector{width:100%;min-width:unset}.voice-selector select,.controls button{width:100%}}.api-key-manager{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin-bottom:20px}.api-key-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.api-key-header h3{margin:0;color:#333}.edit-button{background-color:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background-color .2s}.edit-button:hover{background-color:#5a6268}.api-key-inputs{display:flex;flex-direction:column;gap:15px}.api-key-input{display:flex;flex-direction:column;gap:5px}.api-key-input label{color:#495057;font-weight:500}.api-key-input input{padding:8px;border:1px solid #ced4da;border-radius:4px;font-size:14px}.api-key-input input:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.save-button{background-color:#28a745;color:#fff;border:none;padding:10px;border-radius:4px;cursor:pointer;transition:background-color .2s;margin-top:10px}.save-button:hover{background-color:#218838}.api-key-status{color:#495057}.api-key-status p{margin:5px 0;display:flex;align-items:center;gap:8px}.student-login-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}.panel{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:2rem}.form-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:.5rem;transition:all .15s ease-in-out;cursor:pointer;border:none}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-primary:disabled{background-color:#9ca3af;cursor:not-allowed}.space-y-5>*+*{margin-top:1.25rem}.text-red-600{color:#dc2626}.text-sm{font-size:.875rem}.text-2xl{font-size:1.5rem;line-height:2rem}.mb-3{margin-bottom:.75rem}.mb-7{margin-bottom:1.75rem}.my-7{margin-top:1.75rem;margin-bottom:1.75rem}.text-center{text-align:center}.text-white-dark{color:#6b7280}.dark\:bg-black{background-color:#000}.relative{position:relative}.z-\[1\]{z-index:1}.inline-block{display:inline-block}.before\:w-full:before{content:"";width:100%}.before\:h-\[1px\]:before{content:"";height:1px}.before\:absolute:before{content:"";position:absolute}.before\:inset-0:before{content:"";top:0;right:0;bottom:0;left:0}.before\:m-auto:before{content:"";margin:auto}.before\:bg-\[\#ebedf2\]:before{content:"";background-color:#ebedf2}.dark\:before\:bg-\[\#253b5c\]:before{content:"";background-color:#253b5c}.student-assignments-container,.assignment-detail-container,.student-portal{min-height:100vh;background-color:#f8fafc}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}.user-info{display:flex;align-items:center;gap:1rem}.sign-out-button{background-color:#ef4444;color:#fff;padding:.5rem 1rem;border-radius:.375rem;border:none;font-weight:500;cursor:pointer;transition:background-color .15s ease-in-out}.sign-out-button:hover{background-color:#dc2626}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.gap-6{gap:1.5rem}.gap-4{gap:1rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.bg-white{background-color:#fff}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-gray-200{border-color:#e5e7eb}.p-6{padding:1.5rem}.p-4{padding:1rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.mb-6{margin-bottom:1.5rem}.mb-4{margin-bottom:1rem}.mb-2{margin-bottom:.5rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-gray-900{color:#111827}.text-gray-700{color:#374151}.text-gray-600{color:#4b5563}.text-gray-500{color:#6b7280}.text-gray-400{color:#9ca3af}.text-blue-800{color:#1e40af}.text-blue-600{color:#2563eb}.text-white{color:#fff}.bg-blue-100{background-color:#dbeafe}.bg-blue-600{background-color:#2563eb}.bg-gray-200{background-color:#e5e7eb}.bg-gray-100{background-color:#f3f4f6}.hover\:bg-blue-700:hover{background-color:#1d4ed8}.hover\:bg-gray-300:hover{background-color:#d1d5db}.hover\:bg-gray-100:hover{background-color:#f3f4f6}.hover\:text-gray-800:hover{color:#1f2937}.hover\:text-gray-600:hover{color:#4b5563}.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.rounded-full{border-radius:9999px}.flex{display:flex}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.w-full{width:100%}.w-5{width:1.25rem}.w-6{width:1.5rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-32{height:8rem}.min-h-screen{min-height:100vh}.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}.mx-auto{margin-left:auto;margin-right:auto}.space-y-6>*+*{margin-top:1.5rem}.space-y-3>*+*{margin-top:.75rem}.space-y-2>*+*{margin-top:.5rem}.prose{color:#374151;max-width:65ch}.prose p{margin-top:1.25em;margin-bottom:1.25em}.prose p:first-child{margin-top:0}.prose p:last-child{margin-bottom:0}.max-w-none{max-width:none}.whitespace-pre-wrap{white-space:pre-wrap}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.cursor-pointer{cursor:pointer}.object-cover{object-fit:cover}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:col-span-2{grid-column:span 2 / span 2}}.assignment-submission-container{max-width:1200px;margin:0 auto;padding:2rem;background-color:#f8fafc;min-height:100vh}.assignment-header{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 6px #0000001a}.header-actions{margin-bottom:1rem}.back-button{background:#6b7280;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.back-button:hover{background:#4b5563;transform:translateY(-1px)}.assignment-header h1{color:#1f2937;font-size:2.5rem;font-weight:700;margin:0 0 1rem}.assignment-meta{display:flex;gap:1rem;align-items:center}.assignment-type{background:#3b82f6;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600}.teacher-name{color:#6b7280;font-size:1rem}.submission-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.left-panel,.right-panel{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0}.section-actions{display:flex;gap:.5rem}.speak-button,.view-button{padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.speak-button{background:#10b981;color:#fff}.speak-button:hover:not(:disabled){background:#059669}.speak-button:disabled{background:#9ca3af;cursor:not-allowed}.view-button{background:#6b7280;color:#fff}.view-button:hover{background:#4b5563}.instructions-text,.question-text{color:#374151;font-size:1rem;line-height:1.6;margin:0}.question-navigation{display:flex;gap:1rem;margin-top:1.5rem;justify-content:center}.nav-button{padding:.75rem 1.5rem;border:2px solid #3b82f6;background:#fff;color:#3b82f6;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.nav-button:hover:not(:disabled){background:#3b82f6;color:#fff}.nav-button:disabled{border-color:#d1d5db;color:#9ca3af;cursor:not-allowed}.language-selector{margin-bottom:1.5rem}.language-selector label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151}.language-selector select{width:100%;padding:.75rem;border:2px solid #d1d5db;border-radius:8px;font-size:1rem;background:#3f3030}.language-selector select:focus{outline:none;border-color:#3b82f6}.recording-controls{display:flex;gap:1rem;margin-bottom:1.5rem}.start-button,.stop-button{flex:1;padding:1rem 2rem;border:none;border-radius:12px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s}.start-button{background:#10b981;color:#fff}.start-button:hover:not(:disabled){background:#059669;transform:translateY(-2px)}.stop-button{background:#ef4444;color:#fff}.stop-button:hover:not(:disabled){background:#dc2626;transform:translateY(-2px)}.start-button:disabled,.stop-button:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1rem}.transcription-result{margin-top:1.5rem}.transcription-result h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0 0 1rem}.transcript-text{background:#f3f4f6;padding:1rem;border-radius:8px;color:#374151;font-size:1rem;line-height:1.6;margin:0 0 1rem}.audio-files{margin:1.5rem 0}.audio-files h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 1rem}.audio-controls{display:flex;flex-direction:column;gap:1rem}.audio-file{background:#f9fafb;padding:1rem;border-radius:8px;border:1px solid #e5e7eb}.audio-file h5{color:#374151;font-size:.875rem;font-weight:600;margin:0 0 .5rem}.audio-actions{display:flex;flex-direction:column;gap:.5rem}.audio-player{width:100%;height:40px}.download-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#3b82f6;color:#fff;text-decoration:none;border-radius:6px;font-size:.875rem;font-weight:500;transition:all .2s;align-self:flex-start}.download-link:hover{background:#2563eb;transform:translateY(-1px)}.word-timestamps h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 .5rem}.words-list{display:flex;flex-wrap:wrap;gap:.5rem}.word-item{background:#e5e7eb;padding:.25rem .5rem;border-radius:4px;font-size:.875rem}.word{font-weight:600;color:#1f2937}.timestamp{color:#6b7280;margin-left:.25rem}.confidence{color:#059669;margin-left:.25rem;font-weight:500}.submission-actions{margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.submit-button{width:100%;padding:1rem 2rem;background:#3b82f6;color:#fff;border:none;border-radius:12px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s}.submit-button:hover:not(:disabled){background:#2563eb;transform:translateY(-2px)}.submit-button:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb}.modal-header h2{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:.5rem}.close-button:hover{color:#374151}.modal-body{padding:2rem}.modal-body p{color:#374151;font-size:1rem;line-height:1.6;margin:0 0 1.5rem}.questions-list h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0 0 1rem}.question-item{color:#374151;font-size:1rem;line-height:1.6;margin-bottom:.75rem}.question-item strong{color:#1f2937}@media (max-width: 768px){.submission-content{grid-template-columns:1fr}.assignment-header h1{font-size:2rem}.assignment-meta{flex-direction:column;align-items:flex-start;gap:.5rem}.recording-controls,.question-navigation{flex-direction:column}}.submit-section{background:#fff;border-radius:12px;padding:2rem;margin:1rem 0;box-shadow:0 4px 6px #0000001a;text-align:center;border:2px solid #10b981}.submit-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d}.submit-button:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.submit-button:active{transform:translateY(0)}.submit-note{margin-top:1rem;color:#6b7280;font-size:.9rem}.submission-confirmation{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-radius:12px;padding:2rem;margin:1rem 0;text-align:center;border:2px solid #10b981}.submission-confirmation h3{color:#065f46;margin-bottom:1rem;font-size:1.5rem}.submission-confirmation p{color:#047857;margin-bottom:1.5rem;font-size:1.1rem}.back-button{background:#374151;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .3s ease}.back-button:hover{background:#1f2937;transform:translateY(-1px)}#root{width:100%;margin:0 auto;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.App{text-align:center;min-height:100vh;background-color:#f5f5f5}.App-header{background-color:#282c34;padding:20px;color:#fff;margin-bottom:30px}.App-header h1{margin:0;font-size:2rem}.student-portal .App-header{background:linear-gradient(135deg,#667eea,#764ba2);margin-bottom:0}.student-portal .App-header h1{color:#fff;font-size:2.5rem;font-weight:700}.student-portal main{padding:2rem 0}.student-portal .user-info{display:flex;align-items:center;gap:1rem}.header-buttons{display:flex;gap:.5rem;align-items:center}.nav-button{padding:.5rem 1rem;background:transparent;border:1px solid rgba(255,255,255,.3);color:#3b1717;border-radius:.375rem;cursor:pointer;transition:all .2s}.nav-button:hover{background:#ffffff1a;border-color:#ffffff80}.nav-button.active{background:#fff3;border-color:#fff9}.components-container{margin:0 auto;padding:0 20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}.component-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.component-section h2{color:#333;margin-top:0;margin-bottom:20px;font-size:1.5rem}@media (max-width: 768px){.components-container{grid-template-columns:1fr}.component-section{margin-bottom:20px}}
