/* Wedget components - the reusable class library. Depends on tokens.css + base.css.
 * This is the anti-glitch foundation: every page uses these classes, no one-off inline styles. */

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:var(--fw-semi);font-size:14.5px;line-height:1;
  padding:11px 18px;border-radius:var(--r);border:1px solid transparent;background:var(--bg-card);
  color:var(--text-strong);cursor:pointer;white-space:nowrap;user-select:none;
  transition:background .15s,border-color .15s,box-shadow .15s,transform .08s,color .15s}
.btn:active{transform:translateY(.5px)}
.btn[disabled],.btn.is-loading{opacity:.55;pointer-events:none}
.btn svg{width:18px;height:18px;flex:none}
.btn--primary{background:var(--color-primary);color:var(--text-on-primary);box-shadow:var(--shadow-btn-sm)}
.btn--primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-btn)}
.btn--ghost{background:var(--bg-card);border-color:var(--border);color:var(--text-strong)}
.btn--ghost:hover{background:var(--surface-1);border-color:var(--slate-300)}
.btn--subtle{background:var(--blue-50);color:var(--color-primary);border-color:transparent}
.btn--subtle:hover{background:var(--blue-100)}
.btn--danger{background:var(--white);color:var(--color-danger);border-color:#f3c9c9}
.btn--danger:hover{background:var(--red-50)}
.btn--danger-solid{background:var(--color-danger);color:#fff}
.btn--danger-solid:hover{background:var(--red-500)}
.btn--quiet{background:transparent;color:var(--text-muted);padding:8px 10px}
.btn--quiet:hover{background:var(--surface-4);color:var(--text-strong)}
.btn--sm{padding:8px 13px;font-size:13px;border-radius:var(--r-sm)}
.btn--lg{padding:14px 24px;font-size:16px;border-radius:var(--r)}
.btn--icon{padding:9px;border-radius:var(--r-sm);width:38px;height:38px}
.btn--block{width:100%}
.btn--pill{border-radius:var(--r-pill)}
.btn .spin{width:15px;height:15px;border-width:2px}

/* ============ FORM CONTROLS ============ */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field > label,.label{font-size:13px;font-weight:var(--fw-semi);color:var(--text-strong)}
.field .hint{font-size:12px;color:var(--text-muted)}
.field .err{font-size:12px;color:var(--color-danger);font-weight:var(--fw-med)}
.input,.textarea,.select{width:100%;background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:10px 13px;font-size:14.5px;color:var(--text-strong);
  transition:border-color .15s,box-shadow .15s;outline:none}
.input::placeholder,.textarea::placeholder{color:var(--text-faint)}
.input:focus,.textarea:focus,.select:focus{border-color:var(--color-primary);box-shadow:var(--ring)}
.input[aria-invalid="true"],.textarea[aria-invalid="true"]{border-color:var(--color-danger)}
.textarea{resize:vertical;min-height:84px;line-height:1.5}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:38px;cursor:pointer}
.input--sm{padding:8px 11px;font-size:13.5px}
.inputgroup{display:flex;align-items:stretch}
.inputgroup .input{border-radius:var(--r-sm) 0 0 var(--r-sm)}
.inputgroup .btn{border-radius:0 var(--r-sm) var(--r-sm) 0}

/* checkbox */
.checkbox{display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-size:14px;color:var(--text)}
.checkbox input{position:absolute;opacity:0;width:0;height:0}
.checkbox .box{width:18px;height:18px;border:1.5px solid var(--slate-300);border-radius:5px;background:#fff;
  flex:none;display:flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s}
.checkbox .box svg{width:12px;height:12px;color:#fff;opacity:0;transform:scale(.6);transition:.12s}
.checkbox input:checked + .box{background:var(--color-primary);border-color:var(--color-primary)}
.checkbox input:checked + .box svg{opacity:1;transform:scale(1)}
.checkbox input:focus-visible + .box{box-shadow:var(--ring)}

/* switch (the styled toggle the settings tabs need) */
.switch{position:relative;display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:var(--text)}
.switch input{position:absolute;opacity:0;width:0;height:0}
.switch .track{width:38px;height:22px;border-radius:var(--r-pill);background:var(--slate-300);
  flex:none;transition:background .18s;position:relative}
.switch .track::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;
  background:#fff;box-shadow:0 1px 3px rgba(15,23,42,.3);transition:transform .18s}
.switch input:checked + .track{background:var(--color-primary)}
.switch input:checked + .track::after{transform:translateX(16px)}
.switch input:focus-visible + .track{box-shadow:var(--ring)}

/* segmented control (priority, billing toggle, etc.) */
.segmented{display:inline-flex;background:var(--surface-4);border:1px solid var(--border-2);
  border-radius:var(--r-sm);padding:3px;gap:2px}
.segmented button{padding:6px 13px;font-size:13px;font-weight:var(--fw-semi);color:var(--text-muted);
  border-radius:7px;transition:.15s;white-space:nowrap}
.segmented button:hover{color:var(--text-strong)}
.segmented button.is-active{background:#fff;color:var(--color-primary);box-shadow:var(--shadow-xs)}

/* color swatch input */
.colorpick{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--border);border-radius:var(--r-sm);
  padding:5px 11px 5px 6px;background:#fff}
.colorpick input[type=color]{width:30px;height:30px;border:0;padding:0;background:none;border-radius:7px;cursor:pointer}
.colorpick .val{font-size:13px;font-family:var(--font-body);color:var(--text);text-transform:uppercase;letter-spacing:.02em}

/* ============ CARDS / PANELS ============ */
.card{background:var(--bg-card);border:1px solid var(--border-2);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.card--pad{padding:24px}
.card--flat{box-shadow:none}
.card--hover{transition:transform .16s,box-shadow .2s,border-color .15s}
.card--hover:hover{transform:translateY(-2px);box-shadow:var(--shadow-card);border-color:var(--border)}
.panel{background:var(--bg-card);border:1px solid var(--border-2);border-radius:var(--r-md)}
.kv{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--border-3);font-size:13.5px}
.kv:last-child{border-bottom:0}
.kv .k{color:var(--text-muted)}.kv .v{color:var(--text-strong);font-weight:var(--fw-med);text-align:right}

/* ============ BADGES / TAGS / PILLS ============ */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:var(--fw-bold);
  padding:3px 9px;border-radius:var(--r-pill);letter-spacing:.01em;line-height:1.4}
.badge--blue{background:var(--blue-50);color:var(--color-primary);border:1px solid var(--blue-100)}
.badge--green{background:var(--green-50);color:var(--green-700)}
.badge--amber{background:var(--amber-50);color:var(--amber-700)}
.badge--red{background:var(--red-50);color:var(--color-danger)}
.badge--gray{background:var(--surface-4);color:var(--text-muted)}
.badge--solid{background:var(--color-primary);color:#fff}
.tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:var(--fw-semi);
  padding:4px 10px;border-radius:var(--r-pill);background:var(--surface-4);color:var(--text);border:1px solid transparent}
.tag .dot{width:7px;height:7px;border-radius:50%;flex:none;background:currentColor}
.tag .x{margin-left:1px;opacity:.55;font-size:13px;line-height:1;cursor:pointer}
.tag .x:hover{opacity:1}
.pill{display:inline-flex;align-items:center;gap:8px;background:var(--blue-50);border:1px solid var(--blue-100);
  color:var(--color-primary);font-weight:var(--fw-semi);font-size:13px;padding:6px 13px;border-radius:var(--r-pill)}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--color-primary)}

/* ============ AVATAR ============ */
.avatar{width:36px;height:36px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  font-weight:var(--fw-bold);font-size:13px;color:#fff;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));
  background-size:cover;background-position:center;overflow:hidden;text-transform:uppercase}
.avatar--sm{width:28px;height:28px;font-size:11px}
.avatar--lg{width:46px;height:46px;font-size:16px}
.avatar .pdot{position:absolute}
.presence{position:relative}
.presence::after{content:"";position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;border-radius:50%;
  border:2px solid #fff;background:var(--slate-400)}
.presence.is-online::after{background:var(--green-500)}
.presence.is-away::after{background:var(--amber)}

/* ============ TABS ============ */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);overflow-x:auto}
.tabs::-webkit-scrollbar{height:0}
.tab{padding:11px 14px;font-size:14px;font-weight:var(--fw-semi);color:var(--text-muted);
  border-bottom:2px solid transparent;white-space:nowrap;transition:color .15s,border-color .15s}
.tab:hover{color:var(--text-strong)}
.tab.is-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}
.tabs--pills{border:0;gap:6px}
.tabs--pills .tab{border:0;border-radius:var(--r-pill);padding:7px 14px;background:var(--surface-4)}
.tabs--pills .tab.is-active{background:var(--blue-50);color:var(--color-primary)}

/* ============ MODAL ============ */
/* base hidden rule baked in so it can NEVER go missing (the bug that broke the old auth modal) */
.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;visibility:hidden;transition:opacity .18s,visibility .18s}
.modal.is-open{opacity:1;visibility:visible}
.modal__scrim{position:absolute;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(2px)}
.modal__card{position:relative;background:#fff;border-radius:var(--r-xl);box-shadow:var(--shadow-pop);
  width:min(460px,100%);max-height:90vh;overflow:auto;transform:translateY(10px) scale(.98);transition:transform .22s cubic-bezier(.34,1.3,.5,1)}
.modal.is-open .modal__card{transform:none}
.modal__card--wide{width:min(720px,100%)}
.modal__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:20px 22px 0}
.modal__title{font-family:var(--font-head);font-weight:var(--fw-x);font-size:19px;color:var(--ink)}
.modal__body{padding:18px 22px}
.modal__foot{display:flex;justify-content:flex-end;gap:10px;padding:0 22px 20px}
.modal__x{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}
.modal__x:hover{background:var(--surface-4);color:var(--text-strong)}

/* ============ TOASTS (queue) ============ */
.toast-stack{position:fixed;z-index:1200;right:18px;bottom:18px;display:flex;flex-direction:column;gap:10px;
  max-width:min(380px,calc(100vw - 36px));pointer-events:none}
.toast{display:flex;align-items:flex-start;gap:10px;background:#fff;border:1px solid var(--border);
  border-left:3px solid var(--color-primary);border-radius:var(--r-sm);box-shadow:var(--shadow-pop);
  padding:12px 14px;font-size:13.5px;color:var(--text-strong);pointer-events:auto;
  animation:toast-in .22s cubic-bezier(.34,1.3,.5,1)}
.toast.is-out{animation:toast-out .2s forwards}
.toast--success{border-left-color:var(--green-600)}
.toast--error{border-left-color:var(--color-danger)}
.toast--info{border-left-color:var(--color-primary)}
.toast .ico{flex:none;margin-top:1px}
.toast .msg{flex:1;line-height:1.4}
.toast .x{color:var(--text-faint);cursor:pointer;font-size:15px;line-height:1}
@keyframes toast-in{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}
@keyframes toast-out{to{opacity:0;transform:translateX(16px)}}

/* ============ SKELETON / SPINNER ============ */
.skeleton{background:linear-gradient(100deg,#eef2f7 30%,#f6f8fb 50%,#eef2f7 70%);background-size:200% 100%;
  animation:sk 1.3s linear infinite;border-radius:8px}
@keyframes sk{to{background-position:-200% 0}}
.spin{width:22px;height:22px;border:2.5px solid var(--border);border-top-color:var(--color-primary);
  border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============ DROPDOWN MENU ============ */
.menu{position:absolute;z-index:50;background:#fff;border:1px solid var(--border);border-radius:var(--r-md);
  box-shadow:var(--shadow-pop);padding:6px;min-width:180px}
.menu button,.menu a{display:flex;align-items:center;gap:9px;width:100%;text-align:left;padding:8px 10px;
  border-radius:8px;font-size:13.5px;color:var(--text-strong)}
.menu button:hover,.menu a:hover{background:var(--surface-4)}
.menu hr{margin:5px 4px}

/* ============ LOGO LOCKUP ============ */
.brand{display:inline-flex;align-items:center;gap:9px}
.brand .mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--blue-600),var(--blue-700));
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-btn-sm);flex:none}
.brand .mark svg{width:18px;height:18px;color:#fff}
.brand .word{font-family:var(--font-head);font-weight:var(--fw-x);font-size:19px;letter-spacing:-.02em;color:var(--ink)}
.brand .word .dot{color:var(--color-primary)}

/* shared empty-state */
.empty{text-align:center;color:var(--text-muted);font-size:14px;padding:48px 24px}
.empty .emoji{font-size:30px;margin-bottom:10px}
.empty .e-title{font-size:15px;font-weight:var(--fw-semi);color:var(--text-strong);margin-bottom:5px}
.empty .e-cta{margin-top:14px}

/* ============ CUSTOM DROPDOWN / SELECT (window.WedgetDropdown) ============ */
/* a button + popover menu - keyboard accessible, NOT a native <select> */
.dd{position:relative;display:inline-block}
.dd--block{display:block;width:100%}
.dd-trigger{display:flex;align-items:center;gap:8px;width:100%;background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:9px 12px;font-size:13.5px;color:var(--text-strong);cursor:pointer;font-weight:var(--fw-med);
  transition:border-color .15s,box-shadow .15s;text-align:left}
.dd-trigger:hover{border-color:var(--slate-300)}
.dd-trigger.is-open,.dd-trigger:focus-visible{border-color:var(--color-primary);box-shadow:var(--ring);outline:none}
.dd-trigger .dd-val{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:7px}
.dd-trigger .dd-val.is-placeholder{color:var(--text-faint);font-weight:var(--fw-reg)}
.dd-trigger .dd-caret{flex:none;color:var(--text-faint);transition:transform .18s}
.dd-trigger.is-open .dd-caret{transform:rotate(180deg)}
.dd-trigger--sm{padding:6px 10px;font-size:12.5px;border-radius:8px}
.dd-trigger--ghost{background:transparent;border-color:transparent}
.dd-trigger--ghost:hover{background:var(--surface-4)}

.dd-pop{position:absolute;z-index:90;min-width:100%;max-height:300px;overflow-y:auto;margin-top:5px;
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-pop);padding:5px;
  opacity:0;transform:translateY(-6px) scale(.98);transform-origin:top;pointer-events:none;
  transition:opacity .14s,transform .16s cubic-bezier(.34,1.3,.5,1)}
.dd-pop.is-open{opacity:1;transform:none;pointer-events:auto}
.dd-pop--up{top:auto;bottom:calc(100% + 5px);transform-origin:bottom;transform:translateY(6px) scale(.98)}
.dd-pop--right{right:0;left:auto}
.dd-search{display:flex;align-items:center;gap:7px;padding:7px 9px;margin-bottom:4px;border-bottom:1px solid var(--border-3)}
.dd-search input{flex:1;border:0;outline:none;background:none;font-size:13px;color:var(--text-strong)}
.dd-search svg{width:15px;height:15px;color:var(--text-faint)}
.dd-opt{display:flex;align-items:center;gap:9px;width:100%;text-align:left;padding:8px 10px;border-radius:8px;
  font-size:13.5px;color:var(--text-strong);cursor:pointer;font-weight:var(--fw-med)}
.dd-opt:hover,.dd-opt.is-cursor{background:var(--surface-4)}
.dd-opt.is-sel{color:var(--color-primary);font-weight:var(--fw-semi)}
.dd-opt .dd-ico{flex:none;display:flex;align-items:center;width:18px}
.dd-opt .dd-ico svg{width:16px;height:16px}
.dd-opt .dd-check{margin-left:auto;color:var(--color-primary);opacity:0}
.dd-opt.is-sel .dd-check{opacity:1}
.dd-opt .dd-sub{font-size:11.5px;color:var(--text-muted);font-weight:var(--fw-reg)}
.dd-opt-col{display:flex;flex-direction:column;min-width:0;flex:1}
.dd-opt-col .dd-t{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.menu-pop{min-width:unset}
.dd-sep{height:1px;background:var(--border-3);margin:4px 2px}
.dd-empty{padding:14px;text-align:center;font-size:12.5px;color:var(--text-muted)}
.dd-dot{width:9px;height:9px;border-radius:50%;flex:none}

/* multiselect (tags) */
.ms-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.ms-opt .box{width:17px;height:17px;border:1.5px solid var(--slate-300);border-radius:5px;flex:none;display:flex;
  align-items:center;justify-content:center;transition:.12s}
.ms-opt.is-sel .box{background:var(--color-primary);border-color:var(--color-primary)}
.ms-opt.is-sel .box svg{color:#fff;width:11px;height:11px}
.ms-opt:not(.is-sel) .box svg{opacity:0}

/* ============ COMMAND PALETTE (Cmd/Ctrl-K) ============ */
.palette-scrim{position:fixed;inset:0;z-index:1300;background:rgba(15,23,42,.45);backdrop-filter:blur(3px);
  display:flex;align-items:flex-start;justify-content:center;padding:14vh 16px 16px;
  opacity:0;visibility:hidden;transition:opacity .16s,visibility .16s}
.palette-scrim.is-open{opacity:1;visibility:visible}
.palette{width:min(580px,100%);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);
  box-shadow:var(--shadow-hero);overflow:hidden;transform:translateY(-12px) scale(.97);
  transition:transform .2s cubic-bezier(.34,1.3,.5,1)}
.palette-scrim.is-open .palette{transform:none}
.palette-in{display:flex;align-items:center;gap:11px;padding:15px 18px;border-bottom:1px solid var(--hairline)}
.palette-in svg{width:19px;height:19px;color:var(--text-faint);flex:none}
.palette-in input{flex:1;border:0;outline:none;background:none;font-size:16px;color:var(--text-strong);font-weight:var(--fw-med)}
.palette-in input::placeholder{color:var(--text-faint)}
.palette-list{max-height:50vh;overflow-y:auto;padding:7px}
.palette-grp{font-size:10.5px;font-weight:var(--fw-bold);color:var(--text-faint);text-transform:uppercase;
  letter-spacing:.06em;padding:9px 11px 5px}
.palette-row{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:var(--r-sm);cursor:pointer}
.palette-row.is-cursor{background:var(--blue-50)}
.palette-row .pi{width:30px;height:30px;border-radius:8px;background:var(--surface-4);display:flex;align-items:center;justify-content:center;flex:none;color:var(--text-muted)}
.palette-row.is-cursor .pi{background:var(--bg-card);color:var(--color-primary)}
.palette-row .pi svg{width:17px;height:17px}
.palette-row .pl{flex:1;min-width:0}
.palette-row .pl .pt{font-size:14px;font-weight:var(--fw-semi);color:var(--text-strong);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.palette-row .pl .ps{font-size:11.5px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.palette-row .pk{font-size:11px;color:var(--text-faint);display:flex;gap:3px;flex:none}
.palette-row .pk kbd{background:var(--surface-4);border-radius:5px;padding:2px 6px;font-family:var(--font-body);font-weight:var(--fw-semi);font-size:11px}
.palette-empty{padding:30px;text-align:center;color:var(--text-muted);font-size:13.5px}
.palette-foot{display:flex;gap:14px;padding:9px 16px;border-top:1px solid var(--hairline);font-size:11px;color:var(--text-faint)}
.palette-foot .fk{display:inline-flex;align-items:center;gap:5px}
.palette-foot kbd{background:var(--surface-4);border-radius:4px;padding:1px 5px;font-family:var(--font-body);font-weight:var(--fw-semi)}

/* ============ LIGHTBOX ============ */
.lightbox{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(15,23,42,.82);backdrop-filter:blur(2px);opacity:0;transition:opacity .2s;cursor:zoom-out}
.lightbox.is-open{opacity:1}
.lightbox-img{max-width:92vw;max-height:90vh;border-radius:14px;box-shadow:var(--shadow-hero);transform:scale(.96);transition:transform .22s cubic-bezier(.34,1.3,.5,1)}
.lightbox.is-open .lightbox-img{transform:none}

/* ============ DESKTOP NOTIFICATION TOAST (in-app) ============ */
.note-toast{display:flex;align-items:flex-start;gap:11px;background:var(--bg-card);border:1px solid var(--border);
  border-left:3px solid var(--color-primary);border-radius:var(--r-md);box-shadow:var(--shadow-pop);padding:12px 14px;cursor:pointer;
  pointer-events:auto;animation:toast-in .22s cubic-bezier(.34,1.3,.5,1);max-width:340px}
.note-toast .ntb{flex:1;min-width:0}
.note-toast .nt-t{font-size:13.5px;font-weight:var(--fw-semi);color:var(--text-strong)}
.note-toast .nt-b{font-size:12.5px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}

/* seat-usage meter */
.seatbar{height:6px;border-radius:3px;background:var(--surface-4);overflow:hidden;margin-top:6px}
.seatbar i{display:block;height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s}
.seatbar.is-full i{background:var(--amber)}

/* ============ ADDITIONS for the Intercom/Tidio rebuild ============ */

/* AI spark button - subtle gradient accent for AI affordances */
.btn--ai{background:linear-gradient(135deg,var(--blue-600),#7c3aed);color:#fff;border-color:transparent}
.btn--ai:hover{filter:brightness(1.06);box-shadow:var(--shadow-btn)}
.btn--ai svg{width:17px;height:17px}

/* inline verified check badge */
.vbadge{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;
  background:var(--color-primary);color:#fff;flex:none}
.vbadge svg{width:10px;height:10px}

/* section title with optional action on the right */
.sec-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 12px}
.sec-title h4{font-size:15px}
.sec-title .muted{font-size:12.5px}

/* copyable code/value field (install snippets, DNS, list ids) */
.copyfield{display:flex;align-items:center;gap:8px;background:var(--ink);border-radius:var(--r-md);padding:12px 14px;overflow:auto}
.copyfield code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;color:#cfe0ff;white-space:pre;flex:1;min-width:0}
.copyfield .cp-btn{flex:none;color:#cfe0ff;background:rgba(255,255,255,.08);border-radius:7px;padding:6px 10px;font-size:12px;font-weight:var(--fw-semi)}
.copyfield .cp-btn:hover{background:rgba(255,255,255,.16)}

/* small stat pill (resolution rate, online count) */
.stat-pill{display:inline-flex;align-items:center;gap:7px;background:var(--surface-4);border-radius:var(--r-pill);
  padding:5px 12px;font-size:12.5px;font-weight:var(--fw-semi);color:var(--text)}
.stat-pill b{color:var(--text-strong)}
.stat-pill.is-green{background:var(--green-50);color:var(--green-700)}

/* generic slide-over panel base (campaign/lead editors on tablet) */
.sheet-scrim{position:fixed;inset:0;z-index:1000;background:rgba(15,23,42,.45);backdrop-filter:blur(2px);
  opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}
.sheet-scrim.is-open{opacity:1;visibility:visible}
.sheet{position:fixed;top:0;right:0;bottom:0;width:min(520px,100%);background:var(--bg-card);box-shadow:var(--shadow-pop);
  display:flex;flex-direction:column;transform:translateX(100%);transition:transform .26s cubic-bezier(.4,0,.2,1);z-index:1001}
.sheet.is-open{transform:none}
.sheet__head{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--hairline);flex:none}
.sheet__head h3{font-size:17px;flex:1;min-width:0}
.sheet__body{flex:1;overflow-y:auto;padding:20px;min-height:0}
.sheet__foot{flex:none;display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--hairline)}

/* tiny inline spinner used inside buttons (reuses .spin) */
.spin--xs{width:14px;height:14px;border-width:2px}
