*,:before,:after{box-sizing:border-box;margin:0}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--kp-ink:#1a1f2e;--kp-ink-soft:#1a1f2ee0;--kp-ink-muted:#1a1f2eb8;--kp-ink-faint:#1a1f2e73;--kp-surface-glass:#ffffffc7;--kp-surface-solid:#fff;--kp-line:#ffffff59;--kp-accent-warm:#fb8500;--kp-accent-warm-deep:#c45c00;--kp-accent-violet:#6c5ce7;--kp-focus:#ff9f438c;--kp-focus-ring:0 0 0 3px #ff9f4366;--kp-warning-bg:#ffd28c80;--kp-warning-border:#c8823c61;--kp-warning-ink:#4a2c12;--kp-info-bg:#78c8ff61;--kp-info-border:#508cc861;--kp-info-ink:#143a52;--kp-overlay-scrim:#14161e7a;--kp-toast-bg:#1c1e26f0;--kp-space-xs:.35rem;--kp-space-sm:.5rem;--kp-space-md:.85rem;--kp-space-lg:1.25rem;--kp-space-xl:1.75rem;--kp-radius-sm:12px;--kp-radius-md:18px;--kp-radius-lg:26px;--kp-radius-xl:32px;--kp-radius-pill:999px;--kp-font-body:.98rem;--kp-font-caption:.8rem;--kp-font-title:clamp(1.35rem, 4vw, 1.85rem);--kp-ease-out:cubic-bezier(.22, 1, .36, 1);--kp-ease-soft:cubic-bezier(.4, 0, .2, 1);--kp-dur-1:.12s;--kp-dur-2:.24s;--kp-dur-3:.36s;--kp-elev-1:0 6px 18px #19285014;--kp-elev-2:0 14px 36px #1928501f;--kp-elev-3:0 22px 52px #0f193233;--kp-touch-min:44px;color:var(--kp-ink);background:linear-gradient(165deg,#fff4d6 0%,#ffd8e8 45%,#d6f5ff 100%);font-family:Nunito,Avenir Next,Segoe UI,sans-serif;font-weight:500;line-height:1.45}body{background:0 0;min-height:100dvh}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}#root{min-height:100dvh}.skip-link:not(:focus){clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.skip-link:focus{left:var(--kp-space-lg);top:var(--kp-space-lg);z-index:100;border-radius:var(--kp-radius-sm);background:var(--kp-surface-solid);color:var(--kp-ink);box-shadow:var(--kp-focus-ring), var(--kp-elev-2);outline:none;padding:.5rem 1rem;font-size:.9rem;font-weight:800;position:absolute}.play-root{flex-direction:column;min-height:100dvh;display:flex;position:relative;overflow:hidden}.play-main{width:100%;max-width:56rem;min-height:0;padding-inline:max(var(--kp-space-lg), env(safe-area-inset-left)) max(var(--kp-space-lg), env(safe-area-inset-right));padding-bottom:max(.5rem, env(safe-area-inset-bottom));flex-direction:column;flex:1;margin-inline:auto;display:flex}.boot-strip{margin:0 var(--kp-space-lg) var(--kp-space-sm);border-radius:var(--kp-radius-pill);background:var(--kp-surface-glass);border:1px solid var(--kp-line);font-size:var(--kp-font-caption);color:var(--kp-ink-soft);box-shadow:var(--kp-elev-1);z-index:2;align-self:flex-start;padding:.5rem .85rem;font-weight:800}.cap-banner{margin:0 var(--kp-space-lg) .65rem;border-radius:var(--kp-radius-sm);background:var(--kp-warning-bg);border:1px solid var(--kp-warning-border);color:var(--kp-warning-ink);z-index:2;padding:.65rem 1rem;font-size:.92rem;font-weight:700}.welcome-back{margin:0 var(--kp-space-lg) .65rem;border-radius:var(--kp-radius-sm);background:var(--kp-info-bg);border:1px solid var(--kp-info-border);color:var(--kp-info-ink);z-index:2;padding:.55rem .95rem;font-size:.9rem;font-weight:800}.play-top{padding:var(--kp-space-lg) 0 var(--kp-space-sm);z-index:2}.play-top__row{justify-content:space-between;align-items:flex-start;gap:var(--kp-space-md);width:100%;display:flex}.brand{flex:1;align-items:flex-start;gap:.85rem;min-width:0;max-width:min(100%,44rem);display:flex}.brand-text{flex:1;min-width:0}.brand-title-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem .85rem;width:100%;max-width:40rem;display:flex}.conn-status{border-radius:var(--kp-radius-pill);letter-spacing:.04em;text-transform:uppercase;background:#ffffff8c;border:1px solid #0000000f;align-items:center;gap:.35rem;padding:.2rem .55rem;font-size:.72rem;font-weight:800;display:inline-flex}.conn-label{white-space:nowrap}.conn-dot{background:#94a3b8;border-radius:50%;width:.45rem;height:.45rem;box-shadow:0 0 0 2px #94a3b859}.conn-status--boot .conn-dot{background:#f59e0b;box-shadow:0 0 0 2px #f59e0b59}.conn-status--ready .conn-dot{background:#22c55e;box-shadow:0 0 0 2px #22c55e59}.conn-status--degraded .conn-dot{background:#f97316;box-shadow:0 0 0 2px #f9731659}.conn-status--error .conn-dot{background:#ef4444;box-shadow:0 0 0 2px #ef444459}.play-root.is-large-text .brand-sub,.play-root.is-large-text .transcript{font-size:1.08rem}.play-root.is-large-text .transcript strong{font-size:1.05em}.session-meta{font-size:var(--kp-font-caption);color:var(--kp-ink-faint);margin-bottom:.55rem;font-weight:700}.pill-btn-warn{color:#5c1a2a;background:#ff63842e;border:1px solid #c8506440}.brand-mark{background:conic-gradient(from 210deg,#ff9aa2,#ffdac1,#a2e4ff,#c9b5ff,#ff9aa2);border-radius:1rem;width:3rem;height:3rem;box-shadow:0 8px 22px #0000001f}.brand-title{font-size:var(--kp-font-title);letter-spacing:-.02em;font-weight:800;line-height:1.15}.brand-sub{font-size:var(--kp-font-body);color:var(--kp-ink-muted);max-width:38rem;margin-top:.25rem;font-weight:500;line-height:1.5}.brand-sub .brand-tagline{color:var(--kp-ink);margin-bottom:.35rem;font-weight:800;display:block}.brand-hint{color:var(--kp-ink-muted);margin-top:.35rem;font-weight:500;display:block}.play-root.is-large-text .brand-hint{font-size:1.02rem}.settings-trigger{min-height:var(--kp-touch-min);border-radius:var(--kp-radius-pill);box-shadow:var(--kp-elev-1);color:var(--kp-ink);transition:transform var(--kp-dur-1) var(--kp-ease-soft), box-shadow var(--kp-dur-1) var(--kp-ease-soft);background:linear-gradient(#fffffff2,#f8faffe0);border:1px solid #1a1f2e1a;flex-shrink:0;align-items:center;gap:.4rem;padding:.45rem .95rem;font-size:.92rem;font-weight:800;display:inline-flex}.settings-trigger:hover{box-shadow:var(--kp-elev-2);transform:translateY(-1px)}.settings-trigger:focus-visible{box-shadow:var(--kp-focus-ring), var(--kp-elev-1);outline:none}.settings-trigger__icon{opacity:.92;flex-shrink:0;width:1.35rem;height:1.35rem}.settings-trigger__label{white-space:nowrap}@media (width<=420px){.settings-trigger__label{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.settings-trigger{border-radius:50%;padding:.55rem}}.play-root.is-settings-open{overflow:hidden}.settings-shell{z-index:40;justify-content:flex-end;display:flex;position:fixed;inset:0}.settings-backdrop{z-index:0;cursor:pointer;background:var(--kp-overlay-scrim);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:overlay-in var(--kp-dur-2) var(--kp-ease-out);border:none;margin:0;padding:0;position:absolute;inset:0}.settings-panel{z-index:1;width:min(22.5rem,100vw - .75rem);max-height:100dvh;margin:max(.35rem, env(safe-area-inset-top)) max(.35rem, env(safe-area-inset-right)) max(.35rem, env(safe-area-inset-bottom)) 0;border-radius:var(--kp-radius-lg) 0 0 var(--kp-radius-lg);background:var(--kp-surface-solid);box-shadow:var(--kp-elev-3);pointer-events:auto;animation:settings-drawer-in var(--kp-dur-3) var(--kp-ease-out);flex-direction:column;display:flex;position:relative}@keyframes settings-drawer-in{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.settings-panel__head{justify-content:space-between;align-items:center;gap:var(--kp-space-md);background:linear-gradient(#fffaf5e6,#fffffffa);border-bottom:1px solid #1a1f2e14;padding:1rem 1.1rem;display:flex}.settings-panel__title{letter-spacing:-.02em;font-size:1.25rem;font-weight:900}.settings-panel__close{min-height:var(--kp-touch-min);border-radius:var(--kp-radius-pill);color:#3d2f7a;cursor:pointer;background:#6c5ce71f;border:none;padding:.4rem .85rem;font-size:.88rem;font-weight:800}.settings-panel__close:hover{background:#6c5ce733}.settings-panel__close:focus-visible{box-shadow:var(--kp-focus-ring);outline:none}.settings-panel__body{-webkit-overflow-scrolling:touch;flex:1;padding:.85rem 1.1rem 1.25rem;overflow-y:auto}.settings-section{margin-bottom:1.35rem}.settings-section:last-child{margin-bottom:0}.settings-section__title{letter-spacing:.08em;text-transform:uppercase;color:var(--kp-ink-faint);margin-bottom:.45rem;font-size:.72rem;font-weight:900}.settings-hint{color:var(--kp-ink-muted);margin-bottom:.65rem;font-size:.86rem;font-weight:500;line-height:1.45}.settings-hint strong{color:var(--kp-ink-soft);font-weight:800}.settings-field{gap:var(--kp-space-xs);margin-top:var(--kp-space-sm);flex-direction:column;display:flex}.settings-field__label{font-size:var(--kp-font-caption);color:var(--kp-ink-muted);font-weight:800}.settings-text-input{width:100%;min-height:var(--kp-touch-min);border-radius:var(--kp-radius-sm);border:1px solid var(--kp-line);background:var(--kp-surface-glass);color:var(--kp-ink);box-shadow:var(--kp-elev-1);padding:.5rem .75rem}.settings-text-input:focus-visible{box-shadow:var(--kp-focus-ring), var(--kp-elev-1);outline:none}.settings-row{gap:var(--kp-space-sm);flex-wrap:wrap;margin-bottom:.55rem;display:flex}.audio-mode--block{width:100%}.pill-btn--block{justify-content:center;width:100%}.settings-section--parent .pill-btn--block+.pill-btn--block{margin-top:.45rem}.settings-section--about{border-top:1px dashed #1a1f2e1f;padding-top:.5rem}.settings-about-line{color:var(--kp-ink-soft);margin-bottom:.35rem;font-size:.9rem;font-weight:700}.settings-about-links{font-size:.88rem;font-weight:700}.settings-about-links a{color:#1a1f2e8c;text-underline-offset:3px;text-decoration:underline}.settings-about-links a:hover{color:var(--kp-ink)}.top-actions{gap:var(--kp-space-sm);flex-wrap:wrap;align-items:center;display:flex}.audio-mode{gap:var(--kp-space-xs);flex-wrap:wrap;align-items:center;display:flex}.pill-btn{border-radius:var(--kp-radius-pill);min-height:var(--kp-touch-min);background:var(--kp-surface-glass);box-shadow:var(--kp-elev-1);color:var(--kp-ink);transition:transform var(--kp-dur-1) var(--kp-ease-soft), box-shadow var(--kp-dur-1) var(--kp-ease-soft), background var(--kp-dur-1) var(--kp-ease-soft);border:none;padding:.55rem 1.05rem;font-size:.95rem;font-weight:700}.pill-btn:hover:not(:disabled){box-shadow:var(--kp-elev-2);transform:translateY(-1px)}.pill-btn:active:not(:disabled){transform:translateY(0)}.pill-btn.is-muted{background:#ff638438}.pill-btn.is-on{background:#78c8ff7a;box-shadow:0 8px 20px #2864a02e}.pill-btn:focus-visible{box-shadow:var(--kp-focus-ring), var(--kp-elev-1);outline:none}.play-stage{z-index:1;flex:1;min-height:42vh;padding:0 .5rem;position:relative}:-webkit-any(.play-stage:fullscreen,.play-stage:-webkit-full-screen){background:#0a0e14;flex-direction:column;width:100%;min-height:100%;padding:0;display:flex}:is(.play-stage:fullscreen,.play-stage:fullscreen){background:#0a0e14;flex-direction:column;width:100%;min-height:100%;padding:0;display:flex}:-webkit-any(.play-stage:fullscreen .three-host,.play-stage:-webkit-full-screen .three-host){width:100%;height:100%;min-height:0;max-height:none;box-shadow:none;border-radius:0;flex:1}:is(.play-stage:fullscreen .three-host,.play-stage:fullscreen .three-host){width:100%;height:100%;min-height:0;max-height:none;box-shadow:none;border-radius:0;flex:1}.world-fs-exit{top:max(.65rem, env(safe-area-inset-top));right:max(.65rem, env(safe-area-inset-right));z-index:6;border-radius:var(--kp-radius-pill);color:#f8fafc;letter-spacing:.02em;box-shadow:var(--kp-elev-2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#141820b8;border:1px solid #ffffff59;padding:.45rem .85rem;font-size:.85rem;font-weight:800;position:absolute}.world-fs-exit:focus-visible{box-shadow:var(--kp-focus-ring), var(--kp-elev-2);outline:none}.three-host{border-radius:var(--kp-radius-lg);width:100%;height:min(52vh,520px);box-shadow:0 20px 50px #1928502e, inset 0 0 0 2px var(--kp-line);overscroll-behavior:contain;background:linear-gradient(#bfe9ff 0%,#eafcff 100%);overflow:hidden}.three-host canvas{touch-action:none;cursor:grab;display:block}.three-host canvas:active{cursor:grabbing}.play-controls{z-index:2;justify-content:center;padding:1rem .5rem 1.5rem;display:flex}.phrase-strip{padding:0 var(--kp-space-lg) .75rem;-webkit-overflow-scrolling:touch;scrollbar-width:none;z-index:2;gap:.4rem;display:flex;overflow-x:auto}.phrase-strip::-webkit-scrollbar{display:none}.phrase-btn{border-radius:var(--kp-radius-pill);background:var(--kp-surface-glass);color:var(--kp-ink-soft);white-space:nowrap;box-shadow:var(--kp-elev-1);transition:background var(--kp-dur-1) var(--kp-ease-soft), transform var(--kp-dur-1) var(--kp-ease-soft);border:1px solid #0000001a;flex:none;padding:.4rem .75rem;font-size:.8rem;font-weight:700}.phrase-btn:hover:not(:disabled){background:#fffffff2;transform:translateY(-1px)}.phrase-btn:active:not(:disabled){box-shadow:none;transform:translateY(1px)}.mic-btn{border-radius:var(--kp-radius-xl);background:radial-gradient(circle at 30% 25%, #fff8e7, #ffb703 42%, var(--kp-accent-warm) 100%);color:#1a0f00;width:min(92vw,280px);min-height:7.75rem;box-shadow:0 18px 0 var(--kp-accent-warm-deep), 0 22px 44px #0003;transition:transform var(--kp-dur-1) var(--kp-ease-soft), box-shadow var(--kp-dur-1) var(--kp-ease-soft), filter var(--kp-dur-2) var(--kp-ease-soft);border:none;flex-direction:column;justify-content:center;align-items:center;gap:.35rem;font-size:1.2rem;font-weight:900;display:flex;transform:translateY(0)}.mic-btn:active:not(:disabled){box-shadow:0 10px 0 var(--kp-accent-warm-deep), 0 14px 28px #0000002e;transform:translateY(6px)}.mic-btn:focus-visible{box-shadow:var(--kp-focus-ring), 0 18px 0 var(--kp-accent-warm-deep), 0 22px 44px #0003;outline:none}.mic-btn.is-recording{animation:mic-pulse 1.1s var(--kp-ease-soft) infinite}.mic-btn.is-working{animation:mic-working .9s var(--kp-ease-soft) infinite}.mic-icon{background:#ffffff61;border-radius:50%;width:3rem;height:3rem;box-shadow:inset 0 2px 6px #0000001f}.mic-label{text-align:center;padding-inline:.35rem;font-size:clamp(1rem,3.5vw,1.3rem);line-height:1.25}@keyframes mic-pulse{0%,to{filter:brightness()}50%{filter:brightness(1.07)}}@keyframes mic-working{0%,to{opacity:1}50%{opacity:.88}}.play-foot{z-index:2;padding:0 0 1.5rem}.transcript{border-radius:var(--kp-radius-md);background:var(--kp-surface-glass);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--kp-elev-1);font-size:var(--kp-font-body);color:var(--kp-ink-soft);padding:1rem 1.15rem;font-weight:500;line-height:1.5}.transcript strong{color:var(--kp-ink);font-weight:800}.transcript p+p{margin-top:.5rem}.meta-hint{font-size:var(--kp-font-caption);color:var(--kp-ink-faint);margin-top:.65rem}.legal-foot{font-size:var(--kp-font-caption);color:var(--kp-ink-faint);margin-top:.75rem;line-height:1.45}.legal-link{color:#1a1f2e8c;text-underline-offset:3px;font-weight:600;text-decoration:underline}.legal-link:hover{color:var(--kp-ink)}.legal-link--btn{font:inherit;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:0;font-weight:600}.legal-link--btn:focus-visible{box-shadow:var(--kp-focus-ring);outline:none}.legal-meta{color:var(--kp-ink-faint)}.parent-reset{font-size:var(--kp-font-caption);margin-top:.55rem}.link-btn{min-height:var(--kp-touch-min);font:inherit;color:#1a1f2e8c;text-underline-offset:3px;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.35rem 0;font-weight:600;text-decoration:underline}.link-btn:hover{color:#1a1f2ed9}.link-btn:focus-visible{box-shadow:var(--kp-focus-ring);outline:none}.supervision-overlay{z-index:50;padding:var(--kp-space-lg);padding-bottom:max(var(--kp-space-lg), env(safe-area-inset-bottom));background:var(--kp-overlay-scrim);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:overlay-in var(--kp-dur-2) var(--kp-ease-out);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.supervision-card{width:100%;max-width:420px;padding:var(--kp-space-xl) 1.4rem;border-radius:var(--kp-radius-md);background:var(--kp-surface-solid);box-shadow:var(--kp-elev-3);animation:card-in var(--kp-dur-3) var(--kp-ease-out)}@keyframes card-in{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.supervision-title{letter-spacing:-.02em;margin-bottom:.45rem;font-size:1.4rem;font-weight:800;line-height:1.2}.supervision-copy{font-size:var(--kp-font-body);color:var(--kp-ink-soft);margin-bottom:1rem;font-weight:500;line-height:1.5}.supervision-check{cursor:pointer;font-size:var(--kp-font-body);color:#1a1f2ef0;align-items:center;gap:.85rem;margin-bottom:1.15rem;line-height:1.45;display:flex}.supervision-check-wrap{flex-shrink:0;width:1.4rem;height:1.4rem;position:relative}.supervision-check-input{opacity:0;cursor:pointer;z-index:1;width:100%;height:100%;margin:0;position:absolute;inset:0}.supervision-check-input:focus-visible+.supervision-check-face{box-shadow:0 0 0 3px #6c5ce759,0 2px 8px #283c641f}.supervision-check-face{pointer-events:none;transition:border-color var(--kp-dur-1) var(--kp-ease-soft), background var(--kp-dur-1) var(--kp-ease-soft), box-shadow var(--kp-dur-1) var(--kp-ease-soft);background:linear-gradient(#fffffffa,#f8faffeb);border:2px solid #7887a58c;border-radius:7px;position:absolute;inset:0;box-shadow:inset 0 1px #ffffffd9}.supervision-check-input:hover+.supervision-check-face{border-color:#5a6e96a6}.supervision-check-input:checked+.supervision-check-face{background:linear-gradient(155deg,#ffb088 0%,#ff9aa2 55%,#ff8b9d 100%);border-color:#dc825aa6;box-shadow:0 3px 10px #ff786459,inset 0 1px #ffffff59}.supervision-check-input:checked+.supervision-check-face:after{content:"";border:2.5px solid #1e2840;border-width:0 2.5px 2.5px 0;border-radius:0 0 1px;width:.32rem;height:.58rem;position:absolute;top:46%;left:50%;transform:translate(-50%,-50%)rotate(45deg)}.supervision-check-label{letter-spacing:-.01em;flex:1;min-width:0;font-weight:600}.supervision-continue{width:100%;min-height:var(--kp-touch-min);background:linear-gradient(135deg, var(--kp-accent-violet), #a29bfe);color:#fff;transition:transform var(--kp-dur-1) var(--kp-ease-soft), box-shadow var(--kp-dur-1) var(--kp-ease-soft), filter var(--kp-dur-1) var(--kp-ease-soft);border:none;border-radius:14px;padding:.9rem 1rem;font-size:1.02rem;font-weight:800;box-shadow:0 8px 24px #6c5ce759}.supervision-continue:hover:not(:disabled){filter:brightness(1.03);transform:translateY(-1px)}.supervision-continue:active:not(:disabled){transform:translateY(0)}.supervision-continue:focus-visible{box-shadow:var(--kp-focus-ring), 0 8px 24px #6c5ce759;outline:none}.supervision-continue:disabled{opacity:.45;cursor:not-allowed;filter:none;transform:none}.toast{left:50%;bottom:max(1.25rem, env(safe-area-inset-bottom));border-radius:var(--kp-radius-md);background:var(--kp-toast-bg);color:#fff;max-width:min(92vw,480px);box-shadow:var(--kp-elev-3);z-index:60;animation:toast-in var(--kp-dur-3) var(--kp-ease-out);padding:.9rem 1.15rem;font-size:.95rem;font-weight:700;line-height:1.4;position:fixed;transform:translate(-50%)translateY(0)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.confetti-layer{pointer-events:none;z-index:5;opacity:.55;background-image:radial-gradient(circle,#ff638473 2px,#0000 3px),radial-gradient(circle,#36a2eb73 2px,#0000 3px),radial-gradient(circle,#ffce5680 2px,#0000 3px);background-position:0 0,30px 40px,50px 10px;background-size:60px 60px,80px 80px,70px 70px;animation:2.2s linear infinite drift;position:fixed;inset:0}@keyframes drift{0%{background-position:0 0,30px 40px,50px 10px}to{background-position:0 80px,30px 120px,50px 90px}}@media (prefers-reduced-motion:reduce){:root{--kp-dur-1:0s;--kp-dur-2:0s;--kp-dur-3:0s}.skip-link,.pill-btn,.mic-btn,.supervision-continue{transition:none}.mic-btn.is-recording,.mic-btn.is-working,.confetti-layer,.supervision-overlay,.supervision-card,.toast,.settings-backdrop,.settings-panel{animation:none}}.access-gate{min-height:100dvh;padding:var(--kp-space-lg);background:linear-gradient(165deg,#fff4d6 0%,#ffd8e8 45%,#d6f5ff 100%);justify-content:center;align-items:center;display:flex}.access-card{border-radius:var(--kp-radius-xl);background:var(--kp-surface-glass);border:1px solid var(--kp-line);box-shadow:var(--kp-elev-3);flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:22rem;padding:2.5rem 2rem;display:flex}.access-title{font-size:var(--kp-font-title);letter-spacing:-.02em;font-weight:800}.access-desc{font-size:var(--kp-font-body);color:var(--kp-ink-muted);text-align:center}.access-input{border-radius:var(--kp-radius-sm);text-align:center;background:var(--kp-surface-solid);border:1px solid #0000001f;width:100%;padding:.7rem 1rem;font-size:1rem;font-weight:600}.access-input:focus{border-color:var(--kp-accent-warm);box-shadow:var(--kp-focus-ring);outline:none}.access-error{color:#c0392b;font-size:.85rem;font-weight:700}.access-submit{border-radius:var(--kp-radius-sm);background:var(--kp-accent-warm);color:#fff;width:100%;box-shadow:var(--kp-elev-1);transition:background var(--kp-dur-1) var(--kp-ease-soft);border:none;padding:.7rem;font-size:1rem;font-weight:800}.access-submit:hover:not(:disabled){background:var(--kp-accent-warm-deep)}.sparkle-flash{z-index:50;pointer-events:none;animation:sparkle-fade .6s var(--kp-ease-out) forwards;background:radial-gradient(circle,#ffd70040,#0000 70%);position:fixed;inset:0}@keyframes sparkle-fade{0%{opacity:1}to{opacity:0}}.idle-hint{color:var(--kp-ink-faint);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;font-weight:600;overflow:hidden}.keyboard-hint{color:var(--kp-ink-faint);white-space:nowrap;font-size:.72rem;font-weight:600}.keyboard-hint kbd{background:#fff9;border:1px solid #00000026;border-radius:3px;padding:.05rem .3rem;font-size:.7rem;font-weight:800;display:inline-block;box-shadow:0 1px 2px #00000014}.scene-bar{padding:.15rem var(--kp-space-lg) .75rem;z-index:2;flex-wrap:wrap;justify-content:center;align-items:center;gap:.35rem .65rem;min-height:0;display:flex}.scene-count{color:var(--kp-ink-muted);font-size:.78rem;font-weight:700}.undo-btn{border-radius:var(--kp-radius-pill);color:var(--kp-accent-violet);transition:background var(--kp-dur-1) var(--kp-ease-soft);background:#ffffffb3;border:1px solid #0000001f;padding:.25rem .65rem;font-size:.75rem;font-weight:700}.undo-btn:hover:not(:disabled){background:#fffffff2}.transcript-history{font-size:var(--kp-font-caption);margin-top:.4rem}.transcript-history summary{cursor:pointer;color:var(--kp-ink-muted);font-weight:700}.transcript-history__list{max-height:10rem;margin-top:.3rem;padding:.3rem 0;overflow-y:auto}.transcript-history__entry{border-bottom:1px solid #0000000d;flex-direction:column;gap:.1rem;padding:.25rem 0;font-size:.78rem;display:flex}.transcript-history__num{color:var(--kp-ink-faint);font-weight:800}.speed-slider{min-width:0;height:6px;accent-color:var(--kp-accent-warm);flex:1}.speed-label{color:var(--kp-ink-muted);text-align:right;min-width:2.5rem;font-size:.8rem;font-weight:800}.play-root.is-night{color:#e0e0e0;background:linear-gradient(165deg,#1a1a2e 0%,#16213e 45%,#0f3460 100%)}.play-root.is-night .brand-title,.play-root.is-night .brand-sub{color:#ffffffd9}.play-root.is-night .phrase-btn{color:#fffc;background:#1e1e32b3;border-color:#ffffff1a}.play-root.is-night .pill-btn{color:#fffc;background:#1e1e3299;border-color:#ffffff1f}.play-root.is-night .supervision-card,.play-root.is-night .settings-panel{color:#e0e0e0;background:#141428f2}.play-root.is-night .toast{color:#e0e0e0;background:#ffffff1a}@media (pointer:coarse){.phrase-btn{min-height:48px;padding:.55rem .85rem;font-size:.88rem}.pill-btn{min-height:48px;padding:.55rem 1rem}.settings-trigger{min-width:48px;min-height:48px}}@media (width<=520px){.play-stage{min-height:36vh}.three-host{height:min(44vh,420px)}.top-actions{justify-content:flex-start;width:100%}}@media (width<=380px){.settings-panel{border-radius:0;width:100%;max-height:100dvh;margin:0}}
