@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Outfit:wght@400;500;600;700;800;900&display=swap);*{box-sizing:border-box;margin:0;padding:0}body{background:#f0f2f5;font-family:Segoe UI,sans-serif}.login-wrapper{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);display:flex;justify-content:center;min-height:100vh}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:420px;padding:40px;width:100%}.login-header{margin-bottom:32px;text-align:center}.login-logo{align-items:center;background:#0f3460;border-radius:14px;color:#fff;display:flex;font-size:28px;font-weight:700;height:60px;justify-content:center;margin:0 auto 16px;width:60px}.login-header h1{color:#1a1a2e;font-size:22px;font-weight:700;margin-bottom:6px}.login-header p{color:#888;font-size:14px}.login-error{background:#fff0f0;border:1px solid #fcc;border-radius:8px;color:#c00;font-size:13px;padding:10px 14px;text-align:center}.form-group,.login-error{margin-bottom:20px}.form-group label{margin-bottom:8px}.form-group input{border:1.5px solid #e0e0e0;border-radius:8px;color:#333;font-size:14px;outline:none;padding:12px 16px;transition:border .2s;width:100%}.form-group input:focus{border-color:#0f3460}.login-btn{background:#0f3460;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;margin-top:8px;padding:13px;transition:background .2s;width:100%}.login-btn:hover{background:#16213e}.login-btn:disabled{background:#aaa;cursor:not-allowed}.tab-switcher{margin-bottom:24px}.tab{flex:1 1;padding:9px}.form-select{background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:14px;outline:none;padding:12px 16px;transition:border .2s;width:100%}.form-select:focus{border-color:#0f3460}.login-success{background:#f0fff4;border:1px solid #b7ebc8;border-radius:8px;color:#1a7f3c;font-size:13px;margin-bottom:20px;padding:10px 14px;text-align:center}.layout{background:#f4f6f9;display:flex;min-height:100vh}.main-content{flex:1 1;margin-left:240px;padding:28px 32px}.dash-topbar{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:16px}.dash-topbar h2{color:#1a1a2e;font-size:24px;font-weight:700}.dash-topbar p{color:#888;font-size:14px;margin-top:4px}.dash-filters{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.dash-select{background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:13px;outline:none;padding:9px 14px;transition:border .2s}.dash-select:focus{border-color:#0f3460}.clear-dash-btn{background:#fff0f0;border:none;border-radius:8px;color:#c00;cursor:pointer;font-size:13px;font-weight:500;padding:9px 16px}.filter-tags{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.filter-tag-label{color:#888}.filter-tag,.filter-tag-label{font-size:12px;font-weight:500}.filter-tag{background:#eef2ff;border-radius:20px;color:#0f3460;padding:3px 10px}.filter-result{color:#16a085;font-size:12px;font-weight:600;margin-left:4px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:20px 24px}.stat-value{font-size:34px;font-weight:700;margin-bottom:4px}.stat-label{font-size:13px;font-weight:500}.stat-sub{color:#bbb;font-size:11px;margin-top:4px}.charts-row{display:flex;gap:16px;margin-bottom:20px}.chart-card{padding:20px}.chart-sub{margin-bottom:14px}.topic-list{display:flex;flex-direction:column;gap:13px;max-height:250px;overflow-y:auto;padding-right:8px;padding-top:6px}.topic-list::-webkit-scrollbar{width:4px}.topic-list::-webkit-scrollbar-thumb{background:#eee;border-radius:4px}.topic-row{align-items:center;display:flex;gap:12px}.topic-name{color:#444;flex-shrink:0;font-size:13px;font-weight:500;width:100px}.topic-bar-bg{background:#f0f0f0;border-radius:6px;flex:1 1;height:10px;overflow:hidden}.topic-pct{flex-shrink:0;font-size:13px;font-weight:600;text-align:right;width:40px}.recent-tests-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:24px;overflow:hidden}.tests-table{border-collapse:collapse;font-size:14px;width:100%}.tests-table th{background:#f8f9fc;border-bottom:2px solid #eee;color:#555;font-size:13px;font-weight:600;padding:12px 16px;text-align:left}.tests-table td{border-bottom:1px solid #f5f5f5;color:#333;padding:13px 16px}.tests-table tr:last-child td{border-bottom:none}.tests-table tbody tr:hover{background:#fafbff}.test-name{color:#0f3460;font-weight:500}.test-date{color:#888;font-size:13px}.type-badge{background:#eef2ff;border-radius:20px;color:#3c5bd4;font-size:12px;font-weight:500;padding:3px 10px}.avg-score-row{align-items:center;display:flex;gap:10px}.avg-bar-bg{background:#f0f0f0;border-radius:4px;height:7px;overflow:hidden;width:80px}.avg-bar-fill{border-radius:4px;height:100%;transition:width .5s ease}.status-done{background:#e6f9f0;border-radius:20px;color:#1a7f3c;font-size:12px;font-weight:600;padding:3px 12px}@media (max-width:768px){.dash-filters,.dash-topbar{align-items:stretch;flex-direction:column}.stats-grid{grid-template-columns:1fr}.charts-row{flex-direction:column}.chart-card,.chart-card.wide{box-sizing:border-box;width:100%}.recent-tests-card{overflow-x:auto}}.search-row{margin-bottom:12px}.search-input{border:1.5px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:14px;outline:none;padding:10px 16px;transition:border .2s;width:100%}.search-input:focus{border-color:#0f3460}.clear-all-btn{background:#fff0f0;border:none;border-radius:6px;color:#c00;cursor:pointer;font-size:12px;font-weight:500;margin-left:10px;padding:2px 10px}.table-wrapper{overflow:visible}.header-row th{color:#444;padding:0;position:relative}.th-content{align-items:center;cursor:pointer;display:flex;gap:4px;padding:14px;-webkit-user-select:none;user-select:none;white-space:nowrap}.th-content:hover{background:#eef2ff}.sortable{cursor:pointer}.sort-icon{color:#ccc;font-size:11px}.sort-icon.active{color:#0f3460}.filter-dropdown-wrap{display:block;position:relative}.filter-head-btn{align-items:center;background:#0000;border:none;color:#444;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;justify-content:space-between;padding:14px;text-align:left;white-space:nowrap;width:100%}.filter-head-btn:hover{background:#eef2ff}.filter-head-btn.open{background:#eef2ff;color:#0f3460}.filter-arrow{color:#888;font-size:11px}.filter-panel{min-width:180px;padding:8px}.check-item{align-items:center;border-radius:6px;color:#333;cursor:pointer;display:flex;font-size:13px;font-weight:400;gap:8px;padding:8px 10px}.check-item:hover{background:#f4f6ff}.check-item input{accent-color:#0f3460;cursor:pointer}.clear-filter-btn{background:#fff0f0;border:none;border-radius:6px;color:#c00;cursor:pointer;font-size:12px;font-weight:500;margin-top:6px;padding:6px;width:100%}.students-table td{padding:13px 14px}.student-name{color:#0f3460;font-weight:500}.dept-badge{background:#eef2ff;border-radius:20px;color:#3c5bd4;font-size:12px;font-weight:500;padding:3px 10px}.action-btns{display:flex;gap:8px}.btn-add{white-space:nowrap}.top-actions{align-items:center;gap:12px}.btn-bulk-delete{background:#fff0f0;border:1px solid #fcc;border-radius:8px;color:#c00;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s;white-space:nowrap}.btn-bulk-delete:hover{background:#ffebeb;border-color:#ffb3b3}.btn-view:hover{background:#d1e5ff}.btn-edit{background:#eef2ff;border-radius:6px;color:#3c5bd4;font-size:12px;font-weight:500;padding:5px 14px;transition:all .2s}.btn-edit:hover{background:#e0e7ff}.btn-delete{background:#fff0f0;border:none;border-radius:6px;color:#c00;cursor:pointer;font-size:12px;font-weight:500;padding:5px 14px}.filter-panel{background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 8px 24px #0000001f;left:0;min-width:190px;overflow:hidden;position:absolute;top:100%;z-index:999}.filter-panel-body{padding:8px 8px 4px}.filter-panel-footer{background:#fafafa;border-top:1px solid #f0f0f0;display:flex;gap:8px;padding:10px}.fp-cancel{background:#f0f2f5;color:#555;font-weight:500}.fp-apply,.fp-cancel{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:13px;padding:7px}.fp-apply{background:#0f3460;color:#fff;font-weight:600}.fp-apply:hover{background:#16213e}.has-filter{background:#eef2ff!important;color:#0f3460!important}.filter-active-dot{background:#e94560;border-radius:50%;flex-shrink:0;height:6px;width:6px}@media (max-width:768px){.btn-add{align-items:center;border-radius:50%;bottom:90px;box-shadow:0 6px 16px #e9456066;display:flex;font-size:0;height:60px;justify-content:center;padding:0;position:fixed;right:20px;width:60px;z-index:1000}.btn-add:before{color:#fff;content:"+";font-size:30px}.top-bar{align-items:stretch;flex-direction:column;gap:10px}.table-wrapper{min-height:400px;overflow-x:auto}}.mobile-expanded-row,.show-mobile-only{display:none!important}@media (max-width:768px){.hide-mobile{display:none!important}.show-mobile-only{display:table-cell!important}.mobile-expanded-row{display:table-row!important}.btn-menu-dot{align-items:center;background:#0000;border:none;color:#0f3460;cursor:pointer;display:flex;font-size:20px;font-weight:700;justify-content:center;line-height:1;padding:8px}.mobile-expanded-content{background:#f8f9fc;border-radius:8px;box-shadow:inset 0 2px 4px #00000005;margin:8px 0;padding:16px}.me-row{align-items:center;border-bottom:1px solid #eee;display:flex;font-size:13px;justify-content:space-between;padding:8px 0}.me-row:last-of-type{border-bottom:none;margin-bottom:12px}.me-label{color:#888;font-weight:500}.me-val{color:#1a1a2e;font-weight:600}.action-btns-mobile{display:flex;gap:10px;margin-top:12px;width:100%}.btn-view-m{background:#eef2ff;border:none;border-radius:8px;color:#3c5bd4}.btn-edit-m,.btn-view-m{flex:1 1;font-size:13px;font-weight:600;padding:10px;text-align:center}.btn-edit-m{background:#f0f4ff;border:1px solid #dbeafe;border-radius:8px;color:#0f3460}.btn-delete-m{background:#fff0f0;border:none;border-radius:8px;color:#c00;flex:1 1;font-size:13px;font-weight:600;padding:10px}}.profile-header-bar{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.back-btn{padding:8px 18px}.btn-edit{background:#0f3460;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 20px}.profile-top{align-items:flex-start;background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000f;display:flex;flex-wrap:wrap;gap:24px;margin-bottom:24px;padding:28px}.profile-avatar{align-items:center;background:linear-gradient(135deg,#0f3460,#e94560);border-radius:18px;color:#fff;display:flex;flex-shrink:0;font-size:26px;font-weight:700;height:72px;justify-content:center;width:72px}.profile-info{flex:1 1}.profile-info h2{color:#1a1a2e;font-size:22px;font-weight:700;margin-bottom:6px}.profile-sub{color:#888;font-size:13px;margin-bottom:4px}.profile-stats-row{display:flex;flex-shrink:0;gap:12px}.mini-stat{background:#f8f9fc;border-radius:10px;min-width:80px;padding:14px 20px;text-align:center}.mini-val{color:#0f3460;font-size:22px;font-weight:700;margin-bottom:4px}.mini-label{color:#aaa;font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:uppercase}.section-title{color:#1a1a2e;font-size:16px;font-weight:700;margin-bottom:14px;margin-top:4px}.perf-grid{display:flex;gap:20px;margin-bottom:24px}.chart-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;flex:1 1;padding:22px}.chart-card.wide{flex:2 1}.chart-title{color:#1a1a2e;font-size:14px;font-weight:600;margin-bottom:3px}.chart-sub{color:#aaa;font-size:12px;margin-bottom:12px}.answer-summary{display:flex;gap:10px;margin-top:14px}.ans-box{border-radius:8px;flex:1 1;padding:10px;text-align:center}.ans-box.correct{background:#e6f9f0}.ans-box.wrong{background:#fff0f0}.ans-box.total{background:#f0f4ff}.ans-val{font-size:20px;font-weight:700}.ans-box.correct .ans-val{color:#1a7f3c}.ans-box.wrong .ans-val{color:#c00}.ans-box.total .ans-val{color:#0f3460}.ans-label{color:#888;font-size:11px;margin-top:2px}.topic-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;gap:14px;margin-bottom:24px;padding:22px}.topic-bar-row{align-items:center;display:flex;gap:14px}.topic-bar-label{color:#444;flex-shrink:0;font-size:13px;font-weight:500;width:110px}.topic-bar-track{background:#f0f0f0;border-radius:6px;flex:1 1;height:10px;overflow:hidden}.topic-bar-fill{border-radius:6px;height:100%;transition:width .6s ease}.topic-bar-info{align-items:center;display:flex;flex-shrink:0;gap:10px;justify-content:flex-end;width:80px}.topic-count{color:#aaa;font-size:12px}.streak-card{padding:22px}.streak-card,.table-wrapper{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:24px}.table-wrapper{overflow:hidden}.students-table{border-collapse:collapse;font-size:14px;width:100%}.header-row th{background:#f8f9fc;border-bottom:2px solid #eee;color:#555;font-size:13px;font-weight:600;text-align:left}.students-table td{border-bottom:1px solid #f5f5f5;color:#333;padding:13px 16px}.students-table tr:last-child td{border-bottom:none}.students-table tbody tr:hover{background:#fafbff}.loading{font-size:15px;padding:80px}.readiness-banner{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px;padding:20px 24px}.add-card,.readiness-banner{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.add-card{max-width:860px;padding:32px}.top-bar{margin-bottom:24px}.back-btn{border-radius:8px;font-weight:500;padding:9px 18px}.back-btn:hover{background:#e0e3e8}.tab-switcher{background:#f0f2f5;border-radius:8px;margin-bottom:28px;width:fit-content}.tab{background:#0000;border:none;border-radius:6px;color:#888;cursor:pointer;font-size:14px;font-weight:500;padding:9px 24px;transition:all .2s}.tab.active{background:#fff;box-shadow:0 1px 4px #0000001a;color:#0f3460}.alert{margin-bottom:20px;padding:12px 16px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:28px}.form-group{display:flex;flex-direction:column;gap:7px}.form-group input,.form-group select{background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;font-size:14px;outline:none;padding:11px 14px;transition:border .2s}.form-group input:focus,.form-group select:focus{border-color:#0f3460}.form-actions{gap:12px;margin-top:8px}.btn-cancel{font-size:14px;padding:10px 24px}.btn-submit{font-size:14px;padding:10px 28px;transition:background .2s}.btn-submit:disabled{background:#aaa;cursor:not-allowed}.template-info{align-items:flex-start;background:#f0f4ff;border-radius:10px;display:flex;gap:14px;margin-bottom:24px;padding:16px}.info-icon{align-items:center;background:#0f3460;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:24px;justify-content:center;width:24px}.info-title{color:#0f3460;font-size:13px;font-weight:600;margin-bottom:4px}.info-desc{color:#666;font-size:12px;margin-bottom:10px}.col-tags{display:flex;flex-wrap:wrap;gap:6px}.col-tag{background:#fff;border:1px solid #b0c0e8;border-radius:4px;color:#0f3460;font-family:monospace;font-size:11px;padding:2px 10px}.file-upload-area{border:2px dashed #d0d8f0;border-radius:12px;cursor:pointer;margin-bottom:24px;padding:48px;text-align:center;transition:all .2s}.file-upload-area:hover{background:#f8faff;border-color:#0f3460}.upload-icon{color:#0f3460;font-size:32px;margin-bottom:12px}.upload-text{color:#333;font-size:15px;font-weight:500;margin-bottom:6px}.upload-sub{color:#aaa;font-size:13px}@media (max-width:768px){.form-grid{grid-template-columns:1fr}.top-bar{gap:12px}.form-actions,.template-info,.top-bar{flex-direction:column}.form-actions{justify-content:stretch}.btn-cancel,.btn-submit{width:100%}.add-card{padding:20px}}.top-bar{margin-bottom:20px}.top-actions{display:flex;gap:10px}.btn-auto{background:#eef2ff;border:1.5px solid #c5d0f5;border-radius:8px;color:#0f3460;cursor:pointer;font-size:13px;font-weight:600;padding:10px 18px}.btn-auto:hover{background:#dde6ff}.btn-auto:disabled{cursor:not-allowed;opacity:.6}.msg-close{line-height:1}.batches-layout{align-items:flex-start;display:flex;gap:20px}.batch-list-panel{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;flex-shrink:0;padding:16px;width:280px}.batch-section-label{align-items:center;border-bottom:1px solid #f0f0f0;color:#aaa;display:flex;font-size:11px;font-weight:700;justify-content:space-between;letter-spacing:.06em;margin-bottom:4px;padding:4px 4px 8px;text-transform:uppercase}.batch-section-count{background:#f0f2f5;border-radius:10px;color:#666;font-size:11px;padding:1px 7px}.batch-item{align-items:center;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:4px;padding:10px;transition:background .15s}.batch-item:hover{background:#f4f6ff}.batch-item.active{background:#eef2ff}.batch-item-left{align-items:center;display:flex;gap:10px}.batch-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.batch-item-name{color:#1a1a2e;font-size:13px;font-weight:500}.batch-item-desc{color:#aaa;font-size:11px;margin-top:1px}.batch-count-badge{background:#f0f2f5;border-radius:10px;color:#555;flex-shrink:0;font-size:12px;font-weight:600;padding:2px 8px}.empty-batch{color:#bbb;font-size:12px;line-height:1.6;padding:12px 8px}.loading-sm{color:#aaa;font-size:13px;padding:12px}.batch-detail-panel{flex:1 1}.detail-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:24px}.detail-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:14px}.detail-header h3{color:#1a1a2e;font-size:18px;font-weight:700;margin-bottom:4px}.detail-sub{color:#888;font-size:13px}.detail-header-actions{display:flex;gap:8px}.btn-sm-edit{background:#eef2ff;color:#0f3460}.btn-sm-delete,.btn-sm-edit{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;padding:6px 16px}.btn-sm-delete{background:#fff0f0;color:#c00}.batch-meta{display:flex;gap:8px;margin-bottom:18px}.meta-pill{background:#f0f2f5;border-radius:20px;color:#555;font-size:12px;font-weight:500;padding:3px 12px;text-transform:capitalize}.meta-pill.blue{background:#eef2ff;color:#0f3460}.edit-form-inline{background:#f8f9fc;border-radius:10px;margin-bottom:20px;padding:16px}.form-group{margin-bottom:14px}.form-group label{color:#444;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;outline:none;padding:10px 12px;transition:border .2s;width:100%}.form-group textarea{height:72px;resize:vertical}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#0f3460}.students-in-batch-header{align-items:center;color:#1a1a2e;display:flex;font-size:14px;font-weight:600;justify-content:space-between;margin-bottom:12px}.btn-add-student{background:#0f3460;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px}.students-in-batch{display:flex;flex-direction:column;gap:8px;max-height:420px;overflow-y:auto}.batch-student-row{align-items:center;background:#f8f9fc;border-radius:8px;display:flex;gap:12px;padding:10px 12px;transition:background .15s}.batch-student-row:hover{background:#eef2ff}.bs-num{color:#bbb;flex-shrink:0;font-size:12px;width:20px}.bs-avatar{align-items:center;background:#0f3460;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:34px;justify-content:center;width:34px}.bs-info{flex:1 1}.bs-name{color:#1a1a2e;font-size:13px;font-weight:500}.bs-sub{color:#aaa;font-size:11px;margin-top:1px}.bs-cgpa{flex-shrink:0;text-align:center}.bs-cgpa-val{color:#0f3460;font-size:14px;font-weight:700}.bs-cgpa-label{color:#aaa;font-size:10px;text-transform:uppercase}.bs-arrears{font-weight:500}.bs-arrears,.btn-remove{flex-shrink:0;font-size:12px}.btn-remove{background:#fff0f0;border:none;border-radius:6px;color:#c00;cursor:pointer;padding:4px 12px}.empty-batch-students{color:#bbb;font-size:13px;padding:20px;text-align:center}.add-student-panel{background:#f8f9fc;border-radius:10px;margin-bottom:20px;padding:16px}.asp-header{align-items:center;color:#1a1a2e;display:flex;font-size:13px;font-weight:600;justify-content:space-between;margin-bottom:10px}.icon-btn{background:none;border:none;color:#888;cursor:pointer;font-size:20px;line-height:1}.asp-search{border:1.5px solid #e0e0e0;border-radius:7px;box-sizing:border-box;font-size:13px;margin-bottom:10px;outline:none;padding:8px 12px;width:100%}.asp-list{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto}.asp-item{align-items:center;background:#fff;border:1px solid #eee;border-radius:7px;display:flex;justify-content:space-between;padding:8px 10px}.asp-name{color:#1a1a2e;font-size:13px;font-weight:500}.asp-info{color:#aaa;font-size:11px;margin-top:1px}.asp-empty{color:#bbb;font-size:13px;padding:16px;text-align:center}.btn-add-sm{background:#0f3460;border:none;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:12px;font-weight:500;padding:5px 12px}.empty-detail{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:80px 40px;text-align:center}.empty-icon{color:#ddd;margin-bottom:14px}.empty-detail p{color:#888;font-size:15px;margin-bottom:6px}.empty-sub{color:#bbb;font-size:13px}.batch-list-search{background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:13px;margin-bottom:12px;outline:none;padding:9px 12px;width:100%}.batch-list-search:focus{border-color:#0f3460}.batch-student-filters{align-items:center;background:#f8f9fc;border:1px solid #e0e0e0;border-radius:10px;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;padding:10px 14px}.bsf-search{background:#fff;border:1.5px solid #e0e0e0;border-radius:7px;flex:1 1;font-size:13px;min-width:160px;outline:none;padding:8px 12px}.bsf-search:focus{border-color:#0f3460}.bsf-select{background:#fff;border:1.5px solid #e0e0e0;border-radius:7px;color:#333;cursor:pointer;font-size:12px;outline:none;padding:8px 10px}.bsf-select:focus{border-color:#0f3460}@media (max-width:768px){.btn-add{align-items:center;border-radius:50%;bottom:90px;box-shadow:0 6px 16px #e9456066;display:flex;font-size:0;height:60px;justify-content:center;padding:0;position:fixed;right:20px;width:60px;z-index:1000}.btn-add:before{color:#fff;content:"+";font-size:30px}.batches-layout{flex-direction:column}.batch-detail-panel,.batch-list-panel{box-sizing:border-box;width:100%}.form-row,.two-col{grid-template-columns:1fr}}.top-bar{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:18px}.top-bar h2{color:#1a1a2e;font-size:24px;font-weight:700}.top-bar p{color:#888;font-size:14px;margin-top:4px}.btn-add{background:#0f3460;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px}.btn-add:hover{background:#16213e}.category-pills{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}.cat-pill{background:#fff;border-radius:10px;box-shadow:0 2px 6px #0000000f;cursor:pointer;min-width:100px;padding:12px 18px;transition:box-shadow .2s}.cat-pill:hover{box-shadow:0 4px 12px #0000001a}.cat-pill-count{font-size:22px;font-weight:700;margin-bottom:2px}.cat-pill-label{color:#888;font-size:11px;font-weight:500;text-transform:capitalize}.qb-filters{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}.qb-search{border:1.5px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:14px;min-width:200px;outline:none;padding:9px 14px}.qb-search:focus{border-color:#0f3460}.qb-select{background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;outline:none;padding:9px 14px}.clear-btn,.qb-select{cursor:pointer;font-size:13px}.clear-btn{background:#fff0f0;border:none;border-radius:8px;color:#c00;font-weight:500;padding:9px 16px}.qb-layout{align-items:flex-start;display:flex;gap:20px}.qb-list{display:flex;flex:1 1;flex-direction:column;gap:8px;max-height:calc(100vh - 280px);overflow-y:auto}.qb-item{background:#fff;border:2px solid #0000;border-radius:10px;box-shadow:0 2px 6px #0000000d;cursor:pointer;padding:14px 16px;transition:all .15s}.qb-item:hover{box-shadow:0 4px 12px #00000014}.qb-item.active{border-color:#0f3460}.qb-item-top{align-items:flex-start;display:flex;gap:10px}.qb-num{color:#bbb;flex-shrink:0;font-size:12px;padding-top:2px;width:22px}.qb-item-body{flex:1 1}.qb-question-text{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#1a1a2e;display:-webkit-box;font-size:13px;font-weight:500;line-height:1.5;margin-bottom:8px;overflow:hidden}.qb-item-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.qb-diff,.qb-topic{font-weight:500}.qb-diff,.qb-ownership,.qb-topic{border-radius:20px;font-size:11px;padding:2px 9px}.qb-ownership{align-items:center;display:flex;font-weight:600;gap:4px}.qb-ownership.global{background:#eef2ff;color:#4f46e5}.qb-ownership.college{background:#fff1f2;color:#e11d48}.qb-company,.qb-source{align-items:center;color:#777;display:flex;font-size:11px;gap:4px}.qb-item-actions{display:flex;flex-shrink:0;gap:6px}.btn-edit-sm{background:#eef2ff;color:#0f3460}.btn-del-sm,.btn-edit-sm{border:none;border-radius:5px;cursor:pointer;font-size:11px;font-weight:500;padding:4px 10px}.btn-del-sm{background:#fff0f0;color:#c00}.qb-empty{background:#fff;border-radius:12px;padding:60px 20px;text-align:center}.qb-empty-icon{color:#ddd;font-size:40px;margin-bottom:12px}.qb-empty p{color:#888;font-size:14px}.qb-empty-sub{color:#bbb;font-size:12px;margin-top:4px}.qb-right{flex-shrink:0;position:sticky;top:20px;width:380px}.qb-form-card,.qb-preview-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;max-height:calc(100vh - 200px);overflow-y:auto;padding:22px}.qb-form-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:18px}.qb-form-header h3{color:#1a1a2e;font-size:16px;font-weight:700}.icon-close{background:none;border:none;color:#888;cursor:pointer;font-size:22px;line-height:1}.alert{border-radius:8px;font-size:13px;margin-bottom:14px;padding:10px 14px}.alert.error{background:#fff0f0;border:1px solid #fcc;color:#c00}.alert.success{background:#f0fff4;border:1px solid #b7ebc8;color:#1a7f3c}.fg input,.fg select,.fg textarea{background:#fff;border:1.5px solid #e0e0e0;border-radius:7px;box-sizing:border-box;font-family:inherit;font-size:13px;outline:none;padding:9px 12px;resize:vertical;transition:border .2s;width:100%}.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:#0f3460}.option-row{gap:8px;margin-bottom:8px}.opt-label,.option-row{align-items:center;display:flex}.opt-label{background:#f0f2f5;border-radius:50%;color:#555;cursor:pointer;flex-shrink:0;font-size:12px;font-weight:700;height:28px;justify-content:center;transition:all .15s;width:28px}.opt-label.correct{background:#16a085;color:#fff}.opt-label:hover{background:#dde6ff}.option-row input{border:1.5px solid #e0e0e0;border-radius:6px;flex:1 1;font-size:13px;outline:none;padding:8px 10px}.option-row input:focus{border-color:#0f3460}.correct-tick{color:#16a085;flex-shrink:0;font-size:11px;font-weight:600}.opt-hint{color:#bbb;font-size:11px;margin-top:4px}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}.btn-cancel{border-radius:7px;padding:8px 18px}.btn-submit{border-radius:7px;padding:8px 20px}.btn-submit:hover{background:#16213e}.preview-meta{display:flex;gap:8px;margin-bottom:14px}.preview-question{color:#1a1a2e;font-size:14px;font-weight:500;line-height:1.6;margin-bottom:16px}.preview-options{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.preview-option{align-items:center;border:1.5px solid #eee;border-radius:8px;color:#333;display:flex;font-size:13px;gap:10px;padding:10px 14px}.preview-option.correct{background:#e6f9f0;border-color:#16a085}.preview-opt-letter{align-items:center;background:#f0f2f5;border-radius:50%;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:24px;justify-content:center;width:24px}.preview-option.correct .preview-opt-letter{background:#16a085;color:#fff}.preview-correct-badge{color:#16a085;font-size:11px;font-weight:600;margin-left:auto}.preview-explanation{background:#f8f9fc;border-radius:8px;margin-bottom:16px;padding:12px 14px}.exp-label{color:#888;font-size:11px;font-weight:600;margin-bottom:4px;text-transform:uppercase}.exp-text{color:#444;font-size:13px;line-height:1.5}.preview-actions{display:flex;gap:10px}.btn-edit-full{background:#eef2ff;color:#0f3460}.btn-del-full,.btn-edit-full{border:none;border-radius:7px;cursor:pointer;flex:1 1;font-size:13px;font-weight:500;padding:9px}.btn-del-full{background:#fff0f0;color:#c00}.qb-right-empty{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:60px 20px;text-align:center}.qb-right-empty p{color:#888;font-size:14px}.loading{color:#aaa;padding:60px;text-align:center}.btn-bulk{background:#eef2ff;border:1.5px solid #c5d0f5;border-radius:8px;color:#0f3460;cursor:pointer;font-size:13px;font-weight:600;padding:10px 18px}.btn-bulk:hover{background:#dde6ff}.bulk-results-modal{width:500px!important}.bulk-summary{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr;margin-bottom:24px}.summary-card{border-radius:10px;padding:16px;text-align:center}.summary-card.added{background:#e6f9f0;color:#1a7f3c}.summary-card.skipped{background:#fff0f0;color:#c00}.summary-card.total{background:#f0f2f5;color:#555}.summary-val{font-size:24px;font-weight:700;margin-bottom:4px}.summary-label{font-size:11px;font-weight:600;opacity:.8;text-transform:uppercase}.bulk-errors h4{color:#c00;font-size:14px;font-weight:600;margin-bottom:8px}.error-list{background:snow;border:1px solid #fee2e2;border-radius:8px;max-height:200px;overflow-y:auto;padding:10px}.error-item{border-bottom:1px solid #fee2e2;display:flex;font-size:12px;gap:10px;padding:6px 0}.error-item:last-child{border-bottom:none}.err-row{color:#c00;flex-shrink:0;font-weight:700}.err-msg{color:#555}@media (max-width:768px){.btn-add{align-items:center;border-radius:50%;bottom:90px;box-shadow:0 6px 16px #e9456066;display:flex;font-size:0;height:60px;justify-content:center;padding:0;position:fixed;right:20px;width:60px;z-index:1000}.btn-add:before{color:#fff;content:"+";font-size:30px}.qb-layout{flex-direction:column}.qb-right{box-sizing:border-box;position:static;width:100%}.form-row{grid-template-columns:1fr}.category-pills{flex-wrap:nowrap;overflow-x:auto;padding-bottom:5px}.category-pills::-webkit-scrollbar{height:4px}.category-pills::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:4px}}.qb-pagination{align-items:center;border-top:1px solid #eee;display:flex;gap:20px;justify-content:center;margin-top:30px;padding:20px 0}.page-btn{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:13px;padding:8px 16px;transition:all .2s}.page-btn:hover:not(:disabled){background:#f0f2f5;border-color:#ccc}.page-btn:disabled{cursor:not-allowed;opacity:.5}.page-info{color:#666;font-size:13px;font-weight:500}.sa-company-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.sa-chip{background:#f1f5f9;border:1.5px solid #0000;border-radius:100px;color:#475569;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s;-webkit-user-select:none;user-select:none}.sa-chip:hover{background:#e2e8f0}.sa-chip.active{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.tests-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.test-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;gap:10px;padding:20px}.test-card-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.test-type-badge{border-radius:20px;font-size:12px;font-weight:600;padding:3px 12px}.neg-badge{background:#fff0f0;border-radius:20px;color:#c00;font-size:11px;font-weight:500;padding:3px 10px}.test-card-name{color:#1a1a2e;font-size:16px;font-weight:700}.test-card-meta{color:#888;display:flex;flex-wrap:wrap;font-size:12px;gap:12px}.test-scheduled{color:#f39c12;font-size:12px;font-weight:500}.test-card-stats{background:#f8f9fc;border-radius:8px;display:flex;gap:0;margin-top:4px;padding:10px}.tcs{flex:1 1;text-align:center}.tcs-val{color:#0f3460;font-size:18px;font-weight:700}.tcs-label{color:#aaa;font-size:11px;margin-top:2px}.test-card-actions{display:flex;gap:8px;margin-top:4px}.btn-manage{background:#0f3460;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:9px}.btn-manage:hover{background:#16213e}.btn-results{background:#16a085;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:9px}.btn-results:hover{background:#0f8566}.btn-del-test{background:#fff0f0;border:none;border-radius:8px;color:#c00;cursor:pointer;font-size:13px;padding:9px 16px}.empty-state{border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:80px}.empty-state .empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{color:#1a1a2e}.empty-state p{color:#888}.modal-overlay{background:#00000080;inset:0}.modal-box{background:#fff;border-radius:14px;box-shadow:0 20px 60px #0003;max-width:95vw;width:560px}.modal-header{border-bottom:1px solid #f0f0f0;padding:20px 24px 16px}.modal-header h3{color:#1a1a2e;font-size:17px;font-weight:700}.modal-close{background:none;border:none;color:#888;cursor:pointer;font-size:22px}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid #f0f0f0;gap:10px;padding:16px 24px}.fg{margin-bottom:14px}.fg label{color:#444;display:block;font-size:12px;font-weight:600;margin-bottom:6px}.fg input,.fg select{background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:13px;outline:none;padding:10px 12px;width:100%}.fg input:focus,.fg select:focus{border-color:#0f3460}.form-row{grid-gap:12px;gap:12px}.checkbox-label{align-items:center;color:#555;cursor:pointer;display:flex;font-size:13px;gap:8px}.checkbox-label input{width:auto}.btn-cancel{background:#f0f2f5;color:#555;padding:9px 20px}.btn-cancel,.btn-submit{border:none;border-radius:8px;cursor:pointer;font-size:13px}.btn-submit{background:#0f3460;color:#fff;font-weight:600;padding:9px 22px}.msg-banner{align-items:center;background:#e6f9f0;border:1px solid #b7ebc8;border-radius:8px;color:#1a7f3c;display:flex;font-size:13px;justify-content:space-between;margin-bottom:16px;padding:10px 16px}.msg-close{background:none;border:none;color:#1a7f3c;cursor:pointer;font-size:18px}.test-detail-header{margin-bottom:20px}.test-detail-header h2{color:#1a1a2e;font-size:22px;font-weight:700}.test-detail-meta{color:#888;display:flex;flex-wrap:wrap;font-size:13px;gap:14px;margin-top:6px}.test-tabs{background:#f0f2f5;border-radius:10px;display:flex;gap:4px;margin-bottom:20px;padding:4px;width:fit-content}.test-tab{background:#0000;border:none;border-radius:7px;color:#888;cursor:pointer;font-size:13px;font-weight:500;padding:9px 22px;transition:all .2s}.test-tab.active{background:#fff;box-shadow:0 1px 4px #0000001a;color:#0f3460}.tab-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:24px}.two-col{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.col-title{color:#1a1a2e;font-size:14px;font-weight:700;margin-bottom:12px}.current-q-list{display:flex;flex-direction:column;gap:8px;max-height:500px;overflow-y:auto}.current-q-item{align-items:flex-start;background:#f8f9fc;border-radius:8px;display:flex;gap:10px;padding:10px 12px}.cq-num{color:#bbb;flex-shrink:0;font-size:12px;padding-top:2px;width:20px}.cq-body{flex:1 1}.cq-text{color:#1a1a2e;font-size:13px;font-weight:500;line-height:1.4;margin-bottom:5px}.cq-meta{display:flex;gap:6px}.cq-topic{background:#eef2ff;color:#3c5bd4}.cq-diff,.cq-topic{border-radius:10px;font-size:11px;padding:2px 8px}.cq-diff.easy{background:#e6f9f0;color:#1a7f3c}.cq-diff.medium{background:#fff8e6;color:#b37400}.btn-remove-q,.cq-diff.hard{background:#fff0f0;color:#c00}.btn-remove-q{border:none;border-radius:5px;cursor:pointer;flex-shrink:0;font-size:12px;height:24px;width:24px}.random-panel{background:#f0f4ff;border-radius:10px;margin-bottom:14px;padding:14px}.random-title{color:#0f3460;font-size:12px;font-weight:600;margin-bottom:10px}.random-filters{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.random-filters input,.random-filters select{background:#fff;border:1.5px solid #e0e0e0;border-radius:7px;font-size:12px;outline:none;padding:7px 10px}.btn-random{background:#0f3460;border:none;border-radius:7px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:7px 14px;white-space:nowrap}.q-search{border:1.5px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:13px;margin-bottom:10px;outline:none;padding:9px 12px;width:100%}.avail-q-list{display:flex;flex-direction:column;gap:6px;max-height:380px;overflow-y:auto}.avail-q-item{align-items:center;background:#fff;border:1px solid #eee;border-radius:7px;display:flex;gap:10px;padding:8px 10px}.avail-q-body{flex:1 1}.avail-q-text{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#1a1a2e;display:-webkit-box;font-size:12px;font-weight:500;line-height:1.4;margin-bottom:4px;overflow:hidden}.avail-q-meta{display:flex;gap:5px}.btn-add-q{align-items:center;background:#0f3460;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;height:28px;justify-content:center;width:28px}.assign-panel{margin-bottom:16px}.btn-assign{background:#0f3460;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:10px;padding:11px;width:100%}.btn-assign:disabled{background:#aaa;cursor:not-allowed}.assigned-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.assigned-item{background:#f8f9fc;border-radius:8px;gap:10px;padding:10px 12px}.ai-avatar,.assigned-item{align-items:center;display:flex}.ai-avatar{background:#0f3460;border-radius:50%;color:#fff;flex-shrink:0;font-size:13px;font-weight:700;height:32px;justify-content:center;width:32px}.ai-info{flex:1 1}.ai-name{color:#1a1a2e;font-size:13px;font-weight:500}.ai-meta{color:#aaa;font-size:11px;margin-top:1px}.ai-status{border-radius:20px;font-size:11px;font-weight:600;padding:3px 10px}.ai-status.submitted{background:#e6f9f0;color:#1a7f3c}.ai-status.in_progress{background:#fff8e6;color:#b37400}.ai-status.pending{background:#f0f0f0;color:#888}.empty-col{color:#bbb;font-size:13px;padding:20px;text-align:center}.results-table{border-collapse:collapse;font-size:14px;width:100%}.results-table th{background:#f8f9fc;border-bottom:2px solid #eee;color:#555;font-size:13px;font-weight:600;padding:12px 14px;text-align:left}.results-table td{border-bottom:1px solid #f5f5f5;color:#333;padding:12px 14px}.results-table tr:last-child td{border-bottom:none}.results-table tbody tr:hover{background:#fafbff}.back-btn{background:#f0f2f5;border:none;border-radius:7px;color:#555;cursor:pointer;font-size:13px;padding:7px 16px}.avail-options{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-top:4px}.avail-opt{border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;padding:14px;text-align:center;transition:all .2s}.avail-opt.selected,.avail-opt:hover{border-color:#0f3460}.avail-opt.selected{background:#eef2ff}.avail-opt-icon{font-size:24px;margin-bottom:6px}.avail-opt-title{color:#1a1a2e;font-size:13px;font-weight:600;margin-bottom:3px}.avail-opt-desc{color:#888;font-size:11px}.assign-section{background:#f0f4ff;border-radius:12px;margin-bottom:16px;padding:18px 20px}.assign-section-title{align-items:center;display:flex;gap:14px}.assign-icon{font-size:28px}.assign-title{color:#1a1a2e;font-size:15px;font-weight:700;margin-bottom:3px}.assign-desc{color:#888;font-size:13px}.btn-assign-global{background:#0f3460;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;margin-left:auto;padding:10px 20px;white-space:nowrap}.assign-divider{color:#aaa;font-size:13px;font-weight:600;margin:16px 0;position:relative;text-align:center}.assign-divider:after,.assign-divider:before{background:#e0e0e0;content:"";height:1px;position:absolute;top:50%;width:45%}.assign-divider:before{left:0}.assign-divider:after{right:0}.assign-panel{background:#f8f9fc;border-radius:10px;margin-bottom:4px;padding:16px}.assign-panel.personalized{background:#f0f4ff;border:1.5px solid #c5d0f5}.assign-panel-header{align-items:flex-start;display:flex;gap:12px;margin-bottom:4px}.assign-panel-icon{flex-shrink:0;font-size:24px}.assign-panel-title{color:#1a1a2e;font-size:14px;font-weight:700;margin-bottom:3px}.assign-panel-desc{color:#888;font-size:12px}.personalized-info{background:#fff;border-radius:8px;display:flex;flex-direction:column;gap:6px;margin-bottom:14px;padding:10px 12px}.pi-item{align-items:center;color:#555;display:flex;font-size:12px;gap:8px}.pi-icon{font-size:14px}.btn-assign-personalized{background:linear-gradient(135deg,#0f3460,#8e44ad);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:10px;padding:11px;width:100%}.btn-assign-personalized:disabled{background:#aaa;cursor:not-allowed}.btn-edit-q{background:#eef2ff;border:none;border-radius:5px;color:#0f3460;cursor:pointer;font-size:11px;font-weight:500;padding:4px 10px}.result-stat-pill{background:#f8f9fc;border:1px solid #eee;border-radius:8px;color:#555;font-size:13px;padding:6px 14px}.pending-students-box{background:#fff8e6;border:1px solid #ffe0a0;border-radius:10px;margin-bottom:16px;padding:14px 16px}.pending-title{color:#b37400;font-size:13px;font-weight:600;margin-bottom:10px}.pending-chips{display:flex;flex-wrap:wrap;gap:6px}.pending-chip{background:#fff;border:1px solid #ffe0a0;border-radius:20px;color:#b37400;font-size:12px;padding:3px 10px}.assign-type-row{margin-bottom:16px}.assign-type-title{color:#1a1a2e;font-size:13px;font-weight:600;margin-bottom:10px}.assign-type-options{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr)}.assign-type-opt{border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;padding:12px 14px;transition:all .15s}.assign-type-opt:hover{border-color:#0f3460}.assign-type-opt.selected{background:#eef2ff;border-color:#0f3460}.ato-label{color:#1a1a2e;font-size:13px;font-weight:600;margin-bottom:3px}.ato-desc{color:#888;font-size:11px}.wizard-steps{background:#f8f9fc;border:1px solid #e0e0e0;border-radius:12px;margin-bottom:22px;padding:14px 18px}.wizard-step,.wizard-steps{align-items:center;display:flex}.wizard-step{gap:8px}.ws-num{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:26px;justify-content:center;width:26px}.wizard-step.done .ws-num{background:#16a085;color:#fff}.wizard-step.active .ws-num{background:#0f3460;color:#fff}.wizard-step.pending .ws-num{background:#e0e0e0;color:#888}.ws-label{font-size:13px;font-weight:500}.wizard-step.done .ws-label{color:#16a085}.wizard-step.active .ws-label{color:#0f3460;font-weight:700}.wizard-step.pending .ws-label{color:#bbb}.wizard-line{background:#e0e0e0;flex:1 1;height:2px;margin:0 12px}.wizard-line.done{background:#16a085}.assign-section-label{border-bottom:1px solid #f0f0f0;color:#1a1a2e;font-size:13px;font-weight:700;margin-bottom:10px;padding-bottom:6px}.assign-type-card{align-items:flex-start;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;gap:12px;padding:14px 16px;position:relative;transition:all .15s}.assign-type-card:hover{border-color:#0f3460}.assign-type-card.selected-std{background:#eef2ff;border-color:#0f3460}.assign-type-card.selected-per{background:#f3effe;border-color:#8e44ad}.atc-icon{flex-shrink:0;font-size:22px;margin-top:2px}.atc-title{color:#1a1a2e;font-size:14px;font-weight:700;margin-bottom:4px}.atc-desc{color:#888;font-size:12px;line-height:1.5}.atc-check{color:#0f3460;font-size:14px;font-weight:700;position:absolute;right:12px;top:10px}.batch-section{border:1px solid #e0e0e0;border-radius:10px;margin-bottom:8px;overflow:hidden}.batch-section-header{align-items:center;background:#f8f9fc;cursor:pointer;display:flex;justify-content:space-between;padding:11px 14px;transition:background .15s;-webkit-user-select:none;user-select:none}.batch-section-header:hover{background:#f0f2f5}.batch-section-arrow{color:#888;font-size:10px}.batch-section-title{color:#1a1a2e;font-size:13px;font-weight:600}.batch-section-count{color:#aaa;font-size:12px}.batch-select-all-btn{background:none;border:1px solid #0f3460;border-radius:5px;color:#0f3460;cursor:pointer;font-size:11px;font-weight:500;padding:2px 8px}.batch-select-all-btn:hover{background:#eef2ff}.batch-chips{border-top:1px solid #f0f0f0;flex-wrap:wrap;gap:8px;padding:12px 14px}.batch-chip,.batch-chips{background:#fff;display:flex}.batch-chip{align-items:center;border:1.5px solid #e0e0e0;border-radius:20px;cursor:pointer;gap:6px;padding:6px 12px;transition:all .15s}.batch-chip:hover{border-color:#0f3460}.batch-chip.selected{background:#e6f9f0;border-color:#16a085}.batch-chip-name{color:#1a1a2e;font-size:12px;font-weight:500}.batch-chip-count{color:#aaa;font-size:10px}.batch-chip-check{color:#16a085;font-size:11px;font-weight:700}.tests-section-tabs{display:flex;gap:6px;margin-bottom:20px}.tests-section-tab{align-items:center;background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;color:#888;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;padding:9px 22px;transition:all .2s}.tests-section-tab:hover{border-color:#0f3460;color:#0f3460}.tests-section-tab.active{background:#0f3460;border-color:#0f3460;color:#fff}.section-tab-count{background:#0000001a;border-radius:20px;font-size:11px;font-weight:700;padding:1px 8px}.tests-section-tab.active .section-tab-count{background:#ffffff40}.section-tab-count.completed{background:#e6f9f0;color:#1a7f3c}.tests-section-tab.active .section-tab-count.completed{background:#ffffff40;color:#fff}@media (max-width:768px){.btn-add{align-items:center;border-radius:50%;bottom:90px;box-shadow:0 6px 16px #e9456066;display:flex;font-size:0;height:60px;justify-content:center;padding:0;position:fixed;right:20px;width:60px;z-index:1000}.btn-add:before{color:#fff;content:"+";font-size:30px}.form-row,.two-col{grid-template-columns:1fr!important}.avail-options{grid-template-columns:1fr}.test-tabs{box-sizing:border-box;overflow-x:auto;width:100%}.results-table-container{display:block;overflow-x:auto;width:100%}.tests-grid{grid-template-columns:1fr}}.super-admin-page{animation:fadeIn .4s ease-out;padding:20px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.super-header{align-items:flex-end;border-bottom:1px #f0f0f0;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.super-header h1{color:#0f3460;font-size:1.8rem;margin-bottom:4px}.super-header p{color:#666;font-size:.95rem}.tab-switcher{background:#f4f6f9;border-radius:10px;display:flex;gap:4px;padding:4px}.tab-btn{background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 20px;transition:all .2s}.tab-btn.active,.tab-btn:hover{background:#fff;color:#0f3460}.tab-btn.active{box-shadow:0 4px 10px #0000000d}.super-stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:30px}.super-stat-card{background:#fff;border:1px solid #f0f0f0;border-radius:16px;box-shadow:0 4px 20px #00000008;overflow:hidden;padding:25px;position:relative;transition:transform .3s}.super-stat-card:hover{transform:translateY(-5px)}.stat-label{color:#888;font-size:.85rem;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.stat-val{color:#0f3460;font-size:2.2rem;font-weight:800}.stat-icon{bottom:-10px;font-size:5rem;opacity:.05;position:absolute;right:-10px}.platform-health-card{background:#fff;border:1px solid #f0f0f0;border-radius:16px;margin-top:20px;padding:25px}.platform-health-card h3{color:#0f3460;margin-bottom:20px}.health-metrics{display:flex;flex-direction:column;gap:15px}.metric{align-items:center;border-bottom:1px solid #f9f9f9;display:flex;justify-content:space-between;padding-bottom:12px}.status-badge{border-radius:20px;font-size:.75rem;font-weight:600;padding:4px 12px}.status-badge.online{background:#e6fffa;color:#16a085}.status-badge.offline{background:#fff5f5;color:#e94560}.status-badge.security{background:#ebf8ff;color:#2980b9}.view-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.add-college-btn{background:linear-gradient(135deg,#0f3460,#16213e);border:none;border-radius:8px;box-shadow:0 4px 15px #0f346033;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s}.add-college-btn:hover{box-shadow:0 6px 20px #0f34604d;transform:scale(1.02)}.college-list-card{background:#fff;border:1px solid #f0f0f0;border-radius:16px;overflow:hidden}.super-table{border-collapse:collapse;width:100%}.super-table th{background:#fcfcfc;border-bottom:1px solid #eee;color:#888;font-size:.85rem;font-weight:600;padding:15px 20px;text-align:left}.super-table td{border-bottom:1px solid #f9f9f9;color:#444;font-size:.9rem;padding:15px 20px}.super-table tr:hover{background:#fbfbfb}.bold{color:#0f3460;font-weight:600}.action-btn{border:1px solid #0000;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600;padding:6px 12px;transition:all .2s}.action-btn.toggle{background:#f7fafc;border-color:#e2e8f0;color:#4a5568}.action-btn.toggle:hover{background:#edf2f7}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.super-modal{animation:modalIn .3s cubic-bezier(.175,.885,.32,1.275);background:#fff;border-radius:20px;box-shadow:0 20px 50px #0003;max-width:500px;overflow:hidden;padding:30px;width:100%}@keyframes modalIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:25px}.modal-header h2{color:#0f3460}.close-modal{background:none;border:none;color:#aaa;cursor:pointer;font-size:2rem}.form-section{background:#f8fafc;border-radius:12px;margin-bottom:20px;padding:15px}.form-section h4{color:#64748b;font-size:.75rem;margin-bottom:12px;text-transform:uppercase}.form-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.form-row,input{margin-bottom:10px}input{border:1px solid #e2e8f0;border-radius:8px;font-family:inherit;outline:none;padding:12px;transition:border-color .2s;width:100%}input:focus{border-color:#0f3460}.modal-footer{display:flex;gap:12px;justify-content:flex-end;margin-top:25px}.cancel-btn{background:#f1f5f9;color:#64748b;padding:10px 20px}.cancel-btn,.save-btn{border:none;border-radius:8px;cursor:pointer;font-weight:600}.save-btn{background:#0f3460;color:#fff;padding:10px 24px}.loader{color:#aaa;font-style:italic;padding:100px;text-align:center}.sa-qb-container{margin:0 auto;max-width:1400px;padding:20px}.sa-qb-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.sa-qb-header h1{color:#1a1a2e;font-size:26px;font-weight:800;margin-bottom:4px}.sa-qb-header p{color:#64748b;font-size:14px}.sa-stat-pill{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;display:flex;flex-direction:column;padding:10px 20px}.sa-stat-pill .label{color:#94a3b8;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.sa-stat-pill .val{color:#1e293b;font-size:20px;font-weight:700}.sa-qb-filters{background:#fff;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;display:flex;gap:16px;margin-bottom:20px;padding:16px}.search-group{align-items:center;display:flex;flex:1 1;position:relative}.search-icon{color:#94a3b8;left:12px;position:absolute}.search-group input{border:1.5px solid #e2e8f0;border-radius:8px;font-size:14px;outline:none;padding:10px 10px 10px 38px;transition:all .2s;width:100%}.search-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.sa-filter-select{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;font-size:14px;outline:none;padding:10px 16px}.sa-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden}.sa-questions-table{border-collapse:collapse;font-size:14px;text-align:left;width:100%}.sa-questions-table th{background:#f8fafc;border-bottom:1.5px solid #f1f5f9;color:#64748b;font-weight:600;padding:14px 16px}.sa-questions-table td{border-bottom:1.5px solid #f1f5f9;padding:16px;vertical-align:middle}.q-text-cell{color:#334155;font-weight:500;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topic-tag{background:#f1f5f9;border-radius:6px;color:#475569;font-size:12px;font-weight:600;padding:4px 10px}.diff-badge{border-radius:4px;font-size:11px;font-weight:700;padding:4px 8px;text-transform:uppercase}.diff-badge.easy{background:#dcfce7;color:#166534}.diff-badge.medium{background:#fef9c3;color:#854d0e}.diff-badge.hard{background:#fee2e2;color:#991b1b}.attribution-cell .user-info{display:flex;flex-direction:column}.user-name{color:#1e293b;font-weight:600}.user-role{color:#94a3b8;font-size:11px;text-transform:capitalize}.origin-badge{border-radius:100px;font-size:11px;font-weight:600;padding:3px 8px}.origin-badge.global{background:#eff6ff;border:1px solid #dbeafe;color:#2563eb}.origin-badge.college{background:#faf5ff;border:1px solid #f3e8ff;color:#7c3aed}.date-cell{color:#64748b;font-size:12px}.sa-pagination{align-items:center;background:#f8fafc;display:flex;gap:16px;justify-content:center;padding:16px}.sa-pagination button{background:#fff;border:1.5px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s}.sa-pagination button:hover:not(:disabled){background:#f1f5f9;border-color:#94a3b8}.sa-pagination button:disabled{cursor:not-allowed;opacity:.5}.page-numbers{color:#64748b;font-size:13px;font-weight:600}.sa-loader{color:#94a3b8;font-style:italic;font-weight:500;padding:60px;text-align:center}.btn-add-global{background:#0f172a;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s}.btn-add-global:hover{background:#1e293b;transform:translateY(-1px)}.sa-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a99;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.sa-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;max-width:650px;overflow-y:auto;padding:24px;width:100%}.sa-modal-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.sa-modal-header h2{color:#0f172a;font-size:18px;font-weight:700}.close-btn{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:24px}.sa-form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.sa-form-group.full{grid-column:span 2}.sa-form-group label{color:#475569;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.sa-form-group input,.sa-form-group select,.sa-form-group textarea{border:1.5px solid #e2e8f0;border-radius:8px;font-size:14px;outline:none;padding:10px;width:100%}.sa-form-group input:focus,.sa-form-group select:focus,.sa-form-group textarea:focus{border-color:#3b82f6}.sa-opt-row{align-items:center;display:flex;gap:12px;margin-bottom:8px}.row-actions{display:flex;gap:8px}.icon-btn-edit{color:#3b82f6}.icon-btn-del,.icon-btn-edit{background:#f1f5f9;border:none;border-radius:6px;cursor:pointer;height:32px;width:32px}.icon-btn-del{color:#ef4444}.sa-modal-footer{border-top:1px solid #f1f5f9;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:16px}.sa-btn-cancel{background:#f1f5f9;color:#475569}.sa-btn-cancel,.sa-btn-save{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:10px 20px}.sa-btn-save{background:#3b82f6;color:#fff}.btn-bulk-sa{background:#f1f5f9;border:1.5px solid #e2e8f0;border-radius:8px;color:#0f172a;cursor:pointer;font-weight:600;margin-right:12px;padding:10px 20px}.btn-bulk-sa:hover{background:#e2e8f0}.bulk-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr;margin-bottom:24px}.b-stat{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px;text-align:center}.b-stat span{color:#94a3b8;display:block;font-size:11px;font-weight:700;margin-bottom:4px;text-transform:uppercase}.b-stat strong{color:#0f172a;font-size:20px}.sa-bulk-errors h4{color:#ef4444;font-size:14px;font-weight:700;margin-bottom:12px}.error-log{background:#fffbfa;border:1px solid #fee2e2;border-radius:8px;max-height:200px;overflow-y:auto;padding:12px}.err-row{border-bottom:1px solid #fee2e2;display:flex;font-size:12px;gap:8px;padding:4px 0}.err-row:last-child{border-bottom:none}.row-num{color:#ef4444;font-weight:700}.err-msg{color:#64748b}.portal-loading,.sa-qb-actions{align-items:center;display:flex}.portal-loading{color:#888;flex-direction:column;font-size:15px;gap:16px;justify-content:center;min-height:100vh}.portal-spinner{animation:spin .8s linear infinite;border:3px solid #eee;border-radius:50%;border-top-color:#0f3460;height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.portal-wrapper{background:#f4f6f9;font-family:Segoe UI,sans-serif;min-height:100vh}.portal-navbar{background:#fff;box-shadow:0 2px 8px #0000000f;height:60px;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:100}.portal-brand,.portal-navbar{align-items:center;display:flex}.portal-brand{gap:10px}.portal-logo{align-items:center;background:#0f3460;border-radius:8px;color:#fff;display:flex;font-size:16px;font-weight:700;height:32px;justify-content:center;width:32px}.portal-brand span{color:#1a1a2e;font-size:16px;font-weight:700}.portal-nav-right{gap:16px}.portal-nav-right,.portal-user{align-items:center;display:flex}.portal-user{gap:10px}.portal-avatar{align-items:center;background:linear-gradient(135deg,#0f3460,#e94560);border-radius:50%;color:#fff;display:flex;font-size:15px;font-weight:700;height:36px;justify-content:center;width:36px}.portal-uname{color:#1a1a2e;font-size:13px;font-weight:600}.portal-udept{color:#aaa;font-size:11px}.portal-logout{background:#fff0f0;border:none;border-radius:7px;color:#c00;cursor:pointer;font-size:13px;font-weight:500;padding:7px 16px}.portal-body{margin:0 auto;max-width:1200px;padding:24px 32px}.portal-welcome-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.portal-welcome{color:#1a1a2e;font-size:22px;font-weight:700;margin-bottom:4px}.portal-welcome-sub{color:#888;font-size:13px}.student-profile-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.profile-chip{align-items:center;background:#eef2ff;border:1px solid #e0e7ff;border-radius:20px;color:#3c5bd4;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:4px 12px}.profile-chip.arrears-chip{background:#fff7ed;border-color:#fed7aa;color:#c05621}.btn-quick-start{background:#0f3460;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:11px 22px;transition:background .2s}.btn-quick-start:hover{background:#16213e}.portal-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 340px}.portal-left,.portal-right{display:flex;flex-direction:column;gap:20px}.portal-card{background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000f;padding:20px}.portal-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.portal-card-title{color:#1a1a2e;font-size:14px;font-weight:700}.portal-select{background:#fff;border:1px solid #eee;border-radius:6px;color:#555;font-size:12px;outline:none;padding:5px 10px}.portal-empty{color:#bbb;font-size:13px;padding:20px 0;text-align:center}.progress-circles{display:flex;gap:12px;justify-content:space-around}.progress-circle-item{text-align:center}.circle-chart{display:inline-block;position:relative}.circle-pct{color:#1a1a2e;font-size:16px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.circle-label{color:#333;font-size:12px;font-weight:600;margin-top:6px}.circle-mastery{color:#888;font-size:11px;margin-top:2px}.activity-table{border-collapse:collapse;font-size:13px;width:100%}.activity-table th{border-bottom:1px solid #f0f0f0;color:#aaa;font-size:11px;font-weight:600;padding:8px 10px;text-align:left;text-transform:uppercase}.activity-table td{border-bottom:1px solid #f8f8f8;padding:10px}.activity-table tr:last-child td{border-bottom:none}.act-name{color:#1a1a2e;font-weight:500}.act-date{color:#aaa;font-size:12px}.act-score{font-weight:700}.act-badge{border-radius:20px;font-size:11px;font-weight:600;padding:2px 9px}.act-details{background:#eef2ff;border:none;border-radius:5px;color:#0f3460;cursor:pointer;font-size:11px;font-weight:500;padding:3px 10px}.upcoming-list{display:flex;flex-direction:column;gap:10px}.upcoming-item{align-items:center;background:#f8f9fc;border-radius:10px;display:flex;justify-content:space-between;padding:10px 12px}.upcoming-name{color:#1a1a2e;font-size:13px;font-weight:500;margin-bottom:3px}.upcoming-meta{color:#aaa;font-size:11px}.upcoming-btn{border:none;border-radius:7px;cursor:pointer;flex-shrink:0;font-size:12px;font-weight:600;padding:6px 16px}.upcoming-btn.start{background:#0f3460;color:#fff}.upcoming-btn.wait{background:#f0f2f5;color:#888}.view-all{color:#0f3460;cursor:pointer;font-size:12px;font-weight:500;padding:6px;text-align:center}.perf-card{background:linear-gradient(135deg,#0f3460,#16213e);color:#fff}.perf-card .portal-card-title{color:#fff}.perf-stats{display:flex;gap:0;margin-bottom:16px}.perf-stat{flex:1 1;text-align:center}.perf-stat-val{color:#fff;font-size:26px;font-weight:700;margin-bottom:4px}.perf-stat-label{color:#fff9;font-size:11px}.accuracy-row{align-items:center;background:#ffffff1a;border-radius:10px;display:flex;gap:14px;margin-bottom:12px;padding:12px}.accuracy-val{color:#fff;font-size:22px;font-weight:700}.accuracy-label{color:#ffffffb3;font-size:12px}.readiness-box{align-items:center;background:#ffffff14;border:1.5px solid;border-radius:10px;display:flex;gap:12px;padding:12px}.readiness-icon{font-size:24px}.readiness-title{font-size:13px;font-weight:700}.readiness-sub{color:#fff9;font-size:11px;margin-top:2px}.topic-breakdown-row{align-items:center;display:flex;gap:10px;margin-bottom:10px}.tb-name{color:#444;flex-shrink:0;font-size:12px;font-weight:500;width:110px}.tb-bar-bg{background:#f0f0f0;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.tb-bar-fill{border-radius:4px;height:100%;transition:width .5s}.tb-pct{font-size:12px;font-weight:600;text-align:right;width:36px}@media (max-width:768px){.portal-grid{grid-template-columns:1fr}.portal-welcome-row{align-items:stretch;flex-direction:column;gap:12px}.progress-circles{flex-wrap:wrap}.perf-stats{flex-direction:column;gap:16px}.portal-navbar{padding:0 16px}.portal-body{padding:16px}}.s-layout{background:#f4f6f9;display:flex;min-height:100vh}.s-main{flex:1 1;margin-left:240px;padding:28px 32px}.s-page-header{margin-bottom:24px}.s-page-header h2{color:#1a1a2e;font-size:24px;font-weight:700}.s-page-header p{color:#888;font-size:14px;margin-top:4px}.s-section-title{color:#1a1a2e;font-size:14px;font-weight:700;margin-bottom:14px}.s-loading{font-size:15px;padding:80px}.s-empty,.s-loading{color:#aaa;text-align:center}.s-empty{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;font-size:14px;padding:40px}.s-test-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:16px}.s-test-card{background:#fff;border-left:4px solid #0f3460;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:20px}.s-test-type{color:#0f3460;font-size:11px;font-weight:600;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.s-test-name{color:#1a1a2e;font-size:15px;font-weight:700;margin-bottom:8px}.s-test-meta{color:#888;font-size:12px;margin-bottom:6px}.s-test-date{color:#f39c12;font-size:12px;margin-bottom:14px}.s-btn-start{background:#0f3460;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:10px;width:100%}.s-btn-start:hover{background:#16213e}.s-results-list{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden}.s-result-row{align-items:center;border-bottom:1px solid #f5f5f5;display:flex;gap:14px;padding:14px 18px}.s-result-row:last-child{border-bottom:none}.s-result-name{color:#1a1a2e;font-size:13px;font-weight:500}.s-result-meta{color:#aaa;font-size:11px;margin-top:2px}.s-result-info{flex:1 1}.s-result-score{flex-shrink:0;font-size:14px;font-weight:700}.s-result-pct{flex-shrink:0;font-size:13px;font-weight:600;text-align:right;width:40px}.s-result-bar-bg{background:#f0f0f0;border-radius:4px;flex-shrink:0;height:7px;overflow:hidden;width:100px}.s-result-bar{border-radius:4px;height:100%}.s-result-badge{border-radius:20px;flex-shrink:0;font-size:11px;font-weight:600;padding:3px 10px}.s-analytics-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.s-stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:20px}.s-stat-val{font-size:30px;font-weight:700;margin-bottom:4px}.s-stat-label{color:#888;font-size:13px}.s-chart-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px;padding:22px}.s-chart-title{color:#1a1a2e;font-size:14px;font-weight:700;margin-bottom:14px}.s-topic-breakdown{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;gap:14px;padding:22px}.s-topic-row{align-items:center;display:flex;gap:12px}.s-topic-name{color:#444;flex-shrink:0;font-size:13px;font-weight:500;width:120px}.s-topic-bar-bg{background:#f0f0f0;border-radius:5px;flex:1 1;height:10px;overflow:hidden}.s-topic-bar{border-radius:5px;height:100%;transition:width .5s}.s-topic-info{align-items:center;display:flex;flex-shrink:0;gap:10px;justify-content:flex-end;width:80px}.ai-chat-wrapper{background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;height:calc(100vh - 200px)}.ai-messages{display:flex;flex:1 1;flex-direction:column;gap:14px;overflow-y:auto;padding:20px}.ai-msg{align-items:flex-start;display:flex;gap:10px}.ai-msg.user{flex-direction:row-reverse}.ai-msg-avatar{align-items:center;background:#0f3460;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:32px;justify-content:center;width:32px}.ai-msg-avatar.user{background:#e94560}.ai-msg-bubble{background:#f4f6f9;border-radius:12px;color:#333;font-size:13px;line-height:1.6;max-width:70%;padding:12px 16px;white-space:pre-wrap}.ai-msg.user .ai-msg-bubble{background:#0f3460;color:#fff}.ai-typing{align-items:center;display:flex;gap:4px;padding:14px 16px}.ai-typing span{animation:bounce 1s infinite;background:#0f3460;border-radius:50%;height:7px;width:7px}.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.ai-input-row{border-top:1px solid #f0f0f0;display:flex;gap:10px;padding:14px 20px}.ai-input{border:1.5px solid #e0e0e0;border-radius:9px;flex:1 1;font-size:14px;outline:none;padding:11px 16px}.ai-input:focus{border-color:#0f3460}.ai-send-btn{background:#0f3460;border:none;border-radius:9px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:11px 22px}.ai-send-btn:disabled{background:#aaa;cursor:not-allowed}.ai-suggestions{display:flex;flex-wrap:wrap;gap:8px;padding:10px 20px 14px}.ai-suggestion{background:#eef2ff;border:none;border-radius:20px;color:#0f3460;cursor:pointer;font-size:12px;font-weight:500;padding:6px 14px}.s-profile-top{align-items:center;background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000f;display:flex;gap:20px;margin-bottom:20px;padding:24px}.s-profile-avatar{align-items:center;background:linear-gradient(135deg,#0f3460,#e94560);border-radius:18px;color:#fff;display:flex;flex-shrink:0;font-size:28px;font-weight:700;height:70px;justify-content:center;width:70px}.s-profile-info h3{color:#1a1a2e;font-size:20px;font-weight:700;margin-bottom:4px}.s-profile-info p{color:#888;font-size:13px;margin-bottom:3px}.s-placement-badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:600;margin-top:6px;padding:3px 12px}.s-placement-badge.placed{background:#e6f9f0;color:#1a7f3c}.s-placement-badge.not-placed{background:#fff0f0;color:#c00}.s-placement-badge.in-process{background:#fff8e6;color:#b37400}.s-profile-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.s-info-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:20px}.s-info-title{border-bottom:1px solid #f0f0f0;color:#1a1a2e;font-size:13px;font-weight:700;margin-bottom:14px;padding-bottom:8px}.s-info-row{align-items:center;border-bottom:1px solid #f8f8f8;color:#555;display:flex;font-size:13px;justify-content:space-between;padding:8px 0}.s-info-row:last-child{border-bottom:none}.readiness-level{color:#0f3460;font-size:18px;font-weight:700;margin-bottom:4px}.readiness-score{color:#888;font-size:13px;margin-bottom:14px}.r-row{align-items:center;color:#555;display:flex;font-size:12px;gap:10px;margin-bottom:8px}.r-row span:first-child{flex-shrink:0;width:90px}.r-bar-bg{background:#f0f0f0;flex:1 1;height:7px;overflow:hidden}.r-bar,.r-bar-bg{border-radius:4px}.r-bar{height:100%}.completed-summary{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;display:flex;gap:0;margin-bottom:16px;overflow:hidden}.cs-item{border-right:1px solid #f0f0f0;flex:1 1;padding:16px 20px;text-align:center}.cs-item:last-child{border-right:none}.cs-val{color:#0f3460;font-size:24px;font-weight:700;margin-bottom:4px}.cs-label{color:#aaa;font-size:12px;font-weight:500}.completed-tests-list{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden}.completed-test-row{align-items:center;border-bottom:1px solid #f5f5f5;display:flex;gap:24px;padding:18px 22px;transition:background .15s}.completed-test-row:last-child{border-bottom:none}.completed-test-row:hover{background:#fafbff}.ct-left{flex:1 1}.ct-type-badge{background:#eef2ff;border-radius:20px;color:#3c5bd4;display:inline-block;font-size:11px;font-weight:600;margin-bottom:6px;padding:2px 10px}.ct-name{color:#1a1a2e;font-size:15px;font-weight:600;margin-bottom:4px}.ct-meta{color:#aaa;font-size:12px}.ct-score-section{display:flex;flex-direction:column;gap:5px;min-width:200px}.ct-score-val{font-size:22px;font-weight:700}.ct-bar-row{align-items:center;display:flex;gap:8px}.ct-bar-bg{background:#f0f0f0;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.ct-bar-fill{border-radius:4px;height:100%;transition:width .5s ease}.ct-pct-label{flex-shrink:0;font-size:13px;font-weight:700;text-align:right;width:44px}.ct-breakdown{display:flex;font-size:11px;font-weight:500;gap:12px}.ct-right{flex-shrink:0;text-align:center}.tt-loading{align-items:center;color:#888;font-size:16px;justify-content:center}.tt-loading,.tt-wrapper{display:flex;min-height:100vh}.tt-wrapper{background:#f4f6f9;flex-direction:column;font-family:Segoe UI,sans-serif}.tt-topbar{align-items:center;background:#fff;box-shadow:0 2px 8px #0000000f;display:flex;justify-content:space-between;padding:12px 28px;position:sticky;top:0;z-index:100}.tt-test-name{color:#1a1a2e;font-size:15px;font-weight:700}.tt-session{color:#aaa;font-size:11px;margin-top:2px}.tt-timer{background:#f0f4ff;border-radius:8px;color:#0f3460;font-size:20px;font-weight:700;padding:8px 20px}.tt-timer.danger{animation:pulse 1s infinite;background:#fff0f0;color:#c00}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.tt-topbar-right{align-items:center;display:flex;gap:10px}.tt-feedback-label{color:#555;font-size:13px}.tt-toggle{background:#ddd;border-radius:12px;cursor:pointer;height:24px;position:relative;transition:background .2s;width:44px}.tt-toggle.on{background:#0f3460}.tt-toggle-thumb{background:#fff;border-radius:50%;height:18px;left:3px;position:absolute;top:3px;transition:transform .2s;width:18px}.tt-toggle.on .tt-toggle-thumb{transform:translateX(20px)}.tt-progress-bar{background:#e0e0e0;height:4px;position:sticky;top:60px;z-index:99}.tt-progress-fill{background:#0f3460;height:100%;transition:width .3s}.tt-body{box-sizing:border-box;display:flex;flex:1 1;gap:20px;margin:0 auto;max-width:1200px;padding:24px 28px;width:100%}.tt-question-area{background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000f;flex:1 1;padding:28px}.tt-q-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.tt-q-num{color:#0f3460;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.tt-q-diff{background:#f0f2f5;border-radius:20px;color:#888;font-size:12px;padding:3px 12px}.tt-q-text{color:#1a1a2e;font-size:16px;font-weight:500;line-height:1.7;margin-bottom:24px}.tt-options{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.tt-option{align-items:center;background:#fff;border:1.5px solid #e0e0e0;border-radius:10px;cursor:pointer;display:flex;gap:14px;padding:14px 18px;transition:all .15s}.tt-option:hover{background:#f8faff;border-color:#0f3460}.tt-option.selected{background:#eef2ff;border-color:#0f3460}.tt-option.correct{background:#e6f9f0;border-color:#16a085}.tt-option.wrong{background:#fff0f0;border-color:#e94560}.tt-option.show-correct{background:#e6f9f0;border-color:#16a085;opacity:.7}.tt-opt-letter{align-items:center;background:#f0f2f5;border-radius:50%;color:#555;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:30px;justify-content:center;width:30px}.tt-option.selected .tt-opt-letter{background:#0f3460;color:#fff}.tt-option.correct .tt-opt-letter{background:#16a085;color:#fff}.tt-option.wrong .tt-opt-letter{background:#e94560;color:#fff}.tt-opt-text{color:#333;font-size:14px}.tt-explanation-toggle{align-items:center;background:#f0f4ff;border-radius:8px;color:#0f3460;cursor:pointer;display:flex;font-size:13px;font-weight:500;justify-content:space-between;margin-bottom:8px;padding:10px 14px}.tt-explanation{background:#f8f9fc;border-left:3px solid #0f3460;border-radius:0 8px 8px 0;color:#444;font-size:13px;line-height:1.6;margin-bottom:16px;padding:12px 16px}.tt-bottom-nav{align-items:center;border-top:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-top:24px;padding-top:20px}.tt-btn-prev{background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;color:#555;cursor:pointer;font-size:13px;padding:10px 22px}.tt-btn-prev:disabled{cursor:not-allowed;opacity:.4}.tt-btn-mark{background:#fff;border:1.5px solid #f39c12;border-radius:8px;color:#f39c12;cursor:pointer;font-size:13px;font-weight:500;padding:10px 20px}.tt-btn-next{background:#0f3460}.tt-btn-next,.tt-btn-submit{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:10px 24px}.tt-btn-submit{background:#16a085}.tt-sidebar{display:flex;flex-direction:column;flex-shrink:0;gap:12px;width:240px}.tt-nav-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;color:#1a1a2e;display:flex;font-size:13px;font-weight:700;justify-content:space-between;padding:14px 16px}.tt-nav-answered{color:#888;font-size:12px;font-weight:400}.tt-nav-grid{grid-gap:6px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;display:grid;gap:6px;grid-template-columns:repeat(5,1fr);padding:14px}.tt-nav-btn{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;height:34px;transition:all .15s;width:34px}.tt-nav-btn.answered{background:#16a085;color:#fff}.tt-nav-btn.marked{background:#f39c12;color:#fff}.tt-nav-btn.unvisited{background:#f0f2f5;color:#555}.tt-nav-btn.current{outline:2.5px solid #0f3460}.tt-nav-legend{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;gap:6px;padding:12px 14px}.tt-leg{align-items:center;color:#555;display:flex;font-size:12px;gap:8px}.tt-leg-dot{border-radius:3px;height:12px;width:12px}.tt-leg-dot.answered{background:#16a085}.tt-leg-dot.marked{background:#f39c12}.tt-leg-dot.unvisited{background:#f0f2f5;border:1px solid #ddd}.tt-finish-btn{background:#0f3460;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px;width:100%}.tt-finish-btn:hover{background:#16213e}.tt-pause-btn{background:#fff;border:1.5px solid #e0e0e0;border-radius:10px;color:#555;cursor:pointer;font-size:13px;padding:11px;width:100%}.tt-tab-warning{background:#fff0f0;border-radius:8px;color:#c00;font-size:12px;font-weight:500;padding:8px 12px}.tt-result-screen{align-items:center;background:#f4f6f9;display:flex;justify-content:center;min-height:100vh;padding:40px}.tt-result-card{background:#fff;border-radius:20px;box-shadow:0 8px 32px #0000001a;max-width:480px;padding:48px;text-align:center;width:100%}.tt-result-icon{font-size:56px;margin-bottom:16px}.tt-result-title{color:#1a1a2e;font-size:24px;font-weight:700;margin-bottom:8px}.tt-result-sub{color:#888;font-size:14px;margin-bottom:28px}.tt-result-score{align-items:baseline;display:flex;gap:12px;justify-content:center;margin-bottom:28px}.tt-big-score{font-size:48px;font-weight:700}.tt-big-pct{font-size:28px;font-weight:600}.tt-result-stats{background:#f8f9fc;border-radius:12px;display:flex;gap:32px;justify-content:center;margin-bottom:24px;padding:20px}.tt-rs-val{font-size:28px;font-weight:700}.tt-rs-label{color:#888;font-size:12px;margin-top:4px}.tt-cheat-warning{background:#fff8e6;border-radius:8px;color:#b37400;font-size:13px;margin-bottom:20px;padding:10px 14px}.tt-result-actions{display:flex;gap:12px;justify-content:center}.tt-btn-home{background:#0f3460;color:#fff;font-weight:600}.tt-btn-home,.tt-btn-tests{border:none;border-radius:10px;cursor:pointer;font-size:14px;padding:12px 24px}.tt-btn-tests{background:#f0f2f5;color:#555}.tt-closed-screen{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:40px}.tt-closed-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:480px;padding:48px;text-align:center;width:100%}.tt-closed-icon{font-size:56px;margin-bottom:20px}.tt-closed-title{color:#2c3e50;font-size:28px;font-weight:700;margin:0 0 12px}.tt-closed-message{color:#555;font-size:16px;line-height:1.6;margin:0 0 12px}.tt-closed-submsg{color:#888;font-size:14px;margin:0 0 32px}.tt-close-btn{background:#0f3460;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:background .2s}.tt-close-btn:hover{background:#16213e}.ac-overlay-bg{align-items:center;animation:acFadeIn .2s ease;background:#000000e0;display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}@keyframes acFadeIn{0%{opacity:0}to{opacity:1}}.ac-overlay-card{animation:acSlideUp .25s ease;background:#fff;border-radius:18px;box-shadow:0 24px 64px #00000080;max-width:480px;padding:44px 40px;text-align:center;width:90%}@keyframes acSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ac-warn{border:3px solid #f39c12}.ac-final{border:3px solid #c00}.ac-overlay-icon{font-size:56px;line-height:1;margin-bottom:16px}.ac-overlay-title{color:#1a1a2e;font-size:20px;font-weight:800;margin:0 0 12px}.ac-overlay-body{color:#444;font-size:14px;line-height:1.75;margin:0 0 20px}.ac-overlay-hint{color:#888;font-size:13px;margin:0 0 16px}.ac-overlay-hint kbd{background:#f0f2f5;border:1px solid #ccc;border-radius:5px;color:#333;font-family:monospace;font-size:12px;padding:1px 7px}.ac-overlay-btn{background:#0f3460;border:none;border-radius:10px;color:#fff;cursor:pointer;display:block;font-size:14px;font-weight:700;padding:14px 0;transition:background .15s;width:100%}.ac-overlay-btn:hover{background:#1a4a80}.tt-proctored-badge{background:#fff0f3;border:1px solid #ffccd4;color:#e94560;margin-left:10px;padding:2px 8px}.tt-proctored-badge,.tt-violation-badge{border-radius:20px;font-size:11px;font-weight:700}.tt-violation-badge{display:inline-block;margin-left:6px;padding:3px 10px}.tt-violation-badge.warn{background:#fff8e6;border:1px solid #ffe0a0;color:#b37400}.tt-violation-badge.danger{background:#fff0f0;border:1px solid #fcc;color:#c00}.tt-proctor-box{background:#fff8e6;border:1px solid #ffe0a0;border-radius:9px;color:#b37400;font-size:11px;line-height:1.7;margin-top:12px;padding:12px 14px}.tt-proctor-title{color:#8a5a00;font-size:12px;font-weight:700;margin-bottom:6px}.tt-proctor-rule{padding-left:2px}@media (max-width:768px){.tt-body{padding:16px}.tt-body,.tt-topbar{flex-direction:column}.tt-topbar{gap:12px;height:auto;padding:12px 16px}.tt-sidebar{box-sizing:border-box;max-width:none;width:100%!important}.tt-question-area{box-sizing:border-box;padding:20px;width:100%}.tt-bottom-bar{flex-direction:column;gap:12px;height:auto;padding:16px}.tt-nav-btns{display:flex;gap:8px;justify-content:space-between;width:100%}.btn-tt-nav{flex:1 1}.tt-q-grid{grid-template-columns:repeat(8,1fr)}}.mock-setup-grid{align-items:flex-start;display:flex;gap:20px}.mock-left{flex:1 1;min-width:0}.mock-left,.mock-right{display:flex;flex-direction:column;gap:16px}.mock-right{flex-shrink:0;width:300px}.mock-card{background:#fff;border-radius:14px;box-shadow:0 2px 8px #0000000f;padding:22px}.mock-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.mock-card-title{color:#1a1a2e;font-size:15px;font-weight:700}.flow-mode-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.flow-mode-card{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;gap:12px;padding:14px 16px;position:relative;transition:all .15s}.flow-mode-card:hover{background:#fafafa;border-color:#aaa}.flow-mode-card.active{box-shadow:0 4px 12px #00000014}.fmc-icon{flex-shrink:0;font-size:22px}.fmc-title{color:#1a1a2e;font-size:13px;font-weight:700;margin-bottom:2px}.fmc-desc{color:#888;font-size:11px}.fmc-active-dot{border-radius:50%;height:8px;position:absolute;right:10px;top:10px;width:8px}.flow-panel-card{padding:24px}.flow-panel-title{border-bottom:1.5px solid #f0f0f0;display:flex;flex-direction:column;gap:4px;margin-bottom:20px;padding-bottom:14px}.flow-panel-title>span:first-child{color:#1a1a2e;font-size:16px;font-weight:700}.flow-panel-sub{color:#888;font-size:12px}.flow-row-label{color:#555;font-size:13px;font-weight:600;margin-bottom:10px;margin-top:4px}.topic-group{margin-bottom:16px}.topic-group-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.topic-group-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.topic-chips{display:flex;flex-wrap:wrap;gap:8px}.topic-chip{align-items:center;background:#fff;border:1.5px solid #e0e0e0;border-radius:20px;color:#444;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:6px;padding:6px 12px;transition:all .13s;-webkit-user-select:none;user-select:none}.topic-chip:hover{background:#f8f8f8;border-color:#aaa}.topic-chip.selected{font-weight:600}.chip-count{color:#aaa;font-size:10px;font-weight:500}.topic-chip.selected .chip-count{opacity:.7}.diff-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}.diff-pill{background:#fff;border:1.5px solid #e0e0e0;border-radius:20px;color:#444;cursor:pointer;font-size:12px;font-weight:600;padding:7px 16px;transition:all .13s}.diff-pill:hover{border-color:#aaa}.diff-pill.selected{font-weight:700}.diff-big-cards{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:6px}.diff-big-card{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:18px 10px;text-align:center;transition:all .13s}.diff-big-card:hover{background:#fafafa;border-color:#aaa}.diff-big-card.active{box-shadow:0 4px 12px #00000014}.diff-big-icon{font-size:26px}.diff-big-label{font-size:13px;font-weight:700}.diff-big-desc{color:#888;font-size:11px}.category-cards{display:flex;flex-direction:column;gap:8px;margin-bottom:6px}.category-card{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;gap:14px;padding:14px 16px;transition:all .13s}.category-card:hover{border-color:#aaa}.category-card.active{box-shadow:0 2px 10px #0000000f}.cat-card-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;font-size:18px;height:40px;justify-content:center;width:40px}.cat-card-info{flex:1 1}.cat-card-name{color:#1a1a2e;font-size:14px;font-weight:700}.cat-card-meta{color:#888;font-size:12px;margin-top:2px}.cat-card-check{flex-shrink:0;font-size:18px;font-weight:700}.custom-summary{align-items:center;background:#f8f9fc;border:1px solid #e0e0e0;border-radius:10px;display:flex;flex-wrap:wrap;gap:12px;margin:16px 0 12px;padding:12px 16px}.custom-summary-item{align-items:baseline;display:flex;gap:4px}.csi-val{color:#0f3460;font-size:18px;font-weight:700}.csi-label{color:#888;font-size:11px}.custom-summary-sep{color:#ddd;font-size:18px}.count-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.count-pill{background:#fff;border:1.5px solid #e0e0e0;border-radius:20px;color:#444;cursor:pointer;font-size:13px;font-weight:600;padding:7px 16px;transition:all .13s}.count-pill:hover{border-color:#0f3460;color:#0f3460}.count-pill.selected{background:#0f3460;border-color:#0f3460;color:#fff}.count-note{color:#888;font-size:12px;margin-top:6px}.mock-text-btn{background:#eef2ff;border:none;border-radius:6px;color:#3c5bd4;cursor:pointer;font-size:11px;font-weight:600;padding:4px 10px}.mock-text-btn:hover{background:#dce4ff}.mock-text-btn.red{background:#fff0f0;color:#c00}.mock-text-btn.red:hover{background:#ffe0e0}.btn-start-mock{background:linear-gradient(135deg,#0f3460,#1a4a80);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:15px;font-weight:700;letter-spacing:.01em;margin-top:16px;padding:15px;transition:opacity .15s,transform .1s;width:100%}.btn-start-mock:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-start-mock:disabled{background:#ccc;cursor:not-allowed;transform:none}.mock-error{background:#fff0f0;border:1px solid #fcc;border-radius:8px;color:#c00;font-size:13px;font-weight:500;margin-top:10px;padding:10px 14px}.mock-placeholder{color:#aaa;padding:40px 24px;text-align:center}.mock-placeholder-icon{font-size:40px;margin-bottom:12px}.mock-placeholder-title{color:#555;font-size:15px;font-weight:600;margin-bottom:6px}.mock-placeholder-sub{color:#aaa;font-size:13px}.history-list{display:flex;flex-direction:column;gap:10px}.history-item{align-items:center;border-bottom:1px solid #f5f5f5;display:flex;justify-content:space-between;padding:10px 0}.history-item:last-child{border-bottom:none}.history-topic{color:#1a1a2e;font-size:13px;font-weight:600;margin-bottom:3px}.history-meta{color:#aaa;font-size:11px}.mock-empty{color:#aaa;font-size:13px;padding:16px 0;text-align:center}.tips-card{background:#f8f9fc}.tip-item{align-items:flex-start;border-bottom:1px solid #eee;color:#555;display:flex;font-size:12px;gap:10px;padding:5px 0}.tip-item:last-child{border-bottom:none}.tip-num{align-items:center;background:#0f3460;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:10px;font-weight:700;height:20px;justify-content:center;width:20px}.tt-option.correct{background:#e6f9f0!important;border-color:#16a085!important;color:#1a7f3c!important}.tt-option.wrong{background:#fff0f0!important;border-color:#e94560!important;color:#c00!important}.tt-option.show-correct{background:#f0faf6!important;border-color:#16a085!important}.mb-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.mb-stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:18px 20px}.mb-stat-val{font-size:30px;font-weight:700;margin-bottom:4px}.mb-stat-label{color:#888;font-size:13px}.mb-grid{grid-gap:20px;align-items:flex-start;display:grid;gap:20px;grid-template-columns:1fr}.mb-main{display:flex;flex-direction:column;gap:14px}.mb-tabs-row{align-items:center;display:flex;gap:10px;justify-content:space-between}.mb-filter-tabs{background:#f0f2f5;border-radius:10px;display:flex;gap:2px;padding:4px}.mb-filter-tab{background:#0000;border:none;border-radius:7px;color:#888;cursor:pointer;font-size:13px;font-weight:500;padding:8px 20px;transition:all .2s}.mb-filter-tab.active{background:#fff;box-shadow:0 1px 4px #0000001a;color:#0f3460;font-weight:600}.mb-topic-select{background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;color:#333;font-size:13px;outline:none;padding:8px 12px}.mb-info-banner{background:#f0f4ff;border:1px solid #c5d0f5;border-radius:10px;color:#0f3460;font-size:13px;font-weight:500;padding:12px 16px}.mb-empty{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;color:#aaa;font-size:15px;padding:48px;text-align:center}.mb-list{display:flex;flex-direction:column;gap:10px}.mb-card{background:#fff;border-left:4px solid #e94560;border-radius:12px;box-shadow:0 2px 8px #0000000f;transition:box-shadow .2s}.mb-card:hover{box-shadow:0 4px 12px #0000001a}.mb-card.resolved{border-left-color:#16a085}.mb-card-content{padding:16px 18px}.mb-card-top{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:10px}.mb-card-badges{display:flex;flex-wrap:wrap;gap:6px}.mb-card-num{color:#ccc;flex-shrink:0;font-size:12px;font-weight:600}.mb-diff-badge,.mb-freq-badge,.mb-topic-badge{border-radius:20px;font-size:11px;font-weight:600;padding:3px 10px}.mb-freq-badge{background:#fff8e6;color:#b37400}.mb-resolved-badge{background:#e6f9f0;border-radius:20px;color:#1a7f3c;font-size:11px;font-weight:600;padding:3px 10px}.mb-question-text{color:#1a1a2e;font-size:14px;font-weight:500;line-height:1.6;margin-bottom:12px}.mb-question-text.resolved-text{color:#888;text-decoration:line-through;text-decoration-color:#16a085}.mb-card-footer{align-items:center;display:flex;justify-content:space-between}.mb-last-seen{color:#bbb;font-size:11px}.mb-status-tag{background:#eef2ff;border-radius:20px;color:#0f3460;font-size:11px;font-weight:500;padding:3px 10px}.mb-sidebar{display:flex;flex-direction:column;gap:16px}.mb-sidebar-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:18px}.mb-sidebar-card.tips{background:#f0f4ff}.mb-sidebar-title{border-bottom:1px solid #f0f0f0;color:#1a1a2e;font-size:13px;font-weight:700;margin-bottom:14px;padding-bottom:8px}.mb-topic-row{align-items:center;border-radius:6px;display:flex;gap:10px;margin-bottom:10px;padding:4px 0;transition:background .15s}.mb-topic-row:hover{background:#f8f9fc}.mb-topic-name{flex-shrink:0;font-size:12px;transition:all .15s;width:90px}.mb-topic-bar-bg{background:#f0f0f0;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.mb-topic-bar{border-radius:4px;height:100%;transition:width .4s}.mb-topic-count{flex-shrink:0;font-size:13px;font-weight:700;text-align:right;width:24px}.mb-tip{align-items:flex-start;border-bottom:1px solid #0000000a;color:#444;display:flex;font-size:12px;gap:10px;line-height:1.5;padding:7px 0}.mb-tip:last-child{border-bottom:none}.mb-tip-num{align-items:center;background:#0f3460;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:10px;font-weight:700;height:18px;justify-content:center;margin-top:1px;width:18px}:root{--diag-bg:#f4f7fe;--diag-card-bg:#fff;--diag-card-bg-hover:#fff;--diag-primary:#1e3a8a;--diag-primary-glow:#1e3a8a1a;--diag-secondary:#f43f5e;--diag-success:#10b981;--diag-warning:#f59e0b;--diag-info:#8b5cf6;--diag-text:#1e293b;--diag-text-muted:#64748b;--diag-border:#e2e8f0;--diag-border-hover:#cbd5e1;--font-heading:"Outfit",sans-serif;--font-body:"Inter",sans-serif}.diagnostic-page-content,.diagnostic-report-page-content{background:#f4f7fe;background:var(--diag-bg);color:#1e293b;color:var(--diag-text);font-family:Inter,sans-serif;font-family:var(--font-body);min-height:100vh;padding:40px}.diagnostic-page-wrapper{margin:0 auto;max-width:1400px}.premium-title,h1,h2,h3,h4,h5,h6{color:#1e293b;color:var(--diag-text);font-family:Outfit,sans-serif;font-family:var(--font-heading)}.premium-title{font-size:36px;font-weight:800;letter-spacing:-.02em;margin:0}.premium-subtitle{color:#64748b;color:var(--diag-text-muted);font-size:15px;font-weight:500;margin-top:6px}.tabs-container{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:12px;box-shadow:0 2px 10px #00000005;display:inline-flex;gap:8px;margin:32px 0 40px;padding:6px}.tab-link{background:#0000;border:none;border-radius:8px;color:#64748b;color:var(--diag-text-muted);cursor:pointer;font-family:Inter,sans-serif;font-family:var(--font-body);font-size:14px;font-weight:600;padding:10px 24px;transition:all .2s ease}.tab-link:hover{color:#1e3a8a;color:var(--diag-primary)}.tab-link.active{background:#f43f5e;background:var(--diag-secondary);box-shadow:0 4px 12px #f43f5e33;color:#fff}.search-bar-wrapper{margin-bottom:32px}.diag-search-input{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:12px;box-shadow:0 2px 10px #00000005;color:#1e293b;color:var(--diag-text);font-family:Inter,sans-serif;font-family:var(--font-body);font-size:15px;max-width:480px;padding:14px 20px;transition:all .2s ease;width:100%}.diag-search-input:focus{border-color:#1e3a8a;border-color:var(--diag-primary);box-shadow:0 0 0 3px #1e3a8a1a;box-shadow:0 0 0 3px var(--diag-primary-glow);outline:none}.diag-student-grid{display:flex;flex-direction:column;gap:12px}.diag-student-card{align-items:center;background:#fff;background:var(--diag-card-bg);border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:14px;box-shadow:0 2px 8px #00000008;cursor:pointer;display:flex;flex-direction:row;gap:20px;padding:18px 24px;transition:all .2s ease}.diag-student-card:hover{border-color:#1e3a8a;border-color:var(--diag-primary);box-shadow:0 4px 16px #00000012;transform:translateX(4px)}.dsc-avatar{align-items:center;background:#1e3a8a;background:var(--diag-primary);border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-family:Outfit,sans-serif;font-family:var(--font-heading);font-size:20px;font-weight:700;height:48px;justify-content:center;margin-bottom:0;width:48px}.dsc-main-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.dsc-name{color:#1e293b;color:var(--diag-text);font-size:15px;font-weight:700;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dsc-reg{color:#64748b;color:var(--diag-text-muted);font-size:12px;margin:0}.dsc-college-pill{align-self:flex-start;background:#f4f7fe;background:var(--diag-bg);border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:100px;color:#1e293b;color:var(--diag-text);display:inline-block;font-size:11px;font-weight:600;margin:0;padding:3px 10px}.dsc-test-info{align-items:flex-end;border-top:none;display:flex;flex-direction:column;flex-shrink:0;gap:4px;margin-top:0;padding-top:0}.dsc-test-name{color:#1e3a8a;color:var(--diag-primary);font-size:12px;font-weight:600}.dsc-date{color:#64748b;color:var(--diag-text-muted);font-size:11px}.dsc-action{align-items:center;color:#f43f5e;color:var(--diag-secondary);display:flex;font-size:12px;font-weight:600;gap:4px;margin-top:6px;transition:gap .2s}.diag-student-card:hover .dsc-action{gap:8px}.loading-spinner-premium,.loading-state{align-items:center;color:#1e3a8a;color:var(--diag-primary);display:flex;flex-direction:column;font-weight:600;gap:16px;grid-column:1/-1;justify-content:center;padding:80px}.spinner-glow{animation:diag-spin 1s linear infinite;border:3px solid #e2e8f0;border-top-color:#1e3a8a;border:3px solid var(--diag-border);border-radius:50%;border-top-color:var(--diag-primary);height:40px;width:40px}@keyframes diag-spin{to{transform:rotate(1turn)}}.empty-state{background:#fff;background:var(--diag-card-bg);border:1px dashed #e2e8f0;border:1px dashed var(--diag-border);border-radius:16px;grid-column:1/-1;padding:80px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{font-size:18px;font-weight:700;margin-bottom:8px}.empty-state p{color:#64748b;color:var(--diag-text-muted);font-size:14px}.create-card-premium{background:#fff;background:var(--diag-card-bg);border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:16px;box-shadow:0 4px 20px #00000008;margin:0;max-width:600px;padding:40px}.create-card-header h3{font-size:20px;margin-bottom:8px}.create-card-header p{color:#64748b;color:var(--diag-text-muted);font-size:14px;margin-bottom:32px}.form-group-p{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.form-group-p label{color:#1e293b;color:var(--diag-text);font-size:13px;font-weight:600}.form-group-p input,.form-group-p select{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:10px;color:#1e293b;color:var(--diag-text);font-family:Inter,sans-serif;font-family:var(--font-body);padding:12px 16px;transition:all .2s}.form-group-p input:focus{border-color:#1e3a8a;border-color:var(--diag-primary);box-shadow:0 0 0 3px #1e3a8a1a;box-shadow:0 0 0 3px var(--diag-primary-glow);outline:none}.form-row-p{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.btn-submit-premium{background:#1e3a8a;background:var(--diag-primary);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:14px;transition:all .2s;width:100%}.btn-submit-premium:hover{background:#1e3a8a;box-shadow:0 4px 12px #1e3a8a33}.btn-submit-premium:disabled{cursor:not-allowed;opacity:.7}.bento-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:32px}.uplink-back-btn{align-items:center;background:none;border:none;color:#64748b;color:var(--diag-text-muted);cursor:pointer;display:flex;font-size:13px;font-weight:600;margin-bottom:20px;padding:0;transition:color .2s}.uplink-back-btn:hover{color:#1e3a8a;color:var(--diag-primary)}.bento-profile{gap:20px}.b-avatar,.bento-profile{align-items:center;display:flex}.b-avatar{background:#1e3a8a;background:var(--diag-primary);border-radius:16px;color:#fff;font-family:Outfit,sans-serif;font-family:var(--font-heading);font-size:28px;font-weight:700;height:64px;justify-content:center;width:64px}.b-meta h1{color:#1e293b;color:var(--diag-text);font-size:24px;margin:0 0 6px}.b-meta p{color:#64748b;color:var(--diag-text-muted);font-size:13px;margin:0}.test-badge-premium{background:#f4f7fe;background:var(--diag-bg);border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:100px;color:#1e293b;color:var(--diag-text);font-size:12px;font-weight:600;margin-top:32px;padding:6px 16px}.bento-grid-container{grid-gap:24px;display:grid;gap:24px;grid-auto-rows:minmax(180px,auto);grid-template-columns:repeat(4,1fr)}.bento-item{background:#fff;background:var(--diag-card-bg);border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:12px;box-shadow:0 4px 15px #00000005;display:flex;flex-direction:column;overflow:hidden;padding:24px;position:relative;transition:transform .2s ease,box-shadow .2s ease}.bento-item:hover{box-shadow:0 8px 25px #0000000f}.bento-hero{grid-column:span 2;grid-row:span 2;justify-content:space-between}.hero-content{align-items:flex-start;display:flex;flex-direction:column}.accuracy-label{color:#64748b;color:var(--diag-text-muted);font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase}.big-percent{font-family:Outfit,sans-serif;font-family:var(--font-heading);font-size:80px;font-weight:800;letter-spacing:-.03em;line-height:1;margin:12px 0 16px}.performance-chip{background:#f4f7fe!important;background:var(--diag-bg)!important;border-radius:100px;display:inline-block;font-size:12px;font-weight:600;padding:6px 16px}.hero-stats{border-top:1px solid #e2e8f0;border-top:1px solid var(--diag-border);display:flex;gap:32px;margin-top:24px;padding-top:24px}.h-stat{display:flex;flex-direction:column;gap:4px}.h-val{color:#1e293b;color:var(--diag-text);font-family:Outfit,sans-serif;font-family:var(--font-heading);font-size:20px;font-weight:700}.h-label{color:#64748b;color:var(--diag-text-muted);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.hero-warning{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;color:#f59e0b;color:var(--diag-warning);font-size:12px;margin-top:24px;padding:8px 12px}.bento-radar{grid-column:span 2;grid-row:span 2}.bento-bar-chart{grid-column:span 4;grid-row:span 2}.bento-insights{grid-column:span 3}.bento-priority{background:#1e3a8a;background:var(--diag-primary);border:none;grid-column:span 1}.b-item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.b-item-header h3{color:#1e293b;color:var(--diag-text);font-size:16px;margin:0 0 4px}.b-item-header span,.chart-legend{color:#64748b;color:var(--diag-text-muted);font-size:12px}.leg-item{align-items:center;display:flex;gap:6px}.leg-item .dot{border-radius:50%;height:8px;width:8px}.bar-wrapper-bento,.radar-wrapper-bento{align-items:center;display:flex;flex:1 1;justify-content:center;min-height:250px}.insight-split{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;height:100%}.i-group{display:flex;flex-direction:column}.i-group h4{color:#1e293b;color:var(--diag-text);font-size:14px;font-weight:600;margin-bottom:12px}.i-group ul{flex:1 1;list-style:none;margin:0;padding:0}.i-group li{color:#64748b;color:var(--diag-text-muted);font-size:13px;line-height:1.5;margin-bottom:12px;padding-left:20px;position:relative}.i-group li:before{color:#1e3a8a;color:var(--diag-primary);content:"→";font-size:14px;font-weight:700;left:0;position:absolute}.i-group.weakness li:before{color:#f43f5e;color:var(--diag-secondary)}.bento-priority h3{color:#fff;font-size:16px;margin-bottom:12px}.priority-content{color:#ffffffe6;flex:1 1;font-size:14px;font-weight:500;line-height:1.5;margin-bottom:16px}.priority-meta{border-top:1px solid #fff3;color:#fff;font-size:11px;font-weight:600;letter-spacing:.5px;opacity:.7;padding-top:12px;text-transform:uppercase}.no-data-bento{color:#64748b;color:var(--diag-text-muted);font-size:13px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.empty-state-bento{background:#fff;background:var(--diag-card-bg);border:1px dashed #e2e8f0;border:1px dashed var(--diag-border);border-radius:16px;padding:80px 40px;text-align:center}.empty-icon-bento{font-size:48px;margin-bottom:16px}.empty-state-bento h3{color:#1e293b;color:var(--diag-text);font-size:20px;margin-bottom:8px}.empty-state-bento p{color:#64748b;color:var(--diag-text-muted);font-size:14px;margin-bottom:24px}.btn-back-bento{background:#f4f7fe;background:var(--diag-bg);border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:8px;color:#1e293b;color:var(--diag-text);cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.btn-back-bento:hover{background:#e2e8f0;background:var(--diag-border)}@media (max-width:1200px){.bento-grid-container{grid-template-columns:repeat(2,1fr)}.bento-bar-chart,.bento-hero,.bento-insights,.bento-priority,.bento-radar{grid-column:span 2}}@media (max-width:768px){.bento-grid-container{grid-template-columns:1fr}.bento-item{grid-column:span 1!important}.insight-split{gap:16px;grid-template-columns:1fr}.hero-stats{flex-wrap:wrap;gap:16px}.big-percent{font-size:60px}.bento-header{align-items:flex-start;flex-direction:column;gap:16px}.test-badge-premium{margin-top:0}}.diag-chat-panel{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-bottom:none;border-radius:16px 16px 0 0;bottom:0;box-shadow:0 -8px 40px #1e3a8a1f;display:flex;flex-direction:column;font-family:Inter,sans-serif;font-family:var(--font-body);position:fixed;right:32px;transform:translateY(0);transition:transform .3s cubic-bezier(.4,0,.2,1);width:380px;z-index:1000}.diag-chat-panel:not(.open){display:none}.diag-chat-panel.open{display:flex;max-height:520px}.diag-chat-header{align-items:center;background:#1e3a8a;background:var(--diag-primary);border-radius:16px 16px 0 0;cursor:pointer;display:flex;flex-shrink:0;justify-content:space-between;padding:14px 18px;-webkit-user-select:none;user-select:none}.diag-chat-header-left{align-items:center;display:flex;gap:10px}.diag-chat-icon{font-size:22px;line-height:1}.diag-chat-title{color:#fff;font-family:Outfit,sans-serif;font-family:var(--font-heading);font-size:14px;font-weight:700}.diag-chat-sub{color:#ffffffa6;font-size:11px;margin-top:2px}.diag-chat-toggle{align-items:center;background:#ffffff26;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;height:28px;justify-content:center;transition:background .2s;width:28px}.diag-chat-toggle:hover{background:#ffffff40}.diag-chat-messages{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:16px 14px 8px;scrollbar-color:#e2e8f0 #0000;scrollbar-color:var(--diag-border) #0000;scrollbar-width:thin}.diag-chat-messages::-webkit-scrollbar{width:4px}.diag-chat-messages::-webkit-scrollbar-thumb{background:#e2e8f0;background:var(--diag-border);border-radius:2px}.diag-chat-msg{align-items:flex-start;display:flex;gap:8px}.diag-chat-msg.user{flex-direction:row-reverse}.diag-chat-avatar{align-items:center;background:#1e3a8a;background:var(--diag-primary);border-radius:8px;color:#fff;display:flex;flex-shrink:0;font-size:9px;font-weight:700;height:28px;justify-content:center;letter-spacing:.3px;width:28px}.diag-chat-avatar.user{background:#f43f5e;background:var(--diag-secondary)}.diag-chat-bubble{border-radius:12px;font-size:13px;line-height:1.55;max-width:78%;padding:10px 13px;word-break:break-word}.diag-chat-msg.ai .diag-chat-bubble{background:#f4f7fe;background:var(--diag-bg);border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-top-left-radius:4px;color:#1e293b;color:var(--diag-text)}.diag-chat-msg.user .diag-chat-bubble{background:#1e3a8a;background:var(--diag-primary);border-top-right-radius:4px;color:#fff}.diag-typing{align-items:center;display:flex;gap:4px;min-width:48px;padding:12px 16px}.diag-typing span{animation:diag-bounce 1.2s ease-in-out infinite;background:#94a3b8;border-radius:50%;display:inline-block;height:6px;width:6px}.diag-typing span:nth-child(2){animation-delay:.2s}.diag-typing span:nth-child(3){animation-delay:.4s}@keyframes diag-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.diag-chat-suggestions{border-top:1px solid #e2e8f0;border-top:1px solid var(--diag-border);display:flex;flex-shrink:0;flex-wrap:wrap;gap:6px;padding:6px 14px}.diag-chat-suggest-btn{background:#f4f7fe;background:var(--diag-bg);border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:100px;color:#1e3a8a;color:var(--diag-primary);cursor:pointer;font-family:Inter,sans-serif;font-family:var(--font-body);font-size:11px;font-weight:600;padding:5px 10px;transition:all .15s;white-space:nowrap}.diag-chat-suggest-btn:hover{background:#1e3a8a;background:var(--diag-primary);border-color:#1e3a8a;border-color:var(--diag-primary);color:#fff}.diag-chat-input-row{border-top:1px solid #e2e8f0;border-top:1px solid var(--diag-border);display:flex;flex-shrink:0;gap:8px;padding:10px 14px 14px}.diag-chat-input{background:#f8fafc;border:1px solid #e2e8f0;border:1px solid var(--diag-border);border-radius:10px;color:#1e293b;color:var(--diag-text);flex:1 1;font-family:Inter,sans-serif;font-family:var(--font-body);font-size:13px;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s}.diag-chat-input:focus{background:#fff;border-color:#1e3a8a;border-color:var(--diag-primary);box-shadow:0 0 0 3px #1e3a8a1a;box-shadow:0 0 0 3px var(--diag-primary-glow)}.diag-chat-send{background:#1e3a8a;background:var(--diag-primary);border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:Inter,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:600;padding:10px 16px;transition:all .2s}.diag-chat-send:hover:not(:disabled){background:#1d4ed8}.diag-chat-send:disabled{cursor:not-allowed;opacity:.6}.diag-chat-fab{align-items:center;background:#1e3a8a;background:var(--diag-primary);border:none;border-radius:50%;bottom:32px;box-shadow:0 4px 20px #1e3a8a59;color:#fff;cursor:pointer;display:flex;font-size:24px;height:56px;justify-content:center;position:fixed;right:32px;transition:transform .2s,box-shadow .2s;width:56px;z-index:1000}.diag-chat-fab:hover{box-shadow:0 6px 28px #1e3a8a73;transform:scale(1.08)}@media (max-width:768px){.diag-chat-panel{border-radius:16px 16px 0 0;left:0;right:0;width:100%}.diag-chat-fab{bottom:20px;right:20px}}.navbar{background:#fff;box-shadow:0 2px 10px #0000000d;height:60px;justify-content:space-between;left:0;padding:0 20px;position:fixed;right:0;top:0;z-index:1000}.nav-left,.navbar{align-items:center;display:flex}.nav-left{gap:12px}.hamburger-btn{background:#0000;border:none;color:#1a1a2e;cursor:pointer;padding:0}.navbar-brand{color:#1a1a2e;font-size:20px;font-weight:700}.nav-right{gap:16px}.nav-icon-btn,.nav-right{align-items:center;display:flex}.nav-icon-btn{cursor:pointer;position:relative}.bell-emoji{font-size:20px}.nav-badge{background:#e94560;border-radius:10px;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;position:absolute;right:-8px;top:-4px}.nav-profile-circle{align-items:center;background:#0f3460;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:32px;justify-content:center;width:32px}@media (min-width:769px){.hamburger-btn{display:none}}.sidebar{background:#011f4b;bottom:0;color:#fff;display:flex;flex-direction:column;height:100%;left:0;position:fixed;top:0;transition:transform .3s ease;width:240px;z-index:1100}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.mobile-open{box-shadow:4px 0 24px #0000004d;transform:translateX(0)}}.sidebar-logo{border-bottom:1px solid #ffffff0d;gap:12px;padding:24px 20px;position:relative}.logo-icon,.sidebar-logo{align-items:center;display:flex}.logo-icon{background:#e94560;border-radius:6px;color:#fff;font-size:16px;font-weight:800;height:32px;justify-content:center;width:32px}.sidebar-logo span{font-size:18px;font-weight:700;letter-spacing:.5px}.mobile-sidebar-close{background:#0000;border:none;color:#fff9;cursor:pointer;display:none;font-size:24px;margin-left:auto}@media (max-width:768px){.mobile-sidebar-close{display:block}}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px;padding:16px 10px}.nav-item{align-items:center;border-radius:10px;color:#ffffffb3;display:flex;font-size:14px;font-weight:500;gap:12px;padding:10px 14px;text-decoration:none;transition:all .2s}.nav-item:hover{background:#ffffff0d;color:#fff}.nav-item.active{background:#e94560;color:#fff}.nav-icon{display:flex;font-size:16px;justify-content:center;width:20px}.sidebar-badge{background:#e94560;border:1px solid #fff3;border-radius:10px;color:#fff;font-size:10px;font-weight:700;margin-left:auto;padding:2px 8px}.sidebar-logout{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;color:#ffffffb3;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;margin:16px 10px 24px;padding:10px 14px;text-align:left;transition:all .2s}.sidebar-logout:hover{background:#e945601a;border-color:#e94560;color:#e94560}.logout-icon{font-size:16px}.sidebar-profile-info{align-items:center;background:#ffffff05;border-bottom:1px solid #ffffff0d;display:flex;gap:12px;padding:20px}.sidebar-avatar{align-items:center;background:#ffffff1a;border:2px solid #fff3;border-radius:50%;color:#fff;display:flex;font-weight:700;height:40px;justify-content:center;width:40px}.sidebar-user-details{overflow:hidden}.sidebar-user-name{color:#fff;font-size:14px;font-weight:600}.sidebar-user-dept,.sidebar-user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-dept{color:#ffffff80;font-size:11px}.bottom-nav{align-items:center;background:#fff;bottom:0;box-shadow:0 -2px 10px #0000000d;display:none;height:65px;justify-content:space-around;left:0;padding-bottom:env(safe-area-inset-bottom);position:fixed;right:0;z-index:1000}.bottom-nav-item{align-items:center;color:#888;display:flex;flex:1 1;flex-direction:column;font-size:11px;font-weight:500;gap:4px;text-decoration:none}.bottom-nav-icon{font-size:20px}.bottom-nav-item.active{color:#0f3460}@media (max-width:768px){.bottom-nav{display:flex}}.app-layout{display:flex;flex-direction:column;min-height:100vh}.main-viewport{background:#f8f9fa;margin-left:240px;margin-top:60px;min-height:calc(100vh - 60px);transition:margin-left .3s ease}.content-container{animation:pageIn .3s ease-out;max-width:1400px;padding:32px}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.main-viewport{margin-bottom:65px;margin-left:0}.content-container{padding:20px}}.mobile-overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:1050}@media (max-width:768px){.mobile-overlay{display:block}}
/*# sourceMappingURL=main.5babf999.css.map*/