:root{font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;--surface: #ffffff;--surface-muted: #f5f7fb;--border: #e3e8f2;--text-primary: #1c2434;--text-muted: #7a8196;background-color:var(--surface-muted);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--surface-muted);color:var(--text-primary)}#app{min-height:100vh}.portal{min-height:100vh;display:flex;flex-direction:column;background:var(--surface-muted);color:var(--text-primary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.portal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10}.portal__logo{display:flex;align-items:center;gap:.75rem}.portal__logo-mark{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#5236ff,#8a5bff);color:#fff;display:grid;place-items:center;font-weight:700;font-size:1rem}.portal__logo-label{font-size:1rem;font-weight:600;margin:0}.portal__logo-subtitle{font-size:.8rem;color:var(--text-muted)}.portal__search{position:relative;flex:0 0 40%}.portal__search input{width:100%;border:1px solid var(--border);border-radius:999px;padding:.65rem 2.75rem .65rem 1rem;background:var(--surface-muted);color:inherit}.portal__search input::placeholder{color:var(--text-muted)}.portal__search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-muted)}.portal__user{position:relative}.portal__user-trigger{display:flex;align-items:center;gap:.4rem;border:1px solid var(--border);border-radius:999px;padding:.25rem .5rem;background:var(--surface-muted);cursor:pointer}.portal__user-initials{width:32px;height:32px;border-radius:50%;background:#1d2233;color:#fff;display:grid;place-items:center;font-weight:600}.portal__user-caret{width:16px;height:16px;transition:transform .2s ease}.portal__user-caret.open{transform:rotate(180deg)}.portal__user-menu{position:absolute;right:0;margin-top:.5rem;padding:.75rem;width:220px;border-radius:12px;border:1px solid var(--border);background:var(--surface);box-shadow:0 15px 45px #0a0f1e26;display:flex;flex-direction:column;gap:.35rem}.portal__tenant-switch{display:flex;flex-direction:column;gap:6px}.portal__tenant-label{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#6b7280}.portal__tenant-current{display:flex;justify-content:space-between;align-items:center;border:1px solid #e3e5ec;border-radius:6px;padding:6px 8px;background:#f8f9fc;cursor:pointer;font-size:14px}.portal__tenant-caret{width:16px;height:16px}.portal__tenant-dropdown{display:flex;flex-direction:column;border:1px solid #e3e5ec;border-radius:6px;padding:6px;gap:4px;background:#fff;box-shadow:0 8px 24px #0f172a1f}.portal__tenant-dropdown button{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;border:none;background:none;cursor:pointer;border-radius:4px}.portal__tenant-dropdown button:hover,.portal__tenant-dropdown button.active{background:#eef2ff;color:#111827}.portal__tenant-active-dot{width:8px;height:8px;background:#10b981;border-radius:50%}.portal__user-menu button{border:none;background:transparent;text-align:left;padding:.25rem 0;color:inherit;cursor:pointer}.portal__user-menu hr{border:none;border-top:1px solid var(--border);margin:.35rem 0}.portal__user-name{margin:0;font-weight:600}.portal__user-role{font-size:.8rem;color:var(--text-muted)}.portal__body{display:flex;flex:1}.session-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--surface-muted);padding:2rem}.session-card{background:var(--surface);border-radius:18px;border:1px solid var(--border);padding:2rem;max-width:480px;box-shadow:0 30px 60px #0f172a29;text-align:center}.session-card h1{margin-top:0}.session-form{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem;text-align:left}.session-form label{font-size:.85rem;color:var(--text-muted);display:flex;flex-direction:column;gap:.35rem}.session-form input{border:1px solid var(--border);border-radius:10px;padding:.65rem .85rem;font-size:1rem}.session-form button{border:none;border-radius:10px;background:#5236ff;color:#fff;padding:.75rem 1.25rem;font-weight:600;cursor:pointer}.session-error{color:#d14343;margin:0;font-size:.9rem}.portal__workspace{flex:1;display:flex;position:relative}.portal__workspace.drawer-open .portal__main{margin-right:var(--drawer-width, min(420px, 35vw));transition:margin .3s ease}.portal__sidebar{width:220px;padding:1.5rem 1rem;border-right:1px solid var(--border);background:#0f1425;display:flex;flex-direction:column;gap:.25rem}.portal__sidebar-group{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem}.portal__sidebar-heading{margin:.75rem 0 .15rem;padding:0 .5rem;text-transform:uppercase;letter-spacing:.08em;font-size:.65rem;color:#ffffff8c}.portal__sidebar button{border:none;background:transparent;color:#c2c8ff;text-align:left;padding:.65rem .9rem;border-radius:10px;cursor:pointer;font-weight:500}.portal__sidebar button:hover,.portal__sidebar button.active{background:#ffffff1a;color:#fff}.admin-panel{display:flex;flex-direction:column;gap:16px}.admin-panel__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.admin-card{background:#fff;border:1px solid #e3e5ec;border-radius:8px;padding:16px;box-shadow:0 4px 10px #0000000a}.admin-card header h3{margin:0 0 4px}.admin-card header p{margin:0 0 12px;color:#57607c}.admin-form{display:grid;gap:12px}.admin-form label{display:flex;flex-direction:column;gap:4px;font-size:14px}.admin-form input,.admin-form select{padding:8px 10px;border-radius:6px;border:1px solid #d3d6df;font-size:14px}.admin-form button{justify-self:flex-start}.tenant-membership-stack{display:flex;flex-direction:column;gap:10px}.tenant-membership-card{border:1px solid #e3e5ec;border-radius:8px;padding:10px;background:#fdfdff}.tenant-membership-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.tenant-membership-subline{font-size:12px;color:#6b7280}.tenant-membership-remove{background:none;border:none;color:#b42318;cursor:pointer;font-size:12px}.tenant-membership-controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.tenant-membership-default{display:flex;align-items:center;gap:6px;font-size:13px}.tenant-role-options{display:flex;gap:12px}.tenant-role-options label{display:flex;gap:6px;align-items:center;font-size:13px}.admin-error{color:#c1121f;margin:0}.admin-table{width:100%;display:grid;gap:8px}.admin-table__row{display:grid;grid-template-columns:1.2fr .8fr .8fr 1.4fr .8fr .8fr;gap:8px;padding:8px;border-radius:6px;background:#f8f9fc}.admin-table__head{font-weight:600;background:transparent}.admin-password{font-family:monospace;font-size:13px}.admin-actions{display:flex;gap:8px;align-items:center}.admin-table--audit .admin-table__row{grid-template-columns:1.2fr 1fr 1fr 1fr 1fr}.link-button{border:none;background:none;color:#2563eb;cursor:pointer;padding:0}.modal-backdrop{position:fixed;inset:0;background:#0f172a66;display:grid;place-items:center;z-index:1000}.modal{background:#fff;border-radius:12px;padding:16px;width:min(800px,90vw);max-height:90vh;overflow:auto;box-shadow:0 20px 60px #0f172a40}.modal__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.modal__body{display:grid;gap:8px}.code-block{background:#0f172a;color:#e2e8f0;border-radius:8px;padding:8px;font-family:monospace;font-size:12px;overflow:auto}.portal__sidebar-status{font-size:.85rem;color:#ffffffb3;padding:.5rem .5rem .25rem}.portal__sidebar-status--error{color:#ffb3c1}.portal__main{flex:1;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.portal__main-bar{display:flex;justify-content:space-between;align-items:center}.portal__banner{padding:.75rem 1rem;border-radius:12px;background:#ffd6662e;border:1px solid rgba(255,214,102,.45);color:#1f2533;font-size:.95rem}.portal__eyebrow{margin:0;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.75rem}.portal__eyebrow-subtext{margin:.25rem 0 0;color:#ffffffb3;font-size:.8rem}.module-outlet{display:flex;flex-direction:column;gap:1.5rem;width:100%}.module-placeholder{border:1px dashed var(--border);border-radius:16px;padding:2rem;background:#ffffff05}.module-placeholder--pending{border-color:#f5a524;background:#f5a52414}.module-placeholder h3{margin:0 0 .5rem}.module-placeholder p{margin:0 0 1rem;color:#ffffffbf}.module-placeholder a{color:#8ea8ff;font-weight:600}.module-remote{border:1px solid var(--border);border-radius:18px;overflow:hidden;background:#0f1425f2;display:flex;flex-direction:column;min-height:520px}.module-remote__header{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.06)}.module-remote__eyebrow{margin:0;font-size:.75rem;text-transform:uppercase;color:#fff9;letter-spacing:.08em}.module-remote__header h3{margin:.3rem 0 0}.module-remote iframe{border:none;flex:1;background:#050914}.module-embedded{min-height:360px}.portal__main-bar h2{margin:.2rem 0 0}.portal__main-actions{display:flex;gap:.5rem}.ghost-button{border-radius:999px;border:1px solid var(--border);background:transparent;color:inherit;padding:.5rem 1rem;font-weight:600;cursor:pointer}.ghost-button:hover{border-color:#5236ff;color:#5236ff}.research-drawer{position:absolute;top:0;right:0;bottom:0;width:var(--drawer-width, min(420px, 90vw));border-left:1px solid var(--border);background:var(--surface);box-shadow:-15px 0 45px #0f172a26;transition:transform .3s ease,opacity .3s ease;transform:translate(110%);opacity:0;pointer-events:none;display:flex;z-index:5}.research-drawer.open{transform:translate(0);opacity:1;pointer-events:auto}.research-drawer__handle{position:absolute;top:0;left:-10px;width:16px;height:100%;cursor:col-resize;z-index:10;display:flex;align-items:center;justify-content:center}.research-drawer__handle:before{content:"";width:4px;height:48px;border-radius:999px;background:#5236ffa6;box-shadow:0 0 12px #5236ff59}.panel{background:var(--surface);border-radius:18px;padding:1.5rem;border:1px solid var(--border);box-shadow:0 25px 55px #0f172a14}.panel--cards{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.panel--charts{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.panel__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.panel__header h3{margin:0}.panel__header span{color:var(--text-muted);font-size:.85rem}.metric-card__label{margin:0;color:var(--text-muted);font-size:.85rem}.metric-card__value{margin:.35rem 0;font-size:1.8rem;font-weight:700}.metric-card__delta{font-size:.85rem;color:#32c48d}.bar-chart{display:flex;align-items:flex-end;gap:1rem;height:180px}.bar-chart__column{flex:1;display:flex;flex-direction:column;align-items:center;gap:.75rem;font-size:.85rem;color:var(--text-muted)}.bar-chart__bar{width:100%;background:linear-gradient(180deg,#7c5dff,#5236ff);border-radius:8px 8px 4px 4px;transition:height .3s ease}.channel-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.channel-list li{display:flex;align-items:center;gap:.75rem}.channel-list__name{flex:0 0 80px;font-weight:500}.channel-list__bar{flex:1;height:8px;border-radius:999px;background:var(--surface-muted)}.channel-list__bar div{height:100%;border-radius:inherit;background:#33b9ff}.channel-list__value{width:40px;text-align:right;font-weight:600}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}th{color:var(--text-muted);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.02em}.status-pill{padding:.2rem .8rem;border-radius:999px;font-size:.8rem;font-weight:600}.status-pill--live{background:#32c48d26;color:#1a764d}.status-pill--paused{background:#ffaa2b33;color:#9b5c00}.link-button{border:none;background:transparent;color:#5236ff;font-weight:600;cursor:pointer}@media(max-width:960px){.portal__header{flex-direction:column;gap:1rem}.portal__search{width:100%;flex:none;order:3}.portal__body{flex-direction:column}.portal__sidebar{width:100%;flex-direction:row;flex-wrap:wrap}.portal__workspace{flex-direction:column;position:static}.research-drawer{width:100%;position:relative;transform:translateY(100%);border-left:none;border-top:1px solid var(--border);box-shadow:0 -15px 35px #0f172a1f}.research-drawer.open{transform:translateY(0)}.portal__workspace.drawer-open .portal__main{margin-right:0}.research-drawer__handle{display:none}}.audit-sort{border:none;background:transparent;color:#6b7280;cursor:pointer;padding:2px 4px;font-size:12px;line-height:1;border-radius:4px;margin-left:2px;color:#8a5bff}.audit-sort:hover{background:#eef2ff;color:#111827}.audit-sort.active{background:#8a5bff;color:#eef2ff}.research-panel{display:flex;flex-direction:column;height:100%}.research-panel__header{padding:1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.research-panel__eyebrow{text-transform:uppercase;font-size:.75rem;letter-spacing:.08em;color:var(--text-muted);margin:0}.research-panel__header h3{margin:.15rem 0 .25rem}.research-panel__header span{color:var(--text-muted);font-size:.85rem}.research-panel__body{flex:1;padding:1rem 1.25rem 1.25rem;overflow:hidden;height:100%}.research-chat{background:var(--surface-muted);border:1px solid var(--border);border-radius:14px;display:flex;flex-direction:column;min-height:0;box-shadow:inset 0 1px #fff9;height:100%}.research-chat__input{display:flex;gap:.5rem;padding:.85rem;border-bottom:1px solid var(--border);align-items:center}.research-chat__input input{flex:1;border-radius:10px;border:1px solid var(--border);padding:.65rem .85rem;background:var(--surface);color:inherit;min-width:0}.research-chat__input button{border-radius:10px;border:1px solid transparent;padding:.65rem 1rem;font-weight:600;cursor:pointer;background:#5236ff;color:#fff}.research-chat__actions{display:flex;gap:.5rem;align-items:center}.research-chat__input button.secondary{background:transparent;border-color:var(--border);color:var(--text-muted)}.research-chat__stream{flex:1;padding:.9rem;overflow:auto;width:100%;min-width:0}.research-chat__label{text-transform:uppercase;font-size:.75rem;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.5rem}.research-chat__placeholder{color:var(--text-muted);font-style:italic}.research-notes{background:#f6f7fb;border:1px solid var(--border);border-radius:12px;padding:.75rem .85rem;margin:0 .85rem .85rem;color:var(--text-muted)}.research-notes__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem;color:var(--text);font-weight:600;font-size:.9rem}.research-notes ul{margin:0;padding-left:1rem;color:var(--text);font-size:.9rem;display:grid;gap:.25rem}.research-stream{display:flex;flex-direction:column;gap:.65rem;font-size:.92rem;line-height:1.5;color:inherit;word-break:break-word}.research-stream p{margin:0}.research-stream ul,.research-stream ol{margin:0;padding-left:1.25rem}.research-stream h1,.research-stream h2,.research-stream h3,.research-stream h4{margin:.8rem 0 .35rem;font-size:1rem;font-weight:600}.research-chat__spinner{display:inline-flex;gap:.4rem;align-items:center;margin-top:.75rem;color:var(--text-muted);font-size:.8rem}.research-chat__spinner span{width:.45rem;height:.45rem;border-radius:50%;background:currentColor;animation:research-pulse 1s infinite ease-in-out}.research-chat__spinner span:nth-child(2){animation-delay:.15s}.research-chat__spinner span:nth-child(3){animation-delay:.3s}@keyframes research-pulse{0%,80%,to{opacity:.2;transform:scale(.7)}40%{opacity:1;transform:scale(1)}}.research-chat__error{color:#d14343;padding:.75rem 1rem}.research-history{border-top:1px solid var(--border);padding:.75rem 1rem}.research-history ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}.research-history button{border:none;background:transparent;color:#5236ff;cursor:pointer;padding:0}@media(max-width:960px){.research-panel__header{flex-direction:column;align-items:flex-start}}
