*{margin:0;padding:0;box-sizing:border-box}#app,body,html{height:100%;font-family:Helvetica Neue,Helvetica,PingFang SC,Hiragino Sans GB,Microsoft YaHei,"\5FAE\8F6F\96C5\9ED1",Arial,sans-serif;background-color:#f5f7fa}.layout-container{height:100%}.aside{background-color:#fff;border-right:1px solid #ebeef5;transition:width .3s;display:flex;flex-direction:column}.logo-area{height:60px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid #ebeef5;padding:0 10px}.logo-img{max-height:40px;max-width:100%}.logo-mini{font-size:24px;font-weight:700;color:#9c27b0}.user-profile{display:flex;flex-direction:column;align-items:center;padding:20px 0;border-bottom:1px solid #ebeef5}.user-name{margin-top:10px;font-weight:700;font-size:16px;color:#333}.user-level{font-size:12px;background:#f3e5f5;color:#9c27b0;padding:2px 6px;border-radius:4px;margin-left:5px;font-weight:400;cursor:pointer}.user-level:hover{background:#e1bee7}.rule-dialog>>>.el-dialog__body{padding:10px 30px 30px}.level-content{display:flex;flex-direction:column}.level-card{display:flex;align-items:center;background-color:#faf5ff;border-radius:8px;padding:15px 20px;margin-bottom:20px}.level-card-info{margin-left:15px}.level-name{font-size:15px;font-weight:700;color:#333;margin-bottom:5px}.level-hours{font-size:12px;color:#999}.level-detail-list{display:flex;flex-direction:column;gap:15px}.detail-row{display:flex;font-size:13px;line-height:1.6}.detail-label{color:#666;width:100px;flex-shrink:0}.detail-value{color:#333;flex:1}.history-link{color:#409eff;font-size:12px;cursor:pointer;margin-left:10px}.history-link:hover{text-decoration:underline}.history-dialog>>>.el-dialog__body{padding:0 0 20px}.history-header-row{display:flex;justify-content:space-between;background-color:#f5f7fa;padding:10px 30px;font-size:12px;color:#333;font-weight:700}.history-list{padding:0 30px}.history-item{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid #ebeef5}.history-item:last-child{border-bottom:none}.item-title{font-size:13px;color:#333;margin-bottom:5px}.item-time{font-size:12px;color:#999}.item-right{font-size:14px}.item-right.negative{color:#f56c6c}.item-right.positive{color:#67c23a}.user-tags{margin-top:10px;display:flex;gap:8px}.tag{font-size:12px;padding:2px 8px;border-radius:10px}.tag.blue{background:#ecf5ff;color:#409eff}.tag.orange{background:#fdf6ec;color:#e6a23c}.tag.green{background:#f0f9eb;color:#67c23a}.tag.red{background:#fef0f0;color:#f56c6c}.tag.purple{background:#f4e8fb;color:#8a00e1}.tag.gray{background:#f4f4f5;color:#909399}.sidebar-menu{border-right:none;flex:1;overflow-y:auto}.el-menu-item.is-active{background-color:#fbf0ff!important;color:#9c27b0!important;border-right:3px solid #9c27b0}.el-menu-item.is-active i{color:#9c27b0!important}.header{background-color:#fff;border-bottom:1px solid #ebeef5;justify-content:space-between;padding:0 20px;height:60px!important}.header,.header-left{display:flex;align-items:center}.header-left{flex:1;overflow:hidden}.collapse-btn{font-size:20px;cursor:pointer;margin-right:20px;color:#666}.tabs-wrapper{flex:1;overflow:hidden;padding-top:15px}.custom-tabs .el-tabs__header{margin:0;border-bottom:none!important}.custom-tabs>>>.el-tabs__nav-wrap:after{display:none!important}.custom-tabs .el-tabs__nav{border:none!important}.custom-tabs .el-tabs__item{border:none!important;background:#f5f7fa;margin-right:5px;border-radius:4px 4px 0 0;height:36px;line-height:36px;color:#666}.custom-tabs .el-tabs__item.is-active{background:#fff;color:#9c27b0;border-bottom:2px solid #9c27b0!important}.header-right{display:flex;align-items:center}.status-dropdown{margin-right:20px;cursor:pointer}.status-text{border:1px solid #ebeef5;padding:4px 10px;border-radius:15px;font-size:13px;color:#333;display:flex;align-items:center}.status-dot{width:6px;height:6px;border-radius:50%;display:inline-block;margin-right:5px}.status-dot.green{background:#67c23a}.status-dot.gray{background:#909399}.bell-badge{margin-right:20px;cursor:pointer}.header-icon{font-size:20px;color:#666}.header-avatar,.header-name{margin-right:10px}.header-name{font-size:14px;color:#333}.logout-btn{font-size:13px;color:#999;cursor:pointer}.logout-btn:hover{color:#f56c6c}.main-content{padding:20px;background-color:#f5f7fa;height:calc(100vh - 60px);overflow-y:auto}.classroom-container[data-v-e583f058]{width:100%;height:100vh;background:#f5f7fb;overflow:hidden}.loading-overlay[data-v-e583f058]{padding:50px;background:#fff;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.loading-text[data-v-e583f058]{margin-top:20px;color:#909399}.classroom-shell[data-v-e583f058]{padding:24px}.classroom-header[data-v-e583f058]{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.classroom-title[data-v-e583f058]{font-size:24px;font-weight:600;color:#1f2d3d}.classroom-subtitle[data-v-e583f058]{margin-top:8px;color:#7a8499;font-size:14px}.status-grid[data-v-e583f058]{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:20px}.classroom-panel[data-v-e583f058],.status-card[data-v-e583f058]{background:#fff;border-radius:12px;padding:20px;box-shadow:0 8px 24px rgba(31,45,61,.06)}.status-label[data-v-e583f058]{font-size:13px;color:#909399;margin-bottom:10px}.status-value[data-v-e583f058]{font-size:18px;font-weight:600;color:#303133;word-break:break-all}.panel-title[data-v-e583f058]{font-size:16px;font-weight:600;color:#303133;margin-bottom:12px}.panel-text[data-v-e583f058]{color:#606266;line-height:1.8;margin-bottom:8px}