: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}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#333;background-color:#f5f7fa}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.app-header h1{font-size:1.8rem;font-weight:600}.user-info{display:flex;align-items:center;gap:1rem}.sign-out-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;transition:background-color .2s}.sign-out-btn:hover{background:#ffffff4d}.app-main{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading{text-align:center;padding:2rem;font-size:1.1rem;color:#666}.btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s;text-decoration:none;display:inline-block;text-align:center}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5a6fd8;transform:translateY(-1px)}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-success{background:#28a745;color:#fff}.btn-success:hover:not(:disabled){background:#218838}.btn-warning{background:#ffc107;color:#212529}.btn-warning:hover:not(:disabled){background:#e0a800}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.btn-outline{background:transparent;color:#667eea;border:1px solid #667eea}.btn-outline:hover:not(:disabled){background:#667eea;color:#fff}.btn-sm{padding:.5rem 1rem;font-size:.8rem}.btn:disabled{opacity:.6;cursor:not-allowed}.login-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:2rem}.login-container{background:#fff;border-radius:1rem;box-shadow:0 20px 40px #0000001a;overflow:hidden;max-width:500px;width:100%}.login-header{text-align:center;padding:2rem 2rem 1rem;background:linear-gradient(135deg,#f8f9ff,#e8eeff)}.login-header h1{color:#333;margin-bottom:.5rem;font-size:2rem}.login-header p{color:#666;font-size:.9rem}.login-form-container{padding:2rem}.login-tabs{display:flex;margin-bottom:2rem;border-bottom:1px solid #eee}.login-tabs .tab{flex:1;padding:1rem;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-weight:500;color:#666;transition:all .2s}.login-tabs .tab.active{color:#667eea;border-bottom-color:#667eea}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label{font-weight:500;color:#333;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid #ddd;border-radius:.5rem;font-size:.9rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-button{background:#667eea;color:#fff;padding:1rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:1rem}.login-button:hover:not(:disabled){background:#5a6fd8}.login-help{text-align:center;margin-top:1.5rem;font-size:.9rem;color:#666}.link-button{background:none;border:none;color:#667eea;cursor:pointer;text-decoration:underline}.error-message{background:#ffeaea;color:#d63031;padding:.75rem;border-radius:.5rem;border:1px solid #fab1a0;font-size:.9rem}.dashboard-header{text-align:center;margin-bottom:2rem}.dashboard-header h2{font-size:2.5rem;color:#333;margin-bottom:.5rem}.dashboard-header p{color:#666;font-size:1.1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 4px 6px #0000001a;text-align:center;transition:transform .2s}.stat-card:hover{transform:translateY(-2px)}.stat-card h3{font-size:2.5rem;color:#667eea;margin-bottom:.5rem;font-weight:700}.stat-card p{color:#666;font-weight:500}.dashboard-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:1px solid #eee}.dashboard-tabs .tab{padding:1rem 1.5rem;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-weight:500;color:#666;transition:all .2s}.dashboard-tabs .tab.active{color:#667eea;border-bottom-color:#667eea}.dashboard-content{background:#fff;border-radius:1rem;box-shadow:0 4px 6px #0000001a;padding:2rem}.admin-section{padding:1rem 0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-header h3{font-size:1.5rem;color:#333}.data-table{overflow-x:auto;margin-top:1rem}.data-table table{width:100%;border-collapse:collapse;background:#fff}.data-table th,.data-table td{padding:1rem;text-align:left;border-bottom:1px solid #eee}.data-table th{background:#f8f9fa;font-weight:600;color:#333}.data-table tr:hover{background:#f8f9fa}.status{padding:.25rem .75rem;border-radius:1rem;font-size:.8rem;font-weight:500;text-transform:uppercase}.status.active{background:#d4edda;color:#155724}.status.inactive{background:#f8d7da;color:#721c24}.status.completed{background:#d1ecf1;color:#0c5460}.status.in-progress{background:#fff3cd;color:#856404}.status.not-started{background:#e2e3e5;color:#383d41}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal{background:#fff;border-radius:1rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #eee}.modal-header h4{font-size:1.25rem;color:#333}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-btn:hover{background:#f8f9fa}.modal-form{padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.class-card{background:#fff;border:1px solid #eee;border-radius:1rem;padding:1.5rem;transition:all .2s}.class-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.class-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.class-header h4{color:#333;font-size:1.2rem}.class-type{background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:500}.class-stats{display:flex;gap:2rem;margin:1rem 0}.stat{text-align:center}.stat-number{display:block;font-size:1.5rem;font-weight:700;color:#667eea}.stat-label{font-size:.8rem;color:#666}.header-controls{display:flex;gap:1rem;align-items:center}.class-filter{padding:.5rem;border:1px solid #ddd;border-radius:.5rem}.progress-bar{background:#e9ecef;border-radius:1rem;height:20px;position:relative;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#28a745,#20c997);height:100%;transition:width .3s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:500;color:#333}.student-dashboard{display:flex;flex-direction:column;gap:2rem}.student-nav{display:flex;gap:1rem;background:#fff;padding:1rem;border-radius:1rem;box-shadow:0 2px 10px #0000001a}.nav-btn{padding:.75rem 1.5rem;background:none;border:none;border-radius:.5rem;cursor:pointer;font-weight:500;transition:all .2s;color:#666}.nav-btn.active{background:#667eea;color:#fff}.student-content{flex:1}.student-main{display:flex;flex-direction:column;gap:2rem}.welcome-section{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 4px 6px #0000001a;text-align:center}.welcome-section h2{color:#333;margin-bottom:.5rem}.activities-section{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 4px 6px #0000001a}.activity-category{margin-bottom:2rem}.activity-category h4{color:#333;margin-bottom:1rem;font-size:1.3rem}.activities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.activity-card{border:1px solid #eee;border-radius:1rem;padding:1.5rem;transition:all .2s}.activity-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.activity-card.completed{background:#f8fff9;border-color:#28a745}.activity-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.activity-header h5{color:#333;font-size:1.1rem}.activity-status{margin-left:1rem}.activity-actions{display:flex;justify-content:space-between;align-items:center;margin-top:1rem}.score{background:#28a745;color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.8rem;font-weight:500}.quiz-info{display:flex;gap:1rem;margin:.5rem 0;font-size:.9rem;color:#666}.progress-section{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 4px 6px #0000001a}.progress-stats{display:flex;justify-content:space-around;margin-top:1rem}.progress-stat{text-align:center}.student-notebook{background:#fff;border-radius:1rem;box-shadow:0 4px 6px #0000001a;padding:2rem}.notebook-header{text-align:center;margin-bottom:2rem}.notebook-header h2{color:#333;margin-bottom:.5rem}.notebook-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem}.search-filters{display:flex;gap:1rem;flex:1;max-width:600px}.search-input,.tag-filter{padding:.75rem;border:1px solid #ddd;border-radius:.5rem;font-size:.9rem}.search-input{flex:2}.tag-filter{flex:1}.notes-stats{display:flex;gap:2rem;margin-bottom:2rem;justify-content:center}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.note-card{border:1px solid #eee;border-radius:1rem;padding:1.5rem;transition:all .2s;background:#fff}.note-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.note-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.note-header h4{color:#333;font-size:1.1rem;flex:1}.note-meta{display:flex;gap:.5rem;flex-direction:column;align-items:flex-end}.subject{background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem}.private-badge{background:#ffc107;color:#212529;padding:.25rem .5rem;border-radius:.5rem;font-size:.7rem}.note-content{margin-bottom:1rem;color:#666;line-height:1.6}.note-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tag{background:#e9ecef;color:#495057;padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;display:flex;align-items:center;gap:.5rem}.tag button{background:none;border:none;color:#6c757d;cursor:pointer;font-size:.8rem;padding:0;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.tag button:hover{background:#dc3545;color:#fff}.note-footer{display:flex;justify-content:space-between;align-items:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.note-dates{display:flex;flex-direction:column;gap:.25rem}.note-dates small{color:#6c757d;font-size:.75rem}.note-actions{display:flex;gap:.5rem}.tags-input{display:flex;flex-direction:column;gap:.5rem}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.notebook-modal{max-width:700px}.empty-state{text-align:center;padding:4rem 2rem;color:#666}.empty-state h3{margin-bottom:1rem;color:#333}.error-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:1rem;box-shadow:0 4px 6px #0000001a}.error-state h3{color:#dc3545;margin-bottom:1rem}.quiz-container{background:#fff;border-radius:1rem;box-shadow:0 4px 6px #0000001a;min-height:80vh}.quiz-header{display:flex;justify-content:space-between;align-items:flex-start;padding:2rem;border-bottom:1px solid #eee}.quiz-info h2{color:#333;margin-bottom:.5rem}.quiz-controls{display:flex;gap:1rem;align-items:center}.timer{background:#28a745;color:#fff;padding:.5rem 1rem;border-radius:.5rem;font-weight:600}.timer.warning{background:#dc3545;animation:pulse 1s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.quiz-content{display:flex;height:calc(80vh - 100px)}.notebook-sidebar{width:300px;background:#f8f9fa;padding:1.5rem;border-right:1px solid #eee;overflow-y:auto}.notebook-sidebar h4{margin-bottom:1rem;color:#333}.notebook-preview{background:#fff;padding:1rem;border-radius:.5rem;border:1px solid #eee}.quiz-main{flex:1;padding:2rem;display:flex;flex-direction:column}.quiz-progress{margin-bottom:2rem}.quiz-progress .progress-bar{margin-bottom:.5rem}.question-container{flex:1;margin-bottom:2rem}.question-container h3{color:#333;margin-bottom:1rem}.question-text{font-size:1.1rem;color:#333;margin-bottom:1.5rem;line-height:1.6}.options-container{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.option-label{display:flex;align-items:center;gap:1rem;padding:1rem;border:1px solid #eee;border-radius:.5rem;cursor:pointer;transition:all .2s}.option-label:hover{background:#f8f9fa;border-color:#667eea}.option-label input[type=radio]{margin:0}.answer-textarea{width:100%;min-height:120px;padding:1rem;border:1px solid #ddd;border-radius:.5rem;font-family:inherit;font-size:.9rem;resize:vertical}.quiz-navigation{display:flex;justify-content:space-between;margin-bottom:2rem}.question-overview{border-top:1px solid #eee;padding-top:1.5rem}.question-overview h4{margin-bottom:1rem;color:#333}.question-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:.5rem}.question-nav-btn{width:50px;height:50px;border:1px solid #ddd;background:#fff;border-radius:.5rem;cursor:pointer;font-weight:500;transition:all .2s}.question-nav-btn.current{background:#667eea;color:#fff;border-color:#667eea}.question-nav-btn.answered{background:#28a745;color:#fff;border-color:#28a745}.quiz-error{text-align:center;padding:4rem 2rem}.virtual-lab{background:#fff;border-radius:1rem;box-shadow:0 4px 6px #0000001a;min-height:80vh}.lab-header{display:flex;justify-content:space-between;align-items:flex-start;padding:2rem;border-bottom:1px solid #eee;background:linear-gradient(135deg,#f8f9ff,#e8eeff)}.lab-info h2{color:#333;margin-bottom:.5rem}.lab-content{display:flex;height:calc(80vh - 120px)}.lab-sidebar{width:300px;background:#f8f9fa;padding:1.5rem;border-right:1px solid #eee;overflow-y:auto}.lab-progress h4{margin-bottom:1rem;color:#333}.steps-list{margin-bottom:2rem}.step-item{display:flex;align-items:center;gap:1rem;padding:.75rem;border-radius:.5rem;cursor:pointer;transition:all .2s;margin-bottom:.5rem}.step-item:hover{background:#667eea1a}.step-item.current{background:#667eea;color:#fff}.step-item.completed{background:#28a745;color:#fff}.step-number{width:30px;height:30px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}.step-info{flex:1;display:flex;justify-content:space-between;align-items:center}.step-title{font-weight:500}.step-status{font-size:1.2rem}.materials-list{background:#fff;padding:1rem;border-radius:.5rem;border:1px solid #eee}.materials-list h4{margin-bottom:.5rem;color:#333}.materials-list ul{list-style:none;padding:0}.materials-list li{padding:.25rem 0;color:#666;font-size:.9rem}.lab-main{flex:1;padding:2rem;display:flex;flex-direction:column}.step-content{flex:1;margin-bottom:2rem}.step-header{margin-bottom:2rem}.step-header h3{color:#333;margin-bottom:.5rem}.lab-navigation{display:flex;justify-content:space-between;border-top:1px solid #eee;padding-top:1.5rem}.lab-setup{text-align:center}.materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin:2rem 0}.material-item{padding:1rem;border:2px solid #eee;border-radius:.5rem;cursor:pointer;transition:all .2s;text-align:center}.material-item:hover{border-color:#667eea;background:#f8f9ff}.material-item.selected{border-color:#28a745;background:#f8fff9}.material-icon{font-size:2rem;margin-bottom:.5rem}.workspace{background:#f8f9fa;padding:1.5rem;border-radius:.5rem;margin-top:2rem}.workspace h5{margin-bottom:1rem;color:#333}.selected-materials{display:flex;flex-wrap:wrap;gap:.5rem}.workspace-item{background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.8rem}.lab-hypothesis,.lab-observations,.lab-conclusion{max-width:800px}.hypothesis-input,.observations-input,.conclusion-input{width:100%;padding:1rem;border:1px solid #ddd;border-radius:.5rem;font-family:inherit;font-size:.9rem;resize:vertical;margin-top:1rem}.conclusion-prompts{background:#f8f9fa;padding:1.5rem;border-radius:.5rem;margin-top:1.5rem}.conclusion-prompts h5{margin-bottom:1rem;color:#333}.conclusion-prompts ul{padding-left:1.5rem}.conclusion-prompts li{margin-bottom:.5rem;color:#666}.lab-experiment{text-align:center}.experiment-area{display:flex;gap:2rem;justify-content:center;align-items:flex-start;margin:2rem 0;flex-wrap:wrap}.virtual-beaker{text-align:center}.beaker-container{position:relative}.beaker{width:100px;height:150px;border:3px solid #333;border-top:none;border-radius:0 0 50px 50px;position:relative;background:#ffffff1a;overflow:hidden}.liquid{position:absolute;bottom:0;left:0;right:0;transition:all .5s ease;border-radius:0 0 47px 47px}.chemicals-panel{display:flex;flex-direction:column;gap:1rem;align-items:center}.chemicals-panel h5{margin-bottom:.5rem;color:#333}.chemical-btn{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .2s;font-size:.9rem}.chemical-btn:hover{background:#5a6fd8}.experiment-controls{display:flex;flex-direction:column;gap:1rem;align-items:center}.experiment-status{background:#f8f9fa;padding:1rem;border-radius:.5rem;margin-top:1rem;max-width:400px}.experiment-status h5{margin-bottom:.5rem;color:#333}.experiment-status ul{padding-left:1.5rem;margin:0}.experiment-status li{color:#666;margin-bottom:.25rem}@media (max-width: 768px){.app-header{flex-direction:column;gap:1rem;text-align:center}.app-main{padding:1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.dashboard-tabs{flex-wrap:wrap}.form-row{grid-template-columns:1fr}.header-controls{flex-direction:column;align-items:stretch}.search-filters{flex-direction:column}.modal{margin:1rem;max-width:calc(100vw - 2rem)}.quiz-content,.lab-content{flex-direction:column;height:auto}.notebook-sidebar,.lab-sidebar{width:100%}.activities-grid,.notes-grid,.classes-grid{grid-template-columns:1fr}.experiment-area{flex-direction:column;align-items:center}.question-grid{grid-template-columns:repeat(auto-fill,minmax(40px,1fr))}.question-nav-btn{width:40px;height:40px}}
