.sidebar-root{display:flex;flex-direction:row;background:#fff;border-right:1px solid #ece6fa;z-index:2}.sidebar-modules{display:flex;flex-direction:column;align-items:center;width:64px;background:#fff;border-right:1px solid #ece6fa;padding:8px 0;gap:8px}.sidebar-module-icon{width:36px;height:36px;border-radius:50px;border:3px solid transparent;display:flex;align-items:center;justify-content:center;margin-bottom:2px;transition:border-color .2s,box-shadow .2s;cursor:pointer;outline:none;box-shadow:none;padding:4px}.sidebar-module-icon.active{box-shadow:0 2px 8px #0000001f}.module-icon-img{width:18px;height:18px;-o-object-fit:contain;object-fit:contain}.sidebar-submodules{display:flex;flex-direction:column;text-align:left;padding:8px 12px;gap:4px;flex:1;min-width:180px}.sidebar-submodule-link{display:block;padding:10px 12px;border-radius:6px;color:#374151;font-size:.875rem;font-weight:500;text-decoration:none;background:transparent;transition:background .15s,color .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-submodule-link:hover,.sidebar-submodule-link.active{background:#f3e8ff;color:#7c3aed}@media (max-width: 1024px) and (min-width: 768px){.sidebar-submodules{min-width:120px;padding:8px 6px}.sidebar-submodule-link{padding:9px 10px;font-size:.85rem}}@media (max-width: 767px){.sidebar-root{min-width:220px;max-width:280px;width:70vw;height:100%}.sidebar-modules{width:56px;padding:8px 0;gap:6px}.sidebar-module-icon{width:34px;height:34px;border-width:2px}.module-icon-img{width:17px;height:17px}.sidebar-submodules{min-width:140px;padding:8px}.sidebar-submodule-link{padding:11px 12px;font-size:.875rem;border-radius:6px}}@media (max-width: 479px){.sidebar-root{width:75vw;max-width:260px;min-width:200px}.sidebar-modules{width:50px;padding:6px 0;gap:4px}.sidebar-module-icon{width:32px;height:32px;border-width:2px}.module-icon-img{width:16px;height:16px}.sidebar-submodules{min-width:120px;padding:8px 6px}.sidebar-submodule-link{padding:10px;font-size:.825rem;border-radius:5px}}.program-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.program-modal{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.program-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid #e5e7eb}.program-modal-title{font-size:1.25rem;font-weight:600;color:#111827;margin:0}.program-modal-close{background:none;border:none;cursor:pointer;padding:4px;color:#6b7280;transition:color .2s;border-radius:4px}.program-modal-close:hover{color:#111827;background:#f3f4f6}.program-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.program-card{display:flex;align-items:center;gap:12px;padding:16px;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:12px;cursor:pointer;transition:all .2s ease;position:relative}.program-card:hover{border-color:#7c3aed;background:#faf8ff;box-shadow:0 2px 8px #7c3aed1a}.program-card.selected{border-color:#7c3aed;background:#faf8ff;box-shadow:0 0 0 3px #7c3aed1a}.program-radio{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border:2px solid #d1d5db;border-radius:50%;cursor:pointer;position:relative;transition:all .2s;flex-shrink:0}.program-radio:checked{border-color:#7c3aed;background:#7c3aed}.program-radio:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:#fff}.program-card-content{flex:1}.program-card-name{font-size:1rem;font-weight:600;color:#111827;text-align:left}.program-card-check{width:20px;height:20px;flex-shrink:0}.program-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb}.program-modal-btn{padding:10px 24px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.program-modal-btn-cancel{background:#f3f4f6;color:#374151}.program-modal-btn-cancel:hover:not(:disabled){background:#e5e7eb}.program-modal-btn-select{background:#7c3aed;color:#fff}.program-modal-btn-select:hover:not(:disabled){background:#6d28d9;box-shadow:0 4px 12px #7c3aed4d}.program-modal-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 767px){.program-modal-overlay{padding:0;align-items:flex-end}.program-modal{max-width:100%;max-height:85vh;border-radius:16px 16px 0 0;animation:slideUpMobile .3s ease-out}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.program-modal-header{padding:20px 16px 12px}.program-modal-title{font-size:1.125rem}.program-modal-body{padding:16px}.program-card{padding:12px;margin-bottom:10px}.program-card-name{font-size:.9rem}.program-modal-footer{padding:12px 16px;flex-direction:column-reverse;gap:8px}.program-modal-btn{width:100%;padding:12px 24px}}@media (max-width: 479px){.program-modal{max-height:90vh}.program-modal-header{padding:16px 12px 10px}.program-modal-title{font-size:1rem}.program-modal-body{padding:12px}.program-card{padding:10px;gap:10px}.program-card-name{font-size:.85rem}.program-radio,.program-card-check{width:18px;height:18px}}.main-layout{display:flex;flex-direction:column;min-height:100vh;background:#f8fafc}.main-layout-header{display:flex;align-items:center;justify-content:space-between;height:64px;background:#fff;border-bottom:1px solid #ece6fa;padding:0 32px 0 16px;box-sizing:border-box;z-index:10;position:relative}.header-left{display:flex;align-items:center;gap:12px}.mobile-menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:#333;transition:color .2s}.mobile-menu-toggle:hover{color:#7c3aed}.mobile-menu-toggle:focus{outline:2px solid #7c3aed;outline-offset:2px}.tgm-logo{height:48px;width:auto;max-width:160px;-o-object-fit:contain;object-fit:contain}.header-center{flex:1;text-align:center}.header-title{font-size:1.3rem;font-weight:400;color:#222}.header-right{display:flex;align-items:center;gap:18px}.program-dropdown{border:1px solid #ece6fa;border-radius:6px;padding:6px 28px 6px 12px;font-size:.9rem;background:#faf8ff;color:#333;cursor:pointer;transition:all .2s ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:inherit}.program-dropdown:hover:not(:disabled){border-color:#8b5cf6;background:#f5f0ff}.program-dropdown:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.program-dropdown:disabled{opacity:.6;cursor:not-allowed}.profile-info{display:flex;align-items:center;gap:8px}.profile-avatar{width:32px;height:32px;border-radius:50%;background:#eee;display:flex;align-items:center;justify-content:center;overflow:hidden}.profile-name{font-size:.9rem;color:#222;font-weight:400}.main-layout-body{display:flex;flex:1 1 auto;min-height:0;position:relative}.sidebar-wrapper{display:flex;position:relative;z-index:5}.mobile-sidebar-overlay{display:none;position:fixed;top:64px;left:0;right:0;bottom:0;background:#00000080;z-index:4}.main-layout-content{padding:2rem;flex:1 1 auto;min-width:0;min-height:100vh;background:#f7eeff;overflow-x:auto}@media (max-width: 1024px) and (min-width: 768px){.main-layout-header{padding:0 20px 0 12px}.header-title{font-size:1.1rem}.tgm-logo{height:42px}.program-dropdown{max-width:200px;font-size:.85rem}.profile-name{font-size:.85rem}.main-layout-content{padding:1.5rem}}@media (max-width: 767px){.main-layout-header{height:56px;padding:0 12px 0 8px}.header-left{gap:8px}.mobile-menu-toggle{display:block}.tgm-logo{height:36px;max-width:100px}.header-center{display:none}.header-title{font-size:1rem}.header-right{gap:0;flex:1}.program-dropdown{padding:6px 24px 6px 10px;font-size:.75rem;max-width:none;width:100%;color:#333;background-color:#fff}.profile-info{display:none}.sidebar-wrapper{position:fixed;top:56px;left:-100%;height:calc(100vh - 56px);transition:left .3s ease-in-out;background:#fff;box-shadow:2px 0 8px #0000001a}.sidebar-wrapper.mobile-open{left:0}.mobile-sidebar-overlay{display:block}.main-layout-content{padding:1rem;width:100%}}@media (max-width: 479px){.main-layout-header{padding:0 8px}.tgm-logo{height:32px;max-width:80px}.program-dropdown{max-width:none;font-size:.7rem;padding:5px 22px 5px 8px;width:100%;color:#333;background-color:#fff}.header-right{gap:0;flex:1}.main-layout-content{padding:.75rem}}@media (min-width: 1025px){.mobile-menu-toggle{display:none!important}.sidebar-wrapper{position:relative;left:0}.mobile-sidebar-overlay{display:none!important}}.learn-page{padding:.2rem;max-width:1200px;margin:0 auto}.learn-header{margin-bottom:20px}.learn-header h1{font-size:20px;color:#111827;margin:0;font-weight:600}.learn-header .subtitle{color:#6b7280;font-size:13px;margin:4px 0 0;font-weight:400}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px}.spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top:3px solid #7c3aed;border-radius:50%;animation:spin 1s linear infinite}.access-denied{text-align:center;padding:24px;background-color:#fef3c7;border:1px solid #fcd34d;border-radius:10px;margin-top:16px}.access-denied h2{color:#92400e;margin:0 0 12px;font-size:16px;font-weight:600}.access-denied p{color:#92400e;margin:6px 0;font-size:13px;font-weight:400}.content-viewer{background:#fff;border-radius:10px;box-shadow:0 1px 3px #00000014;padding:16px}.content-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e5e7eb;gap:10px}.content-header h2{font-size:15px;color:#111827;margin:0;font-weight:600;text-align:left;flex:1}.content-category{background-color:#7c3aed;color:#fff;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.content-body{line-height:1.6;color:#374151;margin-bottom:16px;min-height:auto;font-size:13px;font-weight:400}.content-actions{display:flex;gap:10px;padding:12px 0;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;margin-bottom:16px;flex-wrap:wrap}.btn{padding:8px 14px;border:none;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px;font-weight:500}.btn-primary{background-color:#7c3aed;color:#fff}.btn-primary:hover{background-color:#6d28d9;box-shadow:0 2px 6px #7c3aed33}.btn-secondary{background-color:#d1d5db;color:#374151}.btn-secondary:hover{background-color:#c1c3ca;box-shadow:0 2px 4px #0000001a}.btn-link{background-color:transparent;color:#7c3aed;border:1px solid #7c3aed}.btn-link:hover{background-color:#f3e8ff;color:#6d28d9}.permission-info{background-color:#f0f4ff;padding:12px;border-radius:8px;border-left:3px solid #7c3aed}.permission-info h4{margin:0 0 8px;color:#111827;font-size:13px;font-weight:600}.permission-info ul{list-style:none;padding:0;margin:0}.permission-info li{padding:4px 0;font-size:12px;font-weight:400}.permission-granted{color:#059669}.permission-denied{color:#dc2626;opacity:.8}.no-content{text-align:center;padding:24px;color:#9ca3af;font-size:13px;font-weight:400}.test-grid{display:flex;flex-direction:column;gap:12px}.learn-chapter-card{background:#fff;border-radius:10px;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0000000a;overflow:hidden}.learn-chapter-header{width:100%;background:transparent;border:none;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;cursor:pointer;border-radius:10px 10px 0 0;transition:all .2s ease}.learn-chapter-header:hover{background:#f9fafb}.learn-chapter-title{color:#7c3aed;font-weight:600;font-size:.95rem;text-align:left;flex:1;margin:0}.learn-chapter-caret{color:#6b7280;font-weight:700;font-size:13px;flex-shrink:0}.learn-topic-list{padding:8px 8px 12px}.learn-topic-card.horizontal{margin:0}.icon-play{display:inline-block;margin-right:6px;font-size:12px}.subject-tabs{display:flex;gap:10px;margin-bottom:20px;overflow-x:auto;padding:0 0 8px;scrollbar-width:none}.subject-tabs::-webkit-scrollbar{display:none}.subject-tabs button{padding:8px 18px;background:#fff;border-radius:20px;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease;white-space:nowrap;border:1px solid #e5e7eb;flex-shrink:0}.subject-tabs button:hover{color:#7c3aed;border-color:#7c3aed;background:#f9fafb}.subject-tabs button.active{background-color:#7c3aed;color:#fff;border-color:#7c3aed}.test-chapter-group{margin-bottom:16px}.test-chapter-heading{text-align:left;font-size:14px;font-weight:600;color:#7c3aed;margin:0 0 10px;display:flex;align-items:center;justify-content:space-between}.chapter-toggle{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.chapter-toggle .caret{color:#6b7280;font-weight:700;font-size:14px}.learn-topic-list{display:flex;flex-direction:column;gap:10px}.learn-topic-card.horizontal{background:#f3e8ff;border-radius:10px;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0000000a;display:flex;align-items:center;padding:14px 16px;min-height:50px;transition:all .2s ease}.learn-topic-card.horizontal:hover{box-shadow:0 3px 8px #7c3aed1a;border-color:#7c3aed}.learn-topic-content{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px}.learn-topic-title{font-size:.9rem;color:#111827;font-weight:500;flex:1;text-align:left}.learn-topic-actions{display:flex;gap:8px;flex-shrink:0}.btn-open-topic{padding:6px 14px;background:#7c3aed;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-open-topic:hover{background:#6d28d9;box-shadow:0 2px 6px #7c3aed33}.btn-open-topic:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;box-shadow:none}.viewer-section{margin-top:20px}@media (max-width: 768px){.learn-page{padding:.2rem}.learn-header h1{font-size:18px}.learn-header .subtitle{font-size:12px}.subject-tabs button{font-size:14px;padding:6px 14px}.test-chapter-heading{font-size:13px}.learn-topic-title{font-size:.9rem}.btn-open-topic{padding:5px 12px;font-size:11px}.content-actions{flex-direction:column;gap:8px}.btn{width:auto;justify-content:center}.content-header{flex-direction:column;align-items:flex-start}.content-header h2{font-size:14px}}.content-viewer-container{background:linear-gradient(to bottom,#c29eff,#efe6ff);min-height:100vh}.content-viewer-topbar{height:48px;display:flex;align-items:center;justify-content:flex-end;padding:0 16px;background:#fffffff2;border-bottom:1px solid #e5e7eb}.slide-counter{position:absolute;left:16px;font-size:12px;color:#6b7280;font-weight:500;letter-spacing:.5px}.close-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:transparent;border:none;cursor:pointer;color:#6b7280;transition:all .2s ease;font-size:18px}.close-button:hover{background:#f3f4f6;color:#111827}.progress-bar-container{height:2px;background:#e5e7eb;margin:0 16px;border-radius:1px;overflow:hidden}.progress-bar-fill{height:100%;background:#7c3aed;transition:width .3s ease}.content-area{flex:1;overflow-y:auto;padding:12px 12px 80px;display:flex;align-items:flex-start;justify-content:center}.slide-card{position:relative;width:100%;max-width:90%;background:#fff;border-radius:12px;box-shadow:0 4px 12px #7c3aed26;padding:16px}.slide-title{font-size:18px;font-weight:600;margin:0 0 12px;color:#111827;text-align:center;line-height:1.4}.bloom-badge{display:inline-block;margin-bottom:12px;padding:4px 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;background:#d1fae5;color:#065f46;border-radius:6px}.slide-content{font-size:14px;line-height:1.6;color:#374151;text-align:left;margin-bottom:12px}.slide-content h2{font-size:16px;font-weight:600;margin:12px 0 8px;color:#111827}.slide-content h3{font-size:15px;font-weight:600;margin:10px 0 6px;color:#1f2937}.slide-content p{margin:8px 0}.slide-content ul,.slide-content ol{margin:8px 0;padding-left:20px}.slide-content li{margin:4px 0}.slide-content .quiz-card{margin:12px 0;border-radius:10px;border:1px solid #e5e7eb;background:#f9fafb;padding:12px;box-shadow:0 1px 2px #0000000a}.slide-content .quiz-card p{font-size:13px;font-weight:500;color:#111827;margin:0 0 8px;line-height:1.5}.slide-content button{font-size:13px;border-radius:8px;padding:8px 16px;font-weight:600;cursor:pointer;transition:all .2s ease}.slide-content .flex.gap-4{gap:10px;margin:10px 0;display:flex;flex-wrap:wrap}.slide-content .flex.gap-4 button{flex:1;min-width:100px;padding:8px 14px;font-size:12px;border-radius:8px;border-width:1.5px;font-weight:600;cursor:pointer;transition:all .2s ease}.slide-content .flex.gap-4 button:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.slide-content .flex.gap-4 button:disabled{opacity:.5;cursor:not-allowed}.slide-content .rounded-full{padding:4px 10px;font-size:11px;font-weight:600;letter-spacing:.3px;white-space:nowrap}.slide-content .text-xs.text-indigo-600{font-size:12px;margin:8px 0;padding:6px 8px;background:#eef2ff;border-radius:6px;display:block}.slide-content .inline-flex.rounded-full{padding:6px 12px;font-size:12px;margin:8px 0;display:inline-block}.slide-content .text-slate-600{font-size:12px;margin:6px 0;line-height:1.5;color:#4b5563}.slide-content input[type=text],.slide-content input[type=email],.slide-content input[type=password],.slide-content input[type=number]{font-size:13px;padding:8px 12px;border-radius:8px;border:1px solid #d1d5db}.nav-button{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #e5e7eb;border-radius:50%;cursor:pointer;transition:all .2s ease;font-size:16px;color:#6b7280;box-shadow:0 2px 4px #0000000d;display:none}.nav-button:hover:not(:disabled){background:#f9fafb;border-color:#7c3aed;color:#7c3aed;box-shadow:0 4px 8px #7c3aed1a}.nav-button:disabled{opacity:.3;cursor:not-allowed}.nav-button.prev{left:-50px}.nav-button.next{right:-50px}.nav-bottom-bar{position:fixed;bottom:0;left:0;right:0;height:60px;background:#fff;border-top:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;padding:0 16px;z-index:40;box-shadow:0 -2px 8px #0000000d}.nav-bottom-button{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:18px;color:#6b7280;font-weight:600}.nav-bottom-button:hover:not(:disabled){background:#7c3aed;border-color:#7c3aed;color:#fff;box-shadow:0 2px 8px #7c3aed33}.nav-bottom-button:disabled{opacity:.4;cursor:not-allowed;background:#d1d5db;color:#9ca3af}.gating-message{margin-top:12px;text-align:center;font-size:12px;font-weight:500;color:#dc2626}.nav-hint{margin-top:12px;text-align:center;font-size:11px;color:#9ca3af}.loading-text,.error-text,.no-slides-text{text-align:center;padding:20px;font-size:14px;color:#6b7280}.error-text{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:8px;padding:12px;margin-bottom:12px}@media (max-width: 768px){.content-viewer-topbar{height:44px;padding:0 12px}.slide-counter{font-size:11px;left:12px}.close-button{width:28px;height:28px;font-size:16px}.progress-bar-container{margin:0 8px;height:1.5px}.content-area{padding:8px 8px 70px}.slide-card{max-width:100%;padding:12px;border-radius:10px}.slide-title{font-size:17px;margin-bottom:10px}.bloom-badge{padding:3px 8px;font-size:10px}.slide-content{font-size:14px;line-height:1.5;margin-bottom:10px}.slide-content h2{font-size:15px;margin:10px 0 6px}.slide-content h3{font-size:14px;margin:8px 0 5px}.slide-content p{margin:6px 0}.slide-content ul,.slide-content ol{margin:6px 0;padding-left:16px}.slide-content li{margin:3px 0}.slide-content .quiz-card{margin:10px 0;padding:10px;font-size:12px}.slide-content .quiz-card p{font-size:12px}.slide-content .flex.gap-4{gap:8px}.slide-content .flex.gap-4 button{padding:7px 12px;font-size:11px;min-width:90px}.slide-content .rounded-full{padding:3px 8px;font-size:10px}.nav-bottom-bar{height:56px;padding:8px 12px}.nav-bottom-button{width:40px;height:40px;font-size:16px}.gating-message{margin-top:10px;font-size:11px}.nav-hint{margin-top:10px;font-size:10px}}@media (max-width: 480px){.slide-card{padding:10px}.slide-title{font-size:16px;margin-bottom:8px}.slide-content{font-size:13px}.slide-content h2{font-size:14px;margin:8px 0 5px}.slide-content h3{font-size:13px}.slide-content ul,.slide-content ol{padding-left:14px}.slide-content .quiz-card{margin:8px 0;padding:8px;font-size:11px}.slide-content .quiz-card p{font-size:11px;margin:0 0 6px}.slide-content .flex.gap-4{gap:6px}.slide-content .flex.gap-4 button{padding:6px 10px;font-size:10px;min-width:80px}.slide-content .rounded-full{padding:2px 6px;font-size:9px}.slide-content .text-xs.text-indigo-600{font-size:10px;margin:6px 0;padding:4px 6px}.slide-content .inline-flex.rounded-full{padding:4px 8px;font-size:10px}.slide-content .text-slate-600{font-size:11px;margin:4px 0}.nav-bottom-bar{height:52px;padding:6px 10px}.nav-bottom-button{width:36px;height:36px;font-size:14px}.content-area{padding:8px 8px 65px}}.test-list-vertical{display:flex;flex-direction:column;gap:0}.test-card.horizontal{width:100%;min-width:0;margin-left:auto;margin-right:auto;background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:row;align-items:center;padding:0 32px;margin-bottom:0;min-height:64px;transition:box-shadow .2s}.test-card.horizontal:hover{box-shadow:0 4px 12px #0000001a;border-color:#7c3aed}.test-chapter-group{margin-bottom:32px}.test-chapter-heading{text-align:left;font-size:.95rem;font-weight:600;color:#7c3aed;margin-bottom:8px;margin-left:8px}.test-card-content{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:space-between;min-height:64px}.test-title{font-size:.95rem;font-weight:700;color:#111827;margin:0;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-start-test{padding:10px 24px;background:#7c3aed;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s,box-shadow .2s;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;min-width:-moz-fit-content;min-width:fit-content}.btn-start-test:hover:not(:disabled){background:#6d28d9;box-shadow:0 4px 12px #7c3aed26}.btn-start-test:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;box-shadow:none}.btn-start-test:active{transform:scale(.98)}.btn-upload-omr{padding:10px 24px;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s,box-shadow .2s;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;min-width:-moz-fit-content;min-width:fit-content}.btn-upload-omr:hover{background:#059669;box-shadow:0 4px 12px #10b98126}.btn-upload-omr:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;box-shadow:none}.btn-upload-omr:active{transform:scale(.98)}@media (max-width: 768px){.test-chapter-group{margin-bottom:15px}.test-card.horizontal{flex-direction:column;min-height:0;padding:16px}.test-chapter-heading{margin-left:0;text-align:center}.test-card-content{flex-direction:column;align-items:stretch;padding:0;gap:12px}.test-title{font-size:.8rem;white-space:normal;text-align:center}.test-title-area{justify-content:center}.test-card-actions{flex-direction:row;width:100%;gap:8px;justify-content:center}.btn-start-test{flex:1.25;padding:10px 16px;font-size:.8rem;font-weight:500;justify-content:center;min-width:0;height:40px}.btn-upload-omr{flex:1;padding:10px 16px;font-size:.8rem;font-weight:500;justify-content:center;min-width:0;height:40px}}.test-card-content{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:space-between;min-height:80px}.test-title-area{flex:1;display:flex;align-items:center}.test-title{font-size:1rem;font-weight:400;color:#111827;margin:0;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.test-card-actions{display:flex;align-items:center;gap:12px}@media (max-width: 768px){.test-card.horizontal{flex-direction:column;min-height:0}.chapter-name{min-width:100%;border-radius:12px 12px 0 0;padding:12px 16px;justify-content:center}.test-card-content{flex-direction:column;align-items:stretch}.test-title{font-size:1rem;white-space:normal}}.test-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.test-type-icon{font-size:24px}.test-status{display:flex;align-items:center}.test-status-badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.test-status-badge.not-started{background:#dbeafe;color:#1e40af}.test-status-badge.in-progress{background:#fed7aa;color:#c2410c}.test-status-badge.completed{background:#d1fae5;color:#065f46}.test-status-badge.overdue{background:#fee2e2;color:#991b1b}.test-card-body{flex:1;display:flex;flex-direction:column;gap:16px}.test-title{font-size:1rem;font-weight:400;color:#111827;margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.test-metadata{display:flex;flex-direction:column;gap:8px}.metadata-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;padding:6px 0;border-bottom:1px solid #f3f4f6}.metadata-item:last-child{border-bottom:none}.metadata-label{color:#6b7280;font-weight:500}.metadata-value{color:#111827;font-weight:600}.metadata-value.due-date{color:#dc2626}.test-score-summary{background:#f9fafb;border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:8px;border:1px solid #e5e7eb}.score-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.score-label{color:#6b7280;font-weight:500}.score-value{color:#111827;font-weight:700;font-size:1rem}.score-value.occs{color:#7c3aed}.attempt-info{font-size:.75rem;color:#6b7280;text-align:center;padding:6px;background:#f9fafb;border-radius:6px}.test-card-footer{margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}@media (max-width: 768px){.test-card{padding:16px}.test-title{font-size:1rem}.metadata-item,.score-item{font-size:.8125rem}}.test-list-page{padding:0;width:100%;max-width:1400px;margin:0 auto}.page-header{margin-bottom:16px}.page-title{font-size:1.5rem;font-weight:500;color:#111827;margin:0 0 8px}.page-subtitle{font-size:1rem;color:#6b7280;margin:0}.grade-selector-container{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding:16px 20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.grade-label{font-size:1rem;font-weight:600;color:#374151;margin:0}.grade-dropdown{padding:8px 16px;font-size:1rem;font-weight:500;color:#374151;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease;min-width:150px}.grade-dropdown:hover{border-color:#7c3aed;background:#f5f3ff}.grade-dropdown:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}.subject-tabs{display:flex;gap:12px;margin-bottom:10px;overflow-x:auto;padding-bottom:20px}.subject-tab{padding:8px 24px;background:transparent;border-radius:50px;font-size:1rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative;bottom:-2px}.subject-tab:hover{color:#7c3aed;background:#f9fafb}.subject-tab.active{background-color:#7c3aed;color:#fff}.filter-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;gap:16px;flex-wrap:wrap}.filter-buttons{display:flex;gap:12px;flex-wrap:wrap}.filter-btn{padding:10px 20px;background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-size:.9375rem;font-weight:600;color:#6b7280;cursor:pointer;transition:all .2s ease}.filter-btn:hover{border-color:#7c3aed;color:#7c3aed;background:#f9fafb}.filter-btn.active{background:#7c3aed;border-color:#7c3aed;color:#fff}.test-content{min-height:400px}.test-grid{display:flex;flex-direction:column;gap:16px;animation:fadeIn .3s ease}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#7c3aed;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}.loading-state p{font-size:1rem;color:#6b7280;margin:0}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.error-message{font-size:1.125rem;color:#dc2626;margin:0 0 20px}.btn-retry{padding:12px 24px;background:#7c3aed;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-retry:hover{background:#6d28d9;transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed4d}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.empty-state h3{font-size:1.5rem;font-weight:600;color:#111827;margin:0 0 8px}.empty-state p{font-size:1rem;color:#6b7280;margin:0;max-width:400px}@media (max-width: 1024px){.test-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}}@media (max-width: 768px){.page-title{font-size:1.75rem}.page-subtitle{font-size:.9375rem}.subject-tabs{gap:8px}.subject-tab{padding:10px 16px;font-size:.9375rem}.filter-buttons{width:100%}.filter-btn{flex:1;padding:10px 16px;font-size:.875rem}.test-grid{grid-template-columns:1fr;gap:16px}.empty-icon{font-size:48px}.empty-state h3{font-size:1.25rem}.empty-state p{font-size:.9375rem}}@media (max-width: 480px){.page-header{margin-bottom:24px}.page-title{font-size:1.5rem}.subject-tab{padding:8px 12px;font-size:.875rem}.filter-btn{font-size:.8125rem;padding:8px 12px}}.test-meta-page{padding:0;width:100%;max-width:1400px;margin:0 auto}.header{margin-bottom:24px;padding:0}.title{margin:8px 0 4px;font-weight:500;font-size:1.5rem;color:#111827}.sub{color:#6b7280;font-size:1rem}.type-badge{display:inline-block;margin-top:6px;padding:4px 10px;border-radius:999px;background:#eef2ff;color:#3730a3;font-weight:600;font-size:.8rem}.type-badge.proctored{background:#fee2e2;color:#991b1b}.content{display:flex;flex-direction:column;gap:20px;padding:0}.top-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px}.full-width{grid-column:1 / -1}.card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px}.card h3{margin:0 0 12px;font-size:1.05rem}.details-vertical{display:flex;flex-direction:column;gap:10px}.detail-item{display:flex;flex-direction:column;gap:4px;padding:10px;background:#f9fafb;border:1px solid #eef2ff;border-radius:8px}.detail-label{color:#6b7280;font-size:.85rem}.detail-value{color:#111827;font-size:1.1rem;font-weight:600}.instructions{line-height:1.5;color:#111827}.instructions ul{padding-left:24px;margin:8px 0}.instructions li{margin:6px 0}.instructions-content{display:flex;flex-direction:column;gap:8px;text-align:left}.instruction-header{font-weight:600;font-size:1.05rem;color:#111827;margin-top:16px;margin-bottom:8px}.instruction-header:first-child{margin-top:0}.instruction-item{padding-left:0;color:#374151;line-height:1.6}.instruction-item.numbered{padding-left:4px}.instruction-item.bulleted{padding-left:20px;position:relative}.instruction-line{color:#374151;line-height:1.6;padding-left:20px}.note{margin-top:8px;padding:8px;border-radius:8px;background:#fff7ed;border:1px solid #ffedd5;color:#9a3412}.topics-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.topic-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb;gap:12px}.topic-name{font-weight:500;color:#111827;font-size:.95rem;flex:1}.topic-count{color:#7c3aed;font-size:.8rem;font-weight:600;background:#f3e8ff;padding:3px 10px;border-radius:12px;flex-shrink:0}.actions-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:8px}.btn-secondary{padding:12px 20px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.btn-primary-start-test{padding:10px 20px;background:#7c3aed;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary-start-test.disabled,.btn-primary-start-test:disabled{background:#c7c9d1;cursor:not-allowed}.btn-primary-start-test:hover:not(:disabled){background:#6d28d9}.loading,.error{padding:80px 20px;text-align:center;color:#6b7280}.muted{color:#6b7280;font-size:.85rem}@media (max-width: 900px){.top-row{grid-template-columns:1fr}}@media (max-width: 767px){.test-meta-page{padding:0}.header{margin-bottom:16px}.title{font-size:1.1rem;margin:6px 0 4px}.sub{font-size:.85rem;line-height:1.4}.type-badge{font-size:.7rem;padding:3px 8px;margin-top:4px}.content{gap:12px}.card{padding:12px;border-radius:10px}.card h3{font-size:.95rem;margin:0 0 10px}.details-vertical{gap:8px}.detail-item{padding:8px 10px}.detail-label{font-size:.75rem}.detail-value{font-size:.95rem}.instructions{font-size:.85rem;line-height:1.5}.instructions ul{padding-left:20px}.instructions li{margin:4px 0;font-size:.85rem}.instructions-content{gap:6px}.instruction-header{font-size:.9rem;margin-top:12px;margin-bottom:6px}.instruction-item,.instruction-line{font-size:.85rem;line-height:1.5}.instruction-item.bulleted,.instruction-line{padding-left:16px}.note{font-size:.8rem;padding:6px 8px;margin-top:6px}.topics-list{gap:6px}.topic-item{padding:10px 12px;width:inherit;flex-direction:row;align-items:center;justify-content:space-between;gap:8px}.topic-name{font-size:.85rem;font-weight:500;flex:1;text-align:left}.topic-count{font-size:.75rem;font-weight:600;color:#7c3aed;background:#f3e8ff;padding:2px 8px;border-radius:12px;flex-shrink:0}.actions-bottom{flex-direction:column-reverse;gap:10px;padding-top:12px}.btn-secondary,.btn-primary-start-test{width:100%;padding:12px 16px;font-size:.9rem}.muted{font-size:.8rem}}@media (max-width: 479px){.title{font-size:1rem}.sub{font-size:.8rem}.type-badge{font-size:.65rem;padding:2px 6px}.card{padding:10px}.card h3{font-size:.9rem;margin:0 0 8px}.detail-label{font-size:.7rem}.detail-value{font-size:.9rem}.instructions,.instructions li,.instruction-item,.instruction-line{font-size:.8rem}.instruction-header{font-size:.85rem}.topic-name{font-size:.8rem;line-height:1.4}.topic-count{font-size:.7rem;padding:2px 6px}.btn-secondary,.btn-primary-start-test{padding:10px 14px;font-size:.85rem}.note{font-size:.75rem}}.test-player-header{position:fixed;top:0;left:0;right:0;height:70px;background:#fff;border-bottom:2px solid #e5e7eb;z-index:100;box-shadow:0 2px 4px #0000001a}.header-content{max-width:1400px;margin:0 auto;height:100%;padding:0 24px;display:flex;align-items:center;justify-content:space-between}.test-info{flex:1}.test-name{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 4px}.question-indicator{font-size:14px;color:#6b7280;margin:0}.header-actions{display:flex;align-items:center;gap:16px}.btn-close-test{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease}.btn-close-test:hover{background:#e5e7eb;border-color:#9ca3af;color:#1f2937}.btn-close-test:active{transform:scale(.98)}.timer{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#10b981,#059669);border-radius:8px;font-size:18px;font-weight:600;color:#fff;box-shadow:0 2px 8px #10b9814d;transition:all .5s ease}.timer-icon{font-size:20px}.timer-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 2px 8px #f59e0b66;animation:pulse 2s ease-in-out infinite}.timer-critical{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef444480;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 768px){.test-player-header{height:60px}.header-content{padding:0 16px;justify-content:space-between;position:relative}.test-info{display:flex;align-items:center;flex:0}.test-name,.question-indicator{display:none}.header-actions{gap:0;justify-content:flex-end;flex:1}.btn-close-test{position:relative;right:auto;padding:8px 12px;font-size:18px;background:transparent;border:none;color:#6b7280;min-width:auto}.btn-close-test:hover{background:#f3f4f6;color:#1f2937}.timer{padding:8px 20px;font-size:18px;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:24px;position:absolute;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #10b9814d;color:#fff}.timer-icon{font-size:20px}.timer-warning{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px #f59e0b66;color:#fff}.timer-critical{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef444480;color:#fff}}.question-panel{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.question-loading,.error-message{padding:40px;text-align:center;color:#6b7280;font-size:16px}.error-message{color:#dc2626}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.question-number{font-size:14px;font-weight:600;color:#1f2937}.question-type-badge{font-size:12px;padding:4px 12px;background:#e0f2fe;color:#0369a1;border-radius:12px;font-weight:500}.question-content{margin-bottom:24px}.question-text{font-size:16px;line-height:1.6;color:#1f2937;margin-bottom:8px;text-align:left}.question-marks{font-size:14px;color:#059669;font-weight:600;text-align:left;margin-top:8px}.options-container{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;text-align:left}.options-container.true-false{flex-direction:row;gap:16px}.options-container.true-false .option-item{flex:1;justify-content:center}.option-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#fff;position:relative}.option-item:hover:not(.disabled){border-color:#c29eff;background:#faf5ff;transform:translate(2px);box-shadow:0 2px 4px #c29eff26}.option-item.selected{border-color:#c29eff;background:#f3e8ff;box-shadow:0 0 0 3px #c29eff33}.option-item.disabled{cursor:not-allowed;opacity:.6;background:#f9fafb}.option-item input[type=radio],.option-item input[type=checkbox]{display:none}.option-letter{display:flex;align-items:center;justify-content:center;min-width:32px;width:32px;height:32px;background:#f3f4f6;border-radius:50%;font-weight:700;font-size:14px;color:#6b7280;flex-shrink:0;transition:all .2s ease}.option-item:hover:not(.disabled) .option-letter{background:#f3e8ff;color:#9333ea}.option-item.selected .option-letter{background:#c29eff;color:#fff;box-shadow:0 2px 4px #c29eff66}.option-text{flex:1;font-size:15px;line-height:1.6;color:#1f2937;word-wrap:break-word}.question-actions{display:flex;justify-content:flex-end;padding-top:16px;border-top:1px solid #e5e7eb}.btn-clear-response{padding:8px 16px;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-clear-response:hover{background:#f9fafb;border-color:#9ca3af;color:#374151}@media (max-width: 768px){.question-panel{padding:10px;border-radius:12px;box-shadow:0 2px 8px #00000014}.question-type-badge{display:none}.question-header{display:block;text-align:center;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid #f3f4f6}.question-number{font-size:13px;font-weight:700;color:#7c3aed;background:#f3e8ff;padding:6px 16px;border-radius:20px;letter-spacing:.5px;display:block;width:-moz-fit-content;width:fit-content;margin:0 auto}.question-content{margin-bottom:20px}.question-text{font-size:15px;line-height:1.6;color:#111827;font-weight:500}.question-marks{font-size:13px;margin-top:8px;color:#10b981}.options-container{gap:10px;margin-bottom:16px}.option-item{padding:12px 14px;border-radius:10px;border-width:1.5px;box-shadow:0 1px 3px #0000000d}.option-item:hover:not(.disabled){transform:translate(0);box-shadow:0 2px 6px #c29eff33}.option-item.selected{box-shadow:0 0 0 2px #c29eff4d}.option-letter{min-width:28px;width:28px;height:28px;font-size:13px;font-weight:800}.option-text{font-size:14px;line-height:1.5}.question-actions{padding-top:12px;border-top:1.5px solid #f3f4f6}.btn-clear-response{padding:8px 16px;font-size:13px;border-radius:8px;font-weight:600}.options-container.true-false{flex-direction:column}}.navigation-buttons{display:flex;align-items:center;justify-content:space-between;padding:20px 0;gap:12px}.btn-nav{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;white-space:nowrap;position:relative;overflow:hidden}.btn-nav:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-nav:hover:before{width:300px;height:300px}.btn-previous{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#475569;border:2px solid #e2e8f0;flex:1;box-shadow:0 1px 3px #00000014}.btn-previous:hover:not(:disabled){background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.btn-previous:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 3px #00000014}.btn-clear{background:linear-gradient(135deg,#fff1f2,#ffe4e6);color:#dc2626;border:2px solid #fecaca;flex:.8;box-shadow:0 1px 3px #dc26261a}.btn-clear:hover:not(:disabled){background:linear-gradient(135deg,#ffe4e6,#fecdd3);border-color:#fca5a5;transform:translateY(-2px);box-shadow:0 4px 12px #dc262626}.btn-clear:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 3px #dc26261a}.btn-next{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:2px solid #3b82f6;flex:1;box-shadow:0 2px 8px #3b82f640}.btn-next:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:#2563eb;transform:translateY(-2px);box-shadow:0 6px 16px #3b82f659}.btn-next:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #3b82f640}.btn-submit{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:2px solid #10b981;flex:1;box-shadow:0 2px 8px #10b98140}.btn-submit:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);border-color:#059669;transform:translateY(-2px);box-shadow:0 6px 16px #10b98159}.btn-submit:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #10b98140}.btn-nav:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-nav:disabled:before{display:none}.nav-icon{font-size:18px;line-height:1;font-weight:700}.nav-center{flex:1;display:flex;justify-content:center}.answered-indicator{display:flex;align-items:center;gap:6px;color:#059669;font-size:14px;font-weight:600;padding:6px 16px;background:#d1fae5;border-radius:20px}@media (max-width: 768px){.navigation-buttons{position:fixed;bottom:0;left:0;right:0;flex-wrap:nowrap;padding:14px 16px;gap:10px;background:linear-gradient(to top,#fff,#fafafa);border-radius:0;box-shadow:0 -4px 20px #00000014;z-index:50;border-top:1px solid #e5e7eb}.btn-nav{padding:13px 18px;font-size:14px;font-weight:700;border-radius:12px;flex:1}.btn-previous{border-width:2px;flex:1}.btn-clear{flex:.7;font-size:13px;padding:12px 14px}.btn-next,.btn-submit{flex:1}.nav-center{display:none}.answered-indicator{font-size:13px;padding:6px 12px}}.question-palette{background:linear-gradient(to bottom,#fff,#fafafa);border-radius:12px;padding:16px;box-shadow:0 4px 20px #00000014,0 0 0 1px #00000005;position:sticky;top:90px;max-height:calc(100vh - 110px);overflow-y:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.palette-header{border-bottom:2px solid #f1f5f9;background:linear-gradient(90deg,#f8fafc 0%,transparent 100%);margin:-16px -16px 16px;padding:14px 16px 12px;border-radius:12px 12px 0 0}.palette-header h3{margin:0;font-size:15px;font-weight:700;background:linear-gradient(135deg,#1f2937,#4b5563);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.3px}.palette-close-btn{display:none}.palette-summary{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;padding:14px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:10px;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000a}.summary-item{display:flex;align-items:center;gap:10px;font-size:13px;padding:2px 0;transition:all .2s ease}.summary-item:hover{transform:translate(4px)}.summary-circle{width:14px;height:14px;border-radius:50%;flex-shrink:0;box-shadow:0 2px 6px #00000026;transition:all .2s ease}.summary-item:hover .summary-circle{transform:scale(1.15)}.summary-circle.answered{background:linear-gradient(135deg,#10b981,#059669)}.summary-circle.not-answered{background:linear-gradient(135deg,#ef4444,#dc2626)}.summary-circle.not-visited{background:linear-gradient(135deg,#cbd5e1,#94a3b8)}.summary-label{flex:1;color:#475569;font-weight:500}.summary-count{font-weight:700;font-size:16px;background:linear-gradient(135deg,#1f2937,#475569);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;min-width:28px;text-align:right}.palette-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:16px}.palette-item{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:2px solid transparent;border-radius:10px;background:#fff;color:#64748b;font-size:13px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px #0000000f;position:relative;overflow:hidden}.palette-item:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff6;transform:translate(-50%,-50%);transition:width .6s,height .6s}.palette-item:hover:not(:disabled):before{width:100px;height:100px}.palette-item:hover:not(:disabled){transform:translateY(-4px) scale(1.05);box-shadow:0 8px 16px #00000026}.palette-item:active:not(:disabled){transform:translateY(-2px) scale(1.02)}.palette-item:disabled{cursor:not-allowed;opacity:.5}.palette-item.answered{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:#fff;box-shadow:0 4px 12px #10b9814d}.palette-item.not-answered{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444;color:#fff;box-shadow:0 4px 12px #ef44444d}.palette-item.not-visited{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-color:#cbd5e1;color:#64748b;box-shadow:0 2px 6px #0000000f}.palette-item.current{border-color:#3b82f6;border-width:3px;box-shadow:0 0 0 4px #3b82f640,0 4px 12px #3b82f666;animation:pulse-border 2s infinite}@keyframes pulse-border{0%,to{box-shadow:0 0 0 4px #3b82f640,0 4px 12px #3b82f666}50%{box-shadow:0 0 0 6px #3b82f659,0 4px 12px #3b82f680}}.palette-legend{border-top:2px solid #f1f5f9;background:linear-gradient(to bottom,transparent 0%,#fafafa 100%);margin:0 -16px -16px;padding:14px 16px 16px;border-radius:0 0 12px 12px}.legend-title{font-size:10px;font-weight:700;color:#94a3b8;margin-bottom:10px;text-transform:uppercase;letter-spacing:.8px}.legend-items{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#475569;font-weight:500;padding:4px 0;transition:all .2s ease}.legend-item:hover{transform:translate(4px);color:#1f2937}.legend-box{width:18px;height:18px;border-radius:6px;flex-shrink:0;box-shadow:0 2px 6px #0000001f;transition:all .2s ease}.legend-item:hover .legend-box{transform:scale(1.15)}.legend-box.answered{background:linear-gradient(135deg,#10b981,#059669)}.legend-box.not-answered{background:linear-gradient(135deg,#ef4444,#dc2626)}.legend-box.not-visited{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:2px solid #cbd5e1}.legend-box.current{background:#fff;border:3px solid #3b82f6;box-shadow:0 0 0 2px #3b82f633}@media (max-width: 768px){.question-palette{position:static;max-height:none;height:100%;border-radius:0;padding:16px;background:linear-gradient(to bottom,#fafafa,#fff)}.palette-header{display:flex;justify-content:space-between;align-items:center;margin:-16px -16px 16px;padding:14px 16px 12px;border-radius:0}.palette-header h3{font-size:1rem;letter-spacing:-.3px}.palette-close-btn{display:block;background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px 8px;line-height:1}.palette-summary{padding:12px;gap:8px;margin-bottom:14px}.summary-item{gap:8px;font-size:12px}.summary-circle{width:12px;height:12px}.summary-count{font-size:12px}.palette-grid{grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:14px}.palette-item{font-size:12px;min-height:42px;border-radius:8px;font-weight:700}.palette-legend{margin:0 -16px -16px;padding:12px 16px 16px;border-radius:0}.legend-title{font-size:9px;margin-bottom:8px}.legend-items{gap:6px}.legend-item{font-size:11px;gap:6px}.legend-box{width:16px;height:16px;border-radius:5px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:100%;box-shadow:0 20px 25px -5px #0000001a;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:#1f2937}.modal-close{background:none;border:none;font-size:28px;color:#6b7280;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover:not(:disabled){background:#f3f4f6;color:#1f2937}.modal-close:disabled{cursor:not-allowed;opacity:.5}.modal-body{padding:24px}.submission-summary{background:#f9fafb;border-radius:8px;padding:16px;margin-bottom:20px}.summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:15px}.summary-row:not(:last-child){border-bottom:1px solid #e5e7eb}.summary-label{color:#6b7280}.summary-value{font-weight:600;color:#1f2937}.summary-value.answered{color:#059669}.summary-value.unanswered{color:#dc2626}.warning-message{display:flex;gap:12px;padding:16px;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;margin-bottom:20px}.warning-icon{font-size:20px;flex-shrink:0}.warning-message p{margin:0;color:#92400e;font-size:14px;line-height:1.5}.confirmation-text{font-size:16px;color:#1f2937;margin:0;font-weight:500}.modal-footer{display:flex;gap:12px;padding:16px 24px 24px}.modal-footer button{flex:1;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-cancel{background:#fff;color:#374151;border:2px solid #d1d5db}.btn-cancel:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-confirm{background:#059669;color:#fff;border:2px solid #059669}.btn-confirm:hover:not(:disabled){background:#047857;border-color:#047857}.modal-footer button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.modal-content{max-width:100%}.modal-header h2{font-size:18px}.modal-footer{flex-direction:column}}.auto-save-indicator{display:none;position:fixed;top:80px;right:24px;z-index:99;background:#fff;border-radius:8px;padding:8px 16px;box-shadow:0 2px 8px #0000001a;align-items:center;gap:8px;font-size:14px;transition:all .3s ease;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.auto-save-indicator.auto-save-saving{border-left:4px solid #3b82f6}.auto-save-indicator.auto-save-saved{border-left:4px solid #10b981}.auto-save-indicator.auto-save-error{border-left:4px solid #ef4444}.auto-save-icon{font-size:16px}.auto-save-text{font-weight:500}.auto-save-indicator.auto-save-saving .auto-save-icon{animation:rotate 1s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.auto-save-indicator{top:60px;right:16px;padding:6px 12px;font-size:12px}}.test-player-container{min-height:100vh;background:linear-gradient(to bottom,#c29eff,#efe6ff);padding-top:70px}.test-player-content{max-width:1400px;margin:0 auto;padding:24px;display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:start}.question-section{min-height:calc(100vh - 140px);display:flex;flex-direction:column;gap:20px}.test-player-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.test-player-loading p{font-size:16px;color:#6b7280}.test-player-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 20px;text-align:center}.error-icon{font-size:64px;margin-bottom:20px}.test-player-error h2{font-size:24px;color:#1f2937;margin:0 0 12px}.test-player-error p{font-size:16px;color:#6b7280;margin:0 0 24px;max-width:500px}.btn-back{padding:12px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-back:hover{background:#2563eb}@media (max-width: 1024px){.test-player-content{grid-template-columns:1fr 320px;gap:20px}}.mobile-palette-toggle,.mobile-palette-overlay{display:none}@media (max-width: 768px){.test-player-container{padding-top:60px;padding-bottom:80px}.test-player-content{grid-template-columns:1fr;padding:12px;gap:12px;position:relative}.question-section{min-height:auto;gap:12px}.palette-section{position:fixed;top:60px;left:-100%;width:100%;max-width:400px;height:calc(100vh - 60px);background:#fff;box-shadow:2px 0 8px #00000026;z-index:100;transition:left .4s cubic-bezier(.4,0,.2,1);overflow-y:auto}.palette-section.mobile-open{left:0}.mobile-palette-toggle{display:flex;position:relative;bottom:auto;right:auto;width:40px;height:40px;border-radius:8px;background:transparent;color:#6b7280;border:none;box-shadow:none;cursor:pointer;z-index:auto;align-items:center;justify-content:center;font-size:20px;font-weight:600;transition:all .2s}.mobile-palette-toggle:hover{background:#f3f4f6;color:#1f2937}.mobile-palette-toggle:active{transform:scale(.95)}.mobile-palette-toggle .toggle-icon{display:flex;flex-direction:column;gap:3px;align-items:center}.mobile-palette-toggle .toggle-icon span{display:block;width:18px;height:2.5px;background:currentColor;border-radius:2px}.mobile-palette-overlay{display:block;position:fixed;top:60px;left:0;right:0;bottom:0;background:#00000080;z-index:99;opacity:0;visibility:hidden;transition:opacity .4s cubic-bezier(.4,0,.2,1),visibility .4s}.mobile-palette-overlay.active{opacity:1;visibility:visible}}@media print{.test-player-header,.navigation-buttons,.question-palette,.auto-save-indicator{display:none!important}.test-player-content{grid-template-columns:1fr;padding:0}.question-panel{box-shadow:none;border:1px solid #e5e7eb}}.test-player-container :focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.test-player-container{-webkit-user-select:none;-moz-user-select:none;user-select:none}.test-player-container input,.test-player-container textarea{-webkit-user-select:text;-moz-user-select:text;user-select:text}.performance-chart-section.modern{background:linear-gradient(135deg,#fff,#f8f9ff);border-radius:16px;padding:24px;box-shadow:0 4px 16px #0000000f;border:1px solid rgba(99,102,241,.1);margin-bottom:24px}.performance-header-row{display:flex;align-items:center;justify-content:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid rgba(99,102,241,.1)}.performance-header-row .section-title{font-size:22px;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.3px}.bloom-progress-grid{display:flex;flex-direction:column;gap:24px}.bloom-progress-header{margin-bottom:4px}.bloom-progress-title{font-size:14px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.5px}.bloom-progress-list{display:flex;flex-direction:column;gap:16px}.bloom-progress-item{display:flex;flex-direction:column;gap:6px;padding:0}.bloom-progress-label{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600;color:#1f2937;margin-bottom:4px}.bloom-level-name{color:#1f2937;font-weight:600}.bloom-level-stats{color:#6b7280;font-size:13px;font-weight:600}.bloom-progress-bar-track{height:12px;background:linear-gradient(90deg,#f0f4ff,#e8edff);border-radius:8px;overflow:hidden;box-shadow:inset 0 1px 3px #0000000d}.bloom-progress-bar-fill{height:100%;border-radius:8px;transition:width .6s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 8px #0000001f}.no-data{color:#9ca3af;font-size:14px;text-align:center;padding:20px}.distribution-summary.modern{margin-top:32px;padding-top:32px;border-top:2px solid rgba(99,102,241,.12)}.distribution-summary.modern .summary-card{background:transparent;padding:0;box-shadow:none;border:none}.distribution-summary.modern h4{font-size:13px;font-weight:800;color:#374151;text-transform:uppercase;letter-spacing:.6px;margin:0 0 20px}.distribution-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:100%}.distribution-item{background:linear-gradient(135deg,#fff,#fafbff);border:1.5px solid rgba(99,102,241,.14);border-radius:14px;padding:24px 18px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 4px 14px #3b82f614;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:110px;cursor:pointer}.distribution-item:hover{border-color:#6366f159;box-shadow:0 8px 24px #3b82f626;transform:translateY(-4px);background:linear-gradient(135deg,#fff,#f0f4ff)}.dist-label{font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px}.dist-value{font-size:24px;font-weight:700;color:#1f2937;line-height:1.1;margin-bottom:4px}@media (min-width: 1024px){.performance-chart-section.modern{padding:32px}.distribution-grid{grid-template-columns:repeat(3,1fr);gap:16px}}@media (min-width: 768px) and (max-width: 1023px){.performance-chart-section.modern{padding:24px}.distribution-grid{grid-template-columns:repeat(3,1fr);gap:14px}.distribution-item{padding:20px 14px;min-height:100px}.dist-value{font-size:24px}}@media (max-width: 767px){.performance-chart-section.modern{padding:16px;border-radius:12px}.distribution-summary.modern{margin-top:24px;padding-top:24px}.distribution-summary.modern h4{font-size:12px;margin-bottom:16px}.distribution-grid{grid-template-columns:repeat(3,1fr);gap:12px}.distribution-item{padding:16px 10px;min-height:90px;border-radius:12px}.dist-label{font-size:10px;margin-bottom:6px}.dist-value{font-size:22px}}@media (max-width: 480px){.performance-chart-section.modern{padding:14px;border-radius:12px}.distribution-summary.modern{margin-top:20px;padding-top:20px}.distribution-summary.modern h4{font-size:11px;margin-bottom:14px}.distribution-grid{grid-template-columns:repeat(3,1fr);gap:10px}.distribution-item{padding:14px 8px;min-height:80px;border-radius:10px;min-width:0}.dist-label{font-size:9px;margin-bottom:4px}.dist-value{font-size:20px}}.pdbta-analysis-container{max-width:1200px;margin:0 auto;padding:2rem}.pdbta-no-data{text-align:center;padding:4rem 2rem;color:#6b7280}.pdbta-no-data svg{color:#9ca3af;margin-bottom:1rem}.pdbta-no-data h3{font-size:1.5rem;margin-bottom:.5rem;color:#374151}.pdbta-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.pdbta-header-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:#fff3;border-radius:50%}.pdbta-header-text h2{margin:0;font-size:1.75rem;font-weight:700}.pdbta-header-text p{margin:.25rem 0 0;opacity:.9;font-size:.95rem}.pdbta-section{margin-bottom:2.5rem}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:#1f2937}.section-header svg{color:#667eea}.section-header h3{margin:0;font-size:1.5rem;font-weight:600}.occs-section .occs-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.occs-main{display:flex;align-items:center;gap:2rem;margin-bottom:2rem}.occs-score{font-size:4rem;font-weight:700;line-height:1}.occs-label{flex:1}.clarity-badge{display:inline-block;padding:.5rem 1rem;border-radius:9999px;color:#fff;font-weight:600;font-size:.95rem;margin-bottom:.5rem}.risk-badge{display:inline-block;font-weight:600;font-size:.9rem}.occs-breakdown{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;padding:1.5rem;background:#f9fafb;border-radius:8px;margin-bottom:1.5rem}.occs-stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{color:#6b7280;font-size:.875rem}.stat-value{color:#1f2937;font-size:1.25rem;font-weight:600}.occs-explanation{padding:1rem;background:#eff6ff;border-left:4px solid #3b82f6;border-radius:4px;color:#1e40af;font-size:.9rem;line-height:1.6}.occs-explanation strong{color:#1e3a8a}.tbpa-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.tag-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:transform .2s}.tag-card:hover{transform:translateY(-4px)}.tag-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;margin-bottom:1rem}.cc-card .tag-icon{background:#d1fae5;color:#10b981}.pu-card .tag-icon{background:#fef3c7;color:#f59e0b}.mc-card .tag-icon{background:#fee2e2;color:#ef4444}.g-card .tag-icon{background:#fef3c7;color:#f97316}.tag-count{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.tag-label{font-size:1.1rem;font-weight:600;color:#4b5563;margin-bottom:.5rem}.tag-percentage{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.cc-card .tag-percentage{color:#10b981}.pu-card .tag-percentage{color:#f59e0b}.mc-card .tag-percentage{color:#ef4444}.g-card .tag-percentage{color:#f97316}.tag-description{color:#6b7280;font-size:.875rem;line-height:1.4}.topic-list{display:flex;flex-direction:column;gap:1rem}.topic-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.topic-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.topic-name{font-size:1.1rem;font-weight:600;color:#1f2937}.topic-mastery{font-size:1.25rem;font-weight:700}.topic-stats{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;color:#6b7280;font-size:.875rem}.mastery-bar{width:100%;height:8px;background:#e5e7eb;border-radius:9999px;overflow:hidden;margin-bottom:1rem}.mastery-fill{height:100%;transition:width .3s ease}.topic-tags{display:flex;gap:.5rem;margin-bottom:1rem}.mini-tag{padding:.25rem .75rem;border-radius:9999px;font-size:.8rem;font-weight:600}.mini-tag.cc{background:#d1fae5;color:#059669}.mini-tag.pu{background:#fef3c7;color:#d97706}.mini-tag.mc{background:#fee2e2;color:#dc2626}.mini-tag.g{background:#fef3c7;color:#ea580c}.topic-recommendations{display:flex;gap:.75rem;padding:1rem;background:#fffbeb;border-radius:8px;font-size:.875rem;color:#92400e}.topic-recommendations svg{flex-shrink:0;color:#f59e0b;margin-top:.25rem}.topic-recommendations ul{margin:0;padding-left:1.25rem}.topic-recommendations li{margin-bottom:.25rem}.bloom-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.bloom-item{background:#fff;border-radius:8px;padding:1rem 1.5rem;box-shadow:0 2px 4px #0000001a}.bloom-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.bloom-level{font-weight:600;color:#1f2937}.bloom-accuracy{font-size:1.25rem;font-weight:700;color:#667eea}.bloom-bar{width:100%;height:6px;background:#e5e7eb;border-radius:9999px;overflow:hidden;margin-bottom:.5rem}.bloom-fill{height:100%;transition:width .3s ease}.bloom-stats{color:#6b7280;font-size:.875rem}.bloom-explanation{background:#f9fafb;border-radius:8px;padding:1.5rem;color:#374151;font-size:.9rem;line-height:1.6}.bloom-explanation strong{color:#1f2937;display:block;margin-bottom:.75rem;font-size:1rem}.bloom-explanation ul{margin:0;padding-left:1.5rem}.bloom-explanation li{margin-bottom:.5rem}.gaps-alert{display:flex;gap:1rem;padding:1rem 1.5rem;background:#fffbeb;border-left:4px solid #f59e0b;border-radius:4px;margin-bottom:1.5rem;color:#92400e;font-size:.9rem;line-height:1.6}.gaps-alert svg{flex-shrink:0;color:#f59e0b;margin-top:.25rem}.gaps-list{display:flex;flex-direction:column;gap:1rem}.gap-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.gap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.gap-type{font-weight:600;color:#1f2937}.gap-severity{font-weight:600;font-size:.9rem}.gap-description{color:#4b5563;margin-bottom:1rem;line-height:1.6}.gap-recommendation{display:flex;gap:.75rem;padding:1rem;background:#eff6ff;border-radius:8px;color:#1e40af;font-size:.9rem}.gap-recommendation svg{flex-shrink:0;color:#3b82f6;margin-top:.25rem}.feedback-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.feedback-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.feedback-card h4{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1.1rem;font-weight:600}.strengths-card h4{color:#10b981}.weaknesses-card h4{color:#ef4444}.feedback-card ul{margin:0;padding-left:1.5rem;color:#4b5563;font-size:.9rem;line-height:1.8}.overall-comment{display:flex;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;margin-bottom:2rem;font-size:1.05rem;line-height:1.6}.overall-comment svg{flex-shrink:0;margin-top:.25rem}.overall-comment p{margin:0}.focus-areas h4{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:#667eea;font-weight:600}.focus-tags{display:flex;flex-wrap:wrap;gap:.75rem}.focus-tag{padding:.5rem 1rem;background:#eff6ff;color:#1e40af;border-radius:9999px;font-weight:600;font-size:.9rem}.pdbta-footer{display:flex;gap:1rem;padding:1.5rem;background:#f9fafb;border-radius:12px;margin-top:3rem}.footer-icon{flex-shrink:0;color:#667eea}.footer-text{color:#4b5563;font-size:.9rem;line-height:1.6}.footer-text strong{color:#1f2937}@media (max-width: 768px){.pdbta-analysis-container{padding:1rem}.pdbta-header{flex-direction:column;text-align:center}.occs-main{flex-direction:column;align-items:center;text-align:center}.occs-breakdown,.tbpa-grid,.feedback-grid{grid-template-columns:1fr}.topic-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.version-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#ffffff40;border-radius:9999px;font-size:.8rem;font-weight:600;margin-top:.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lms-metrics-section{margin-bottom:2.5rem}.lms-explanation{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;background:#eff6ff;border-left:4px solid #3b82f6;border-radius:8px;margin-bottom:1.5rem}.lms-explanation svg{color:#3b82f6;flex-shrink:0;margin-top:2px}.lms-explanation p{margin:0;color:#1e40af;font-size:.9rem;line-height:1.5}.lms-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-bottom:1.5rem}.lms-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;transition:transform .2s,box-shadow .2s}.lms-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.lms-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.lms-card-header h4{margin:0;font-size:1.1rem;font-weight:700}.lms-badge{padding:.5rem 1rem;border-radius:9999px;color:#fff;font-weight:700;font-size:1.1rem}.lms-progress-container{margin-bottom:1.25rem}.lms-progress-bar{position:relative;height:12px;background:#e5e7eb;border-radius:9999px;overflow:visible}.lms-progress-fill{height:100%;border-radius:9999px;transition:width .8s ease}.lms-threshold-marker{position:absolute;top:-28px;transform:translate(-50%)}.threshold-label{font-size:.75rem;color:#6b7280;font-weight:600;white-space:nowrap}.lms-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1rem;background:#f9fafb;border-radius:8px;margin-bottom:.75rem}.lms-stat{display:flex;flex-direction:column;gap:.25rem}.lms-achievement{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#d1fae5;border-radius:8px;color:#065f46;font-weight:600;font-size:.9rem}.lms-achievement svg{color:#10b981}.lms-legend{display:flex;flex-wrap:wrap;gap:1.5rem;padding:1rem;background:#fff;border-radius:8px;justify-content:center}.lms-legend .legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.legend-dot{width:16px;height:16px;border-radius:50%}.tier-assignment-section{margin-bottom:2.5rem}.tier-explanation{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:8px;margin-bottom:1.5rem}.tier-explanation svg{color:#f59e0b;flex-shrink:0;margin-top:2px}.tier-explanation p{margin:0;color:#92400e;font-size:.9rem;line-height:1.5}.tier-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem}.summary-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #00000014}.summary-icon{flex-shrink:0}.summary-content{flex:1}.summary-count{font-size:1.5rem;font-weight:700;color:#1f2937;line-height:1}.summary-label{font-size:.875rem;color:#6b7280;margin-top:.25rem}.tier-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.tier-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.tier-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.tier-card-header h4{margin:0;font-size:1.1rem;font-weight:700}.tier-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:9999px;font-weight:600;font-size:.875rem}.tier-status{font-size:1.1rem;font-weight:700;margin-bottom:.75rem}.tier-description{color:#6b7280;font-size:.9rem;line-height:1.5;margin-bottom:1rem}.tier-reason{padding:.75rem;background:#f9fafb;border-radius:8px;font-size:.875rem;color:#374151;line-height:1.5}.learning-path-recommendation{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.recommendation-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;color:#1f2937}.recommendation-header h4{margin:0;font-size:1.2rem;font-weight:700}.recommendation-content{display:flex;flex-direction:column;gap:1rem}.path-step{display:flex;gap:1rem;padding:1rem;background:#f9fafb;border-radius:8px;border-left:4px solid}.tier-3-step{border-left-color:#ef4444}.tier-2-step{border-left-color:#f59e0b}.tier-1-step{border-left-color:#10b981}.step-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#3b82f6;color:#fff;border-radius:50%;font-weight:700;flex-shrink:0}.step-content{flex:1}.step-content strong{display:block;color:#1f2937;margin-bottom:.25rem}.step-content p{margin:0;color:#6b7280;font-size:.875rem;line-height:1.5}.prerequisite-analysis-section{margin-bottom:2.5rem}.prerequisite-explanation{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;background:#f0fdf4;border-left:4px solid #10b981;border-radius:8px;margin-bottom:1.5rem}.prerequisite-explanation svg{color:#10b981;flex-shrink:0;margin-top:2px}.prerequisite-explanation p{margin:0;color:#065f46;font-size:.9rem;line-height:1.5}.prerequisite-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem}.prerequisite-details{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2rem}.prerequisite-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.prerequisite-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.prerequisite-card-header h4{margin:0;font-size:1.1rem;font-weight:700}.prerequisite-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:9999px;font-weight:600;font-size:.875rem}.prerequisite-message{font-size:1rem;font-weight:600;margin-bottom:1rem}.prerequisite-gaps{padding:1rem;background:#fef3c7;border-radius:8px;margin-top:1rem}.gaps-header{display:flex;align-items:center;gap:.5rem;color:#92400e;font-weight:600;margin-bottom:.75rem}.gaps-list{margin:0;padding-left:1.5rem;color:#92400e}.gaps-list li{margin-bottom:.5rem;line-height:1.5}.prerequisite-success{padding:.75rem;background:#d1fae5;border-radius:8px;color:#065f46;font-size:.875rem;line-height:1.5}.prerequisite-recommendations{background:#fee2e2;border:2px solid #ef4444;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.prerequisite-recommendations .recommendation-header{display:flex;align-items:center;gap:.75rem;color:#991b1b;margin-bottom:1rem}.prerequisite-recommendations .recommendation-header h4{margin:0;font-size:1.1rem;font-weight:700}.prerequisite-recommendations .recommendation-content{color:#7f1d1d}.prerequisite-recommendations .recommendation-content p{margin:0 0 .75rem;line-height:1.6}.learning-sequence{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.learning-sequence h4{margin:0 0 1.25rem;font-size:1.1rem;font-weight:700;color:#1f2937}.sequence-flow{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center}.sequence-step{display:flex;flex-direction:column;align-items:center;gap:.5rem}.sequence-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;font-weight:700}.sequence-label{font-size:.75rem;color:#6b7280;font-weight:600;text-align:center;max-width:80px}.sequence-arrow{font-size:1.5rem;color:#d1d5db;font-weight:700;margin:0 .25rem}.progressive-gaps-section,.progressive-gaps-section.no-gaps{margin-bottom:2.5rem}.no-gaps-card{background:#fff;border-radius:12px;padding:3rem 2rem;text-align:center;box-shadow:0 2px 8px #00000014}.success-icon{display:flex;justify-content:center;margin-bottom:1rem}.no-gaps-card h4{margin:0 0 .75rem;font-size:1.5rem;color:#065f46;font-weight:700}.no-gaps-card p{color:#6b7280;line-height:1.6;max-width:600px;margin:0 auto}.gaps-explanation{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:8px;margin-bottom:1.5rem}.gaps-explanation svg{flex-shrink:0;margin-top:2px}.gaps-explanation p{margin:0;color:#92400e;font-size:.9rem;line-height:1.5}.gaps-alert{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;background:#fee2e2;border:2px solid #ef4444;border-radius:12px;margin-bottom:2rem}.gaps-alert svg{flex-shrink:0;margin-top:2px}.alert-content h4{margin:0 0 .5rem;color:#991b1b;font-size:1.1rem;font-weight:700}.alert-content p{margin:0;color:#7f1d1d;line-height:1.6}.gaps-list{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2rem}.gap-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.gap-card-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.gap-bloom-badge{padding:.5rem 1rem;border-radius:9999px;color:#fff;font-weight:600;font-size:.875rem}.gap-severity-badge{padding:.5rem 1rem;border-radius:9999px;font-weight:600;font-size:.875rem}.gap-type{color:#374151;margin-bottom:.75rem;font-size:.9rem}.gap-description{color:#1f2937;line-height:1.6;margin-bottom:1rem}.gap-pattern{padding:1rem;background:#f9fafb;border-radius:8px;margin-bottom:1rem}.pattern-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.pattern-label{font-weight:600;color:#6b7280}.pattern-value{font-weight:600;padding:.375rem .75rem;border-radius:4px;font-size:.875rem}.pattern-value.failed{background:#fee2e2;color:#991b1b}.pattern-value.passed{background:#d1fae5;color:#065f46}.pattern-arrow{text-align:center;font-size:1.5rem;color:#d1d5db;margin:.25rem 0}.gap-recommendation{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#fffbeb;border-radius:8px}.gap-recommendation svg{flex-shrink:0;margin-top:2px}.recommendation-text{flex:1;color:#78350f;line-height:1.5}.recommendation-text strong{display:block;margin-bottom:.25rem}.gaps-action-plan{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;margin-bottom:1.5rem}.action-plan-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;color:#1f2937}.action-plan-header h4{margin:0;font-size:1.2rem;font-weight:700}.action-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.action-step{display:flex;gap:.75rem;padding:1rem;background:#f9fafb;border-radius:8px}.gaps-importance{background:#eff6ff;border-left:4px solid #3b82f6;border-radius:8px;padding:1.25rem}.gaps-importance h4{margin:0 0 .75rem;color:#1e40af;font-size:1.1rem;font-weight:700}.gaps-importance p{margin:0;color:#1e40af;line-height:1.6}@media (max-width: 768px){.lms-metrics-grid,.tier-details-grid,.tier-summary,.prerequisite-summary,.lms-stats{grid-template-columns:1fr}.sequence-flow{flex-direction:column}.sequence-arrow{transform:rotate(90deg)}.action-steps{grid-template-columns:1fr}.gap-card-header{flex-direction:column;align-items:flex-start}}.topic-wise-analysis-table{padding:20px;background:#f9fafb;min-height:400px}.analysis-header{display:flex;align-items:center;gap:16px;padding:20px 24px;background:#fff;border-radius:12px;margin-bottom:20px;box-shadow:0 1px 3px #0000001a}.header-icon{color:#3b82f6;flex-shrink:0}.header-text h2{margin:0 0 4px;font-size:22px;color:#1f2937;font-weight:700}.header-text p{margin:0;color:#6b7280;font-size:14px}.topics-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow-x:auto;overflow-y:hidden;margin-bottom:20px}.topics-table{width:100%;min-width:1400px;border-collapse:collapse;font-size:14px}.topics-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.topics-table th{padding:16px 12px;text-align:left;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-right:1px solid rgba(255,255,255,.2);color:#fff!important}.topics-table th:last-child{border-right:none}.col-topic-no{width:60px;text-align:center!important}.col-topic-name{width:180px;min-width:160px}.col-bloom{width:262px;min-width:240px;text-align:center!important}.col-expand{width:60px;text-align:center!important}.topics-table tbody tr.topic-row{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.topics-table tbody tr.topic-row:hover{background-color:#f9fafb}.topics-table td{padding:8px 12px;vertical-align:top;border-right:1px solid #f3f4f6}.topics-table td:last-child{border-right:none}.cell-topic-no{text-align:center;font-weight:700;font-size:16px;color:#6b7280}.cell-topic-name strong{color:#1f2937;font-size:15px}.cell-bloom{text-align:center;padding:8px;vertical-align:top}.cell-bloom-mastery-perfect{background:#f0fdf4!important;vertical-align:top}.cell-bloom-mastery-good{background:#fffbeb!important;vertical-align:top}.cell-bloom-mastery-poor{background:#fef2f2!important;vertical-align:top}.cell-empty{color:#d1d5db;font-size:18px;font-weight:300}.bloom-cell-content{display:flex;flex-direction:column;align-items:stretch;gap:8px;width:100%;padding:0}.mastery-analysis-full{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:6px;border:2px solid;background:#fff}.mastery-analysis-full.mastery-perfect{background:#ecfdf5;border-color:#10b981;color:#065f46}.mastery-analysis-full.mastery-good{background:#fffbeb;border-color:#f59e0b;color:#92400e}.mastery-analysis-full.mastery-poor{background:#fef2f2;border-color:#ef4444;color:#991b1b}.mastery-icon{flex-shrink:0;margin-top:2px}.mastery-icon.perfect{color:#10b981}.mastery-icon.good{color:#f59e0b}.mastery-icon.poor{color:#ef4444}.mastery-message{flex:1;display:flex;flex-direction:column;gap:4px;text-align:left}.mastery-title{font-size:13px;font-weight:700;line-height:1.3}.mastery-description{font-size:12px;line-height:1.4;font-weight:500;opacity:.9}.learning-outcome-text{font-size:11px;margin-top:4px;color:#374151;background:#f3f4f6;padding:4px 6px;border-radius:4px}.bloom-progress-wrapper{margin-top:8px;display:flex;flex-direction:column;gap:4px}.bloom-progress-bar{position:relative;height:6px;background:#e5e7eb;border-radius:4px;overflow:hidden}.bloom-progress-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#10b981,#3b82f6,#f59e0b);transition:width .4s ease}.bloom-progress-label{font-size:10px;font-weight:600;color:#4b5563;text-align:right}.performance-chart-section .bloom-progress-list .bloom-progress-label{text-align:left}.full-questions-list{display:flex;flex-direction:column;gap:6px;width:100%}.full-question-item{padding:6px 0;border-radius:0;border:none;background:transparent;transition:none}.full-question-item:hover{box-shadow:none;transform:none}.full-question-item.question-correct,.full-question-item.question-incorrect{border:none;background:transparent}.question-merged-content{display:flex;align-items:flex-start;gap:8px}.question-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #e5e7eb}.question-label{font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.question-status-icon{flex-shrink:0;margin-top:2px}.question-status-icon.correct{color:#10b981}.question-status-icon.incorrect{color:#ef4444}.question-full-text{flex:1;font-size:13px;line-height:1.6;color:#1f2937;font-weight:400;text-align:left}.question-full-text strong{font-weight:700;color:#374151}.cell-expand{text-align:center}.expand-button{background:transparent;border:1px solid #d1d5db;border-radius:6px;padding:6px;cursor:pointer;transition:all .2s;color:#6b7280;display:inline-flex;align-items:center;justify-content:center}.expand-button:hover{background:#f3f4f6;border-color:#9ca3af;color:#374151}.expanded-row{background:#fafbfc;border-bottom:2px solid #e5e7eb}.expanded-cell{padding:0!important}.expanded-content{padding:24px;display:flex;flex-direction:column;gap:24px}.bloom-detail-section{border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#fff}.bloom-detail-header{padding:16px 20px;background:#f9fafb;border-left:5px solid #3b82f6}.bloom-detail-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:12px}.bloom-detail-title h4{margin:0;font-size:17px;font-weight:700}.bloom-detail-stats{font-size:13px;color:#6b7280;font-weight:600}.mastery-analysis-detail{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;font-size:13px}.mastery-analysis-detail.mastery-perfect{background:#d1fae5;border:1px solid #6ee7b7;color:#065f46}.mastery-analysis-detail.mastery-good{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}.mastery-analysis-detail.mastery-poor{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.mastery-analysis-detail strong{font-weight:700}.bloom-questions-list{padding:16px;display:flex;flex-direction:column;gap:12px;background:#fff}.question-item{display:flex;gap:14px;padding:14px;border:1px solid #e5e7eb;border-radius:8px;transition:all .2s;background:#fafbfc}.question-item:hover{box-shadow:0 2px 4px #0000000f;transform:translateY(-1px)}.question-item.correct{border-left:4px solid #10b981}.question-item.incorrect{border-left:4px solid #ef4444}.question-number{flex-shrink:0;height:38px;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-weight:700;font-size:13px;color:#374151}.question-details{flex:1}.question-text{color:#1f2937;font-size:14px;line-height:1.5;margin-bottom:8px;font-weight:500}.question-meta{display:flex;gap:12px;flex-wrap:wrap}.meta-tag{display:inline-flex;padding:4px 10px;background:#fff;border:1px solid #e5e7eb;border-radius:4px;font-size:12px;color:#6b7280;font-weight:500}.question-status{flex-shrink:0;display:flex;align-items:center}.status-correct,.status-incorrect{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:6px 12px;border-radius:6px}.status-correct{background:#d1fae5;color:#065f46}.status-incorrect{background:#fee2e2;color:#991b1b}.legend-section{background:#fff;padding:16px 24px;border-radius:12px;box-shadow:0 1px 3px #0000001a}.legend-section h4{margin:0 0 12px;font-size:14px;color:#374151;font-weight:700}.legend-items{display:flex;gap:24px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280}.legend-icon.perfect{color:#059669}.legend-icon.good{color:#d97706}.legend-icon.poor{color:#dc2626}@media (max-width: 1400px){.topics-table{font-size:13px}.col-bloom{width:240px;min-width:225px}.bloom-detail-title{flex-direction:column;align-items:flex-start}.mastery-description{font-size:11px}.question-full-text{font-size:12px}}@media (max-width: 768px){.topic-wise-analysis-table{padding:12px}.analysis-header{padding:16px}.header-text h2{font-size:18px}.topics-table-container{overflow-x:auto}.topics-table{min-width:2000px}.question-item{flex-direction:column;align-items:flex-start}.question-status{align-self:flex-start}.mastery-description{font-size:11px}.question-full-text{font-size:12px}}.empty-tab-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;background:#fff;border-radius:12px;margin:20px}.empty-icon{font-size:64px;margin-bottom:16px;opacity:.5}.empty-tab-state h3{font-size:20px;color:#1f2937;margin-bottom:8px}.empty-tab-state p{color:#6b7280;font-size:14px}.test-result-container{margin:0 auto;padding:2rem 10rem;background-color:#f7eeff;min-height:100vh}.test-result-container.loading,.test-result-container.error{display:flex;align-items:center;justify-content:center;min-height:60vh}.loading-spinner{text-align:center}.spinner{width:60px;height:60px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.error-message{text-align:center;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.error-icon{font-size:4rem;margin-bottom:1rem}.error-message h2{color:#ef4444;margin-bottom:1rem}.modern-result-header{background:#fff;border-radius:14px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 20px #00000014;border:1px solid #f3f4f6}.header-back-row{margin-bottom:1.5rem}.back-button{width:40px;height:40px;border-radius:12px;border:1px solid #e5e7eb;background:#f9fafb;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0}.back-button:hover{background:#f3f4f6;border-color:#d1d5db;transform:translate(-2px)}.back-button:active{transform:translate(-4px)}.back-icon{width:20px;height:20px;stroke-width:2.5;color:#6b7280}.header-title-section{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:1.5rem}.modern-result-title{font-size:2rem;font-weight:700;color:#111827;margin-bottom:.75rem;line-height:1.2;letter-spacing:-.02em}.submission-date-inline{display:inline-flex;align-items:center;gap:.5rem;background:#6366f10f;padding:.375rem .875rem;border-radius:10px;color:#374151;font-weight:600;font-size:.875rem}.date-icon{width:16px;height:16px;stroke-width:2;color:#6366f1}.submission-text{text-transform:uppercase;color:#6b7280;font-size:.68rem;font-weight:700;letter-spacing:.05em}.submission-date{color:#111827;font-weight:700}.header-meta-row{margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem}.header-subtitle{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.subtitle-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280}.subtitle-item{font-size:.875rem;font-weight:600;color:#374151}.subtitle-icon{width:16px;height:16px;stroke-width:2;color:#6b7280}.subtitle-separator{color:#d1d5db;font-weight:300}.header-right{flex-shrink:0}.submission-date-badge{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:1px solid #e5e7eb;border-radius:12px;transition:all .2s}.submission-date-badge:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000d}.date-icon{width:20px;height:20px;stroke-width:2;color:#667eea;flex-shrink:0}.date-content{display:flex;flex-direction:column;gap:.125rem}.date-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af}.date-value{font-size:.875rem;font-weight:600;color:#374151;white-space:nowrap}.header-topics-row{padding-top:1.5rem;border-top:1px solid #f3f4f6;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.topics-label{display:flex;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;flex-shrink:0}.topics-icon{width:16px;height:16px;stroke-width:2;color:#9ca3af}.topics-list{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap;flex:1}.topic-badge{display:inline-flex;align-items:center;gap:.625rem;padding:.5rem .875rem;background:linear-gradient(135deg,#667eea08,#764ba208);border:1px solid #667eea20;border-radius:10px;transition:all .2s cubic-bezier(.4,0,.2,1);width:auto}.topic-badge:hover{background:linear-gradient(135deg,#667eea15,#764ba215);border-color:#667eea40;transform:translateY(-1px);box-shadow:0 2px 8px #667eea26}.topic-number{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#667eea;background:#667eea15;padding:.25rem .5rem;border-radius:6px}.topic-name{font-size:.875rem;font-weight:600;color:#374151}.topic-count{font-size:.75rem;font-weight:700;color:#667eea;background:#667eea15;padding:.125rem .5rem;border-radius:6px}@media (max-width: 768px){.modern-result-header{padding:1.5rem}.header-main-row{flex-direction:column;gap:1rem}.header-left{width:100%}.modern-result-title{font-size:1.5rem}.header-right{width:100%}.submission-date-badge{width:100%;justify-content:flex-start}.subtitle-label{font-size:.6875rem}.subtitle-item{font-size:.8125rem;font-weight:600}.subtitle-icon{width:14px;height:14px}.header-meta-row{gap:.625rem}.header-subtitle{gap:.5rem}.header-topics-row{flex-direction:column;align-items:flex-start;gap:.75rem;padding-top:1.25rem}.topics-label{font-size:.6875rem;color:#6b7280}.topics-icon{width:14px;height:14px}.topics-list{width:100%;flex-direction:column;gap:.625rem}.topic-badge{width:100%;justify-content:space-between;padding:.875rem 1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1.5px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 6px #0000000d}.topic-badge:hover{background:linear-gradient(135deg,#667eea10,#764ba210);border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.topic-number{font-size:.6875rem;padding:.375rem .625rem;border-radius:8px;font-weight:700}.topic-name{flex:1;font-size:.8125rem;font-weight:600;color:#374151}.topic-count{font-size:.6875rem;padding:.375rem .625rem;border-radius:8px;font-weight:700}}.result-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.header-content{flex:1}.result-title{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:.75rem}.test-metadata{display:flex;gap:1.5rem;flex-wrap:wrap}.metadata-item{color:#6b7280;font-size:.875rem}.metadata-item strong{color:#374151;margin-right:.25rem}.result-tabs{display:flex;gap:.5rem;margin-bottom:2rem;background:#fff;padding:.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.tab-button{flex:1;padding:.875rem 1.5rem;background:transparent;border:none;border-radius:8px;font-size:1rem;font-weight:600;color:#6b7280;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.tab-button:hover{background:#f3f4f6;color:#374151}.tab-button.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 8px #3b82f64d}.tab-button.pdbta-tab{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700}.tab-button.pdbta-tab:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);color:#fff}.tab-button.pdbta-tab.active{background:linear-gradient(135deg,#4c5fd9,#5d367a);transform:scale(1.02);box-shadow:0 4px 12px #667eea66}.tab-content{min-height:400px}.overview-tab,.topicwise-tab,.questionwise-tab,.pdbta-tab{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.empty-tab-state{background:#fff;border-radius:12px;padding:4rem 2rem;text-align:center;box-shadow:0 2px 8px #0000001a}.empty-tab-state .empty-icon{font-size:4rem;margin-bottom:1rem}.empty-tab-state h3{font-size:1.5rem;font-weight:600;color:#374151;margin-bottom:.5rem}.empty-tab-state p{color:#6b7280;font-size:1rem}.score-summary-card{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.modern-score-summary{display:flex;flex-direction:column;gap:1.5rem}.hero-score-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;padding:3rem 2rem;box-shadow:0 10px 40px #667eea4d;position:relative;overflow:hidden}.score-hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.modern-status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:100px;font-weight:600;font-size:.875rem;color:#fff;text-transform:uppercase;letter-spacing:.05em}.badge-icon{width:1.25rem;height:1.25rem}.hero-score-display{display:flex;flex-direction:column;align-items:center;gap:.5rem}.score-main{display:flex;align-items:baseline;gap:.5rem;color:#fff}.score-obtained{font-size:4.5rem;font-weight:800;line-height:1;letter-spacing:-.02em}.score-divider{font-size:3rem;font-weight:300;opacity:.7}.score-total{font-size:3rem;font-weight:600;opacity:.9}.score-percentage{font-size:1.5rem;font-weight:600;color:#ffffffe6}.passing-threshold{width:100%;max-width:400px}.threshold-bar{position:relative;height:8px;background:#fff3;border-radius:100px;overflow:visible}.threshold-fill{position:absolute;top:0;left:0;height:100%;background:#fff;border-radius:100px;transition:width .8s cubic-bezier(.4,0,.2,1);box-shadow:0 0 20px #ffffff80}.threshold-marker{position:absolute;top:-8px;transform:translate(-50%);z-index:2}.threshold-marker:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:3px;height:24px;background:#ffffff80;border-radius:100px}.marker-label{position:absolute;top:-24px;left:50%;transform:translate(-50%);white-space:nowrap;font-size:.75rem;font-weight:600;color:#ffffffe6;background:#0003;padding:.25rem .625rem;border-radius:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modern-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.modern-stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.modern-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.4,0,.2,1)}.modern-stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a;border-color:#667eea}.modern-stat-card:hover:before{transform:scaleX(1)}.modern-stat-card.success:before{background:linear-gradient(90deg,#10b981,#059669)}.modern-stat-card.error:before{background:linear-gradient(90deg,#ef4444,#dc2626)}.stat-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.stat-icon-wrapper{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:all .3s}.stat-icon-wrapper.questions{background:linear-gradient(135deg,#667eea15,#764ba215);color:#667eea}.stat-icon-wrapper.correct{background:linear-gradient(135deg,#10b98115,#05966915);color:#10b981}.stat-icon-wrapper.incorrect{background:linear-gradient(135deg,#ef444415,#dc262615);color:#ef4444}.stat-icon-wrapper.time{background:linear-gradient(135deg,#f59e0b15,#d9770615);color:#f59e0b}.modern-stat-card:hover .stat-icon-wrapper{transform:scale(1.1) rotate(5deg)}.stat-icon-svg{width:24px;height:24px;stroke-width:2.5}.stat-card-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280}.stat-card-value{font-size:1.75rem;font-weight:700;color:#1f2937;line-height:1;margin-bottom:.5rem}.stat-card-footer{font-size:.875rem;color:#9ca3af;font-weight:500}.submission-info-card{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;color:#6b7280;font-size:.875rem;font-weight:500}.info-icon{width:20px;height:20px;stroke-width:2;color:#9ca3af}.info-text{color:#374151}@media (max-width: 768px){.modern-stats-grid{grid-template-columns:1fr}.score-obtained{font-size:3.5rem}.score-divider,.score-total{font-size:2.5rem}.hero-score-card{padding:2rem 1.5rem}}.score-display{text-align:center;padding:2rem;border-radius:12px;margin-bottom:2rem}.score-display.passed{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.score-display.failed{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff3;border-radius:50px;font-weight:600;font-size:.875rem;margin-bottom:1rem}.status-icon{font-size:1.25rem}.score-value{margin:1.5rem 0}.marks{font-size:3rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:.5rem}.percentage{font-size:2rem;font-weight:600;margin-top:.5rem;opacity:.9}.passing-info{font-size:.875rem;opacity:.85}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.stat-card.correct{background:#f0fdf4;border-color:#86efac}.stat-card.incorrect{background:#fef2f2;border-color:#fca5a5}.stat-icon{font-size:2rem}.stat-content{flex:1}.stat-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:#1f2937}.stat-value-small{font-size:.875rem;font-weight:600;color:#1f2937}.stat-subtitle{font-size:.75rem;color:#9ca3af;margin-top:.25rem}.performance-chart-section{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.section-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:1.5rem}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;margin-bottom:2rem}.chart-card{background:#f9fafb;border-radius:8px;padding:1.5rem;border:1px solid #e5e7eb}.chart-title{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:#374151;margin-bottom:1rem}.chart-icon{font-size:1.5rem}.progress-bars{display:flex;flex-direction:column;gap:1rem}.progress-bar-item{display:flex;flex-direction:column;gap:.5rem}.progress-label{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.label-text{font-weight:600;color:#374151}.label-stats{color:#6b7280}.progress-bar-track{height:24px;background:#e5e7eb;border-radius:12px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:12px;transition:width .5s ease-in-out;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;color:#fff;font-weight:600;font-size:.75rem}.no-data{text-align:center;color:#9ca3af;font-style:italic;padding:1rem}.distribution-summary{margin-top:1.5rem}.summary-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem}.summary-card h4{font-size:1rem;font-weight:600;color:#374151;margin-bottom:1rem}.distribution-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.distribution-item{display:flex;justify-content:space-between;padding:.75rem;background:#fff;border-radius:6px}.dist-label{font-weight:600;color:#6b7280}.dist-value{color:#1f2937}.question-review-section{background:linear-gradient(135deg,#fff,#f8f9ff);border-radius:16px;padding:28px;margin-bottom:28px;box-shadow:0 4px 16px #3b82f614;border:1px solid rgba(99,102,241,.12)}.question-list{display:flex;flex-direction:column;gap:14px}.question-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000d}.question-card.correct{border-color:#d1fae5;background:linear-gradient(135deg,#f0fdf4,#fbfef9)}.question-card.correct:hover{border-color:#a7f3d0;box-shadow:0 8px 16px #10b98114;transform:translateY(-1px)}.question-card.incorrect{border-color:#fee2e2;background:linear-gradient(135deg,#fef2f2,#fffbfb)}.question-card.incorrect:hover{border-color:#fecaca;box-shadow:0 8px 16px #ef444414;transform:translateY(-1px)}.question-header{display:flex;align-items:center;gap:14px;padding:16px 18px;cursor:pointer;background:transparent;transition:all .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.question-header:hover{background:#6366f10a}.question-number-badge{display:flex;align-items:center;justify-content:center;gap:8px;min-width:-moz-fit-content;min-width:fit-content}.result-icon{font-size:12px;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;order:-1}.result-icon.correct{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b98140}.result-icon.incorrect{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef444440}.question-number-badge .number{font-size:16px;font-weight:800;color:#111827;line-height:1}.question-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.question-meta{display:flex;gap:7px;flex-wrap:wrap;align-items:center}.meta-badge{font-size:10px;padding:4px 10px;border-radius:6px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.meta-badge.difficulty{background:#e0f2fe;color:#0369a1}.meta-badge.taxonomy{background:#ece9ff;color:#6330a7}.meta-badge.marks{background:#fdedff;color:#6d28d9;font-size:8px;padding:3px 7px}.question-preview{color:#6b7280;font-size:14px;line-height:1.5;font-weight:500;text-align:left}.expand-icon{font-size:12px;color:#9ca3af;flex-shrink:0;transition:transform .3s ease;font-weight:700}.question-card:hover .expand-icon{transform:scale(1.2)}.question-details{padding:20px;border-top:1px solid #e5e7eb;background:#fff;display:flex;flex-direction:column;gap:16px}.question-full-text h4{font-size:13px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.4px;margin:0 0 8px}.question-full-text p{color:#1f2937;line-height:1.7;font-size:15px;font-weight:500}.options-section{display:flex;flex-direction:column;gap:10px}.options-section h4{font-size:13px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.4px;margin:0}.options-list{display:flex;flex-direction:column;gap:10px;text-align:left}.option-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border:1.5px solid #e5e7eb;border-radius:10px;background:#f9fafb;transition:all .3s cubic-bezier(.4,0,.2,1)}.option-item.correct-option{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-color:#10b9814d}.option-item.wrong-option{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#ef44444d}.option-item.user-correct-option{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#10b981;border-width:2px;box-shadow:0 4px 12px #10b98126}.option-marker{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.correct-marker{color:#10b981;font-weight:700}.wrong-marker{color:#ef4444;font-weight:700}.option-text{flex:1;color:#1f2937;line-height:1.6;font-size:14px;font-weight:500}.option-labels{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;flex-shrink:0}.label-badge{font-size:8px;padding:2px 6px;border-radius:5px;font-weight:700;text-transform:uppercase;letter-spacing:.2px;white-space:nowrap}.label-badge.user{background:#dbeafe;color:#0c4a6e}.label-badge.correct{background:#d1fae5;color:#065f46}@media (max-width: 768px){.question-review-section{padding:16px;margin-bottom:20px;border-radius:12px}.question-list{gap:10px}.question-header{gap:10px;padding:12px;flex-wrap:wrap}.question-number-badge{gap:6px;order:1}.question-number-badge .number{font-size:13px}.result-icon{width:28px;height:28px;font-size:10px}.question-info{order:2;width:100%;gap:6px}.question-meta{gap:4px;margin-bottom:2px}.meta-badge{font-size:8px;padding:2px 6px}.question-preview{font-size:12px}.expand-icon{font-size:10px;order:3;align-self:center}.question-details{padding:14px;gap:12px}.question-full-text h4,.options-section h4{font-size:12px;margin-bottom:6px;text-align:left}.question-full-text p{font-size:13px}.option-item{gap:10px;padding:10px}.option-text{font-size:13px}}@media (max-width: 480px){.question-review-section{padding:12px;margin-bottom:16px;border-radius:10px}.question-list{gap:8px}.question-header{gap:10px;padding:10px;flex-wrap:wrap}.question-number-badge{gap:6px;order:1}.question-number-badge .number{font-size:13px}.result-icon{width:28px;height:28px;font-size:10px}.question-info{order:2;width:100%;gap:6px}.question-meta{gap:4px;margin-bottom:2px}.meta-badge{font-size:8px;padding:2px 5px}.expand-icon{font-size:10px;order:3;align-self:center}.question-preview{font-size:12px}.expand-icon{font-size:10px}.question-details{padding:12px;gap:10px}.options-list{gap:8px}.option-item{gap:8px;padding:8px}.option-marker{width:24px;height:24px;font-size:12px}.option-text{font-size:12px}.option-labels{gap:4px}.label-badge{font-size:7px;padding:2px 4px}}.result-footer{display:flex;justify-content:center;gap:1rem;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.btn-primary,.btn-secondary,.btn-outline{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover{background:#4b5563}.btn-outline{background:#fff;color:#374151;border:2px solid #d1d5db}.btn-outline:hover{background:#f9fafb;border-color:#9ca3af}@media (max-width: 768px){.test-result-container{padding:.75rem}.result-header{flex-direction:column;gap:1rem}.result-title{font-size:1.5rem}.test-metadata{flex-direction:column;gap:.5rem}.result-tabs{flex-direction:column;gap:.5rem;padding:.75rem;background:linear-gradient(to bottom,#fafafa,#fff);border-radius:16px;box-shadow:0 2px 12px #00000014;margin-bottom:1.5rem}.tab-button{padding:.875rem 1rem;font-size:.875rem;border-radius:10px;font-weight:600;text-align:center;position:relative}.tab-button:not(.active){background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#64748b;border:1px solid #e2e8f0}.tab-button:not(.active):hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#475569;border-color:#cbd5e1;transform:translateY(-1px)}.tab-button.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f659;border:1px solid transparent;transform:translateY(-1px)}.tab-button.pdbta-tab:not(.active){background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#7c3aed;border:1px solid #e9d5ff}.tab-button.pdbta-tab:not(.active):hover{background:linear-gradient(135deg,#ddd6fe,#c4b5fd);color:#6d28d9;border-color:#d8b4fe}.stats-grid,.chart-grid{grid-template-columns:1fr}.marks{font-size:2rem}.percentage{font-size:1.5rem}.result-footer{flex-direction:column}.question-header{flex-wrap:wrap}.question-number-badge{min-width:50px}}@media print{.result-header button,.result-tabs,.result-footer,.expand-icon{display:none!important}.tab-content,.overview-tab,.questionwise-tab{display:block!important}.question-card{page-break-inside:avoid}.question-details{display:block!important}}.overview-top-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1rem;margin-bottom:1.5rem}.hero-score-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;padding:2rem;box-shadow:0 10px 40px #667eea4d;position:relative;overflow:hidden}.hero-score-card.passed{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 10px 40px #10b9814d}.hero-score-card.failed{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 10px 40px #ef44444d}.hero-score-card:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.score-hero-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1rem}.modern-status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:100px;font-weight:600;font-size:.75rem;color:#fff;text-transform:uppercase;letter-spacing:.05em}.badge-icon{width:1.125rem;height:1.125rem}.hero-score-display{display:flex;flex-direction:column;align-items:center;gap:.25rem}.score-main{display:flex;align-items:baseline;gap:.375rem;color:#fff}.score-obtained{font-size:3rem;font-weight:800;line-height:1;letter-spacing:-.02em}.score-divider{font-size:2rem;font-weight:300;opacity:.7}.score-total{font-size:2rem;font-weight:600;opacity:.9}.score-percentage{font-size:1.25rem;font-weight:600;color:#ffffffe6}.passing-threshold{width:100%;margin-top:.5rem}.threshold-bar{position:relative;height:6px;background:#fff3;border-radius:100px;overflow:visible}.threshold-fill{position:absolute;top:0;left:0;height:100%;background:#fff;border-radius:100px;transition:width .8s cubic-bezier(.4,0,.2,1);box-shadow:0 0 12px #ffffff80}.threshold-marker{position:absolute;top:-6px;transform:translate(-50%);z-index:2}.threshold-marker:before{content:"";position:absolute;top:6px;left:50%;transform:translate(-50%);width:2px;height:18px;background:#fff9;border-radius:100px}.marker-label{position:absolute;top:-20px;left:50%;transform:translate(-50%);white-space:nowrap;font-size:.625rem;font-weight:600;color:#fffffff2;background:#0003;padding:.25rem .5rem;border-radius:4px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.overview-mini-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.overview-mini-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.4,0,.2,1)}.overview-mini-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a;border-color:#667eea}.overview-mini-card:hover:before{transform:scaleX(1)}.overview-mini-card.occs:before{background:linear-gradient(90deg,#f59e0b,#d97706)}.overview-mini-card.percentage:before{background:linear-gradient(90deg,#3b82f6,#2563eb)}.overview-mini-card.rank:before{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.mini-card-header{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.mini-card-icon{width:18px;height:18px;stroke-width:2.5}.mini-card-title{flex:1}.mini-card-value{font-size:2.5rem;font-weight:800;line-height:1;margin:.25rem 0}.mini-card-badge{padding:.375rem .875rem;border-radius:6px;color:#fff;font-size:.75rem;font-weight:600;text-align:center}.mini-card-badge.excellent{background:linear-gradient(135deg,#10b981,#059669)}.mini-card-badge.good{background:linear-gradient(135deg,#3b82f6,#2563eb)}.mini-card-badge.moderate{background:linear-gradient(135deg,#f59e0b,#d97706)}.mini-card-badge.poor{background:linear-gradient(135deg,#ef4444,#dc2626)}.mini-card-badge.blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.mini-card-badge.coming-soon{background:linear-gradient(135deg,#6b7280,#4b5563)}.mini-card-footer{font-size:.75rem;color:#9ca3af;font-weight:500}.modern-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.hero-compact-badge .badge-icon{width:1rem;height:1rem}.hero-compact-score{display:flex;align-items:baseline;gap:.5rem;color:#fff;z-index:1}.hero-compact-score .score-obtained{font-size:2.5rem;font-weight:800;line-height:1}.hero-compact-score .score-divider{font-size:1.75rem;font-weight:300;opacity:.7}.hero-compact-score .score-total{font-size:1.75rem;font-weight:600;opacity:.9}.hero-compact-percentage{font-size:1.125rem;font-weight:600;color:#ffffffe6;z-index:1}.hero-compact-threshold{width:100%;z-index:1}.threshold-bar-compact{position:relative;height:6px;background:#fff3;border-radius:100px;overflow:visible}.threshold-fill-compact{position:absolute;top:0;left:0;height:100%;background:#fff;border-radius:100px;transition:width .8s cubic-bezier(.4,0,.2,1);box-shadow:0 0 15px #ffffff80}.threshold-marker-compact{position:absolute;top:-6px;transform:translate(-50%);z-index:2}.threshold-marker-compact:before{content:"";position:absolute;top:6px;left:50%;transform:translate(-50%);width:2px;height:18px;background:#ffffff80;border-radius:100px}.marker-label-compact{position:absolute;top:-20px;left:50%;transform:translate(-50%);white-space:nowrap;font-size:.65rem;font-weight:600;color:#ffffffe6;background:#0003;padding:.2rem .5rem;border-radius:4px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.occs-mini-card,.percentage-mini-card,.rank-mini-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px #00000014;border:1px solid #e5e7eb;display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:240px;justify-content:space-between}.occs-mini-card:hover,.percentage-mini-card:hover,.rank-mini-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001f}.mini-card-header{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.mini-card-icon{width:20px;height:20px;stroke-width:2.5}.mini-card-value{font-size:3rem;font-weight:800;line-height:1;color:#1f2937;margin:.5rem 0}.mini-card-label{display:inline-block;padding:.5rem 1rem;border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;text-align:center;min-width:120px}.mini-card-footer{font-size:.875rem;color:#9ca3af;font-weight:500}.tbpa-section{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #00000014}.section-header-minimal{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.section-icon{width:24px;height:24px;stroke-width:2;color:#667eea}.section-header-minimal h3{font-size:1.25rem;font-weight:700;color:#1f2937;margin:0}.tbpa-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.tbpa-card{background:#f9fafb;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center;transition:all .3s;border:2px solid transparent}.tbpa-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001a}.tbpa-card.cc-card{border-color:#10b98130;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.tbpa-card.cc-card:hover{border-color:#10b981}.tbpa-card.pu-card{border-color:#3b82f630;background:linear-gradient(135deg,#eff6ff,#dbeafe)}.tbpa-card.pu-card:hover{border-color:#3b82f6}.tbpa-card.mc-card{border-color:#f59e0b30;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.tbpa-card.mc-card:hover{border-color:#f59e0b}.tbpa-card.g-card{border-color:#ef444430;background:linear-gradient(135deg,#fef2f2,#fee2e2)}.tbpa-card.g-card:hover{border-color:#ef4444}.tbpa-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px}.cc-card .tbpa-icon{background:#10b98120;color:#10b981}.pu-card .tbpa-icon{background:#3b82f620;color:#3b82f6}.mc-card .tbpa-icon{background:#f59e0b20;color:#f59e0b}.g-card .tbpa-icon{background:#ef444420;color:#ef4444}.tbpa-icon svg{width:28px;height:28px;stroke-width:2}.tbpa-count{font-size:2rem;font-weight:800;color:#1f2937}.tbpa-label{font-size:.875rem;font-weight:600;color:#374151}.tbpa-percentage{font-size:1rem;font-weight:700;color:#6b7280}.topic-mastery-section{background:#fff;border-radius:16px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #00000014}.topic-mastery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.topic-mastery-card{background:#f9fafb;border-radius:12px;padding:1.25rem;border:1px solid #e5e7eb;transition:all .3s}.topic-mastery-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26}.topic-mastery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.topic-mastery-header h4{font-size:1rem;font-weight:600;color:#1f2937;margin:0;flex:1}.mastery-percent{font-size:1.25rem;font-weight:800}.mastery-bar-container{height:6px;background:#e5e7eb;border-radius:100px;overflow:hidden;margin-bottom:.75rem}.mastery-bar-fill{height:100%;border-radius:100px;transition:width .8s cubic-bezier(.4,0,.2,1)}.topic-bloom-tags{display:flex;gap:.5rem;flex-wrap:wrap}.bloom-tag{padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.bloom-tag.tier-1{background:#d1fae5;color:#065f46}.bloom-tag.tier-2{background:#fed7aa;color:#92400e}.bloom-tag.tier-3{background:#fecaca;color:#991b1b}.feedback-section-minimal{background:linear-gradient(135deg,#fff,#f8f9ff);border-radius:16px;padding:28px;margin-bottom:24px;box-shadow:0 4px 16px #3b82f614;border:1px solid rgba(99,102,241,.12)}.section-header-minimal{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid rgba(99,102,241,.12)}.section-icon{width:28px;height:28px;stroke-width:1.5;color:#4f46e5;min-width:28px;flex-shrink:0}.section-header-minimal h3{font-size:20px;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.3px}.overall-insight{display:flex;gap:16px;padding:20px;background:linear-gradient(135deg,#e0e7ff,#f3e8ff);border-radius:14px;border-left:5px solid #4f46e5;margin-bottom:24px;align-items:flex-start}.insight-icon{width:24px;height:24px;min-width:24px;stroke-width:2;color:#4f46e5;flex-shrink:0;margin-top:2px}.overall-insight p{font-size:15px;line-height:1.7;color:#1f2937;margin:0;font-weight:500;text-align:left}.feedback-grid-minimal{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.feedback-box{background:#fff;border-radius:14px;padding:20px;border:1.5px solid #e5e7eb;box-shadow:0 2px 8px #0000000a;transition:all .3s cubic-bezier(.4,0,.2,1)}.feedback-box:hover{box-shadow:0 8px 16px #00000014;border-color:#6366f133;transform:translateY(-2px)}.feedback-box.strengths{border-left:5px solid #10b981;background:linear-gradient(135deg,#f0fdf4,#ecfdf5)}.feedback-box.strengths:hover{border-color:#10b9814d}.feedback-box.weaknesses{border-left:5px solid #f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.feedback-box.weaknesses:hover{border-color:#f59e0b4d}.feedback-box-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;font-weight:700;color:#1f2937;font-size:15px}.feedback-box-header svg{width:20px;height:20px;stroke-width:2;flex-shrink:0}.feedback-box.strengths .feedback-box-header{color:#059669}.feedback-box.weaknesses .feedback-box-header{color:#d97706}.feedback-box ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.feedback-box ul li{padding-left:20px;position:relative;font-size:14px;line-height:1.6;color:#374151;font-weight:500;text-align:left}.feedback-box ul li:before{content:"•";position:absolute;left:6px;font-weight:800;font-size:16px}.feedback-box.strengths ul li:before{color:#10b981}.feedback-box.weaknesses ul li:before{color:#f59e0b}.focus-areas-minimal{background:linear-gradient(135deg,#fff,#f9fafb);border-radius:14px;padding:20px;border:1.5px solid #e5e7eb;box-shadow:0 2px 8px #0000000a}.focus-label{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:700;color:#1f2937;margin-bottom:12px;text-transform:uppercase;letter-spacing:.3px}.focus-label svg{width:18px;height:18px;stroke-width:2;color:#f59e0b;flex-shrink:0}.focus-tags-minimal{display:flex;flex-wrap:wrap;gap:8px}.focus-tag-minimal{padding:6px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:13px;font-weight:600;color:#6b7280;transition:all .3s cubic-bezier(.4,0,.2,1)}.focus-tag-minimal:hover{border-color:#f59e0b;background:#fffbeb;color:#d97706;transform:translateY(-1px);box-shadow:0 2px 8px #f59e0b1f}@media (max-width: 768px){.feedback-section-minimal{padding:20px;margin-bottom:20px;border-radius:14px}.section-header-minimal{gap:10px;margin-bottom:16px;padding-bottom:12px}.section-icon{width:24px;height:24px}.section-header-minimal h3{font-size:18px}.overall-insight{padding:16px;gap:12px;margin-bottom:16px}.overall-insight p{font-size:14px;line-height:1.6}.feedback-grid-minimal{grid-template-columns:1fr;gap:14px;margin-bottom:16px}.feedback-box{padding:16px;border-radius:12px}.feedback-box-header{font-size:14px;margin-bottom:12px}.feedback-box ul{gap:8px}.feedback-box ul li{font-size:13px;padding-left:18px}.focus-areas-minimal{padding:16px;border-radius:12px}.focus-label{font-size:12px;margin-bottom:10px}.focus-tags-minimal{gap:6px}.focus-tag-minimal{padding:5px 10px;font-size:12px}}@media (max-width: 480px){.feedback-section-minimal{padding:16px;margin-bottom:16px;border-radius:12px}.section-header-minimal{gap:8px;margin-bottom:14px}.section-icon{width:22px;height:22px}.section-header-minimal h3{font-size:16px}.overall-insight{padding:14px;gap:10px;margin-bottom:14px;border-left:4px solid #4f46e5}.overall-insight p{font-size:13px}.feedback-grid-minimal{gap:12px}.feedback-box{padding:14px}.feedback-box-header{font-size:13px}.feedback-box ul li{font-size:12px;padding-left:16px}.focus-areas-minimal{padding:14px}.focus-label{font-size:11px}.focus-tag-minimal{font-size:11px;padding:4px 8px}}.pdbta-footer-minimal{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-radius:12px;border:1px solid #e5e7eb;margin-top:2rem}.footer-icon-minimal{width:20px;height:20px;min-width:20px;stroke-width:2;color:#667eea}.pdbta-footer-minimal p{font-size:.875rem;line-height:1.6;color:#6b7280;margin:0}.pdbta-footer-minimal strong{color:#374151}@media (max-width: 1024px){.overview-two-column{grid-template-columns:1fr;gap:1.5rem}.mini-cards-column{flex-direction:row;flex-wrap:wrap;gap:1rem}.hero-score-card-compact,.occs-mini-card,.percentage-mini-card,.rank-mini-card{flex:1;min-width:200px}.tbpa-grid{grid-template-columns:repeat(2,1fr)}.feedback-grid-minimal{grid-template-columns:1fr}}@media (max-width: 768px){.overview-top-row{grid-template-columns:1fr}.modern-stats-grid{grid-template-columns:1fr 1fr}.hero-score-card{padding:1.5rem}.score-obtained{font-size:2.5rem}.score-divider,.score-total{font-size:1.75rem}.mini-card-value{font-size:2rem}.tbpa-grid,.topic-mastery-grid{grid-template-columns:1fr}}.permission-gate-loading{display:flex;align-items:center;justify-content:center;padding:1rem}.permission-gate-loading .spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:permission-gate-spin .6s linear infinite}@keyframes permission-gate-spin{to{transform:rotate(360deg)}}.protected-route-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#f9fafb}.protected-route-loading .spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:pr-spin .8s linear infinite;margin-bottom:1rem}.protected-route-loading p{color:#6b7280;font-size:1rem}@keyframes pr-spin{to{transform:rotate(360deg)}}.access-denied-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.access-denied-content{background:#fff;border-radius:12px;padding:3rem 2rem;max-width:500px;text-align:center;box-shadow:0 20px 60px #0000004d}.access-denied-icon{font-size:4rem;margin-bottom:1rem}.access-denied-content h1{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.access-denied-content p{color:#6b7280;margin-bottom:1rem;line-height:1.6}.permission-code{font-family:Courier New,monospace;background:#f3f4f6;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;color:#dc2626;margin:1rem 0}.help-text{font-size:.875rem;color:#9ca3af}.btn-back{margin-top:1.5rem;padding:.75rem 2rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-back:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.program-selector{position:relative;padding:1rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-width:400px}.program-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:#6b7280;margin-bottom:.75rem}.label-icon{font-size:1.25rem}.program-dropdown{padding:.5rem 1rem;width:auto;font-size:.85rem;border:1px solid #e5e7eb;border-radius:48px;background:#fff;cursor:pointer;transition:all .2s;font-weight:500;color:#1f2937;text-align:left}.program-dropdown:hover:not(:disabled){border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.program-dropdown:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.program-dropdown:disabled{opacity:.6;cursor:not-allowed;background:#f9fafb}.program-selector-static{display:flex;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 12px #667eea4d;max-width:400px}.program-icon{font-size:2.5rem;background:#fff;width:60px;height:60px;display:flex;align-items:center;justify-content:center;border-radius:10px}.program-info{flex:1;color:#fff}.program-name{font-weight:700;font-size:1.125rem;margin-bottom:.25rem}.program-code{font-size:.875rem;opacity:.9;font-family:Courier New,monospace}.program-switching{display:flex;align-items:center;gap:.75rem;margin-top:.75rem;padding:.75rem;background:#dbeafe;border-radius:8px;color:#1e40af;font-size:.875rem;font-weight:500}.program-switching .spinner{width:16px;height:16px;border:2px solid #3b82f6;border-top-color:transparent;border-radius:50%;animation:ps-spin .6s linear infinite}@keyframes ps-spin{to{transform:rotate(360deg)}}.program-error{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.75rem;background:#fee2e2;border-radius:8px;color:#991b1b;font-size:.875rem;font-weight:500}.error-icon{font-size:1.125rem}.dynamic-navigation{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#fff;border-right:1px solid #e5e7eb;height:100%;overflow-y:auto;min-width:250px}.dynamic-navigation::-webkit-scrollbar{width:6px}.dynamic-navigation::-webkit-scrollbar-track{background:#f9fafb}.dynamic-navigation::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.dynamic-navigation::-webkit-scrollbar-thumb:hover{background:#9ca3af}.nav-loading{padding:1rem}.nav-skeleton{height:48px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:nav-loading 1.5s ease-in-out infinite;border-radius:8px;margin-bottom:.5rem}@keyframes nav-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.nav-empty{padding:2rem 1rem;text-align:center;color:#9ca3af;font-size:.875rem}.nav-module{border-radius:8px;overflow:hidden;transition:all .2s;margin-bottom:.25rem}.nav-module-header{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;cursor:pointer;transition:all .2s;border-radius:8px;border-left:4px solid transparent}.nav-module-header:hover{background:#f3f4f6}.nav-module-header.expanded{background:#3b82f60d}.nav-module-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-module-icon img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.nav-module-icon span{font-size:1.5rem}.nav-module-content{flex:1;display:flex;flex-direction:column;gap:.125rem}.nav-module-name{font-weight:600;color:#1f2937;font-size:.95rem;line-height:1.2}.nav-module-desc{font-size:.75rem;color:#9ca3af;line-height:1.2}.nav-module-arrow{font-size:.75rem;color:#6b7280;transition:transform .2s;flex-shrink:0}.nav-module-arrow.expanded{transform:rotate(180deg)}.nav-submodules{display:flex;flex-direction:column;padding-left:2.75rem;padding-right:.5rem;margin-top:.25rem;margin-bottom:.5rem}.nav-submodule{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem;color:#6b7280;text-decoration:none;border-radius:6px;border-left:3px solid transparent;transition:all .2s;font-size:.9rem;margin-bottom:.125rem}.nav-submodule:hover{background:#f9fafb;color:#1f2937;transform:translate(2px)}.nav-submodule.active{background:#dbeafe;color:#1e40af;font-weight:500;border-left-color:#3b82f6}.nav-submodule-name{flex:1}.nav-active-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}@media (max-width: 768px){.dynamic-navigation{min-width:200px;padding:.75rem}.nav-module-header{padding:.75rem}.nav-submodules{padding-left:2rem}.nav-module-desc{display:none}}.dynamic-navigation.collapsed{min-width:70px;padding:.5rem}.dynamic-navigation.collapsed .nav-module-content,.dynamic-navigation.collapsed .nav-module-arrow,.dynamic-navigation.collapsed .nav-submodules{display:none}.dynamic-navigation.collapsed .nav-module-header{justify-content:center;padding:.75rem}.user-list-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center}.header-text h1{font-size:2rem;color:#1a1a1a;margin-bottom:.5rem}.header-text .subtitle{color:#666;font-size:1rem}.search-bar{position:relative;margin-bottom:2rem}.search-input{width:100%;padding:1rem 3rem 1rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.search-input:focus{outline:none;border-color:#3498db}.search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:1.2rem;color:#666}.table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;margin-bottom:2rem}.user-table{width:100%;border-collapse:collapse}.user-table thead{background-color:#f8f9fa;border-bottom:2px solid #e0e0e0}.user-table th{padding:1rem;text-align:left;font-weight:600;color:#333;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.user-table td{padding:1rem;border-bottom:1px solid #f0f0f0}.user-row{transition:background-color .2s ease}.user-row:hover{background-color:#f8f9fa}.tgm-pin{font-weight:600;color:#3498db}.user-name{font-weight:500;color:#1a1a1a}.user-email{color:#666;font-size:.9rem}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.role-admin{background-color:#e8f4f8;color:#2980b9}.role-teacher{background-color:#fef5e7;color:#d68910}.role-student{background-color:#eaf2f8;color:#5499c7}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}.actions-column{width:150px;text-align:center}.actions{display:flex;gap:.5rem;justify-content:center;align-items:center}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.5rem;border-radius:4px;transition:all .2s ease}.btn-icon:hover{transform:scale(1.1)}.btn-view:hover{background-color:#e3f2fd}.btn-edit:hover{background-color:#fff3e0}.btn-delete:hover{background-color:#ffebee}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover{background-color:#2980b9;transform:translateY(-2px);box-shadow:0 4px 8px #3498db4d}.no-results{text-align:center;padding:3rem;color:#666;font-style:italic}.stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center;transition:transform .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 8px #00000026}.stat-value{font-size:2.5rem;font-weight:700;color:#3498db;margin-bottom:.5rem}.stat-label{font-size:.9rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.permission-info{background-color:#f8f9fa;padding:1.5rem;border-radius:8px;border-left:4px solid #3498db}.permission-info h4{margin-top:0;margin-bottom:1rem;color:#1a1a1a}.permission-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem}.permission-item{padding:.75rem;background:#fff;border-radius:6px;font-size:.9rem;text-align:center}.permission-item.granted{color:#27ae60;border:2px solid #27ae60}.permission-item.denied{color:#e74c3c;border:2px solid #e74c3c;opacity:.6}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.access-denied{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;margin-top:2rem;box-shadow:0 4px 6px #0000001a}.access-denied h2{font-size:2rem;margin-bottom:1rem}.access-denied p{font-size:1.1rem;margin:.75rem 0;opacity:.9}.contact-admin{margin-top:1.5rem;font-weight:500;background:#fff3;padding:1rem;border-radius:8px}@media (max-width: 1024px){.user-table{font-size:.9rem}.user-table th,.user-table td{padding:.75rem .5rem}}@media (max-width: 768px){.user-list-page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.btn{width:100%;justify-content:center}.user-table{display:block;overflow-x:auto;white-space:nowrap}.stats-summary{grid-template-columns:repeat(2,1fr)}.permission-list{grid-template-columns:1fr}}#root{text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:1em}.read-the-docs{color:#888}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Noto Sans Gujarati,system-ui,Avenir,Helvetica,Arial,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.left-0{left:0}.right-0{right:0}.right-3{right:.75rem}.top-0{top:0}.top-1\/2{top:50%}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.-ml-1{margin-left:-.25rem}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.mr-3{margin-right:.75rem}.mt-0\.5{margin-top:.125rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.\!contents{display:contents!important}.contents{display:contents}.hidden{display:none}.h-10{height:2.5rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-auto{height:auto}.h-full{height:100%}.h-screen{height:100vh}.max-h-\[70vh\]{max-height:70vh}.max-h-none{max-height:none}.min-h-screen{min-height:100vh}.w-12{width:3rem}.w-16{width:4rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-auto{width:auto}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-full{max-width:100%}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.flex-shrink{flex-shrink:1}.flex-shrink-0{flex-shrink:0}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.self-center{align-self:center}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b-4{border-bottom-width:4px}.border-t{border-top-width:1px}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.border-gray-800{--tw-border-opacity: 1;border-color:rgb(31 41 55 / var(--tw-border-opacity, 1))}.border-green-200{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity, 1))}.border-green-500{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity, 1))}.border-purple-600{--tw-border-opacity: 1;border-color:rgb(147 51 234 / var(--tw-border-opacity, 1))}.border-red-200{--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity, 1))}.border-red-300{--tw-border-opacity: 1;border-color:rgb(252 165 165 / var(--tw-border-opacity, 1))}.border-red-500{--tw-border-opacity: 1;border-color:rgb(239 68 68 / var(--tw-border-opacity, 1))}.border-slate-100{--tw-border-opacity: 1;border-color:rgb(241 245 249 / var(--tw-border-opacity, 1))}.border-slate-200{--tw-border-opacity: 1;border-color:rgb(226 232 240 / var(--tw-border-opacity, 1))}.border-slate-300{--tw-border-opacity: 1;border-color:rgb(203 213 225 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.bg-\[\#5a22be\]{--tw-bg-opacity: 1;background-color:rgb(90 34 190 / var(--tw-bg-opacity, 1))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-green-50{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-indigo-100{--tw-bg-opacity: 1;background-color:rgb(224 231 255 / var(--tw-bg-opacity, 1))}.bg-indigo-600{--tw-bg-opacity: 1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.bg-purple-50{--tw-bg-opacity: 1;background-color:rgb(250 245 255 / var(--tw-bg-opacity, 1))}.bg-purple-600{--tw-bg-opacity: 1;background-color:rgb(147 51 234 / var(--tw-bg-opacity, 1))}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-slate-100{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.bg-slate-200{--tw-bg-opacity: 1;background-color:rgb(226 232 240 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/60{background-color:#fff9}.bg-white\/80{background-color:#fffc}.bg-white\/90{background-color:#ffffffe6}.bg-yellow-500{--tw-bg-opacity: 1;background-color:rgb(234 179 8 / var(--tw-bg-opacity, 1))}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.from-purple-50{--tw-gradient-from: #faf5ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(250 245 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-white{--tw-gradient-to: #fff var(--tw-gradient-to-position)}.bg-cover{background-size:cover}.bg-center{background-position:center}.object-contain{-o-object-fit:contain;object-fit:contain}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pb-20{padding-bottom:5rem}.pl-5{padding-left:1.25rem}.pl-6{padding-left:1.5rem}.pr-12{padding-right:3rem}.pt-32{padding-top:8rem}.pt-4{padding-top:1rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.tracking-wide{letter-spacing:.025em}.text-\[\#5a22be\]{--tw-text-opacity: 1;color:rgb(90 34 190 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-green-900{--tw-text-opacity: 1;color:rgb(20 83 45 / var(--tw-text-opacity, 1))}.text-indigo-600{--tw-text-opacity: 1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.text-indigo-700{--tw-text-opacity: 1;color:rgb(67 56 202 / var(--tw-text-opacity, 1))}.text-purple-600{--tw-text-opacity: 1;color:rgb(147 51 234 / var(--tw-text-opacity, 1))}.text-purple-700{--tw-text-opacity: 1;color:rgb(126 34 206 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.text-red-800{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.text-slate-500{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity, 1))}.text-slate-600{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity, 1))}.text-slate-700{--tw-text-opacity: 1;color:rgb(51 65 85 / var(--tw-text-opacity, 1))}.text-slate-800{--tw-text-opacity: 1;color:rgb(30 41 59 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-600{--tw-text-opacity: 1;color:rgb(202 138 4 / var(--tw-text-opacity, 1))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.placeholder-gray-400::-moz-placeholder{--tw-placeholder-opacity: 1;color:rgb(156 163 175 / var(--tw-placeholder-opacity, 1))}.placeholder-gray-400::placeholder{--tw-placeholder-opacity: 1;color:rgb(156 163 175 / var(--tw-placeholder-opacity, 1))}.opacity-80{opacity:.8}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.drop-shadow{--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / .1)) drop-shadow(0 1px 1px rgb(0 0 0 / .06));filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.grayscale{--tw-grayscale: grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}html,body,#root{height:100%}.hover\:border-indigo-400:hover{--tw-border-opacity: 1;border-color:rgb(129 140 248 / var(--tw-border-opacity, 1))}.hover\:bg-\[\#4a1ca3\]:hover{--tw-bg-opacity: 1;background-color:rgb(74 28 163 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-50:hover{--tw-bg-opacity: 1;background-color:rgb(238 242 255 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-500:hover{--tw-bg-opacity: 1;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))}.hover\:bg-purple-50:hover{--tw-bg-opacity: 1;background-color:rgb(250 245 255 / var(--tw-bg-opacity, 1))}.hover\:bg-purple-700:hover{--tw-bg-opacity: 1;background-color:rgb(126 34 206 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-300:hover{--tw-bg-opacity: 1;background-color:rgb(203 213 225 / var(--tw-bg-opacity, 1))}.hover\:text-\[\#5a22be\]:hover{--tw-text-opacity: 1;color:rgb(90 34 190 / var(--tw-text-opacity, 1))}.hover\:text-gray-700:hover{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.hover\:text-purple-700:hover{--tw-text-opacity: 1;color:rgb(126 34 206 / var(--tw-text-opacity, 1))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.hover\:shadow-md:hover{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:border-purple-500:focus{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.focus\:border-transparent:focus{border-color:transparent}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-\[\#5a22be\]:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(90 34 190 / var(--tw-ring-opacity, 1))}.focus\:ring-indigo-400\/40:focus{--tw-ring-color: rgb(129 140 248 / .4)}.focus\:ring-indigo-400\/50:focus{--tw-ring-color: rgb(129 140 248 / .5)}.focus\:ring-purple-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(168 85 247 / var(--tw-ring-opacity, 1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-slate-100:disabled{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.disabled\:text-gray-400:disabled{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:bg-indigo-500{--tw-bg-opacity: 1;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}@media (min-width: 640px){.sm\:mb-6{margin-bottom:1.5rem}.sm\:mt-8{margin-top:2rem}.sm\:w-1\/3{width:33.333333%}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.sm\:p-6{padding:1.5rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}}@media (min-width: 768px){.md\:mt-12{margin-top:3rem}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:p-8{padding:2rem}.md\:text-6xl{font-size:3.75rem;line-height:1}}@media (min-width: 1024px){.lg\:block{display:block}.lg\:hidden{display:none}.lg\:w-1\/3{width:33.333333%}.lg\:w-2\/3{width:66.666667%}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
