*{box-sizing:border-box}html,body{color:#0f172a;background:linear-gradient(#eef4ff 0%,#f8fbff 40%,#f6f8fc 100%);margin:0;padding:0;font-family:Arial,Helvetica,sans-serif}button,input,select{font:inherit}.mobileCameraPreview{aspect-ratio:3/4;background:#000;border-radius:18px;width:100%;position:relative;overflow:hidden}.mobileCameraVideo{object-fit:cover;width:100%;height:100%}.mainTabs{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;max-width:1500px;margin:0 auto 18px;display:grid}@media (max-width:900px){.mainTabs{grid-template-columns:1fr}.tabBtn,.secondaryBtn{width:100%}}.mobileTemplateGrid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.mobileTemplateCard{text-align:left;cursor:pointer;background:#fff;border:2px solid #dbe5f3;border-radius:18px;padding:12px;transition:all .2s}.mobileTemplateCard.active{background:#eff6ff;border-color:#2563eb;box-shadow:0 10px 24px #2563eb24}.mobileTemplateThumbWrap{aspect-ratio:3/4;background:#f8fafc;border:1px solid #dbe5f3;border-radius:14px;width:100%;overflow:hidden}.mobileTemplateThumb{object-fit:cover;width:100%;height:100%}.mobileTemplateThumbPlaceholder{color:#64748b;place-items:center;width:100%;height:100%;font-weight:700;display:grid}.mobileTemplateInfo{margin-top:10px}.mobileTemplateName{color:#0f172a;font-weight:800}.mobileTemplateMeta{color:#64748b;margin-top:4px;font-size:12px}.mobileCameraCard{background:#fff;border:1px solid #dbe5f3;border-radius:20px;padding:14px}.mobileCameraToolbar{flex-wrap:wrap;gap:10px;margin-bottom:12px;display:flex}.mobileCameraPreview{aspect-ratio:3/4;background:#000;border-radius:18px;width:100%;min-height:320px;position:relative;overflow:hidden}.mobileCameraVideo{object-fit:cover;width:100%;height:100%;display:block}.mobileGuideOverlay{pointer-events:none;position:absolute;inset:0}.guideCorner{border:0 solid #22c55e;width:44px;height:44px;position:absolute}.guideCorner.topLeft{border-top-width:4px;border-left-width:4px;top:10%;left:8%}.guideCorner.topRight{border-top-width:4px;border-right-width:4px;top:10%;right:8%}.guideCorner.bottomLeft{border-bottom-width:4px;border-left-width:4px;bottom:10%;left:8%}.guideCorner.bottomRight{border-bottom-width:4px;border-right-width:4px;bottom:10%;right:8%}.guideCenterText{color:#fff;text-align:center;background:#0000008c;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:700;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}.appPage{min-height:100vh;padding:24px}.invalidScanRow td{color:#b91c1c!important;background:#ffe3e3!important}.invalidScanRow:hover td{background:#ffd0d0!important}.resultTable{table-layout:fixed}.resultTable tbody tr{height:42px!important}.pageContainer{max-width:1500px;margin:0 auto}.topHeader{color:#fff;background:linear-gradient(135deg,#0f172a,#1d4ed8);border-radius:22px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1500px;margin:0 auto 18px;padding:18px 22px;display:flex;box-shadow:0 18px 50px #1d4ed838}.responsesTable tbody tr{height:42px;max-height:42px}.responsesTable tbody td{white-space:nowrap;text-overflow:ellipsis;vertical-align:middle;height:10px;max-height:42px;padding:6px 8px;overflow:hidden}.invalidScanRow td{background-color:#f8d7da}.scanIssueCell{white-space:nowrap;text-overflow:ellipsis;max-height:40px;display:block;overflow:hidden}.brandBox{flex-wrap:wrap;align-items:center;gap:16px;min-width:0;display:flex}.brandLogo{letter-spacing:1px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff29;border-radius:16px;place-items:center;width:58px;height:58px;font-size:20px;font-weight:800;display:grid}.brandTitle{margin:0;font-size:28px;font-weight:800}.brandSubtitle{color:#ffffffd1;margin:6px 0 0;font-size:14px}.headerInfo{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.headerBadge{color:#fff;background:#ffffff24;border:1px solid #ffffff2e;border-radius:999px;padding:10px 14px;font-size:13px;font-weight:700}.mainTabs{flex-wrap:wrap;gap:12px;max-width:1500px;margin:0 auto 18px;display:flex}.tabBtn{color:#0f172a;cursor:pointer;background:#e2e8f0;border:none;border-radius:14px;padding:13px 18px;font-weight:700;transition:all .2s}.tabBtn:hover{transform:translateY(-1px)}.tabBtn.active{color:#fff;background:#2563eb;box-shadow:0 10px 24px #2563eb38}.sectionCard{background:#fffffff5;border:1px solid #dbe5f3;border-radius:22px;margin-bottom:20px;padding:22px;box-shadow:0 12px 40px #0f172a14}.sectionHeader{justify-content:space-between;gap:16px;margin-bottom:18px;display:flex}.sectionTitle{color:#0f172a;margin:0;font-size:24px;font-weight:800}.sectionText{color:#475569;margin:6px 0 0;font-size:14px}.designerTopBar{margin-bottom:20px}.formGrid{gap:14px;display:grid}.formGrid.twoCol{grid-template-columns:repeat(2,minmax(0,1fr))}.formGrid.threeCol{grid-template-columns:repeat(3,minmax(0,1fr))}.fieldGroup{flex-direction:column;gap:8px;display:flex}.fieldGroup.fullWidth{grid-column:1/-1}.fieldLabel{color:#334155;font-size:13px;font-weight:700}.inputControl,.readOnlyBox{background:#fff;border:1px solid #cbd5e1;border-radius:14px;outline:none;width:100%;min-height:46px;padding:12px 14px;transition:border-color .2s,box-shadow .2s}.inputControl:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.readOnlyBox{color:#334155;background:#f8fafc;align-items:center;display:flex}.toolbar{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.primaryBtn,.secondaryBtn,.dangerBtn,.fileLabelBtn{cursor:pointer;border:none;border-radius:14px;padding:12px 16px;font-weight:700;transition:all .2s}.primaryBtn{color:#fff;background:#2563eb}.scanStatusBadge{border-radius:999px;justify-content:center;align-items:center;min-width:96px;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.scanStatusBadge.ok{color:#166534;background:#dcfce7}.scanStatusBadge.error{color:#b91c1c;background:#fee2e2}.scanIssueCell{white-space:normal;font-size:12px;line-height:1.45}.clickableFileCell{cursor:pointer;color:#1d4ed8;font-weight:600;text-decoration:underline}.clickableFileCell:hover{color:#1e40af;background:#eaf2ff!important}.largeCropModalCard{width:min(980px,94vw)}.cropMetaLine{color:#475569;margin-top:4px;font-size:13px;font-weight:600}.enhancedCropPreviewWrap{background:linear-gradient(#fff 0%,#f8fbff 100%);border:1px solid #d6e2f5;border-radius:20px;justify-content:center;align-items:center;min-height:160px;padding:24px;display:flex;overflow:auto}.enhancedCropPreviewImage{max-width:100%;max-height:320px;image-rendering:crisp-edges;image-rendering:pixelated;transform-origin:50%;filter:grayscale()contrast(2.8)brightness(.72)saturate(0);background:#fff;border-radius:8px;transform:scale(2)}.fullOmrPreviewImage{image-rendering:auto;filter:contrast(1.1)brightness(.98);background:#fff;border-radius:8px;width:auto;max-width:100%;height:auto;max-height:75vh;transform:none}.cropPreviewHint{color:#64748b;margin-top:12px;font-size:12px;font-weight:600}.secondaryBtn,.fileLabelBtn{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.dangerBtn{color:#b91c1c;background:#fee2e2;padding:10px 12px}.primaryBtn:hover,.secondaryBtn:hover,.dangerBtn:hover,.fileLabelBtn:hover{transform:translateY(-1px)}.primaryBtn:disabled,.secondaryBtn:disabled{opacity:.55;cursor:not-allowed;transform:none}.designerLayout{grid-template-columns:minmax(0,1.4fr) minmax(360px,.9fr);align-items:start;gap:20px;display:grid}.canvasPanel,.settingsPanel{background:#f8fbff;border:1px solid #dbe5f3;border-radius:20px;padding:16px}.panelTitle{color:#0f172a;margin-bottom:14px;font-size:16px;font-weight:800}.chipRow{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.columnChip{cursor:pointer;background:#fff;border:2px solid #cbd5e1;border-radius:999px;align-items:center;gap:8px;padding:9px 12px;font-weight:700;display:inline-flex}.columnChip.active{background:#eff6ff;box-shadow:0 8px 18px #2563eb1f}.chipDot{border-radius:999px;width:10px;height:10px}.canvasWrap{background:#fff;border:1px solid #dbe5f3;border-radius:18px;width:100%;padding:14px;overflow:auto}.designCanvas{cursor:crosshair;background:#fff;border-radius:12px;max-width:100%;display:block}.canvasFooter{color:#475569;margin-top:12px;font-size:13px;font-weight:600}.columnCard{background:#fff;border:1px solid #dbe5f3;border-radius:18px;margin-bottom:14px;padding:16px}.columnCard.active{border-color:#60a5fa;box-shadow:0 10px 22px #2563eb1a}.coordText{color:#64748b;margin-bottom:14px;font-size:12px}.helpBox{color:#1e3a8a;background:#eff6ff;border-radius:14px;margin-top:14px;padding:12px 14px;font-size:13px;line-height:1.5}.emptyState{color:#64748b;text-align:center;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:14px;padding:18px}.uploadPanel{background:#f8fbff;border:1px solid #dbe5f3;border-radius:20px;padding:16px}.statusBar{color:#334155;background:#f8fafc;border-radius:14px;flex-wrap:wrap;gap:16px;margin-top:14px;padding:12px 14px;font-size:14px;display:flex}.tableWrap{border:1px solid #dbe5f3;border-radius:18px;overflow-x:auto}.resultTable{border-collapse:collapse;text-align:center;background:#fff;width:100%;min-width:920px}.groupHead{color:#1e3a8a;text-align:center;background:#dbeafe;border:1px solid #bfdbfe;padding:12px;font-size:13px}.subHead{color:#1e293b;text-align:center;white-space:nowrap;background:#eff6ff;border:1px solid #dbe5f3;padding:10px;font-size:13px}.tableCell{text-align:center;white-space:nowrap;border:1px solid #e2e8f0;padding:10px;font-size:13px}.resultTable tbody tr:nth-child(2n){background:#f8fbff}@media (max-width:1200px){.designerLayout{grid-template-columns:1fr}}@media (max-width:900px){.formGrid.twoCol,.formGrid.threeCol{grid-template-columns:1fr}.brandBox,.headerInfo{width:100%}.headerInfo{justify-content:flex-start}.brandTitle{font-size:24px}}@media (max-width:640px){.appPage{padding:14px}.sectionCard{padding:16px}.tabBtn{width:100%}}.collapseToggleBtn{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:0;display:flex}.collapseArrow{color:#334155;font-size:14px;font-weight:800;transition:transform .2s}.collapseArrow.collapsed{transform:rotate(-90deg)}.columnCardHead{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.columnCardTitle{font-size:16px;font-weight:800}.settingsPanel{background:#f8fbff;border:1px solid #dbe5f3;border-radius:20px;max-height:85vh;padding:16px;overflow-y:auto}.stickyPanelTitle{z-index:5;background:#f8fbff;padding-bottom:10px;position:sticky;top:0}.accordionList{flex-direction:column;gap:12px;display:flex}.accordionCard{background:#fff;border:1px solid #dbe5f3;border-radius:18px;transition:box-shadow .2s,border-color .2s,transform .2s;overflow:hidden}.accordionCard.active{border-color:#93c5fd;box-shadow:0 10px 26px #2563eb14}.accordionHeader{justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.accordionToggle{cursor:pointer;text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:12px;min-width:0;padding:0;display:flex}.accordionArrow{flex-shrink:0;font-size:14px;font-weight:800;transition:transform .2s}.accordionArrow.collapsed{transform:rotate(-90deg)}.accordionColorBar{border-radius:999px;flex-shrink:0;width:6px;height:42px}.accordionTitleWrap{flex:1;min-width:0}.accordionTitleRow{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.accordionTitle{font-size:16px;font-weight:800;line-height:1.2}.accordionMeta{color:#64748b;margin-top:4px;font-size:12px;font-weight:600}.typeBadge{letter-spacing:.2px;border-radius:999px;align-items:center;padding:4px 10px;font-size:11px;font-weight:800;display:inline-flex}.typeBadge.field{color:#6d28d9;background:#ede9fe}.typeBadge.objective{color:#15803d;background:#dcfce7}.smallDangerBtn{border-radius:12px;flex-shrink:0;padding:9px 14px;font-size:13px}.accordionBody{border-top:1px solid #eef2f7;padding:0 16px 16px}.coordPillRow{flex-wrap:wrap;gap:8px;margin:14px 0 16px;display:flex}.coordPill{color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;align-items:center;padding:7px 12px;font-size:12px;font-weight:700;display:inline-flex}@media (max-width:640px){.accordionHeader{flex-direction:column;align-items:flex-start}.smallDangerBtn{width:100%}.accordionColorBar{height:34px}}.answerKeyPanel,.resultSummaryPanel{background:#fff;border:1px solid #dbe5f3;border-radius:18px;margin-top:18px;padding:16px}.answerKeyPanelHead{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.answerKeyTitle{color:#0f172a;margin:0;font-size:18px;font-weight:800}.answerKeyCount{color:#475569;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;padding:7px 12px;font-size:13px;font-weight:700}.answerKeyGrid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:10px;max-height:360px;padding-right:4px;display:grid;overflow-y:auto}.answerKeyItem{appearance:none;text-align:center;cursor:pointer;background:#f8fbff;border:1px solid #dbe5f3;border-radius:14px;width:100%;padding:10px 8px}.answerKeyItem.selected{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1f}.answerKeyQno{color:#475569;margin-bottom:4px;font-size:12px;font-weight:800;display:block}.answerKeyAns{color:#1d4ed8;font-size:16px;font-weight:800;display:block}.answerKeyPanelActions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.answerKeyToggleBtn{padding:7px 12px}.answerKeyInspector{background:#f8fbff;border:1px solid #dbe5f3;border-radius:18px;margin-bottom:14px;padding:14px}.answerKeyInspectorHead{flex-wrap:wrap;justify-content:space-between;gap:12px;margin-bottom:10px;display:flex}.answerKeyInspectorHead strong{color:#0f172a;font-size:14px}.answerKeyInspectorHead span{color:#475569;font-size:13px}.answerKeyInspectorImage{background:#fff;border:1px solid #dbe5f3;border-radius:14px;width:100%;max-width:520px;height:auto;display:block}.answerKeyCropThumb{object-fit:contain;background:#fff;border:1px solid #dbe5f3;border-radius:10px;width:100%;height:44px;margin-top:8px;display:block}@media (max-width:640px){.answerKeyGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.answerKeyInspectorImage{max-width:100%}}.studentResponsesPanel{background:#fff;border:1px solid #dbe5f3;border-radius:18px;margin-top:18px;padding:16px}.responsesTableWrap{background:#fff;border:1px solid #dbe5f3;border-radius:16px;overflow:auto}.mobileScanPage{padding-bottom:48px}.mobileScanTopHeader{background:linear-gradient(135deg,#052e16,#0f766e 48% 100%);box-shadow:0 20px 52px #0f766e38}.mobileBrandLogo{background:#ffffff1f;border-radius:20px;justify-content:center;align-items:center;width:196px;min-width:196px;height:72px;padding:12px 16px;display:flex}.mobileBrandLogoImage{object-fit:contain;width:100%;height:auto}.mobileBrandText{min-width:0}.mobileBrandTitle{max-width:720px;line-height:1.08}.mobileHeaderInfo{align-items:center}.mobileBackLink{color:#fff;background:#ffffff29;border:1px solid #fff3;border-radius:999px;justify-content:center;align-items:center;min-height:44px;padding:0 16px;font-size:13px;font-weight:800;text-decoration:none;display:inline-flex}.mobileScanIntroCard{overflow:hidden}.mobilePaperSelectorCard{margin-bottom:18px}.mobilePaperMeta{flex-wrap:wrap;gap:10px;display:flex}.mobilePaperDropdownWrapper{margin-top:4px}.mobilePaperDropdown{color:#0f172a;cursor:pointer;appearance:none;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") right 14px center no-repeat;border:1px solid #d7efe9;border-radius:14px;outline:none;width:100%;padding:12px 40px 12px 16px;font-size:15px;transition:border-color .15s,box-shadow .15s}.mobilePaperDropdown:focus{border-color:#14b8a6;box-shadow:0 0 0 2px #14b8a62e}.mobileSelectedPaperCard{background:#f0fdfa;border:1px solid #99f6e4;border-radius:18px;margin-top:14px;padding:14px 16px}.mobileSelectedPaperCard strong{color:#0f172a;margin-bottom:4px;font-size:14px;display:block}.mobileSelectedPaperCard span{color:#155e75;font-size:13px}.customKeySection{flex-direction:column;gap:10px;margin-top:14px;display:flex}.customKeyUploadBtn{width:100%}.customKeyHint{margin-top:0}.customKeySuccess{background:#f0fdfa;border:1px solid #99f6e4;border-radius:14px;flex-wrap:wrap;align-items:center;gap:12px;padding:12px 16px;display:flex}.customKeySuccess span{color:#155e75;flex:1;min-width:0;font-size:13px}.customKeyReuploadBtn{flex-shrink:0;padding:6px 14px;font-size:13px}.customKeyPreview{border:1px solid #d7efe9;border-radius:14px;margin-top:4px;overflow:hidden}.customKeyPreviewTitle{color:#64748b;text-transform:uppercase;letter-spacing:.04em;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:9px 14px;font-size:12px;font-weight:700}.customKeyPreviewGrid{background:#e2e8f0;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:1px;max-height:260px;display:grid;overflow-y:auto}.customKeyPreviewItem{background:#fff;justify-content:space-between;align-items:center;padding:5px 10px;font-size:13px;display:flex}.customKeyPreviewQ{color:#64748b;font-size:11px}.customKeyPreviewAns{color:#0f172a;font-weight:700}.processingTimer{color:#0891b2;align-items:center;gap:8px;margin-top:8px;font-size:13px;font-weight:600;display:flex}.processingTimerDot{background:#0891b2;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:1s ease-in-out infinite timerPulse}@keyframes timerPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.mobileScanLayout{grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);align-items:start;gap:20px;display:grid}.mobileUploadCard{background:linear-gradient(#fff 0%,#f7fefc 100%);border:1px solid #d7efe9;border-radius:22px;padding:18px}.mobileUploadHero{background:radial-gradient(circle at 0 0,#2dd4bf2e,#0000 42%),linear-gradient(#f8fffd 0%,#eefcf8 100%);border:1px solid #d9f4ec;border-radius:18px;grid-template-columns:140px minmax(0,1fr);align-items:center;gap:18px;padding:16px;display:grid}.mobileUploadIllustration{min-height:140px;position:relative}.mobileUploadSheet,.mobileUploadPhone{border-radius:18px;position:absolute}.mobileUploadSheet{background:linear-gradient(#fff 0%,#f8fbff 100%);border:2px solid #cbd5e1;inset:10px 24px 18px 12px;box-shadow:0 14px 28px #0f172a14}.mobileUploadSheet:before,.mobileUploadSheet:after{content:"";background:#e2e8f0;border-radius:999px;height:10px;position:absolute;left:18px;right:18px}.mobileUploadSheet:before{top:24px}.mobileUploadSheet:after{top:48px}.mobileUploadPhone{background:linear-gradient(#0f172a 0%,#1e293b 100%);border:2px solid #0f172a;width:68px;height:118px;top:0;right:0;box-shadow:0 18px 32px #0f172a2e}.mobileUploadPhone:before{content:"";background:linear-gradient(#22c55e2e,#0ea5e924),#eff6ff;border-radius:12px;position:absolute;inset:10px}.mobileUploadPhone:after{content:"";background:#ffffffb3;border-radius:999px;width:18px;height:3px;position:absolute;bottom:7px;left:50%;transform:translate(-50%)}.mobileUploadCopy{min-width:0}.mobileUploadLead{margin-top:8px}.mobileGalleryBtn{background:linear-gradient(135deg,#0f766e,#14b8a6)}.mobilePhotoPreviewGrid{grid-template-columns:1fr;gap:16px;margin-top:18px;display:grid}.mobilePhotoPreviewCard{background:#fff;border:1px solid #dbe5f3;border-radius:18px;padding:14px}.mobilePhotoPreviewHead{justify-content:space-between;gap:12px;margin-bottom:12px;display:flex}.mobilePhotoPreviewHead strong{color:#0f172a;font-size:14px}.mobilePhotoPreviewHead span{color:#64748b;text-align:right;font-size:12px}.mobilePhotoPreviewImage{background:#fff;border:1px solid #e2e8f0;border-radius:14px;width:100%;height:auto}.mobileSidebarCard{background:linear-gradient(#fff 0%,#f7fefc 100%);border:1px solid #d7efe9;border-radius:22px;padding:18px}.mobileScanSidebar{flex-direction:column;gap:16px;display:flex}.mobileCameraStatusBar{flex-wrap:wrap;gap:10px;margin-bottom:14px;display:flex}.mobileStatusPill{color:#155e75;letter-spacing:.2px;background:#ecfeff;border:1px solid #bae6fd;border-radius:999px;justify-content:center;align-items:center;padding:8px 12px;font-size:12px;font-weight:800;display:inline-flex}.mobileStatusPill.ready{color:#166534;background:#dcfce7;border-color:#86efac}.mobileStatusPill.waiting{color:#92400e;background:#fef3c7;border-color:#fcd34d}.mobileCameraFrame{background:radial-gradient(circle at top,#2dd4bf2e,#0000 45%),linear-gradient(#081c15 0%,#0f172a 100%);border:2px solid #94a3b84d;border-radius:28px;width:100%;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0f}.mobileCameraFrame.aligned{border-color:#22c55ed9;box-shadow:0 0 0 4px #22c55e24,inset 0 0 0 1px #ffffff14}.mobileCameraOverlay{pointer-events:none;position:absolute;inset:0}.mobileGuideFrame{border:2px solid #f8fafcd6;border-radius:22px;position:absolute;inset:18px;box-shadow:0 0 0 1px #0f172a38,inset 0 0 0 1px #ffffff2e}.mobileCameraFrame.aligned .mobileGuideFrame{border-color:#86efacf2;box-shadow:0 0 0 1px #16653433,0 0 24px #22c55e2e}.mobileReferencePoint{border:2px solid #ffffffe6;border-radius:999px;place-items:center;width:34px;height:34px;font-size:12px;font-weight:800;transition:transform .2s,background .2s,box-shadow .2s;display:grid;position:absolute;transform:translate(-50%,-50%)}.mobileReferencePoint.waiting{color:#111827;background:#fbbf24e6;box-shadow:0 0 0 6px #fbbf2429}.mobileReferencePoint.ok{color:#fff;background:#22c55ef0;transform:translate(-50%,-50%)scale(1.04);box-shadow:0 0 0 8px #22c55e29}.mobileCameraPlaceholder{text-align:center;color:#f8fafc;background:linear-gradient(#081c15ad,#0f172ad1);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px;display:flex;position:absolute;inset:0}.mobileCameraPlaceholder strong{font-size:18px}.mobileCameraPlaceholder span{color:#f8fafcd6;max-width:280px;font-size:13px;line-height:1.5}.mobileActionBar{margin-top:16px}.mobileScanBtn{background:linear-gradient(135deg,#15803d,#16a34a)}.mobileErrorBox,.mobileHintBox{border-radius:16px;margin-top:14px;padding:13px 14px;font-size:13px;font-weight:700;line-height:1.5}.mobileErrorBox{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.mobileHintBox{color:#155e75;background:#ecfeff;border:1px solid #a5f3fc}.mobileReferenceList,.mobileInstructionList{flex-direction:column;gap:12px;display:flex}.mobileReferenceRow,.mobileInstructionItem{background:#f8fffd;border:1px solid #dcf3ee;border-radius:16px;align-items:flex-start;gap:12px;padding:12px 14px;display:flex}.mobileReferenceDot{border-radius:999px;flex-shrink:0;place-items:center;width:34px;height:34px;font-size:12px;font-weight:800;display:grid}.mobileReferenceDot.waiting{color:#92400e;background:#fef3c7}.mobileReferenceDot.ok{color:#166534;background:#dcfce7}.mobileReferenceMeta{min-width:0}.mobileReferenceMeta strong{color:#0f172a;font-size:14px;display:block}.mobileReferenceMeta span,.mobileInstructionItem{color:#475569;font-size:13px;line-height:1.5}.mobileResultCard{margin-top:20px}.mobileResultLayout{grid-template-columns:minmax(0,1fr) minmax(280px,.85fr);gap:18px;display:grid}.mobilePreviewCard{background:#f8fbff;border:1px solid #dbe5f3;border-radius:22px;padding:16px}.mobileResultPreviewImage{background:#fff;border-radius:16px;width:100%;height:auto}.mobileResultDetails{flex-direction:column;gap:16px;display:flex}.mobileResultActionCard{flex-direction:column;gap:12px;display:flex}.mobileShowResultBtn{background:linear-gradient(135deg,#0f766e,#0ea5e9)}.mobileScoreGrid,.mobileFieldGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.mobileScoreItem,.mobileFieldItem{background:#f8fffd;border:1px solid #dcf3ee;border-radius:16px;padding:14px}.mobileScoreItem span,.mobileFieldItem span{color:#64748b;margin-bottom:6px;font-size:12px;font-weight:700;display:block}.mobileScoreItem strong,.mobileFieldItem strong{color:#0f172a;font-size:18px}.mobileResultSummaryWrap{flex-direction:column;gap:16px;margin-top:18px;display:flex}.mobileSubjectSummaryGrid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.mobileResponsesPanel{background:#fff;border:1px solid #dbe5f3;border-radius:22px;margin-top:18px;padding:16px}.mobileSubjectTabs{flex-wrap:wrap;gap:10px;margin-bottom:14px;display:flex}.mobileSubjectTab{color:#334155;cursor:pointer;background:#f8fbff;border:1px solid #cbd5e1;border-radius:999px;min-height:40px;padding:0 16px;font-size:13px;font-weight:800}.mobileSubjectTab.selected{color:#fff;background:linear-gradient(135deg,#0f766e,#0ea5e9);border-color:#0000}.mobileResponsesTableWrap{background:#fff;border:1px solid #dbe5f3;border-radius:18px;overflow:auto}.mobileResponsesTable{border-collapse:collapse;width:100%;min-width:540px}.mobileResponsesTable th,.mobileResponsesTable td{text-align:left;color:#1e293b;border-bottom:1px solid #eef2f7;padding:12px 10px;font-size:13px}.mobileResponsesTable th{color:#0f172a;letter-spacing:.2px;background:#eff6ff;font-size:12px;font-weight:800}.mobileResponsesTable tbody tr:nth-child(2n) td{background:#f8fbff}.mobileRowCropThumb{object-fit:contain;background:#fff;border:1px solid #dbe5f3;border-radius:8px;width:120px;max-width:100%;height:34px;display:block}.mobileRowCropPlaceholder{color:#94a3b8;font-weight:700}.mobileSolutionLink{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0f766e,#0ea5e9);border:none;border-radius:999px;justify-content:center;align-items:center;min-height:32px;padding:0 12px;font-size:12px;font-weight:800;text-decoration:none;display:inline-flex}.mobileSolutionLink.disabled{color:#94a3b8;cursor:not-allowed;background:#e2e8f0}.mobileStatusChip{border-radius:999px;justify-content:center;align-items:center;min-height:28px;padding:0 10px;font-size:12px;font-weight:800;display:inline-flex}.mobileStatusChip.correct{color:#166534;background:#dcfce7}.mobileStatusChip.incorrect{color:#b91c1c;background:#fee2e2}.mobileStatusChip.blank{color:#475569;background:#e2e8f0}@media (max-width:1100px){.mobileScanLayout,.mobileResultLayout,.mobileSubjectSummaryGrid{grid-template-columns:1fr}}@media (max-width:640px){.mobileUploadHero{grid-template-columns:1fr}.mobileSidebarCard{padding:14px}.mobileBrandLogo{width:164px;min-width:164px;height:62px;padding:10px 14px}.mobilePhotoPreviewGrid,.mobileScoreGrid,.mobileFieldGrid{grid-template-columns:1fr}.mobileGuideFrame{border-radius:18px;inset:12px}.mobileReferencePoint{width:30px;height:30px;font-size:11px}.mobileBackLink{width:100%}}.responsesTable{border-collapse:separate;border-spacing:0;background:#fff;width:max-content;min-width:max-content}.responsesTable thead th{z-index:3;color:#0f172a;text-align:center;white-space:nowrap;background:#eaf2ff;border-bottom:1px solid #cbd5e1;border-right:1px solid #e2e8f0;min-width:52px;padding:10px 8px;font-size:14px;font-weight:800;position:sticky;top:0}.responsesTable tbody td{text-align:center;white-space:nowrap;color:#1e293b;border-bottom:1px solid #eef2f7;border-right:1px solid #eef2f7;min-width:52px;padding:10px 8px;font-size:14px}.responsesTable tbody tr:nth-child(2n) td{background:#f8fbff}.responsesTable tbody tr:hover td{background:#eef6ff}.responsesTable .stickyCol{z-index:4;background:#fff;position:sticky}.responsesTable thead .stickyCol{z-index:6;background:#dbeafe}.responsesTable .stickyCol1{text-align:left;min-width:130px;max-width:130px;padding-left:12px;left:0;box-shadow:1px 0 #dbe5f3}.responsesTable .stickyCol2{text-align:center;min-width:90px;max-width:90px;left:130px;box-shadow:1px 0 #dbe5f3}.responsesTable tbody .stickyCol1,.responsesTable tbody .stickyCol2{background:inherit}.responsesTable thead .stickyCol1,.responsesTable thead .stickyCol2{background:#dbeafe}@media (max-width:768px){.responsesTable thead th,.responsesTable tbody td{min-width:48px;padding:8px 6px;font-size:13px}.responsesTable .stickyCol1{min-width:110px;max-width:110px}.responsesTable .stickyCol2{min-width:80px;max-width:80px;left:110px}}.clickableResponseCell{cursor:pointer;transition:background .2s,transform .2s}.clickableResponseCell:hover{background:#dbeafe!important}.cropModalOverlay{z-index:9999;background:#0f172a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.cropModalCard{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #0f172a38}.compactCropModalCard{width:min(760px,92vw);max-width:760px}.largeCropModalCard{width:min(1100px,96vw);max-width:1100px;max-height:92vh}.cropModalHead{border-bottom:1px solid #dbe4f0;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 20px 12px;display:flex}.cropModalTitle{color:#172033;margin:0;font-size:18px;font-weight:800}.cropMetaLine{color:#5f6f8a;margin-top:4px;font-size:13px}.compactRowCropPreviewWrap{padding:14px 20px 10px}.fullOmrCropPreviewWrap{max-height:calc(92vh - 120px);padding:14px 20px 10px;overflow:auto}.cropPreviewImage{background:#f3f6fb;border:1px solid #d8e1ee;border-radius:16px;width:100%;display:block}.compactRowPreviewImage{object-fit:contain;max-height:180px;padding:8px}.fullOmrPreviewImage{object-fit:contain;height:auto}.cropPreviewHint{color:#60708c;padding:0 20px 16px;font-size:13px}.orderBadge{color:#1d4ed8;background:#e8f0ff;border:1px solid #bfd3ff;border-radius:999px;justify-content:center;align-items:center;min-width:34px;height:26px;margin-right:8px;padding:0 10px;font-size:13px;font-weight:700;line-height:1;display:inline-flex}.docCameraOverlay{z-index:9999;background:#000;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.docCameraFlash{opacity:.85;z-index:10;pointer-events:none;background:#fff;animation:.25s ease-out forwards cameraFlash;position:absolute;inset:0}@keyframes cameraFlash{0%{opacity:.85}to{opacity:0}}.docCameraTopBar{z-index:5;background:#0009;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.docCameraTopTitle{color:#fff;letter-spacing:.03em;font-size:15px;font-weight:700}.docCameraTopBtn{color:#fff;cursor:pointer;opacity:.85;background:0 0;border:none;border-radius:8px;padding:6px 10px;font-size:14px;font-weight:600}.docCameraTopBtn:hover{opacity:1}.docViewfinder{flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.docCameraVideo{object-fit:cover;width:100%;height:100%;display:block}.docScanLine{pointer-events:none;background:linear-gradient(90deg,#0000,#14b8a6,#0000);height:3px;animation:2.4s ease-in-out infinite scanLineMove;position:absolute;left:0;right:0;box-shadow:0 0 10px 2px #14b8a699}@keyframes scanLineMove{0%{top:2%}50%{top:96%}to{top:2%}}.docGuideVeil{pointer-events:none;background:#0000004d;position:absolute;inset:0}.docGuideFrame{aspect-ratio:8.5/11;pointer-events:none;width:82%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 100vmax #0000004d}.docCorner{border-style:solid;border-color:#14b8a6;width:36px;height:36px;position:absolute}.docCornerTL{border-width:4px 0 0 4px;border-radius:4px 0 0;top:0;left:0}.docCornerTR{border-width:4px 4px 0 0;border-radius:0 4px 0 0;top:0;right:0}.docCornerBL{border-width:0 0 4px 4px;border-radius:0 0 0 4px;bottom:0;left:0}.docCornerBR{border-width:0 4px 4px 0;border-radius:0 0 4px;bottom:0;right:0}.docCameraStarting{color:#ffffffd9;z-index:6;background:#0000008c;justify-content:center;align-items:center;font-size:15px;font-weight:600;display:flex;position:absolute;inset:0}.docCameraErr{color:#f87171}.docCameraBottomBar{z-index:5;background:#000000a6;flex-direction:column;align-items:center;gap:16px;padding:20px 24px 36px;display:flex}.docCameraHint{color:#ffffffbf;text-align:center;margin:0;font-size:13px}.docShutterBtn{cursor:pointer;background:#ffffff26;border:4px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;padding:0;transition:transform .1s,background .1s;display:flex}.docShutterBtn:active{background:#ffffff4d;transform:scale(.92)}.docShutterBtn:disabled{opacity:.4;cursor:not-allowed}.docShutterRing{background:#fff;border-radius:50%;width:52px;height:52px;display:block}.docShutterBtn.docShutterReady{background:#14b8a62e;border-color:#14b8a6;animation:1.2s ease-in-out infinite shutterPulse}.docShutterBtn.docShutterReady .docShutterRing{background:#14b8a6}@keyframes shutterPulse{0%,to{box-shadow:0 0 #14b8a680}50%{box-shadow:0 0 0 12px #14b8a600}}.docTitleDetected{color:#14b8a6}.docScanCanvas{pointer-events:none;width:100%;height:100%;position:absolute;inset:0}
