.message-wrapper{color:#7b7b7b;display:flex;flex-direction:column;font-size:.85rem;justify-content:center;left:0;padding:2.5rem 0;pointer-events:none;position:fixed;top:0;width:100%;z-index:130}.message-container{margin:auto;max-height:100px;opacity:1;padding-bottom:.5rem;transition:all .3s ease-in-out}.message-container.hide{max-height:0;opacity:0;padding-bottom:0;transform:translateY(-100px)}.message{align-items:center;animation-duration:.5s;animation-fill-mode:forwards;animation-name:message-show;background:#fff;border-radius:.25rem;box-shadow:0 2px 8px 0 #63636333;display:inline-flex;font-size:.75rem;gap:.5rem;max-width:300px;opacity:0;padding:.5rem .825rem;text-transform:uppercase}.message p{-webkit-line-clamp:10;-webkit-box-orient:vertical;display:-webkit-box!important;line-height:1.5;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:pre}.message svg{height:20px;min-width:20px;width:20px}.message.success{background:#89eb69;color:#264c1a}.message.error{background:#f05757;color:#ffcece}.message.info{background:#4098ff;color:#e8f3ff}.message.warn{background:#ffcc25;color:#705b17}@keyframes message-show{0%{opacity:0}to{opacity:1}}.top-bar{background-color:var(--common-dark-bg-color);border-bottom:1px solid var(--common-border-color);box-shadow:0 1px 3px #0000000f;height:64px;padding:0 1rem;position:relative;z-index:50}.top-bar,.top-bar-left{align-items:center;display:flex;gap:1rem}.top-bar-left{flex-shrink:0}.top-bar-tabs{-ms-overflow-style:none;align-items:center;display:flex;flex:1 1;gap:.5rem;overflow-x:auto;overflow-y:hidden;padding:.5rem 0;scrollbar-width:none}.top-bar-tabs::-webkit-scrollbar{display:none}.tab-item{align-items:center;background-color:var(--common-btn-bg-color);border:1px solid #0000;border-radius:6px;color:var(--common-semidark-text-color);cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;max-width:180px;min-width:100px;padding:.5rem .75rem;transition:background-color .2s,color .2s,box-shadow .2s;white-space:nowrap}.tab-item:hover{background-color:var(--common-btn-bg-hover-color);color:var(--common-text-color)}.tab-item.active{background-color:var(--common-bg-color);border-color:var(--common-border-color);box-shadow:0 1px 3px #00000014;color:var(--common-text-color)}.tab-title{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tab-close{align-items:center;background:#0000;border:none;border-radius:4px;color:inherit;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;opacity:.5;padding:2px;transition:opacity .15s,background-color .15s}.tab-close:hover{background-color:var(--common-btn-bg-hover-color);opacity:1}.tab-item:hover .tab-close{opacity:.8}.top-bar-right{flex-shrink:0;gap:1rem}.menu-btn,.top-bar-right{align-items:center;display:flex}.menu-btn{background:#0000;border:none;border-radius:6px;color:var(--common-semidark-text-color);cursor:pointer;justify-content:center;padding:.5rem;transition:background-color .2s,color .2s}.menu-btn:hover{background-color:var(--common-btn-bg-hover-color);color:var(--common-text-color)}.teacher-dashboard-btn{background:linear-gradient(135deg,#8b5cf6,#ec4899);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;padding:.4rem .75rem;transition:transform .2s,box-shadow .2s;white-space:nowrap}.teacher-dashboard-btn:hover{box-shadow:0 2px 10px #8b5cf666;transform:scale(1.02)}.header-user-section{align-items:center;display:flex;gap:.75rem}.avatar-btn{background:none;border:none;cursor:pointer;padding:0}.avatar-btn,.user-avatar{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#8b5cf6,#ec4899);border-radius:50%;color:#fff;cursor:default;flex-shrink:0;font-size:.875rem;font-weight:700;height:2rem;justify-content:center;-webkit-user-select:none;user-select:none;width:2rem}.user-avatar.user-avatar-emoji{background:var(--common-btn-bg-color);border:1px solid var(--common-border-light-color);font-size:1.25rem}.classroom-selector{background-color:var(--common-light-bg-color);border:1px solid var(--common-border-color);border-radius:6px;color:var(--common-text-color);cursor:pointer;font-size:.85rem;font-weight:500;max-width:180px;outline:none;padding:.35rem .6rem;transition:border-color .2s,box-shadow .2s}.classroom-selector:focus{border-color:var(--common-primary-color);box-shadow:0 0 0 2px #8b5cf633}.classroom-selector option{background-color:var(--common-bg-color);color:var(--common-text-color)}.modal-wrapper{height:100%;left:0;opacity:1;position:fixed;top:0;width:100%;z-index:50}.close{position:absolute;right:6px;top:6px}.close:after,.close:before{border-top:2px solid #000;content:"";height:20px;position:absolute;right:-8px;top:7px;transform:rotate(-45deg);width:20px}.close:before{right:6px;transform:rotate(45deg)}.close:hover{opacity:.3}.modal-none{display:none;opacity:1;transition-duration:.2s;transition-timing-function:cubic-bezier(.4,0,1,1)}.modal-backdrop{--tw-bg-opacity:0.25;background-color:#6b7280;background-color:rgb(107 114 128/var(--tw-bg-opacity,1));inset:0;position:fixed}.modal-container{align-items:center;display:flex;justify-content:center;min-height:100%;padding:1rem;text-align:center}@media (min-width:640px){.modal-container{padding:0}}.modal-box{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);background-color:var(--modal-bg-color);border:1px solid var(--modal-border-color);border-radius:.5rem;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);color:var(--common-text-color);overflow:hidden;position:relative;text-align:left;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.pad-navigation{display:flex;flex-direction:column;gap:.25rem}.pad-item{align-items:center;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.85rem;gap:.5rem;padding:.4rem .5rem;transition:all .15s}.pad-item:hover{background:var(--bg-hover);color:var(--text-primary)}.pad-item.empty{color:var(--text-tertiary);cursor:default;font-style:italic}.pad-item.empty:hover{background:#0000}.pad-title{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pad-badge{border-radius:4px;flex-shrink:0;font-size:.7rem;padding:0 4px}.pad-badge.worksheet{background:#8b5cf626}.pad-badge.ai{background:#fbbf2433}.no-pads{color:var(--text-tertiary);font-size:.85rem;padding:1rem;text-align:center}.pad-delete-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;margin-left:auto;opacity:0;padding:.25rem;transition:opacity .15s,background .15s,color .15s}.pad-item:hover .pad-delete-btn{opacity:1}.pad-delete-btn:hover{background:#ef44441a;color:#ef4444}.notification-bell{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:18px;justify-content:center;padding:6px 8px;position:relative;transition:background .15s}.notification-bell:hover{background:#00000014;background:var(--color-bg-hover,#00000014)}.bell-badge{align-items:center;background:#ef4444;border-radius:8px;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;line-height:1;min-width:16px;padding:0 3px;position:absolute;right:0;top:0}.classroom-manager{margin:0 auto;max-width:1000px;padding:32px}.cm-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.cm-header h1{font-size:24px;font-weight:700;margin:0}.cm-layout{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}@media (max-width:700px){.cm-layout{grid-template-columns:1fr}}.cm-list{display:flex;flex-direction:column;gap:12px}.cm-empty,.cm-loading{color:var(--common-dark-text-color);font-size:14px;padding:16px 0}.cm-empty-small{color:var(--common-dark-text-color);font-size:13px;margin:8px 0}.classroom-card{background:var(--common-btn-bg-color);border:1px solid var(--common-border-color);border-radius:12px;cursor:pointer;padding:16px;transition:box-shadow .15s}.classroom-card:hover{box-shadow:0 4px 16px #0000001a}.classroom-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.classroom-name{font-size:16px;font-weight:600}.classroom-subject{background:var(--common-primary-color);border-radius:10px;color:#fff;font-size:12px;padding:2px 8px}.classroom-grade{color:var(--common-dark-text-color);font-size:12px;margin-bottom:8px}.classroom-invite{align-items:center;display:flex;gap:6px;margin-top:8px}.invite-label{color:var(--common-dark-text-color);font-size:11px}.invite-code{color:var(--common-primary-color);font-family:monospace;font-size:14px;font-weight:700;letter-spacing:2px}.invite-copy{background:none;border:none;color:var(--common-dark-text-color);cursor:pointer;padding:2px}.cm-detail{background:var(--common-bg-color);border:1px solid var(--common-border-color);border-radius:12px;padding:16px}.cm-detail-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.cm-detail-header h2{font-size:18px;font-weight:600;margin:0}.cm-detail-actions{display:flex;gap:8px}.cm-members-section h3{align-items:center;display:flex;font-size:14px;font-weight:600;gap:6px;margin-bottom:8px}.member-row{background:var(--common-btn-bg-color);border-radius:8px;gap:10px;margin-bottom:6px;padding:8px}.member-avatar,.member-row{align-items:center;display:flex}.member-avatar{background:var(--common-primary-color);border-radius:50%;color:#fff;flex-shrink:0;font-size:12px;font-weight:700;height:32px;justify-content:center;width:32px}.member-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.member-id{color:var(--common-dark-text-color);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-role{font-size:11px;font-weight:600}.member-role.role-student{color:#3b82f6}.member-role.role-teacher{color:#8b5cf6}.member-remove{background:none;border:none;color:var(--common-dark-text-color);cursor:pointer;opacity:0;padding:4px}.member-row:hover .member-remove{opacity:.6}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal-box{background:var(--common-bg-color);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:440px;padding:28px;width:100%}.modal-title{font-size:20px;font-weight:700;margin:0 0 20px}.modal-form{gap:14px}.modal-form,.modal-form label{display:flex;flex-direction:column}.modal-form label{color:var(--common-dark-text-color);font-size:13px;font-weight:600;gap:4px}.modal-form input,.modal-form textarea{background:var(--common-dark-bg-color);border:1px solid var(--common-border-color);border-radius:8px;color:var(--common-text-color);font-size:14px;outline:none;padding:8px 12px}.modal-form input:focus,.modal-form textarea:focus{border-color:var(--common-primary-color)}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}.btn-primary{align-items:center;background:var(--common-primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:8px 18px}.btn-primary:hover{opacity:.9}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background:var(--common-btn-bg-color);border:1px solid var(--common-border-color);border-radius:8px;color:var(--common-text-color);cursor:pointer;font-size:14px;padding:8px 16px}.btn-secondary:hover{background:var(--common-btn-bg-hover-color)}.distribute-modal{max-width:380px}.distribute-subtitle{color:var(--common-dark-text-color);font-size:14px;margin:0 0 20px}.distribute-form{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.distribute-label{color:var(--common-dark-text-color);display:flex;flex-direction:column;font-size:13px;font-weight:600;gap:4px}.distribute-select{background:var(--common-dark-bg-color);border:1px solid var(--common-border-color);border-radius:8px;color:var(--common-text-color);cursor:pointer;font-size:14px;outline:none;padding:8px 12px}.distribute-select:focus{border-color:var(--common-primary-color)}.distribute-error{color:#ef4444;font-size:13px;margin:0}.distribute-empty{color:var(--common-dark-text-color);font-size:13px;padding:8px 0 16px}.distribute-success{color:#059669;font-size:14px;padding:16px 0;text-align:center}.distribute-student-count{color:var(--editor-text-secondary);font-size:14px;margin:0}.distribute-print-link{margin:12px 0 0;text-align:center}.distribute-print-btn{background:none;border:none;color:var(--editor-text-faint);cursor:pointer;font-size:13px;padding:0;text-decoration:underline}.distribute-print-btn:hover{color:var(--editor-accent)}.distribute-modal-actions{border-top:1px solid var(--common-border-color);margin-top:20px;padding-top:16px}.distribute-send-btn{font-size:15px;min-width:100px;padding:10px 20px}.prompt-container{align-items:center;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%}.titlebar{cursor:pointer;display:flex;justify-content:space-between}.titlebar,.titlebar:hover{background-color:var(--common-bg-color)}.ttb-icon{cursor:pointer;font-size:1rem;line-height:1.5rem;padding:.125rem .375rem}.ttb-icon:hover{color:var(--common-text-hover-color)}.ttb-icon.ttb-close{--tw-text-opacity:1;color:#f87171;color:rgb(248 113 113/var(--tw-text-opacity,1))}.ttb-icon.ttb-close:hover{--tw-text-opacity:1;color:#ef4444;color:rgb(239 68 68/var(--tw-text-opacity,1))}.ai-toggle-btn{align-items:center;background:#fff;border:1px solid #0000000d;border-radius:50%;bottom:2rem;box-shadow:0 8px 30px #0000001f;cursor:pointer;display:flex;font-size:1.75rem;height:56px;justify-content:center;position:fixed;right:2rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:56px;z-index:1600}.ai-toggle-logo{height:auto;object-fit:contain;pointer-events:none;width:75%}.ai-toggle-btn:hover{box-shadow:0 12px 40px #00000026;transform:translateY(-2px) scale(1.05)}.ai-toggle-btn.active{background:#fff;right:420px}.ai-toggle-btn.active:after{align-items:center;background:#ef4444;border-radius:50%;color:#fff;content:"✕";display:flex;font-size:.6rem;height:18px;justify-content:center;position:absolute;right:-4px;top:-4px;width:18px}.worksheet-viewer{margin:0 auto;max-width:800px;padding:2rem}.worksheet-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem}.worksheet-badge{background:linear-gradient(135deg,#8b5cf6,#6366f1);border-radius:12px;color:#fff;font-size:.85rem;font-weight:600;padding:.25rem .75rem}.ai-usage-badge{background:#fbbf24;border-radius:8px;color:#78350f;font-size:.8rem;font-weight:600;padding:.25rem .5rem}.worksheet-content{display:flex;flex-direction:column;gap:1.5rem}.worksheet-markdown{color:var(--text-primary);line-height:1.6}.worksheet-task{background:var(--bg-secondary);border:1px solid var(--border-color);border-left:4px solid #8b5cf6;border-radius:8px;display:flex;gap:.75rem;padding:1.25rem}.task-marker{flex-shrink:0;font-size:1.25rem}.task-content{flex:1 1}.worksheet-task.teacher-editable{cursor:pointer;transition:all .2s}.worksheet-task.teacher-editable:hover{border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf61a}.task-edit-container{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.task-content.clickable{position:relative}.task-content.clickable .edit-hint{background:#8b5cf61a;border-radius:4px;color:#8b5cf6;display:none;font-size:.75rem;padding:.25rem .5rem;position:absolute;right:0;top:0}.task-content.clickable:hover .edit-hint{display:inline-block}.task-edit-textarea{background:var(--bg-primary);border:2px solid #8b5cf6;border-radius:6px;color:var(--text-primary);font-family:monospace;font-size:.95rem;line-height:1.5;min-height:120px;padding:.75rem;resize:vertical;width:100%}.task-edit-textarea:focus{box-shadow:0 0 0 3px #8b5cf633;outline:none}.task-edit-actions{display:flex;gap:.5rem}.task-cancel-btn,.task-save-btn{border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:500;padding:.4rem .75rem;transition:all .2s}.task-save-btn{background:#8b5cf6;border:none;color:#fff}.task-save-btn:hover{background:#7c3aed}.task-cancel-btn{background:#0000;border:1px solid var(--border-color);color:var(--text-secondary)}.task-cancel-btn:hover{background:var(--bg-secondary)}.rendered-markdown{white-space:normal}.rendered-markdown h2{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.rendered-markdown h3{font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.rendered-markdown p{margin:.5rem 0}.rendered-markdown p:last-child{margin-bottom:0}.rendered-markdown ol,.rendered-markdown ul{margin:.5rem 0;padding-left:1.5rem}.rendered-markdown code{background:#8b5cf61a;border-radius:3px;font-family:monospace;padding:.1rem .3rem}.rendered-markdown strong{font-weight:600}.worksheet-input-wrapper{display:block}.worksheet-input-wrapper.inline{display:block;margin:.5rem 0}.worksheet-input-wrapper.short{display:inline-block;margin:0 .25rem}.worksheet-input-wrapper.long{margin:1rem 0}.worksheet-input{background:#fff;border:2px solid #d1d5db;border-radius:6px;color:#1f2937;font-size:1rem;padding:.5rem .75rem;transition:all .2s}.worksheet-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf626;outline:none}.worksheet-input:disabled{background:#f3f4f6;cursor:not-allowed}.worksheet-input.short{font-weight:500;text-align:center;width:80px}.worksheet-textarea{background:#fff;border:2px solid #d1d5db;border-radius:6px;box-sizing:border-box;color:#1f2937;font-family:inherit;font-size:1rem;line-height:1.6;min-height:120px;padding:.75rem;resize:vertical;width:100%}.worksheet-textarea::placeholder{color:#9ca3af;font-style:italic}.worksheet-textarea:focus{background:#fefefe;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf626;outline:none}.worksheet-textarea:disabled{background:#f3f4f6;cursor:not-allowed}.input-label{color:#8b5cf6;font-size:.8rem;font-weight:500;margin-bottom:.5rem}.student-answer-preview{background:#fef3c7;border:1px solid #fbbf24;border-radius:6px;margin-top:.5rem;padding:.75rem}.student-answer-preview .preview-label{color:#92400e;font-size:.75rem;font-weight:600;margin-right:.5rem}.student-answer-preview .preview-content{color:#78350f}.worksheet-error{color:var(--text-secondary);padding:2rem;text-align:center}.worksheet-error code{background:#8b5cf61a;border-radius:4px;font-family:monospace;padding:.2rem .5rem}.ai-disabled-banner{align-items:center;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;color:#991b1b;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;margin-bottom:1.5rem;padding:.65rem 1rem}.worksheet-footer{background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;margin-top:2rem;padding:1rem}.ai-notice{color:#78350f;font-size:.9rem;margin:0}.ai-usage-log{background:#fbbf241a;border:1px solid #fbbf24;border-radius:8px;margin-top:2rem;padding:1rem}.ai-usage-log h4{color:#78350f;margin:0}.ai-usage-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.ai-usage-reset-btn{background:#0000;border:1px solid #f59e0b;border-radius:4px;color:#b45309;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;transition:all .2s}.ai-usage-reset-btn:hover{background:#fef3c7;border-color:#d97706;color:#92400e}.ai-log-entry{border-bottom:1px solid #fbbf244d;display:flex;font-size:.85rem;gap:.75rem;padding:.5rem 0}.ai-log-entry:last-child{border-bottom:none}.log-time{color:var(--text-secondary);flex-shrink:0}.log-question{color:var(--text-primary)}.worksheet-add-question{border-top:2px dashed #e5e7eb;border-top:2px dashed var(--common-border-color,#e5e7eb);display:flex;justify-content:center;margin-top:1.5rem;padding-top:1rem}.add-question-btn{align-items:center;background:#0000;border:1.5px dashed #7c3aed;border-radius:8px;color:#7c3aed;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;gap:.4rem;padding:.5rem 1.25rem;transition:background .15s,color .15s}.add-question-btn:hover{background:#ede9fe;color:#5b21b6}@media (prefers-color-scheme:dark){.worksheet-input,.worksheet-textarea{background:#1f2937;border-color:#4b5563;color:#f3f4f6}.worksheet-input:focus,.worksheet-textarea:focus{background:#111827}.worksheet-input:disabled,.worksheet-textarea:disabled{background:#374151}.worksheet-input.short{background:#1f2937}}.teacher-dashboard{margin:0 auto;max-width:1200px;min-height:calc(100vh - 64px);padding:2rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{color:var(--common-text-color);font-size:2rem;font-weight:700;margin-bottom:.5rem}.welcome-message{color:var(--common-semidark-text-color);font-size:1.1rem}.dashboard-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:var(--common-light-bg-color);border:1px solid var(--common-border-light-color);border-radius:.75rem;padding:1.5rem;text-align:center;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.stat-value{color:var(--common-primary-color);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:var(--common-semidark-text-color);font-size:.9rem;letter-spacing:.5px;text-transform:uppercase}.dashboard-actions{margin-bottom:2rem}.action-btn{border:none;border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:background-color .2s,transform .2s}.action-btn.primary{background-color:var(--common-primary-color);color:#fff}.action-btn.primary:hover{background-color:var(--common-primary-hover-color);transform:translateY(-1px)}.dashboard-section{margin-bottom:2rem}.dashboard-section h2{color:var(--common-text-color);font-size:1.5rem;font-weight:600;margin-bottom:1rem}.worksheets-list{grid-gap:1rem;display:grid;gap:1rem}.worksheet-item{background:var(--common-light-bg-color);border:1px solid var(--common-border-light-color);border-radius:.5rem;cursor:pointer;padding:1rem;transition:background-color .2s,border-color .2s}.worksheet-item:hover{background-color:var(--common-btn-bg-hover-color);border-color:var(--common-primary-color)}.worksheet-title{color:var(--common-text-color);font-weight:600;margin-bottom:.25rem}.worksheet-date{color:var(--common-semidark-text-color);font-size:.875rem}.dashboard-empty,.dashboard-loading{color:var(--common-semidark-text-color);padding:3rem;text-align:center}.coming-soon{background:var(--common-light-bg-color);border:1px solid var(--common-border-light-color);border-radius:.5rem;padding:1.5rem}.coming-soon p{color:var(--common-semidark-text-color);font-size:1rem;margin:.5rem 0}.ai-sidebar{background:#fff;background:var(--common-bg-color,#fff);border-left:1px solid var(--border-color);box-shadow:-4px 0 30px #00000014;display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;height:calc(100vh - 64px);position:fixed;right:0;top:64px;width:400px;z-index:1500}.ai-sidebar-header{align-items:center;background:#0000;display:flex;justify-content:space-between;padding:12px 20px;z-index:10}.ai-sidebar-header h3{color:var(--text-secondary);font-size:14px;font-weight:500;margin:0;opacity:.8}.btn-clear{align-items:center;background:#0000;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s}.btn-clear:hover{background:var(--surface-hover);color:var(--text-primary)}.ai-messages{display:flex;flex:1 1;flex-direction:column;gap:16px;overflow-y:auto;padding:20px;position:relative}.ai-welcome-state{flex-direction:column;height:100%;margin-top:-40px;padding:0 32px;text-align:center}.ai-logo-placeholder,.ai-welcome-state{align-items:center;display:flex;justify-content:center}.ai-logo-placeholder{background:var(--surface-2);border-radius:20px;box-shadow:0 8px 20px #0000000d;height:64px;margin-bottom:24px;width:64px}.ai-logo-placeholder span{color:var(--text-primary);font-size:32px;font-weight:700}.ai-welcome-title{color:var(--text-primary);font-size:20px;font-weight:600;margin:0 0 12px}.ai-welcome-desc{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0 0 24px;max-width:280px}.ai-context-badge{background:var(--surface-2);border:1px solid var(--border-color);border-radius:100px;color:var(--text-secondary);font-size:12px;max-width:100%;overflow:hidden;padding:6px 12px;text-overflow:ellipsis;white-space:nowrap}.ai-message{display:flex;flex-direction:column;max-width:85%}.ai-message-user{align-self:flex-end}.ai-message-assistant{align-self:flex-start}.ai-message-content{border-radius:18px;font-size:14px;line-height:1.5;padding:10px 16px}.ai-message-user .ai-message-content{background:var(--text-primary);border-bottom-right-radius:4px;color:var(--bg-primary)}@media (prefers-color-scheme:light){.ai-message-user .ai-message-content{background:#222;color:#fff}}@media (prefers-color-scheme:dark){.ai-message-user .ai-message-content{background:#eee;color:#111}}.ai-message-assistant .ai-message-content{background:var(--surface-2);border-bottom-left-radius:4px;color:var(--text-primary)}.ai-footer{background:#0000;display:flex;flex-direction:column;gap:12px;padding:20px}.ai-input-wrapper{align-items:center;background:var(--surface-1);border:1px solid var(--border-color);border-radius:24px;box-shadow:0 2px 10px #00000008;display:flex;padding:4px 6px 4px 16px;transition:box-shadow .2s,border-color .2s}.ai-input-wrapper:focus-within{border-color:var(--text-muted);box-shadow:0 4px 12px #0000000f}.ai-minimal-input{background:#0000;border:none;color:var(--text-primary);flex:1 1;font-size:14px;outline:none;padding:8px 0}.ai-minimal-send-btn{align-items:center;background:#eab308;background:var(--common-primary-color,#eab308);border:none;border-radius:50%;color:#fff;color:var(--common-primary-text-color,#fff);cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;margin-left:8px;min-width:32px;transition:transform .1s,background .2s;width:32px}.ai-minimal-send-btn:hover:not(:disabled){transform:scale(1.05)}.ai-minimal-send-btn:disabled{background:var(--text-muted);cursor:default}.ai-controls{display:flex;justify-content:center}.ai-pipeline-select-minimal{background:#0000;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:12px;outline:none;padding:4px 8px;text-align:center;transition:color .2s,background .2s}.ai-pipeline-select-minimal:hover{background:var(--surface-2);color:var(--text-primary)}.ai-error-toast{align-items:center;animation:slideUp .3s ease;background:#ffecb3;border-radius:8px;bottom:100px;box-shadow:0 4px 12px #0000001a;color:#5d4a1a;display:flex;font-size:13px;justify-content:space-between;left:20px;padding:10px 16px;position:absolute;right:20px}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ai-typing{font-style:italic;opacity:.7}.ai-messages::-webkit-scrollbar{width:6px}.ai-messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.ai-messages::-webkit-scrollbar-track{background:#0000}.ai-message-error .ai-message-content{background:#fff3cd;border:1px solid #ffeeba;color:#856404}.ai-open-in-pad-btn{align-items:center;background:var(--surface-2);border:1px solid var(--border-color);border-radius:16px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:12px;gap:4px;margin-top:8px;padding:6px 12px;transition:all .2s ease}.ai-open-in-pad-btn:hover{background:var(--surface-1);background:var(--surface-hover,var(--surface-1));border-color:var(--text-muted);box-shadow:0 2px 8px #00000014;color:var(--text-primary);transform:translateY(-1px)}.join-classroom{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:24px}.join-card{background:var(--common-bg-color);border:1px solid var(--common-border-color);border-radius:20px;box-shadow:0 8px 40px #0000001f;max-width:400px;padding:40px;text-align:center;width:100%}.join-icon{font-size:48px;margin-bottom:16px}.join-card h1{font-size:24px;font-weight:700;margin:0 0 8px}.join-description{color:var(--common-dark-text-color);font-size:14px;margin-bottom:28px}.join-form{display:flex;flex-direction:column;gap:12px}.join-input{background:var(--common-dark-bg-color);border:2px solid var(--common-border-color);border-radius:12px;color:var(--common-text-color);font-family:monospace;font-size:20px;font-weight:700;letter-spacing:4px;outline:none;padding:14px 18px;text-align:center;transition:border-color .15s}.join-input:focus{border-color:var(--common-primary-color)}.join-btn{background:var(--common-primary-color);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:opacity .15s}.join-btn:hover:not(:disabled){opacity:.9}.join-btn:disabled{cursor:not-allowed;opacity:.5}.join-error{color:#ef4444;font-size:13px;margin:0}.join-success{align-items:center;display:flex;flex-direction:column;gap:8px;padding:20px 0}.join-success span{font-size:40px}.join-success p{color:var(--common-text-color);font-size:15px}.join-back{background:none;border:none;border-radius:6px;color:var(--common-dark-text-color);cursor:pointer;font-size:13px;margin-top:20px;padding:4px 8px}.join-back:hover{color:var(--common-text-color)}.notifications-panel{margin:0 auto;max-width:480px;padding:0}.notif-panel-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-border,#e5e7eb);display:flex;justify-content:space-between;padding:20px 24px 12px}.notif-panel-header h2{font-size:18px;font-weight:600;margin:0}.mark-all-btn{background:none;border:none;border-radius:6px;color:#3b82f6;color:var(--color-primary,#3b82f6);cursor:pointer;font-size:13px;padding:4px 8px}.mark-all-btn:hover{background:#3b82f61a;background:var(--color-bg-hover,#3b82f61a)}.notif-list{padding:8px 0}.notification-item{align-items:flex-start;cursor:pointer;display:flex;gap:12px;padding:12px 24px;position:relative;transition:background .12s}.notification-item:hover{background:#0000000a;background:var(--color-bg-hover,#0000000a)}.notification-item.unread{background:#3b82f60d;background:var(--color-bg-unread,#3b82f60d)}.notif-icon{flex-shrink:0;font-size:22px;margin-top:2px}.notif-body{flex:1 1;min-width:0}.notif-title{font-size:14px;font-weight:600;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-message{color:#6b7280;color:var(--color-text-secondary,#6b7280);font-size:13px;margin-bottom:4px}.notif-time{color:#9ca3af;color:var(--color-text-tertiary,#9ca3af);font-size:11px}.notif-dot{background:#3b82f6;border-radius:50%;flex-shrink:0;height:8px;margin-top:6px;width:8px}.notif-empty{align-items:center;color:#6b7280;color:var(--color-text-secondary,#6b7280);display:flex;flex-direction:column;font-size:14px;gap:8px;padding:48px 24px}.notif-empty span{font-size:32px}.notif-loading{color:#6b7280;color:var(--color-text-secondary,#6b7280);font-size:14px;padding:24px;text-align:center}.student-inbox{margin:0 auto;max-width:680px;padding:32px 24px}.inbox-header{margin-bottom:24px}.inbox-header h1{font-size:24px;font-weight:700;margin:0}.inbox-empty,.inbox-loading{align-items:center;color:var(--common-dark-text-color);display:flex;flex-direction:column;font-size:14px;gap:12px;padding:48px;text-align:center}.inbox-empty span{font-size:40px}.inbox-list{display:flex;flex-direction:column;gap:8px}.inbox-item{align-items:center;background:var(--common-btn-bg-color);border:1px solid var(--common-border-color);border-radius:12px;cursor:pointer;display:flex;gap:14px;padding:16px;transition:box-shadow .12s}.inbox-item:hover{box-shadow:0 4px 16px #0000001a}.inbox-item-icon{font-size:24px}.inbox-item-info{flex:1 1}.inbox-item-id{font-size:14px;font-weight:600;margin-bottom:4px}.inbox-status-badge{border-radius:10px;display:inline-block;font-size:11px;font-weight:600;padding:2px 8px}.inbox-status-badge.status-pending{background:#fef3c7;color:#d97706}.inbox-status-badge.status-submitted{background:#d1fae5;color:#059669}.inbox-status-badge.status-reviewed{background:#dbeafe;color:#2563eb}.inbox-item-arrow{color:var(--common-dark-text-color)}.worksheet-fill-view{display:flex;flex-direction:column;gap:0;margin:0 auto;max-height:calc(100vh - 80px);max-width:800px;overflow-y:auto;padding:24px}.worksheet-fill-header{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:12px;margin-bottom:24px}.worksheet-fill-header h2{flex:1 1;font-size:20px;font-weight:700;margin:0}.back-btn{background:none;border:1px solid var(--common-border-color);border-radius:8px;color:var(--common-text-color);cursor:pointer;font-size:13px;padding:6px 12px}.back-btn:hover{background:var(--common-btn-bg-hover-color)}.worksheet-fill-actions{display:flex;flex-shrink:0;justify-content:flex-end;margin-top:24px;padding-bottom:24px}.submit-btn{font-size:16px;padding:12px 28px}.worksheet-submitted-notice{background:var(--common-btn-bg-color);border-radius:12px;color:var(--common-dark-text-color);font-size:14px;margin-top:20px;padding:16px;text-align:center}.submissions-dashboard{margin:0 auto;max-width:1100px;min-height:0;padding:32px}.sd-header{margin-bottom:24px}.sd-header h1{font-size:24px;font-weight:700;margin:0}.sd-layout{grid-gap:24px;display:grid;gap:24px;grid-template-columns:280px 1fr;min-height:0}@media (max-width:700px){.sd-layout{grid-template-columns:1fr}}.sd-empty,.sd-loading{color:var(--common-dark-text-color);font-size:14px;padding:12px 0}.sd-dist-list{min-height:0;overflow-y:auto}.sd-dist-list h3{color:var(--common-dark-text-color);font-size:13px;font-weight:700;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.dist-item{background:var(--common-btn-bg-color);border:1px solid var(--common-border-color);border-radius:10px;cursor:pointer;margin-bottom:6px;padding:12px;transition:box-shadow .12s}.dist-item:hover{box-shadow:0 2px 12px #0000001a}.dist-item.active{background:var(--common-primary-color);border-color:var(--common-primary-color);color:#fff}.dist-id{font-size:14px;font-weight:600}.dist-date{margin:2px 0}.dist-count,.dist-date{font-size:12px;opacity:.7}.sd-detail{background:var(--common-bg-color);border:1px solid var(--common-border-color);border-radius:12px;display:flex;flex-direction:column;min-height:0;overflow-x:hidden;overflow-y:auto}.sd-tabs{border-bottom:1px solid var(--common-border-color);display:flex}.sd-tab{background:none;border:none;border-bottom:2px solid #0000;color:var(--common-dark-text-color);cursor:pointer;font-size:14px;font-weight:500;padding:12px 20px;transition:all .12s}.sd-tab.active{border-bottom-color:var(--common-primary-color);color:var(--common-primary-color)}.sd-tab:hover:not(.active){color:var(--common-text-color)}.sd-overview{flex:1 1;min-height:0;overflow-y:auto;padding:20px}.sd-stats{display:flex;flex-shrink:0;gap:16px;margin-bottom:20px}.sd-stat{background:var(--common-btn-bg-color);border-radius:10px;flex:1 1;padding:16px;text-align:center}.sd-stat-val{display:block;font-size:28px;font-weight:800}.sd-stat-label{color:var(--common-dark-text-color);font-size:12px;letter-spacing:.05em;text-transform:uppercase}.sd-sub-list{display:flex;flex-direction:column;gap:6px}.sub-row{align-items:center;background:var(--common-btn-bg-color);border-radius:8px;cursor:pointer;display:flex;font-size:13px;gap:12px;padding:10px 14px;transition:background .12s}.sub-row:hover{background:var(--common-border-color)}.sub-row:focus{outline:2px solid var(--common-primary-color);outline-offset:2px}.sub-student{flex:1 1;font-family:monospace;font-weight:500}.sub-row .sub-view-btn{background:var(--common-bg-color);border:1px solid var(--common-primary-color);border-radius:8px;color:var(--common-primary-color);cursor:pointer;flex-shrink:0;font-size:12px;font-weight:600;padding:6px 12px}.sub-row .sub-view-btn:hover{background:var(--common-primary-color);color:#fff}.sub-badge{border-radius:10px;font-size:11px;font-weight:600;padding:2px 8px}.sub-badge.status-pending{background:#fef3c7;color:#d97706}.sub-badge.status-submitted{background:#d1fae5;color:#059669}.sub-badge.status-reviewed{background:#dbeafe;color:#2563eb}.sub-date{color:var(--common-dark-text-color);font-size:11px}.sub-pending-analysis{color:#9ca3af;font-size:11px}.sub-has-analysis{color:#059669;font-size:11px}.weakness-report{padding:20px}.wr-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.wr-subtitle{color:var(--common-dark-text-color);font-size:14px;margin:0}.wr-progress{align-items:center;display:flex;gap:10px;margin-bottom:20px}.wr-progress-bar{background:var(--common-border-color);border-radius:3px;flex:1 1;height:6px;overflow:hidden}.wr-progress-fill{background:var(--common-primary-color);border-radius:3px;height:100%;transition:width .3s}.wr-progress-label{font-size:13px;font-weight:600;min-width:36px}.wr-existing h3,.wr-results h3{font-size:16px;font-weight:700;margin-bottom:12px}.wr-student{background:var(--common-btn-bg-color);border-radius:10px;margin-bottom:10px;padding:14px}.wr-student-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:8px}.wr-student-id{font-family:monospace;font-size:13px;font-weight:700}.wr-gen-btn{font-size:12px;padding:5px 12px}.wr-weaknesses{margin:0;padding:0 0 0 16px}.wr-weaknesses li{color:var(--common-text-color);font-size:13px;margin-bottom:4px}.wr-empty{align-items:center;color:var(--common-dark-text-color);display:flex;flex-direction:column;font-size:14px;gap:10px;padding:40px;text-align:center}.wr-empty span{font-size:36px}.sd-submission-detail{min-height:0;padding:20px}.sd-detail-header{flex-shrink:0;margin-bottom:20px}.sd-detail-back{background:none;border:none;color:var(--common-primary-color);cursor:pointer;font-size:14px;margin-bottom:8px;padding:0 0 8px}.sd-detail-back:hover{text-decoration:underline}.sd-detail-title{font-size:18px;font-weight:700;margin:0 0 4px}.sd-detail-meta{color:var(--common-dark-text-color);font-size:13px;margin:0}.sd-detail-worksheet{background:var(--common-btn-bg-color);border:1px solid var(--common-border-color);border-radius:10px;margin-bottom:24px;overflow-y:auto;padding:16px}.sd-detail-loading{color:var(--common-dark-text-color);font-size:14px;margin:0}.sd-detail-analysis{background:var(--common-btn-bg-color);border:1px solid var(--common-border-color);border-radius:10px;padding:16px}.sd-detail-analysis h4{color:var(--common-dark-text-color);font-size:14px;font-weight:700;letter-spacing:.05em;margin:0 0 10px;text-transform:uppercase}.sd-analysis-weaknesses{margin:0 0 12px;padding-left:20px}.sd-analysis-weaknesses li{color:var(--common-text-color);font-size:13px;margin-bottom:4px}.sd-analysis-raw{font-size:12px}.sd-analysis-raw pre{color:var(--common-dark-text-color);font-family:inherit;margin:0;white-space:pre-wrap;word-break:break-word}