.dashboard{display:flex;height:100vh;overflow:hidden}.dashboard-sidebar{width:250px;background-color:#2c3e50;color:#fff;display:flex;flex-direction:column;overflow-y:auto}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.logo-container{display:flex;align-items:center;margin-bottom:5px}.logo-image{width:32px;height:32px;margin-right:10px;object-fit:contain}.sidebar-header h2{margin:0;font-size:22px;color:#4285f4}.sidebar-header p{margin:5px 0 0;font-size:14px;opacity:.7}.sidebar-menu{flex:1;padding:15px 0}.menu-item{padding:12px 20px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center}.menu-item:hover{background-color:#ffffff1a}.menu-item.active{background-color:#4285f433;border-left:4px solid #4285f4}.menu-item span{margin-left:10px}.sidebar-footer{padding:15px 20px;border-top:1px solid rgba(255,255,255,.1)}.user-info{margin-bottom:10px}.user-info span{display:block;margin-bottom:3px}.user-info small{opacity:.7}.logout-button{width:100%;padding:8px;background-color:#ffffff1a;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.logout-button:hover{background-color:#fff3}.dashboard-content{flex:1;overflow-y:auto;background-color:#f5f5f5;display:flex;flex-direction:column}.content-header{padding:20px;background-color:#fff;box-shadow:0 2px 4px #0000001a;z-index:1}.content-header h1{margin:0;font-size:24px;color:#333}.content-body{flex:1;padding:20px;overflow-y:auto}.search-input{padding:10px;border:1px solid #ddd;border-radius:4px;width:100%;max-width:300px}.action-button{background-color:#4285f4;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;transition:all .3s ease;font-weight:500;box-shadow:0 1px 3px #0000001f;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;line-height:1.5}.action-button:hover{background-color:#3367d6;transform:translateY(-1px);box-shadow:0 2px 8px #4285f44d}.action-button:disabled{background-color:#9eb8e3;cursor:not-allowed}.action-bar{display:flex;align-items:center;gap:10px;margin-bottom:20px}.stats-card,.profile-card,.settings-card{background-color:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.stats-card{text-align:center}.stats-number{font-size:24px;font-weight:700;color:#4285f4}.profile-header{display:flex;align-items:center;margin-bottom:20px}.profile-avatar{width:60px;height:60px;background-color:#4285f4;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:700;margin-right:15px}.profile-info h2{margin:0 0 5px}.profile-info p{margin:0;opacity:.7}.profile-stats{display:flex;justify-content:space-between;margin-top:20px}.stat-item{text-align:center;flex:1}.stat-item h3{font-size:16px;margin:0 0 5px;color:#666}.stat-item p{font-size:20px;font-weight:700;margin:0;color:#4285f4}.form-group label{display:block;margin-bottom:5px;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px}.form-group textarea{min-height:100px;resize:vertical}.form-error{color:#d93025;font-size:12px;margin-top:5px;margin-bottom:0}.form-actions{display:flex;justify-content:flex-end;margin-top:20px;gap:10px}.cancel-button{background-color:#f1f3f4;color:#333;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;transition:background-color .2s}.cancel-button:hover{background-color:#e8eaed}.modal-container{background-color:#fff;border-radius:8px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #eee}.modal-header h2{margin:0;font-size:20px;color:#333}.modal-close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#666}.success-message{text-align:center;padding:20px 0}.success-message p{color:#0f9d58;font-size:18px;font-weight:500}.course-cards,.games-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:15px}.course-card,.game-card{background-color:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.course-image,.game-image{height:150px;background-color:#eee}.course-info,.game-info{padding:15px}.course-info h4,.game-info h4{margin:0 0 5px}.course-info p,.game-info p{margin:0 0 15px;color:#666}.game-stats{display:flex;justify-content:space-between;font-size:14px;color:#666;margin-bottom:15px}.game-categories{display:flex;gap:10px;margin-bottom:20px;overflow-x:auto;padding-bottom:10px}.category-button{padding:8px 16px;background-color:#fff;border:1px solid #ddd;border-radius:20px;cursor:pointer;white-space:nowrap}.category-button.active{background-color:#4285f4;color:#fff;border-color:#4285f4}@media (max-width: 768px){.dashboard{flex-direction:column}.dashboard-sidebar{width:100%;height:auto}.content-body{padding:15px}.profile-stats,.action-bar{flex-direction:column;gap:10px}.course-cards,.games-list{grid-template-columns:1fr}}.placeholder-box,.course-placeholder{background-color:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;padding:30px;text-align:center;margin-bottom:20px}.placeholder-box p,.course-placeholder p{color:#6c757d;font-size:16px;margin:0}.chat-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;height:450px}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column}.chat-message{margin-bottom:15px;max-width:80%;display:flex;flex-direction:column}.ai-message{align-self:flex-start}.message-bubble{padding:12px 16px;border-radius:18px;box-shadow:0 1px 2px #0000001a}.ai-message .message-bubble{background-color:#f0f2f5;color:#333;border-bottom-left-radius:4px}.user-message .message-bubble{background-color:#4285f4;color:#fff;border-bottom-right-radius:4px}.message-info{font-size:12px;margin-top:4px;color:#888;align-self:flex-start}.user-message .message-info{align-self:flex-end}.chat-input{display:flex;padding:15px;border-top:1px solid #eee}.chat-input input{flex:1;padding:10px 15px;border:1px solid #ddd;border-radius:20px;font-size:14px;outline:none}.chat-input input:focus{border-color:#4285f4}.chat-input button{background-color:#4285f4;color:#fff;border:none;border-radius:20px;padding:0 20px;margin-left:10px;cursor:pointer;font-weight:500}.chat-input button:hover{background-color:#3367d6}.api-key-input{position:relative;display:flex}.api-key-input input{flex:1}.toggle-visibility-button{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:#666;cursor:pointer;font-size:18px;padding:0}.agent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:20px}.agent-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px;display:flex;flex-direction:column}.agent-header{display:flex;align-items:flex-start;margin-bottom:10px}.agent-card-avatar{width:120px;height:120px;border-radius:50%;overflow:hidden;margin-right:12px;background-color:#f0f0f0;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid #e0e0e0}.agent-card-avatar img{width:100%;height:100%;object-fit:cover}.agent-card-avatar .avatar-placeholder{font-size:20px;color:#999;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.agent-title-area{flex-grow:1}.agent-header h3{margin:0 8px 0 0;font-size:18px;display:inline-block}.agent-badge{padding:3px 8px;border-radius:12px;font-size:12px;font-weight:500;color:#fff;background-color:#0f9d58;display:inline-block;vertical-align:middle}.agent-description{color:#666;margin:0 0 15px;flex-grow:1;font-size:14px;padding-left:132px}.agent-actions{display:flex;gap:10px;margin-bottom:15px}.agent-actions button{padding:6px 12px;border-radius:4px;border:none;cursor:pointer;font-size:12px}.share-button{background-color:#f1f3f4;color:#333}.share-button.shared{background-color:#4285f4;color:#fff}.edit-button{background-color:#f1f3f4;color:#333}.delete-button{background-color:#f1f3f4;color:#db4437}.agent-meta{font-size:12px;color:#888}.checkbox-group{display:flex;align-items:center;gap:10px}.checkbox-group input{width:auto}.checkbox-group label{margin-bottom:0}.empty-state{text-align:center;padding:40px;background-color:#f8f9fa;border-radius:8px;margin-top:20px}.empty-state p{color:#666;margin-bottom:20px}.loading{text-align:center;padding:40px;color:#666}.visibility-dropdown{padding:10px;width:100%;border-radius:6px;border:1px solid #e0e0e0;background-color:#fff;font-size:14px;margin-bottom:5px}.visibility-dropdown:focus{outline:none;border-color:#1677ff;box-shadow:0 0 0 2px #1890ff1a}.visibility-description{font-size:12px;color:#666;margin-top:5px;padding:5px 0}.visibility-menu{position:absolute;width:200px;background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-top:5px;border:1px solid #e0e0e0;z-index:1000}.visibility-option{padding:12px;cursor:pointer;display:flex;align-items:center;border-bottom:1px solid #f0f0f0}.visibility-option:last-child{border-bottom:none}.visibility-option:hover{background-color:#f5f5f7}.visibility-option.selected{background-color:#f0f7ff;font-weight:500}.visibility-icon{margin-right:10px;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.visibility-details{display:flex;flex-direction:column}.visibility-name{font-size:14px;margin-bottom:2px}.visibility-desc{font-size:12px;color:#666}.modal-container{max-width:550px;width:100%}.visibility-selector{position:relative;width:100%}.visibility-button{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 14px;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;text-align:left;font-size:14px;color:#333;cursor:pointer}.visibility-button:hover{border-color:#bbb}.user-selection-area{margin-top:15px;border:1px solid #eee;border-radius:8px;padding:15px;background-color:#f9f9fb}.user-search input{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;margin-bottom:10px;font-size:14px}.user-search-results{max-height:200px;overflow-y:auto;border:1px solid #eee;border-radius:6px;background-color:#fff}.user-option{padding:12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer}.user-option:last-child{border-bottom:none}.user-option:hover{background-color:#f5f5f7}.user-option.selected{background-color:#f0f7ff}.user-name{font-weight:500;font-size:14px}.user-role{font-size:12px;color:#666;padding:2px 8px;background-color:#f0f0f0;border-radius:12px}.selected-icon{color:#1677ff;font-weight:700}.search-loading,.no-results{padding:15px;text-align:center;color:#666;font-size:14px}.selected-users{margin-top:15px}.selected-users-title{font-size:14px;margin-bottom:10px;color:#666}.selected-users-list{display:flex;flex-wrap:wrap;gap:8px}.selected-user-tag{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;background-color:#f0f7ff;border:1px solid #d7e6fd;border-radius:16px;font-size:12px;color:#1677ff}.remove-user{background:none;border:none;color:#999;font-size:14px;cursor:pointer;padding:0 3px}.remove-user:hover{color:#ff4d4f}.visibility-options{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.visibility-checkbox{display:flex;align-items:center;padding:12px;border-radius:6px;border:1px solid #eaeaea;cursor:pointer;transition:all .2s ease;background-color:#fff}.visibility-checkbox:hover{background-color:#f5f5f7;border-color:#d9d9d9}.visibility-checkbox.selected{background-color:#f0f7ff;border-color:#1677ff}.checkbox-icon{width:20px;height:20px;border:1px solid #d9d9d9;border-radius:4px;display:flex;align-items:center;justify-content:center;margin-right:12px;font-size:14px;color:#1677ff;background:white;transition:all .2s ease}.visibility-checkbox.selected .checkbox-icon{border-color:#1677ff;background-color:#1677ff;color:#fff}.advanced-params-section{margin-bottom:20px;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.advanced-params-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#f5f5f5;cursor:pointer;font-weight:500;transition:background-color .2s}.advanced-params-header:hover{background-color:#eee}.advanced-params-content{padding:16px;border-top:1px solid #e0e0e0;background-color:#fafafa}.dropdown-icon{transition:transform .3s ease}.range-input-container{display:flex;align-items:center;gap:10px}.range-input-container input[type=range]{flex-grow:1}.range-value{min-width:40px;text-align:center;font-weight:500}.param-description{display:block;margin-top:5px;color:#666;font-size:.85em}.advanced-params-content input[type=range]{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:#e0e0e0;outline:none}.advanced-params-content input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:#4a90e2;cursor:pointer}.advanced-params-content input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#4a90e2;cursor:pointer;border:none}.advanced-params-content input[type=number],.advanced-params-content input[type=text]{width:100%;padding:8px 12px;border-radius:4px;border:1px solid #ddd;font-size:14px}.two-column-layout{display:flex;gap:20px;margin-top:20px}.left-column,.right-column{flex:1;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:16px}.tools-container{width:100%;padding:0}.tools-container h3{margin-bottom:20px;font-size:20px;font-weight:600;color:#333}.tools-list{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;width:100%}@media (max-width: 1600px){.tools-list{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1200px){.tools-list{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.tools-list{grid-template-columns:1fr}}.tool-card{background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;justify-content:space-between;min-height:280px}.tool-card:hover{transform:translateY(-6px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.tool-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.tool-header h3{margin:0 0 16px;font-size:18px;font-weight:700;color:#1e293b;letter-spacing:-.02em}.tool-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.tool-status{display:inline-flex;align-items:center;font-size:11px;padding:4px 12px;border-radius:9999px;font-weight:600;white-space:nowrap;letter-spacing:.01em}.status-global{background-color:#dbeafe;color:#1e40af;border:none}.status-always-active{background-color:#fef3c7;color:#b45309;border:none;padding-left:8px}.status-always-active:before{content:"⚡";margin-right:4px;font-size:12px}.tool-info{display:flex;gap:8px;margin-bottom:12px;font-size:14px;line-height:1.8}.tool-type-label{color:#475569;font-weight:500}.tool-type-value{color:#334155}.tool-type{font-size:12px;color:#666;background-color:#eee;border-radius:4px;padding:2px 6px;display:inline-block;margin-bottom:8px}.tool-description{font-size:14px;color:#64748b;margin-bottom:0;margin-top:4px;flex:1;line-height:1.8}.tool-actions{margin-top:auto;padding-top:16px;border-top:1px solid #e2e8f0;display:flex;flex-direction:column;gap:0}.tool-actions-links{display:flex;align-items:center;gap:16px;margin-bottom:12px;min-height:20px}.tool-actions-links a{font-size:12px;color:#64748b;text-decoration:none;transition:color .2s ease}.tool-actions-links a:hover{color:#2563eb}.tool-actions-buttons{display:flex;align-items:center;gap:12px}.tool-actions-buttons .btn-edit{flex:1;background-color:#1e293b;color:#fff;border:none;padding:10px 16px;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.tool-actions-buttons .btn-edit:hover{background-color:#334155}.tool-actions-buttons .btn-edit:focus{outline:none;box-shadow:0 0 0 3px #3341554d}.tool-actions-buttons .btn-delete{flex-shrink:0;width:40px;height:40px;padding:0;background-color:transparent;border:none;border-radius:50%;color:#94a3b8;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.tool-actions-buttons .btn-delete:hover{background-color:#fef2f2;color:#dc2626}.tool-actions-buttons .btn-delete:focus{outline:none;box-shadow:0 0 0 3px #dc26264d}.tool-actions-buttons .btn-delete svg{width:20px;height:20px}.switch{position:relative;display:inline-block;width:40px;height:20px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s;border-radius:20px}.slider:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#2196f3}input:focus+.slider{box-shadow:0 0 1px #2196f3}input:checked+.slider:before{transform:translate(20px)}.tools-selection{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto;border:1px solid #ddd;border-radius:4px;padding:8px}.tool-hint{margin:6px 0 8px;font-size:12px;color:#94a3b8}.tool-selection-item{display:flex;align-items:center;padding:8px;border-radius:4px;cursor:pointer;transition:background-color .2s}.tool-selection-item:hover{background-color:#f0f0f0}.tool-selection-item.selected{background-color:#e6f7ff}.tool-selection-item .checkbox{width:20px;height:20px;border:1px solid #ccc;border-radius:4px;display:flex;align-items:center;justify-content:center;margin-right:10px;font-size:14px;color:#1890ff}.tool-selection-item.selected .checkbox{background-color:#1890ff;border-color:#1890ff;color:#fff}.tool-info{flex:1}.tool-info h4{margin:0 0 4px;font-size:14px}.tool-info p{margin:0;font-size:12px;color:#666}.template-variables{display:flex;flex-direction:column;gap:8px}.variable-item{display:flex;align-items:center}.variable-item input{flex:1;padding:6px 8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.remove-variable{width:24px;height:24px;border:none;background-color:#ff4d4f;color:#fff;border-radius:50%;margin-left:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.add-variable{background-color:#f0f0f0;border:1px dashed #ccc;border-radius:4px;padding:6px;cursor:pointer;text-align:center;margin-top:4px}.add-variable:hover{background-color:#e6e6e6}.template-actions{margin-bottom:8px;text-align:right}.extract-button{padding:4px 8px;font-size:12px;background-color:#1890ff;color:#fff;border:none;border-radius:4px;cursor:pointer}.extract-button:hover{background-color:#40a9ff}.modal-large{width:1000px;max-width:90%}.button-icon{display:flex;align-items:center;padding:6px 12px;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease;margin-right:8px;background:transparent}.button-icon svg{margin-right:5px}.button-icon span{font-size:14px}.button-icon.edit-button{color:#4285f4;border:1px solid #4285f4}.button-icon.edit-button:hover{background-color:#4285f41a}.button-icon.delete-button{color:#ea4335;border:1px solid #ea4335}.button-icon.delete-button:hover{background-color:#ea43351a}.settings-note{background-color:#f8f9fa;border-left:4px solid #4285f4;padding:12px 16px;margin:15px 0;border-radius:4px}.settings-note p{margin:0;color:#555;font-size:14px;line-height:1.5}.api-config-card{background-color:#f9f9f9;border-radius:8px;padding:16px;margin-bottom:16px;border:1px solid #e0e0e0}.api-config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.api-config-title{display:flex;align-items:center;gap:10px}.api-name-input{font-weight:500;padding:8px;border-radius:4px;border:1px solid #ddd}.default-badge{background-color:#4285f4;color:#fff;padding:2px 8px;border-radius:12px;font-size:12px}.set-default-button{background-color:transparent;border:1px solid #4285f4;color:#4285f4;padding:2px 8px;border-radius:12px;font-size:12px;cursor:pointer}.remove-api-button{background-color:transparent;color:#ea4335;border:1px solid #ea4335;padding:4px 8px;border-radius:4px;font-size:12px;cursor:pointer}.api-config-actions{display:flex;justify-content:space-between;align-items:center;margin-top:16px}.add-api-button{display:flex;align-items:center;background-color:transparent;color:#4285f4;border:1px dashed #4285f4;padding:8px 16px;border-radius:4px;font-size:14px;cursor:pointer;gap:8px}.add-api-button:hover{background-color:#4285f40d}.error-message{background-color:#fdeded;border-left:4px solid #ea4335;padding:12px 16px;margin:15px 0;border-radius:4px}.error-message p{margin:0;color:#d93025;font-size:14px;line-height:1.5}.error-message .error-details{font-size:12px;color:#666;margin-top:8px;padding-top:8px;border-top:1px solid #eee;word-break:break-word}.avatar-upload-section{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background-color:#f5f5f7;border-radius:8px;margin-bottom:20px}.avatar-preview{width:240px;height:240px;border-radius:50%;overflow:hidden;background-color:#e0e0e0;display:flex;align-items:center;justify-content:center;margin-bottom:15px;border:2px dashed #ccc;margin-left:auto;margin-right:auto}.agent-avatar{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:36px;color:#999;background-color:#f0f0f0}.upload-avatar-button{background:none;border:none;color:#4285f4;cursor:pointer;font-size:16px;padding:12px 0;width:100%;text-align:center;margin-top:10px}.underlined-text{text-decoration:underline;font-weight:500}.field-hint{font-size:12px;color:#666;margin-top:4px}.agent-header-section{display:flex;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #e0e0e0}.basic-info-section{flex-grow:1;display:flex;flex-direction:column;justify-content:center}.basic-info-section h3{margin:0 0 8px;font-size:18px}.section-description{color:#666;margin:0}.agent-header-layout{display:flex;flex-direction:column;align-items:center;gap:30px;margin-bottom:30px}.avatar-upload-section{width:320px;flex-shrink:0;margin:0 auto}.basic-info-section{flex-grow:1;width:100%;text-align:center}} .basic-info-section{flex-grow:1;width:100%;text-align:center}.custom-tool-code{margin-top:20px;padding:15px;border:1px solid #e0e0e0;border-radius:5px;background-color:#f9f9f9}.custom-tool-code .tool-code-editor{margin-top:0}.custom-tool-code .code-editor-container{margin-bottom:20px}.custom-tool-code .form-error{color:#e74c3c;margin-top:5px;font-size:.9em}.teaching-management-section,.teaching-subsection{padding:20px}.subsection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.subsection-header h2{color:#2c3e50;margin:0;flex:1;text-align:center}.teaching-management-section h1{color:#2c3e50;margin-bottom:10px}.teaching-management-section p{color:#7f8c8d;margin-bottom:30px}.teaching-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:20px}.teaching-card{background:white;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .3s ease;border:2px solid transparent}.teaching-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026;border-color:#3498db}.teaching-card.development{cursor:default;opacity:.7}.teaching-card.development:hover{transform:none;box-shadow:0 2px 8px #0000001a;border-color:transparent}.teaching-card.active{border-color:#3498db;background:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 16px #3498db33}.card-icon{font-size:48px;margin-bottom:16px;display:block}.teaching-card h3{color:#2c3e50;margin-bottom:8px;font-size:20px}.teaching-card p{color:#7f8c8d;margin-bottom:16px;line-height:1.5}.card-stats{color:#3498db;font-weight:600}.development-badge{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;display:inline-block}.teaching-card,.teaching-card *,.teaching-management-section h1,.teaching-management-section h2,.teaching-management-section h3,.teaching-management-section p,.teaching-card .card-stats,.teaching-card .card-icon,.teaching-card .development-badge{user-select:none;-webkit-user-select:none;caret-color:transparent}.section-header h1{color:#2c3e50;margin:0}.back-button{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;transition:background-color .2s}.class-actions{display:flex;gap:12px;margin-bottom:30px}.students-list h3{color:#2c3e50;margin-bottom:20px}.students-table{background:white;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.course-management-section{padding:20px}.course-type-btn{padding:10px 18px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#374151;box-shadow:0 1px 2px #0000000a;cursor:pointer}.list-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.list-header h3{color:#2c3e50;margin:0}.filter-controls{display:flex;gap:12px;align-items:center}.courses-table .table-header{background:#f8f9fa;padding:16px 20px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr;gap:20px;font-weight:600;color:#2c3e50;border-bottom:1px solid #e0e0e0}.courses-table .table-row{padding:16px 20px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr;gap:20px;align-items:center;border-bottom:1px solid #f0f0f0}.courses-table .table-row:last-child{border-bottom:none}.course-title{font-weight:600;color:#2c3e50}.course-description{font-size:12px;color:#6c757d;line-height:1.4}.permission-badge{color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-align:center}.class-selection{margin-top:20px}.class-selection h4{color:#2c3e50;margin-bottom:16px}.class-option{display:flex;align-items:center;gap:8px;padding:8px 12px;background:white;border-radius:6px;border:1px solid #e0e0e0;transition:all .2s}.class-option:hover{border-color:#3498db;background:#f0f8ff}.class-option label{margin:0;cursor:pointer;font-size:14px;color:#2c3e50;flex:1}.tool-header{position:relative}.edit-tool-button{position:absolute;right:10px;top:10px;width:30px;height:30px;background-color:#f5f5f5;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;z-index:10}.edit-tool-button:hover{background-color:#e0e0e0}.edit-icon{font-size:16px;color:#666}.btn-delete-custom{background-color:#fff!important;border:1px solid #dc3545!important;color:#dc3545!important;padding:4px 8px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;min-width:60px;height:24px}.btn-delete-custom:hover{background-color:#dc3545!important;color:#fff!important;border-color:#dc3545!important;transform:translateY(-1px);box-shadow:0 2px 4px #dc354533}.btn-delete-custom:active{transform:translateY(0);box-shadow:0 1px 2px #dc354533}.btn-delete-custom:focus{outline:none;box-shadow:0 0 0 2px #dc354540}.menu-section{margin-bottom:20px}.menu-section-title{padding:10px 20px 5px;font-size:12px;font-weight:600;color:#bdc3c7;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #34495e;margin-bottom:5px}.course-management-section,.game-management-section,.learning-analytics-section,.content-review-section,.user-activity-section{padding:20px}.course-stats,.game-stats,.analytics-charts,.review-stats,.activity-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin:20px 0}.analytics-filters,.activity-filters{display:flex;gap:15px;margin-bottom:20px}.filter-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:white}.review-tabs{display:flex;gap:10px;margin-bottom:20px}.tab-button{padding:8px 16px;border:1px solid #ddd;background:white;border-radius:4px;cursor:pointer;transition:all .2s}.tab-button.active{background:#3498db;color:#fff;border-color:#3498db}.tab-button:hover:not(.active){background:#f8f9fa}.create-class-section{padding:20px;max-width:600px;margin:0 auto}.create-class-form{background:white;padding:30px;border-radius:8px;box-shadow:0 2px 10px #0000001a}.form-group{margin-bottom:25px}.form-input,.form-select{width:100%;padding:12px;border:2px solid #e1e8ed;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-input:focus,.form-select:focus{outline:none;border-color:#3498db}.form-input::placeholder{color:#95a5a6}.file-upload-area{position:relative;margin-bottom:10px}.file-input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.file-upload-label{display:block;padding:12px;border:2px dashed #bdc3c7;border-radius:6px;text-align:center;cursor:pointer;transition:all .2s;background:#f8f9fa}.file-upload-label:hover{border-color:#3498db;background:#e3f2fd}.file-upload-hint{background:#f8f9fa;padding:15px;border-radius:6px;border-left:4px solid #3498db}.file-upload-hint p{margin:0 0 10px;font-weight:600;color:#2c3e50}.file-upload-hint ul{margin:0;padding-left:20px;color:#7f8c8d}.file-upload-hint li{margin-bottom:5px}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px;border-top:1px solid #e1e8ed}.btn{padding:12px 24px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;min-width:100px}.btn-primary:hover:not(:disabled){background:#2980b9}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover{background:#7f8c8d}.class-detail-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.class-detail-section .header-actions{display:flex;gap:12px;align-items:center}.action-button.danger{background:#e74c3c;color:#fff}.status-active{color:#27ae60;font-weight:600}.status-inactive{color:#e74c3c;font-weight:600}.students-table .table-header{display:grid;grid-template-columns:1fr 1fr 1fr 1.5fr .8fr 1fr;gap:15px;padding:12px 15px;background:#f8f9fa;border-radius:6px;font-weight:600;color:#2c3e50}.students-table .table-row{display:grid;grid-template-columns:1fr 1fr 1fr 1.5fr .8fr 1fr;gap:15px;padding:12px 15px;border-bottom:1px solid #e1e8ed;align-items:center;transition:background-color .2s}.students-table .table-row:hover{background:#f8f9fa}.students-table .table-row:last-child{border-bottom:none}.add-student-section{padding:20px;max-width:600px;margin:0 auto}.add-student-form{background:white;padding:30px;border-radius:8px;box-shadow:0 2px 10px #0000001a}.form-hint{background:#e3f2fd;padding:15px;border-radius:6px;border-left:4px solid #2196f3;margin-bottom:25px}.form-hint p{margin:0;color:#1976d2;font-size:14px}.edit-teachers-section{padding:20px;max-width:1000px;margin:0 auto}.edit-teachers-content{background:white;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a}.teachers-list h3{color:#2c3e50;margin-bottom:20px;font-size:18px;font-weight:600}.teachers-table{border:1px solid #e1e8ed;border-radius:8px;overflow:hidden}.teachers-table .table-header{display:grid;grid-template-columns:1fr 1fr 1fr;gap:15px;padding:12px 15px;background:#f8f9fa;border-bottom:1px solid #e1e8ed;font-weight:600;color:#2c3e50}.teachers-table .table-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:15px;padding:12px 15px;border-bottom:1px solid #e1e8ed;align-items:center;transition:background-color .2s}.teachers-table .table-row:hover{background:#f8f9fa}.teachers-table .table-row:last-child{border-bottom:none}.subject-name{font-weight:500;color:#2c3e50}.teacher-name{color:#34495e}.row-actions{display:flex;gap:8px}.btn-small{padding:4px 8px;font-size:12px;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.btn-small:not(.danger){background:#3498db;color:#fff}.btn-small:not(.danger):hover{background:#2980b9}.btn-small.danger{background:#e74c3c;color:#fff}.loading{text-align:center;padding:40px;color:#7f8c8d;font-size:16px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:white;border-radius:8px;padding:0;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:#111827}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#374151}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb}.loading-text{font-size:14px;color:#6b7280;margin-top:8px}.profile-header p{color:#7f8c8d;font-size:16px}.error-state{text-align:center;padding:40px;color:#e74c3c}.error-state p{font-size:16px}.agent-header-layout{display:flex;flex-direction:row;gap:20px;margin-bottom:20px}.avatar-upload-section.square{width:150px;flex-shrink:0}.avatar-upload-section.square .avatar-preview{width:150px;height:150px;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5;margin-bottom:10px}.avatar-upload-section.square .avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-upload-section.square .avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#e1e1e1;font-size:36px;color:#666}.basic-info-section{flex-grow:1}.upload-avatar-button{width:100%;padding:8px;background:transparent;border:1px dashed #ccc;border-radius:4px;cursor:pointer;color:#06c;font-size:14px}.upload-avatar-button:hover{background-color:#f0f0f0}.underlined-text{text-decoration:underline}.form-group label{display:block;margin-bottom:6px;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-error{color:#d32f2f;font-size:12px;margin-top:4px}.tools-section{padding:20px;width:100%}.tools-container{margin-top:20px}.tools-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:20px}.tool-card{background-color:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;position:relative;overflow:hidden;display:flex;flex-direction:column}.tool-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px #00000026}.tool-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;border-bottom:1px solid #eee;padding-bottom:8px}.tool-header h3{margin:0;font-size:18px;color:#333}.tool-status{font-size:.8rem;padding:3px 8px;border-radius:12px;font-weight:500}.tool-badges{display:flex;gap:8px}.status-global{background-color:#e3f2fd;color:#0d6efd;display:inline-flex;align-items:center}.status-global:before{content:"🌐";margin-right:4px}.status-always-active{background-color:#fff3cd;color:#856404;display:inline-flex;align-items:center}.status-always-active:before{content:"⚡";margin-right:4px}.tool-info{display:flex;align-items:center;margin-bottom:8px;font-size:14px}.tool-type-label{color:#6c757d;margin-right:4px}.tool-type-value{font-weight:500;color:#495057;background-color:#f1f3f5;padding:2px 6px;border-radius:4px}.tool-description{margin:8px 0 16px;color:#6c757d;flex:1}.tool-actions{display:flex;justify-content:space-between;gap:10px;margin-top:15px}.tool-actions .btn{flex:1;padding:6px 12px;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-primary{background-color:#0d6efd;color:#fff;border:1px solid #0d6efd}.btn-outline-primary{background-color:transparent;color:#0d6efd;border:1px solid #0d6efd}.btn-warning{background-color:#ffc107;color:#212529;border:1px solid #ffc107}.btn-outline-warning{background-color:transparent;color:#ffc107;border:1px solid #ffc107}.edit-button{color:#0d6efd}.edit-button:hover{background-color:#e7f1ff;border-color:#0d6efd}.toggle-button{color:#6c757d;position:relative;overflow:hidden}.toggle-button:hover{background-color:#f1f3f5}.tool-card:has(.status-global) .toggle-button{color:#0d6efd;border-color:#0d6efd}.tool-card:has(.status-global) .toggle-button:hover{background-color:#e7f1ff}.delete-button{color:#dc3545}.delete-button:hover{background-color:#f8d7da;border-color:#dc3545}.empty-state{text-align:center;padding:40px 0;color:#6c757d}.empty-state p{margin-bottom:20px}.action-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.action-buttons{display:flex;gap:10px;align-items:center}.action-button{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;line-height:1.5;font-weight:500;text-align:center;background-color:#0d6efd;color:#fff}.action-button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0d6efd4d;background-color:#0b5ed7}.action-button.secondary{background-color:#f8f9fa;color:#212529;border:1px solid #ced4da}.action-button.secondary:hover{background-color:#e9ecef;border-color:#adb5bd;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.search-input{padding:8px 12px;border:1px solid #ced4da;border-radius:4px;width:300px}.checkbox-group{display:flex;align-items:center;margin-bottom:8px}.checkbox-group input[type=checkbox]{margin-right:8px;width:16px;height:16px;cursor:pointer}.checkbox-group label{cursor:pointer;font-weight:500}.form-hint{font-size:.85rem;color:#6c757d;margin-top:4px;margin-left:24px}.btn-secondary{background-color:#6c757d;color:#fff;border:1px solid #6c757d}.btn-secondary:hover{background-color:#5a6268;border-color:#545b62}.btn-icon{min-width:36px;width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;font-size:16px;flex:none!important}.btn-danger{background-color:#dc3545;color:#fff;border:1px solid #dc3545}.btn-danger:hover{background-color:#c82333;border-color:#bd2130}.delete-modal-overlay{background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.delete-confirm-modal{background:white;border-radius:16px;box-shadow:0 20px 40px #00000026;max-width:420px;width:90%;padding:0;position:relative;animation:slideIn .3s ease-out;overflow:hidden}.delete-modal-icon{text-align:center;padding:24px 24px 16px;background:linear-gradient(135deg,#fff5f5 0%,#fed7d7 100%)}.warning-icon{font-size:48px;animation:pulse 2s infinite}.delete-modal-content{padding:0 24px 24px;text-align:center}.delete-modal-title{font-size:20px;font-weight:600;color:#2d3748;margin:0 0 12px}.delete-modal-message{font-size:16px;color:#4a5568;margin:0 0 8px;line-height:1.5}.tool-name-highlight{font-weight:600;color:#e53e3e}.delete-modal-warning{font-size:14px;color:#718096;margin:0;line-height:1.4}.delete-modal-actions{display:flex;gap:12px;padding:20px 24px 24px;background:#f7fafc}.delete-cancel-btn{flex:1;padding:12px 20px;border:2px solid #e2e8f0;background:white;color:#4a5568;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.delete-cancel-btn:hover{background:#f7fafc;border-color:#cbd5e0;transform:translateY(-1px)}.delete-confirm-btn{flex:1;padding:12px 20px;border:none;background:linear-gradient(135deg,#e53e3e 0%,#c53030 100%);color:#fff;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.delete-confirm-btn:hover{background:linear-gradient(135deg,#c53030 0%,#9c2626 100%);transform:translateY(-1px);box-shadow:0 4px 12px #e53e3e4d}.delete-confirm-btn .btn-icon{font-size:16px}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.tool-code-editor{display:flex;flex-direction:column;gap:20px;margin-top:15px}.code-editor-container{width:100%}.editor-hint{margin:5px 0 10px;font-size:.9em;color:#666}.code-validation{margin-top:15px;display:flex;flex-direction:column;gap:10px}.validate-button{padding:8px 15px;background-color:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:700;align-self:flex-start}.validate-button:hover{background-color:#218838}.validate-button:disabled{background-color:#6c757d;cursor:not-allowed}.validation-result{padding:10px 15px;border-radius:4px;margin-top:5px}.validation-result.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.validation-result.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.knowledge-management{display:flex;flex-direction:column;height:100%;background:#f5f5f5}.knowledge-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #e0e0e0;background:white;box-shadow:0 2px 4px #0000000d}.knowledge-header h2{margin:0;font-size:20px;color:#333}.search-input{padding:8px 16px;border:1px solid #ddd;border-radius:20px;width:300px;font-size:14px;transition:border-color .2s}.search-input:focus{outline:none;border-color:#1976d2}.knowledge-container{display:flex;flex:1;overflow:hidden}.hierarchy-tree-container{width:30%;min-width:250px;max-width:400px;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;background:white}.mode-switch{padding:12px 16px;border-bottom:1px solid #e0e0e0;display:flex;gap:16px}.mode-switch label{display:flex;align-items:center;gap:6px;cursor:pointer;padding:6px 12px;border-radius:4px;font-size:14px;transition:all .2s}.mode-switch label:hover{background:#f5f5f5}.mode-switch label.active{background:#e3f2fd;color:#1976d2;font-weight:600}.mode-switch input[type=radio]{margin:0}.tree-actions{padding:8px 16px;border-bottom:1px solid #e0e0e0;display:flex;gap:12px}.hierarchy-tree{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px}.hierarchy-tree::-webkit-scrollbar{width:8px}.hierarchy-tree::-webkit-scrollbar-track{background:#f1f1f1}.hierarchy-tree::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.hierarchy-tree::-webkit-scrollbar-thumb:hover{background:#999}.tree-loading,.tree-empty{padding:20px;text-align:center;color:#999;font-size:14px}.tree-node-wrapper{margin-bottom:2px}.tree-node{display:flex;align-items:center;padding:8px 12px;cursor:pointer;border-radius:4px;transition:background .2s;-webkit-user-select:none;user-select:none}.tree-node:hover{background:#f5f5f5}.tree-node.active{background:#e3f2fd;border-left:3px solid #1976d2;font-weight:600;color:#1976d2}.tree-node.depth-0{padding-left:12px}.tree-node.depth-1{padding-left:28px}.tree-node.depth-2{padding-left:44px}.tree-node.depth-3{padding-left:60px}.tree-node.depth-4{padding-left:76px}.expand-icon{width:16px;font-size:10px;margin-right:6px;color:#666}.expand-icon-placeholder{width:16px;margin-right:6px}.node-name{flex:1;font-size:14px}.node-count{font-size:12px;color:#999;margin-left:8px}.tree-children{animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:2000px}}.document-list-container{width:70%;display:flex;flex-direction:column;background:white;overflow:hidden}.breadcrumb{padding:12px 24px;font-size:14px;color:#666;border-bottom:1px solid #e0e0e0;background:#fafafa}.list-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;border-bottom:1px solid #e0e0e0}.doc-count{font-size:14px;color:#666}.toolbar-actions{display:flex;gap:8px}.doc-table{width:100%;border-collapse:collapse;font-size:14px}.doc-table th{text-align:left;padding:12px 16px;background:#f5f5f5;font-weight:600;color:#333;border-bottom:2px solid #ddd;position:sticky;top:0;z-index:1}.doc-table td{padding:12px 16px;border-bottom:1px solid #eee}.doc-table tbody tr:hover{background:#fafafa}.doc-table input[type=checkbox]{cursor:pointer}.btn-primary{background:#1976d2;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.btn-primary:hover{background:#1565c0}.btn-secondary{background:white;color:#333;border:1px solid #ddd;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.btn-secondary:hover{background:#f5f5f5;border-color:#999}.btn-danger{background:#d32f2f;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:background .2s}.btn-danger:hover{background:#b71c1c}.btn-link{background:none;border:none;color:#1976d2;cursor:pointer;padding:4px 8px;font-size:14px;text-decoration:none}.btn-link:hover{text-decoration:underline}.btn-link.btn-danger{color:#d32f2f}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:16px;border-top:1px solid #e0e0e0}.pagination button{padding:6px 12px;border:1px solid #ddd;background:white;border-radius:4px;cursor:pointer;font-size:14px}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination button:hover:not(:disabled){background:#f5f5f5}.loading,.empty-state{padding:40px;text-align:center;color:#999;font-size:14px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s}.modal-content{background:white;padding:24px;border-radius:8px;width:500px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 4px 12px #00000026;animation:slideUp .3s}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content h3{margin:0 0 20px;font-size:18px;color:#333}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:600;font-size:14px;color:#333}.form-group input,.form-group select{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#1976d2}.form-group input[type=file]{padding:4px}.file-info{margin-top:8px;font-size:12px;color:#666}.hint{font-size:12px;color:#666;margin-top:4px;display:block}.progress-bar{width:100%;height:32px;background:#f0f0f0;border-radius:16px;position:relative;margin:16px 0;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50 0%,#66bb6a 100%);border-radius:16px;transition:width .3s}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;font-weight:600;color:#333}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}@media (max-width: 1200px){.hierarchy-tree-container{width:35%}.document-list-container{width:65%}}@media (max-width: 768px){.knowledge-container{flex-direction:column}.hierarchy-tree-container,.document-list-container{width:100%;max-width:100%}.hierarchy-tree-container{max-height:300px}}.action-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px 20px;background:white;border-radius:8px;box-shadow:0 2px 8px #0000001a}.filter-controls,.action-controls{display:flex;gap:12px;align-items:center}.action-button{background:#007bff;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;line-height:1.5}.action-button:hover{background:#0056b3;transform:translateY(-1px);box-shadow:0 2px 8px #007bff4d}.role-filter{padding:8px 12px;border:1px solid #ddd;border-radius:6px;background:white;font-size:14px;min-width:120px}.user-list-loading{margin-left:10px;font-size:12px;color:#6b7280}.user-list-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e5e7eb;background:white;margin-top:10px}.user-list-table{width:100%;border-collapse:collapse}.user-list-th{background:#f9fafb;padding:12px 16px;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;font-size:14px}.user-list-td{padding:12px 16px;border-bottom:1px solid #f3f4f6;font-size:14px;color:#374151}.user-list-tr:hover{background:#f9fafb}.user-status-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.user-status-active{background:#d1fae5;color:#065f46}.user-status-inactive{background:#fee2e2;color:#991b1b}.user-delete-btn{background:#ef4444;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s}.user-delete-btn:hover{background:#dc2626}.user-delete-disabled{color:#9ca3af;font-size:12px;font-style:italic}.user-actions{display:flex;gap:8px;align-items:center}.user-view-btn{background:#2196F3;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s}.user-view-btn:hover{background:#1976D2}.user-list-error{text-align:center;padding:40px 20px;color:#ef4444;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-top:20px}.user-list-error button{margin-left:10px;padding:4px 12px;background:#ef4444;color:#fff;border:none;border-radius:4px;cursor:pointer}.user-list-empty{text-align:center;padding:60px 20px;color:#6b7280;background:#f9fafb;border-radius:8px;margin-top:20px}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding:16px 20px;background:white;border-radius:8px;box-shadow:0 2px 8px #0000001a}.pagination-btn{padding:8px 16px;border:1px solid #ddd;border-radius:6px;background:white;color:#374151;cursor:pointer;font-size:14px;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{display:flex;align-items:center;gap:8px;font-size:14px;color:#6b7280}.total-count{font-size:12px;color:#9ca3af}@media (max-width: 768px){.user-list-th,.user-list-td{padding:8px 12px;font-size:13px}.user-list-table-container{font-size:12px}.user-delete-btn{padding:4px 8px;font-size:11px}}.user-delete-btn{padding:4px 8px;font-size:11px}} .memory-viewer-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;padding:20px}.memory-viewer-modal{background:white;border-radius:12px;width:95%;max-width:1200px;max-height:90vh;overflow:hidden;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column}.memory-viewer-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid #e0e0e0;background:#f8f9fa}.memory-viewer-header h2{margin:0;color:#333;font-size:1.5rem}.close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:5px 10px;border-radius:50%;transition:background-color .2s}.close-button:hover{background-color:#f0f0f0;color:#333}.memory-viewer-tabs{display:flex;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.tab-button{flex:1;padding:15px 20px;border:none;background:none;cursor:pointer;font-size:16px;color:#666;transition:all .2s;border-bottom:3px solid transparent}.tab-button:hover{background-color:#e9ecef}.tab-button.active{color:#4caf50;background-color:#fff;border-bottom-color:#4caf50}.memory-sub-tabs{display:flex;gap:10px;margin-bottom:20px;padding:0 10px}.sub-tab-button{padding:8px 16px;border:2px solid #e0e0e0;background:white;border-radius:20px;cursor:pointer;font-size:14px;color:#666;transition:all .2s}.sub-tab-button:hover{border-color:#4caf50;color:#4caf50}.sub-tab-button.active{background:#4CAF50;color:#fff;border-color:#4caf50}.memory-viewer-content{flex:1;padding:20px 30px;overflow-y:auto}.memory-viewer-loading{text-align:center;padding:60px 20px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #4CAF50;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.memory-viewer-error{text-align:center;padding:40px 20px}.retry-button{background:#4CAF50;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;margin-top:15px}.retry-button:hover{background:#45a049}.no-data{text-align:center;padding:60px 20px;color:#666}.no-data p{font-size:18px;margin-bottom:10px}.stats-section{display:flex;gap:20px;margin-bottom:30px;flex-wrap:wrap}.stat-card{background:linear-gradient(135deg,#4CAF50,#45a049);color:#fff;padding:20px;border-radius:10px;text-align:center;min-width:120px;flex:1}.stat-label{font-size:.9rem;opacity:.9}.summary-section{margin-bottom:30px}.summary-section h3{color:#333;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #4CAF50}.summary-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px}.summary-meta{color:#666;font-size:.9rem;margin-bottom:15px}.summary-content{line-height:1.6;color:#333}.conversations-section h3,.summary-history-section h3{color:#333;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #4CAF50}.conversations-list{display:flex;flex-direction:column;gap:15px}.conversation-item{border:1px solid #e0e0e0;border-radius:8px;padding:15px;transition:box-shadow .2s}.conversation-item:hover{box-shadow:0 2px 8px #0000001a}.conversation-item.human{background:#e3f2fd;border-left:4px solid #2196F3}.conversation-item.ai{background:#f3e5f5;border-left:4px solid #9C27B0}.conversation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.role-badge{font-weight:700;padding:4px 8px;border-radius:4px;font-size:.9rem}.timestamp{color:#666;font-size:.85rem}.conversation-content{line-height:1.5;margin-bottom:10px;color:#333}.expand-button{background:#2196F3;color:#fff;border:none;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:.8rem;margin-left:10px}.expand-button:hover{background:#1976D2}.keywords-section{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:10px}.keywords-label{font-weight:700;color:#666;font-size:.9rem}.keyword-tag{background:#4CAF50;color:#fff;padding:3px 8px;border-radius:12px;font-size:.8rem;display:inline-block}.summary-history-list{display:flex;flex-direction:column;gap:15px}.summary-history-item{border:1px solid #e0e0e0;border-radius:8px;padding:15px;background:#fafafa}.summary-version{font-weight:700;color:#4caf50;font-size:1.1rem;margin-bottom:5px}.summary-date{color:#666;font-size:.9rem;margin-bottom:10px}.summary-text{line-height:1.5;color:#333}.regular-conversations-list{display:flex;flex-direction:column;gap:15px}.regular-conversation-item{border:1px solid #e0e0e0;border-radius:8px;padding:20px;background:#fff;transition:box-shadow .2s}.regular-conversation-item:hover{box-shadow:0 2px 8px #0000001a}.conversation-title{font-size:1.1rem;font-weight:700;color:#333;margin-bottom:10px}.conversation-meta{display:flex;gap:20px;margin-bottom:10px;flex-wrap:wrap}.conversation-meta span{color:#666;font-size:.9rem}.conversation-preview{color:#777;line-height:1.4;font-style:italic}.dates-view{margin-top:20px}.dates-list{display:flex;flex-direction:column;gap:15px}.date-group{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.date-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:15px 20px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e0e0;transition:background-color .2s}.date-header:hover{background:linear-gradient(135deg,#e9ecef,#dee2e6)}.date-title{font-weight:700;color:#333;font-size:1.1rem}.expand-icon{font-size:1.2rem;transition:transform .2s}.date-conversations{padding:15px;background:#fafafa;display:flex;flex-direction:column;gap:12px}.date-conversations .conversation-item{margin-bottom:0;border:1px solid #e0e0e0;background:white}@media (max-width: 768px){.memory-viewer-modal{width:100%;max-width:none;height:100vh;max-height:none;border-radius:0}.memory-viewer-header,.memory-viewer-content{padding:15px 20px}.stats-section{flex-direction:column}.stat-card{min-width:auto}.conversation-meta{flex-direction:column;gap:5px}.memory-sub-tabs{flex-direction:column;gap:8px}.sub-tab-button{text-align:center}.date-header{padding:12px 15px}.date-title{font-size:1rem}.date-conversations{padding:10px}}.edit-class-modal{max-width:600px;width:90%;padding:32px}.edit-class-modal h2{margin:0 0 24px;font-size:22px;font-weight:600;color:#333}.edit-class-modal .error-alert{padding:12px;background:#ffebee;border:1px solid #ef5350;border-radius:6px;color:#c62828;font-size:14px;margin-bottom:16px}.edit-class-modal .form-group{margin-bottom:20px}.edit-class-modal .form-group label{display:block;margin-bottom:8px;font-size:15px;font-weight:500;color:#333}.edit-class-modal .form-group input{width:100%;padding:12px 14px;border:1px solid #ddd;border-radius:6px;font-size:15px;box-sizing:border-box;transition:border-color .2s}.edit-class-modal .form-group input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.edit-class-modal .form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.edit-class-modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.edit-class-modal .modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.edit-class-modal .modal-actions button{padding:12px 28px;border:1px solid #ddd;border-radius:6px;background:#fff;cursor:pointer;font-size:15px;font-weight:500;transition:all .2s;min-width:100px}.edit-class-modal .modal-actions button:hover:not(:disabled){background:#f4f6f8}.edit-class-modal .modal-actions button.primary{background:#1976d2;color:#fff;border-color:#1976d2}.edit-class-modal .modal-actions button.primary:hover:not(:disabled){background:#1565c0}.edit-class-modal .modal-actions button:disabled{opacity:.6;cursor:not-allowed}.class-management-section{padding:20px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h1{color:#2c3e50;margin:0;flex:1;text-align:center}.grade-list{max-width:800px}.grade-item{margin-bottom:16px;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.grade-header{background:#f8f9fa;padding:16px 20px;cursor:pointer;display:flex;align-items:center;transition:background-color .2s}.grade-header:hover{background:#e9ecef}.grade-toggle{margin-right:12px;font-size:14px;color:#6c757d;width:20px}.grade-name{font-weight:600;color:#2c3e50;flex:1}.class-count{color:#6c757d;font-size:14px}.classes-list{background:white;padding:0}.class-item{padding:16px 20px;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s}.class-item:hover{background:#f8f9fa}.class-item:last-child{border-bottom:none}.class-name{font-weight:500;color:#2c3e50}.student-count{color:#6c757d;font-size:14px}.empty-classes{padding:40px 20px;text-align:center;color:#6c757d}.create-class-btn{background:#3498db;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;margin-top:12px;transition:background-color .2s}.create-class-btn:hover{background:#2980b9}.class-detail-section{padding:20px}.content-layout{display:flex;gap:20px;margin-top:20px}.students-section{flex:2;background:white;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.teachers-section{flex:1;background:white;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.students-section h3,.teachers-section h3{margin:0 0 20px;color:#000;font-size:18px;font-weight:600}.students-table{width:100%}.students-table .table-header{display:grid;grid-template-columns:1fr 1fr 2fr 1fr;gap:12px;padding:16px 0;border-bottom:2px solid #e0e0e0;font-weight:600;font-size:16px;color:#000;height:48px;align-items:center}.students-table .table-row{display:grid;grid-template-columns:1fr 1fr 2fr 1fr;gap:12px;padding:16px 0;border-bottom:1px solid #f0f0f0;align-items:center;height:48px;font-size:14px}.students-table .table-row:hover{background-color:#f8f9fa}.students-table .col-name{font-weight:500;font-size:14px;color:#000;text-align:center}.students-table .col-id{font-family:monospace;color:#000;font-size:14px;text-align:center}.students-table .col-email{color:#000;font-size:14px;text-align:center}.students-table .col-actions{display:flex;gap:8px;font-size:14px;justify-content:center}.teachers-list{display:flex;flex-direction:column;gap:16px}.teacher-item{display:flex;align-items:center;gap:12px}.subject-label{font-weight:500;color:#2c3e50;min-width:60px}.teacher-select{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:white;font-size:14px}.teacher-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.teacher-dropdown-container{position:relative;flex:1}.teacher-dropdown-trigger{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:white;cursor:pointer;font-size:14px;min-height:36px}.teacher-dropdown-trigger:hover{border-color:#007bff}.selected-teacher{flex:1;color:#333}.dropdown-arrow{color:#6c757d;font-size:12px;transition:transform .2s}.teacher-dropdown-trigger.active .dropdown-arrow{transform:rotate(180deg)}.teacher-dropdown-menu{position:absolute;top:100%;left:0;right:0;background:white;border:1px solid #ddd;border-radius:4px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:200px;overflow:hidden}.search-container{padding:8px;border-bottom:1px solid #e0e0e0}.teacher-search-input{width:100%;padding:6px 8px;border:1px solid #ddd;border-radius:3px;font-size:12px;box-sizing:border-box}.teacher-search-input:focus{outline:none;border-color:#007bff}.teacher-options{max-height:150px;overflow-y:auto}.teacher-option{padding:8px 12px;cursor:pointer;font-size:14px;color:#333;border-bottom:1px solid #f0f0f0}.teacher-option:hover{background-color:#f8f9fa}.teacher-option:last-child{border-bottom:none}.teacher-option.no-results{color:#6c757d;font-style:italic;cursor:default}.teacher-option.no-results:hover{background-color:transparent}.teacher-option.selected{background-color:#e3f2fd;color:#1976d2;font-weight:600}.modal-content{background:white;border-radius:8px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;color:#2c3e50;font-size:20px}.modal-close:hover{color:#495057}.modal-body{padding:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#2c3e50}.form-group input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.class-info{color:#6c757d;font-style:italic}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px;border-top:1px solid #e0e0e0}.btn-cancel{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:14px}.btn-cancel:hover{background:#5a6268}.btn-confirm{background:#007bff;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:14px}.btn-confirm:hover{background:#0056b3}.btn-confirm:disabled{background:#6c757d;cursor:not-allowed}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.section-header h1{color:#2c3e50;margin:0;flex:1;text-align:center;line-height:40px}.section-header .action-button{margin-left:12px}.back-button{background:#6c757d;color:#fff;border:none;height:40px;padding:0 16px;border-radius:6px;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.back-button:hover{background:#5a6268}.action-button{background:#3498db;color:#fff;border:none;height:40px;padding:0 20px;border-radius:6px;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;line-height:1.5}.action-button.danger:hover{background:#c0392b}.students-list h3,.teachers-list h3{color:#2c3e50;margin-bottom:20px}.students-table,.teachers-table{background:white;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.table-header{background:#f8f9fa;padding:16px 20px;display:grid;grid-template-columns:1fr 1fr 1fr 120px;gap:20px;font-weight:600;color:#2c3e50;border-bottom:1px solid #e0e0e0}.teachers-table .table-header{grid-template-columns:1fr 1fr 120px}.table-row{padding:16px 20px;display:grid;grid-template-columns:1fr 1fr 1fr 120px;gap:20px;align-items:center;border-bottom:1px solid #f0f0f0}.teachers-table .table-row{grid-template-columns:1fr 1fr 120px}.class-form-section{padding:20px}.class-form{max-width:600px;background:white;padding:30px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#2c3e50}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:30px}.btn-primary{background:#3498db;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;transition:background-color .2s}.btn-secondary{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;transition:background-color .2s}.btn-secondary:disabled{background:#bdc3c7;cursor:not-allowed}.teacher-classes-section{padding:20px}.classes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:20px}.class-card{background:white;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:transform .2s,box-shadow .2s}.class-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.class-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.class-header h3{color:#2c3e50;margin:0}.grade-badge{background:#3498db;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px}.class-info{margin-bottom:15px}.class-info p{margin:5px 0;color:#6c757d;font-size:14px}.class-actions{text-align:right}.error-message{background:#f8d7da;color:#721c24;padding:12px 16px;border-radius:6px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#721c24;cursor:pointer;font-weight:700}.loading{text-align:center;padding:40px;color:#6c757d;font-size:16px}@media (max-width: 768px){.section-header{flex-direction:column;align-items:flex-start;gap:15px}.header-actions{width:100%;justify-content:flex-end}.class-actions,.form-actions{flex-direction:column}.table-header,.table-row{grid-template-columns:1fr;gap:10px}.table-header span,.table-row span{padding:5px 0}}.tabs-container{display:flex;gap:0;border-bottom:2px solid #e0e0e0;margin-bottom:20px}.tab-button{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;font-size:16px;font-weight:500;color:#6c757d;cursor:pointer;transition:all .3s;position:relative;bottom:-2px}.tab-button:hover{color:#2196f3;background:#f5f5f5}.tab-button.active{color:#2196f3;border-bottom-color:#2196f3;font-weight:600}.groups-section{flex:2;background:white;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.groups-section h3{margin:0 0 20px;color:#000;font-size:18px;font-weight:600}.groups-container{display:flex;flex-direction:column;gap:30px}.group-tag-section{background:#f8f9fa;padding:20px;border-radius:8px}.group-tag-title{margin:0 0 15px;color:#495057;font-size:18px;font-weight:600;padding-bottom:10px;border-bottom:2px solid #dee2e6}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:15px}.group-card{background:white;border:1px solid #dee2e6;border-radius:8px;padding:15px;transition:box-shadow .3s,transform .2s}.group-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.group-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #e9ecef}.group-header h5{margin:0;color:#2c3e50;font-size:16px;font-weight:600;flex:1}.group-actions{display:flex;gap:5px}.group-members{color:#6c757d}.member-count{margin:0 0 10px;font-size:14px;font-weight:500;color:#495057}.member-list{list-style:none;padding:0;margin:0;max-height:150px;overflow-y:auto}.member-list li{padding:5px 8px;margin:3px 0;background:#f8f9fa;border-radius:4px;font-size:13px;color:#495057}.group-modal{max-width:600px;max-height:80vh;overflow-y:auto}.student-selection{max-height:300px;overflow-y:auto;border:1px solid #dee2e6;border-radius:4px;padding:10px;background:#f8f9fa}.student-checkbox{display:flex;align-items:center;padding:8px 10px;margin:4px 0;background:white;border-radius:4px;cursor:pointer;transition:background .2s}.student-checkbox:hover{background:#e3f2fd}.student-checkbox input[type=checkbox]{margin-right:10px;cursor:pointer;width:18px;height:18px}.student-checkbox span{font-size:14px;color:#495057}.selection-count{margin-top:10px;font-size:14px;color:#6c757d;font-weight:500}.empty-state .hint{font-size:14px;color:#6c757d;margin-top:10px}.agent-selector-modal.modal-content{width:1000px!important;max-width:95vw!important;max-height:85vh!important;display:flex;flex-direction:column}.agent-selector-modal .modal-body{flex:1;overflow-y:auto;padding:20px}.agent-selector-modal .agent-grid{display:grid;grid-template-columns:repeat(6,1fr)!important;gap:12px;padding:12px 0}.agent-selector-modal .agent-card{border:2px solid #e0e0e0;border-radius:6px;padding:12px;text-align:center;cursor:pointer;transition:all .2s;position:relative;background:white}.agent-selector-modal .agent-card:hover{border-color:#1976d2;box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.agent-selector-modal .agent-card.selected{border-color:#1976d2;background:#e3f2fd}.agent-selector-modal .agent-avatar{width:60px;height:60px;border-radius:50%;margin:0 auto 8px;object-fit:cover;display:block}.agent-selector-modal .agent-card h3{font-size:14px;margin:4px 0;color:#333;font-weight:500}.agent-selector-modal .agent-desc{font-size:12px;color:#666;line-height:1.3;margin:0;min-height:32px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.agent-selector-modal .selected-badge{position:absolute;top:6px;right:6px;width:22px;height:22px;background:#1976d2;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.agent-selector-modal .no-data{text-align:center;padding:40px 20px;color:#999;font-size:14px}.prompt-editor-modal{width:700px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column}.prompt-editor-modal .modal-body{flex:1;overflow-y:auto;padding:20px}.hint{background:#fff3cd;border:1px solid #ffc107;border-radius:4px;padding:12px;margin-bottom:16px;font-size:14px;line-height:1.6;color:#856404}.prompt-textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;line-height:1.6;resize:vertical;min-height:200px;box-sizing:border-box}.prompt-textarea:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d21a}.char-count{text-align:right;font-size:12px;color:#999;margin-top:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:10000}.modal-content.push-course-modal{width:680px;background:#fff;border-radius:12px;box-shadow:0 12px 48px #0003;overflow:hidden;max-height:80vh;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #eef0f3}.modal-close{background:transparent;border:none;font-size:22px;cursor:pointer}.modal-body{padding:16px}.push-course-modal form{display:flex;flex-direction:column;flex:1 1 auto;min-height:0}.push-course-modal .modal-body{flex:1 1 auto;overflow-y:auto;min-height:0}.push-course-modal .modal-header,.push-course-modal .modal-footer{flex-shrink:0}.modal-footer{padding:12px 16px;display:flex;gap:12px;justify-content:flex-end;border-top:1px solid #eef0f3}.btn{border-radius:8px;padding:8px 14px;border:1px solid #e5e7eb;background:#fff;cursor:pointer}.btn-primary{background:#1677ff;color:#fff;border-color:#1677ff}.course-info{background:transparent;padding:0}.course-info p{margin:2px 0}.selection-header{display:flex;align-items:center;gap:12px;margin:6px 0}.muted{color:#6b7280;font-size:12px}.select-all-btn{margin-left:auto;background:transparent;border:none;color:#1677ff;padding:0;cursor:pointer}.grades-accordion{display:flex;flex-direction:column;gap:4px}.grade-block{border:none}.grade-header{display:flex;align-items:center;gap:10px;padding:6px 0;cursor:pointer;background:transparent;border:none;width:100%;text-align:left}.grade-header .caret{width:14px;color:#6b7280}.grade-header .grade-title{margin-right:4px}.grade-header .spacer{flex:1}.grade-header .link-btn{color:#1677ff;font-size:12px}.grade-header .link-btn.disabled{color:#a3a3a3;cursor:not-allowed}.classes-grid{display:block;padding:0}.classes-grid.list{display:block}.class-option{display:flex;align-items:center;gap:8px;padding:6px 0;margin:0;background:transparent!important;border:none!important;box-shadow:none!important;border-radius:0!important}.class-option+.class-option{border-top:none}.selection-summary{margin-top:8px;color:#374151}.course-management{padding:20px}.course-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:white;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000001a;text-align:center}.stat-card h3{color:#6c757d;font-size:14px;margin-bottom:8px;font-weight:500}.stat-number{color:#2c3e50;font-size:32px;font-weight:700;margin:0}.course-type-tabs{display:flex;gap:20px;margin:12px 0 16px}.course-type-btn{padding:10px 18px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;color:#374151;box-shadow:0 1px 2px #0000000a;cursor:pointer;transition:all .2s}.course-type-btn:hover{background:#f8f9fa}.course-type-btn.active{border-color:#22c55e;color:#16a34a;box-shadow:inset 0 -3px #22c55e33}.courses-list{background:white;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.list-header-compact{padding:12px 20px;border-bottom:1px solid #e0e0e0;display:flex;gap:12px;align-items:center;flex-wrap:wrap}.list-header-compact h3{color:#2c3e50;margin:0 20px 0 0}.filter-select{padding:8px 12px;border:1px solid #ddd;border-radius:6px;background:white;font-size:14px}.search-input{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;min-width:200px}.courses-table{overflow-x:auto}.table-header{background:#f8f9fa;padding:16px 20px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr;gap:20px;font-weight:600;color:#2c3e50;border-bottom:1px solid #e0e0e0}.table-row{padding:16px 20px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr;gap:20px;align-items:center;border-bottom:1px solid #f0f0f0}.table-row:last-child{border-bottom:none}.course-info{display:flex;flex-direction:column;gap:4px}.course-title{font-weight:600;color:#2c3e50;background:transparent}.course-title.clickable{cursor:pointer;transition:color .2s ease}.course-title.clickable:hover{color:#3498db;text-decoration:underline}.course-description{font-size:12px;color:#6c757d;line-height:1.4;max-width:28rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.courses-table .table-row,.courses-table .course-info,.courses-table .course-title{background:transparent!important;box-shadow:none!important;border-radius:0!important}.courses-table .course-info{padding:0!important}.permission-badge{color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-align:center;background:#3498db}.pushed-classes{color:#6c757d;font-size:14px}.course-actions{display:flex;gap:8px}.btn-small{background:#3498db;color:#fff;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px;margin-right:8px;transition:background-color .2s}.btn-small:hover{background:#2980b9}.btn-small.danger{background:#e74c3c}.btn-small.danger:hover{background:#c0392b}.course-detail-container{padding:20px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.section-header h1{color:#2c3e50;margin:0;flex:1;text-align:center}.back-button{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px}.header-actions{display:flex;gap:12px;align-items:center}.action-button{background:#3498db;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;line-height:1.5;font-weight:500;text-align:center}.action-button:hover{background:#2980b9;transform:translateY(-1px);box-shadow:0 2px 8px #3498db4d}.action-button.learn{background:#27ae60}.action-button.learn:hover{background:#229954;transform:translateY(-1px);box-shadow:0 2px 8px #27ae604d}.action-button.danger{background:#e74c3c}.action-button.danger:hover{background:#c0392b;transform:translateY(-1px);box-shadow:0 2px 8px #e74c3c4d}.course-info-card{background:white;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px}.course-info-card h2{color:#2c3e50;margin-bottom:20px;font-size:18px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.info-item{display:flex;align-items:flex-start;gap:12px}.info-item.full-width{grid-column:1 / -1}.info-item label{font-weight:600;color:#6c757d;min-width:100px}.info-item span{color:#2c3e50}.description-text{color:#2c3e50;line-height:1.6;white-space:pre-wrap}.course-content-management{background:white;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px}.course-content-management h2{color:#2c3e50;margin-bottom:20px;font-size:18px}.content-modules{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.content-module{border:1px solid #e0e0e0;border-radius:8px;padding:20px;background:#f8f9fa}.module-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.module-icon{font-size:24px}.module-header h3{color:#2c3e50;margin:0;font-size:16px}.module-content{display:flex;flex-direction:column;gap:12px}.module-button{background:#3498db;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s}.module-button:hover{background:#2980b9}.module-stats{font-size:12px;color:#6c757d}.module-stats p{margin:4px 0}.module-link{background:none;border:none;color:#3498db;cursor:pointer;font-size:12px;text-decoration:underline}.module-link:hover{color:#2980b9}.push-records{background:white;border-radius:8px;padding:24px;box-shadow:0 2px 8px #0000001a}.push-records h2{color:#2c3e50;margin-bottom:20px;font-size:18px}.push-info{display:flex;flex-direction:column;gap:12px}.push-item{display:flex;align-items:center;gap:12px}.push-item label{font-weight:600;color:#6c757d;min-width:120px}.push-item span{color:#2c3e50}.status-active{color:#22c55e!important;font-weight:600}.create-course-modal{max-width:600px;width:90%}.course-form{display:flex;flex-direction:column;gap:16px}.course-form .form-group{display:flex;flex-direction:column;gap:8px}.course-form .form-group label{font-weight:600;color:#2c3e50;font-size:14px}.course-form .form-input,.course-form .form-textarea{padding:12px;border:2px solid #e1e8ed;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.course-form .form-input:focus,.course-form .form-textarea:focus{outline:none;border-color:#3498db}.course-form .form-input:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.course-form .form-textarea{resize:vertical;min-height:100px}.push-course-modal{max-width:700px;width:90%}.course-info{background:#f8f9fa;padding:16px;border-radius:6px;margin-bottom:20px}.course-info h3{color:#2c3e50;margin-bottom:8px;font-size:16px}.course-info p{margin:4px 0;color:#6c757d}.push-target,.push-time{margin-bottom:20px}.push-target label,.push-time label{display:block;font-weight:600;color:#2c3e50;margin-bottom:8px}.class-selection{margin-bottom:20px}.selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.selection-header h4{color:#2c3e50;margin:0;font-size:16px}.select-all-btn{background:#6c757d;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px}.select-all-btn:hover{background:#5a6268}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;max-height:300px;overflow-y:auto;padding:16px;border:1px solid #e0e0e0;border-radius:6px;background:#f8f9fa}.class-option{display:flex;align-items:center;gap:8px}.class-option input[type=checkbox]{margin:0}.class-option label{display:flex;flex-direction:column;cursor:pointer;margin:0}.class-name{font-weight:600;color:#2c3e50}.student-count{font-size:12px;color:#6c757d}.selection-summary{margin-top:12px;padding:12px;background:#e8f5e8;border-radius:6px;color:#22c55e;font-weight:600;text-align:center}.loading{text-align:center;padding:40px;color:#6c757d}.empty-state{padding:40px;text-align:center;color:#6c757d}.empty-state p{margin-bottom:16px}.action-button{background:#3498db;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s}.action-button:hover{background:#2980b9}.btn{padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s;border:none}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn:disabled{background:#95a5a6;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:white;border-radius:8px;box-shadow:0 4px 20px #00000026;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0}.modal-header h2{color:#2c3e50;margin:0;font-size:18px}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#2c3e50}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e0e0e0}.required-badge{background:#f44336;color:#fff;font-size:11px;padding:2px 6px;border-radius:3px;margin-left:6px;font-weight:500}.optional-badge{background:#9e9e9e;color:#fff;font-size:11px;padding:2px 6px;border-radius:3px;margin-left:6px;font-weight:500}.agent-info-compact{display:flex;align-items:center;gap:8px;padding:8px;background:#f5f5f5;border-radius:4px}.agent-avatar-tiny{width:32px;height:32px;border-radius:50%;object-fit:cover}.agent-name{flex:1;font-size:13px;color:#333;font-weight:500}.btn-text-small{background:none;border:none;color:#1976d2;font-size:12px;cursor:pointer;padding:4px 8px;border-radius:3px;transition:background .2s}.btn-text-small:hover{background:rgba(25,118,210,.1)}.material-info-compact{display:flex;align-items:flex-start;gap:10px;padding:10px;background:#f5f5f5;border-radius:6px}.material-cover{font-size:32px;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:white;border-radius:4px;box-shadow:0 1px 3px #0000001a}.material-details{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.material-name{font-size:13px;color:#333;font-weight:500;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.prompt-preview-compact{display:flex;align-items:center;gap:8px;padding:8px;background:#f5f5f5;border-radius:4px}.prompt-text-short{flex:1;font-size:12px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#999;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.btn-cancel{padding:8px 16px;border:1px solid #ddd;background:white;color:#666;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.btn-cancel:hover{background:#f5f5f5;border-color:#bbb}.btn-primary{padding:8px 16px;border:none;background:#1976d2;color:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.btn-primary:hover:not(:disabled){background:#1565c0}cursor: pointer; font-size: 14px; transition: all .2s; } .btn-primary:hover:not(:disabled){background:#1565c0}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.dialog-content{background:white;border-radius:8px;width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 4px 12px #00000026}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid #e8e8e8}.dialog-header h2{margin:0;font-size:18px;font-weight:600}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#999;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .3s}.close-btn:hover{background:#f5f5f5;color:#333}.dialog-body{flex:1;overflow-y:auto;padding:24px}.loading{text-align:center;padding:40px;color:#999}.tree-container{min-height:300px}.tree-node{margin-bottom:4px}.tree-node-content{display:flex;align-items:center;gap:8px;padding:8px;border-radius:4px;cursor:pointer;transition:background .3s}.tree-node-content:hover{background:#f5f5f5}.expand-icon{font-size:12px;width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;color:#666}.expand-icon.expanded{transform:rotate(0)}.expand-icon-placeholder{width:16px;display:inline-block}.node-name{flex:1;font-size:14px;color:#333}.tree-node-children{margin-left:20px}.dialog-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 24px;border-top:1px solid #e8e8e8}.cancel-btn,.submit-btn{padding:8px 24px;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:all .3s}.cancel-btn{background:#f5f5f5;color:#333}.cancel-btn:hover{background:#e8e8e8}.submit-btn{background:#1890ff;color:#fff}.submit-btn:hover{background:#40a9ff}.practice-management{padding:24px;background:#f5f5f5;min-height:100%}.practice-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.practice-header h2{margin:0;font-size:24px;font-weight:600;color:#333}.header-actions{display:flex;gap:12px}.create-btn,.upload-btn{padding:10px 24px;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.create-btn{background:#1890ff}.create-btn:hover{background:#40a9ff;transform:translateY(-2px);box-shadow:0 4px 12px #1890ff4d}.upload-btn{background:#52c41a}.upload-btn:hover{background:#73d13d;transform:translateY(-2px);box-shadow:0 4px 12px #52c41a4d}.loading{text-align:center;padding:60px;font-size:16px;color:#999}.empty-state{text-align:center;padding:80px 20px;background:white;border-radius:8px;box-shadow:0 2px 8px #0000000d}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state p{font-size:16px;color:#999;margin-bottom:24px}.create-btn-large{padding:12px 32px;background:#1890ff;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s}.create-btn-large:hover{background:#40a9ff;transform:translateY(-2px);box-shadow:0 4px 12px #1890ff4d}.practice-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px}.practice-card{background:white;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000000d;transition:all .3s}.practice-card:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.practice-card-header h3{margin:0 0 12px;font-size:18px;font-weight:600;color:#333}.practice-meta{display:flex;gap:16px;font-size:14px;color:#666}.practice-meta .subject{padding:2px 8px;background:#e6f7ff;color:#1890ff;border-radius:4px;font-size:12px}.practice-card-body{margin:16px 0;padding:16px 0;border-top:1px solid #f0f0f0;border-bottom:1px solid #f0f0f0}.practice-info{display:flex;flex-direction:column;gap:12px}.info-item{display:flex;align-items:center;gap:8px;font-size:14px}.info-item .label{color:#999;min-width:80px}.info-item .value{color:#333;font-weight:500}.practice-card-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.action-btn{padding:6px 16px;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:all .3s}.view-btn{background:#52c41a;color:#fff}.view-btn:hover{background:#73d13d}.assign-btn{background:#1890ff;color:#fff}.assign-btn:hover{background:#40a9ff}.edit-btn{background:#faad14;color:#fff}.edit-btn:hover{background:#ffc53d}.details-btn{background:#722ed1;color:#fff}.details-btn:hover{background:#9254de}.delete-btn{background:#ff4d4f;color:#fff}.delete-btn:hover{background:#ff7875}.llm-selector{border:1px solid #e0e0e0;border-radius:8px;padding:16px;margin-bottom:20px;background-color:#f9f9f9}.llm-selector-title{margin-top:0;margin-bottom:10px;font-size:16px;font-weight:600;color:#333}.llm-selector-description{margin-bottom:15px;font-size:14px;color:#666}.llm-selector-content{display:grid;grid-template-columns:1fr 1fr;gap:15px}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500;font-size:14px;color:#333}.form-control{width:100%;padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px}.form-control:focus{border-color:#007bff;outline:none;box-shadow:0 0 0 2px #007bff40}.form-control:disabled{background-color:#e9ecef;cursor:not-allowed}.loading-indicator{font-size:14px;color:#666;margin-top:5px}.error-message{color:#dc3545;font-size:14px;margin-top:8px;padding:8px;background-color:#dc35451a;border-radius:4px;border-left:3px solid #dc3545}.warning-message{color:#f0ad4e;font-size:14px;margin-top:5px}.info-message{color:#5bc0de;font-size:14px;padding:10px;background-color:#f9f9f9;border-radius:4px;border:1px solid #e0e0e0}.required-mark{color:#dc3545;margin-left:4px}.preferred-model{font-weight:500;color:#007bff}.llm-config-container{margin-top:20px;padding:20px;border:1px solid #ddd;border-radius:8px;background-color:#fff}.llm-config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #eee}.llm-config-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.llm-selectors{display:flex;flex-direction:column;gap:15px}.config-error{color:#dc3545;font-size:14px;margin-left:15px}.saving-indicator{margin-top:15px;padding:10px;background-color:#007bff1a;color:#007bff;font-size:14px;border-radius:4px;text-align:center}.llm-config-button{margin:20px 0;text-align:center}.action-button{padding:10px 20px;background-color:#007bff;color:#fff;border:none;border-radius:4px;font-size:16px;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;line-height:1.5}.action-button:hover{background-color:#0069d9;transform:translateY(-1px);box-shadow:0 2px 8px #007bff4d}.action-button:focus{outline:none;box-shadow:0 0 0 2px #007bff40}.loading-button{padding:10px 20px;background-color:#6c757d;color:#fff;border:none;border-radius:4px;font-size:16px;display:inline-flex;align-items:center;justify-content:center;gap:10px;cursor:not-allowed}.loading-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s infinite linear}@keyframes spin{to{transform:rotate(360deg)}}.llm-config-error{margin:20px 0;padding:15px;background-color:#dc35451a;border-radius:8px;border-left:4px solid #dc3545}.retry-button{margin-top:10px;padding:8px 16px;background-color:#6c757d;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer}.retry-button:hover{background-color:#5a6268}.llm-config-message{margin:20px 0;padding:15px;background-color:#6c757d1a;border-radius:8px;color:#6c757d;text-align:center;font-style:italic}@media (max-width: 768px){.llm-selector-content{grid-template-columns:1fr}}.dashboard-content{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%)!important}.teacher-overview{padding:24px;max-width:1200px;margin:0 auto;min-height:100vh;background:transparent;border-radius:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:#ffffff;border:1px solid rgba(226,232,240,.8);border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;transition:all .2s ease;box-shadow:0 2px 8px #00000014}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001f;border-color:#d1d5db}.stat-icon{font-size:32px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.stat-content{flex:1}.stat-number{font-size:28px;font-weight:700;color:#1e293b;line-height:1.2;margin-bottom:4px}.stat-label{font-size:14px;color:#64748b;font-weight:500}.quick-actions-section{margin-bottom:32px}.quick-actions-section h2{font-size:20px;font-weight:600;color:#1e293b;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid #f1f5f9;text-shadow:0 1px 2px rgba(255,255,255,.8)}.action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.action-card{background:#ffffff;border:1px solid rgba(226,232,240,.8);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:all .2s ease;text-align:left;box-shadow:0 2px 8px #00000014}.action-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001f;border-color:#3b82f6;background:#fafbff}.action-icon{font-size:24px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.action-text{flex:1}.action-title{font-size:16px;font-weight:600;color:#1e293b;margin-bottom:4px}.action-desc{font-size:13px;color:#64748b;line-height:1.4}.recent-section{margin-bottom:32px}.recent-section h2{font-size:20px;font-weight:600;color:#1e293b;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid #f1f5f9;text-shadow:0 1px 2px rgba(255,255,255,.8)}.activity-card{background:#ffffff;border:1px solid rgba(226,232,240,.8);border-radius:12px;padding:32px;box-shadow:0 2px 8px #00000014}.empty-state{text-align:center;padding:24px}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.6}.empty-text{font-size:18px;font-weight:600;color:#374151;margin-bottom:8px}.empty-desc{font-size:14px;color:#6b7280;line-height:1.5;max-width:400px;margin:0 auto}@media (max-width: 768px){.teacher-overview{padding:16px}.stats-grid{grid-template-columns:1fr;gap:16px}.action-grid{grid-template-columns:1fr;gap:12px}.stat-card,.action-card{padding:16px}.stat-number{font-size:24px}.action-title{font-size:15px}.action-desc{font-size:12px}}@media (max-width: 480px){.stat-card,.action-card{flex-direction:column;text-align:center;gap:12px}}.chat-interface{display:flex;height:100vh;width:100%;overflow:hidden;background-color:#f5f7fa;position:relative}.chat-main{flex:1;display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.selected-assistant{display:flex;align-items:center;padding:10px 20px;background-color:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 1px 3px #0000001a;position:relative}.assistant-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;margin-right:10px}.assistant-info{flex:1;position:relative}.assistant-selector{display:flex;align-items:center;gap:6px}.dropdown-toggle{background:none;border:none;cursor:pointer;color:#757575;font-size:12px;padding:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:3px}.dropdown-toggle:hover{background-color:#f0f0f0}.assistant-dropdown{position:absolute;top:100%;left:0;width:220px;max-height:300px;overflow-y:auto;background-color:#fff;box-shadow:0 4px 12px #00000026;border-radius:6px;z-index:10;margin-top:5px}.assistant-option{display:flex;align-items:center;padding:10px 12px;cursor:pointer}.assistant-option:hover{background-color:#f5f7fa}.assistant-option.selected{background-color:#e3f2fd}.assistant-option-avatar{width:24px;height:24px;border-radius:50%;margin-right:8px}.assistant-info h3{margin:0;font-size:16px;font-weight:500}.assistant-info p{margin:0;font-size:12px;color:#757575;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.new-conversation-btn{width:30px;height:30px;border-radius:50%;background-color:#2196f3;color:#fff;border:none;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;margin-left:10px}.new-conversation-btn:hover{background-color:#0d8aee}.messages-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px;background-color:#f5f7fa;max-height:calc(100vh - 140px)}.message{max-width:80%;margin-bottom:15px;padding:10px 15px;border-radius:10px;position:relative}.message.user{background-color:#e3f2fd;margin-left:auto;border-bottom-right-radius:0}.message.assistant{background-color:#fff;margin-right:auto;border-bottom-left-radius:0;box-shadow:0 1px 2px #0000001a}.message.system{background-color:#fff3e0;margin:10px auto;max-width:90%;text-align:center;font-style:italic;color:#e65100}.message-content{word-break:break-word;line-height:1.5}.message-time{font-size:10px;color:#9e9e9e;margin-top:5px;text-align:right}.message.loading .loading-indicator{display:flex;align-items:center;justify-content:center;height:20px}.loading-indicator .dot{width:8px;height:8px;background-color:#2196f3;border-radius:50%;margin:0 3px;animation:pulse 1.5s infinite ease-in-out}.loading-indicator .dot:nth-child(2){animation-delay:.2s}.loading-indicator .dot:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,to{transform:scale(.8);opacity:.5}50%{transform:scale(1.2);opacity:1}}.input-container{display:flex;align-items:center;padding:10px 20px;background-color:#fff;border-top:1px solid #e0e0e0;position:relative}.attachment-button{padding:8px;background:none;border:none;cursor:pointer;font-size:18px;color:#757575;margin-right:10px}.attachment-options{position:absolute;bottom:60px;left:20px;background-color:#fff;border-radius:5px;box-shadow:0 2px 10px #0003;padding:10px;z-index:100}.attachment-options button{display:block;width:100%;padding:8px 12px;margin-bottom:5px;text-align:left;background:none;border:none;border-radius:3px;cursor:pointer}.attachment-options button:hover{background-color:#f5f5f5}.attachment-options button:last-child{margin-bottom:0}.workspace-status{display:flex;align-items:center;gap:8px;margin-top:8px;padding:6px 12px;background-color:#e3f2fd;border:1px solid #bbdefb;border-radius:6px;font-size:13px;color:#1565c0}.workspace-icon{font-size:14px}.workspace-path{flex:1;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.workspace-clear{background:none;border:none;color:#1565c0;cursor:pointer;padding:2px 4px;border-radius:3px;font-size:12px;line-height:1}.workspace-clear:hover{background-color:#bbdefb}textarea{flex:1;resize:none;height:40px;max-height:150px;padding:10px;border:1px solid #e0e0e0;border-radius:20px;outline:none;font-family:inherit;font-size:14px;line-height:1.5}textarea:focus{border-color:#2196f3}.send-button{padding:8px 15px;margin-left:10px;background-color:#2196f3;color:#000;border:none;border-radius:20px;cursor:pointer;font-weight:500}.send-button:hover{background-color:#0d8aee;color:#000}.send-button:disabled{background-color:#2196f3;color:#000;opacity:.7;cursor:not-allowed}.empty-chat .chat-input-container.centered{display:none}@media (max-width: 768px){.message{max-width:95%}.empty-chat .chat-input-container{width:95%}}.api-status-error{color:#d32f2f;font-size:12px;background-color:#ffebee;padding:4px 8px;border-radius:4px;white-space:nowrap}.pasted-images-preview{display:flex;gap:10px;padding:10px 20px;background:#f9fafb;border-top:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0;flex-wrap:wrap;max-height:180px;overflow-y:auto}.image-preview-item{position:relative;width:120px;height:120px;border-radius:8px;overflow:hidden;background:#fff;border:2px solid #e0e0e0;display:flex;flex-direction:column}.image-preview-item img{width:100%;height:90px;object-fit:cover}.image-preview-item .image-name{padding:4px 8px;font-size:11px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#f5f5f5;flex:1;display:flex;align-items:center}.remove-image-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1;transition:background .2s}.remove-image-btn:hover{background:rgba(0,0,0,.8)}.message-attachments{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.message-image{max-width:300px;max-height:300px;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.message-image:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.voice-button{padding:10px 16px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:18px;margin-left:8px;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d}.voice-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.voice-button:active:not(:disabled){transform:translateY(0)}.voice-button.active{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{box-shadow:0 2px 8px #f5576c4d}50%{box-shadow:0 4px 16px #f5576c99}}.voice-button:disabled{opacity:.5;cursor:not-allowed}.temp-message{opacity:.8;animation:fadeIn .3s ease-in}.temp-message .message-content{position:relative;border:2px dashed rgba(102,126,234,.3)}.temp-indicator{display:inline-block;font-size:12px;color:#667eea;margin-left:8px;animation:blink 1.5s infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:.8;transform:translateY(0)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.conversation-history{width:250px;height:100%;background-color:#f5f5f5;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden}.history-header{padding:15px;border-bottom:1px solid #e0e0e0}.history-header h3{margin:0;font-size:16px;color:#333}.conversation-list{list-style:none;padding:0;margin:0;overflow-y:auto;flex:1}.conversation-item{padding:12px 15px;border-bottom:1px solid #e0e0e0;cursor:pointer;transition:background-color .2s}.conversation-item:hover{background-color:#e9e9e9}.conversation-item.active{background-color:#e1f5fe;border-left:3px solid #2196f3}.conversation-title{font-size:14px;font-weight:500;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-details{display:flex;justify-content:space-between;font-size:12px;color:#757575}.agent-name{max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-date{text-align:right}.loading-indicator{padding:20px;text-align:center;color:#757575}.error-message{padding:20px;text-align:center;color:#d32f2f}.empty-history{padding:20px;text-align:center;color:#757575}.empty-history p{margin:5px 0}.empty-history .hint{font-size:12px;opacity:.8}.image-preview-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-preview-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.preview-image{max-width:100%;max-height:85vh;object-fit:contain;border-radius:4px;box-shadow:0 10px 40px #00000080}.close-button{position:absolute;top:-40px;right:0;background:rgba(255,255,255,.2);border:none;color:#fff;font-size:32px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.close-button:hover{background:rgba(255,255,255,.3)}.image-name{margin-top:16px;color:#fff;font-size:14px;text-align:center;max-width:90vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 768px){.preview-image{max-height:80vh}.close-button{top:-50px;font-size:28px;width:36px;height:36px}}.chat-container{display:flex;height:calc(100vh - 120px);background-color:#f9f9fb;border-radius:8px;overflow:hidden;box-shadow:0 2px 10px #0000000d}.chat-sidebar{width:280px;background-color:#f9f9fb;border-right:none;padding:15px;display:flex;flex-direction:column;overflow:hidden}.dropdown{position:relative;display:inline-block;width:100%;margin-bottom:15px;z-index:9000}.dropdown-button{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 14px;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:14px;text-align:left;color:#333;transition:all .2s ease}.dropdown-button:hover{border-color:#bbb}.dropdown-button.active{border-color:#1677ff}.dropdown-icon{margin-left:8px;transition:transform .2s ease;color:#999}.dropdown-icon.open{transform:rotate(180deg)}.dropdown-menu{position:fixed;left:50%;transform:translate(-50%);top:100px;width:350px;max-height:450px;overflow-y:auto;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 20px #0000004d;z-index:99999;display:none;scrollbar-width:thin;padding:8px 0}.dropdown-menu.open{display:block}.dropdown-menu::-webkit-scrollbar{width:6px}.dropdown-menu::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.dropdown-menu::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.dropdown-menu::-webkit-scrollbar-thumb:hover{background:#aaa}.chat-container *{z-index:auto!important}.dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0000001a;z-index:9998;display:none}.dropdown-backdrop.show{display:block}.dropdown-search{position:relative;padding:12px 15px;border-bottom:1px solid #eee;margin-bottom:10px}.dropdown-search-input{width:100%;padding:8px 12px 8px 30px;border:1px solid #e0e0e0;border-radius:6px;font-size:13px;background-color:#f5f5f7}.dropdown-search-input:focus{outline:none;border-color:#bbb;background-color:#fff}.dropdown-search-icon{position:absolute;left:25px;top:20px;color:#999;pointer-events:none}.dropdown-item{padding:10px 15px;cursor:pointer;transition:background-color .2s ease}.dropdown-item:hover{background-color:#f5f5f7}.dropdown-item.selected{background-color:#f0f7ff}.dropdown-item-content{display:flex;flex-direction:row;align-items:center}.dropdown-item-icon{width:24px;height:24px;border-radius:50%;background-color:#ddd;display:flex;justify-content:center;align-items:center;margin-right:12px;color:#666;font-size:12px}.dropdown-item-details{flex:1}.dropdown-item-title{font-size:14px;font-weight:500;margin-bottom:2px;display:flex;align-items:center}.link-icon{margin-left:4px;color:#bbb;font-size:12px;visibility:hidden}.dropdown-item:hover .link-icon{visibility:visible}.dropdown-item-description{font-size:12px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agent-creator,.agent-model{display:block;font-size:11px;color:#888;margin-top:2px}.dropdown-empty{padding:16px;color:#888;text-align:center;font-size:14px;min-height:60px;display:flex;align-items:center;justify-content:center}.dropdown-footer{padding:10px 15px;border-top:1px solid #eee;margin-top:8px;display:flex;align-items:center;justify-content:space-between}.temp-chat-label{font-size:13px;color:#666}.toggle-switch{position:relative;display:inline-block;width:40px;height:20px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s;border-radius:34px}.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.toggle-slider{background-color:#1677ff}input:checked+.toggle-slider:before{transform:translate(20px)}.agent-selector h3,.model-selector h3{font-size:16px;margin-bottom:15px;color:#333;font-weight:500}.agent-list{max-height:300px;overflow-y:auto}.agent-item{padding:12px;border-radius:6px;margin-bottom:10px;cursor:pointer;background-color:#f9f9fb;transition:all .2s ease;border:1px solid #eaeaea}.agent-item:hover{background-color:#f0f0f0;border-color:#ddd}.agent-item.selected{background-color:#f0f0f0;border-color:#ddd;box-shadow:0 1px 3px #0000001a}.agent-item h4{margin:0 0 6px;font-size:15px;font-weight:500}.agent-item p{margin:0 0 8px;font-size:13px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid #eaeaea;background-color:#f9f9fb;height:48px}.selected-agent-info{display:flex;align-items:center}.agent-name{font-size:16px;font-weight:500;margin-right:8px}.model-info{font-size:12px;color:#888;background-color:transparent;padding:2px 8px}.chat-main{flex:1;display:flex;flex-direction:column;background-color:#f9f9fb;z-index:1;position:relative}.chat-messages{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column}.welcome-message{text-align:center;margin:auto;max-width:600px;padding:30px}.welcome-message h2{font-size:24px;margin-bottom:16px;color:#222}.welcome-message p{font-size:16px;color:#666;margin-bottom:24px}.suggestion-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}.suggestion-chip{background-color:#f0f0f0;border:1px solid #ddd;color:#333;padding:8px 16px;border-radius:16px;font-size:14px;cursor:pointer;transition:all .2s ease}.suggestion-chip:hover{background-color:#e6e6e6;border-color:#ccc}.message{max-width:75%;margin-bottom:16px;display:flex;flex-direction:column}.user-message{align-self:flex-end}.assistant-message{align-self:flex-start}.message-content{padding:12px 16px;border-radius:12px;font-size:15px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.user-message .message-content{background-color:#343541;color:#fff;border-bottom-right-radius:4px}.assistant-message .message-content{background-color:#f7f7f8;color:#333;border-bottom-left-radius:4px;border:1px solid #eaeaea}.message-timestamp{font-size:12px;color:#999;margin-top:4px;align-self:flex-end}.user-message .message-timestamp{margin-right:4px}.assistant-message .message-timestamp{align-self:flex-start;margin-left:4px}.chat-input{display:flex;padding:16px;border-top:1px solid #eaeaea;background-color:#f9f9fb;position:relative;max-width:768px;margin:0 auto;width:100%}.chat-input-container{position:relative;width:100%;display:flex;align-items:center;background-color:#fff;border-radius:8px;border:1px solid #ddd;box-shadow:0 1px 5px #0000000d}.chat-input input{flex:1;padding:12px 16px;border:none;border-radius:8px;font-size:15px;outline:none;background:transparent;min-height:48px}.chat-input-buttons{display:flex;align-items:center;padding-right:8px}.chat-input button{background:none;border:none;padding:8px;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.send-button{color:#666;transition:color .2s ease}.send-button:hover{color:#1677ff}.send-button:disabled{color:#ccc;cursor:not-allowed}.voice-button{color:#666;margin-right:4px}.voice-button:hover{color:#1677ff}.attach-button{color:#666;margin-right:4px;position:relative}.attach-button:hover{color:#1677ff}.attach-menu{position:absolute;bottom:100%;right:0;background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:8px 0;border:1px solid #eaeaea;z-index:10;min-width:150px;display:none}.attach-menu.show{display:block}.attach-menu-item{padding:8px 16px;display:flex;align-items:center;cursor:pointer;font-size:14px}.attach-menu-item:hover{background-color:#f5f5f5}.attach-menu-item-icon{margin-right:8px;color:#666}.profile-section{padding:10px 20px;max-width:1400px;margin:0 auto}.profile-header{margin-bottom:15px;text-align:center}.profile-header h2{color:#2c3e50;margin-bottom:5px;font-size:24px}.profile-content{background:white;border-radius:12px;padding:20px;box-shadow:0 4px 12px #0000001a}.profile-main{display:grid;grid-template-columns:160px 1fr;gap:20px;align-items:start}.avatar-section{text-align:center}.avatar-container{margin-bottom:15px}.basic-info{display:flex;flex-direction:column;gap:15px}.avatar-image{width:100px;height:100px;border-radius:50%;object-fit:cover;border:4px solid #e1e8ed}.avatar-placeholder{width:100px;height:100px;border-radius:50%;background:#3498db;color:#fff;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700;margin:0 auto;border:4px solid #e1e8ed}.avatar-actions{display:flex;flex-direction:column;gap:10px}.profile-form{display:flex;flex-direction:column;gap:15px}.form-group label{font-weight:600;color:#2c3e50;font-size:14px}.form-input{padding:12px 16px;border:2px solid #e1e8ed;border-radius:8px;font-size:14px;transition:border-color .2s}.form-input:focus{outline:none;border-color:#3498db}.form-input.disabled{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.form-textarea{padding:10px 14px;border:2px solid #e1e8ed;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;min-height:80px;transition:border-color .2s}.form-textarea:focus{outline:none;border-color:#3498db}.subjects-selection{display:flex;flex-wrap:wrap;gap:20px;margin-top:5px;margin-bottom:5px}.subject-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#2c3e50;flex-direction:row-reverse}.subject-checkbox:hover{color:#3498db}.subject-checkbox input[type=checkbox]{width:16px;height:16px;margin:0;cursor:pointer}.subject-checkbox input[type=checkbox]:checked~span{color:#3498db;font-weight:600}.form-actions{margin-top:10px;display:flex;justify-content:flex-end}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover{background:#2980b9}.btn-primary:disabled{background:#bdc3c7;cursor:not-allowed}.loading{padding:20px;text-align:center;color:#666}.sliding-menu-container{position:relative;height:100vh;z-index:1000;display:flex}.trigger-area{position:absolute;left:0;top:50%;transform:translateY(-50%);width:15px;height:60px;cursor:pointer;z-index:1010;display:flex;align-items:center;opacity:.8;transition:opacity .3s ease,left .3s ease}.trigger-area:hover{opacity:1}.trigger-indicator{background-color:#4285f4e6;width:15px;height:60px;border-radius:0 4px 4px 0;display:flex;align-items:center;justify-content:center;box-shadow:2px 0 5px #0003}.arrow-icon{color:#fff;font-size:18px;font-weight:700}.sliding-menu{position:relative;height:100%;width:0;background-color:#2c3e50;transition:width .3s ease;overflow:hidden;box-shadow:2px 0 5px #0003}.sliding-menu.expanded{width:250px}.sliding-menu.expanded+.trigger-area{left:250px}.sliding-menu>*{min-width:250px;opacity:1}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{display:flex;flex-direction:column;min-height:100vh}.content{flex:1;padding:20px}.container{max-width:1200px;margin:0 auto;padding:0 20px}.app{min-height:100vh;display:flex;justify-content:center;align-items:center;background-color:#f5f5f5}.login-container{width:100%;max-width:450px;padding:20px}.login-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:30px}.login-title{color:#4285f4;text-align:center;margin-bottom:30px;font-size:28px}form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}label{font-weight:500;color:#333}input{padding:12px 16px;border:1px solid #e0e0e0;border-radius:4px;font-size:16px}input:focus{outline:none;border-color:#4285f4}.login-button{background-color:#4285f4;color:#fff;border:none;border-radius:4px;padding:12px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;margin-top:10px}.login-button:hover{background-color:#3367d6}.login-button:disabled{background-color:#e0e0e0;cursor:not-allowed}.error-message{color:#d32f2f;text-align:center;margin:0}.admin-note{text-align:center;color:#666;margin-top:24px;font-size:14px}.icp-beian{display:block;text-align:center;margin-top:30px;color:#666;font-size:14px;text-decoration:none;transition:color .2s}.icp-beian:hover{color:#4a90e2;text-decoration:underline}.student-overview{padding:20px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;color:#fff}.welcome-banner{background:rgba(255,255,255,.1);border-radius:20px;padding:30px;margin-bottom:30px;display:flex;align-items:center;justify-content:space-between;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.welcome-content h2{font-size:2rem;margin-bottom:10px;font-weight:700}.welcome-content p{font-size:1.1rem;opacity:.9}.welcome-mascot{display:flex;align-items:center;justify-content:center}.mascot-emoji{font-size:4rem;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:rgba(255,255,255,.15);border-radius:15px;padding:25px;display:flex;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #0003}.stat-icon{font-size:3rem;margin-right:20px}.stat-content h3{font-size:1rem;margin-bottom:5px;opacity:.9}.stat-number{font-size:2.5rem;font-weight:700;margin-bottom:5px}.stat-content p{font-size:.9rem;opacity:.8}.daily-tasks,.quick-start,.achievements{background:rgba(255,255,255,.1);border-radius:20px;padding:25px;margin-bottom:30px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.daily-tasks h3,.quick-start h3,.achievements h3{font-size:1.5rem;margin-bottom:20px;font-weight:600}.task-list{display:flex;flex-direction:column;gap:15px}.task-item{display:flex;align-items:center;background:rgba(255,255,255,.1);border-radius:12px;padding:15px;border:1px solid rgba(255,255,255,.2)}.task-icon{font-size:1.5rem;margin-right:15px}.task-content{flex:1}.task-content span{display:block;margin-bottom:8px;font-weight:500}.task-progress{display:flex;align-items:center;gap:10px}.progress-bar{flex:1;height:8px;background:rgba(255,255,255,.2);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4ade80,#22c55e);border-radius:4px;transition:width .3s ease}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.action-card{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);border-radius:15px;padding:20px;display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;transition:all .3s ease;color:#fff}.action-card:hover{transform:translateY(-5px);background:rgba(255,255,255,.2);box-shadow:0 10px 25px #0003}.action-icon{font-size:2.5rem;margin-bottom:15px}.action-content h4{font-size:1.1rem;margin-bottom:5px;font-weight:600}.action-content p{font-size:.9rem;opacity:.8}.achievement-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}.achievement-item{display:flex;align-items:center;background:rgba(255,255,255,.1);border-radius:12px;padding:15px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.achievement-item.locked{opacity:.6}.achievement-item:not(.locked){background:linear-gradient(135deg,#fbbf24,#f59e0b);box-shadow:0 5px 15px #fbbf244d}.achievement-icon{font-size:2rem;margin-right:15px}.achievement-content h4{font-size:1rem;margin-bottom:5px;font-weight:600}.achievement-content p{font-size:.85rem;opacity:.8}@media (max-width: 768px){.student-overview{padding:15px}.welcome-banner{flex-direction:column;text-align:center;gap:20px}.welcome-content h2{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.quick-actions-grid{grid-template-columns:repeat(2,1fr)}.achievement-list{grid-template-columns:1fr}}:root{--primary-color: #4285f4;--secondary-color: #34a853;--accent-color: #ea4335;--warning-color: #fbbc05;--background-color: #f5f5f5;--text-color: #333333;--light-text-color: #666666;--light-gray: #e0e0e0;--dark-gray: #444444;--base-font-size: 16px;--font-family: "Roboto", "Helvetica", "Arial", sans-serif;--heading-font-family: "Roboto", "Helvetica", "Arial", sans-serif;--body-font-family: "Open Sans", sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 12px;--box-shadow-sm: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24);--box-shadow-md: 0 3px 6px rgba(0, 0, 0, .15), 0 2px 4px rgba(0, 0, 0, .12);--box-shadow-lg: 0 10px 20px rgba(0, 0, 0, .15), 0 3px 6px rgba(0, 0, 0, .1)}html,body{height:100%;margin:0;padding:0;font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color);color:var(--text-color)}#root{height:100%}*{box-sizing:border-box}a{color:var(--primary-color);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;user-select:none;-webkit-user-select:none;caret-color:transparent}button:focus{outline:none}.card,[class*=card],[class*=Card]{user-select:none;-webkit-user-select:none;caret-color:transparent}h1,h2,h3,h4,h5,h6,p,span,small,label,a,ul,ol,li,dl,dt,dd,strong,em,b,i,blockquote,figcaption,th,td{user-select:none;-webkit-user-select:none;caret-color:transparent}input,textarea,select,[contenteditable=true],input:focus,textarea:focus,select:focus,[contenteditable=true]:focus{user-select:text;-webkit-user-select:text;caret-color:auto}
