@tailwind base;@tailwind components;@tailwind utilities;*{box-sizing:border-box}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;background-color:#f3f4f6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color: #3b82f6;--primary-hover: #2563eb;--secondary-color: #8b5cf6;--success-color: #10b981;--warning-color: #f59e0b;--danger-color: #ef4444;--info-color: #06b6d4;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background-color:var(--gray-50);color:var(--gray-900);line-height:1.5}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.25}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{margin:0}a{color:var(--primary-color);text-decoration:none;transition:color .2s ease}a:hover{color:var(--primary-hover);text-decoration:underline}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;background-color:var(--gray-100);padding:.125rem .25rem;border-radius:var(--radius-sm);font-size:.875em}pre{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;background-color:var(--gray-900);color:var(--gray-100);padding:var(--spacing-md);border-radius:var(--radius-md);overflow-x:auto}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit}button{font-family:inherit;font-size:inherit;line-height:inherit;cursor:pointer}:focus{outline:2px solid var(--primary-color);outline-offset:2px}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}::selection{background-color:var(--primary-color);color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.skeleton{background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-300) 50%,var(--gray-200) 75%);background-size:200% 100%;animation:loading 1.5s infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 640px){html{font-size:14px}}@media (max-width: 768px){.container{padding:0 var(--spacing-sm)}}@media print{body{background:#fff;color:#000}.no-print{display:none!important}}:root{--primary-color: #3b82f6;--primary-hover: #2563eb;--secondary-color: #8b5cf6;--success-color: #10b981;--warning-color: #f59e0b;--danger-color: #ef4444;--info-color: #06b6d4;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1);--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--z-dropdown: 1000;--z-modal: 1050;--z-popover: 1100;--z-tooltip: 1150}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:translateY(0);animation-timing-function:cubic-bezier(0,0,.2,1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.animate-fadeIn{animation:fadeIn .5s ease-out}.animate-slideIn{animation:slideIn .3s ease-out}.animate-slideUp{animation:slideUp .3s ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-bounce{animation:bounce 1s infinite}.animate-spin{animation:spin 1s linear infinite}.animate-scaleIn{animation:scaleIn .3s ease-out}.transition-all{transition:all .3s ease}.transition-colors{transition:background-color .3s ease,color .3s ease}.transition-transform{transition:transform .3s ease}.transition-opacity{transition:opacity .3s ease}.language-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:2px solid var(--gray-300);border-radius:var(--radius-full);font-size:1.25rem;cursor:pointer;transition:all .2s}.language-toggle:hover{border-color:var(--primary-color);box-shadow:var(--shadow-sm)}.language-toggle .flag{opacity:.5;transition:opacity .2s}.language-toggle .flag.active{opacity:1}.language-toggle .separator{color:var(--gray-400);font-size:1rem}.audio-control{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.audio-control.enabled{background:var(--success-color);color:#fff}.audio-control.enabled:hover{background:#059669;transform:scale(1.05)}.audio-control.disabled{background:var(--gray-200);color:var(--gray-600)}.audio-control.disabled:hover{background:var(--gray-300)}.control-label{font-weight:500}.countdown-timer{text-align:center;padding:1.5rem;background:#fff;border-radius:1rem;box-shadow:0 2px 8px #0000001a}.countdown-label{font-size:1rem;font-weight:500;color:#6b7280;margin-bottom:1rem}.countdown-display{display:flex;align-items:center;justify-content:center;gap:.5rem}.time-unit{text-align:center}.time-value{font-size:2.5rem;font-weight:700;color:#1f2937;line-height:1;font-variant-numeric:tabular-nums;background:#f3f4f6;padding:.75rem 1rem;border-radius:.5rem;min-width:70px}.time-label{font-size:.75rem;color:#6b7280;margin-top:.5rem;text-transform:uppercase;letter-spacing:.05em}.time-separator{font-size:2rem;font-weight:700;color:#9ca3af;align-self:flex-start;padding-top:.75rem}.countdown-timer.danger .time-value{background:#fee2e2;color:#991b1b;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.countdown-timer.compact{padding:0;background:transparent;box-shadow:none}.countdown-timer.compact .countdown-label{display:none}.countdown-timer.compact .countdown-display{gap:.25rem}.countdown-timer.compact .time-value{font-size:1.25rem;padding:.25rem .5rem;min-width:40px}.countdown-timer.compact .time-label{display:none}.countdown-timer.compact .time-separator{font-size:1rem;padding-top:.25rem}@media (max-width: 768px){.time-value{font-size:2rem;min-width:60px}.countdown-timer.compact .time-value{font-size:1rem;min-width:35px}}.classroom-header{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a}.header-content{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;max-width:1920px;margin:0 auto}.header-left{flex:1}.header-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0}.header-subtitle{font-size:.875rem;color:#6b7280;margin:.25rem 0 0}.header-center{flex:2;display:flex;justify-content:center}.session-info{display:flex;align-items:center;gap:2rem}.header-right{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:1rem}.session-code{font-size:.875rem;color:#6b7280}.session-code code{background:#f3f4f6;padding:.25rem .5rem;border-radius:.25rem;font-weight:600;color:#3b82f6}.student-login{width:100%;max-width:400px}.login-card{background:#fff;padding:3rem;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a}.login-header{text-align:center;margin-bottom:2rem}.login-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:#eff6ff;border-radius:50%;margin-bottom:1rem}.login-icon svg{color:#3b82f6}.login-header h2{font-size:1.875rem;font-weight:700;color:#1f2937;margin:0}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column}.form-group label{font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-input{padding:.75rem 1rem;font-size:1rem;border:1px solid #d1d5db;border-radius:.5rem;transition:all .2s}.form-input.error{border-color:#ef4444}.error-message{font-size:.875rem;color:#ef4444;margin-top:.25rem}.login-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.login-button:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.lesson-progress{background:#fff;padding:1.5rem;border-radius:1rem;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.progress-label{font-size:.875rem;font-weight:500;color:#6b7280}.progress-percentage{font-size:1.125rem;font-weight:700;color:#1f2937}.progress-bar{height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden;margin-bottom:.75rem}.progress-fill{height:100%;border-radius:6px;transition:width .5s ease-out;position:relative;overflow:hidden}.progress-glow{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:glow 2s ease-in-out infinite}@keyframes glow{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-milestones{display:flex;justify-content:space-between;font-size:.75rem}.milestone{color:#9ca3af;transition:color .3s}.milestone.completed{color:#10b981;font-weight:600}.logout-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;margin-left:1rem}.logout-btn:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.logout-btn svg{width:20px;height:20px}.header-right{display:flex;align-items:center;gap:1rem}.student-dropdown{position:relative;display:inline-block}.student-dropdown-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f8fafc;color:#374151;border:1px solid #e2e8f0;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.student-dropdown-toggle:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.student-name{font-weight:600;color:#1f2937}.dropdown-arrow{transition:transform .2s ease;color:#6b7280}.dropdown-arrow.rotated{transform:rotate(180deg)}.student-dropdown-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;min-width:160px;z-index:1000;overflow:hidden}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;color:#374151;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:left}.dropdown-item:hover{background:#f8fafc;color:#1f2937}.dropdown-item:first-child{border-bottom:1px solid #f1f5f9}.dropdown-item svg{color:#6b7280;width:16px;height:16px}.dropdown-item:hover svg{color:#3b82f6}.virtual-teacher-avatar{display:flex;flex-direction:column;align-items:center;padding:2rem;background:#fff;border-radius:1rem;box-shadow:var(--shadow-lg);transition:transform .3s ease}.virtual-teacher-avatar:hover{transform:translateY(-5px)}.avatar-stage{position:relative;margin-bottom:1.5rem}.avatar-svg{filter:drop-shadow(0 4px 6px rgba(0,0,0,.1));transition:transform .3s ease}.avatar-svg:hover{transform:scale(1.05)}.speaking-indicator{position:absolute;bottom:-20px;left:50%;transform:translate(-50%)}.sound-wave{display:flex;align-items:center;gap:3px;height:20px}.sound-wave span{display:block;width:3px;height:100%;background:var(--primary-color);border-radius:3px;animation:soundWave 1s ease-in-out infinite}.sound-wave span:nth-child(2){animation-delay:.1s}.sound-wave span:nth-child(3){animation-delay:.2s}.sound-wave span:nth-child(4){animation-delay:.3s}.sound-wave span:nth-child(5){animation-delay:.4s}@keyframes soundWave{0%,to{height:5px}50%{height:20px}}.avatar-info{text-align:center}.avatar-name{font-size:1.5rem;font-weight:600;color:var(--gray-800);margin-bottom:.5rem}.audio-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.audio-toggle.enabled{background:var(--success-color);color:#fff}.audio-toggle.disabled{background:var(--gray-200);color:var(--gray-600)}.audio-toggle:hover{transform:scale(1.05)}.chat-interface{height:100%;display:flex;flex-direction:column;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.chat-header{display:flex;align-items:center;gap:.5rem;padding:1rem;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.chat-header h3{flex:1;font-size:1.125rem;font-weight:600;color:var(--gray-800);margin:0}.chat-status{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--gray-600)}.status-indicator{width:8px;height:8px;border-radius:50%;background:var(--gray-400)}.status-indicator.active{background:var(--success-color);animation:pulse 2s infinite}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--gray-400);text-align:center;padding:2rem}.empty-icon{margin-bottom:1rem;opacity:.5}.chat-message{padding:.75rem;border-radius:var(--radius-md);animation:fadeIn .3s ease-out}.message-teacher{background:#dbeafe;border:1px solid #93c5fd}.message-student{background:#d1fae5;border:1px solid #86efac}.message-system{background:var(--gray-100);border:1px solid var(--gray-200)}.own-message{background:#e0e7ff;border:1px solid #a5b4fc;margin-left:2rem}.message-header{display:flex;justify-content:space-between;margin-bottom:.25rem}.message-author{font-weight:600;font-size:.875rem;color:var(--gray-700)}.message-time{font-size:.75rem;color:var(--gray-500)}.message-content{color:var(--gray-800);line-height:1.5}.typing-indicator{display:flex;gap:4px;padding:.75rem}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:var(--gray-400);animation:bounce 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}.quick-actions{padding:.75rem;background:var(--gray-50);border-top:1px solid var(--gray-200)}.quick-actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.quick-action-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem;border:1px solid var(--gray-200);border-radius:var(--radius-md);background:#fff;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease}.quick-action-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.action-emoji{font-size:1rem}.action-yellow:hover{background:#fef3c7;border-color:#fcd34d;color:#92400e}.action-blue:hover{background:#dbeafe;border-color:#60a5fa;color:#1e3a8a}.action-purple:hover{background:#ede9fe;border-color:#a78bfa;color:#5b21b6}.action-green:hover{background:#d1fae5;border-color:#34d399;color:#065f46}.action-orange:hover{background:#fed7aa;border-color:#fb923c;color:#9a3412}.action-cyan:hover{background:#cffafe;border-color:#22d3ee;color:#155e75}.chat-input-container{display:flex;gap:.5rem;padding:1rem;background:#fff;border-top:1px solid var(--gray-200)}.chat-input{flex:1;padding:.75rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:.875rem;outline:none;transition:border-color .2s ease}.chat-input:focus{border-color:var(--primary-color)}.chat-input:disabled{background:var(--gray-100);cursor:not-allowed}.send-button{padding:.75rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.send-button:hover:not(:disabled){background:var(--primary-hover);transform:scale(1.05)}.send-button:disabled{background:var(--gray-400);cursor:not-allowed}.status-indicator.waiting{background:#fbbf24;animation:pulse 2s infinite}.waiting-note{font-size:.875rem;color:#6b7280;margin-top:.5rem;font-style:italic}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.loading-spinner{display:inline-block;position:relative}.spinner-small{width:32px;height:32px}.spinner-medium{width:64px;height:64px}.spinner-large{width:96px;height:96px}.spinner-ring{display:block;position:absolute;width:100%;height:100%;border:3px solid transparent;border-radius:50%;border-top-color:var(--primary-color);animation:spin 1.2s cubic-bezier(.5,0,.5,1) infinite}.spinner-ring:nth-child(1){animation-delay:-.45s}.spinner-ring:nth-child(2){animation-delay:-.3s}.spinner-ring:nth-child(3){animation-delay:-.15s}.loading-text{margin-top:1rem;color:var(--gray-600);font-size:.875rem}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gray-50)}.error-content{text-align:center;padding:3rem;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:400px}.error-icon{color:var(--danger-color);margin-bottom:1rem}.error-content h2{font-size:1.5rem;margin-bottom:.5rem;color:var(--gray-800)}.error-content p{color:var(--gray-600);margin-bottom:1.5rem}.error-reload-btn{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s}.error-reload-btn:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.virtual-classroom{height:100vh;display:flex;flex-direction:column;background-color:#f3f4f6}.virtual-classroom-loading{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f3f4f6}.virtual-classroom-loading p{margin-top:1rem;color:#6b7280;font-size:1.125rem}.virtual-classroom-login{height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);position:relative}.virtual-classroom-login .language-toggle{position:absolute;top:2rem;right:2rem}.classroom-main{flex:1;display:flex;overflow:hidden}.classroom-content{flex:1;display:flex;flex-direction:column;padding:2rem;overflow-y:auto}.avatar-section{margin-bottom:2rem;animation:fadeIn .5s ease-out}.lesson-content{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 4px 6px #0000001a;animation:slideIn .5s ease-out}.lesson-content h2{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.lesson-section{font-size:1.125rem;line-height:1.75;color:#374151}.error-message{background:#fee2e2;border:1px solid #fca5a5;border-radius:.5rem;padding:1rem;margin-top:1rem;text-align:center}.error-message p{color:#991b1b;margin-bottom:.5rem}.error-message button{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.25rem;cursor:pointer;font-weight:500;transition:background .2s}.error-message button:hover{background:#dc2626}.classroom-sidebar{width:400px;padding:1rem}@media (max-width: 1024px){.classroom-main{flex-direction:column}.classroom-sidebar{width:100%;height:400px}}@media (max-width: 768px){.classroom-content{padding:1rem}.lesson-content{padding:1.5rem}.lesson-content h2{font-size:1.5rem}.classroom-sidebar{height:300px}}.waiting-room{flex:1;display:flex;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2)}.waiting-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#fff}.waiting-content h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-align:center}.waiting-content>p{font-size:1.25rem;margin-bottom:3rem;text-align:center;opacity:.9}.waiting-info{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:1rem;margin-top:3rem;max-width:400px}.waiting-info p{font-size:1.125rem;font-weight:600;margin-bottom:1rem}.waiting-info ul{list-style:none;padding:0;margin:0}.waiting-info li{padding:.5rem 0 .5rem 1.5rem;position:relative}.waiting-info li:before{content:"✓";position:absolute;left:0;color:#10b981;font-weight:700}.countdown-timer.large{background:#fffffff2;padding:2.5rem;box-shadow:0 10px 40px #0003}.countdown-timer.large .time-value{font-size:4rem;min-width:100px}.late-join-notice{background:#fef3c7;border:1px solid #fcd34d;border-radius:.5rem;padding:1rem 1.5rem;margin-bottom:1rem;color:#92400e;font-weight:500;text-align:center;animation:slideIn .5s ease-out}.session-status-badge{display:inline-block;padding:.25rem .75rem;border-radius:.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.session-card.upcoming .session-status-badge{background:#fef3c7;color:#92400e}.session-card.active .session-status-badge{background:#d1fae5;color:#065f46}.session-timing{margin:1rem 0;padding:1rem;background:#f9fafb;border-radius:.5rem}.virtual-classroom-ended{height:100vh;display:flex;align-items:center;justify-content:center;background:#f3f4f6}.ended-content{text-align:center;padding:3rem;background:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a;max-width:500px}.ended-content h2{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.ended-content p{font-size:1.125rem;color:#6b7280;margin-bottom:2rem}.ended-content .btn-primary{margin:0 auto}.teacher-dashboard{min-height:100vh;background-color:#f3f4f6}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.btn-primary:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.btn-primary:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.btn-danger{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#dc2626}.btn-link{display:inline-flex;align-items:center;gap:.25rem;color:#3b82f6;background:none;border:none;cursor:pointer;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s;padding:0}.btn-link:hover{color:#2563eb;text-decoration:underline}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;padding:1.5rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:1.5rem;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.stat-icon{width:60px;height:60px;border-radius:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.blue{background:#dbeafe;color:#3b82f6}.stat-icon.green{background:#d1fae5;color:#10b981}.stat-icon.purple{background:#ede9fe;color:#8b5cf6}.stat-content{flex:1}.stat-content h3{font-size:.875rem;font-weight:500;color:#6b7280;margin:0 0 .25rem}.stat-value{font-size:2rem;font-weight:700;color:#1f2937;margin:0;line-height:1}.dashboard-section{margin-bottom:3rem}.dashboard-section h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem}.sessions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.session-card{background:#fff;padding:1.5rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a;transition:all .2s;border:2px solid transparent}.session-card.active{border-color:#10b981}.session-header h3{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0;flex:1;margin-right:1rem}.session-code{font-size:.875rem;font-weight:600;color:#3b82f6;background:#eff6ff;padding:.25rem .75rem;border-radius:.25rem;white-space:nowrap}.session-info{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;font-size:.875rem;color:#6b7280}.session-info span{display:flex;align-items:center;gap:.25rem}.session-info svg{width:16px;height:16px}.session-actions{display:flex;gap:.5rem;margin-top:1rem}.recent-sessions{background:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 1px 3px #0000001a}.recent-session-item{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;transition:background .2s;gap:1rem}.recent-session-item:last-child{border-bottom:none}.recent-session-item:hover{background:#f9fafb}.session-details{flex:1;min-width:0}.session-details h4{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-details p{font-size:.875rem;color:#6b7280;margin:0}.session-stats{display:flex;align-items:center;gap:1.5rem;font-size:.875rem;color:#6b7280;flex-shrink:0}.session-stats span{display:flex;align-items:center;gap:.25rem;white-space:nowrap}.session-stats svg{width:16px;height:16px;flex-shrink:0}.completion-rate{font-weight:600;color:#10b981}.empty-state{text-align:center;padding:3rem 2rem;color:#6b7280;background:#fff;border-radius:1rem;box-shadow:0 1px 3px #0000001a}.empty-state svg{width:64px;height:64px;margin:0 auto 1rem;color:#d1d5db}.empty-state h3{font-size:1.125rem;font-weight:600;color:#4b5563;margin:0 0 .5rem}.empty-state p{margin:0;color:#9ca3af}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.modal-content{background:#fff;padding:2rem;border-radius:1rem;width:90%;max-width:600px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-content h2{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:#1f2937}.modal-content p{color:#6b7280;margin:0 0 1.5rem}.lessons-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.lesson-option{padding:1rem;border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;transition:all .2s}.lesson-option.selected{border-color:#3b82f6;background:#eff6ff}.lesson-option:hover{border-color:#3b82f6}.lesson-option h4{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 .25rem}.lesson-option p{font-size:.875rem;color:#6b7280;margin:0}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}@media (max-width: 768px){.dashboard-header .header-content{flex-direction:column;align-items:flex-start;gap:1rem}.header-actions{width:100%;justify-content:space-between}.stats-grid,.sessions-grid{grid-template-columns:1fr}.session-info{flex-direction:column;gap:.5rem}.recent-session-item{flex-direction:column;align-items:flex-start}.session-stats{width:100%;justify-content:space-between;margin-top:.5rem}.modal-content{padding:1.5rem}}.recent-sessions{min-height:200px}.dashboard-section{border:1px solid transparent}.modal-content.extended{max-width:700px;max-height:90vh}.session-scheduling{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.session-scheduling h3{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0 0 .5rem}.schedule-note{font-size:.875rem;color:#6b7280;margin-bottom:1rem}.schedule-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.schedule-inputs .form-group{display:flex;flex-direction:column;gap:.5rem}.schedule-inputs label{font-size:.875rem;font-weight:500;color:#374151}.schedule-inputs input[type=datetime-local]{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;color:#1f2937}.schedule-inputs input[type=datetime-local]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.session-card.upcoming{border-color:#fbbf24;background:#fffbeb}.session-card.completed{border-color:#e5e7eb;background:#f9fafb}.header-right .countdown-timer.compact{margin-right:1rem}.countdown-timer.warning .time-value{background:#fef3c7;color:#92400e}.countdown-timer.danger .time-value{background:#fee2e2;color:#991b1b}.lesson-upload-modal{background:#fff;border-radius:1rem;width:90%;max-width:900px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb}.modal-header h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0}.close-btn{background:none;border:none;color:#6b7280;cursor:pointer;padding:.5rem;border-radius:.375rem;transition:all .2s}.close-btn:hover{background:#f3f4f6;color:#1f2937}.upload-methods{display:flex;gap:1rem;padding:1.5rem 2rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.method-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:#fff;border:2px solid #e5e7eb;border-radius:.5rem;font-size:.875rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s}.method-btn:hover{border-color:#3b82f6;color:#3b82f6}.method-btn.active{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.file-upload-section{padding:2rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.upload-area{border:2px dashed #d1d5db;border-radius:.75rem;padding:3rem;text-align:center;background:#fff;transition:all .2s}.upload-label{display:block;cursor:pointer;color:#6b7280}.upload-label:hover .upload-area{border-color:#3b82f6;background:#f0f9ff}.upload-label svg{color:#9ca3af;margin-bottom:1rem}.upload-label p{margin:.5rem 0}.file-type{font-size:.875rem;color:#9ca3af}.upload-note{margin-top:1rem;font-size:.875rem;color:#6b7280;text-align:center}.upload-note p{margin:.25rem 0}.lesson-form{flex:1;overflow-y:auto;padding:2rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem;color:#6b7280}.form-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e5e7eb}.form-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section h3{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.form-group.small{max-width:150px}.form-group label{font-size:.875rem;font-weight:500;color:#374151}.form-group input,.form-group select,.form-group textarea{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:100px}.section-editor{background:#f9fafb;padding:1.5rem;border-radius:.5rem;margin-bottom:1rem;border:1px solid #e5e7eb}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h4{font-size:1rem;font-weight:600;color:#1f2937;margin:0}.array-item{display:flex;gap:.5rem;margin-bottom:.5rem}.array-item input{flex:1}.remove-btn{background:#fee2e2;color:#991b1b;border:none;border-radius:.375rem;padding:.5rem;cursor:pointer;transition:all .2s}.remove-btn:hover{background:#fca5a5}.remove-btn.small{padding:.375rem}.add-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.5rem .75rem;background:#eff6ff;color:#3b82f6;border:1px solid #3b82f6;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.add-btn:hover{background:#3b82f6;color:#fff}.add-btn.small{padding:.375rem .5rem;font-size:.75rem}.add-section-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;background:#fff;border:2px dashed #d1d5db;border-radius:.5rem;color:#6b7280;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.add-section-btn:hover{border-color:#3b82f6;color:#3b82f6;background:#f0f9ff}.preview-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s}.preview-btn:hover{border-color:#3b82f6;color:#3b82f6}.preview-container{background:#fff;padding:2rem;border-radius:.5rem;border:1px solid #e5e7eb}.preview-container h4{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 .5rem}.preview-meta{font-size:.875rem;color:#6b7280;margin-bottom:1.5rem}.preview-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.preview-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.preview-section h5{font-size:1rem;font-weight:600;color:#374151;margin:0 0 .75rem}.preview-section p{color:#1f2937;line-height:1.6;margin-bottom:1rem}.preview-list{margin-top:.75rem}.preview-list strong{font-size:.875rem;color:#374151}.preview-list ul{margin:.5rem 0 0 1.5rem;padding:0}.preview-list li{font-size:.875rem;color:#4b5563;margin-bottom:.25rem}.error-message{background:#fee2e2;border:1px solid #fca5a5;border-radius:.5rem;padding:1rem;margin:1rem 0}.error-message p{color:#991b1b;margin:0;font-size:.875rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem 2rem;background:#f9fafb;border-top:1px solid #e5e7eb}@media (max-width: 768px){.lesson-upload-modal{width:100%;height:100vh;max-height:100vh;border-radius:0}.upload-methods{flex-direction:column}.form-row{grid-template-columns:1fr}.form-group.small{max-width:none}.section-editor,.preview-container{padding:1rem}}.session-report{min-height:100vh;background-color:#f3f4f6}.report-loading,.report-error{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.report-error button{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s}.report-error button:hover{background:#2563eb}.report-header{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.report-header .header-content{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;max-width:1400px;margin:0 auto;gap:2rem}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;color:#4b5563;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.back-button:hover{background:#f9fafb;border-color:#9ca3af;transform:translate(-2px)}.header-title{flex:1}.header-title h1{font-size:1.875rem;font-weight:700;color:#1f2937;margin:0}.header-title p{font-size:1rem;color:#6b7280;margin:.25rem 0 0}.header-actions{display:flex;gap:.75rem}.header-actions .btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;color:#4b5563;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.header-actions .btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.report-content{max-width:1400px;margin:0 auto;padding:0 2rem 2rem}.summary-section{margin-bottom:2rem}.summary-section h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{background:#fff;padding:1.5rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:1rem;transition:transform .2s,box-shadow .2s}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.card-icon{width:56px;height:56px;padding:1rem;border-radius:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.card-icon svg{width:24px;height:24px}.summary-card:nth-child(1) .card-icon{background:#dbeafe;color:#3b82f6}.summary-card:nth-child(2) .card-icon{background:#fce7f3;color:#ec4899}.summary-card:nth-child(3) .card-icon{background:#e0e7ff;color:#6366f1}.summary-card:nth-child(4) .card-icon{background:#d1fae5;color:#10b981}.card-content{flex:1}.card-content h3{font-size:.875rem;font-weight:500;color:#6b7280;margin:0 0 .25rem}.card-value{font-size:2rem;font-weight:700;color:#1f2937;margin:0;line-height:1}.engagement-section{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.engagement-section h2{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem}.engagement-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e5e7eb}.stat-item{display:flex;flex-direction:column;gap:.5rem}.stat-label{font-size:.875rem;font-weight:500;color:#6b7280}.stat-value{font-size:1.75rem;font-weight:700;color:#1f2937;line-height:1}.struggling-topics h3{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 1rem}.struggling-topics ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.struggling-topics li{padding:.75rem 1rem;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:.25rem;color:#92400e;font-size:.875rem;font-weight:500}.attendance-section{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.attendance-section h2{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem}.attendance-table{overflow-x:auto;margin:-2rem;padding:2rem}.attendance-table table{width:100%;border-collapse:collapse;font-size:.875rem}.attendance-table thead{background:#f9fafb}.attendance-table th{text-align:left;padding:.75rem 1rem;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb;white-space:nowrap}.attendance-table td{padding:.75rem 1rem;color:#1f2937;border-bottom:1px solid #f3f4f6}.attendance-table tbody tr:hover{background:#f9fafb}.engagement-badge{display:inline-block;padding:.25rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:600;text-align:center;min-width:60px}.engagement-badge.high{background:#d1fae5;color:#065f46}.engagement-badge.medium{background:#fef3c7;color:#92400e}.engagement-badge.low{background:#fee2e2;color:#991b1b}.questions-section{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a}.questions-section h2{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem}.questions-list{display:flex;flex-direction:column;gap:1rem}.question-item{padding:1rem 1.5rem;background:#f9fafb;border-radius:.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:all .2s}.question-item:hover{background:#f3f4f6}.question-text{font-size:.875rem;color:#1f2937;font-weight:500;flex:1}.question-count{font-size:.75rem;font-weight:600;color:#3b82f6;background:#eff6ff;padding:.375rem .75rem;border-radius:.375rem;white-space:nowrap}@media (max-width: 1024px){.report-header .header-content{flex-wrap:wrap}.header-title{width:100%;margin-bottom:1rem}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media (max-width: 768px){.report-header .header-content{padding:1rem}.report-content{padding:0 1rem 2rem}.header-actions{flex-wrap:wrap;width:100%}.header-actions .btn-secondary{flex:1}.summary-grid{grid-template-columns:1fr 1fr;gap:1rem}.summary-card{padding:1rem}.card-icon{width:48px;height:48px;padding:.75rem}.card-value{font-size:1.5rem}.engagement-stats{grid-template-columns:1fr 1fr;gap:1.5rem}.attendance-table{margin:-1rem;padding:1rem}.attendance-table th,.attendance-table td{padding:.5rem;font-size:.75rem}.question-item{flex-direction:column;align-items:flex-start}}@media (max-width: 480px){.summary-grid,.engagement-stats{grid-template-columns:1fr}}.session-info-section{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a;margin-top:2rem}.session-info-section h2{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem}.session-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.875rem;font-weight:500;color:#6b7280}.info-value{font-size:1rem;font-weight:600;color:#1f2937}@media print{.report-header{position:static;box-shadow:none;border-bottom:2px solid #000}.back-button,.header-actions{display:none!important}.summary-card,.engagement-section,.attendance-section,.questions-section{box-shadow:none;border:1px solid #e5e7eb;break-inside:avoid}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.auth-card{background:#fff;padding:2.5rem;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a;width:100%;max-width:480px;animation:fadeIn .5s ease-out}.auth-header{text-align:center;margin-bottom:2rem}.auth-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:#eff6ff;border-radius:50%;margin-bottom:1rem}.auth-icon svg{color:#3b82f6}.auth-header h2{font-size:1.875rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.auth-header p{font-size:1rem;color:#6b7280;margin:0}.error-alert{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fee2e2;border:1px solid #fca5a5;border-radius:.5rem;color:#991b1b;margin-bottom:1.5rem;font-size:.875rem}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:#374151}.form-group label svg{color:#6b7280}.form-input{padding:.75rem 1rem;font-size:1rem;border:1px solid #d1d5db;border-radius:.5rem;transition:all .2s;width:100%}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:#9ca3af}.submit-button{padding:.875rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;margin-top:.5rem}.submit-button:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.submit-button:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.auth-footer{text-align:center;margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.auth-footer p{color:#6b7280;font-size:.875rem;margin:0}.auth-link{color:#3b82f6;text-decoration:none;font-weight:500;margin-left:.25rem}.auth-link:hover{text-decoration:underline}@media (max-width: 640px){.auth-card{padding:2rem}.form-row{grid-template-columns:1fr}.auth-header h2{font-size:1.5rem}}.student-dashboard{min-height:100vh;background-color:#f3f4f6}.dashboard-loading{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.dashboard-header{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;padding:0;margin-bottom:2rem}.dashboard-header .header-content{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;max-width:1400px;margin:0 auto}.dashboard-header h1{font-size:2rem;font-weight:700;color:#1f2937;margin:0}.dashboard-header .subtitle{font-size:1rem;color:#6b7280;margin-top:.25rem}.header-actions{display:flex;align-items:center;gap:1rem}.dashboard-content{max-width:1400px;margin:0 auto;padding:0 2rem 2rem}.sessions-section{margin-bottom:3rem}.section-title{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem}.title-icon{position:relative;display:flex;align-items:center;justify-content:center}.title-icon.active{color:#10b981}.pulse-indicator{position:absolute;width:12px;height:12px;background:#10b981;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 10px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}.sessions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.5rem}.session-card{background:#fff;padding:1.5rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a;transition:all .3s;border:2px solid transparent}.session-card.active{border-color:#10b981;background:#f0fdf4}.session-card.upcoming{border-color:#3b82f6}.session-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.session-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.session-header h3{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0;flex:1;margin-right:1rem}.session-badge{font-size:.75rem;font-weight:700;padding:.375rem .75rem;border-radius:.375rem;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.session-badge.active{background:#10b981;color:#fff;animation:pulse-text 2s infinite}.session-badge.upcoming{background:#3b82f6;color:#fff}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.8}}.session-info{display:flex;gap:.75rem;margin-bottom:1rem}.info-item{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.875rem}.info-item svg{color:#9ca3af;flex-shrink:0}.session-code{background:#f9fafb;padding:.75rem;border-radius:.5rem;font-size:.875rem;color:#6b7280;margin-bottom:1rem;text-align:center}.session-code code{font-weight:600;color:#1f2937;background:#fff;padding:.25rem .5rem;border-radius:.25rem;margin-left:.5rem}.join-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.join-button.active{background:#10b981;color:#fff}.join-button.active:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.join-button.upcoming{background:#3b82f6;color:#fff}.join-button.upcoming:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.no-sessions{text-align:center;padding:4rem 2rem;color:#6b7280}.no-sessions svg{width:64px;height:64px;margin:0 auto 1.5rem;color:#d1d5db}.no-sessions h3{font-size:1.5rem;font-weight:600;color:#4b5563;margin:0 0 .5rem}.no-sessions p{margin:.5rem 0;color:#9ca3af}.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;color:#4b5563;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}@media (max-width: 768px){.dashboard-header .header-content{flex-direction:column;align-items:flex-start;gap:1rem}.header-actions{width:100%;justify-content:space-between}.sessions-grid{grid-template-columns:1fr}.session-info{gap:.5rem}}.grade-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;background:#e0e7ff;color:#4338ca;border-radius:.375rem;font-size:.75rem;font-weight:600;margin-left:.5rem}.session-card .session-header{flex-wrap:wrap;gap:.5rem}
