/* --- Context Menu styles (for ris-order) – v4 --- */
:root {
  --cm-bg: #ffffff;
  --cm-fg: #1f2937;         /* gray-800 */
  --cm-border: #e5e7eb;     /* gray-200 */
  --cm-hover: #f5f7fb;      /* soft hover */
  --cm-sep: #e5e7eb;
  --cm-muted: #6b7280;      /* gray-500 */
  --cm-shadow: 0 10px 30px rgba(0,0,0,.12), 0 2px 8px rgba(0,0,0,.06);
  --cm-radius: 10px;
  --cm-item-h: 34px;        /* nhỏ gọn hơn */
  --cm-font: system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,'Noto Sans',sans-serif;
  --cm-font-size: 13px;
}

@media (prefers-color-scheme: dark) {
  :root {
    --cm-bg: #0b1220;
    --cm-fg: #e5e7eb;
    --cm-border: #0f172a;
    --cm-hover: #111827;
    --cm-sep: #111827;
    --cm-muted: #94a3b8;
    --cm-shadow: 0 18px 40px rgba(0,0,0,.55), 0 2px 10px rgba(0,0,0,.45);
  }
}

/* Root */
#wl-cm-root{
  position:fixed;
  z-index:3200;
  min-width:220px;          /* nhỏ lại một chút */
  max-width:360px;
  max-height:none;
  overflow:visible;
  background:var(--cm-bg);
  color:var(--cm-fg);
  border:1px solid var(--cm-border);
  border-radius:var(--cm-radius);
  box-shadow:var(--cm-shadow);
  padding:6px;
  display:none;
  font-family:var(--cm-font);
  font-size:var(--cm-font-size);
  user-select:none;
}

/* Item */
#wl-cm-root .cm-item{
  position:relative;
  display:grid;
  grid-template-columns: 18px 1fr auto; /* icon | label | accel/arrow */
  align-items:center;
  gap:10px;
  padding:6px 10px;
  height:var(--cm-item-h);
  border-radius:8px;
  cursor:pointer;
  line-height:1.15;
  -webkit-tap-highlight-color: transparent;
}

#wl-cm-root .cm-item:hover{ background:var(--cm-hover); }
#wl-cm-root .cm-item.is-disabled{ opacity:.45; pointer-events:none; }

/* Icon slot */
#wl-cm-root .cm-item .cm-icon{
  width:18px; height:18px; display:inline-flex; align-items:center; justify-content:center;
  opacity:.95;
}

/* Label & note */
#wl-cm-root .cm-item .cm-label{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
#wl-cm-root .cm-item .cm-note{ color:var(--cm-muted); margin-left:12px; font-variant-numeric: tabular-nums; }

/* Divider */
#wl-cm-root .cm-divider{
  height:1px;
  background:var(--cm-sep);
  margin:6px 0;
  border-radius:1px;
}

/* Submenu */
#wl-cm-root .cm-sub{
  position:absolute;
  left:100%;
  top:-6px;                 /* ăn nhẹ vào item cha để dễ trỏ */
  margin-left:6px;
  display:none;
  background:var(--cm-bg);
  color:var(--cm-fg);
  border:1px solid var(--cm-border);
  border-radius:var(--cm-radius);
  box-shadow:var(--cm-shadow);
  padding:6px;
  min-width:200px;
  max-height:calc(100dvh - 16px);
  overflow-y:auto;
  overflow-x:hidden;
  z-index:3201;
}
#wl-cm-root .has-sub:hover > .cm-sub,
#wl-cm-root .has-sub.is-sub-open > .cm-sub{ display:block; }

/* Arrow, “cầu nối” hover */
#wl-cm-root .has-sub::after{
  content:"▸";
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  color:var(--cm-muted);
  pointer-events:none;
}
#wl-cm-root .has-sub::before{
  content:"";
  position:absolute;
  top:-6px; bottom:-6px; right:-8px;
  width:14px;               /* vùng đệm để không hụt chuột */
}

/* State current */
#wl-cm-root .cm-item.is-current{
  outline:2px solid rgba(37,99,235,.35);
  outline-offset:-2px;
  background:var(--cm-hover);
}

/* Modal nền trắng–xám, nhỏ gọn */
.wl-modal{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;z-index:3199;padding:12px;overflow:auto;}
.wl-modal .inner{background:var(--cm-bg);color:var(--cm-fg);border-radius:12px;max-width:820px;width:92vw;max-height:calc(100dvh - 24px);overflow:auto;padding:16px;box-shadow:0 20px 60px rgba(0,0,0,.2);}
.wl-modal .actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px;}
.wl-btn{min-height:36px;padding:8px 12px;border-radius:8px;border:1px solid #d1d5db;background:#fff;cursor:pointer}
.wl-btn.primary{background:#00a8cc;color:#fff;border-color:#00a8cc}
.wl-btn.danger{background:#dc2626;color:#fff;border-color:#b91c1c}
.wl-consult-modal{width:min(720px,calc(100vw - 28px));max-width:720px;padding:14px 16px 16px;}
.wl-consult-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px;}
.wl-consult-head h3{margin:0;font-size:19px;line-height:1.2;color:#172033;}
.wl-consult-sub{margin-top:5px;color:#64748b;font-size:13px;line-height:1.35;overflow-wrap:anywhere;}
.wl-consult-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px;margin:10px 0 12px;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;background:#f8fafc;}
.wl-consult-meta-item{display:grid;grid-template-columns:74px minmax(0,1fr);gap:8px;align-items:start;min-width:0;font-size:13px;line-height:1.3;}
.wl-consult-meta-item span{color:#64748b;font-weight:700;}
.wl-consult-meta-item strong{min-width:0;color:#111827;font-weight:600;overflow-wrap:anywhere;}
.wl-modal .wl-consult-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px 16px;margin-top:8px;align-items:center;}
.wl-modal .wl-consult-grid label{display:grid;grid-template-columns:76px minmax(0,1fr);gap:8px;align-items:center;margin:0;font-size:13px;color:#374151;}
.wl-modal .wl-consult-grid label span{font-weight:700;color:#475569;}
.wl-modal .wl-consult-grid input{width:100%;height:34px;box-sizing:border-box;border-radius:8px;}
.wl-modal .wl-consult-grid .wl-consult-url{grid-column:1 / -1;grid-template-columns:96px minmax(0,1fr);}
.wl-consult-link-box{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;min-width:0;}
.wl-consult-inline-copy{height:34px;min-width:78px;padding:0 10px;border-color:#2563eb;background:#2563eb;color:#fff;white-space:nowrap;}
.wl-consult-inline-copy:hover{background:#1d4ed8;border-color:#1d4ed8;}
.wl-consult-share{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;padding-top:10px;border-top:1px solid #e5e7eb;}
.wl-consult-share>span{font-size:13px;font-weight:700;color:#475569;white-space:nowrap;}
.wl-share-icons{display:flex;align-items:center;justify-content:flex-end;gap:7px;flex-wrap:wrap;}
.wl-share-icon{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#334155;text-decoration:none;font-size:17px;cursor:pointer;box-sizing:border-box;}
.wl-share-icon:hover{background:#f8fafc;border-color:#94a3b8;}
.wl-share-mail{color:#2563eb;}
.wl-share-zalo{color:#0068ff;}
.wl-share-whatsapp{color:#128c7e;}
.wl-share-viber{color:#665cac;}
.wl-share-telegram{color:#229ed9;}
.wl-share-sms{color:#0f766e;}
.wl-share-native{color:#475569;}
.wl-share-zalo .wl-share-zalo{font-weight:800;font-size:16px;line-height:1;}
.wl-consult-actions{align-items:center;}
.wl-consult-actions .wl-btn{min-height:36px;}
.wl-consult-actions .wl-consult-copy-btn{background:#2563eb;color:#fff;border-color:#1d4ed8;}
.wl-consult-actions .wl-consult-open-btn{background:#16a34a;color:#fff;border-color:#15803d;}
.wl-consult-x{white-space:nowrap;}
@media (max-width:720px){
  .wl-consult-head{align-items:stretch;flex-direction:column;}
  .wl-consult-meta{grid-template-columns:1fr;}
  .wl-consult-meta-item{grid-template-columns:86px minmax(0,1fr);}
  .wl-modal .wl-consult-grid{grid-template-columns:1fr;}
  .wl-modal .wl-consult-grid label{grid-template-columns:1fr;gap:4px;align-items:start;}
  .wl-modal .wl-consult-grid .wl-consult-url{grid-template-columns:1fr;}
  .wl-consult-link-box{grid-template-columns:1fr;}
  .wl-consult-inline-copy{width:100%;}
  .wl-consult-share{align-items:flex-start;flex-direction:column;}
  .wl-share-icons{justify-content:flex-start;}
  .wl-consult-actions{justify-content:stretch;flex-direction:column;}
  .wl-consult-actions .wl-btn{width:100%;}
}
@media print { .wl-modal{display:block}.wl-modal .inner{box-shadow:none;border:0} }

.wl-edit-modal{
  width:min(92vw, 820px);
}
.wl-edit-title{
  margin:0 0 10px 0;
}
.wl-edit-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.wl-edit-actions{
  display:flex;
  justify-content:flex-end;
  gap:8px;
  margin-top:12px;
}

/* Form trong modal – layout label 2 cột nhỏ gọn */
.wl-modal fieldset { border:1px solid #e5e7eb; border-radius:10px; padding:12px; background:#fff; }
.wl-modal legend   { font-weight:600; color:#374151; }
.wl-modal label    { display:grid; grid-template-columns:140px 1fr; align-items:center; gap:8px; margin:8px 0; font-size:13px; color:#374151; }
.wl-modal input, .wl-modal select {
  height:32px; border:1px solid #d1d5db; border-radius:8px; padding:0 10px; background:#fff; font-size:13px; color:#111827;
}
.wl-modal input::placeholder{ color:#9ca3af; }
.wl-modal .ris-input-hint { grid-column: 2 / 3; margin-top:4px; font-size:12px; color:#6b7280; }

/* Sửa chỉ định: cố định độ dài control và cắt gọn text dài bằng tooltip */
.wl-modal .wl-edit-modal.theme-xp{
  --wl-edit-label-width: 150px;
  --wl-edit-control-width: 340px;
  width:min(92vw, 560px) !important;
  max-width:560px !important;
  padding:12px !important;
}
.wl-modal .wl-edit-modal.theme-xp .wl-edit-title{
  margin:0 0 8px 0 !important;
  font-size:20px;
  line-height:1.2;
}
.wl-modal .wl-edit-modal.theme-xp .wl-edit-grid{
  grid-template-columns:1fr !important;
  gap:8px !important;
}
.wl-modal .wl-edit-modal.theme-xp fieldset{
  padding:8px 10px 10px !important;
  border-radius:8px;
}
.wl-modal .wl-edit-modal.theme-xp legend{
  font-size:16px;
  line-height:1.2;
  padding:0 6px;
}
.wl-modal .wl-edit-modal.theme-xp label{
  grid-template-columns:var(--wl-edit-label-width) var(--wl-edit-control-width) !important;
  min-width:0;
  gap:8px !important;
  margin:6px 0 !important;
  font-size:14px;
}
.wl-modal .wl-edit-modal.theme-xp input,
.wl-modal .wl-edit-modal.theme-xp select{
  width:var(--wl-edit-control-width) !important;
  min-width:var(--wl-edit-control-width) !important;
  max-width:var(--wl-edit-control-width) !important;
  height:30px !important;
  min-height:30px !important;
  padding:0 8px !important;
  font-size:14px !important;
  box-sizing:border-box;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.wl-modal .wl-edit-modal.theme-xp input[readonly]{
  cursor:default;
}
.wl-modal .wl-edit-modal.theme-xp .wl-edit-actions{
  margin-top:8px !important;
  gap:6px;
}
.wl-modal .wl-edit-modal.theme-xp .wl-btn{
  min-height:32px;
  padding:6px 12px;
}

/* Touch */
@media (pointer: coarse), (max-width: 640px){
  #wl-cm-root{
    width: min(218px, calc(100vw - 24px));
    min-width: 0;
    max-width: calc(100vw - 24px);
    max-height: calc(100dvh - 20px);
    overflow: visible;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    padding: 4px;
    border-radius: 12px;
    font-size: 13px;
  }
  #wl-cm-root .cm-item{
    grid-template-columns: 18px minmax(0, 1fr) 14px;
    grid-auto-rows: auto;
    gap: 8px;
    min-height: 34px;
    height: auto;
    padding: 7px 9px;
    border-radius: 9px;
  }
  #wl-cm-root .cm-sub{
    position: absolute;
    left: auto;
    right: 100%;
    top: -4px;
    width: min(178px, calc(100vw - 246px));
    min-width: 156px;
    max-width: 190px;
    max-height: calc(100dvh - 20px);
    overflow-y: auto;
    overflow-x: hidden;
    padding: 4px;
    margin: 0 6px 0 0;
    box-shadow: var(--cm-shadow);
  }
  #wl-cm-root .has-sub:hover > .cm-sub{
    display:none;
  }
  #wl-cm-root .has-sub.is-sub-open > .cm-sub{
    display:block;
  }
  #wl-cm-root .has-sub::after{
    content: "◂";
    transform: translateY(-50%);
  }
  #wl-cm-root .has-sub::before{
    left: -10px;
    right: auto;
    width: 14px;
  }
  #wl-cm-root .cm-divider{
    margin: 4px 0;
  }

  .wl-modal{
    align-items:flex-start;
    justify-content:center;
    padding:10px;
  }
  .wl-modal .inner,
  .wl-edit-modal{
    width:100%;
    max-width:none;
    max-height:calc(100dvh - 20px);
    padding:12px;
  }
  .wl-edit-grid{
    grid-template-columns:1fr;
    gap:10px;
  }
  .wl-modal fieldset{
    padding:10px;
  }
  .wl-modal label{
    grid-template-columns:1fr;
    align-items:stretch;
    gap:5px;
    margin:8px 0;
    font-size:13px;
  }
  .wl-modal input,
  .wl-modal select{
    width:100%;
    height:42px;
    min-height:42px;
    font-size:16px;
  }
  .wl-modal .ris-input-hint{
    grid-column:1;
  }
  .wl-modal .wl-edit-modal.theme-xp{
    --wl-edit-label-width: 1fr;
    --wl-edit-control-width: 100%;
    width:100% !important;
    max-width:none !important;
  }
  .wl-modal .wl-edit-modal.theme-xp label{
    grid-template-columns:1fr !important;
  }
  .wl-modal .wl-edit-modal.theme-xp input,
  .wl-modal .wl-edit-modal.theme-xp select{
    width:100% !important;
    min-width:0 !important;
    max-width:100% !important;
  }
  .wl-edit-actions{
    position:sticky;
    bottom:-12px;
    margin:12px -12px -12px;
    padding:10px 12px 12px;
    background:var(--cm-bg);
    border-top:1px solid var(--cm-border);
    justify-content:stretch;
  }
  .wl-edit-actions .wl-btn{
    flex:1 1 0;
    min-height:44px;
  }
}

@media (pointer: coarse) and (min-width: 641px){
  .wl-modal .wl-edit-modal.theme-xp{
    --wl-edit-label-width: 150px;
    --wl-edit-control-width: 340px;
    width:min(92vw, 560px) !important;
    max-width:560px !important;
    padding:12px !important;
  }
  .wl-modal .wl-edit-modal.theme-xp .wl-edit-title{
    font-size:20px;
    margin:0 0 8px 0 !important;
  }
  .wl-modal .wl-edit-modal.theme-xp fieldset{
    padding:8px 10px 10px !important;
  }
  .wl-modal .wl-edit-modal.theme-xp legend{
    font-size:16px;
  }
  .wl-modal .wl-edit-modal.theme-xp label{
    grid-template-columns:var(--wl-edit-label-width) var(--wl-edit-control-width) !important;
    gap:8px !important;
    margin:6px 0 !important;
    font-size:14px;
  }
  .wl-modal .wl-edit-modal.theme-xp input,
  .wl-modal .wl-edit-modal.theme-xp select{
    width:var(--wl-edit-control-width) !important;
    min-width:var(--wl-edit-control-width) !important;
    max-width:var(--wl-edit-control-width) !important;
    height:30px !important;
    min-height:30px !important;
    padding:0 8px !important;
    font-size:14px !important;
  }
  .wl-modal .wl-edit-modal.theme-xp .wl-edit-actions{
    position:static;
    bottom:auto;
    margin:8px 0 0 !important;
    padding:0 !important;
    border-top:0;
    justify-content:flex-end;
  }
  .wl-modal .wl-edit-modal.theme-xp .wl-edit-actions .wl-btn{
    flex:0 0 auto;
    min-height:32px;
    padding:6px 12px;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  * { transition:none !important; animation:none !important; }
}

/* ===== Cho phép theme XP ăn cả khi gắn trực tiếp lên .inner ===== */
/* ===== Modal 1 màu đồng nhất (theme-xp) ===== */
.theme-xp{
  --xp-bg:     #D4D0C8;   /* màu nền XP dùng chung cho cả modal */
  --xp-border: #A6A29A;
}

.wl-modal .theme-xp{
  background:var(--xp-bg) !important;
  border:1px solid var(--xp-border) !important;
  box-shadow:none !important;
}

.wl-modal .theme-xp fieldset{
  background:transparent !important;
}

.wl-modal .theme-xp .wl-edit-title,
.wl-modal .theme-xp .wl-edit-actions{
  background:var(--xp-bg) !important;
}

/* Toàn bộ khung modal 1 màu */
.theme-xp .wl-modal .inner{
  background: var(--xp-bg) !important;
  box-shadow: none !important;         /* tránh cảm giác tách lớp */
  border: 1px solid var(--xp-border) !important;
  border-radius: 8px !important;
}

/* Xóa “tấm panel” 2 bên: bỏ nền/viền để không còn mảng trắng */
.theme-xp .wl-modal fieldset{
  background: transparent !important;  /* hoặc dùng var(--xp-bg) đều được */
  border: 0 !important;                /* bỏ khung viền mỗi panel */
  padding: 12px 0 !important;          /* gọn lại do bỏ viền */
}
.theme-xp .wl-modal legend{
  color:#2b2b2b !important;
  font-weight: 700;
  margin-bottom: 6px;
}

/* Nhãn + input giữ nguyên bố cục 2 cột; nền modal đồng nhất nên giảm “khối hộp” */
.theme-xp .wl-modal label{ margin: 10px 0 !important; }

/* Input/select – nếu muốn cũng hòa vào nền chung (nhìn “phẳng” hơn) */
.theme-xp .wl-modal input,
.theme-xp .wl-modal select{
  background: var(--xp-bg) !important;
  border: 1px solid var(--xp-border) !important;
  border-top-color:#F1EFE8 !important; border-left-color:#F1EFE8 !important;
  border-right-color:#8E8A84 !important; border-bottom-color:#8E8A84 !important;
}

/* Thanh tiêu đề & khu vực nút cùng màu nền modal để thành một khối */
.theme-xp .wl-modal .inner h3{
  margin: -16px -16px 12px -16px !important;
  padding: 10px 16px !important;
  background: var(--xp-bg) !important;
  color:#2b2b2b !important;
  border: 0 !important;
  box-shadow: none !important;
}
.theme-xp .wl-modal .actions{
  padding: 0 16px 8px 16px !important;
  background: var(--xp-bg) !important;
}

/* Menu chuột phải & submenu dùng cùng 1 màu để đồng bộ cảm giác 1 hệ */
.theme-xp #wl-cm-root,
.theme-xp #wl-cm-root .cm-sub{
  background: var(--xp-bg) !important;
  border-color: var(--xp-border) !important;
  box-shadow: none !important;
}
.theme-xp #wl-cm-root .cm-item:hover{ background: #E3E0D7 !important; }

/* Worklist QMS room assignment */
.wl-modal .wl-qms-assign-modal {
  width: min(680px, calc(100vw - 28px));
  max-width: 680px;
  padding: 16px;
}
.wl-qms-assign-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.wl-qms-assign-head h3 {
  margin: 0;
  color: #172033;
  font-size: 20px;
  line-height: 1.2;
}
.wl-qms-assign-sub {
  margin-top: 4px;
  color: #64748b;
  font-size: 13px;
  overflow-wrap: anywhere;
}
.wl-qms-close {
  width: 36px;
  min-width: 36px;
  padding: 0;
}
.wl-qms-assign-meta {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 10px 16px;
  padding: 10px 12px;
  border: 1px solid #e2e8f0;
  border-radius: 7px;
  background: #f8fafc;
}
.wl-qms-assign-meta > div {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.wl-qms-assign-meta span,
.wl-qms-date-field span,
.wl-qms-room-title {
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
}
.wl-qms-assign-meta strong {
  min-width: 0;
  color: #111827;
  font-size: 13px;
  overflow-wrap: anywhere;
}
.wl-modal .wl-qms-date-field {
  display: grid;
  grid-template-columns: 140px minmax(0, 220px);
  align-items: center;
  gap: 10px;
  margin: 14px 0 12px;
}
.wl-modal .wl-qms-date-field input {
  width: 100%;
  box-sizing: border-box;
}
.wl-qms-room-title { margin-bottom: 6px; }
.wl-qms-room-list {
  display: grid;
  gap: 6px;
  max-height: min(390px, 46vh);
  overflow: auto;
  padding-right: 2px;
}
.wl-modal .wl-qms-room-option {
  display: grid;
  grid-template-columns: 20px 62px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 54px;
  margin: 0;
  padding: 7px 10px;
  border: 1px solid #dbe3ee;
  border-radius: 7px;
  background: #fff;
  color: #1f2937;
  cursor: pointer;
}
.wl-modal .wl-qms-room-option:hover { border-color: #93c5fd; background: #f8fbff; }
.wl-modal .wl-qms-room-option.is-current { border-color: #60a5fa; background: #eff6ff; }
.wl-modal .wl-qms-room-option input[type="radio"] {
  width: 17px;
  height: 17px;
  margin: 0;
  padding: 0;
}
.wl-qms-room-number {
  color: #1d4ed8;
  font-size: 14px;
  font-weight: 800;
}
.wl-qms-room-info {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.wl-qms-room-info strong,
.wl-qms-room-info small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.wl-qms-room-info small { color: #64748b; font-size: 12px; }
.wl-qms-current-badge {
  padding: 2px 7px;
  border-radius: 999px;
  background: #dbeafe;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}
.wl-qms-room-loading,
.wl-qms-room-empty {
  padding: 18px 12px;
  border: 1px dashed #cbd5e1;
  border-radius: 7px;
  color: #64748b;
  text-align: center;
}
.wl-qms-assign-error {
  min-height: 18px;
  margin-top: 8px;
  color: #b91c1c;
  font-size: 12px;
}
@media (max-width: 620px) {
  .wl-qms-assign-meta { grid-template-columns: 1fr; }
  .wl-modal .wl-qms-date-field { grid-template-columns: 1fr; gap: 4px; }
  .wl-modal .wl-qms-room-option { grid-template-columns: 20px 52px minmax(0, 1fr); }
  .wl-qms-current-badge { grid-column: 3; justify-self: start; }
  .wl-qms-assign-modal .actions { flex-direction: column-reverse; }
  .wl-qms-assign-modal .actions .wl-btn { width: 100%; }
}

/* Compact QMS room picker */
.wl-modal .wl-qms-assign-modal {
  width: min(500px, calc(100vw - 24px));
  max-width: 500px;
  padding: 12px;
}
.wl-qms-assign-head { margin-bottom: 8px; }
.wl-qms-assign-head h3 { font-size: 17px; }
.wl-qms-assign-sub { margin-top: 2px; font-size: 12px; }
.wl-qms-close { width: 32px; min-width: 32px; min-height: 32px; height: 32px; }
.wl-qms-assign-summary {
  display: flex;
  align-items: center;
  gap: 7px;
  min-width: 0;
  padding: 6px 8px;
  border: 1px solid #e2e8f0;
  border-radius: 5px;
  background: #f8fafc;
  font-size: 12px;
}
.wl-qms-assign-summary span { color: #64748b; white-space: nowrap; }
.wl-qms-assign-summary strong {
  min-width: 0;
  overflow: hidden;
  color: #1d4ed8;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.wl-qms-assign-controls {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 10px;
  margin: 8px 0 5px;
}
.wl-modal .wl-qms-date-field {
  display: grid;
  grid-template-columns: auto 138px;
  gap: 7px;
  margin: 0;
}
.wl-modal .wl-qms-date-field input { height: 30px; }
.wl-qms-room-title { padding-bottom: 5px; }
.wl-qms-room-list {
  gap: 3px;
  max-height: min(315px, 45vh);
}
.wl-modal .wl-qms-room-option {
  grid-template-columns: 18px minmax(0, 1fr) auto;
  gap: 7px;
  min-height: 40px;
  padding: 4px 7px;
  border-radius: 5px;
}
.wl-qms-room-info { display: block; }
.wl-qms-room-info strong { display: block; font-size: 12px; }
.wl-qms-room-number { margin-right: 4px; font-size: 12px; }
.wl-qms-current-badge { padding: 1px 5px; border-radius: 4px; font-size: 10px; }
.wl-qms-room-loading,
.wl-qms-room-empty { padding: 12px 8px; border-radius: 5px; font-size: 12px; }
.wl-qms-assign-error { min-height: 14px; margin-top: 4px; }
.wl-qms-assign-modal .actions { margin-top: 5px; }
.wl-qms-assign-modal .actions .wl-btn { min-height: 32px; padding: 5px 10px; }
@media (max-width: 620px) {
  .wl-qms-assign-controls { align-items: stretch; flex-direction: column; gap: 5px; }
  .wl-modal .wl-qms-date-field { grid-template-columns: 1fr; gap: 3px; }
  .wl-qms-room-title { padding: 0; }
  .wl-modal .wl-qms-room-option { grid-template-columns: 18px minmax(0, 1fr) auto; }
  .wl-qms-current-badge { grid-column: auto; justify-self: auto; }
}
