:root{--paper: #faf7f0;--paper-2: #f1ece0;--card: #fffdf9;--line: rgba(20, 48, 43, .09);--line-strong: rgba(20, 48, 43, .16);--ink: #16302b;--ink-soft: #50615b;--ink-faint: #8a968f;--pine: #0e3a34;--teal: #0e7c6b;--teal-bright: #18a589;--mist: #e2efe8;--mist-2: #cfe6dc;--honey: #cf8a2c;--honey-soft: #f6e8cd;--coral: #df5a34;--coral-deep: #c5431f;--good: #2f8a6c;--good-bg: #eef7f1;--warn: #c4861a;--warn-bg: #fbf2dd;--bad: #d2552e;--bad-bg: #fbeee7;--font-ui: "Hanken Grotesk", system-ui, -apple-system, sans-serif;--font-display: "Fraunces", "Noto Serif TC", Georgia, serif;--font-han: "Noto Serif TC", "Fraunces", serif;--font-mono: "IBM Plex Mono", ui-monospace, monospace;--r: 18px;--r-lg: 26px;--shadow-soft: 0 1px 2px rgba(20, 48, 43, .04), 0 10px 26px -14px rgba(20, 48, 43, .18);--shadow-lg: 0 2px 6px rgba(20, 48, 43, .05), 0 34px 60px -28px rgba(14, 58, 52, .42)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}#root{position:relative;z-index:1}body{font-family:var(--font-ui);background:var(--paper);color:var(--ink);font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;letter-spacing:.1px}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(60% 50% at 12% 0%,rgba(24,165,137,.16),transparent 60%),radial-gradient(55% 45% at 100% 18%,rgba(207,138,44,.12),transparent 58%),radial-gradient(70% 60% at 50% 110%,rgba(14,58,52,.1),transparent 60%)}body:after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.app{max-width:520px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;padding:0 20px env(safe-area-inset-bottom,22px)}.appbar{display:flex;align-items:center;gap:13px;padding:22px 2px 16px}.appbar .mark{width:44px;height:44px;border-radius:14px;background:radial-gradient(120% 120% at 30% 20%,var(--teal-bright),var(--pine) 80%);color:#f7efe0;display:flex;align-items:center;justify-content:center;font-family:var(--font-han);font-weight:700;font-size:21px;flex-shrink:0;box-shadow:0 6px 16px -6px #0e3a348c,inset 0 1px #ffffff40;position:relative}.appbar .mark:after{content:"";position:absolute;inset:5px;border-radius:10px;border:1px solid rgba(247,239,224,.28)}.appbar h1{font-family:var(--font-display);font-optical-sizing:auto;font-size:21px;font-weight:600;margin:0;color:var(--pine);letter-spacing:.2px}.appbar .sub{font-size:11px;color:var(--ink-faint);margin-top:2px;letter-spacing:1.4px;text-transform:uppercase}.appbar .right{margin-left:auto}.progress{padding:4px 2px 16px}.progress-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}.progress-step{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--pine);letter-spacing:.3px}.progress-meta{font-size:12px;color:var(--ink-faint);letter-spacing:.4px}.seg{display:flex;gap:5px}.seg-item{flex:1;height:6px;border-radius:99px;background:var(--mist-2);cursor:pointer;border:none;padding:0;transition:background .3s,transform .2s}.seg-item.done{background:linear-gradient(90deg,var(--teal),var(--teal-bright))}.seg-item.current{background:var(--honey);box-shadow:0 0 0 3px var(--honey-soft);transform:scaleY(1.5)}.seg-item.skipped{background:#e3c79a}.stage{flex:1;display:flex;flex-direction:column;animation:rise .55s cubic-bezier(.2,.7,.2,1) both}@keyframes rise{0%{opacity:0;transform:translateY(14px)}}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-soft);padding:26px 22px;margin-bottom:16px}.title-xl{font-family:var(--font-display);font-size:26px;font-weight:600;margin:2px 0 6px;color:var(--pine);letter-spacing:.2px}.lede{color:var(--ink-soft);font-size:14.5px;margin:0 0 22px}.tasktype{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--teal);background:var(--mist);border:1px solid var(--mist-2);padding:7px 15px;border-radius:99px;letter-spacing:1px;text-transform:uppercase}.promptbox{position:relative;background:radial-gradient(120% 80% at 50% 0%,#ffffff,var(--card)),var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:38px 24px 32px;text-align:center;margin:16px 0 22px;overflow:hidden}.promptbox:before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,var(--teal),var(--teal-bright),var(--honey));opacity:.85}.glyph{font-family:var(--font-display);font-optical-sizing:auto;font-size:clamp(56px,17vw,92px);font-weight:600;color:var(--pine);line-height:1.05;letter-spacing:1px}.say{font-family:var(--font-han);font-size:clamp(27px,7.6vw,38px);font-weight:700;color:var(--pine);line-height:1.5;letter-spacing:.5px}.subline{font-size:16px;color:var(--ink-soft);margin-top:16px;letter-spacing:.3px}.repeat-pill{display:inline-block;margin-top:16px;font-size:13px;font-weight:700;color:var(--honey);background:var(--honey-soft);padding:6px 14px;border-radius:99px;letter-spacing:.5px}.reczone{display:flex;flex-direction:column;align-items:center;gap:18px;padding:10px 0 4px}.mic-wrap{position:relative;width:176px;height:176px;display:flex;align-items:center;justify-content:center}.mic-ring{position:absolute;inset:0;transform:rotate(-90deg)}.mic-btn{position:relative;width:138px;height:138px;border-radius:50%;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:#fbf4e6;font-family:var(--font-ui);font-size:14px;font-weight:700;letter-spacing:.6px;transition:transform .1s ease}.mic-btn:after{content:"";position:absolute;inset:7px;border-radius:50%;border:1px solid rgba(255,255,255,.22)}.mic-btn:active{transform:scale(.95)}.mic-btn.idle{background:radial-gradient(130% 130% at 32% 22%,var(--teal-bright),var(--pine) 78%);box-shadow:0 22px 50px -18px #0e3a3499,0 0 0 10px #18a58914;animation:breathe 3.4s ease-in-out infinite}@keyframes breathe{0%,to{box-shadow:0 22px 50px -18px #0e3a348c,0 0 0 10px #18a58912}50%{box-shadow:0 26px 56px -18px #0e3a349e,0 0 0 18px #18a5891f}}.mic-btn.rec{background:radial-gradient(130% 130% at 32% 22%,var(--coral),var(--coral-deep) 80%);box-shadow:0 22px 52px -18px #c5431f9e}.mic-btn.rec.ready{background:radial-gradient(130% 130% at 32% 22%,var(--teal-bright),var(--good) 82%);box-shadow:0 22px 52px -18px #2f8a6c99}.mic-time{font-family:var(--font-mono);font-size:30px;font-weight:600;line-height:1;letter-spacing:1px}.mic-sub{font-size:12px;font-weight:700;opacity:.92;letter-spacing:1px}.rec-hint{font-size:15px;color:var(--ink-soft);min-height:22px;text-align:center;letter-spacing:.3px}.rec-hint b{color:var(--good);font-weight:700}.scope{width:100%;height:96px;display:block;border-radius:16px;background:linear-gradient(180deg,#ffffff,var(--mist) 140%);border:1px solid var(--mist-2);box-shadow:inset 0 1px 3px #14302b0d}.voice-cue{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;padding:6px 13px;border-radius:99px;letter-spacing:.5px;white-space:nowrap}.voice-cue.on{color:var(--good);background:var(--good-bg)}.voice-cue.off{color:var(--ink-faint);background:var(--paper-2)}.voice-cue .pip{width:9px;height:9px;border-radius:50%;background:currentColor}.voice-cue.on .pip{animation:pulse 1.1s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.78)}}.meter{width:100%;height:9px;border-radius:99px;background:var(--mist-2);overflow:hidden}.meter-fill{height:100%;background:linear-gradient(90deg,var(--teal-bright),var(--honey) 82%,var(--coral));transition:width .06s linear}.btn{appearance:none;border:none;border-radius:16px;padding:17px 20px;font-family:var(--font-ui);font-size:16.5px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:9px;letter-spacing:.4px;transition:transform .08s ease,box-shadow .18s ease,background .18s ease}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.42;cursor:not-allowed}.btn-lg{padding:19px 22px;font-size:17.5px;border-radius:18px}.btn-primary{background:linear-gradient(135deg,var(--teal),var(--pine));color:#f7efe0;box-shadow:0 16px 34px -16px #0e3a3499}.btn-primary:hover:not(:disabled){box-shadow:0 20px 40px -16px #0e3a34b3}.btn-success{background:linear-gradient(135deg,var(--teal-bright),var(--good));color:#f7fbf8;box-shadow:0 16px 34px -16px #2f8a6c8c}.btn-danger{background:linear-gradient(135deg,var(--coral),var(--coral-deep));color:#fff;box-shadow:0 16px 34px -16px #c5431f8c}.btn-ghost{background:#14302b0d;color:var(--ink-soft)}.btn-ghost:hover:not(:disabled){background:#14302b17}.btn-block{width:100%}.btn-row{display:flex;gap:12px}.btn-row>*{flex:1}.row{display:flex;gap:12px}.row>*{flex:1}label.field{display:block;margin-bottom:18px}label.field>span{display:block;font-size:12.5px;font-weight:700;color:var(--ink-soft);margin-bottom:9px;letter-spacing:.8px;text-transform:uppercase}input[type=text],input[type=number],select{width:100%;padding:15px 16px;border:1.5px solid var(--line-strong);border-radius:14px;font-size:17px;font-family:var(--font-ui);background:#fffdf9;color:var(--ink);transition:border-color .15s,box-shadow .15s}input.code-input{font-family:var(--font-mono);font-size:27px;font-weight:600;letter-spacing:5px;text-align:center;color:var(--pine)}input:focus,select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px var(--mist)}.hint{font-size:12.5px;color:var(--ink-faint);margin-top:7px;letter-spacing:.2px}.field-error{font-size:13px;color:var(--bad);margin-top:7px;font-weight:600}.toggle-row{display:flex;gap:10px}.toggle{flex:1;padding:15px 12px;border-radius:14px;border:1.5px solid var(--line-strong);background:#fffdf9;color:var(--ink-soft);font-family:var(--font-ui);font-size:16px;font-weight:700;cursor:pointer;text-align:center;transition:all .14s ease}.toggle.on{border-color:var(--teal);background:var(--mist);color:var(--pine);box-shadow:0 0 0 3px var(--mist)}.check{display:flex;align-items:center;gap:14px;padding:16px;border:1.5px solid var(--line);border-radius:15px;margin-bottom:11px;cursor:pointer;transition:all .14s ease}.check.on{border-color:var(--teal);background:var(--mist)}.check .box{width:28px;height:28px;border-radius:9px;border:2px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:all .14s}.check.on .box{background:var(--teal);border-color:var(--teal)}.check span{font-size:15.5px;color:var(--ink);font-weight:600}.disclosure{border-top:1px solid var(--line);margin-top:6px;padding-top:14px}.disclosure>summary{cursor:pointer;font-size:13.5px;font-weight:700;color:var(--teal);list-style:none;display:flex;align-items:center;gap:6px;letter-spacing:.4px}.disclosure>summary::-webkit-details-marker{display:none}.verdict{display:flex;align-items:center;gap:15px;padding:18px;border-radius:17px;margin-bottom:16px;position:relative;overflow:hidden}.verdict:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px}.verdict.good{background:var(--good-bg);border:1px solid #cfe9da}.verdict.good:before{background:var(--good)}.verdict.warn{background:var(--warn-bg);border:1px solid #f1e0b8}.verdict.warn:before{background:var(--warn)}.verdict.bad{background:var(--bad-bg);border:1px solid #f3d3c5}.verdict.bad:before{background:var(--bad)}.verdict .vic{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.verdict.good .vic{background:var(--good)}.verdict.warn .vic{background:var(--warn)}.verdict.bad .vic{background:var(--bad)}.verdict .vt{font-family:var(--font-display);font-weight:600;font-size:19px;color:var(--pine)}.verdict .vs{font-size:13.5px;color:var(--ink-soft);margin-top:2px}.checks{display:flex;flex-direction:column;gap:1px;margin:6px 0 14px}.chk{display:flex;align-items:center;gap:11px;padding:9px 4px;font-size:14px;border-bottom:1px solid var(--line)}.chk:last-child{border-bottom:none}.chk .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.chk .dot.ok{background:var(--good)}.chk .dot.warn{background:var(--warn)}.chk .dot.fail{background:var(--bad)}.chk .lbl{color:var(--ink);font-weight:600}.chk .val{margin-left:auto;color:var(--ink-faint);font-family:var(--font-mono);font-size:13px}.metricline{display:flex;flex-wrap:wrap;gap:8px 18px;font-size:13px;color:var(--ink-faint);margin:4px 2px 16px}.metricline b{color:var(--ink);font-family:var(--font-mono)}.alert{border-radius:14px;padding:14px 16px;font-size:14.5px;margin-bottom:14px;display:flex;gap:10px;align-items:flex-start}.alert-error{background:var(--bad-bg);color:var(--coral-deep);border:1px solid #f3d3c5}.alert-ok{background:var(--good-bg);color:var(--good);border:1px solid #cfe9da}.alert-warn{background:var(--warn-bg);color:var(--warn);border:1px solid #f1e0b8}audio{width:100%;height:40px;border-radius:12px}.spacer{flex:1}.foot{color:var(--ink-faint);font-size:11.5px;text-align:center;padding:16px 0 22px;letter-spacing:.4px}.muted{color:var(--ink-faint);font-size:14px}.center{text-align:center}
