.openai-config{background:var(--card-bg);border-radius:1rem;padding:2rem;margin:2rem 0;box-shadow:0 2px 8px #0000001a;border:2px solid var(--border)}.config-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.config-icon{width:1.5rem;height:1.5rem;color:var(--primary)}.config-header h3{font-size:1.3rem;color:var(--text);margin:0}.config-info{background:#2563eb0d;border-left:4px solid var(--primary);padding:1rem 1.5rem;border-radius:.5rem;margin-bottom:1.5rem}.config-info p{margin:0;color:var(--text);line-height:1.6}.config-info ul{margin:.5rem 0;padding-left:1.5rem}.config-info li{margin:.25rem 0;color:var(--text)}.api-link{color:var(--primary);text-decoration:none;font-weight:500;display:inline-block;margin-top:.5rem;transition:opacity .2s}.api-link:hover{opacity:.8;text-decoration:underline}.info-icon{width:1.2rem;height:1.2rem;color:var(--primary);float:left;margin-right:.5rem;margin-top:.2rem}.config-status{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#10b9811a;border-radius:.5rem;margin-bottom:1rem}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.5rem;font-weight:500}.status-badge.success{background:var(--success);color:#fff}.edit-button{padding:.5rem 1rem;background:var(--bg);color:var(--text);border:2px solid var(--border);border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s}.edit-button:hover{border-color:var(--primary);background:#2563eb0d}.config-form,.input-group{margin-bottom:1rem}.input-group label{display:block;margin-bottom:.5rem;color:var(--text);font-weight:500}.input-wrapper{position:relative;display:flex;align-items:center}.api-key-input{width:100%;padding:.75rem 3rem .75rem 1rem;border:2px solid var(--border);border-radius:.5rem;font-size:1rem;font-family:monospace;transition:border-color .2s}.api-key-input:focus{outline:none;border-color:var(--primary)}.api-key-input:disabled{background:var(--bg);cursor:not-allowed}.toggle-visibility{position:absolute;right:.75rem;background:none;border:none;color:var(--text-light);cursor:pointer;padding:.25rem;display:flex;align-items:center;transition:color .2s}.toggle-visibility:hover{color:var(--text)}.message{padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1rem;font-weight:500}.message.success{background:#10b9811a;color:var(--success);border:1px solid var(--success)}.message.error{background:#ef44441a;color:var(--error);border:1px solid var(--error)}.config-actions{display:flex;gap:1rem}.save-button,.clear-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s}.save-button{background:var(--primary);color:#fff}.save-button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.save-button:disabled{opacity:.5;cursor:not-allowed}.clear-button{background:var(--bg);color:var(--text);border:2px solid var(--border)}.clear-button:hover{border-color:var(--error);color:var(--error)}.config-note{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.config-note small{color:var(--text-light);font-size:.85rem}@media (max-width: 768px){.openai-config{padding:1.5rem}.config-actions{flex-direction:column}.save-button,.clear-button{width:100%;justify-content:center}}.chat-container{display:flex;flex-direction:column;height:600px;max-height:80vh;background:var(--card-bg);border-radius:1rem;box-shadow:0 4px 20px #0000001a;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}.chat-title{display:flex;align-items:center;gap:.75rem}.chat-title h3{margin:0;font-size:1.1rem;font-weight:600}.chat-title svg{width:1.5rem;height:1.5rem}.ai-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background:#fff3;border-radius:1rem;font-size:.85rem;font-weight:500;margin-left:.5rem}.ai-badge svg{width:.9rem;height:.9rem}.close-button{background:#fff3;border:none;color:#fff;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.close-button:hover{background:#ffffff4d}.close-button svg{width:1.2rem;height:1.2rem}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;background:var(--bg)}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:var(--bg)}.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.message{display:flex;max-width:80%;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end;margin-left:auto}.message.assistant{align-self:flex-start;margin-right:auto}.message-content{padding:.75rem 1rem;border-radius:1rem;position:relative}.message.user .message-content{background:var(--primary);color:#fff;border-bottom-right-radius:.25rem}.message.assistant .message-content{background:var(--card-bg);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:.25rem}.message-text{line-height:1.5;word-wrap:break-word;white-space:pre-wrap}.message.user .message-text{color:#fff}.message.assistant .message-text{color:var(--text)}.message.assistant .message-text .spinning{display:inline-block;margin-right:.5rem;vertical-align:middle}.message-time{font-size:.75rem;opacity:.7;margin-top:.5rem;text-align:right}.message.user .message-time{color:#fffc}.message.assistant .message-time{color:var(--text-light)}.chat-mode-toggle{padding:.75rem 1.5rem;background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.mode-toggle-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--card-bg);border:2px solid var(--border);border-radius:.5rem;color:var(--text);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.mode-toggle-button:hover{border-color:var(--primary);background:#2563eb0d}.mode-toggle-button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.mode-toggle-button svg{width:1rem;height:1rem}.chat-input-container{display:flex;gap:.5rem;padding:1rem 1.5rem;background:var(--card-bg);border-top:1px solid var(--border)}.chat-input{flex:1;padding:.75rem 1rem;border:2px solid var(--border);border-radius:.75rem;font-size:.95rem;font-family:inherit;resize:none;transition:border-color .2s;background:var(--bg);color:var(--text);line-height:1.5}.chat-input:focus{outline:none;border-color:var(--primary)}.chat-input:disabled{opacity:.6;cursor:not-allowed}.chat-input::placeholder{color:var(--text-light)}.send-button{padding:.75rem 1.25rem;background:var(--primary);color:#fff;border:none;border-radius:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;min-width:3rem}.send-button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.send-button:disabled{opacity:.5;cursor:not-allowed}.send-button svg{width:1.25rem;height:1.25rem}.voice-record-button{padding:.75rem 1.25rem;background:var(--secondary);color:#fff;border:none;border-radius:.75rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s;font-weight:500;min-width:120px;justify-content:center}.voice-record-button:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px)}.voice-record-button:disabled{opacity:.5;cursor:not-allowed}.voice-record-button.recording{background:var(--error);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.voice-record-button svg{width:1.25rem;height:1.25rem}.pulsing{animation:pulse 1.5s ease-in-out infinite;display:inline-block;margin-right:.5rem;vertical-align:middle}.listening-indicator{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#2563eb1a,#8b5cf61a);border-top:1px solid var(--border);color:var(--primary);font-weight:500;font-size:.95rem}.listening-indicator.initializing{background:linear-gradient(135deg,#fbbf241a,#f59e0b1a);color:var(--warning)}.listening-indicator svg{width:1.25rem;height:1.25rem;animation:pulse 1.5s ease-in-out infinite}.listening-indicator.initializing svg{animation:spin 1s linear infinite}.chat-error{padding:.75rem 1.5rem;background:#ef44441a;color:var(--error);border-top:1px solid rgba(239,68,68,.2);font-size:.9rem}.chat-unavailable{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--text-light)}.chat-unavailable p{margin:.5rem 0}@media (max-width: 768px){.chat-container{height:500px;max-height:70vh}.message{max-width:90%}.chat-input-container{padding:.75rem 1rem}.chat-header{padding:1rem}.chat-title h3{font-size:1rem}}.dashboard{min-height:100vh;background:var(--bg)}.dashboard-header{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;padding:3rem 2rem;text-align:center;position:relative}.header-actions{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;align-items:center}.chat-button{background:#fff3;border:none;color:#fff;padding:.5rem 1rem;border-radius:2rem;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .2s;font-weight:500;font-size:.9rem}.chat-button:hover{background:#ffffff4d;transform:translateY(-2px)}.chat-button svg{width:1.2rem;height:1.2rem}.settings-button{background:#fff3;border:none;color:#fff;width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.settings-button:hover{background:#ffffff4d;transform:rotate(90deg)}.settings-button svg{width:1.5rem;height:1.5rem}.chat-modal{position:fixed;bottom:2rem;right:2rem;z-index:1000;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-modal-content{width:450px;max-width:calc(100vw - 4rem);box-shadow:0 8px 32px #0000004d}@media (max-width: 768px){.header-actions{flex-direction:column;gap:.25rem}.chat-button{padding:.4rem .75rem;font-size:.85rem}.chat-modal{bottom:1rem;right:1rem;left:1rem}.chat-modal-content{width:100%;max-width:100%}}.config-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.config-modal-content{background:var(--card-bg);border-radius:1rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d}.config-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--border)}.config-modal-header h2{margin:0;color:var(--text)}.close-button{background:none;border:none;color:var(--text-light);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:.5rem;transition:all .2s}.close-button:hover{background:var(--bg);color:var(--text)}.close-button svg{width:1.5rem;height:1.5rem}.header-content h1{font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.subtitle{font-size:1.2rem;opacity:.9}.dashboard-content{max-width:1200px;margin:0 auto;padding:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:var(--card-bg);border-radius:1rem;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-icon{width:3rem;height:3rem;color:var(--primary);flex-shrink:0}.stat-info h3{font-size:2rem;color:var(--text);margin-bottom:.25rem}.stat-info p{color:var(--text-light);font-size:.9rem}.lessons-section h2{font-size:1.8rem;margin-bottom:1.5rem;color:var(--text)}.lessons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.lesson-card{background:var(--card-bg);border-radius:1rem;padding:1.5rem;text-decoration:none;color:inherit;box-shadow:0 2px 8px #0000001a;transition:all .2s;display:flex;flex-direction:column;border:2px solid transparent}.lesson-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026;border-color:var(--primary)}.lesson-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.lesson-number{background:var(--primary);color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.85rem;font-weight:600}.lesson-badge{background:var(--success);color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.85rem;font-weight:600}.lesson-card h3{font-size:1.3rem;margin-bottom:.5rem;color:var(--text)}.lesson-card p{color:var(--text-light);margin-bottom:1rem;flex-grow:1;line-height:1.5}.lesson-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border)}.lesson-content-type{font-size:.9rem;color:var(--text-light);font-weight:500}.play-icon{width:1.5rem;height:1.5rem;color:var(--primary)}@media (max-width: 768px){.dashboard-header{padding:2rem 1rem}.header-content h1{font-size:2rem}.subtitle{font-size:1rem}.dashboard-content{padding:1rem}.lessons-grid{grid-template-columns:1fr}}.speech-practice{background:var(--card-bg);border-radius:1rem;padding:2rem;margin:1.5rem 0;box-shadow:0 2px 8px #0000001a}.microphone-selector{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem;background:#2563eb0d;border-radius:.5rem;border:1px solid var(--border)}.microphone-selector label{font-weight:500;color:var(--text);white-space:nowrap}.microphone-selector select{flex:1;padding:.5rem .75rem;border:2px solid var(--border);border-radius:.5rem;background:var(--bg);color:var(--text);font-size:.9rem;cursor:pointer;transition:border-color .2s}.microphone-selector select:focus{outline:none;border-color:var(--primary)}.microphone-selector select:disabled{opacity:.6;cursor:not-allowed}.microphone-hint{margin:.5rem 0 0;padding:.5rem;font-size:.85rem;color:var(--text-light);background:#2563eb0d;border-radius:.25rem;border-left:3px solid var(--primary)}.practice-word{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem}.practice-word h3{font-size:2rem;color:var(--primary);font-weight:600}.speak-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--secondary);color:#fff;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background .2s}.speak-button:hover{background:#7c3aed}.practice-controls{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem}.mic-button{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:var(--primary);color:#fff;border:none;border-radius:.75rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:180px}.mic-button:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.mic-button:disabled{opacity:.7;cursor:not-allowed}.mic-button.listening{background:var(--error);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.reset-button{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:var(--bg);color:var(--text);border:2px solid var(--border);border-radius:.75rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.reset-button:hover{border-color:var(--primary);background:#2563eb0d}.practice-result{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid var(--border)}.transcript-label{font-size:.9rem;color:var(--text-light);margin-bottom:.5rem;text-align:center}.transcript{font-size:1.2rem;text-align:center;padding:1rem;background:var(--bg);border-radius:.5rem;margin-bottom:1rem;font-weight:500}.transcript.correct{color:var(--success);background:#10b9811a}.transcript.incorrect{color:var(--error);background:#ef44441a}.result-message{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border-radius:.5rem;font-weight:500;text-align:center}.result-message strong{font-weight:700}.openai-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:.5rem;font-size:.9rem;font-weight:500;margin-bottom:1rem}.sparkles-icon{width:1rem;height:1rem}.whisper-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-radius:.5rem;font-size:.9rem;font-weight:500;margin-bottom:1rem}.radio-icon{width:1rem;height:1rem}.analyzing-indicator{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;color:var(--text-light)}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.score-display{margin:1rem 0}.score-bar{width:100%;height:8px;background:var(--bg);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.score-fill{height:100%;background:linear-gradient(90deg,var(--success) 0%,#34d399 100%);transition:width .3s ease;border-radius:4px}.score-text{font-size:.9rem;color:var(--text-light);font-weight:500}.suggestions-box{margin-top:1rem;padding:1rem;background:#2563eb0d;border-radius:.5rem;border-left:3px solid var(--primary)}.suggestions-box h4{font-size:.95rem;margin-bottom:.75rem;color:var(--text)}.suggestions-box ul{list-style:none;padding:0;margin:0}.suggestions-box li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:var(--text);line-height:1.5}.suggestions-box li:before{content:"•";position:absolute;left:0;color:var(--primary);font-weight:700}.permission-help{margin:1.5rem 0;padding:1.5rem;background:#f59e0b1a;border-left:4px solid var(--warning);border-radius:.5rem}.permission-help h4{font-size:1rem;margin-bottom:1rem;color:var(--text)}.permission-help ol{margin:.5rem 0;padding-left:1.5rem;color:var(--text)}.permission-help li{margin:.5rem 0;line-height:1.6}.permission-help .note{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(245,158,11,.2);font-size:.9rem;color:var(--text-light);line-height:1.5}.permission-help .note strong{color:var(--text)}.network-help{margin:1.5rem 0;padding:1.5rem;background:#ef44441a;border-left:4px solid var(--error);border-radius:.5rem}.network-help h4{font-size:1rem;margin-bottom:1rem;color:var(--text)}.network-help>p{margin:.5rem 0 1rem;color:var(--text);line-height:1.6}.network-help ol{margin:.5rem 0;padding-left:1.5rem;color:var(--text)}.network-help li{margin:.5rem 0;line-height:1.6}.network-help .note{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(239,68,68,.2);font-size:.9rem;color:var(--text-light);line-height:1.5}.network-help .note strong{color:var(--text)}.feedback-message{margin:1rem 0;padding:1rem;border-radius:.5rem;background:#2563eb1a;border-left:3px solid var(--primary);color:var(--text);line-height:1.6}.feedback-message.error{background:#ef44441a;border-left-color:var(--error);color:var(--error);font-weight:500;white-space:pre-line}.feedback-message.error strong{font-weight:700;font-size:1.05em}.speech-practice-unsupported{background:var(--card-bg);border-radius:1rem;padding:2rem;margin:1.5rem 0;text-align:center;border:2px dashed var(--border)}.speech-practice-unsupported p{color:var(--text);margin-bottom:1rem;line-height:1.6}.speech-practice-unsupported .hint{font-size:.95rem;font-style:normal;margin-bottom:.75rem;color:var(--text)}.speech-practice-unsupported .hint strong{color:var(--primary);font-weight:600}.speech-practice-unsupported .hint a{color:var(--primary);text-decoration:underline}.hint{font-size:.9rem;font-style:italic}@media (max-width: 768px){.speech-practice{padding:1.5rem}.practice-word h3{font-size:1.5rem}.mic-button,.reset-button{width:100%;justify-content:center}}.lesson-page{min-height:100vh;background:var(--bg)}.lesson-header{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;padding:2rem}.lesson-title-section{max-width:1200px;margin:0 auto}.lesson-badge-level{display:inline-block;background:#fff3;padding:.5rem 1rem;border-radius:1rem;margin-bottom:1rem;font-weight:600}.lesson-title-section h1{font-size:2.5rem;margin-bottom:.5rem}.lesson-title-section p{font-size:1.1rem;opacity:.9}.lesson-content{max-width:1200px;margin:0 auto;padding:2rem}.content-section{margin-bottom:3rem}.content-section h2{font-size:1.8rem;margin-bottom:2rem;color:var(--text)}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.content-item{background:var(--card-bg);border-radius:1rem;padding:1.5rem;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:1rem;transition:transform .2s,box-shadow .2s}.content-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.item-main{flex-grow:1}.item-french{font-size:1.5rem;color:var(--primary);margin-bottom:.5rem;font-weight:600}.item-pronunciation{color:var(--text-light);font-style:italic;margin-bottom:.25rem;font-size:.9rem}.item-translations{display:flex;flex-direction:column;gap:.5rem}.item-translation{color:var(--text);font-weight:500;line-height:1.5}.item-english{color:var(--text)}.item-urdu{color:var(--text);direction:rtl;text-align:right;font-family:Noto Nastaliq Urdu,Jameel Noori Nastaleeq,Al Qalam Taj Nastaleeq,Urdu Typesetting,Segoe UI,sans-serif;font-size:1.1rem;line-height:1.8}.lang-label{font-weight:600;color:var(--primary);margin-right:.5rem}.item-urdu .lang-label{margin-right:0;margin-left:.5rem}.item-actions{display:flex;gap:.5rem}.speak-button,.practice-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;color:#fff;border:none;border-radius:.5rem;font-weight:500;transition:all .2s;flex:1}.speak-button{background:var(--primary)}.speak-button:hover{background:var(--primary-dark)}.practice-button{background:var(--secondary)}.practice-button:hover{background:#7c3aed}.speak-button svg,.practice-button svg{width:1.2rem;height:1.2rem}.speech-practice-section{background:var(--bg);border-radius:1rem;padding:2rem;margin:2rem 0;border:2px solid var(--primary)}.speech-practice-section h2{font-size:1.5rem;margin-bottom:1.5rem;color:var(--text);text-align:center}.close-practice-button{display:block;margin:1.5rem auto 0;padding:.75rem 1.5rem;background:var(--bg);color:var(--text);border:2px solid var(--border);border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s}.close-practice-button:hover{border-color:var(--primary);background:#2563eb0d}.actions-section{display:flex;gap:1rem;justify-content:center;padding:2rem 0;flex-wrap:wrap}.action-button{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;border:none;border-radius:.75rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s}.action-button.primary{background:var(--primary);color:#fff}.action-button.primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.action-button.secondary{background:var(--card-bg);color:var(--text);border:2px solid var(--border)}.action-button.secondary:hover{background:var(--bg);border-color:var(--primary)}.lesson-not-found{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.lesson-not-found a{color:var(--primary);text-decoration:none;font-weight:500}@media (max-width: 768px){.lesson-header{padding:1.5rem 1rem}.lesson-title-section h1{font-size:1.8rem}.lesson-content{padding:1rem}.items-grid{grid-template-columns:1fr}.actions-section{flex-direction:column}.action-button{width:100%;justify-content:center}}.exercise-page{min-height:100vh;background:var(--bg)}.exercise-header{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);color:#fff;padding:2rem}.back-button{display:inline-flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;margin-bottom:1.5rem;font-weight:500;transition:opacity .2s}.back-button:hover{opacity:.8}.exercise-progress{max-width:800px;margin:0 auto}.progress-bar{width:100%;height:8px;background:#ffffff4d;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:#fff;transition:width .3s ease}.exercise-progress p{text-align:center;font-weight:500}.exercise-content{max-width:800px;margin:2rem auto;padding:0 2rem}.question-card{background:var(--card-bg);border-radius:1rem;padding:2rem;box-shadow:0 4px 16px #0000001a}.question-text{font-size:1.5rem;margin-bottom:2rem;color:var(--text);text-align:center}.audio-button{display:block;margin:0 auto 2rem;padding:.75rem 1.5rem;background:var(--secondary);color:#fff;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background .2s}.audio-button:hover{background:#7c3aed}.options-grid{display:grid;gap:1rem;margin-bottom:2rem}.option-button{padding:1.25rem;background:var(--bg);border:2px solid var(--border);border-radius:.75rem;font-size:1rem;text-align:left;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:space-between;font-weight:500}.option-button:hover:not(:disabled){border-color:var(--primary);background:#2563eb0d}.option-button.selected{border-color:var(--primary);background:#2563eb1a}.option-button.correct{border-color:var(--success);background:#10b9811a;color:var(--success)}.option-button.incorrect{border-color:var(--error);background:#ef44441a;color:var(--error)}.option-button:disabled{cursor:not-allowed}.result-icon{width:1.5rem;height:1.5rem}.result-message{padding:1rem;border-radius:.5rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;font-weight:500;text-align:center;justify-content:center}.result-message.correct{background:#10b9811a;color:var(--success)}.result-message.incorrect{background:#ef44441a;color:var(--error)}.exercise-actions{display:flex;justify-content:center}.submit-button,.next-button{padding:1rem 2rem;background:var(--primary);color:#fff;border:none;border-radius:.75rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.submit-button:hover:not(:disabled),.next-button:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.submit-button:disabled{opacity:.5;cursor:not-allowed}.exercise-completed{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.completion-content{background:var(--card-bg);border-radius:1.5rem;padding:3rem;text-align:center;box-shadow:0 8px 32px #0000001a;max-width:500px;width:100%}.completion-content h1{font-size:2.5rem;margin-bottom:2rem;color:var(--text)}.score-display{margin-bottom:2rem}.score-circle{display:inline-flex;align-items:baseline;justify-content:center;font-size:3rem;font-weight:700;color:var(--primary);margin-bottom:.5rem}.score-number{font-size:4rem}.score-total{font-size:2rem;color:var(--text-light)}.score-percentage{font-size:1.2rem;color:var(--text-light)}.completion-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.completion-actions .action-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:.75rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s}.completion-actions .action-button.primary{background:var(--primary);color:#fff}.completion-actions .action-button.primary:hover{background:var(--primary-dark);transform:translateY(-2px)}.completion-actions .action-button.secondary{background:var(--bg);color:var(--text);border:2px solid var(--border)}.completion-actions .action-button.secondary:hover{border-color:var(--primary)}.exercise-not-found{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.exercise-not-found a{color:var(--primary);text-decoration:none;font-weight:500}@media (max-width: 768px){.exercise-header{padding:1.5rem 1rem}.exercise-content{padding:0 1rem}.question-card{padding:1.5rem}.question-text{font-size:1.2rem}.completion-content{padding:2rem 1.5rem}.completion-content h1{font-size:2rem}.score-number{font-size:3rem}}.app-container{min-height:100vh;display:flex;flex-direction:column}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-dark: #1e40af;--secondary: #8b5cf6;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--bg: #f8fafc;--card-bg: #ffffff;--text: #1e293b;--text-light: #64748b;--border: #e2e8f0}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:var(--bg);color:var(--text);line-height:1.6}#root{min-height:100vh}button{cursor:pointer;font-family:inherit}input,textarea{font-family:inherit}
