:root{--bg: #0e0f13;--panel: #171922;--accent: #6c8cff;--text: #e7e9f0;--muted: #8b90a3}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 1rem}h1{font-size:1.4rem;margin:0}.subtitle{color:var(--muted);margin:0 0 1rem;font-size:.9rem}.stage{width:480px;max-width:90vw;aspect-ratio:3 / 4;background:#000;border-radius:16px;overflow:hidden;position:relative;box-shadow:0 8px 40px #0006}.stage canvas{width:100%;height:100%;display:block}.controls{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;justify-content:center}button{background:var(--accent);color:#fff;border:0;border-radius:10px;padding:.7rem 1.3rem;font-size:.95rem;cursor:pointer;transition:opacity .15s}button:disabled{opacity:.45;cursor:not-allowed}.status{font-size:.85rem;color:var(--muted);min-height:1.2em;text-align:center}.status.live{color:#4ade80}.status.error{color:#f87171}.transcript{width:480px;max-width:90vw;background:var(--panel);border-radius:12px;padding:1rem;font-size:.9rem;max-height:200px;overflow-y:auto}.transcript .line{margin:.2rem 0}.transcript .user{color:var(--accent)}.transcript .assistant{color:var(--text)}.transcript .tool{color:var(--muted);font-style:italic}.muted{color:var(--muted)}.small{font-size:.8rem}.spacer{flex:1}.row{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.col{display:flex;flex-direction:column;gap:.7rem}.row-between{display:flex;justify-content:space-between;align-items:center;gap:1rem}input,select,textarea{background:#0f1118;color:var(--text);border:1px solid #2a2d3a;border-radius:8px;padding:.55rem .7rem;font:inherit;width:100%}label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;color:var(--muted)}label input,label select,label textarea{color:var(--text)}button.danger{background:#b13b4a}button.secondary{background:#2a2d3a}.card{background:var(--panel);border-radius:12px;padding:1rem;box-shadow:0 4px 24px #0000004d}.admin{min-height:100vh}.topbar{display:flex;align-items:center;gap:1rem;padding:.8rem 1.2rem;background:var(--panel);border-bottom:1px solid #23262f}.topnav{display:flex;gap:.5rem}.topnav a{color:var(--muted);text-decoration:none;padding:.35rem .7rem;border-radius:8px}.topnav a.active{color:#fff;background:#2a2d3a}.content{padding:1.5rem;max-width:1100px;margin:0 auto}h2{margin:0 0 1rem}h3{margin:0 0 .4rem}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.dh-card{display:flex;flex-direction:column;gap:.6rem;text-align:left}.dh-card.pick{cursor:pointer;border:1px solid transparent}.dh-card.pick:hover{border-color:var(--accent)}.thumb{aspect-ratio:1/1;background:#000;border-radius:8px;overflow:hidden;display:flex}.thumb img{width:100%;height:100%;object-fit:cover;object-position:top center}.thumb-empty{margin:auto;color:var(--muted);font-size:.85rem}.dh-meta{display:flex;flex-direction:column}.dh-actions{display:flex;gap:.5rem}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:.5rem;border-bottom:1px solid #23262f}.doclist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.3rem}.checkrow{flex-direction:row;align-items:center;gap:.5rem;color:var(--text)}.checkrow input{width:auto}.wizard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}@media (max-width: 800px){.wizard-grid{grid-template-columns:1fr}}.preview-stage{aspect-ratio:3/4;background:#000;border-radius:10px;overflow:hidden}.preview-stage>div{width:100%;height:100%}.talk-page{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;background:#000;color:var(--text)}.talk-stage{flex:1;min-width:0;position:relative;background:radial-gradient(120% 100% at 50% 0%,#0a0a0d,#000 70%)}.talk-stage>div{width:100%;height:100%}.ghost-btn{background:#ffffff0f;color:#d7dae6;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:.5rem .9rem;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.ghost-btn:hover{background:#ffffff1f}.back{position:absolute;top:18px;left:18px;z-index:5}.stage-status{position:absolute;bottom:16px;left:50%;transform:translate(-50%);color:var(--muted);font-size:.85rem;background:#0006;padding:.3rem .7rem;border-radius:8px}.talk-chat{width:390px;max-width:90vw;display:flex;flex-direction:column;background:#12141cb8;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-left:1px solid rgba(255,255,255,.08)}.chat-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.07)}.chat-title{display:flex;align-items:center;gap:.7rem}.chat-title div{display:flex;flex-direction:column;line-height:1.2}.dot{width:10px;height:10px;border-radius:50%;background:#4b5060;flex:none}.dot.live{background:#4ade80;box-shadow:0 0 0 4px #4ade802e}.dot.connecting{background:#fbbf24;box-shadow:0 0 0 4px #fbbf242e}.pill{font-size:.72rem;padding:.25rem .6rem;border-radius:999px;background:#23262f;color:var(--muted)}.pill.live{background:#4ade8026;color:#4ade80}.pill.connecting{background:#fbbf2426;color:#fbbf24}.chat-scroll{flex:1;overflow-y:auto;padding:1.1rem;display:flex;flex-direction:column;gap:.7rem}.chat-empty{margin:auto;text-align:center;color:var(--text);opacity:.8}.bubble{max-width:86%;display:flex;flex-direction:column;gap:.2rem}.bubble .who{font-size:.7rem;color:var(--muted);padding:0 .3rem}.bubble-text{padding:.6rem .85rem;border-radius:14px;line-height:1.35;font-size:.95rem}.bubble.user{align-self:flex-end;align-items:flex-end}.bubble.user .bubble-text{background:linear-gradient(135deg,#6c8cff,#8a6cff);color:#fff;border-bottom-right-radius:4px}.bubble.assistant{align-self:flex-start}.bubble.assistant .bubble-text{background:#20232e;border:1px solid rgba(255,255,255,.06);border-bottom-left-radius:4px}.chat-tool{align-self:center;font-size:.78rem;color:var(--muted);font-style:italic}.chat-foot{padding:1rem 1.1rem;border-top:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;gap:.6rem}.mic-btn{width:100%;padding:.95rem;font-size:1.02rem;border:0;border-radius:14px;cursor:pointer;color:#fff;background:linear-gradient(135deg,#6c8cff,#8a6cff);box-shadow:0 8px 24px #6c8cff59;transition:transform .08s,opacity .15s}.mic-btn:hover{transform:translateY(-1px)}.mic-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.mic-btn.stop{background:linear-gradient(135deg,#b13b4a,#d4485a);box-shadow:0 8px 24px #b13b4a59}@media (max-width: 760px){.talk-page{flex-direction:column}.talk-stage{flex:1 1 55%}.talk-chat{width:100%;max-width:none;flex:1 1 45%;border-left:0;border-top:1px solid rgba(255,255,255,.08)}}.doc-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem}button.small{padding:.2rem .5rem;font-size:.8rem;border-radius:6px;line-height:1}
