:root{--bg:#080f18;--bg2:#0b1420;--bg3:#0f1c2e;--bg4:#111f33;--blue:#5a8fda;--cyan:#4ab3cc;--cream:#ddeaf7;--text:#9eb8d4;--muted:#5e7b98;--slate:#4a6480;--dim:#5a8fda1f;--border:#5a8fda24;--green:#6cc49a;--amber:#c8a468;--danger:#cc8080;--surface:#0b1420;--card:#0f1c2e;--card2:#111f33;--border2:#5a8fda4d;--red:#cc8080;--red-dim:#cc80801a;--cyan-dim:#5a8fda1a;--green-dim:#6cc49a1a;--purple:#8b5cf6;--mono:"JetBrains Mono", "SF Mono", "Fira Code", monospace;--radius:0px;--max-w:520px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:JetBrains Mono,SF Mono,Fira Code,monospace;font-size:15px;line-height:1.5}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--border)}.app-wrapper{max-width:var(--max-w);margin:0 auto;padding:0 0 60px}html.telerehab,body.telerehab{background:#1c1814;height:100vh;margin:0;overflow:hidden}body.telerehab .app-wrapper{max-width:100vw;padding:0}body.telerehab .app-header,body.telerehab .step-indicator,body.telerehab .step-panel,body.telerehab #insecureCtxBanner,body.telerehab #lang-switcher,body.telerehab footer,body.telerehab #alertBox{display:none!important}body.telerehab #cameraWidget{z-index:1;width:100vw;height:100vh;margin:0;padding:0;position:fixed;inset:0;display:block!important}body.telerehab #cameraWidget .camera-container{background:#1c1814;border-radius:0;width:100%;height:100%;position:relative}body.telerehab #cameraWidget video,body.telerehab #cameraWidget canvas{object-fit:cover;width:100%;height:100%}body.telerehab #cameraWidget .camera-container:after{content:"● 監測中 · 訊號傳給訓練師";color:#f7f3ed;letter-spacing:.08em;pointer-events:none;z-index:10;background:#0000008c;border-radius:14px;padding:6px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;position:absolute;bottom:16px;left:16px}#insecureCtxBanner{z-index:9999;color:#cc9898;background:#370a0af5;border-bottom:1px solid #cc80804d;padding:.52rem 1rem;font-size:.65rem;line-height:1.82;display:none;position:fixed;top:0;left:0;right:0}#insecureCtxBanner strong{color:var(--text)}#insecureCtxBanner code{background:#00000047;padding:0 3px}.app-header{border-bottom:1px solid var(--border);background:var(--bg2);align-items:center;gap:.75rem;padding:.85rem 1.1rem .7rem;display:flex;position:relative}.app-header:after{content:"";background:linear-gradient(90deg, transparent, var(--blue), transparent);height:1px;position:absolute;bottom:-1px;left:10%;right:10%}.home-btn{border:1px solid var(--border);width:28px;height:28px;color:var(--muted);background:0 0;flex-shrink:0;justify-content:center;align-items:center;text-decoration:none;transition:all .15s;display:flex}.home-btn:hover{border-color:var(--blue);color:var(--cyan)}.logo-block{flex:1;align-items:center;gap:.48rem;min-width:0;display:flex}.logo-glyph{color:var(--blue);letter-spacing:-.05em;flex-shrink:0;font-family:Cormorant Garamond,serif;font-size:1.4rem;font-style:italic;font-weight:300;line-height:1}.logo-text{flex-direction:column;min-width:0;display:flex}.app-title{color:var(--cream);letter-spacing:.06em;-webkit-text-fill-color:var(--cream);background:0 0;-webkit-background-clip:unset;background-clip:unset;font-size:.8rem;font-weight:500;line-height:1.1}.app-powered{opacity:.45;color:var(--muted);letter-spacing:.02em;-webkit-text-fill-color:var(--muted);font-size:.52rem;font-weight:400}.app-subtitle{color:var(--muted);margin-top:.04rem;font-size:.6rem}#appVersion{opacity:.38;margin-left:5px;font-size:.75em}#lang-switcher{flex-shrink:0;gap:3px;display:flex}.lang-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;letter-spacing:.05em;background:0 0;border-radius:0;padding:.18rem .42rem;font-family:JetBrains Mono,monospace;font-size:.62rem;transition:all .18s}.lang-btn.active{color:var(--blue);border-color:#5a8fda61}.lang-btn:hover{color:var(--text);border-color:var(--blue)}.step-indicator{background:var(--bg2);border-bottom:1px solid var(--border);flex-direction:column;gap:4px;padding:.55rem 1.1rem .5rem;display:flex}.step-track{align-items:center;width:100%;max-width:100%;display:flex}.step-dot{border:1px solid var(--border);background:var(--bg3);width:22px;height:22px;color:var(--muted);z-index:1;border-radius:0;flex-shrink:0;justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:.58rem;font-weight:600;transition:all .3s;display:flex;position:relative}.step-dot.active{background:var(--dim);border-color:var(--blue);color:var(--blue)}.step-dot.done{background:var(--blue);border-color:var(--blue);color:var(--bg)}.step-connector{background:var(--border);flex:1;height:1px;transition:background .4s}.step-connector.filled{background:var(--blue)}.step-labels{justify-content:space-between;width:100%;max-width:100%;display:flex}.step-labels span{text-align:center;width:22px;color:var(--muted);font-family:JetBrains Mono,monospace;font-size:.54rem;transition:color .3s}.step-labels span.active{color:var(--blue)}.step-labels span.done{color:var(--slate)}.step-panel{padding:0;animation:.18s fadeUp;display:none}.step-panel.active{display:block}@keyframes fadeUp{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}#cameraWidget{margin-bottom:0;padding:0;display:none}.camera-container{border-bottom:1px solid var(--border);aspect-ratio:4/3;background:#000;border-radius:0;justify-content:center;align-items:center;width:100%;max-height:280px;display:flex;position:relative;overflow:hidden}#video{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}#canvas{display:none}#overlayCanvas{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0;transform:scaleX(-1)}#signalCanvas{background:var(--bg4);border-top:1px solid var(--border);border-radius:0;width:100%;height:80px;margin-top:0;display:block}.card{background:var(--bg2);border:none;border-bottom:1px solid var(--border);border-radius:0;margin-bottom:0;padding:.9rem 1.1rem 1rem;position:relative}.card:before{display:none}.card-title{letter-spacing:.16em;text-transform:uppercase;color:var(--blue);border-bottom:1px solid #5a8fda1a;align-items:center;gap:.4rem;margin-bottom:.9rem;padding-bottom:.28rem;font-size:.62rem;font-weight:400;display:flex}.card-title:before{content:"";background:var(--blue);opacity:.5;flex-shrink:0;width:8px;height:1px}.card-icon{display:none}.form-grid{grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.6rem;display:grid}.form-group{flex-direction:column;gap:.22rem;display:flex}.form-group.full{grid-column:span 2}label{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:.65rem;font-weight:400}input,select,textarea{background:var(--bg4);border:1px solid var(--dim);color:var(--cream);appearance:none;border-radius:0;outline:none;width:100%;padding:.3rem .4rem;font-family:JetBrains Mono,monospace;font-size:.8rem;transition:border-color .18s}input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:none;background:#060c14e0}input::placeholder,textarea::placeholder{color:var(--slate);opacity:1}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%235a8fda' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:10px;padding-right:22px}select option{background:var(--bg3)}textarea{resize:none;min-height:46px}.inst-list{color:var(--text);padding-left:1rem;font-size:.72rem;line-height:2.1}.inst-list li strong{color:var(--cream);font-weight:500}.btn-row{flex-wrap:wrap;justify-content:flex-end;gap:.3rem;margin-top:.9rem;display:flex}.btn{cursor:pointer;letter-spacing:.05em;white-space:nowrap;border:1px solid var(--border);color:var(--text);background:0 0;border-radius:0;align-items:center;gap:.28rem;padding:.35rem .9rem;font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:400;transition:all .15s;display:inline-flex}.btn:hover:not(:disabled){border-color:var(--blue);color:var(--cream)}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-primary{color:var(--blue);border-color:#5a8fda70}.btn-primary:hover:not(:disabled){color:var(--cream);background:#5a8fda17;border-color:#5a8fdaad}.btn-secondary{border-color:var(--border);color:var(--muted)}.btn-secondary:hover:not(:disabled){border-color:var(--blue);color:var(--text)}.btn-outline{color:var(--cyan);border-color:#4ab3cc57}.btn-outline:hover:not(:disabled){background:#4ab3cc14}.btn-danger{color:var(--danger);border-color:#cc80804d}.btn-danger:hover:not(:disabled){background:#cc808014}.btn-green{color:var(--green);background:0 0;border-color:#6cc49a4d}.btn-purple{color:var(--purple);background:0 0;border-color:#8b5cf64d}.btn-sm{padding:.25rem .65rem;font-size:.62rem}#alertBox{background:var(--bg3);color:var(--danger);z-index:999;text-align:center;letter-spacing:.04em;border:1px solid #cc808061;border-radius:0;max-width:80%;padding:.42rem 1rem;font-size:.68rem;display:none;position:fixed;top:1.1rem;left:50%;transform:translate(-50%)}.align-tip{color:var(--text);margin-bottom:.75rem;font-size:.72rem;line-height:1.75}.align-tip strong{color:var(--cream)}#cameraErrorPanel{background:#41141452;border:1px solid #cc808042;border-radius:0;margin-top:.6rem;padding:.55rem}#cameraErrorTitle{color:var(--danger);margin-bottom:.3rem;font-size:.72rem}#cameraErrorBody{color:#dda0a0;white-space:pre-wrap;margin-bottom:.45rem;font-family:inherit;font-size:.64rem}.lighting-bar-wrap{background:var(--bg4);border:1px solid #ffffff05;border-radius:0;height:4px;margin-bottom:.28rem;overflow:hidden}#lightingBar{background:linear-gradient(90deg, var(--bg4) 0%, var(--danger) 10%, var(--amber) 22%, var(--green) 42%, var(--green) 68%, var(--amber) 82%, var(--danger) 92%, var(--bg4) 100%);background-repeat:no-repeat;background-size:460px 100%;width:50%;height:100%;transition:width .35s}.lighting-status{color:var(--green);margin-top:3px;font-size:.65rem;font-weight:400}.lighting-status.good{color:var(--green)}.lighting-status.warn{color:var(--amber)}.lighting-status.bad{color:var(--danger)}.dur-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;letter-spacing:.04em;background:0 0;border-radius:0;padding:.22rem .55rem;font-family:JetBrains Mono,monospace;font-size:.66rem;transition:all .14s}.dur-btn:hover{border-color:var(--blue);color:var(--cream)}.dur-btn-active{color:var(--blue)!important;background:#5a8fda17!important;border-color:#5a8fda70!important}.rec-header{align-items:center;gap:.45rem;margin-bottom:.7rem;display:flex}.rec-dot{background:var(--danger);border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:.9s ease-in-out infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.2}}#faceWarnBanner{color:#de9090;background:#41141461;border:1px solid #cc808042;border-radius:0;margin-bottom:.6rem;padding:.3rem .55rem;font-size:.68rem;font-weight:400}.progress-bar-wrap{background:var(--bg4);border:1px solid #ffffff05;border-radius:0;height:2px;margin-bottom:.85rem;overflow:hidden}.progress-bar{background:linear-gradient(90deg, var(--blue), var(--cyan));width:0%;height:100%;transition:width .2s linear}.rec-countdown{color:var(--cream);letter-spacing:-.02em;text-align:right;min-width:6.5ch;font-family:JetBrains Mono,monospace;font-size:2.1rem;font-weight:400;line-height:1;display:inline-block}.live-beat{color:var(--cyan);letter-spacing:.04em;flex-shrink:0;font-size:.72rem}#liveVitalsPanel{background:var(--bg3);border:1px solid #5a8fda14;border-radius:0;margin:0 0 .65rem;padding:.6rem .65rem}.live-panel-title{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.62rem;font-weight:400;display:flex}.live-metrics-grid{grid-template-columns:repeat(4,1fr);gap:4px;display:grid}.live-metric-cell{background:var(--bg4);text-align:center;border:1px solid #5a8fda12;border-radius:0;padding:.55rem .25rem}.live-metric-val{color:var(--blue);letter-spacing:-.02em;margin-bottom:.1rem;font-family:JetBrains Mono,monospace;font-size:1.15rem;font-weight:400;line-height:1;transition:color .5s}.live-metric-lbl{color:var(--muted);letter-spacing:.03em;font-size:.6rem;line-height:1.4}.live-val-flash{color:var(--green)!important}.processing-wrap{text-align:center;flex-direction:column;align-items:center;gap:.85rem;padding:3rem 1rem;display:flex}.processing-spinner{border:1.5px solid var(--dim);border-top-color:var(--blue);border-radius:50%;width:44px;height:44px;animation:1.1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.processing-status{color:var(--blue);letter-spacing:.04em;font-size:.68rem}.process-progress-wrap{background:var(--bg4);border-radius:0;width:180px;height:2px;overflow:hidden}#processProgress{background:linear-gradient(90deg, var(--blue), var(--cyan));width:0%;height:100%;transition:width .3s}.res-hero{background:var(--bg3);border-bottom:1px solid #5a8fda1f;border-radius:0;align-items:center;gap:1rem;padding:1rem 1.1rem;display:flex;position:relative;overflow:hidden}.res-hero:before{content:"";background:linear-gradient(90deg, transparent, var(--blue), transparent);height:1px;position:absolute;top:0;left:0;right:0}.score-ring-outer{flex-shrink:0;position:relative}.score-svg{display:block;transform:rotate(-90deg)}.score-track{fill:none;stroke:var(--dim);stroke-width:5px}.score-fill{fill:none;stroke:url(#scoreGrad);stroke-width:5px;stroke-linecap:butt;stroke-dasharray:226;stroke-dashoffset:56px;transition:stroke-dashoffset 1.2s cubic-bezier(.4,0,.2,1)}.score-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.score-num{color:var(--blue);letter-spacing:-.02em;font-family:JetBrains Mono,monospace;font-size:1.3rem;font-weight:500;line-height:1}.score-lbl{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:.05rem;font-size:.58rem}.res-hero-body{flex:1;min-width:0}.res-hero-title{color:var(--cream);letter-spacing:.02em;margin-bottom:.1rem;font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:500}.results-title{color:var(--cream);font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:500}.results-time{color:var(--muted);margin-top:2px;margin-bottom:4px;font-size:.65rem}#resDurationNote{color:var(--amber);margin:2px 0;padding:2px 0;font-size:.65rem;display:inline-block}#resDurationNote:empty{display:none}#resZSummary{color:var(--cyan);margin:2px 0;font-size:.68rem}.res-badge{color:var(--green);letter-spacing:.04em;border:1px solid #6cc49a3d;border-radius:0;align-items:center;gap:.22rem;padding:.16rem .44rem;font-size:.62rem;display:inline-flex}#reportQRSection{text-align:center;background:var(--bg3);border:1px solid var(--border);border-radius:0;margin:0 1.1rem .6rem;padding:.65rem;display:none}.export-grid{border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;gap:3px;padding:.55rem 1.1rem;display:grid}.res-section{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);background:var(--bg2);border-top:1px solid #5a8fda14;align-items:center;gap:.4rem;padding:.35rem 1.1rem;font-size:.65rem;display:flex}.res-section:before{content:"";background:var(--blue);opacity:.5;flex-shrink:0;width:8px;height:1px;display:block}.res-list{background:0 0;border:none;border-radius:0;flex-direction:column;gap:2px;margin-bottom:0;padding:.35rem 0;display:flex;overflow:visible}.res-row{background:var(--bg3);border:1px solid #5a8fda0f;border-left:2px solid var(--dim);border-radius:0;align-items:center;gap:.6rem;padding:.55rem 1.1rem;transition:background .13s;display:flex}.res-row:last-child{border-bottom:1px solid #5a8fda0f}.res-row:hover{background:#5a8fda0a}.res-icon{display:none}.res-info{flex:1;min-width:0}.res-name{color:var(--text);flex-wrap:wrap;align-items:center;gap:.28rem;margin-bottom:.05rem;font-size:.68rem;line-height:1.3;display:flex}.res-sub{color:var(--muted);margin-top:0;font-size:.62rem;line-height:1.4}.metric-value{color:var(--cream);text-align:right;white-space:nowrap;letter-spacing:-.02em;font-family:JetBrains Mono,monospace;font-size:1.05rem;font-weight:400;line-height:1}.metric-value.good{color:var(--green)}.metric-value.warn{color:var(--amber)}.metric-value.crit{color:var(--danger)}.metric-interp{color:var(--muted);font-size:.62rem}.tag{letter-spacing:.03em;white-space:nowrap;border:1px solid;border-radius:0;padding:.04rem .28rem;font-size:.62rem;font-weight:400}.tag.green{color:var(--green);background:0 0;border-color:#6cc49a4d}.tag.amber{color:var(--amber);background:0 0;border-color:#c8a4684d}.tag.red{color:var(--danger);background:0 0;border-color:#cc80804d}.disclaimer{background:var(--bg4);color:var(--muted);border-top:1px solid #5a8fda14;border-radius:0;margin-bottom:0;padding:.65rem 1.1rem;font-size:.65rem;line-height:1.9}.disclaimer strong{color:var(--text);font-weight:400}.hrv-card{background:var(--bg3);border:1px solid var(--border);border-radius:0;margin-bottom:0;padding:.75rem 1.1rem}.hrv-area{background:#0003;height:62px;margin:.5rem 0;overflow:hidden}.hrv-svg{width:100%;height:100%}.hrv-stats{color:var(--muted);flex-wrap:wrap;gap:.9rem;font-size:.65rem;display:flex}.hrv-stats strong{color:var(--text)}@media (width<=560px){.step-panel,#cameraWidget{padding:0}.live-metrics-grid{grid-template-columns:repeat(2,1fr)}.btn-row{flex-direction:column}.btn{justify-content:center}}@media (width<=400px){.form-grid{grid-template-columns:1fr}.form-group.full{grid-column:span 1}}
