.auth-container{border:1px solid #ddd;border-radius:8px;max-width:400px;margin:50px auto;padding:30px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;box-shadow:0 2px 10px #0000001a}.auth-container h2{text-align:center;color:#333;margin-bottom:25px}.auth-container form{flex-direction:column;gap:15px;display:flex}.auth-container input,.auth-container button{border:1px solid #ccc;border-radius:4px;padding:12px;font-size:14px}.auth-container input{border:1px solid #ddd;transition:border-color .3s}.auth-container input:focus{border-color:#007bff;outline:none;box-shadow:0 0 5px #007bff80}.auth-container button{color:#fff;cursor:pointer;background-color:#007bff;border:none;font-weight:700;transition:background-color .3s}.auth-container button:hover:not(:disabled){background-color:#0056b3}.auth-container button:disabled{cursor:not-allowed;background-color:#ccc}.error-message{color:#721c24;text-align:center;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;margin-bottom:15px;padding:12px}.success-message{color:#155724;text-align:center;background-color:#d4edda;border:1px solid #c3e6cb;border-radius:4px;margin-bottom:15px;padding:12px}.auth-container p{text-align:center;color:#666;margin-top:15px;font-size:14px}.auth-container a{color:#007bff;text-decoration:none}.auth-container a:hover{text-decoration:underline}.google-auth-btn{color:#333;cursor:pointer;background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px;justify-content:center;align-items:center;gap:10px;padding:12px;font-weight:500;transition:background-color .3s;display:flex}.google-auth-btn:hover{background-color:#f0f0f0}.auth-container button[disabled]{opacity:.7}.message.success{color:#155724;background-color:#d4edda}.message.error{color:#721c24;background-color:#f8d7da}.message{text-align:center;border-radius:4px;margin:15px 0;padding:12px}.admin-dashboard-page{color:#1f2d3d;box-sizing:border-box;background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);min-height:100vh;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.admin-dashboard-header{color:#fff;background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%);justify-content:space-between;align-items:center;padding:16px 28px;display:flex;box-shadow:0 4px 16px #00000026}.brand-logo{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;width:44px;height:44px;padding:6px}.admin-dashboard-header h1{letter-spacing:.2px;margin:0;font-size:24px;font-weight:700}.header-right{align-items:center;display:flex}.user-profile{background:#ffffff1a;border:1px solid #fff3;border-radius:25px;align-items:center;gap:10px;padding:8px 14px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.user-name{color:#fff;font-size:14px;font-weight:500}.welcome-section{background:#fff;border-bottom:1px solid #e0e6ed;padding:16px 28px}.welcome-message{color:#3b526c;margin:0;font-size:16px;font-weight:500}.modules-grid-container{max-width:1400px;margin:0 auto;padding:28px}.modules-grid{grid-template-columns:repeat(2,1fr);gap:24px;margin-top:20px;display:grid}.module-card{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:12px;padding:28px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 2px 8px #00000014}.module-card:before{content:"";background:inherit;height:4px;position:absolute;top:0;left:0;right:0}.module-card:hover{transform:translateY(-6px);box-shadow:0 12px 24px #00000026}.module-card.gradient-blue{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.module-card.gradient-green{color:#fff;background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%)}.module-card.gradient-purple{color:#fff;background:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%)}.module-card.gradient-orange{color:#fff;background:linear-gradient(135deg,#fa709a 0%,#fee140 100%)}.module-icon{margin-bottom:12px;font-size:48px;display:block}.module-title{letter-spacing:.2px;margin:0 0 10px;font-size:22px;font-weight:700}.module-description{opacity:.95;margin:0;font-size:14px;line-height:1.5}.module-arrow{opacity:.7;font-size:24px;transition:all .3s;position:absolute;bottom:16px;right:16px}.module-card:hover .module-arrow{opacity:1;transform:translate(4px)}@media (width<=960px){.modules-grid{grid-template-columns:1fr;gap:16px}.admin-dashboard-header{flex-direction:column;align-items:flex-start;gap:12px}.header-right{justify-content:flex-start;width:100%}.modules-grid-container{padding:16px}.module-card{padding:20px}.module-title{font-size:18px}}@media (width<=640px){.admin-dashboard-header h1{font-size:18px}.brand-logo{width:36px;height:36px}.user-profile{padding:6px 10px}.user-avatar{width:28px;height:28px;font-size:12px}.user-name{font-size:12px}.welcome-message{font-size:14px}.module-icon{font-size:36px}}.teacher-pref-summary,.teacher-pref-table-section{background:#f8fafc;border:1px solid #dbe4ef;border-radius:8px;padding:18px}.teacher-pref-section-title{color:#1f2d3d;margin:0 0 14px;font-size:18px;font-weight:700}.teacher-pref-summary-grid{grid-template-columns:repeat(4,minmax(180px,1fr));gap:14px;display:grid}.teacher-pref-summary-card{text-align:center;border:1px solid #0000;border-radius:8px;padding:18px}.teacher-pref-summary-card.blue{color:#245ed6;background:#ecf3ff;border-color:#d7e6ff}.teacher-pref-summary-card.green{color:#18944f;background:#ecfaf2;border-color:#d1f1df}.teacher-pref-summary-card.amber{color:#cc8a05;background:#fff7e7;border-color:#fce6b9}.teacher-pref-summary-card.violet{color:#7d38d8;background:#f6eeff;border-color:#ead7ff}.teacher-pref-summary-value{margin:0;font-size:40px;font-weight:700;line-height:1}.teacher-pref-summary-label{margin:8px 0 0;font-size:16px;font-weight:500}.teacher-pref-table-wrap{overflow-x:auto}.teacher-pref-table{border-collapse:collapse;background:#fff;width:100%;min-width:1200px}.teacher-pref-table th,.teacher-pref-table td{text-align:left;vertical-align:top;color:#2a3f56;border:1px solid #e6edf5;padding:12px 10px;font-size:14px}.teacher-pref-table tbody tr.row-even td{background-color:#fff}.teacher-pref-table tbody tr.row-odd td{background-color:#f2f7f2}.teacher-pref-table tbody tr:hover td{background-color:#e3f0e8}.teacher-pref-table tbody tr.active-row td{box-shadow:inset 3px 0 #f0b429;background-color:#fff8dc!important}.teacher-pref-table th{color:#344b63;background:#f3f7fc;font-size:15px;font-weight:700}.teacher-name-block{color:#13263d;min-width:150px;font-size:18px;font-weight:600;line-height:1.35}.teacher-short-code{color:#0e3f88}.teacher-pref-count-pill{color:#b13c49;white-space:nowrap;background:#ffe8ea;border-radius:999px;padding:6px 10px;font-size:13px;font-weight:600;display:inline-block}.teacher-pref-cell-wrap{align-items:flex-start;gap:8px;display:flex}.teacher-pref-tags{flex-wrap:wrap;gap:6px;max-width:230px;display:flex}.teacher-pref-tag{color:#2e465f;background:#f1f5fa;border-radius:6px;padding:6px 8px;font-size:12px;font-weight:600;line-height:1.35;display:inline-block}.teacher-pref-tag.pref{color:#1a6b3c;background:#d6f0e0;border:1px solid #b3e0c4}.teacher-pref-tag.assigned{color:#fff;background:#22c55e;border:1px solid #16a34a}.teacher-pref-tag.empty{color:#8194ab;background:#eef2f7;font-weight:400}.teacher-pref-tag[data-tooltip]{cursor:default;position:relative}.teacher-pref-tag[data-tooltip]:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;pointer-events:none;opacity:0;z-index:200;text-overflow:ellipsis;background:#1f2d3d;border-radius:6px;max-width:320px;padding:6px 10px;font-size:12px;font-weight:400;transition:opacity .15s;position:absolute;bottom:calc(100% + 7px);left:50%;overflow:hidden;transform:translate(-50%)}.teacher-pref-tag[data-tooltip]:hover:after{opacity:1}.teacher-pref-edit-btn{color:#3e5670;cursor:pointer;background:#fff;border:1px solid #ced9e6;border-radius:6px;flex-shrink:0;width:30px;height:30px;font-size:14px;line-height:1}.teacher-pref-edit-btn:hover{background:#eef4fc;border-color:#b9cae2}.teacher-pref-modal-overlay,.teacher-pref-confirm-overlay{z-index:1300;background:#0f172a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.teacher-pref-modal,.teacher-pref-confirm-modal{background:#fff;border:1px solid #dbe4ef;border-radius:10px;width:100%;max-width:620px;padding:18px;box-shadow:0 14px 32px #0f172a40}.teacher-pref-confirm-modal{max-width:460px}.teacher-pref-modal-title,.teacher-pref-confirm-title{color:#1f2d3d;margin:0;font-size:18px;font-weight:700}.teacher-pref-confirm-text{color:#3b526c;margin:12px 0 0;font-size:14px;line-height:1.5}.teacher-pref-search-input{box-sizing:border-box;color:#1f2d3d;border:1px solid #ccd7e5;border-radius:6px;width:100%;max-width:100%;margin-top:12px;padding:10px 12px;font-family:inherit;font-size:14px}.teacher-pref-search-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea26}.teacher-pref-course-list{box-sizing:border-box;border:1px solid #dde6f0;border-radius:6px;flex-direction:column;gap:6px;width:100%;max-width:100%;max-height:300px;margin-top:12px;padding:8px;display:flex;overflow-y:auto}.teacher-pref-no-course{color:#647a92;margin:0;padding:10px;font-size:14px}.teacher-pref-list-header{letter-spacing:.04em;text-transform:uppercase;border-radius:4px;margin:4px 0 6px;padding:6px 10px;font-size:12px;font-weight:700}.teacher-pref-list-header.preferred{color:#1a6b3c;background:#d6f0e0;border-left:3px solid #3db870}.teacher-pref-list-header.other{color:#4a6580;background:#f0f4f9;border-left:3px solid #8eaac8;margin-top:14px}.teacher-pref-course-item{cursor:pointer;text-align:left;background:#fff;border:1px solid #d5e0ec;border-radius:6px;align-items:center;gap:10px;padding:10px;display:flex}.teacher-pref-course-item.selected{background:#eef5ff;border-color:#7da1d8}.teacher-pref-course-code{color:#1f2d3d;min-width:80px;font-weight:700}.teacher-pref-course-title{color:#304860;flex:1}.teacher-pref-course-type{color:#435b73;white-space:nowrap;background:#f1f5fa;border-radius:999px;padding:4px 8px;font-size:12px}.teacher-pref-modal-actions,.teacher-pref-confirm-actions{justify-content:flex-end;gap:10px;margin-top:14px;display:flex}.teacher-pref-modal-btn{cursor:pointer;border:none;border-radius:6px;padding:9px 14px;font-family:inherit;font-size:13px;font-weight:600}.teacher-pref-modal-btn.cancel{color:#32465a;background:#edf1f6}.teacher-pref-modal-btn.cancel:hover{background:#e0e7ef}.teacher-pref-modal-btn.ok{color:#fff;background:#2d6cdf}.teacher-pref-modal-btn.ok:hover{background:#1f5fcc}@media (width<=1150px){.teacher-pref-summary-grid{grid-template-columns:repeat(2,minmax(200px,1fr))}}@media (width<=640px){.teacher-pref-summary-grid{grid-template-columns:1fr}.teacher-pref-summary-value{font-size:34px}.teacher-pref-modal,.teacher-pref-confirm-modal{padding:14px}}.teacher-container{padding:20px}.teacher-page-tabs{border-bottom:2px solid #e2eaf4;gap:4px;margin-bottom:24px;padding-bottom:0;display:flex}.teacher-page-tab-btn{color:#5a7494;cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;border-radius:6px 6px 0 0;margin-bottom:-2px;padding:10px 20px;font-family:inherit;font-size:15px;font-weight:600;transition:color .18s,border-color .18s,background .18s}.teacher-page-tab-btn:hover{color:#1f2d3d;background:#f0f5fb}.teacher-page-tab-btn.active{color:#2d6cdf;background:#f4f8ff;border-bottom-color:#2d6cdf}.load-limit-select{color:#1f2d3d;cursor:pointer;background:#fff;border:1px solid #d0d8e6;border-radius:6px;padding:5px 8px;font-family:inherit;font-size:13px;transition:border-color .2s,box-shadow .2s}.load-limit-select:hover{border-color:#667eea}.load-limit-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1f}.teachers-loading{color:#3f5570;text-align:center;padding:40px 0;font-size:15px}.teachers-error{color:#a43d3d;background:#fff0f0;border:1px solid #f4cccc;border-radius:8px;padding:16px 20px;font-size:14px}.teacher-container h2{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 8px;font-size:24px;font-weight:700}.teacher-container>p{color:#666;margin:0 0 20px;font-size:14px}.action-btn{cursor:pointer;color:#333;white-space:nowrap;background-color:#fff;border:1px solid #ddd;border-radius:4px;padding:10px 16px;font-size:14px;font-weight:500;transition:all .3s}.action-btn:hover{background-color:#f5f5f5;border-color:#999}.action-btn.add-btn{color:#fff;background-color:#4a90e2;border-color:#4a90e2}.action-btn.add-btn:hover{background-color:#357abd;border-color:#357abd}.action-btn.import-btn{color:#fff;background-color:#27ae60;border-color:#27ae60}.action-btn.import-btn:hover{background-color:#1e8449;border-color:#1e8449}.action-btn.removed-btn{color:#fff;background-color:#f39c12;border-color:#f39c12}.action-btn.removed-btn:hover{background-color:#d68910;border-color:#d68910}.action-btn.remove-btn{color:#fff;background-color:#e74c3c;border-color:#e74c3c}.action-btn.remove-btn:hover{background-color:#c0392b;border-color:#c0392b}.summary-cards-container{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:30px;margin-left:15px;margin-right:15px;padding:0 10px;display:grid}.summary-card{background:#fff;border-left:5px solid #4a90e2;border-radius:12px;padding:20px;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 4px 15px #0000001a}.summary-card:before{content:"";background:linear-gradient(90deg,#667eea 0%,#764ba2 100%);height:3px;position:absolute;top:0;left:0;right:0}.summary-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.summary-card.preferences-card{border-left-color:#667eea}.summary-card.preferences-card:before{background:linear-gradient(90deg,#667eea 0%,#764ba2 100%)}.summary-card.load-card{border-left-color:#f39c12}.summary-card.load-card:before{background:linear-gradient(90deg,#f39c12 0%,#e74c3c 100%)}.card-title{color:#fff;border-radius:12px 12px 0 0;margin:-20px -20px 16px;padding:12px 16px;font-size:17px;font-weight:700}.summary-card.preferences-card .card-title{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);box-shadow:0 2px 8px #667eea4d}.summary-card.load-card .card-title{background:linear-gradient(135deg,#f39c12 0%,#e74c3c 100%);box-shadow:0 2px 8px #f39c124d}.summary-item{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.summary-item:last-child{border-bottom:none}.summary-label{color:#666;font-size:14px;font-weight:500}.summary-value{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:700}.summary-card.load-card .summary-value{background:linear-gradient(135deg,#f39c12 0%,#e74c3c 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.summary-value.overloaded{color:#e74c3c;-webkit-text-fill-color:unset;background:0 0}.summary-value.near-limit{color:#f39c12;-webkit-text-fill-color:unset;background:0 0}.view-all-btn{color:#fff;cursor:pointer;white-space:nowrap;background-color:#4a90e2;border:1px solid #4a90e2;border-radius:4px;flex-shrink:0;padding:8px 14px;font-size:12px;font-weight:500;transition:all .3s}.view-all-btn:hover{background-color:#357abd}.teachers-table-wrapper{border:1px solid #ddd;border-radius:4px;margin-bottom:15px;overflow-x:auto}.teachers-table{border-collapse:collapse;width:100%;font-size:14px}.teachers-table thead{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-bottom:2px solid #667eea}.teachers-table th{text-align:left;color:#fff;padding:12px;font-weight:600}.teachers-table td{vertical-align:top;border-bottom:1px solid #eee;padding:12px}.teachers-table tbody tr.row-light{background-color:#fff}.teachers-table tbody tr.row-dark{background-color:#f9f9f9}.teachers-table tbody tr:hover{background-color:#f0f0f0}.initials-badge{color:#fff;background-color:#4a90e2;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;font-weight:600;display:inline-flex}.preferences-cell{flex-direction:column;gap:6px;display:flex}.preference-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.preference-btn{cursor:pointer;text-align:center;background-color:#fff;border:1px solid #ddd;border-radius:3px;min-width:50px;padding:4px 8px;font-size:11px;font-weight:500;transition:all .2s}.preference-btn:hover{background-color:#f5f5f5;border-color:#999}.preference-btn.theory-btn{color:#2196f3;background-color:#e3f2fd;border-color:#2196f3}.preference-btn.theory-btn:hover{background-color:#bbdefb}.preference-btn.lab-btn{color:#9c27b0;background-color:#f3e5f5;border-color:#9c27b0}.preference-btn.lab-btn:hover{background-color:#e1bee7}.preference-btn.time-btn{color:#4caf50;background-color:#e8f5e9;border-color:#4caf50}.preference-btn.time-btn:hover{background-color:#c8e6c9}.preference-badge{color:#333;background-color:#e0e0e0;border-radius:50%;justify-content:center;align-items:center;min-width:20px;height:20px;font-size:11px;font-weight:600;display:inline-flex}.add-remove-preference-btn{cursor:pointer;color:#666;background-color:#fff;border:1px solid #ddd;border-radius:3px;min-width:20px;padding:4px 6px;font-size:10px;transition:all .2s}.add-remove-preference-btn:hover{background-color:#f0f0f0;border-color:#999}.load-cell{flex-direction:column;gap:6px;display:flex}.load-hours{color:#333;font-size:13px;font-weight:600}.load-bar-container{background-color:#e0e0e0;border-radius:3px;width:100%;height:6px;overflow:hidden}.load-bar{background-color:#4a90e2;border-radius:3px;height:100%;transition:width .3s}.load-bar.overloaded{background-color:#e74c3c}.status-tag{text-align:center;border-radius:12px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-block}.status-tag.status-ok{color:#fff;background-color:#22c55e;border:none}.status-tag.status-overloaded{color:#fff;background-color:#ef4444;border:none}.courses-cell{flex-direction:column;gap:8px;display:flex}.courses-list{flex-direction:column;gap:4px;display:flex}.course-item{color:#333;background-color:#f5f5f5;border-left:3px solid #4a90e2;border-radius:3px;padding:6px 8px;font-size:12px}.no-course-assigned{color:#b0bec5;font-size:12px;font-style:italic}.no-results{text-align:center;color:#999;font-style:italic;padding:30px 12px!important}@media (width<=1440px){.filter-block{gap:8px}.search-box-container{flex:0 0 200px}.filter-dropdown select{min-width:100px;padding:6px;font-size:11px}.filter-dropdown label{font-size:11px}.view-all-btn{padding:6px 12px;font-size:11px}}@media (width<=1024px){.summary-cards-container{grid-template-columns:1fr}.filter-block{flex-wrap:wrap;gap:10px}.search-box-container{flex:0 0 100%;min-width:auto}.filter-dropdown select{min-width:120px}.preference-btn{padding:3px 6px;font-size:10px}}@media (width<=768px){.action-buttons-block{flex-direction:column}.action-btn{width:100%}.filter-block{flex-direction:column;gap:12px}.search-box-container{flex:100%;min-width:auto}.filter-dropdown{width:100%}.filter-dropdown select{width:100%;min-width:auto}.view-all-btn{width:100%}.teachers-table{font-size:12px}.teachers-table th,.teachers-table td{padding:8px}.initials-badge{width:32px;height:32px;font-size:12px}.preference-row{gap:4px}.preference-btn{min-width:45px;padding:3px 4px;font-size:9px}.preference-badge{min-width:18px;height:18px;font-size:10px}.preference-cell{gap:4px}}.modal-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;animation:.2s ease-in fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-content{background-color:#fff;border-radius:8px;width:90%;max-width:700px;max-height:90vh;animation:.3s ease-out slideUp;overflow-y:auto;box-shadow:0 4px 20px #00000026}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.add-teacher-modal{max-width:500px}.import-teachers-modal{max-width:700px}.remove-teachers-modal,.removed-teachers-modal{max-width:600px}.preference-modal{max-width:500px}.modal-header{background-color:#f9f9f9;border-bottom:1px solid #e0e0e0;border-radius:8px 8px 0 0;justify-content:space-between;align-items:flex-start;padding:20px;display:flex}.modal-header h2{color:#333;margin:0;font-size:20px;font-weight:600}.preference-teacher-name{color:#666;margin:4px 0 0;font-size:14px}.modal-close-btn{color:#999;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:28px;transition:all .2s;display:flex}.modal-form{flex-direction:column;gap:15px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#333;font-size:14px;font-weight:500}.form-group input,.form-group select{border:1px solid #ddd;border-radius:4px;padding:10px;font-family:inherit;font-size:14px;transition:border-color .3s}.form-group input.input-error{border-color:#e74c3c}.form-group input.input-error:focus{box-shadow:0 0 0 3px #e74c3c1a}.error-text{color:#e74c3c;font-size:12px}.form-row{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}.import-section{text-align:center;padding:20px 0}.import-instructions{color:#666;margin-bottom:20px;font-size:13px;line-height:1.6}.import-instructions code{background-color:#f5f5f5;border-radius:4px;margin-top:10px;padding:10px;font-size:12px;display:block;overflow-x:auto}.import-format-hint{text-align:left;flex-wrap:wrap;justify-content:center;gap:16px;margin:0 0 18px;display:flex}.hint-block{background:#f5f7fa;border:1px solid #e0e6ed;border-radius:6px;min-width:160px;padding:10px 14px;font-size:12px}.hint-block strong{color:#3f5570;text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px;font-size:11px;display:block}.hint-block code{color:#1f2d3d;white-space:pre;font-family:Courier New,monospace;font-size:12px;line-height:1.7;display:block}.form-note{color:#7a90a8;margin:0;font-size:12px;font-style:italic}.initials-preview{color:#3f5570;background:#edf2fb;border:1px solid #d4d8f7;border-radius:6px;margin:0;padding:8px 12px;font-size:13px}.initials-preview strong{color:#667eea;font-family:Courier New,monospace;font-size:14px}.file-input-wrapper{margin-bottom:15px;display:inline-block;position:relative}.file-input{opacity:0;width:0;height:0;position:absolute}.file-input-label{color:#fff;cursor:pointer;background-color:#4a90e2;border-radius:4px;padding:12px 20px;font-weight:500;transition:background-color .3s;display:inline-block}.file-input-label:hover{background-color:#357abd}.preview-section h3{color:#333;margin-top:0;margin-bottom:15px;font-size:16px}.preview-table-wrapper{border:1px solid #ddd;border-radius:4px;margin-bottom:15px;overflow-x:auto}.preview-table thead{background-color:#f5f5f5;border-bottom:2px solid #ddd}.preview-table th{text-align:left;color:#333;padding:10px;font-weight:600}.selection-controls{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;display:flex}.select-all-label{cursor:pointer;color:#333;align-items:center;gap:8px;font-weight:500;display:flex}.select-all-label input{cursor:pointer}.selected-count{color:#4a90e2;font-size:13px;font-weight:500}.teachers-selection-list{flex-direction:column;gap:8px;max-height:350px;margin-bottom:15px;display:flex;overflow-y:auto}.teacher-selection-item{cursor:pointer;border:1px solid #eee;border-radius:4px;align-items:center;gap:12px;padding:12px;transition:all .2s;display:flex}.teacher-selection-item:hover{background-color:#f9f9f9;border-color:#ddd}.teacher-selection-item input{cursor:pointer;width:18px;height:18px}.teacher-info{flex-direction:column;gap:2px;display:flex}.teacher-info strong{color:#333;font-size:14px}.teacher-initials{color:#999;font-size:12px}.confirmation-body{text-align:center}.confirmation-icon{margin-bottom:15px;font-size:48px}.confirmation-message{color:#333;margin-bottom:15px;font-size:16px;font-weight:500}.confirmation-list{text-align:left;background-color:#f9f9f9;border:1px solid #eee;border-radius:4px;max-height:200px;margin-bottom:12px;padding:12px;overflow-y:auto}.confirmation-item{color:#333;border-bottom:1px solid #eee;padding:8px;font-size:13px}.confirmation-item:last-child{border-bottom:none}.confirmation-note{color:#999;margin-bottom:15px;font-size:12px}.preference-count-section{justify-content:center;margin-bottom:20px;display:flex}.preference-count-display{background-color:#f9f9f9;border-radius:4px;align-items:center;gap:12px;padding:12px 16px;display:flex}.count-label{color:#333;font-weight:500}.count-badge{color:#333;border-radius:50%;justify-content:center;align-items:center;min-width:32px;height:32px;font-size:14px;font-weight:600;display:inline-flex}.preference-items-section{margin-bottom:20px}.section-title{color:#333;margin-bottom:12px;font-size:14px;font-weight:600}.preference-items-list{flex-direction:column;gap:8px;display:flex}.preference-item{background-color:#fafafa;border:1px solid #eee;border-radius:4px;align-items:center;gap:12px;padding:12px;font-size:13px;display:flex}.pref-number{color:#4a90e2;min-width:24px;font-weight:600}.pref-label-tag{white-space:nowrap;text-align:center;border-radius:4px;min-width:90px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.pref-course-code{color:#1f2d3d;min-width:80px;font-weight:700}.pref-course-title{color:#3b526c;flex:1}.pref-placeholder{color:#888;font-style:italic}.empty-preferences{text-align:center;color:#999;padding:30px 0;font-size:14px}.empty-hint{color:#bbb;margin:6px 0 0;font-size:13px}.empty-state{text-align:center;color:#999;padding:40px 20px;font-size:14px}.modal-buttons{justify-content:flex-end;gap:12px;margin-top:20px;display:flex}.btn-cancel,.btn-confirm,.btn-remove,.btn-restore{cursor:pointer;border:none;border-radius:4px;min-width:100px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .3s}.btn-confirm,.btn-restore{color:#fff;background-color:#4a90e2}.btn-confirm:hover,.btn-restore:hover{background-color:#357abd}.btn-remove{color:#fff;background-color:#e74c3c}.btn-remove:hover{background-color:#c0392b}.btn-cancel:disabled,.btn-confirm:disabled,.btn-remove:disabled,.btn-restore:disabled{opacity:.5;cursor:not-allowed}.allocate-room-source-panel{background:linear-gradient(135deg,#f0f4ff 0%,#eef1f8 100%);border:1px solid #d5dfee;border-radius:8px;padding:16px}.allocate-room-source-title{color:#1f2d3d;margin:0 0 12px;font-size:15px;font-weight:700}.allocate-room-clusters-grid{flex-direction:column;gap:10px;display:flex}.allocate-room-cluster-row{flex-wrap:wrap;align-items:flex-start;gap:12px;display:flex}.allocate-room-cluster-label{color:#fff;white-space:nowrap;text-align:center;background:#667eea;border-radius:5px;min-width:80px;margin-top:2px;padding:4px 10px;font-size:12px;font-weight:700;display:inline-block}.allocate-room-cluster-chips{flex-wrap:wrap;gap:6px;display:flex}.allocate-room-draggable-chip{color:#1f2d3d;cursor:grab;-webkit-user-select:none;user-select:none;background:#fff;border:1.5px solid #b3c2d9;border-radius:5px;padding:5px 10px;font-size:13px;transition:box-shadow .15s,border-color .15s}.allocate-room-draggable-chip:hover{border-color:#667eea;box-shadow:0 2px 6px #667eea40}.allocate-room-draggable-chip:active{cursor:grabbing}.allocate-room-empty-inline{color:#8a9ab5;font-size:12px;font-style:italic}.allocate-room-clusters{grid-template-columns:repeat(2,minmax(280px,1fr));gap:16px;display:grid}.allocate-room-card{background:linear-gradient(135deg,#f9fafc 0%,#f5f7fa 100%);border:1px solid #dfe8f2;border-radius:8px;padding:16px}.allocate-room-card-title{color:#1f2d3d;margin:0 0 12px;font-size:16px;font-weight:700}.allocate-room-drop-zone{border:2px dashed #c8d5e8;border-radius:6px;flex-direction:column;gap:8px;min-height:90px;padding:10px;transition:border-color .15s,background .15s;display:flex}.allocate-room-drop-zone.drag-over{background:#667eea0f;border-color:#667eea}.allocate-room-drop-hint{color:#8a9ab5;text-align:center;margin:auto;font-size:13px;font-style:italic}.allocate-room-chip{color:#1f2d3d;background:#fff;border:1px solid #dbe4ef;border-radius:6px;justify-content:space-between;align-items:center;gap:10px;padding:8px 12px;font-size:14px;display:flex}.allocate-room-remove-btn{cursor:pointer;color:#fff;background:#d9534f;border:none;border-radius:5px;padding:4px 8px;font-size:12px;font-weight:700;line-height:1;transition:background-color .2s}.allocate-room-remove-btn:hover{background:#c63f3a}.allocate-room-table-wrap{border:1px solid #dfe8f2;border-radius:8px;overflow-x:auto}.allocate-room-table{border-collapse:collapse;background:#fff;width:100%}.allocate-room-table th,.allocate-room-table td{text-align:left;vertical-align:middle;border-bottom:1px solid #ebf0f6;padding:12px 14px}.allocate-room-table th{color:#1f2d3d;background:#f3f6fb;font-size:13px;font-weight:700}.allocate-room-table td{color:#3b526c;font-size:14px}.allocate-room-table tbody tr:last-child td{border-bottom:none}.allocate-room-select{color:#1f2d3d;background:#fff;border:1px solid #ccd7e5;border-radius:6px;width:100%;max-width:280px;padding:9px 10px;font-family:inherit;font-size:14px}.allocate-room-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea26}.allocate-room-empty{color:#6a7d94;margin:0;font-size:13px}.allocate-room-loading{color:#6a7d94;margin:0;font-size:14px}.allocate-room-confirm-overlay{z-index:1200;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.allocate-room-confirm-modal{background:#fff;border:1px solid #dfe8f2;border-radius:10px;width:100%;max-width:420px;padding:20px;box-shadow:0 12px 30px #00000038}.allocate-room-confirm-title{color:#1f2d3d;margin:0 0 10px;font-size:18px;font-weight:700}.allocate-room-confirm-text{color:#3b526c;margin:0;font-size:14px;line-height:1.5}.allocate-room-confirm-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.allocate-room-confirm-btn{cursor:pointer;border:none;border-radius:6px;padding:9px 14px;font-family:inherit;font-size:13px;font-weight:600}.allocate-room-confirm-btn.cancel{color:#32465a;background:#edf1f6}.allocate-room-confirm-btn.cancel:hover{background:#e2e8f0}.allocate-room-confirm-btn.confirm{color:#fff;background:#667eea}.allocate-room-confirm-btn.confirm:hover{background:#5a6fd6}@media (width<=900px){.allocate-room-clusters{grid-template-columns:1fr}}@media (width<=600px){.allocate-room-cluster-row,.allocate-room-chip{flex-direction:column;align-items:flex-start}.allocate-room-remove-btn{align-self:flex-end}.allocate-room-select{max-width:100%}}.allocation-panel{flex-direction:column;gap:16px;display:flex}.allocation-panel-title{color:#1f2d3d;margin:0;font-size:20px;font-weight:700}.allocation-panel-description{color:#3b526c;margin:0;font-size:14px;line-height:1.6}.cwt-summary-grid{grid-template-columns:repeat(4,minmax(180px,1fr));gap:14px;display:grid}.cwt-summary-card{background:#fff;border:1px solid #dce7f4;border-radius:8px;flex-direction:column;gap:6px;padding:16px;display:flex}.cwt-summary-card h4{margin:0;font-size:40px;font-weight:700;line-height:1}.cwt-summary-card p{margin:0;font-size:16px;font-weight:500}.cwt-summary-card.blue{color:#2d63da;background:#eef4ff}.cwt-summary-card.amber{color:#c67a00;background:#fff6e8}.cwt-summary-card.green{color:#119662;background:#ecfaf4}.cwt-summary-card.indigo{color:#3d63dd;background:#eef2ff}.cwt-filters-wrap{background:#f8fbff;border:1px solid #dce7f4;border-radius:10px;grid-template-columns:minmax(260px,1fr) 180px 180px;gap:12px;padding:14px;display:grid}.cwt-search-input,.cwt-filter-select,.cwt-modal-search{color:#243a53;background:#fff;border:1px solid #cfd9e7;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px}.cwt-search-input:focus,.cwt-filter-select:focus,.cwt-modal-search:focus{border-color:#3c6fd9;outline:none;box-shadow:0 0 0 3px #3c6fd926}.cwt-table-section{background:#fff;border:1px solid #dce7f4;border-radius:10px;overflow:hidden}.cwt-table-heading{border-bottom:1px solid #e2ebf5;padding:14px}.cwt-table-heading h4{color:#10243d;margin:0;font-size:20px}.cwt-table-heading p{color:#4a647f;margin:4px 0 0}.cwt-table-wrap{overflow-x:auto}.cwt-table{border-collapse:collapse;width:100%;min-width:1280px}.cwt-table th,.cwt-table td{vertical-align:top;text-align:left;color:#1d334d;border:1px solid #e3ebf4;padding:12px;font-size:14px}.cwt-table th{color:#2e4561;background:#f3f7fd;font-size:15px;font-weight:700}.cwt-table tbody tr:nth-child(2n) td{background:#fbfdff}.cwt-table tbody tr:hover td{background:#eaf3ff}.cwt-empty-row{text-align:center;color:#607891;padding:22px}.cwt-empty-notice{color:#6a7d94;margin:0;font-size:14px}.cwt-course-cell{flex-direction:column;gap:6px;min-width:230px;display:flex}.cwt-course-code{color:#2c5fce;margin:0;font-size:22px;font-weight:700;line-height:1}.cwt-course-title{color:#344d67;margin:0;font-size:14px;line-height:1.4}.cwt-course-type{text-transform:uppercase;border-radius:999px;width:fit-content;padding:4px 8px;font-size:12px;font-weight:700}.cwt-course-type.theory{color:#2d65d9;background:#e8f1ff}.cwt-course-type.lab{color:#1c9964;background:#e7f8f1}.cwt-edit-cell{flex-direction:column;gap:8px;min-width:120px;display:flex}.cwt-tag-wrap{flex-wrap:wrap;gap:6px;display:flex}.cwt-tag{color:#2f4f7a;cursor:default;background:#eef4ff;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:600;position:relative}.cwt-tag[data-tooltip]:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;pointer-events:none;opacity:0;z-index:200;background:#1f2d3d;border-radius:6px;padding:6px 10px;font-size:12px;font-weight:400;transition:opacity .15s;position:absolute;bottom:calc(100% + 7px);left:50%;transform:translate(-50%)}.cwt-tag[data-tooltip]:hover:after{opacity:1}.cwt-tag.assigned{color:#fff;background:#22c55e}.cwt-tag.empty{color:#7389a1;background:#edf1f6}.cwt-mini-btn{color:#35506b;cursor:pointer;background:#fff;border:1px solid #c7d6e9;border-radius:6px;width:fit-content;padding:6px 10px;font-size:12px;font-weight:600}.cwt-mini-btn:hover{background:#f5f9ff;border-color:#94abd1}.cwt-mini-btn.primary{color:#fff;background:#2f67d9;border-color:#2f67d9}.cwt-mini-btn.primary:hover{background:#245ac7;border-color:#245ac7}.cwt-assignment-actions{flex-wrap:wrap;gap:6px;display:flex}.cwt-modal-overlay{z-index:1300;background:#101d2d73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.cwt-modal{background:#fff;border:1px solid #d5e1ef;border-radius:10px;width:100%;max-width:560px;padding:16px;box-shadow:0 18px 32px #101d2d3d}.cwt-modal-title{color:#13263d;margin:0;font-size:19px}.cwt-modal-text{color:#4a637d;margin:6px 0 12px;font-size:14px}.cwt-modal-list{border:1px solid #d7e3f0;border-radius:8px;flex-direction:column;gap:8px;max-height:280px;margin-top:10px;padding:8px;display:flex;overflow-y:auto}.cwt-modal-item{text-align:left;cursor:pointer;background:#fff;border:1px solid #d3deec;border-radius:8px;grid-template-columns:70px 1fr;gap:10px;padding:10px;display:grid}.cwt-modal-item.selected{background:#eef4ff;border-color:#6e91d2}.cwt-modal-item-code{color:#214a95;font-weight:700}.cwt-modal-item-name{color:#2a425e}.cwt-modal-actions{justify-content:flex-end;gap:8px;margin-top:12px;display:flex}.cwt-modal-btn{cursor:pointer;border:none;border-radius:6px;padding:9px 13px;font-size:13px;font-weight:600}.cwt-modal-btn.cancel{color:#2e465f;background:#ecf1f7}.cwt-modal-btn.cancel:hover{background:#dfe8f2}.cwt-modal-btn.save{color:#fff;background:#2f67d9}.cwt-modal-btn.save:hover{background:#245ac7}@media (width<=1240px){.cwt-summary-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}}@media (width<=860px){.cwt-filters-wrap{grid-template-columns:1fr}}@media (width<=640px){.cwt-summary-grid{grid-template-columns:1fr}.cwt-summary-card h4{font-size:34px}.cwt-course-code{font-size:24px}}.allocation-container{max-width:1400px;margin:0 auto}.allocation-tabs{flex-wrap:wrap;gap:12px;margin:24px 0;display:flex}.allocation-tab-btn{color:#1f2d3d;cursor:pointer;background:#f0f2f5;border:1px solid #d0d8e6;border-radius:6px;padding:12px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .3s}.allocation-tab-btn:hover{background:#e8ecf3;border-color:#b8cbe0}.allocation-tab-btn.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;box-shadow:0 6px 16px #667eea59}.allocation-tab-content{background:#fff;border-radius:8px;min-height:320px;padding:20px}@media (width<=768px){.allocation-tabs{flex-direction:column}.allocation-tab-btn{width:100%}.allocation-tab-content{min-height:280px;padding:15px}}.class-time-details-container{width:100%}.timeslot-layout{grid-template-columns:350px 1fr;align-items:flex-start;gap:30px;display:grid}.timeslot-fields{flex-direction:column;gap:16px;display:flex;position:relative}.field-item{background:#f8fafb;border:1px solid #e0e6ed;border-radius:8px;padding:14px;transition:all .2s}.field-item:hover{background:#f0f4fa;border-color:#667eea}.field-label{color:#3f5570;text-transform:uppercase;letter-spacing:.3px;margin-bottom:8px;font-size:12px;font-weight:600;display:block}.field-value-container{justify-content:space-between;align-items:center;gap:10px;display:flex}.field-value{color:#1f2d3d;font-size:15px;font-weight:600}.edit-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:4px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .2s}.edit-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.edit-btn:active{transform:translateY(0)}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:12px;min-width:380px;max-width:500px;padding:28px;animation:.3s slideUp;box-shadow:0 10px 40px #0003}.modal-title{color:#1f2d3d;text-align:center;margin:0 0 24px;font-size:18px;font-weight:700}.time-picker-container{justify-content:center;align-items:flex-end;gap:12px;margin-bottom:24px;display:flex}.time-input-group{flex-direction:column;gap:8px;display:flex}.time-input-group label{color:#3f5570;text-transform:uppercase;font-size:12px;font-weight:600}.time-input{text-align:center;color:#1f2d3d;border:2px solid #d0d8e6;border-radius:6px;width:80px;padding:10px 12px;font-family:inherit;font-size:16px;font-weight:600;transition:all .2s}.time-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.time-separator{color:#1f2d3d;margin-bottom:6px;font-size:24px;font-weight:700}.time-period-group{flex-direction:column;gap:8px;display:flex}.time-period-group label{color:#3f5570;text-transform:uppercase;font-size:12px;font-weight:600}.period-select{color:#1f2d3d;cursor:pointer;background:#fff;border:2px solid #d0d8e6;border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.period-select:hover{background:#f9fafd;border-color:#b8cbe0}.period-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.duration-picker-container{justify-content:center;align-items:flex-end;gap:12px;margin-bottom:24px;display:flex}.duration-input-group{flex-direction:column;gap:8px;display:flex}.duration-input-group label{color:#3f5570;text-transform:uppercase;font-size:12px;font-weight:600}.duration-input{text-align:center;color:#1f2d3d;border:2px solid #d0d8e6;border-radius:6px;width:80px;padding:10px 12px;font-family:inherit;font-size:16px;font-weight:600;transition:all .2s}.duration-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.duration-separator{color:#1f2d3d;margin-bottom:6px;font-size:24px;font-weight:700}.day-picker-container{flex-direction:column;gap:16px;margin-bottom:24px;display:flex}.day-input-group{flex-direction:column;gap:8px;display:flex}.day-input-group label{color:#3f5570;text-transform:uppercase;font-size:12px;font-weight:600}.day-select{color:#1f2d3d;cursor:pointer;background:#fff;border:2px solid #d0d8e6;border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px;transition:all .2s}.day-select:hover{background:#f9fafd;border-color:#b8cbe0}.day-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.modal-buttons{justify-content:flex-end;gap:12px;display:flex}.modal-btn{cursor:pointer;border:none;border-radius:6px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.confirm-btn{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.confirm-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.cancel-btn{color:#1f2d3d;background:#f0f2f5;border:1px solid #d0d8e6}.cancel-btn:hover{background:#e8ecf3;border-color:#b8cbe0}.dropdown-overlay{z-index:999;pointer-events:none;position:fixed;inset:0}.dropdown-content{pointer-events:auto;z-index:1001;background:#fff;border:1px solid #d0d8e6;border-radius:8px;min-width:120px;max-height:300px;animation:.2s slideDown;overflow-y:auto;box-shadow:0 4px 16px #00000026}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.loading-message{color:#1565c0;background:#e3f2fd;border-left:4px solid #1976d2;border-radius:6px;margin-bottom:16px;padding:12px 16px;font-size:14px}.error-message{color:#c62828;background:#ffebee;border-left:4px solid #d32f2f;border-radius:6px;margin-bottom:16px;padding:12px 16px;font-size:14px}.save-all-btn.saving{opacity:.7;cursor:not-allowed}.save-all-btn.saving:hover{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);transform:none}.dropdown-item{cursor:pointer;color:#1f2d3d;text-align:center;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s}.dropdown-item:hover{color:#667eea;background:#f0f4fa}.dropdown-item.selected{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);font-weight:700}.timeslot-grid-container{background:#fff;border:1px solid #e0e6ed;border-radius:8px;flex-direction:column;flex:1;gap:0;display:flex;overflow:hidden}.grid-save-section{background:#f9fafd;border-bottom:1px solid #e0e6ed;justify-content:flex-end;gap:8px;padding:12px 16px;display:flex}.save-all-btn{cursor:pointer;border:none;border-radius:6px;padding:10px 24px;font-family:inherit;font-size:14px;font-weight:600;transition:all .3s}.save-all-btn.saved{color:#fff;cursor:default;background:linear-gradient(135deg,#2ecc71 0%,#27ae60 100%);box-shadow:0 2px 8px #2ecc714d}.save-all-btn.pending{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);box-shadow:0 4px 12px #667eea66}.save-all-btn.pending:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.save-all-btn:disabled{opacity:.8}.grid-wrapper-scroll{flex:1;overflow:auto}.grid-wrapper{gap:0;min-width:fit-content;display:grid}.grid-day-cell{color:#fff;text-align:center;background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%);border-bottom:2px solid #1f2d3d;border-right:1px solid #e0e6ed;justify-content:center;align-items:center;min-height:70px;padding:12px;font-size:13px;font-weight:600;display:flex}.grid-header-cell{color:#fff;text-align:center;background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%);border-bottom:2px solid #1f2d3d;border-right:1px solid #e0e6ed;flex-direction:column;justify-content:center;align-items:center;min-height:70px;padding:12px;font-size:12px;font-weight:600;display:flex}.grid-header-cell.lunch{background:linear-gradient(135deg,#f5576c 0%,#f093fb 100%);border-left:3px solid #ff6b6b}.grid-day-label{color:#1f2d3d;background:#f8fafb;border-bottom:1px solid #e0e6ed;border-right:2px solid #1f2d3d;justify-content:center;align-items:center;min-height:60px;padding:12px;font-size:13px;font-weight:600;display:flex}.grid-cell{background:#fff;border-bottom:1px solid #e0e6ed;border-right:1px solid #e0e6ed;justify-content:center;align-items:center;min-height:60px;padding:12px;transition:background .2s;display:flex}.grid-cell:hover{background:#f9fafd}.grid-cell.lunch{background:linear-gradient(135deg,#f5576c26 0%,#f093fb26 100%);border-left:2px solid #f5576c}.grid-cell.lunch:hover{background:linear-gradient(135deg,#f5576c40 0%,#f093fb40 100%)}.class-indicator{opacity:.3;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:4px;width:100%;height:100%}.slot-time{font-size:11px;line-height:1.4}.slot-time-divider{color:#fffc;font-size:10px;line-height:1.2}.lunch-header{flex-direction:column;align-items:center;gap:4px;display:flex}.lunch-header .lunch-label{margin-bottom:4px;font-size:13px;font-weight:700}.class-header{flex-direction:column;align-items:center;gap:2px;display:flex}.lunch-label{font-size:13px;font-weight:700}@media (width<=1024px){.timeslot-layout{grid-template-columns:1fr}.timeslot-fields{max-width:100%}.modal-content{min-width:300px}}@media (width<=768px){.timeslot-layout{grid-template-columns:1fr}.grid-header-cell{min-height:50px;padding:8px;font-size:10px}.grid-cell{min-height:50px;padding:6px}.field-item{padding:12px}.field-label{font-size:11px}.field-value{font-size:14px}.modal-content{min-width:90vw;max-width:90vw}.time-picker-container,.duration-picker-container{flex-wrap:wrap}.time-input,.duration-input{width:60px}}.tab-content{background:#fff;border-radius:8px;min-height:600px;padding:20px}.clusters-container{flex-direction:column;gap:20px;display:flex}.clusters-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;display:flex}.clusters-title{color:#333;margin:0;font-size:24px;font-weight:600}.header-buttons{align-items:center;gap:10px;display:flex}.add-cluster-btn,.btn-add-cluster,.remove-cluster-btn,.btn-remove-cluster{cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:10px 16px;font-size:14px;font-weight:600;transition:all .3s}.add-cluster-btn,.btn-add-cluster{color:#fff;background-color:#4caf50}.add-cluster-btn:hover,.btn-add-cluster:hover{background-color:#45a049;box-shadow:0 2px 8px #4caf504d}.remove-cluster-btn,.btn-remove-cluster{color:#fff;border:1px solid #b71c1c;box-shadow:0 2px 6px #d32f2f40;background-color:#d32f2f!important}.remove-cluster-btn:hover:not(:disabled),.btn-remove-cluster:hover:not(:disabled){box-shadow:0 2px 8px #f443364d;background-color:#b71c1c!important}.remove-cluster-btn:disabled,.btn-remove-cluster:disabled{opacity:.5;cursor:not-allowed}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:500px;animation:.3s slideIn;box-shadow:0 4px 16px #0003}@keyframes slideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.modal-close{color:#666;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:28px;display:flex}.modal-close:hover{color:#000}.modal-body{padding:20px}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:4px;width:100%;padding:10px;font-family:inherit;font-size:14px}.form-group input:focus,.form-group textarea:focus{border-color:#4caf50;outline:none;box-shadow:0 0 0 3px #4caf501a}.form-group select{box-sizing:border-box;background-color:#fff;border:1px solid #ddd;border-radius:4px;width:100%;padding:10px;font-family:inherit;font-size:14px}.form-group select:focus{border-color:#d32f2f;outline:none;box-shadow:0 0 0 3px #d32f2f1f}.modal-footer{border-top:1px solid #e0e0e0;justify-content:flex-end;gap:10px;padding:20px;display:flex}.btn-cancel,.btn-submit{cursor:pointer;border:none;border-radius:4px;padding:10px 16px;font-size:14px;font-weight:500;transition:all .3s}.btn-cancel{color:#333;background-color:#f0f0f0}.btn-cancel:hover{background-color:#e0e0e0}.btn-submit{color:#fff;background-color:#4caf50}.btn-submit:hover{background-color:#45a049}.btn-remove-danger{color:#fff;background-color:#d32f2f}.btn-remove-danger:hover:not(:disabled){background-color:#b71c1c}.btn-remove-danger:disabled{opacity:.55;cursor:not-allowed}.remove-cluster-modal .modal-body{flex-direction:column;gap:12px;display:flex}.remove-cluster-warning{color:#b71c1c;margin:0;font-size:14px;font-weight:600;line-height:1.5}.distance-section{margin-top:20px}.distance-section h3{color:#333;margin:0 0 15px;font-size:16px}.distance-table{border-collapse:collapse;border-radius:4px;width:100%;overflow:hidden;box-shadow:0 2px 4px #0000001a}.distance-table thead{background-color:#f5f5f5}.distance-table th{text-align:left;color:#333;border-bottom:2px solid #ddd;padding:12px;font-weight:600}.distance-table td{border-bottom:1px solid #eee;padding:12px}.distance-table tbody tr:hover{background-color:#f9f9f9}.distance-input{border:1px solid #ddd;border-radius:4px;width:100px;padding:6px;font-size:14px}.distance-input:focus{border-color:#4caf50;outline:none;box-shadow:0 0 0 3px #4caf501a}.clusters-section{margin-top:20px}.clusters-section h3{color:#333;margin:0 0 15px;font-size:16px}.no-clusters{text-align:center;color:#999;background-color:#f9f9f9;border:2px dashed #ddd;border-radius:8px;padding:40px;font-style:italic}.clusters-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.cluster-card{cursor:context-menu;background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);border:1px solid #ddd;border-radius:8px;padding:16px;transition:all .3s;box-shadow:0 2px 8px #00000014}.cluster-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.cluster-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.cluster-card-header h4{color:#333;margin:0;font-size:16px}.btn-remove-card{color:#fff;cursor:pointer;background:#ff5252;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;transition:all .3s;display:flex}.btn-remove-card:hover{background:#ff1744;transform:scale(1.1)}.cluster-rooms{margin-bottom:12px}.rooms-label{color:#555;margin:0 0 8px;font-size:13px;font-weight:600}.rooms-list{flex-wrap:wrap;gap:8px;display:flex}.room-badge{color:#1976d2;background-color:#e3f2fd;border-radius:16px;align-items:center;gap:6px;padding:6px 10px;font-size:13px;font-weight:500;display:inline-flex}.btn-remove-room{color:#1976d2;cursor:pointer;background:0 0;border:none;align-items:center;padding:0;font-size:14px;transition:all .2s;display:flex}.btn-remove-room:hover{color:#d32f2f;transform:scale(1.2)}.cluster-card-footer{gap:8px;display:flex}.add-room-form{gap:6px;width:100%;display:flex}.add-room-form input{border:1px solid #ddd;border-radius:4px;flex:1;padding:6px 10px;font-size:13px}.add-room-form input:focus{border-color:#4caf50;outline:none;box-shadow:0 0 0 2px #4caf501a}.btn-add-room,.btn-cancel-room,.btn-add-room-primary{cursor:pointer;border:none;border-radius:4px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .3s}.btn-add-room-primary{color:#fff;background-color:#4caf50;width:100%;padding:8px 12px}.btn-add-room-primary:hover{background-color:#45a049}.btn-add-room{color:#fff;background-color:#4caf50}.btn-add-room:hover{background-color:#45a049}.btn-cancel-room{color:#333;background-color:#f0f0f0}.btn-cancel-room:hover{background-color:#e0e0e0}.cc-alert-overlay,.cc-confirm-overlay{z-index:1100}.cc-alert-modal,.cc-confirm-modal{max-width:420px}.cc-popup-message{color:#333;white-space:pre-wrap;margin:0;font-size:15px;line-height:1.6}.distance-toast{color:#fff;z-index:2000;pointer-events:none;background:#2e7d32;border-radius:6px;align-items:center;gap:8px;padding:11px 20px;font-size:14px;font-weight:500;animation:2.5s forwards ccToastFade;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 14px #00000040}.distance-toast-icon{font-size:16px;font-weight:700}@keyframes ccToastFade{0%{opacity:0;transform:translateY(16px)}12%{opacity:1;transform:translateY(0)}70%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.btn-removed-clusters{cursor:pointer;white-space:nowrap;color:#fff;background-color:#1565c0;border:none;border-radius:4px;padding:10px 16px;font-size:14px;font-weight:600;transition:all .3s}.btn-removed-clusters:hover{background-color:#0d47a1;box-shadow:0 2px 8px #1565c04d}.clusters-loading,.clusters-error{color:#555;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 20px;font-size:15px;display:flex}.clusters-error{color:#b71c1c}.btn-retry{color:#fff;cursor:pointer;background-color:#1565c0;border:none;border-radius:4px;padding:8px 20px;font-size:14px;font-weight:500;transition:background-color .2s}.btn-retry:hover{background-color:#0d47a1}.removed-clusters-modal{max-width:620px}.removed-clusters-list{flex-direction:column;gap:12px;max-height:420px;padding-right:4px;display:flex;overflow-y:auto}.removed-cluster-item{background-color:#fafafa;border:1px solid #e0e0e0;border-radius:6px;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;display:flex}.removed-cluster-item:hover{background-color:#f5f5f5}.removed-cluster-info{flex:1;min-width:0}.removed-cluster-name{color:#333;margin:0 0 8px;font-size:15px;font-weight:600}.removed-cluster-rooms{flex-wrap:wrap;gap:6px;display:flex}.removed-room-badge{color:#3949ab;background-color:#e8eaf6;border-radius:12px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-block}.no-rooms-text{color:#999;font-size:12px;font-style:italic}.no-removed-clusters{text-align:center;color:#999;padding:30px;font-style:italic}.loading-text{text-align:center;color:#555;padding:30px;font-style:italic}.btn-restore{color:#fff;cursor:pointer;white-space:nowrap;background-color:#2e7d32;border:none;border-radius:4px;flex-shrink:0;padding:7px 16px;font-size:13px;font-weight:600;transition:background-color .2s}.btn-restore:hover{background-color:#1b5e20}@media (width<=768px){.clusters-grid{grid-template-columns:1fr}.clusters-header{flex-direction:column}.btn-add-cluster,.btn-remove-cluster,.btn-removed-clusters{width:100%}.removed-cluster-item{flex-direction:column;align-items:flex-start}.btn-restore{width:100%}.distance-table{font-size:13px}.distance-table th,.distance-table td{padding:8px}.distance-input{width:80px}}.course-time-container{width:100%}.ct-sections-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:flex-start;gap:20px;display:grid}.ct-section-card{background:#f8fafb;border:1px solid #e0e6ed;border-radius:10px;flex-direction:column;gap:16px;padding:18px;display:flex}.ct-section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.ct-section-header h3{color:#1f2d3d;margin:0;font-size:20px}.ct-course-count{color:#3f5570;letter-spacing:.2px;background:#edf2fb;border:1px solid #d7e2f3;border-radius:16px;padding:6px 10px;font-size:12px;font-weight:700}.ct-block{background:#fff;border:1px solid #e0e6ed;border-radius:8px;flex-direction:column;gap:12px;padding:14px;display:flex}.ct-block-title{color:#3f5570;text-transform:uppercase;letter-spacing:.4px;margin:0;font-size:14px}.ct-inline-controls{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.ct-grid-controls{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.ct-input-group{flex-direction:column;gap:6px;display:flex}.ct-input-group label{color:#3f5570;text-transform:uppercase;letter-spacing:.3px;font-size:12px;font-weight:600}.ct-input-group input,.ct-input-group select{color:#1f2d3d;background:#fff;border:1px solid #d0d8e6;border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px;transition:all .25s}.ct-input-group input:hover,.ct-input-group select:hover{background:#f9fafd;border-color:#b8cbe0}.ct-input-group input:focus,.ct-input-group select:focus{background:#fff;border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1f}.ct-btn{color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .25s}.ct-btn:hover{transform:translateY(-1px)}.ct-btn-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.ct-btn-primary:hover{box-shadow:0 4px 12px #667eea59}.ct-btn-secondary{background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%);align-self:flex-start}.ct-btn-secondary:hover{box-shadow:0 4px 12px #2c3e504d}.ct-message{border-radius:6px;margin:0;padding:10px 12px;font-size:13px;font-weight:600}.ct-message.success{color:#20603d;background:#eaf8ef;border:1px solid #c4e7d0}.ct-message.error{color:#a43d3d;background:#fff0f0;border:1px solid #f4cccc}.ct-table-wrapper{border:1px solid #dfe6ef;border-radius:8px;overflow-x:auto}.ct-table{border-collapse:collapse;width:100%;min-width:420px}.ct-table thead{color:#fff;background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%)}.ct-table th,.ct-table td{text-align:left;border-bottom:1px solid #edf1f5;padding:11px 12px;font-size:13px}.ct-table th{text-transform:uppercase;letter-spacing:.3px;font-size:12px}.ct-table tbody tr:hover{background:#f5f8fc}.ct-table tbody tr:last-child td{border-bottom:none}.ct-status-box{color:#3f5570;text-align:center;background:#f8fafb;border:1px solid #e0e6ed;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:60px 24px;font-size:15px;display:flex}.ct-status-error{color:#a43d3d;background:#fff0f0;border-color:#f4cccc}.ct-hint{color:#7a90a8;margin:0;font-size:13px}.ct-empty{text-align:center;color:#8a9bb0;background:#f8fafb;border:1px dashed #d0dae6;border-radius:6px;margin:0;padding:20px 12px;font-size:13px;font-style:italic}.ct-row-assigned{background:#f6fbf7}.ct-row-assigned:hover{background:#edf7ef!important}.ct-course-code{color:#3f5570;white-space:nowrap;background:#edf2fb;border-radius:4px;padding:3px 8px;font-family:Courier New,Courier,monospace;font-size:12px;font-weight:700}.ct-meta{color:#7a90a8;font-size:12px}.ct-duration-badge{color:#2e7d32;background:#e6f4ea;border:1px solid #c8e6c9;border-radius:12px;align-items:center;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.ct-unset{color:#b0bec5;font-size:12px;font-style:italic}.ct-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}@media (width<=1200px){.ct-sections-grid{grid-template-columns:1fr}.ct-grid-controls{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=768px){.ct-section-card{padding:14px}.ct-inline-controls{flex-direction:column;align-items:stretch}.ct-grid-controls{grid-template-columns:1fr}.ct-btn-primary,.ct-btn-secondary{text-align:center;width:100%}}.teachers-time-container{flex-direction:column;gap:18px;width:100%;display:flex}.tt-page-header{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.tt-header-actions{flex-wrap:wrap;gap:10px;display:flex}.tt-btn{color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .25s}.tt-btn:hover{transform:translateY(-1px)}.tt-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.tt-btn-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.tt-btn-primary:hover{box-shadow:0 4px 12px #667eea59}.tt-btn-secondary{background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%)}.tt-btn-secondary:hover{box-shadow:0 4px 12px #2c3e504d}.tt-btn-danger{background:linear-gradient(135deg,#e74c3c 0%,#c0392b 100%)}.tt-btn-danger:hover{box-shadow:0 4px 12px #e74c3c59}.tt-btn-import{color:#1a3a2a;background:linear-gradient(135deg,#11998e 0%,#38ef7d 100%)}.tt-btn-import:hover{box-shadow:0 4px 12px #11998e59}.tt-feedback{border-radius:6px;margin:0;padding:10px 14px;font-size:13px;font-weight:600}.tt-feedback.success{color:#20603d;background:#eaf8ef;border:1px solid #c4e7d0}.tt-feedback.error{color:#a43d3d;background:#fff0f0;border:1px solid #f4cccc}.tt-status-box{color:#3f5570;text-align:center;background:#f8fafb;border:1px solid #e0e6ed;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:60px 24px;font-size:15px;display:flex}.tt-status-error{color:#a43d3d;background:#fff0f0;border-color:#f4cccc}.tt-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.tt-alert-overlay{z-index:1100}.tt-modal{background:#fff;border-radius:10px;flex-direction:column;gap:18px;width:100%;max-width:400px;padding:24px;display:flex;box-shadow:0 8px 32px #0000002e}.tt-add-modal{max-width:520px}.tt-modal-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.tt-modal-header h3{color:#1f2d3d;margin:0;font-size:18px}.tt-modal-close{cursor:pointer;color:#7a90a8;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:20px;line-height:1}.tt-modal-close:hover{color:#1f2d3d;background:#f0f4f8}.tt-modal-message{color:#1f2d3d;white-space:pre-wrap;margin:0;font-size:14px;line-height:1.55}.tt-modal-actions{flex-wrap:wrap;gap:10px;display:flex}.tt-form{flex-direction:column;gap:14px;display:flex}.tt-form-row{flex-wrap:wrap;gap:12px;display:flex}.tt-form-group{flex-direction:column;gap:6px;display:flex}.tt-form-grow{flex:160px}.tt-form-group label{color:#3f5570;text-transform:uppercase;letter-spacing:.3px;font-size:12px;font-weight:600}.tt-required{color:#e74c3c;margin-left:2px}.tt-form-group input{color:#1f2d3d;background:#fff;border:1px solid #d0d8e6;border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px;transition:all .25s}.tt-form-group input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1f}.teachers-time-search-block{background:#f8fafb;border:1px solid #e0e6ed;border-radius:8px;flex-direction:column;gap:8px;padding:14px;display:flex}.teachers-time-search-label{color:#3f5570;text-transform:uppercase;letter-spacing:.3px;font-size:12px;font-weight:600}.teachers-time-search{color:#1f2d3d;background:#fff;border:1px solid #d0d8e6;border-radius:6px;width:100%;max-width:420px;padding:10px 12px;font-family:inherit;font-size:14px;transition:all .25s}.teachers-time-search:hover{background:#f9fafd;border-color:#b8cbe0}.teachers-time-search:focus{background:#fff;border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1f}.teacher-cards-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.teacher-card{background:#fff;border:1px solid #e0e6ed;border-radius:10px;flex-direction:column;gap:10px;min-width:0;padding:12px;display:flex}.teacher-card-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.teacher-card-title{flex-direction:column;gap:3px;min-width:0;display:flex}.teacher-card-title h3{color:#1f2d3d;margin:0;font-size:15px;font-weight:700;line-height:1.3}.teacher-initials{color:#667eea;letter-spacing:.5px;background:#eef0fd;border:1px solid #d4d8f7;border-radius:4px;align-self:flex-start;padding:1px 6px;font-size:11px;font-weight:700}.teacher-card-meta{flex-shrink:0;align-items:center;gap:6px;display:flex}.teacher-delete-btn{color:#b0bec5;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:5px;padding:2px 6px;font-size:16px;line-height:1;transition:all .2s}.teacher-delete-btn:hover{color:#e74c3c;background:#fff0f0;border-color:#f4cccc}.teacher-availability{color:#25623e;white-space:nowrap;background:#eaf8ef;border:1px solid #c4e7d0;border-radius:14px;padding:4px 8px;font-size:13px;font-weight:700}.teacher-grid-scroll{overflow-x:auto}.teacher-time-grid{border:1px solid #dfe6ef;border-radius:6px;gap:0;min-width:max-content;display:grid;overflow:hidden}.teacher-grid-head{color:#fff;text-align:center;background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%);border-bottom:1px solid #1f2d3d;border-right:1px solid #3f5570;justify-content:center;align-items:center;padding:3px;font-size:9px;font-weight:600;line-height:1.2;display:flex}.teacher-grid-head.day-head{font-size:10px}.teacher-grid-head.break-head{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%)}.teacher-day-cell{color:#1f2d3d;background:#f8fafb;border-bottom:1px solid #dfe6ef;border-right:1px solid #dfe6ef;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex}.teacher-slot-cell{cursor:default;background:#fff;border:1px solid #dfe6ef;border-top:none;border-left:none;margin:0;padding:0;transition:background .2s}.teacher-slot-cell.break-cell{background:#f5f7fa}.teacher-slot-cell.selected{background:#31b766}.teacher-slot-cell:enabled{cursor:pointer}.teacher-slot-cell:enabled:hover{background:#eaf8ef}.teacher-slot-cell.selected:enabled:hover{background:#29a95c}.teacher-progress-head{color:#3f5570;justify-content:space-between;align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.teacher-progress-track{background:#d1d5db;border-radius:999px;width:100%;height:10px;overflow:hidden}.teacher-progress-fill{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-radius:999px;height:100%;transition:width .25s}.teacher-edit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:6px;align-self:flex-start;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .25s}.teacher-edit-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea59}.teacher-edit-btn--ok{color:#1a3a2a;background:linear-gradient(135deg,#11998e 0%,#38ef7d 100%)}.teacher-edit-btn--ok:hover{box-shadow:0 4px 12px #11998e59}.teacher-no-results{color:#3f5570;text-align:center;background:#f8fafb;border:1px solid #e0e6ed;border-radius:8px;padding:16px;font-size:14px}@media (width<=1280px){.teacher-cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=900px){.teacher-cards-grid{grid-template-columns:1fr}.teachers-time-search{max-width:100%}}.timeslot-container{max-width:1400px;margin:0 auto}.timeslot-tabs{flex-wrap:wrap;gap:12px;margin:24px 0;display:flex}.tab-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:6px;padding:12px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .3s}.tab-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.tab-btn.active{background:linear-gradient(135deg,#764ba2 0%,#667eea 100%);box-shadow:0 6px 16px #667eea80}.tab-btn:not(.active){color:#1f2d3d;background:#f0f2f5;border:1px solid #d0d8e6}.tab-btn:not(.active):hover{background:#e8ecf3;border-color:#b8cbe0}.tab-content{background:#fff;border-radius:8px;min-height:400px;margin-top:20px;padding:20px}@media (width<=768px){.timeslot-tabs{flex-direction:column}.tab-btn{width:100%}.tab-content{min-height:300px;padding:15px}}.modal-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:500px;max-height:90vh;animation:.3s ease-out slideUp;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.modal-content.modal-large{max-width:700px}.modal-header{border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:20px;display:flex}.modal-header h2{color:#333;margin:0;font-size:20px}.modal-close-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:28px;transition:all .2s;display:flex}.modal-close-btn:hover{color:#333;background-color:#f0f0f0}.modal-body{color:#333;padding:20px}.form-group{margin-bottom:16px}.form-group label{color:#333;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-group input,.form-group select{border:1px solid #ddd;border-radius:4px;width:100%;padding:10px;font-size:14px;transition:border-color .3s}.form-group input:focus,.form-group select:focus{border-color:#4a90e2;outline:none;box-shadow:0 0 0 3px #4a90e21a}.error-message{color:#c00;background-color:#fee;border:1px solid #fcc;border-radius:4px;margin-bottom:16px;padding:12px;font-size:14px}.import-section{text-align:center}.import-info{color:#666;margin:10px 0;font-size:14px}.file-input-btn{color:#fff;cursor:pointer;background-color:#4a90e2;border:none;border-radius:4px;margin:15px 0;padding:10px 20px;font-size:14px;transition:background-color .3s}.file-input-btn:hover{background-color:#357abd}.file-selected{color:#2e7d32;background-color:#e8f5e9;border:1px solid #4caf50;border-radius:4px;margin-top:10px;padding:10px;font-size:14px}.preview-section{text-align:left;margin-top:20px}.preview-section h3{color:#333;margin:0 0 10px;font-size:16px}.preview-table-wrapper{border:1px solid #ddd;border-radius:4px;max-height:300px;overflow-y:auto}.preview-table{border-collapse:collapse;width:100%;font-size:13px}.preview-table thead{background-color:#f5f5f5;position:sticky;top:0}.preview-table th{text-align:left;border-bottom:1px solid #ddd;padding:10px;font-weight:600}.preview-table td{border-bottom:1px solid #f0f0f0;padding:8px 10px}.preview-table tbody tr:hover{background-color:#fafafa}.checkbox-group-header{border-bottom:1px solid #e0e0e0;margin-bottom:10px;padding:10px 0}.checkbox-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;font-size:14px;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;accent-color:#4a90e2;width:auto;margin-right:8px}.remove-courses-list,.removed-courses-list{border:1px solid #ddd;border-radius:4px;max-height:400px;margin:15px 0;padding:10px;overflow-y:auto}.course-checkbox-item{border-bottom:1px solid #f0f0f0;padding:12px}.course-checkbox-item:last-child{border-bottom:none}.course-info{flex-direction:column;gap:4px;display:flex}.course-info small{color:#666;font-size:12px}.selection-info{color:#666;background-color:#f5f5f5;border-radius:4px;margin-top:10px;padding:10px;font-size:13px}.no-courses,.no-courses-message{text-align:center;color:#999;padding:20px;font-size:14px}.confirmation-alert{background-color:#fff3e0;border:1px solid #ffe0b2;border-radius:4px;margin-bottom:15px;padding:15px}.alert-title{color:#e65100;margin:0 0 10px;font-weight:600}.confirmation-alert p{color:#666;margin:8px 0;font-size:14px}.courses-to-remove{background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;max-height:250px;margin-top:10px;overflow-y:auto}.course-item{color:#333;border-bottom:1px solid #f0f0f0;padding:8px 12px;font-size:13px}.course-item:last-child{border-bottom:none}.course-header{border-bottom:1px solid #e0e0e0;margin-bottom:20px;padding-bottom:15px}.course-header h3{color:#333;margin:0;font-size:18px}.course-header p{color:#666;margin:5px 0 0;font-size:14px}.history-list{margin-top:15px}.history-list h4{color:#333;margin:0 0 10px;font-size:15px}.history-table{border-collapse:collapse;width:100%;font-size:14px}.history-table thead{background-color:#f5f5f5}.history-table th{text-align:left;border-bottom:2px solid #ddd;padding:10px;font-weight:600}.history-table td{border-bottom:1px solid #e0e0e0;padding:10px}.history-table tbody tr:hover{background-color:#fafafa}.no-history{text-align:center;color:#999;padding:20px;font-size:14px}.modal-footer{background-color:#f9f9f9;border-top:1px solid #e0e0e0;justify-content:flex-end;gap:10px;padding:15px 20px;display:flex}.btn{cursor:pointer;border:none;border-radius:4px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .3s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-confirm{color:#fff;background-color:#4caf50}.btn-confirm:hover:not(:disabled){background-color:#45a049}.btn-cancel{color:#333;background-color:#f0f0f0;border:1px solid #ddd}.btn-cancel:hover:not(:disabled){background-color:#e0e0e0}.btn-danger{color:#fff;background-color:#f44336}.btn-danger:hover:not(:disabled){background-color:#da190b}@media (width<=600px){.modal-content,.modal-content.modal-large{max-width:95%;max-height:95vh}.modal-header,.modal-body{padding:15px}.modal-footer{flex-direction:column-reverse;padding:12px 15px}.btn{width:100%}}.courses-container{max-width:1200px;margin:0 auto}.action-buttons-block{flex-wrap:wrap;gap:12px;margin:20px 0;display:flex}.action-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:6px;align-items:center;gap:6px;padding:12px 20px;font-family:inherit;font-size:15px;font-weight:600;transition:all .3s;display:flex}.action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.action-btn:active{transform:translateY(0)}.add-btn{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.import-btn{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%)}.remove-btn{background:linear-gradient(135deg,#ff6b6b 0%,#ee5a52 100%)}.remove-btn:hover{box-shadow:0 4px 12px #ff6b6b66}.removed-courses-btn{background:linear-gradient(135deg,orange 0%,#ff8c00 100%);margin-left:auto}.removed-courses-btn:hover{box-shadow:0 4px 12px #ffa50066}.filter-block{box-sizing:border-box;background:#f8fafb;border:1px solid #e0e6ed;border-radius:8px;flex-wrap:wrap;align-items:center;gap:16px;width:100%;margin:20px 0;padding:16px;display:flex}.view-all-btn{color:#1f2d3d;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #d0d8e6;border-radius:6px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:all .3s}.view-all-btn:hover{background:#f0f4fa;border-color:#b8cbe0}.view-all-btn:active{background:#fff}.search-box{color:#1f2d3d;box-sizing:border-box;background:#fff;border:1px solid #d0d8e6;border-radius:6px;width:100%;padding:10px 14px;font-family:inherit;font-size:14px;transition:all .3s}.search-box::placeholder{color:#9ca9b8}.search-box:hover{background:#f9fafd;border-color:#b8cbe0}.search-box:focus{background:#fff;border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.filters-group{flex-wrap:wrap;flex:0 auto;align-items:flex-end;gap:12px;margin-left:auto;display:flex}.filter-dropdown{flex-direction:column;gap:6px;display:flex}.filter-dropdown label{color:#3f5570;text-transform:uppercase;letter-spacing:.3px;font-size:12px;font-weight:600}.filter-dropdown select{color:#1f2d3d;cursor:pointer;background:#fff;border:1px solid #d0d8e6;border-radius:6px;min-width:140px;padding:8px 12px;font-family:inherit;font-size:14px;transition:all .3s}.filter-dropdown select:hover{background:#f9fafd;border-color:#b8cbe0}.filter-dropdown select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.courses-table-wrapper{border:1px solid #e0e6ed;border-radius:8px;margin-top:20px;overflow-x:auto}.courses-table{border-collapse:collapse;background:#fff;width:100%}.courses-table thead{color:#fff;background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%)}.courses-table th{text-align:left;letter-spacing:.3px;padding:14px;font-size:14px;font-weight:600}.courses-table tbody tr:hover{background:#f5f8fc}.courses-table td{color:#1f2d3d;border-bottom:1px solid #e8ecf3;padding:12px 14px;font-size:14px}.courses-table tbody tr.row-light{background:#fff}.courses-table tbody tr.row-dark{background:#f8fafb}.courses-table tbody tr.row-light:hover,.courses-table tbody tr.row-dark:hover{background:#f0f4fa}.history-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%);border:none;border-radius:4px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .3s}.history-btn:hover{transform:translateY(-1px);box-shadow:0 3px 8px #4facfe4d}.history-btn:active{transform:translateY(0)}.no-results{text-align:center;color:#7a8fa8;font-weight:500;padding:24px!important}.table-info{color:#6a7d94;text-align:right;background:#f8fafb;border:1px solid #e0e6ed;border-top:none;border-radius:0 0 8px 8px;padding:12px 14px;font-size:13px}@media (width<=1024px){.filter-block{flex-direction:column;align-items:flex-start}.filters-group{width:100%;margin-left:0}.view-all-btn,.filter-dropdown select{width:100%}}@media (width<=640px){.action-buttons-block{gap:8px}.action-btn{flex:1;padding:10px 14px;font-size:13px}.filter-block{gap:8px;padding:12px}.view-all-btn,.filter-dropdown,.filter-dropdown select{width:100%}.courses-table th,.courses-table td{padding:8px 10px;font-size:12px}.courses-table th{font-size:13px}.history-btn{padding:5px 10px;font-size:11px}}.courses-container{width:100%}.courses-container h2{color:#333;margin-bottom:5px}.courses-container>p{color:#666;margin-bottom:20px;font-size:14px}.action-buttons-block{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.action-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:10px 16px;font-size:14px;font-weight:500;transition:all .3s}.add-btn{color:#fff;background-color:#4caf50}.add-btn:hover{background-color:#45a049;box-shadow:0 2px 8px #4caf504d}.import-btn{color:#fff;background-color:#2196f3}.import-btn:hover{background-color:#0b7dda;box-shadow:0 2px 8px #2196f34d}.removed-courses-btn{color:#fff;background-color:#ff9800}.removed-courses-btn:hover{background-color:#f57c00;box-shadow:0 2px 8px #ff98004d}.remove-btn{color:#fff;background-color:#f44336}.remove-btn:hover{background-color:#da190b;box-shadow:0 2px 8px #f443364d}.filter-block{background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px;flex-wrap:nowrap;align-items:flex-end;gap:10px;margin-bottom:20px;padding:15px;display:flex;overflow-x:auto}.view-mode-toggle{background-color:#f0f0f0;border-radius:4px;gap:0;margin-bottom:15px;padding:4px;display:inline-flex}.toggle-btn{cursor:pointer;color:#666;text-align:center;background-color:#fff;border:1px solid #ddd;border-radius:0;flex:1;min-width:120px;padding:8px 20px;font-size:13px;font-weight:500;transition:all .3s}.toggle-btn:first-child{border-radius:4px 0 0 4px;margin-right:-1px}.toggle-btn:last-child{border-radius:0 4px 4px 0;margin-left:-1px}.toggle-btn:hover{color:#4a90e2;background-color:#fafafa;border-color:#4a90e2}.toggle-btn.active{color:#fff;background-color:#4a90e2;border-color:#4a90e2}.toggle-btn:disabled{opacity:.5;cursor:not-allowed;color:#999;background-color:#f5f5f5}.toggle-btn:disabled:hover{color:#999;background-color:#f5f5f5;border-color:#ddd}.search-box-container{flex:0 0 220px;min-width:0}.search-box{border:1px solid #ddd;border-radius:4px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .3s}.search-box:focus{border-color:#4a90e2;outline:none;box-shadow:0 0 0 3px #4a90e21a}.filters-group{flex-wrap:nowrap;flex:1;justify-content:flex-start;align-items:flex-end;gap:8px;min-width:0;display:flex}.filter-dropdown{flex-direction:column;flex-shrink:0;gap:4px;min-width:0;display:flex}.filter-dropdown label{color:#333;white-space:nowrap;margin-bottom:0;font-size:12px;font-weight:500}.filter-dropdown select{cursor:pointer;white-space:nowrap;background-color:#fff;border:1px solid #ddd;border-radius:4px;min-width:110px;padding:8px;font-size:12px;transition:border-color .3s}.filter-dropdown select:focus{border-color:#4a90e2;outline:none}.clear-filters-btn{cursor:pointer;color:#333;white-space:nowrap;background-color:#f0f0f0;border:1px solid #ddd;border-radius:4px;flex-shrink:0;height:fit-content;padding:8px 14px;font-size:12px;font-weight:500;transition:all .3s}.clear-filters-btn:hover{background-color:#e0e0e0}.courses-table-wrapper{border:1px solid #ddd;border-radius:4px;margin-bottom:15px;overflow-x:auto}.courses-table{border-collapse:collapse;width:100%;font-size:14px}.courses-table thead{background:linear-gradient(135deg,#4a90e2 0%,#357abd 100%);border-bottom:2px solid #4a90e2}.courses-table th{text-align:left;color:#fff;padding:12px;font-weight:600}.courses-table td{border-bottom:1px solid #e0e0e0;padding:12px}.courses-table tbody tr{transition:background-color .2s}.courses-table tbody tr:hover{background-color:#f9f9f9}.row-light{background-color:#fff}.row-dark{background-color:#fafafa}.no-results{text-align:center;color:#999;font-size:14px;padding:30px 12px!important}.history-btn{color:#fff;cursor:pointer;background-color:#2196f3;border:none;border-radius:3px;padding:6px 12px;font-size:12px;font-weight:500;transition:background-color .3s}.history-btn:hover{background-color:#0b7dda}.table-info{text-align:right;color:#666;padding:10px 0;font-size:13px}.view-mode-info{color:#4a90e2;margin-left:5px;font-weight:500}@media (width<=1440px){.filter-block{gap:8px}.search-box-container{flex:0 0 200px}.filter-dropdown select{min-width:100px;padding:6px;font-size:11px}.filter-dropdown label{font-size:11px}.clear-filters-btn{padding:6px 12px;font-size:11px}}@media (width<=1024px){.filter-block{flex-wrap:wrap;gap:10px}.search-box-container{flex:0 0 100%;min-width:auto}.filters-group{flex-wrap:wrap;flex:0 100%}.filter-dropdown select{min-width:120px}}@media (width<=768px){.action-buttons-block{flex-direction:column}.action-btn{width:100%}.view-mode-toggle{width:100%;margin-bottom:15px}.toggle-btn{flex:1}.filter-block{flex-direction:column;gap:12px}.search-box-container{flex:100%;min-width:auto}.filters-group{flex-direction:column;width:100%}.filter-dropdown{width:100%}.filter-dropdown select{width:100%;min-width:auto}.clear-filters-btn{width:100%}.courses-table{font-size:12px}.courses-table th,.courses-table td{padding:8px}.history-btn{padding:4px 8px;font-size:11px}}@media (width<=480px){.search-box{font-size:12px}.courses-table{font-size:11px}.courses-table th,.courses-table td{padding:6px}}.module-page{color:#1f2d3d;box-sizing:border-box;background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);min-height:100vh;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.module-header{color:#fff;background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%);align-items:center;gap:20px;padding:20px 28px;display:flex;box-shadow:0 4px 16px #00000026}.module-header h1{letter-spacing:.2px;margin:0;font-size:28px;font-weight:700}.module-content{max-width:1200px;margin:0 auto;padding:28px}.content-placeholder{background:#fff;border:1px solid #e0e6ed;border-radius:12px;padding:32px;box-shadow:0 2px 12px #00000014}.content-placeholder p{color:#3b526c;margin:0 0 16px;font-size:15px;line-height:1.6}.content-placeholder p:first-child{color:#1f2d3d;font-size:18px;font-weight:600}.content-placeholder ul{margin:16px 0 0;padding-left:24px;list-style:outside}.content-placeholder li{color:#3b526c;margin:8px 0;line-height:1.5}@media (width<=960px){.module-header{flex-direction:column;align-items:flex-start;padding:16px}.module-header h1{font-size:24px}.module-content{padding:16px}.content-placeholder{padding:20px}}@media (width<=640px){.module-header{padding:12px 16px}.module-header h1{font-size:20px}.back-button{padding:8px 12px;font-size:12px}.module-content{padding:12px}.content-placeholder{padding:16px}}.routine-management-page{color:#1f2d3d;box-sizing:border-box;background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);min-height:100vh;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.routine-module-header{color:#fff;background:linear-gradient(135deg,#2c3e50 0%,#34495e 100%);box-shadow:0 4px 16px #00000026}.header-top{justify-content:space-between;align-items:center;gap:16px;padding:16px 28px;display:flex}.header-left{align-items:center;gap:16px;display:flex}.back-button{color:#fff;cursor:pointer;white-space:nowrap;background:#fff3;border:1px solid #ffffff4d;border-radius:6px;padding:10px 16px;font-size:14px;font-weight:600;transition:all .3s}.back-button:hover{background:#ffffff4d;border-color:#ffffff80}.header-top h1{letter-spacing:.2px;margin:0;font-size:24px;font-weight:700}.routine-navigation{align-items:center;gap:0;margin:0;padding:0;display:flex}.nav-option{color:#fffc;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:3px solid #0000;margin:0;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .3s}.nav-option:hover{color:#fff}.nav-option.active{color:#fff;border-bottom-color:#3498db}.routine-content{max-width:1400px;margin:0 auto;padding:28px}.routine-section-content{background:#fff;border:1px solid #e0e6ed;border-radius:12px;padding:28px;animation:.3s ease-in fadeIn;box-shadow:0 2px 12px #00000014}.routine-section-content h2{color:#1f2d3d;margin:0 0 10px;font-size:26px;font-weight:700}.routine-section-content>p{color:#3b526c;margin:0 0 20px;font-size:15px;line-height:1.6}.routine-home{background:radial-gradient(circle at 18% -10%,#5597ff24,#0000 40%),radial-gradient(circle at 92% 4%,#1c996424,#0000 36%),#fff}.home-dashboard-grid{grid-template-columns:330px minmax(0,1fr);align-items:start;gap:18px;display:grid}.semester-selector-card{background:linear-gradient(135deg,#f5f9ff 0%,#eef6ff 100%);border:1px solid #d4e5fb;border-radius:14px;padding:18px}.semester-selector-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.semester-selector-head h3{color:#15365a;margin:0;font-size:18px}.semester-selector-head span{color:#255ec6;background:#e3efff;border-radius:999px;padding:6px 11px;font-size:12px;font-weight:700;display:inline-block}.semester-grid{grid-template-columns:1fr;gap:10px;margin-top:12px;display:grid}.semester-option{color:#304d6d;cursor:pointer;background:#fff;border:1px solid #d7e5f5;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;transition:all .2s;display:flex}.semester-option span{color:#1f57c6;font-size:16px;font-weight:600}.semester-option:hover{background:#f7fbff;border-color:#9fbde2}.semester-option.checked{background:#edf4ff;border-color:#3e79d4;box-shadow:0 0 0 2px #3e79d41f}.semester-option input{accent-color:#2d66d8;width:16px;height:16px;margin:0}.home-actions-card{background:linear-gradient(160deg,#fff 0%,#f5f9ff 100%);border:1px solid #d5e4f6;border-radius:14px;padding:16px}.home-actions-head h3{color:#173a5f;margin:0;font-size:18px}.home-actions-head p{color:#4a637d;margin:6px 0 0;font-size:14px}.home-cards{grid-template-columns:repeat(2,minmax(260px,320px));justify-content:center;gap:24px;margin:18px auto 0;display:grid}.info-card{border:1px solid #4f79b0;border-radius:4px;padding:18px;transition:all .24s}.info-card-action{text-align:left;cursor:pointer;background:linear-gradient(155deg,#c7dbff 0%,#8fb2e7 100%);font-family:inherit}.info-card:hover{border-color:#355d98;transform:translateY(-3px);box-shadow:0 14px 24px #12346647}.info-card-icon{color:#fff;letter-spacing:.4px;background:linear-gradient(145deg,#2f66d8 0%,#1f4fae 100%);border-radius:8px;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:12px;font-size:13px;font-weight:800;display:inline-flex}.info-card-icon svg{width:22px;height:22px}.info-card h3{color:#15355b;margin:0 0 8px;font-size:20px;font-weight:700}.info-card p{color:#2d4f78;margin:0;font-size:15px;line-height:1.5}.info-card-cta{color:#1f56c2;align-items:center;margin-top:12px;font-size:14px;font-weight:700;display:inline-flex}.home-confirm-overlay{z-index:1500;background:#0c182880;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.home-confirm-modal{background:#fff;border:1px solid #d5e2f0;border-radius:14px;width:100%;max-width:560px;padding:18px;box-shadow:0 20px 38px #1229454d}.home-confirm-modal h3{color:#132f4f;margin:0;font-size:20px}.home-confirm-modal p{color:#405a76;margin:8px 0 12px;line-height:1.5}.home-confirm-semesters{flex-wrap:wrap;gap:8px;display:flex}.home-confirm-chip{color:#2f62be;background:#e8f0ff;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700}.home-confirm-actions{justify-content:flex-end;gap:10px;margin-top:14px;display:flex}.home-btn{cursor:pointer;border:none;border-radius:8px;padding:9px 14px;font-family:inherit;font-size:13px;font-weight:700}.home-btn.cancel{color:#345170;background:#e8eef6}.home-btn.cancel:hover{background:#dbe5f0}.home-btn.proceed{color:#fff;background:#2d66d8}.home-btn.proceed:hover{background:#2258c4}.section-controls{flex-wrap:wrap;gap:12px;margin:20px 0;display:flex}.section-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:6px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:all .3s}.section-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.section-btn:active{transform:translateY(0)}.content-area{text-align:center;color:#3b526c;background:linear-gradient(135deg,#f9fafc 0%,#f5f7fa 100%);border:1px dashed #d7e1ee;border-radius:8px;justify-content:center;align-items:center;min-height:200px;margin-top:20px;padding:24px;display:flex}@media (width<=1024px){.home-dashboard-grid{grid-template-columns:1fr}.semester-grid{grid-template-columns:repeat(2,minmax(160px,1fr))}.home-cards{grid-template-columns:repeat(2,minmax(220px,280px));justify-content:center;gap:20px}.header-top{flex-wrap:wrap}.routine-navigation{width:100%;padding:8px 0;overflow-x:auto}.nav-option{padding:8px 12px;font-size:12px}}@media (width<=640px){.routine-module-header{padding:0}.header-top{flex-direction:column;align-items:flex-start;gap:10px;padding:12px 16px}.header-left{width:100%}.header-top h1{font-size:18px}.back-button{padding:8px 12px;font-size:12px}.routine-navigation{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.nav-option{padding:8px 10px;font-size:11px}.routine-section-content{padding:16px}.routine-section-content h2{font-size:20px}.semester-selector-head{flex-direction:column;align-items:flex-start}.home-cards{grid-template-columns:1fr}.home-confirm-actions{flex-direction:column}.home-btn{width:100%}.section-controls{flex-direction:column}.section-btn{width:100%}}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}
