:root{color:#172033;background:#f3f7fb;font-family:Inter,Microsoft YaHei,PingFang SC,system-ui,sans-serif;font-synthesis:none;text-rendering:geometricPrecision}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,textarea{font:inherit}.app-shell{min-height:100vh;padding:24px;background:linear-gradient(120deg,rgba(14,100,184,.08),transparent 38%),linear-gradient(245deg,rgba(48,128,96,.08),transparent 36%),#f3f7fb}.workspace{width:min(1180px,100%);min-height:calc(100vh - 48px);margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:20px;align-items:stretch}.stage{min-height:560px;display:grid;place-items:center;padding:28px;border:1px solid rgba(80,105,136,.18);border-radius:8px;background:#0f365e;overflow:hidden}.portrait-shell{position:relative;width:min(560px,100%);aspect-ratio:1 / 1;overflow:hidden;border-radius:8px;background:#0b6cb1;box-shadow:0 24px 60px #03132752}.fallback-face,.stream-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.fallback-face{z-index:0}.stream-video{z-index:1;opacity:0;transition:opacity .18s ease;background:transparent}.stream-video.active{opacity:1}.subtitle-rail{position:absolute;right:0;bottom:0;left:0;z-index:4;height:86px;padding:28px 28px 18px;overflow:hidden;color:#fff;opacity:0;transform:translateY(8px);transition:opacity .18s ease,transform .18s ease;background:linear-gradient(180deg,transparent 0%,rgba(3,15,30,.64) 35%,rgba(3,15,30,.86) 100%);pointer-events:none;display:flex;align-items:flex-end;justify-content:center}.subtitle-rail.visible{opacity:1;transform:translateY(0)}.subtitle-line{width:min(92%,460px);min-width:0;margin:0 auto;overflow:hidden;color:#ffffffbd;font-size:17px;font-weight:700;line-height:1.42;text-align:center;text-overflow:ellipsis;text-shadow:0 2px 8px rgba(0,0,0,.58);white-space:nowrap;transition:color .16s ease,transform .16s ease,opacity .16s ease}.subtitle-line.active{color:#fff;opacity:1;transform:scale(1.04)}.subtitle-line.past{opacity:.46}.status-chip{position:absolute;right:14px;top:14px;z-index:5;min-width:78px;padding:7px 10px;border-radius:999px;background:#ffffffeb;color:#19324d;text-align:center;font-size:12px;font-weight:700;text-transform:uppercase}.status-chip.playing{color:#0f6a3c}.status-chip.error{color:#a92828}.panel{display:flex;min-width:0;flex-direction:column;gap:16px;padding:20px;border:1px solid rgba(80,105,136,.18);border-radius:8px;background:#fffffff0}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.eyebrow{margin:0 0 4px;color:#5a6f85;font-size:12px;font-weight:700;letter-spacing:0}h1{margin:0;font-size:28px;line-height:1.1}.icon-button{display:inline-grid;width:38px;height:38px;place-items:center;border:1px solid #d6e0ea;border-radius:8px;color:#29405a;background:#fff;cursor:pointer}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;padding:20px;background:#0c162480;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.auth-dialog{display:flex;width:min(360px,100%);flex-direction:column;gap:14px;border:1px solid rgba(214,224,234,.9);border-radius:8px;padding:22px;background:#fff;box-shadow:0 24px 70px #03132747}.auth-dialog h2{margin:0;color:#172033;font-size:20px;line-height:1.2}.auth-input{width:100%;height:42px;border:1px solid #ccd9e6;border-radius:8px;padding:0 12px;color:#172033;outline:none;background:#fbfdff}.auth-input:focus{border-color:#2275bd;box-shadow:0 0 0 3px #2275bd21}.auth-error{margin:-4px 0 0;color:#9b2525;font-size:13px}.auth-button{width:100%}.composer{display:flex;flex-direction:column;gap:10px}textarea{width:100%;min-height:138px;resize:vertical;border:1px solid #ccd9e6;border-radius:8px;padding:12px;color:#172033;outline:none;background:#fbfdff}textarea:focus{border-color:#2275bd;box-shadow:0 0 0 3px #2275bd21}.composer-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#687c90;font-size:13px}.primary-button{display:inline-flex;min-width:96px;height:40px;align-items:center;justify-content:center;gap:8px;border:0;border-radius:8px;color:#fff;background:#1469ad;cursor:pointer;font-weight:700}.primary-button:disabled{cursor:not-allowed;background:#9bb0c4}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-box{padding:10px 12px;border:1px solid #f0c3c3;border-radius:8px;color:#8b2323;background:#fff4f4;font-size:14px}.timing-panel{padding:12px;border:1px solid #dbe5ee;border-radius:8px;background:#fff}.timing-title{display:flex;width:100%;align-items:center;justify-content:space-between;gap:8px;margin:0;border:0;padding:0;color:#29405a;background:transparent;cursor:pointer;font-size:14px;font-weight:700;text-align:left}.timing-title-label{display:inline-flex;min-width:0;align-items:center;gap:8px}.timing-chevron{flex:0 0 auto;color:#62768b;transition:transform .16s ease}.timing-chevron.open{transform:rotate(180deg)}.timing-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px}.timing-item{display:flex;min-width:0;align-items:center;justify-content:space-between;gap:8px;padding:8px 9px;border-radius:8px;background:#f5f8fb;color:#62768b;font-size:12px}.timing-item strong{color:#19324d;font-weight:800;white-space:nowrap}.history{display:flex;min-height:0;flex:1;flex-direction:column;gap:12px;overflow:auto;padding:10px;border-radius:8px;background:#edf1f5}.message{display:flex;max-width:86%;flex-direction:column;gap:4px}.message.user{align-self:flex-end;align-items:flex-end}.message.assistant{align-self:flex-start;align-items:flex-start}.message strong{font-size:13px;color:#6b7785;font-weight:700}.message p{position:relative;margin:0;padding:10px 12px;border-radius:8px;color:#172033;background:#fff;box-shadow:0 1px 2px #1b2b3d14;line-height:1.55;overflow-wrap:anywhere}.message.user p{background:#95ec69}.message.assistant p:before,.message.user p:after{position:absolute;top:12px;width:0;height:0;border:5px solid transparent;content:""}.message.assistant p:before{left:-9px;border-right-color:#fff}.message.user p:after{right:-9px;border-left-color:#95ec69}@media(max-width:880px){.app-shell{padding:12px}.workspace{min-height:auto;grid-template-columns:1fr}.stage{min-height:auto;padding:12px}.subtitle-rail{height:72px;padding:22px 14px 14px}.subtitle-line{width:96%;font-size:15px;line-height:1.38}.panel{padding:16px}h1{font-size:24px}}
