:root{color-scheme:dark;font-family:Aptos,Segoe UI,system-ui,sans-serif;--bg: #0d1117;--panel: #161b22;--panel-alt: #1c2330;--border: rgba(255, 255, 255, .08);--border-md: rgba(255, 255, 255, .14);--border-hi: rgba(255, 255, 255, .22);--text: #e6edf3;--muted: #8b949e;--accent: #4ee7ff;--accent-dim: rgba(78, 231, 255, .18);--accent-glow: rgba(78, 231, 255, .12);--ok: #3fb950;--warn: #d29922;--danger: #f85149;--cyan: #4ee7ff;--green: #3fb950;--amber: #d29922;--red: #f85149;--violet: #a997ff;--shadow-card: 0 1px 3px rgba(0, 0, 0, .4), 0 4px 12px rgba(0, 0, 0, .25);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .5);--rail-width: 300px;--convo-width: 340px;--topbar-h: 52px;--gap: 12px;--radius: 14px}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background-color:var(--bg);color:var(--text);overflow-x:hidden}button,input,textarea{font:inherit}button{cursor:pointer}.jarvis-shell{display:flex;flex-direction:column;height:100vh;min-height:0;overflow:hidden}.jarvis-topbar{flex-shrink:0;height:var(--topbar-h);padding:0 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);background:var(--panel)}.interface-grid{flex:1;display:grid;grid-template-columns:var(--rail-width) 1fr var(--convo-width);gap:var(--gap);padding:var(--gap);min-height:0;overflow:hidden}.command-core,.workshop,.mission-control{position:relative;min-width:0;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow-card)}.command-core{display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:12px;padding:20px}.workshop,.mission-control{padding:16px}.mission-control{display:flex;flex-direction:column;gap:12px;overflow:auto}.widget-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow-card);overflow:hidden}.widget-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border)}.widget-card-title{display:flex;align-items:center;gap:7px;color:var(--text);font-size:.85rem;font-weight:600;letter-spacing:.01em}.widget-card-title svg{width:15px;height:15px;color:var(--accent);flex-shrink:0}.widget-card-actions{display:flex;align-items:center;gap:6px;color:var(--muted)}.widget-card-body{padding:12px 14px}.status-rail{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;max-width:1120px;margin:0 auto 14px}.status-rail div{display:grid;grid-template-columns:24px minmax(0,1fr);align-items:center;column-gap:8px;row-gap:4px;min-height:56px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--panel);box-shadow:var(--shadow-card)}.status-rail svg,.core-signal-grid svg,.mission-block svg,.mission-metrics svg,.mode-toggle svg{width:18px;height:18px;color:var(--accent)}.status-rail span,.core-signal-grid span,.mission-metrics span,.event-strip span,.section-heading span,.core-identity span{color:var(--muted);font-size:.72rem;text-transform:uppercase}.status-rail strong,.core-signal-grid strong,.mission-metrics strong,.event-strip strong,.agent-list strong{color:var(--text);font-size:.9rem;font-weight:600;overflow-wrap:normal;word-break:normal}.status-rail svg,.core-signal-grid svg,.mission-metrics svg,.event-strip svg{grid-row:1 / span 2}.status-rail strong,.core-signal-grid strong,.mission-metrics strong,.event-strip strong{grid-column:2}.core-identity{width:100%;display:flex;align-items:baseline;justify-content:space-between;gap:12px}.core-identity strong{color:var(--accent);font-size:1.1rem}.voice-core{position:relative;width:min(68%,318px);aspect-ratio:1;display:grid;place-items:center;margin:12px 0}.voice-core-ring{position:absolute;inset:0;border-radius:50%;border:1px solid var(--border-md);animation:core-spin 18s linear infinite}.voice-core-ring-middle{inset:14%;border-style:dashed;animation-duration:12s;animation-direction:reverse}.voice-core-ring-inner{inset:29%;border-color:#d1992273;animation-duration:8s}.voice-core-content{width:42%;aspect-ratio:1;border-radius:50%;display:grid;place-items:center;gap:8px;border:1px solid rgba(78,231,255,.22);background:radial-gradient(circle,#4ee7ff24,#0d1117e6);box-shadow:0 0 24px #4ee7ff24;text-align:center}.voice-core-content svg{width:32px;height:32px;color:var(--accent)}.voice-core-content span{max-width:120px;color:var(--text);font-size:.8rem;font-weight:700;text-transform:uppercase}.voice-core-executing .voice-core-content,.voice-core-thinking .voice-core-content{box-shadow:0 0 28px #d1992247}.voice-core-blocked .voice-core-content,.voice-core-conflict .voice-core-content{box-shadow:0 0 28px #f8514947}.command-summary{width:100%;min-height:96px;padding:14px;border-left:2px solid var(--accent);border-radius:0 8px 8px 0;background:var(--accent-dim)}.command-summary p{margin:0 0 8px;color:var(--text);font-size:1rem;line-height:1.45}.command-summary span,.mission-block p{color:var(--muted);font-size:.9rem;line-height:1.45}.command-input-panel{width:100%;display:flex;flex-direction:column;gap:8px}.command-input-panel label{color:var(--muted);font-size:.78rem;text-transform:uppercase}.command-input-row{display:grid;grid-template-columns:minmax(0,1fr) 116px;gap:8px}.command-input-row input,.command-input-row button,.mode-toggle{min-height:44px;border:1px solid var(--border-md);border-radius:8px;background:var(--panel-alt);color:var(--text)}.command-input-row input{min-width:0;padding:0 12px;outline:none}.command-input-row input:focus{border-color:var(--warn)}.command-input-row button,.mode-toggle{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700}.command-input-row button:disabled{cursor:not-allowed;opacity:.5}.command-input-row button svg{width:17px;height:17px}.core-signal-grid{width:100%;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.core-signal-grid div,.mission-metrics div{display:grid;grid-template-columns:24px minmax(0,1fr);align-content:center;column-gap:8px;row-gap:4px;min-height:72px;padding:10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-alt)}.core-response,.core-error{width:100%;padding:10px 12px;border-radius:8px;border:1px solid rgba(63,185,80,.3);background:#3fb9500f}.core-response span,.core-error{color:var(--muted);font-size:.82rem}.core-response strong{display:block;color:var(--ok);overflow-wrap:anywhere}.core-error{border-color:#f8514959;background:#f8514912;color:#ffd6d6}.section-heading{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.section-heading h2{margin:4px 0 0;font-size:1.02rem;font-weight:700}.mode-toggle{min-width:88px;padding:0 12px}.hologram-stage{position:relative;height:calc(100% - 142px);min-height:360px;overflow:hidden;border:1px solid var(--border);border-radius:10px;background:radial-gradient(circle at 50% 50%,rgba(78,231,255,.06),transparent 60%),var(--panel-alt)}.hologram-grid{position:absolute;inset:10%;transform:perspective(700px) rotateX(62deg);border:1px solid rgba(78,231,255,.12);background:linear-gradient(rgba(78,231,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(78,231,255,.07) 1px,transparent 1px);background-size:34px 34px}.hologram-axis{position:absolute;background:#d1992240}.hologram-axis-x{left:10%;right:10%;top:52%;height:1px}.hologram-axis-y{top:14%;bottom:12%;left:50%;width:1px}.hologram-core{position:absolute;left:50%;top:50%;width:74px;height:74px;transform:translate(-50%,-50%);display:grid;place-items:center;border:1px solid var(--border-md);border-radius:50%;background:var(--panel);color:var(--accent);font-size:2rem;font-weight:800;box-shadow:0 0 20px #4ee7ff26}.hologram-node{position:absolute;width:142px;min-height:96px;display:flex;flex-direction:column;justify-content:center;gap:6px;padding:12px;border:1px solid var(--border-md);border-radius:10px;background:var(--panel);box-shadow:var(--shadow-card)}.hologram-node svg{width:20px;height:20px;color:var(--warn)}.hologram-node strong{color:var(--text);text-transform:capitalize}.hologram-node span{color:var(--muted);font-size:.78rem}.hologram-node-1{left:12%;top:18%}.hologram-node-2{right:10%;top:24%}.hologram-node-3{left:20%;bottom:16%}.hologram-node-4{right:17%;bottom:14%}.event-strip{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}.event-strip div{display:flex;flex-direction:column;justify-content:center;row-gap:4px;min-height:64px;padding:10px;border:1px solid var(--border);border-radius:10px;background:var(--panel-alt)}.stream-pill{min-width:106px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;color:var(--muted);text-align:center;text-transform:uppercase;font-size:.72rem}.stream-connected{border-color:#3fb95066;color:var(--ok)}.stream-failed{border-color:#f8514966;color:var(--danger)}.mission-block{position:relative;z-index:1;border:1px solid var(--border);border-radius:10px;background:var(--panel-alt);padding:12px}.mission-block h3{display:flex;align-items:center;gap:8px;margin:0 0 10px;color:var(--text);font-size:.92rem}.agent-list,.mission-metrics{display:grid;gap:8px}.agent-list div{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:42px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--panel)}.agent-list span{color:var(--accent);text-transform:capitalize}.agent-list strong{color:var(--muted)}.mission-metrics{position:relative;z-index:1;grid-template-columns:repeat(3,minmax(0,1fr))}.alert-list{display:flex;flex-direction:column;gap:8px;margin:0;padding:0;list-style:none}.alert-list li{border-left:2px solid var(--warn);padding-left:8px;color:#e8d08a;font-size:.86rem;line-height:1.45}@keyframes core-spin{to{transform:rotate(360deg)}}.top-bar{flex-shrink:0;height:var(--topbar-h);padding:0 16px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;border-bottom:1px solid var(--border);background:var(--panel);-webkit-user-select:none;user-select:none}.top-bar-left{display:flex;align-items:center;gap:10px;min-width:0}.top-bar-wordmark{color:var(--accent);font-size:.98rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap}.top-bar-status-pill{display:inline-flex;align-items:center;gap:5px;padding:2px 9px 2px 7px;border-radius:999px;font-size:.72rem;font-weight:600;letter-spacing:.04em;border:1px solid var(--border-md);color:var(--muted);background:var(--panel-alt);white-space:nowrap}.top-bar-status-online{border-color:#3fb95059;color:var(--ok);background:#3fb95014}.top-bar-status-offline{border-color:var(--border);color:var(--muted);background:transparent}.top-bar-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0;background:currentColor}.top-bar-status-online .top-bar-dot{background:var(--ok);box-shadow:0 0 6px #3fb95099}.top-bar-clock{display:flex;flex-direction:column;align-items:center;gap:1px;justify-self:center}.top-bar-time{color:var(--text);font-size:1.02rem;font-weight:700;letter-spacing:.06em;font-variant-numeric:tabular-nums;line-height:1}.top-bar-date{color:var(--muted);font-size:.7rem;letter-spacing:.03em;text-transform:capitalize;line-height:1}.top-bar-right{display:flex;align-items:center;justify-content:flex-end}.top-bar-gear{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--muted);transition:color .15s,border-color .15s,background .15s}.top-bar-gear:hover{color:var(--text);border-color:var(--border-md);background:var(--panel-alt)}.top-bar-gear:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media(max-width:720px){.top-bar{padding:0 10px;gap:8px}.top-bar-date{display:none}}@media(max-width:1100px){.interface-grid{grid-template-columns:1fr;overflow:visible}.jarvis-shell{overflow:auto}.command-core,.workshop,.mission-control{min-height:560px}}@media(max-width:720px){:root{--gap: 8px}.jarvis-topbar{padding:0 10px}.status-rail,.core-signal-grid,.event-strip,.mission-metrics,.command-input-row{grid-template-columns:1fr}.command-core{align-items:stretch}.core-identity{display:grid;grid-template-columns:1fr;gap:6px}.core-identity strong{justify-self:start}.voice-core{align-self:center;width:min(92%,300px)}.hologram-node{width:118px}}.arc-orb{position:relative;display:block;width:100%}.arc-orb__seg-ring{transform-origin:140px 140px;transform-box:fill-box;animation:arc-seg-spin 22s linear infinite}.arc-orb__mid-ring{transform-origin:140px 140px;transform-box:fill-box;animation:arc-mid-spin 14s linear infinite}.arc-orb__inner-arcs{transform-origin:140px 140px;transform-box:fill-box;animation:arc-inner-spin 30s linear infinite}.arc-orb__core-glow,.arc-orb__core-halo{transform-origin:140px 140px;transform-box:fill-box;animation:arc-core-pulse 3s ease-in-out infinite}.arc-orb__state-label{animation:arc-label-fade 2.5s ease-in-out infinite}.arc-orb-idle .arc-orb__seg-ring{animation-duration:22s}.arc-orb-idle .arc-orb__mid-ring{animation-duration:14s}.arc-orb-idle .arc-orb__core-glow,.arc-orb-idle .arc-orb__core-halo{animation-duration:3.5s}.arc-orb-listening .arc-orb__seg-ring{animation-duration:7s}.arc-orb-listening .arc-orb__mid-ring{animation-duration:5s}.arc-orb-listening .arc-orb__ticks{opacity:.9}.arc-orb-listening .arc-orb__binary{opacity:.8;animation:arc-binary-scroll .8s steps(1) infinite}.arc-orb-listening .arc-orb__core-glow,.arc-orb-listening .arc-orb__core-halo{animation-duration:1.2s}.arc-orb-thinking .arc-orb__seg-ring{animation-duration:4s}.arc-orb-thinking .arc-orb__mid-ring{animation-duration:2.5s}.arc-orb-thinking .arc-orb__inner-arcs{animation-duration:8s}.arc-orb-thinking .arc-orb__core-glow,.arc-orb-thinking .arc-orb__core-halo{animation-duration:.7s;opacity:.85}.arc-orb-thinking .arc-orb__core-ring{animation:arc-core-ring-pulse .7s ease-in-out infinite}.arc-orb-thinking .arc-orb__label{animation:arc-text-bright .7s ease-in-out infinite}.arc-orb-speaking .arc-orb__seg-ring{animation-duration:10s}.arc-orb-speaking .arc-orb__mid-ring{animation-duration:6s}.arc-orb-speaking .arc-orb__core-glow,.arc-orb-speaking .arc-orb__core-halo{animation:arc-core-pulse .55s ease-in-out infinite,arc-speak-beat 1.1s ease-in-out infinite}.arc-orb-speaking .arc-orb__seg-ring{animation:arc-seg-spin 10s linear infinite,arc-speak-ring-beat 1.1s ease-in-out infinite}@keyframes arc-seg-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes arc-mid-spin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}@keyframes arc-inner-spin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}@keyframes arc-core-pulse{0%,to{opacity:.45;transform:scale(1)}50%{opacity:.85;transform:scale(1.12)}}@keyframes arc-core-ring-pulse{0%,to{opacity:.8}50%{opacity:1}}@keyframes arc-text-bright{0%,to{opacity:.85}50%{opacity:1}}@keyframes arc-label-fade{0%,to{opacity:.5}50%{opacity:.9}}@keyframes arc-binary-scroll{0%{opacity:.8}50%{opacity:.4}to{opacity:.8}}@keyframes arc-speak-beat{0%,to{opacity:.45;transform:scale(1)}25%{opacity:.9;transform:scale(1.18)}50%{opacity:.55;transform:scale(1.05)}75%{opacity:.88;transform:scale(1.15)}}@keyframes arc-speak-ring-beat{0%,to{opacity:1}50%{opacity:.6}}.hologram-floor{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none;background:radial-gradient(ellipse 80% 40% at 50% 72%,rgba(78,231,255,.07) 0%,transparent 70%)}.hologram-floor__grid{position:absolute;left:-20%;right:-20%;bottom:-8%;height:62%;transform:perspective(520px) rotateX(58deg);transform-origin:50% 100%;background-image:linear-gradient(rgba(78,231,255,calc(.09 * var(--hf-intensity, 1))) 1px,transparent 1px),linear-gradient(90deg,rgba(78,231,255,calc(.09 * var(--hf-intensity, 1))) 1px,transparent 1px);background-size:44px 44px;border:1px solid rgba(78,231,255,calc(.1 * var(--hf-intensity, 1)));animation:hf-grid-drift 24s linear infinite}.hologram-floor__horizon{position:absolute;left:0;right:0;bottom:0;height:55%;background:linear-gradient(to bottom,var(--bg) 0%,transparent 40%,transparent 100%);pointer-events:none}.hologram-floor__bloom{position:absolute;left:50%;bottom:36%;width:260px;height:80px;transform:translate(-50%);border-radius:50%;background:radial-gradient(ellipse at 50% 50%,rgba(78,231,255,.12) 0%,transparent 70%);pointer-events:none;animation:hf-bloom-pulse 4s ease-in-out infinite}@keyframes hf-grid-drift{0%{background-position:0 0,0 0}to{background-position:0 44px,0 0}}@keyframes hf-bloom-pulse{0%,to{opacity:.7;transform:translate(-50%) scaleY(1)}50%{opacity:1;transform:translate(-50%) scaleY(1.18)}}.center-stage{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow-card)}.center-stage__content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px 28px;width:100%}.center-stage__orb-wrap{width:min(72%,320px);filter:drop-shadow(0 8px 32px rgba(78,231,255,.18))}.center-stage__wordmark{margin:0;color:var(--accent);font-size:1.05rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;text-shadow:0 0 18px rgba(78,231,255,.45)}.stage-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 14px;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.05em;border:1px solid var(--border-md);color:var(--muted);background:var(--panel-alt);transition:color .3s,border-color .3s,background .3s}.stage-pill:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.stage-pill--idle{color:var(--muted);border-color:var(--border)}.stage-pill--listening{color:var(--accent);border-color:#4ee7ff66;background:#4ee7ff0f}.stage-pill--listening:before{animation:stage-pill-blink 1s ease-in-out infinite}.stage-pill--thinking{color:var(--warn);border-color:#d2992266;background:#d299220f}.stage-pill--thinking:before{animation:stage-pill-blink .55s ease-in-out infinite}.stage-pill--speaking{color:var(--ok);border-color:#3fb95066;background:#3fb9500f}.stage-pill--speaking:before{animation:stage-pill-blink .9s ease-in-out infinite}@keyframes stage-pill-blink{0%,to{opacity:1}50%{opacity:.2}}.stage-buttons{display:flex;align-items:center;gap:14px}.stage-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid var(--border-md);background:var(--panel-alt);color:var(--muted);transition:color .2s,border-color .2s,background .2s,box-shadow .2s}.stage-btn svg{width:18px;height:18px}.stage-btn--disabled{opacity:.38;cursor:not-allowed}.stage-btn--recording{color:#ff4e4e;border-color:#ff4e4e80;background:#ff4e4e1f;animation:mic-pulse .9s ease-in-out infinite}@keyframes mic-pulse{0%,to{box-shadow:0 0 6px #ff4e4e4d}50%{box-shadow:0 0 18px #ff4e4eb3}}.stage-btn--active{color:var(--accent);border-color:#4ee7ff59;background:#4ee7ff12}.stage-btn--active:hover{color:#9ef8ff;border-color:#4ee7ff99;background:#4ee7ff21;box-shadow:0 0 14px #4ee7ff38}.stage-btn--active:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.stage-btn--active:active{transform:scale(.94)}.left-rail{display:flex;flex-direction:column;gap:var(--gap);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent;padding-right:2px}.left-rail::-webkit-scrollbar{width:4px}.left-rail::-webkit-scrollbar-track{background:transparent}.left-rail::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:4px}.card-value{margin:0 0 6px;color:var(--accent);font-size:.95rem;font-weight:700;overflow-wrap:anywhere}.card-note{margin:0;color:var(--muted);font-size:.78rem;line-height:1.5}.card-empty,.card-loading{margin:0;color:var(--muted);font-size:.82rem;font-style:italic}.card-label{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}.privacy-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:5px 0;border-bottom:1px solid var(--border)}.privacy-row:last-child{border-bottom:none}.badge-ok{padding:2px 8px;border-radius:999px;font-size:.72rem;font-weight:600;color:var(--ok);background:#3fb9501a;border:1px solid rgba(63,185,80,.3)}.badge-warn{padding:2px 8px;border-radius:999px;font-size:.72rem;font-weight:600;color:var(--warn);background:#d299221a;border:1px solid rgba(210,153,34,.3)}.badge-danger{padding:2px 8px;border-radius:999px;font-size:.72rem;font-weight:600;color:var(--danger);background:#f851491a;border:1px solid rgba(248,81,73,.3)}.stat-stack{display:flex;flex-direction:column;gap:10px}.stat-row{display:flex;flex-direction:column;gap:4px}.stat-row-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.stat-value{color:var(--text);font-size:.78rem;font-variant-numeric:tabular-nums}.stat-bar-track{width:100%;height:4px;border-radius:2px;background:var(--panel-alt);overflow:hidden}.stat-bar-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .4s ease}.uptime-value{margin:0;color:var(--accent);font-size:1.45rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.06em;text-align:center}.placeholder-body{display:flex;flex-direction:column;gap:8px}.badge-soon{display:inline-block;align-self:flex-start;padding:2px 9px;border-radius:999px;font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border-md);background:var(--panel-alt)}.conversation-panel{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow-card)}.convo-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--panel)}.convo-title{color:var(--text);font-size:.85rem;font-weight:600;letter-spacing:.01em}.convo-clear-btn{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border:1px solid var(--border-md);border-radius:6px;background:transparent;color:var(--muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.convo-clear-btn:hover{color:var(--danger);border-color:#f8514966;background:#f851490f}.convo-clear-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.chat-log{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:8px;padding:14px 12px;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent}.chat-log::-webkit-scrollbar{width:4px}.chat-log::-webkit-scrollbar-track{background:transparent}.chat-log::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:4px}.chat-empty{margin:auto;color:var(--muted);font-size:.82rem;font-style:italic;text-align:center;padding:16px;line-height:1.5}.chat-thinking{align-self:flex-start;color:var(--muted);font-size:.78rem;font-style:italic;padding:4px 10px;animation:convo-blink 1.2s ease-in-out infinite}@keyframes convo-blink{0%,to{opacity:.5}50%{opacity:1}}.chat-bubble{max-width:84%;padding:9px 12px;border-radius:12px;font-size:.86rem;line-height:1.5;word-break:break-word}.chat-bubble--user{align-self:flex-end;background:#4ee7ff1f;border:1px solid rgba(78,231,255,.22);color:var(--text);border-bottom-right-radius:3px}.chat-bubble--jarvis{align-self:flex-start;background:var(--panel-alt);border:1px solid var(--border-md);color:var(--text);border-bottom-left-radius:3px}.chat-bubble--attention{border-color:#d2992273;background:#d2992214;color:#e8d08a}.chat-bubble__text{display:block;white-space:pre-wrap}.convo-input-row{flex-shrink:0;display:flex;align-items:flex-end;gap:8px;padding:10px 12px;border-top:1px solid var(--border);background:var(--panel)}.convo-textarea{flex:1;min-width:0;resize:none;padding:8px 10px;border:1px solid var(--border-md);border-radius:8px;background:var(--panel-alt);color:var(--text);font-size:.86rem;line-height:1.45;outline:none;transition:border-color .15s;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent}.convo-textarea::placeholder{color:var(--muted)}.convo-textarea:focus{border-color:#4ee7ff66}.convo-textarea:disabled{opacity:.55;cursor:not-allowed}.convo-send-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;border:1px solid rgba(78,231,255,.3);background:#4ee7ff14;color:var(--accent);transition:background .15s,border-color .15s,box-shadow .15s;cursor:pointer}.convo-send-btn:hover:not(:disabled){background:#4ee7ff29;border-color:#4ee7ff80;box-shadow:0 0 10px #4ee7ff2e}.convo-send-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.convo-send-btn:disabled{opacity:.38;cursor:not-allowed}.approval-badge{display:inline-flex;align-items:center;gap:6px;margin-left:auto;padding:4px 10px;border:1px solid rgba(78,231,255,.4);border-radius:999px;background:#4ee7ff14;color:#4ee7ff;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;animation:approval-badge-pulse 2.4s ease-in-out infinite}.approval-badge:hover{background:#4ee7ff29;border-color:#4ee7ff99}.approval-badge:active{transform:scale(.97)}.approval-badge:focus-visible{outline:2px solid #4ee7ff;outline-offset:2px}.approval-badge__count{display:inline-block;min-width:16px;text-align:center}@keyframes approval-badge-pulse{0%,to{box-shadow:0 0 #4ee7ff66}50%{box-shadow:0 0 0 8px #4ee7ff00}}@media(prefers-reduced-motion:reduce){.approval-badge{animation:none}}.approval-consent-overlay{position:fixed;inset:0;z-index:950;display:flex;align-items:center;justify-content:center;background:#0d111766;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:approval-fade-in .2s ease-out}.approval-consent{position:relative;width:min(420px,90vw);padding:24px 24px 18px;border:1px solid rgba(78,231,255,.4);border-radius:12px;background:linear-gradient(180deg,#142533,#0d1117);box-shadow:0 12px 40px #0009,0 0 24px #4ee7ff26;color:#e6edf3}.approval-consent__close{position:absolute;top:8px;right:8px;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:6px;background:transparent;color:#e6edf380;cursor:pointer;transition:color .15s,background .15s}.approval-consent__close:hover{color:#e6edf3;background:#ffffff0d}.approval-consent__prompt{margin:0;font-size:1rem;line-height:1.4}.approval-consent__sub{margin:4px 0 18px;color:#e6edf3b3;font-size:.92rem}.approval-consent__actions{display:flex;gap:10px;margin-bottom:12px}.approval-btn{flex:1;padding:9px 14px;border-radius:8px;border:1px solid transparent;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.approval-btn--primary{background:#4ee7ff;color:#0d1117}.approval-btn--primary:hover{background:#6deeff}.approval-btn--ghost{background:transparent;border-color:#e6edf333;color:#e6edf3}.approval-btn--ghost:hover{border-color:#e6edf366;background:#ffffff0a}.approval-btn--danger{background:#f8514929;border-color:#f8514966;color:#f85149}.approval-btn--danger:hover{background:#f851493d}.approval-consent__voice{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:8px;border:1px dashed rgba(78,231,255,.3);border-radius:8px;background:transparent;color:#4ee7ffcc;font-size:.8rem;cursor:pointer;transition:background .15s,border-color .15s}.approval-consent__voice:hover:not(:disabled){background:#4ee7ff14;border-color:#4ee7ff80}.approval-consent__voice.is-recording{background:#f851491f;border-color:#f8514980;color:#f85149}.approval-consent__hint{margin:8px 0 0;color:#e6edf399;font-size:.78rem;text-align:center}@keyframes approval-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.approval-consent-overlay,.approval-consent{animation:none}}.approval-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.approval-fallback__glow{position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,#4ee7ff59,#0d111700 70%);filter:blur(20px)}.approval-fallback__ring{position:absolute;border-radius:50%;border:1px solid rgba(78,231,255,.5);box-shadow:0 0 24px #4ee7ff40 inset}.approval-fallback__ring--outer{width:280px;height:280px}.approval-fallback__ring--inner{width:200px;height:200px;border-color:#4ee7ffb3;border-style:dashed}.approval-gate-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;animation:approval-fade-in .22s ease-out}.approval-gate-backdrop{position:absolute;inset:0;background:#0d1117a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.approval-gate{position:relative;width:min(640px,92vw);max-height:86vh;padding:32px 28px 24px;border:1px solid rgba(78,231,255,.4);border-radius:16px;background:linear-gradient(180deg,#142533eb,#0d1117eb);box-shadow:0 24px 80px #000000a6,0 0 40px #4ee7ff33;overflow:hidden}.approval-gate__visual{position:absolute;inset:0;pointer-events:none;opacity:.7}.approval-canvas-wrap{position:absolute;inset:0}.approval-gate__content{position:relative;z-index:1;color:#e6edf3}.approval-gate__close{position:absolute;top:0;right:0;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:8px;background:#ffffff0d;color:#e6edf3b3;cursor:pointer;transition:color .15s,background .15s}.approval-gate__close:hover:not(:disabled){color:#e6edf3;background:#ffffff1a}.approval-gate__title{margin:0 0 4px;font-size:.85rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#4ee7ff}.approval-gate__subtitle{margin:0 0 16px;font-size:1.5rem;font-weight:700;line-height:1.2}.approval-gate__summary{margin:0 0 20px;padding:12px 14px;border-radius:8px;background:#ffffff0a;border-left:3px solid rgba(78,231,255,.6);color:#e6edf3d9;font-size:.92rem;line-height:1.5}.approval-gate__meta{display:grid;grid-template-columns:auto 1fr;gap:4px 18px;margin:0 0 22px;font-size:.85rem}.approval-gate__meta dt{color:#e6edf380}.approval-gate__meta dd{margin:0;font-weight:600;color:#4ee7ff}.approval-gate__actions{display:flex;gap:10px;margin-bottom:14px}.approval-gate__actions .approval-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px}.approval-gate__voice{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:8px;border:1px dashed rgba(78,231,255,.3);border-radius:8px;background:transparent;color:#4ee7ffcc;font-size:.8rem;cursor:pointer;transition:background .15s,border-color .15s}.approval-gate__voice:hover:not(:disabled){background:#4ee7ff14}.approval-gate__voice.is-recording{background:#f851491f;border-color:#f8514980;color:#f85149}.approval-gate__hint{margin:8px 0 0;color:#e6edf399;font-size:.78rem;text-align:center}@media(prefers-reduced-motion:reduce){.approval-gate-overlay{animation:none}}.card-value--flash{animation:model-card-flash 1.5s ease-out}@keyframes model-card-flash{0%{color:#4ee7ff;text-shadow:0 0 12px rgba(78,231,255,.8)}to{color:inherit;text-shadow:none}}@media(prefers-reduced-motion:reduce){.card-value--flash{animation:none}}.mobile-nav{display:none}@media(max-width:720px){.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--panel);border-top:1px solid var(--border-md);padding:4px;gap:4px;padding-bottom:max(4px,env(safe-area-inset-bottom))}.mobile-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:transparent;border:0;color:var(--muted);font-size:10px;letter-spacing:.3px;padding:8px 0;border-radius:8px;cursor:pointer;min-height:56px}.mobile-nav-tab.is-active{color:var(--accent);background:var(--accent-dim)}}@media(max-width:720px){body,html,#root,.jarvis-shell{height:100vh;height:100dvh;overflow:hidden}.jarvis-shell{display:flex;flex-direction:column}.interface-grid{display:flex!important;flex-direction:column;flex:1;padding:0;gap:0;overflow:hidden;margin-bottom:64px}.interface-grid>.left-rail,.interface-grid>.center-stage,.interface-grid>.conversation-panel{display:none!important;border-radius:0;border-left:0;border-right:0}.jarvis-shell[data-mobile-view=chat] .interface-grid>.conversation-panel{display:flex!important;flex-direction:column;flex:1;min-height:0;max-height:none;overflow:hidden;padding:0}.jarvis-shell[data-mobile-view=voice] .interface-grid>.center-stage{display:flex!important;flex-direction:column;flex:1;align-items:center;justify-content:center;padding:16px;min-height:0}.jarvis-shell[data-mobile-view=voice] .center-stage__orb-wrap{width:min(80vw,320px)!important}.jarvis-shell[data-mobile-view=panels] .interface-grid>.left-rail{display:flex!important;flex-direction:column!important;flex:1;gap:8px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:8px}.jarvis-shell[data-mobile-view=panels] .left-rail>*{width:100%;flex:0 0 auto;min-height:unset}.top-bar{padding:0 8px!important;height:48px!important;flex:0 0 auto;gap:6px!important;display:flex;align-items:center;justify-content:space-between}.top-bar-left{gap:6px!important;align-items:center;min-width:0;flex:0 1 auto}.top-bar-wordmark{font-size:13px;white-space:nowrap}.top-bar-clock,.top-bar-date{display:none!important}.top-bar-status-pill{font-size:9px!important;padding:2px 5px!important;gap:3px!important}.top-bar-right{flex:0 0 auto;gap:4px!important}.persona-selector{margin-right:4px!important}.persona-selector-label{font-size:0;gap:0}.persona-selector-label svg{width:16px!important;height:16px!important}.persona-selector-select{max-width:110px;font-size:12px;padding:4px 6px}.conversation-panel{height:100%;display:flex!important;flex-direction:column;border-radius:0;border-left:0;border-right:0}.convo-header{padding:8px!important;border-bottom:1px solid var(--border)}.convo-tabs{flex:0 0 auto}.chat-log,.convo-messages{flex:1;overflow-y:auto!important;-webkit-overflow-scrolling:touch;padding:8px}.convo-composer{flex:0 0 auto;background:var(--panel);padding:8px;border-top:1px solid var(--border);display:flex;gap:6px}.convo-input{font-size:16px!important;flex:1}.convo-send-btn{min-width:44px;min-height:44px}.top-bar-gear{min-width:40px;min-height:40px}.onboarding-overlay{padding:16px 8px}.onboarding-modal{padding:14px;max-height:calc(100vh - 32px);overflow-y:auto}.onboarding-provider-row{flex-direction:column;align-items:flex-start;gap:6px}.chat-bubble{max-width:92%!important;font-size:14px}}@media(max-width:480px){.top-bar-wordmark{font-size:12px}.persona-selector-select{max-width:95px}}.convo-tabs{display:inline-flex;gap:4px;background:var(--bg);padding:3px;border-radius:8px;border:1px solid var(--border)}.convo-tab{display:inline-flex;align-items:center;gap:5px;background:transparent;border:0;color:var(--muted);font-size:12px;padding:5px 10px;border-radius:5px;cursor:pointer;font-weight:500}.convo-tab:hover{color:var(--text)}.convo-tab.is-active{background:var(--accent-dim);color:var(--accent)}.chat-bubble--claude{border-left:2px solid var(--violet)!important}.alert-budget{color:var(--warn);font-weight:500}.persona-selector{display:inline-flex;align-items:center;gap:6px;margin-right:10px}.persona-selector-label{display:inline-flex;align-items:center;gap:4px;color:var(--muted);font-size:11px;letter-spacing:.4px;text-transform:uppercase;cursor:help}.persona-selector-select{background:var(--panel-alt);border:1px solid var(--border-md);color:var(--text);border-radius:6px;padding:4px 8px;font-size:12px;cursor:pointer}.persona-selector-select:hover{border-color:var(--border-hi)}.persona-selector-select:focus{outline:none;border-color:var(--accent)}.cost-providers{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}.cost-providers li{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);font-family:ui-monospace,SFMono-Regular,monospace}.cost-providers li span:first-child{text-transform:capitalize}.arbiter-tier-pill{display:inline-block;margin-top:4px;padding:2px 8px;border-radius:10px;font-size:10px;letter-spacing:.4px;text-transform:uppercase;font-weight:600;cursor:help}.arbiter-tier-s1_quick{background:#4ee7ff2e;color:var(--accent);border:1px solid rgba(78,231,255,.4)}.arbiter-tier-s2_deliberative{background:#a997ff2e;color:var(--violet);border:1px solid rgba(169,151,255,.4)}.arbiter-tier-s2_default{background:#8b949e2e;color:var(--muted);border:1px solid var(--border-md)}.onboarding-overlay{position:fixed;inset:0;background:#0a0e16c7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-start;justify-content:center;padding:56px 16px;z-index:9000;overflow-y:auto}.onboarding-modal{background:var(--panel);border:1px solid var(--border-md);border-radius:14px;max-width:720px;width:100%;padding:22px;box-shadow:0 20px 60px #0000008c}.onboarding-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.onboarding-header h2{margin:0 0 6px;font-size:18px;letter-spacing:.5px}.onboarding-subtitle{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.onboarding-subtitle code{background:var(--panel-alt);padding:1px 5px;border-radius:3px;font-size:12px}.onboarding-close{background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:6px;cursor:pointer}.onboarding-close:hover{color:var(--text);border-color:var(--border-hi)}.onboarding-error{background:#f851491f;border:1px solid rgba(248,81,73,.4);color:var(--danger);padding:10px;border-radius:8px;margin-bottom:14px;font-size:13px}.onboarding-loading{display:flex;align-items:center;gap:8px;color:var(--muted);padding:18px}.onboarding-providers{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.onboarding-provider{background:var(--panel-alt);border:1px solid var(--border);border-radius:10px;overflow:hidden}.onboarding-provider.is-present{border-color:#3fb95059}.onboarding-provider-row{width:100%;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;background:transparent;border:0;text-align:left;cursor:pointer;color:var(--text)}.onboarding-provider-row:hover{background:#ffffff05}.onboarding-provider-meta{display:flex;flex-direction:column;gap:4px}.onboarding-provider-name{display:inline-flex;align-items:center;gap:6px;font-weight:600}.onboarding-badge{background:#4ee7ff24;color:var(--accent);font-size:10px;padding:2px 6px;border-radius:4px;margin-left:6px;text-transform:uppercase;letter-spacing:.5px}.onboarding-provider-desc{color:var(--muted);font-size:12px}.onboarding-status{font-size:12px;padding:4px 10px;border-radius:12px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.onboarding-status-ok{background:#3fb95029;color:var(--ok)}.onboarding-status-missing{background:#d2992229;color:var(--warn)}.onboarding-provider-form{padding:0 14px 14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.onboarding-purpose{margin:12px 0 0;font-size:12px;color:var(--muted)}.onboarding-docs-link{color:var(--accent);font-size:12px;text-decoration:none;display:inline-flex;align-items:center;gap:4px;width:fit-content}.onboarding-docs-link:hover{text-decoration:underline}.onboarding-field{display:flex;flex-direction:column;gap:4px}.onboarding-field-label{font-size:11px;color:var(--muted);letter-spacing:.4px;font-family:ui-monospace,SFMono-Regular,monospace}.onboarding-field-input-wrap{position:relative}.onboarding-field-input-wrap input{width:100%;background:var(--bg);border:1px solid var(--border-md);border-radius:6px;padding:8px 36px 8px 10px;color:var(--text);font-family:ui-monospace,SFMono-Regular,monospace;font-size:13px}.onboarding-field-input-wrap input:focus{outline:none;border-color:var(--accent)}.onboarding-eye{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:transparent;border:0;color:var(--muted);cursor:pointer;padding:4px}.onboarding-eye:hover{color:var(--text)}.onboarding-actions{display:flex;gap:8px;margin-top:4px}.onboarding-btn{padding:7px 14px;border-radius:6px;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border-md);background:var(--panel-alt);color:var(--text)}.onboarding-btn:disabled{opacity:.45;cursor:not-allowed}.onboarding-btn-secondary:hover:not(:disabled){border-color:var(--border-hi)}.onboarding-btn-primary{background:var(--accent);color:#07111c;border-color:var(--accent);font-weight:600}.onboarding-btn-primary:hover:not(:disabled){filter:brightness(1.08)}.onboarding-msg{margin:0;font-size:12px;padding:8px 10px;border-radius:6px;display:inline-flex;align-items:center;gap:6px}.onboarding-msg-ok{background:#3fb9501f;border:1px solid rgba(63,185,80,.3);color:var(--ok)}.onboarding-msg-error{background:#f851491f;border:1px solid rgba(248,81,73,.3);color:var(--danger)}.onboarding-footer{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);color:var(--muted);font-size:12px}.onboarding-footer code{background:var(--panel-alt);padding:1px 5px;border-radius:3px;font-size:11px}.spin{animation:onboarding-spin 1s linear infinite}@keyframes onboarding-spin{to{transform:rotate(360deg)}}
