:root{--bg: var(--color-bg);--surface: var(--color-surface);--surface-2: var(--color-surface-2);--border: var(--color-border);--text: var(--color-text);--muted: var(--color-muted);--accent: var(--color-accent);--accent-2: var(--color-accent-2);--ok: var(--color-ok);--warn: var(--color-warn);--err: var(--color-err);--radius: var(--radius-md);--chrome-h: 52px;--sidebar-w: 232px;--sidebar-rail-w: 56px;font-family:var(--font-sans)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}*{box-sizing:border-box}html,body,app-root{height:100%;margin:0}body{background:var(--bg);color:var(--text)}button{font:inherit;cursor:pointer}app-root{display:block}app-chrome,app-dashboard,app-auth-gate,app-toaster,app-iframe-host,app-ops-view,app-debug-panel,app-modal-host{display:contents}.shell{display:flex;flex-direction:column;height:100%}.shell.with-chrome{display:grid;grid-template-rows:var(--chrome-h) minmax(0,1fr);grid-template-columns:var(--sidebar-w) minmax(0,1fr);grid-template-areas:"topbar topbar" "sidebar stage"}.shell.with-chrome.sidebar-collapsed{--sidebar-w: var(--sidebar-rail-w)}.topbar{grid-area:topbar;display:flex;align-items:center;gap:12px;padding:0 14px;background:var(--surface);border-bottom:1px solid var(--border)}.brand{background:none;border:none;color:var(--text);font-weight:700;font-size:15px;letter-spacing:.2px}.sidebar-toggle{width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1}.chrome-hamburger{display:none;align-items:center;justify-content:center;width:38px;height:38px;padding:0;font-size:18px;line-height:1}.active-app{display:flex;align-items:baseline;gap:8px;min-width:0;padding-left:12px;border-left:1px solid var(--border)}.active-app-icon{font-size:14px;align-self:center}.active-app-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap}.active-app-origin{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chrome-session{margin-left:auto;display:flex;align-items:center;gap:10px;font-size:13px}.sidebar{grid-area:sidebar;display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;overflow-x:hidden;padding:12px 8px}.sidebar-nav{display:flex;flex-direction:column;gap:16px}.nav-group-label{margin:0 0 4px;padding:0 8px;font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.nav-group-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:1px solid transparent;color:var(--muted);padding:6px 8px;border-radius:var(--radius);text-align:left}.nav-item:hover{color:var(--text);background:var(--surface-2)}.nav-item.active{color:var(--text);background:var(--surface-2);border-color:var(--border)}.nav-icon{flex:0 0 auto;width:20px;font-size:14px;text-align:center}.nav-text{display:flex;flex-direction:column;min-width:0}.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-origin{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed{padding:12px 6px}.sidebar.collapsed .sidebar-nav{gap:10px}.sidebar.collapsed .nav-group+.nav-group{border-top:1px solid var(--border);padding-top:10px}.sidebar.collapsed .nav-group-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.sidebar.collapsed .nav-text{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:8px 0}.sidebar.collapsed .nav-icon{width:auto;font-size:16px}.sidebar-session{display:none}.who{color:var(--text)}.profile-pill{text-transform:uppercase;font-size:10px;letter-spacing:.08em;padding:2px 7px;border-radius:999px;border:1px solid var(--border);color:var(--muted)}.profile-pill.local{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 50%,transparent)}.profile-pill.prod{color:var(--accent-2);border-color:color-mix(in srgb,var(--accent-2) 50%,transparent)}.ghost{background:transparent;border:1px solid var(--border);color:var(--muted);padding:4px 10px;border-radius:var(--radius)}.ghost:hover{color:var(--text);border-color:var(--accent)}.stage{grid-area:stage;position:relative;flex:1 1 auto;overflow:hidden;min-width:0}.iframe-host,.iframe-slot{position:absolute;inset:0}.iframe-slot iframe{width:100%;height:100%;border:0;background:var(--bg)}.app-loading{position:absolute;inset:0;display:grid;place-items:center;background:var(--bg);color:var(--muted)}.app-fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:24px}.app-fallback h2{margin:0}.retry{background:var(--accent);color:var(--color-on-accent);border:none;padding:8px 16px;border-radius:var(--radius);margin-top:8px;cursor:pointer}.launcher{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:40px;gap:10px}.launcher h1{margin:0;font-size:28px}.muted{color:var(--muted);max-width:620px}.tiles{display:flex;gap:16px;margin-top:18px;flex-wrap:wrap;justify-content:center}.tile{width:180px;height:150px;background:var(--surface);border:1px solid var(--border);border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text);transition:transform .08s ease,border-color .12s ease}.tile:hover{transform:translateY(-3px);border-color:var(--accent)}.tile-icon{font-size:34px}.tile-name{font-weight:600}.tile-path{color:var(--muted);font-size:12px;font-family:ui-monospace,monospace}.dashboard{position:absolute;inset:0;overflow:hidden;padding:16px;display:flex;flex-direction:column;gap:14px}.dash-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.layout-switch{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.layout-opt{appearance:none;background:transparent;border:0;border-right:1px solid var(--border);color:var(--muted);padding:6px 9px;display:inline-flex;align-items:center;cursor:pointer}.layout-opt svg{display:block;fill:currentColor}.layout-opt:last-child{border-right:0}.layout-opt:hover{color:var(--text);background:var(--surface-2)}.layout-opt.active{color:var(--accent);background:var(--surface-2)}.dash-notice{flex:1 1 auto;min-width:0;margin:0;color:var(--muted);font-size:13px}.add-widget{background:var(--accent);color:var(--color-on-accent);border:1px solid transparent;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.add-widget:disabled{opacity:.45;cursor:default}.dash-empty{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center}.dash-empty h2{margin:0}.dash-grid{flex:1 1 auto;min-height:0;overflow-y:auto;display:grid;gap:14px;grid-auto-rows:minmax(180px,1fr)}.dash-cell{border:1px dashed transparent;border-radius:12px}.dashboard.dragging .dash-cell{border-color:var(--border)}.dash-cell.drag-over{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent)}.widget{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;min-height:0}.widget.dragging-self{opacity:.4}.widget.drag-over{outline:2px solid var(--accent);outline-offset:-2px}.widget-chrome{flex:0 0 auto;display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--surface-2);border-bottom:1px solid var(--border)}.drag-handle{cursor:grab;color:var(--muted);-webkit-user-select:none;user-select:none}.widget-title{flex:1 1 auto;font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-provenance{flex:0 1 auto;min-width:0;font-size:var(--text-xs);color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-provenance-origin{font-family:var(--font-mono)}.chrome-actions{display:flex;gap:2px}.chrome-btn{background:transparent;border:1px solid transparent;color:var(--muted);width:24px;height:24px;border-radius:6px;cursor:pointer;font:inherit;line-height:1}.chrome-btn:hover{color:var(--text);border-color:var(--border);background:var(--surface)}.widget-body{flex:1 1 auto;position:relative;min-height:0}.widget-body iframe{display:block;width:100%;height:100%;border:0;background:var(--bg)}.widget-loading{position:absolute;inset:0;display:grid;place-items:center;background:var(--bg);color:var(--muted)}.drag-shield{position:absolute;inset:0;pointer-events:none}.dashboard.dragging .drag-shield{pointer-events:auto}.widget-placeholder{height:100%;display:grid;place-items:center;padding:20px;text-align:center;color:var(--muted)}.picker-backdrop{position:fixed;inset:0;display:grid;place-items:center;background:color-mix(in srgb,var(--bg) 70%,transparent);z-index:50}.picker{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:min(440px,92vw);max-height:80vh;overflow:auto;padding:16px}.picker-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.picker-head h3{margin:0}.picker-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.picker-item{width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;font:inherit;text-align:left}.picker-item:hover:not([disabled]){border-color:var(--accent)}.picker-item[disabled]{opacity:.5;cursor:default}.picker-title{font-weight:600}.picker-app{color:var(--muted);font-size:12px}.picker-added{margin-left:auto;color:var(--muted);font-size:12px}.authgate{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:40px;gap:14px}.authgate h1{margin:0;font-size:28px}.authgate-reject{display:flex;flex-direction:column;gap:4px;max-width:560px;text-align:left;border:1px solid color-mix(in srgb,var(--accent-2) 50%,transparent);background:color-mix(in srgb,var(--accent-2) 12%,transparent);color:var(--text);padding:12px 16px;border-radius:var(--radius)}.authgate-signin{margin-top:6px;background:var(--accent);color:var(--color-on-accent);border:none;padding:10px 20px;border-radius:var(--radius);font-weight:600;cursor:pointer}.authgate-signin:hover{filter:brightness(1.05)}.toaster{position:fixed;top:calc(var(--chrome-h) + 12px);right:14px;display:flex;flex-direction:column;gap:8px;z-index:1000}.toast{text-align:left;border:1px solid var(--border);background:var(--surface-2);color:var(--text);padding:10px 14px;border-radius:var(--radius);min-width:220px;max-width:340px;box-shadow:var(--shadow-2);border-left-width:4px}.toast.success{border-left-color:var(--ok)}.toast.error{border-left-color:var(--err)}.toast.warning{border-left-color:var(--warn)}.toast.info{border-left-color:var(--accent)}.debug{position:fixed;bottom:0;left:0;right:0;z-index:900;font-size:12px}.debug-toggle{background:var(--surface);color:var(--muted);border:1px solid var(--border);border-bottom:none;border-radius:8px 8px 0 0;padding:4px 12px;margin-left:12px;font-family:ui-monospace,monospace}.debug.open .debug-body{background:var(--surface);border-top:1px solid var(--border);display:grid;grid-template-columns:200px 1fr 1fr;gap:16px;padding:12px 16px;max-height:38vh;overflow:auto}.debug-body h4{margin:0 0 6px;color:var(--muted);text-transform:uppercase;font-size:10px;letter-spacing:.08em}.debug-body .row{display:flex;align-items:center;gap:8px;padding:2px 0}.log{font-family:ui-monospace,monospace;line-height:1.5}.log-line{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-line .tag{display:inline-block;width:58px;color:var(--muted)}.log-line.in .tag{color:var(--accent)}.log-line.out .tag{color:var(--accent-2)}.log-line.drop .tag,.log-line.security .tag{color:var(--err)}.pill{padding:1px 7px;border-radius:999px;border:1px solid var(--border);color:var(--muted);font-size:10px}.mini{background:var(--surface-2);border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:1px 7px;font-size:10px;cursor:pointer}.mini:hover{color:var(--text);border-color:var(--accent)}.mini.on{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 55%,transparent);background:color-mix(in srgb,var(--ok) 12%,var(--surface-2))}.pill.active,.pill.ready{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 50%,transparent)}.pill.error{color:var(--err);border-color:color-mix(in srgb,var(--err) 50%,transparent)}.pill.mounting,.pill.handshaking{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 50%,transparent)}.ops{position:fixed;bottom:0;right:0;z-index:901;font-size:12px}.ops-toggle{background:var(--surface);color:var(--accent-2);border:1px solid var(--border);border-bottom:none;border-radius:8px 8px 0 0;padding:4px 12px;margin-right:12px;font-family:ui-monospace,monospace;cursor:pointer}.ops.open .ops-body{background:var(--surface);border:1px solid var(--border);border-right:none;border-radius:8px 0 0;display:grid;gap:14px;padding:12px 16px;width:min(560px,96vw);max-height:70vh;overflow:auto}.ops-body h4{margin:0 0 6px;color:var(--accent-2);text-transform:uppercase;font-size:10px;letter-spacing:.08em}.ops-col{border-top:1px solid var(--border);padding-top:8px}.ops-col:first-child{border-top:none;padding-top:0}.ops-health.alert{background:color-mix(in srgb,var(--err) 12%,transparent);border-radius:6px;padding:2px 4px}.ops-note{margin:6px 0 0;font-size:11px}.ops-filters{gap:6px;margin-bottom:6px}.ops-filters select{background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-radius:6px;font-size:11px;padding:1px 4px}.ops-tracelist{max-height:120px;overflow:auto}.ops-trace{cursor:pointer;padding:1px 2px;border-radius:4px}.ops-trace:hover{background:var(--surface-2)}.ops-trace.sel{background:color-mix(in srgb,var(--accent) 18%,transparent)}.ops-logstream{max-height:180px;overflow:auto}.ops-log{white-space:normal}.ops-waterfall{margin-top:8px;display:flex;flex-direction:column;gap:3px}.ops-span-label{font-family:ui-monospace,monospace;font-size:11px}.ops-span-track{position:relative;height:8px;background:var(--surface-2);border-radius:4px;margin-top:2px}.span-bar{position:absolute;top:0;height:8px;background:var(--accent);border-radius:4px;min-width:2px}.perf-block{margin-top:8px}.perf-cap{display:block;font-size:11px;color:var(--text);margin-bottom:4px}.perf-row{display:flex;align-items:center;gap:8px;padding:2px 0}.perf-row b{min-width:64px}.perf-row .ops-span-track{flex:1 1 auto;min-width:80px;margin-top:0}.perf-row code,.ops-note code{font-family:ui-monospace,monospace;background:var(--surface-2);padding:0 4px;border-radius:4px}html.modal-open,html.modal-open body{overflow:hidden}.modal-backdrop{position:fixed;inset:0;display:grid;place-items:center;padding:24px;background:color-mix(in srgb,var(--bg) 60%,transparent);z-index:2000;overscroll-behavior:contain;visibility:hidden}.modal-backdrop.revealed{visibility:visible}.modal-panel{display:flex;flex-direction:column;max-width:96vw;max-height:88vh;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-2);overflow:hidden}.modal-titlebar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}.modal-titles{display:flex;flex-direction:column;gap:2px;min-width:0}.modal-title{font-weight:600}.modal-provenance{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.modal-close{flex:none;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:8px;width:28px;height:28px;line-height:1}.modal-close:hover{color:var(--text);border-color:var(--accent)}.modal-body{position:relative;flex:1 1 auto;min-height:0;overflow:auto;overscroll-behavior:contain}.modal-body iframe{display:block;width:100%;border:0;background:var(--color-bg)}@media(max-width:768px){.chrome-hamburger{display:inline-flex}.sidebar-toggle{display:none}.shell.with-chrome{grid-template-columns:minmax(0,1fr);grid-template-areas:"topbar" "stage"}.topbar .chrome-session,.active-app-origin{display:none}.sidebar{position:fixed;top:var(--chrome-h);left:0;bottom:0;width:min(320px,86vw);border-right:1px solid var(--border);box-shadow:var(--shadow-1);z-index:1100;transform:translate(-100%);visibility:hidden;transition:transform var(--motion-base),visibility var(--motion-base)}.sidebar.drawer-open{transform:none;visibility:visible}.sidebar.collapsed{padding:12px 8px}.sidebar.collapsed .nav-text{display:flex}.sidebar.collapsed .nav-item{justify-content:flex-start;padding:6px 8px}.sidebar.collapsed .nav-icon{width:20px;font-size:14px}.sidebar.collapsed .nav-group+.nav-group{border-top:none;padding-top:0}.sidebar.collapsed .nav-group-label{position:static;width:auto;height:auto;margin:0 0 4px;padding:0 8px;overflow:visible;clip-path:none;white-space:normal}.sidebar-session{display:flex;flex-direction:column;align-items:stretch;gap:8px;border-top:1px solid var(--border);padding-top:10px;margin-top:12px}.sidebar-session .ghost{text-align:center}.dashboard{padding:12px;gap:10px}.dash-toolbar{display:none}.dash-grid{grid-auto-rows:minmax(0,1fr);overflow:hidden}.widget.tab-hidden{display:none}.dash-tabs{flex:0 0 auto;display:flex;align-items:center;gap:6px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.dash-tabs::-webkit-scrollbar{display:none}.dash-tab-add{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid transparent;border-radius:var(--radius-pill);background:var(--accent);color:var(--color-on-accent);font:inherit;font-size:18px;font-weight:700;line-height:1}.dash-tab-add:disabled{opacity:.45;cursor:default}.dash-tab{flex:0 0 auto;padding:6px 12px;border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--surface);color:var(--muted);white-space:nowrap;font:inherit;font-size:13px}.dash-tab.active{color:var(--text);border-color:var(--accent);background:var(--surface-2)}.widget .drag-handle,.layout-switch{display:none}.toaster{left:12px;right:12px;top:calc(var(--chrome-h) + 8px)}.toast{min-width:0;max-width:none}.debug.open .debug-body{grid-template-columns:1fr;gap:10px;max-height:60vh}.modal-backdrop:not(.sheet){padding:12px}.modal-backdrop.sheet{padding:0}.modal-backdrop.sheet .modal-panel{width:100vw!important;max-width:100vw;border-radius:0;border:0;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh}.tile{width:100%;max-width:260px;height:auto;padding:20px}}
