:root{
  --bg:#f3f5f9;
  --surface:#fff;
  --surface-2:#f8fafc;
  --text:#101a2d;
  --muted:#60708c;
  --border:#dde4ee;
  --blue:#2168f3;
  --blue-2:#eaf2ff;
  --red:#ef1717;
  --green:#20b955;
  --purple:#7653e8;
  --orange:#f47b20;
  --shadow:0 10px 28px rgba(20,31,52,.07);
  --radius:14px;
  --nav:280px;
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html,body{margin:0;min-height:100%;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--text);background:var(--bg);font-size:16px;overflow-x:hidden}
body::before{content:"";position:fixed;left:0;right:0;top:0;height:7px;background:var(--red);z-index:10}
button,input,select,textarea{font:inherit}
a{color:inherit;text-decoration:none}
.i{width:22px;height:22px;flex:0 0 22px}
.muted{color:var(--muted);line-height:1.55}
.app-frame{min-height:100vh;padding:22px 24px 28px}
.app-header{min-height:58px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:22px;padding:0 18px;margin-bottom:18px;min-width:0}
.brand-header{display:flex;align-items:center;gap:14px;min-width:0;color:#171923;font-weight:900;overflow:hidden}
.brand-header img{width:38px;height:30px;flex:0 0 auto}
.brand-header span{font-size:21px;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-user{display:flex;align-items:center;gap:12px;font-weight:850;text-align:right;margin-left:auto;flex:0 1 auto;min-width:0}
.user-link{max-width:360px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid var(--border);background:#fff;border-radius:10px;padding:10px 14px}
.app-shell{display:grid;grid-template-columns:var(--nav) minmax(0,1fr);gap:22px;align-items:start}
.sidebar{position:sticky;top:18px;display:flex;flex-direction:column;gap:14px;max-height:calc(100vh - 36px);min-width:0}
.sidebar nav{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:14px;display:flex;flex-direction:column;gap:6px;overflow:auto}
.global-search{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:12px}
.global-search-box{display:grid;grid-template-columns:24px minmax(0,1fr);align-items:center;gap:8px;border:1px solid var(--border);border-radius:12px;background:#fff;padding:0 10px}
.global-search input{height:44px;border:0;outline:none;background:transparent;color:var(--text);font-weight:750;min-width:0}
.global-search-results{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:30;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 18px 42px rgba(20,31,52,.16);padding:8px;display:grid;gap:4px}
.global-search-results[hidden]{display:none}
.search-suggestion{display:grid;gap:3px;border-radius:10px;padding:10px;color:var(--text)}
.search-suggestion:hover,.search-suggestion.active{background:var(--blue-2)}
.search-suggestion b{font-size:15px}
.search-suggestion span{font-size:13px;color:var(--muted);line-height:1.35}
.nav-item{height:48px;border-radius:12px;display:flex;align-items:center;gap:12px;padding:0 12px;color:#18305f;font-weight:750}
.nav-item:hover,.nav-item.active{background:var(--blue-2);color:#0c57e8}
.nav-item.active{box-shadow:inset 3px 0 0 var(--blue)}
.main{min-width:0;display:flex;flex-direction:column;gap:18px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;min-height:58px}
.page-head h1{margin:0;font-size:34px;line-height:1.08}
.page-head p{margin:6px 0 0;color:var(--muted)}
.ghost{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:10px;padding:10px 14px;cursor:pointer;font-weight:850;display:inline-flex;align-items:center;justify-content:center;gap:7px}
.ghost.compact{padding:8px 10px;font-size:13px}
.ghost.danger{color:#b51f2f;border-color:#f2c6cc}
.primary{border:0;background:var(--blue);color:#fff;border-radius:10px;padding:11px 16px;cursor:pointer;font-weight:850;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.primary:hover{background:#0b57df}
.full{width:100%}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:20px;min-width:0}
.panel h2{font-size:22px;margin:0 0 12px}
.panel-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
.panel-title-row h2,.panel-title-row p{margin:0}
.channels-hero{display:flex;align-items:center;justify-content:space-between;gap:16px}
.channel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.channel-card{display:grid;gap:14px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:18px}
.channel-card.disabled{opacity:.7}
.channel-card-head,.channel-title-row,.channel-status-line,.channel-actions,.screen-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px}
.channel-card-head{justify-content:flex-start;align-items:flex-start}
.channel-card h2,.channel-card p{margin:0}
.channel-logo{width:36px;height:36px;object-fit:contain;flex:0 0 auto}
.channel-logo.large{width:58px;height:58px}
.channel-state{display:inline-flex;border:1px solid #bfd6ff;background:var(--blue-2);color:#0c57e8;border-radius:999px;padding:6px 9px;font-weight:900}
.channel-kind{color:var(--muted);font-size:13px;font-weight:850}
.channel-session{display:grid;grid-template-columns:minmax(300px,.7fr) minmax(0,1.3fr);gap:18px;align-items:start}
.channel-control{display:grid;gap:12px}
.control-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.remote-type-form{display:grid;gap:8px}
.remote-type-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}
.remote-keys{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px}
.remote-keys button{border:1px solid var(--border);background:#fff;border-radius:10px;padding:9px;font-size:13px;font-weight:850;cursor:pointer}
.channel-screen-panel{display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px}
.remote-screen-wrap{min-height:560px;border:1px solid var(--border);border-radius:12px;background:#101a2d;display:grid;place-items:start center;overflow:auto}
.remote-screen-wrap img{display:block;max-width:100%;height:auto}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:20px;min-height:154px;position:relative;overflow:hidden}
.kpi span{display:block;color:var(--muted);font-weight:800;margin-bottom:12px}
.kpi strong{font-size:44px;line-height:1}
.kpi.green strong{color:var(--green)}
.kpi.blue strong{color:var(--blue)}
.kpi.purple strong{color:var(--purple)}
.kpi.red strong{color:var(--red)}
.spark{position:absolute;left:18px;right:18px;bottom:18px;height:28px;background:linear-gradient(120deg,transparent 0 13%,currentColor 14% 16%,transparent 17% 31%,currentColor 32% 34%,transparent 35% 49%,currentColor 50% 52%,transparent 53% 67%,currentColor 68% 70%,transparent 71%);opacity:.45}
.dashboard-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(300px,.78fr);gap:18px}
.wide{min-width:0}
.flow{display:grid;grid-template-columns:minmax(0,1fr) 190px minmax(0,1fr);gap:18px;align-items:center;margin-top:22px}
.source-card,.mini-msg{border:1px solid var(--border);background:var(--surface-2);border-radius:12px;padding:14px;margin-bottom:12px;min-height:82px}
.source-card b,.mini-msg b{display:block;margin-bottom:8px}
.source-card p,.mini-msg span{display:block;margin:0;color:var(--muted);font-size:14px;line-height:1.4}
.source-card.wa{border-left:5px solid var(--green)}
.source-card.tg{border-left:5px solid #2aa6df}
.source-card.mx{border-left:5px solid var(--purple)}
.flow-core{width:174px;height:174px;border-radius:50%;border:7px solid #d9e7fb;background:#fff;display:grid;place-items:center;text-align:center;font-weight:900;color:#174ac9;box-shadow:0 10px 26px rgba(33,104,243,.14)}
.leader-list{display:grid;gap:12px}
.leader-list div{border:1px solid var(--border);border-radius:12px;padding:16px;background:var(--surface-2);font-weight:800}
.process .steps{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;margin-top:10px}
.steps span{min-height:82px;border:1px solid var(--border);border-radius:12px;background:var(--surface-2);display:grid;place-items:center;text-align:center;font-weight:850;padding:12px;position:relative}
.steps span:not(:last-child)::after{content:"";position:absolute;right:-13px;top:50%;width:20px;height:2px;background:#8fa4c8}
.chat-workspace{display:grid;grid-template-columns:minmax(240px,.85fr) minmax(0,1.45fr) minmax(210px,.7fr);gap:14px;min-height:calc(100vh - 154px);min-width:0}
.chat-list,.chat-panel,.client-panel{padding:14px}
.tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin-bottom:12px}
.tabs button,.status-pills button,.channel-pills button,.quick-actions button{border:1px solid var(--border);background:#fff;color:#29406d;border-radius:10px;padding:9px 10px;font-weight:800;cursor:pointer}
.tabs button.active,.status-pills button.active,.channel-pills button.active{background:var(--blue);color:white;border-color:var(--blue)}
.search-line{display:grid;grid-template-columns:1fr 44px;gap:8px;margin-bottom:10px}
.search-line input,.send-box input,input,select,textarea{border:1px solid var(--border);border-radius:11px;padding:12px 13px;outline:none;background:#fff;color:var(--text);min-width:0}
textarea{resize:vertical}
.search-line input:focus,.send-box input:focus,input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(33,104,243,.12)}
.status-pills,.channel-pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.status-pills button,.channel-pills button{font-size:12px;padding:7px 9px}
.chat-row{width:100%;display:grid;grid-template-columns:32px minmax(0,1fr) 42px;gap:10px;align-items:center;border:0;background:#fff;border-bottom:1px solid var(--border);padding:12px 4px;cursor:pointer;text-align:left;color:var(--text)}
.chat-row:hover,.chat-row.active{background:#f4f8ff}
.chat-row.outgoing small:first-of-type{color:#2265d8}
.chat-row.incoming small:first-of-type{color:#50627d}
.chat-row.group{background:linear-gradient(90deg,#fffaf0,#fff)}
.chat-row.group:hover,.chat-row.group.active{background:#fff5dd}
.chat-row b{display:block}
.chat-row small{display:block;color:var(--muted);font-size:13px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-row em{font-style:normal;color:var(--muted);font-size:12px}
.unread-badge,.queue-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:11px;font-weight:900;margin-left:6px;padding:2px 6px;vertical-align:middle}
.unread-badge{min-width:20px;background:#eaf2ff;color:var(--blue);border:1px solid #bfd6ff}
.queue-badge{background:#fff4d8;color:#876012;border:1px solid #f3d27a}
.chat-kind-badge{display:inline-flex;align-items:center;border-radius:999px;font-size:10px;font-weight:900;margin-left:6px;padding:2px 6px;vertical-align:middle;color:#5f6f88;background:#f4f6fa;border:1px solid var(--border)}
.chat-kind-badge.group{color:#9a5b00;background:#fff4dc;border-color:#ffd894}
.channel-icon-wrap{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;background:#fff;border:1px solid var(--border);box-shadow:0 4px 12px rgba(20,31,52,.06)}
.channel-icon-wrap.wa{background:#e9fbef;border-color:#b8efc8}
.channel-icon-wrap.tg{background:#eaf7ff;border-color:#bfe7fb}
.channel-icon-wrap.mx{background:#f0edff;border-color:#d7ceff}
.channel-icon-wrap.av{background:#fff3e9;border-color:#ffd6b9}
.channel-icon-img{width:20px;height:20px;display:block;object-fit:contain}
.chat-panel{display:grid;grid-template-rows:auto minmax(0,1fr) auto auto}
.channel-theme.wa{background:#fbfaf5}
.channel-theme.tg{background:#f8fbff}
.channel-theme.mx{background:#fbfaff}
.channel-theme.av{background:#fffdf9}
.chat-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;padding-bottom:12px;border-bottom:1px solid var(--border)}
.chat-head h2{margin:0}
.chat-head p{margin:5px 0 0;color:var(--muted)}
.chat-title-link,.client-panel-link{color:inherit;text-decoration:none}
.chat-title-link:hover,.client-panel-link:hover{color:var(--blue);text-decoration:underline}
.deal-badge{background:#dff7e8;color:#167c39;border:1px solid #b7e8c7;border-radius:10px;padding:8px 10px;font-weight:850}
.chat-panel.drag-over{outline:2px dashed #2f6df6;outline-offset:-8px;background:#f5f9ff}
.messages{overflow:auto;padding:16px;display:flex;flex-direction:column;gap:10px;border-radius:12px;min-height:0}
.channel-wallpaper.wa{background-color:#efe7dc;background-image:radial-gradient(rgba(58,92,76,.12) 1px,transparent 1px),radial-gradient(rgba(58,92,76,.08) 1px,transparent 1px);background-position:0 0,12px 12px;background-size:24px 24px}
.channel-wallpaper.tg{background-color:#dcecf8;background-image:linear-gradient(135deg,rgba(42,166,223,.12) 25%,transparent 25%),linear-gradient(315deg,rgba(42,166,223,.10) 25%,transparent 25%);background-size:28px 28px}
.channel-wallpaper.mx{background-color:#ece9fb;background-image:radial-gradient(rgba(91,63,224,.11) 1px,transparent 1px);background-size:18px 18px}
.channel-wallpaper.av{background-color:#fff2e5;background-image:linear-gradient(90deg,rgba(244,123,32,.08) 1px,transparent 1px),linear-gradient(0deg,rgba(244,123,32,.06) 1px,transparent 1px);background-size:22px 22px}
.bubble{max-width:78%;border:1px solid var(--border);border-radius:12px;padding:12px 13px;background:#fff;position:relative}
.bubble.has-voice{width:min(520px,78%);max-width:min(520px,78%)}
.bubble.selected{outline:3px solid rgba(33,104,243,.28);outline-offset:2px}
.bubble.pinned{box-shadow:0 0 0 2px rgba(245,158,11,.18)}
.bubble.favorite{box-shadow:0 0 0 2px rgba(33,104,243,.14)}
.bubble.pinned.favorite{box-shadow:0 0 0 2px rgba(245,158,11,.18),0 0 0 5px rgba(33,104,243,.10)}
.bubble.deleted{opacity:.72}
.message-menu-trigger{position:absolute;top:6px;right:7px;width:26px;height:24px;border:0;border-radius:8px;background:rgba(255,255,255,.78);color:#41516b;font-weight:900;line-height:1;cursor:pointer;opacity:0;transition:opacity .12s,background .12s}
.bubble:hover .message-menu-trigger,.bubble:focus-within .message-menu-trigger{opacity:1}
.message-menu-trigger:hover{background:#eef4ff}
.channel-wallpaper.wa .bubble.outgoing{background:#d9fdd3;border-color:#bde9b9}
.channel-wallpaper.tg .bubble.outgoing{background:#e5f1ff;border-color:#b9d8f7}
.channel-wallpaper.mx .bubble.outgoing{background:#eeeaff;border-color:#d4caff}
.channel-wallpaper.av .bubble.outgoing{background:#fff0e1;border-color:#ffd5b0}
.bubble.outgoing{align-self:flex-end;background:#eaf2ff;border-color:#bfd6ff}
.bubble.incoming{align-self:flex-start}
.message-author{font-size:12px;font-weight:900;color:#50627d;margin-bottom:5px}
.bubble.outgoing .message-author{text-align:right;color:#0f6f36}
.bubble p{margin:0;line-height:1.45;white-space:pre-wrap}
.message-deleted{color:var(--muted);font-style:italic}
.message-flags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:6px}
.message-flag{display:inline-flex;border:1px solid #f3d27a;background:#fff8e4;color:#876012;border-radius:999px;padding:2px 7px;font-size:11px;font-weight:900}
.message-reply-preview{width:100%;border:0;border-left:3px solid #2f6df6;background:rgba(33,104,243,.08);border-radius:8px;padding:7px 9px;margin-bottom:8px;text-align:left;display:grid;gap:2px;cursor:pointer;color:var(--text)}
.message-reply-preview b{font-size:12px;color:#0c57e8}
.message-reply-preview span{font-size:12px;color:#52627a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.message-reactions{display:flex;justify-content:flex-end;gap:4px;margin-top:5px}
.message-reactions button{min-width:26px;height:24px;border:1px solid rgba(84,112,150,.22);border-radius:999px;background:#fff;cursor:pointer;font-size:15px;line-height:1}
.jump-highlight{animation:jumpFlash 1.1s ease}
@keyframes jumpFlash{0%,100%{outline-color:transparent}25%,70%{outline:3px solid rgba(33,104,243,.45);outline-offset:3px}}
.bubble time{display:block;text-align:right;margin-top:6px;color:var(--muted);font-size:12px}
.message-attachments{display:grid;gap:8px;margin-top:9px}
.attachment-card{display:grid;gap:7px;color:var(--text);border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.72);padding:8px;text-decoration:none}
button.attachment-card{font:inherit;text-align:left;cursor:pointer}
button.attachment-card:hover{border-color:#9db8e8;background:#f8fbff}
.attachment-card-row{display:grid;grid-template-columns:34px minmax(0,1fr);gap:8px;align-items:center}
.attachment-card b{display:block;font-size:13px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.attachment-card small{display:block;color:var(--muted);font-size:12px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.attachment-mini-icon{width:34px;height:24px;border-radius:8px;background:var(--blue-2);color:var(--blue);display:grid;place-items:center;font-weight:900;font-size:10px}
.attachment-preview{max-width:220px;max-height:150px;border-radius:8px;border:1px solid var(--border);object-fit:cover}
.attachment-card.voice{width:100%;min-width:0;border-radius:16px;padding:10px 12px;background:linear-gradient(180deg,#fff,#f6f9ff);border-color:#cfd9e8;box-shadow:0 8px 22px rgba(33,51,82,.08)}
.voice-player-main{display:grid;grid-template-columns:42px minmax(0,1fr);gap:10px;align-items:center}
.voice-play{width:42px;height:42px;border:0;border-radius:50%;display:grid;place-items:center;background:#2168f3;color:#fff;font-size:15px;font-weight:900;line-height:1;cursor:pointer;box-shadow:0 7px 18px rgba(33,104,243,.26)}
.voice-play:hover{background:#1557d6}
.voice-player.is-playing .voice-play{background:#163f9f}
.voice-player-track{display:grid;gap:5px;min-width:0}
.voice-player-title{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:baseline}
.voice-player-title b{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.voice-player-title small{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.voice-seek{width:100%;height:18px;margin:0;accent-color:#2168f3;cursor:pointer;background:transparent;-webkit-appearance:none;appearance:none}
.voice-seek::-webkit-slider-runnable-track{height:5px;border-radius:999px;background:#d8e1ef}
.voice-seek::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;margin-top:-5.5px;border-radius:50%;background:#2168f3;border:3px solid #fff;box-shadow:0 3px 8px rgba(33,51,82,.24)}
.voice-seek::-moz-range-track{height:5px;border-radius:999px;background:#d8e1ef}
.voice-seek::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#2168f3;border:3px solid #fff;box-shadow:0 3px 8px rgba(33,51,82,.24)}
.voice-player-time{display:flex;justify-content:space-between;gap:8px;color:#64748b;font-size:12px;font-weight:800}
.attachment-audio.voice-audio{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}
.attachment-download{font-size:12px;font-weight:800;color:var(--blue);text-decoration:none}
.attachment-download.voice-original{justify-self:end}
.attachment-download:hover{text-decoration:underline}
.voice-transcript{margin-top:10px;border-top:1px solid #dbe5f2;padding-top:9px;color:#172033}
.voice-transcript b{display:block;font-size:12px;margin-bottom:4px;color:#52627a}
.voice-transcript p{margin:0;font-size:13px;line-height:1.45;white-space:normal}
.voice-transcript.muted p{color:#66758c}
.send-box.is-recording [data-attach-voice]{background:#fee2e2;color:#b91c1c;border-color:#fecaca}
.attachment-video{width:min(320px,100%);max-height:220px;border-radius:8px;border:1px solid var(--border);background:#0f172a}
.image-lightbox{position:fixed;inset:0;z-index:80;display:grid;place-items:center;background:rgba(13,22,38,.68);padding:18px}
.image-lightbox-panel{width:min(1100px,calc(100vw - 36px));max-height:calc(100vh - 36px);display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:10px;border-radius:14px;background:#fff;box-shadow:0 28px 90px rgba(0,0,0,.34);padding:12px}
.image-lightbox-head{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}
.image-lightbox-head b{display:block;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.image-lightbox-head small{display:block;color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.image-lightbox-head button{width:34px;height:34px;border:1px solid var(--border);border-radius:9px;background:#fff;cursor:pointer;font-size:24px;line-height:1;color:#34415a}
.image-lightbox img{max-width:100%;max-height:calc(100vh - 150px);object-fit:contain;justify-self:center;align-self:center;border-radius:8px;background:#eef2f7}
.image-lightbox-actions{display:flex;justify-content:flex-end}
.image-lightbox-actions a{font-weight:900;color:var(--blue);text-decoration:none}
.message-meta{display:flex;align-items:center;justify-content:flex-end;gap:7px;margin-top:7px}
.message-meta time{margin-top:0}
.message-status{border:1px solid var(--border);border-radius:999px;padding:2px 6px;font-size:11px;font-weight:900;color:#6b7890;background:#f7f9fc}
.message-status.queued{color:#876012;border-color:#f3d27a;background:#fff8e4}
.message-status.sent,.message-status.delivered,.message-status.read{color:#167c39;border-color:#b7e8c7;background:#eafaf0}
.message-status.failed{color:#b51f2f;border-color:#ffc8c8;background:#fff1f1}
.message-error{display:block;margin-top:7px;color:#b51f2f;font-size:12px;font-weight:800}
.send-box{display:grid;grid-template-columns:minmax(0,1fr) 44px 44px 44px 44px auto;gap:8px;padding-top:12px;border-top:1px solid var(--border)}
.send-input-stack{display:grid;gap:8px;min-width:0}
.reply-draft{display:grid;grid-template-columns:minmax(0,1fr) 30px;align-items:center;gap:8px;border-left:3px solid #2f6df6;background:#f0f6ff;border-radius:10px;padding:8px 9px;color:var(--text)}
.reply-draft b{display:block;font-size:12px;color:#0c57e8}
.reply-draft small{display:block;color:#52627a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.reply-draft button{width:30px;height:30px;border:0;border-radius:9px;background:#fff;color:#52627a;font-size:20px;cursor:pointer}
.attachment-tray{display:flex;flex-wrap:wrap;gap:6px}
.voice-record-status{border:1px solid var(--border);border-radius:10px;padding:8px 10px;background:#f8fafc;color:var(--muted);font-size:13px;font-weight:700;line-height:1.35}
.voice-record-status[data-type="recording"]{background:#fee2e2;border-color:#fecaca;color:#991b1b}
.voice-record-status[data-type="success"]{background:#dcfce7;border-color:#bbf7d0;color:#166534}
.voice-record-status[data-type="error"]{background:#fff1f2;border-color:#fecdd3;color:#be123c}
.pending-attachment{display:inline-flex;align-items:center;gap:6px;max-width:240px;border:1px solid var(--border);background:#fff;border-radius:999px;padding:5px 7px;font-size:12px;color:var(--muted)}
.pending-attachment b{color:var(--text)}
.pending-attachment button{width:20px;height:20px;border:0;border-radius:50%;background:#eef2f7;color:#52627a;cursor:pointer;font-weight:900;line-height:1}
.attach-btn{padding:0;min-width:44px}
.quick-actions{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-top:10px}
.quick-actions button{font-size:12px}
.chat-sync-status{grid-column:1/-1;display:inline-flex;align-items:center;color:var(--muted);font-size:12px;font-weight:800;min-height:22px}
.message-action-menu{position:fixed;z-index:80;min-width:238px;background:rgba(4,36,27,.96);color:#eefdf6;border:1px solid rgba(122,202,167,.42);border-radius:16px;box-shadow:0 20px 46px rgba(0,0,0,.32);padding:10px}
.message-action-menu button{width:100%;border:0;background:transparent;color:inherit;display:grid;grid-template-columns:28px minmax(0,1fr);gap:8px;align-items:center;text-align:left;border-radius:10px;padding:9px 10px;font-weight:850;cursor:pointer}
.message-action-menu button:hover{background:rgba(255,255,255,.12)}
.message-action-menu span{font-size:20px;line-height:1;text-align:center}
.message-action-menu hr{border:0;border-top:1px solid rgba(255,255,255,.16);margin:7px 8px}
.reaction-picker{position:fixed;z-index:85;display:flex;gap:5px;background:#fff;border:1px solid var(--border);border-radius:999px;box-shadow:0 16px 36px rgba(20,31,52,.18);padding:6px}
.reaction-picker button{width:36px;height:36px;border:0;border-radius:50%;background:#fff;cursor:pointer;font-size:20px;line-height:1}
.reaction-picker button:hover{background:#edf4ff;transform:translateY(-1px)}
.chat-emoji-picker{position:fixed;z-index:86;display:grid;grid-template-columns:repeat(7,34px);gap:5px;max-width:min(290px,calc(100vw - 16px));background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 18px 42px rgba(20,31,52,.2);padding:8px}
.chat-emoji-picker button{width:34px;height:34px;border:0;border-radius:9px;background:#fff;cursor:pointer;font-size:20px;line-height:1}
.chat-emoji-picker button:hover{background:#edf4ff;transform:translateY(-1px)}
.client-panel dl{display:grid;grid-template-columns:96px minmax(0,1fr);gap:10px;border-bottom:1px solid var(--border);padding-bottom:16px;margin-bottom:16px}
.client-panel dt{color:var(--muted)}
.client-panel dd{margin:0;font-weight:850;overflow-wrap:anywhere;word-break:break-word}
.clients-table{min-width:980px}
.clients-list-panel{overflow:auto}
.client-link{display:grid;gap:4px}
.client-link b{color:#0c57e8}
.client-link small,.table-note{display:block;color:var(--muted);font-size:13px;margin-top:4px;line-height:1.35}
.contact-chip{display:inline-flex;align-items:center;border:1px solid var(--border);background:var(--surface-2);border-radius:999px;padding:6px 9px;margin:2px;font-size:13px;font-weight:750}
.client-hero{display:flex;align-items:center;justify-content:space-between;gap:18px}
.client-hero h2{font-size:34px;margin:6px 0 4px}
.client-hero p{margin:0;color:var(--muted)}
.back-link{font-size:14px;color:var(--blue);font-weight:850}
.client-hero-stats{text-align:right;display:grid;gap:4px}
.client-hero-stats span{color:var(--green);font-weight:900}
.client-hero-stats b{font-size:28px}
.client-hero-stats small{color:var(--muted)}
.client-detail-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr);gap:18px}
.client-history-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.client-finance-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.client-work-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:start}
.work-panel{min-height:430px}
.panel form{display:grid;gap:10px}
.panel label{font-weight:850;color:#253b68}
.autosave-form .form-result{margin-top:2px}
.client-action-bar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:8px}
.contact-list{display:grid;gap:10px;margin-bottom:16px}
.contact-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:12px;border:1px solid var(--border);background:var(--surface-2);border-radius:12px;padding:12px}
.contact-view{display:grid;gap:10px;min-width:0}
.contact-main{min-width:0}
.contact-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-start}
.contact-row b{display:block;font-size:18px}
.contact-row small{display:block;color:var(--muted);font-size:13px;margin-top:3px}
.contact-row p{margin:7px 0 0;color:var(--muted);font-size:13px}
.mini-status{display:inline-flex;width:max-content;border:1px solid #cfe0ff;background:var(--blue-2);color:#0c57e8;border-radius:999px;padding:4px 8px;margin-bottom:6px;font-size:12px;font-weight:850}
.phone-add-form,.contact-edit-form,.requisite-form,.invoice-form,.task-form{border-top:1px solid var(--border);padding-top:14px;margin-top:14px}
.contact-edit-form{grid-column:1/-1}
.form-field{display:grid;gap:6px}
.inline-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.check-line{display:flex;align-items:center;gap:9px;font-weight:850}
.check-line input{width:18px;height:18px}
.client-write-toolbar{border:1px solid var(--border);border-radius:12px;background:#fff;padding:12px;margin-bottom:12px}
.write-caption{font-weight:900;color:#253b68;margin:4px 0 8px;text-transform:lowercase}
.channel-write-row{display:grid;grid-template-columns:repeat(4,minmax(70px,1fr));gap:8px}
.channel-write-cell{display:grid;gap:6px;justify-items:center;min-width:0}
.channel-write-btn{width:46px;height:42px;border:1px solid var(--border);border-radius:10px;background:#fff;display:grid;place-items:center;cursor:pointer;transition:.16s ease}
.channel-write-btn:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(20,31,52,.12)}
.channel-write-btn img{width:24px;height:24px;display:block}
.channel-write-btn.wa{border-color:#b9edcb;background:#effbf3}
.channel-write-btn.tg{border-color:#b9e6fb;background:#eef9ff}
.channel-write-btn.mx{border-color:#d1c7ff;background:#f4f1ff}
.channel-write-btn.av{border-color:#ffd3b7;background:#fff5ed}
.channel-proof{width:100%;min-height:32px;display:grid;place-items:center;border:1px solid #d7dde8;border-radius:999px;padding:3px 6px;font-size:11px;font-weight:900;color:#7b879b;background:#f6f8fb;text-align:center;white-space:normal;line-height:1.05;overflow-wrap:anywhere}
.channel-proof.confirmed{color:#12843d;border-color:#24c85a;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(120deg,#24c85a,#7be495) border-box;border-width:1px}
.channel-proof.unknown{color:#6f7a8d;background:#f4f6fa}
.history-list{display:grid;gap:10px}
.history-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:start;border:1px solid var(--border);background:var(--surface-2);border-radius:12px;padding:14px}
.history-card h3{margin:0 0 5px;font-size:17px}
.history-card p{margin:0;color:var(--muted);line-height:1.4}
.history-card b{font-size:19px;white-space:nowrap}
.history-card small{display:block;color:var(--muted);text-align:right;margin-top:5px}
.history-card .success{color:var(--green);font-weight:850}
.history-card .loss{color:#b51f2f}
.timeline{display:grid;gap:10px;list-style:none;padding:0;margin:0}
.timeline li{border-left:3px solid var(--blue);padding:8px 0 8px 14px}
.timeline b{display:block}
.timeline span{display:block;color:var(--muted);font-size:13px;margin-top:3px}
.timeline p{margin:6px 0 0;color:var(--muted)}
.scroll-list{max-height:332px;overflow:auto;padding-right:4px}
.requisites-list,.invoice-list,.task-list{display:grid;gap:10px}
.requisite-card,.invoice-card,.task-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;border:1px solid var(--border);background:var(--surface-2);border-radius:12px;padding:14px}
.requisite-card h3,.invoice-card h3,.task-card h3{margin:0 0 5px;font-size:17px}
.requisite-card p,.invoice-card p,.task-card p{margin:0;color:var(--muted);line-height:1.4}
.requisite-card small,.invoice-card small,.task-card small{display:block;color:var(--muted);margin-top:6px}
.requisite-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px;color:#4c5f7f;font-size:12px;font-weight:800}
.requisite-meta span{border:1px solid var(--border);border-radius:999px;padding:4px 7px;background:#fff}
.invoice-card b{display:block;margin-top:7px;font-size:20px}
.invoice-actions,.task-actions{display:flex;align-items:flex-start;justify-content:flex-end;gap:8px;flex-wrap:wrap;min-width:130px}
.invoice-qr{width:156px;height:156px;border:1px solid var(--border);border-radius:10px;background:#fff;padding:8px}
.finance-create-zone{border-top:1px solid var(--border);padding-top:12px;margin-top:4px}
.finance-create-zone h3,.finance-list-zone h3{font-size:15px;margin:0 0 10px;color:#253b68}
.finance-list-zone{border-top:1px solid var(--border);padding-top:12px;margin-top:14px}
.task-card.done{opacity:.72}
.task-card.done h3{text-decoration:line-through}
.client-modal{border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 80px rgba(20,31,52,.25);padding:20px;width:min(480px,calc(100vw - 32px));color:var(--text)}
.client-modal::backdrop{background:rgba(16,26,45,.32)}
.client-modal h2{margin:0 0 12px}
.modal-list{display:grid;gap:8px;margin-bottom:14px}
.search-results-list{margin:0;padding:2px 0 0 0;list-style:none;display:grid;gap:4px}
.search-result-line{display:flex;align-items:baseline;gap:6px;min-height:34px;border-radius:9px;padding:6px 8px;font-weight:800;line-height:1.45}
.search-result-line:hover{background:var(--blue-2);color:#0c57e8}
.search-result-line strong{text-decoration:underline;text-underline-offset:2px}
.search-result-line span{color:#253b68}
.search-result-line .result-number{color:var(--text);font-weight:500;flex:0 0 auto;text-decoration:none}
.funnel{display:grid;gap:14px;max-width:680px;margin:auto}
.funnel-row{height:72px;margin:auto;border:1px solid #cfe1f7;background:linear-gradient(90deg,#dcf8e5,#eaf2ff);display:flex;align-items:center;justify-content:center;gap:18px;font-weight:900;color:#12315f}
.funnel-row:nth-child(1){width:100%;clip-path:polygon(0 0,100% 0,92% 100%,8% 100%)}
.funnel-row:nth-child(2){width:86%;background:#e8f1ff;clip-path:polygon(0 0,100% 0,92% 100%,8% 100%)}
.funnel-row:nth-child(3){width:70%;background:#f0e9ff;clip-path:polygon(0 0,100% 0,92% 100%,8% 100%)}
.funnel-row:nth-child(4){width:54%;background:#fff0e4;clip-path:polygon(0 0,100% 0,92% 100%,8% 100%)}
.funnel-row:nth-child(5){width:40%;background:#e6f8ec;clip-path:polygon(0 0,100% 0,92% 100%,8% 100%)}
.funnel-row strong{font-size:30px;color:var(--blue)}
.funnel-summary{display:grid;grid-template-columns:1fr auto 1fr auto;gap:16px;margin-top:20px;border-top:1px solid var(--border);padding-top:18px}
.funnel-summary strong{font-size:28px;color:var(--green)}
.channel-stat,.bar-list span{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border);padding:13px 0}
.bar-list b{color:var(--blue)}
table{width:100%;border-collapse:collapse}
th,td{padding:12px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
th{color:var(--muted);font-size:13px}
.rules td:nth-child(3){color:var(--muted);line-height:1.5}
.rule-code{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--red);color:#fff;font-weight:900}
.work-list{display:grid;gap:13px;counter-reset:item;list-style:none;padding:0;margin:0}
.work-list li{border:1px solid var(--border);border-radius:12px;background:var(--surface-2);padding:14px;font-weight:850}
.profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.password-field{display:grid;grid-template-columns:minmax(0,1fr) 44px;gap:8px}
.eye{border:1px solid var(--border);background:#fff;border-radius:11px;display:grid;place-items:center;cursor:pointer;color:var(--blue)}
.form-result{min-height:22px;color:var(--green);font-weight:850}
.status{display:inline-flex;border:1px solid var(--border);border-radius:999px;padding:6px 10px;background:var(--surface-2);font-weight:850}
.login-body{min-height:100vh;background:linear-gradient(180deg,#f7f9fd 0,#eef4ff 100%);display:grid;place-items:center;padding:24px}
.login-shell{width:min(1060px,100%);display:grid;grid-template-columns:minmax(0,1.2fr) 420px;gap:28px;align-items:center}
.login-story{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:42px;min-height:460px;display:flex;flex-direction:column;justify-content:center}
.login-logo{width:min(330px,100%);height:auto;margin-bottom:28px}
.login-story h1{font-size:48px;line-height:1.04;margin:0 0 16px}
.login-story p{font-size:20px;color:var(--muted);line-height:1.5;margin:0 0 24px}
.login-metrics{display:flex;flex-wrap:wrap;gap:10px}
.login-metrics span{background:var(--blue-2);color:var(--blue);border-radius:999px;padding:10px 14px;font-weight:900}
.login-card{background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:30px}
.login-card h2{font-size:30px;margin:0 0 20px}
.login-card form{display:grid;gap:10px}
.login-card label{font-weight:900}
.alert{border:1px solid #ffc8c8;background:#fff1f1;color:#b00020;border-radius:12px;padding:12px;margin-bottom:12px;font-weight:800}
@media(max-width:1180px){
  .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dashboard-grid,.client-detail-grid,.client-history-grid,.client-finance-grid{grid-template-columns:1fr}
  .channel-session{grid-template-columns:1fr}
  .chat-workspace{grid-template-columns:280px minmax(0,1fr)}
  .client-panel{grid-column:1/-1}
  .flow{grid-template-columns:1fr}
  .flow-core{width:150px;height:150px;margin:auto}
  .process .steps{grid-template-columns:repeat(3,minmax(0,1fr))}
  .steps span::after{display:none}
}
@media(max-width:820px){
  .app-frame{padding:12px}
  .app-header{height:auto;align-items:flex-start;flex-direction:column;padding:14px}
  .brand-header span{font-size:18px}
  .top-user{width:100%;justify-content:space-between;text-align:left}
  .app-shell{display:block}
  .sidebar{position:relative;top:auto;max-height:none;margin-bottom:14px}
  .sidebar nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));max-height:none}
  .page-head h1{font-size:26px}
  .kpi-grid,.profile-grid{grid-template-columns:1fr}
  .channels-hero,.channel-card-head,.channel-title-row,.channel-status-line,.channel-actions{display:grid;justify-items:start}
  .channel-grid,.control-grid,.remote-type-row{grid-template-columns:1fr}
  .remote-keys{grid-template-columns:repeat(2,minmax(0,1fr))}
  .remote-screen-wrap{min-height:360px}
  .chat-workspace{grid-template-columns:1fr}
  .send-box{grid-template-columns:1fr repeat(4,42px)}
  .send-box .primary{grid-column:1/-1}
  .quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))}
  .client-action-bar,.client-work-grid{grid-template-columns:1fr}
  .channel-write-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .process .steps{grid-template-columns:1fr}
  .funnel-summary{grid-template-columns:1fr}
  .login-shell{grid-template-columns:1fr}
  .login-story{min-height:auto;padding:28px}
  .login-story h1{font-size:36px}
  .login-card{padding:24px}
  .bubble{max-width:92%}
  .bubble.has-voice{width:92%;max-width:92%}
  .voice-player-title{grid-template-columns:1fr}
  .client-hero,.history-card,.contact-row,.requisite-card,.invoice-card,.task-card{display:grid;text-align:left}
  .contact-row,.requisite-card,.invoice-card,.task-card{grid-template-columns:1fr}
  .client-hero-stats{text-align:left}
  .contact-actions,.invoice-actions,.task-actions{justify-content:flex-start}
  .search-result-line{display:grid;gap:2px;align-items:start}
}
