:root{--brand:#1fa855;--brand-dark:#128c7e;--bg:#f6f7f9;--surface:#fff;--border:#e6e8eb;--fg:#0f172a;--fg-muted:#64748b;--radius:10px;--sidebar:#0b1220}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--fg)}a{color:var(--brand-dark);text-decoration:none}.container{max-width:960px;margin:0 auto;padding:32px 20px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:0 1px 2px rgba(16,24,40,.06)}.btn{display:inline-block;background:var(--brand);color:#fff;border:none;border-radius:8px;padding:9px 14px;font-size:14px;font-weight:600;cursor:pointer}.btn:hover{background:var(--brand-dark)}.btn.sm{padding:5px 10px;font-size:12px}.btn.ghost{background:#eef2f6;color:var(--fg)}.btn[disabled]{opacity:.6;cursor:not-allowed}.input,.select,textarea.input{width:100%;padding:9px 11px;border:1px solid var(--border);border-radius:8px;font-size:14px;margin-top:4px;font-family:inherit}label{font-weight:600;display:block;margin-top:12px}.muted,label{font-size:13px;color:var(--fg-muted)}.error{color:#dc2626;font-size:13px;margin-top:10px}.row{display:flex;gap:16px;align-items:flex-start}hr{border:none;border-top:1px solid var(--border);margin:18px 0}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:230px;background:var(--sidebar);color:#cbd5e1;display:flex;flex-direction:column;flex-shrink:0}.brand{padding:20px;font-size:20px;font-weight:800;color:#fff;letter-spacing:-.5px;flex-shrink:0}.brand .dot{color:var(--brand)}.brand-logo{max-height:34px;max-width:180px;object-fit:contain;display:block}.sb-profile{gap:10px;margin:0 12px 8px;padding:10px;border-radius:10px;background:hsla(0,0%,100%,.05)}.sb-ava,.sb-profile{display:flex;align-items:center;flex-shrink:0}.sb-ava{width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;justify-content:center;font-weight:700;font-size:13px}.sb-pinfo{display:flex;flex-direction:column;min-width:0}.sb-pname{color:#fff;font-size:13px;font-weight:600}.sb-pmeta,.sb-pname{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-pmeta{color:#94a3b8;font-size:11px;text-transform:capitalize}.nav{flex:1 1;min-height:0;overflow-y:auto;padding:8px}.nav::-webkit-scrollbar{width:8px}.nav::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.14);border-radius:8px}.nav::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,100%,.24)}.nav{scrollbar-width:thin;scrollbar-color:hsla(0,0%,100%,.18) transparent}.nav-group{margin:14px 12px 4px;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#64748b}.nav-group:first-child{margin-top:2px}.nav-grpbtn,.nav-link{width:100%;display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;color:#cbd5e1;font-size:14px;font-weight:500;margin-bottom:2px;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left}.nav-grpbtn:hover,.nav-link:hover{background:hsla(0,0%,100%,.06);color:#fff}.nav-link.active{background:var(--brand);color:#fff}.nav-grpbtn.has-active{color:#fff}.nav-grpbtn .lbl,.nav-link .lbl{flex:1 1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-ic{flex:none;opacity:.8}.nav-grpbtn.has-active .nav-ic,.nav-link.active .nav-ic{opacity:1}.chev{flex:none;opacity:.65;transition:transform .15s ease}.nav-grpbtn.open .chev{transform:rotate(90deg)}.nav-grp{margin-bottom:2px}.nav-children{margin:1px 0 6px 23px;padding-left:11px;border-left:1px solid hsla(0,0%,100%,.12);display:flex;flex-direction:column}.nav-children a{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:7px;color:#94a3b8;font-size:13.5px;font-weight:500}.nav-children a:hover{background:hsla(0,0%,100%,.05);color:#fff}.nav-children a.active{background:rgba(37,211,102,.14);color:#fff}.nav-children a .dot{flex:none;width:6px;height:6px;border-radius:50%;background:transparent}.nav-children a.active .dot{background:var(--brand)}.nav-children a .clbl{flex:1 1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-badge{margin-left:auto;flex:none;background:#ef4444;color:#fff;font-size:11px;font-weight:700;line-height:1;border-radius:999px;min-width:20px;height:18px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 0 0 2px rgba(239,68,68,.25)}.nav-link.active .nav-badge{background:#fff;color:var(--brand);box-shadow:none}.nav-sep{margin:12px 12px 4px;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#64748b}.upgrade-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:linear-gradient(100deg,#6d28d9,#4f46e5);color:#fff;border-radius:12px;padding:16px 20px;margin-bottom:20px;box-shadow:0 6px 20px rgba(79,70,229,.25)}.upgrade-banner strong{font-size:15px}.upgrade-banner p{margin:4px 0 0;font-size:13px;opacity:.9}.upgrade-banner .upgrade-btn{background:#fff;color:#4f46e5;font-weight:700;white-space:nowrap}.upgrade-banner .upgrade-btn:hover{background:#f1f5f9}.locked-state{text-align:center;padding:60px 24px;background:#fff;border:1px dashed var(--border);border-radius:12px}.locked-state .locked-emoji{font-size:48px}.locked-state h2{margin:12px 0 6px;font-size:20px}.locked-state p{color:var(--fg-muted);margin:0 0 6px}.locked-state .upgrade-btn{background:#4f46e5;color:#fff}.locked-state .upgrade-btn:hover{background:#4338ca}.admin-sidebar{background:#0b1220;border-right:1px solid #1e293b}.admin-sidebar .brand{color:#fff}.admin-sidebar .nav a,.admin-sidebar .nav-link{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;color:#cbd5e1;font-size:14px;font-weight:500;margin-bottom:2px}.admin-sidebar .nav a:hover{background:hsla(0,0%,100%,.06);color:#fff}.admin-sidebar .nav a.active,.admin-sidebar .nav-link.active{background:#6d28d9;color:#fff}.sb-foot{padding:14px;border-top:1px solid hsla(0,0%,100%,.08);font-size:12px;color:#94a3b8}.credits,.sb-foot,.wallet{flex-shrink:0}.main{flex:1 1;min-width:0;min-height:0;display:flex;flex-direction:column}.topbar{padding:16px 28px;border-bottom:1px solid var(--border);background:#fff;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.topbar h1{font-size:18px;margin:0}.content{padding:24px 28px;flex:1 1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:14px;gap:14px}.kpi{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px}.kpi .v{font-size:26px;font-weight:800}.kpi .l{font-size:12px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.crm-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:14px;gap:14px;align-items:start}.crm-plan{display:flex;flex-direction:column}table{width:100%;border-collapse:collapse;font-size:14px}th{text-align:left;color:var(--fg-muted);font-size:12px;text-transform:uppercase;padding:8px 10px}td,th{border-bottom:1px solid var(--border)}td{padding:10px}.badge{display:inline-block;font-size:11px;font-weight:700;background:#eef2ff;color:#3730a3;border-radius:999px;padding:2px 8px}.badge.green{background:#dcfce7;color:#166534}.badge.amber{background:#fef3c7;color:#92400e}.conv-list{list-style:none;padding:0;margin:0}.conv-item{border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:8px;background:#fff;cursor:pointer}.conv-item:hover{border-color:var(--brand)}.bubble{border-radius:10px;padding:8px 12px;margin:6px 0;max-width:75%;font-size:14px}.bubble.inbound{background:#fff;border:1px solid var(--border)}.bubble.outbound{background:#d9fdd3;margin-left:auto}.meta{font-size:11px;color:var(--fg-muted);margin-top:2px}.progress{height:8px;background:#eef2f6;border-radius:999px;overflow:hidden;margin-top:6px}.progress>span{display:block;height:100%;background:var(--brand)}.grid2{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}@media (max-width:800px){.grid2{grid-template-columns:1fr}}.wa-phone{width:320px;border:9px solid #111b21;border-radius:30px;overflow:hidden;background:#111b21;box-shadow:0 8px 30px rgba(16,24,40,.18)}.wa-top{background:#008069;color:#fff;padding:12px 14px;gap:10px}.wa-top,.wa-top .ava{display:flex;align-items:center}.wa-top .ava{width:30px;height:30px;border-radius:50%;background:#ffffff33;justify-content:center;font-size:14px}.wa-top .nm{font-size:14px;font-weight:600;line-height:1.1}.wa-top .st{font-size:11px;opacity:.85}.wa-wall{background-color:#efeae2;background-image:radial-gradient(rgba(0,0,0,.035) 1px,transparent 0);background-size:14px 14px;padding:16px 12px;min-height:280px}.wa-bubble{background:#fff;border-radius:9px;border-top-left-radius:0;padding:6px 7px 5px;max-width:92%;box-shadow:0 1px .5px rgba(11,20,26,.13);position:relative}.wa-bubble:before{content:"";position:absolute;top:0;left:-8px;border-color:#fff #fff transparent transparent;border-style:solid;border-width:7px}.wa-media{width:100%;display:block;max-height:190px;object-fit:cover;background:#d1d7db}.wa-doc,.wa-media{border-radius:6px;margin-bottom:5px}.wa-doc{background:#f0f2f5;padding:10px;font-size:13px;color:#54656f}.wa-htext{font-weight:700;font-size:14px;color:#111b21;margin-bottom:3px}.wa-body{font-size:13.5px;color:#111b21;white-space:pre-wrap;line-height:1.35}.wa-foot{font-size:12px;color:#8696a0;margin-top:5px}.wa-time{font-size:10.5px;color:#8696a0;text-align:right;margin-top:2px}.wa-time .tick{color:#53bdeb;font-weight:700}.wa-btns{margin:6px -7px -5px}.wa-btn{background:#fff;color:#00a5f4;text-align:center;font-size:14px;font-weight:500;padding:9px;border-top:1px solid #e9edef}.wa-btn:last-child{border-radius:0 0 8px 8px}.wa-var{background:#fff3cd;border-radius:3px;padding:0 2px}.wa-media-ph{height:110px;display:flex;align-items:center;justify-content:center;color:#8696a0;font-size:13px}.wap-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;margin:14px 0 4px}.wap-stat{border:1px solid var(--border);border-radius:8px;padding:9px 10px}.wap-stat .l{font-size:10.5px;color:var(--fg-muted)}.wap-stat .v{font-weight:700;margin-top:2px;font-size:14px}.wap-id{padding:9px 0;border-bottom:1px solid #f1f5f9}.dotrow{font-size:12px;font-weight:600;margin-top:2px}.dotg{color:#16a34a}.dota{color:#d97706}.dotn{color:#94a3b8}.wap-steps{display:flex;align-items:flex-start;margin-top:16px}.wap-step{text-align:center;font-size:11px;color:var(--fg-muted);flex:0 0 auto;width:80px}.wap-step .dot{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin-bottom:4px;font-size:14px}.wap-line{height:2px;flex:1 1;margin-top:12px}.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:18px;gap:18px}.tpl-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px}.tpl-card .meta-row{align-items:center;margin:4px 0 12px}.tpl-actions,.tpl-card .meta-row{display:flex;flex-wrap:wrap;gap:6px}.tpl-actions{margin-top:12px;border-top:1px solid var(--border);padding-top:10px}.wa-stage{background:#d9d2c8;border-radius:10px;padding:12px}.modal-bg{position:fixed;inset:0;background:rgba(15,23,42,.45);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:50;overflow:auto}.modal{background:#fff;border-radius:12px;padding:22px;width:100%;max-width:440px}.steps{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}.step{font-size:12px;font-weight:600;color:var(--fg-muted);padding:6px 12px;border-radius:999px;background:#eef2f6}.step.active{background:var(--brand);color:#fff}.step.done{background:#dcfce7;color:#166534}.chip{display:inline-flex;align-items:center;gap:4px;background:#eef2f6;border-radius:999px;padding:3px 10px;font-size:12px;cursor:pointer}.chip:hover{background:#e2e8f0}.counter{font-size:11px;text-align:right}.counter,.dz{color:var(--fg-muted)}.dz{border:2px dashed var(--border);border-radius:10px;padding:28px;text-align:center;cursor:pointer}.dz.drag{border-color:var(--brand);background:#f0fdf4}.pop{position:absolute;z-index:60;top:calc(100% + 4px);left:0;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 34px rgba(16,24,40,.18);padding:12px}.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:2px;gap:2px}.cal-dow{font-size:11px;color:var(--fg-muted);text-align:center;padding:4px 0}.cal-day{text-align:center;padding:7px 0;border-radius:7px;cursor:pointer;font-size:13px}.cal-day:hover{background:#eef2f6}.cal-day.muted{color:#cbd5e1}.cal-day.today{box-shadow:inset 0 0 0 1px var(--brand)}.cal-day.sel{background:var(--brand);color:#fff}.cal-day.sel:hover{background:var(--brand-dark)}.picker-trigger{-webkit-user-select:none;-moz-user-select:none;user-select:none}.phone-row{display:flex;gap:6px}.cc-btn{cursor:pointer}.ccdrop{position:absolute;z-index:61;top:calc(100% + 4px);left:0;width:300px;max-height:280px;overflow:auto;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 34px rgba(16,24,40,.18)}.ccitem{display:flex;gap:8px;align-items:center;padding:8px 10px;cursor:pointer;font-size:14px}.ccitem:hover{background:#eef2f6}.ccitem.muted{color:var(--fg-muted);cursor:default}@media print{.no-print,.sidebar,.topbar{display:none!important}.app,.content,.main{display:block}.content{padding:0}body{background:#fff}.card,.kpi{box-shadow:none;page-break-inside:avoid;break-inside:avoid}}.ib{flex:1 1;min-height:0;margin:-24px -28px}.ib,.ib-list{display:flex;background:#fff}.ib-list{width:350px;flex-shrink:0;border-right:1px solid var(--border);flex-direction:column}.ib-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px}.ib-head h2{margin:0;font-size:22px;font-weight:300;letter-spacing:-.3px}.ib-head .actions{gap:8px}.ib-head .actions,.ib-iconbtn{display:flex;align-items:center}.ib-iconbtn{width:34px;height:34px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer;justify-content:center;color:var(--fg-muted);font-size:16px}.ib-iconbtn:hover{background:#f1f5f9}.ib-tabs{display:flex;gap:22px;padding:0 16px;border-bottom:1px solid var(--border)}.ib-tab{background:none;padding:10px 0;font-size:14px;font-weight:600;color:var(--fg-muted);cursor:pointer;border:none;border-bottom:2px solid transparent;display:flex;align-items:center;gap:7px}.ib-tab:hover{color:var(--fg)}.ib-tab.active{color:var(--brand);border-bottom-color:var(--brand)}.ib-count{background:#ef4444;color:#fff;font-size:11px;font-weight:700;border-radius:999px;min-width:20px;height:18px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center}.ib-tab.active .ib-count{background:var(--brand)}.ib-search{padding:10px 16px;border-bottom:1px solid var(--border)}.ib-rows{flex:1 1;overflow-y:auto}.ib-group{padding:8px 16px 4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--fg-muted);background:#f8fafc}.ib-group,.ib-row{border-bottom:1px solid #f1f5f9}.ib-row{display:flex;gap:12px;align-items:center;padding:11px 16px;cursor:pointer}.ib-row:hover{background:#f8fafc}.ib-row.active{background:#f0fdf4;box-shadow:inset 3px 0 0 var(--brand)}.ib-row.unread{background:#f0f9ff}.ib-row.unread .ib-name{font-weight:800}.ib-row.unread .ib-prev{color:var(--fg);font-weight:600}.ib-ava{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.ib-rowmain{flex:1 1;min-width:0}.ib-rowtop{display:flex;align-items:center;gap:6px}.ib-name{font-weight:600;font-size:14px;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ib-chan{font-size:10px;font-weight:700;color:var(--brand-dark);border:1px solid #bbf7d0;background:#f0fdf4;border-radius:999px;padding:1px 7px;flex-shrink:0}.ib-prev{font-size:13px;color:var(--fg-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:3px}.ib-tick{color:#53bdeb;margin-right:3px}.ib-rowmeta{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.ib-time{font-size:11px;color:var(--fg-muted)}.ib-unread{background:#1f2937;color:#fff;font-size:11px;font-weight:700;border-radius:999px;min-width:20px;height:20px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center}.ib-chat{min-width:0}.ib-chat,.ib-empty{flex:1 1;display:flex;flex-direction:column}.ib-empty{align-items:center;justify-content:center;text-align:center;background-color:#f3f4f6;background-image:radial-gradient(rgba(15,23,42,.045) 1.1px,transparent 0);background-size:20px 20px}.ib-empty h2{font-size:32px;font-weight:400;color:#374151;margin:0}.ib-empty p{color:var(--fg-muted);margin-top:8px;font-size:15px}.ib-chathead{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);background:#fff}.ib-chathead .nm{font-weight:600;font-size:15px}.ib-chathead .sub{font-size:12px;color:var(--fg-muted)}.ib-chathead .sp{flex:1 1}.ib-wall{flex:1 1;overflow-y:auto;padding:18px 7%;background-color:#efeae2;background-image:radial-gradient(rgba(15,23,42,.04) 1.1px,transparent 0);background-size:18px 18px}.ib-msg{display:flex;margin:7px 0}.ib-msg.outbound{justify-content:flex-end}.ib-mb{max-width:68%;padding:7px 10px 5px;border-radius:9px;font-size:14px;line-height:1.35;white-space:pre-wrap;word-break:break-word;box-shadow:0 1px .5px rgba(11,20,26,.13)}.ib-msg.inbound .ib-mb{background:#fff;border-top-left-radius:0}.ib-msg.outbound .ib-mb{background:#d9fdd3;border-top-right-radius:0}.ib-mb .t{font-size:10.5px;color:#667781;text-align:right;margin-top:3px}.ib-resend{margin-top:5px;background:#fff;border:1px solid #dc2626;color:#dc2626;font-size:12px;font-weight:700;border-radius:6px;padding:3px 10px;cursor:pointer}.ib-resend:hover{background:#dc2626;color:#fff}.ib-resend[disabled]{opacity:.6;cursor:not-allowed}.ib-toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:#0f172a;color:#fff;padding:11px 18px;border-radius:10px;font-size:14px;box-shadow:0 8px 24px rgba(0,0,0,.25);z-index:80;max-width:90vw}.ib-composer{display:flex;gap:8px;align-items:center;padding:12px 16px;background:#f0f2f5;border-top:1px solid var(--border)}.ib-composer input{flex:1 1;border:1px solid var(--border);border-radius:999px;padding:10px 16px;font-size:14px;font-family:inherit;background:#fff}.ib-ai{width:330px;flex-shrink:0;border-left:1px solid var(--border);background:#fff;display:flex;flex-direction:column}.ib-ai-head{padding:13px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.ib-ai-body{flex:1 1;overflow-y:auto;padding:16px}.ib-ai-card{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:12px;margin-top:14px}.ib-src{font-size:11px;color:var(--fg-muted);border-left:2px solid var(--border);padding-left:8px;margin:6px 0}@media (max-width:1100px){.ib-ai{display:none}}.wallet{display:block;padding:12px 14px;border-top:1px solid hsla(0,0%,100%,.08);text-decoration:none}.wallet:hover{background:hsla(0,0%,100%,.05)}.wallet-l{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8}.wallet-v{display:block;font-size:21px;font-weight:800;color:#fff;margin-top:2px}.wallet-add{display:inline-block;margin-top:3px;font-size:11px;font-weight:600;color:var(--brand)}.credits{padding:12px 14px;border-top:1px solid hsla(0,0%,100%,.08)}.credits-h{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;margin-bottom:8px}.credit-row{margin-bottom:10px}.credit-top{display:flex;justify-content:space-between;font-size:12px;color:#cbd5e1;margin-bottom:4px}.credit-rem{color:#94a3b8}.credit-bar{height:6px;background:hsla(0,0%,100%,.1);border-radius:999px;overflow:hidden}.credit-bar>span{display:block;height:100%;border-radius:999px}.ib-composer-wrap{position:relative}.ib-warn{background:#fef3c7;color:#92400e;border-top:1px solid #fcd34d;padding:8px 16px;font-size:13px}.ib-warn.err{background:#fee2e2;color:#991b1b;border-top-color:#fca5a5}.ib-warn a{color:inherit;font-weight:700;text-decoration:underline}.ib-canned{position:absolute;bottom:calc(100% + 6px);left:12px;right:12px;max-width:540px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 34px rgba(16,24,40,.18);z-index:30;overflow:hidden}.ib-canned-h{padding:10px 12px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--fg-muted);border-bottom:1px solid var(--border)}.ib-canned-list{max-height:220px;overflow-y:auto}.ib-canned-item{display:flex;gap:8px;align-items:center;padding:8px 12px;border-bottom:1px solid #f1f5f9}.ib-canned-item:hover{background:#f8fafc}.ib-canned-item.sel{background:#f0fdf4;box-shadow:inset 3px 0 0 var(--brand)}.ib-canned-add{display:flex;gap:6px;padding:10px 12px;border-top:1px solid var(--border);background:#f8fafc}.bot-pal{background:#fff;border:1px solid var(--border);border-left:4px solid var(--brand);border-radius:10px;padding:12px;margin-bottom:10px;cursor:pointer}.bot-pal:hover{box-shadow:0 4px 12px rgba(16,24,40,.08)}.bot-node{background:#fff;border:1px solid var(--border);border-radius:10px;margin-bottom:12px;overflow:hidden}.bot-node-h{display:flex;align-items:center;gap:4px;padding:8px 12px;background:#f8fafc;border-bottom:1px solid var(--border)}.cv-wrap{position:relative;flex:1 1;min-width:0;height:72vh;border:1px solid var(--border);border-radius:12px;overflow:hidden;background-color:#f3f4f6;background-image:radial-gradient(rgba(15,23,42,.06) 1px,transparent 0);background-size:22px 22px}.cv-zoom{position:absolute;top:10px;left:10px;z-index:5;display:flex;flex-direction:column;gap:4px}.cv-canvas{position:absolute;inset:0;transform-origin:0 0;cursor:-webkit-grab;cursor:grab}.cv-canvas:active{cursor:-webkit-grabbing;cursor:grabbing}.cv-edges{position:absolute;top:0;left:0;pointer-events:none;overflow:visible}.cv-node{position:absolute;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 2px 8px rgba(16,24,40,.1);-webkit-user-select:none;-moz-user-select:none;user-select:none}.cv-node.sel{border-color:var(--brand);box-shadow:0 0 0 2px rgba(31,168,85,.3)}.cv-node-h{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:8px 12px;color:#fff;border-radius:12px 12px 0 0;font-weight:600;font-size:13px;cursor:-webkit-grab;cursor:grab}.cv-start{background:hsla(0,0%,100%,.25);border-radius:6px;padding:1px 6px;font-size:10px}.cv-node-b{padding:10px 12px}.cv-sum{font-size:13px;color:var(--fg);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cv-ports{display:flex;flex-wrap:wrap;gap:4px;padding:0 10px 10px}.cv-port{font-size:11px;border:1px solid var(--border);background:#f8fafc;color:var(--fg-muted);border-radius:999px;padding:2px 8px;cursor:pointer}.cv-port.on,.cv-port:hover{border-color:var(--brand);color:var(--brand-dark);background:#f0fdf4}.cv-drawer{flex:0 0 280px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;align-self:flex-start;max-height:72vh;overflow-y:auto}