:root{color-scheme:dark;font-family:Space Grotesk,system-ui,-apple-system,sans-serif;background:#12151b;color:#e6ebf1}*{box-sizing:border-box}body{margin:0;padding:0;background:radial-gradient(circle at top left,rgba(88,120,200,.22),transparent 62%),radial-gradient(circle at 15% 85%,rgba(40,160,130,.12),transparent 55%),#171c24;height:100vh;overflow:hidden}#app{min-height:100vh;height:100vh;padding:28px 32px 48px;display:flex;justify-content:center;align-items:flex-start;overflow:hidden}.viewer-shell{width:100%;max-width:1200px;height:100%;display:flex;flex-direction:column;min-height:0;max-height:845px}.viewer-topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:18px;padding:8px 6px}.viewer-title{display:flex;align-items:center;gap:14px}.viewer-logo{width:68px;height:68px;border-radius:0;object-fit:contain}.title-text{display:flex;flex-direction:column;gap:4px}.title-line{font-size:24px;letter-spacing:.18em;text-transform:uppercase;color:#ffffffe6}.title-strong{font-weight:700}.title-thin{font-weight:300}.title-sub{display:inline-block;width:100%;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:#ffffff73}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.viewer-content{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:22px;flex:1;min-height:0;height:auto;max-height:none}.viewer-content.is-locked{opacity:.18;filter:blur(2px);pointer-events:none}.auth-panel{margin:18px 0 24px;display:flex;justify-content:center;align-items:center;min-height:58vh}.auth-card{max-width:520px;width:min(92vw,520px);background:#14181eb8;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:20px 22px;box-shadow:0 16px 28px #00000059,inset 0 1px #ffffff0d}.auth-title{font-size:14px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.auth-message{margin-top:8px;font-size:12px;color:#ffffffbf}.auth-form{margin-top:14px;display:grid;gap:12px}.auth-toggle{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:4px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#0a0e1299}.auth-toggle button{border-radius:10px;border:1px solid transparent;padding:8px 10px;background:transparent;color:#ffffffb3;font-size:11px;letter-spacing:.16em;text-transform:uppercase}.auth-toggle button.is-active{background:#ffffff14;border-color:#ffffff1f;color:#f7f7f9}.auth-block{display:grid;gap:10px}.auth-block.hidden{display:none}.auth-hint{font-size:11px;color:#ffffffa6}.auth-divider{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#ffffff80;text-align:center}.auth-block button{width:100%;border-radius:12px;border:1px solid rgba(255,255,255,.12);padding:10px 12px;background:#182028b3;color:#f3f4f6}.auth-actions{margin-top:10px;display:flex;justify-content:flex-end}.auth-actions button{border-radius:10px;border:1px solid rgba(255,255,255,.12);padding:6px 10px;background:transparent;color:#ffffffb3}.stream-panel,.chat-panel{background:#14181eb8;border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:22px 24px 26px;box-shadow:0 16px 32px #00000061,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(26px);backdrop-filter:blur(26px);min-height:0}.stream-panel,.chat-panel{display:flex;flex-direction:column}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.sync-indicator{display:inline-flex;flex-direction:column;align-items:center;gap:4px;color:#fff9}.sync-icon{display:inline-flex;align-items:center;justify-content:center}.sync-indicator svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.6;fill:none}.sync-label{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:currentColor}.sync-indicator[data-status=ok]{color:#6fe7b6}.sync-indicator[data-status=warn]{color:#f0b15d}.sync-indicator[data-status=error]{color:#f87171}.panel-title{font-size:14px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}.panel-timeline{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}.timeline-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.timeline-dot{width:22px;height:22px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#ffffffb3;font-size:10px;font-weight:600;letter-spacing:.08em;display:flex;align-items:center;justify-content:center}.timeline-dot.is-active{background:#6fe7b6;border-color:#6fe7b6;color:#0e1b15}.timeline-dot.is-completed{background:#f0b15d;border-color:#f0b15d;color:#2a1b05}.timeline-dot.is-pending{background:#ffffff0f;border-color:#ffffff2e;color:#fff9}.timeline-label{font-size:11px;text-transform:uppercase;letter-spacing:.24em;color:#ffffff80}.stream-card{border-radius:18px;padding:16px 18px;border:1px solid rgba(255,255,255,.08);background:#12161cb8;margin-bottom:14px;position:relative}.stream-card-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#fffc}.stream-card-body{margin-top:8px;font-size:13px;color:#fff9}.stream-card.muted{opacity:.7}.stream-list{display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto;padding-right:18px}.stream-section{margin:12px 0 8px;padding:6px 10px;border-radius:10px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#fff9;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.stream-card.is-clickable{cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.stream-card.is-clickable:hover{border-color:#ffffff24}.stream-card.has-comments{border-color:#58dca047;box-shadow:inset 0 1px #58dca014}.stream-card.has-unread{border-color:#58dca073;box-shadow:inset 0 1px #58dca029}.stream-card.is-active{border-color:#f0b15d73;box-shadow:inset 0 1px #f0b15d2e}.comment-badge{position:absolute;top:10px;right:12px;min-width:22px;height:22px;padding:0 6px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#58dca02e;border:1px solid rgba(88,220,160,.4);color:#6fe7b6;font-size:10px;letter-spacing:.08em}.comment-badge.is-unread{background:#f4a3402e;border-color:#f4a34080;color:#f4a340}.chat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.08);position:relative}.chat-header>div{min-width:0}.chat-header>div:first-child{flex:1}.chat-title{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#ffffffa6}.chat-step-title{margin-top:6px;font-size:10px;letter-spacing:.06em;color:#ffffffb8}.chat-step-select{margin-top:6px;position:relative;display:inline-flex;align-items:center;gap:6px;font-size:10px;color:#ffffffd9;text-transform:uppercase;letter-spacing:.12em;justify-content:flex-start;width:100%}.step-button{background:transparent;border:none;color:inherit;font:inherit;text-transform:inherit;letter-spacing:inherit;padding:0;display:inline-flex;align-items:center;gap:6px;cursor:pointer;justify-content:flex-start;text-align:left;max-width:100%}.step-label{text-align:left}.step-button .select-arrow{display:inline-flex;align-items:center;justify-content:center;opacity:.7;transition:transform .2s ease}.step-button .select-arrow svg{width:14px;height:14px;stroke:currentColor;stroke-width:2.2;fill:none}.step-button.is-open .select-arrow{transform:rotate(180deg)}.step-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:180px;max-height:500px;overflow-y:auto;scrollbar-gutter:stable;border-radius:12px;border:1px solid rgba(255,255,255,.15);background:#080a0ed1;padding:6px;box-shadow:0 20px 40px #00000073,inset 0 1px #ffffff0d;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);z-index:20}.step-menu::-webkit-scrollbar{width:6px}.step-menu::-webkit-scrollbar-track{background:transparent}.step-menu::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:999px}.step-option{width:100%;display:flex;align-items:center;gap:8px;text-align:left;padding:7px 10px;border-radius:10px;background:transparent;color:#fffc;font-size:9px;letter-spacing:.1em;text-transform:uppercase}.step-option-label{flex:1;min-width:0}.step-option-dot{width:6px;height:6px;border-radius:999px;flex-shrink:0}.step-option-dot.is-read{background:#6fe7b6e6;box-shadow:0 0 6px #6fe7b673}.step-option-dot.is-unread{background:#fbbf24f2;box-shadow:0 0 6px #fbbf2480}.step-review-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;margin-left:8px;padding:0 6px;border-radius:999px;background:#fbbf2433;color:#fbbf24f2;font-size:9px;letter-spacing:.06em;text-transform:uppercase;opacity:0;transform:translateY(-1px);transition:opacity .2s ease}.step-review-badge.is-visible{opacity:1}.step-option:hover{background:#ffffff0f;color:#f1f5f9}.step-option.is-active{background:#ffffff1a;color:#6fe7b6}.chat-user{display:flex;align-items:center;gap:8px;position:relative;flex-shrink:0}.chat-user .avatar{width:26px;height:26px;border-radius:999px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);display:inline-flex;align-items:center;justify-content:center;font-size:10px;letter-spacing:.1em;color:#fffc}.chat-user .avatar.has-image,.avatar.has-image{background-size:cover;background-position:center;color:transparent}.comment-row .avatar.has-image{background-size:contain;background-position:center;background-repeat:no-repeat}.user-menu-button{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;gap:3px;border:none;background:transparent;cursor:pointer;padding:0;color:#fff9}.user-menu-button span{width:3px;height:3px;border-radius:999px;background:currentColor;display:inline-block}.user-menu-button.is-vertical{flex-direction:column}.user-menu-button:hover{color:#ffffffe6}.user-menu{position:absolute;top:calc(100% + 10px);right:0;width:260px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#0c0e12f5;padding:14px;box-shadow:0 20px 40px #00000073,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:30}.user-menu-header{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:#fff9;margin-bottom:12px}.user-menu-logout{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;padding:0;background:transparent;color:#ffffffbf;cursor:pointer}.user-menu-logout:hover{color:#fffffffa}.user-menu-logout svg{width:16px;height:16px;stroke:currentColor;stroke-width:1.8;fill:none}.user-menu-avatar{display:flex;justify-content:center;margin-bottom:12px}.user-menu-avatar .avatar-wrapper{position:relative;display:inline-flex}.user-menu-avatar .avatar-large{width:56px;height:56px;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#fffc;font-size:14px;letter-spacing:.12em;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.user-menu-avatar .avatar-badge{position:absolute;right:-4px;bottom:-4px;width:20px;height:20px;border-radius:999px;background:#1b2028;border:1px solid rgba(255,255,255,.2);display:inline-flex;align-items:center;justify-content:center;color:#ececec;pointer-events:none}.user-menu-avatar .avatar-badge svg{width:12px;height:12px;stroke:currentColor;stroke-width:1.6;fill:none}.user-menu-avatar input{display:none}.user-menu-field{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.user-menu-field label{font-size:9px;text-transform:uppercase;letter-spacing:.16em;color:#ffffff8c}.user-menu-field input{border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#00000059;padding:8px 10px;color:#ffffffe6;font-size:12px}.user-menu-readonly{border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#00000040;padding:8px 10px;color:#fff9;font-size:11px}.user-menu-actions{margin-top:4px;display:flex;justify-content:flex-end}.user-menu-save{border:none;border-radius:9px;padding:5px 9px;font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(135deg,#397efff2,#2960d2f2);cursor:pointer}.chat-step{display:flex;flex-direction:column;gap:6px;text-align:right}.chat-step-label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:#fff6}.chat-step input{background:#0c0e12b3;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:7px 10px;font-size:11px;color:#ffffffd9;width:180px}.eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:#ffffff8c}.comment-list{display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding-right:18px;padding-bottom:10px;flex:1;min-height:0}.comment-list::-webkit-scrollbar,.stream-list::-webkit-scrollbar{width:6px}.comment-list::-webkit-scrollbar-track,.stream-list::-webkit-scrollbar-track{background:transparent}.comment-list::-webkit-scrollbar-thumb{background-color:transparent}.comment-list{scrollbar-width:none}.stream-list::-webkit-scrollbar-thumb{background-color:#cfad5d;border-radius:999px}.stream-list{scrollbar-color:#cfad5d transparent;scrollbar-width:thin}.comment-row{display:flex;flex-direction:row;align-items:flex-start;gap:10px}.row-admin,.row-self{flex-direction:row-reverse;text-align:right}.row-viewer,.row-other{align-items:flex-start}.comment-row .avatar{margin-top:10px;width:20px;height:20px;border-radius:999px;background:#ffffff14;display:inline-flex;align-items:center;justify-content:center;font-size:9px;letter-spacing:.1em;color:#ffffffb3;overflow:hidden}.comment-row .avatar img{width:100%;height:100%;object-fit:contain;display:block}.comment-stack{display:flex;flex-direction:column;gap:6px;max-width:85%}.row-admin .comment-stack,.row-self .comment-stack{align-items:flex-end}.row-other .comment-stack{align-items:flex-start}.comment-meta{display:flex;align-items:center;gap:4px;text-transform:uppercase;letter-spacing:.16em;font-size:8px;color:#ffffff8c}.comment-step{font-size:7px;letter-spacing:.2em;text-transform:uppercase;color:#ffffff73}.comment-meta .dot{opacity:.7}.comment-meta .time{color:#ffffff73;cursor:pointer}.comment-bubble{display:inline-flex;width:fit-content;max-width:100%;padding:8px 12px;border-radius:12px;background:#12161cb3;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px #ffffff0d;align-self:flex-start}.row-self .comment-bubble{align-self:flex-end}.bubble-admin{background:#1a2822bf;border-color:#58dca040;box-shadow:inset 0 1px #58dca01a}.bubble-viewer{background:#12161cb3}.comment-bubble .body{font-size:12px;color:#ffffffe0}input,textarea,button{font:inherit}input,textarea{width:100%;background:#0a0c10cc;border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:12px 14px;color:#f3f4f6}textarea{min-height:110px;resize:none}.chat-compose{margin-top:auto;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);display:grid;gap:12px}.author-row{display:flex;align-items:center;gap:8px}.author-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#fff9;cursor:pointer}.user-name{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:#ffffffb3;cursor:pointer}.author-input{width:180px;background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:6px 10px;font-size:10px}.hidden{display:none}.composer{position:relative;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#0c0e12b3;padding:10px 14px 42px;--composer-min-height: 64px;--composer-max-height: 140px;--composer-height: 64px}.composer-banner{position:absolute;left:12px;right:12px;top:-32px;padding:8px 12px;border-radius:12px;background:#141820eb;border:1px solid rgba(255,255,255,.16);color:#ececece6;font-size:12px;letter-spacing:.02em;text-align:center;opacity:0;transform:translateY(6px);transition:opacity .2s ease,transform .2s ease;pointer-events:none;z-index:3}.composer-banner.is-visible{opacity:1;transform:translateY(0)}.composer textarea{border:none;background:transparent;padding:2px 4px;height:var(--composer-height);min-height:var(--composer-min-height);max-height:var(--composer-max-height);line-height:1.5;font-size:13px;overflow-y:auto;box-sizing:border-box}.composer textarea:focus{outline:none}.send-button{position:absolute;right:12px;bottom:12px;height:28px;width:28px;border-radius:0;border:none;background:transparent;color:#fff;opacity:1;z-index:2;padding:0;display:inline-flex;align-items:center;justify-content:center;transition:color .2s ease,border-color .2s ease}.send-button:hover{color:#fff;border-color:#fff3}.send-button .send-icon{width:28px;height:28px;display:block;pointer-events:none}.chat-activity{display:flex;justify-content:flex-end;align-items:center;gap:10px;position:relative}.activity-button{width:26px;height:26px;border-radius:0;background:transparent;border:none;color:#ffffffb3;display:inline-flex;align-items:center;justify-content:center;padding:0}.activity-button[data-status=ok]{color:#6fe7b6}.activity-button[data-status=warn]{color:#f0b15d}.activity-button[data-status=error]{color:#f87171}.activity-button svg{width:16px;height:16px;stroke:currentColor;stroke-width:1.6;fill:none}.activity-panel{position:absolute;right:0;bottom:calc(100% + 10px);width:260px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:#0c0e12e6;padding:12px;display:flex;flex-direction:column;gap:8px;font-size:10px;color:#ffffffb3;box-shadow:0 12px 24px #00000061;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:30}.activity-panel.hidden{display:none}.activity-header{display:flex;align-items:center;justify-content:space-between;text-transform:uppercase;letter-spacing:.18em;font-size:9px;color:#ffffff80}.activity-status.status-ok{color:#6fe7b6}.activity-status.status-warn{color:#f0b15d}.activity-status.status-error{color:#f87171}.activity-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.activity-row .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;color:#ffffffbf}.activity-copy{background:transparent;color:#fff9;padding:0;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}.activity-copy svg{width:12px;height:12px;stroke:currentColor;stroke-width:1.6;fill:none}.activity-copy[data-copied=true]{color:#6fe7b6}.composer-resize{position:absolute;bottom:8px;width:14px;height:14px;background:transparent;border:none;opacity:0;cursor:se-resize}.resize-se{right:46px}.resize-sw{left:8px;cursor:sw-resize}button{border:none;border-radius:999px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:12px 18px;cursor:pointer}button.primary{background:linear-gradient(120deg,#5078ffb3,#5ac88cb3);color:#0f131a}button.ghost{background:#ffffff14;color:#ffffffbf;border:1px solid rgba(255,255,255,.1)}button:disabled{opacity:.5;cursor:not-allowed}.notice{padding:12px;border-radius:12px;background:#ffffff0d;color:#fff9;font-size:13px}@media (max-width: 900px){#app{padding:20px}.viewer-content{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) minmax(0,1fr)}}
