:root,[data-theme=light]{--bg: #f4f6f8;--surface: #ffffff;--surface-2: #f8fafc;--surface-hover:#eef2f7;--border: #e1e6ed;--border-strong:#cbd2dc;--text: #0f172a;--text-muted: #475569;--text-dim: #94a3b8;--accent: #1e3a8a;--accent-hover: #1e40af;--accent-fg: #ffffff;--success: #15803d;--danger: #b91c1c;--warning: #b45309;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 12px rgba(15, 23, 42, .06)}[data-theme=dark]{--bg: #0b1220;--surface: #111a2d;--surface-2: #0f1729;--surface-hover:#1a2742;--border: #1e2a44;--border-strong:#2a3a5c;--text: #e8edf5;--text-muted: #a3b0c2;--text-dim: #6b7a91;--accent: #60a5fa;--accent-hover: #93c5fd;--accent-fg: #0b1220;--success: #4ade80;--danger: #f87171;--warning: #fbbf24;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 6px 18px rgba(0, 0, 0, .45)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3{font-weight:600;letter-spacing:-.01em;color:var(--text)}h1{font-size:22px;margin:0 0 4px}h2{font-size:16px;margin:0 0 4px}p{margin:4px 0;color:var(--text-muted)}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{font:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border-strong);padding:8px 14px;border-radius:6px;cursor:pointer;transition:background .12s,border-color .12s,color .12s;display:inline-flex;align-items:center;justify-content:center;gap:6px;vertical-align:middle;line-height:1}button>svg{display:block;flex-shrink:0}a>svg{display:block}button:hover:not(:disabled){background:var(--surface-hover);border-color:var(--text-dim)}button:disabled{opacity:.55;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-fg)}button.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}button.ghost{background:transparent;border-color:transparent;color:var(--text-muted);padding:6px 10px}button.ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}input,select,textarea{font:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border-strong);padding:8px 12px;border-radius:6px;width:100%;transition:border-color .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1e3a8a1f}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{box-shadow:0 0 0 3px #60a5fa33}.app{display:grid;grid-template-rows:56px 1fr;height:100vh}.app-body{display:grid;grid-template-columns:232px 1fr;min-height:0}.topbar{display:flex;align-items:center;gap:24px;padding:0 24px;background:var(--surface);border-bottom:1px solid var(--border)}.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px;letter-spacing:-.01em;padding-right:12px;border-right:1px solid var(--border);height:100%;margin-right:-12px}.topbar .brand-logo{width:28px;height:28px;border-radius:6px;background:var(--accent);color:var(--accent-fg);display:grid;place-items:center;font-weight:700;font-size:13px}.topbar .workspaces{display:flex;gap:2px}.topbar .workspaces a{padding:7px 14px;border-radius:6px;color:var(--text-muted);font-weight:500;font-size:13px;transition:background .12s,color .12s}.topbar .workspaces a:hover{background:var(--surface-hover);color:var(--text)}.topbar .workspaces a.active{background:var(--surface-hover);color:var(--text);box-shadow:inset 0 -2px 0 0 var(--accent)}.topbar .spacer{flex:1}.topbar .user-cluster{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:16px 12px;overflow-y:auto}.sidebar nav{display:flex;flex-direction:column;gap:2px}.sidebar a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:6px;color:var(--text-muted);font-size:13px;font-weight:500;transition:background .12s,color .12s}.sidebar a:hover,.sidebar a.active{background:var(--surface-hover);color:var(--text)}.sidebar a.active:before{content:"";width:3px;height:18px;background:var(--accent);border-radius:3px;margin-left:-12px;margin-right:9px}.sidebar .nav-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:currentColor}.content{padding:28px 32px;overflow-y:auto;background:var(--bg)}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px}.page-header .subtitle{color:var(--text-muted);font-size:13px;margin-top:4px}.page-header .actions{display:flex;gap:8px}.crumbs{font-size:12px;color:var(--text-dim);margin-bottom:8px;display:flex;align-items:center;gap:6px}.crumbs a{color:var(--text-muted)}.crumbs a:hover{color:var(--text)}.crumbs .sep{color:var(--text-dim)}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-sm)}.card-body{padding:20px}.card-row{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border)}.card-row:last-child{border-bottom:none}.card-row .label{color:var(--text-muted);font-size:13px}.card-row .value{font-size:13px;font-weight:500}.integration-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.integration-tile{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:18px;display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:border-color .12s,box-shadow .12s,transform .12s;text-decoration:none;color:inherit;box-shadow:var(--shadow-sm)}.integration-tile:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);color:inherit;transform:translateY(-1px)}.integration-tile .tile-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.integration-tile .tile-title{display:flex;align-items:center;gap:12px;font-weight:600;font-size:14px}.brand-mark{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;line-height:0}.brand-mark svg{display:block}.brand-mark.large svg{width:36px;height:36px}.brand-mark.small svg{width:16px;height:16px}.integration-tile .tile-meta{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-muted)}.integration-tile .tile-foot{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted)}.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border:1px solid transparent}.pill:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.pill.active{color:var(--success);background:#15803d1a;border-color:#15803d40}.pill.inactive{color:var(--text-muted);background:var(--surface-2);border-color:var(--border)}.pill.error{color:var(--danger);background:#b91c1c1a;border-color:#b91c1c40}[data-theme=dark] .pill.active{background:#4ade801a;border-color:#4ade8040}[data-theme=dark] .pill.error{background:#f871711a;border-color:#f8717140}.switch{position:relative;display:inline-block;width:38px;height:22px;flex-shrink:0}.switch input{display:none}.switch .slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border-strong);border-radius:22px;transition:background .16s}.switch .slider:before{content:"";position:absolute;left:2px;top:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .16s;box-shadow:0 1px 2px #0003}.switch input:checked+.slider{background:var(--accent)}.switch input:checked+.slider:before{transform:translate(16px)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--text-muted);text-align:center}.empty-state h2{margin:0 0 6px;color:var(--text)}.empty-state p{color:var(--text-muted);max-width:360px}.data-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.data-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}.data-table td{padding:14px 16px;border-bottom:1px solid var(--border);font-size:13px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--surface-hover)}.login-page{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:36px;width:380px;box-shadow:var(--shadow-md)}.login-card .login-brand{display:flex;align-items:center;gap:10px;margin-bottom:28px}.login-card .login-brand .brand-logo{width:32px;height:32px;border-radius:7px;background:var(--accent);color:var(--accent-fg);display:grid;place-items:center;font-weight:700;font-size:14px}.login-card h1{font-size:20px;margin:0}.login-card .field{margin-bottom:16px}.login-card label{display:block;margin-bottom:6px;color:var(--text-muted);font-size:12px;font-weight:500}.login-card .error{padding:10px 12px;background:#b91c1c14;color:var(--danger);border:1px solid rgba(185,28,28,.2);border-radius:6px;font-size:13px;margin-bottom:16px}.login-card .switch-mode{margin-top:18px;font-size:13px;color:var(--text-muted);text-align:center}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-dim)}.divider{height:1px;background:var(--border);margin:16px 0}.row-gap{display:flex;gap:8px;align-items:center}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;background:transparent;border:1px solid var(--border);cursor:pointer;color:var(--text-muted);padding:0;transition:background .12s,color .12s}.theme-toggle:hover{background:var(--surface-hover);color:var(--text);border-color:var(--border-strong)}.theme-toggle svg{width:16px;height:16px}.notice{display:flex;gap:12px;padding:12px 16px;border-radius:8px;font-size:13px;border:1px solid;margin-bottom:20px;line-height:1.5}.notice.info{background:#1e3a8a0d;border-color:#1e3a8a33;color:var(--text)}[data-theme=dark] .notice.info{background:#60a5fa14;border-color:#60a5fa33}.notice.warning{background:#b453090f;border-color:#b4530940;color:var(--text)}[data-theme=dark] .notice.warning{background:#fbbf2414;border-color:#fbbf2440}.notice strong{color:var(--text)}.stepper{display:flex;flex-direction:column;max-width:720px}.step{position:relative;padding:0 0 24px 48px}.step:last-child{padding-bottom:0}.step:not(:last-child):after{content:"";position:absolute;left:19px;top:32px;bottom:0;width:2px;background:var(--border)}.step.done:not(:last-child):after{background:var(--success);opacity:.4}.step-indicator{position:absolute;left:4px;top:0;width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:600;background:var(--surface);border:2px solid var(--border-strong);color:var(--text-muted);z-index:1;transition:background .15s,border-color .15s,color .15s}.step.active .step-indicator{background:var(--accent);border-color:var(--accent);color:var(--accent-fg);box-shadow:0 0 0 4px #1e3a8a1f}[data-theme=dark] .step.active .step-indicator{box-shadow:0 0 0 4px #60a5fa2e}.step.done .step-indicator{background:var(--success);border-color:var(--success);color:#fff}.step-header{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:32px;padding-right:4px}.step-header.clickable{cursor:pointer}.step-header.clickable:hover .step-title{color:var(--accent)}.step-title{font-weight:600;font-size:14px;color:var(--text);transition:color .12s}.step.pending .step-title{color:var(--text-dim)}.step-summary{margin-top:4px;font-size:12px;color:var(--text-muted)}.step-body{margin-top:14px;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-sm)}.step.pending .step-body,.step.collapsed .step-body{display:none}.step-body p{color:var(--text)}.step-body p.muted{color:var(--text-muted)}.steps-list{margin:8px 0 0;padding-left:20px;color:var(--text)}.steps-list li{margin:4px 0;font-size:13px}.steps-list code{background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:12px}.form-grid{display:grid;gap:14px;margin-bottom:16px}.form-field label{display:block;font-size:12px;font-weight:500;color:var(--text-muted);margin-bottom:6px}.form-field .hint{font-size:11px;color:var(--text-dim);margin-top:4px}.form-actions{display:flex;gap:8px;align-items:center;margin-top:4px}.form-actions .spacer{flex:1}.step-detail-list{display:grid;gap:8px;margin:8px 0 16px}.step-detail-list .detail-row{display:flex;justify-content:space-between;font-size:13px;padding:6px 0;border-bottom:1px dashed var(--border)}.step-detail-list .detail-row:last-child{border-bottom:none}.step-detail-list .detail-label{color:var(--text-muted)}.step-detail-list .detail-value{color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.code-input input{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:18px;letter-spacing:6px;text-align:center;max-width:200px}.content.no-pad{padding:0;overflow:hidden}.inbox-layout{display:grid;grid-template-columns:340px minmax(0,1fr);height:100%;min-height:0;background:var(--bg)}.chat-list-pane{border-right:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;min-height:0}.chat-list-header{padding:14px 16px 0;border-bottom:1px solid var(--border)}.chat-list-header h2{font-size:17px;font-weight:600;margin:0 0 12px}.tabs{display:flex;gap:2px}.tabs .tab{flex:1;background:transparent;border:none;border-bottom:2px solid transparent;padding:10px 12px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;text-align:center;transition:color .12s,border-color .12s}.tabs .tab:hover{color:var(--text)}.tabs .tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tabs .tab .count{display:inline-block;margin-left:6px;font-size:11px;background:var(--surface-hover);color:var(--text-muted);padding:1px 6px;border-radius:999px}.tabs .tab.active .count{background:var(--accent);color:var(--accent-fg)}.chat-list{overflow-y:auto;flex:1;min-height:0}.chat-list-empty{padding:40px 24px;text-align:center;color:var(--text-muted);font-size:13px}.chat-row{display:grid;grid-template-columns:40px 1fr auto;grid-template-rows:auto auto;gap:2px 12px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;align-items:center}.chat-row:hover{background:var(--surface-hover)}.chat-row.selected{background:var(--surface-hover);box-shadow:inset 3px 0 0 0 var(--accent)}.chat-row .source-icon{grid-row:1 / span 2}.source-icon{width:40px;height:40px;border-radius:50%;background:var(--surface-hover);display:inline-grid;place-items:center;position:relative;flex-shrink:0;line-height:1}.source-icon .avatar-initial{font-weight:600;font-size:14px;color:var(--text-muted);line-height:1;transform:translateY(-.5px)}.source-icon .brand-badge{position:absolute;bottom:-2px;right:-2px;width:18px;height:18px;border-radius:50%;background:var(--surface);border:2px solid var(--surface);display:inline-grid;place-items:center;overflow:hidden;line-height:0}.source-icon .brand-badge svg{display:block}.source-icon .avatar-image{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}.chat-row .name{font-weight:600;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-row .time{font-size:11px;color:var(--text-dim);text-align:right;white-space:nowrap}.chat-row .preview{grid-column:2 / span 2;font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-row .preview .out-prefix{color:var(--text-dim)}.chat-row .badge-unread{grid-column:3;grid-row:2;background:var(--accent);color:var(--accent-fg);border-radius:999px;padding:1px 7px;font-size:11px;font-weight:600;justify-self:end}.chat-row.awaiting{box-shadow:inset 3px 0 0 0 var(--warning)}.chat-row.awaiting.selected{box-shadow:inset 3px 0 0 0 var(--accent)}.chat-row.closed .name,.chat-row.closed .preview{color:var(--text-dim)}.chat-row.closed .source-icon{opacity:.7}.chat-row .awaiting-pill{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:var(--warning);color:#fff;font-size:10px;font-weight:700;margin-left:6px;vertical-align:middle}.chat-pane{display:flex;flex-direction:column;min-height:0;min-width:0;background:var(--bg)}.chat-header{padding:14px 20px;border-bottom:1px solid var(--border);background:var(--surface);display:flex;align-items:center;gap:12px}.chat-header .chat-title{font-weight:600;font-size:15px}.chat-header .chat-subtitle{font-size:12px;color:var(--text-muted)}.chat-header .spacer{flex:1}.messages{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:4px;min-height:0}.message-group{display:flex;align-items:center;gap:4px;margin-bottom:8px}.message-group.inbound{justify-content:flex-start}.message-group.outbound{justify-content:flex-end;flex-direction:row-reverse}@keyframes msg-slide-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes msg-flash{0%{box-shadow:0 0 #1e3a8a00,var(--shadow-sm)}30%{box-shadow:0 0 0 4px #1e3a8a2e,var(--shadow-sm)}to{box-shadow:0 0 #1e3a8a00,var(--shadow-sm)}}.message-group.is-new .bubble{animation:msg-slide-in .22s ease-out,msg-flash 1.5s ease-out .2s}.bubble{max-width:70%;padding:9px 13px;border-radius:14px;font-size:14px;line-height:1.4;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:anywhere;word-break:break-word;min-width:0;box-shadow:var(--shadow-sm)}.bubble-text{white-space:pre-wrap}.bubble .media-image-btn,.bubble .media-video-btn{display:block;margin:-4px -6px 6px;padding:0;background:transparent;border:none;cursor:pointer;position:relative;border-radius:8px;overflow:hidden}.bubble .media-image{display:block;width:100%;max-width:360px;max-height:300px;object-fit:cover}.bubble .media-video{display:block;width:100%;max-width:360px;border-radius:8px}.bubble .media-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#00000040;color:#fff;pointer-events:none;transition:background .15s}.bubble .media-video-btn:hover .media-play-overlay{background:#0006}.bubble .media-audio{display:block;width:100%;max-width:280px;margin-bottom:6px}.voice-player{display:flex;align-items:center;gap:10px;padding:6px 4px;min-width:240px;max-width:320px;margin:-2px 0 6px}.voice-play{flex-shrink:0;width:36px;height:36px;border-radius:50%;border:none;background:var(--accent);color:var(--accent-fg);display:grid;place-items:center;cursor:pointer;transition:background .12s}.voice-play:hover{background:var(--accent-hover)}.message-group.outbound .voice-play{background:#ffffffeb;color:var(--accent)}.message-group.outbound .voice-play:hover{background:#fff}.voice-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.voice-track{position:relative;height:4px;background:#0000001f;border-radius:2px;cursor:pointer}.message-group.outbound .voice-track{background:#ffffff40}.voice-progress{height:100%;background:var(--accent);border-radius:2px}.message-group.outbound .voice-progress{background:#fffffff2}.voice-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%;background:var(--accent);pointer-events:none}.message-group.outbound .voice-thumb{background:#fff}.voice-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted)}.message-group.outbound .voice-meta{color:#ffffffd9}.voice-time{flex:1;font-family:ui-monospace,monospace}.voice-speed{background:transparent;border:1px solid currentColor;color:inherit;padding:1px 6px;border-radius:999px;font-size:10px;font-weight:600;cursor:pointer;min-width:32px;opacity:.6}.voice-speed.active,.voice-speed:hover{opacity:1}.voice-dl{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;color:inherit;text-decoration:none;opacity:.7}.voice-dl:hover{opacity:1;background:#00000014}.message-group.outbound .voice-dl:hover{background:#ffffff2e}.bubble .media-file{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;background:#0000000f;border:none;border-radius:8px;margin-bottom:6px;cursor:pointer;color:inherit;max-width:100%;text-align:left}.bubble .media-file:hover{background:#0000001a}.message-group.outbound .bubble .media-file{background:#ffffff26;color:inherit}.message-group.outbound .bubble .media-file:hover{background:#ffffff40}.bubble .media-file-info{display:flex;flex-direction:column;min-width:0;flex:1}.bubble .media-file-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.bubble .media-file-size{font-size:11px;opacity:.7;margin-top:2px}.bubble .media-loading,.bubble .media-error{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;font-size:12px;background:#0000000f;border-radius:8px;margin-bottom:6px;color:var(--text-muted)}.message-group.outbound .bubble .media-loading,.message-group.outbound .bubble .media-error{background:#ffffff26;color:#ffffffd9}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:1000;display:grid;place-items:center;padding:16px;animation:media-fade-in .15s ease-out}.modal{background:var(--surface);border-radius:10px;box-shadow:var(--shadow-md);width:min(440px,100%);max-height:85vh;display:flex;flex-direction:column;min-height:0}.modal-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-body{padding:8px 6px;overflow-y:auto;min-height:0}.participants-list{list-style:none;margin:0;padding:0}.participants-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px}.participants-row:hover{background:var(--surface-hover)}.role-pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;border:1px solid;background:var(--surface)}.media-viewer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:1000;display:grid;grid-template-rows:48px 1fr;animation:media-fade-in .15s ease-out}@keyframes media-fade-in{0%{opacity:0}to{opacity:1}}.media-viewer-toolbar{display:flex;align-items:center;gap:12px;padding:0 16px;background:#00000073;color:#fff;font-size:13px}.media-viewer-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#ffffffe6}.media-viewer-btn{background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff;width:32px;height:32px;border-radius:6px;display:grid;place-items:center;cursor:pointer;text-decoration:none}.media-viewer-btn:hover{background:#ffffff1f;border-color:#ffffff59}.media-viewer-body{min-height:0;min-width:0;display:grid;place-items:center;padding:16px;overflow:hidden}.media-viewer-image{max-width:100%;max-height:100%;object-fit:contain;cursor:zoom-out}.media-viewer-video{max-width:100%;max-height:100%;outline:none}.media-viewer-audio{width:min(420px,90vw)}.media-viewer-pdf{width:100%;height:100%;border:0;background:#525659}.media-viewer-text{width:100%;height:100%;margin:0;padding:18px 22px;background:#1e1e1e;color:#d4d4d4;font-family:ui-monospace,monospace;font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word;overflow:auto;border-radius:4px;box-sizing:border-box}.media-viewer-file{background:var(--surface);color:var(--text);border-radius:12px;padding:32px 28px;display:flex;flex-direction:column;align-items:center;gap:12px;max-width:420px;text-align:center}.media-viewer-file-icon{font-size:48px}.media-viewer-file-name{font-weight:600;font-size:15px;word-break:break-all}.media-viewer-file-note{font-size:13px;color:var(--text-muted)}.media-viewer-download{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;background:var(--accent);color:var(--accent-fg);text-decoration:none;font-weight:500;margin-top:6px}.media-viewer-download:hover{background:var(--accent-hover);color:var(--accent-fg)}.message-group.inbound .bubble{background:var(--surface);color:var(--text);border-bottom-left-radius:4px}.message-group.outbound .bubble{background:var(--accent);color:var(--accent-fg);border-bottom-right-radius:4px}.bubble .meta{font-size:10px;margin-top:4px;opacity:.7}.day-divider{align-self:center;font-size:11px;color:var(--text-dim);padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:999px;margin:12px 0}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);text-align:center;padding:40px}.chat-empty svg{color:var(--text-dim);margin-bottom:12px}.reply-box{border-top:1px solid var(--border);background:var(--surface);padding:12px 20px;display:flex;gap:12px;align-items:flex-end}.mail-subject-row{border-top:1px solid var(--border);background:var(--surface);padding:8px 20px 0;display:flex;gap:10px;align-items:center}.mail-subject-row+.reply-box{border-top:none;padding-top:8px}.mail-subject-row label{font-size:12px;color:var(--text-muted);font-weight:600}.mail-subject-row input{flex:1;font-size:14px;padding:6px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--text)}.mail-subject-row input:focus{outline:none;border-color:var(--accent)}.reply-box textarea{flex:1;resize:none;min-height:40px;max-height:160px;font-size:14px;border:1px solid var(--border-strong);border-radius:18px;padding:10px 16px;background:var(--bg);color:var(--text)}.reply-box textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1e3a8a1f}[data-theme=dark] .reply-box textarea:focus{box-shadow:0 0 0 3px #60a5fa33}.reply-send{width:40px;height:40px;border-radius:50%;background:var(--accent);border:none;color:var(--accent-fg);display:grid;place-items:center;cursor:pointer;flex-shrink:0}.reply-send:disabled{opacity:.5;cursor:not-allowed}.reply-send:not(:disabled):hover{background:var(--accent-hover)}.message-group .msg-actions{display:none;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm);padding:2px;flex-shrink:0}.message-group:hover .msg-actions{display:flex}.msg-actions button{background:transparent;border:none;padding:4px 6px;cursor:pointer;color:var(--text-muted);border-radius:4px;display:grid;place-items:center}.msg-actions button:hover{background:var(--surface-hover);color:var(--text)}.bubble .quote{border-left:3px solid currentColor;padding:4px 8px;margin-bottom:6px;opacity:.75;font-size:12px;border-radius:0 4px 4px 0;background:#ffffff14}.message-group.inbound .bubble .quote{background:var(--surface-hover);border-left-color:var(--accent)}.reply-draft{display:flex;align-items:center;gap:12px;padding:8px 20px 0;margin:0;font-size:13px;color:var(--text-muted)}.reply-draft .quote{flex:1;border-left:3px solid var(--accent);padding:4px 10px;background:var(--surface-hover);border-radius:0 4px 4px 0;min-width:0;overflow:hidden}.reply-draft .quote .qname{font-weight:600;color:var(--text);font-size:12px}.reply-draft .quote .qtext{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-draft .cancel{background:transparent;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:4px}.reply-draft .cancel:hover{color:var(--danger);background:var(--surface-hover)}.qr-picker-wrap{position:relative}.qr-button{width:40px;height:40px;border-radius:50%;background:var(--surface);border:1px solid var(--border-strong);cursor:pointer;display:grid;place-items:center;color:var(--text-muted);flex-shrink:0}.qr-button:hover{background:var(--surface-hover);color:var(--text)}.qr-popover{position:absolute;bottom:calc(100% + 8px);left:0;width:320px;max-height:320px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-md);padding:6px;z-index:30}.qr-popover .qr-empty{padding:18px 12px;text-align:center;color:var(--text-muted);font-size:13px}.qr-popover .qr-item{display:flex;flex-direction:column;gap:2px;padding:8px 10px;border-radius:6px;cursor:pointer;text-align:left;background:transparent;border:none;width:100%;color:var(--text)}.qr-popover .qr-item:hover{background:var(--surface-hover)}.qr-popover .qr-item .qr-label{font-weight:600;font-size:13px}.qr-popover .qr-item .qr-content{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qr-popover .qr-foot{margin-top:4px;border-top:1px solid var(--border);padding-top:6px}.qr-popover .qr-foot a{display:block;padding:8px 10px;font-size:12px;color:var(--text-muted)}.qr-popover .qr-foot a:hover{background:var(--surface-hover);color:var(--text);border-radius:6px}.compose-card{margin:12px;padding:14px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px}.compose-card h3{margin:0 0 10px;font-size:13px;font-weight:600}.compose-card .form-grid{gap:10px;margin-bottom:10px}.compose-card input,.compose-card textarea{font-size:13px}.qr-list{display:flex;flex-direction:column;gap:10px;max-width:760px}.qr-list .qr-row{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 14px;display:grid;grid-template-columns:1fr 2fr auto;gap:12px;align-items:center}.qr-list .qr-row .qr-label-text{font-weight:600;font-size:13px}.qr-list .qr-row .qr-content-text{font-size:13px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qr-att-badge{display:inline-block;margin-left:8px;font-size:10px;font-weight:600;padding:1px 6px;border-radius:999px;background:var(--surface-2);color:var(--text-muted)}.qr-list .qr-row .qr-attachments{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding-top:10px;border-top:1px dashed var(--border);font-size:12px}.qr-att{display:inline-flex;align-items:center;gap:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:2px 6px 2px 8px}.qr-att-x{background:transparent;border:none;padding:2px;cursor:pointer;color:var(--text-muted);display:grid;place-items:center}.qr-att-x:hover,.text-danger{color:var(--danger)}.inbox-layout.with-contact{grid-template-columns:340px minmax(0,1fr) 320px}.inbox-layout.with-contact .contact-pane{display:flex}.contact-pane{display:none;flex-direction:column;background:var(--surface);border-left:1px solid var(--border);min-height:0;overflow-y:auto}.contact-pane.standalone{display:flex}.contact-header{padding:18px 16px 12px;text-align:center;border-bottom:1px solid var(--border)}.contact-header .source-icon{width:64px;height:64px;margin:0 auto 10px}.contact-header .source-icon .avatar-initial{font-size:22px}.contact-header .source-icon .brand-badge{width:22px;height:22px;bottom:0;right:0}.contact-header .source-icon .brand-badge svg{width:16px;height:16px}.contact-header h3{font-size:16px;font-weight:600;margin:0 0 2px}.contact-header .handle{font-size:12px;color:var(--text-muted)}.contact-section{padding:14px 16px;border-bottom:1px solid var(--border)}.contact-section:last-child{border-bottom:none}.contact-section h4{margin:0 0 8px;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.contact-section .kv{display:grid;grid-template-columns:80px 1fr;gap:4px 12px;font-size:13px;align-items:baseline}.contact-section .kv dt{color:var(--text-muted)}.contact-section .kv dd{margin:0;color:var(--text);word-break:break-word}.contact-section .editable-field{display:block;border:1px solid transparent;background:transparent;border-radius:6px;padding:6px 8px;margin-left:-8px;font:inherit;color:var(--text);width:calc(100% + 8px);cursor:text}.contact-section .editable-field:hover{background:var(--surface-hover)}.contact-section .editable-field:focus{outline:none;border-color:var(--accent);background:var(--bg)}.contact-section textarea.editable-field{resize:vertical;min-height:60px;font-size:13px}.tag-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--surface-hover);border:1px solid var(--border);border-radius:999px;font-size:11px;color:var(--text)}.tag-chip .x{background:transparent;border:none;cursor:pointer;color:var(--text-muted);padding:0;line-height:0;display:inline-grid;place-items:center}.tag-chip .x:hover{color:var(--danger)}.tag-input{font-size:12px;padding:4px 8px}.chat-link-row{display:grid;grid-template-columns:28px 1fr auto;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);cursor:pointer;text-decoration:none;color:inherit}.chat-link-row:hover{background:var(--surface-hover);margin:0 -16px;padding:8px 16px;border-radius:6px}.chat-link-row:last-child{border-bottom:none}.chat-link-row .source-icon{width:28px;height:28px}.chat-link-row .source-icon .avatar-initial{font-size:11px}.chat-link-row .source-icon .brand-badge{width:13px;height:13px;bottom:-2px;right:-2px}.chat-link-row .source-icon .brand-badge svg{width:9px;height:9px}.chat-link-row .name{font-size:13px;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-link-row .time{font-size:11px;color:var(--text-dim)}.clients-layout{display:grid;grid-template-columns:1fr;height:100%;min-height:0;background:var(--bg)}.clients-layout.with-detail{grid-template-columns:1fr 360px}.clients-main{display:flex;flex-direction:column;min-height:0;overflow:hidden}.clients-toolbar{padding:18px 24px 14px;background:var(--surface);border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}.clients-toolbar h1{margin:0;font-size:20px}.clients-toolbar .meta{color:var(--text-muted);font-size:12px;margin-top:2px}.search-box{position:relative;width:320px}.search-box svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-dim)}.search-box input{padding-left:32px;font-size:13px}.clients-table-wrap{flex:1;overflow:auto;padding:8px 24px 24px}.clients-table{width:100%;border-collapse:collapse;min-width:1100px;table-layout:fixed}.clients-table .channel-head{display:inline-flex;align-items:center;gap:6px}.clients-table .channel-head svg{display:block}.ellipsis-cell{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px;color:var(--text);min-width:0}.clients-table tr:not(.editing):hover{background:var(--surface-hover);cursor:default}.clients-table tr.editing{background:var(--surface-2);box-shadow:inset 3px 0 0 0 var(--accent)}.cell-input{width:100%;padding:4px 8px;font-size:13px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text)}.cell-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #1e3a8a1f}.claim-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;font-size:11px;background:var(--surface-2);border:1px solid var(--border-strong);border-radius:999px;color:var(--accent);cursor:pointer;white-space:nowrap}.claim-btn:hover:not(:disabled){background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.manager-me{font-weight:600;color:var(--success)}.managers-table{width:100%;border-collapse:collapse;table-layout:fixed}.managers-table thead th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:14px 16px;background:var(--surface-2);border-bottom:1px solid var(--border)}.managers-table tbody td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}.managers-table tbody tr{cursor:pointer;transition:background .08s}.managers-table tbody tr:hover{background:var(--surface-hover)}.managers-table tbody tr.expanded{background:var(--surface-hover);box-shadow:inset 3px 0 0 0 var(--accent)}.managers-table tbody tr.expanded td{border-bottom:none}.managers-table .num-cell{font-size:18px;font-weight:600;color:var(--text);text-align:center}.manager-expanded-row td{background:var(--surface-2);border-bottom:1px solid var(--border)}.manager-expanded{padding:8px 8px 12px}.manager-clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:6px}.manager-clients-preview{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.client-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.presence-toggle{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border-strong);background:var(--surface);transition:background .12s,border-color .12s}.presence-toggle.on{background:#15803d1a;border-color:#15803d4d;color:var(--success)}.presence-toggle.off{background:var(--surface-2);color:var(--text-muted)}.presence-toggle:hover:not(:disabled){border-color:var(--text-dim)}.presence-toggle .dot,.presence-pill .dot{width:8px;height:8px;border-radius:50%;display:inline-block}.presence-toggle .dot.on,.presence-pill .dot.on{background:var(--success)}.presence-toggle .dot.off,.presence-pill .dot.off{background:var(--text-dim)}.presence-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.presence-pill.on{color:var(--success)}.distribution-card .distribution-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:4px}.dist-field{display:flex;flex-direction:column;gap:4px;font-size:13px}.dist-field>span{color:var(--text-muted);font-size:12px}.dist-field input,.dist-field select{font-size:13px}.dist-field small{font-size:11px;margin-top:2px}.dist-toggle{grid-column:1 / -1;display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;padding:8px;border-top:1px dashed var(--border)}.dist-toggle input{width:auto}.managers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.manager-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-sm)}.manager-card.online{border-color:#15803d4d}.manager-head{display:flex;align-items:center;gap:12px}.manager-head .source-icon{position:relative}.presence-dot{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;border-radius:50%;border:2px solid var(--surface)}.presence-dot.on{background:var(--success)}.presence-dot.off{background:var(--text-dim)}.manager-name{font-weight:600;font-size:14px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manager-email{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manager-status{font-size:11px;margin-top:2px}.text-success{color:var(--success);font-weight:500}.text-warning{color:var(--warning);font-weight:500}.manager-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.manager-stats .stat{text-align:center}.manager-stats .stat-num{font-size:22px;font-weight:600;color:var(--text)}.manager-stats .stat-label{font-size:11px;color:var(--text-muted);margin-top:2px}.manager-clients-head{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:5px;margin-bottom:6px}.manager-client-row{display:flex;align-items:center;gap:8px;padding:6px 4px;border-radius:4px}.manager-client-row:hover{background:var(--surface-hover)}.manager-client-channels{display:flex;gap:3px;flex-shrink:0}.manager-client-channels svg{display:block}.open-chats-pill{display:inline-flex;align-items:center;gap:2px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:1px 6px;font-size:10px;color:var(--accent);font-weight:600}.clients-table th{position:sticky;top:0;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:12px 14px;background:var(--bg);border-bottom:1px solid var(--border)}.clients-table td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}.clients-table tr{cursor:pointer;transition:background .08s}.clients-table tbody tr:hover{background:var(--surface-hover)}.clients-table tbody tr.selected{background:var(--surface-hover);box-shadow:inset 3px 0 0 0 var(--accent)}.clients-table .name-cell{display:flex;align-items:center;gap:10px}.clients-table .name-cell .name-text{font-weight:500;color:var(--text)}.clients-table .channels{display:flex;gap:4px}.clients-table .channels svg{display:block}.clients-table .unread-pill{background:var(--accent);color:var(--accent-fg);border-radius:999px;padding:1px 7px;font-size:11px;font-weight:600}.form-row{display:block;font-size:13px}.form-row>span{display:block;margin-bottom:4px;color:var(--text-muted);font-size:12px}.form-row>input{display:block;width:100%;font-size:13px}.banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-radius:6px;margin-bottom:16px;font-size:13px;border:1px solid transparent}.banner.success{color:var(--success);background:#15803d14;border-color:#15803d38}.banner.danger{color:var(--danger);background:#b91c1c14;border-color:#b91c1c38}.banner code{font-family:ui-monospace,monospace;font-size:12px}.merge-picker .search-box svg{left:10px}.merge-picker .search-box input{padding-left:32px;font-size:13px}.merge-results{display:flex;flex-direction:column;gap:2px;max-height:260px;overflow-y:auto;margin-top:8px;border:1px solid var(--border);border-radius:6px;padding:4px;background:var(--surface-2)}.merge-result{display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:none;border-radius:4px;cursor:pointer;text-align:left;width:100%}.merge-result:hover{background:var(--surface-hover)}.merge-confirm p{color:var(--text)}.funnel-layout{display:grid;grid-template-columns:1fr;height:100%;min-height:0;background:var(--bg)}.funnel-layout.with-detail{grid-template-columns:1fr 360px}.funnel-main{display:flex;flex-direction:column;min-height:0;overflow:hidden}.funnel-toolbar{padding:18px 24px 14px;background:var(--surface);border-bottom:1px solid var(--border)}.funnel-toolbar h1{margin:0;font-size:20px}.funnel-toolbar .meta{color:var(--text-muted);font-size:12px;margin-top:2px}.funnel-board{flex:1;min-height:0;display:flex;gap:12px;padding:16px 24px 24px;overflow-x:auto;overflow-y:hidden;align-items:stretch}.funnel-column{flex:0 0 280px;background:var(--surface);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;min-height:0;box-shadow:var(--shadow-sm)}.funnel-column-header{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;justify-content:space-between}.funnel-column-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13px;color:var(--text)}.funnel-color-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--text-dim)}.funnel-column-count{background:var(--surface-hover);color:var(--text-muted);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600}.funnel-column-cards{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px}.funnel-empty-col{color:var(--text-dim);font-size:12px;text-align:center;padding:20px 8px}.funnel-card{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:10px;cursor:pointer;transition:background .08s,border-color .08s}.funnel-card:hover{background:var(--surface-hover);border-color:var(--border-strong)}.funnel-card.selected{border-color:var(--accent);box-shadow:inset 3px 0 0 0 var(--accent)}.funnel-card-head{display:flex;align-items:center;gap:8px}.funnel-card-name{font-size:13px;font-weight:500;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.funnel-card-head .unread-pill{background:var(--accent);color:var(--accent-fg);border-radius:999px;padding:1px 7px;font-size:11px;font-weight:600}.funnel-card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.funnel-card-foot .channels{display:flex;gap:4px}.funnel-card-foot .channels svg{display:block}
