*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Helvetica Neue,sans-serif;background:#0d0e14;display:flex;justify-content:center;align-items:center;min-height:100vh}.phone-frame{width:448px;height:966px;background:#1a1b22;border-radius:40px;overflow:hidden;position:relative;display:flex;flex-direction:column;box-shadow:0 0 80px #00f0ff14}@media(max-width:500px){body{align-items:stretch}.phone-frame{width:100%;height:100vh;border-radius:0;box-shadow:none}}.status-bar{height:53px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:8px;color:#fff;font-size:15px;font-weight:600}.nav-bar{height:44px;display:flex;align-items:center;justify-content:center;padding:0 16px;position:relative}.nav-bar .title{color:#fff;font-size:17px;font-weight:600}.nav-bar .nav-back{position:absolute;left:16px;color:#a7c8ff;font-size:28px;cursor:pointer;line-height:1}.nav-bar .nav-placeholder{width:28px}.page-content{flex:1;overflow-y:auto;padding:16px;scrollbar-width:none}.page-content::-webkit-scrollbar{display:none}.progress-header{padding:10px 16px;background:#1e1f26;border-bottom:1px solid #30353b}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.progress-text{color:#dae2fd;font-size:13px;font-weight:500}.progress-count{color:#6c6f71;font-size:12px}.progress-track{height:4px;background:#30353b;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#a7c8ff,#86b7ee);border-radius:2px;transition:width .3s ease}.progress-fill.pass{background:linear-gradient(90deg,#43c363,#2dd4bf)}.progress-segments{display:flex;gap:2px;height:6px}.progress-segments .seg{flex:1;border-radius:3px;background:#30353b;transition:background .3s}.progress-segments .seg.pass{background:#43c363}.progress-segments .seg.fail{background:#eb655e}.progress-segments .seg.active{background:#a7c8ff;animation:segPulse 1s infinite}@keyframes segPulse{0%,to{opacity:1}50%{opacity:.5}}.section-header.clickable{cursor:pointer}.section-header-right{display:flex;align-items:center;gap:8px}.collapse-icon{color:#6c6f71;font-size:16px;transition:transform .2s}.bottom-bar{min-height:53px;background:#1e1f26;display:flex;align-items:center;justify-content:center;padding:0 16px}.bottom-bar .input-box{flex:1;height:36px;background:#2a2b33;border:1px solid #30353b;border-radius:18px;padding:0 16px;color:#fff;font-size:13px;outline:none}.steps-card{background:#252a31;border-radius:12px;padding:16px;margin-bottom:16px}.step-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.05)}.step-item:last-child{border-bottom:none}.step-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}.step-dot.done{background:#1a3a2a;color:#43c363}.step-name{color:#dae2fd;font-size:14px}.entry-cell{display:flex;align-items:center;gap:12px;background:#252a31;border-radius:12px;padding:16px;margin-bottom:10px;cursor:pointer;transition:background .2s}.entry-cell:hover{background:#2d3340}.entry-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#1e1f26;border-radius:10px}.entry-info{flex:1;display:flex;flex-direction:column;gap:3px}.entry-title{color:#fff;font-size:15px;font-weight:500}.entry-status{font-size:12px}.entry-status.pending{color:#f0c040}.entry-status.pass{color:#43c363}.entry-status.fail{color:#eb655e}.entry-status.checking{color:#a7c8ff}.entry-arrow{color:#6c6f71;font-size:24px}.access-system-btn{width:100%;height:44px;border-radius:10px;border:none;background:#324089;color:#86b7ee;font-size:15px;font-weight:500;margin-top:20px;cursor:pointer}.access-system-btn:disabled{opacity:.4;cursor:not-allowed}.section-card{background:#252a31;border-radius:12px;padding:16px;margin-bottom:16px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.section-title{color:#fff;font-size:16px;font-weight:600}.section-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;background:#324089;color:#86b7ee}.section-badge.pass{background:#1a3a2a;color:#43c363}.section-badge.fail{background:#3a1a1a;color:#eb655e}.section-desc{color:#6c6f71;font-size:12px;margin-bottom:12px}.image-row{display:flex;gap:10px}.image-cell{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer}.image-add{width:100%;aspect-ratio:1;border:1.5px dashed #6c6f71;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:border-color .2s}.image-cell:hover .image-add{border-color:#a7c8ff}.image-add .add-icon{color:#6c6f71;font-size:24px}.image-preview{width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;position:relative}.image-preview img{width:100%;height:100%;object-fit:cover}.image-badge{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.image-badge.pass{background:#1a3a2a;color:#43c363}.image-badge.fail{background:#3a1a1a;color:#eb655e}.image-badge.analyzing{background:#1a2a3a;color:#a7c8ff;animation:pulse 1s infinite}.image-label{color:#9b9e9f;font-size:11px;text-align:center}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{background:#252a31;border-radius:16px;padding:24px;width:320px;max-width:90vw}.modal-title{color:#fff;font-size:17px;font-weight:600;margin-bottom:12px;text-align:center}.modal-example{margin-bottom:12px;border-radius:8px;overflow:hidden;display:flex;justify-content:center}.modal-example canvas{border-radius:8px}.modal-example img{width:100%;border-radius:8px;object-fit:cover;max-height:200px}.modal-desc{color:#9b9e9f;font-size:12px;line-height:1.8;margin-bottom:16px}.modal-actions{display:flex;gap:10px}.modal-btn{flex:1;height:38px;border-radius:8px;border:none;font-size:14px;font-weight:500;cursor:pointer}.modal-btn.cancel{background:#1e1f26;color:#9b9e9f}.modal-btn.confirm{background:#a7c8ff;color:#1a1b22}.camera-view{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0a0a0a}.camera-frame{width:260px;height:260px;border:2px solid rgba(167,200,255,.5);border-radius:12px;animation:cameraScan 2s infinite}@keyframes cameraScan{0%,to{box-shadow:0 0 20px #a7c8ff33}50%{box-shadow:0 0 40px #a7c8ff66}}.camera-label{color:#9b9e9f;font-size:13px;margin-top:16px}.camera-shutter{width:64px;height:64px;border-radius:50%;border:4px solid #fff;margin-top:30px;cursor:pointer;position:relative;transition:transform .1s}.camera-shutter:active{transform:scale(.9)}.camera-shutter:after{content:"";position:absolute;top:4px;left:4px;right:4px;bottom:4px;background:#fff;border-radius:50%}.check-list{display:flex;flex-direction:column;gap:2px}.check-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:6px;position:relative;overflow:hidden}.check-item.running{background:linear-gradient(90deg,rgba(96,160,255,.12) 0%,rgba(96,160,255,.12) calc(var(--progress,0%) - 8%),rgba(120,200,255,.35) calc(var(--progress,0%) - 2%),rgba(167,200,255,.5) var(--progress,0%),transparent calc(var(--progress,0%) + 1%));box-shadow:inset 0 0 8px #60a0ff1a}.check-item.running:after{content:"";position:absolute;top:0;left:0;width:var(--progress,0%);height:100%;background:linear-gradient(90deg,transparent 60%,rgba(167,200,255,.15) 80%,rgba(167,200,255,.4) 95%,rgba(200,230,255,.6) 100%);animation:electricPulse .8s ease-in-out infinite;pointer-events:none}@keyframes electricPulse{0%,to{opacity:.6}50%{opacity:1;filter:brightness(1.3)}}.check-item.running .item-name{color:#a7c8ff}.check-item.pass-bg{background:#43c36314}.check-item.pass-bg .status-icon{text-shadow:0 0 4px rgba(67,195,99,.6)}.check-item.fail-bg{background:#eb655e14}.check-item.fail-bg .status-icon{text-shadow:0 0 4px rgba(235,101,94,.6)}.status-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0}.status-icon.pass{background:#1a3a2a;color:#43c363}.status-icon.fail{background:#3a1a1a;color:#eb655e}.status-icon.pending{background:#2a2a2a;color:#6c6f71}.status-icon.running{background:#1a2a3a;color:#60a0ff;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.item-name{color:#dae2fd;font-size:13px;flex:1}.item-detail{color:#6c6f71;font-size:11px;max-width:120px;text-align:right}.item-status{font-size:12px;color:#6c6f71;min-width:50px;text-align:right}.item-status.pass{color:#43c363}.item-status.fail{color:#eb655e}.summary-section{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08);display:flex;gap:16px}.summary-row{display:flex;align-items:center;gap:6px}.summary-label{color:#6c6f71;font-size:12px}.summary-value{color:#fff;font-size:16px;font-weight:600}.summary-value.pass{color:#43c363}.summary-value.fail{color:#eb655e}.troubleshoot-card{margin-top:12px;background:#1e1f26;border-radius:8px;padding:12px}.ts-header{color:#eb655e;font-size:13px;font-weight:500;margin-bottom:4px}.ts-error{color:#9b9e9f;font-size:12px;margin-bottom:8px}.ts-steps{display:flex;flex-direction:column;gap:4px}.ts-step{color:#6c6f71;font-size:12px}.ts-actions{display:flex;gap:8px;margin-top:10px}.action-btn{padding:7px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;border:none;transition:opacity .2s}.action-btn:hover{opacity:.8}.action-btn.primary{background:#324089;color:#86b7ee}.start-btn{width:100%;height:40px;border-radius:10px;border:none;background:#a7c8ff;color:#1a1b22;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s}.start-btn:hover{opacity:.9}
