*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;background:radial-gradient(ellipse 120% 90% at 50% 10%,#2b3854,#1c2438,#141926);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;color:#213047}#root{width:100%;max-width:1280px}.app{width:100%}.app-shell{display:grid;grid-template-columns:380px 1fr;gap:28px;align-items:stretch}.primary-column{display:flex;min-width:0}.demo-column{display:flex;flex-direction:column;min-width:0}.video-card{background:linear-gradient(180deg,#fff,#f5f7fb);border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.6);box-shadow:0 1px 2px #0000000a,0 16px 56px #080c143d;display:flex;flex-direction:column;width:100%;position:relative}.video-stage{position:relative;flex:1 1 0;min-height:480px;background:radial-gradient(circle at 50% 20%,#fffffff5,#ecf0f7f7),linear-gradient(180deg,#f5f7fb,#e8edf5);display:flex;align-items:center;justify-content:center;overflow:hidden}.video-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;object-position:center top}.video-active{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;object-position:center top;z-index:1}.video-loading{position:absolute;z-index:2;display:flex;align-items:center;gap:8px;padding:10px 16px;background:#0000008c;border-radius:20px;color:#fff;font-size:13px}.loading-dot{width:7px;height:7px;background:#fff;border-radius:50%;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}.video-bottom-stack{position:absolute;bottom:0;left:0;width:100%;z-index:10;display:flex;flex-direction:column;align-items:center;gap:20px;padding-bottom:20px;pointer-events:none}.video-bottom-stack>*{pointer-events:auto}.caption-bar{padding:10px 18px;background:#0e121c8c;color:#f0f4f9;font-size:14px;line-height:1.5;min-height:40px;display:flex;align-items:center;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:14px;max-width:calc(100% - 32px);width:auto}.caption-text{width:100%}.caption-text.user{color:#9dd3ff}.caption-text.hint{opacity:.55;font-size:13px}.history-drawer{position:absolute;top:0;left:0;width:100%;height:calc(100% - 96px);overflow-y:auto;background:#0f141fb3;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);z-index:5;display:flex;flex-direction:column-reverse}.history-drawer:before{content:"";position:sticky;top:0;left:0;width:100%;height:48px;background:linear-gradient(180deg,rgba(15,20,31,.85) 0%,transparent 100%);z-index:6;flex-shrink:0;pointer-events:none}.history-content{padding:20px 18px 36px;display:flex;flex-direction:column;gap:14px;justify-content:flex-end}.hist-item{display:flex;gap:10px;font-size:13px;color:#ffffffeb;animation:slideUpFade .3s cubic-bezier(.16,1,.3,1) forwards;line-height:1.5}@keyframes slideUpFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.hist-item .role{color:#74c0fc;min-width:34px;flex-shrink:0;font-weight:600}.hist-item.assistant .role{color:#ffd43b}.hist-item span:last-child{flex:1;word-break:break-word;background:#ffffff14;padding:8px 12px;border-radius:3px 10px 10px}.hist-item.user span:last-child{background:#74c0fc1f;border-top-left-radius:10px;border-top-right-radius:3px}.control-dock{display:flex;align-items:center;justify-content:center}.dock{display:flex;align-items:center;gap:16px;justify-content:center;background:#ffffff38;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:10px 22px;border-radius:999px;box-shadow:0 6px 24px #0000001f,inset 0 1px 1px #ffffff59;pointer-events:auto}.icon-btn{width:44px;height:44px;border-radius:50%;border:none;background:#ffffffd9;color:#314056;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 8px #0000000f,inset 0 1px #fffc;font-size:18px}.icon-btn:hover:not(:disabled){background:#fff;transform:scale(1.06) translateY(-1px);box-shadow:0 4px 12px #0000001a}.icon-btn:active:not(:disabled){transform:scale(.95)}.icon-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.icon-btn.muted{background:#ffe6e6eb;color:#e03131}.icon-btn.muted:hover:not(:disabled){background:#ffdbdb}.icon-btn.active{background:#deeeffeb;color:#1864ab}.call-btn{width:56px;height:56px;border-radius:50%;border:none;background:linear-gradient(135deg,#2fd38a,#13b46f);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:inset 0 2px #ffffff4d,0 6px 20px #18b2694d;font-size:22px}.call-btn:hover:not(:disabled){transform:scale(1.06) translateY(-1px);box-shadow:inset 0 2px #fff6,0 10px 24px #18b26966}.call-btn:active:not(:disabled){transform:scale(.95)}.call-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.call-btn.active{background:linear-gradient(135deg,#ff6b6b,#e03131);box-shadow:0 6px 20px #e031314d}.call-btn.active:hover:not(:disabled){box-shadow:0 10px 24px #e0313166}.smart-home-grid{columns:2;column-gap:16px;padding:4px}.room-card{break-inside:avoid;margin-bottom:16px;background:linear-gradient(168deg,#fffffff7,#f6f9fdfa);border:1px solid rgba(255,255,255,.7);box-shadow:0 1px 2px #0000000a,0 6px 20px #070d1614;border-radius:18px;padding:16px}.room-card-title{font-size:15px;font-weight:700;color:#24344c;margin-bottom:10px}.room-devices{display:flex;flex-direction:column;gap:8px}.device-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:12px;background:#e9eef799;transition:background .2s}.device-row.active{background:#ffefd0b3}.device-dot{width:10px;height:10px;border-radius:50%;background:#a3b1c6;flex-shrink:0;transition:background .2s}.device-dot.active{background:#f5b83d}.device-name{font-size:13px;font-weight:600;color:#31425d;flex:1}.device-status{font-size:12px;color:#8d9bb2;font-weight:500}.error-toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%);padding:12px 24px;background:linear-gradient(135deg,#ff6b6b,#e03131);color:#fff;border-radius:12px;font-size:14px;box-shadow:0 6px 20px #e0313140;z-index:100;max-width:90%;text-align:center}@media (max-width: 820px){body{padding:12px;align-items:flex-start}.app-shell{grid-template-columns:1fr;gap:16px}.primary-column{max-width:400px;margin:0 auto}.video-stage{min-height:420px}}@media (max-width: 480px){body{padding:0}.app-shell{gap:0}.primary-column{max-width:100%}.smart-home-grid{columns:1;padding:12px}.video-card{border-radius:0;min-height:100vh}.video-stage{flex:1;min-height:0}.dock{gap:12px;padding:10px 18px}.icon-btn{width:40px;height:40px}.call-btn{width:50px;height:50px}}
