*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #667eea;--secondary-color: #764ba2;--success-color: #2ed573;--danger-color: #ff4757;--warning-color: #ffa502;--text-primary: #2c3e50;--text-secondary: #7f8c8d;--bg-primary: #f8f9fa;--bg-secondary: #ffffff;--border-color: #e1e8ed;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .16);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;padding:20px;color:var(--text-primary);line-height:1.6}.app-container{animation:fadeIn .5s ease-out;position:relative}.settings-btn{position:fixed;top:20px;right:20px;width:50px;height:50px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;font-size:24px;cursor:pointer;box-shadow:var(--shadow-md);transition:var(--transition);z-index:100;display:flex;align-items:center;justify-content:center}.settings-btn:hover{transform:rotate(90deg) scale(1.1);box-shadow:var(--shadow-lg)}.user-role{font-size:12px;padding:2px 8px;border-radius:10px;margin-left:8px;font-weight:500}.user-role.admin{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.user-role.teacher{background:linear-gradient(135deg,#11998e 0%,#38ef7d 100%);color:#fff}.subject-module.disabled{opacity:.7;cursor:not-allowed;background:#f5f5f5}.subject-module.disabled:hover{transform:none;box-shadow:none;border-color:#e1e8ed}.logout-btn{position:fixed;top:20px;right:80px;width:50px;height:50px;border-radius:50%;border:none;background:linear-gradient(135deg,#ff4757 0%,#ff3838 100%);color:#fff;font-size:24px;cursor:pointer;box-shadow:var(--shadow-md);transition:var(--transition);z-index:100;display:flex;align-items:center;justify-content:center}.logout-btn.single{right:20px}.logout-btn:hover{transform:scale(1.1);box-shadow:var(--shadow-lg)}.user-info{position:fixed;top:20px;right:140px;display:flex;align-items:center;gap:10px;background:white;padding:10px 20px;border-radius:25px;box-shadow:var(--shadow-md);z-index:100}.user-avatar{font-size:24px}.user-name{font-size:14px;font-weight:600;color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.container{max-width:1600px;margin:0 auto;background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);padding:32px 40px;text-align:center;color:#fff}.header h1{font-size:36px;font-weight:700;margin-bottom:8px;letter-spacing:-.5px}.subtitle{font-size:16px;opacity:.9;font-weight:400}.tab-container{display:flex;background:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:0 24px;overflow-x:auto}.tab-btn{display:flex;align-items:center;gap:8px;padding:16px 24px;border:none;background:transparent;color:var(--text-secondary);font-size:15px;font-weight:500;cursor:pointer;border-bottom:3px solid transparent;transition:var(--transition);white-space:nowrap}.tab-btn:hover{color:var(--primary-color);background:rgba(102,126,234,.05)}.tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background:white}.tab-icon{font-size:20px}.tab-content{display:none;padding:24px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.tab-content.active{display:block}.main-layout{display:flex;gap:24px;min-height:600px}.modules-panel{flex:0 0 320px;background:var(--bg-primary);border-radius:var(--radius-md);padding:20px;display:flex;flex-direction:column;gap:20px}.panel-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.panel-header h3{font-size:18px;font-weight:600;color:var(--text-primary)}.tooltip{font-size:12px;color:var(--text-secondary);padding:6px 12px;background:white;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.class-selector{display:flex;flex-direction:column;gap:8px}.class-selector label{font-size:14px;font-weight:500;color:var(--text-primary)}.class-selector select{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;background:white;cursor:pointer;transition:var(--transition)}.class-selector select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.modules-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding-right:8px}.modules-list::-webkit-scrollbar{width:6px}.modules-list::-webkit-scrollbar-track{background:transparent}.modules-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.course-module{background:white;padding:16px;border-radius:var(--radius-sm);border:2px solid var(--border-color);cursor:grab;transition:var(--transition)}.course-module:hover{border-color:var(--primary-color);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.course-module:active{cursor:grabbing;transform:scale(.98)}.subject-module{display:flex;align-items:center;gap:12px;padding:12px 16px;background:white;border-radius:12px;border:2px solid #e1e8ed;cursor:grab;transition:var(--transition);margin-bottom:10px}.subject-module:hover{border-color:#667eea;box-shadow:var(--shadow-md);transform:translateY(-2px)}.subject-module:active{cursor:grabbing;transform:scale(.98)}.subject-module.user-subject{border-color:#667eea;background:linear-gradient(135deg,#f0f7ff 0%,#e8f4ff 100%);box-shadow:0 2px 8px #667eea33}.subject-module.user-subject:hover{border-color:#764ba2;box-shadow:0 4px 12px #667eea4d}.module-subject{display:flex;align-items:center;gap:10px;flex:1}.subject-icon{font-size:24px}.subject-name-text{font-weight:600;color:var(--text-primary)}.user-subject-badge{display:inline-block;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;font-size:10px;padding:2px 8px;border-radius:10px;margin-left:8px;font-weight:500}.subject-icon-small{font-size:18px}.subject-name-display{font-size:14px;font-weight:600;color:#2c3e50}.module-course{font-weight:600;color:var(--text-primary);margin-bottom:10px;font-size:15px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.course-name-text{flex:1}.course-subject-tag{font-size:11px;font-weight:500;padding:2px 8px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;border-radius:10px}.module-teacher{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:13px;background:var(--bg-primary)}.action-buttons{display:flex;flex-direction:column;gap:10px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);text-decoration:none}.btn-icon{font-size:16px}.btn-primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-success{background:linear-gradient(135deg,#2ed573 0%,#1abc9c 100%);color:#fff}.btn-success:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-danger{background:linear-gradient(135deg,#ff4757 0%,#ff3838 100%);color:#fff}.btn-danger:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-warning{background:linear-gradient(135deg,#ffa502 0%,#ff7f50 100%);color:#fff}.btn-warning:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn-outline{background:transparent;color:var(--primary-color);border:2px solid var(--primary-color);padding:6px 12px;font-size:12px}.btn-outline:hover{background:var(--primary-color);color:#fff}.btn-sm{padding:8px 16px;font-size:13px}.timetable-panel{flex:1;display:flex;flex-direction:column;gap:20px}.class-selector-inline{display:flex;align-items:center;gap:12px}.class-selector-inline label{font-size:14px;font-weight:500;color:var(--text-secondary)}.class-selector-inline select{padding:8px 16px;border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;background:white;cursor:pointer;transition:var(--transition)}.class-selector-inline select:focus{outline:none;border-color:var(--primary-color)}.timetable-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-color)}.timetable{width:100%;border-collapse:collapse;background:white}.timetable th{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;font-weight:600;padding:16px 12px;text-align:center;font-size:14px}.period-header{width:100px}.day-header{min-width:150px}.timetable td{border:1px solid var(--border-color);padding:0;vertical-align:top;min-height:100px}.period-cell{background:var(--bg-primary);padding:12px!important;text-align:center}.period-number{font-weight:600;color:var(--text-primary);font-size:14px;margin-bottom:4px}.period-time{font-size:11px;color:var(--text-secondary)}.timetable-cell{background:white;transition:var(--transition);padding:8px;min-height:100px}.timetable-cell.drop-highlight{background:rgba(102,126,234,.1);border:2px dashed var(--primary-color)}.class-info{position:relative;background:linear-gradient(135deg,#e3f2fd 0%,#bbdefb 100%);border-radius:8px;padding:10px;margin:4px;cursor:grab;transition:var(--transition);border-left:4px solid var(--primary-color)}.class-info:hover{transform:scale(1.02);box-shadow:var(--shadow-sm)}.class-info.fixed-class{background:linear-gradient(135deg,#fff5f5 0%,#ffe8e8 100%);border-left-color:var(--danger-color);cursor:not-allowed}.class-name{font-weight:600;color:var(--primary-color);font-size:12px;margin-bottom:4px}.course-name{font-size:13px;color:var(--text-primary);font-weight:500;margin-bottom:4px}.teacher-name{font-size:11px;color:var(--text-secondary);display:flex;align-items:center;gap:4px}.fixed-icon{color:var(--danger-color)}.remove-btn{position:absolute;top:4px;right:4px;background:rgba(255,255,255,.9);border:none;color:var(--danger-color);font-size:14px;cursor:pointer;padding:4px 8px;border-radius:4px;opacity:0;transition:var(--transition)}.class-info:hover .remove-btn{opacity:1}.remove-btn:hover{background:var(--danger-color);color:#fff}.timetable-legend{display:flex;gap:24px;padding:12px 16px;background:var(--bg-primary);border-radius:var(--radius-sm)}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.legend-color{width:20px;height:20px;border-radius:4px}.legend-color.normal{background:linear-gradient(135deg,#e3f2fd 0%,#bbdefb 100%);border-left:4px solid var(--primary-color)}.legend-color.fixed{background:linear-gradient(135deg,#fff5f5 0%,#ffe8e8 100%);border-left:4px solid var(--danger-color)}.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}.empty-state p{font-size:14px}.management-panel{max-width:1200px;margin:0 auto}.form-section{background:var(--bg-primary);padding:24px;border-radius:var(--radius-md);margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h4{margin-bottom:0}.form-section h4{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.form-group{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}.form-input{flex:1;min-width:200px;display:flex;flex-direction:column;gap:8px}.form-input label{font-size:14px;font-weight:500;color:var(--text-primary)}.form-input input{padding:12px 16px;border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;transition:var(--transition)}.form-input input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.list-section{margin-top:24px}.list-section h4{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:16px;display:flex;align-items:center;gap:12px}.count-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;background:var(--primary-color);color:#fff;border-radius:12px;font-size:12px;font-weight:600}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.item-card{display:flex;align-items:center;gap:16px;background:white;padding:16px;border-radius:var(--radius-sm);border:2px solid var(--border-color);transition:var(--transition)}.item-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-sm)}.teacher-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.teacher-card{background:white;border-radius:var(--radius-md);border:2px solid var(--border-color);overflow:hidden;transition:var(--transition)}.teacher-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-sm)}.teacher-card-header{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-primary);border-bottom:1px solid var(--border-color)}.teacher-info{flex:1}.teacher-courses{padding:12px 16px;border-bottom:1px solid var(--border-color)}.teacher-courses-label{font-size:12px;color:var(--text-secondary);margin-bottom:8px}.teacher-courses-list{display:flex;flex-wrap:wrap;gap:6px}.course-tag{display:inline-block;padding:4px 10px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;border-radius:12px;font-size:12px}.no-courses{color:var(--text-secondary);font-size:12px;font-style:italic}.teacher-courses-edit{padding:12px 16px;background:var(--bg-primary)}.course-checkbox-list{display:flex;flex-wrap:wrap;gap:8px}.checkbox-item-sm{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;background:white;border-radius:6px;border:1px solid var(--border-color);font-size:12px;cursor:pointer;transition:var(--transition)}.checkbox-item-sm:hover{border-color:var(--primary-color)}.checkbox-item-sm input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--primary-color)}.item-avatar{font-size:32px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:50%}.item-content{flex:1}.item-name{font-weight:600;color:var(--text-primary);font-size:15px;margin-bottom:4px}.item-subject,.item-grade{font-size:13px;color:var(--text-secondary)}.auto-schedule-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5)}.modal-content{position:relative;background:white;border-radius:var(--radius-lg);max-width:600px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s ease-out;z-index:1001}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:20px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:4px;transition:var(--transition)}.modal-close:hover{color:var(--danger-color)}.modal-body{padding:24px}.modal-body .form-section{background:var(--bg-primary);margin-bottom:20px;padding:20px}.modal-body .form-section h4{font-size:15px;margin-bottom:12px}.checkbox-list{display:flex;flex-wrap:wrap;gap:12px}.checkbox-item{display:flex;align-items:center;gap:8px;cursor:pointer;padding:10px 16px;background:white;border-radius:var(--radius-sm);border:2px solid var(--border-color);transition:var(--transition);font-size:14px}.checkbox-item:hover{border-color:var(--primary-color)}.checkbox-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color)}.hint{font-size:12px;color:var(--text-secondary);margin-top:8px}.teacher-list{display:flex;flex-direction:column;gap:12px}.teacher-item{display:flex;align-items:center;gap:12px;padding:12px;background:white;border-radius:var(--radius-sm);border:2px solid var(--border-color);transition:var(--transition)}.teacher-item:hover{border-color:var(--primary-color)}.teacher-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;flex:1;font-size:14px}.teacher-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color)}.teacher-count-input{width:100px;padding:8px 12px;border:2px solid var(--border-color);border-radius:6px;font-size:14px;transition:var(--transition)}.teacher-count-input:focus{outline:none;border-color:var(--primary-color)}.teacher-count-input:disabled{background:var(--bg-primary);color:var(--text-secondary);cursor:not-allowed}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:24px;border-top:1px solid var(--border-color)}.settings-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.settings-modal .modal-content{max-width:500px}.time-settings{display:flex;flex-direction:column;gap:12px}.time-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:white;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.time-row label{width:50px;font-weight:600;color:var(--text-primary)}.time-row input[type=time]{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;transition:var(--transition)}.time-row input[type=time]:focus{outline:none;border-color:var(--primary-color)}.time-row span{color:var(--text-secondary)}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:white;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.setting-item label{font-weight:500;color:var(--text-primary)}.setting-item input[type=number]{width:80px;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;text-align:center}.setting-item input[type=number]:focus{outline:none;border-color:var(--primary-color)}.data-buttons{display:flex;gap:12px;flex-wrap:wrap}.data-buttons .btn{flex:1;min-width:140px}@media (max-width: 768px){body{padding:10px}.header{padding:24px}.header h1{font-size:28px}.main-layout{flex-direction:column}.modules-panel{flex:none}.tab-container{padding:0 12px}.tab-btn{padding:12px 16px}.tab-text{display:none}.tab-icon{font-size:24px}.form-group{flex-direction:column}.items-grid{grid-template-columns:1fr}.user-info{display:none}.logout-btn{right:70px;width:40px;height:40px;font-size:18px}.settings-btn{width:40px;height:40px;font-size:18px}}.teacher-card{cursor:pointer;transition:all .2s}.teacher-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.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;padding:20px}.modal-content{background:white;border-radius:20px;max-width:420px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e1e8ed}.modal-header h3{font-size:18px;font-weight:600;color:#2c3e50;margin:0}.modal-close{background:none;border:none;font-size:24px;color:#7f8c8d;cursor:pointer;padding:4px;transition:color .2s}.modal-close:hover{color:#ff4757}.modal-body{padding:24px}.teacher-detail-modal .detail-avatar{font-size:64px;text-align:center;margin-bottom:16px}.teacher-detail-modal .detail-name{font-size:24px;font-weight:700;color:#2c3e50;text-align:center;margin-bottom:8px}.teacher-detail-modal .detail-subject{font-size:16px;color:#667eea;text-align:center;margin-bottom:24px}.detail-info-list{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.detail-info-item{display:flex;align-items:center;gap:12px;padding:16px;background:#f8f9fa;border-radius:12px}.detail-info-item .info-icon{font-size:24px}.detail-info-item .info-label{font-size:14px;color:#7f8c8d;min-width:70px}.detail-info-item .info-value{font-size:15px;font-weight:500;color:#2c3e50;flex:1}.detail-actions{display:flex;gap:12px;justify-content:center}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}.login-container[data-v-5b6bbb84]{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.login-card[data-v-5b6bbb84]{background:white;border-radius:24px;box-shadow:0 20px 60px #00000026;padding:48px;width:100%;max-width:440px;position:relative;z-index:10;animation:slideUp-5b6bbb84 .5s ease-out}@keyframes slideUp-5b6bbb84{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header[data-v-5b6bbb84]{text-align:center;margin-bottom:40px}.logo[data-v-5b6bbb84]{font-size:64px;margin-bottom:16px;animation:bounce-5b6bbb84 2s infinite}@keyframes bounce-5b6bbb84{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-header h1[data-v-5b6bbb84]{font-size:28px;font-weight:700;color:#2c3e50;margin-bottom:8px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle[data-v-5b6bbb84]{color:#7f8c8d;font-size:14px}.login-form[data-v-5b6bbb84]{display:flex;flex-direction:column;gap:24px}.form-group[data-v-5b6bbb84]{display:flex;flex-direction:column;gap:8px}.form-group label[data-v-5b6bbb84]{font-size:14px;font-weight:600;color:#2c3e50;display:flex;align-items:center;gap:8px}.label-icon[data-v-5b6bbb84]{font-size:16px}.input-wrapper[data-v-5b6bbb84]{position:relative;display:flex;align-items:center}.input-wrapper input[data-v-5b6bbb84]{width:100%;padding:14px 48px 14px 16px;border:2px solid #e1e8ed;border-radius:12px;font-size:15px;transition:all .3s ease;background:#f8f9fa}.input-wrapper input[data-v-5b6bbb84]:focus{outline:none;border-color:#667eea;background:white;box-shadow:0 0 0 4px #667eea1a}.input-wrapper input[data-v-5b6bbb84]:disabled{background:#f0f0f0;cursor:not-allowed}.form-group.has-error .input-wrapper input[data-v-5b6bbb84]{border-color:#ff4757;background:#fff5f5}.form-group.has-error .input-wrapper input[data-v-5b6bbb84]:focus{box-shadow:0 0 0 4px #ff47571a}.input-clear[data-v-5b6bbb84]{position:absolute;right:48px;color:#bdc3c7;cursor:pointer;font-size:14px;transition:color .2s}.input-clear[data-v-5b6bbb84]:hover{color:#7f8c8d}.password-toggle[data-v-5b6bbb84]{position:absolute;right:12px;background:none;border:none;font-size:20px;cursor:pointer;padding:4px;transition:transform .2s}.password-toggle[data-v-5b6bbb84]:hover{transform:scale(1.1)}.password-toggle[data-v-5b6bbb84]:disabled{cursor:not-allowed;opacity:.5}.error-message[data-v-5b6bbb84]{color:#ff4757;font-size:12px;display:flex;align-items:center;gap:4px}.form-options[data-v-5b6bbb84]{display:flex;justify-content:space-between;align-items:center;margin-top:-8px}.remember-me[data-v-5b6bbb84]{display:flex;align-items:center;gap:10px;cursor:pointer;position:relative}.remember-me input[data-v-5b6bbb84]{position:absolute;opacity:0;cursor:pointer}.checkbox-custom[data-v-5b6bbb84]{width:20px;height:20px;border:2px solid #e1e8ed;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.remember-me input:checked+.checkbox-custom[data-v-5b6bbb84]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea}.remember-me input:checked+.checkbox-custom[data-v-5b6bbb84]:after{content:"\2713";color:#fff;font-size:12px;font-weight:700}.remember-me input:disabled+.checkbox-custom[data-v-5b6bbb84]{background:#f0f0f0;cursor:not-allowed}.checkbox-label[data-v-5b6bbb84]{font-size:14px;color:#7f8c8d}.forgot-password[data-v-5b6bbb84]{color:#667eea;font-size:14px;text-decoration:none;transition:color .2s}.forgot-password[data-v-5b6bbb84]:hover{color:#764ba2;text-decoration:underline}.login-error[data-v-5b6bbb84]{background:#fff5f5;border:1px solid #ffccd5;border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:10px;color:#ff4757;font-size:14px}.error-icon[data-v-5b6bbb84]{font-size:18px}.login-btn[data-v-5b6bbb84]{width:100%;padding:16px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-height:52px}.login-btn[data-v-5b6bbb84]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.login-btn[data-v-5b6bbb84]:active:not(:disabled){transform:translateY(0)}.login-btn[data-v-5b6bbb84]:disabled{cursor:not-allowed;opacity:.7}.login-btn.loading[data-v-5b6bbb84]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.loading-spinner[data-v-5b6bbb84]{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-5b6bbb84 .8s linear infinite}@keyframes spin-5b6bbb84{to{transform:rotate(360deg)}}.login-footer[data-v-5b6bbb84]{text-align:center;margin-top:32px;padding-top:24px;border-top:1px solid #e1e8ed;display:flex;align-items:center;justify-content:center;gap:8px}.login-footer p[data-v-5b6bbb84]{color:#7f8c8d;font-size:14px}.register-link[data-v-5b6bbb84]{color:#667eea;font-size:14px;font-weight:600;text-decoration:none;transition:color .2s}.register-link[data-v-5b6bbb84]:hover{color:#764ba2;text-decoration:underline}.login-background[data-v-5b6bbb84]{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;z-index:1}.bg-shape[data-v-5b6bbb84]{position:absolute;border-radius:50%;animation:float-5b6bbb84 6s ease-in-out infinite}.shape-1[data-v-5b6bbb84]{width:400px;height:400px;background:linear-gradient(135deg,rgba(102,126,234,.3) 0%,rgba(118,75,162,.3) 100%);top:-100px;left:-100px;animation-delay:0s}.shape-2[data-v-5b6bbb84]{width:300px;height:300px;background:linear-gradient(135deg,rgba(46,213,115,.2) 0%,rgba(26,188,156,.2) 100%);bottom:-50px;right:-50px;animation-delay:2s}.shape-3[data-v-5b6bbb84]{width:200px;height:200px;background:linear-gradient(135deg,rgba(255,165,2,.2) 0%,rgba(255,127,80,.2) 100%);top:50%;right:10%;animation-delay:4s}@keyframes float-5b6bbb84{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(5deg)}}.fade-enter-active[data-v-5b6bbb84],.fade-leave-active[data-v-5b6bbb84]{transition:opacity .3s ease}.fade-enter-from[data-v-5b6bbb84],.fade-leave-to[data-v-5b6bbb84]{opacity:0}.modal-overlay[data-v-5b6bbb84]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content[data-v-5b6bbb84]{background:white;border-radius:20px;max-width:420px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header[data-v-5b6bbb84]{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e1e8ed}.modal-header h3[data-v-5b6bbb84]{font-size:20px;font-weight:600;color:#2c3e50}.modal-close[data-v-5b6bbb84]{background:none;border:none;font-size:24px;color:#7f8c8d;cursor:pointer;padding:4px;transition:color .2s}.modal-close[data-v-5b6bbb84]:hover{color:#ff4757}.modal-body[data-v-5b6bbb84]{padding:24px}.modal-hint[data-v-5b6bbb84]{color:#7f8c8d;font-size:14px;margin-bottom:20px;line-height:1.6}.modal-body .form-group[data-v-5b6bbb84]{margin-bottom:16px}.modal-body .form-group[data-v-5b6bbb84]:last-child{margin-bottom:0}.modal-body input[data-v-5b6bbb84]{width:100%;padding:12px 16px;border:2px solid #e1e8ed;border-radius:10px;font-size:14px;transition:all .2s}.modal-body input[data-v-5b6bbb84]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-footer[data-v-5b6bbb84]{display:flex;gap:12px;padding:24px;border-top:1px solid #e1e8ed}.btn[data-v-5b6bbb84]{flex:1;padding:12px 24px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary[data-v-5b6bbb84]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.btn-primary[data-v-5b6bbb84]:hover{transform:translateY(-1px);box-shadow:0 4px 15px #667eea66}.btn-secondary[data-v-5b6bbb84]{background:#f8f9fa;color:#2c3e50;border:2px solid #e1e8ed}.btn-secondary[data-v-5b6bbb84]:hover{background:#e1e8ed}.modal-enter-active[data-v-5b6bbb84],.modal-leave-active[data-v-5b6bbb84]{transition:all .3s ease}.modal-enter-from[data-v-5b6bbb84],.modal-leave-to[data-v-5b6bbb84]{opacity:0}.modal-enter-from .modal-content[data-v-5b6bbb84],.modal-leave-to .modal-content[data-v-5b6bbb84]{transform:scale(.9) translateY(20px)}@media (max-width: 480px){.login-card[data-v-5b6bbb84]{padding:32px 24px}.login-header h1[data-v-5b6bbb84]{font-size:24px}.logo[data-v-5b6bbb84]{font-size:48px}.form-options[data-v-5b6bbb84]{flex-direction:column;gap:12px;align-items:flex-start}.login-footer[data-v-5b6bbb84]{flex-direction:column;gap:8px}.subject-grid[data-v-5b6bbb84]{grid-template-columns:repeat(3,1fr)}.register-modal[data-v-5b6bbb84]{max-width:100%;margin:10px}}.required[data-v-5b6bbb84]{color:#ff4757;font-size:12px}.hint-text[data-v-5b6bbb84]{font-size:12px;color:#7f8c8d;font-weight:400}.subject-grid[data-v-5b6bbb84]{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:8px}.subject-item[data-v-5b6bbb84]{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border:2px solid #e1e8ed;border-radius:12px;cursor:pointer;transition:all .2s;background:white}.subject-item input[data-v-5b6bbb84]{display:none}.subject-item[data-v-5b6bbb84]:hover{border-color:#667eea;background:#f8f9ff}.subject-item.selected[data-v-5b6bbb84]{border-color:#667eea;background:linear-gradient(135deg,#e3f2fd 0%,#bbdefb 100%)}.subject-icon[data-v-5b6bbb84]{font-size:24px}.subject-name[data-v-5b6bbb84]{font-size:12px;font-weight:500;color:#2c3e50;text-align:center}.subject-item.selected .subject-name[data-v-5b6bbb84]{color:#667eea;font-weight:600}.loading-spinner-small[data-v-5b6bbb84]{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-5b6bbb84 .8s linear infinite;display:inline-block}.register-modal[data-v-5b6bbb84]{max-width:500px}.register-modal .modal-body[data-v-5b6bbb84]{max-height:60vh;overflow-y:auto}.version-footer[data-v-5b6bbb84]{position:fixed;bottom:0;left:0;right:0;text-align:center;padding:8px;font-size:11px;color:#fff9;z-index:1}.version-footer .divider[data-v-5b6bbb84]{margin:0 8px}.mobile-timetable[data-v-44007b94]{min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);display:flex;flex-direction:column;overflow:hidden;touch-action:pan-y pinch-zoom}.mobile-header[data-v-44007b94]{background:white;padding:16px;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:100}.header-top[data-v-44007b94]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.header-top h2[data-v-44007b94]{font-size:20px;font-weight:700;color:#2c3e50;margin:0}.header-actions[data-v-44007b94]{display:flex;gap:8px}.action-btn[data-v-44007b94]{width:40px;height:40px;border:none;border-radius:12px;background:#f0f2f5;font-size:20px;cursor:pointer;transition:all .2s}.action-btn[data-v-44007b94]:active{transform:scale(.95);background:#e4e6e9}.current-info[data-v-44007b94]{display:flex;gap:12px;font-size:14px;color:#65676b}.current-class[data-v-44007b94]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:4px 12px;border-radius:12px;font-weight:500}.current-week[data-v-44007b94]{padding:4px 0}.view-mode-tabs[data-v-44007b94]{display:flex;background:white;padding:8px;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch}.view-mode-tabs[data-v-44007b94]::-webkit-scrollbar{display:none}.day-tab[data-v-44007b94]{flex:1;min-width:50px;padding:12px 8px;border:none;border-radius:12px;background:#f0f2f5;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .2s}.day-tab.active[data-v-44007b94]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.day-tab.is-today[data-v-44007b94]:not(.active){border:2px solid #667eea}.day-name[data-v-44007b94]{font-size:14px;font-weight:600}.day-date[data-v-44007b94]{font-size:12px;opacity:.8}.timetable-content[data-v-44007b94]{flex:1;overflow-y:auto;padding:16px;transition:transform .1s}.day-view[data-v-44007b94],.period-list[data-v-44007b94]{display:flex;flex-direction:column;gap:12px}.period-item[data-v-44007b94]{background:white;border-radius:16px;padding:16px;display:flex;gap:16px;box-shadow:0 2px 8px #00000014;transition:all .2s}.period-item[data-v-44007b94]:active{transform:scale(.98)}.period-item.has-subject[data-v-44007b94]{border-left:4px solid #667eea}.period-item.is-current[data-v-44007b94]{background:linear-gradient(135deg,#e3f2fd 0%,#bbdefb 100%);box-shadow:0 4px 12px #667eea4d}.period-info[data-v-44007b94]{min-width:60px;text-align:center}.period-number[data-v-44007b94]{font-size:16px;font-weight:700;color:#2c3e50;margin-bottom:4px}.period-time[data-v-44007b94]{font-size:11px;color:#65676b}.period-subjects[data-v-44007b94]{flex:1;display:flex;flex-direction:column;gap:8px}.subject-card[data-v-44007b94]{padding:12px;border-radius:12px;border-left:4px solid}.subject-card.fixed[data-v-44007b94]{border-left-color:#ff4757!important}.subject-name-display[data-v-44007b94]{font-size:16px;font-weight:600;margin-bottom:8px}.subject-details[data-v-44007b94]{display:flex;flex-wrap:wrap;gap:8px;font-size:13px;opacity:.9}.subject-location[data-v-44007b94]{font-size:12px;margin-top:4px;opacity:.8}.no-subject[data-v-44007b94]{display:flex;align-items:center;justify-content:center;padding:20px;color:#65676b;font-size:14px}.week-view[data-v-44007b94]{background:white;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #00000014}.week-header[data-v-44007b94]{display:flex;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;position:sticky;top:0}.header-cell[data-v-44007b94]{padding:12px 8px;text-align:center;font-size:12px;font-weight:600}.time-header[data-v-44007b94]{width:50px;background:rgba(0,0,0,.1)}.day-header[data-v-44007b94]{flex:1}.day-header.is-today[data-v-44007b94]{background:rgba(255,255,255,.2)}.week-body[data-v-44007b94]{display:flex;flex-direction:column}.week-row[data-v-44007b94]{display:flex;border-bottom:1px solid #f0f2f5}.week-row[data-v-44007b94]:last-child{border-bottom:none}.time-cell[data-v-44007b94]{width:50px;padding:8px 4px;background:#f8f9fa;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid #e1e8ed}.period-num[data-v-44007b94]{font-size:11px;font-weight:600;color:#2c3e50}.period-time-small[data-v-44007b94]{font-size:9px;color:#65676b}.subject-cell[data-v-44007b94]{flex:1;min-height:50px;padding:4px;border-right:1px solid #f0f2f5;display:flex;flex-direction:column;gap:2px}.subject-cell[data-v-44007b94]:last-child{border-right:none}.subject-cell.is-today[data-v-44007b94]{background:#f0f7ff}.subject-cell.is-current[data-v-44007b94]{background:#e3f2fd;box-shadow:inset 0 0 0 2px #667eea}.mini-subject[data-v-44007b94]{padding:4px 6px;border-radius:6px;font-size:10px;border-left:3px solid;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mini-name[data-v-44007b94]{font-weight:500}.quick-actions[data-v-44007b94]{display:flex;gap:8px;padding:12px 16px;background:white;border-top:1px solid #e1e8ed;position:sticky;bottom:0}.quick-btn[data-v-44007b94]{flex:1;padding:12px;border:none;border-radius:12px;background:#f0f2f5;font-size:13px;font-weight:500;color:#2c3e50;cursor:pointer;transition:all .2s}.quick-btn[data-v-44007b94]:active{transform:scale(.95)}.quick-btn[data-v-44007b94]:disabled{opacity:.5;cursor:not-allowed}.detail-modal[data-v-44007b94],.class-selector-modal[data-v-44007b94]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:flex-end;justify-content:center;z-index:1000}.detail-content[data-v-44007b94],.class-selector-content[data-v-44007b94]{background:white;border-radius:24px 24px 0 0;width:100%;max-height:70vh;overflow-y:auto;padding:24px}.detail-header[data-v-44007b94],.selector-header[data-v-44007b94]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.detail-header h3[data-v-44007b94],.selector-header h3[data-v-44007b94]{font-size:20px;font-weight:700;color:#2c3e50;margin:0}.close-btn[data-v-44007b94]{width:36px;height:36px;border:none;border-radius:50%;background:#f0f2f5;font-size:18px;cursor:pointer}.detail-subjects[data-v-44007b94]{display:flex;flex-direction:column;gap:16px}.detail-subject-card[data-v-44007b94]{padding:20px;border-radius:16px;border-left:4px solid}.detail-subject-name[data-v-44007b94]{font-size:18px;font-weight:700;margin-bottom:12px}.detail-info-row[data-v-44007b94]{display:flex;gap:8px;margin-bottom:8px;font-size:14px}.info-label[data-v-44007b94]{color:#65676b}.info-value[data-v-44007b94]{font-weight:500}.no-detail[data-v-44007b94]{text-align:center;padding:40px;color:#65676b}.no-detail-icon[data-v-44007b94]{font-size:48px;margin-bottom:16px}.class-list[data-v-44007b94]{display:flex;flex-direction:column;gap:12px}.class-item[data-v-44007b94]{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border:2px solid #e1e8ed;border-radius:12px;background:white;cursor:pointer;transition:all .2s}.class-item[data-v-44007b94]:active{transform:scale(.98)}.class-item.active[data-v-44007b94]{border-color:#667eea;background:linear-gradient(135deg,#e3f2fd 0%,#bbdefb 100%)}.class-item .class-name[data-v-44007b94]{font-size:16px;font-weight:600;color:#2c3e50}.class-item .class-grade[data-v-44007b94]{font-size:13px;color:#65676b}.loading-overlay[data-v-44007b94]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.9);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:2000}.loading-spinner[data-v-44007b94]{width:48px;height:48px;border:4px solid #f0f2f5;border-top-color:#667eea;border-radius:50%;animation:spin-44007b94 .8s linear infinite}@keyframes spin-44007b94{to{transform:rotate(360deg)}}.slide-up-enter-active[data-v-44007b94],.slide-up-leave-active[data-v-44007b94]{transition:all .3s ease}.slide-up-enter-from[data-v-44007b94],.slide-up-leave-to[data-v-44007b94]{transform:translateY(100%)}.fade-enter-active[data-v-44007b94],.fade-leave-active[data-v-44007b94]{transition:opacity .3s ease}.fade-enter-from[data-v-44007b94],.fade-leave-to[data-v-44007b94]{opacity:0}@media (min-width: 768px){.mobile-timetable[data-v-44007b94]{max-width:480px;margin:0 auto;border-radius:0}.detail-content[data-v-44007b94],.class-selector-content[data-v-44007b94]{max-width:480px;border-radius:24px;margin:auto}}.version-footer[data-v-44007b94]{text-align:center;padding:8px;font-size:11px;color:#ffffffb3;background:rgba(0,0,0,.1)}.version-footer .divider[data-v-44007b94]{margin:0 8px}.my-courses-container[data-v-7caddbc4]{padding:20px;max-width:1200px;margin:0 auto}.header[data-v-7caddbc4]{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.header h2[data-v-7caddbc4]{font-size:24px;font-weight:700;color:#2c3e50;margin:0}.date-display[data-v-7caddbc4]{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-radius:20px;font-weight:500}.date-icon[data-v-7caddbc4]{font-size:18px}.status-summary[data-v-7caddbc4]{display:flex;gap:16px;margin-bottom:24px}.status-item[data-v-7caddbc4]{flex:1;padding:16px;border-radius:12px;text-align:center;transition:transform .2s}.status-item[data-v-7caddbc4]:hover{transform:translateY(-2px)}.status-item.completed[data-v-7caddbc4]{background:linear-gradient(135deg,#e8f5e9 0%,#c8e6c9 100%);border:2px solid #4caf50}.status-item.in-progress[data-v-7caddbc4]{background:linear-gradient(135deg,#fff3e0 0%,#ffe0b2 100%);border:2px solid #ff9800}.status-item.not-started[data-v-7caddbc4]{background:linear-gradient(135deg,#e3f2fd 0%,#bbdefb 100%);border:2px solid #2196f3}.status-count[data-v-7caddbc4]{display:block;font-size:32px;font-weight:700;margin-bottom:4px}.status-item.completed .status-count[data-v-7caddbc4]{color:#2e7d32}.status-item.in-progress .status-count[data-v-7caddbc4]{color:#e65100}.status-item.not-started .status-count[data-v-7caddbc4]{color:#1565c0}.status-label[data-v-7caddbc4]{font-size:14px;color:#666}.courses-list[data-v-7caddbc4]{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.empty-state[data-v-7caddbc4]{text-align:center;padding:48px;background:#f8f9fa;border-radius:16px;color:#7f8c8d}.empty-icon[data-v-7caddbc4]{font-size:48px;margin-bottom:12px}.course-card[data-v-7caddbc4]{display:flex;align-items:center;gap:20px;padding:16px 20px;background:white;border-radius:12px;border:2px solid #e1e8ed;transition:all .2s}.course-card[data-v-7caddbc4]:hover{box-shadow:0 4px 12px #0000001a}.course-card.completed[data-v-7caddbc4]{border-left:4px solid #4caf50;background:linear-gradient(135deg,#fafafa 0%,#f5f5f5 100%)}.course-card.in-progress[data-v-7caddbc4]{border-left:4px solid #ff9800;background:linear-gradient(135deg,#fff8e1 0%,#fff3e0 100%);animation:pulse-7caddbc4 2s infinite}.course-card.not-started[data-v-7caddbc4]{border-left:4px solid #2196f3}@keyframes pulse-7caddbc4{0%,to{box-shadow:0 0 #ff980066}50%{box-shadow:0 0 0 8px #ff980000}}.course-time[data-v-7caddbc4]{display:flex;flex-direction:column;align-items:center;min-width:80px}.period-badge[data-v-7caddbc4]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;margin-bottom:4px}.time-range[data-v-7caddbc4]{font-size:12px;color:#7f8c8d}.course-content[data-v-7caddbc4]{flex:1}.course-subject[data-v-7caddbc4]{display:flex;align-items:center;gap:8px;margin-bottom:4px}.subject-icon[data-v-7caddbc4]{font-size:24px}.subject-name[data-v-7caddbc4]{font-size:18px;font-weight:600;color:#2c3e50}.course-class[data-v-7caddbc4]{font-size:14px;color:#7f8c8d}.course-status[data-v-7caddbc4]{min-width:80px;text-align:center}.status-badge[data-v-7caddbc4]{display:inline-block;padding:6px 12px;border-radius:16px;font-size:12px;font-weight:600}.status-badge.completed[data-v-7caddbc4]{background:#e8f5e9;color:#2e7d32}.status-badge.in-progress[data-v-7caddbc4]{background:#fff3e0;color:#e65100}.status-badge.not-started[data-v-7caddbc4]{background:#e3f2fd;color:#1565c0}.week-view[data-v-7caddbc4]{background:white;border-radius:16px;padding:20px;box-shadow:0 2px 8px #0000000d}.week-view h3[data-v-7caddbc4]{font-size:18px;font-weight:600;color:#2c3e50;margin:0 0 16px}.week-grid[data-v-7caddbc4]{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.day-column[data-v-7caddbc4]{border-radius:12px;overflow:hidden;border:2px solid #e1e8ed}.day-column.today[data-v-7caddbc4]{border-color:#667eea;box-shadow:0 4px 12px #667eea33}.day-header[data-v-7caddbc4]{background:#f8f9fa;padding:12px;text-align:center;border-bottom:1px solid #e1e8ed}.day-column.today .day-header[data-v-7caddbc4]{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.day-name[data-v-7caddbc4]{display:block;font-weight:600;font-size:14px}.day-date[data-v-7caddbc4]{font-size:12px;opacity:.8}.day-courses[data-v-7caddbc4]{padding:8px;min-height:100px}.mini-course[data-v-7caddbc4]{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:6px;margin-bottom:4px;font-size:11px}.mini-course.completed[data-v-7caddbc4]{background:#e8f5e9;color:#2e7d32}.mini-course.in-progress[data-v-7caddbc4]{background:#fff3e0;color:#e65100}.mini-course.not-started[data-v-7caddbc4]{background:#e3f2fd;color:#1565c0}.mini-period[data-v-7caddbc4]{font-weight:600}.mini-subject[data-v-7caddbc4]{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-course[data-v-7caddbc4]{text-align:center;color:#bdc3c7;padding:20px}@media (max-width: 768px){.status-summary[data-v-7caddbc4]{flex-direction:column}.course-card[data-v-7caddbc4]{flex-direction:column;align-items:flex-start}.course-time[data-v-7caddbc4]{flex-direction:row;gap:12px}.week-grid[data-v-7caddbc4]{grid-template-columns:1fr}}.version-footer[data-v-7caddbc4]{text-align:center;padding:12px;font-size:11px;color:#95a5a6;margin-top:20px}.version-footer .divider[data-v-7caddbc4]{margin:0 8px}.version-footer[data-v-ef61b750]{text-align:center;padding:12px;font-size:11px;color:#95a5a6;margin-top:auto}.version-footer .divider[data-v-ef61b750]{margin:0 8px}
