/* X-Live admin styles. Theme via CSS variables.
   Default (no attribute) = LIGHT. html[data-theme="dark"] = dark override. */
:root{
  color-scheme:light;
  /* Cobalt theme (formerly the separate admin.css override; now the app default). */
  --bg:#eef2f8; --panel:#ffffff; --panel2:#f4f7fc; --line:#e3e8f3;
  --txt:#101828; --muted:#5b6b85; --accent:#3b5bdb; --accent2:#2f49b8;
  --ok:#1fa85a; --amber:#cf8a14; --red:#e23b3b;
  --canvas:#eef2f8; --cell-line:#9fb0cf; --gutter:#e6ecf6;
  --field:#ffffff; --field-border:#cdd6e6;
  --shadow:0 1px 2px rgba(16,24,40,.05),0 6px 14px rgba(22,34,74,.07),0 18px 40px rgba(22,34,74,.10);
  --tile-shadow:0 1px 2px rgba(16,24,40,.05),0 8px 20px rgba(22,34,74,.08);
}
html[data-theme="dark"]{
  color-scheme:dark;
  --bg:#0f141b; --panel:#171f29; --panel2:#1f2a36; --line:#2b3947;
  --txt:#e7eef6; --muted:#8aa0b4; --accent:#2f8fff; --accent2:#1b6fd6;
  --ok:#37c871; --amber:#f5b53d; --red:#ef4d4d;
  --canvas:#0b0f15; --cell-line:#283543; --gutter:#0b0f15;
  --field:#1f2a36; --field-border:#2b3947;
  --shadow:0 6px 24px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--txt);font:14px/1.45 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
a{color:var(--accent)}
button{font:inherit;cursor:pointer;border:0;border-radius:8px;padding:9px 14px;background:var(--accent);color:#fff}
button:hover{background:var(--accent2)}
button.ghost{background:var(--panel2);color:var(--txt);border:1px solid var(--line)}
button.ghost:hover{border-color:var(--accent)}
button.danger{background:var(--red)}
button:disabled{opacity:.5;cursor:default}
input,select,textarea{font:inherit;color:var(--txt);background:var(--field);border:1px solid var(--field-border);border-radius:8px;padding:8px 10px;width:100%}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(59,91,219,.20)}
label{display:block;color:var(--muted);font-size:12px;margin:10px 0 4px}
.row{display:flex;gap:10px;align-items:center}
.muted{color:var(--muted)}
.pill{display:inline-block;padding:2px 8px;border-radius:999px;background:var(--panel2);border:1px solid var(--line);font-size:11px;color:var(--muted)}

/* ---- login ---- */
.login-wrap{height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:26px;width:340px}
/* dialog modal: icon badge + title + message */
.xl-modal-ov{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.xl-modal{width:380px;max-width:calc(100vw - 32px);padding:24px}
.xl-modal-head{display:flex;align-items:center;gap:13px}
.xl-modal-ic{flex:none;width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center}
.xl-modal-ic svg{width:22px;height:22px}
.xl-modal-ic.accent{background:rgba(59,91,219,.12);color:var(--accent)}
.xl-modal-ic.danger{background:rgba(226,59,59,.12);color:var(--red)}
.xl-modal-ttl{font-size:17px;font-weight:800;letter-spacing:-.01em;color:var(--txt);line-height:1.25}
.xl-modal-msg{margin:13px 0 0;color:var(--muted);font-size:13.5px;line-height:1.55}
.xl-modal label:first-of-type{margin-top:16px}
.xl-modal-foot{margin-top:18px;gap:9px}
.brand{font-size:22px;font-weight:700;letter-spacing:.5px;margin-bottom:2px}
.brand span{color:var(--accent)}
.brand-ic{height:1.15em;width:auto;vertical-align:-0.2em;margin-right:.4em}
.sub{color:var(--muted);font-size:12px;margin-bottom:18px}
.err{color:var(--red);font-size:13px;min-height:18px;margin-top:10px}
.themelink{background:none;border:0;color:var(--muted);font-size:12px;cursor:pointer;padding:4px}

/* ---- admin shell ---- */
.topbar{display:flex;align-items:center;gap:14px;padding:10px 16px;background:var(--panel);border-bottom:1px solid var(--line)}
.topbar .brand{font-size:17px;margin:0}
.topbar .spacer{flex:1}
.layout{display:grid;grid-template-columns:230px 1fr 300px;height:calc(100vh - 53px)}
.col{overflow:auto;padding:14px}
.col.left{border-right:1px solid var(--line);background:var(--panel)}
.col.right{border-left:1px solid var(--line);background:var(--panel)}
.col.center{background:var(--bg)}
h3{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin:6px 0 8px}

/* palette */
.palette-item{display:flex;gap:8px;align-items:center;padding:8px 10px;margin-bottom:6px;background:var(--panel2);border:1px solid var(--line);border-radius:8px;cursor:grab;user-select:none}
.palette-item:hover{border-color:var(--accent)}
.palette-item .dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}
.dot.q{background:var(--accent)} .dot.v{background:var(--ok)} .dot.p{background:var(--amber)} .dot.d{background:var(--muted)}
.dot.o{background:#9b59b6}

/* palette: direction tabs (Inbound / Outbound / Both) - underline style + item name and category tag */
.pal-tabs{display:flex;justify-content:space-between;gap:8px;border-bottom:1px solid var(--line);margin-bottom:0}
.pal-tab{flex:0 0 auto;background:none;border:0;border-radius:0;color:var(--muted);font-weight:600;font-size:13px;padding:9px 2px 11px;white-space:nowrap;position:relative;cursor:pointer;transition:color .14s}
.pal-tab:hover{background:none;color:var(--txt)}
.pal-tab[aria-selected="true"]{color:var(--accent)}
.pal-lab{position:relative;display:inline-block}
.pal-tab[aria-selected="true"] .pal-lab::after{content:"";position:absolute;left:0;right:0;bottom:-11px;height:2px;background:var(--accent);border-radius:2px}
.pal-count{font-size:11px;color:var(--muted);letter-spacing:.2px;margin:20px 2px}
.pal-nm{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pal-tag{flex:0 0 auto;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.2px;white-space:nowrap}
.pal-empty{color:var(--muted);text-align:center;padding:20px 8px;font-size:13px}

/* palette sections (collapsible) */
.pal-sec{margin-bottom:8px;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.pal-sec>summary{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;user-select:none;font-size:12px;font-weight:600;color:var(--txt);background:var(--panel2);list-style:none}
.pal-sec>summary::-webkit-details-marker{display:none}
.pal-sec>summary:hover{color:var(--accent)}
.pal-sec .caret{flex:0 0 auto;width:0;height:0;border-left:5px solid var(--muted);border-top:4px solid transparent;border-bottom:4px solid transparent;transition:transform .15s}
.pal-sec[open]>summary .caret{transform:rotate(90deg)}
.pal-sec-name{flex:1}
.pal-sec-n{flex:0 0 auto;color:var(--muted);font-weight:400;font-size:11px;border:1px solid var(--line);border-radius:999px;padding:0 7px;line-height:16px}
.pal-sec-body{padding:8px 8px 2px}

/* grid editor */
.board-head{display:flex;gap:10px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.grid{position:relative;display:grid;gap:8px;background:var(--canvas);border:1px solid var(--line);border-radius:10px;padding:14px}
.cell{border:1px dashed var(--cell-line);border-radius:8px;min-height:64px}
.cell.over{border-color:var(--accent);background:rgba(47,143,255,.10)}
.tile{position:relative;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px;overflow:hidden;cursor:grab;display:flex;flex-direction:column;gap:4px}
.tile.sel{border-color:var(--accent);box-shadow:0 0 0 2px rgba(47,143,255,.35)}
.tile .t-type{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.tile .t-label{font-weight:600}
.tile .t-src{font-size:12px;color:var(--muted)}
.tile .t-demo{font-size:26px;font-weight:700;margin-top:auto}
.tile .rsz{position:absolute;right:2px;bottom:2px;width:14px;height:14px;cursor:nwse-resize;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);border-bottom-right-radius:4px}
.thr{display:flex;gap:6px;align-items:center;margin-bottom:6px}
.thr select,.thr input{width:auto;flex:1}
.token-box{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:8px;word-break:break-all;font-family:ui-monospace,Menlo,monospace;font-size:12px}
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:var(--panel2);color:var(--txt);border:1px solid var(--line);padding:10px 16px;border-radius:10px;box-shadow:var(--shadow);opacity:0;transition:opacity .2s;z-index:50}
.toast.show{opacity:1}
.toast.ok{background:#22c55e;color:#fff;border-color:#16a34a;font-weight:700;box-shadow:0 6px 20px rgba(34,197,94,.5)}
.toast.ok.show{animation:xlSavePop .42s ease-out}
@keyframes xlSavePop{0%{transform:translateX(-50%) scale(.82)}55%{transform:translateX(-50%) scale(1.07)}100%{transform:translateX(-50%) scale(1)}}
.toast.err{background:var(--red);color:#fff;border-color:color-mix(in srgb,var(--red) 55%,#000)}
.list-item{display:flex;gap:8px;align-items:center;padding:7px 9px;margin-bottom:5px;background:var(--panel2);border:1px solid var(--line);border-radius:8px;cursor:pointer}
.list-item.sel{border-color:var(--accent)}
.list-item .spacer{flex:1}

/* trash drop zone (drag a tile here to remove; Remove button still in inspector) */
.trash{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:14px;padding:14px 10px;border:1.5px dashed var(--line);border-radius:10px;color:var(--muted);font-size:12px;text-align:center;user-select:none;transition:border-color .15s,background .15s,color .15s}
.trash .trash-x{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--muted);font-size:11px}
.trash.armed{border-color:var(--red);color:var(--red);background:rgba(226,59,59,.10)}
.trash.armed .trash-x{border-color:var(--red)}

/* kiosk-token list + one-time pairing-URL card */
.tok-item{padding:8px 9px;margin-bottom:6px;background:var(--panel2);border:1px solid var(--line);border-radius:8px}
.tok-row{display:flex;align-items:center;gap:8px}
.tok-lbl{font-weight:600}
.tok-meta{font-size:11px;color:var(--muted);margin-top:2px}
.pill.tok-active{color:var(--ok);border-color:var(--ok)}
.pill.tok-revoked{color:var(--muted)}
.pill.tok-expired{color:var(--amber);border-color:var(--amber)}
.tok-new{margin-top:8px;padding:10px;border:1px solid var(--accent);border-radius:8px;background:rgba(47,143,255,.06)}


/* ===================================================================
   Admin editor shell - Refined Studio (merged in from admin.css).
   .xl-* rules are admin-only; the display renderer never sees them.
   =================================================================== */

/* ---- app frame ---------------------------------------------------------- */
.xl-app{display:flex;flex-direction:column;height:100vh;min-height:0}

/* ---- Floating panels: each region is a card on a tinted gutter ---------- */
.xl-app{padding:12px;gap:12px;background:linear-gradient(180deg,#e9eff7 0%,#dbe3f0 100%)}
html[data-theme="dark"] .xl-app{background:var(--gutter)}
.xl-top{border:1px solid color-mix(in srgb,var(--accent) 18%,var(--line));border-radius:14px;box-shadow:var(--shadow)}
.xl-shell{gap:12px}
.xl-left{border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
.xl-right{border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
.xl-center{background:var(--panel);border:1px solid color-mix(in srgb,var(--accent) 18%,var(--line));border-radius:14px;box-shadow:var(--shadow);overflow:hidden}

/* ---- top bar: context (left) vs actions (right) ------------------------- */
.xl-top{display:flex;align-items:center;gap:14px;flex:0 0 auto;
  padding:10px 16px;background:linear-gradient(180deg,#eceff5,#f7f9fc);border-bottom:1px solid #dce2ec}
html[data-theme="dark"] .xl-top{background:var(--panel)}
.xl-brand{justify-self:start;display:flex;align-items:center;font-size:17px;font-weight:700;letter-spacing:.4px}
.xl-brand span{color:var(--accent)}
.xl-board{display:flex;align-items:center;gap:8px}
.xl-board #boardSel{width:auto;min-width:200px;max-width:320px;font-weight:600;height:38px;padding:0 12px}
#hpbxBadge{height:38px;display:inline-flex;align-items:center;padding:0 11px;border-radius:8px}
#newBoard{height:38px;display:inline-flex;align-items:center;padding:0 14px}
.xl-actions{margin-left:auto;display:flex;align-items:center;gap:10px}

/* icon buttons (kebab + avatar) */
.xl-menuwrap{position:relative}
.xl-icon-btn{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;
  background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:9px;font-size:17px;line-height:1}
.xl-icon-btn:hover{border-color:var(--accent);background:var(--panel2)}
.xl-avatar{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-color:transparent;font-size:13px;font-weight:700;width:38px;height:38px}
.xl-avatar:hover{background:linear-gradient(135deg,var(--accent),var(--accent2))}
.xl-board-opts{display:inline-flex;align-items:center;justify-content:center;height:38px;padding:0 13px;font-size:18px;line-height:1}

/* dropdown menus */
.xl-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:210px;z-index:60;
  background:var(--panel);border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow);
  padding:6px;display:none}
.xl-menu.xl-menu-right{left:auto;right:0}
.xl-menu.open{display:block}
.xl-item{display:block;width:100%;text-align:left;background:none;border:0;border-radius:7px;
  padding:9px 11px;color:var(--txt);font:inherit;text-decoration:none}
.xl-item:hover{background:var(--panel2)}
.xl-item.danger-item{color:var(--red)}
.xl-item.danger-item:hover{background:rgba(226,59,59,.10)}
.xl-menu-sep{height:1px;background:var(--line);margin:6px 4px}
.xl-menu-id{padding:8px 11px 4px;font-size:12px;color:var(--muted)}
/* account menu: prominent profile header */
#who{display:flex;align-items:center;gap:10px;padding:10px 11px 12px}
.xl-me-av{width:32px;height:32px;flex:0 0 auto;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;line-height:1}
.xl-me-txt{display:flex;flex-direction:column;min-width:0;line-height:1.25}
.xl-me-name{font-weight:700;font-size:14px;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.xl-me-role{font-size:11px;color:var(--muted);text-transform:capitalize}
/* account menu: leading icons on each item */
.xl-item.xl-item-ic{display:flex;align-items:center;gap:10px}
.xl-mi-ic{flex:0 0 auto;width:16px;height:16px;display:inline-flex;opacity:.85}
.xl-mi-ic svg{width:16px;height:16px;display:block}
.xl-mi-label{min-width:0}

/* ---- three-column shell ------------------------------------------------- */
.xl-shell{flex:1 1 auto;display:grid;grid-template-columns:248px 1fr 320px;min-height:0}
.xl-col{overflow:auto;min-height:0;padding:14px}
.xl-left{border-right:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column}
.xl-right{border-left:1px solid var(--line);background:var(--panel);overflow:hidden;padding:0;display:flex;flex-direction:column}
.xl-center{background:var(--bg);padding:0;display:flex;flex-direction:column}

/* ---- palette ------------------------------------------------------------ */
.xl-left h3{margin:4px 2px 8px}
.xl-palhead{display:flex;align-items:center;justify-content:space-between;margin:9.5px 2px 20px}
.xl-palhead h3{margin:0}
.xl-palhead h3,.xl-insp-head h3,.xl-drawer-head h3{font-size:14px}
.xl-linkbtn{background:none;border:0;padding:2px 5px;border-radius:6px;color:var(--accent);font:inherit;font-size:12px;font-weight:600}
.xl-linkbtn:hover{background:var(--panel2)}
.xl-search{display:flex;align-items:center;gap:8px;background:var(--field);border:1px solid var(--field-border);
  border-radius:9px;padding:0 10px;margin-bottom:12px}
.xl-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px rgba(59,91,219,.18)}
.xl-search input{border:0;background:none;padding:9px 0;box-shadow:none}
.xl-search input:focus{box-shadow:none}
.xl-search-ic{color:var(--muted);font-size:14px}
#palette{flex:0 1 auto;overflow-x:hidden;overflow-y:auto}
/* search hides non-matching sections; matching ones force-open */
.pal-sec.nomatch{display:none}
.xl-left .trash{margin-top:12px;flex:0 0 auto}

/* --- palette hierarchy (overrides app.css; admin-only, display unaffected) --- */
/* each category carries its own accent colour via --cat */
.xl-left .palette-item[data-cat="queue"]{--cat:var(--accent)}
.xl-left .palette-item[data-cat="volume"]{--cat:var(--ok)}
.xl-left .palette-item[data-cat="outbound"]{--cat:#9b59b6}
.xl-left .palette-item[data-cat="presence"]{--cat:var(--amber)}
.xl-left .palette-item[data-cat="deco"]{--cat:var(--muted)}

.xl-left .pal-sec{border:0;background:transparent;margin-bottom:7px;overflow:visible}

/* header: a clear, colour-tagged bar - distinct from the items below it */
.xl-left .pal-sec>summary{
  display:flex;align-items:center;gap:9px;padding:10px 11px;list-style:none;cursor:pointer;
  background:var(--panel2);border:1px solid var(--line);border-radius:9px;
  font-size:13px;font-weight:600;color:var(--txt)}
.xl-left .pal-sec>summary:hover{border-color:var(--cat);color:var(--txt)}
.xl-left .pal-sec[open]>summary{
  background:color-mix(in srgb,var(--cat) 12%, var(--panel));
  border-color:color-mix(in srgb,var(--cat) 40%, var(--line));
  border-bottom-left-radius:0;border-bottom-right-radius:0;box-shadow:inset 3px 0 0 var(--cat)}
.xl-left .pal-sec .caret{flex:0 0 auto;border-left-color:var(--cat)}
.xl-left .pal-sec-dot{flex:0 0 auto;width:9px;height:9px;border-radius:50%;background:var(--cat)}
.xl-left .pal-sec-name{flex:1;letter-spacing:.1px}
.xl-left .pal-sec-n{
  flex:0 0 auto;font-size:11px;font-weight:700;color:var(--muted);
  background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:1px 8px;line-height:16px}

/* body: items sit in a white tray under the header, joined by a colour spine */
.xl-left .pal-sec-body{
  padding:6px;background:var(--panel);border:1px solid var(--line);border-top:0;
  border-bottom-left-radius:9px;border-bottom-right-radius:9px;box-shadow:inset 3px 0 0 var(--cat)}
.xl-left .palette-item{
  display:flex;align-items:center;gap:10px;padding:8px 10px;margin:6px 0;
  background:var(--panel2);border:0;border-radius:7px;cursor:grab;font-size:13px;color:var(--txt)}
.xl-left .palette-item:first-child{margin-top:0}
.xl-left .palette-item:last-child{margin-bottom:0}
.xl-left .palette-item:hover{background:color-mix(in srgb,var(--cat) 14%, var(--panel))}
.xl-left .palette-item::after{
  content:"";flex:0 0 auto;margin-left:auto;width:10px;height:15px;opacity:0;color:var(--muted);
  transition:opacity .12s ease,color .12s ease;
  background-image:radial-gradient(currentColor 1.5px,transparent 1.7px);background-size:5px 5px}
.xl-left .palette-item:hover::after{opacity:1;color:var(--accent)}
.xl-left .palette-item.disabled{opacity:.5;cursor:not-allowed}
.xl-left .palette-item.disabled:hover{background:var(--panel2)}
.xl-left .palette-item.disabled:hover::after{opacity:0}
.xl-tip{position:fixed;z-index:200;pointer-events:none;max-width:220px;
  background:linear-gradient(180deg,#ffffff,#eef2f8);color:#1b2733;font-size:11.5px;line-height:1.4;
  padding:6px 9px 6px 11px;border-radius:8px;border-left:3px solid var(--accent);
  border-top:1px solid rgba(16,24,40,.10);border-right:1px solid rgba(16,24,40,.10);border-bottom:1px solid rgba(16,24,40,.10);
  box-shadow:0 8px 22px rgba(16,24,40,.28)}
/* over a light-theme wall, flip to a dark bubble for contrast */
.xl-tip.t-onlight{background:linear-gradient(180deg,#1c2748,#141d36);color:#eef2f8;
  border-top-color:rgba(255,255,255,.08);border-right-color:rgba(255,255,255,.08);border-bottom-color:rgba(255,255,255,.08);
  box-shadow:0 8px 22px rgba(22,34,74,.32)}
.xl-left .palette-item .dot{width:8px;height:8px;background:var(--cat)}

/* ---- canvas toolbar ----------------------------------------------------- */
.xl-ctl input.xl-switch{width:17px;height:17px;accent-color:var(--accent);cursor:pointer;margin:0}
/* ---- title bar band ----------------------------------------------------- */
.xl-titlebar{display:flex;align-items:center;gap:16px;min-height:60px;padding:14px;margin:0 15px 12px;
  background:transparent;border-radius:12px;position:relative}
/* editor-only affordances; the live display uses its own .xlm-titlebar */
.xl-center .xl-titlebar{cursor:pointer;transition:background .15s ease,box-shadow .15s ease}
.xl-center .xl-titlebar:not(.sel):hover{background:rgba(59,91,219,.05)}
.xl-center .xl-titlebar.sel{background:rgba(59,91,219,.06);box-shadow:0 0 0 3px rgba(59,91,219,.28)}
.xl-titlebar .tb-zone{flex:1;display:flex;align-items:center;gap:16px;min-width:0}
.xl-titlebar .tb-zone.l{justify-content:flex-start}
.xl-titlebar .tb-zone.c{justify-content:center}
.xl-titlebar .tb-zone.r{justify-content:flex-end}
.xl-titlebar .tb-title{font-size:calc(23px * var(--tb-scale,1));font-weight:800;letter-spacing:-.015em;color:var(--txt);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.xl-titlebar .tb-title.empty{color:var(--muted);font-weight:500;font-style:italic;opacity:.5;font-size:17px}
.xl-titlebar .tb-clock{display:flex;flex-direction:column;line-height:1.04}
.xl-titlebar .tb-clock.l{align-items:flex-start}
.xl-titlebar .tb-clock.c{align-items:center}
.xl-titlebar .tb-clock.r{align-items:flex-end}
.xl-titlebar .tb-time{font-size:calc(23px * var(--tb-scale,1));font-weight:800;letter-spacing:-.01em;color:var(--accent);font-variant-numeric:tabular-nums}
.xl-titlebar .tb-date{font-size:calc(10.5px * var(--tb-scale,1));color:var(--muted);margin-top:2px;text-transform:uppercase;letter-spacing:.6px;white-space:nowrap}

/* ---- inspector: segmented position control + toggles -------------------- */
.xl-seg{display:flex;gap:4px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:3px;margin:3px 0 6px}
.xl-seg-btn{flex:1;border:0;background:none;border-radius:7px;padding:8px 4px;font:inherit;font-size:12px;font-weight:600;
  color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .12s ease,color .12s ease}
.xl-seg-btn:hover{background:rgba(59,91,219,.07);color:var(--txt)}
.xl-seg-btn.active,.xl-seg-btn.active:hover{background:var(--accent);color:#fff;box-shadow:0 1px 3px rgba(59,91,219,.35)}
.xl-seg-ic{position:relative;width:13px;height:9px;flex:0 0 auto}
.xl-seg-ic::before,.xl-seg-ic::after{content:"";position:absolute;height:2px;border-radius:1px;background:currentColor}
.xl-seg-ic::before{top:1px;left:0;width:100%}
.xl-seg-ic::after{bottom:1px;width:64%}
.xl-seg-ic.left::after{left:0}
.xl-seg-ic.center::after{left:50%;transform:translateX(-50%)}
.xl-seg-ic.right::after{right:0}
/* disabled segmented control (e.g. label size with no label set) */
.xl-seg.disabled{position:relative;cursor:not-allowed;background:var(--panel2)}
.xl-seg.disabled .xl-seg-btn,.xl-seg.disabled .xl-seg-btn:hover{cursor:not-allowed;color:var(--muted);opacity:.5;background:none;box-shadow:none}
.xl-seg.disabled .xl-seg-btn.active{background:var(--line);color:var(--txt);box-shadow:none}
.xl-seg.disabled[data-disabledtip]:hover::after{content:attr(data-disabledtip);
  position:absolute;left:50%;bottom:calc(100% + 9px);transform:translateX(-50%);
  background:#1e293b;color:#fff;font-size:11px;font-weight:500;line-height:1.4;
  padding:7px 11px;border-radius:8px;width:max-content;max-width:230px;white-space:normal;text-align:center;
  box-shadow:0 8px 22px rgba(2,6,23,.32);z-index:40;pointer-events:none}
.xl-seg.disabled[data-disabledtip]:hover::before{content:"";
  position:absolute;left:50%;bottom:calc(100% + 4px);transform:translateX(-50%);
  border:5px solid transparent;border-top-color:#1e293b;z-index:40;pointer-events:none}
.xl-fieldrow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0}
.xl-fieldrow .lbl{font-weight:600;font-size:13px;color:var(--txt)}
.xl-fieldrow .sub{font-size:11px;color:var(--muted);margin-top:2px}
.xl-divider{height:1px;background:var(--line);margin:9px 0}
.xl-toggle{position:relative;display:inline-block;width:38px;height:22px;flex:0 0 auto}
.xl-toggle input{position:absolute;opacity:0;width:0;height:0}
.xl-toggle .tk{position:absolute;inset:0;background:var(--cell-line);border-radius:999px;transition:background .15s ease;cursor:pointer}
.xl-toggle .tk::before{content:"";position:absolute;left:3px;top:3px;width:16px;height:16px;border-radius:50%;
  background:#fff;box-shadow:0 1px 2px rgba(16,24,40,.3);transition:transform .15s ease}
.xl-toggle input:checked + .tk{background:var(--accent)}
.xl-toggle input:checked + .tk::before{transform:translateX(16px)}
.xl-swatches{display:flex;flex-wrap:wrap;gap:8px;margin:4px 0 6px;position:relative}
.xl-swatch{width:24px;height:24px;border-radius:50%;border:2px solid var(--line);background:var(--sw);
  cursor:pointer;padding:0;position:relative;box-shadow:inset 0 0 0 2px var(--panel)}
.xl-swatch:hover{border-color:var(--muted)}
.xl-swatch.active{border-color:var(--accent);box-shadow:0 0 0 2px rgba(59,91,219,.28),inset 0 0 0 2px var(--panel)}
.xl-swatch.disabled{cursor:not-allowed;background-image:linear-gradient(rgba(248,250,252,.62),rgba(248,250,252,.62))}
.xl-swatch.disabled:hover{border-color:var(--line)}
/* tooltip explaining why swatches are disabled, anchored to the row so it stays on-page */
.xl-swatches[data-disabledtip]:has(.xl-swatch.disabled:hover)::after{content:attr(data-disabledtip);
  position:absolute;left:50%;bottom:calc(100% + 9px);transform:translateX(-50%);
  background:#1e293b;color:#fff;font-size:11px;font-weight:500;line-height:1.4;
  padding:7px 11px;border-radius:8px;width:max-content;max-width:220px;white-space:normal;text-align:center;
  box-shadow:0 8px 22px rgba(2,6,23,.32);z-index:40;pointer-events:none}
.xl-swatches[data-disabledtip]:has(.xl-swatch.disabled:hover)::before{content:"";
  position:absolute;left:50%;bottom:calc(100% + 4px);transform:translateX(-50%);
  border:5px solid transparent;border-top-color:#1e293b;z-index:40;pointer-events:none}
/* unsaved-changes ripple on the Save board button */
#save{position:relative}
#save.xl-dirty::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  animation:xlRipple 1.4s ease-out infinite}
@keyframes xlRipple{0%{box-shadow:0 0 0 0 rgba(34,197,94,.9)}70%{box-shadow:0 0 0 13px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
/* vivid green burst when a save succeeds */
#save.xl-saved{animation:xlSaveFlash .65s ease-out}
@keyframes xlSaveFlash{
  0%{box-shadow:0 0 0 0 rgba(34,197,94,.95), 0 0 18px 5px rgba(34,197,94,.8)}
  100%{box-shadow:0 0 0 16px rgba(34,197,94,0), 0 0 0 0 rgba(34,197,94,0)}}
.xl-warn{display:flex;align-items:flex-start;gap:9px;flex-wrap:wrap;margin:6px 0 8px;padding:9px 11px;
  border-radius:9px;font-size:12px;line-height:1.5;color:var(--txt);
  background:color-mix(in srgb,var(--amber) 13%,var(--panel));
  border:1px solid color-mix(in srgb,var(--amber) 38%,transparent)}
.xl-warn-ic{flex:0 0 auto;width:16px;height:16px;margin-top:1px;border-radius:50%;
  background:var(--amber);color:#fff;font-size:11px;font-weight:800;line-height:16px;text-align:center}
.xl-warn-tx{flex:1 1 150px;min-width:0}
.xl-warn-tx strong{font-weight:700}
.xl-warn-fix{appearance:none;cursor:pointer;font:inherit;font-size:12px;font-weight:600;padding:4px 11px;border-radius:7px;
  color:var(--txt);background:var(--panel);border:1px solid color-mix(in srgb,var(--amber) 45%,transparent)}
.xl-warn-fix:hover{background:color-mix(in srgb,var(--amber) 16%,var(--panel))}
.xl-canvasbar{flex:0 0 auto;display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding:10px 16px;background:linear-gradient(180deg,#f3f6ff,var(--panel));border-bottom:1px solid color-mix(in srgb,var(--accent) 22%,var(--line))}
html[data-theme="dark"] .xl-canvasbar{background:var(--panel)}
/* centre column title (BOARD) + its info button, matching WIDGETS/TILE */
.xl-panel-h{display:inline-flex;align-items:center;gap:6px;align-self:center}
.xl-panel-h-t{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}
/* info (i) buttons beside each panel title */
.xl-info-i{width:19px;height:19px;padding:0;border:0;background:none;border-radius:50%;cursor:pointer;
  color:var(--muted);vertical-align:middle;margin-left:6px;flex:0 0 auto;
  display:inline-flex;align-items:center;justify-content:center;transition:color .12s,background .12s}
.xl-info-i:hover{color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent)}
.xl-info-i svg{width:16px;height:16px;display:block}
.xl-insp-head .xl-info-i,.xl-panel-h .xl-info-i{margin-left:0}
/* panel description dialog (reuses the themed .xl-modal shell, so it adapts to light/dark) */
.xl-info-modal{max-width:470px}
.xl-info-body{color:var(--txt);font-size:13.5px;line-height:1.6;margin:15px 0 6px}
.xl-info-body p{margin:0 0 10px}
.xl-info-body ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:7px}
.xl-info-body strong{font-weight:700;color:var(--txt)}
.xl-info-modal .xl-modal-foot{justify-content:flex-end}
.xl-boardname{width:auto;min-width:180px;max-width:260px;font-weight:600;font-size:15px}
.xl-ctl{display:flex;align-items:center;gap:7px}
.xl-ctl-l{font-size:12px;color:var(--muted);white-space:nowrap}
.xl-ctl input[type=number]{width:60px}
#gridCols,#gridRows,#refresh,#boardTheme{padding:3px 10px;height:28px}
.xl-ctl select{width:auto}
.xl-x{color:var(--muted)}
.xl-unit{color:var(--muted);font-size:12px;margin-left:-3px}
.xl-spacer{flex:1}
.xl-settings{display:flex;align-items:center;align-self:center;gap:14px;flex-wrap:wrap;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:8px 12px}
.xl-tb-div{width:1px;align-self:stretch;background:color-mix(in srgb,var(--accent) 22%,var(--line));margin:3px 0}
.xl-canvas{flex:1 1 auto;overflow:auto;padding:18px;background-color:#eff3f9;
  box-shadow:inset 0 4px 0 -2px color-mix(in srgb,var(--accent) 45%,transparent),inset 0 3px 8px -4px rgba(16,24,40,.16)}
html[data-theme="dark"] .xl-canvas{background:var(--bg)}

/* Dark display preview: render the canvas (and its tiles) dark while the
   editor chrome stays light, so a dark board previews realistically. */
.xl-canvas[data-display="dark"]{
  --bg:#0f141b; --panel:#171f29; --panel2:#1f2a36; --line:#2b3947;
  --txt:#e7eef6; --muted:#8aa0b4; --accent:#2f8fff; --accent2:#1b6fd6;
  --ok:#37c871; --amber:#f5b53d; --red:#ef4d4d;
  --canvas:#0b0f15; --cell-line:#33425a; --field:#1f2a36; --field-border:#2b3947;
  --tile-shadow:0 1px 2px rgba(0,0,0,.4),0 8px 20px rgba(0,0,0,.45);
  background:linear-gradient(180deg,#11171f,#0b0f15);
  box-shadow:inset 0 4px 0 -2px color-mix(in srgb,var(--accent) 55%,transparent),inset 0 3px 10px -4px rgba(0,0,0,.6)}
.xl-canvas[data-display="dark"] .cell{background:transparent;border-color:var(--cell-line)}
.xl-empty{margin:6px 2px}

/* ---- inspector ---------------------------------------------------------- */
/* consistent control height so the Source-type select matches the Label input */
.xl-panes input:not([type=checkbox]),.xl-panes select{height:40px}
.xl-panes textarea{min-height:64px}
/* group separators so the tile options aren't one cramped stack */
.xl-group-h{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin:6px 0 4px}
.xl-insp-head{flex:0 0 auto;display:flex;align-items:center;gap:9px;padding:23px 15px 24px;border-bottom:1px solid var(--line)}
.xl-insp-head h3{margin:0}
.xl-tag{margin-left:auto;display:none;border-radius:8px}
#inspector.has-sel .xl-tag{display:inline-block;color:var(--accent);border-color:var(--accent)}
.xl-tabs{flex:0 0 auto;display:flex;gap:2px;padding:8px 12px 0;border-bottom:1px solid var(--line)}
.xl-tab{background:none;border:0;border-bottom:2px solid transparent;border-radius:0;color:var(--muted);
  font:inherit;font-weight:600;font-size:13px;padding:8px 12px;margin-bottom:-1px}
.xl-tab:hover{background:none;color:var(--txt)}
.xl-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.xl-panes{flex:1 1 auto;overflow:auto;padding:15px}
/* clearer vertical rhythm inside the tile/title-bar inspector (scoped, so modals keep their tighter spacing) */
.xl-panes label:not(.xl-toggle){margin:16px 0 6px}
.xl-panes .xl-tabpane>*:first-child{margin-top:0}
.xl-panes input:not([type=checkbox]),.xl-panes select,.xl-panes textarea{margin-bottom:2px}
.xl-panes .xl-seg{margin:6px 0 10px}
.xl-panes .xl-swatches{margin:6px 0 10px}
.xl-panes .xl-fieldrow{padding:12px 0}
/* section breaks (Appearance / Size): a rule plus generous air, then the heading */
.xl-panes .xl-divider{margin:14px 0 0}
.xl-panes .xl-group-h{margin:8px 0 10px}
.xl-tabpane{display:none}
.xl-tabpane.active{display:block}

/* idle inspector: centered graphic + guidance (no tile selected) */
#inspector:not(.has-sel) .xl-panes{display:flex;flex-direction:column}
#inspector:not(.has-sel) .xl-tabpane.active{flex:1 1 auto;display:flex}
.xl-empty-state{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:14px;padding:32px 28px;color:var(--muted)}
.xl-empty-state svg{width:92px;height:92px}
.xl-empty-state h4{margin:0;font-size:15px;font-weight:700;color:var(--txt)}
.xl-empty-state p{margin:0;font-size:13px;line-height:1.55;max-width:230px}
.xl-insp-foot{flex:0 0 auto;padding:12px 15px;border-top:1px solid var(--line)}
.xl-insp-foot:empty{display:none}
#inspector:not(.has-sel) .xl-tabs{display:none}

/* ---- displays drawer (board-level kiosk tokens) ------------------------- */
.xl-scrim{position:fixed;inset:0;background:rgba(12,18,26,.42);opacity:0;visibility:hidden;
  transition:opacity .2s,visibility .2s;z-index:70}
.xl-scrim.open{opacity:1;visibility:visible}
.xl-drawer{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:92vw;z-index:80;
  background:var(--panel);border-left:1px solid var(--line);box-shadow:var(--shadow);
  transform:translateX(100%);transition:transform .22s ease;display:flex;flex-direction:column}
.xl-drawer.open{transform:none}
.xl-drawer-head{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line)}
.xl-drawer-body{flex:1 1 auto;overflow:auto;padding:16px}

/* ---- Cobalt tiles: white cards, soft elevation, category dot ----------- */
.tile .t-type{font-weight:700}
.xl-center [data-cat="queue"]{--cat:var(--accent)}
.xl-center [data-cat="volume"]{--cat:var(--ok)}
.xl-center [data-cat="outbound"]{--cat:#9b59b6}
.xl-center [data-cat="presence"]{--cat:var(--amber)}
.xl-center [data-cat="deco"]{--cat:var(--muted)}
.xl-center .tile{
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:12px 22px;box-shadow:var(--tile-shadow);overflow:hidden;
  display:flex;flex-direction:column;min-height:0;
  transition:box-shadow .15s ease,border-color .15s ease,transform .15s ease}
.xl-center .tile .t-type{display:flex;align-items:center;gap:7px;flex:0 0 auto;white-space:nowrap;overflow:hidden}
.xl-center .tile .t-label{font-size:calc(1em * var(--label-scale,1));color:var(--txt);flex:0 0 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.xl-center .tile.al-left{text-align:left}
.xl-center .tile.al-center{text-align:center}
.xl-center .tile.al-center .t-type{justify-content:center}
.xl-center .tile.al-right{text-align:right}
.xl-center .tile.al-right .t-type{justify-content:flex-end}
.xl-center .tile .t-dot{flex:0 0 auto;width:7px;height:7px;border-radius:50%;background:var(--cat,var(--muted))}
.xl-center .tile:not(.sel):hover{border-color:#cdd8ec;transform:translateY(-1px);
  box-shadow:0 2px 4px rgba(16,24,40,.06),0 12px 24px rgba(16,24,40,.10)}
.xl-center .tile.sel{border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,91,219,.28),var(--tile-shadow)}
.xl-center .tile .rsz{right:8px;bottom:8px;opacity:0;transition:opacity .15s ease}
.xl-center .tile:hover .rsz,.xl-center .tile.sel .rsz{opacity:1}
/* move grab handle (top-right); the body no longer advertises grab so the handle reads as the move point */
.xl-center .tile{cursor:default}
.xl-center .tile .t-move{position:absolute;top:6px;right:7px;width:17px;height:19px;
  display:flex;align-items:center;justify-content:center;border-radius:5px;
  cursor:grab;opacity:0;transition:opacity .15s ease,background .15s ease}
.xl-center .tile .t-move:hover{background:rgba(120,140,180,.16)}
.xl-center .tile .t-move:active{cursor:grabbing}
.xl-center .tile .t-move svg circle{fill:var(--muted)}
.xl-center .tile:hover .t-move,.xl-center .tile.sel .t-move{opacity:1}
.xl-center .tile.tile-filled .t-move svg circle{fill:var(--tile-fg)}
.xl-center .tile .t-src{font-size:12px;color:var(--txt);font-weight:600;flex:0 0 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.xl-center .tile.alarmed{box-shadow:inset 5px 0 0 var(--alarm),var(--tile-shadow)}
.xl-center .tile.alarmed .pv-value{color:var(--alarm)}
.xl-center .tile.alarmed .pv-value .u{color:var(--alarm);opacity:.65}
/* coloured tile (static colour or whole-tile alarm fill): text follows --tile-fg */
.xl-center .tile.tile-filled{background:var(--tile-surface);border-color:transparent;box-shadow:var(--tile-shadow)}
.xl-center .tile.tile-filled .t-type,
.xl-center .tile.tile-filled .t-src,
.xl-center .tile.tile-filled .pv-sub,
.xl-center .tile.tile-filled .pv-clock2 .dt{color:var(--tile-fg);opacity:.82}
.xl-center .tile.tile-filled .t-label,
.xl-center .tile.tile-filled .pv-value,
.xl-center .tile.tile-filled .pv-value .u,
.xl-center .tile.tile-filled .pv-clock2 .tm,
.xl-center .tile.tile-filled .pv-message,
.xl-center .tile.tile-filled .pv-lb .nm{color:var(--tile-fg)}
.xl-center .tile.tile-filled .pv-lb .rank{background:color-mix(in srgb,var(--tile-fg) 22%,transparent);color:var(--tile-fg)}
.xl-center .tile.tile-filled .pv-lb .vl{color:var(--tile-fg)}
.xl-center .tile.tile-filled .t-dot{background:var(--tile-fg)}

/* ---- editor tile previews (mini live render with sample data) ---- */
.xl-center .t-prev{flex:1 1 auto;min-height:0;overflow:hidden}
.xl-center .t-prev.pv-num2{display:flex;flex-direction:column;justify-content:center}
.xl-center .t-prev.pv-lb,.xl-center .t-prev.pv-message{margin-top:8px}
.xl-center .pv-value{font-size:48px;font-weight:800;letter-spacing:-.025em;color:var(--tile-fg,var(--txt));line-height:1;white-space:nowrap;font-variant-numeric:tabular-nums}
.xl-center .pv-value.lead-one{margin-left:-.1em}   /* cancel the wide left bearing of a leading 1 */
.xl-center .tile.has-label .pv-value{font-size:36px}   /* crowded tiles: keep the value inside */
.xl-center .pv-value .u{font-size:.46em;font-weight:700;color:var(--muted);margin-left:2px}
.xl-center .pv-sub{font-size:11px;color:var(--muted);margin-top:3px}
.xl-center .pv-lb{display:flex;flex-direction:column;gap:8px;width:100%}
.xl-center .pv-lb .row{display:flex;align-items:center;gap:9px}
.xl-center .pv-lb .rank{flex:0 0 auto;width:20px;height:20px;border-radius:50%;background:var(--accent);
  color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center}
.xl-center .pv-lb .nm{flex:1 1 auto;font-size:13px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.xl-center .pv-lb .vl{flex:0 0 auto;font-size:13px;font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}
.xl-center .pv-message{font-size:15px;font-weight:700;color:var(--txt);line-height:1.3;
  overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.xl-center .pv-clock2 .tm{font-size:28px;font-weight:800;letter-spacing:-.01em;color:var(--txt);font-variant-numeric:tabular-nums;line-height:1}
.xl-center .pv-clock2 .dt{font-size:11px;color:var(--muted);margin-top:3px}
.xl-center .cell{background:rgba(59,91,219,.05);border-radius:12px;min-height:80px;position:relative;border-color:color-mix(in srgb,var(--accent) 30%,var(--cell-line))}
.xl-center .cell.over{border-color:var(--accent);background:rgba(59,91,219,.10)}
.xl-center .cell::after{content:"";position:absolute;left:50%;top:50%;width:15px;height:15px;
  transform:translate(-50%,-50%);opacity:.32;transition:opacity .15s ease;
  background:linear-gradient(var(--accent),var(--accent)) center/15px 1.6px no-repeat,
             linear-gradient(var(--accent),var(--accent)) center/1.6px 15px no-repeat}
.xl-center .cell.over::after{opacity:.9}
html[data-theme="dark"] .xl-center .cell{background:transparent;border-color:var(--cell-line)}
.xl-canvas-hint{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;
  margin:48px auto 0;max-width:340px;padding:0 20px;color:var(--muted);pointer-events:none}
.xl-canvas-hint svg{width:84px;height:84px}
.xl-canvas-hint .ch-t{font-size:15px;font-weight:700;color:var(--txt)}
.xl-canvas-hint .ch-s{font-size:13px;line-height:1.55;max-width:280px}

/* ---- lift: primary CTA gradient + outlined destructive action ---------- */
#save{background-image:linear-gradient(180deg,#4a68e6,#3b5bdb)}
#save:hover{background-image:linear-gradient(180deg,#3f5ce0,#3251cf)}
.xl-insp-foot button.danger{background:transparent;color:var(--red);border:1px solid color-mix(in srgb,var(--red) 45%,var(--line))}
.xl-insp-foot button.danger:hover{background:color-mix(in srgb,var(--red) 10%,var(--panel));border-color:var(--red)}

@media (max-width:1100px){
  .xl-shell{grid-template-columns:210px 1fr 280px}
}
