body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}*,body{margin:0;padding:0}body{background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif}.app-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #0000001a;box-shadow:0 2px 10px #0000001a}.header-content{gap:12px;padding:12px 30px}.header-icon{color:#4f46e5}.header-title{color:#1a202c;font-size:20px;margin-bottom:2px}.header-subtitle{color:#718096;font-size:13px}.app-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-bottom:1px solid #0000001a}.nav-content{padding:0 260px 0 30px}.tab-list{display:flex;gap:32px}.tab-button{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:12px 10px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.tab-button.active{border-bottom-color:#4f46e5;color:#4f46e5;transform:translateY(-1px)}.tab-button.disabled{color:#cbd5e0;cursor:not-allowed}.tab-button:not(.disabled):not(.active):hover{border-bottom-color:#e2e8f0;color:#2d3748;transform:translateY(-1px)}.tab-badge{background:linear-gradient(45deg,#ffd89b,#19547b);border-radius:10px;color:#fff;font-size:9px;font-weight:600;padding:2px 6px}.app-main{height:auto;overflow-y:auto}.chat-container{height:auto!important;min-height:calc(100vh - 160px);overflow:visible!important}.input-container{align-items:flex-end}.input-field{background:#fff;border:2px solid #e2e8f0;border-radius:22px;box-shadow:0 2px 8px #0000000d;padding:12px 18px}.input-field:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a,0 2px 15px #4f46e51a}.send-button{border-radius:22px;min-width:90px;padding:12px 20px}.markdown-content .md-line+.md-line{margin-top:.5em}.markdown-content .md-h1,.markdown-content .md-h2,.markdown-content .md-h3,.markdown-content .md-h4{margin:.5em 0 .3em}.markdown-content pre.code-block{background:#1e293b;box-shadow:0 2px 8px #0000001a;color:#e2e8f0}.markdown-content pre.code-block code{white-space:pre}.compiler-container{background:#fffffff2;display:flex;flex-direction:column;height:100%}.compiler-header{align-items:center;background:#fff;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;padding:15px 25px}.compiler-title{align-items:center;color:#1e293b;display:flex;font-size:16px;font-weight:600;gap:8px}.compiler-actions{display:flex;gap:10px}.practice-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .3s ease}.practice-btn:hover{box-shadow:0 4px 12px #6366f14d;transform:translateY(-2px)}.practice-panel{animation:slideDown .3s ease;background:#f8f9fa;border-bottom:2px solid #e2e8f0;padding:20px 25px}.practice-controls{display:flex;gap:12px;margin-bottom:16px}.practice-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;max-width:300px;padding:10px 12px;transition:all .3s ease}.practice-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.generate-btn{background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:8px;font-weight:500;padding:10px 20px}.compiler-main{display:flex;flex:1 1;gap:20px;min-height:0;padding:20px}.code-editor-panel{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.editor-header{background:linear-gradient(135deg,#1e293b,#334155);color:#fff;font-weight:500;padding:12px 16px}.hint-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;padding:6px 12px;transition:all .3s ease}.hint-btn:hover:not(:disabled){background:#ffffff4d}.run-btn{align-items:center;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:6px;cursor:pointer;display:flex;font-weight:500;gap:4px;padding:8px 16px;transition:all .3s ease}.run-btn:hover:not(:disabled){box-shadow:0 4px 12px #22c55e4d;transform:translateY(-1px)}.run-btn:disabled{cursor:not-allowed;opacity:.6}.clear-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;padding:6px 12px;transition:all .3s ease}.clear-btn:hover{background:#ffffff4d}.code-editor{background:#fafafa;font-family:SF Mono,Monaco,Consolas,Courier New,monospace;font-size:14px;line-height:1.6;padding:16px}.output-panel{border-radius:12px;box-shadow:0 2px 8px #0000001a}.output-tabs{background:#f8f9fa;border-bottom:2px solid #e2e8f0;display:flex}.output-tab{background:#0000;border:none;color:#64748b;cursor:pointer;font-weight:500;padding:12px 20px;position:relative;transition:all .3s ease}.output-tab.active{background:#fff;color:#1e293b}.output-tab.active:after{background:#6366f1;bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}.output-tab.error-tab.active{color:#ef4444}.output-tab.error-tab.active:after{background:#ef4444}.output-content{flex:1 1;overflow-y:auto;padding:16px}.output-text{word-wrap:break-word;color:#2d3748;font-family:SF Mono,Monaco,Consolas,monospace;font-size:13px;line-height:1.6;margin:0;white-space:pre-wrap}.error-diagnosis{display:flex;flex-direction:column;height:100%}.diagnosis-header{align-items:center;background:#fef2f2;border-radius:8px;color:#991b1b;display:flex;font-weight:600;gap:8px;margin-bottom:16px;padding:12px}.diagnosis-icon{font-size:20px}.diagnosis-content{color:#2d3748;flex:1 1;line-height:1.6;overflow-y:auto}.diagnosis-content h4{color:#1e293b;margin:16px 0 8px}.diagnosis-content ul{margin:8px 0;padding-left:20px}.diagnosis-content li{margin:4px 0}.diagnosis-content code{background:#f1f5f9;border-radius:4px;color:#6366f1;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;padding:2px 6px}.diagnosis-actions{border-top:1px solid #e2e8f0;margin-top:12px;padding-top:12px}.show-output-btn{background:#f1f5f9;border:1px solid #cbd5e0;border-radius:6px;color:#475569;cursor:pointer;font-size:13px;padding:8px 16px;transition:all .3s ease}.show-output-btn:hover{background:#e2e8f0}.code-snippets{align-items:center;background:#fff;border-top:2px solid #e2e8f0;display:flex;gap:12px;padding:15px 20px}.snippets-title{color:#64748b;font-size:13px;font-weight:500}.snippet-list{display:flex;flex-wrap:wrap;gap:8px}.snippet-list button{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;color:#475569;cursor:pointer;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;padding:6px 12px;transition:all .3s ease}.snippet-list button:hover{background:#e2e8f0;border-color:#cbd5e0;transform:translateY(-1px)}.status-badge-small{background:linear-gradient(45deg,#4ade80,#22c55e);border-radius:10px;color:#fff;font-size:10px;font-weight:600;margin-left:8px;padding:2px 6px}.status-badge-small.loading{animation:pulse 1.5s infinite;background:linear-gradient(45deg,#fbbf24,#f59e0b)}@keyframes fadeInPanel{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInOverlay{to{opacity:1}}@keyframes slideInSession{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.messages-area::-webkit-scrollbar-thumb:hover{background:#ffffff80}.sidebar-content::-webkit-scrollbar{width:6px}.sidebar-content::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}.sidebar-content::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:#0000004d}@media (max-width:768px){.header-content{padding:8px 20px}.nav-content{padding:0 20px}.tab-list{-ms-overflow-style:none;gap:16px;overflow-x:auto;scrollbar-width:none}.tab-list::-webkit-scrollbar{display:none}.chat-sidebar{overflow:hidden;transition:width .3s ease;width:0}.chat-sidebar.open{width:300px}.sidebar-toggle-btn{display:flex}.messages-area{padding:15px}.message-container{max-width:95%}.input-area{padding:8px 20px}.input-container{flex-direction:column;gap:6px}.send-button{align-self:stretch;margin-left:6px}.markdown-content{font-size:13px}.markdown-content pre.code-block{font-size:12px;padding:8px 12px}.exercise-content{max-height:95vh;width:95%}.exercise-header{padding:15px 20px}.exercise-body{padding:20px}.exercise-tabs{padding:12px 20px}.exercise-tab{font-size:14px;height:36px;min-width:36px}.question-text{font-size:15px}.exercise-footer{flex-wrap:wrap;gap:10px}.nav-btn{flex:1 1}.score-display,.submit-btn{text-align:center;width:100%}.exercise-history-content{max-height:90vh;width:95%}.history-item{padding:12px}.history-item-info{align-items:flex-start;flex-direction:column;gap:4px}.compiler-main{padding:15px}.compiler-main,.practice-controls{flex-direction:column}.practice-select{max-width:100%}.code-snippets{align-items:flex-start;flex-direction:column}.snippet-list{width:100%}}@media (min-width:769px){.sidebar-overlay{display:none}.chat-sidebar{position:relative}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-4{gap:16px}.p-2{padding:8px}.p-4{padding:16px}.m-2{margin:8px}.m-4{margin:16px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.w-full{width:100%}.h-full{height:100%}.rounded{border-radius:8px}.rounded-lg{border-radius:12px}.shadow{box-shadow:0 2px 8px #0000001a}.shadow-lg{box-shadow:0 4px 12px #00000026}.border{border:1px solid #e2e8f0}.border-2{border:2px solid #e2e8f0}.bg-white{background:#fff}.bg-gray-50{background:#f8f9fa}.bg-gray-100{background:#f1f5f9}.text-gray-500{color:#64748b}.text-gray-700{color:#374151}.text-gray-900{color:#1f2937}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-sm{font-size:14px}.text-lg{font-size:18px}.text-xl{font-size:20px}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.transition-all{transition:all .3s ease}.hover\:opacity-80:hover{opacity:.8}.hover\:transform:hover{transform:translateY(-2px)}.loading{opacity:.7}.disabled,.loading{pointer-events:none}.disabled{cursor:not-allowed;opacity:.5}.hidden{display:none}.visible{visibility:visible}.invisible{visibility:hidden}@media print{.clear-button,.close-btn,.send-button,.sidebar-toggle-btn,.toolbar-buttons{display:none}.exercise-modal{background:#fff;box-shadow:none;position:static}.messages-area{background:#fff}.message-content{border:1px solid #e2e8f0;box-shadow:none}}body,html{height:auto;min-height:100vh;overflow:visible}.app-container{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;height:auto!important;min-height:100vh;overflow:visible!important}.app-main{flex:1 1;height:auto!important;max-height:none!important;min-height:0;overflow-x:hidden;overflow-y:auto!important;position:relative}.compiler-container,.compiler-main,.evaluation-container,.evaluation-content,.questionnaire-container,.questionnaire-content{height:auto!important;max-height:none!important;overflow:visible!important}.chat-container{background:#ffffff0d;height:auto;min-height:calc(100vh - 120px);position:relative}.sidebar-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #0000001a;color:#fff;padding:16px 20px}.sidebar-header h3{font-size:16px;font-weight:600;margin:0 0 12px}.sidebar-actions{gap:8px;justify-content:space-between}.new-chat-btn,.sidebar-actions{align-items:center;display:flex}.new-chat-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;gap:6px;padding:8px 12px;transition:all .3s ease}.new-chat-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.close-sidebar-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:4px;color:#fff;cursor:pointer;padding:6px;transition:all .3s ease}.close-sidebar-btn:hover{background:#ffffff4d}.sidebar-content{flex:1 1;overflow-y:auto;padding:16px}.loading-sessions,.no-sessions{color:#64748b;font-size:14px;padding:40px 20px;text-align:center}.sessions-list{display:flex;flex-direction:column;gap:8px}.session-item{align-items:center;animation:slideInSession .3s ease;border:2px solid #e2e8f0;padding:12px;position:relative;transition:all .3s ease}.session-item:hover{border-color:#6366f1;transform:translateX(4px)}.session-item.active{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);box-shadow:0 2px 8px #6366f133}.session-info{flex:1 1;min-width:0}.session-title{font-size:14px;font-weight:500;margin-bottom:4px}.session-meta{color:#64748b;display:flex;font-size:12px;justify-content:space-between}.message-count{color:#6366f1;font-weight:500}.last-time{color:#94a3b8}.delete-session-btn{background:#0000;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;margin-left:8px;opacity:0;padding:4px;transition:all .3s ease}.session-item:hover .delete-session-btn{opacity:1}.delete-session-btn:hover{background:#fef2f2;color:#ef4444}.sidebar-toggle-btn{align-items:center;background:#ffffff1a;border:1px solid #0000001a;border-radius:6px;color:#64748b;cursor:pointer;display:flex;justify-content:center;margin-right:8px;padding:8px;transition:all .3s ease}.sidebar-toggle-btn:hover{background:#fff3;color:#4f46e5;transform:translateY(-1px)}.chat-container{display:flex;height:100%}.chat-sidebar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffffa;border-right:1px solid #0000001a;display:flex;flex:0 0;flex-direction:column;overflow:hidden;transition:width .3s ease;width:0;z-index:100}.chat-sidebar.open{flex:0 0 300px;width:300px}.chat-main{display:flex;flex:1 1 auto;flex-direction:column;min-height:0}.chat-container.sidebar-open .chat-main,.chat-container:has(.chat-sidebar.open) .chat-main{margin-left:0!important}.sidebar-overlay{animation:fadeInOverlay .3s ease forwards;background:#0000004d;bottom:0;left:0;opacity:0;position:fixed;right:0;top:0;z-index:50}.chat-toolbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #0000001a;justify-content:space-between;padding:10px 25px}.chat-toolbar,.toolbar-left{align-items:center;display:flex}.toolbar-left{gap:10px}.toolbar-title{color:#2d3748;font-size:15px;font-weight:600}.toolbar-subtitle{color:#718096;font-size:12px}.status-badge{background:linear-gradient(45deg,#4ade80,#22c55e);border-radius:12px;box-shadow:0 2px 8px #22c55e4d;color:#fff;font-size:10px;padding:3px 8px}.clear-button{background:linear-gradient(45deg,#f87171,#ef4444);border:none;border-radius:18px;box-shadow:0 2px 8px #ef44444d;color:#fff;cursor:pointer;font-size:11px;font-weight:500;padding:6px 14px;transition:all .3s ease}.clear-button:hover{box-shadow:0 4px 15px #ef444466;transform:translateY(-2px)}.toolbar-buttons{display:flex;gap:10px}.view-exercise-btn{background:linear-gradient(45deg,#22c55e,#16a34a);border:none;border-radius:18px;box-shadow:0 2px 8px #22c55e4d;color:#fff;cursor:pointer;font-size:11px;font-weight:500;padding:6px 14px;transition:all .3s ease}.view-exercise-btn:hover{box-shadow:0 4px 15px #22c55e66;transform:translateY(-2px)}.history-btn{align-items:center;background:linear-gradient(45deg,#6366f1,#8b5cf6);border:none;border-radius:18px;box-shadow:0 2px 8px #6366f14d;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:500;gap:4px;padding:6px 14px;transition:all .3s ease}.history-btn:hover{box-shadow:0 4px 15px #6366f166;transform:translateY(-2px)}.messages-area{background:#0000;flex:1 1 auto;max-height:none;overflow-y:auto;padding:20px 25px}.message-container{align-items:flex-end;display:flex;margin-bottom:16px;max-width:85%}.message-container.user{flex-direction:row-reverse;margin-left:auto}.message-avatar{align-items:center;border-radius:50%;box-shadow:0 3px 12px #0003;color:#fff;display:flex;height:36px;justify-content:center;margin:0 10px;width:36px}.message-avatar.user{background:linear-gradient(135deg,#667eea,#764ba2)}.message-avatar.ai{background:linear-gradient(135deg,#ffecd2,#fcb69f);color:#d97706}.message-content{word-wrap:break-word;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 3px 12px #0000001a;max-width:100%;padding:14px 18px;position:relative}.message-content.user{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom-right-radius:6px;color:#fff;margin-right:6px}.message-content.ai{background:#fffffff2;border:1px solid #fff3;border-bottom-left-radius:6px;color:#2d3748;margin-left:6px}.message-time{font-size:10px;margin-top:6px;opacity:.8;text-align:right}.message-time.user{color:#fffc}.message-time.ai{color:#718096}.typing-indicator{align-items:flex-end;margin-bottom:16px;max-width:85%}.typing-content{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:16px 16px 16px 6px;box-shadow:0 3px 12px #0000001a;display:flex;gap:8px;margin-left:6px;padding:14px 18px}.typing-text{color:#718096;font-size:14px}.typing-dots{gap:3px}.typing-dot{animation:bounce 1.4s infinite;background:linear-gradient(45deg,#ffecd2,#fcb69f)}.input-area{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-top:1px solid #0000001a;flex-shrink:0;padding:16px 25px}.input-container{align-items:center;background:#f8fafc;border:1px solid #dbe3ef;border-radius:28px;display:flex;gap:12px;padding:8px 10px}.input-field{background:#0000;border:none;border-radius:16px;box-shadow:none;flex:1 1;font-family:inherit;font-size:14px;line-height:1.5;max-height:180px;min-height:42px;outline:none;overflow:hidden;padding:10px 14px;resize:none;transition:all .3s ease}.input-field:focus{background:#fff;box-shadow:0 0 0 2px #4f46e51a}.input-field:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.send-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:18px;box-shadow:0 3px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;justify-content:center;min-width:80px;padding:10px 16px;transition:all .3s ease}.send-button:hover:not(:disabled){box-shadow:0 5px 20px #667eea66;transform:translateY(-2px)}.send-button:disabled{background:#cbd5e0;box-shadow:none;cursor:not-allowed;transform:none}.send-button.secondary{background:#fff;border:1px solid #cbd5e1;box-shadow:none;color:#334155}.send-button.secondary:hover:not(:disabled){background:#f8fafc;box-shadow:none}.input-footer{color:#718096;display:flex;font-size:11px;justify-content:space-between;margin-top:8px;padding:0 5px}.api-status{color:#22c55e;font-weight:500}.input-simulation-panel{animation:fadeInPanel .3s ease;background:#f8f9fa;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 12px #6366f133;margin:20px 25px;padding:16px}.input-panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.input-panel-header span{color:#1a202c;font-size:14px;font-weight:600}.input-clear-btn{background:linear-gradient(135deg,#f87171,#ef4444);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .3s ease}.input-clear-btn:hover{box-shadow:0 4px 12px #ef44444d;transform:translateY(-2px)}.input-values-editor{border:2px solid #e2e8f0;border-radius:8px;font-family:inherit;font-size:14px;min-height:80px;padding:12px;resize:vertical;transition:all .3s ease;width:100%}.input-values-editor:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.input-panel-tips{color:#475569;font-size:13px;margin-top:8px}.input-panel-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .3s ease}.input-panel-btn:hover{box-shadow:0 4px 12px #6366f14d;transform:translateY(-2px)}.markdown-content{color:#2d3748;font-size:14px;line-height:1.6}.markdown-content .md-line{line-height:1.6;margin:0;padding:0}.markdown-content .md-line+.md-line{margin-top:.4em}.markdown-content .md-h1,.markdown-content .md-h2,.markdown-content .md-h3,.markdown-content .md-h4{color:#1f2937;font-weight:700;line-height:1.3;margin:.6em 0 .3em;padding:0}.markdown-content .md-h1{font-size:20px}.markdown-content .md-h2{font-size:18px}.markdown-content .md-h3{font-size:16px}.markdown-content .md-h4{font-size:15px}.markdown-content>:first-child{margin-top:0!important}.markdown-content .md-h1+.md-line,.markdown-content .md-h2+.md-line,.markdown-content .md-h3+.md-line,.markdown-content .md-h4+.md-line{margin-top:0}.markdown-content .md-ol,.markdown-content .md-ul{list-style-position:outside;margin:.3em 0;padding-left:1.5em}.markdown-content .md-li{line-height:1.6;margin:0;padding:.1em 0}.markdown-content .md-li .md-line{margin:0}.markdown-content .md-line+.md-ol,.markdown-content .md-line+.md-ul{margin-top:.2em}.markdown-content .md-ol+.md-line,.markdown-content .md-ul+.md-line{margin-top:.3em}.markdown-content .md-ul{list-style-type:disc}.markdown-content .md-ol{list-style-type:decimal}.markdown-content .md-strong,.markdown-content strong{color:#1a202c;font-weight:700}.markdown-content .md-em,.markdown-content em{font-style:italic}.markdown-content a{color:#4f46e5;text-decoration:underline;transition:opacity .2s}.markdown-content a:hover{opacity:.8}.markdown-content code.inline-code{background:#4f46e514;border-radius:4px;color:#6366f1;display:inline;font-size:.9em;padding:2px 6px;white-space:nowrap}.markdown-content code.inline-code,.markdown-content pre.code-block{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.markdown-content pre.code-block{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000000d;color:#334155;font-size:13px;line-height:1.5;margin:.5em 0;overflow-x:auto;padding:12px 16px;white-space:pre}.markdown-content pre.code-block code{background:none;color:inherit;display:block;font-size:inherit;padding:0;tab-size:2;white-space:pre-wrap}.markdown-content .md-blockquote{background:#6366f10d;border-left:3px solid #6366f1;border-radius:0 4px 4px 0;color:#475569;margin:.5em 0;padding:.5em 0 .5em 1em}.markdown-content .md-blockquote .md-line{margin:0}.markdown-content table{font-size:.9em;margin:.5em 0}.markdown-content td,.markdown-content th{border:1px solid #e2e8f0;padding:8px 12px;text-align:left}.markdown-content th{background:#6366f114;color:#1a202c;font-weight:600}.markdown-content tr:nth-child(2n){background:#00000005}.markdown-content hr{background:linear-gradient(90deg,#0000,#cbd5e0,#0000);height:1px;margin:.8em 0}.markdown-content img{border-radius:6px;box-shadow:0 2px 8px #0000001a;height:auto;margin:.5em 0;max-width:100%}.markdown-content>:last-child{margin-bottom:0!important}.message-content.user .markdown-content,.message-content.user .markdown-content .md-h1,.message-content.user .markdown-content .md-h2,.message-content.user .markdown-content .md-h3,.message-content.user .markdown-content .md-h4,.message-content.user .markdown-content .md-strong,.message-content.user .markdown-content strong{color:#fff}.message-content.user .markdown-content a{color:#93bbfb}.message-content.user .markdown-content code.inline-code{background:#fff3;color:#fff}.message-content.user .markdown-content pre.code-block{background:#ffffff26;border-color:#ffffff4d;color:#fff}.exercise-modal{align-items:center;animation:fadeIn .3s ease;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.exercise-content{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:800px;width:90%}.exercise-header{border-bottom:1px solid #e2e8f0;border-radius:16px 16px 0 0;padding:20px 25px}.exercise-header h3{color:#fff;font-size:20px;font-weight:600;margin:0}.exercise-tabs{background:#f8f9fa;border-bottom:1px solid #e2e8f0;display:flex;gap:8px;overflow-x:auto;padding:15px 25px}.exercise-tab{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-weight:600;gap:4px;height:40px;justify-content:center;min-width:40px;padding:0 12px;transition:all .3s ease}.exercise-tab:hover{border-color:#6366f1;box-shadow:0 4px 12px #6366f133;color:#6366f1;transform:translateY(-2px)}.exercise-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 4px 12px #667eea4d;color:#fff}.exercise-tab.correct{background:#f0fdf4;border-color:#22c55e;color:#22c55e}.exercise-tab.incorrect{background:#fef2f2;border-color:#ef4444;color:#ef4444}.exercise-tab.neutral{background:#f1f5f9;border-color:#94a3b8;color:#64748b}.tab-icon{margin-left:4px}.exercise-body{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:25px}.question-container{flex:1 1}.question-header{margin-bottom:20px}.question-type-badge{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:20px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px}.question-number{color:#64748b}.question-content{background:#f8f9fa;border-radius:12px;padding:20px}.question-text{color:#1a202c;margin-bottom:20px}.options-container{display:flex;flex-direction:column;gap:12px}.option-label{transition:all .3s ease}.option-label:hover{background:#f0f9ff;border-color:#6366f1}.option-label input[type=radio]{cursor:pointer;margin-right:12px}.option-label.correct{background:#f0fdf4;border-color:#22c55e}.option-label.incorrect{background:#fef2f2;border-color:#ef4444}.option-text{color:#2d3748;font-size:15px}.fill-container{margin-top:20px}.fill-input{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:15px;padding:12px 16px;transition:all .3s ease;width:100%}.fill-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.fill-input.correct{background:#f0fdf4;border-color:#22c55e}.fill-input.incorrect{background:#fef2f2;border-color:#ef4444}.judge-container{display:flex;gap:20px;margin-top:20px}.judge-option{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;flex:1 1;justify-content:center;padding:16px;transition:all .3s ease}.judge-option:hover{background:#f0f9ff;border-color:#6366f1}.judge-option input[type=radio]{margin-right:8px}.judge-option span{font-size:16px;font-weight:500}.judge-option.correct{background:#f0fdf4;border-color:#22c55e}.judge-option.incorrect{background:#fef2f2;border-color:#ef4444}.short-container{margin-top:20px}.short-input{border:2px solid #e2e8f0;font-family:inherit;font-size:15px;padding:12px 16px;transition:all .3s ease}.short-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.code-container{margin-top:20px}.code-input{background:#1e293b;border:2px solid #e2e8f0;color:#e2e8f0;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;min-height:150px;padding:12px 16px}.code-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.answer-section{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-top:20px;padding:16px}.answer-header{margin-bottom:12px}.answer-status{font-size:14px;font-weight:600}.correct-answer{color:#2d3748;margin-bottom:12px}.correct-answer strong{color:#1a202c;margin-right:8px}.code-answer{background:#1e293b;color:#e2e8f0;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:13px;margin-top:8px;padding:12px}.explanation{border-top:1px solid #e2e8f0;color:#475569;padding-top:12px}.explanation strong{color:#1a202c;margin-right:8px}.explanation p{margin:8px 0 0}.exercise-footer{border-top:1px solid #e2e8f0;justify-content:space-between;margin-top:20px;padding:20px 0 0}.exercise-footer,.nav-btn{align-items:center;display:flex}.nav-btn{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;font-weight:500;gap:6px;padding:10px 20px;transition:all .3s ease}.nav-btn:hover:not(:disabled){border-color:#6366f1;color:#6366f1;transform:translateX(-2px)}.nav-btn:disabled{cursor:not-allowed;opacity:.5}.nav-btn:last-child:hover:not(:disabled){transform:translateX(2px)}.submit-btn{background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:8px;box-shadow:0 4px 12px #22c55e4d;color:#fff;cursor:pointer;font-weight:600;padding:12px 32px;transition:all .3s ease}.submit-btn:hover{box-shadow:0 6px 20px #22c55e66;transform:translateY(-2px)}.score-display{background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:8px;box-shadow:0 4px 12px #fbbf244d;color:#fff;font-size:16px;font-weight:600;padding:12px 24px}.exercise-history-modal{align-items:center;animation:fadeIn .3s ease;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:999}.exercise-history-content{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:80vh;max-width:600px;width:90%}.exercise-history-header{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-bottom:1px solid #e2e8f0;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;padding:20px 25px}.exercise-history-header h3{align-items:center;color:#fff;display:flex;font-size:20px;font-weight:600;gap:8px;margin:0}.exercise-history-body{flex:1 1;overflow-y:auto;padding:20px}.no-history{align-items:center;color:#94a3b8;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.no-history p{font-size:16px;margin-top:16px}.history-list{gap:12px}.history-item:hover{background:#fff;border-color:#6366f1;box-shadow:0 4px 12px #6366f11a;transform:translateX(4px)}.history-item-header{align-items:center}.history-index{color:#6366f1;font-size:14px;font-weight:600}.history-time{align-items:center;color:#64748b;display:flex;font-size:12px;gap:4px}.history-item-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.history-topic{color:#1e293b;font-size:15px;font-weight:500}.history-stats{color:#64748b;font-size:13px;gap:12px}.history-score,.history-stats{align-items:center;display:flex}.history-score{color:#22c55e;font-weight:600;gap:4px}.history-progress{background:#e2e8f0;border-radius:2px;height:4px;margin-top:8px;overflow:hidden}.history-progress-bar{background:linear-gradient(90deg,#22c55e,#16a34a);height:100%;transition:width .3s ease}.generate-btn:hover:not(:disabled){box-shadow:0 4px 12px #22c55e4d}.generate-btn:disabled{opacity:.5}.practice-content{background:#fff;border-radius:8px;max-height:300px;overflow-y:auto;padding:20px}.practice-description{color:#2d3748;line-height:1.6}.practice-description h3{color:#1e293b;margin-top:0}.practice-description code{background:#f1f5f9;border-radius:4px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:13px;padding:2px 6px}.practice-description pre{background:#1e293b;border-radius:6px;color:#e2e8f0;overflow-x:auto;padding:12px}.messages-area::-webkit-scrollbar{width:5px}.messages-area::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}.messages-area::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:10px}@media (max-width:768px){.chat-sidebar{overflow:hidden;transition:width .3s ease;width:0}.chat-sidebar.open{width:300px}.sidebar-toggle-btn{display:flex}.messages-area{padding:15px}.message-container{max-width:95%}.input-area{padding:8px 20px}.input-container{align-items:center;flex-direction:row;gap:6px;padding:6px 8px}.send-button{align-self:auto;margin-left:0}.markdown-content{font-size:13px}.markdown-content pre.code-block{font-size:12px;padding:8px 12px}.exercise-content{max-height:95vh;width:95%}.exercise-header{padding:15px 20px}.exercise-body{padding:20px}.exercise-tabs{padding:12px 20px}.exercise-tab{font-size:14px;height:36px;min-width:36px}.question-text{font-size:15px}.exercise-footer{flex-wrap:wrap;gap:10px}.nav-btn{flex:1 1}.score-display,.submit-btn{text-align:center;width:100%}.exercise-history-content{max-height:90vh;width:95%}.history-item{padding:12px}.history-item-info{align-items:flex-start;flex-direction:column;gap:4px}}.code-container{margin:20px 0}.code-input{background-color:#0f172a;border:2px solid #e0e0e0;border-radius:8px;caret-color:#e5e7eb;color:#e5e7eb;font-family:Consolas,Monaco,Courier New,monospace;font-size:14px;line-height:1.5;min-height:200px;padding:12px;resize:vertical;width:100%}.code-input::placeholder{color:#94a3b8}.code-answer{word-wrap:break-word;background-color:#2d2d2d;border-radius:6px;color:#f8f8f2;font-family:Consolas,Monaco,Courier New,monospace;font-size:14px;line-height:1.6;overflow-x:auto;padding:16px;white-space:pre-wrap}.short-container{margin:20px 0}.short-input{border:2px solid #e0e0e0;border-radius:8px;font-size:14px;line-height:1.6;min-height:120px;padding:12px;resize:vertical;width:100%}.chat-container.chat-module-root{display:flex!important;height:calc(100vh - 56px)!important;height:calc(100dvh - 56px)!important;min-height:420px!important;overflow:hidden!important}.chat-container.chat-module-root .chat-main{display:flex!important;flex:1 1 auto!important;flex-direction:column!important;min-height:0!important;overflow:hidden!important}.chat-container.chat-module-root .messages-area{flex:1 1 auto!important;min-height:0!important;overflow-x:hidden!important;overflow-y:auto!important;padding-bottom:20px!important;scroll-behavior:smooth}.chat-container.chat-module-root .input-area{flex:0 0 auto!important;padding-bottom:max(16px,env(safe-area-inset-bottom))!important;position:relative;z-index:2}@media (max-width:768px){.chat-container.chat-module-root{height:calc(100vh - 52px)!important;height:calc(100dvh - 52px)!important;min-height:300px!important}}.kb-upload-btn{align-items:center;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:12px;gap:5px;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.kb-upload-btn:hover:not(:disabled){box-shadow:0 3px 10px #f59e0b66;transform:translateY(-1px)}.kb-upload-btn:disabled{cursor:not-allowed;opacity:.6}.voice-input-btn{align-items:center;background:#fff;border:1.5px solid #cbd5e0;border-radius:50%;color:#64748b;cursor:pointer;display:flex;flex-shrink:0;height:38px;justify-content:center;transition:all .2s ease;width:38px}.voice-input-btn:hover:not(:disabled){background:#f0f0ff;border-color:#6366f1;color:#6366f1}.voice-input-btn.recording{animation:pulse-recording 1s infinite;background:#ef4444;border-color:#ef4444;color:#fff}.voice-input-btn:disabled{cursor:not-allowed;opacity:.5}.voice-input-btn.recording .chat-tool-icon{font-size:12px}@keyframes pulse-recording{0%,to{box-shadow:0 0 0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}.image-upload-btn{align-items:center;background:#fff;border:1.5px solid #cbd5e0;border-radius:50%;color:#64748b;cursor:pointer;display:flex;flex-shrink:0;height:38px;justify-content:center;transition:all .2s ease;width:38px}.image-upload-btn:hover:not(:disabled){background:#f0f0ff;border-color:#6366f1;color:#6366f1}.image-upload-btn:disabled{cursor:not-allowed;opacity:.5}.image-preview-container{align-items:flex-start;display:inline-flex;margin-bottom:8px;margin-left:4px;position:relative}.image-preview-thumb{border:2px solid #6366f1;border-radius:8px;max-height:90px;max-width:120px;object-fit:cover}.remove-image-btn{align-items:center;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:20px;justify-content:center;padding:0;position:absolute;right:-6px;top:-6px;transition:background .2s;width:20px}.remove-image-btn:hover{background:#dc2626}.message-image-container{margin-bottom:8px}.message-image{border:1px solid #e2e8f0;border-radius:8px;display:block;max-height:180px;max-width:240px;object-fit:contain}.python-module-container{background:#f1f5f9;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;height:100vh}.top-toolbar{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 4px #0000000f;display:flex;flex-shrink:0;gap:10px;padding:12px 24px}.toolbar-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .2s ease}.practice-btn{background:#4f46e5;color:#fff}.practice-btn:hover{background:#4338ca;box-shadow:0 3px 10px #4f46e54d;transform:translateY(-1px)}.summary-btn{background:#0ea5e9;color:#fff}.summary-btn:hover{background:#0284c7;box-shadow:0 3px 10px #0ea5e94d;transform:translateY(-1px)}.package-btn{background:#f1f5f9;border:1px solid #e2e8f0;color:#475569}.package-btn:hover{background:#e2e8f0;color:#1e293b;transform:translateY(-1px)}.main-layout{grid-gap:14px;display:grid;flex:1 1;gap:14px;grid-template-columns:1fr 1fr 1fr;min-height:0;overflow:hidden;padding:14px}.chat-pane,.editor-pane,.output-pane{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 6px #00000012;display:flex;flex-direction:column;min-height:0;overflow:hidden}.editor-pane:before{background:#f59e0b}.editor-pane:before,.output-pane:before{content:"";display:block;flex-shrink:0;height:3px}.output-pane:before{background:#10b981}.chat-pane:before{background:#4f46e5;content:"";display:block;flex-shrink:0;height:3px}.chat-pane>:not(:first-child),.editor-pane>:not(:first-child),.output-pane>:not(:first-child){padding-left:18px;padding-right:18px}.chat-pane h3,.editor-pane h3,.output-pane h3{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;color:#1e293b;display:flex;flex-shrink:0;font-size:13px;font-weight:700;gap:7px;margin:0;padding:12px 18px}.editor-pane{animation:slideIn .25s ease}.code-editor{background:#f8fafc;border:none;border-bottom:1px solid #e2e8f0;border-radius:0;box-sizing:border-box;color:#1e293b;flex:1 1;font-family:Fira Code,Consolas,monospace;font-size:13px;line-height:1.65;min-height:0;outline:none;overflow-y:auto;padding:14px 18px;resize:none;transition:border-color .2s,background .2s;width:100%}.code-editor:focus{background:#fff;border-bottom-color:#4f46e5}.code-editor::placeholder{color:#94a3b8}.editor-actions{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;flex-shrink:0;gap:8px;padding:10px 18px}.clear-btn,.file-upload-btn,.run-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:5px;padding:8px 14px;transition:all .2s ease}.file-upload-btn{background:#f1f5f9;border:1px solid #e2e8f0;color:#475569}.file-upload-btn:hover{background:#e2e8f0;color:#1e293b}.run-btn{background:#4f46e5;color:#fff;flex:1 1}.run-btn:hover{background:#4338ca;box-shadow:0 3px 10px #4f46e540;transform:translateY(-1px)}.clear-btn{background:#f1f5f9;border:1px solid #e2e8f0;color:#64748b}.clear-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.output-pane{animation:fadeIn .25s ease .05s both;overflow-y:auto}.output-box{word-wrap:break-word;background:#0f172a;border:1px solid #1e293b;border-radius:8px;color:#e2e8f0;font-family:Fira Code,monospace;font-size:12px;height:auto;line-height:1.65;margin:0 18px 14px;max-height:280px;min-height:100px;overflow-y:auto;padding:14px 18px;white-space:pre-wrap}.output-box::-webkit-scrollbar{width:6px}.output-box::-webkit-scrollbar-track{background:#1e293b;border-radius:3px}.output-box::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.analysis-card,.practice-card{animation:fadeIn .25s ease;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin:0 18px 14px;padding:14px 18px}.analysis-card h4,.practice-card h4{color:#166534;font-size:13px;font-weight:700;margin:0 0 10px}.analysis-card p,.practice-card p{color:#15803d;font-size:13px;line-height:1.6;margin:6px 0}.chat-pane{animation:fadeIn .25s ease .1s both}.chat-history{display:flex;flex:1 1;flex-direction:column;gap:8px;min-height:0;overflow-y:auto;padding:12px 18px}.chat-bubble{word-wrap:break-word;animation:fadeIn .2s ease;border-radius:10px;font-size:13px;line-height:1.55;max-width:85%;padding:10px 14px}.chat-bubble.user{background:#4f46e5;border-bottom-right-radius:3px;color:#fff;margin-left:auto}.chat-bubble.ai{background:#f1f5f9;border-bottom-left-radius:3px;color:#1e293b;margin-right:auto}.chat-input{border-top:1px solid #e2e8f0;flex-shrink:0;padding:12px 18px}.chat-input input{border:1.5px solid #e2e8f0;color:#1e293b;font-size:13px;padding:9px 13px;transition:border-color .2s}.chat-input input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e514}.chat-input button{background:#4f46e5;font-size:13px;font-weight:600;padding:9px 18px;transition:all .2s ease}.chat-input button:hover{background:#4338ca;box-shadow:0 3px 10px #4f46e540}.loading{animation:pulse 1.5s ease-in-out infinite;display:inline-block}.package-modal-overlay{align-items:center;animation:fadeIn .15s ease;background:#0f172a73;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.package-modal{animation:slideIn .25s ease;background:#fff;border-radius:14px;box-shadow:0 16px 48px #0000002e;max-height:80vh;max-width:560px;overflow-y:auto;padding:24px;width:90%}.package-modal h3{align-items:center;color:#1e293b;display:flex;font-size:17px;font-weight:700;gap:8px;margin:0 0 16px}.package-search{display:flex;gap:8px;margin-bottom:16px}.package-search input{border:1.5px solid #e2e8f0;border-radius:8px;flex:1 1;font-size:13px;outline:none;padding:9px 13px;transition:border-color .2s}.package-search input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e514}.package-install-btn{background:#4f46e5;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:9px 18px;transition:all .2s ease;white-space:nowrap}.package-install-btn:hover:not(:disabled){background:#4338ca;box-shadow:0 3px 10px #4f46e540}.package-install-btn:disabled{cursor:not-allowed;opacity:.5}.installed-packages{margin-top:18px}.installed-packages h4{color:#64748b;font-size:13px;font-weight:600;margin:0 0 10px}.package-list{display:flex;flex-direction:column;gap:6px}.package-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;padding:10px 12px;transition:all .15s ease}.package-item:hover{background:#f1f5f9;border-color:#cbd5e1}.package-info{align-items:center;display:flex;gap:10px}.package-badge{align-items:center;background:#eef2ff;border-radius:5px;color:#4f46e5;display:inline-flex;font-size:11px;font-weight:700;gap:4px;padding:3px 8px}.package-name{color:#1e293b;font-size:13px;font-weight:600}.package-version{color:#94a3b8;font-size:12px}.package-remove-btn{background:#fee2e2;border:none;border-radius:5px;color:#b91c1c;cursor:pointer;font-size:11px;font-weight:600;padding:5px 10px;transition:all .15s ease}.package-remove-btn:hover{background:#fecaca}.modal-actions{gap:8px;justify-content:flex-end;margin-top:18px;padding-top:14px}.modal-close-btn{background:#f1f5f9;border:1px solid #e2e8f0;color:#475569;font-size:13px;font-weight:600;padding:8px 18px;transition:all .15s ease}.modal-close-btn:hover{background:#e2e8f0}.install-status{animation:fadeIn .2s ease;border-radius:7px;font-size:13px;margin-bottom:14px;padding:10px 14px}.install-status.success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.install-status.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.install-status.loading{background:#eef2ff;border:1px solid #c7d2fe;color:#4338ca}.popular-packages{margin-top:14px}.popular-packages h4{color:#94a3b8;font-size:12px;font-weight:600;letter-spacing:.05em;margin:0 0 8px;text-transform:uppercase}.popular-chips{display:flex;flex-wrap:wrap;gap:6px}.popular-chip{background:#f5f3ff;border:1px solid #ddd6fe;border-radius:6px;color:#5b21b6;cursor:pointer;font-size:12px;font-weight:600;padding:5px 11px;transition:all .15s ease}.popular-chip:hover{background:#ede9fe;transform:translateY(-1px)}.file-manager{background:#f8fafc;border:1.5px dashed #cbd5e1;border-radius:8px;flex-shrink:0;margin:0 18px 10px;padding:10px;transition:all .2s ease}.file-manager.drag-over{background:#eef2ff;border-color:#4f46e5}.file-upload-zone{align-items:center;color:#94a3b8;cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:12px;transition:all .15s ease}.file-upload-zone:hover{background:#f1f5f9;border-radius:6px;color:#64748b}.file-upload-text{color:#64748b;font-size:13px;text-align:center}.file-upload-hint{color:#94a3b8;font-size:11px}.uploaded-files-list{margin-top:10px}.uploaded-files-list h4{align-items:center;color:#64748b;display:flex;font-size:12px;font-weight:600;gap:5px;margin:0 0 6px}.file-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:7px;display:flex;justify-content:space-between;margin-bottom:5px;padding:7px 9px;transition:all .15s ease}.file-item:hover{border-color:#4f46e5;box-shadow:0 1px 4px #4f46e51a}.file-item-info{flex:1 1;gap:8px;min-width:0}.file-icon,.file-item-info{align-items:center;display:flex}.file-icon{background:#f1f5f9;border-radius:5px;color:#64748b;flex-shrink:0;font-size:10px;font-weight:700;height:28px;justify-content:center;width:28px}.file-icon.txt{background:#dbeafe;color:#1e40af}.file-icon.csv{background:#d1fae5;color:#065f46}.file-icon.json{background:#fef3c7;color:#92400e}.file-icon.img{background:#fce7f3;color:#9f1239}.file-icon.other{background:#e2e8f0;color:#475569}.file-details{flex:1 1;min-width:0}.file-name{color:#1e293b;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#94a3b8;font-size:11px}.file-actions{display:flex;gap:4px}.file-action-btn{align-items:center;border:none;border-radius:5px;cursor:pointer;display:flex;font-size:11px;font-weight:600;gap:3px;padding:4px 8px;transition:all .15s ease}.file-copy-btn{background:#eef2ff;color:#4f46e5}.file-copy-btn:hover{background:#e0e7ff}.file-delete-btn{background:#fee2e2;color:#b91c1c}.file-delete-btn:hover{background:#fecaca}@media (max-width:1200px){.main-layout{grid-template-columns:1fr 1fr}.chat-pane{grid-column:1/-1}}@media (max-width:768px){.main-layout{grid-template-columns:1fr}.toolbar-btn{font-size:12px;padding:7px 12px}}.evaluation-container{animation:fadeInUp .5s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 10px 40px #0000001a;margin:20px;overflow:hidden}.evaluation-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;gap:16px;padding:24px 28px;position:relative}.evaluation-header:before{background:linear-gradient(135deg,#ffffff1a,#0000);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.evaluation-header h2{color:#fff;flex:1 1;font-size:22px;font-weight:700;margin:0}.migration-panel,.stats-panel{border:1px solid #00000014;border-radius:16px;margin:20px 28px;overflow:hidden;padding:20px;position:relative}.stats-panel{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-color:#3b82f6}.migration-panel{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b}.migration-panel:before,.stats-panel:before{background:linear-gradient(135deg,#ffffff4d,#0000);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.migration-panel p,.stats-panel h4{font-weight:700;margin:0 0 16px;position:relative;z-index:1}.stats-panel h4{color:#1d4ed8;font-size:16px}.migration-panel p{color:#92400e;font-size:14px}.stats-grid{font-size:13px;font-weight:600;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));position:relative;z-index:1}.stats-grid div{background:#ffffffb3;border:1px solid #3b82f633;border-radius:10px;color:#1e40af;padding:10px 14px}.migration-buttons{display:flex;gap:12px;position:relative;z-index:1}.migration-btn{align-items:center;border:none;border-radius:10px;box-shadow:0 2px 8px #00000026;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.migration-btn:not(:disabled){background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.migration-btn:disabled{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;cursor:default}.migration-btn:not(:disabled):hover{box-shadow:0 4px 15px #f59e0b66;transform:translateY(-2px)}.evaluation-controls{align-items:flex-end;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #00000014;border-radius:16px;display:flex;gap:20px;margin:20px 28px;padding:20px}.evaluation-controls label{color:#475569;display:flex;flex-direction:column;font-size:14px;font-weight:600;gap:8px}.evaluation-controls input[type=date]{background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#1e293b;font-size:14px;font-weight:500;padding:10px 14px;transition:all .3s ease}.evaluation-controls input[type=date]:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none;transform:translateY(-1px)}.evaluate-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;gap:8px;padding:12px 24px;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.evaluate-btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.evaluate-btn:disabled{box-shadow:0 4px 15px #667eea33;cursor:not-allowed;opacity:.7;transform:none}.evaluate-btn:before{content:"✨";font-size:16px}.evaluation-content{background:#fff;border:1px solid #0000000d;border-radius:16px;box-shadow:0 4px 20px #00000014;margin:0 28px 28px;max-height:none;overflow:visible}.evaluation-loading{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);display:flex;gap:16px;justify-content:center;padding:60px 20px}.evaluation-loading span{color:#667eea;font-size:16px;font-weight:600}.typing-dots{gap:6px}.typing-dot{animation:bounce 1.4s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);height:8px;width:8px}.typing-dot:first-child{animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}.typing-dot:nth-child(3){animation-delay:0s}.evaluation-content:not(.evaluation-loading){color:#2d3748;font-size:15px;line-height:1.6;max-height:500px;overflow-y:auto;padding:28px}.evaluation-content::-webkit-scrollbar{width:6px}.evaluation-content::-webkit-scrollbar-track{background:#0000000d;border-radius:10px}.evaluation-content::-webkit-scrollbar-thumb{background:#0003;border-radius:10px}.evaluation-content::-webkit-scrollbar-thumb:hover{background:#0000004d}.evaluation-content h1,.evaluation-content h2,.evaluation-content h3,.evaluation-content h4{color:#1e293b;font-weight:700;margin:16px 0 10px}.evaluation-content h1{font-size:20px}.evaluation-content h2{font-size:18px}.evaluation-content h3{font-size:16px}.evaluation-content h4{font-size:15px}.evaluation-content p{line-height:1.6;margin:6px 0}.evaluation-content ol,.evaluation-content ul{margin:16px 0;padding-left:24px}.evaluation-content li{line-height:1.6;margin:8px 0}.evaluation-content strong{color:#1e293b;font-weight:700}.evaluation-content code{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:1px solid #0000001a;border-radius:6px;color:#475569;font-family:SF Mono,Monaco,Consolas,monospace;font-size:.9em;padding:3px 8px}.evaluation-content pre{background:linear-gradient(135deg,#1e293b,#334155);border:1px solid #475569;border-radius:12px;color:#e2e8f0;margin:20px 0;overflow-x:auto;padding:20px}.evaluation-content blockquote{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-left:4px solid #667eea;border-radius:0 12px 12px 0;color:#475569;font-style:italic;margin:20px 0;padding:16px 20px}.history-modal-overlay{align-items:center;animation:fadeIn .3s ease;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.history-modal{animation:slideUp .3s cubic-bezier(.4,0,.2,1);background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:80vh;max-width:800px;width:90%}.history-modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e2e8f0;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;padding:20px 25px}.history-modal-header h3{align-items:center;color:#fff;display:flex;font-size:20px;font-weight:600;gap:12px;margin:0}.history-modal-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:36px;justify-content:center;transition:background .2s ease;width:36px}.history-modal-close:hover{background:#ffffff4d}.history-modal-content{flex:1 1;overflow-y:auto;padding:20px}.history-empty{color:#94a3b8;padding:60px 20px;text-align:center}.history-list{display:flex;flex-direction:column;gap:16px}.history-item{background:#f8f9fa;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;padding:16px;transition:all .3s ease}.history-item:hover{background:#f0f4ff;border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.history-item-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px}.history-item-header strong{color:#1e293b;font-size:15px}.history-item-date{color:#64748b;font-size:12px;white-space:nowrap}.history-item-period{color:#475569;font-size:14px;font-weight:500;margin-bottom:8px}.history-item-preview{color:#64748b;font-size:13px;line-height:1.4}@media (max-width:768px){.evaluation-container{border-radius:16px;margin:10px}.evaluation-header{align-items:flex-start;flex-direction:column;gap:12px;padding:16px 20px}.evaluation-header h2{font-size:18px}.migration-panel,.stats-panel{margin:16px 20px;padding:16px}.stats-grid{gap:8px;grid-template-columns:1fr}.evaluation-controls,.migration-buttons{flex-direction:column}.evaluation-controls{align-items:stretch;gap:16px;margin:16px 20px;padding:16px}.evaluation-controls label{width:100%}.evaluate-btn{justify-content:center;width:100%}.evaluation-content{font-size:14px;margin:0 20px 20px;padding:20px}.history-modal{max-height:85vh;width:95%}.history-modal-header{padding:16px 20px}.history-modal-header h3{font-size:18px}.history-item-header{align-items:flex-start;flex-direction:column;gap:4px}}@media (max-width:480px){.evaluation-container{border-radius:12px;margin:5px}.evaluation-header{padding:12px 16px}.evaluation-header h2{font-size:16px}.evaluation-controls,.migration-panel,.stats-panel{margin:12px 16px;padding:12px}.evaluation-content{font-size:13px;margin:0 16px 16px;padding:16px}.history-modal{border-radius:12px;max-height:90vh;width:98%}.history-modal-header{padding:12px 16px}.history-modal-content{padding:16px}}.stats-panel{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 8px 24px #667eea4d;color:#fff;margin-bottom:24px;padding:24px}.stats-header{margin-bottom:20px}.stats-header h4{font-size:20px;font-weight:600;margin:0}.date-range{background:#fff3;border-radius:12px;font-size:13px;opacity:.9;padding:4px 12px}.stats-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{align-items:flex-start;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;gap:12px;padding:16px}.stat-card:hover{background:#ffffff40}.stat-icon{line-height:1}.stat-content{flex:1 1}.stat-label{display:block;margin-bottom:6px}.stat-value{display:block;line-height:1.2}.stat-detail{display:block;font-size:12px;margin-top:4px;opacity:.8}.empty-stats{background:#ffffff1a;border-radius:12px;margin-top:20px;padding:40px 20px;text-align:center}.empty-stats p{margin:8px 0}.empty-hint{opacity:.8}@media (max-width:768px){.stats-grid{grid-template-columns:1fr}.stats-header{align-items:flex-start;flex-direction:column;gap:12px}}.questionnaire-container{animation:fadeInUp .5s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 10px 40px #0000001a;margin:20px;overflow:visible}.questionnaire-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:24px 28px;position:relative}.questionnaire-header:before{background:linear-gradient(135deg,#ffffff1a,#0000);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.header-content{position:relative;z-index:1}.header-content h2{color:#fff;flex:1 1;font-size:22px;font-weight:700;margin:0}.header-content p{color:#ffffffe6;font-size:14px;margin:4px 0 0}.questionnaire-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-bottom:1px solid #00000014;padding:0 28px}.nav-tabs{display:flex;gap:0}.tab-btn{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:16px 20px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.tab-btn.active{background:#667eea0d;border-bottom-color:#667eea;color:#667eea}.tab-btn:not(.active):hover{background:#00000005;color:#475569}.questionnaire-content{height:auto;min-height:auto;padding:28px}.questionnaire-create{margin:0 auto;max-width:800px}.create-header{margin-bottom:32px;text-align:center}.create-header h3{color:#1e293b;font-size:24px;font-weight:700;margin:0 0 8px}.create-header p{color:#64748b;font-size:16px;margin:0}.create-form{background:#fff;border:1px solid #0000000d;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:32px}.form-group{margin-bottom:24px}.form-group label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#1e293b;font-family:inherit;font-size:14px;padding:12px 16px;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none;transform:translateY(-1px)}.form-group textarea{min-height:80px;resize:vertical}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:24px}.knowledge-points-preview{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:24px;padding:20px}.knowledge-points-preview h4{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 12px}.points-list{display:flex;flex-wrap:wrap;gap:8px}.point-tag{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:12px;font-weight:500;padding:6px 12px}.create-actions{margin-top:32px;text-align:center}.generate-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;min-width:160px;padding:16px 32px;transition:all .3s ease}.generate-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.generate-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.stats-questionnaire-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:20px}.stats-questionnaire-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.stats-questionnaire-card h5{color:#1e293b;margin:0 0 10px}.stats-meta{color:#64748b;display:flex;font-size:14px;gap:15px;margin-bottom:15px}.view-stats-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px}.view-stats-btn:hover{background:#5a67d8}.questionnaire-manage{margin:0 auto;max-width:1200px}.manage-header{margin-bottom:32px}.manage-header h3{color:#1e293b;font-size:24px;font-weight:700}.status-badge{align-items:center;border-radius:20px;display:flex;font-size:12px;font-weight:600;gap:6px;padding:8px 12px}.status-badge.connected{background:#22c55e1a;border:1px solid #22c55e33;color:#22c55e}.status-badge.disconnected{background:#ef44441a;border:1px solid #ef444433;color:#ef4444}.questionnaire-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.questionnaire-card{animation:fadeInCard .3s ease;background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:24px;transition:all .3s ease}.questionnaire-card:hover{border-color:#667eea;box-shadow:0 8px 25px #667eea26;transform:translateY(-4px)}@keyframes fadeInCard{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.card-header h4{color:#1e293b;flex:1 1;font-size:18px;font-weight:600;line-height:1.3;margin:0}.type-badge{border-radius:12px;font-size:11px;font-weight:600;margin-left:12px;padding:4px 10px;text-transform:uppercase}.type-badge.pre-course{background:#3b82f61a;color:#3b82f6}.type-badge.post-course{background:#22c55e1a;color:#22c55e}.type-badge.knowledge-test{background:#a855f71a;color:#a855f7}.card-content .card-description{-webkit-line-clamp:1;-webkit-box-orient:vertical;color:#64748b;display:-webkit-box;font-size:14px;line-height:1.5;margin:0 0 16px;overflow:hidden;text-overflow:ellipsis;word-break:break-word}.card-meta{display:flex;gap:16px;margin-bottom:20px}.card-meta span{align-items:center;color:#94a3b8;display:flex;font-size:12px;font-weight:500;gap:4px}.card-actions{display:flex;flex-wrap:wrap;gap:8px}.action-btn{font-size:12px;font-weight:500;gap:5px;padding:7px 12px;transition:all .3s ease;white-space:nowrap}.action-btn.preview{background:#f1f5f9;border:1px solid #e2e8f0;color:#475569}.action-btn.preview:hover{background:#e2e8f0;color:#334155}.action-btn.start{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea4d;color:#fff}.action-btn.start:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.action-btn.secondary{background:#f8fafc;border:1px solid #e2e8f0;color:#64748b}.action-btn.secondary:hover{background:#f1f5f9;color:#475569}.empty-state{padding:80px 20px}.empty-state h3{color:#64748b;font-size:20px;margin:16px 0 8px}.questionnaire-statistics{margin:0 auto;max-width:1000px}.stats-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:32px}.stats-header h3{color:#1e293b;font-size:24px;font-weight:700;margin:0}.stats-actions{display:flex;gap:12px}.stats-btn{align-items:center;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:10px;box-shadow:0 4px 12px #22c55e4d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 20px;transition:all .3s ease}.stats-btn:hover{box-shadow:0 6px 16px #22c55e66;transform:translateY(-2px)}.stats-content{background:#fff;border:1px solid #0000000d;border-radius:16px;box-shadow:0 4px 20px #00000014;line-height:1.6;padding:32px}.stats-placeholder{padding:80px 20px}.stats-placeholder h3{font-weight:600;margin:20px 0 12px}.stats-placeholder p{margin:0 0 32px}.feature-item{background:#f8fafc;border-radius:12px;gap:12px;padding:16px}.feature-item span{color:#475569}.questionnaire-modal{align-items:center;animation:fadeIn .3s ease;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideUp .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;max-height:90vh}.modal-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e2e8f0;border-radius:16px 16px 0 0;padding:24px 28px}.modal-header h3{color:#fff;font-size:20px}.close-btn{align-items:center;background:#fff3;border-radius:50%;display:flex;height:36px;justify-content:center;width:36px}.close-btn:hover{background:#ffffff4d}.modal-body{flex:1 1;overflow-y:auto;padding:28px}.questionnaire-description{background:#f8fafc;border-left:4px solid #667eea;border-radius:12px;color:#64748b;font-size:16px;line-height:1.6;margin:0 0 32px;padding:20px}.questions-preview{display:flex;flex-direction:column;gap:24px}.question-preview{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:24px;transition:all .3s ease}.question-preview:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.question-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.question-number{color:#667eea;font-size:14px;font-weight:600}.question-type{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:11px;font-weight:600;padding:4px 10px}.question-content p{color:#1e293b;font-size:16px;font-weight:500;line-height:1.6;margin:0 0 16px}.options{gap:8px;margin:16px 0}.option{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#475569}.answer-info,.option{font-size:14px;padding:12px 16px}.answer-info{background:#f0fdf4;border:1px solid #22c55e;border-radius:8px;color:#166534;margin-top:16px}.modal-actions{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:16px;justify-content:center;padding:24px 28px}@media (max-width:768px){.questionnaire-container{border-radius:16px;margin:10px}.questionnaire-header{padding:16px 20px}.questionnaire-content{padding:20px}.create-form{padding:24px}.form-row{gap:16px;grid-template-columns:1fr}.nav-tabs{-ms-overflow-style:none;overflow-x:auto;scrollbar-width:none}.nav-tabs::-webkit-scrollbar{display:none}.questionnaire-grid,.stats-features{grid-template-columns:1fr}.modal-content{max-height:95vh;width:95%}.modal-body{padding:20px}.modal-actions{flex-direction:column}.action-btn{justify-content:center;width:100%}}@media (max-width:480px){.questionnaire-header{padding:12px 16px}.header-content{align-items:flex-start;flex-direction:column;gap:8px}.questionnaire-content{padding:16px}.create-form{padding:20px}.manage-header{align-items:flex-start;flex-direction:column;gap:12px}.points-list{gap:6px}.point-tag{font-size:11px;padding:4px 8px}}.questionnaire-container,.questionnaire-content{overflow:visible!important}.create-form,.questionnaire-container,.questionnaire-content{height:auto!important;max-height:none!important;min-height:auto!important}.role-badge{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 2px 8px #667eea4d;color:#fff;display:flex;font-size:14px;font-weight:600;gap:6px;padding:8px 12px}.questionnaire-available{padding:20px}.available-header{border-bottom:2px solid #e2e8f0;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.available-header,.user-info{align-items:center;display:flex}.user-info{background:#22c55e1a;border-radius:8px;color:#16a34a;font-weight:600;gap:8px;padding:8px 12px}.questionnaire-card.student{border-left:4px solid #22c55e;transform:translateY(0);transition:all .3s ease}.questionnaire-card.student:hover{box-shadow:0 10px 25px #22c55e26;transform:translateY(-5px)}.questionnaire-card.teacher{border-left:4px solid #8b5cf6}.questionnaire-card.teacher:hover{box-shadow:0 8px 20px #8b5cf626;transform:translateY(-2px)}.questionnaire-modal.answering{z-index:1001}.questionnaire-modal.answering .modal-content{max-height:90vh;max-width:800px;overflow-y:auto}.progress-info{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #7dd3fc;border-radius:20px;color:#0369a1;font-weight:600;padding:8px 16px}.questions-answering{max-height:60vh;overflow-y:auto;padding-right:10px}.question-answering{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:20px;padding:20px;transition:all .3s ease}.question-answering:hover{border-color:#cbd5e1;box-shadow:0 4px 12px #0000000d}.question-text{color:#1e293b;font-size:16px;font-weight:500;margin-bottom:15px}.options{display:flex;flex-direction:column;gap:12px}.option-label{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:all .2s ease}.option-label:hover{background:#f1f5f9;border-color:#94a3b8}.option-label input[type=checkbox],.option-label input[type=radio]{accent-color:#3b82f6;height:18px;width:18px}.option-label input[type=checkbox]:checked+.option-text,.option-label input[type=radio]:checked+.option-text{color:#3b82f6;font-weight:600}.option-text,.short-answer{font-size:14px;line-height:1.5}.short-answer{border:2px solid #e2e8f0;border-radius:8px;min-height:80px;padding:12px 16px;resize:vertical;transition:border-color .2s ease;width:100%}.short-answer:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.sound-table-wrap{background:#fff;border:1px solid #dbe3ee;border-radius:10px;margin:14px 0 8px;padding:12px}.sound-table{border-collapse:collapse;width:100%}.sound-table td,.sound-table th{border:1px solid #cbd5e1;padding:10px;text-align:left;vertical-align:middle}.sound-table th{background:#f8fafc;font-weight:700}.sound-cell-input{border:1px solid #cbd5e1;border-radius:6px;font-size:14px;min-width:120px;padding:6px 8px;width:100%}.sound-cell-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61f;outline:none}.sound-reference{color:#334155;font-size:13px;line-height:1.6;margin-top:10px}.sound-support-line{align-items:center;display:flex;flex-wrap:wrap;font-size:14px;gap:10px;margin-bottom:12px}.sound-support-line label{align-items:center;display:inline-flex;gap:6px}.sound-angle-tip{color:#334155;font-size:14px;margin-bottom:10px}.inline-choice{align-items:center;display:inline-flex;gap:4px}.choice-split{color:#64748b;margin:0 8px}.action-btn.submit{align-items:center;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.action-btn.submit:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 4px 12px #22c55e4d;transform:translateY(-1px)}.action-btn.submit:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.action-btn.stats{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.stats-placeholder{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:16px;padding:60px 40px;text-align:center}.stats-placeholder svg{color:#64748b;margin-bottom:20px}.stats-placeholder h3{color:#1e293b;font-size:24px;margin-bottom:12px}.stats-placeholder p{color:#64748b;font-size:16px;margin-bottom:30px;margin-left:auto;margin-right:auto;max-width:500px}.stats-features{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:0 auto;max-width:600px}.feature-item{border:1px solid #e2e8f0;box-shadow:0 2px 4px #0000000d;gap:10px;padding:15px}.feature-item svg{color:#22c55e;flex-shrink:0}.feature-item span{color:#374151;font-size:14px;font-weight:500}@media (max-width:768px){.questionnaire-header{flex-direction:column;gap:15px}.role-badge{align-self:flex-start}.form-row{flex-direction:column}.questionnaire-grid{grid-template-columns:1fr}.modal-content{margin:10px;max-height:calc(100vh - 20px);width:calc(100% - 20px)}.stats-features{grid-template-columns:1fr}}.question-answering,.questionnaire-card{animation:slideIn .3s ease-out}.overview-cards,.student-records .records-overview{margin-bottom:30px}.overview-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.overview-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;text-align:center}.overview-card .card-number{color:#667eea;font-size:2em;font-weight:700;margin-bottom:8px}.overview-card .card-label{color:#64748b;font-size:14px}.records-table{display:flex;flex-direction:column;gap:16px}.record-item{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.record-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.record-badges{display:flex;gap:8px}.status-badge.completed{background:#22c55e;color:#fff}.status-badge.incomplete{background:#f59e0b;color:#fff}.record-details{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:15px}.detail-item{display:flex;justify-content:space-between}.detail-item .label{color:#64748b}.detail-item .value.score{color:#667eea;font-weight:700}.record-progress{align-items:center;display:flex;gap:12px}.progress-bar{background:#e2e8f0;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;transition:width .3s ease}.empty-records{text-align:center}.empty-records,.loading-state{padding:60px 20px}.record-item.clickable{cursor:pointer;transition:all .2s ease}.record-item.clickable:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.click-hint{background:#667eea1a;border-radius:4px;color:#667eea;font-size:12px;margin-top:10px;padding:5px;text-align:center}.modal-content.large{max-height:90vh;max-width:900px;overflow-y:auto}.answer-summary{margin-bottom:30px}.summary-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}.summary-card{background:#f8fafc;border-radius:8px;padding:15px;text-align:center}.summary-card .card-label{color:#64748b;font-size:14px;margin-bottom:5px}.summary-card .card-value{color:#1e293b;font-size:20px;font-weight:700}.summary-card .card-value.score{color:#667eea}.question-detail{border:2px solid #e2e8f0;border-radius:12px;margin-bottom:20px;padding:20px}.question-detail.correct{background:#22c55e0d;border-color:#22c55e}.question-detail.incorrect{background:#ef44440d;border-color:#ef4444}.question-detail .question-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.answer-status.correct{color:#22c55e;font-weight:700}.answer-status.incorrect{color:#ef4444;font-weight:700}.options-review{margin:15px 0}.option-review{align-items:center;background:#f8fafc;border-radius:6px;display:flex;margin:5px 0;padding:10px}.option-review.correct-option{background:#22c55e1a;border:1px solid #22c55e}.option-review.user-choice{background:#667eea1a;border:1px solid #667eea}.option-review.user-choice.correct-option{background:#22c55e26}.option-label{font-weight:700;margin-right:10px;min-width:25px}.option-text{flex:1 1}.choice-indicator,.correct-indicator{border-radius:4px;font-size:12px;margin-left:10px;padding:2px 8px}.choice-indicator{background:#667eea;color:#fff}.correct-indicator{background:#22c55e;color:#fff}.answer-comparison{grid-gap:20px;gap:20px;grid-template-columns:1fr 1fr}.correct-answer,.reference-answer,.user-answer{background:#f8fafc;border-radius:8px;padding:15px}.correct-answer .label,.reference-answer .label,.user-answer .label{display:block;font-weight:700;margin-bottom:8px}.answer-text{background:#fff;border:1px solid #e2e8f0;border-radius:4px;min-height:60px;padding:10px}.value.correct{color:#22c55e;font-weight:700}.value.incorrect{color:#ef4444;font-weight:700}.question-explanation{background:#667eea0d;border-left:4px solid #667eea;border-radius:0 8px 8px 0;margin-top:15px;padding:15px}.question-explanation h6{color:#667eea;font-weight:700;margin:0 0 10px}.question-explanation p{line-height:1.6;margin:0}.editing-indicator{background:#f59e0b;border-radius:4px;color:#fff;font-size:12px;font-weight:500;padding:4px 8px}.modal-header-actions{align-items:center;display:flex;gap:10px}.questionnaire-meta{background:#f8fafc;border-radius:8px;display:flex;gap:20px;margin-bottom:20px;padding:15px}.meta-item{color:#64748b;font-size:14px}.questions-editor{margin-top:20px}.editor-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.add-question-btn{align-items:center;background:#22c55e;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:5px;padding:8px 16px}.question-editor{background:#fff;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:20px;padding:20px}.question-editor-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.question-type-select{border:1px solid #d1d5db;border-radius:4px;font-size:14px;padding:5px 10px}.delete-question-btn{background:#ef4444;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:5px 10px}.question-editor-content .form-group{margin-bottom:15px}.question-editor-content label{color:#374151;display:block;font-weight:500;margin-bottom:5px}.question-editor-content input,.question-editor-content select,.question-editor-content textarea{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px;width:100%}.option-editor{align-items:center;display:flex;gap:10px;margin-bottom:8px}.option-editor span{font-weight:700;min-width:20px}.scale-editor{align-items:center;display:flex;gap:10px}.scale-editor input{width:80px}.question-category{border-radius:4px;font-size:11px;font-weight:500;padding:2px 8px}.question-category.background{background:#dbeafe;color:#1e40af}.question-category.knowledge{background:#dcfce7;color:#166534}.question-category.reflection{background:#fef3c7;color:#92400e}.question-category.confusion{background:#fecaca;color:#b91c1c}.question-category.suggestion{background:#e0e7ff;color:#3730a3}.question-category.expectation{background:#f3e8ff;color:#6b21a8}.scale-input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin:20px 0;padding:15px}.scale-options{flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:15px}.scale-option,.scale-options{align-items:center;display:flex}.scale-option{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;flex-direction:column;min-width:80px;padding:15px 10px;transition:background-color .2s ease}.scale-option:hover{background-color:#f1f5f9;border-color:#cbd5e1}.scale-option input[type=radio]{accent-color:#667eea;height:20px;margin-bottom:8px;width:20px}.scale-option input[type=radio]:checked+.scale-value{color:#667eea;font-weight:700}.scale-value{color:#1e293b;font-size:18px;font-weight:700;margin-bottom:5px}.scale-label{color:#64748b;font-size:12px;line-height:1.3;max-width:80px;text-align:center}.scale-range-display{background:#667eea1a;border-radius:6px;color:#64748b;font-size:14px;font-weight:500;padding:8px 12px;text-align:center}.short-answer-wrapper{margin:15px 0;position:relative}.analysis-modal .modal-content{max-width:1000px}.analysis-content{padding:20px 0}.analysis-overview,.class-overview{margin-bottom:30px}.analysis-overview h4,.class-knowledge-mastery h4,.class-overview h4,.knowledge-mastery h4,.question-analysis h4,.question-stats h4,.student-ranking h4{color:#1e293b;font-size:18px;font-weight:600;margin-bottom:15px}.overview-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center}.stat-label{opacity:.9}.knowledge-chart,.knowledge-list{display:flex;flex-direction:column;gap:15px}.knowledge-bar,.knowledge-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:15px}.knowledge-label,.knowledge-name{color:#1e293b;font-weight:600;margin-bottom:10px}.bar-container,.knowledge-progress{align-items:center;display:flex;gap:10px}.bar-container,.progress-bar{background:#e2e8f0;border-radius:12px;flex:1 1;height:24px;overflow:hidden;position:relative}.bar-fill,.progress-fill{background:linear-gradient(90deg,#22c55e,#16a34a);height:100%;transition:width .3s ease}.bar-value,.progress-text{color:#64748b;font-size:13px;font-weight:600;min-width:80px;text-align:right}.question-analysis{margin-top:30px}.analysis-question{background:#fff;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:15px;padding:20px}.analysis-question.correct{background:#22c55e0d;border-color:#22c55e}.analysis-question.incorrect{background:#ef44440d;border-color:#ef4444}.result-badge{border-radius:12px;font-size:12px;font-weight:600;padding:4px 10px}.result-badge.correct{background:#22c55e;color:#fff}.result-badge.incorrect{background:#ef4444;color:#fff}.answer-comparison{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:15px 0}.answer-item{background:#f8fafc;border-radius:8px;padding:10px}.answer-item .label{color:#64748b;font-weight:600;margin-right:8px}.answer-item .value{color:#1e293b}.answer-item .value.correct{color:#22c55e;font-weight:600}.explanation{background:#667eea0d;border-left:4px solid #667eea;border-radius:0 8px 8px 0;line-height:1.6;margin-top:15px;padding:15px}.class-selector{align-items:center;background:#f8fafc;border-radius:8px;display:flex;gap:10px;margin-bottom:20px;padding:15px}.class-selector select{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px}.ranking-table,.stats-table{display:flex;flex-direction:column;gap:10px}.ranking-row,.stat-row{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;padding:15px}.stat-question{align-items:center;display:flex;flex:1 1;gap:10px}.question-brief{color:#64748b;font-size:14px}.stat-rate{align-items:center;display:flex;gap:10px;width:300px}.rate-bar{background:#e2e8f0;border-radius:10px;flex:1 1;height:20px;overflow:hidden}.rate-fill{height:100%;transition:width .3s ease}.rate-value{font-weight:600;min-width:50px;text-align:right}.ranking-row{gap:20px}.rank-num{color:#667eea;font-size:20px;font-weight:700;min-width:40px}.student-name{flex:1 1}.student-score{color:#22c55e;font-size:18px;font-weight:700}.student-correct{color:#64748b}.action-btn.analysis{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.action-btn.analysis:hover{background:linear-gradient(135deg,#d97706,#b45309)}.stat-row-container{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:12px;overflow:hidden}.stat-row.clickable{cursor:pointer;transition:background-color .2s}.stat-row.clickable:hover{background-color:#f8fafc}.stat-question .expand-icon{color:#64748b;font-size:12px;margin-left:8px}.question-detail-expanded{background:#f8fafc;border-top:1px solid #e2e8f0;padding:20px}.detail-section{margin-bottom:16px}.detail-section:last-child{margin-bottom:0}.detail-section h5{color:#475569;font-size:14px;font-weight:600;margin-bottom:8px}.full-question{color:#1e293b;font-size:15px;line-height:1.6}.answer-distribution{display:flex;flex-direction:column;gap:8px}.distribution-item{align-items:center;display:flex;gap:12px}.distribution-label{color:#334155;font-size:14px;min-width:120px}.distribution-label .correct-mark{color:#22c55e;font-weight:600}.distribution-bar{align-items:center;display:flex;flex:1 1;gap:8px}.distribution-fill{align-items:center;border-radius:4px;display:flex;height:24px;padding:0 8px;transition:width .3s}.distribution-count{color:#64748b;font-size:13px;min-width:50px}.correct-answer-display{background:#dcfce7;border-left:3px solid #22c55e;border-radius:4px;color:#166534;font-size:14px;padding:10px 12px}.knowledge-point-display{background:#dbeafe;border-radius:4px;color:#1e40af;font-size:14px;padding:8px 12px}.stats-summary{border-top:1px solid #e2e8f0;display:flex;gap:24px;padding-top:12px}.stats-summary .stat-item{align-items:center;display:flex;gap:8px}.stats-summary .stat-label{color:#64748b;font-size:13px}.stats-summary .stat-value{color:#1e293b;font-size:14px;font-weight:600}.subjective-stats{margin-bottom:30px}.word-cloud-placeholder{background:linear-gradient(135deg,#f8fafc,#e0f2fe);border:2px dashed #94a3b8;border-radius:12px;padding:40px;text-align:center}.word-cloud-placeholder p{color:#64748b;font-size:16px;margin:8px 0}.word-cloud-placeholder .note{color:#94a3b8;font-size:13px;font-style:italic}.distribution-item{transition:all .2s ease}.distribution-item:hover{background:#f8fafc;transform:translateX(4px)}.questionnaire-card.subjective{border-left:4px solid #3b82f6}.type-badge.pre-course{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.type-badge.post-course{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.type-badge.knowledge-test{background:linear-gradient(135deg,#a855f7,#9333ea);color:#fff}.word-cloud-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;height:400px;overflow:hidden;padding:20px;width:100%}.word-cloud-empty{background:linear-gradient(135deg,#f8fafc,#e0f2fe);border:2px dashed #cbd5e1;border-radius:12px;padding:60px 20px;text-align:center}.word-cloud-empty p{color:#64748b;font-size:15px;margin:8px 0}.word-cloud-empty .note{color:#94a3b8;font-size:13px;font-style:italic}.keyword-tags{background:#f8fafc;border-radius:8px;display:flex;flex-wrap:wrap;gap:12px;padding:20px}.keyword-tag{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-weight:500;padding:6px 12px;transition:transform .2s}.keyword-tag:hover{transform:scale(1.1)}.scale-review{background:#f8fafc;border-radius:8px;padding:15px}.scale-label-text{color:#64748b;font-size:14px;margin-left:8px}.word-cloud-wrapper{background:linear-gradient(135deg,#f8fafc,#e0f2fe);border-radius:16px;box-shadow:0 4px 20px #0000000d;margin:20px 0;min-height:300px;padding:30px}.word-cloud-canvas{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:center;min-height:250px;padding:20px}.word-item{animation:fadeInWord .5s ease-out forwards;cursor:default;display:inline-block;font-family:Microsoft YaHei,SimHei,Arial,sans-serif;font-weight:700;opacity:0;padding:6px 12px;text-shadow:1px 1px 2px #0000001a;transition:all .3s ease}@keyframes fadeInWord{0%{opacity:0;transform:scale(.5) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.word-item:hover{text-shadow:2px 2px 4px #0003;transform:scale(1.2) rotate(0deg)!important;z-index:10}.word-cloud-legend{border-top:2px solid #ffffff80;display:flex;gap:24px;justify-content:center;margin-top:20px;padding-top:20px}.legend-item{font-weight:500}.legend-dot{height:12px;width:12px}.legend-dot.high{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 6px #667eea66}.legend-dot.medium{background:linear-gradient(135deg,#3b82f6,#22c55e);box-shadow:0 2px 6px #22c55e66}.legend-dot.low{background:linear-gradient(135deg,#f59e0b,#ef4444);box-shadow:0 2px 6px #f59e0b66}.class-selector-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:12px}.class-checkbox{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:12px;transition:all .2s}.class-checkbox:hover{background:#f1f5f9;border-color:#667eea}.class-checkbox input[type=checkbox]{accent-color:#667eea;height:18px;width:18px}.class-settings-grid{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.class-setting-item{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:16px;transition:all .2s}.class-setting-item:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.class-setting-item input[type=checkbox]:checked+.class-name{color:#667eea;font-weight:600}.class-count{color:#94a3b8;font-size:13px;margin-left:auto}.markdown-body{color:#1e293b;line-height:1.8;white-space:pre-wrap}.markdown-body p{margin:0 0 10px}.markdown-body ol,.markdown-body ul{margin:10px 0 10px 20px;padding:0}.markdown-body li{margin-bottom:6px}.markdown-body code{background-color:#f3f4f6}.markdown-body pre{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-family:Consolas,monospace;font-size:14px;padding:10px 14px}.markdown-body strong{color:#334155;font-weight:700}.markdown-body blockquote{background:#667eea0d;border-left:4px solid #667eea;border-radius:4px;color:#475569;margin:10px 0;padding:10px 14px}.markdown-body h1,.markdown-body h2,.markdown-body h3{color:#1e293b;font-weight:700;margin:14px 0 8px}.markdown-body h1{font-size:20px}.markdown-body h2{font-size:18px}.markdown-body h3{font-size:16px}.question-text{line-height:1.6}.option-label,.question-text{white-space:pre-wrap}.markdown-body p,.question-explanation,.question-text,.questionnaire-description{white-space:pre-line!important}.unsaved-banner{animation:slideUp .4s ease;bottom:24px;left:50%;position:fixed;transform:translateX(-50%);z-index:999}.unsaved-content{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#fbbf24f2,#f59e0bf2);border:1px solid #f59e0b80;border-radius:16px;box-shadow:0 8px 32px #f59e0b66;color:#78350f;display:flex;font-weight:600;gap:12px;padding:16px 32px}.unsaved-content svg{flex-shrink:0}button:disabled{opacity:.6}.action-button:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.action-button:disabled:hover{background:#fffc;transform:none!important}.modal-overlay{cursor:pointer}.modal-content{cursor:default}.class-select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.create-group-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.action-buttons{align-items:center;display:flex;gap:12px}.strict-kb-mode-toggle{align-items:center;background:#ffffffd9;border:1px solid #667eea59;border-radius:12px;color:#334155;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:8px 12px}.strict-kb-mode-toggle input{accent-color:#10b981;margin:0}.save-btn{align-items:center;animation:pulse-glow 2s infinite;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:16px;box-shadow:0 4px 16px #f59e0b4d;display:flex;font-size:15px;font-weight:600;gap:8px;padding:14px 24px;transition:all .3s ease}@keyframes pulse-glow{0%,to{box-shadow:0 4px 16px #f59e0b4d}50%{box-shadow:0 4px 24px #f59e0b80}}.save-btn:hover{box-shadow:0 8px 24px #f59e0b66;transform:translateY(-2px)}.save-btn:disabled{animation:none;cursor:not-allowed;opacity:.6;transform:none}.error-banner{align-items:center;animation:slideDown .3s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#fee2e2e6,#fecacae6);border:1px solid #ef444480;border-left:4px solid #ef4444;border-radius:16px;color:#991b1b;display:flex;font-weight:500;gap:12px;margin-bottom:24px;padding:16px 20px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-close{background:none;border:none;border-radius:8px;color:#991b1b;cursor:pointer;font-size:24px;margin-left:auto;padding:0 8px;transition:background .2s ease}.error-close:hover{background:#ef44441a}.group-management-container{background:linear-gradient(135deg,#667eea,#764ba2);font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;padding:20px}.group-management-container *{box-sizing:border-box}.group-management-container>*{margin:0 auto;max-width:1400px}.header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:24px;box-shadow:0 32px 64px #0000001a;margin-bottom:40px;padding:32px;position:relative;text-align:center}.header:before{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px;content:"";height:4px;left:50%;position:absolute;top:-2px;transform:translateX(-50%);width:60px}.header-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:36px;font-weight:700;margin:0 0 12px}.header-subtitle{color:#6b7280;font-size:16px;font-weight:400;margin:0}.class-selector{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#ffffffe6,#ffffffb3);border:1px solid #ffffff4d;border-radius:20px;box-shadow:0 8px 32px #00000014;margin-bottom:32px;padding:28px}.class-selector-content{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}.class-input-group{gap:16px}.class-icon,.class-input-group{align-items:center;display:flex}.class-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff;height:48px;justify-content:center;width:48px}.select-wrapper{position:relative}.select-label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.class-select{-webkit-appearance:none;appearance:none;background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#374151;font-size:15px;min-width:280px;padding:12px 40px 12px 16px}.class-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.select-wrapper:after{color:#6b7280;content:"▼";font-size:12px;margin-top:12px;pointer-events:none;position:absolute;right:16px;top:50%;transform:translateY(-50%)}.create-group-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:16px;box-shadow:0 4px 16px #10b9814d;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;padding:14px 24px;transition:all .3s ease}.create-group-btn:hover{box-shadow:0 8px 24px #10b98166;transform:translateY(-2px)}.main-content{display:flex;flex-direction:column;gap:32px}.ungrouped-section{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#ffffffe6,#f8fafce6);border:1px solid #ffffff4d;border-radius:20px;box-shadow:0 8px 32px #00000014;padding:28px}.section-header{gap:12px;margin-bottom:20px}.section-header,.section-icon{align-items:center;display:flex}.section-icon{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:12px;color:#fff;height:40px;justify-content:center;width:40px}.section-title{color:#1f2937;font-size:20px;font-weight:700;margin:0}.student-card{background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #0000;border-radius:16px;box-shadow:0 4px 16px #00000014;cursor:move;display:inline-block;margin:6px;min-width:120px;overflow:hidden;padding:16px;position:relative;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none}.student-card:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.student-card:hover:before{transform:scaleX(1)}.student-card:hover{border-color:#667eea4d;box-shadow:0 12px 32px #00000026;transform:translateY(-4px) scale(1.02)}.student-card.dragging{box-shadow:0 16px 40px #0003;opacity:.7;transform:scale(.95) rotate(3deg);z-index:1000}.student-id{color:#667eea;font-family:SF Mono,Monaco,Cascadia Code,monospace;font-size:13px;font-weight:700;margin-bottom:8px}.student-name{color:#374151;font-weight:500}.drop-zone{background:linear-gradient(135deg,#f9fafbcc,#f3f4f6cc);border:2px dashed #d1d5db;border-radius:20px;min-height:140px;overflow:hidden;padding:24px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.drop-zone.drag-over{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea;box-shadow:0 8px 32px #667eea33;transform:scale(1.02)}.drop-zone.drag-over:before{animation:pulse 2s infinite;background:radial-gradient(circle at center,#667eea0d 0,#0000 70%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.ungrouped-drop-zone{background:linear-gradient(135deg,#fef3c7cc,#fde68acc);border-color:#f59e0b}.ungrouped-drop-zone.drag-over{background:linear-gradient(135deg,#f59e0b1a,#d977061a);border-color:#f59e0b;box-shadow:0 8px 32px #f59e0b33}.group-drop-zone{background:linear-gradient(135deg,#f0fdf4cc,#dcfce7cc);border-color:#10b981}.group-drop-zone.drag-over{background:linear-gradient(135deg,#10b9811a,#0596691a);border-color:#10b981;box-shadow:0 8px 32px #10b98133}.students-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start;margin:0;padding:0}.groups-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.group-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#fffffff2,#f8fafcf2);border:1px solid #ffffff4d;box-shadow:0 8px 32px #00000014;transition:all .3s cubic-bezier(.4,0,.2,1)}.group-card:hover{box-shadow:0 16px 48px #0000001f;transform:translateY(-4px)}.group-header{background:linear-gradient(135deg,#ffffffe6,#f8fafce6);border-bottom:1px solid #e5e7eb80;justify-content:space-between;padding:24px}.group-header,.group-title{align-items:center;display:flex}.group-title{color:#1f2937;font-size:16px;font-weight:700;gap:12px}.group-color-indicator{border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0003;height:16px;width:16px}.group-actions{display:flex;gap:8px}.action-button{align-items:center;background:#fffc;border:none;border-radius:12px;cursor:pointer;display:flex;justify-content:center;padding:10px;transition:all .3s ease}.action-button:hover{background:#fff;box-shadow:0 4px 16px #0000001a;transform:scale(1.1)}.action-button.stats{color:#3b82f6}.action-button.stats:hover{background-color:#3b82f61a}.action-button.delete{color:#ef4444}.action-button.delete:hover{background-color:#ef44441a}.group-footer{background:linear-gradient(135deg,#f9fafbcc,#f3f4f6cc);border-top:1px solid #e5e7eb80;padding:20px 24px;text-align:center}.member-count{color:#6b7280;font-size:14px;font-weight:500}.create-first-group{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#f9fafbcc,#f3f4f6cc);border:2px dashed #d1d5db;border-radius:20px;cursor:pointer;padding:48px 24px;text-align:center;transition:all .3s ease}.create-first-group:hover{background:linear-gradient(135deg,#eff6ffcc,#dbeafecc);border-color:#667eea;transform:translateY(-2px)}.create-first-group-icon{align-items:center;color:#d1d5db;display:flex;justify-content:center;margin-bottom:16px;transition:color .3s ease}.create-first-group:hover .create-first-group-icon{color:#667eea}.create-first-group-title{color:#6b7280;font-size:18px;font-weight:600;margin-bottom:8px}.create-first-group-description{color:#9ca3af;font-size:14px;margin:0}.empty-state{padding:48px 24px}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-title{color:#6b7280;font-size:18px;font-weight:600;margin-bottom:8px}.empty-state-description{color:#9ca3af;font-size:14px;margin:0}.modal-overlay{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009}.modal-content{animation:slideUp .4s cubic-bezier(.4,0,.2,1);border:1px solid #fff3;border-radius:24px;box-shadow:0 32px 64px #00000040;max-width:400px;overflow:hidden;width:100%}.modal-header{padding:24px 24px 0}.modal-title{color:#1f2937;font-size:20px;font-weight:700;margin:0}.modal-close-btn{background:none;border:none;border-radius:8px;color:#9ca3af;cursor:pointer;padding:4px;transition:all .2s ease}.modal-close-btn:hover{background:#0000000d;color:#6b7280}.modal-input{border:2px solid #e5e7eb;border-radius:16px;font-size:15px;margin:0;padding:16px;transition:all .3s ease}.modal-footer{padding:0 24px 24px}.modal-button{border:none;border-radius:16px;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:14px;transition:all .3s ease}.modal-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-button.primary:hover{box-shadow:0 8px 24px #667eea66;transform:translateY(-2px)}.modal-button.secondary{background:#f3f4f6;color:#6b7280}.modal-button.secondary:hover{background:#e5e7eb}.stats-list{display:flex;flex-direction:column;gap:16px}.stats-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:12px 0}.stats-item:last-child{border-bottom:none}.stats-label{color:#6b7280;font-weight:500}.stats-value{color:#1f2937;font-weight:600}.stats-value.highlight{color:#10b981}.tip-box{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#dbeafecc,#bfdbfecc);border:1px solid #93c5fd80;border-left:4px solid #3b82f6;border-radius:16px;margin-top:32px;padding:20px}.tip-header{align-items:center;display:flex;gap:8px;margin-bottom:8px}.tip-icon{font-size:18px}.tip-title{color:#1e40af;font-size:15px;font-weight:600}.tip-content{color:#1e40af;font-size:14px;line-height:1.6;margin:0}.loading-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#fffc;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:999}.loading-spinner{border:3px solid #f3f4f6;border-top-color:#667eea;height:40px;margin-bottom:16px;width:40px}.loading-text{color:#6b7280;font-weight:500;margin:0}.access-denied{align-items:center;display:flex;justify-content:center;min-height:60vh}.access-denied-content{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#ffffffe6,#f8fafce6);border:1px solid #ffffff4d;border-radius:20px;box-shadow:0 8px 32px #00000014;padding:48px;text-align:center}.access-denied-icon{font-size:64px;margin-bottom:20px;opacity:.7}.access-denied-content h3{color:#1f2937;font-size:24px;font-weight:700;margin-bottom:12px}.access-denied-content p{color:#6b7280;font-size:16px;margin:0}@media (max-width:768px){.group-management-container{padding:12px}.header{padding:24px 20px}.header-title{font-size:28px}.class-selector-content{align-items:stretch;flex-direction:column}.class-select{min-width:100%}.groups-grid{grid-template-columns:1fr}.students-grid{gap:6px}.student-card{margin:3px;min-width:calc(50% - 12px)}.modal-content{margin:16px}.modal-body,.modal-footer,.modal-header{padding-left:20px;padding-right:20px}}@media (max-width:480px){.student-card{min-width:calc(100% - 12px)}.header-title{font-size:24px}.class-selector,.ungrouped-section{padding:20px}.section-title{font-size:18px}}@media (prefers-contrast:high){.student-card{border:2px solid #374151}.drop-zone{border:3px dashed #374151}.group-card{border:2px solid #374151}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.group-tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff80;border-radius:16px;box-sizing:border-box;display:flex;gap:8px;margin:0 auto 24px;padding:6px;width:100%}.group-tab{background:#0000;border:none;border-radius:12px;color:#6b7280;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:12px 24px;text-align:center;transition:all .3s ease;white-space:nowrap}.group-tab:hover{background:#667eea1a;color:#667eea}.group-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 16px #667eea4d;color:#fff}.group-management-container .group-tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff80;border-radius:16px;box-sizing:border-box;display:flex;gap:8px;margin:0 auto 24px;padding:6px;width:100%}.group-management-container .group-tab{background:#0000;border:none;border-radius:12px;color:#6b7280;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:12px 24px;text-align:center;transition:all .3s ease;white-space:nowrap}.group-management-container .group-tab:hover{background:#667eea1a;color:#667eea}.group-management-container .group-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 16px #667eea4d;color:#fff}.group-management-container .knowledge-graph-container{grid-gap:24px;all:unset;display:grid;gap:24px;grid-template-columns:1fr 360px}.group-chat-modal{background:#fff;border-radius:16px;box-shadow:0 8px 24px #0000001a;display:flex;flex-direction:column;height:70vh;max-width:90%;overflow:hidden;width:600px}.chat-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:12px 16px}.chat-header-actions{align-items:center;display:flex;gap:10px}.strict-kb-toggle{align-items:center;background:#ffffff2e;border:1px solid #ffffff4d;border-radius:999px;display:inline-flex;font-size:12px;gap:6px;padding:4px 8px;-webkit-user-select:none;user-select:none}.strict-kb-toggle input{accent-color:#10b981;margin:0}.close-btn{color:#fff;transition:all .3s ease}.close-btn:hover{transform:rotate(90deg)}.chat-window{background:#f9fafb;flex:1 1;overflow-y:auto;padding:16px}.empty-state{color:#94a3b8;font-size:14px;height:100%}.chat-message{animation:slideIn .3s ease;display:flex;margin-bottom:12px}.chat-message.mine{flex-direction:row-reverse}.chat-message .avatar{align-items:center;background:#667eea1a;border-radius:50%;color:#667eea;display:flex;height:32px;justify-content:center;margin:0 8px;min-width:32px}.chat-message.ai .avatar{background:#f59e0b1a;color:#f59e0b}.chat-message .bubble{background:#fff;border-radius:12px;box-shadow:0 2px 6px #0000000d;max-width:70%;padding:10px 14px}.chat-message.mine .bubble{background:#667eea;color:#fff}.chat-message.ai .bubble{background:#f8fafc;border:1px solid #dbeafe;color:#1f2937}.bubble .username{font-size:12px;font-weight:600;margin-bottom:4px;opacity:.8}.bubble .content{word-wrap:break-word;font-size:14px;line-height:1.5}.markdown-content{color:inherit;line-height:1.72;word-break:break-word}.md-line{margin:0 0 8px}.md-h1,.md-h2,.md-h3{color:#0f172a;line-height:1.4;margin:10px 0 8px}.md-h1{font-size:23px}.md-h2{font-size:20px}.md-h3{font-size:17px}.md-ol,.md-ul{margin:8px 0 10px 20px;padding:0}.md-li{margin:4px 0}.md-blockquote{background:#eff6ff;border-left:4px solid #60a5fa;border-radius:6px;color:#1e3a8a;margin:10px 0;padding:8px 12px}.md-hr{border:none;border-top:1px solid #d1d5db;margin:12px 0}.inline-code{background:#eef2ff;border-radius:4px;color:#3730a3;font-family:Consolas,Courier New,monospace;font-size:13px;padding:2px 6px}.code-block{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;font-size:13px;line-height:1.6;margin:10px 0;overflow-x:auto;overflow-y:visible;padding:10px 12px}.code-block code{display:block;font-family:Consolas,Courier New,monospace;tab-size:2;white-space:pre-wrap}.typing-bubble{min-width:120px}.typing-indicator{align-items:center;display:flex;gap:8px;padding:4px 0}.typing-text{color:#64748b;font-size:13px;font-style:italic}.typing-dots{align-items:center;display:flex;gap:4px}.typing-dot{animation:bounce 1.4s ease-in-out infinite both;background:#f59e0b;border-radius:50%;height:6px;width:6px}.typing-dot:first-child{animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.5;transform:scale(0)}40%{opacity:1;transform:scale(1)}}.chat-input{background:#fff;border-top:1px solid #e5e7eb;display:flex;gap:8px;padding:10px}.chat-input input{border:1px solid #ddd;border-radius:8px;flex:1 1;font-size:14px;outline:none;padding:8px 12px;transition:all .3s ease}.chat-input input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.chat-input input:disabled{background:#f1f5f9;cursor:not-allowed}.chat-input button{align-items:center;background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:4px;padding:0 16px;transition:all .3s ease}.chat-input button:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.chat-input button:disabled{background:#cbd5e0;cursor:not-allowed;transform:none}.chat-input .ai-btn{background:#10b981}.chat-input .ai-btn:hover:not(:disabled){background:#059669;box-shadow:0 4px 12px #10b9814d}.chat-overlay{background:#0006;z-index:999}.chat-window::-webkit-scrollbar{width:6px}.chat-window::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}.chat-window::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.chat-window::-webkit-scrollbar-thumb:hover{background:#0000004d}@media (max-width:768px){.group-chat-modal{height:85vh;width:95%}.chat-message .bubble{max-width:80%}.chat-input{flex-wrap:wrap}.chat-input button{flex:1 1;min-width:100px}}.tabs{border-bottom:1px solid #ddd;margin:0 0 10px}.tab{background:#f5f5f5;border-right:1px solid #ddd;color:#555;font-size:14px;padding:8px 16px;transition:all .2s ease}.tab:last-child{border-right:none}.tab:hover{background:#eee}.tab.active{background:#fff;border-bottom:2px solid #007bff;color:#007bff;font-weight:700}.knowledge-graph-container{max-width:100%;padding:0}.knowledge-graph-container .graph-left{min-width:0;width:100%}.knowledge-graph-container .graph-right{padding:24px;position:-webkit-sticky;position:sticky;top:20px}.knowledge-graph-container .filter-panel,.knowledge-graph-container .graph-right{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(135deg,#fffffff2,#f8fafcf2);border:1px solid #ffffff4d;border-radius:24px;box-shadow:0 8px 32px #00000014;width:100%}.knowledge-graph-container .filter-panel{box-sizing:border-box;margin:0 0 24px;padding:32px}.filter-header{margin-bottom:28px;text-align:center}.filter-title-group{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:12px}.filter-icon{animation:sparkle 2s ease-in-out infinite;color:#667eea}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.filter-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:700;margin:0}.filter-subtitle{color:#6b7280;font-size:15px;margin:0}.filter-controls{display:flex;flex-direction:column;gap:20px}.filter-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-label{align-items:center;color:#374151;display:flex;font-size:14px;font-weight:600;gap:8px}.filter-label svg{color:#667eea}.filter-date,.filter-select{background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#374151;cursor:pointer;font-size:15px;font-weight:500;padding:12px 16px;transition:all .3s ease;width:100%}.filter-date:focus,.filter-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filter-date:disabled,.filter-select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.filter-actions{display:flex;gap:12px;justify-content:center;padding-top:8px}.btn-download,.btn-generate{align-items:center;border:none;border-radius:16px;box-shadow:0 4px 16px #0000001a;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;padding:14px 28px;transition:all .3s ease}.btn-generate{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-generate:hover:not(:disabled){box-shadow:0 8px 24px #667eea66;transform:translateY(-2px)}.btn-generate:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-download{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-download:hover:not(:disabled){box-shadow:0 8px 24px #10b98166;transform:translateY(-2px)}.spinning{animation:spin 1s linear infinite}.stats-bar{background:linear-gradient(135deg,#dbeafe80,#bfdbfe80);border:1px solid #93c5fd4d;border-radius:16px;display:flex;gap:24px;justify-content:center;margin-top:24px;padding:20px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-label{color:#6b7280;font-weight:500}.stat-value{color:#1e40af;font-size:18px}.legend-bar{background:linear-gradient(135deg,#f9fafbe6,#f3f4f6e6);border:1px solid #e5e7eb;border-radius:16px;margin-top:20px;padding:20px}.legend-title{color:#374151;font-size:15px;font-weight:600;margin-bottom:16px;text-align:center}.legend-items{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.legend-item{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:8px 16px;transition:transform .2s ease}.legend-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.legend-dot{align-items:center;border:2px solid #fff;box-shadow:0 2px 4px #0000001a;display:flex;font-size:12px;height:24px;justify-content:center;width:24px}.legend-text{color:#374151;font-size:13px;font-weight:500}.chart-wrapper{border:1px solid #ffffff4d;border-radius:24px;box-shadow:0 8px 32px #00000014;min-height:600px;position:relative}.chart-canvas{height:600px;width:100%}.empty-chart{align-items:center;color:#9ca3af;display:flex;flex-direction:column;height:600px;justify-content:center}.empty-icon{color:#667eea;opacity:.3}.empty-title{color:#6b7280;font-size:24px;font-weight:600;margin:0 0 12px}.empty-description{color:#9ca3af;font-size:15px;line-height:1.6;margin:0;max-width:400px;text-align:center}.json-preview{background:linear-gradient(135deg,#f9fafbe6,#f3f4f6e6);border:1px solid #e5e7eb;border-radius:16px;margin-top:24px;overflow:hidden}.json-summary{color:#374151;cursor:pointer;font-size:15px;font-weight:600;padding:16px 20px;transition:background .2s ease;-webkit-user-select:none;user-select:none}.json-summary:hover{background:#667eea0d}.json-content{background:#1f2937;color:#10b981;font-family:SF Mono,Monaco,Cascadia Code,monospace;font-size:13px;line-height:1.6;margin:0;overflow-x:auto;padding:20px}@media (max-width:768px){.knowledge-graph-container{padding:0}.filter-panel{border-radius:16px;padding:24px 20px}.filter-title{font-size:24px}.filter-row{grid-template-columns:1fr}.filter-actions{flex-direction:column}.btn-download,.btn-generate{justify-content:center;width:100%}.stats-bar{flex-direction:column;gap:16px}.chart-wrapper{border-radius:16px;padding:16px}.chart-canvas,.empty-chart{height:400px}}@media (min-width:769px) and (max-width:1200px){.filter-row{grid-template-columns:repeat(2,1fr)}}.tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff80;border-radius:16px;box-sizing:border-box;display:flex;gap:8px;margin:0 auto 24px;padding:6px;width:100%}.tab{background:#0000;border:none;border-radius:12px;color:#6b7280;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:12px 24px;text-align:center;transition:all .3s ease;white-space:nowrap}.tab:hover{background:#667eea1a;color:#667eea}.tab.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 16px #667eea4d;color:#fff}.knowledge-graph-container{grid-template-columns:1fr 350px}.graph-left{min-width:0}.graph-right{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px}.ranking-header{border-bottom:2px solid #e5e7eb;gap:12px;margin-bottom:20px;padding-bottom:16px}.ranking-header h3{color:#1f2937;flex:1 1;font-size:18px;font-weight:700;margin:0}.knowledge-graph-layout{display:flex;justify-content:space-between}.ranking-header svg{color:#f59e0b}.ranking-empty{color:#9ca3af;padding:40px 20px;text-align:center}.ranking-empty svg{margin:0 auto 12px}.ranking-empty p{font-size:14px;margin:0}.ranking-list{display:flex;flex-direction:column;gap:12px;max-height:600px;padding-right:8px}.ranking-list::-webkit-scrollbar-track{background:#f3f4f6}.ranking-list::-webkit-scrollbar-thumb{background:#d1d5db}.ranking-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}.ranking-item{background:#fff;border:2px solid #f3f4f6;border-radius:16px;padding:16px;transition:all .3s ease}.ranking-item:hover{border-color:#667eea;box-shadow:0 4px 16px #667eea33}.rank-index{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:36px;justify-content:center;width:36px}.ranking-item:first-child .rank-index{background:linear-gradient(135deg,#fbbf24,#f59e0b);font-size:18px}.ranking-item:nth-child(2) .rank-index{background:linear-gradient(135deg,#d1d5db,#9ca3af)}.ranking-item:nth-child(3) .rank-index{background:linear-gradient(135deg,#f59e0b,#d97706)}.rank-info{flex:1 1;min-width:0}.rank-name{color:#1f2937;display:block;font-size:15px;font-weight:600;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-stats{color:#6b7280;display:flex;font-size:13px;gap:12px}.rank-score{color:#667eea;flex-shrink:0;font-size:18px;font-weight:700}.graph-right{width:25%}.ranking-item.clickable{cursor:pointer}.ranking-item.clickable:hover{border-color:#f59e0b;box-shadow:0 6px 20px #f59e0b4d;transform:translateX(-4px) scale(1.02)}.ranking-item.clickable:active{transform:translateX(-2px) scale(.98)}.back-button{align-items:center;background:none;border:none;border-radius:8px;color:#667eea;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.back-button:hover{background:#667eea1a;transform:translateX(-2px)}.back-button:active{transform:translateX(0)}.current-group-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 16px #667eea4d;color:#fff;font-size:14px;font-weight:600;margin-bottom:16px;padding:12px 16px;text-align:center}.ranking-item.clickable .rank-score:after{color:#9ca3af;content:"›";font-size:20px;margin-left:8px;transition:all .2s ease}.ranking-item.clickable:hover .rank-score:after{color:#f59e0b;transform:translateX(2px)}.ranking-item.clickable:first-child{background:linear-gradient(135deg,#fef3c74d,#fde68a4d);border:2px solid #fbbf24}.ranking-item.clickable:nth-child(2){background:linear-gradient(135deg,#f3f4f64d,#e5e7eb4d);border:2px solid #d1d5db}.ranking-item.clickable:nth-child(3){background:linear-gradient(135deg,#fed7aa4d,#fdba744d);border:2px solid #f59e0b}.graph-list-panel{animation:slideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;left:50%;max-height:70vh;position:fixed;top:50%;transform:translate(-50%,-50%);width:600px;z-index:1000}.graph-list-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.graph-list-header h3{align-items:center;color:#1f2937;display:flex;font-size:18px;gap:8px;margin:0}.close-btn{background:none;border:none;color:#6b7280;cursor:pointer;font-size:24px;line-height:1;padding:4px 8px;transition:color .2s}.close-btn:hover{color:#1f2937}.graph-list-content{max-height:calc(70vh - 80px);overflow-y:auto;padding:16px}.loading-state{color:#6b7280;font-size:14px;padding:40px;text-align:center}.empty-state{color:#9ca3af;padding:40px}.empty-state svg{margin:0 auto 16px;opacity:.5}.empty-state p{font-size:14px}.graph-items{display:flex;flex-direction:column;gap:12px}.graph-item{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;display:flex;justify-content:space-between}.graph-item:hover{background:#f3f4f6;border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.graph-item-info{flex:1 1;min-width:0}.graph-item-title{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.graph-item-meta{color:#6b7280;flex-wrap:wrap}.graph-item-meta span{align-items:center;display:flex;gap:4px}.graph-item-actions{flex-shrink:0}.action-btn{border:none;justify-content:center;padding:8px}.action-btn.view{background:#eff6ff;color:#2563eb}.action-btn.view:hover{background:#dbeafe;transform:scale(1.1)}.action-btn.delete{background:#fef2f2;color:#dc2626}.action-btn.delete:hover{background:#fee2e2;transform:scale(1.1)}.btn-list{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s ease}.btn-list:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-list:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-save{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:10px;box-shadow:0 4px 12px #10b9814d;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s ease}.btn-save:hover:not(:disabled){box-shadow:0 6px 20px #10b98166}.btn-save:disabled{transform:none}.btn-icon{flex-shrink:0}.modal-overlay{animation:fadeIn .2s ease-out;bottom:0;right:0;z-index:2000}.modal-content{animation:scaleIn .3s ease-out;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h3{color:#1f2937;font-size:18px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;line-height:1;padding:0;transition:color .2s;width:32px}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-body{padding:24px}.modal-label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.modal-input{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:14px;padding:12px 16px;transition:all .2s;width:100%}.modal-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.modal-input::placeholder{color:#9ca3af}.modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.modal-btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s}.modal-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-btn.primary:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.modal-btn.secondary{background:#f3f4f6;color:#374151}.modal-btn.secondary:hover{background:#e5e7eb}@media (max-width:768px){.graph-list-panel{max-width:none;width:90%}.graph-item{align-items:flex-start;flex-direction:column;gap:12px}.graph-item-actions{justify-content:flex-end;width:100%}.modal-content{width:95%}}.graph-item-title-wrapper{align-items:center;display:flex;gap:8px;margin-bottom:6px}.title-edit-btn{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;opacity:0;padding:4px;transition:all .2s}.graph-item:hover .title-edit-btn{opacity:1}.title-edit-btn:hover{background:#f3f4f6;color:#667eea}.graph-item-title-edit{align-items:center;display:flex;gap:8px;margin-bottom:6px;width:100%}.title-edit-input{border:1px solid #667eea;border-radius:6px;box-shadow:0 0 0 3px #667eea1a;color:#1f2937;flex:1 1;font-size:15px;font-weight:600;outline:none;padding:6px 10px}.title-edit-input:focus{border-color:#764ba2}.title-edit-actions{display:flex;flex-shrink:0;gap:4px}.title-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s}.title-btn.save{background:#10b981;color:#fff}.title-btn.save:hover{background:#059669;transform:scale(1.05)}.title-btn.cancel{background:#f3f4f6;color:#6b7280}.title-btn.cancel:hover{background:#e5e7eb;color:#374151}@media (max-width:768px){.graph-item-title-wrapper{align-items:flex-start;flex-direction:column}.title-edit-btn{opacity:1}.graph-item-title-edit{align-items:stretch;flex-direction:column}.title-edit-actions{justify-content:flex-end;width:100%}}@media (max-width:1200px){.knowledge-graph-container{grid-template-columns:1fr!important}.knowledge-graph-container .graph-right{margin-top:24px;position:static}}@media (max-width:768px){.knowledge-graph-container{grid-template-columns:1fr!important;padding:0}.knowledge-graph-container .filter-panel{border-radius:16px;padding:24px 20px}.knowledge-graph-container .filter-title{font-size:24px}.knowledge-graph-container .graph-right{padding:20px}}.group-graph-wrapper{box-sizing:border-box;display:flex;flex-direction:column;gap:24px;margin:0 auto;max-width:1400px;width:100%}.knowledge-graph-container{grid-template-columns:1fr 360px}.graph-left,.graph-right{min-width:0}.graph-left{width:72%}@media (max-width:1200px){.knowledge-graph-container{grid-template-columns:1fr}.graph-right{margin-top:16px;position:static}}.chart-wrapper{background:#fff;box-shadow:0 8px 24px #00000014;overflow:hidden}.chart-wrapper,.filter-panel{border-radius:20px;box-sizing:border-box;padding:24px;width:100%}.filter-panel{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);border:1px solid #ffffff4d;box-shadow:0 8px 32px #00000014}.knowledge-graph-container{grid-gap:24px;align-items:start;box-sizing:border-box;display:grid;gap:24px;grid-template-columns:1fr 340px;width:100%}.graph-left{background:#fff;border-radius:16px;box-shadow:0 8px 24px #0000000d;min-height:600px;padding:24px}.graph-right{background:linear-gradient(135deg,#fffffff2,#f8fafcf2);border:1px solid #ffffff4d;border-radius:20px;box-shadow:0 8px 32px #00000014;padding:24px;position:-webkit-sticky;position:sticky;top:20px}@media (max-width:1200px){.knowledge-graph-container{grid-template-columns:1fr}.graph-right{position:static}}.student-groups-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:40px 20px}.groups-header{justify-content:space-between;margin-bottom:40px;padding:0 20px}.groups-header,.header-content{align-items:center;display:flex}.header-content{gap:16px}.header-icon{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:16px;color:#fff;padding:12px}.header-text h2{color:#fff;font-size:32px;font-weight:700;margin:0 0 4px}.header-text p{color:#ffffffe6;font-size:16px}.groups-count{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:24px;color:#fff;font-weight:600;padding:10px 20px}.loading-state{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;padding:100px 20px}.loading-spinner{border:4px solid #ffffff4d;height:50px;margin-bottom:20px;width:50px}.loading-state p{font-size:16px;margin:0}.empty-state{flex-direction:column;padding:100px 20px;text-align:center}.empty-icon,.empty-state{align-items:center;display:flex;justify-content:center}.empty-icon{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:50%;height:120px;margin-bottom:24px;width:120px}.empty-icon svg{color:#fff}.empty-state h3{color:#fff;font-size:24px;font-weight:600;margin:0 0 12px}.empty-state p{color:#ffffffe6;font-size:16px;margin:0;max-width:400px}.groups-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));margin:0 auto;max-width:1400px;padding:0 20px}.group-card{animation:fadeInUp .6s ease-out backwards;background:#fff;border-radius:20px;box-shadow:0 10px 30px #0003;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:24px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.group-card:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transform-origin:left;transition:transform .4s ease}.group-card:hover{box-shadow:0 20px 40px #0000004d;transform:translateY(-8px)}.group-card:hover:before{transform:scaleX(1)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.group-card-header{justify-content:space-between;margin-bottom:20px}.group-card-header,.group-icon{align-items:center;display:flex}.group-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 12px #667eea4d;color:#fff;height:56px;justify-content:center;width:56px}.group-badge{background:linear-gradient(135deg,#10b981,#059669);border-radius:20px;box-shadow:0 2px 8px #10b9814d;color:#fff;font-size:12px;font-weight:600;padding:6px 14px}.group-card-body{flex:1 1;margin-bottom:20px}.group-name{color:#1e293b;font-size:20px;font-weight:700;line-height:1.3;margin:0 0 12px}.group-description{color:#64748b;font-size:14px;line-height:1.6;margin:0}.group-card-footer{margin-top:auto}.enter-chat-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;overflow:hidden;padding:14px 20px;position:relative;transition:all .3s ease;width:100%}.enter-chat-btn:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.enter-chat-btn:hover:before{left:100%}.enter-chat-btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.enter-chat-btn:active{transform:translateY(0)}.arrow-icon{transition:transform .3s ease}.enter-chat-btn:hover .arrow-icon{transform:translateX(4px)}.chat-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@media (max-width:768px){.student-groups-container{padding:20px 12px}.groups-header{align-items:flex-start;flex-direction:column;gap:16px;padding:0 8px}.header-text h2{font-size:24px}.header-text p{font-size:14px}.groups-grid{gap:16px;grid-template-columns:1fr;padding:0 8px}.group-card{padding:20px}.group-icon{height:48px;width:48px}.group-name{font-size:18px}.enter-chat-btn{font-size:14px;padding:12px 16px}}@media (min-width:769px) and (max-width:1200px){.groups-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1201px){.groups-grid{grid-template-columns:repeat(3,1fr)}}.knowledge-graph-container{background:#f8f9fa;display:flex;flex-direction:column;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.knowledge-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px 24px}.header-left h2{color:#1e293b;font-size:20px}.session-id{background:#f1f5f9;border-radius:4px;color:#64748b;font-size:12px;padding:4px 8px}.header-actions{align-items:center;display:flex;gap:12px}.action-btn,.auto-refresh-toggle{align-items:center;cursor:pointer;display:flex;font-size:14px;gap:6px}.action-btn{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:8px 16px;transition:all .2s}.action-btn:hover{background:#f8fafc;border-color:#cbd5e1}.action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.action-btn.primary:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.knowledge-content{grid-gap:20px;display:grid;gap:20px}.graph-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;position:relative}.graph-legend{background:#f8fafc;border-radius:8px;display:flex;gap:24px;margin-bottom:16px;padding:12px}.legend-item{align-items:center;color:#64748b;display:flex;font-size:13px;gap:8px}.legend-dot{border-radius:50%;height:16px;width:16px}.legend-dot.student{background:#ef4444}.legend-dot.important{background:#f59e0b}.legend-dot.normal{background:#3b82f6}.graph-canvas{border:1px solid #e2e8f0;border-radius:8px;height:600px;width:100%}.graph-empty{align-items:center;color:#94a3b8;display:flex;flex-direction:column;height:600px;justify-content:center}.graph-empty .hint{font-size:14px;margin-top:8px}.summary-section{box-shadow:0 2px 8px #0000001a;max-height:700px;overflow-y:auto;padding:20px}.summary-header{align-items:center;border-bottom:2px solid #f1f5f9;display:flex;gap:8px;margin-bottom:20px;padding-bottom:16px}.summary-header h3{flex:1 1;font-size:18px;margin:0}.summary-time{color:#64748b;font-size:12px}.summary-block{background:#f8fafc;border-left:4px solid #3b82f6;border-radius:8px;margin-bottom:24px;padding:16px}.summary-block.weak{background:#fef2f2;border-left-color:#ef4444}.summary-block.suggestions{background:#f0fdf4;border-left-color:#22c55e}.summary-block h4{color:#1e293b;font-size:15px;margin:0 0 12px}.summary-block p{color:#475569;line-height:1.6;margin:0}.summary-block ul{margin:0;padding-left:20px}.summary-block li{color:#475569;line-height:1.6;margin-bottom:8px}@media (max-width:1200px){.knowledge-content{grid-template-columns:1fr}.summary-section{max-height:none}}.ranking-panel{background:#fff;border-left:2px solid #e8e8e8;box-shadow:-4px 0 12px #00000014;display:flex;flex-direction:column;height:calc(100vh - 140px);position:fixed;right:0;top:120px;transition:transform .3s ease;width:320px;z-index:100}.ranking-panel.hide{transform:translateX(100%)}.ranking-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #f0f0f0;color:#fff;justify-content:space-between;padding:16px}.ranking-header,.ranking-title{align-items:center;display:flex}.ranking-title{gap:8px}.ranking-title h3{font-size:16px;font-weight:600;margin:0}.toggle-ranking-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:4px 12px;transition:all .2s}.toggle-ranking-btn:hover{background:#ffffff4d}.ranking-empty,.ranking-loading{color:#999;padding:40px 20px;text-align:center}.ranking-empty svg{margin-bottom:12px;opacity:.5}.ranking-list{flex:1 1;overflow-y:auto;padding:12px}.ranking-item{align-items:center;background:#fafafa;border:2px solid #e8e8e8;border-radius:8px;cursor:pointer;display:flex;gap:12px;margin-bottom:8px;padding:12px;transition:all .2s}.ranking-item:hover{border-color:#1677ff;box-shadow:0 2px 8px #1677ff26;transform:translateX(-4px)}.ranking-item.active{background:#e6f4ff;border-color:#1677ff;box-shadow:0 4px 12px #1677ff33}.ranking-badge{flex-shrink:0}.rank-medal{align-items:center;border-radius:50%;display:inline-flex;font-size:16px;font-weight:700;height:36px;justify-content:center;width:36px}.rank-medal.rank-1{background:linear-gradient(135deg,gold,#ffed4e);color:#d4af37}.rank-medal.rank-2{background:linear-gradient(135deg,silver,#e8e8e8);color:grey}.rank-medal.rank-3{background:linear-gradient(135deg,#cd7f32,#e6b87d);color:#8b4513}.rank-medal:not(.rank-1):not(.rank-2):not(.rank-3){background:#f0f0f0;color:#666;font-size:14px}.ranking-info{flex:1 1;min-width:0}.student-name{align-items:center;color:#333;display:flex;font-size:14px;font-weight:600;gap:4px;margin-bottom:6px}.ranking-stats{display:flex;flex-wrap:wrap;gap:8px}.stat-item{align-items:center;border-radius:4px;color:#666;display:inline-flex;font-size:11px;padding:2px 6px}.ranking-score{flex-shrink:0;text-align:center}.score-value{color:#1677ff;display:block;font-size:18px;font-weight:700}.score-label{color:#999;display:block;font-size:10px;margin-top:2px}.ranking-legend{background:#f9f9f9;border-top:2px solid #e8e8e8;font-size:12px;padding:16px}.ranking-legend h4{color:#333;font-size:13px;margin:0 0 8px}.ranking-legend ul{color:#666;margin:0;padding-left:20px}.ranking-legend li{line-height:1.5;margin-bottom:4px}.knowledge-content{position:relative}.graph-section{transition:margin-right .3s ease}.ranking-panel.show~.graph-section{margin-right:320px}.ranking-list::-webkit-scrollbar{width:6px}.ranking-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.ranking-list::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.ranking-list::-webkit-scrollbar-thumb:hover{background:#555}.toggle-ranking-btn-outside{background:#007bff;border:none;border-radius:20px;color:#fff;cursor:pointer;padding:8px 14px;position:fixed;right:10px;top:50%;transform:translateY(-50%);z-index:2000}.kg-container{grid-gap:20px;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);display:grid;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;gap:20px;grid-template-columns:420px 1fr;min-height:calc(100vh - 48px);padding:24px}.kg-left,.kg-right{background:#fff;border:none;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:24px;transition:all .3s ease}.kg-left:hover,.kg-right:hover{box-shadow:0 6px 28px #0000001f}.segmented{background:#f0f2f5;border-radius:12px;display:flex;gap:0;margin-bottom:24px;padding:4px;position:relative}.segmented button{background:#0000;border:none;border-radius:10px;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:10px 16px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1}.segmented button.active{background:#fff;box-shadow:0 2px 8px #1677ff26;color:#1677ff}.segmented button:hover:not(.active){color:#1677ff}.doc-box,.rec-box{background:linear-gradient(135deg,#fafbfc,#f5f7fa);border:2px dashed #e0e0e0;border-radius:12px;font-size:14px;margin-bottom:20px;padding:20px;transition:all .3s ease}.doc-box:hover,.rec-box:hover{background:linear-gradient(135deg,#f0f8ff,#e6f4ff);border-color:#1677ff}.rec-box>div{color:#333;font-weight:500;margin-bottom:12px}.rec-box>div:last-child{margin-bottom:0}.rec-indicator{background:#52c41a;height:10px;width:10px}.rec-indicator.recording{animation:pulse 1.5s ease-in-out infinite}.doc-box button,.rec-box button{background:linear-gradient(135deg,#1677ff,#0958d9);border:none;border-radius:8px;box-shadow:0 2px 8px #1677ff4d;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .3s ease}.doc-box button:hover:not(:disabled),.rec-box button:hover:not(:disabled){box-shadow:0 4px 12px #1677ff66;transform:translateY(-2px)}.doc-box button:active:not(:disabled),.rec-box button:active:not(:disabled){transform:translateY(0)}.doc-box button:disabled,.rec-box button:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.rec-box button.stop-btn{background:linear-gradient(135deg,#ff4d4f,#cf1322);box-shadow:0 2px 8px #ff4d4f4d}.rec-box button.stop-btn:hover{box-shadow:0 4px 12px #ff4d4f66}.doc-box{padding:40px 20px;text-align:center}.doc-box input[type=file]{display:none}.file-upload-label{align-items:center;background:linear-gradient(135deg,#52c41a,#389e0d);border-radius:8px;box-shadow:0 2px 8px #52c41a4d;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:8px;padding:12px 24px;transition:all .3s ease}.file-upload-label:hover{box-shadow:0 4px 12px #52c41a66;transform:translateY(-2px)}.file-upload-icon{font-size:18px}.transcript-box{margin-top:20px}.transcript-box-title{align-items:center;color:#333;display:flex;font-size:15px;font-weight:600;gap:8px;margin-bottom:12px}.transcript-box textarea{background:#fafafa;border:2px solid #e0e0e0;border-radius:8px;font-family:SF Mono,Consolas,Microsoft YaHei,monospace;font-size:13px;line-height:1.6;padding:12px;resize:vertical;transition:all .3s ease;width:100%}.transcript-box textarea:focus{background:#fff;border-color:#1677ff;box-shadow:0 0 0 3px #1677ff1a;outline:none}.transcript-box textarea::placeholder{color:#bbb;font-style:italic}.transcript-box button{background:linear-gradient(135deg,#52c41a,#389e0d);border:none;border-radius:8px;box-shadow:0 2px 8px #52c41a4d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:12px;padding:12px 20px;transition:all .3s ease;width:100%}.transcript-box button:hover:not(:disabled){box-shadow:0 4px 12px #52c41a66;transform:translateY(-2px)}.transcript-box button:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.kg-right{display:flex;flex-direction:column}.chart-container{background:linear-gradient(135deg,#fff,#f9fafb);border:2px solid #f0f0f0;border-radius:12px;height:560px;overflow:hidden;position:relative;width:100%}.chart-placeholder{color:#999;left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.chart-placeholder-icon{font-size:64px;margin-bottom:16px;opacity:.3}.chart-placeholder-text{font-size:16px;font-weight:500}.kg-right details{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#333;font-size:13px;margin-top:16px;padding:12px;transition:all .3s ease}.kg-right details:hover{background:#f1f3f5;border-color:#dee2e6}.kg-right details summary{color:#1677ff;cursor:pointer;font-weight:600;padding:4px 0;-webkit-user-select:none;user-select:none}.kg-right details summary:hover{color:#0958d9}.kg-right pre{word-wrap:break-word;background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:12px;line-height:1.6;margin-top:12px;overflow-x:auto;padding:12px;white-space:pre-wrap}.info-banner{align-items:center;background:linear-gradient(135deg,#fff7e6,#ffe7ba);border:1px solid #ffd591;border-radius:8px;color:#d46b08;display:flex;font-size:13px;gap:10px;margin-bottom:16px;padding:12px 16px}.info-banner-icon{flex-shrink:0;font-size:16px}@media (max-width:1200px){.kg-container{grid-template-columns:1fr}.kg-left{order:1}.kg-right{order:2}}.loading-spinner{border:2px solid #ffffff4d;border-top-color:#fff}.realtime-transcript{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #667eea4d;margin-top:20px;padding:20px}.realtime-transcript-title{align-items:center;color:#fff;display:flex;gap:8px}.realtime-transcript-content{word-wrap:break-word;background:#fffffff2;border-radius:8px;box-shadow:inset 0 2px 8px #0000001a;color:#333;font-size:15px;max-height:300px;min-height:120px;padding:16px}.realtime-transcript-content:empty:before{color:#999;content:"等待语音输入...";font-style:italic}.rec-box{background:#fff;border:1px solid #d9d9d9;border-radius:8px;margin-bottom:16px;padding:20px}.rec-status{align-items:center;color:#666;display:flex;font-size:14px;gap:8px;margin-bottom:12px}.rec-indicator{background:#d9d9d9;border-radius:50%;height:12px;transition:all .3s;width:12px}.rec-indicator.recording{animation:pulse 1.5s infinite;background:#ff4d4f}.audio-level{background:#f5f5f5;border-radius:4px;margin-top:12px;padding:12px}.audio-level-bar{align-items:center;display:flex;gap:8px}.audio-level-progress{background:#eee;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.audio-level-fill{border-radius:4px;height:100%;transition:width .1s ease-out,background .3s}.audio-warning{align-items:center;color:#ff4d4f;display:flex;font-size:12px;gap:4px;margin-top:8px}.realtime-transcript{background:#f0f7ff;border:1px solid #91caff;border-radius:8px;margin-bottom:16px;padding:16px}.realtime-transcript-title{color:#1677ff;font-size:14px;font-weight:600;margin-bottom:12px}.realtime-transcript-content{color:#262626;font-size:14px;line-height:1.8;max-height:200px;min-height:60px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}button{background:#fff;border:1px solid #d9d9d9;border-radius:6px;font-size:14px;padding:8px 16px}button:hover:not(:disabled){border-color:#1677ff;color:#1677ff}button:disabled{cursor:not-allowed;opacity:.5}button.stop-btn{background:#ff4d4f;border-color:#ff4d4f;color:#fff}button.stop-btn:hover{background:#ff7875;border-color:#ff7875}.loading-spinner{animation:spin .8s linear infinite;border:2px solid #f0f0f0;height:14px;margin-right:8px;vertical-align:middle;width:14px}.manage-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:20px}.manage-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:12px}.manage-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.graph-list{display:flex;flex-direction:column;gap:12px;max-height:600px;overflow-y:auto}.graph-item{background:#fafafa;border:2px solid #e8e8e8;border-radius:8px;cursor:pointer;padding:16px;transition:all .2s}.graph-item:hover{border-color:#1677ff;box-shadow:0 2px 8px #1677ff26;transform:translateY(-2px)}.graph-item.active{background:#e6f4ff;border-color:#1677ff;box-shadow:0 4px 12px #1677ff33}.graph-item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.graph-item-header h4{color:#333;flex:1 1;font-size:16px;font-weight:600;line-height:1.5;margin:0}.graph-item-actions{display:flex;gap:8px;margin-left:12px}.btn-delete,.btn-view{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;min-width:36px;padding:6px 12px;transition:all .2s}.btn-view:hover{background:#e6f4ff;transform:scale(1.1)}.btn-delete:hover{background:#fff1f0;transform:scale(1.1)}.graph-item-meta{align-items:center;color:#666;display:flex;font-size:13px;gap:12px}.meta-badge{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:4px 12px}.meta-badge.audio{background:linear-gradient(135deg,#f093fb,#f5576c)}.meta-badge.document{background:linear-gradient(135deg,#4facfe,#00f2fe)}.meta-time{align-items:center;color:#999;display:flex;font-size:12px;gap:4px}.meta-time:before{content:"🕐";font-size:14px}.graph-list-empty{color:#999;padding:60px 20px;text-align:center}.graph-list-empty-icon{font-size:64px;margin-bottom:16px;opacity:.5}.graph-list-empty-text{font-size:16px;margin-bottom:8px}.graph-list-empty-hint{color:#bbb;font-size:13px}.loading-spinner{border:2px solid #f3f3f3;border-top-color:#1677ff;display:inline-block;height:16px;width:16px}.graph-list::-webkit-scrollbar{width:6px}.graph-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.graph-list::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.graph-list::-webkit-scrollbar-thumb:hover{background:#555}.collaborative-kg-container,.student-kg-container{background:linear-gradient(135deg,#667eea,#764ba2);box-sizing:border-box;display:flex;flex-direction:column;height:100vh;padding:20px}.notification{animation:slideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:400px;min-width:320px;padding:20px;position:fixed;right:20px;top:20px;z-index:1000}.notification-info{border-left:4px solid #1890ff}.notification-success{border-left:4px solid #52c41a}.kg-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px;padding:20px 30px}.header-left{flex-wrap:wrap;gap:20px}.header-left h2{color:#1890ff;font-size:28px;font-weight:700;margin:0}.session-badge{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:25px;color:#fff;display:flex;font-weight:600;gap:12px;padding:10px 20px}.badge-label{font-size:14px;opacity:.9}.badge-value{font-size:15px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge-code{background:#ffffff4d;border-radius:12px;font-family:Courier New,monospace;font-size:16px;font-weight:700;letter-spacing:1px;padding:4px 12px}.header-right{align-items:center;display:flex;flex-wrap:wrap;gap:12px}button{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .3s;white-space:nowrap}.btn-primary{background:#1890ff;color:#fff}.btn-primary:hover{background:#096dd9;box-shadow:0 4px 12px #1890ff66;transform:translateY(-2px)}.btn-success{background:#52c41a;color:#fff}.btn-success:hover{background:#389e0d;transform:translateY(-2px)}.btn-warning{background:#faad14;color:#fff}.btn-warning:hover:not(:disabled){background:#d48806}.btn-warning:disabled{background:#d9d9d9;cursor:not-allowed;opacity:.6}.btn-secondary{background:#6c63ff;color:#fff}.btn-secondary:hover{background:#5148d3}.btn-danger,.btn-exit{background:#ff4d4f;color:#fff}.btn-danger:hover,.btn-exit:hover{background:#cf1322}.btn-info{background:#13c2c2;color:#fff}.btn-info:hover{background:#08979c}.kg-main{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;flex:1 1;min-height:0;overflow-y:auto;padding:20px}.idle-state{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center}.idle-icon{animation:float 3s ease-in-out infinite;font-size:120px;margin-bottom:30px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.idle-state h3{color:#262626;font-size:24px;margin-bottom:10px}.idle-state p{color:#8c8c8c;font-size:16px;margin-bottom:40px}.student-idle{align-items:center;color:#fff;display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center}.student-idle h3{color:#fff;font-size:24px;margin-bottom:10px}.student-idle p{color:#ffffffe6;font-size:16px}.idle-illustration{animation:pulse 2s infinite;font-size:120px;margin-bottom:30px}@keyframes pulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.active-session{grid-gap:20px;display:grid;gap:20px;grid-template-columns:380px 1fr;height:100%}.left-panel{display:flex;flex-direction:column;gap:15px;max-height:calc(100vh - 200px);overflow-y:auto}.keywords-card,.resources-card,.stats-card,.votes-card{background:#fafafa;border-radius:10px;box-shadow:0 2px 8px #0000000d;padding:15px}.keywords-card h3,.resources-card h3,.stats-card h3,.votes-card h3{color:#262626;font-size:16px;font-weight:600;margin:0 0 15px}.stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.stat-item{background:#fff;border-radius:8px;padding:15px;text-align:center}.stat-value{color:#1890ff;font-size:32px}.stat-label{color:#8c8c8c}.keywords-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.keyword-item{align-items:center;background:#fff;border-left:3px solid #1890ff;border-radius:6px;display:flex;justify-content:space-between;padding:10px 12px;transition:all .2s}.keyword-item:hover{box-shadow:0 2px 8px #1890ff26;transform:translateX(4px)}.keyword-text{color:#262626;flex:1 1;font-weight:500}.keyword-badge{background:#1890ff;border-radius:12px;color:#fff;font-size:11px;font-weight:600;padding:4px 10px}.votes-list{display:flex;flex-direction:column;gap:10px}.vote-item{align-items:center;background:#fff;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .2s}.vote-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.vote-item.winner{background:linear-gradient(135deg,gold,#fa0);color:#fff}.vote-rank{align-items:center;background:#1890ff;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:32px;justify-content:center;width:32px}.vote-item.winner .vote-rank{background:#fff;color:#faad14}.vote-content{align-items:center;display:flex;flex:1 1;justify-content:space-between}.vote-keyword{font-size:15px;font-weight:600}.vote-count{color:#1890ff;font-weight:600}.vote-item.winner .vote-count,.vote-item.winner .vote-keyword{color:#fff}.empty-votes{background:#fff;border:2px dashed #e6e6e6;border-radius:8px;color:#8c8c8c;padding:40px;text-align:center}.resources-card h3{color:#52c41a}.resource-preview details{background:#fff;border:1px solid #f0f0f0;border-radius:6px;margin:10px 0;overflow:hidden}.resource-preview summary{background:#fafafa;cursor:pointer;font-weight:600;padding:12px 15px;transition:all .2s}.resource-preview summary:hover{background:#e6f7ff;color:#1890ff}.resource-content{background:#fff;padding:15px}.resource-content pre{background:#f5f5f5;border-radius:6px;font-size:13px;line-height:1.6;padding:12px;white-space:pre-wrap}.exercises-preview{background:#fff;display:flex;flex-direction:column;gap:8px;padding:15px}.exercise-mini{align-items:center;background:#fafafa;border-radius:6px;cursor:pointer;display:flex;font-size:13px;gap:10px;padding:10px 12px;transition:all .2s}.exercise-mini:hover{background:#e6f7ff;transform:translateX(4px)}.level-tag{border-radius:4px;flex-shrink:0;font-size:12px;font-weight:600;padding:4px 10px}.level-tag.基础{background:#e6fffb;color:#13c2c2}.level-tag.进阶{background:#fff7e6;color:#fa8c16}.level-tag.挑战{background:#fff1f0;color:#f5222d}.right-panel{align-items:center;flex-direction:column;justify-content:center;min-height:500px;padding:20px;position:relative}.graph-wrapper,.right-panel{background:#fafafa;border-radius:10px;display:flex}.graph-wrapper{flex:1 1;flex-direction:column;padding:15px;width:100%}.graph-title{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.graph-title h3{color:#262626;font-size:18px;font-weight:600;margin:0}.phase-indicator{border-radius:20px;font-size:14px;font-weight:600;padding:6px 16px}.phase-indicator.phase-collecting{background:#e6f7ff;color:#1890ff}.phase-indicator.phase-voting{background:#fff7e6;color:#fa8c16}.phase-indicator.phase-analyzing{background:#f0f5ff;color:#597ef7}.phase-indicator.phase-completed{background:#f6ffed;color:#52c41a}.graph-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:5px solid #f0f0f0;border-radius:50%;border-top-color:#1890ff;height:60px;margin-bottom:24px;width:60px}.graph-loading p{color:#595959;font-size:15px;line-height:1.6;margin:0}.generating-overlay{align-items:center;background:#fffffff2;border-radius:12px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.generating-content{text-align:center}.generating-spinner{animation:spin 1s linear infinite;border:6px solid #f0f0f0;border-radius:50%;border-top-color:#52c41a;height:80px;margin:0 auto 20px;width:80px}.generating-content h3{color:#262626;margin-bottom:10px}.generating-content p{color:#8c8c8c}.submit-row{align-items:center;display:flex;gap:10px}.keyword-input{border:2px solid #e6e6e6;border-radius:8px;font-size:14px;min-width:300px;padding:10px 16px;transition:all .2s}.keyword-input:focus{border-color:#1890ff;box-shadow:0 0 0 3px #1890ff1a;outline:none}.info-chip{background:#fff;border-radius:20px;box-shadow:0 2px 8px #00000014;color:#595959;font-size:14px;font-weight:600;padding:10px 20px}.voting-phase{display:flex;flex-direction:column;gap:20px}.voting-instruction{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:20px;text-align:center}.voting-instruction h4{color:#fa8c16;font-size:20px;margin:0 0 10px}.voting-instruction p{color:#8c8c8c;margin:0}.voting-list{display:flex;flex-direction:column;gap:12px}.vote-option{background:#fff;border:2px solid #f0f0f0;border-radius:10px;cursor:pointer;overflow:hidden;padding:0;transition:all .3s;width:100%}.vote-option:hover{border-color:#1890ff;box-shadow:0 4px 12px #1890ff33;transform:translateY(-2px)}.vote-option.voted{border-color:#52c41a}.vote-option-content{align-items:center;display:flex;justify-content:space-between;padding:15px}.vote-option-text{color:#262626;font-size:16px;font-weight:600}.vote-option-count{background:#e6f7ff;border-radius:12px;color:#1890ff;font-size:14px;font-weight:600;padding:4px 12px}.vote-option-bar{background:#f0f0f0;height:4px;position:relative}.vote-option-fill{background:linear-gradient(90deg,#1890ff,#52c41a);height:100%;transition:width .5s ease-out}.voted-indicator{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;color:#52c41a;font-weight:600;padding:15px;text-align:center}.completed-phase{display:flex;flex-direction:column;gap:20px}.resources-header{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:25px;text-align:center}.resources-header h3{color:#52c41a;font-size:24px;margin:0 0 10px}.resources-header p{color:#8c8c8c;margin:0}.resource-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:hidden}.section-header{background:linear-gradient(135deg,#1890ff,#096dd9);padding:15px 20px}.section-header h4{color:#fff;font-size:18px;margin:0}.section-content{padding:20px}.exercises-container{display:flex;flex-direction:column;gap:15px;padding:20px}.exercise-card{border:2px solid #f0f0f0;border-radius:10px;transition:all .3s}.exercise-card:hover{border-color:#1890ff;box-shadow:0 4px 12px #1890ff26}.exercise-card[open]{border-color:#1890ff}.exercise-summary{align-items:center;background:#fafafa;cursor:pointer;display:flex;font-weight:600;gap:12px;padding:15px;transition:background .3s}.exercise-summary:hover{background:#f0f0f0}.exercise-level{border-radius:6px;flex-shrink:0;font-size:13px;font-weight:600;padding:6px 14px}.exercise-title{flex:1 1}.exercise-body{padding:20px}.exercise-question{color:#262626;font-size:16px;line-height:1.8;margin-bottom:15px}.exercise-answer-toggle{border:1px solid #f0f0f0;border-radius:6px;margin-top:15px;overflow:hidden}.exercise-answer-toggle summary{background:#f5f5f5;color:#1890ff;cursor:pointer;font-weight:600;padding:10px 15px;transition:background .3s}.exercise-answer-toggle summary:hover{background:#e6f7ff}.exercise-answer{background:#fafafa;border-radius:6px;color:#262626;font-size:14px;line-height:1.6;margin:15px;padding:15px;white-space:pre-wrap}.modal-overlay{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-height:85vh;max-width:900px;overflow-y:auto;padding:30px;width:90%}.modal-content h3{color:#262626;font-size:24px;margin:0 0 20px}.session-table{border-collapse:collapse;margin-top:15px;width:100%}.session-table td,.session-table th{border-bottom:1px solid #f0f0f0;padding:12px;text-align:left}.session-table th{background:#fafafa;color:#595959;font-weight:600}.session-table tr:hover{background:#f5f5f5}.btn-mini{background:#52c41a;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;padding:6px 12px;transition:all .2s}.btn-mini:hover{background:#389e0d;transform:scale(1.05)}.btn-close{background:#8c8c8c;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:20px;padding:10px 20px}.btn-close:hover{background:#595959}.history-session{display:flex;gap:20px;height:calc(100vh - 180px)}.history-session .left-panel{flex:1 1;max-height:none}.history-session .right-panel{background:#fff;border:1px solid #f0f0f0;border-radius:12px;flex:1.2 1;overflow-y:auto;padding:20px}.history-session .graph-wrapper{display:flex;flex-direction:column;height:100%}.markdown-body{background:#fafafa;border:1px solid #e6e6e6;border-radius:8px;color:#262626;font-size:15px;line-height:1.7;padding:16px}.markdown-body h1,.markdown-body h2,.markdown-body h3{border-left:4px solid #52c41a;color:#262626;margin-top:1em;padding-left:12px}.markdown-body code{background:#f1f1f1;border-radius:4px;color:#c7254e;font-family:Consolas,monospace;font-size:14px;padding:2px 6px}.markdown-body pre{background:#282c34;border-radius:6px;color:#f8f8f2;overflow-x:auto;padding:12px}.markdown-body pre code{background:#0000;color:inherit;padding:0}@media (max-width:1200px){.active-session{grid-template-columns:1fr}.left-panel{max-height:none;order:1}.right-panel{min-height:400px;order:2}}@media (max-width:768px){.collaborative-kg-container,.student-kg-container{padding:10px}.kg-header{padding:15px}.header-left h2{font-size:22px}.header-right{width:100%}.submit-row{flex-direction:column;width:100%}.keyword-input{min-width:auto;width:100%}.notification{left:10px;min-width:auto;right:10px}.active-session{grid-template-columns:1fr}.modal-content{padding:20px;width:95%}button{width:100%}}.completed-panel{background:#f5f7fa;height:100%;overflow-y:auto;width:100%}.resources-display{margin:0 auto;max-width:900px;padding:30px 20px}.resources-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 20px #667eea4d;color:#fff;display:flex;gap:20px;margin-bottom:30px;padding:30px}.header-icon{font-size:48px;line-height:1}.header-text h2{font-size:28px;font-weight:600;margin:0 0 8px}.header-text p{font-size:14px;margin:0;opacity:.9}.section-title{align-items:center;display:flex;gap:12px;margin-bottom:20px}.title-icon{font-size:24px}.section-title h3{color:#2c3e50;font-size:22px;font-weight:600;margin:0}.exercise-count{background:#667eea;border-radius:12px;color:#fff;font-size:14px;font-weight:500;margin-left:auto;padding:4px 12px}.summary-section{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;margin-bottom:30px;padding:30px}.exercises-list{gap:20px}.exercise-item{background:#fafbfc;border:2px solid #e2e8f0;border-radius:12px;padding:20px;transition:all .3s ease}.exercise-item:hover{border-color:#667eea;box-shadow:0 4px 16px #667eea26}.exercise-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.exercise-index{color:#2c3e50;font-size:16px;font-weight:600}.difficulty-tag{border-radius:20px;font-size:13px;font-weight:600;padding:6px 14px}.difficulty-tag.easy{background:#d4edda;color:#155724}.difficulty-tag.medium{background:#fff3cd;color:#856404}.difficulty-tag.hard{background:#f8d7da;color:#721c24}.exercise-question{margin-bottom:12px}.exercise-question strong{color:#495057;display:block;font-size:15px;margin-bottom:8px}.exercise-question p{color:#212529;line-height:1.7}.exercise-answer,.exercise-explanation{margin-top:12px}.exercise-answer summary,.exercise-explanation summary{background:#e9ecef;border-radius:6px;padding:10px 14px}.exercise-answer summary:hover,.exercise-explanation summary:hover{background:#dee2e6}.exercise-answer[open] summary,.exercise-explanation[open] summary{margin-bottom:12px}.answer-content,.explanation-content{background:#fff;border-left:4px solid #17a2b8;border-radius:6px;padding:14px}.explanation-content{border-left-color:#28a745}.answer-content strong,.explanation-content strong{color:#495057;display:block;font-size:14px;margin-bottom:8px}.answer-content p,.explanation-content p{color:#212529;line-height:1.7;margin:0}.completed-panel::-webkit-scrollbar{width:8px}.completed-panel::-webkit-scrollbar-track{background:#f1f1f1}.completed-panel::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.completed-panel::-webkit-scrollbar-thumb:hover{background:#a0aec0}.markdown-content{color:#333;font-size:15px;line-height:1.8}.markdown-content h1,.markdown-content h2{font-weight:600}.markdown-content h3{color:#4a5568;font-size:18px;font-weight:600;margin:16px 0 10px}.markdown-content p{color:#2d3748;line-height:1.8;margin:12px 0}.markdown-content li{color:#2d3748;margin:6px 0}.markdown-content ul li::marker{color:#667eea}.markdown-content ol li::marker{color:#667eea;font-weight:600}.markdown-content .inline-code{background:linear-gradient(180deg,#fef3f4,#fff5f6);border:1px solid #fce4e9;border-radius:4px;color:#d63384;line-height:inherit}.markdown-content .code-block{box-shadow:0 4px 12px #00000026;overflow:hidden}.code-header{align-items:center;background:#0f172a;border-bottom:1px solid #334155;display:flex;gap:8px;padding:8px 16px}.code-language{color:#94a3b8;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.markdown-content .code-block code{background:none;display:block;overflow-x:auto;padding:16px}.markdown-content .code-block code::-webkit-scrollbar{height:8px}.markdown-content .code-block code::-webkit-scrollbar-track{background:#0f172a}.markdown-content .code-block code::-webkit-scrollbar-thumb{background:#475569;border-radius:4px}.markdown-content .code-block code::-webkit-scrollbar-thumb:hover{background:#64748b}.markdown-content blockquote{background:#f8fafc;border-left:4px solid #667eea;color:#475569;font-style:italic;margin:16px 0;padding:12px 16px}.markdown-content strong{color:#1e293b;font-weight:600}.markdown-content em{color:#475569}.markdown-content table{border-collapse:collapse;margin:20px 0;width:100%}.markdown-content table td,.markdown-content table th{border:1px solid #e2e8f0;padding:10px 12px;text-align:left}.markdown-content table th{background:#f8fafc;color:#1e293b;font-weight:600}.markdown-content table tr:hover{background:#f8fafc}.markdown-content hr{border:none;border-top:2px solid #e2e8f0;margin:24px 0}.markdown-content a{border-bottom:1px solid #0000;color:#667eea;text-decoration:none;transition:border-color .2s}.markdown-content a:hover{border-bottom-color:#667eea}.markdown-content .inline-code{background:#f1f3f5;border:1px solid #e9ecef;border-radius:3px;color:#e83e8c;display:inline;font-family:Consolas,Monaco,Courier New,monospace;font-size:.92em;font-weight:500;padding:2px 6px}.markdown-content .code-block{background:#1e293b;border-radius:8px;margin:20px 0;overflow-x:auto;padding:16px}.markdown-content .code-block code{color:#e2e8f0;font-family:Consolas,Monaco,Courier New,monospace;font-size:14px;line-height:1.6}.markdown-content h1{border-bottom:2px solid #667eea;color:#2c3e50;font-size:24px;margin:24px 0 16px;padding-bottom:10px}.markdown-content h2{border-left:4px solid #667eea;color:#34495e;font-size:20px;margin:20px 0 12px;padding-left:12px}.markdown-content ol,.markdown-content ul{margin:12px 0;padding-left:28px}.markdown-content li{line-height:1.7;margin:8px 0}.markdown-content li strong{color:#2c3e50}.exercises-section{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;padding:30px}.exercises-list{display:flex;flex-direction:column;gap:24px}.exercise-card{background:#fafbfc;border:2px solid #e2e8f0;border-radius:12px;overflow:hidden;padding:0;transition:all .3s ease}.exercise-card:hover{border-color:#667eea;box-shadow:0 4px 16px #667eea26}.exercise-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:16px 20px}.exercise-number{align-items:center;display:flex;gap:12px}.number-badge{color:#fff;font-size:16px;font-weight:600}.difficulty-badge{background:#ffffff40;border-radius:12px;color:#fff;font-size:13px;font-weight:600;padding:4px 12px}.difficulty-badge.easy{background:#4caf504d}.difficulty-badge.medium{background:#ff98004d}.difficulty-badge.hard{background:#f443364d}.exercise-question{background:#fff;padding:24px}.question-label{align-items:center;display:flex;gap:8px;margin-bottom:12px}.label-icon{font-size:18px}.question-label strong{color:#2c3e50;font-size:15px}.exercise-question p{color:#2d3748;font-size:15px;line-height:1.8;margin:0;padding-left:26px}.exercise-answer,.exercise-explanation{border-top:1px solid #e2e8f0}.exercise-answer summary,.exercise-explanation summary{align-items:center;background:#f8f9fa;color:#495057;cursor:pointer;display:flex;font-weight:500;gap:8px;list-style:none;padding:14px 24px;transition:all .2s;-webkit-user-select:none;user-select:none}.exercise-answer summary::-webkit-details-marker,.exercise-explanation summary::-webkit-details-marker{display:none}.summary-icon{font-size:16px}.exercise-answer summary:hover,.exercise-explanation summary:hover{background:#e9ecef}.exercise-answer[open] summary{background:#d1ecf1;border-bottom:2px solid #bee5eb;color:#0c5460}.exercise-explanation[open] summary{background:#d4edda;border-bottom:2px solid #c3e6cb;color:#155724}.answer-content{background:#f8f9fa;padding:20px 24px}.content-wrapper{background:#fff;border-left:4px solid #17a2b8;border-radius:8px;padding:16px}.answer-code{background:#2d3748;border-radius:6px;color:#e2e8f0;font-family:Consolas,Monaco,Courier New,monospace;font-size:14px;line-height:1.6;margin:0;overflow-x:auto;padding:16px}.answer-code code{background:none;color:inherit}.explanation-content{background:#f8f9fa;padding:20px 24px}.explanation-content .content-wrapper{border-left-color:#28a745}.explanation-content p{color:#2d3748;font-size:15px;line-height:1.8;margin:0}.answer-code::-webkit-scrollbar{height:8px}.answer-code::-webkit-scrollbar-track{background:#1a202c}.answer-code::-webkit-scrollbar-thumb{background:#4a5568;border-radius:4px}.answer-code::-webkit-scrollbar-thumb:hover{background:#718096}@media (max-width:768px){.exercise-card{border-radius:8px}.exercise-header{padding:12px 16px}.exercise-question{padding:16px}.exercise-question p{padding-left:0}.exercise-answer summary,.exercise-explanation summary{font-size:14px;padding:12px 16px}.answer-content,.explanation-content{padding:16px}}.flowchart-editor-container{padding:0}.flowchart-header{border-bottom:2px solid #e2e8f0;margin-bottom:15px;margin-top:0;padding-bottom:15px;position:relative;z-index:1}.flowchart-header h2{align-items:center;color:#1e293b;display:flex;font-size:24px;gap:8px;margin:0}.flowchart-toolbar{max-width:100%;overflow-x:auto;padding:4px 0}.flowchart-toolbar button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .3s ease}.btn-redo,.btn-undo{background:#e2e8f0;color:#475569}.btn-redo:hover:not(:disabled),.btn-undo:hover:not(:disabled){background:#cbd5e1;transform:translateY(-2px)}.btn-redo:disabled,.btn-undo:disabled{cursor:not-allowed;opacity:.4}.btn-save{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.btn-save:hover:not(:disabled){box-shadow:0 4px 12px #6366f14d;transform:translateY(-2px)}.btn-save:disabled{cursor:not-allowed;opacity:.6}.btn-submit{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.btn-submit:hover:not(:disabled){box-shadow:0 4px 12px #f59e0b4d;transform:translateY(-2px)}.btn-submit:disabled{cursor:not-allowed;opacity:.6}.btn-export{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.btn-export:hover{box-shadow:0 4px 12px #22c55e4d;transform:translateY(-2px)}.btn-play{background:linear-gradient(135deg,#0ea5e9,#2563eb);color:#fff}.btn-play:hover:not(:disabled){box-shadow:0 4px 12px #2563eb4d;transform:translateY(-2px)}.btn-play:disabled{cursor:not-allowed;opacity:.5}.btn-stop{background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff}.btn-stop:disabled{cursor:not-allowed;opacity:.5}.btn-clear{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-clear:hover{box-shadow:0 4px 12px #ef44444d;transform:translateY(-2px)}.flowchart-info{align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:15px;width:100%}.flowchart-desc-input,.flowchart-title-input{border:2px solid #e2e8f0;font-size:14px;min-width:250px;padding:10px 14px;transition:all .3s ease}.flowchart-desc-input{border:2px solid #e2e8f0;border-radius:8px;flex:3 1;font-size:14px;min-width:0;padding:12px 16px;transition:all .3s ease}.flowchart-desc-input:focus,.flowchart-title-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.flowchart-tips{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:12px;padding:8px 16px}.flowchart-tips p{color:#0c4a6e;font-size:13px;font-weight:500;line-height:1.5;margin:0}.flowchart-workspace{margin:0;padding:0}.flowchart-stencil .x6-widget-stencil{background:#fff!important;border:none!important;height:100%!important;width:100%!important}.flowchart-stencil .x6-widget-stencil-title{border-radius:0!important;color:#fff!important;font-size:15px!important;font-weight:600!important;margin:0!important;text-align:center!important}.flowchart-stencil .x6-widget-stencil-group-title{background:#f1f5f9!important;border-bottom:1px solid #e2e8f0!important;color:#475569!important;font-size:14px!important;font-weight:600!important;margin:0!important;padding:12px!important}.flowchart-stencil .x6-widget-stencil-group{margin-bottom:10px!important}.flowchart-canvas>div{height:100%!important;width:100%!important}.flowchart-list{background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;margin-top:20px;padding:20px}.flowchart-list h3{color:#1e293b;font-size:18px;margin:0 0 15px}.no-charts{color:#94a3b8;padding:40px 0;text-align:center}.charts-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.chart-card{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;overflow:hidden;transition:all .3s ease}.chart-card:hover{border-color:#6366f1;box-shadow:0 8px 20px #6366f133;transform:translateY(-4px)}.chart-thumbnail{background:#f1f5f9;border-bottom:2px solid #e2e8f0;height:150px;object-fit:cover;width:100%}.chart-card-content{padding:15px}.chart-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.chart-card-header h4{color:#1e293b;font-size:16px;font-weight:600;margin:0}.chart-score{background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:12px;box-shadow:0 2px 4px #fbbf244d;color:#fff;font-size:12px;font-weight:600;padding:3px 10px}.chart-desc{color:#64748b;font-size:13px;margin:8px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart-meta{align-items:center;border-top:1px solid #e2e8f0;color:#94a3b8;display:flex;font-size:12px;justify-content:space-between;margin-top:10px;padding-top:10px}.has-comment{color:#22c55e;font-weight:500}@media (max-width:1200px){.charts-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media (max-width:768px){.flowchart-workspace{flex-direction:column;height:auto}.flowchart-stencil{height:200px;width:100%}.flowchart-canvas{height:400px}.flowchart-toolbar{flex-wrap:wrap}.charts-grid{grid-template-columns:1fr}}.flowchart-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:10px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.flowchart-canvas .x6-graph-scroller,.x6-graph-scroller>div{overflow:hidden!important}.x6-graph-scroller>div{height:100%!important;width:100%!important}.flowchart-stencil .x6-widget-stencil-content{background:#fff!important;display:flex!important;flex:1 1!important;flex-direction:column!important;gap:15px!important;max-height:none!important;overflow-y:visible!important;padding:0 10px!important}.flowchart-workspace{align-items:stretch;gap:20px;height:calc(100vh - 200px);justify-content:space-between;margin:0 20px}.flowchart-stencil{box-shadow:0 2px 8px #0000000d;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;width:240px}.flowchart-canvas,.flowchart-stencil{border:2px solid #e2e8f0;border-radius:8px}.flowchart-canvas{background:#f8fafc;height:100%}.x6-node-selected ellipse,.x6-node-selected polygon,.x6-node-selected rect{stroke:#facc15!important;stroke-width:2px!important;stroke-dasharray:6 3!important;fill-opacity:1!important}@keyframes dashMove{to{stroke-dashoffset:-9}}.x6-node-selected ellipse,.x6-node-selected polygon,.x6-node-selected rect{animation:dashMove .6s linear infinite}.x6-node-selected .x6-shape{filter:drop-shadow(0 0 4px rgba(250,204,21,.5))}.flowchart-code-panel{background:#fff;border-left:1px solid #e2e8f0;box-sizing:border-box;display:flex;flex-direction:column;gap:10px;height:100%;padding:12px;width:340px}.flowchart-code-header{align-items:center;color:#0f172a;display:flex;font-size:15px;font-weight:600;justify-content:space-between}.flowchart-code-output{background:#0f172a;border:1px solid #cbd5e1;border-radius:10px;box-shadow:inset 0 2px 6px #0f172a59;color:#e2e8f0;flex:1 1;font-family:Fira Code,Consolas,Courier New,monospace;font-size:13px;line-height:1.5;padding:12px;resize:none;width:100%}.btn-copy-code{background:linear-gradient(135deg,#0ea5e9,#2563eb);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;padding:6px 14px;transition:transform .2s ease,box-shadow .2s ease}.btn-copy-code:hover{box-shadow:0 4px 12px #0ea5e959;transform:translateY(-1px)}.btn-copy-code:active{box-shadow:none;transform:translateY(0)}.decision-overlay{align-items:center;background:#0f172a59;display:flex;inset:0;justify-content:center;padding:16px;position:absolute;z-index:20}.decision-card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0f172a40;max-width:360px;min-width:260px;padding:16px}.decision-title{color:#0f172a;font-size:16px;font-weight:700;margin-bottom:12px}.decision-options{display:flex;flex-direction:column;gap:8px}.decision-btn{background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;cursor:pointer;padding:10px 12px;text-align:left;transition:all .2s ease}.decision-btn:hover{background:#e0f2fe;border-color:#38bdf8}.decision-cancel{background:linear-gradient(135deg,#ef4444,#b91c1c);border:none;border-radius:8px;color:#fff;cursor:pointer;margin-top:12px;padding:10px 12px;width:100%}.flowchart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.flowchart-toolbar{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.flowchart-info{display:flex;gap:8px;margin-top:8px}.flowchart-desc-input,.flowchart-title-input{border:1px solid #cbd5e1;border-radius:6px;flex:1 1;padding:6px 10px}.flowchart-tips{color:#475569;font-size:13px;margin-top:6px}.flowchart-workspace{background:#f8fafc;display:flex;flex:1 1;overflow:hidden;position:relative}.flowchart-stencil{background:#fff;border-right:1px solid #e2e8f0;height:100%;overflow-y:auto;position:relative;width:220px}.flowchart-canvas{flex:1 1;overflow:hidden;position:relative}.flowchart-canvas-wrapper{display:flex;flex:1 1;position:relative}.flowchart-editor-container{background:#fff;display:flex;flex-direction:column;height:100vh;overflow:hidden}.flowchart-header-section{background:#f9fafb;border-bottom:2px solid #e2e8f0;flex:0 0 auto;padding:12px 16px;position:relative;z-index:10}.flowchart-stencil{min-height:400px}.flowchart-anim-status{align-items:center;background:#0f172aeb;border:1px solid #38bdf859;border-radius:12px;box-shadow:0 8px 20px #0f172a59;color:#e0f2fe;display:flex;gap:10px;padding:10px 14px;position:absolute;right:12px;top:12px;z-index:10}.flowchart-anim-marker{background:radial-gradient(circle at 30% 30%,#e0f2fe,#0ea5e9 65%);border-radius:999px;box-shadow:0 0 0 0 #0ea5e973;pointer-events:none;position:absolute;transform:translate(-50%,-50%);transition:left .9s linear,top .9s linear;z-index:9}.flowchart-anim-dot,.flowchart-anim-marker{animation:fc-pulse 1.2s ease-in-out infinite;height:12px;width:12px}.flowchart-anim-dot{background:#38bdf8;border-radius:50%;box-shadow:0 0 0 0 #38bdf866}.flowchart-anim-text{display:flex;flex-direction:column;line-height:1.2}.flowchart-anim-label{font-size:12px;opacity:.8}.flowchart-anim-value{font-size:14px;font-weight:700}.x6-node.fc-anim-node .x6-shape{animation:fc-glow 1.2s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(56,189,248,.7))}.x6-edge.fc-anim-edge path{stroke:#0ea5e9!important;stroke-width:3!important;stroke-dasharray:10 6;stroke-linecap:round;animation:fc-dash 1s linear infinite;filter:drop-shadow(0 0 6px rgba(14,165,233,.55))}@keyframes fc-pulse{0%{box-shadow:0 0 0 0 #38bdf873;transform:scale(1)}70%{box-shadow:0 0 0 10px #38bdf800;transform:scale(1.08)}to{box-shadow:0 0 0 0 #38bdf800;transform:scale(1)}}@keyframes fc-glow{0%{filter:drop-shadow(0 0 4px rgba(56,189,248,.5))}50%{filter:drop-shadow(0 0 12px rgba(56,189,248,.85))}to{filter:drop-shadow(0 0 4px rgba(56,189,248,.5))}}@keyframes fc-dash{to{stroke-dashoffset:-24}}.flowchart-gallery-container{background:#f8fafc;min-height:calc(100vh - 60px)}.gallery-header{border-bottom:2px solid #e2e8f0;padding-bottom:15px}.gallery-header h2{margin:0}.class-select{border:2px solid #e2e8f0;font-weight:500;padding:10px 16px;transition:all .3s ease}.class-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.gallery-stats{grid-gap:15px;gap:15px;margin-bottom:25px}.stat-card{border:2px solid #e2e8f0;gap:15px;transition:all .3s ease}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-icon{align-items:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;display:flex;height:50px;justify-content:center;width:50px}.stat-value{line-height:1;margin-bottom:5px}.stat-label{font-size:13px}.gallery-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.no-charts-message{color:#94a3b8;font-size:16px;grid-column:1/-1;padding:60px 20px;text-align:center}.gallery-card{border:2px solid #e2e8f0;transition:all .3s ease}.gallery-card:hover{border-color:#6366f1;box-shadow:0 8px 20px #6366f126}.gallery-thumbnail{background:#f1f5f9;border-bottom:2px solid #e2e8f0;height:180px;object-fit:contain}.gallery-card-header{align-items:center;margin-bottom:10px}.gallery-card-header h4{font-size:16px}.scored-badge{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 2px 4px #22c55e4d;font-size:12px}.unscored-badge{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 4px #f59e0b4d;font-size:12px}.gallery-card-author{border-bottom:1px solid #e2e8f0;justify-content:space-between;margin-bottom:10px;padding-bottom:10px}.author-name{color:#475569;font-size:14px;font-weight:500}.author-class{background:#f1f5f9;border-radius:4px;color:#94a3b8}.gallery-card-desc{font-size:13px;margin:10px 0}.btn-view{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:6px;gap:4px;padding:6px 12px;transition:all .3s ease}.btn-view:hover{box-shadow:0 4px 12px #6366f14d;transform:translateY(-2px)}.viewer-modal{animation:fadeIn .3s ease;background:#0009}.viewer-content{animation:slideUp .3s ease;display:flex;flex-direction:column;max-width:1400px}.viewer-header{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-bottom:2px solid #e2e8f0;border-radius:16px 16px 0 0;padding:20px 25px}.viewer-title h3{color:#fff;margin:0 0 5px}.viewer-author-info{color:#ffffffe6;font-size:13px;gap:15px}.close-viewer-btn{align-items:center;background:#fff3;border-radius:50%;color:#fff;display:flex;height:40px;justify-content:center;transition:all .3s ease;width:40px}.close-viewer-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.viewer-body{flex:1 1;overflow:hidden}.viewer-canvas-container{overflow:auto;padding:20px}.viewer-canvas{background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px}.viewer-chart-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:13px;margin-top:12px;padding:10px 12px}.scoring-panel{border-left:2px solid #e2e8f0;display:flex;flex-direction:column;gap:20px;padding:25px;width:350px}.scoring-panel h4{margin:0}.comment-input-group,.score-input-group{display:flex;flex-direction:column;gap:8px}.comment-input-group label,.score-input-group label{align-items:center;display:flex;font-weight:600;gap:6px}.score-input{border:2px solid #e2e8f0;font-size:16px;font-weight:600;padding:12px 16px;transition:all .3s ease}.score-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.comment-textarea{border:2px solid #e2e8f0;min-height:100px;padding:12px 16px;transition:all .3s ease}.comment-textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.previous-score-info{background:#e0f2fe;border:2px solid #bae6fd;color:#0c4a6e}.previous-score-info p{margin:5px 0}.score-date{color:#0369a1;font-size:12px}.submit-score-btn{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 12px #22c55e4d;font-size:16px;margin-top:auto;padding:14px 24px;transition:all .3s ease}.submit-score-btn:hover:not(:disabled){box-shadow:0 6px 20px #22c55e66;transform:translateY(-2px)}.submit-score-btn:disabled{opacity:.6;transform:none}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1200px){.viewer-body{flex-direction:column}.scoring-panel{border-left:none;border-top:2px solid #e2e8f0;width:100%}}@media (max-width:768px){.gallery-stats{grid-template-columns:repeat(2,1fr)}.gallery-grid{grid-template-columns:1fr}.viewer-canvas{height:400px}}.flowchart-notification-card{align-items:flex-start;animation:slideInRight .3s ease-out;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 8px 24px #00000026;color:#fff}.flowchart-notification-card .notification-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.flowchart-notification-card .notification-content{flex:1 1}.flowchart-notification-card .notification-title{font-size:14px;font-weight:600;margin-bottom:6px}.flowchart-notification-card .notification-body{color:#fffffff2;font-size:13px;line-height:1.5}.flowchart-notification-card .notification-desc{color:#fffc;font-size:12px;font-style:italic;margin-top:6px}.flowchart-notification-card .notification-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:28px;justify-content:center;transition:background .2s;width:28px}.flowchart-notification-card .notification-close:hover{background:#ffffff4d}.flowchart-gallery-container{margin:0 auto;max-width:1400px;padding:20px}.gallery-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.gallery-header h2{color:#1e293b;font-size:24px;font-weight:600}.gallery-controls{align-items:center;display:flex;gap:12px}.class-select{border:1px solid #e2e8f0;border-radius:8px;min-width:150px}.btn-refresh,.class-select{cursor:pointer;font-size:14px;padding:8px 16px}.btn-refresh{background:#3b82f6;border:none;border-radius:8px;color:#fff;transition:all .2s}.btn-refresh:hover{background:#2563eb;transform:translateY(-1px)}.btn-refresh:disabled{cursor:not-allowed;opacity:.5}.gallery-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:16px;padding:20px}.stat-icon{font-size:32px}.stat-info{flex:1 1}.stat-value{color:#1e293b;font-size:28px;font-weight:700}.stat-label{color:#64748b;font-size:14px;margin-top:4px}.gallery-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:40px}.gallery-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;overflow:hidden;transition:all .3s}.gallery-card:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-4px)}.gallery-thumbnail{background:#f8fafc;height:200px;object-fit:cover;width:100%}.gallery-thumbnail-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:48px;height:200px;justify-content:center;width:100%}.gallery-card-content{padding:16px}.gallery-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.gallery-card-header h4{color:#1e293b;flex:1 1;font-size:18px;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scored-badge{background:#10b981}.scored-badge,.unscored-badge{border-radius:12px;color:#fff;font-size:13px;font-weight:600;margin-left:8px;padding:4px 12px;white-space:nowrap}.unscored-badge{background:#f59e0b}.gallery-card-author{align-items:center;color:#64748b;display:flex;font-size:14px;gap:12px;margin-bottom:12px}.author-name{align-items:center;display:flex;gap:4px}.author-class{background:#eff6ff;border-radius:6px;color:#3b82f6;font-size:12px;padding:2px 8px}.gallery-card-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#64748b;display:-webkit-box;font-size:14px;margin:8px 0;overflow:hidden;text-overflow:ellipsis}.gallery-card-footer{align-items:center;border-top:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-top:12px;padding-top:12px}.card-date{color:#94a3b8;font-size:12px}.btn-view{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.btn-view:hover{background:#2563eb;transform:translateY(-1px)}.error-message,.loading-message,.no-charts-message{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:60px 20px;text-align:center}.error-message p,.loading-message p,.no-charts-message p{color:#64748b;font-size:16px;margin-bottom:16px}.btn-retry{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:10px 24px;transition:all .2s}.btn-retry:hover{background:#2563eb}.flowchart-notifications{z-index:1000}.flowchart-notification-card{animation:slideIn .3s ease;background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000026;display:flex;gap:12px;margin-bottom:12px;padding:16px}@keyframes slideIn{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}.notification-icon{color:#3b82f6}.notification-body{color:#64748b}.notification-close{background:none}.viewer-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.viewer-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:1200px;overflow:auto;width:100%}.viewer-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 24px}.viewer-title h3{color:#1e293b;font-size:20px;font-weight:600;margin:0 0 8px}.viewer-author-info{color:#64748b;display:flex;font-size:14px;gap:16px}.close-viewer-btn{background:none;border:none;color:#64748b;cursor:pointer;padding:8px;transition:all .2s}.close-viewer-btn:hover{color:#1e293b;transform:scale(1.1)}.viewer-body{display:flex;gap:24px;padding:24px}.viewer-canvas-container{flex:1 1}.viewer-canvas{border:1px solid #e2e8f0;border-radius:12px;height:600px;overflow:hidden;width:100%}.scoring-panel{background:#f8fafc;border-radius:12px;padding:20px;width:320px}.scoring-panel h4{align-items:center;color:#1e293b;display:flex;font-size:18px;font-weight:600;gap:8px;margin:0 0 20px}.comment-input-group,.score-input-group{margin-bottom:20px}.comment-input-group label,.score-input-group label{color:#475569;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.comment-textarea,.score-input{border:1px solid #e2e8f0;border-radius:8px;font-size:14px;padding:10px 12px;width:100%}.comment-textarea{font-family:inherit;resize:vertical}.previous-score-info{background:#fffbeb;border:1px solid #fef3c7;border-radius:8px;color:#92400e;font-size:13px;margin-bottom:16px;padding:12px}.previous-score-info p{margin:4px 0}.submit-score-btn{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px;transition:all .2s;width:100%}.submit-score-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px)}.submit-score-btn:disabled{cursor:not-allowed;opacity:.5}.flowchart-notifications{display:flex;flex-direction:column;gap:12px;max-width:400px;position:fixed;right:20px;top:80px;z-index:9999}.notification-card{animation:slideInRight .3s ease;background:#fff;border:2px solid #22c55e;border-radius:12px;box-shadow:0 8px 24px #22c55e33;display:flex;gap:12px;padding:16px}.notification-icon{align-items:center;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.notification-content{flex:1 1}.notification-title{color:#1e293b;font-size:14px;font-weight:600;margin-bottom:4px}.notification-body{color:#475569;font-size:14px;margin-bottom:8px}.notification-body strong{color:#22c55e;font-size:18px;font-weight:700}.notification-comment{background:#f0fdf4;border-left:3px solid #22c55e;border-radius:4px;color:#166534;font-size:13px;margin:8px 0;padding:8px 12px}.notification-meta{color:#94a3b8;font-size:12px;margin-top:8px}.notification-close{background:#0000;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;flex-shrink:0;padding:4px;transition:all .2s ease}.notification-close:hover{background:#f1f5f9;color:#64748b}@keyframes slideInRight{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.flowchart-notifications{left:10px;max-width:none;right:10px}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.web-module-root{background:#f8fafc;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;height:100vh;overflow:hidden}.web-module-header{align-items:center;background:#4f46e5;color:#fff;display:flex;flex-shrink:0;justify-content:space-between;padding:12px 24px}.header-left{align-items:center;display:flex;gap:12px}.web-module-header h2{font-size:17px;font-weight:700;margin:0}.web-module-header p{font-size:12px;margin:0;opacity:.8}.step-bar{background:#fff;border-bottom:1px solid #e2e8f0;overflow-x:auto;padding:0 24px}.step-bar,.step-item{align-items:center;display:flex;flex-shrink:0}.step-item{background:#0000;border:none;border-bottom:3px solid #0000;cursor:pointer;gap:8px;padding:10px;transition:all .2s;white-space:nowrap}.step-item.active{border-bottom-color:#6366f1;border-bottom-color:var(--step-color,#6366f1)}.step-item.done .step-circle{background:#10b981;color:#fff}.step-item.active .step-circle{background:#6366f1;background:var(--step-color,#6366f1);color:#fff}.step-item.reachable .step-circle{background:#f1f5f9;color:#64748b}.step-item.locked{cursor:not-allowed;opacity:.4}.step-item.locked .step-circle{background:#f1f5f9;color:#94a3b8}.step-circle{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:15px;height:32px;justify-content:center;transition:background .2s;width:32px}.step-text{align-items:flex-start;display:flex;flex-direction:column;max-width:120px}.step-label{color:#1e293b;font-size:12px;font-weight:600}.step-label,.step-sub{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.step-sub{color:#94a3b8;font-size:10px}.step-item:not(.active) .step-sub{display:none}.step-item.active .step-label{color:#6366f1;color:var(--step-color,#6366f1)}.step-connector{background:#e2e8f0;flex:1 1;height:2px;min-width:20px;transition:background .3s}.step-connector.filled{background:#10b981}.web-access-panel{background:#f8fafc;border-bottom:1px solid #e2e8f0;justify-content:space-between;padding:10px 24px}.web-access-left,.web-access-panel{align-items:flex-start;display:flex;gap:12px}.web-access-left{flex-wrap:wrap}.web-access-label{color:#334155;font-size:12px;font-weight:700;padding-top:6px}.web-access-select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;height:32px;min-width:140px;padding:0 10px}.web-access-mode{align-items:center;color:#334155;display:flex;flex-wrap:wrap;font-size:12px;gap:10px;padding-top:6px}.web-access-mode label{align-items:center;cursor:pointer;display:inline-flex;gap:6px}.web-access-steps{display:flex;flex-wrap:wrap;gap:8px;width:100%}.web-access-step-item{align-items:center;background:#fff;border:1px solid #dbe1ea;border-radius:999px;color:#334155;display:inline-flex;font-size:12px;gap:6px;padding:4px 10px}.web-access-student-tip{background:#fff7ed;border-bottom:1px solid #fed7aa;color:#9a3412;font-size:12px;padding:8px 24px}.web-module-body{display:flex;flex:1 1;min-height:0;overflow:hidden}.session-sidebar{background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;transition:width .24s ease;width:220px}.session-sidebar.collapsed{width:42px}.session-sidebar.expanded{width:260px}.session-sidebar-header{align-items:center;border-bottom:1px solid #f1f5f9;color:#64748b;display:flex;font-size:12px;font-weight:700;justify-content:space-between;padding:10px 12px}.session-sidebar.collapsed .session-sidebar-header{cursor:pointer;justify-content:center;padding:10px 6px}.session-sidebar.collapsed .session-sidebar-header:hover{background:#f8fafc}.session-sidebar-header-actions{align-items:center;display:flex;gap:6px}.session-toggle-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:inline-flex;height:28px;justify-content:center;white-space:nowrap;width:28px}.session-toggle-btn.with-label{gap:3px;padding:0 7px;width:auto}.toggle-btn-label{font-size:11px}.session-toggle-btn:hover{background:#f8fafc}.session-new-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#475569;cursor:pointer;display:inline-flex;font-size:12px;gap:4px;padding:4px 8px}.session-new-btn:hover:not(:disabled){background:#f8fafc}.session-new-btn:disabled{cursor:not-allowed;opacity:.5}.session-list{flex:1 1;gap:6px;overflow-y:auto;padding:8px}.session-item,.session-list{display:flex;flex-direction:column}.session-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;gap:4px;min-width:0;padding:8px 9px;text-align:left}.session-item:hover{background:#f8fafc}.session-item.active{background:#f5f3ff;border-color:#6366f1}.session-title{color:#1e293b;display:block;font-size:12px;font-weight:600;max-width:100%;min-width:0;overflow:hidden;padding:0 2px;text-overflow:ellipsis;white-space:nowrap}.session-meta{color:#94a3b8;font-size:11px;min-width:0}.session-empty{color:#94a3b8;font-size:12px;line-height:1.5;padding:10px 8px}.web-module-body.sidebar-collapsed .chat-panel:not(.collapsed){width:538px}.web-module-content{min-width:0}.step-layout,.web-module-content{display:flex;flex:1 1;min-height:0;overflow:hidden}.feature-sidebar{background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;width:160px}.sidebar-title{color:#94a3b8;flex-shrink:0;font-size:11px;font-weight:700;letter-spacing:.06em;padding:12px 14px 8px;text-transform:uppercase}.sidebar-item{align-items:flex-start;background:#0000;border:none;border-left:3px solid #0000;cursor:pointer;display:flex;flex-direction:column;padding:10px 14px;position:relative;text-align:left;transition:background .15s}.sidebar-item:hover{background:#f8fafc}.sidebar-item.active{background:#f0f4ff;border-left-color:#6366f1}.sidebar-feature-name{color:#1e293b;font-size:13px;font-weight:600;line-height:1.3}.sidebar-module{color:#94a3b8;font-size:11px;margin-top:2px}.done-dot{color:#10b981;font-size:12px;font-weight:700;position:absolute;right:8px;top:8px}.chat-panel{background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;flex-shrink:0;min-height:0;overflow:hidden;transition:width .24s ease;width:320px}.chat-panel.collapsed{min-width:42px;width:42px}.chat-panel-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;flex-shrink:0;gap:6px;justify-content:space-between;padding:7px 10px}.chat-panel-title{display:flex;font-weight:700;gap:5px}.chat-collapse-btn,.chat-panel-title{align-items:center;color:#64748b;font-size:11px;white-space:nowrap}.chat-collapse-btn{background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;display:inline-flex;flex-shrink:0;gap:3px;padding:3px 6px}.chat-collapse-btn:hover{background:#f8fafc}.chat-collapse-label{font-size:11px}.chat-collapsed-strip{align-items:center;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:8px;padding:8px 0 0}.chat-collapsed-strip:hover{background:#f8fafc}.chat-collapsed-label{align-items:center;color:#94a3b8;display:flex;flex:1 1;flex-direction:column;gap:6px;justify-content:center}.chat-collapsed-label span{font-size:11px;letter-spacing:2px;transform:rotate(180deg);writing-mode:vertical-rl}.chat-messages{display:flex;flex:1 1;flex-direction:column;gap:10px;overflow-y:auto;padding:14px}.msg{animation:fadeIn .2s ease}.msg.user{align-self:flex-end;max-width:85%}.msg.assistant{align-self:flex-start;max-width:90%}.msg-label{color:#94a3b8;font-size:11px;margin-bottom:3px;padding:0 3px}.msg.user .msg-label{text-align:right}.msg-bubble{border-radius:12px;font-size:13px;line-height:1.55;padding:9px 13px;word-break:break-word}.msg.user .msg-bubble{background:#6366f1;border-bottom-right-radius:4px;color:#fff}.msg.assistant .msg-bubble{background:#f1f5f9;border-bottom-left-radius:4px;color:#1e293b}.msg-bubble.loading{align-items:center;color:#64748b;display:flex;gap:6px}.spin{animation:spin 1s linear infinite}.chat-hint{background:#f8fafc;border-top:1px solid #f1f5f9;color:#94a3b8;flex-shrink:0;font-size:12px;line-height:1.5;padding:8px 14px}.chat-input-row{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:20px;display:flex;flex-shrink:0;gap:6px;margin:10px 10px 12px;padding:8px 10px}.chat-textarea{background:#0000;border:none;border-radius:0;flex:1 1;font-family:inherit;font-size:13px;line-height:1.5;max-height:140px;min-height:24px;outline:none;overflow:hidden;padding:8px 4px;resize:none}.chat-textarea:focus{border:none}.chat-send-btn{align-items:center;background:#6366f1;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:opacity .2s;width:36px}.chat-send-btn:disabled{cursor:not-allowed;opacity:.5}.chat-tool-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:999px;color:#334155;cursor:pointer;display:flex;flex-shrink:0;height:34px;justify-content:center;transition:all .15s;width:34px}.chat-tool-btn svg{stroke-width:2.25;display:block;height:18px;width:18px}.chat-tool-icon{align-items:center;display:inline-flex;font-size:18px;font-weight:700;justify-content:center;line-height:1}.chat-tool-btn:hover:not(:disabled){background:#f8fafc;color:#1e293b}.chat-tool-btn:disabled{cursor:not-allowed;opacity:.45}.chat-tool-btn.recording{animation:pulse-border 1s ease-in-out infinite;background:#fef2f2;border-color:#fca5a5;color:#ef4444}.chat-tool-btn.mic-btn,.chat-tool-btn.plus-btn{color:#111827}.chat-tool-btn.mic-btn .chat-tool-icon{font-size:15px}.chat-tool-btn.mic-btn.recording .chat-tool-icon{font-size:12px}@keyframes pulse-border{0%,to{box-shadow:0 0 0 0 #ef44444d}50%{box-shadow:0 0 0 4px #ef44441a}}.chat-image-preview{align-items:center;background:#f8fafc;border-top:1px solid #f1f5f9;display:flex;flex-shrink:0;gap:8px;padding:8px 12px;position:relative}.chat-image-preview img{border:1.5px solid #e2e8f0;border-radius:6px;height:48px;object-fit:cover;width:48px}.ocr-badge{font-size:11px;gap:4px}.chat-remove-img,.ocr-badge{align-items:center;color:#64748b;display:flex}.chat-remove-img{background:#f1f5f9;border:none;border-radius:50%;cursor:pointer;height:20px;justify-content:center;transition:background .15s;width:20px}.chat-remove-img:hover{background:#fef2f2;color:#ef4444}.chat-textarea.recording{border-color:#fca5a5}.output-panel{background:#fff;display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.output-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;gap:8px;justify-content:space-between;padding:10px 16px}.output-header h3{color:#1e293b;font-size:14px;font-weight:600;margin:0}.project-name-badge{background:#ede9fe;border-radius:10px;color:#7c3aed;display:inline-block;font-size:12px;margin-left:10px;padding:2px 8px}.mini-tab,.tab-row{display:flex;gap:4px}.mini-tab{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;font-size:12px;padding:5px 12px;transition:all .15s}.mini-tab:hover{background:#f8fafc}.mini-tab.active{background:#f5f3ff;border-color:#6366f1;color:#6366f1}.icon-btn{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;display:flex;font-size:12px;gap:5px;padding:5px 12px;transition:all .15s;white-space:nowrap}.icon-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.icon-btn:disabled{cursor:not-allowed;opacity:.5}.copy-btn{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-size:12px;gap:4px;padding:5px 12px;transition:all .15s}.copy-btn.copied{border-color:#10b981;color:#10b981}.output-footer{align-items:center;background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;flex-shrink:0;justify-content:space-between;padding:8px 12px}.output-footer.compact-footer{background:#fff;min-height:46px;padding:6px 12px}.next-btn{align-items:center;background:#6366f1;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 18px;transition:opacity .2s}.next-btn:disabled{cursor:not-allowed;opacity:.45}.next-btn:hover{opacity:.9}.prev-btn{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;color:#64748b;cursor:pointer;display:flex;font-size:13px;gap:6px;padding:8px 14px}.prev-btn:hover{background:#f8fafc}.count-badge{background:#fff;border:1px solid #e2e8f0;border-radius:20px;color:#64748b;font-size:12px;padding:4px 10px}.feature-list{gap:10px;overflow-y:auto;padding:14px 16px}.feature-list,.step1-output-body{display:flex;flex:1 1;flex-direction:column}.step1-output-body{background:#f8fafc;overflow:hidden}.step1-tree-area{background:#fff;flex:1 1;min-height:0;overflow:hidden}.step1-entity-area{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;flex-direction:column;gap:8px;max-height:48%;min-height:180px;padding:10px 14px}.entity-header h4{color:#1e293b;font-size:13px;font-weight:700;margin:0}.entity-header p{color:#64748b;font-size:12px;margin:3px 0 0}.entity-panel{gap:8px}.entity-list,.entity-panel{display:flex;flex:1 1;flex-direction:column;min-height:0}.entity-list{gap:6px;overflow-y:auto}.entity-item{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:6px;padding:8px 10px}.entity-main{align-items:center;display:flex;gap:8px;min-width:0}.entity-name{color:#334155;cursor:text;font-size:13px;font-weight:700;-webkit-user-select:none;user-select:none}.entity-source{background:#eef2ff;border-radius:999px;color:#4f46e5;font-size:11px;margin-left:auto;max-width:52%;overflow:hidden;padding:2px 8px;text-overflow:ellipsis;white-space:nowrap}.entity-desc-wrap{align-items:center;display:flex;gap:6px}.entity-desc{color:#64748b;cursor:text;flex:1 1;font-size:12px;min-width:0;overflow:hidden;text-overflow:ellipsis;-webkit-user-select:none;user-select:none;white-space:nowrap}.entity-desc.placeholder{color:#cbd5e1;font-style:italic}.flask-sim-root{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;display:flex;flex-direction:column;margin:10px 14px 0;overflow:hidden;position:relative}.flask-sim-root.flask-sim-root-lg{height:calc(100% - 20px);margin:10px 12px}.flask-sim-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:10px 12px}.flask-sim-title{color:#1e293b;font-size:13px;font-weight:700}.flask-sim-desc{color:#64748b;font-size:12px;line-height:1.6;margin-top:3px}.flask-sim-toolbar{align-items:flex-start;display:flex;gap:10px;justify-content:space-between;padding:10px 10px 0}.flask-sim-requests{display:flex;flex-wrap:wrap;gap:8px}.flask-request-btn{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#334155;cursor:pointer;min-width:150px;padding:8px 9px;text-align:left}.flask-request-btn.active{background:#eef2ff;border-color:#818cf8}.flask-request-main{align-items:center;display:flex;font-size:12px;font-weight:700;gap:6px}.flask-request-sub{color:#64748b;font-size:11px;margin-top:2px}.flask-toolbar-actions{display:flex;gap:6px}.flask-method-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:10px;font-weight:700;justify-content:center;padding:2px 7px}.flask-method-badge.get{background:#dbeafe;color:#1d4ed8}.flask-method-badge.post{background:#fee2e2;color:#b91c1c}@keyframes packetRight{0%{left:0;opacity:1;transform:translateY(-50%) scale(1)}80%{left:92%;opacity:1;transform:translateY(-50%) scale(1.15)}to{left:100%;opacity:0;transform:translateY(-50%) scale(.8)}}@keyframes packetLeft{0%{opacity:1;right:0;transform:translateY(-50%) scale(1)}80%{opacity:1;right:92%;transform:translateY(-50%) scale(1.15)}to{opacity:0;right:100%;transform:translateY(-50%) scale(.8)}}.fd-strip{align-items:stretch;gap:0;min-height:0;padding:12px 14px 10px}.fd-node,.fd-strip{display:flex;flex:1 1;overflow:hidden}.fd-node{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:12px;flex-direction:column;min-width:0;transition:border-color .2s,box-shadow .2s}.fd-node.active{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.fd-node-header{align-items:center;background:#f1f5f9;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;flex-wrap:wrap;gap:6px;padding:7px 12px}.fd-dots{display:flex;gap:4px}.fd-dots i{border-radius:50%;display:inline-block;height:9px;width:9px}.fd-dots i:first-child{background:#f87171}.fd-dots i:nth-child(2){background:#fbbf24}.fd-dots i:nth-child(3){background:#34d399}.fd-node-icon{font-size:15px}.fd-node-title{color:#374151;font-size:13px;font-weight:700}.fd-node-status{border-radius:4px;font-size:10px;font-weight:700;margin-left:auto;padding:2px 6px}.fd-node-status.ok{background:#dcfce7;color:#166534}.fd-node-status.err{background:#fef2f2;color:#dc2626}.fd-node-body{display:flex;flex:1 1;flex-direction:column;gap:6px;overflow-y:auto;padding:10px 12px}.fd-browser-node .fd-node-header{background:#f8fafc}.fd-browser-node.active{border-color:#6366f1}.fd-login-form{display:flex;flex-direction:column;gap:7px}.fd-form-title{border-bottom:1px solid #f1f5f9;color:#374151;font-size:13px;font-weight:700;padding-bottom:4px}.fd-form-field{display:flex;flex-direction:column;gap:3px}.fd-form-field label{color:#64748b;font-size:11px;font-weight:600}.fd-form-field input{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#374151;font-size:12px;outline:none;padding:5px 8px}.fd-login-btn{background:#6366f1;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;margin-top:2px;padding:7px;transition:background .15s}.fd-login-btn:hover{background:#4f46e5}.fd-flask-node .fd-node-header{background:#f0fdf4;border-bottom-color:#bbf7d0}.fd-flask-node.active{border-color:#22c55e;box-shadow:0 0 0 3px #22c55e1a}.fd-code-body{font-family:Consolas,monospace;gap:0;padding:10px 14px}.fd-code-line{align-items:center;border-radius:4px;color:#374151;display:flex;font-size:13px;gap:8px;padding:3px 5px}.fd-code-line.route-hit{background:#fef9c3;color:#713f12;font-weight:600}.fd-code-line.fn-hit{background:#dcfce7;color:#14532d;font-weight:600}.fd-ln{color:#94a3b8;font-size:10px;min-width:16px}.fd-lc{flex:1 1;white-space:pre}.fd-tag{border-radius:3px;font-size:9px;font-weight:700;padding:1px 5px;white-space:nowrap}.fd-tag.route{background:#fde68a;color:#92400e}.fd-tag.fn{background:#bbf7d0;color:#14532d}.fd-return-hint{background:#ecfdf5;color:#047857;font-family:Consolas,monospace;margin-top:5px;padding:5px 10px;word-break:break-all}.fd-nomatch,.fd-return-hint{border-radius:5px;font-size:12px}.fd-nomatch{background:#fef2f2;color:#dc2626;margin-top:4px;padding:4px 8px}.fd-address-bar{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;gap:6px;padding:6px 10px}.fd-addr-method-select{background:#fff;border:1px solid #e2e8f0;border-radius:4px;color:#334155}.fd-addr-method,.fd-addr-method-select{flex-shrink:0;font-size:11px;font-weight:700;padding:2px 7px}.fd-addr-method{border-radius:4px}.fd-addr-method.get{background:#dbeafe;color:#1d4ed8}.fd-addr-method.post{background:#fef3c7;color:#92400e}.fd-addr-url{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;flex:1 1;min-width:0;padding:2px 8px}.fd-addr-input{background:#0000;border:none;color:#334155;font-family:Consolas,monospace;font-size:12px;outline:none;width:100%}.fd-addr-scheme{color:#94a3b8}.fd-addr-host{color:#64748b}.fd-addr-path{color:#6366f1;font-weight:600}.fd-route-builder{background:#f8fff9;border:1px dashed #bbf7d0;border-radius:8px;display:flex;flex-direction:column;gap:6px;margin-bottom:10px;padding:8px}.fd-route-builder-title{color:#166534;font-size:11px;font-weight:700}.fd-route-builder-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:76px 1fr}.fd-route-input{background:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#334155;font-family:Consolas,monospace;font-size:12px;outline:none;padding:4px 6px;width:100%}.fd-route-input:focus{border-color:#22c55e;box-shadow:0 0 0 2px #22c55e26}.fd-route-builder-actions{align-items:center;display:flex;gap:8px}.fd-route-builder-msg{color:#15803d;font-size:11px}.fd-viewport{display:flex;flex:1 1;flex-direction:column;gap:4px}.fd-viewport-label{color:#94a3b8;font-size:10px;letter-spacing:.05em;text-transform:uppercase}.fd-viewport-content{background:#f8fafc;border:1px dashed #e2e8f0;border-radius:6px;color:#94a3b8;flex:1 1;font-size:13px;font-style:italic;padding:10px 14px}.fd-viewport-content.ready{background:#f0fdf4;border-color:#bbf7d0;color:#166534;font-style:normal;font-weight:500}.fd-tip-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:5px;color:#475569;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:11px;gap:3px;padding:2px 7px;transition:background .15s,border-color .15s;white-space:nowrap}.fd-tip-btn:hover{background:#f8fafc;border-color:#cbd5e1}.fd-tip-btn.full{font-size:12px;justify-content:center;padding:5px;width:100%}.fd-tip-btn.active{background:#eff6ff;border-color:#6366f1;color:#4f46e5}.fd-tip-btns{display:flex;flex-direction:column;gap:5px}.fd-tip-overlay{align-items:center;background:#0f172a59;display:flex;inset:0;justify-content:center;position:absolute;z-index:50}.fd-tip-card{background:#fff;border-radius:14px;box-shadow:0 20px 60px #0000002e;max-width:560px;padding:22px 24px 20px;position:relative;width:90%}.fd-tip-close{background:#0000;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;font-size:14px;padding:2px 6px;position:absolute;right:14px;top:12px}.fd-tip-close:hover{background:#f1f5f9;color:#374151}.fd-tip-title{color:#1e293b;font-size:15px;font-weight:700;margin-bottom:14px}.fd-tip-url-demo{align-items:baseline;background:#f8fafc;border-radius:8px;display:flex;flex-wrap:wrap;font-family:Consolas,monospace;font-size:16px;gap:0;margin-bottom:14px;padding:10px 14px}.fd-url-part{border-radius:4px;font-weight:700;padding:2px 5px}.fd-url-sep{color:#94a3b8}.fd-url-part.scheme{background:#dbeafe;color:#1d4ed8}.fd-url-part.host{background:#fef3c7;color:#92400e}.fd-url-part.port{background:#fde68a;color:#78350f}.fd-url-part.path{background:#dcfce7;color:#166534}.fd-tip-rows{display:flex;flex-direction:column;gap:8px}.fd-tip-row{align-items:flex-start;display:flex;gap:10px}.fd-tip-key{border-radius:4px;flex-shrink:0;font-size:11px;font-weight:700;min-width:90px;padding:2px 8px;text-align:center;white-space:nowrap}.fd-tip-key.scheme{background:#dbeafe;color:#1d4ed8}.fd-tip-key.host{background:#fef3c7;color:#92400e}.fd-tip-key.port{background:#fde68a;color:#78350f}.fd-tip-key.path{background:#dcfce7;color:#166534}.fd-tip-val{color:#374151;font-size:13px;line-height:1.5;padding-top:1px}.fd-tip-compare{display:flex;gap:0}.fd-tip-col{display:flex;flex:1 1;flex-direction:column;gap:6px}.fd-tip-divider{background:#e2e8f0;flex-shrink:0;margin:0 16px;width:1px}.fd-tip-col-head{border-radius:6px;font-size:13px;font-weight:800;margin-bottom:4px;padding:5px 10px;text-align:center}.fd-tip-col-head.get{background:#dbeafe;color:#1d4ed8}.fd-tip-col-head.post{background:#fef3c7;color:#92400e}.fd-tip-item{align-items:flex-start;color:#374151;display:flex;font-size:12px;gap:7px;line-height:1.5}.fd-ci-dot{background:#6366f1;border-radius:50%;flex-shrink:0;height:7px;margin-top:5px;width:7px}.fd-ci-dot.orange{background:#f59e0b}.fd-tip-eg{background:#f8fafc;border-radius:5px;color:#64748b;font-family:Consolas,monospace;font-size:11px;margin-top:4px;padding:5px 8px}.fd-pipe{flex-shrink:0;gap:14px;justify-content:center;min-width:0;padding:0 10px;width:220px}.fd-pipe,.fd-pipe-row{display:flex;flex-direction:column}.fd-pipe-row{gap:4px}.fd-pipe-meta{align-items:center;display:flex;gap:6px}.fd-pipe-meta.res-meta{justify-content:flex-end}.fd-pipe-num{color:#6366f1;font-size:12px;font-weight:800}.fd-pipe-num.res{color:#22c55e}.fd-pipe-desc{align-items:center;color:#475569;display:flex;font-size:11px;gap:5px}.fd-badge{border-radius:4px;font-size:10px;font-weight:700;padding:1px 6px}.fd-badge.get{background:#dbeafe;color:#1d4ed8}.fd-badge.post{background:#fef3c7;color:#92400e}.fd-status-chip{border-radius:4px;font-size:11px;font-weight:700;padding:1px 6px}.fd-status-chip.ok{background:#dcfce7;color:#166534}.fd-status-chip.err{background:#fef2f2;color:#dc2626}.fd-pipe-track{align-items:center;display:flex;height:24px;position:relative}.fd-pipe-line{background:#e2e8f0;flex:1 1;height:2px;transition:background .3s}.fd-pipe-line.lit{background:#6366f1}.fd-pipe-line.lit.green{background:#22c55e}.fd-arrowhead{color:#94a3b8;flex-shrink:0;font-size:13px;line-height:1}.fd-arrowhead.res{color:#22c55e}.fd-pipe-req .fd-arrowhead{color:#6366f1}.fd-payload-bubble{background:#fffbeb;border:1px solid #fde68a;border-radius:6px;color:#92400e;display:flex;flex-direction:column;font-family:Consolas,monospace;font-size:10px;gap:1px;padding:4px 8px}.fd-payload-title{color:#b45309;font-size:9px;font-weight:700;letter-spacing:.05em;margin-bottom:2px;text-transform:uppercase}.fd-payload-code{line-height:1.5}.fd-steps{border-top:1px solid #f1f5f9;display:flex;flex-direction:column;gap:4px;margin-top:4px;padding:8px 0 0}.fd-step{align-items:center;color:#94a3b8;display:flex;font-size:11px;gap:6px}.fd-step.done{color:#475569}.fd-step-dot{background:#e2e8f0;border-radius:50%;flex-shrink:0;height:7px;transition:background .2s;width:7px}.fd-step.done .fd-step-dot{background:#22c55e}.fd-packet{border-radius:50%;height:12px;position:absolute;top:50%;width:12px;z-index:2}.fd-packet-right{animation:packetRight .9s ease-out forwards;background:#6366f1;box-shadow:0 0 8px #6366f1b3;left:0}.fd-packet-right.post{background:#f59e0b;box-shadow:0 0 8px #f59e0bb3}.fd-packet-left{animation:packetLeft .9s ease-out forwards;background:#22c55e;box-shadow:0 0 8px #22c55eb3;right:0}.flask-sim-grid{grid-gap:10px;align-items:stretch;display:grid;flex:1 1;gap:10px;grid-template-columns:1.2fr 1.25fr .85fr;min-height:0;padding:10px}.flask-sim-grid.flask-sim-grid-xl{grid-template-columns:1.35fr 1.35fr .9fr}.flask-pane{background:#fff;border:1px solid #dbe1ea;border-radius:10px;display:flex;flex-direction:column;min-width:0;overflow:hidden}.browser-topbar{align-items:center;background:#eef2f7;border-bottom:1px solid #dbe1ea;display:flex;gap:6px;padding:7px 10px}.dot{border-radius:50%;height:10px;width:10px}.dot.red{background:#ef4444}.dot.yellow{background:#f59e0b}.dot.green{background:#22c55e}.browser-title{color:#334155;font-size:12px;font-weight:700;margin-left:4px}.browser-body{display:flex;flex:1 1;flex-direction:column;min-height:0;padding:8px}.browser-address{align-items:center;display:flex;gap:6px}.browser-address.browser-address-live{align-items:stretch}.browser-method-select{color:#334155;padding:0 6px}.browser-address-input,.browser-method-select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;font-size:12px}.browser-address-input{color:#0f172a;flex:1 1;min-width:0;padding:6px 8px}.browser-action{color:#475569;font-size:12px;margin-top:8px}.url-tip-wrap{flex:0 0 auto;margin-top:0;position:relative}.url-tip-toggle{background:#fff;border:1px dashed #cbd5e1;border-radius:999px;color:#475569;cursor:pointer;font-size:11px;padding:4px 10px;transition:all .2s ease}.url-tip-toggle.active,.url-tip-toggle:hover{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8}.url-tip-popover{background:#fff;border:1px solid #dbe1ea;border-radius:10px;box-shadow:0 10px 24px #0f172a14;opacity:0;padding:8px;pointer-events:none;position:absolute;right:0;top:calc(100% + 6px);transform:translateY(-4px) scale(.98);transition:opacity .18s ease,transform .18s ease,visibility .18s ease;visibility:hidden;width:340px;z-index:30}.url-tip-popover.open{opacity:1;pointer-events:auto;transform:translateY(0) scale(1);visibility:visible}.url-tip-popover:before{background:#fff;border-left:1px solid #dbe1ea;border-top:1px solid #dbe1ea;content:"";height:10px;position:absolute;right:20px;top:-6px;transform:rotate(45deg);width:10px}.url-tip-bar{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:6px 8px}.url-tip-url{color:#334155;font-family:Consolas,Courier New,monospace;font-size:12px;word-break:break-all}.url-part{border-radius:4px;padding:1px 2px;transition:all .25s ease}.url-part.protocol.active{background:#ede9fe;color:#6d28d9;transform:translateY(-1px)}.url-part.host.active{background:#dcfce7;color:#166534;transform:translateY(-1px)}.url-part.port.active{background:#ffedd5;color:#c2410c;transform:translateY(-1px)}.url-part.path.active{background:#fee2e2;color:#b91c1c;transform:translateY(-1px)}.url-tip-dots{display:flex;gap:6px;margin-top:7px}.url-tip-dot{background:#cbd5e1;border:0;border-radius:999px;cursor:pointer;height:8px;transition:transform .2s ease,background .2s ease;width:8px}.url-tip-dot.active{background:#3b82f6;transform:scale(1.2)}.url-tip-card{animation:fadeIn .2s ease;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:8px;padding:7px 8px}.url-tip-step{color:#64748b;font-size:11px}.url-tip-title{color:#1e293b;font-size:12px;font-weight:700;margin-top:2px}.url-tip-text{color:#475569;font-size:11px;line-height:1.5;margin-top:3px}.url-tip-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:8px}.browser-viewport{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:8px;min-height:96px;padding:8px 9px}.browser-viewport.browser-viewport-large{flex:1 1;min-height:200px;overflow-y:auto}.browser-login-box{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 4px #0000000f;margin-bottom:8px;max-width:260px;padding:14px 16px}.browser-login-title{color:#1e293b;font-size:14px;font-weight:700;margin-bottom:12px;text-align:center}.browser-login-form{display:flex;flex-direction:column;gap:8px}.browser-login-field{display:flex;flex-direction:column;gap:3px}.browser-login-label{color:#64748b;font-size:11px;font-weight:600}.browser-login-input{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:6px;box-sizing:border-box;color:#94a3b8;font-size:12px;outline:none;padding:6px 10px;width:100%}.browser-login-btn{background:#4f46e5;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;margin-top:4px;padding:7px 0;transition:background .15s;width:100%}.browser-login-btn:hover{background:#4338ca}.browser-login-hint{color:#94a3b8;font-size:10px;margin-top:2px;text-align:center}.browser-viewport-label{color:#94a3b8;font-size:11px;margin-bottom:4px}.browser-viewport-content{color:#94a3b8;font-size:12px}.browser-viewport-content.ready{color:#0f766e}.editor-pane{background:#1e1e1e;border-color:#293241}.editor-tabbar{background:#252526;border-bottom:1px solid #333;padding:6px 8px 0}.editor-tab{border-top-left-radius:6px;border-top-right-radius:6px;color:#a5b4c4;display:inline-block;font-size:12px;padding:5px 10px}.editor-tab.active{background:#1e1e1e;color:#e2e8f0}.editor-header-tip{border-bottom:1px solid #2b3645;color:#94a3b8;font-size:11px;padding:7px 10px}.editor-header-tip .matched{color:#a5b4fc;font-weight:700}.editor-code{padding:8px 0}.editor-line{align-items:center;display:grid;font-family:Consolas,Courier New,monospace;font-size:12px;grid-template-columns:38px 1fr;line-height:1.6}.editor-line.active{background:#2c3850}.line-no{color:#6b7280;padding-right:10px;text-align:right;-webkit-user-select:none;user-select:none}.line-code{color:#dbe7ff;white-space:pre}.response-pane{padding:8px}.response-title{color:#475569;font-size:12px;font-weight:700}.response-sub{color:#64748b;font-size:11px;margin-top:4px}.status-chip{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:700;justify-content:center;margin-top:8px;min-width:42px;padding:2px 9px}.status-chip.ok{background:#dcfce7;color:#166534}.status-chip.err{background:#fee2e2;color:#991b1b}.response-explain{color:#475569;font-size:12px;margin-top:6px}.response-code{background:#ecfeff;border:1px solid #bae6fd;border-radius:8px;color:#94a3b8;font-size:12px;margin:8px 0 0;min-height:82px;padding:8px 9px;white-space:pre-wrap}.response-code.ready{color:#0f766e}.response-status-list{grid-gap:5px;display:grid;gap:5px;margin-top:8px}.response-status-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#94a3b8;font-size:11px;padding:4px 7px}.response-status-item.done{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.module-group{display:flex;flex-direction:column;gap:6px}.module-title{background:#f0f4ff;border-radius:6px;color:#6366f1;display:inline-block;font-size:12px;font-weight:700;padding:4px 8px}.feature-item{align-items:center;animation:fadeIn .2s ease;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;padding:8px 12px}.feature-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.feature-name{color:#1e293b;font-size:13px;font-weight:600}.feature-desc{color:#94a3b8;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.feature-actions{display:flex;flex-shrink:0;gap:4px}.icon-btn-sm{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;display:flex;height:26px;justify-content:center;transition:all .15s;width:26px}.icon-btn-sm:hover{background:#f8fafc;color:#1e293b}.icon-btn-sm.danger:hover{background:#fef2f2;border-color:#fca5a5;color:#ef4444}.req-tree{display:flex;flex-direction:column;gap:0;padding:8px 12px}.tree-root-node{align-items:center;background:#4f46e5;border-radius:8px;color:#fff;display:flex;font-size:13px;font-weight:700;gap:8px;margin-bottom:2px;max-width:100%;padding:7px 14px;width:-webkit-fit-content;width:fit-content}.tree-root-icon{font-size:15px}.tree-root-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-modules-wrap{border-left:2px solid #c7d2fe;display:flex;flex-direction:column;gap:6px;margin-left:14px;margin-top:2px;padding-bottom:4px;padding-left:18px;padding-top:6px}.tree-module-branch{display:flex;flex-direction:column;gap:2px}.tree-module-row{align-items:center;display:flex;position:relative}.tree-module-row:before{background:#c7d2fe;content:"";height:2px;left:-18px;position:absolute;top:50%;width:14px}.tree-module-node{align-items:center;background:#ede9fe;border:1.5px solid #c4b5fd;border-radius:6px;color:#5b21b6;display:flex;flex:1 1;font-size:13px;font-weight:600;gap:6px;min-width:0;padding:5px 10px}.tree-module-name{cursor:text;flex:1 1;overflow:hidden;text-overflow:ellipsis;-webkit-user-select:none;user-select:none;white-space:nowrap}.tree-features-wrap{border-left:2px solid #e2e8f0;display:flex;flex-direction:column;gap:4px;margin-left:14px;margin-top:2px;padding-bottom:2px;padding-left:18px;padding-top:2px}.tree-feature-row{align-items:center;display:flex;position:relative}.tree-feature-row:before{background:#e2e8f0;content:"";height:2px;left:-18px;position:absolute;top:50%;width:14px}.tree-feature-node{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:5px;display:flex;flex:1 1;font-size:12px;gap:6px;min-width:0;padding:4px 8px;transition:border-color .15s}.tree-feature-node:hover{border-color:#c4b5fd}.tree-feat-name{color:#1e293b;flex-shrink:0;font-weight:600}.tree-feat-desc,.tree-feat-name{cursor:text;-webkit-user-select:none;user-select:none;white-space:nowrap}.tree-feat-desc{color:#64748b;flex:1 1;font-size:11px;overflow:hidden;text-overflow:ellipsis}.tree-feat-desc.placeholder{color:#cbd5e1;font-style:italic}.tree-inline-input{background:#fff;border:1.5px solid #6366f1;border-radius:4px;flex:1 1;font-family:inherit;font-size:13px;font-weight:600;min-width:0;outline:none;padding:2px 6px}.tree-inline-input.sm{flex:0 0 auto;font-size:12px;font-weight:600;width:100px}.tree-inline-input.desc{font-size:11px;font-weight:400}.tree-node-actions{display:flex;flex-shrink:0;gap:3px;margin-left:auto}.tree-action-btn{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:11px;height:20px;justify-content:center;line-height:1;transition:background .15s;width:20px}.tree-action-btn.add{background:#d1fae5;color:#065f46}.tree-action-btn.add:hover{background:#6ee7b7}.tree-action-btn.del{background:#fee2e2;color:#991b1b}.tree-action-btn.del:hover{background:#fca5a5}.tree-action-btn.sm{font-size:10px;height:18px;width:18px}.tree-add-module-btn{align-items:center;background:#0000;border:1.5px dashed #c7d2fe;border-radius:6px;color:#6366f1;cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:4px;margin-top:4px;padding:5px 12px;transition:all .15s;width:-webkit-fit-content;width:fit-content}.tree-add-module-btn:hover{background:#ede9fe;border-color:#818cf8}.feature-edit{display:flex;flex-direction:column;gap:6px;width:100%}.edit-input{border:1.5px solid #e2e8f0;border-radius:6px;font-family:inherit;font-size:13px;outline:none;padding:6px 10px}.edit-input:focus{border-color:#6366f1}.edit-input.small{width:120px}.edit-actions{display:flex;gap:6px}.save-btn{background:#6366f1;border:none;border-radius:6px;color:#fff}.cancel-btn,.save-btn{cursor:pointer;font-size:12px;padding:5px 12px}.cancel-btn{background:#fff;border:1.5px solid #e2e8f0;border-radius:6px;color:#64748b}.preview-area{background:#f8fafc;flex:1 1;overflow:hidden}.preview-iframe{background:#fff;border:none;height:100%;width:100%}.db-area{background:#f8fafc;flex:1 1;overflow-y:auto}.table-list{display:flex;flex-direction:column;gap:14px;padding:14px}.db-table-card{animation:fadeIn .2s ease;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;overflow:hidden}.db-table-name{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#10b981;display:flex;font-size:14px;font-weight:700;gap:8px;padding:10px 14px}.db-table-desc{color:#94a3b8;font-size:12px;font-weight:400;margin-left:4px}.fields-table{border-collapse:collapse;font-size:12px;width:100%}.fields-table th{background:#f1f5f9;border-bottom:1px solid #e2e8f0;color:#64748b;font-weight:600;padding:6px 12px;text-align:left}.fields-table td{border-bottom:1px solid #f1f5f9;color:#374151;padding:7px 12px}.fields-table tr:last-child td{border-bottom:none}.fields-table .pk-row td{background:#f0fdf4}.pk-badge{background:#dcfce7;border-radius:4px;color:#16a34a;display:inline-block;font-size:10px;font-weight:700;margin-right:5px;padding:1px 5px}.field-name{font-family:monospace;font-weight:600}.field-type{color:#7c3aed;font-family:monospace}.field-constraint{color:#ea580c;font-family:monospace;font-size:11px}.field-desc{color:#94a3b8}.code-scroll{background:#1e293b;flex:1 1;overflow:auto}.code-scroll pre{font-family:Fira Code,Consolas,Monaco,monospace;line-height:1.7;margin:0;min-height:100%;white-space:pre-wrap;word-break:break-all}.code-scroll pre,.logic-text{color:#e2e8f0;font-size:13px;padding:20px}.logic-text{height:100%;line-height:1.8;overflow-y:auto}.drag-handle{align-items:center;color:#cbd5e1;cursor:grab;display:flex;flex-shrink:0;margin-right:4px}.drag-handle:active{cursor:grabbing}.feature-item.dragging{opacity:.4}.feature-item.drag-over{background:#f0f4ff;border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.feature-item.skipped{background:#f8fafc;opacity:.45}.feature-item.skipped .feature-name{color:#94a3b8;text-decoration:line-through}.sidebar-item-wrap{align-items:stretch;display:flex;position:relative}.sidebar-item-wrap .sidebar-item{flex:1 1}.sidebar-item.skipped{opacity:.5}.sidebar-skip-btn{align-items:center;background:#0000;border:none;color:#cbd5e1;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:0;transition:color .15s;width:24px}.sidebar-skip-btn:hover{color:#6366f1}.skip-badge{background:#f1f5f9;border-radius:4px;color:#94a3b8;font-size:10px;padding:1px 4px;position:absolute;right:28px;top:6px}.empty-hint{color:#94a3b8;font-size:13px;line-height:1.6;padding:16px}.empty-hint.center{align-items:center;display:flex;height:100%;justify-content:center;text-align:center}.step-bar-project{border-right:1px solid #e2e8f0;color:#6366f1;font-size:11px;font-weight:700;letter-spacing:.02em;margin-right:4px;padding:0 12px 0 4px;white-space:nowrap}.s4-gen-area{align-items:center;background:#f8fafc;display:flex;flex:1 1;justify-content:center;padding:24px}.s4-default-box,.s4-sketch-box{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 2px 12px #0000000d;display:flex;flex-direction:column;gap:14px;max-width:440px;padding:32px 36px;text-align:center;width:100%}.s4-gen-title{color:#1e293b;font-size:15px;font-weight:700}.s4-gen-desc{color:#64748b;font-size:13px;line-height:1.6}.s4-upload-zone{align-items:center;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:8px;justify-content:center;min-height:120px;padding:16px;transition:border-color .2s,background .2s;width:100%}.s4-upload-zone:hover{background:#f5f3ff;border-color:#6366f1}.s4-upload-hint{color:#94a3b8;font-size:12px}.s4-sketch-preview{border-radius:6px;max-height:200px;max-width:100%;object-fit:contain}.s4-workspace{display:flex;flex:1 1;gap:10px;min-height:0;overflow:hidden;padding:10px}.s4-teaching-layout .output-panel,.s4-workspace{background:#f8fafc}.s4-split-body{flex:1 1}.s4-left-panel,.s4-split-body{display:flex;min-height:0;overflow:hidden}.s4-left-panel{border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;width:55%}.s4-right-panel{background:#f8fafc;display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:14px 16px}.s4-left-full{width:100%!important}.s4-open-questions-btn{align-self:flex-start;background:#6366f1;border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:13px;font-weight:600;margin:10px 12px;padding:9px 16px}.s4-open-questions-btn:hover{background:#4f46e5}.s4-flask-snippet{background:#1e1e2e;border-top:1px solid #334155;display:flex;flex-direction:column;flex-shrink:0;gap:3px;padding:8px 12px}.s4-flask-snippet-label{color:#94a3b8;font-size:11px;font-weight:600}.s4-flask-snippet-code{color:#e2e8f0;font-family:monospace;font-size:13px;white-space:pre}.s4-flask-snippet-tip{color:#6b7280;font-size:11px;font-style:italic}.s4-obs-tip{border-bottom:1px solid #0000;flex-shrink:0;font-size:13px;line-height:1.5;padding:8px 16px}.s4-obs-static{background:#fff7ed;border-color:#fed7aa;color:#92400e}.s4-obs-dynamic{background:#f0fdf4;border-color:#bbf7d0;color:#166534}.s4-teacher-guide{background:#fefce8;border-bottom:1px solid #fde68a;flex-shrink:0;padding:8px 16px}.s4-guide-toggle{background:none;border:none;color:#92400e;cursor:pointer;font-size:12px;font-weight:600;margin-bottom:6px;padding:0}.s4-guide-toggle:hover{color:#78350f}.s4-guide-cards{display:flex;flex-direction:column;gap:6px}.s4-guide-card{background:#fff;border:1px solid #fde68a;border-radius:8px;display:flex;gap:10px;padding:8px 12px}.s4-guide-num{background:#fef3c7;border-radius:5px;color:#92400e;flex-shrink:0;font-size:11px;font-weight:700;height:-webkit-fit-content;height:fit-content;padding:2px 7px}.s4-guide-action{color:#b45309;font-size:11px;font-weight:600;margin-bottom:3px}.s4-guide-q{color:#1e293b;font-size:12px;line-height:1.5}.s4-questions-section{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;flex-direction:column;flex-shrink:0;gap:10px;padding:14px 16px}.s4-questions-title{color:#1e293b;font-size:13px;font-weight:700}.s4-question-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:5px;padding:10px 12px}.s4-question-label{color:#6366f1;font-size:11px;font-weight:700}.s4-question-text{color:#334155;font-size:13px;line-height:1.5}.s4-question-input{border:1px solid #cbd5e1;border-radius:6px;box-sizing:border-box;color:#1e293b;font-family:inherit;font-size:13px;padding:6px 10px;resize:vertical;width:100%}.s4-question-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11f;outline:none}.s4-question-input:disabled{background:#f8fafc;color:#64748b}.s4-teaching-workspace{gap:12px}.s4-teaching-goal{color:#64748b;font-size:12px;font-weight:500}.s4-toolbar-left,.s4-toolbar-right{align-items:center;display:flex;gap:8px;min-width:0}.s4-toolbar-left{flex:1 1;overflow-x:auto}.s4-page-chip{background:#0000;display:inline-block;padding:0;position:relative}.s4-page-edit-input{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#1e293b;font-size:12px;height:28px;outline:none;padding:0 8px;width:96px}.s4-page-edit-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f12e}.s4-chip-close{background:#0f172a0d;border:0;border-radius:999px;color:#64748b;cursor:pointer;font-size:11px;height:14px;line-height:14px;padding:0;position:absolute;right:6px;text-align:center;top:5px;width:14px;z-index:1}.s4-chip-close:hover:not(:disabled){background:#dc262624;color:#dc2626}.s4-chip-close:disabled{cursor:not-allowed;opacity:.45}.s4-page-main-btn{padding-right:24px}.s4-toolbar-right{flex-shrink:0}.s4-thumb{border:1px solid #cbd5e1;border-radius:6px;height:34px;object-fit:cover;width:34px}.s4-code-panel,.s4-iframe-wrap{background:#fff;border:1px solid #dbe1ea;border-radius:10px;display:flex;flex:1 1;flex-direction:column;min-height:0;min-width:0;overflow:hidden}.s4-panel-label{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#334155;display:flex;font-size:12px;font-weight:700;gap:8px;justify-content:space-between;padding:8px 10px}.s4-panel-label-dark{background:#0f172a;border-bottom:1px solid #223044;color:#e2e8f0}.s4-code-actions{align-items:center;display:flex;gap:6px}.s4-hint-tag{color:#64748b;font-size:11px;font-weight:500}.s4-inspect-tools{align-items:center;display:flex;gap:8px}.s4-segmented{background:#fff;border:1px solid #cbd5e1;border-radius:999px;display:inline-flex;overflow:hidden}.s4-seg-btn{background:#0000;border:0;color:#475569;cursor:pointer;font-size:11px;padding:3px 10px;transition:background .2s,color .2s}.s4-seg-btn+.s4-seg-btn{border-left:1px solid #e2e8f0}.s4-seg-btn.active{background:#e0e7ff;color:#3730a3;font-weight:600}.s4-code-scroll{background:#0b1220;flex:1 1;min-height:0;overflow:auto;padding:8px 0}.s4-code-line{grid-gap:0;display:grid;font-family:Consolas,Fira Code,monospace;font-size:12px;gap:0;grid-template-columns:52px 1fr;line-height:1.7;position:relative}.s4-line-no{color:#64748b;padding-right:10px;text-align:right;-webkit-user-select:none;user-select:none}.s4-line-text{color:#dbe7ff;padding-right:10px;white-space:pre}.s4-line-hl{background:#f59e0b2e;position:relative}.s4-line-dim-hl{background:#ffffff0a}.s4-line-tip{background:#1e293b;border:1px solid #334155;border-radius:4px;color:#cbd5e1;font-family:Microsoft YaHei,sans-serif;pointer-events:none;position:absolute;right:8px;top:50%;transform:translateY(-50%);white-space:nowrap;z-index:10}.s4-hl-badge,.s4-line-tip{font-size:11px;padding:2px 8px}.s4-hl-badge{border:1px solid;border-radius:10px;font-family:Fira Code,Consolas,monospace;font-weight:600;margin-left:8px;transition:all .15s}.s4-code-legend{background:#0d1a2d;border-bottom:1px solid #1e3a5f;display:flex;flex-wrap:wrap;gap:4px;padding:6px 10px}.s4-legend-item{border:1px solid #334155;border:1px solid var(--g-color,#334155);border-radius:3px;color:#94a3b8;color:var(--g-color,#94a3b8);cursor:pointer;font-family:Fira Code,Consolas,monospace;font-size:10.5px;opacity:.7;padding:2px 7px;transition:background .15s,opacity .15s;-webkit-user-select:none;user-select:none}.s4-legend-item.active,.s4-legend-item:hover{background:#ffffff14;opacity:1}.s4-line-note .s4-line-no{color:#475569}.s4-line-note .s4-line-text{color:#93c5fd;font-style:italic}.s4-monaco-container{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.s4-monaco-hl-line{background:#6366f138!important}@media (max-width:980px){.s4-teaching-workspace{flex-direction:column}.s4-teaching-goal{display:none}.s4-code-panel,.s4-iframe-wrap{min-height:300px}}.s4-page-list{background:#fafafa;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;width:130px}.s4-page-list-title{color:#94a3b8;flex-shrink:0;font-size:11px;font-weight:700;letter-spacing:.05em;padding:10px 12px 6px;text-transform:uppercase}.s4-page-item{background:#0000;border:none;border-left:3px solid #0000;cursor:pointer;display:flex;flex-direction:column;gap:2px;padding:9px 12px;text-align:left;transition:background .15s}.s4-page-item:hover{background:#f1f5f9}.s4-page-item.active{background:#f0f4ff;border-left-color:#6366f1}.s4-page-name{color:#1e293b;font-size:12px;font-weight:600;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.s4-page-time{color:#94a3b8;font-size:10px}.s4-main{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.s4-view-tabs{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;gap:6px;padding:8px 12px}.s4-page-badge{background:#f0f0ff;border-radius:20px;color:#6366f1;font-size:11px;font-weight:600;margin-left:auto;max-width:120px;overflow:hidden;padding:2px 8px;text-overflow:ellipsis;white-space:nowrap}.s4-iframe-wrap{flex:1 1;min-height:0;overflow:hidden}.s4-iframe{border:none;display:block;height:100%;width:100%}.s4-code-wrap{background:#0f172a;flex:1 1;min-height:0;overflow-y:auto}.s4-code{color:#e2e8f0;font-family:Fira Code,Consolas,monospace;font-size:12px;line-height:1.7;margin:0;padding:16px 18px;white-space:pre-wrap;word-break:break-all}.s4-quiz-bar{background:#fffbeb;border-bottom:1px solid #fde68a;border-top:1px solid #e2e8f0;flex-shrink:0;padding:10px 14px}.s4-quiz-form{display:flex;flex-direction:column;gap:6px}.s4-quiz-counter{color:#94a3b8;font-size:11px;font-weight:600}.s4-quiz-q{color:#1e293b;font-size:13px;font-weight:600;line-height:1.5}.s4-quiz-feedback{border-radius:6px;font-size:12px;padding:6px 10px}.s4-quiz-feedback.pass{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.s4-quiz-feedback.fail{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.project-setup{align-items:center;background:#f1f5f9;display:flex;flex:1 1;justify-content:center;overflow-y:auto;padding:24px}.setup-card{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;display:flex;flex-direction:column;gap:24px;max-width:860px;padding:36px 40px;width:100%}.setup-header{text-align:center}.setup-globe{color:#6366f1;margin-bottom:12px}.setup-card h2{color:#1e293b;font-size:22px;font-weight:700;margin:0 0 8px}.setup-card p{color:#64748b;font-size:14px;line-height:1.6;margin:0}.preset-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.preset-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:8px;justify-content:center;min-height:96px;padding:18px 14px;text-align:center;transition:all .18s}.preset-card:hover{background:#f5f3ff;border-color:#a5b4fc}.preset-card.selected{background:#f0f0ff;border-color:#6366f1;box-shadow:0 0 0 3px #e0e7ff}.preset-icon{font-size:26px;line-height:1}.preset-name{color:#1e293b;font-size:13px;font-weight:600;line-height:1.3}.preset-desc{color:#94a3b8;font-size:11px;line-height:1.4}.custom-fields{display:flex;flex-direction:column;gap:10px}.setup-input{border:1.5px solid #e2e8f0;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:14px;outline:none;padding:10px 14px;resize:none;transition:border-color .2s;width:100%}.setup-input:focus{border-color:#6366f1}.setup-info{background:#f8fafc;border-radius:10px;display:flex;flex-direction:column;gap:10px;padding:14px 16px}.setup-tech-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.tech-label{color:#64748b;font-size:12px;font-weight:600}.tech-badge{align-items:center;background:#e0e7ff;border-radius:20px;color:#4338ca;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:3px 10px}.setup-features{color:#475569;display:flex;flex-wrap:wrap;font-size:12px;gap:12px}.start-btn{align-items:center;align-self:center;background:#6366f1;border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:700;gap:8px;justify-content:center;min-width:160px;padding:12px 32px;transition:opacity .2s}.start-btn:hover:not(:disabled){opacity:.9}.start-btn:disabled{cursor:not-allowed;opacity:.4}.reset-project-btn{background:#ffffff26;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:12px;padding:5px 12px;transition:background .15s}.reset-project-btn:hover{background:#ffffff40}.code-pane{background:#1e293b;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.code-pane-header{align-items:center;background:#0f172a;border-bottom:1px solid #334155;display:flex;flex-shrink:0;gap:8px;justify-content:space-between;padding:8px 14px}.code-pane-header .mini-tab{background:#0000;border-color:#334155;color:#94a3b8}.code-pane-header .mini-tab:hover{background:#1e293b}.code-pane-header .mini-tab.active{background:#1e293b;border-color:#6366f1;color:#a5b4fc}.code-pane-area{display:flex;flex:1 1;flex-direction:column;overflow:hidden;position:relative}.explain-tip{color:#64748b;font-size:11px;white-space:nowrap}.review-btn{align-items:center;background:#1e293b;border:1px solid #334155;border-radius:6px;color:#a5b4fc;cursor:pointer;display:flex;font-size:11px;gap:4px;padding:4px 10px;transition:background .15s}.review-btn:hover:not(:disabled){background:#334155}.review-btn:disabled{cursor:not-allowed;opacity:.5}.explain-float-btn{align-items:center;animation:fadeIn .15s ease;background:#6366f1;border:none;border-radius:8px;box-shadow:0 4px 12px #6366f166;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:5px;padding:5px 12px;position:absolute;white-space:nowrap;z-index:100}.explain-float-btn:hover{background:#4f46e5}.student-editor-wrap{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.student-editor-label{align-items:center;background:#0f172a;border-bottom:1px solid #1e293b;color:#64748b;display:flex;flex-shrink:0;font-size:11px;gap:6px;padding:8px 14px}.student-code-editor{background:#1e293b;border:none;box-sizing:border-box;color:#e2e8f0;flex:1 1;font-family:Fira Code,Consolas,Monaco,monospace;font-size:13px;line-height:1.7;outline:none;padding:20px;resize:none;width:100%}.student-code-editor::placeholder{color:#475569}.comprehension-bar{background:#fefce8;border-bottom:1px solid #fde68a;border-top:1px solid #fde68a;flex-shrink:0;padding:8px 16px}.comprehension-bar.engaged{background:#f0fdf4;border-color:#bbf7d0}.comprehension-trigger{align-items:center;background:none;border:none;color:#92400e;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:6px;padding:0}.comprehension-bar.engaged .comprehension-trigger{color:#166534}.comprehension-form{display:flex;flex-direction:column;gap:6px}.comprehension-question{color:#78350f;font-size:12px;font-weight:600;line-height:1.4}.comprehension-input-row{align-items:flex-end;display:flex;gap:6px}.comprehension-textarea{background:#fff;border:1.5px solid #fbbf24;border-radius:8px;flex:1 1;font-family:inherit;font-size:12px;outline:none;padding:7px 10px;resize:none}.comprehension-textarea:focus{border-color:#f59e0b}.comprehension-submit{align-items:center;background:#f59e0b;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px}.comprehension-submit:disabled{cursor:not-allowed;opacity:.4}.comprehension-cancel{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:11px;padding:0;text-align:left}.migration-panel{padding:20px 24px}.migration-title{align-items:center;color:#0f766e;display:flex;font-size:14px;font-weight:700;gap:6px;margin-bottom:8px}.migration-desc{color:#475569;font-size:13px;line-height:1.6;margin:0 0 16px}.migration-targets{display:flex;flex-wrap:wrap;gap:10px}.migration-target-btn{align-items:center;background:#f0fdfa;border:2px solid #99f6e4;border-radius:10px;color:#0f766e;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .15s}.migration-target-btn:hover{background:#ccfbf1;border-color:#2dd4bf}.migration-target-btn.custom{background:#f5f3ff;border-color:#c4b5fd;color:#7c3aed}.migration-target-btn.custom:hover{background:#ede9fe}.icon-btn.active{background:#e0f2fe;border-color:#0ea5e9;color:#0284c7}.step-task-bar{align-items:flex-start;background:linear-gradient(135deg,#f0f0ff,#e8f4ff);border-bottom:1px solid #c7d2fe;display:flex;flex-shrink:0;gap:10px;padding:10px 16px}.task-icon{flex-shrink:0;font-size:16px;margin-top:1px}.task-label{color:#4338ca;font-size:11px;font-weight:700;letter-spacing:.05em;margin-bottom:3px;text-transform:uppercase}.task-text{color:#1e293b;font-size:13px;font-weight:500;line-height:1.5}.code-tab-header{align-items:center;background:#0f172a;border-bottom:1px solid #334155;display:flex;flex-shrink:0;justify-content:space-between;padding:8px 14px}.code-tab-header .mini-tab{background:#0000;border-color:#334155;color:#94a3b8}.code-tab-header .mini-tab:hover{background:#1e293b}.code-tab-header .mini-tab.active{background:#1e293b;border-color:#6366f1;color:#a5b4fc}.code-tab-header .mini-tab.tab-locked{border-style:dashed;cursor:not-allowed;opacity:.5}.hint-skeleton-btn{align-items:center;background:#1e293b;border:1px solid #fbbf24;border-radius:6px;color:#fbbf24;cursor:pointer;display:flex;font-size:11px;gap:5px;padding:4px 10px;transition:background .15s;white-space:nowrap}.hint-skeleton-btn:hover:not(:disabled){background:#2d3748}.hint-skeleton-btn:disabled{cursor:not-allowed;opacity:.4}.mine-area{background:#1e293b;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.mine-actions{align-items:center;background:#0f172a;border-top:1px solid #334155;display:flex;flex-shrink:0;gap:8px;justify-content:space-between;padding:8px 14px}.attempt-badge{color:#64748b;flex:1 1;font-size:11px}.attempt-badge.done{color:#10b981}.submit-review-btn{align-items:center;background:#6366f1;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:12px;font-weight:600;gap:6px;padding:6px 14px;transition:opacity .15s;white-space:nowrap}.submit-review-btn:hover:not(:disabled){opacity:.9}.submit-review-btn:disabled{cursor:not-allowed;opacity:.4}.review-feedback-panel{background:#0f172a;border-top:1px solid #334155;flex-shrink:0;max-height:160px;overflow-y:auto}.rfp-header{align-items:center;color:#a5b4fc;display:flex;font-size:12px;font-weight:700;gap:6px;padding:8px 14px 4px}.rfp-body{color:#cbd5e1;font-size:12px;line-height:1.6;padding:4px 14px 8px}.rfp-footer{border-top:1px solid #1e293b;color:#475569;font-size:11px;padding:4px 14px 8px}.comprehension-gate{background:#fffbeb;border-bottom:1px solid #fde68a;border-top:1px solid #fde68a;flex-shrink:0;padding:10px 16px}.comprehension-gate.gate-locked{background:#f8fafc;border-color:#e2e8f0;opacity:.6;pointer-events:none}.comprehension-gate.passed-bar{background:#f0fdf4;border-color:#bbf7d0;color:#166534;font-size:12px;font-weight:600;padding:8px 16px}.gate-header{align-items:center;color:#92400e;display:flex;font-size:12px;gap:6px;margin-bottom:6px}.gate-lock-tip{color:#b45309;font-weight:400;margin-left:4px}.gate-question{color:#78350f;font-size:12px;font-weight:600;line-height:1.5;margin-bottom:8px}.gate-input-row{align-items:flex-end;display:flex;gap:6px}.gate-textarea{background:#fff;border:1.5px solid #fbbf24;border-radius:8px;flex:1 1;font-family:inherit;font-size:12px;line-height:1.5;outline:none;padding:7px 10px;resize:none}.gate-textarea:focus{border-color:#f59e0b}.gate-submit-btn{align-items:center;background:#f59e0b;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:opacity .15s;width:32px}.gate-submit-btn:disabled{cursor:not-allowed;opacity:.4}.gate-feedback{border-radius:8px;font-size:12px;line-height:1.5;margin-top:8px;padding:6px 10px}.gate-feedback.passed{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.gate-feedback.retry{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412}.retry-hint{color:#ea580c;font-style:italic}.db-flow-root{background:#f8faff;border-top:1px solid #e2e8f0}.db-flow-intro{padding:12px 14px 8px}.db-flow-title{color:#312e81;font-size:15px;font-weight:700}.db-flow-desc{color:#475569;font-size:12px;margin-top:4px}.db-flow-finish{align-items:center;background:#ccfbf1;border:1px solid #99f6e4;border-radius:999px;color:#0f766e;display:inline-flex;font-size:11px;gap:6px;margin-top:8px;padding:4px 10px}.db-flow-toolbar{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;border-top:1px solid #e2e8f0;display:flex;gap:10px;justify-content:space-between;padding:8px 14px}.db-flow-actions,.db-flow-case-switch{align-items:center;display:flex;gap:8px}.db-flow-main{grid-template-columns:1fr 1fr 1.05fr;padding:12px 14px;position:relative}.db-flow-arrows{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr 1fr;left:14px;pointer-events:none;position:absolute;right:14px;top:6px}.db-arrow{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:999px;color:#64748b;font-size:11px;justify-self:center;opacity:.75;padding:2px 10px;transition:all .2s ease}.db-arrow.active{background:#e0e7ff;border-color:#6366f1;box-shadow:0 0 0 1px #6366f126;color:#4338ca}.db-browser-panel,.db-flask-panel,.db-tables-panel{box-shadow:0 2px 10px #0f172a0d}.db-panel-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;gap:8px;justify-content:space-between;padding:8px 10px}.db-panel-title{color:#334155;font-size:12px;font-weight:700}.db-status-chip{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:999px;color:#64748b;font-size:11px;padding:2px 8px}.db-status-chip.active{background:#eef2ff;border-color:#6366f1;color:#4338ca}.db-browser-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin:10px;padding:10px}.db-browser-card.active{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11f}.db-form-row{grid-gap:6px;align-items:center;display:grid;gap:6px;grid-template-columns:auto 1fr auto}.db-form-row label{color:#475569;font-size:12px}.db-form-row input{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;font-size:12px;height:30px;padding:0 8px}.db-borrow-btn,.db-form-row button{background:#6366f1;border:1px solid #6366f1;border-radius:8px;color:#fff;font-size:12px;padding:6px 10px}.db-borrow-btn{margin:10px 0 0;width:100%}.db-borrow-btn.active{box-shadow:0 0 0 2px #6366f12e}.db-book-card{background:#eff6ff;border:1px solid #dbeafe;border-radius:10px;padding:10px}.db-book-title{color:#1e3a8a;font-size:13px;font-weight:700}.db-book-line{color:#334155;font-size:12px;margin-top:4px}.db-result-box{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-top:10px;padding:8px}.db-result-title{color:#334155;font-size:12px;font-weight:700}.db-result-empty{color:#64748b;font-size:12px;margin-top:6px}.db-result-list{color:#0f172a;font-size:12px;margin:6px 0 0;padding-left:16px}.db-result-list li+li{margin-top:5px}.db-browser-tip{background:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;color:#4338ca;font-size:12px;margin:auto 10px 10px;padding:7px 9px}.db-flask-panel{padding-bottom:10px}.db-flow-node{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin:10px 10px 0;padding:8px}.db-flow-node.active{background:#eef2ff;border-color:#6366f1;box-shadow:0 0 0 2px #6366f124}.db-node-title{color:#312e81;font-size:12px;font-weight:700;margin-bottom:6px}.db-kv{align-items:center;color:#334155;display:flex;font-size:12px;gap:8px;justify-content:space-between;margin-top:4px}.db-kv code{background:#dbeafe;border-radius:6px;color:#1d4ed8;font-size:11px;padding:2px 6px}.db-flow-node pre{color:#0f172a;font-family:Consolas,Fira Code,monospace;font-size:12px;line-height:1.5;margin:0;white-space:pre-wrap}.db-tables-panel{overflow:auto;padding:0 10px 10px}.db-table-card-lite{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-top:10px;overflow:hidden}.db-table-title{background:#f0fdfa;border-bottom:1px solid #d1fae5;color:#0f766e;font-size:12px;font-weight:700;padding:7px 10px}.db-table{border-collapse:collapse;font-size:12px;width:100%}.db-table th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#475569;padding:7px 8px;text-align:left}.db-table td{border-bottom:1px solid #f1f5f9;color:#0f172a;padding:7px 8px}.db-table tbody tr:last-child td{border-bottom:none}.step6-reflect-bar{align-items:flex-end;background:#fff;border-top:1px solid #e2e8f0;display:flex;flex-shrink:0;gap:8px;padding:8px 14px}.step6-reflect-input{border:1.5px solid #cbd5e1;border-radius:8px;flex:1 1;font-family:inherit;font-size:12px;line-height:1.45;max-height:88px;min-height:34px;outline:none;padding:7px 9px;resize:vertical}.step6-reflect-input:focus{border-color:#6366f1}.step6-full-width{width:100%}.db-flow-root{background:#f8fafc;display:flex;flex:1 1;flex-direction:column;gap:10px;min-height:0;overflow:hidden;padding:10px 12px 12px}.db-flow-topline{background:#fff;border:1px solid #dbe1ea;border-radius:12px;padding:10px 12px}.db-flow-track{grid-gap:8px;align-items:center;display:grid;gap:8px;grid-template-columns:repeat(6,1fr);position:relative}.db-flow-stage{background:#f8fafc;border:1px solid #dbe1ea;border-radius:999px;color:#64748b;font-size:12px;font-weight:600;padding:6px 4px;text-align:center}.db-flow-stage.active{background:#eef2ff;border-color:#a5b4fc;color:#3730a3}.db-flow-anim{height:8px;left:0;pointer-events:none;position:absolute;right:0;top:-4px}.db-flow-dot{background:#6366f1;border-radius:50%;box-shadow:0 0 0 4px #6366f129;height:10px;position:absolute;transition:left .35s ease;width:10px}.db-flow-dot.pos-0{left:3%}.db-flow-dot.pos-1{left:21%}.db-flow-dot.pos-2{left:39%}.db-flow-dot.pos-3{left:57%}.db-flow-dot.pos-4{left:75%}.db-flow-dot.pos-5{left:93%}.db-flow-controller{align-items:center;background:#fff;border:1px solid #dbe1ea;border-radius:12px;display:flex;gap:10px;justify-content:space-between;padding:8px 10px}.db-flow-step-text{color:#334155;font-size:12px;font-weight:600}.db-flow-main{grid-gap:10px;display:grid;flex:1 1;gap:10px;grid-template-columns:1fr 1.05fr 1fr;min-height:0}.db-step-inactive{opacity:.4}.db-step-active{box-shadow:0 0 0 2px #6366f126;opacity:1}.db-browser-panel,.db-flask-panel,.db-tables-panel{background:#fff;border:1px solid #dbe1ea;border-radius:12px;box-shadow:0 1px 6px #0f172a0f;display:flex;flex-direction:column;min-height:0;min-width:0;overflow:hidden}.db-form-grid{grid-gap:6px;align-items:center;display:grid;gap:6px;grid-template-columns:78px 1fr auto}.db-form-grid.borrow{grid-template-columns:90px 1fr}.db-form-grid.borrow button{grid-column:1/-1}.db-form-grid input{border:1px solid #cbd5e1;border-radius:8px;font-size:12px;height:30px;padding:0 8px}.db-form-grid button{background:#6366f1;border:1px solid #6366f1;border-radius:8px;color:#fff;cursor:pointer;font-size:12px;height:30px;padding:0 10px}.db-dao-viewer{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr;margin:10px}.db-code-card{background:#0f172a;border:1px solid #dbe1ea;border-radius:10px;color:#dbeafe;overflow:hidden}.db-code-title{border-bottom:1px solid #24354f;color:#bfdbfe;font-size:11px;font-weight:700;padding:6px 8px}.db-code-line{grid-gap:8px;display:grid;font-size:11px;gap:8px;grid-template-columns:24px 1fr;padding:4px 8px}.db-code-line span{color:#64748b}.db-code-line code{color:#e2e8f0;font-family:Consolas,Fira Code,monospace}.db-code-line.hit{background:#6366f13d}.db-sql-box.active{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11f}.db-row-highlight{animation:dbFlash .8s ease;background:#fef9c3}@keyframes dbFlash{0%{background:#fde68a}to{background:#fef9c3}}.s7-selector{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0}.s7-tab-row{border-bottom:1px solid #f1f5f9;gap:2px;padding:0 12px}.s7-tab,.s7-tab-row{align-items:center;display:flex}.s7-tab{background:none;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-size:13px;font-weight:500;gap:5px;padding:7px 14px;transition:color .15s,border-color .15s;white-space:nowrap}.s7-tab:hover{background:#f8fafc;border-radius:6px 6px 0 0;color:#374151}.s7-tab.active{font-weight:700}.s7-tab-icon{font-size:15px}.s7-hint-toggle{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;font-size:11px;margin-left:auto;padding:4px 10px;transition:background .12s;white-space:nowrap}.s7-hint-toggle:hover{background:#f1f5f9;color:#374151}.s7-info-bar{align-items:baseline;background:#fafbff;border-left:3px solid #6366f1;display:flex;flex-wrap:wrap;font-size:12px;gap:6px 12px;padding:7px 14px}.s7-info-desc{color:#374151;font-weight:600;white-space:nowrap}.s7-info-code-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.s7-info-label{background:#e2e8f0;border-radius:4px;color:#475569;font-size:10px;font-weight:700;padding:1px 5px;white-space:nowrap}.s7-info-sql{background:#f1f5f9;color:#1e293b;white-space:nowrap}.s7-info-python,.s7-info-sql{border-radius:4px;font-family:Consolas,monospace;font-size:11.5px;padding:2px 7px}.s7-info-python{background:#eef2ff;color:#4338ca;white-space:pre}.s7-info-note{background:#fef3c7;border-radius:4px;color:#92400e;font-size:11.5px;padding:2px 8px;white-space:nowrap}.type-tip-wrap{display:inline-block;position:relative;vertical-align:middle}.type-tip-btn{background:#6366f1;border:none;border-radius:50%;color:#fff;cursor:pointer;flex-shrink:0;font-size:10px;font-weight:700;height:15px;line-height:15px;margin-left:4px;padding:0;text-align:center;vertical-align:middle;width:15px}.type-tip-btn:hover{background:#4f46e5}.type-tip-popover{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 4px 20px #0000001f;display:flex;flex-direction:column;gap:8px;left:auto;padding:10px 12px;position:absolute;right:0;top:calc(100% + 6px);transform:none;width:280px;z-index:200}.type-tip-title{border-bottom:1px solid #f1f5f9;color:#1e293b;font-size:12px;font-weight:700;padding-bottom:6px}.type-tip-row{align-items:flex-start;display:flex;gap:8px}.type-tip-badge{border-radius:5px;color:#fff;flex-shrink:0;font-size:10.5px;font-weight:700;margin-top:1px;padding:2px 6px;white-space:nowrap}.type-tip-content{display:flex;flex-direction:column;gap:1px}.type-tip-desc{color:#1e293b;font-size:12px;font-weight:600}.type-tip-examples{color:#64748b;font-size:11px}.type-tip-note{color:#0369a1;font-size:11px}.sqlite-type-ref{align-items:center;background:#f0f9ff;border-bottom:1px solid #bae6fd;display:flex;flex-wrap:wrap;font-size:11.5px;gap:6px;padding:7px 12px}.sqlite-type-ref-title{color:#0369a1;font-weight:600;margin-right:4px;white-space:nowrap}.sqlite-type-tag{background:#fff;border:1px solid #bae6fd;border-radius:6px;color:#334155;padding:2px 8px;white-space:nowrap}.sqlite-type-tag b{color:#0ea5e9;margin-right:3px}.td-overlay{align-items:flex-start;background:#00000073;display:flex;inset:0;justify-content:center;overflow-y:auto;padding:24px 16px;position:fixed;z-index:1000}.td-modal{background:#fff;border-radius:12px;box-shadow:0 8px 40px #0000002e;display:flex;flex-direction:column;max-height:calc(100vh - 48px);max-width:1100px;width:100%}.td-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;padding:14px 20px}.td-header,.td-title-row{align-items:center;display:flex}.td-title-row{gap:10px}.td-title{color:#1e293b;font-size:15px;font-weight:600;white-space:nowrap}.td-class-select{background:#f8fafc;border:1px solid #d1d5db;border-radius:6px;color:#1e293b;cursor:pointer;font-size:13px;outline:none;padding:3px 8px}.td-class-select:focus{border-color:#6366f1}.td-header-right{align-items:center;display:flex;gap:10px}.td-refresh-time{color:#94a3b8;font-size:11px}.td-refresh-btn{align-items:center;background:none;border:none;border-radius:4px;color:#64748b;cursor:pointer;display:flex;padding:4px}.td-refresh-btn:hover{background:#f1f5f9}.td-close-btn{background:none;border:none;border-radius:4px;color:#64748b;cursor:pointer;font-size:14px;padding:4px 8px}.td-close-btn:hover{background:#f1f5f9}.td-empty,.td-loading{align-items:center;color:#94a3b8;display:flex;font-size:14px;gap:8px;justify-content:center;padding:48px;text-align:center}.td-table-wrap{flex:1 1;overflow:auto;padding:16px}.td-table{border-collapse:collapse;font-size:12.5px;width:100%}.td-table td,.td-table th{border:1px solid #e5e7eb;padding:0}.td-th-name{background:#f8fafc;color:#475569;font-weight:600;left:0;padding:8px 10px;position:-webkit-sticky;position:sticky;text-align:left;width:90px;z-index:1}.td-th-step{background:#f8fafc;min-width:100px;padding:6px 8px;text-align:center}.td-th-step-id{color:#94a3b8;font-size:10px}.td-th-step-label{color:#334155;font-size:11.5px;font-weight:600}.td-td-name{background:#f8fafc;border-right:2px solid #e2e8f0;left:0;padding:8px 10px;position:-webkit-sticky;position:sticky;z-index:1}.td-stu-name{color:#1e293b;font-size:12.5px;font-weight:600}.td-stu-meta{color:#94a3b8;font-size:10.5px;margin-top:2px}.td-td-step{padding:6px 8px;text-align:center;transition:background .15s;vertical-align:top}.td-td-step.has-answer{cursor:pointer}.td-td-step.has-answer:hover{background:#f0f9ff}.td-status-done{background:#f0fdf4}.td-status-active{background:#fefce8}.td-status-pending{background:#fff}.td-status-badge{border-radius:10px;display:inline-block;font-size:11px;font-weight:600;padding:2px 6px}.td-status-done .td-status-badge{background:#dcfce7;color:#16a34a}.td-status-active .td-status-badge{background:#fef9c3;color:#ca8a04}.td-status-pending .td-status-badge{color:#94a3b8}.td-answer-preview{color:#475569;font-size:10.5px;line-height:1.4;margin-top:4px;text-align:left;word-break:break-all}.td-detail-overlay{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1100}.td-detail-card{background:#fff;border-radius:10px;box-shadow:0 4px 24px #00000026;max-width:520px;width:100%}.td-detail-header{align-items:center;border-bottom:1px solid #e5e7eb;color:#1e293b;display:flex;font-size:13px;font-weight:600;justify-content:space-between;padding:12px 16px}.td-detail-header button{background:none;border:none;color:#64748b;cursor:pointer;font-size:14px}.td-detail-body{color:#334155;font-size:13.5px;line-height:1.7;max-height:60vh;overflow-y:auto;padding:16px;white-space:pre-wrap}.rfm-root{background:#f8fafc;display:flex;flex-direction:column;height:100%;overflow:hidden}.rfm-tab-bar{background:#fff;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;gap:4px;padding:8px 16px 0}.rfm-tab-btn{align-items:center;background:#f1f5f9;border:1px solid #0000;border-bottom:none;border-radius:8px 8px 0 0;bottom:-1px;color:#64748b;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:7px 18px;position:relative;transition:background .15s,color .15s,opacity .15s}.rfm-tab-btn.active{background:#fff;border-color:#e2e8f0 #e2e8f0 #fff;color:#1e40af;font-weight:600}.rfm-tab-btn.locked{color:#94a3b8;cursor:not-allowed;opacity:.65}.rfm-tab-btn.unlocked:not(.active):hover{background:#e2e8f0;color:#334155}@keyframes rfm-unlock-flash{0%{background:#fef9c3}to{background:#f1f5f9}}.rfm-tab-btn.just-unlocked{animation:rfm-unlock-flash .4s ease-out}.rfm-tab-num{align-items:center;background:currentColor;border-radius:50%;color:#fff;display:inline-flex;font-size:10px;font-weight:700;height:18px;justify-content:center;opacity:.8;width:18px}.rfm-tab-btn.active .rfm-tab-num{background:#2563eb;opacity:1}.rfm-tab-lock{font-size:12px}.rfm-tab-content{flex:1 1;min-height:0;overflow-y:auto;padding:0}.rfm-arch-view{display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding:16px}.rfm-arch-diagram{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:visible;padding:16px 12px 4px;position:relative}.rfm-arch-svg{display:block;margin:0 auto;max-width:800px;overflow:visible}.rfm-arch-hint{color:#94a3b8;font-size:11px;margin:4px 0 6px;text-align:center}.rfm-node-card{align-items:flex-start;animation:rfm-card-in .2s ease-out;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;color:#1e3a8a;display:flex;font-size:13px;gap:10px;padding:12px 14px;position:relative}@keyframes rfm-card-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.rfm-node-card-icon{flex-shrink:0;font-size:22px;line-height:1}.rfm-node-card-body strong{display:block;font-size:14px;font-weight:600;margin-bottom:4px}.rfm-node-card-body p{color:#1e40af;line-height:1.55;margin:0}.rfm-node-card-close{background:none;border:none;color:#64748b;cursor:pointer;font-size:13px;line-height:1;padding:2px 4px;position:absolute;right:10px;top:8px}.rfm-node-card-close:hover{color:#1e40af}.rfm-arch-controls{display:flex;justify-content:center}.rfm-replay-btn{background:#fff;border:1px solid #6366f1;border-radius:8px;color:#6366f1;cursor:pointer;font-size:13px;font-weight:500;padding:7px 22px;transition:background .15s,color .15s}.rfm-replay-btn:hover:not(:disabled){background:#6366f1;color:#fff}.rfm-replay-btn:disabled{cursor:not-allowed;opacity:.55}.rfm-demo{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px}.rfm-demo-title{color:#374151;font-size:13px;font-weight:600;margin-bottom:10px}.rfm-demo-row{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.rfm-demo-label{color:#374151;font-size:13px;white-space:nowrap}.rfm-demo-input{border:1px solid #cbd5e1;border-radius:6px;flex:1 1;font-size:13px;height:32px;max-width:200px;min-width:120px;outline:none;padding:0 10px;transition:border-color .15s}.rfm-demo-input:focus{border-color:#6366f1}.rfm-demo-btn{background:#6366f1;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;height:32px;padding:0 16px;transition:background .15s;white-space:nowrap}.rfm-demo-btn:hover:not(:disabled){background:#4f46e5}.rfm-demo-btn:disabled{cursor:not-allowed;opacity:.55}.rfm-demo-steps{display:flex;flex-direction:column;gap:6px;margin-top:10px}.rfm-demo-step{align-items:flex-start;animation:rfm-card-in .2s ease-out;display:flex;gap:8px}.rfm-demo-step-badge{border-radius:6px;color:#fff;flex-shrink:0;font-size:11px;font-weight:700;padding:3px 8px;white-space:nowrap}.rfm-demo-step-desc{color:#334155;font-size:12px;line-height:1.5;padding-top:2px}.rfm-goto-tab2{align-items:center;background:#f0f9ff;border:1px solid #bae6fd;border-radius:10px;display:flex;gap:12px;justify-content:space-between;margin-top:12px;padding:10px 14px}.rfm-goto-tab2-tip{color:#0369a1;font-size:12px;line-height:1.5}.rfm-goto-tab2-btn{background:#0ea5e9;border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:13px;font-weight:600;padding:7px 14px;white-space:nowrap}.rfm-goto-tab2-btn:hover{background:#0284c7}.rfm-node-card-name{color:#1e293b;display:block;font-size:14px;margin-bottom:4px}.rfm-node-card-core{color:#334155;font-size:13px;line-height:1.5;margin:0 0 5px}.rfm-node-card-prior{color:#64748b;font-size:11px;line-height:1.4;margin:0}.rfm-demo-result{animation:rfm-card-in .2s ease-out;margin-top:10px}.rfm-demo-result-label{color:#64748b;font-size:12px;margin-bottom:6px}.rfm-demo-book{align-items:center;background:#f8fafc;border-radius:6px;display:flex;font-size:13px;gap:8px;margin-bottom:4px;padding:5px 10px}.rfm-demo-empty{color:#94a3b8;font-size:13px;padding:6px 0}.rfm-book-id{background:#e2e8f0;border-radius:4px;color:#475569;font-family:monospace;font-size:11px;padding:1px 5px}.rfm-book-status{border-radius:10px;font-size:11px;font-weight:500;margin-left:auto;padding:1px 8px}.rfm-book-status.in{background:#dcfce7;color:#15803d}.rfm-book-status.out{background:#fee2e2;color:#b91c1c}.rfm-layer-view{display:flex;flex-direction:column;gap:8px;padding:16px}.rfm-layer-intro{color:#64748b;font-size:13px;margin:0 0 4px}.rfm-layer-row{background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;transition:border-color .2s}.rfm-layer-row.open{border-color:#6366f1}.rfm-layer-row.layer-browser.open{border-color:#3b82f6}.rfm-layer-row.layer-flask.open{border-color:#8b5cf6}.rfm-layer-row.layer-db.open{border-color:#22c55e}.rfm-layer-header{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:10px;padding:12px 16px;text-align:left;transition:background .15s;width:100%}.rfm-layer-header:hover{background:#f8fafc}.rfm-layer-num{align-items:center;background:#e2e8f0;border-radius:50%;color:#475569;display:inline-flex;flex-shrink:0;font-size:12px;font-weight:700;height:22px;justify-content:center;width:22px}.rfm-layer-row.open .rfm-layer-num{background:#6366f1;color:#fff}.rfm-layer-icon{font-size:20px}.rfm-layer-label{color:#1f2937;flex:1 1;font-size:14px;font-weight:600}.rfm-layer-chevron{color:#94a3b8;font-size:11px}.rfm-layer-body{animation:rfm-card-in .15s ease-out;border-top:1px solid #f1f5f9;padding:0 16px 16px}.rfm-layer-analogy{color:#374151;font-size:13px;line-height:1.55;margin:12px 0 10px}.rfm-analogy-badge,.rfm-boundary-badge{border-radius:10px;display:inline-block;font-size:11px;font-weight:600;margin-right:8px;padding:1px 8px}.rfm-analogy-badge{background:#fef3c7;color:#92400e}.rfm-boundary-badge{background:#fee2e2;color:#991b1b}.rfm-layer-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:10px}@media (max-width:600px){.rfm-layer-grid{grid-template-columns:1fr}}.rfm-layer-io{background:#f8fafc;border-radius:8px;padding:10px 12px}.rfm-io-label{font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase}.rfm-io-label.in{color:#2563eb}.rfm-io-label.out{color:#16a34a}.rfm-io-text{color:#374151;font-size:13px;line-height:1.5}.rfm-layer-boundary{background:#fff5f5;border-radius:8px;color:#374151;font-size:13px;line-height:1.55;padding:8px 12px}.rfm-layer-footer{margin-top:4px}.rfm-layer-tip{color:#64748b;font-size:12px;line-height:1.55}.rfm-code-view{grid-gap:0;display:grid;gap:0;grid-template-columns:190px 1fr;height:100%;min-height:0;overflow:hidden}.rfm-node-list{background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;gap:0;overflow-y:auto;padding:12px 8px 10px}.rfm-node-list-title{color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:.6px;margin-bottom:10px;padding-left:4px;text-transform:uppercase}.rfm-node-list-items{align-items:stretch;display:flex;flex:1 1;flex-direction:column}.rfm-node-item{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;display:flex;gap:7px;padding:9px 8px;text-align:left;transition:border-color .15s,background .15s,box-shadow .15s}.rfm-node-item:hover{background:#f0f4ff;border-color:#a5b4fc}.rfm-node-item.active{box-shadow:0 2px 8px #00000014}.rfm-node-item-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.rfm-node-item-icon{flex-shrink:0;font-size:18px}.rfm-node-item-text{display:flex;flex:1 1;flex-direction:column;min-width:0}.rfm-node-item-label{color:#1f2937;font-size:12px;font-weight:600;line-height:1.3}.rfm-node-item-sub{color:#94a3b8;font-size:10px;margin-top:1px}.rfm-node-item-status{flex-shrink:0;font-size:13px}.rfm-node-list-arrow{color:#cbd5e1;font-size:13px;line-height:1;padding:2px 0;text-align:center}.rfm-node-list-progress{border-top:1px solid #f1f5f9;color:#94a3b8;font-size:11px;margin-top:10px;padding-top:8px;text-align:center}.rfm-node-list-pass{color:#16a34a;font-weight:600}.rfm-detail-panel{background:#f8fafc;display:flex;flex-direction:column;overflow-y:auto}.rfm-detail-empty{align-items:center;color:#94a3b8;display:flex;flex:1 1;flex-direction:column;gap:10px;justify-content:center}.rfm-detail-empty-icon{font-size:36px}.rfm-detail-empty-text{font-size:13px;line-height:1.6;text-align:center}.rfm-detail-content{display:flex;flex-direction:column;gap:12px;padding:14px 16px}.rfm-detail-header{align-items:flex-start;background:#fff;border-left:4px solid #6366f1;border-radius:8px;box-shadow:0 1px 3px #0000000f;display:flex;gap:10px;padding:10px 12px}.rfm-detail-header-icon{flex-shrink:0;font-size:22px;margin-top:1px}.rfm-detail-header-title{font-size:14px;font-weight:700;line-height:1.3}.rfm-detail-header-comment{color:#6b7280;font-family:Consolas,Monaco,monospace;font-size:11px;font-style:italic;margin-top:2px}.rfm-detail-lang-badge{align-self:flex-start;background:#f1f5f9;border-radius:6px;color:#64748b;flex-shrink:0;font-size:10px;font-weight:700;letter-spacing:.5px;margin-left:auto;padding:2px 8px}.rfm-detail-code{background:#0f172a;border-radius:10px;color:#e2e8f0;font-family:Consolas,Monaco,Courier New,monospace;font-size:12.5px;line-height:1.6;margin:0;min-height:120px;overflow-x:auto;padding:14px 16px;white-space:pre}.rfm-detail-section-title{color:#374151;font-size:12px;font-weight:700;margin-bottom:6px}.rfm-detail-annotations{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000d;padding:10px 12px}.rfm-ann-row{align-items:flex-start;background:#fefce8;border-left:3px solid #facc15;border-radius:6px;color:#78350f;display:flex;font-size:12px;gap:8px;line-height:1.5;margin-bottom:5px;padding:5px 8px}.rfm-ann-row:last-child{margin-bottom:0}.rfm-ann-line{color:#92400e;flex-shrink:0;font-weight:700;min-width:44px}.rfm-detail-bridge{align-items:flex-start;background:#f0f9ff;border-left:3px solid #38bdf8;border-radius:6px;color:#0c4a6e;display:flex;font-size:12px;gap:6px;padding:7px 10px}.rfm-detail-bridge-arrow{color:#6366f1;flex-shrink:0;font-size:14px}.rfm-detail-explain{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000d;padding:10px 12px}.rfm-explain-card{align-items:flex-start;border-radius:8px;color:#1f2937;display:flex;font-size:12.5px;gap:8px;line-height:1.6;margin-bottom:6px;padding:8px 10px}.rfm-explain-card:last-child{margin-bottom:0}.rfm-explain-analogy{background:#eff6ff;border-left:3px solid #60a5fa}.rfm-explain-key{background:#f0fdf4;border-left:3px solid #4ade80}.rfm-explain-boundary{background:#fff7ed;border-left:3px solid #fb923c}.rfm-explain-tag{align-self:flex-start;background:#dbeafe;border-radius:99px;color:#1d4ed8;flex-shrink:0;font-size:10px;font-weight:700;margin-top:2px;padding:1px 7px;white-space:nowrap}.rfm-tag-boundary{background:#fed7aa;color:#9a3412}.rfm-explain-key .rfm-explain-tag{background:#bbf7d0;color:#166534}.rfm-explain-text{flex:1 1}.rfm-detail-quiz{background:#fff;border:1px solid #e0e7ff;border-radius:8px;box-shadow:0 1px 3px #0000000d;padding:12px 14px}.rfm-dquiz-question{color:#1f2937;font-size:13px;font-weight:600;line-height:1.5;margin-bottom:8px}.rfm-dquiz-options{display:flex;flex-direction:column;gap:5px;margin-bottom:8px}.rfm-dquiz-opt{align-items:flex-start;border:1.5px solid #e2e8f0;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:12.5px;gap:7px;line-height:1.5;padding:7px 10px;transition:background .12s}.rfm-dquiz-opt:hover:not([disabled]){background:#f1f5f9;border-color:#a5b4fc}.rfm-dquiz-opt input{accent-color:#6366f1;flex-shrink:0;margin-top:2px}.rfm-dquiz-correct{background:#dcfce7!important;border-color:#4ade80!important;color:#15803d;font-weight:600}.rfm-dquiz-wrong{background:#fee2e2!important;border-color:#f87171!important;color:#b91c1c}.rfm-dquiz-explain{border-radius:7px;font-size:12px;line-height:1.55;padding:7px 10px}.rfm-dquiz-explain.correct{background:#f0fdf4;border-left:3px solid #22c55e;color:#166534}.rfm-dquiz-explain.wrong{background:#fef2f2;border-left:3px solid #ef4444;color:#991b1b}.rfm-code-blocks{background:#f8fafc;display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding:12px 14px}.rfm-code-block{background:#fff;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;padding:12px 14px;scroll-margin-top:12px;transition:border-color .2s,box-shadow .2s}.rfm-code-block:hover{border-color:#6366f1}.rfm-code-block.active{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.rfm-code-block-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.rfm-code-block-title{color:#1f2937;font-size:13px;font-weight:600}.rfm-code-lang{background:#f1f5f9;border-radius:6px;color:#64748b;font-size:10px;font-weight:600;letter-spacing:.5px;padding:1px 7px;text-transform:uppercase}.rfm-code-comment{color:#6b7280;font-family:Consolas,Monaco,monospace;font-size:12px;font-style:italic;margin-bottom:6px}.rfm-code-pre{background:#0f172a;border-radius:7px;color:#e2e8f0;font-family:Consolas,Monaco,Courier New,monospace;font-size:12.5px;line-height:1.55;margin:0;overflow-x:auto;padding:10px 12px;white-space:pre}.rfm-code-block.active .rfm-code-pre{background:#1e1b4b}.rfm-code-color,.rfm-mini-color{border-radius:50%;height:8px;width:8px}.rfm-code-color{display:inline-block;margin-right:6px;vertical-align:middle}.rfm-code-inline-notes{background:#eef2ff;border-radius:6px;color:#334155;font-size:12px;line-height:1.5;margin-top:8px;padding:8px 10px}.rfm-code-bridge{align-items:flex-start;background:#f0f9ff;border-left:3px solid #93c5fd;border-radius:6px;color:#0c4a6e;display:flex;font-size:12px;gap:6px;margin:2px 4px;padding:6px 10px}.rfm-code-bridge-arrow{color:#6366f1;flex-shrink:0;font-size:14px;line-height:1.2}.rfm-code-bridge-text{line-height:1.5}.rfm-quiz-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-top:6px;padding:12px 14px}.rfm-quiz-title{color:#1f2937;font-size:13px;font-weight:700;margin-bottom:8px}.rfm-quiz-q{color:#334155;display:flex;flex-direction:column;font-size:12px;gap:5px;margin-bottom:10px}.rfm-quiz-qtitle{font-weight:600}.rfm-quiz-q label{align-items:center;display:flex;gap:6px}.rfm-quiz-result{font-size:12px;font-weight:600;margin-top:8px}.rfm-quiz-result.wait{color:#64748b}.rfm-quiz-result.pass{color:#16a34a}.rfm-quiz-option{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:6px;padding:4px 8px;transition:background .15s}.rfm-quiz-option:hover{background:#f1f5f9}.rfm-opt-correct{background:#dcfce7!important;color:#15803d;font-weight:600}.rfm-opt-wrong{background:#fee2e2!important;color:#b91c1c}.rfm-quiz-explain{border-radius:6px;font-size:11.5px;line-height:1.5;margin-top:4px;padding:6px 8px}.rfm-explain-correct{background:#f0fdf4;border-left:3px solid #22c55e;color:#166534}.rfm-explain-wrong{background:#fef2f2;border-left:3px solid #ef4444;color:#991b1b}.rfm-quiz-q.correct,.rfm-quiz-q.wrong{border-left:none}.rfm-code-annotations{display:flex;flex-direction:column;gap:5px;margin-top:8px}.rfm-code-ann-item{align-items:flex-start;background:#fefce8;border-left:3px solid #facc15;border-radius:6px;color:#78350f;display:flex;font-size:11.5px;gap:6px;line-height:1.5;padding:4px 8px}.rfm-code-ann-line{color:#92400e;flex-shrink:0;font-weight:700}.rfm-code-ann-note{flex:1 1}.rfm-code-ann-hint{color:#94a3b8;font-size:11px;font-style:italic;margin-top:6px}
/*# sourceMappingURL=main.aeabefbc.css.map*/