*{box-sizing:border-box}:root{--sage: #9fb88f;--matcha: #b8c98f;--cream: #f1e7c8;--cream-soft: #fff5d8;--old-gold: #846f18;--deep-olive: #302d18;--tea-brown: #4a3620;--danger-soft: #bd7659;--panel-bg: rgba(48, 45, 24, .72);--panel-border: rgba(241, 231, 200, .16);color:var(--cream-soft);background:var(--deep-olive);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,PingFang TC,Noto Sans TC,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}button,input{font:inherit}button{border:0;border-radius:8px;padding:11px 15px;color:var(--deep-olive);background:var(--matcha);box-shadow:0 8px 24px #00000038;cursor:pointer;font-weight:750}button:hover{background:var(--cream)}button:disabled{opacity:.48;cursor:not-allowed}button.secondary{color:var(--cream-soft);background:#9fb88f2e;border:1px solid rgba(241,231,200,.24)}button.danger{color:var(--cream-soft);background:var(--danger-soft)}main{width:100vw;height:100vh;position:relative;background:var(--deep-olive)}.scene-canvas{position:fixed;inset:0}.scene-canvas canvas{display:block;width:100%;height:100%;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.scene-canvas canvas.is-looking{cursor:grabbing}.sr-only{position:fixed!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.hud{position:fixed;z-index:10;pointer-events:none}.hud--top{top:12px;left:12px;right:12px;display:flex;align-items:center;gap:8px;opacity:.8;transition:opacity .16s ease}.hud--top:hover,.hud--top:focus-within{opacity:1}.hud--quiet{opacity:.62}.brand{display:flex;align-items:baseline;gap:10px;padding:7px 10px;border-radius:8px;background:var(--panel-bg);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid var(--panel-border)}.brand span{font-size:14px;font-weight:900;letter-spacing:0}.brand small{color:var(--matcha);font-size:11px;font-weight:800}.status-pill,.toggle{border-radius:999px;padding:6px 9px;background:#302d188f;border:1px solid var(--panel-border);color:#fff5d8d6;font-size:12px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.pressure-meter{min-width:132px;display:grid;gap:4px;padding:6px 8px 7px;border-radius:8px;background:#302d188f;border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.pressure-meter span{color:var(--cream-soft);font-size:11px;font-weight:850}.pressure-meter div{width:100%;height:6px;overflow:hidden;border-radius:999px;background:#f1e7c824}.pressure-meter i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--sage),var(--old-gold));transition:width .22s ease}.toggle{pointer-events:auto;display:inline-flex;align-items:center;gap:7px;margin-left:auto}.toggle input{accent-color:var(--old-gold)}.panel,.ticket,.npc-caption,.partial,.speech-feedback,.controls,.order-chip,.technical,.end-actions{position:fixed;z-index:12}.start-panel{left:50%;bottom:56px;width:min(520px,calc(100vw - 32px));transform:translate(-50%);padding:24px;border-radius:8px;background:linear-gradient(180deg,#4a3620bd,#302d18e6),#302d18d6;border:1px solid rgba(132,111,24,.34);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.mode-kicker{display:inline-flex;margin-bottom:9px;color:var(--matcha);font-size:13px;font-weight:900}.start-panel h1{margin:0 0 8px;font-size:44px;line-height:1.05}.start-panel p{margin:0 0 18px;color:#fff5d8cc;line-height:1.55}.intro-loader{position:fixed;left:50%;bottom:44px;z-index:30;width:min(520px,calc(100vw - 32px));transform:translate(-50%);padding:18px;border-radius:8px;background:#302d18e0;border:1px solid rgba(241,231,200,.18);box-shadow:0 22px 86px #0000006b;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.intro-art{height:150px;margin-bottom:14px;border-radius:8px;display:grid;place-items:center;overflow:hidden;background:linear-gradient(135deg,#9fb88f57,#bd765938),linear-gradient(180deg,#fff5d829,#302d181a);border:1px solid rgba(241,231,200,.16)}.intro-art span{display:grid;place-items:center;width:70px;height:70px;border-radius:50%;color:var(--deep-olive);background:var(--cream);font-size:34px;font-weight:950}.intro-loader h1{margin:0 0 8px;font-size:34px;line-height:1.08}.intro-loader p{margin:0 0 12px;color:#fff5d8d1;line-height:1.48}.intro-loader small{display:block;margin:0 0 12px;color:#b8c98fe6;line-height:1.35}.intro-progress{display:flex;gap:6px;margin-bottom:14px}.intro-progress i{display:block;width:36px;height:5px;border-radius:999px;background:#fff5d82e}.intro-progress--active{background:var(--matcha)!important}.button-row{display:flex;flex-wrap:wrap;gap:10px}.ticket{left:50%;top:50%;width:min(360px,calc(100vw - 40px));transform:translate(-50%,-50%) rotate(-1deg);padding:22px 22px 18px;color:var(--deep-olive);background:linear-gradient(90deg,rgba(0,0,0,.045) 1px,transparent 1px) 0 0 / 22px 22px,var(--cream);border-radius:4px;box-shadow:0 18px 80px #0000006b;display:grid;gap:9px;text-align:center;animation:ticketPop .42s ease-out both}.ticket:before,.ticket:after{content:"";position:absolute;left:0;right:0;height:10px;background:repeating-linear-gradient(90deg,transparent 0 10px,rgba(132,111,24,.2) 10px 20px)}.ticket:before{top:-1px}.ticket:after{bottom:-1px}.ticket-label{color:var(--old-gold);font-size:13px;font-weight:800}.ticket strong{font-size:28px;line-height:1.05}.ticket small{color:#6f6023;margin-top:4px}.npc-caption{left:50%;bottom:34px;width:min(720px,calc(100vw - 28px));min-height:74px;transform:translate(-50%);padding:16px 18px 16px 50px;border-radius:8px;background:#302d18e6;border:1px solid rgba(132,111,24,.32);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 16px 54px #00000047}.npc-caption p{margin:0;font-size:clamp(20px,2.4vw,31px);line-height:1.25;font-weight:800}.caption-dot{position:absolute;left:18px;top:24px;width:16px;height:16px;border-radius:50%;background:var(--sage);box-shadow:0 0 0 5px #9fb88f29}.caption-dot--speaking{background:var(--matcha);box-shadow:0 0 0 8px #b8c98f33}.partial{left:50%;bottom:72px;transform:translate(-50%);width:min(420px,calc(100vw - 42px));text-align:center;color:#fff5d8db;background:#302d188a;border:1px solid var(--panel-border);border-radius:8px;padding:8px 12px;font-size:13px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.speech-feedback{left:50%;bottom:16px;width:min(640px,calc(100vw - 260px));min-height:54px;transform:translate(-50%);padding:9px 14px 10px;color:var(--cream-soft);background:#302d18ad;border:1px solid rgba(241,231,200,.18);border-radius:8px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 14px 42px #0000003d}.speech-feedback span{display:block;margin-bottom:3px;color:var(--matcha);font-size:12px;font-weight:900}.speech-feedback p{margin:0;color:#fff5d8f0;font-size:18px;font-weight:850;line-height:1.25;white-space:normal}.speech-feedback--listening{border-color:#b8c98f6b;box-shadow:0 14px 42px #0000003d,0 0 0 5px #b8c98f1a}.order-chip{right:18px;top:74px;width:min(330px,calc(100vw - 36px));padding:12px 14px;border-radius:8px;background:#302d18c2;border:1px solid rgba(132,111,24,.26);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.order-chip span{display:block;margin-bottom:5px;color:var(--matcha);font-size:12px;font-weight:800}.order-chip strong{display:block;line-height:1.35;font-size:16px}.controls{left:12px;bottom:16px;display:flex;align-items:flex-end;gap:8px;opacity:.52;transition:opacity .16s ease}.controls:hover,.controls:focus-within{opacity:1}.controls--ready{opacity:.9}.controls>button{min-width:92px;padding:8px 11px;font-size:13px}.controls details{width:min(260px,calc(100vw - 150px));padding:7px 9px;border-radius:8px;background:#302d187a;border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.controls summary{cursor:pointer;color:#fff5d8c7;font-size:13px}.controls form{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:8px}.controls input{width:100%;min-width:0;border:1px solid rgba(241,231,200,.22);border-radius:8px;padding:9px;color:var(--cream-soft);background:#f1e7c814}.reticle{position:fixed;left:50%;top:50%;z-index:9;width:14px;height:14px;transform:translate(-50%,-50%);border-radius:50%;border:1px solid rgba(241,231,200,.42);pointer-events:none}.reticle--active{border-color:var(--matcha);box-shadow:0 0 0 6px #b8c98f21}.reticle--ready{border-color:#fff5d8d1;box-shadow:0 0 0 6px #b8c98f29,0 0 22px #fff5d847}.reticle--listening{border-color:var(--danger-soft);box-shadow:0 0 0 9px #bd765929}.technical{left:50%;top:50%;width:min(420px,calc(100vw - 40px));transform:translate(-50%,-50%);padding:22px;border-radius:8px;color:var(--deep-olive);background:var(--cream);box-shadow:0 24px 90px #00000080}.technical h2{margin:0 0 8px}.technical p{line-height:1.5}.fail-screen{position:fixed;inset:0;z-index:20;display:grid;place-items:center;text-align:center;background:radial-gradient(circle,#846f18d1,#1f1d0ff5 68%);animation:fadeIn .8s ease-out both}.fail-screen h2{margin:0;font-size:clamp(54px,10vw,128px);letter-spacing:0;color:var(--cream-soft);text-shadow:0 0 30px rgba(132,111,24,.56)}.fail-screen p{width:min(680px,calc(100vw - 40px));margin:14px auto 24px;font-size:22px;color:#fff5d8e0}.end-actions{left:18px;bottom:18px;display:grid;gap:8px;width:max-content;max-width:calc(100vw - 36px);padding:10px;border:1px solid rgba(241,231,200,.18);border-radius:8px;background:#302d189e;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 18px 70px #00000052;transition:opacity .18s ease,transform .18s ease}.end-actions--quiet{opacity:.38;transform:translateY(10px)}.end-actions--quiet:hover,.end-actions--quiet:focus-within{opacity:1;transform:translateY(0)}.end-actions button{padding:9px 11px;font-size:13px}.share-status{display:block;color:#fff5d8c7;font-size:12px;font-weight:800}.vr-button{right:18px!important;bottom:18px!important;left:auto!important;border-radius:8px!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes ticketPop{0%{opacity:0;transform:translate(-50%,-44%) rotate(-2deg) scale(.94)}to{opacity:1;transform:translate(-50%,-50%) rotate(-1deg) scale(1)}}@media(max-width:720px){.hud--top{align-items:flex-start}.status-pill{display:none}.pressure-meter{min-width:128px}.order-chip{left:18px;right:auto;top:74px}.controls{bottom:112px}.speech-feedback{bottom:18px;width:min(420px,calc(100vw - 28px))}.speech-feedback p{white-space:normal}.controls details{display:none}.end-actions{left:12px;right:12px;bottom:12px;width:auto}}
