:root{--primary:#0d9488;--primary-dark:#0f766e;--primary-light:#ccfbf1;--accent:#f59e0b;--bg:#f8fafc;--surface:#fff;--text:#0f172a;--text-secondary:#64748b;--border:#e2e8f0;--success:#10b981;--error:#ef4444;--warning:#f59e0b;--shadow-sm:0 1px 2px rgba(15,23,42,.05);--shadow:0 4px 6px -1px rgba(15,23,42,.08),0 2px 4px -2px rgba(15,23,42,.05);--shadow-lg:0 10px 15px -3px rgba(15,23,42,.08),0 4px 6px -4px rgba(15,23,42,.05);--radius:12px;--radius-lg:16px;--font:"Segoe UI","PingFang SC","Microsoft YaHei",system-ui,sans-serif}*,:after,:before{margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;display:flex;flex-direction:column}.app-footer{text-align:center;padding:2rem 1.5rem 2.5rem;border-top:1px solid var(--border);background:var(--surface)}.app-footer-text{font-size:.75rem;line-height:1.6}.app-footer-icp,.app-footer-text{color:var(--text-secondary)}.app-footer-icp:hover{color:var(--primary);text-decoration:underline}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:.875rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.logo{gap:.625rem;font-weight:700;color:var(--text);text-decoration:none}.logo,.logo-icon{display:flex;align-items:center;font-size:1.125rem}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--primary),#06b6d4);border-radius:10px;justify-content:center;color:#fff}.header-links{display:flex;gap:1.25rem}.header-links a{color:var(--text-secondary);text-decoration:none;font-size:.875rem;transition:color .15s}.header-links a:hover{color:var(--primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;border:none;transition:all .15s;text-decoration:none;font-family:inherit}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px rgba(13,148,136,.35)}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:.5rem .75rem}.btn-ghost:hover{color:var(--primary);background:var(--primary-light)}.btn-lg{padding:.875rem 2rem;font-size:1rem}.btn-block{width:100%}.container{max-width:1120px}.container,.container-narrow{margin:0 auto;padding:0 1.5rem}.container-narrow{max-width:720px}.page-body{padding:2rem 0 4rem}.stepper{gap:.5rem;margin-bottom:2rem;font-size:.8125rem;color:var(--text-secondary)}.stepper,.stepper .step{display:flex;align-items:center}.stepper .step{gap:.375rem}.stepper .dot{width:24px;height:24px;border-radius:50%;background:var(--border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.stepper .step.active .dot{background:var(--primary);color:#fff}.stepper .step.done .dot{background:var(--success);color:#fff}.stepper .line{flex:1;height:2px;background:var(--border);max-width:40px}.stepper .line.done{background:var(--success)}.page-title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.page-subtitle{color:var(--text-secondary);margin-bottom:2rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-body{padding:1.5rem}.hero{text-align:center;padding:4rem 0 3rem;background:linear-gradient(180deg,#f0fdfa 0,var(--bg) 100%)}.hero-desc{font-size:1.125rem;margin:0 auto .75rem}.hero-desc,.hero-feedback{color:var(--text-secondary);max-width:540px}.hero-feedback{font-size:.875rem;margin:0 auto 2rem}.hero-feedback a{color:var(--primary);text-decoration:none}.hero-feedback a:hover{text-decoration:underline}.hero h1{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:800;line-height:1.2;margin-bottom:1rem;letter-spacing:-.02em}.hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--primary),#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-cta{margin-bottom:2.5rem}.hero-features{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem 2rem;font-size:.875rem;color:var(--text-secondary)}.hero-features li{list-style:none;display:flex;align-items:center;gap:.375rem}.hero-features li:before{content:"✓";color:var(--success);font-weight:700}.landing-section{padding:3.5rem 0}.landing-section-alt{background:var(--surface)}.landing-heading{font-size:1.5rem;font-weight:800;text-align:center;margin-bottom:.5rem;letter-spacing:-.02em}.landing-lead{text-align:center;color:var(--text-secondary);margin-bottom:2rem;font-size:1rem}.landing-steps{list-style:none;padding:0;margin:0 auto;max-width:36rem;display:flex;flex-direction:column;gap:1.5rem}.landing-step{display:flex;gap:1rem;align-items:flex-start}.landing-step-num{flex-shrink:0;width:2rem;height:2rem;border-radius:50%;background:var(--primary-light);color:var(--primary-dark);font-weight:700;font-size:.875rem;display:flex;align-items:center;justify-content:center}.landing-step h3{font-size:1rem;font-weight:700;margin-bottom:.25rem}.landing-step p{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin:0}.landing-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}.landing-feature-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem}.landing-feature-card h3{font-size:1rem;font-weight:700;margin-bottom:.5rem}.landing-feature-card p{font-size:.875rem;color:var(--text-secondary);line-height:1.6;margin:0}.landing-faq{margin:0 auto;max-width:36rem}.landing-faq-item{border-bottom:1px solid var(--border);padding:1.25rem 0}.landing-faq-item:first-child{padding-top:0}.landing-faq-item dt{font-weight:700;font-size:.9375rem;margin-bottom:.375rem}.landing-faq-item dd{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.6}.landing-cta{text-align:center;padding:3rem 0 4rem;background:linear-gradient(180deg,var(--bg) 0,#f0fdfa 100%)}.landing-cta .landing-heading{margin-bottom:.5rem}.landing-cta .landing-lead{margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.form-group label{display:block;font-size:.875rem;font-weight:600;margin-bottom:.375rem}.form-group select{width:100%;padding:.625rem .875rem;border:1px solid var(--border);border-radius:10px;font-size:.9375rem;background:var(--surface);font-family:inherit}.page-footer-actions{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}.mobile-only,.upload-subtitle-mobile{display:none}.upload-layout{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;min-height:520px}.upload-mobile-bar,.upload-mobile-tabs{display:none}.upload-sidebar .sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.sidebar-footer{margin-top:1rem}.sidebar-footer-hint{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem;text-align:center}.submission-list{display:flex;flex-direction:column;gap:.5rem}.submission-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s;background:var(--surface)}.submission-item.active,.submission-item:hover{border-color:var(--primary)}.submission-item.active{background:var(--primary-light);box-shadow:0 0 0 2px rgba(13,148,136,.12)}.submission-thumb{width:40px;height:40px;border-radius:8px;background:linear-gradient(135deg,#e2e8f0,#cbd5e1);display:flex;align-items:center;justify-content:center;font-size:1.125rem;flex-shrink:0}.submission-info{flex:1;min-width:0}.submission-info .name{font-weight:600;font-size:.875rem}.submission-info .name-row{display:flex;align-items:center;gap:.25rem;min-width:0}.submission-info .name-row .name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.submission-rename-btn{flex-shrink:0;padding:.125rem .375rem;border:none;background:transparent;color:var(--text-secondary);font-size:.8125rem;cursor:pointer;border-radius:4px;line-height:1}.submission-rename-btn:hover{color:var(--primary);background:rgba(13,148,136,.08)}.submission-info .name-input{width:100%;font-weight:600;font-size:.875rem;font-family:inherit;padding:.125rem .375rem;border:1px solid var(--primary);border-radius:4px;background:var(--surface);outline:none}.submission-delete,.submission-info .meta{font-size:.75rem;color:var(--text-secondary)}.submission-delete{flex-shrink:0;padding:.25rem .5rem;border-radius:6px}.submission-delete:hover:not(:disabled){color:var(--error);background:#fef2f2}.submission-delete:disabled{opacity:.35;cursor:not-allowed}.upload-add-mobile,.upload-empty-hint-mobile{display:none}.upload-empty-hint-desktop{display:block}.upload-main{display:flex;flex-direction:column;gap:1rem}.submission-detail.hidden{display:none}.detail-panel-header{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;padding-bottom:.25rem}.detail-panel-meta{font-size:.8125rem;color:var(--text-secondary)}.upload-empty-state{text-align:center;padding:2.5rem 1rem;border:1px dashed var(--border);border-radius:var(--radius-lg);background:#fafafa}.upload-empty-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.5}.upload-empty-state p{color:var(--text-secondary);font-size:.9375rem}.upload-empty-hint{font-size:.8125rem!important;margin-top:.25rem}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.image-thumb{aspect-ratio:3/4;border-radius:10px;overflow:hidden;position:relative;border:1px solid var(--border);background:#f1f5f9;cursor:zoom-in;transition:box-shadow .15s,border-color .15s}.image-thumb:hover{border-color:var(--primary);box-shadow:var(--shadow)}.image-thumb:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.image-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.image-thumb .page-label{position:absolute;bottom:0;left:0;right:0;background:rgba(15,23,42,.6);color:#fff;font-size:.6875rem;padding:.25rem;text-align:center}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:2.5rem 1.5rem;text-align:center;background:#fafafa;transition:border-color .15s,background .15s}.drop-zone:hover{border-color:var(--primary);background:var(--primary-light)}.drop-zone-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.6}.drop-zone p{color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem}.drop-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.upload-summary{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-top:auto}.upload-summary .stats{font-size:.875rem;color:var(--text-secondary)}.upload-summary .stats strong{color:var(--text)}@media (max-width:900px){.page-upload .upload-drop-desktop,.page-upload .upload-footer-desktop,.page-upload .upload-subtitle-desktop,.page-upload .upload-summary-desktop,.page-upload .upload-tip-desktop{display:none}.page-upload .upload-subtitle-mobile{display:block}.page-upload .upload-empty-hint-desktop{display:none}.page-upload .upload-empty-hint-mobile,.upload-add-mobile{display:block}.page-upload .detail-panel-header.mobile-only{display:flex}.page-upload .page-body{padding-bottom:6.5rem}.upload-mobile-tabs{display:flex;gap:.5rem;margin-bottom:1rem;padding:.25rem;background:var(--surface);border:1px solid var(--border);border-radius:12px}.upload-tab{flex:1;padding:.625rem .75rem;border:none;border-radius:10px;background:transparent;font-family:inherit;font-size:.875rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-tab.active{background:var(--primary);color:#fff}.upload-layout{grid-template-columns:1fr;min-height:auto}.upload-panel-detail,.upload-panel-list{display:none}.upload-layout[data-mobile-tab=list] .upload-panel-list{display:block}.upload-layout[data-mobile-tab=detail] .upload-panel-detail{display:flex}.upload-mobile-bar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;position:fixed;left:0;right:0;bottom:0;z-index:60;padding:.75rem 1rem max(.75rem,env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -4px 12px rgba(15,23,42,.06)}.upload-mobile-bar-stats{font-size:.8125rem;color:var(--text-secondary);flex-shrink:0}.upload-mobile-bar-actions{display:flex;gap:.5rem;flex:1;justify-content:flex-end}.upload-mobile-bar .btn-mobile-add{padding:.5rem .875rem;font-size:.8125rem}.upload-mobile-bar .btn-primary{padding:.5rem 1rem;font-size:.875rem}.page-upload .image-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.page-upload .submission-delete{font-size:.6875rem;padding:.2rem .375rem}.upload-mobile-bar .btn-mobile-upload{padding:.5rem .75rem;font-size:.8125rem}}.tip-box{background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:.75rem 1rem;font-size:.8125rem;color:#92400e;display:flex;gap:.5rem;align-items:flex-start}.radio-group{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.radio-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .15s}.radio-item:has(input:checked){border-color:var(--primary);background:var(--primary-light)}.radio-item input{margin-top:.25rem;accent-color:var(--primary)}.radio-item .radio-content h4{font-size:.9375rem;margin-bottom:.125rem}.radio-item .radio-content p{font-size:.8125rem;color:var(--text-secondary)}.slider-group{margin:1.5rem 0}.slider-group label{font-size:.875rem;font-weight:600;display:block;margin-bottom:.75rem}.slider-row{display:flex;align-items:center;gap:1rem}.slider-row input[type=range]{flex:1;accent-color:var(--primary)}.slider-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.checkbox-row{display:flex;align-items:center;gap:.5rem;font-size:.9375rem}.checkbox-row input{accent-color:var(--primary);width:18px;height:18px}.answer-panel.hidden{display:none}.answer-panel-hint{font-size:.8125rem;color:var(--text-secondary);margin-bottom:1rem}.answer-add-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.answer-image-count{font-size:.8125rem;color:var(--text-secondary);margin-top:.75rem}.answer-image-grid{margin-bottom:.25rem}.image-thumb-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border:none;border-radius:50%;background:rgba(15,23,42,.65);color:#fff;font-size:1rem;line-height:1;cursor:pointer;opacity:0;transition:opacity .15s;font-family:inherit;padding:0}.image-thumb:focus-within .image-thumb-remove,.image-thumb:hover .image-thumb-remove{opacity:1}.image-thumb-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;border:2px dashed var(--border);background:#fafafa;cursor:pointer}.image-thumb-add:hover{border-color:var(--primary);background:var(--primary-light)}.image-thumb-add-icon{font-size:1.75rem;color:var(--text-secondary);line-height:1}.image-thumb-add-text{font-size:.75rem;color:var(--text-secondary)}.answer-text-input{width:100%;padding:.75rem .875rem;border:1px solid var(--border);border-radius:10px;font-size:.9375rem;font-family:inherit;line-height:1.5;resize:vertical}.answer-text-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(13,148,136,.15)}.warning-box{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:.875rem 1rem;font-size:.8125rem;color:#991b1b;margin-top:1.5rem;display:flex;gap:.5rem}.processing-page{text-align:center;max-width:480px;margin:0 auto;padding-top:2rem}.processing-icon{width:80px;height:80px;margin:0 auto 1.5rem;border-radius:50%;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:2rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.85}}.progress-bar{height:8px;background:var(--border);border-radius:999px;overflow:hidden;margin:1.5rem 0}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#06b6d4);border-radius:999px;transition:width .5s ease}.progress-text{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.progress-percent{font-size:2rem;font-weight:800;color:var(--primary)}.submission-progress-list{text-align:left;margin-top:2rem;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.submission-progress-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-bottom:1px solid var(--border);font-size:.875rem}.submission-progress-item:last-child{border-bottom:none}.status-icon{width:24px;text-align:center}.status-done{color:var(--success)}.status-review{color:var(--warning)}.status-pending{color:var(--text-secondary)}.status-active{color:var(--primary)}.session-resume-box{margin-top:2rem;padding:1rem 1.125rem;background:#f0fdfa;border:1px solid #99f6e4;border-radius:10px;display:flex;gap:.75rem;align-items:flex-start;text-align:left}.session-resume-icon{font-size:1.25rem;line-height:1.4;flex-shrink:0}.session-resume-box strong{display:block;font-size:.9375rem;color:var(--text);margin-bottom:.25rem}.session-resume-box p{font-size:.8125rem;color:var(--text-secondary);margin:0;line-height:1.5}.session-resume-box a{color:var(--primary-dark)}.session-resume-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;max-width:520px;margin:0 auto 2rem;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);text-align:left}.session-resume-banner-text{display:flex;flex-direction:column;gap:.25rem;font-size:.8125rem;color:var(--text-secondary)}.session-resume-banner-text strong{font-size:.9375rem;color:var(--text)}.session-resume-banner .btn{flex-shrink:0}.recent-history-section{padding:0 0 3rem;margin-top:-1rem}.recent-history-header{margin-bottom:1rem}.recent-history-header h2{font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.recent-history-header p{font-size:.8125rem;color:var(--text-secondary);margin:0}.recent-history-list{display:flex;flex-direction:column;gap:.5rem}.recent-history-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:inherit;transition:box-shadow .15s,border-color .15s}a.recent-history-item:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.recent-history-item-expired{opacity:.55;background:var(--bg);cursor:not-allowed}.recent-history-main{display:flex;flex-direction:column;gap:.125rem;min-width:0}.recent-history-time{font-size:.75rem;color:var(--text-secondary)}.recent-history-title{font-size:.9375rem;font-weight:600}.recent-history-meta{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.recent-history-score{font-size:.875rem;font-weight:600;color:var(--primary-dark)}.recent-history-arrow{color:var(--text-secondary)}.recent-history-badge{font-size:.75rem;padding:.2rem .5rem;border-radius:999px;background:var(--bg);color:var(--text-secondary);border:1px solid var(--border)}.recent-history-footnote{margin-top:1rem;font-size:.75rem;color:var(--text-secondary);text-align:center}.results-header{justify-content:space-between;align-items:flex-start;gap:1rem}.results-header,.stats-row{display:flex;flex-wrap:wrap;margin-bottom:1.5rem}.stats-row{gap:1.5rem}.stat-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;min-width:100px}.stat-item .value{font-size:1.5rem;font-weight:800;color:var(--primary)}.stat-item .label{font-size:.75rem;color:var(--text-secondary)}.result-list{display:flex;flex-direction:column;gap:.75rem}.result-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:box-shadow .15s;text-decoration:none;color:inherit}.result-item:hover{box-shadow:var(--shadow);border-color:var(--primary)}.result-score{width:56px;height:56px;border-radius:12px;background:var(--primary-light);color:var(--primary-dark);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:800;flex-shrink:0}.result-score.low{background:#fef2f2;color:#dc2626}.result-info{flex:1}.result-info h3{font-size:1rem;margin-bottom:.125rem}.result-info p{font-size:.8125rem}.result-arrow,.result-info p{color:var(--text-secondary)}.survey-box{margin-top:2rem;padding:1.25rem;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius)}.survey-box h4{font-size:.875rem;margin-bottom:.75rem;color:var(--text-secondary)}.survey-options{display:flex;gap:.5rem;flex-wrap:wrap}.survey-options label{padding:.375rem .875rem;border:1px solid var(--border);border-radius:999px;font-size:.8125rem;cursor:pointer;transition:all .15s}.survey-options label:has(input:checked){border-color:var(--primary);background:var(--primary-light);color:var(--primary-dark)}.survey-options input{display:none}.survey-dialog .survey-options{justify-content:center}.survey-option-btn{padding:.375rem .875rem;border:1px solid var(--border);border-radius:999px;font-size:.8125rem;font-family:inherit;cursor:pointer;transition:all .15s;background:var(--bg);color:var(--text)}.survey-option-btn:hover{border-color:var(--primary);background:var(--primary-light);color:var(--primary-dark)}.detail-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media (max-width:900px){.detail-layout{grid-template-columns:1fr}}.detail-image-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.detail-image-wrap{aspect-ratio:3/4;background:#f1f5f9;position:relative;overflow:hidden}.detail-image-wrap img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.page-tabs{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--border)}.page-tab{padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;background:var(--bg);border:none;cursor:pointer;font-family:inherit}.page-tab.active{background:var(--primary);color:#fff}.question-list{display:flex;flex-direction:column;gap:.625rem}.question-item{padding:.875rem 1rem;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.question-item.correct{border-left:3px solid var(--success)}.question-item.incorrect{border-left:3px solid var(--error)}.question-item.review{border-left:3px solid var(--warning)}.question-item.review-low{background:#fffbeb}.confidence-badge{display:inline-block;margin-left:.5rem;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;color:#92400e;background:#fef3c7;border-radius:4px;vertical-align:middle}.question-score.review{color:var(--warning)}.badge-review{display:inline-block;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;color:#92400e;background:#fef3c7;border-radius:4px;vertical-align:middle}.question-review-hint{font-size:.75rem;color:#92400e;margin:.25rem 0 0}.stat-item-review .value{color:var(--warning)}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.question-no{font-weight:700;font-size:.875rem}.question-score{font-size:.8125rem;font-weight:600}.question-score.correct{color:var(--success)}.question-score.incorrect{color:var(--error)}.question-answers{font-size:.8125rem;color:var(--text-secondary)}.overall-comment{margin-top:1rem;padding:1rem;background:var(--primary-light);border-radius:10px;font-size:.875rem}.detail-actions{display:flex;gap:.75rem;margin-top:1rem}.detail-header-row{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.detail-header-actions{display:flex;gap:.75rem;flex-wrap:wrap}.detail-type-badge{display:inline-block;font-size:.8125rem;padding:.2rem .625rem;border-radius:999px;background:var(--primary-light);color:var(--primary-dark);font-weight:600}.detail-score-line{margin:.5rem 0 0}.detail-score-value{font-size:1.5rem;font-weight:800;color:var(--primary)}.detail-score-suffix{color:var(--text-secondary);font-size:.9375rem}.detail-essay-prompt{font-size:.875rem;color:var(--text-secondary);margin:.375rem 0 0}.detail-section-title{font-size:1rem;margin-bottom:1rem}.detail-image-hint{font-size:.75rem;color:var(--text-secondary);text-align:center;padding:.5rem .75rem .75rem;margin:0}.detail-image-wrap-essay{background:#fffef8}.essay-rubric-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.essay-rubric-item{padding:.875rem 1rem;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.essay-rubric-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-weight:600;font-size:.875rem}.essay-rubric-score{color:var(--primary-dark);font-size:.8125rem}.essay-rubric-bar{height:6px;background:var(--border);border-radius:999px;overflow:hidden;margin-bottom:.5rem}.essay-rubric-fill{height:100%;background:linear-gradient(90deg,var(--primary),#06b6d4);border-radius:999px}.essay-rubric-comment{margin:0;line-height:1.5}.essay-meta-row,.essay-rubric-comment{font-size:.8125rem;color:var(--text-secondary)}.essay-meta-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding:.625rem .75rem;background:var(--bg);border-radius:8px}.essay-ocr-details{margin-top:1rem;font-size:.875rem}.essay-ocr-details summary{cursor:pointer;color:var(--primary-dark);font-weight:600;margin-bottom:.5rem}.essay-ocr-text{font-size:.8125rem;color:var(--text-secondary);line-height:1.6;padding:.75rem;background:var(--bg);border-radius:8px;margin:0}.image-preview-lightbox{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem}.image-preview-lightbox[hidden]{display:none!important}.image-preview-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.72);backdrop-filter:blur(4px)}.image-preview-dialog{position:relative;z-index:1;width:min(920px,100%);max-height:calc(100vh - 2rem);display:flex;flex-direction:column;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.image-preview-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}.image-preview-title{font-size:.9375rem;font-weight:600}.image-preview-close{width:36px;height:36px;border:none;border-radius:8px;background:var(--bg);font-size:1.25rem;line-height:1;cursor:pointer;color:var(--text-secondary);font-family:inherit}.image-preview-close:hover{background:var(--primary-light);color:var(--primary-dark)}.image-preview-stage-wrap{position:relative;flex:1;min-height:0;background:#0f172a;padding:1rem}.image-preview-stage,.image-preview-stage-wrap{display:flex;align-items:center;justify-content:center}.image-preview-stage{width:100%;max-height:calc(100vh - 10rem);overflow:auto}.image-preview-stage img,.image-preview-stage svg{max-width:100%;max-height:calc(100vh - 10rem);width:auto;height:auto;-o-object-fit:contain;object-fit:contain;border-radius:4px;box-shadow:0 8px 32px rgba(0,0,0,.35)}.image-preview-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border:none;border-radius:50%;background:hsla(0,0%,100%,.92);box-shadow:var(--shadow);font-size:1.25rem;cursor:pointer;z-index:2;font-family:inherit;color:var(--text)}.image-preview-nav:hover{background:#fff}.image-preview-nav:disabled{opacity:.35;cursor:not-allowed}.image-preview-nav.prev{left:.75rem}.image-preview-nav.next{right:.75rem}.image-preview-footer{padding:.625rem 1rem;font-size:.8125rem;color:var(--text-secondary);text-align:center;border-top:1px solid var(--border);flex-shrink:0}@media (max-width:900px){.image-preview-lightbox{padding:0}.image-preview-dialog{width:100%;max-height:100vh;height:100%;border-radius:0}.image-preview-stage img,.image-preview-stage svg{max-height:calc(100vh - 8rem)}}.proto-modal{position:fixed;inset:0;z-index:210;display:flex;align-items:center;justify-content:center;padding:1rem}.proto-modal[hidden]{display:none!important}.proto-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.55);backdrop-filter:blur(3px)}.proto-modal-dialog{position:relative;z-index:1;width:min(440px,100%);max-height:calc(100vh - 2rem);overflow:auto;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:1.25rem 1.25rem 1rem}.proto-modal-title{margin:0 0 1rem;font-size:1.0625rem;font-weight:600}.proto-modal-body{display:flex;flex-direction:column;gap:.875rem}.proto-field label{display:block;font-size:.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:.375rem}.proto-field input[type=number],.proto-field input[type=text],.proto-field textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:.9375rem;font-family:inherit;color:var(--text);background:var(--bg);box-sizing:border-box}.proto-field textarea{min-height:120px;resize:vertical;line-height:1.55}.proto-field input:focus,.proto-field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.proto-field-hint{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.proto-dimension-row{display:grid;grid-template-columns:4.5rem 1fr auto;align-items:center;gap:.5rem}.proto-dimension-row span:first-child{font-size:.875rem;font-weight:600}.proto-dimension-row input{width:100%}.proto-dimension-row .proto-dimension-max{font-size:.8125rem;color:var(--text-secondary);white-space:nowrap}.proto-modal-footer{display:flex;justify-content:flex-end;gap:.625rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.proto-toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(12px);z-index:220;padding:.625rem 1rem;background:rgba(15,23,42,.92);color:#fff;font-size:.875rem;border-radius:999px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s}.proto-toast.is-visible{opacity:1;transform:translateX(-50%) translateY(0)}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Segoe UI,PingFang SC,Microsoft YaHei,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.block{display:block}.flex{display:flex}.hidden{display:none}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}a{color:inherit;text-decoration:none}.hidden{display:none!important}