:root{--font-sans:"Outfit", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;--border-radius-xs:4px;--border-radius-sm:8px;--border-radius-md:12px;--border-radius-lg:16px;--border-radius-xl:24px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s cubic-bezier(.16, 1, .3, 1);--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--primary-h:240;--primary-s:70%;--success-h:142;--success-s:70%;--danger-h:346;--danger-s:77%;--warning-h:45;--warning-s:90%;--info-h:195;--info-s:85%}:root,[data-theme=light]{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--bg-accent:#e2e8f0;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-inverse:#fff;--border-color:#e2e8f0;--border-focus:hsla(var(--primary-h), var(--primary-s), 50%, .5);--color-primary:hsl(var(--primary-h), var(--primary-s), 55%);--color-primary-hover:hsl(var(--primary-h), var(--primary-s), 45%);--color-primary-light:hsl(var(--primary-h), var(--primary-s), 95%);--color-success:hsl(var(--success-h), var(--success-s), 40%);--color-success-hover:hsl(var(--success-h), var(--success-s), 30%);--color-success-light:hsl(var(--success-h), var(--success-s), 95%);--color-danger:hsl(var(--danger-h), var(--danger-s), 50%);--color-danger-hover:hsl(var(--danger-h), var(--danger-s), 40%);--color-danger-light:hsl(var(--danger-h), var(--danger-s), 95%);--color-warning:hsl(var(--warning-h), var(--warning-s), 45%);--color-warning-hover:hsl(var(--warning-h), var(--warning-s), 35%);--color-warning-light:hsl(var(--warning-h), var(--warning-s), 95%);--color-info:hsl(var(--info-h), var(--info-s), 45%);--color-info-hover:hsl(var(--info-h), var(--info-s), 35%);--color-info-light:hsl(var(--info-h), var(--info-s), 95%);--glass-bg:#ffffffb3;--glass-border:#fff6;--glass-shadow:0 8px 32px 0 #1f26870f}[data-theme=dark]{--bg-primary:#0b0f19;--bg-secondary:#121826;--bg-tertiary:#1b2234;--bg-accent:#252d42;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--text-inverse:#0f172a;--border-color:#1e293b;--border-focus:hsla(var(--primary-h), var(--primary-s), 60%, .5);--color-primary:hsl(var(--primary-h), var(--primary-s), 65%);--color-primary-hover:hsl(var(--primary-h), var(--primary-s), 75%);--color-primary-light:hsla(var(--primary-h), var(--primary-s), 65%, .15);--color-success:hsl(var(--success-h), var(--success-s), 45%);--color-success-hover:hsl(var(--success-h), var(--success-s), 55%);--color-success-light:hsla(var(--success-h), var(--success-s), 45%, .15);--color-danger:hsl(var(--danger-h), var(--danger-s), 60%);--color-danger-hover:hsl(var(--danger-h), var(--danger-s), 70%);--color-danger-light:hsla(var(--danger-h), var(--danger-s), 60%, .15);--color-warning:hsl(var(--warning-h), var(--warning-s), 50%);--color-warning-hover:hsl(var(--warning-h), var(--warning-s), 60%);--color-warning-light:hsla(var(--warning-h), var(--warning-s), 50%, .15);--color-info:hsl(var(--info-h), var(--info-s), 50%);--color-info-hover:hsl(var(--info-h), var(--info-s), 60%);--color-info-light:hsla(var(--info-h), var(--info-s), 50%, .15);--glass-bg:#121826b3;--glass-border:#ffffff0d;--glass-shadow:0 8px 32px 0 #0000005e}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background-color var(--transition-normal), color var(--transition-normal);overflow-x:hidden}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}button,input,select,textarea{font-family:inherit;font-size:inherit}.app-container{min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow-y:auto}.content-body{flex:1;padding:2rem}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--border-radius-md);transition:transform var(--transition-normal), box-shadow var(--transition-normal)}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:10;width:260px;height:100vh;transition:background-color var(--transition-normal), border-color var(--transition-normal);flex-direction:column;display:flex;position:sticky;top:0}.sidebar-header{border-bottom:1px solid var(--border-color);align-items:center;gap:.75rem;padding:1.5rem;display:flex}.sidebar-logo{background:linear-gradient(135deg, var(--color-primary), var(--color-success));-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;font-size:1.25rem;font-weight:800}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:1.5rem 1rem;display:flex;overflow-y:auto}.sidebar-nav-item{color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;text-align:left;transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1rem;font-weight:500;display:flex}.sidebar-nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--color-primary-light);color:var(--color-primary)}.sidebar-footer{border-top:1px solid var(--border-color);flex-direction:column;gap:.5rem;padding:1.5rem;display:flex}.user-profile-summary{align-items:center;gap:.75rem;display:flex}.user-avatar{background:var(--color-primary-light);width:40px;height:40px;color:var(--color-primary);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.user-details{flex-direction:column;min-width:0;display:flex}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.user-role-badge{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;font-size:.7rem;font-weight:700}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:5;height:70px;transition:background-color var(--transition-normal), border-color var(--transition-normal);justify-content:space-between;align-items:center;padding:0 2rem;display:flex}.header-search{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);align-items:center;gap:.5rem;width:300px;padding:.5rem .75rem;display:flex}.header-search input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%}.header-actions{align-items:center;gap:1.25rem;display:flex}.icon-btn{color:var(--text-secondary);cursor:pointer;width:38px;height:38px;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.icon-btn .badge-dot{background:var(--color-danger);border:2px solid var(--bg-secondary);border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.page-title-area{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.page-title{letter-spacing:-.5px;font-size:1.75rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.9rem}.grid-cols-4{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.grid-cols-3{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.grid-cols-2{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);padding:1.5rem}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-title{justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:1.1rem;font-weight:600;display:flex}.table-container{margin-bottom:1.5rem;overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%}.custom-table th{background:var(--bg-tertiary);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);padding:1rem;font-size:.85rem;font-weight:600}.custom-table td{border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle;padding:1rem;font-size:.925rem}.custom-table tr:hover td{background:var(--bg-tertiary)}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.form-control{border-radius:var(--border-radius-sm);border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:.75rem 1rem}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--border-focus)}.badge{text-transform:capitalize;border-radius:9999px;align-items:center;padding:.25rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-primary{background:var(--color-primary-light);color:var(--color-primary)}.badge-success{background:var(--color-success-light);color:var(--color-success)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning)}.badge-info{background:var(--color-info-light);color:var(--color-info)}.btn{border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--color-primary);color:var(--text-inverse)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-success{background:var(--color-success);color:var(--text-inverse)}.btn-success:hover{background:var(--color-success-hover)}.btn-danger{background:var(--color-danger);color:var(--text-inverse)}.btn-danger:hover{background:var(--color-danger-hover)}.btn-outline{border-color:var(--border-color);color:var(--text-primary);background:0 0}.btn-outline:hover{background:var(--bg-tertiary)}.btn-icon{border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;display:flex}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-group{gap:.5rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0000008c;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);width:90%;max-width:550px;max-height:90vh;box-shadow:var(--shadow-xl);flex-direction:column;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-body{padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);background:var(--bg-tertiary);justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.login-wrapper{background:radial-gradient(circle at 10% 20%, var(--bg-tertiary) 0%, var(--bg-primary) 90%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{border-radius:var(--border-radius-lg);width:100%;max-width:420px;padding:2.5rem}.login-header{text-align:center;margin-bottom:2rem}.login-logo{background:linear-gradient(135deg, var(--color-primary), var(--color-success));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:2rem;font-weight:800}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.theme-rotate{transition:transform var(--transition-slow)}.theme-rotate:hover{transform:rotate(45deg)}@media (width<=768px){.app-container{flex-direction:column}.sidebar{border-right:none;border-bottom:1px solid var(--border-color);width:100%;height:auto}.sidebar-nav{flex-direction:row;height:auto;padding:.5rem 1rem;overflow-x:auto}.sidebar-nav-item{white-space:nowrap;padding:.5rem .75rem}.sidebar-footer{display:none}.content-body{padding:1rem}}.stat-card{justify-content:space-between;align-items:center;display:flex;position:relative;overflow:hidden}.stat-card:after{content:"";background:var(--bg-accent);width:100%;height:4px;position:absolute;bottom:0;left:0}.stat-card.primary:after{background:var(--color-primary)}.stat-card.success:after{background:var(--color-success)}.stat-card.danger:after{background:var(--color-danger)}.stat-card.warning:after{background:var(--color-warning)}.stat-val{letter-spacing:-1px;margin:.5rem 0 .25rem;font-size:2rem;font-weight:800}.stat-change{align-items:center;gap:.25rem;font-size:.775rem;font-weight:600;display:flex}.stat-icon{background:var(--bg-tertiary);color:var(--text-secondary);border-radius:var(--border-radius-md);justify-content:center;align-items:center;width:48px;height:48px;display:flex}.charts-grid{grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:2rem;display:grid}@media (width<=1024px){.charts-grid{grid-template-columns:1fr}}.chart-svg-container{width:100%;height:260px;position:relative}.chart-svg{width:100%;height:100%}.chart-axis-line{stroke:var(--border-color);stroke-width:1px}.chart-grid-line{stroke:var(--border-color);stroke-dasharray:4 4;stroke-width:1px}.chart-line{fill:none;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.chart-bar{rx:4}.chart-area{opacity:.15}.chart-label{fill:var(--text-secondary);font-size:10px;font-family:var(--font-sans)}.chart-tooltip{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);box-shadow:var(--shadow-md);pointer-events:none;padding:.5rem;font-size:.75rem;display:none;position:absolute}.filter-bar{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;display:flex}.filter-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.filter-select{border-radius:var(--border-radius-sm);border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);outline:none;padding:.5rem 1rem}.proctor-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem;display:grid}.proctor-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);transition:all var(--transition-normal);flex-direction:column;gap:.75rem;padding:1.25rem;display:flex;position:relative}.proctor-card.violated{border-color:var(--color-danger);animation:2s infinite alternate pulse-danger-border;box-shadow:0 0 10px #f43f5e1a}@keyframes pulse-danger-border{0%{border-color:var(--color-danger)}to{border-color:hsla(var(--danger-h), var(--danger-s), 50%, .4)}}.student-monitor-header{justify-content:space-between;align-items:flex-start;display:flex}.student-monitor-info{align-items:center;gap:.75rem;display:flex}.student-monitor-name{font-size:.95rem;font-weight:600}.student-monitor-class{color:var(--text-muted);margin-top:.15rem;font-size:.75rem}.proctor-progress-wrapper{margin:.5rem 0}.proctor-progress-label{color:var(--text-secondary);justify-content:space-between;margin-bottom:.25rem;font-size:.75rem;display:flex}.progress-bar-container{background:var(--bg-tertiary);border-radius:99px;height:6px;overflow:hidden}.progress-bar-fill{background:var(--color-primary);height:100%;transition:width var(--transition-normal);border-radius:99px}.progress-bar-fill.success{background:var(--color-success)}.progress-bar-fill.warning{background:var(--color-warning)}.violations-counter{color:var(--color-danger);background:var(--color-danger-light);border-radius:var(--border-radius-xs);align-items:center;gap:.5rem;padding:.35rem .6rem;font-size:.8rem;font-weight:600;display:flex}.status-indicator{align-items:center;gap:.35rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot.online{background:var(--color-success);box-shadow:0 0 6px var(--color-success);animation:1.5s infinite pulse-online}.status-dot.offline{background:var(--text-muted)}@keyframes pulse-online{0%{opacity:.7;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}to{opacity:.7;transform:scale(.9)}}.ticker-container{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);align-items:center;gap:1rem;height:42px;margin-bottom:1.5rem;padding:.75rem 1rem;display:flex;overflow:hidden}.ticker-title{text-transform:uppercase;color:var(--color-danger);letter-spacing:.5px;white-space:nowrap;align-items:center;gap:.35rem;font-size:.75rem;font-weight:700;display:flex}.ticker-slider{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.85rem;font-weight:500;overflow:hidden}.question-item{border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:var(--border-radius-sm);transition:all var(--transition-fast);margin-bottom:1rem;padding:1.25rem}.question-item:hover{border-color:var(--color-primary)}.question-meta{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.exam-layout{background-color:var(--bg-primary);grid-template-columns:1fr 300px;height:100vh;display:grid;overflow:hidden}@media (width<=900px){.exam-layout{grid-template-rows:auto 1fr;grid-template-columns:1fr;overflow-y:auto}}.exam-main-panel{flex-direction:column;height:100%;padding:1.5rem;display:flex;overflow-y:auto}.exam-side-panel{background:var(--bg-secondary);border-left:1px solid var(--border-color);flex-direction:column;height:100%;padding:1.5rem;display:flex;overflow-y:auto}.exam-navbar{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.exam-timer{border-radius:var(--border-radius-sm);background:var(--bg-tertiary);font-variant-numeric:tabular-nums;border:1px solid var(--border-color);align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:1.25rem;font-weight:700;display:flex}.exam-timer.warning{color:var(--color-danger);border-color:var(--color-danger);background:var(--color-danger-light);animation:1s infinite alternate flash-red}@keyframes flash-red{0%{opacity:1}to{opacity:.6}}.question-viewport{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm);flex-direction:column;flex:1;gap:1.5rem;margin:1rem 0;padding:2rem;display:flex}.question-text-content{font-size:1.1rem;font-weight:500;line-height:1.6}.question-media-wrapper{border-radius:var(--border-radius-md);background:var(--bg-tertiary);border:1px solid var(--border-color);max-width:100%;margin:1rem 0;padding:.5rem;overflow:hidden}.question-media-wrapper img,.question-media-wrapper video{border-radius:var(--border-radius-sm);max-width:100%;max-height:360px;margin:0 auto;display:block}.question-media-wrapper audio{width:100%;margin:.5rem 0;display:block}.options-list{flex-direction:column;gap:.75rem;display:flex}.option-item{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-secondary);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:1rem;padding:.85rem 1.25rem;display:flex}.option-item:hover{background:var(--bg-tertiary);border-color:var(--color-primary)}.option-item.selected{border-color:var(--color-primary);background:var(--color-primary-light)}.option-label{background:var(--bg-tertiary);width:28px;height:28px;color:var(--text-secondary);border:1px solid var(--border-color);transition:all var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.option-item.selected .option-label{background:var(--color-primary);color:var(--text-inverse);border-color:var(--color-primary)}.option-text{font-size:.95rem;font-weight:500}.short-answer-input{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-secondary);width:100%;max-width:400px;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:.85rem 1.25rem;font-size:1rem}.short-answer-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--border-focus)}.drag-drop-container{flex-direction:column;gap:1rem;display:flex}.draggable-items-pool{background:var(--bg-tertiary);border:2px dashed var(--border-color);border-radius:var(--border-radius-sm);flex-wrap:wrap;align-items:center;gap:.75rem;min-height:60px;padding:1rem;display:flex}.draggable-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:grab;box-shadow:var(--shadow-sm);-webkit-user-select:none;user-select:none;padding:.5rem 1rem;font-size:.9rem;font-weight:600}.draggable-item:active{cursor:grabbing}.drop-zones-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.drop-zone-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);flex-direction:column;align-items:center;gap:.75rem;padding:1rem;display:flex}.drop-zone-label{color:var(--text-secondary);text-align:center;font-size:.85rem;font-weight:700}.drop-zone{border:2px dashed var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-tertiary);width:100%;min-height:50px;transition:all var(--transition-fast);justify-content:center;align-items:center;padding:.25rem;display:flex}.drop-zone.drag-over{border-color:var(--color-primary);background:var(--color-primary-light)}.matching-pairs-container{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.matching-column{flex-direction:column;gap:.75rem;display:flex}.matching-item{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:.9rem;font-weight:500;display:flex}.matching-item:hover{background:var(--bg-tertiary)}.matching-item.selected{border-color:var(--color-primary);background:var(--color-primary-light)}.matching-item.paired{border-color:var(--color-success);background:var(--color-success-light)}.file-upload-dragzone{border:2px dashed var(--border-color);border-radius:var(--border-radius-md);background:var(--bg-tertiary);text-align:center;cursor:pointer;transition:all var(--transition-fast);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:2.5rem 1.5rem;display:flex}.file-upload-dragzone:hover{border-color:var(--color-primary);background:var(--bg-secondary)}.file-uploaded-summary{border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:var(--border-radius-sm);align-items:center;gap:.75rem;width:100%;max-width:400px;margin-top:1rem;padding:.75rem 1rem;display:flex}.exam-grid-title{margin-bottom:.75rem;font-size:.95rem;font-weight:700}.exam-grid{grid-template-columns:repeat(5,1fr);gap:.5rem;margin-bottom:1.5rem;display:grid}.exam-grid-btn{aspect-ratio:1;border-radius:var(--border-radius-sm);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:.9rem;font-weight:600;display:flex}.exam-grid-btn:hover{border-color:var(--color-primary)}.exam-grid-btn.current{border-color:var(--color-primary);background:var(--bg-accent);border-width:2px}.exam-grid-btn.answered{background:var(--color-primary);color:var(--text-inverse);border-color:var(--color-primary)}.exam-grid-btn.flagged{background:var(--color-warning);color:var(--text-inverse);border-color:var(--color-warning)}.exam-legend{border-top:1px solid var(--border-color);flex-direction:column;gap:.5rem;margin-top:auto;padding-top:1.25rem;font-size:.8rem;display:flex}.exam-legend-item{align-items:center;gap:.5rem;display:flex}.exam-legend-dot{border:1px solid var(--border-color);border-radius:4px;width:16px;height:16px}.exam-legend-dot.answered{background:var(--color-primary);border-color:var(--color-primary)}.exam-legend-dot.flagged{background:var(--color-warning);border-color:var(--color-warning)}.exam-legend-dot.unanswered{background:var(--bg-secondary)}.exam-controls-bar{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.25rem 0;display:flex}.ragu-btn{color:var(--color-warning);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:flex}.cheat-blocker-overlay{color:#f8fafc;z-index:9999;background:#0f172a;justify-content:center;align-items:center;width:100vw;height:100vh;padding:2rem;animation:.15s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.cheat-blocker-card{border-radius:var(--border-radius-lg);text-align:center;background:#1e293b;border:2px solid #ef4444;flex-direction:column;align-items:center;gap:1.5rem;max-width:550px;padding:3rem;display:flex;box-shadow:0 25px 50px -12px #00000080}.cheat-blocker-icon{color:#ef4444;animation:1s infinite alternate bounce}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-8px)}}.cheat-blocker-title{text-transform:uppercase;letter-spacing:.5px;font-size:1.5rem;font-weight:800}.cheat-blocker-desc{color:#94a3b8;font-size:1rem;line-height:1.5}.cheat-blocker-count{color:#ef4444;font-size:1.1rem;font-weight:700}
