:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;color:#0f172a;background:#f1f5f9}*{box-sizing:border-box}body{margin:0}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#0f172a;color:#f8fafc;padding:.6rem 1.1rem;display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.app-header a{color:#93c5fd}.app-header label{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.token-field{margin-left:auto}.header-api-note{color:#94a3b8;font-size:.8rem}.app-header input[type=password],.app-header input[type=text]{min-width:220px;padding:.35rem .5rem;border-radius:6px;border:1px solid #334155;background:#1e293b;color:#f8fafc}.app-main{flex:1;padding:1.5rem;max-width:1500px;margin:0 auto;width:100%}.page-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:1rem}.page-subheader{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.9rem}.page-subheader h1{margin:0}.page-body-container{background:#ffffff59;border:1px solid rgb(226 232 240 / .45);border-radius:12px;padding:1rem;box-shadow:none}.card-grid>a:hover{text-decoration:none}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.card{background:#fff;border-radius:12px;padding:1rem 1.1rem;box-shadow:0 2px 8px #0f172a14;border:1px solid #e2e8f0;position:relative}.card h3{margin:0 0 .5rem;font-size:1rem}.tenant-card{min-height:190px}.channel-card{min-height:290px;padding:1.2rem 1.25rem}.channel-card h3{font-size:1.2rem;margin-bottom:.65rem}.muted{color:#64748b;font-size:.875rem}.badge{display:inline-block;padding:.15rem .45rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-on{background:#dcfce7;color:#166534}.badge-off{background:#fee2e2;color:#991b1b}.btn{padding:.45rem .85rem;border-radius:8px;border:1px solid #cbd5e1;background:#fff;transition:background-color .12s ease,border-color .12s ease}.btn:hover{background:#f8fafc}.btn-primary{background:#2563eb;color:#fff;border-color:#1d4ed8}.btn-primary:hover{background:#1d4ed8;color:#fff;border-color:#1e40af}.btn-primary:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}.btn-ghost{background:transparent;border:none;padding:.25rem .5rem}.channel-card-actions{position:absolute;top:.5rem;right:.5rem;display:flex;gap:.25rem}.card-top-actions{display:flex;justify-content:flex-end;align-items:center;margin:-.2rem -.2rem .2rem 0}.card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.35rem}.card-title-row h3{margin:0}.card-inline-actions{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.action-menu-wrap{position:relative}.action-menu{position:absolute;top:2rem;right:0;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:.35rem;display:grid;gap:.35rem;z-index:5;min-width:160px;box-shadow:0 10px 24px #0f172a29}.action-menu-item{border:0;background:transparent;text-align:left;width:100%;padding:.5rem .6rem;border-radius:6px;color:#0f172a;display:block}.action-menu-item:hover{background:#eff6ff;text-decoration:none}.menu-dots{font-size:1.15rem;line-height:1;min-width:2rem;min-height:2rem;display:inline-flex;align-items:center;justify-content:center;padding:.2rem .35rem}.channel-meta{margin-top:.75rem;padding:.8rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;display:grid;gap:.55rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:12px;padding:1.25rem;width:min(420px,92vw);max-height:90vh;overflow:auto}.modal h2{margin-top:0}.channel-chip-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.channel-chip{border:1px solid #cbd5e1;background:#fff;border-radius:8px;padding:.5rem;text-transform:capitalize}.channel-chip.is-active{border-color:#1d4ed8;background:#eff6ff;color:#1e3a8a;font-weight:600}.inline-checkbox{display:inline-flex!important;align-items:center;gap:.5rem;margin-bottom:0}.template-card{text-align:left;width:100%;min-height:340px;height:auto;padding:1.3rem 1.35rem;display:flex;flex-direction:column}.template-card h3{margin:0 0 .6rem;font-size:1.15rem;line-height:1.4;overflow:hidden;overflow-wrap:anywhere;word-break:break-word;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.template-card:hover{border-color:#bfdbfe;box-shadow:0 8px 20px #2563eb1f}.template-card .kv-list{grid-template-columns:max-content minmax(0,1fr);gap:8px 10px;font-size:.95rem}.template-card .kv-list span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.template-card .kv-list span:nth-child(2n){display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.template-card-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.channel-card-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.4rem}.switch{position:relative;display:inline-block;width:60px;height:34px;flex:0 0 auto;overflow:hidden;border-radius:34px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ef4444;transition:.4s;box-sizing:border-box}.slider:before{position:absolute;content:"";height:26px;width:26px;left:4px;bottom:4px;background-color:#fff;transition:.4s;box-sizing:border-box}.switch input:checked+.slider{background-color:#22c55e}.switch input:focus+.slider{box-shadow:0 0 1px #22c55e}.switch input:checked+.slider:before{transform:translate(26px)}.slider.round{border-radius:34px}.slider.round:before{border-radius:50%}.channel-enable-switch{width:52px;height:30px}.channel-enable-switch .slider:before{width:22px;height:22px;left:4px;bottom:4px}.channel-enable-switch input:checked+.slider:before{transform:translate(22px)}.empty-state-card{margin-top:.4rem;text-align:center;padding:1.4rem}.template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1rem;align-items:stretch}.template-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;margin-bottom:.8rem}.template-add-btn{flex:0 0 auto;max-width:100%;white-space:nowrap}@media (max-width: 1300px){.template-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media (max-width: 980px){.template-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media (max-width: 680px){.template-grid{grid-template-columns:1fr}}.form-row{margin-bottom:.75rem}.form-row label{display:block;font-size:.85rem;margin-bottom:.25rem}.form-row input,.form-row select,.form-row textarea{width:100%;padding:.55rem .65rem;border-radius:6px;border:1px solid #cbd5e1;background:#fff;transition:border-color .12s ease,box-shadow .12s ease}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.form-card{max-width:980px}.form-card h3{margin-bottom:.85rem}.form-row textarea{resize:vertical}.split-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}@media (max-width: 760px){.split-grid{grid-template-columns:1fr}}.drawer{position:fixed;top:0;right:0;width:min(480px,100vw);height:100vh;background:#fff;box-shadow:-4px 0 24px #0f172a26;z-index:40;display:flex;flex-direction:column}.drawer-header{padding:1rem;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.drawer-body{flex:1;overflow:auto;padding:1rem}table.data-table{width:100%;border-collapse:collapse;font-size:.85rem}table.data-table th,table.data-table td{text-align:left;padding:.4rem .35rem;border-bottom:1px solid #e2e8f0}.virtual-list-wrap{border:1px solid #e2e8f0;border-radius:8px}.kv-list{display:grid;grid-template-columns:max-content minmax(0,1fr);gap:6px 10px}.data-pretty{margin:0;font-size:.78rem;overflow:auto;max-height:160px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.6rem}.inline-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.virtual-list-header,.virtual-row{display:grid;grid-template-columns:.8fr 1fr 1fr 1.2fr;gap:8px;align-items:center;padding:8px;font-size:12px}.virtual-list-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;font-weight:600}.virtual-list-body{overflow:auto;position:relative}.virtual-row{position:absolute;left:0;right:0;height:42px;border:0;border-bottom:1px solid #f1f5f9;background:#fff;text-align:left}.virtual-row.is-selected{background:#eff6ff}.error-banner{background:#fef2f2;color:#991b1b;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}
