:root{--bg:#07111f;--bg-soft:#08182cb8;--card:#0a1b31db;--card-strong:#0c1f3af5;--line:#94bbe92e;--text:#edf6ff;--muted:#9fb6ce;--accent:#74f0c9;--accent-strong:#08c89d;--warn:#ff7f7f;--user-bubble:#0f7f92;--assistant-bubble:#113250;--interim-bubble:#503a12;--shadow:0 20px 60px #00000059}*{box-sizing:border-box;margin:0;padding:0}html{min-height:100%}body{min-height:100vh;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#1b508d73,#0000 35%),radial-gradient(circle at 100% 0,#08c89d2e,#0000 28%),linear-gradient(#07111f 0%,#05101a 100%);font-family:Avenir Next,Hiragino Sans,Yu Gothic,sans-serif}button,input,textarea{font:inherit}button{cursor:pointer;border:0}.console-shell,.login-shell{width:min(1180px,100vw - 24px);margin:0 auto;padding:24px 0 48px}.hero-card,.chat-card,.status-card,.login-card{border:1px solid var(--line);background:var(--card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow);border-radius:28px}.hero-card{justify-content:space-between;gap:16px;margin-bottom:18px;padding:22px;display:flex}.hero-actions,.composer-footer{align-items:center;gap:10px;display:flex}.workspace-grid{grid-template-columns:minmax(0,1.4fr) minmax(320px,.9fr);gap:18px;display:grid}.chat-card,.status-card{padding:18px}.section-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.eyebrow{color:var(--accent);letter-spacing:.12em;text-transform:uppercase;font-family:SFMono-Regular,IBM Plex Mono,Courier New,monospace;font-size:.82rem}h1,h2,h3{font-weight:700}h1{font-size:clamp(1.8rem,4vw,2.8rem)}h2{font-size:1.25rem}.muted,.support-text,.timestamp{color:var(--muted)}.chat-body{flex-direction:column;gap:12px;min-height:48vh;max-height:62vh;padding-right:6px;display:flex;overflow-y:auto}.bubble{border:1px solid #ffffff0f;border-radius:18px;padding:14px 16px}.bubble.assistant{background:var(--assistant-bubble)}.bubble.user{background:var(--user-bubble)}.bubble.interim{background:var(--interim-bubble)}.bubble-role{color:#ffffffa8;text-transform:uppercase;margin-bottom:6px;font-family:SFMono-Regular,IBM Plex Mono,Courier New,monospace;font-size:.76rem;display:block}.bubble p{white-space:pre-wrap;line-height:1.6}.composer{border-top:1px solid var(--line);margin-top:14px;padding-top:14px}.composer textarea,.login-form input{width:100%;color:var(--text);resize:vertical;background:#04101ed9;border:1px solid #9bcdff2e;border-radius:18px;padding:14px 16px}.composer textarea::placeholder,.login-form input::placeholder{color:#d4e6f96b}.composer-footer{justify-content:space-between;margin-top:12px}.mic-button,.secondary-button,.composer button,.login-form button{border-radius:999px;padding:12px 16px;transition:transform .12s,background .12s,opacity .12s}.mic-button,.composer button,.login-form button{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-strong) 100%);color:#041118;font-weight:700}.secondary-button{color:var(--text);background:#ffffff0f}.mic-button.active{background:linear-gradient(135deg,#ffd36f 0%,#ff9f1a 100%)}.mic-button:disabled,.composer button:disabled,.login-form button:disabled{opacity:.5;cursor:not-allowed}.panel-stack{flex-direction:column;gap:12px;display:flex}.status-panel{border:1px solid var(--line);background:var(--card-strong);border-radius:20px;overflow:hidden}.status-panel-header{border-bottom:1px solid var(--line);padding:12px 14px}.status-panel pre{color:#d5e8ff;padding:14px;font-family:SFMono-Regular,IBM Plex Mono,Courier New,monospace;font-size:.82rem;line-height:1.5;overflow-x:auto}.login-shell{place-items:center;min-height:100vh;display:grid}.login-card{width:min(460px,100vw - 24px);padding:28px}.login-form{flex-direction:column;gap:12px;margin-top:18px;display:flex}.error-text{color:var(--warn)}@media (max-width:900px){.workspace-grid{grid-template-columns:1fr}.chat-body{min-height:38vh;max-height:48vh}}@media (max-width:640px){.console-shell,.login-shell{width:min(100vw - 16px,1180px);padding-top:12px}.hero-card,.chat-card,.status-card,.login-card{border-radius:22px}.hero-card,.section-header,.composer-footer{flex-direction:column;align-items:stretch}.hero-actions,.composer-footer,.hero-actions>*,.composer-footer>button{width:100%}}
