*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: #1a365d;--primary-light: #2d4a7c;--primary-dark: #0f2744;--success: #22c55e;--success-dark: #16a34a;--warning: #eab308;--danger: #ef4444;--info: #3b82f6;--text: #1f2937;--text-light: #6b7280;--text-muted: #9ca3af;--bg: #f8fafc;--bg-alt: #f1f5f9;--white: #ffffff;--border: #e5e7eb;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--container-max: 1200px;--container-wide: 1400px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .15);--shadow-xl: 0 25px 50px rgba(0, 0, 0, .2);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;width:100%}h1,h2,h3,h4,h5,h6{line-height:1.3;font-weight:600;color:var(--text)}a{color:var(--info);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}button:disabled{cursor:not-allowed;opacity:.6}input,textarea,select{font-family:inherit;font-size:inherit}input:focus,textarea:focus,select:focus{outline:none}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 1.5rem}.container-wide{width:100%;max-width:var(--container-wide);margin:0 auto;padding:0 1.5rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-alt)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}::selection{background:var(--primary-light);color:var(--white)}.exam-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fff,#f8fafc);padding:24px}.exam-login .login-container{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;border:1px solid #e2e8f0;padding:40px;width:100%;max-width:400px}.exam-login .login-header{text-align:center;margin-bottom:32px}.exam-login .login-logo{width:80px;height:80px;object-fit:contain;margin:0 auto 16px;display:block}.exam-login .login-header h1{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 8px;letter-spacing:-.02em}.exam-login .login-header p{color:#64748b;margin:0;font-size:.9375rem}.exam-login .login-form{display:flex;flex-direction:column;gap:20px}.exam-login .error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:12px 16px;color:#dc2626;font-size:.875rem;display:flex;align-items:center;gap:10px}.exam-login .error-message .anticon{font-size:1rem}.exam-login .form-group{display:flex;flex-direction:column;gap:8px}.exam-login .form-group label{font-weight:500;color:#475569;font-size:.875rem}.exam-login .form-group input{padding:12px 16px;border:1px solid #e2e8f0;border-radius:10px;font-size:1rem;transition:all .2s ease;background:#f8fafc}.exam-login .form-group input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.exam-login .form-group input:disabled{background:#f1f5f9;color:#94a3b8}.exam-login .submit-btn{background:#3b82f6;color:#fff;border:none;padding:14px 20px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:8px}.exam-login .submit-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.exam-login .submit-btn:disabled{background:#94a3b8;cursor:not-allowed}.exam-login .login-footer{text-align:center;margin-top:24px;padding-top:20px;border-top:1px solid #e2e8f0}.exam-login .login-footer p{color:#94a3b8;font-size:.8125rem;margin:0}.exam-login .login-tabs{display:flex;gap:8px;margin-bottom:24px;background:#f1f5f9;padding:4px;border-radius:12px}.exam-login .tab-btn{flex:1;padding:10px 16px;border:none;background:transparent;border-radius:8px;font-size:.875rem;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.exam-login .tab-btn:hover{color:#475569}.exam-login .tab-btn.active{background:#fff;color:#3b82f6;box-shadow:0 1px 3px #0000001a}.exam-login .tab-btn .anticon{font-size:1rem}.exam-login .token-input{text-transform:uppercase;letter-spacing:4px;font-weight:600;font-size:1.125rem!important;text-align:center;font-family:SF Mono,Monaco,Inconsolata,monospace}.exam-login .input-hint{font-size:.75rem;color:#94a3b8;margin-top:4px}.exam-login .back-link{display:inline-flex;align-items:center;gap:6px;color:#64748b;text-decoration:none;font-size:.875rem;margin-bottom:24px;transition:color .2s ease}.exam-login .back-link:hover{color:#3b82f6}:root{--primary: #6366f1;--primary-dark: #4f46e5;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--purple: #8b5cf6;--bg: #f8fafc;--card-bg: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border: #e2e8f0}*{box-sizing:border-box}.exam-portal{min-height:100vh;background:var(--bg)}.portal-header{background:var(--card-bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000d}.header-content{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.brand{display:flex;align-items:center;gap:.875rem}.brand-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--primary) 0%,var(--purple) 100%);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 4px 12px #6366f14d}.brand-text h1{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.brand-text span{font-size:.8rem;color:var(--text-secondary);font-weight:500}.user-section{display:flex;align-items:center;gap:1rem}.user-avatar{width:42px;height:42px;background:linear-gradient(135deg,var(--primary) 0%,var(--purple) 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem;box-shadow:0 2px 8px #6366f140}.user-details{display:flex;flex-direction:column;gap:.125rem}.user-name{font-weight:600;color:var(--text-primary);font-size:.9rem}.user-badge{font-size:.65rem;color:#fff;background:var(--success);padding:.15rem .5rem;border-radius:4px;width:fit-content;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.logout-btn{background:transparent;border:1px solid var(--border);width:42px;height:42px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s}.logout-btn:hover{background:var(--danger);border-color:var(--danger);color:#fff}.portal-main{max-width:1200px;margin:0 auto;padding:2rem 1.5rem;position:relative;z-index:1}.welcome-banner{background:linear-gradient(135deg,var(--primary) 0%,var(--purple) 100%);border-radius:20px;padding:2rem 2.5rem;color:#fff;margin-bottom:2rem;box-shadow:0 10px 40px #6366f140}.welcome-text h2{margin:0 0 .5rem;font-size:1.75rem;font-weight:800;text-shadow:0 2px 10px rgba(0,0,0,.1)}.welcome-text p{margin:0;opacity:.95;font-size:1rem}.stats-row{display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.2)}.stat-item{display:flex;flex-direction:column;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 1.5rem;border-radius:16px;min-width:100px;text-align:center;box-shadow:0 4px 15px #0000001a;border:1px solid rgba(255,255,255,.5)}.stat-value{font-size:2rem;font-weight:800;line-height:1;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:.75rem;color:#64748b;margin-top:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.section-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding:0 .5rem}.section-title h3{margin:0;font-size:1.1rem;color:var(--text-primary);font-weight:700}.refresh-btn{background:var(--card-bg);border:1px solid var(--border);width:38px;height:38px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s}.refresh-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:rotate(180deg)}.state-container{background:#fff;border-radius:16px;padding:3rem;text-align:center;box-shadow:0 4px 20px #0000000d}.state-container p{color:#64748b;margin:.5rem 0 0}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.state-container.empty h3{margin:1rem 0 .25rem;color:#334155}.empty-illustration svg{opacity:.8}.retry-btn{margin-top:1rem;background:var(--primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s}.retry-btn:hover{background:var(--primary-dark);transform:translateY(-2px)}.exam-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.exam-card{background:var(--card-bg);border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #0000000f;transition:all .2s ease;position:relative;border:1px solid var(--border)}.exam-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a;border-color:var(--primary)}.card-accent{height:4px;width:100%}.card-content{padding:1.25rem 1.5rem 1.5rem}.card-header{margin-bottom:.75rem}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.status-badge.available{background:#ecfdf5;color:#059669}.status-badge.progress{background:#eff6ff;color:#2563eb}.status-badge.completed,.status-badge.graded{background:#ecfdf5;color:#059669}.status-badge.scheduled{background:#fffbeb;color:#d97706}.status-badge.expired{background:#fef2f2;color:#dc2626}.status-icon{font-size:.875rem}.exam-title{margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:#1e293b;line-height:1.4}.info-grid{display:flex;gap:1.25rem;margin-bottom:1rem}.info-item{display:flex;align-items:center;gap:.5rem}.info-icon{width:36px;height:36px;background:#f8fafc;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem}.info-content{display:flex;flex-direction:column}.info-value{font-weight:700;color:#1e293b;font-size:1rem}.info-label{font-size:.7rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.score-display{background:#f8fafc;border-radius:12px;padding:.875rem 1rem;margin-bottom:1rem}.score-bar{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.score-fill{height:100%;border-radius:3px;transition:width .5s ease}.score-info{display:flex;justify-content:space-between;align-items:center}.score-info .score-value{font-size:1.1rem;font-weight:800;color:#1e293b}.score-detail{font-size:.75rem;color:#64748b}.card-actions{margin-top:auto}.action-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.25rem;border:none;border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.action-btn.primary{background:linear-gradient(135deg,var(--primary) 0%,var(--purple) 100%);color:#fff;box-shadow:0 4px 15px #6366f159}.action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f173}.action-btn.warning{background:linear-gradient(135deg,var(--warning) 0%,#f97316 100%);color:#fff;box-shadow:0 4px 15px #f59e0b59}.action-btn.warning:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b73}.action-btn.secondary{background:#fff;color:var(--primary);border:2px solid var(--primary)}.action-btn.secondary:hover{background:var(--primary);color:#fff}.action-btn.info{background:linear-gradient(135deg,#3b82f6,#06b6d4);color:#fff;box-shadow:0 4px 15px #3b82f659}.action-btn.info:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f673}.action-btn svg{transition:transform .2s}.action-btn:hover svg{transform:translate(3px)}.status-message{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;border-radius:12px;font-size:.85rem;font-weight:500}.status-message.scheduled{background:#fffbeb;color:#b45309}.status-message.expired{background:#fef2f2;color:#b91c1c}.card-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.preload-progress{display:flex;align-items:center;gap:.5rem;flex:1;min-width:120px}.preload-progress .progress-bar{flex:1;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.preload-progress .progress-fill{height:100%;background:linear-gradient(135deg,var(--primary) 0%,var(--purple) 100%);border-radius:4px;transition:width .3s ease}.preload-progress span{font-size:.75rem;color:var(--primary);font-weight:600;min-width:35px}.preloaded-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;background:#ecfdf5;color:#059669;border-radius:20px;font-size:.75rem;font-weight:600}.action-btn.secondary{background:#fff;color:var(--primary);border:2px solid var(--primary);flex:0 0 auto;width:auto;padding:.5rem .75rem;font-size:.8rem}.action-btn.primary{flex:1}@media(max-width:768px){.header-content{padding:.75rem 1rem}.brand-text span,.user-details{display:none}.portal-main{padding:1rem}.welcome-banner{padding:1.25rem;border-radius:16px}.welcome-text h2{font-size:1.25rem}.stats-row{gap:1rem}.stat-value{font-size:1.25rem}.exam-list{grid-template-columns:1fr}.info-grid{gap:1rem}}@media(max-width:480px){.stats-row{flex-wrap:wrap}.stat-item{flex:1;min-width:80px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.exam-card{animation:fadeInUp .4s ease forwards}.exam-card:nth-child(1){animation-delay:.05s}.exam-card:nth-child(2){animation-delay:.1s}.exam-card:nth-child(3){animation-delay:.15s}.exam-card:nth-child(4){animation-delay:.2s}.exam-card:nth-child(5){animation-delay:.25s}.exam-card:nth-child(6){animation-delay:.3s}.completed-section{margin-top:2rem;background:var(--card-bg);border-radius:16px;overflow:hidden;border:1px solid var(--border)}.completed-header{padding:1rem 1.25rem;background:#f8fafc;border-bottom:1px solid var(--border)}.completed-header h3{margin:0;font-size:.95rem;font-weight:600;color:var(--text-secondary)}.completed-list{max-height:300px;overflow-y:auto}.completed-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #f1f5f9;transition:background .15s}.completed-item:last-child{border-bottom:none}.completed-item:hover{background:#f8fafc}.completed-info{display:flex;flex-direction:column;gap:.25rem}.completed-title{font-weight:600;color:var(--text-primary);font-size:.9rem}.completed-meta{font-size:.8rem;color:var(--text-secondary)}.completed-actions{display:flex;align-items:center;gap:.75rem}.score-badge{padding:.375rem .75rem;border-radius:6px;font-size:.85rem;font-weight:700}.score-badge.pending{background:#f1f5f9;color:var(--text-secondary)}.view-result-btn{padding:.5rem 1rem;background:transparent;color:var(--primary);border:1px solid var(--primary);border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.view-result-btn:hover{background:var(--primary);color:#fff}.state-icon{font-size:3rem;margin-bottom:.5rem}.system-check{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b);display:flex;align-items:center;justify-content:center;padding:2rem}.system-check-container{background:#1e293b;border-radius:16px;padding:2rem;max-width:500px;width:100%;box-shadow:0 20px 50px #0006}.system-check h1{color:#f8fafc;text-align:center;margin-bottom:.5rem}.system-check .subtitle{color:#94a3b8;text-align:center;margin-bottom:1.5rem;font-size:.9rem}.exam-info-card{background:linear-gradient(135deg,#1e3a5f,#0f172a);border-radius:12px;padding:1.25rem;margin-bottom:1rem;border:1px solid #334155}.exam-info-card h2{color:#f8fafc;font-size:1.1rem;margin-bottom:.75rem}.exam-meta{display:flex;gap:1.5rem;color:#94a3b8;font-size:.85rem;margin-bottom:.75rem}.exam-status{font-size:.85rem;font-weight:600;padding:.5rem .75rem;border-radius:8px;display:inline-block}.exam-status.active{background:#22c55e33;color:#22c55e}.exam-status.waiting{background:#f59e0b33;color:#f59e0b}.preload-status{margin-bottom:1rem}.preload-progress{background:#334155;border-radius:8px;padding:.75rem}.preload-progress span{color:#94a3b8;font-size:.85rem;display:block;margin-bottom:.5rem}.progress-bar{height:6px;background:#475569;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);transition:width .3s}.preload-complete{background:#22c55e1a;color:#22c55e;padding:.5rem .75rem;border-radius:8px;font-size:.85rem}.preload-error{background:#ef44441a;color:#ef4444;padding:.5rem .75rem;border-radius:8px;font-size:.85rem}.waiting-hint{color:#94a3b8;font-size:.8rem;text-align:center;margin-top:.5rem}.device-selection{background:#334155;border-radius:12px;padding:1rem;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.75rem}.device-select{display:flex;align-items:center;gap:.75rem}.device-select label{color:#94a3b8;font-size:.85rem;min-width:80px}.device-select select{flex:1;background:#1e293b;border:1px solid #475569;color:#f8fafc;padding:.5rem;border-radius:8px;font-size:.85rem;cursor:pointer}.device-select select:focus{outline:none;border-color:#6366f1}.check-item{background:#334155;border-radius:12px;padding:1rem;margin-bottom:1rem;transition:all .3s}.check-item.passed{border-left:4px solid #22c55e}.check-item.failed{border-left:4px solid #ef4444}.check-item.testing{border-left:4px solid #f59e0b}.check-header{display:flex;align-items:center;gap:.75rem}.check-icon{font-size:1.25rem}.check-title{color:#f8fafc;font-weight:600;flex:1}.test-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;cursor:pointer;transition:transform .2s}.test-btn:hover{transform:scale(1.05)}.video-preview{margin-top:1rem;border-radius:8px;overflow:hidden;background:#0f172a}.video-preview video{width:100%;height:auto;display:block}.mic-level{margin-top:1rem}.mic-level-bar{height:8px;background:#475569;border-radius:4px;overflow:hidden}.mic-level-fill{height:100%;background:linear-gradient(90deg,#22c55e,#84cc16);transition:width .1s}.mic-hint{display:block;color:#94a3b8;font-size:.75rem;margin-top:.5rem}.hint{color:#94a3b8;font-size:.85rem;margin-top:.5rem}.error-msg{color:#ef4444;font-size:.85rem;margin-top:.5rem}.check-actions{margin-top:2rem;display:flex;flex-direction:column;gap:.75rem}.continue-btn{width:100%;padding:1rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;background:#475569;color:#94a3b8;transition:all .3s}.continue-btn:disabled{cursor:not-allowed;opacity:.7}.continue-btn.success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 4px 15px #22c55e4d}.continue-btn.success:hover{transform:translateY(-2px);box-shadow:0 6px 20px #22c55e66}.skip-btn{background:transparent;border:1px solid #475569;color:#94a3b8;padding:.75rem;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s}.skip-btn:hover{border-color:#64748b;color:#cbd5e1}.check-item.testing .check-icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.continue-btn.countdown-active{animation:countdown-pulse 1s ease-in-out infinite}@keyframes countdown-pulse{0%,to{transform:scale(1);box-shadow:0 4px 15px #22c55e4d}50%{transform:scale(1.02);box-shadow:0 8px 25px #22c55e80}}.exam-timer{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#1a365d,#2d3748);border-radius:1rem;box-shadow:0 4px 15px #0003;min-width:140px}.timer-display{display:flex;align-items:center;gap:.5rem}.timer-icon{font-size:1.25rem}.timer-value{font-size:1.75rem;font-weight:700;font-family:SF Mono,Monaco,Consolas,monospace;color:#fff;letter-spacing:.05em}.timer-progress{width:100%;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.timer-progress-bar{height:100%;background:linear-gradient(90deg,#22c55e,#4ade80);border-radius:2px;transition:width .1s linear}.timer-paused{font-size:.7rem;font-weight:600;color:#fbbf24;text-transform:uppercase;letter-spacing:.1em;animation:blink 1s infinite}.timer-warning .timer-value{color:#fbbf24}.timer-warning .timer-progress-bar{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.timer-critical .timer-value{color:#ef4444;animation:pulse-red .5s infinite}.timer-critical .timer-progress-bar{background:linear-gradient(90deg,#dc2626,#ef4444)}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.7}}.question-display{background:#fff;border-radius:1.25rem;box-shadow:0 4px 25px #00000014;overflow:hidden}.question-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#1a365d,#2d4a7c);color:#fff}.question-number{font-size:1rem;font-weight:600}.question-number .total{opacity:.7;font-weight:400}.doubt-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff26;border:none;border-radius:2rem;color:#fff;cursor:pointer;transition:all .2s ease;font-size:.85rem}.doubt-btn:hover{background:#ffffff40}.doubt-btn.active{background:#fbbf24;color:#92400e}.doubt-icon{font-size:1rem}.question-content{padding:1.5rem;border-bottom:1px solid #f3f4f6}.question-text{font-size:1.1rem;line-height:1.7;color:#1f2937}.question-text p{margin:0 0 1rem}.question-text p:last-child{margin-bottom:0}.question-image-container{margin-top:1rem}.image-placeholder{padding:2rem;background:#f9fafb;border-radius:.75rem;text-align:center;color:#9ca3af}.question-image{max-width:100%;border-radius:.75rem;box-shadow:0 2px 10px #0000001a}.options-list{padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.75rem}.option-btn{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.25rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:.75rem;cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.option-btn:hover{border-color:#3b82f6;background:#eff6ff}.option-btn.selected{border-color:#3b82f6;background:#dbeafe}.option-letter{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#e5e7eb;border-radius:50%;font-weight:600;color:#4b5563;transition:all .15s ease}.option-btn:hover .option-letter,.option-btn.selected .option-letter{background:#3b82f6;color:#fff}.option-content{flex-grow:1}.option-text{font-size:1rem;line-height:1.5;color:#374151}.option-image{max-width:200px;margin-top:.75rem;border-radius:.5rem}.option-check{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#3b82f6;border-radius:50%;color:#fff;font-weight:600;font-size:.85rem}.question-actions{display:flex;justify-content:space-between;padding:1rem 1.5rem;background:#f9fafb}.action-btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .15s ease}.action-btn.prev{background:#e5e7eb;color:#374151}.action-btn.prev:hover:not(:disabled){background:#d1d5db}.action-btn.next{background:#3b82f6;color:#fff}.action-btn.next:hover:not(:disabled){background:#2563eb}.action-btn.finish{background:#16a34a;color:#fff;font-weight:600;box-shadow:0 1px 2px #16a34a40}.action-btn.finish:hover:not(:disabled){background:#15803d}.action-btn.finish:focus-visible{outline:2px solid #86efac;outline-offset:2px}.action-btn:disabled{opacity:.5;cursor:not-allowed}.question-type-badge{display:inline-block;padding:.25rem .75rem;margin-left:.75rem;border-radius:1rem;font-size:.75rem;font-weight:600;text-transform:uppercase}.question-type-badge.essay{background:#8b5cf633;color:#a78bfa}.essay-answer-section{padding:1.5rem}.essay-label{display:block;font-size:.9rem;font-weight:600;color:#374151;margin-bottom:.75rem}.essay-textarea{width:100%;padding:1rem;border:2px solid #e5e7eb;border-radius:.75rem;font-size:1rem;line-height:1.7;resize:vertical;transition:border-color .2s,box-shadow .2s;font-family:inherit;box-sizing:border-box}.essay-textarea:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf626}.essay-textarea::placeholder{color:#9ca3af}.essay-meta{display:flex;justify-content:flex-end;padding-top:.5rem}.word-count{font-size:.8rem;color:#9ca3af}@media(max-width:640px){.question-header{flex-direction:column;gap:.75rem;align-items:flex-start}.doubt-btn{width:100%;justify-content:center}.option-btn{padding:.75rem 1rem}.option-letter{width:28px;height:28px;font-size:.85rem}.question-type-badge{display:block;margin:.5rem 0 0}}.question-navigation{background:#fff;border-radius:1rem;padding:1.25rem;box-shadow:0 4px 20px #00000014}.nav-header{margin-bottom:1rem}.nav-header h3{font-size:1rem;font-weight:600;color:#1a365d;margin:0 0 .5rem}.nav-stats{display:flex;gap:1rem;flex-wrap:wrap}.stat{font-size:.75rem;padding:.25rem .5rem;border-radius:1rem;font-weight:500}.stat.answered{background:#22c55e1a;color:#16a34a}.stat.doubt{background:#eab3081a;color:#ca8a04}.stat.remaining{background:#6b72801a;color:#4b5563}.nav-grid{display:flex;flex-direction:column;gap:.5rem}.nav-row{display:flex;gap:.5rem;flex-wrap:wrap}.nav-btn{width:36px;height:36px;border:2px solid #e5e7eb;border-radius:.5rem;background:#fff;color:#374151;font-weight:500;font-size:.85rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.nav-btn:hover{border-color:#3b82f6;background:#eff6ff}.nav-btn.active{border-color:#3b82f6;background:#3b82f6;color:#fff;transform:scale(1.05);box-shadow:0 2px 8px #3b82f64d}.nav-btn.answered{border-color:#22c55e;background:#dcfce7;color:#16a34a}.nav-btn.answered.active{background:#22c55e;color:#fff}.nav-btn.doubt{border-color:#eab308;background:#fef9c3;color:#a16207}.nav-btn.doubt.active{background:#eab308;color:#fff}.nav-legend{display:flex;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #f3f4f6;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:#6b7280}.legend-dot{width:12px;height:12px;border-radius:.25rem;border:2px solid}.legend-dot.answered{border-color:#22c55e;background:#dcfce7}.legend-dot.doubt{border-color:#eab308;background:#fef9c3}.legend-dot.unanswered{border-color:#e5e7eb;background:#fff}.connection-indicator{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:2rem;font-size:.85rem}.connection-status{display:flex;align-items:center;gap:.5rem;color:var(--status-color);font-weight:500}.status-icon{font-size:1rem}.sync-status{display:flex;align-items:center;gap:.5rem;color:#fffc;padding-left:1rem;border-left:1px solid rgba(255,255,255,.2)}.sync-dot{width:8px;height:8px;border-radius:50%;transition:background .3s ease}.sync-dot.synced{background:#22c55e}.sync-dot.pending{background:#eab308}.sync-dot.syncing{background:#3b82f6;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.sync-text{white-space:nowrap}.connection-online{color:#22c55e}.connection-slow{color:#eab308}.connection-offline{color:#ef4444}.sync-indicator{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.sync-indicator.syncing{background:#6366f133;color:#6366f1;border:1px solid rgba(99,102,241,.3)}.sync-indicator.pending{background:#f59e0b33;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.sync-indicator.error{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.sync-indicator.success{background:#22c55e33;color:#22c55e;border:1px solid rgba(34,197,94,.3);animation:fadeInOut 2s ease}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-5px)}15%{opacity:1;transform:translateY(0)}85%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-5px)}}.sync-spinner{width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}.sync-icon{font-size:.9rem}.sync-indicator.compact{padding:.25rem .5rem;font-size:.75rem}.sync-indicator.compact .sync-spinner{width:12px;height:12px}.chat-panel{display:flex;flex-direction:column;height:400px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;overflow:hidden;box-shadow:0 4px 15px #00000014}.chat-panel.loading{justify-content:center;align-items:center}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-weight:600;font-size:.95rem}.chat-status{font-size:.75rem;font-weight:500;opacity:.9;background:#fff3;padding:.25rem .6rem;border-radius:10px}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem;background:linear-gradient(180deg,#f8fafc,#f1f5f9)}.message{max-width:85%;padding:.625rem .875rem;border-radius:16px;font-size:.875rem;position:relative;animation:fadeInUp .2s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message.sent{align-self:flex-end;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-bottom-right-radius:4px;box-shadow:0 2px 8px #6366f140}.message.received{align-self:flex-start;background:#fff;color:#334155;border:1px solid #e2e8f0;border-bottom-left-radius:4px;box-shadow:0 2px 6px #0000000f}.message-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.25rem;font-size:.7rem}.message.sent .message-header{opacity:.85}.message.received .message-header{opacity:.6}.sender-name{font-weight:600;font-size:.72rem}.message-time{font-size:.65rem;opacity:.8}.message-content{word-wrap:break-word;line-height:1.45;min-height:1em}.message-content:empty{display:none}.message:has(.message-content:empty){display:none}.chat-input{display:flex;gap:.5rem;padding:.875rem;border-top:1px solid #e2e8f0;background:#fff}.chat-input .ant-input{flex:1;border-radius:20px;border:1px solid #e2e8f0;padding:.5rem 1rem;transition:border-color .2s,box-shadow .2s}.chat-input .ant-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf626}.chat-input .ant-btn{border-radius:50%;width:38px;height:38px;padding:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;transition:transform .2s,box-shadow .2s}.chat-input .ant-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #6366f166}.chat-messages .ant-empty{margin:auto;opacity:.7}.chat-messages .ant-empty-description{color:#64748b;font-size:.875rem}.chat-messages::-webkit-scrollbar{width:5px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media(max-width:480px){.chat-panel{height:350px}.message{max-width:90%}}.webcam-preview-inchat{width:100%;height:120px;border-radius:8px;object-fit:cover;border:2px solid #10b981;margin-bottom:8px}.chat-floating-btn{position:fixed;bottom:80px;right:20px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 20px #6366f166;transition:all .3s;z-index:1000;display:flex;align-items:center;justify-content:center}.chat-floating-btn:hover{transform:scale(1.1);box-shadow:0 6px 25px #6366f180}.chat-floating-btn.has-unread{animation:pulse-chat 2s infinite}@keyframes pulse-chat{0%{box-shadow:0 4px 20px #6366f166}50%{box-shadow:0 4px 30px #6366f1b3}to{box-shadow:0 4px 20px #6366f166}}.unread-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:.7rem;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px}.chat-overlay{position:fixed;bottom:0;right:0;width:100%;height:100%;background:#0000004d;z-index:1001;display:flex;justify-content:flex-end;align-items:flex-end;padding:20px}.chat-container{width:360px;max-width:100%;max-height:80vh;position:relative;animation:slide-up .3s ease}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-close-btn{position:absolute;top:-12px;right:-12px;width:28px;height:28px;border-radius:50%;background:#ef4444;color:#fff;border:none;font-size:1.2rem;cursor:pointer;z-index:1;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #0003}.chat-close-btn:hover{background:#dc2626}@media(max-width:480px){.chat-floating-btn{bottom:70px;right:16px;width:48px;height:48px;font-size:1.25rem}.chat-container{width:100%;max-height:70vh}.chat-overlay{padding:10px}}.exam-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);width:100%}.exam-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:linear-gradient(135deg,#1a365d,#2d4a7c);color:#fff;box-shadow:0 4px 15px #00000026}.header-left{flex:1}.exam-title{margin:0;font-size:1.25rem;font-weight:600}.header-center{flex:0 0 auto}.header-right{flex:1;display:flex;justify-content:flex-end}.exam-content{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;padding:1.5rem 2rem;max-width:1400px;margin:0 auto}.exam-main{min-width:0}.exam-sidebar{display:flex;flex-direction:column;gap:1rem}.submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:.75rem;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #22c55e4d}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #22c55e66}.exam-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a365d,#2d4a7c)}.loading-content{text-align:center;color:#fff}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}.loading-content h2{margin:0 0 .5rem;font-size:1.5rem}.loading-content p{margin:0 0 1.5rem;opacity:.8}.loading-bar{width:300px;height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin:0 auto .75rem}.loading-progress{height:100%;background:linear-gradient(90deg,#22c55e,#4ade80);border-radius:4px;transition:width .3s ease}.loading-percent{font-size:.875rem;opacity:.8}.exam-error{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a365d,#2d4a7c)}.error-content{text-align:center;color:#fff}.error-icon{font-size:4rem;display:block;margin-bottom:1rem}.error-content h2{margin:0 0 .5rem}.error-content p{margin:0 0 1.5rem;opacity:.8}.error-content button{padding:.75rem 2rem;background:#fff;border:none;border-radius:.5rem;color:#1a365d;font-weight:600;cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:1rem;padding:2rem;max-width:480px;width:90%;box-shadow:0 25px 50px #00000040}.modal-content h2{margin:0 0 1.5rem;text-align:center;color:#1a365d}.submit-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:1.5rem}.stat-item{text-align:center}.stat-value{display:block;font-size:2rem;font-weight:700;color:#22c55e}.stat-item.warning .stat-value{color:#ef4444}.stat-label{font-size:.85rem;color:#6b7280}.warning-text{text-align:center;color:#b45309;background:#fef3c7;padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1.5rem}.modal-actions{display:flex;gap:1rem}.cancel-btn,.confirm-btn{flex:1;padding:.875rem;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .15s ease}.cancel-btn{background:#f3f4f6;color:#374151}.confirm-btn{background:#22c55e;color:#fff}.confirm-btn:hover{background:#16a34a}.confirm-btn:disabled,.cancel-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:900px){.exam-content{grid-template-columns:1fr;padding:1rem}.exam-sidebar{order:-1}.exam-header{flex-wrap:wrap;gap:1rem;padding:1rem}.header-left,.header-center,.header-right{flex:none;width:100%}.header-center{order:-1}.header-right{justify-content:center}}.force-submit-modal .modal-content{text-align:center;background:linear-gradient(135deg,#1e293b,#0f172a);color:#fff;border:1px solid rgba(255,255,255,.1)}.force-submit-icon{font-size:4rem;margin-bottom:1rem;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.force-submit-modal h2{color:#ef4444;margin-bottom:1rem}.force-submit-reason{color:#f8fafc;font-size:1rem;margin-bottom:.5rem}.force-submit-redirect{color:#94a3b8;font-size:.9rem;margin-bottom:1.5rem}.force-submit-modal .confirm-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);width:100%}.result-page{--bg: #f8fafc;--surface: #ffffff;--surface-elev: #ffffff;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-muted: #475569;--text-subtle: #64748b;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-soft: #eff6ff;--success: #15803d;--success-soft: #f0fdf4;--success-border: #bbf7d0;--danger: #b91c1c;--danger-soft: #fef2f2;--danger-border: #fecaca;--warning: #b45309;--warning-soft: #fffbeb;--warning-border: #fde68a;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 3px rgba(15, 23, 42, .06);--shadow-md: 0 4px 6px -1px rgba(15, 23, 42, .06), 0 2px 4px -2px rgba(15, 23, 42, .06);--shadow-lg: 0 10px 25px -10px rgba(15, 23, 42, .18);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--duration: .18s;--ease: cubic-bezier(.16, 1, .3, 1);min-height:100vh;background:var(--bg);color:var(--text);padding:clamp(1rem,4vw,2.5rem) clamp(1rem,4vw,2rem);font-feature-settings:"ss01","cv11"}.result-header{max-width:880px;margin:0 auto 1.5rem;padding:0 .25rem}.result-header__eyebrow{margin:0 0 .5rem;font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle)}.result-header__title{margin:0;font-size:clamp(1.5rem,1.1rem + 1.5vw,2rem);font-weight:700;line-height:1.2;color:var(--text)}.result-header__meta{margin:.5rem 0 0;font-size:.9rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.result-content{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem}.result-loading{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-muted)}.result-loading__spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@media(prefers-reduced-motion:reduce){.result-loading__spinner{animation-duration:2s}}.result-state{max-width:560px;margin:4rem auto;padding:2.5rem 2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);text-align:center;display:flex;flex-direction:column;gap:.75rem;align-items:center}.result-state__icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.5rem;font-weight:700;background:var(--primary-soft);color:var(--primary)}.result-state--error .result-state__icon{background:var(--danger-soft);color:var(--danger)}.result-state--pending .result-state__icon{background:var(--warning-soft);color:var(--warning)}.result-state h2{margin:0;font-size:1.25rem;color:var(--text)}.result-state p{margin:0;color:var(--text-muted)}.score-hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.score-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--accent, transparent) 0%,transparent 60%);pointer-events:none;opacity:.5}.score-hero--excellent{--accent: rgba(34, 197, 94, .08);border-color:#bbf7d0}.score-hero--good{--accent: rgba(37, 99, 235, .08);border-color:#bfdbfe}.score-hero--average{--accent: rgba(245, 158, 11, .08);border-color:#fde68a}.score-hero--poor{--accent: rgba(220, 38, 38, .08);border-color:#fecaca}.score-hero__main{flex:1;min-width:0;position:relative}.score-hero__label{margin:0 0 .5rem;font-size:.85rem;font-weight:600;color:var(--text-subtle);letter-spacing:.02em}.score-hero__value{display:flex;align-items:baseline;gap:.25rem;line-height:1}.score-hero__number{font-size:clamp(3.5rem,2rem + 5vw,5rem);font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.score-hero__unit{font-size:1.5rem;font-weight:600;color:var(--text-muted)}.score-hero__caption{margin:.5rem 0 0;font-size:.95rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.score-hero__grade{width:110px;height:110px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:50%;background:var(--surface);border:2px solid;position:relative}.score-hero--excellent .score-hero__grade{border-color:#15803d;color:#15803d}.score-hero--good .score-hero__grade{border-color:#1d4ed8;color:#1d4ed8}.score-hero--average .score-hero__grade{border-color:#b45309;color:#b45309}.score-hero--poor .score-hero__grade{border-color:#b91c1c;color:#b91c1c}.score-hero__grade-letter{font-size:2.75rem;font-weight:700;line-height:1}.score-hero__grade-label{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-top:.25rem;color:var(--text-subtle)}@media(max-width:600px){.score-hero{flex-direction:column;align-items:flex-start;padding:1.5rem}.score-hero__grade{align-self:flex-end;width:88px;height:88px}.score-hero__grade-letter{font-size:2rem}}.pending-banner{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;background:var(--warning-soft);border:1px solid var(--warning-border);border-radius:var(--radius-md)}.pending-banner__icon{font-size:1.5rem;line-height:1;flex-shrink:0;margin-top:.1rem}.pending-banner__body{flex:1;min-width:0}.pending-banner__title{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:#78350f}.pending-banner__text{margin:0;font-size:.9rem;line-height:1.55;color:#92400e}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.125rem;display:flex;flex-direction:column;gap:.25rem;box-shadow:var(--shadow-sm)}.stat-card__label{font-size:.78rem;font-weight:600;color:var(--text-subtle);letter-spacing:.02em;text-transform:uppercase}.stat-card__value{font-size:1.5rem;font-weight:700;color:var(--text);line-height:1.1;font-variant-numeric:tabular-nums}.stat-card__unit{font-size:.95rem;font-weight:500;color:var(--text-muted);margin-left:.1rem}.stat-card__hint{font-size:.78rem;color:var(--text-subtle);margin-top:.1rem}.answers{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem clamp(1rem,3vw,1.75rem);box-shadow:var(--shadow-sm)}.answers__heading{margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:var(--text)}.answers__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.875rem}.answer-card{border:1px solid var(--border);border-left:4px solid var(--border-strong);border-radius:var(--radius-md);padding:1rem 1.125rem;background:var(--surface-elev);transition:border-color var(--duration) var(--ease)}.answer-card--correct{border-left-color:var(--success)}.answer-card--incorrect{border-left-color:var(--danger)}.answer-card--pending{border-left-color:var(--warning)}.answer-card__head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.625rem}.answer-card__num{font-size:.78rem;font-weight:600;color:var(--text-subtle);letter-spacing:.04em;text-transform:uppercase}.answer-card__status{font-size:.78rem;font-weight:600;padding:.25rem .625rem;border-radius:999px;border:1px solid transparent;white-space:nowrap}.answer-card__status--correct{color:var(--success);background:var(--success-soft);border-color:var(--success-border)}.answer-card__status--incorrect{color:var(--danger);background:var(--danger-soft);border-color:var(--danger-border)}.answer-card__status--pending{color:var(--warning);background:var(--warning-soft);border-color:var(--warning-border)}.answer-card__question{font-size:.95rem;line-height:1.55;color:var(--text);margin-bottom:.75rem}.answer-card__question :is(p,ul,ol){margin:0 0 .5rem}.answer-card__question :is(p,ul,ol):last-child{margin-bottom:0}.answer-card__rows{margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.answer-row{display:grid;grid-template-columns:130px 1fr;gap:.75rem;align-items:start}@media(max-width:540px){.answer-row{grid-template-columns:1fr;gap:.25rem}}.answer-row__label{font-size:.82rem;font-weight:600;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.04em;margin:0}.answer-row__value{margin:0;font-size:.95rem;line-height:1.5;color:var(--text);word-break:break-word}.answer-row__value--correct{color:var(--success);font-weight:600}.answer-row__value--incorrect{color:var(--danger);font-weight:600}.answer-row__value--pending{color:var(--warning);font-weight:600}.answer-row__essay{display:block;background:#f8fafc;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem .875rem;white-space:pre-wrap;font-size:.92rem;color:var(--text);font-weight:400;line-height:1.55}.answer-row__muted{color:var(--text-subtle);font-style:italic}.result-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;padding:0 1.25rem;font-size:.95rem;font-weight:600;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--text);cursor:pointer;transition:background var(--duration) var(--ease),border-color var(--duration) var(--ease),color var(--duration) var(--ease),transform var(--duration) var(--ease);flex:1;min-width:160px}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn:active{transform:translateY(1px)}.btn--primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn--primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn--secondary{background:var(--surface);color:var(--text);border-color:var(--border-strong)}.btn--secondary:hover{background:#f1f5f9}.btn__hint{font-size:.78rem;font-weight:500;color:var(--text-subtle);font-variant-numeric:tabular-nums}@media(prefers-reduced-motion:reduce){.btn{transition:none}.btn:active{transform:none}}.proctor-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fff,#f8fafc);padding:24px}.proctor-login .login-container{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;border:1px solid #e2e8f0;padding:40px;width:100%;max-width:400px}.proctor-login .login-header{text-align:center;margin-bottom:32px}.proctor-login .login-logo{width:80px;height:80px;object-fit:contain;margin:0 auto 16px;display:block}.proctor-login .login-header h1{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 8px;letter-spacing:-.02em}.proctor-login .login-header p{color:#64748b;margin:0;font-size:.9375rem}.proctor-login .login-form{display:flex;flex-direction:column;gap:20px}.proctor-login .error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:12px 16px;color:#dc2626;font-size:.875rem;display:flex;align-items:center;gap:10px}.proctor-login .error-message .anticon{font-size:1rem}.proctor-login .form-group{display:flex;flex-direction:column;gap:8px}.proctor-login .form-group label{font-weight:500;color:#475569;font-size:.875rem}.proctor-login .form-group input{padding:12px 16px;border:1px solid #e2e8f0;border-radius:10px;font-size:1rem;transition:all .2s ease;background:#f8fafc}.proctor-login .form-group input:focus{outline:none;border-color:#22c55e;background:#fff;box-shadow:0 0 0 3px #22c55e1a}.proctor-login .form-group input:disabled{background:#f1f5f9;color:#94a3b8}.proctor-login .submit-btn{background:#22c55e;color:#fff;border:none;padding:14px 20px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:8px}.proctor-login .submit-btn:hover:not(:disabled){background:#16a34a;transform:translateY(-1px);box-shadow:0 4px 12px #22c55e4d}.proctor-login .submit-btn:disabled{background:#94a3b8;cursor:not-allowed}.proctor-login .login-footer{text-align:center;margin-top:24px;padding-top:20px;border-top:1px solid #e2e8f0}.proctor-login .login-footer p{color:#94a3b8;font-size:.8125rem;margin:0}.proctor-login .back-link{display:inline-flex;align-items:center;gap:6px;color:#64748b;text-decoration:none;font-size:.875rem;margin-bottom:24px;transition:color .2s ease}.proctor-login .back-link:hover{color:#22c55e}.session-detail-modal{background:#fff;border-radius:16px;width:90%;max-width:600px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.session-detail-modal .modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.session-detail-modal .modal-header h2{margin:0;font-size:1.25rem}.session-detail-modal .modal-header p{margin:.25rem 0 0;opacity:.9;font-size:.9rem}.session-detail-modal .close-btn{background:#fff3;border:none;width:32px;height:32px;border-radius:50%;font-size:1.25rem;color:#fff;cursor:pointer;transition:background .2s}.session-detail-modal .close-btn:hover{background:#ffffff4d}.session-detail-modal .header-actions{display:flex;align-items:center;gap:.5rem}.session-detail-modal .live-view-btn{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;background:#ef4444e6;border:none;border-radius:6px;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.session-detail-modal .live-view-btn:hover{background:#ef4444;transform:scale(1.05)}.session-stats{display:flex;gap:1rem;padding:1rem 1.5rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.session-stats .stat{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff;border-radius:8px;flex:1}.session-stats .stat.warning{background:#fef3c7}.session-stats .stat-icon{font-size:1.25rem}.session-stats .stat-value{font-weight:600;color:#1e293b;display:block}.session-stats .stat-label{font-size:.75rem;color:#64748b}.detail-tabs{display:flex;padding:.5rem 1.5rem 0;gap:.5rem;background:#f8fafc}.detail-tabs button{padding:.6rem 1rem;border:none;background:transparent;color:#64748b;font-size:.85rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.detail-tabs button:hover{color:#475569}.detail-tabs button.active{color:#6366f1;border-bottom-color:#6366f1;font-weight:500}.tab-content{flex:1;overflow-y:auto;padding:1.5rem}.overview-tab .info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #f1f5f9}.overview-tab .label{color:#64748b}.overview-tab .value{font-weight:500;color:#1e293b}.overview-tab .status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.85rem}.overview-tab .status-badge.in_progress{background:#dcfce7;color:#166534}.overview-tab .status-badge.submitted{background:#dbeafe;color:#1e40af}.empty-violations{text-align:center;padding:2rem;color:#22c55e}.empty-violations span{font-size:2rem}.violations-list{display:flex;flex-direction:column;gap:.75rem}.violation-item{background:#fef2f2;padding:.75rem 1rem;border-radius:8px;border-left:3px solid #ef4444}.violation-header{display:flex;justify-content:space-between;align-items:center}.violation-type{font-weight:500;color:#dc2626}.violation-time{font-size:.8rem;color:#94a3b8}.violation-details{margin:.5rem 0 0;font-size:.85rem;color:#64748b}.answers-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:.5rem}.answer-item{width:100%;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:6px;font-size:.8rem;font-weight:500;position:relative}.answer-item.answered{background:#dcfce7;color:#166534}.answer-item.unanswered{background:#fee2e2;color:#dc2626}.answer-item.doubt{background:#fef3c7;color:#92400e}.answer-status{position:absolute;bottom:2px;font-size:.6rem}.answer-status.correct{color:#22c55e}.answer-status.incorrect{color:#ef4444}.answers-legend{display:flex;gap:1rem;justify-content:center;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.legend-item{font-size:.8rem;color:#64748b}.snapshots-tab .empty-state{text-align:center;padding:2rem;color:#94a3b8}.snapshots-tab .empty-state .icon{font-size:2.5rem;display:block;margin-bottom:.5rem}.snapshots-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.snapshot-item{background:#f8fafc;border-radius:8px;overflow:hidden;border:1px solid #e2e8f0}.snapshot-image{width:100%;height:100px;object-fit:cover;display:block}.snapshot-time{padding:.5rem;font-size:.75rem;color:#64748b;text-align:center;background:#fff}.session-detail-modal .modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;background:#f8fafc;border-top:1px solid #e2e8f0}.force-submit-btn{padding:.6rem 1.25rem;background:#f97316;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:background .2s}.force-submit-btn:hover{background:#ea580c}.close-action-btn{padding:.6rem 1.25rem;background:#e2e8f0;color:#475569;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:background .2s}.close-action-btn:hover{background:#cbd5e1}.force-submit-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;border-radius:16px}.force-submit-dialog{background:#fff;padding:1.5rem;border-radius:12px;width:90%;max-width:400px}.force-submit-dialog h3{margin:0 0 .5rem;color:#f97316}.force-submit-dialog p{margin:.5rem 0;color:#64748b}.force-submit-dialog .warning{color:#dc2626;font-weight:500}.force-submit-dialog .form-group{margin:1rem 0}.force-submit-dialog label{display:block;font-size:.9rem;color:#374151;margin-bottom:.5rem}.force-submit-dialog input{width:100%;padding:.6rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem}.dialog-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.dialog-actions .cancel-btn{padding:.5rem 1rem;background:#f1f5f9;color:#64748b;border:none;border-radius:6px;cursor:pointer}.dialog-actions .confirm-btn{padding:.5rem 1rem;background:#f97316;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500}.modal-loading,.modal-error{padding:3rem;text-align:center}.modal-loading .spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.modal-error span{font-size:2rem;display:block;margin-bottom:.5rem}.modal-error button{margin-top:1rem;padding:.5rem 1.5rem;background:#6366f1;color:#fff;border:none;border-radius:6px;cursor:pointer}.snapshot-lightbox{position:fixed;inset:0;background:#000000e6;z-index:10000;display:flex;align-items:center;justify-content:center;cursor:pointer;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.snapshot-lightbox-content{position:relative;max-width:90vw;max-height:90vh;cursor:default}.snapshot-lightbox-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 40px #00000080}.snapshot-lightbox-close{position:absolute;top:-15px;right:-15px;width:40px;height:40px;border-radius:50%;background:#ef4444;color:#fff;border:none;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #0000004d;transition:transform .2s,background .2s}.snapshot-lightbox-close:hover{background:#dc2626;transform:scale(1.1)}.snapshot-image{transition:transform .2s,box-shadow .2s}.snapshot-image:hover{transform:scale(1.05);box-shadow:0 4px 15px #0000004d}.snapshot-gallery{display:flex;flex-direction:column;gap:16px;padding:16px 0}.snapshot-gallery__filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.snapshot-gallery__filter-btn{padding:6px 14px;border-radius:999px;border:1px solid #d1d5db;background:#fff;cursor:pointer;font-size:.875rem;transition:all .15s}.snapshot-gallery__filter-btn.active{background:#1e40af;color:#fff;border-color:#1e40af}.snapshot-gallery__count{margin-left:auto;color:#6b7280;font-size:.875rem}.snapshot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.snapshot-card{aspect-ratio:4 / 3;border:3px solid var(--card-border, #10b981);border-radius:8px;overflow:hidden;position:relative;cursor:pointer;background:#f3f4f6;transition:transform .15s ease}.snapshot-card:hover{transform:scale(1.02)}.snapshot-card--alert{--card-border: #dc2626;animation:snapshot-pulse 1.4s ease-in-out infinite}.snapshot-card--idle{--card-border: #f59e0b}.snapshot-card--active{--card-border: #10b981}.snapshot-card--submitted{--card-border: #6b7280;opacity:.55}@keyframes snapshot-pulse{0%,to{box-shadow:0 0 #dc262680}50%{box-shadow:0 0 0 6px #dc262600}}.snapshot-card__img,.snapshot-card__placeholder{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.snapshot-card__placeholder{display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:.75rem;text-align:center;padding:8px}.snapshot-card__overlay{position:absolute;left:0;right:0;bottom:0;padding:6px 8px;background:linear-gradient(to top,#000000bf,#0000);color:#fff;font-size:.75rem;line-height:1.2}.snapshot-card__name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.snapshot-card__meta{display:flex;justify-content:space-between;color:#d1d5db;margin-top:2px}.snapshot-card__badge{position:absolute;top:6px;right:6px;background:#dc2626;color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:999px}.snapshot-card__stale{position:absolute;top:6px;left:6px;background:#f59e0beb;color:#fff;font-size:.65rem;font-weight:600;padding:2px 6px;border-radius:4px}.snapshot-gallery__empty{text-align:center;color:#6b7280;padding:48px 16px}.monitoring-dashboard{min-height:100vh;background:#f8fafc;color:#0f172a}.monitoring-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px clamp(12px,3vw,24px);background:#fff;border-bottom:1px solid #e2e8f0;flex-wrap:wrap}.monitoring-pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:currentColor;margin-right:6px;animation:monitoring-pulse 1.6s ease-in-out infinite;vertical-align:middle}@keyframes monitoring-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}@media(prefers-reduced-motion:reduce){.monitoring-pulse{animation:none}}.monitoring-stats{padding:16px clamp(12px,3vw,24px) 0}.exam-info-bar{padding:8px clamp(12px,3vw,24px);background:#f8fafc;border-bottom:1px solid #e2e8f0}.monitoring-tabs{padding:16px clamp(12px,3vw,24px) 0}.ranking-section,.sessions-section{padding:1.5rem 2rem}.sessions-table-wrapper{overflow-x:auto;border-radius:12px;background:#fff;border:1px solid #e2e8f0}.sessions-table{width:100%;border-collapse:collapse}.sessions-table th{text-align:left;padding:1rem 1.25rem;background:#f1f5f9;font-size:.75rem;text-transform:uppercase;color:#64748b;font-weight:600;letter-spacing:.5px}.sessions-table td{padding:1rem 1.25rem;border-top:1px solid #e2e8f0;color:#0f172a}.sessions-table tr:hover{background:#f8fafc}.student-cell{min-width:180px}.student-info{display:flex;flex-direction:column}.student-name{font-weight:600;display:flex;align-items:center;gap:.5rem}.student-id{font-size:.75rem;color:#64748b}.progress-cell{display:flex;align-items:center;gap:.75rem}.progress-text{font-size:.8rem;color:#64748b}@media(max-width:768px){.sessions-section{padding:1rem}}.sessions-table tr.clickable{cursor:pointer;transition:background .2s}.sessions-table tr.clickable:hover{background:#f1f5f9}.not-started-section{padding:16px clamp(12px,3vw,24px)}.not-started-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}.dashboard-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fff,#f8fafc);padding:24px}.dashboard-login .login-container{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;border:1px solid #e2e8f0;padding:40px;width:100%;max-width:420px}.dashboard-login .login-header{text-align:center;margin-bottom:28px}.dashboard-login .login-logo{width:80px;height:80px;object-fit:contain;margin:0 auto 16px;display:block}.dashboard-login .login-header h1{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 8px;letter-spacing:-.02em}.dashboard-login .login-header p{color:#64748b;margin:0;font-size:.9375rem}.dashboard-login .role-tabs{display:flex;gap:10px;margin-bottom:24px}.dashboard-login .role-tab{flex:1;padding:12px 16px;border:1px solid #e2e8f0;background:#f8fafc;border-radius:10px;cursor:pointer;font-size:.875rem;font-weight:500;color:#64748b;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.dashboard-login .role-tab:hover{border-color:#a855f7;color:#a855f7;background:#faf5ff}.dashboard-login .role-tab.active{border-color:#a855f7;background:#a855f7;color:#fff}.dashboard-login .role-tab .anticon{font-size:1.125rem}.dashboard-login .login-form{display:flex;flex-direction:column;gap:20px}.dashboard-login .error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:12px 16px;color:#dc2626;font-size:.875rem;display:flex;align-items:center;gap:10px}.dashboard-login .error-message .anticon{font-size:1rem}.dashboard-login .form-group{display:flex;flex-direction:column;gap:8px}.dashboard-login .form-group label{font-weight:500;color:#475569;font-size:.875rem}.dashboard-login .form-group input{padding:12px 16px;border:1px solid #e2e8f0;border-radius:10px;font-size:1rem;transition:all .2s ease;background:#f8fafc}.dashboard-login .form-group input:focus{outline:none;border-color:#a855f7;background:#fff;box-shadow:0 0 0 3px #a855f71a}.dashboard-login .form-group input:disabled{background:#f1f5f9;color:#94a3b8}.dashboard-login .submit-btn{background:#a855f7;color:#fff;border:none;padding:14px 20px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:8px}.dashboard-login .submit-btn:hover:not(:disabled){background:#9333ea;transform:translateY(-1px);box-shadow:0 4px 12px #a855f74d}.dashboard-login .submit-btn:disabled{background:#94a3b8;cursor:not-allowed}.dashboard-login .login-footer{text-align:center;margin-top:24px;padding-top:20px;border-top:1px solid #e2e8f0}.dashboard-login .login-footer p{color:#94a3b8;font-size:.8125rem;margin:0}.dashboard-login .back-link{display:inline-flex;align-items:center;gap:6px;color:#64748b;text-decoration:none;font-size:.875rem;margin-bottom:24px;transition:color .2s ease}.dashboard-login .back-link:hover{color:#a855f7}.setup-progress{display:inline-flex;align-items:center;gap:6px}.setup-progress__dot{width:24px;height:24px;padding:7px;border:none;background:transparent;cursor:pointer;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.setup-progress__dot:focus-visible{outline:2px solid var(--color-ring, #1E40AF);outline-offset:2px}.setup-progress__dot:before{content:"";width:10px;height:10px;border-radius:50%;transition:transform .18s ease-out,background-color .18s ease-out;background:var(--color-muted, #cbd5e1)}.setup-progress__dot--ready:before{background:var(--color-success, #16a34a)}.setup-progress__dot--missing:before{background:var(--color-warning, #d97706)}.setup-progress__dot:hover:before{transform:scale(1.2)}@media(prefers-reduced-motion:reduce){.setup-progress__dot:before{transition:none}.setup-progress__dot:hover:before{transform:none}}.import-container{padding:1.5rem}.import-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.import-header h3{margin:0;color:#1a365d}.template-btn{padding:.5rem 1rem;background:#f3f4f6;border:none;border-radius:.5rem;cursor:pointer;font-weight:500;color:#374151;transition:all .15s}.template-btn:hover{background:#e5e7eb}.drop-zone{border:2px dashed #d1d5db;border-radius:1rem;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s;background:#f9fafb}.drop-zone:hover{border-color:#3b82f6;background:#eff6ff}.drop-zone.drag-over{border-color:#3b82f6;background:#dbeafe;transform:scale(1.02)}.drop-zone.has-file{border-style:solid;border-color:#22c55e;background:#f0fdf4}.drop-prompt .upload-icon{font-size:3rem;display:block;margin-bottom:1rem}.drop-prompt p{margin:0;color:#6b7280}.drop-prompt .sub{font-size:.85rem;color:#9ca3af;margin-top:.5rem}.file-info{display:flex;flex-direction:column;align-items:center;gap:.5rem}.file-icon{font-size:2.5rem}.file-name{font-weight:600;color:#1a365d}.file-action{font-size:.85rem;color:#6b7280}.parsing{display:flex;flex-direction:column;align-items:center;gap:1rem}.parsing .spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.errors{margin-top:1.5rem;padding:1rem;background:#fef2f2;border-radius:.75rem;border:1px solid #fee2e2}.errors h4{margin:0 0 .75rem;color:#dc2626;font-size:.9rem}.errors ul{margin:0;padding-left:1.25rem}.errors li{color:#b91c1c;font-size:.85rem;margin-bottom:.25rem}.errors .row{font-weight:600;margin-right:.5rem}.preview{margin-top:1.5rem}.preview h4{margin:0 0 1rem;color:#16a34a}.preview-table{overflow-x:auto;border:1px solid #e5e7eb;border-radius:.75rem}.preview-table table{width:100%;border-collapse:collapse;font-size:.85rem}.preview-table th,.preview-table td{padding:.75rem;text-align:left;border-bottom:1px solid #f3f4f6}.preview-table th{background:#f9fafb;font-weight:600;color:#374151}.preview-table .question-cell{max-width:200px}.preview-table .answer{font-weight:700;color:#16a34a;text-align:center}.preview .more{text-align:center;color:#6b7280;font-size:.85rem;margin:.75rem 0 0}.import-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #f3f4f6}.cancel-btn{padding:.75rem 1.5rem;background:#f3f4f6;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;color:#374151}.cancel-btn:hover{background:#e5e7eb}.import-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:.5rem;font-weight:600;cursor:pointer;color:#fff;transition:all .15s}.import-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #22c55e66}.import-btn:disabled{opacity:.5;cursor:not-allowed}.shared-bank-browser{display:flex;flex-direction:column;gap:16px;padding:12px 0}.shared-bank-browser__tabs{display:flex;gap:4px;border-bottom:1px solid #e5e7eb}.shared-bank-browser__tab{padding:8px 14px;border:none;background:transparent;color:#6b7280;cursor:pointer;font-size:.9rem;border-bottom:2px solid transparent;display:inline-flex;align-items:center;gap:6px}.shared-bank-browser__tab.active{color:#1e40af;border-bottom-color:#1e40af;font-weight:600}.shared-bank-browser__quiz-toolbar{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;align-items:center;padding:4px 0 8px}.shared-bank-browser__import-bar{position:sticky;bottom:0;background:#1e40af;color:#fff;padding:10px 14px;border-radius:8px;display:flex;justify-content:space-between;align-items:center;z-index:5}.shared-bank-browser__preview-list{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:12px;max-height:60vh;overflow-y:auto}.shared-bank-browser__preview-list>li{border:1px solid #e5e7eb;border-radius:8px;padding:10px 12px;background:#fafafa}.shared-bank-browser__preview-q{display:flex;gap:8px;align-items:flex-start;line-height:1.45;color:#111827;font-size:.92rem}.shared-bank-browser__preview-options{margin:8px 0 0;padding-left:18px;color:#4b5563;font-size:.85rem;display:flex;flex-direction:column;gap:2px}.question-bank-manager{padding:1.5rem 2rem;max-width:1400px;margin:0 auto}.bank-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.bank-header h2{margin:0;font-size:1.5rem;color:#1f2937}.create-btn{padding:.75rem 1.25rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.create-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.bank-layout{display:grid;grid-template-columns:350px 1fr;gap:1.5rem;min-height:500px}.banks-list{display:flex;flex-direction:column;gap:.75rem}.bank-card{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;cursor:pointer;transition:all .2s}.bank-card:hover{border-color:#3b82f6}.bank-card.selected{border-color:#3b82f6;background:#eff6ff}.bank-info h4{margin:0 0 .5rem;font-size:1rem;color:#1f2937}.bank-meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.badge{padding:.25rem .5rem;border-radius:1rem;font-size:.7rem;font-weight:600}.badge.subject{background:#dbeafe;color:#1d4ed8}.badge.grade{background:#fef3c7;color:#92400e}.question-count{font-size:.8rem;color:#6b7280}.empty-state button{margin-top:1rem;padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;cursor:pointer}.questions-panel{background:#fff;border-radius:1rem;box-shadow:0 4px 15px #00000014;overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:linear-gradient(135deg,#1a365d,#2d4a7c);color:#fff}.add-question-btn{padding:.5rem 1rem;background:#fff3;color:#fff;border:none;border-radius:.5rem;cursor:pointer}.add-question-btn:hover{background:#ffffff4d}.no-selection,.empty-questions{display:flex;align-items:center;justify-content:center;padding:3rem;color:#9ca3af;min-height:400px}.questions-list{padding:1rem;display:flex;flex-direction:column;gap:1rem;max-height:600px;overflow-y:auto}.question-item{padding:1rem;background:#f9fafb;border-radius:.75rem}.question-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.question-number{font-weight:600;color:#6b7280}.difficulty-badge{padding:.2rem .5rem;border-radius:1rem;font-size:.65rem;color:#fff;font-weight:600;text-transform:uppercase}.points{font-size:.8rem;color:#6b7280;margin-left:auto}.question-content{font-size:.95rem;line-height:1.5;color:#374151;margin-bottom:.75rem}.options-preview{display:flex;flex-wrap:wrap;gap:.5rem}.options-preview .option{padding:.25rem .5rem;background:#e5e7eb;border-radius:.25rem;font-size:.75rem;color:#4b5563}.options-preview .option.correct{background:#dcfce7;color:#166534;font-weight:600}.tags{display:flex;gap:.25rem;margin-top:.75rem}.tag{padding:.2rem .5rem;background:#f3e8ff;color:#7c3aed;border-radius:1rem;font-size:.7rem}.bank-modal{max-width:500px}.bank-modal textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;resize:vertical;font-family:inherit;font-size:.9rem;box-sizing:border-box}.bank-loading{padding:3rem;text-align:center;color:#6b7280}@media(max-width:900px){.bank-layout{grid-template-columns:1fr}.banks-list{max-height:300px;overflow-y:auto}}.exam-period-manager{padding:1.5rem 2rem;max-width:1400px;margin:0 auto}.period-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.period-header h2{margin:0;font-size:1.5rem;color:#1f2937}.period-layout{display:grid;grid-template-columns:350px 1fr;gap:1.5rem;min-height:500px}.periods-list{display:flex;flex-direction:column;gap:.75rem}.period-card{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;cursor:pointer;transition:all .2s}.period-card:hover{border-color:#f59e0b}.period-card.selected{border-color:#f59e0b;background:#fffbeb}.period-info h4{margin:0 0 .5rem;font-size:1rem;color:#1f2937}.period-meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:.5rem}.date-range{font-size:.8rem;color:#6b7280}.status-badge{padding:.2rem .5rem;border-radius:1rem;font-size:.7rem;font-weight:600}.status-badge.upcoming{background:#dbeafe;color:#1d4ed8}.status-badge.active{background:#dcfce7;color:#16a34a}.status-badge.ended{background:#f3f4f6;color:#6b7280}.token-count{font-size:.8rem;color:#f59e0b;font-weight:600}.delete-btn{background:none;border:none;font-size:1rem;cursor:pointer;opacity:.5;transition:opacity .2s}.delete-btn:hover{opacity:1}.tokens-panel{background:#fff;border-radius:1rem;box-shadow:0 4px 15px #00000014;overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.panel-header h3{margin:0;font-size:1rem}.panel-actions{display:flex;gap:.5rem}.generate-btn,.print-btn{padding:.5rem 1rem;background:#fff3;color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.85rem}.generate-btn:hover,.print-btn:hover{background:#ffffff4d}.no-selection,.empty-tokens{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#9ca3af;min-height:400px}.empty-tokens button,.empty-state button{margin-top:1rem;padding:.5rem 1rem;background:#f59e0b;color:#fff;border:none;border-radius:.5rem;cursor:pointer}.tokens-table{padding:1rem;max-height:600px;overflow-y:auto}.tokens-table table{width:100%;border-collapse:collapse}.tokens-table th,.tokens-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #f3f4f6}.tokens-table th{background:#f9fafb;font-weight:600;color:#374151;font-size:.85rem}.token-cell{font-family:monospace;font-weight:600;color:#d97706;background:#fffbeb;padding:.25rem .5rem;border-radius:.25rem}.period-modal,.generate-modal{max-width:500px}.generate-modal textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-family:monospace;font-size:.9rem;resize:vertical;box-sizing:border-box}.generate-modal small{display:block;margin-top:.5rem;color:#6b7280;font-size:.8rem}.empty-state{padding:2rem;text-align:center;color:#6b7280;background:#f9fafb;border-radius:.75rem}.period-loading{padding:3rem;text-align:center;color:#6b7280}@media(max-width:900px){.period-layout{grid-template-columns:1fr}.periods-list{max-height:300px;overflow-y:auto}}.generate-modal{max-width:600px}.filter-row{display:flex;gap:.75rem;margin-bottom:1rem}.filter-row select{flex:1;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9rem;background:#fff}.bulk-actions{display:flex;gap:.5rem;margin-bottom:1rem}.select-all-btn{padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:.85rem}.deselect-btn{padding:.5rem 1rem;background:#e5e7eb;color:#374151;border:none;border-radius:.5rem;cursor:pointer;font-size:.85rem}.rombel-list{max-height:300px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:1rem}.rombel-card{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid #f3f4f6;transition:all .15s}.rombel-card:last-child{border-bottom:none}.rombel-card:hover{background:#f9fafb}.rombel-card.selected{background:#eff6ff;border-color:#bfdbfe}.rombel-check input[type=checkbox]{width:18px;height:18px;cursor:pointer}.rombel-info{flex:1}.rombel-info strong{display:block;color:#1f2937;margin-bottom:.25rem}.rombel-meta{display:flex;gap:.5rem;flex-wrap:wrap}.class-badge{padding:.15rem .5rem;background:#dbeafe;color:#1d4ed8;border-radius:1rem;font-size:.7rem;font-weight:600}.major-badge{padding:.15rem .5rem;background:#fef3c7;color:#b45309;border-radius:1rem;font-size:.7rem;font-weight:600}.student-count{font-size:.8rem;color:#6b7280}.loading-state{padding:2rem;text-align:center;color:#9ca3af}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid #e5e7eb}.selection-info{font-size:.9rem;color:#6b7280}.selection-info strong{color:#1f2937}.error-message{padding:.75rem;background:#fee2e2;color:#dc2626;border-radius:.5rem;margin-bottom:1rem;font-size:.9rem}.user-management{padding:1.5rem}.user-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.header-info h2{font-size:1.5rem;margin:0;color:#1e293b}.header-info p{color:#64748b;margin:.25rem 0 0;font-size:.9rem}.user-loading{text-align:center;padding:3rem;color:#64748b}.filter-bar{display:flex;gap:1rem;align-items:center;margin-bottom:1rem;padding:.75rem 1rem;background:#f8fafc;border-radius:8px}.filter-select{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer}.user-count{color:#64748b;font-size:.85rem}.user-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.user-table th{text-align:left;padding:1rem;background:#f1f5f9;font-weight:600;color:#475569;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.user-table td{padding:1rem;border-top:1px solid #e2e8f0;vertical-align:middle}.user-table tr.inactive td{opacity:.6}.user-table tr:hover td{background:#f8fafc}.user-name{display:flex;align-items:center;gap:.75rem}.user-name .avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem}.user-name strong{display:block;color:#1e293b}.user-name small{color:#94a3b8;font-size:.8rem}.role-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500}.role-badge.operator{background:#fef3c7;color:#92400e}.role-badge.proctor{background:#dbeafe;color:#1e40af}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;cursor:pointer;transition:transform .15s,opacity .15s}.status-badge:hover{transform:scale(1.05)}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.inactive{background:#fee2e2;color:#991b1b}.action-buttons{display:flex;gap:.5rem}.action-btn{padding:.4rem .75rem;border:none;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .2s}.action-btn.edit{background:#f1f5f9;color:#475569}.action-btn.edit:hover{background:#e2e8f0}.action-btn.delete{background:#fee2e2;color:#dc2626}.action-btn.delete:hover{background:#fecaca}.empty-state{text-align:center;padding:4rem 2rem;background:#f8fafc;border-radius:12px}.empty-icon{font-size:3rem;opacity:.5}.empty-state p{color:#64748b;margin-top:1rem}.user-modal{max-width:500px}.user-modal .form-group{margin-bottom:1.25rem}.user-modal label{display:block;font-weight:500;color:#374151;margin-bottom:.5rem;font-size:.9rem}.user-modal input[type=text],.user-modal input[type=email],.user-modal input[type=password],.user-modal input[type=tel]{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s}.user-modal input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.user-modal input:disabled{background:#f3f4f6;cursor:not-allowed}.role-selector{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.role-option{display:block;padding:1rem;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .2s}.role-option:hover{border-color:#c7d2fe;background:#f8fafc}.role-option.selected{border-color:#6366f1;background:#eef2ff}.role-option input[type=radio]{display:none}.role-info{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.25rem}.role-icon{font-size:1.5rem}.role-name{font-weight:600;color:#1e293b}.role-info small{font-size:.75rem;color:#64748b}.checkbox-label{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400!important}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#6366f1}.error-message{background:#fee2e2;color:#dc2626;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.user-modal .modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e2e8f0}.spacer{flex:1}.reset-pwd-btn{padding:.6rem 1rem;border:1px solid #e2e8f0;background:#fff;border-radius:8px;color:#64748b;cursor:pointer;font-size:.85rem;transition:all .2s}.reset-pwd-btn:hover{background:#f1f5f9;color:#475569}.image-upload{margin:.5rem 0}.upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:1.5rem;border:2px dashed rgba(99,102,241,.3);border-radius:8px;background:#6366f10d;cursor:pointer;transition:all .2s}.upload-area:hover{border-color:#6366f180;background:#6366f11a}.upload-icon{font-size:2rem}.upload-text{font-weight:600;color:#6366f1}.upload-hint{font-size:.75rem;color:#94a3b8}.uploading{display:flex;align-items:center;gap:.5rem;color:#6366f1}.uploading .spinner{width:20px;height:20px;border:2px solid rgba(99,102,241,.2);border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite}.image-preview{position:relative;display:inline-block}.image-preview img{max-width:100%;max-height:200px;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.image-preview .remove-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;background:#ef4444;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s}.image-preview .remove-btn:hover{background:#dc2626;transform:scale(1.1)}.upload-error{margin-top:.5rem;padding:.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:4px;color:#ef4444;font-size:.85rem}.section-target{border-radius:8px}@keyframes sectionPulse{0%{box-shadow:0 0 #d9770600}20%{box-shadow:0 0 0 10px #d9770652}to{box-shadow:0 0 #d9770600}}.section-pulse{animation:sectionPulse 1.6s ease-out 1}@media(prefers-reduced-motion:reduce){.section-pulse{animation:none}}.essay-grading{--bg: #f8fafc;--surface: #ffffff;--border: #e2e8f0;--text: #0f172a;--text-muted: #475569;--primary: #2563eb;background:var(--bg);min-height:calc(100vh - 64px)}.essay-grading__loading,.essay-grading__empty,.essay-grading__done{min-height:calc(100vh - 200px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;padding:2rem}.essay-grading__done-icon{font-size:64px;color:#16a34a}.essay-grading__header{display:flex;align-items:center;gap:1rem;padding:12px 24px;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap}.essay-grading__title{flex:1;min-width:0}.essay-grading__layout{background:var(--bg);min-height:calc(100vh - 120px)}.essay-grading__sider{background:var(--surface)!important;border-right:1px solid var(--border)}.essay-grading__sider-head{padding:12px 16px;border-bottom:1px solid var(--border)}.essay-grading__students{list-style:none;margin:0;padding:8px;display:flex;flex-direction:column;gap:6px;max-height:calc(100vh - 200px);overflow-y:auto}.essay-student{padding:10px 12px;border-radius:8px;cursor:pointer;border:1px solid transparent;transition:background .15s ease,border-color .15s ease;display:flex;flex-direction:column;gap:4px}.essay-student:hover{background:#f1f5f9}.essay-student:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.essay-student--active{background:#eff6ff;border-color:#bfdbfe}.essay-student__row1{display:flex;align-items:center;justify-content:space-between;gap:8px}.essay-grading__content{padding:24px clamp(16px,4vw,32px);background:var(--surface);margin:16px;border-radius:12px;border:1px solid var(--border);overflow-y:auto;max-height:calc(100vh - 152px)}.essay-grading__nav{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:20px}.essay-grading__question-text{font-size:16px;line-height:1.6;color:var(--text);margin-top:8px}.essay-grading__answer-text{margin:8px 0 0;background:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:12px 14px;white-space:pre-wrap;font-family:inherit;font-size:14px;line-height:1.6;color:var(--text)}.essay-grading__grade{margin-top:20px;display:flex;flex-direction:column;gap:14px;background:#f8fafc;border:1px solid var(--border);border-radius:12px;padding:16px}.essay-grading__score,.essay-grading__feedback{display:flex;flex-direction:column;gap:6px}.essay-grading__actions{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}@media(max-width:768px){.essay-grading__sider{display:none}.essay-grading__content{margin:8px}}.token-print-page{min-height:100vh;background:#f8fafc}.print-controls{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;position:sticky;top:0;z-index:100}.print-info h1{margin:0 0 .5rem;font-size:1.5rem}.print-info p{margin:.25rem 0;opacity:.9}.card-count{font-weight:600;font-size:1.1rem;margin-top:.5rem!important}.print-actions{display:flex;gap:1rem}.back-btn{padding:.75rem 1.5rem;background:#fff3;color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.back-btn:hover{background:#ffffff4d}.print-btn{padding:.75rem 2rem;background:#fff;color:#d97706;border:none;border-radius:.5rem;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.print-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.token-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:2rem;max-width:1400px;margin:0 auto}.token-card{background:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 4px 15px #0000001a;break-inside:avoid;page-break-inside:avoid}.card-header{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center}.school-name{font-weight:700;font-size:.85rem;letter-spacing:.5px}.period-name{font-size:.75rem;opacity:.9}.card-body{padding:1rem}.student-info{margin-bottom:1rem}.info-row{display:flex;margin-bottom:.5rem}.info-row .label{width:50px;color:#6b7280;font-size:.8rem}.info-row .value{flex:1;color:#1f2937;font-weight:500;font-size:.9rem}.token-section{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:.75rem;padding:1rem;text-align:center;border:2px dashed #f59e0b}.token-label{display:block;font-size:.7rem;color:#92400e;font-weight:600;margin-bottom:.25rem;letter-spacing:1px}.token-value{display:block;font-family:Courier New,monospace;font-size:1.5rem;font-weight:700;color:#b45309;letter-spacing:2px}.card-footer{background:#f3f4f6;padding:.5rem 1rem;text-align:center;color:#6b7280;font-size:.75rem}.print-loading,.print-error,.print-empty{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#6b7280}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#f59e0b;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.print-error button,.print-empty button{padding:.75rem 1.5rem;background:#f59e0b;color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer}@media print{.no-print{display:none!important}.token-print-page{background:#fff}.token-cards-grid{padding:0;gap:.75rem;grid-template-columns:repeat(3,1fr)}.token-card{box-shadow:none;border:1px solid #d1d5db;break-inside:avoid;page-break-inside:avoid}@page{size:A4;margin:1cm}}.landing-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fff,#f8fafc);padding:2rem;width:100%}.landing-content{max-width:800px;width:100%;margin:0 auto}.landing-page .logo-section{text-align:center;color:#1e293b;margin-bottom:3.5rem}.landing-page .logo-icon{font-size:3rem;display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 1.25rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:20px;box-shadow:0 4px 12px #3b82f640}.landing-page .logo-section h1{font-size:2rem;font-weight:700;margin-bottom:.5rem;color:#1e293b;letter-spacing:-.02em}.landing-page .subtitle{color:#64748b;font-size:1rem;font-weight:400}.portal-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:3rem}@media(max-width:768px){.portal-cards{grid-template-columns:1fr;gap:1rem}}.portal-card{background:#fff;border-radius:12px;padding:1.75rem 1.5rem;text-align:center;text-decoration:none;color:inherit;transition:all .2s ease;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;border:1px solid #e2e8f0}.portal-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a;border-color:transparent}.portal-icon{font-size:1.75rem;display:flex;align-items:center;justify-content:center;width:56px;height:56px;margin:0 auto 1rem;border-radius:12px;transition:transform .2s ease}.portal-card:hover .portal-icon{transform:scale(1.05)}.student-portal .portal-icon{background:#eff6ff;color:#3b82f6}.proctor-portal .portal-icon{background:#f0fdf4;color:#22c55e}.admin-portal .portal-icon{background:#faf5ff;color:#a855f7}.portal-card h2{font-size:1.125rem;font-weight:600;margin:0 0 .375rem;color:#1e293b}.portal-card p{color:#64748b;margin:0;font-size:.875rem;line-height:1.4}.landing-page .features{display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;padding-top:1rem;border-top:1px solid #e2e8f0}.landing-page .feature{display:flex;align-items:center;gap:.625rem;color:#64748b}.landing-page .feature-icon{font-size:1.125rem;display:flex;align-items:center;color:#94a3b8}.landing-page .feature-text h3{font-size:.875rem;font-weight:500;margin:0;color:#475569}.landing-page .feature-text p{font-size:.75rem;margin:0;color:#94a3b8}@media(max-width:640px){.landing-page .features{flex-direction:column;align-items:center;gap:1rem}}.exam-home,.proctor-home{min-height:100vh;background:#f5f7fa}.exam-header,.proctor-header{background:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.exam-header h1,.proctor-header h1{margin:0;font-size:1.3rem}.user-info{display:flex;align-items:center;gap:1rem}.logout-btn{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-weight:600}.exam-content,.proctor-content{padding:2rem;max-width:1200px;margin:0 auto}.exam-placeholder,.proctor-placeholder{background:#fff;border-radius:12px;padding:3rem;text-align:center;color:#888;margin-top:2rem}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f7fa;font-size:1.2rem;color:#666}.home-page .demo-card h2{color:var(--primary);margin-bottom:.75rem}.home-page .demo-card p{color:var(--text-light);margin-bottom:1.5rem}.home-page .start-btn{display:inline-block;padding:1rem 2.5rem;background:linear-gradient(135deg,var(--success) 0%,#16a34a 100%);color:var(--white);text-decoration:none;border-radius:.75rem;font-weight:600;font-size:1.1rem;transition:all .2s ease;box-shadow:0 10px 30px #22c55e4d}.home-page .start-btn:hover{transform:translateY(-3px);box-shadow:0 15px 40px #22c55e66}.home-page .features{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.home-page .feature{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:1rem;padding:1.25rem;text-align:center;color:var(--white)}.home-page .feature-icon{font-size:2rem;display:block;margin-bottom:.5rem}.home-page .feature h3{font-size:.9rem;font-weight:600;margin-bottom:.25rem}.home-page .feature p{font-size:.75rem;opacity:.8}.home-page .admin-link{display:block;text-align:center;margin-top:1.5rem;color:#fffc;text-decoration:none;padding:.75rem;background:#ffffff1a;border-radius:.5rem;transition:all .2s}.home-page .admin-link:hover{background:#fff3;color:#fff}.home-page .user-info{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#ffffff1a;border-radius:.5rem;margin-bottom:1.5rem;color:#fff}.home-page .logout-btn{background:#fff3;border:none;padding:.5rem 1rem;border-radius:.25rem;color:#fff;cursor:pointer;font-size:.85rem}.home-page .logout-btn:hover{background:#ffffff4d}.home-page .home-links{display:flex;gap:1rem;margin-top:1.5rem}.home-page .home-link{flex:1;text-align:center;color:#fffc;text-decoration:none;padding:.75rem;background:#ffffff1a;border-radius:.5rem;transition:all .2s}.home-page .home-link:hover{background:#fff3;color:#fff}.home-page .loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a365d,#2d4a7c);color:#fff;font-size:1.25rem}.home-page .result-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);padding:2rem}.home-page .result-content{text-align:center;color:var(--white);max-width:400px}.home-page .result-icon{font-size:5rem;display:block;margin-bottom:1rem}.home-page .result-content h1{font-size:2rem;margin-bottom:.75rem}.home-page .result-content p{opacity:.9;margin-bottom:.5rem}.home-page .result-content .note{font-size:.9rem;opacity:.7;margin-bottom:2rem}.home-page .home-btn{display:inline-block;padding:.875rem 2rem;background:var(--white);color:var(--primary);text-decoration:none;border-radius:.5rem;font-weight:600;transition:all .2s ease}.home-page .home-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #0003}@media(max-width:640px){.home-page .logo-section h1{font-size:1.75rem}.home-page .features{grid-template-columns:1fr}.home-page .demo-card{padding:1.5rem}}
