.module-workspace{display:flex;flex-direction:column;height:100vh;background-color:#f5f7fa}.module-header{background:#fff;padding:20px 40px;border-bottom:2px solid #e1e8ed;box-shadow:0 2px 4px #0000000d}.back-link{color:#667eea;text-decoration:none;font-size:14px;font-weight:600;margin-bottom:8px;display:inline-block}.back-link:hover{text-decoration:underline}.module-header h1{margin:8px 0;color:#2c3e50;font-size:28px}.module-progress-indicator{display:flex;align-items:center;gap:8px;margin-top:12px}.level-dot{width:32px;height:32px;border-radius:50%;background:#ecf0f1;color:#95a5a6;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;transition:all .3s}.level-dot.active{background:#667eea;color:#fff}.completion-badge{margin-left:12px;padding:6px 12px;background:#27ae60;color:#fff;border-radius:12px;font-size:13px;font-weight:600}.module-error{background:#e74c3c;color:#fff;padding:12px 40px;font-size:14px}.three-pane-container{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;height:calc(100vh - 120px);overflow:hidden}.pane{display:flex;flex-direction:column;background:#fff;border-right:2px solid #e1e8ed;overflow:hidden}.pane:last-child{border-right:none}.pane-guide{background:#fefefe}.pane-console{background:#f9fafb}.pane-canvas{background:#fff}.pane-title{padding:16px 20px;margin:0;font-size:16px;font-weight:600;color:#2c3e50;border-bottom:2px solid #e1e8ed;background:#f8f9fa;display:flex;align-items:center;justify-content:space-between}.lock-indicator{font-size:12px;color:#e74c3c;font-weight:500}.guide-content{padding:24px;overflow-y:auto;flex:1}.instruction-box{background:#e8f4f8;border:2px solid #3498db;border-radius:8px;padding:20px;margin-bottom:20px}.instruction-box h2{margin-top:0;color:#2980b9}.feedback-box{background:#fef5e7;border:2px solid #f39c12;border-radius:8px;padding:20px;margin-bottom:20px}.feedback-box h3{margin-top:0;color:#e67e22}.reflection-input-area{background:#fff4e6;border:2px solid #f39c12;border-radius:8px;padding:20px}.reflection-input-area h3{margin-top:0;color:#e67e22}.reflection-input-area textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;resize:vertical;margin-bottom:12px}.reflection-input-area textarea:focus{outline:none;border-color:#f39c12}.btn-primary{width:100%;padding:12px;background:#f39c12;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){background:#e67e22;transform:translateY(-2px);box-shadow:0 4px 12px #e67e224d}.btn-primary:disabled{background:#95a5a6;cursor:not-allowed}.pane-console.locked{opacity:.6;pointer-events:none}.locked-message,.completed-message{padding:40px 20px;text-align:center;color:#7f8c8d}.prompt-input-area{padding:24px;display:flex;flex-direction:column;height:100%}.prompt-input-area textarea{flex:1;padding:16px;border:2px solid #e1e8ed;border-radius:8px;font-family:Courier New,monospace;font-size:14px;resize:none;margin-bottom:16px}.prompt-input-area textarea:focus{outline:none;border-color:#667eea}.btn-submit{padding:14px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-submit:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-submit:disabled{background:#95a5a6;cursor:not-allowed}.output-tabs{display:flex;background:#f8f9fa;border-bottom:2px solid #e1e8ed}.output-tab{flex:1;padding:12px 16px;background:transparent;border:none;border-right:1px solid #e1e8ed;cursor:pointer;font-size:14px;font-weight:600;color:#7f8c8d;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.output-tab:last-child{border-right:none}.output-tab:hover:not(:disabled){background:#ecf0f1}.output-tab.active{background:#fff;color:#667eea;border-bottom:3px solid #667eea;margin-bottom:-2px}.output-tab.empty{opacity:.5;cursor:not-allowed}.output-tab:disabled{cursor:not-allowed}.tab-indicator{color:#27ae60;font-size:10px}.output-display{flex:1;overflow-y:auto;padding:24px}.output-content{background:#fff}.output-meta{display:flex;justify-content:space-between;padding:12px;background:#f8f9fa;border-radius:6px;margin-bottom:16px;font-size:13px;color:#7f8c8d}.output-content h1,.output-content h2,.output-content h3{color:#2c3e50;margin-top:24px;margin-bottom:12px}.output-content p{line-height:1.8;margin-bottom:16px;color:#34495e}.output-content ul,.output-content ol{margin-bottom:16px;padding-left:24px}.output-content li{margin-bottom:8px;line-height:1.6}.output-empty{height:100%;display:flex;align-items:center;justify-content:center;text-align:center;color:#95a5a6;font-size:16px}@media (max-width: 1200px){.three-pane-container{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.pane-canvas{grid-column:1 / -1}}@media (max-width: 768px){.three-pane-container{grid-template-columns:1fr;grid-template-rows:auto auto auto}.pane{border-right:none;border-bottom:2px solid #e1e8ed}.pane:last-child{border-bottom:none}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:320px;background-color:#fff;border-right:1px solid #e0e0e0;padding:20px;overflow-y:auto;flex-shrink:0}.sidebar h2{font-size:18px;margin-bottom:20px;color:#333}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:#555}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit}.form-group textarea{resize:vertical;min-height:80px}.mode-selector{margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0}.mode-info{margin-top:10px;padding:12px;background-color:#f8f9fa;border-left:3px solid #007bff;font-size:13px;color:#666;line-height:1.4}.main-content{flex:1;display:flex;flex-direction:column;background-color:#fafafa;overflow:hidden}.header{background-color:#fff;border-bottom:1px solid #e0e0e0;padding:20px 30px}.header h1{font-size:24px;color:#333;margin-bottom:5px}.header p{font-size:14px;color:#666}.chat-container{flex:1;overflow-y:auto;padding:20px 30px;display:flex;flex-direction:column;gap:20px}.message{display:flex;flex-direction:column;max-width:85%;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-header{font-size:12px;color:#666;margin-bottom:6px;font-weight:500}.message-content{padding:15px 18px;border-radius:12px;line-height:1.6;word-wrap:break-word}.message.user .message-content{background-color:#007bff;color:#fff}.message.assistant .message-content{background-color:#fff;color:#333;border:1px solid #e0e0e0}.message-content p{margin-bottom:10px}.message-content p:last-child{margin-bottom:0}.message-content ul,.message-content ol{margin-left:20px;margin-bottom:10px}.message-content code{background-color:#f5f5f5;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:13px}.message.user .message-content code{background-color:#fff3}.reflection-prompt{margin-top:12px;padding:15px;background-color:#fff8e1;border-left:3px solid #ffc107;border-radius:4px}.reflection-prompt h4{font-size:14px;margin-bottom:12px;color:#333}.rating-group{margin-bottom:12px}.rating-group label{display:block;font-size:13px;margin-bottom:6px;color:#555}.rating-buttons{display:flex;gap:8px}.rating-button{padding:6px 12px;border:1px solid #ddd;background-color:#fff;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s}.rating-button:hover{background-color:#f5f5f5}.rating-button.selected{background-color:#007bff;color:#fff;border-color:#007bff}.reflection-textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:13px;font-family:inherit;resize:vertical;min-height:60px;margin-bottom:10px}.submit-reflection-btn{padding:8px 16px;background-color:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:background-color .2s}.submit-reflection-btn:hover{background-color:#218838}.submit-reflection-btn:disabled{background-color:#ccc;cursor:not-allowed}.input-area{background-color:#fff;border-top:1px solid #e0e0e0;padding:20px 30px}.input-container{display:flex;gap:10px;align-items:flex-end}.input-container textarea{flex:1;padding:12px 15px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit;resize:none;min-height:50px;max-height:150px}.input-container textarea:focus{outline:none;border-color:#007bff}.send-button{padding:12px 24px;background-color:#007bff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s;white-space:nowrap}.send-button:hover{background-color:#0056b3}.send-button:disabled{background-color:#ccc;cursor:not-allowed}.export-button{margin-top:20px;padding:10px 16px;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;width:100%;transition:background-color .2s}.export-button:hover{background-color:#5a6268}.loading{text-align:center;padding:20px;color:#666}.error-message{padding:15px;background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px;margin:10px 0;font-size:14px}.empty-state{text-align:center;padding:60px 20px;color:#999}.empty-state h3{font-size:20px;margin-bottom:10px}.empty-state p{font-size:14px}.admin-container{display:flex;height:100vh;background-color:#f5f7fa}.admin-login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.admin-login-box{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:400px}.admin-login-box h1{margin-bottom:10px;color:#333;font-size:28px}.login-subtitle{color:#666;margin-bottom:30px;font-size:14px}.btn-primary{width:100%;padding:12px;background-color:#667eea;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s}.btn-primary:hover{background-color:#5568d3}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.admin-sidebar{width:250px;background-color:#2c3e50;color:#fff;padding:20px 0;flex-shrink:0}.admin-sidebar-header{padding:0 20px 20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:20px}.admin-sidebar-header h2{font-size:20px;margin-bottom:5px}.admin-sidebar-header p{font-size:13px;color:#ffffffb3}.admin-nav{list-style:none}.admin-nav a{display:block;padding:12px 20px;color:#fffc;text-decoration:none;transition:background-color .2s}.admin-nav a:hover{background-color:#ffffff1a}.admin-nav a.active{background-color:#34495e;color:#fff;border-left:3px solid #3498db}.admin-logout-btn{margin:20px;padding:10px;background-color:#e74c3c;color:#fff;border:none;border-radius:6px;cursor:pointer;width:calc(100% - 40px);font-size:14px}.admin-logout-btn:hover{background-color:#c0392b}.admin-main{flex:1;overflow-y:auto;padding:30px}.admin-header{margin-bottom:30px}.admin-header h1{font-size:28px;color:#2c3e50;margin-bottom:8px}.admin-header p{color:#7f8c8d;font-size:14px}.admin-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px;margin-bottom:24px}.admin-card h2{font-size:20px;margin-bottom:16px;color:#2c3e50}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.stat-value{font-size:32px;font-weight:700;color:#3498db;margin-bottom:5px}.stat-label{font-size:14px;color:#7f8c8d}.admin-table{width:100%;border-collapse:collapse}.admin-table th{text-align:left;padding:12px;background-color:#f8f9fa;color:#2c3e50;font-weight:600;font-size:14px;border-bottom:2px solid #dee2e6}.admin-table td{padding:12px;border-bottom:1px solid #dee2e6;font-size:14px}.admin-table tr:hover{background-color:#f8f9fa}.btn-secondary{padding:8px 16px;background-color:#95a5a6;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;margin-right:8px}.btn-secondary:hover{background-color:#7f8c8d}.btn-success{padding:8px 16px;background-color:#27ae60;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px}.btn-success:hover{background-color:#229954}.btn-danger{padding:8px 16px;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px}.btn-danger:hover{background-color:#c0392b}.btn-small{padding:6px 12px;font-size:12px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:30px;border-radius:8px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h2{font-size:22px;color:#2c3e50}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#7f8c8d}.modal-close:hover{color:#2c3e50}.modal-content .form-group{margin-bottom:20px}.modal-content label{display:block;margin-bottom:8px;font-weight:500;color:#2c3e50}.modal-content input,.modal-content textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.annotation-panel{background:#f8f9fa;padding:16px;border-radius:6px;margin-top:12px}.annotation-section{margin-bottom:16px}.annotation-section h4{font-size:14px;color:#2c3e50;margin-bottom:8px}.checkbox-group{display:flex;flex-wrap:wrap;gap:12px}.checkbox-label{display:flex;align-items:center;cursor:pointer}.checkbox-label input{margin-right:6px}.rating-input{display:flex;gap:8px;align-items:center}.rating-input select{padding:6px;border:1px solid #ddd;border-radius:4px}.participant-badge{display:inline-block;padding:4px 12px;background-color:#3498db;color:#fff;border-radius:12px;font-size:12px;font-weight:600}.loading-spinner{text-align:center;padding:40px;color:#7f8c8d}.empty-state{text-align:center;padding:60px 20px;color:#7f8c8d}.empty-state-icon{font-size:48px;margin-bottom:16px}.badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}.badge-primary{background-color:#3498db;color:#fff}.badge-success{background-color:#27ae60;color:#fff}.badge-warning{background-color:#f39c12;color:#fff}.badge-danger{background-color:#e74c3c;color:#fff}.session-messages{max-height:600px;overflow-y:auto;padding:20px;background:#f8f9fa;border-radius:6px}.admin-message{margin-bottom:20px;padding:16px;background:#fff;border-radius:6px;border-left:4px solid #3498db}.admin-message.user-message{border-left-color:#2ecc71}.admin-message-header{display:flex;justify-content:space-between;margin-bottom:12px;font-size:13px;color:#7f8c8d}.admin-message-content{color:#2c3e50;line-height:1.6}@media (max-width: 768px){.admin-container{flex-direction:column}.admin-sidebar{width:100%}.stats-grid{grid-template-columns:1fr}}
