:root{
  /* Brand colours */
  --navy:#14263F;--blue:#1F4E8C;--blue-soft:#EEF4FB;--blue-mid:#2B6CB0;
  --blue-2:#3B6FB6;--soft-grey:#AEB8C2;
  --success:#2F9E44;--success-soft:#E8F5EC;
  --danger:#C53030;--danger-soft:#FEF0F0;
  --warning:#D4AC0D;--warning-alt:#E67E22;--warning-soft:#FFF3E8;--warning-soft-alt:#FDECD6;
  --purple:#7D3C98;--purple-soft:#EEEDFE;
  --pink:#EFA3B1;--green-dark:#1E8449;
  --teal:#0F6E56;--teal-soft:#E1F5EE;
  --amber:#D97706;--amber-soft:#FAEEDA;
  /* Surface & text */
  --bg:#F6F8FA;--surface:#FFFFFF;--surface-2:#F8FAFC;
  --border:#E2E8F0;--border-light:#EEF2F7;--light:#F8FAFC;
  --text:#14263F;--text-secondary:#374151;--muted:#64748B;--subtle:#94A3B8;
  /* Shadows */
  --shadow-xs:0 1px 2px rgba(15,23,42,.04);
  --shadow-sm:0 1px 3px rgba(15,23,42,.05),0 2px 8px rgba(15,23,42,.04);
  --shadow-md:0 4px 16px rgba(15,23,42,.08),0 1px 4px rgba(15,23,42,.04);
  --shadow-lg:0 18px 45px rgba(20,38,63,.10);
  --shadow-focus:0 0 0 3px rgba(31,78,140,.15);
  --shadow-card:0 18px 45px rgba(20,38,63,.08);
  --shadow-card-hover:0 22px 52px rgba(20,38,63,.12);
  --shadow-modal:0 24px 72px rgba(0,0,0,.2),0 4px 16px rgba(0,0,0,.08);
  /* Radii */
  --radius-sm:10px;--radius-md:14px;--radius-lg:18px;
  --radius-card:22px;--radius-input:14px;--radius-btn:999px;
  /* Type & spacing */
  --font-ui:'Montserrat',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  --space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;
  --content-max:1560px;
  --control-h:44px;
  --control-h-sm:36px;
  /* Gloved-clinical touch target floor (Rule 03 of the TapFlow research spec):
     - 56 dp primary controls on touch surfaces (gloved hand minimum)
     - 44 dp secondary controls on touch surfaces
     - 12 dp minimum inter-control spacing (see gap/margin overrides below)
     Desktop admin surfaces (mouse/trackpad) keep the denser 44/36 defaults. */
  /* Transitions */
  --transition:all .15s ease;
  --transition-card:transform .18s ease,box-shadow .18s ease;
  /* Layout */
  --sidebar-w:240px;
  --app-vh:1vh;
}
/* Rule 03 (TapFlow research): bump touch targets on coarse-pointer devices
   so gloved clinical staff get a 56 dp primary / 44 dp secondary floor.
   Desktop pointers stay on the denser admin defaults above. */
@media (pointer: coarse){
  :root{
    --control-h:56px;
    --control-h-sm:44px;
  }
  .btn, .btn-p, .btn-purple, .btn-sm,
  .ops-subtab, .page-section-tab,
  .sb-item, .tab, .chip,
  .msg-bell, .mob-drawer-close, .edit-modal-close{
    min-height:var(--control-h);
  }
  .btn-sm, .btn-icon.btn-sm{
    min-height:var(--control-h-sm);
    min-width:var(--control-h-sm);
  }
  /* 12 dp minimum spacing between adjacent controls on touch surfaces */
  .btn + .btn, .btn-sm + .btn-sm, .ops-subtab + .ops-subtab{
    margin-left:12px;
  }
}

/* Rule 10 (TapFlow research): visual escalation for items >= 15 min overdue.
   Applied passively by workflow-alerts.js _applyVisualEscalation() — this is
   the non-interruptive half of staged escalation. Interruptive notifications
   go through AlertThrottle (Rule 14). */
.wf-escalate-visual{
  position:relative;
  box-shadow:inset 3px 0 0 var(--danger, #C53030);
  background:linear-gradient(90deg, var(--danger-soft, #FEF0F0) 0%, transparent 40%);
  animation:wf-escalate-pulse 2.4s ease-in-out infinite;
}
@keyframes wf-escalate-pulse{
  0%, 100% { box-shadow:inset 3px 0 0 var(--danger, #C53030); }
  50%      { box-shadow:inset 3px 0 0 var(--danger, #C53030), 0 0 0 2px rgba(197,48,48,.12); }
}
@media (prefers-reduced-motion: reduce){
  .wf-escalate-visual{ animation:none; }
}
*{box-sizing:border-box;margin:0;padding:0}
html{height:100%;background:var(--bg);scroll-behavior:smooth}
body{font-family:var(--font-ui);background:
  radial-gradient(circle at top left,rgba(31,78,140,.12),transparent 30%),
  linear-gradient(180deg,#FBFCFE 0%,#F6F8FA 100%);
  color:var(--text);min-height:100vh;min-height:calc(var(--app-vh, 1vh) * 100);overflow-x:hidden;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;
  font-feature-settings:"cv03","cv04","cv11";line-height:1.45}
body.drawer-open{overflow:hidden}
body[data-platform="ios"]{letter-spacing:-.01em}
body[data-platform="android"] .btn,body[data-platform="android"] .fi{font-weight:600}
.screen{display:none}.screen.active{display:flex;flex-direction:column;min-height:100vh;min-height:calc(var(--app-vh, 1vh) * 100)}
a{color:inherit}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
textarea{resize:vertical}

/* ── LOGIN ── */
#s-login{align-items:center;justify-content:center;padding:20px;background:linear-gradient(180deg,#FBFCFE 0%,#F6F8FA 100%)}
.login-card{background:rgba(255,255,255,.96);border-radius:30px;box-shadow:var(--shadow-lg);border:1px solid var(--border);width:100%;max-width:428px;overflow:hidden;backdrop-filter:blur(18px)}
.login-bar{height:4px;background:linear-gradient(90deg,#1F4E8C 0%,#3B6FB6 60%,#60A5FA 100%)}
.login-body{padding:18px 28px 28px}
/* Login brand: tightened spacing for a cleaner, more compact card.
 * Previous values left a lot of vertical air between the wordmark, the
 * tagline, and the form. The new spacing keeps the elements visually
 * grouped as one piece of identity instead of three stacked components. */
.brand-row{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;margin-bottom:0}
.brand-row img#brand-login-logo{width:min(100%,190px);height:72px;object-fit:contain;border-radius:12px;display:none;background:#fff;padding:8px;border:1px solid rgba(20,38,63,.08);box-shadow:0 6px 20px rgba(20,38,63,.06)}
.brand-wordmark-img{height:46px;width:auto;max-width:min(100%,220px);display:block}
/* Cap the vertical TapFlow logo at ~110px so the brand row doesn't
 * dominate the card. Previously this was 180px, which (combined with
 * the tagline below it) pushed the form down the page and made the
 * Tap.Log.Flow tagline sit visually low even though its own margins
 * were correct. A shorter logo brings the whole composition up. */
#brand-login-wordmark{width:min(140px,50vw);height:auto;max-height:110px;object-fit:contain}
#brand-login-name{display:none}
.brand-name{font-size:18px;font-weight:800;color:var(--navy);letter-spacing:-.3px}
.brand-tag{font-size:12px;color:var(--muted);text-align:center;margin-bottom:14px;letter-spacing:.01em;font-weight:500}
/* Wordmark variant — used when the tag content is the default
   "Tap.Log.Flow" identity line rather than a tenant-supplied headline.
   Gives the three words real breathing room (instead of "Tap.Log.Flow"
   reading as one cramped 12-character string) and pushes the dots back
   so they look like deliberate separators, not punctuation crammed
   between letters. */
/* Tagline placement between the TapFlow logo (top) and the form (below).
 * The login form is a tall, heavy block — label/input/label/input/
 * verify/button/note — and the tagline kept reading as glued to it.
 * Sit the tagline HIGH in the gap: small top margin (16px below the
 * logo) and a much larger bottom margin (52px above the form) so the
 * tagline visually attaches to the brand mark, not to the inputs.
 * Earlier passes used 22/36 and 14/14 which were too symmetrical for
 * the asymmetric visual weight on either side. */
.brand-tag-wordmark{font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin:16px 0 52px;display:flex;align-items:baseline;justify-content:center;gap:0;line-height:1.1}
.brand-tag-wordmark .bt-w{display:inline-block;padding:0 2px;color:var(--blue)}
.brand-tag-wordmark .bt-d{display:inline-block;color:var(--blue);font-weight:800;letter-spacing:0;padding:0 8px;transform:translateY(-1px);opacity:.85}
@media (max-width:480px){
  .brand-tag-wordmark{font-size:12px;letter-spacing:.16em;margin:12px 0 40px}
  .brand-tag-wordmark .bt-d{padding:0 6px}
}
.login-platform-mark{display:none;align-items:center;justify-content:center;flex-direction:column;gap:6px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}
.login-platform-kicker{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.login-platform-img{height:42px;width:auto;max-width:150px;display:block;opacity:.82;object-fit:contain}
.fl{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.ti{width:100%;border:1.5px solid var(--border);border-radius:var(--radius-input);padding:12px 14px;font-size:15px;color:var(--navy);background:#fff;outline:none;margin-bottom:11px;transition:all .15s ease;font-family:var(--font-ui);min-height:48px;box-shadow:0 6px 18px rgba(20,38,63,.04)}
.ti:focus{border-color:var(--blue);box-shadow:var(--shadow-focus),0 8px 24px rgba(31,78,140,.08);background:#FAFCFF}
.mfa-wrap{display:none;margin-bottom:10px}
.login-btn{width:100%;border:none;border-radius:999px;background:linear-gradient(135deg,#14263F 0%,#1F4E8C 100%);color:#fff;font-size:15px;font-weight:800;padding:14px;cursor:pointer;letter-spacing:.01em;box-shadow:0 12px 28px rgba(31,78,140,.24);transition:all .16s ease;font-family:var(--font-ui);min-height:50px}
.login-btn:hover{background:linear-gradient(135deg,#173154 0%,#1F4E8C 100%);box-shadow:0 16px 34px rgba(31,78,140,.3);transform:translateY(-1px)}
.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.login-err{font-size:12px;font-weight:600;text-align:center;padding:8px 12px;border-radius:10px;margin-bottom:10px;display:none}
.login-note{font-size:11.5px;color:var(--muted);text-align:center;margin-top:12px;line-height:1.6;font-weight:500}

/* ── WORDMARK LOGO ── */
.brand-wordmark{font-size:22px;font-weight:800;letter-spacing:-.5px;text-align:center;line-height:1}
.bw-t{color:#1F4E8C}.bw-f{color:#2B6CB0}.bw-h{color:#14263F}
.sb-wordmark{font-size:13px;font-weight:800;letter-spacing:-.2px;line-height:1;display:flex;align-items:center;gap:0}
.sb-wordmark img[data-brand-logo]{height:56px;width:auto;max-width:200px;object-fit:contain}
.sb-wordmark .bw-t,.sb-wordmark .bw-f{color:#60A5FA}.sb-wordmark .bw-h{color:rgba(255,255,255,.72)}
.mh-wordmark{font-size:14px;font-weight:800;letter-spacing:-.2px;line-height:1;display:flex;align-items:center;gap:0}
.mh-wordmark img[data-brand-logo]{height:32px;width:auto;max-width:168px;object-fit:contain}
.mh-wordmark .bw-t,.mh-wordmark .bw-f{color:#60A5FA}.mh-wordmark .bw-h{color:rgba(255,255,255,.72)}

/* ── APP SHELL ── */
#s-app{flex-direction:row}
.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:linear-gradient(180deg,#14263F 0%,#1B3557 55%,#17304E 100%);display:flex;flex-direction:column;min-height:100vh;border-right:1px solid rgba(255,255,255,.06);position:sticky;top:0;height:100vh;overflow-y:auto;box-shadow:18px 0 40px rgba(20,38,63,.18)}
.sidebar::-webkit-scrollbar{width:0}
.sb-top{padding:18px 14px 14px;border-bottom:1px solid rgba(255,255,255,.06)}
.sb-brand{font-size:13.5px;font-weight:800;color:#fff;letter-spacing:-.2px}
.sb-ctx{font-size:10px;color:rgba(255,255,255,.36);margin-top:3px;letter-spacing:.02em;font-weight:500}
.sb-user-row{display:flex;align-items:center;gap:9px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.05);margin-bottom:4px}
.sb-av{width:28px;height:28px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;flex-shrink:0}
.sb-uname{font-size:12px;color:rgba(255,255,255,.48);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.sb-tier-pill{margin-left:auto;font-size:9.5px;padding:2px 7px;border-radius:8px;font-weight:700;flex-shrink:0;letter-spacing:.02em}
.tp-master{background:rgba(83,74,183,.3);color:#C4B5FD}
.tp-hospital{background:rgba(15,110,86,.3);color:#6EE7B7}
.tp-clinical{background:rgba(47,158,68,.22);color:#86EFAC}
.sb-sec{font-size:9px;font-weight:700;color:rgba(255,255,255,.2);padding:14px 14px 5px;letter-spacing:.12em;text-transform:uppercase}
.sb-item{display:flex;align-items:center;gap:9px;padding:10px 12px;cursor:pointer;font-size:12.5px;color:rgba(255,255,255,.52);border-radius:10px;margin:2px 8px;transition:all .14s ease;position:relative;font-weight:600;min-height:42px}
.sb-item:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.88)}
.sb-item.active{background:rgba(96,165,250,.16);color:#E0EDFF;font-weight:600;box-shadow:inset 0 0 0 1px rgba(96,165,250,.16)}
.sb-item.active::before{content:'';position:absolute;left:-6px;top:6px;bottom:6px;width:3px;background:#60A5FA;border-radius:0 3px 3px 0}
.sb-item svg{width:14px;height:14px;flex-shrink:0;opacity:.45;transition:opacity .14s}
.sb-item:hover svg{opacity:.7}
.sb-item.active svg{opacity:1}
.sb-badge{margin-left:auto;background:#EF4444;color:#fff;font-size:9.5px;font-weight:700;padding:1px 6px;border-radius:8px;min-width:18px;text-align:center}
.sb-footer{margin-top:auto;padding:12px 14px;border-top:1px solid rgba(255,255,255,.05)}
.sb-out{font-size:12px;color:rgba(255,255,255,.3);cursor:pointer;display:flex;align-items:center;gap:7px;padding:7px 6px;border-radius:8px;transition:all .14s;font-weight:500}
.sb-out:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.06)}
.sb-lock{font-size:10px;color:rgba(255,255,255,.16);margin-top:5px;display:flex;align-items:center;gap:4px;padding:0 6px}

/* ── MOBILE BOTTOM TAB BAR ── */
#mob-tabbar{display:none;position:fixed;bottom:0;left:0;right:0;background:rgba(10,20,38,.96);border-top:1px solid rgba(255,255,255,.08);z-index:1000;padding:0 0 env(safe-area-inset-bottom,0);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 -10px 28px rgba(8,15,28,.24)}
#mob-tabbar .mt-items{display:flex;justify-content:space-around;align-items:stretch;padding:2px 4px}
.mt-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px 10px;cursor:pointer;color:rgba(255,255,255,.42);font-size:9.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;gap:4px;border:none;background:none;min-height:58px;border-radius:12px;margin:2px 1px;transition:all .14s ease;-webkit-tap-highlight-color:transparent}
.mt-btn svg{width:20px;height:20px;flex-shrink:0;transition:transform .14s}
.mt-btn:active{transform:scale(.93)}
.mt-btn.active{color:#60A5FA}
.mt-btn.active svg{filter:drop-shadow(0 0 6px rgba(96,165,250,.45));transform:scale(1.05)}

/* ── MOBILE HEADER ── */
#mob-header{display:none;background:rgba(12,26,46,.94);padding:calc(10px + env(safe-area-inset-top,0)) 12px 12px;align-items:center;gap:8px;position:sticky;top:0;z-index:500;border-bottom:1px solid rgba(255,255,255,.06);box-shadow:0 8px 18px rgba(0,0,0,.18);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
/* Tenant pill — matches the desktop SC pill aesthetic. Master users get
   the caret + clickable affordance; non-masters get static text. */
#mob-header .mh-tenant{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:#fff;padding:6px 10px;border-radius:999px;font-size:11px;font-weight:700;cursor:pointer;font-family:inherit;margin-left:auto;max-width:160px;min-height:30px;-webkit-tap-highlight-color:transparent}
#mob-header .mh-tenant:active{transform:scale(.98);background:rgba(255,255,255,.14)}
#mob-header .mh-tenant.is-locked{cursor:default;background:transparent;border-color:rgba(255,255,255,.08)}
#mob-header .mh-tenant.is-locked .mh-tenant-caret{display:none}
#mob-header .mh-tenant-dot{width:18px;height:18px;border-radius:999px;background:#7C3AED;color:#fff;font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}
#mob-header .mh-tenant-name{font-size:11px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.02em}
#mob-header .mh-tenant-caret{flex-shrink:0;opacity:.6}
/* Status chip (pending count + online dot) */
#mob-header .mh-status{display:flex;align-items:center;gap:5px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);color:rgba(255,255,255,.78);padding:5px 9px;border-radius:999px;font-size:10.5px;font-weight:700;font-variant-numeric:tabular-nums;min-height:28px}
#mob-header .mh-status-dot{width:7px;height:7px;border-radius:999px;background:#34D399;box-shadow:0 0 0 2px rgba(52,211,153,.18)}
#mob-header .mh-status.is-offline .mh-status-dot{background:#F87171;box-shadow:0 0 0 2px rgba(248,113,113,.22)}
/* Icon buttons (+create, bell) */
#mob-header .mh-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.06);color:#fff;border-radius:10px;cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent;flex-shrink:0}
#mob-header .mh-icon-btn:active{transform:scale(.96);background:rgba(255,255,255,.12)}
#mob-header .mh-bell-badge{position:absolute;top:-3px;right:-3px;min-width:14px;height:14px;padding:0 3px;border-radius:999px;background:#DC2626;color:#fff;font-size:9px;font-weight:900;display:flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums}
/* Hide the status chip + icon buttons on very narrow viewports to keep
   the header readable. The tenant pill stays because it's the most
   important master-user control. */
@media (max-width:480px){
  #mob-header .mh-status{display:none}
  #mob-header .mh-tenant{max-width:120px}
}
#mob-header .mh-brand{font-size:14px;font-weight:800;color:#fff;letter-spacing:-.2px}
#mob-header .mh-ctx{font-size:11px;color:rgba(255,255,255,.42);margin-left:auto;font-weight:500}
#mob-header .mh-av{width:30px;height:30px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0}

@media (max-width: 768px) {
  .sidebar{display:none!important}
  #mob-header{display:flex!important}
  #mob-tabbar{display:block!important}
  #s-app{flex-direction:column}
  .main{padding-bottom:60px}
  .content{padding:12px}
  .login-card{max-width:100%;border-radius:14px}
  .brand-row img#brand-login-logo{width:min(100%,180px);height:66px}
  .brand-wordmark-img{height:40px;max-width:200px}
  #brand-login-wordmark{width:min(120px,46vw);height:auto;max-height:88px}
}

/* ── SESSION BAR ── */


/* ── BANNERS ── */
.banner{padding:7px 16px;font-size:12px;font-weight:700;display:none;align-items:center;gap:7px}
#b-offline{background:var(--warning-soft);border-bottom:1px solid #FCD34D;color:var(--warning)}
#b-sync{background:var(--blue-soft);border-bottom:1px solid #B5D4F4;color:var(--blue)}
#b-sec{background:var(--danger-soft);border-bottom:1px solid #F7C1C1;color:var(--danger)}

/* ── MAIN ── */
.main{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-width:0;-webkit-overflow-scrolling:touch}
.topbar{background:rgba(246,248,250,.88);border-bottom:1px solid rgba(221,227,234,.8);padding:16px 24px;display:flex;align-items:center;gap:10px;flex-shrink:0;box-shadow:none;position:sticky;top:0;z-index:150;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.topbar-title{font-size:14px;font-weight:700;color:var(--navy);letter-spacing:-.1px;flex-shrink:0}
.topbar-r{margin-left:auto;display:flex;align-items:center;gap:8px}
/* ── Topbar global search ──────────────────────────────────────────────
 * Inline search palette anchored in the topbar. Hidden on narrow widths.
 * The dropdown of results is absolutely positioned below the input so
 * results overlay the page below without pushing layout around. */
.topbar-search{position:relative;flex:1;max-width:480px;margin:0 12px;display:flex;align-items:center;background:#fff;border:1px solid var(--border);border-radius:10px;padding:0 12px;height:38px;color:var(--muted);transition:border-color .15s ease,box-shadow .15s ease}
.topbar-search:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,78,140,.08)}
.topbar-search svg{width:16px;height:16px;flex-shrink:0;color:var(--muted)}
.topbar-search input{flex:1;border:none;outline:none;background:transparent;font-size:13px;color:var(--navy);padding:0 8px;min-width:0;font-family:inherit}
.topbar-search input::placeholder{color:var(--muted);font-weight:500}
.topbar-search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 14px 40px rgba(15,23,42,.14);max-height:420px;overflow-y:auto;z-index:200;padding:6px}
.topbar-search-result{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--navy)}
.topbar-search-result:hover,.topbar-search-result.is-active{background:var(--blue-soft)}
.topbar-search-kind{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:2px 6px;border-radius:8px;background:#F1F5F9;flex-shrink:0}
.topbar-search-result .name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}
.topbar-search-result .meta{font-size:11px;color:var(--muted);flex-shrink:0}
.topbar-search-empty{padding:18px 14px;text-align:center;color:var(--muted);font-size:12px}
.topbar-search-section-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 10px 4px}
/* ── Topbar user dropdown ─────────────────────────────────────────────
 * Circle avatar with initials. Menu shows identity, then actions. */
.topbar-user-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:linear-gradient(135deg,#1F4E8C,#3B6FB6);color:#fff;font-size:12px;font-weight:800;letter-spacing:.5px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .12s ease,box-shadow .12s ease;flex-shrink:0;padding:0}
.topbar-user-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(31,78,140,.25)}
.topbar-user-menu{position:absolute;top:60px;right:18px;min-width:240px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 16px 44px rgba(15,23,42,.18);z-index:9000;padding:6px;animation:tfMenuIn .14s ease-out}
@keyframes tfMenuIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.topbar-user-menu .um-head{padding:12px 12px 8px;border-bottom:1px solid var(--border);margin-bottom:4px}
.topbar-user-menu .um-name{font-size:13px;font-weight:800;color:var(--navy)}
.topbar-user-menu .um-meta{font-size:11px;color:var(--muted);margin-top:2px;text-transform:uppercase;letter-spacing:.4px}
.topbar-user-menu .um-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;color:var(--navy);font-size:13px;border:none;background:transparent;width:100%;text-align:left;font-weight:600}
.topbar-user-menu .um-item:hover{background:var(--blue-soft)}
.topbar-user-menu .um-item.is-danger{color:var(--danger)}
.topbar-user-menu .um-item.is-danger:hover{background:var(--danger-soft)}
.topbar-user-menu .um-divider{height:1px;background:var(--border);margin:4px 0}
.diag-panel{display:none;background:#fff;border-bottom:1px solid var(--border);padding:14px 18px}
.diag-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.diag-card{background:#F8FAFC;border:1px solid var(--border);border-radius:12px;padding:12px}
.diag-kv{display:flex;justify-content:space-between;gap:10px;font-size:12px;padding:4px 0;border-bottom:1px solid #EDF2F7}
.diag-kv:last-child{border-bottom:none}
.diag-routes{display:flex;flex-direction:column;gap:6px}
.diag-route{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:12px;padding:7px 9px;border:1px solid var(--border);border-radius:8px;background:#fff}
.diag-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.diag-ok{background:var(--success)}
.diag-warn{background:var(--warning)}
.diag-bad{background:var(--danger)}
.diag-muted{background:#CBD5E1}
.diag-errors{display:flex;flex-direction:column;gap:7px}
.diag-error{font-size:12px;padding:8px 10px;border:1px solid #FECACA;border-radius:8px;background:#FFF7F7}
.cdot{width:7px;height:7px;border-radius:50%;background:#2F9E44}
.cdot.off{background:var(--amber)}
.clabel{font-size:12px;color:var(--muted)}
.pchip{background:var(--amber-soft);color:var(--warning);font-size:11px;font-weight:700;padding:3px 8px;border-radius:8px;cursor:pointer;display:none}
.pchip.show{display:block}

.content{flex:1;width:100%;max-width:var(--content-max);margin:0 auto;padding:24px clamp(16px,2vw,28px) 32px}
/* TV Control viewport-fit pass — matches the Unit Dashboard treatment so
   the page fills the visible area cleanly instead of letting the content
   column grow tall while the cards float at the top. */
.content:has(> #tab-tv-control.active){min-height:0;height:calc(100dvh - 70px);overflow:hidden}
#tab-tv-control{min-width:0;max-width:100%}
#tab-tv-control.active{height:100%;max-height:100%;display:flex !important;flex-direction:column}
#tab-tv-control.active > #tv-control-root{flex:1;min-height:0;overflow:auto}
.tab-panel{display:none}.tab-panel.active{display:block;animation:fadePanel .18s ease}
/* .ph / .ph-title / .ph-sub are now defined in tapflow-enhancements.css
   (unified with .page-header). These stubs are left intentionally empty so
   that any in-flight browser caches still resolve the selectors without
   conflicting with the canonical definitions. */
@keyframes fadePanel{from{opacity:.65;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ── CARDS ── */
.card{background:rgba(255,255,255,.9);border-radius:var(--radius-card);border:1px solid var(--border);padding:22px 24px;margin-bottom:16px;box-shadow:var(--shadow-card);backdrop-filter:blur(14px)}
.ct{font-size:10.5px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.09em;margin-bottom:12px}
.metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}
.metric{background:linear-gradient(180deg,#fff 0%,#F8FBFF 100%);border-radius:18px;padding:18px 18px;border:1px solid var(--border);box-shadow:0 10px 24px rgba(20,38,63,.06)}
.mlabel{font-size:11px;color:var(--muted);margin-bottom:4px;font-weight:700;letter-spacing:.02em;text-transform:uppercase}
.mval{font-size:22px;font-weight:800;letter-spacing:-.5px;line-height:1}
.mv-b{color:var(--blue)}.mv-g{color:var(--success)}.mv-a{color:var(--warning)}.mv-r{color:var(--danger)}.mv-p{color:var(--purple)}
.two-col{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px}
.three-col{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}

/* ── BADGES ── */
.badge{display:inline-block;font-size:11px;padding:2px 7px;border-radius:8px;font-weight:700}
.b-ok{background:var(--success-soft);color:var(--success)}
.b-warn{background:var(--warning-soft);color:var(--warning)}
.b-crit{background:var(--danger-soft);color:var(--danger)}
.b-blue{background:var(--blue-soft);color:var(--blue)}
.b-gray{background:#F1EFE8;color:#5F5E5A}
.b-purple{background:var(--purple-soft);color:var(--purple)}
.b-teal{background:var(--teal-soft);color:var(--teal)}

/* ── BUTTONS ── */
.btn{padding:0 18px;border:1px solid var(--border);border-radius:var(--radius-btn);background:#fff;cursor:pointer;font-size:13px;font-weight:700;color:var(--navy);transition:all .14s ease;font-family:var(--font-ui);display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;line-height:1.2;min-height:var(--control-h);box-shadow:0 8px 20px rgba(20,38,63,.06)}
.btn:hover{background:var(--surface-2);border-color:#cfd9e4;transform:translateY(-1px);box-shadow:0 12px 28px rgba(20,38,63,.10)}
.btn:active{transform:translateY(0);box-shadow:none}
.btn-p{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border-color:transparent;box-shadow:0 12px 28px rgba(31,78,140,.22)}
.btn-p:hover{background:linear-gradient(135deg,#173154,var(--blue));box-shadow:0 16px 32px rgba(31,78,140,.28);border-color:transparent}
.btn-purple{background:linear-gradient(135deg,var(--purple) 0%,#6B63D0 100%);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(83,74,183,.22)}
.btn-purple:hover{background:linear-gradient(135deg,#3C3489 0%,var(--purple) 100%);box-shadow:0 4px 14px rgba(83,74,183,.3);border-color:transparent}
.btn-sm{min-height:var(--control-h-sm);padding:0 14px;font-size:12px;border-radius:999px}
.btn-danger{background:var(--danger-soft);color:var(--danger);border-color:rgba(201,42,42,.2)}
.btn-danger:hover{background:#fde2e2;border-color:rgba(201,42,42,.35)}
.btn-success{background:var(--success-soft);color:var(--success);border-color:rgba(47,158,68,.2)}
.btn-success:hover{background:#d4f0dc;border-color:rgba(47,158,68,.35)}

/* ── DATA ROWS ── */
.dr{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.dr:last-child{border-bottom:none}
.f1{flex:1}

/* ── FORMS ── */
select,.fi{width:100%;border:1.5px solid var(--border);border-radius:var(--radius-input);padding:11px 13px;font-size:14px;color:var(--navy);background:#fff;outline:none;transition:border-color .15s,box-shadow .15s,background .15s;font-family:var(--font-ui);line-height:1.4;min-height:var(--control-h);box-shadow:0 6px 18px rgba(20,38,63,.04)}
select:focus,.fi:focus{border-color:var(--blue);box-shadow:var(--shadow-focus),0 8px 24px rgba(31,78,140,.08);background:#FAFCFF}
select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748B' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}
.fw{margin-bottom:10px}
.fw label{display:block;font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px}
.form-builder-card{background:rgba(255,255,255,.82);border:1px solid var(--border);border-radius:18px;padding:14px;box-shadow:0 10px 24px rgba(20,38,63,.05)}
.form-builder-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.ops-shell{display:grid;grid-template-columns:minmax(0,1fr);gap:14px}
.ops-subtabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.ops-subtab{padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--muted);font-size:12px;font-weight:800;cursor:pointer;transition:all .14s ease}
.ops-subtab.active{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border-color:transparent;box-shadow:0 10px 22px rgba(31,78,140,.18)}
.ops-dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;margin-bottom:14px}
.ops-dashboard-card{padding:16px;border-radius:18px;border:1px solid var(--border);background:#fff;box-shadow:0 10px 24px rgba(20,38,63,.05);cursor:pointer;transition:all .14s ease;text-align:left}
.ops-dashboard-card:hover{transform:translateY(-1px);border-color:rgba(31,78,140,.35);box-shadow:0 16px 30px rgba(20,38,63,.09)}
.ops-dashboard-card .k{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.07em}
.ops-dashboard-card .v{font-size:18px;font-weight:900;color:var(--navy);margin-top:6px}
.ops-dashboard-card .sub{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.5}
.ops-filter-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-bottom:12px}
.ops-asset-list{display:grid;gap:10px}
.ops-asset-card{padding:14px;border:1px solid var(--border);border-radius:16px;background:#fff;box-shadow:0 8px 20px rgba(20,38,63,.04)}
.ops-asset-card.dragging{opacity:.55}
.ops-asset-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.ops-asset-title{font-size:14px;font-weight:800;color:var(--navy)}
.ops-asset-sub{font-size:12px;color:var(--muted);margin-top:4px}
.ops-asset-meta-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.ops-asset-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.ops-section-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.ops-management-list{display:grid;gap:10px}
.ops-management-card{padding:14px;border:1px solid var(--border);border-radius:16px;background:#fff;box-shadow:0 8px 20px rgba(20,38,63,.04)}
.ops-modal-toggle{display:none}
.ops-modal-toggle.active{display:block}
.ops-breadcrumbs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.ops-crumb{padding:6px 10px;border-radius:999px;background:var(--blue-soft);color:var(--blue);font-size:11px;font-weight:700;cursor:pointer;border:none}
.ops-explorer-summary{margin-bottom:12px;padding:14px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(180deg,#fff 0%,#F8FBFF 100%);box-shadow:0 8px 20px rgba(20,38,63,.05)}
.ops-explorer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.ops-explorer-title{font-size:15px;font-weight:900;color:var(--navy)}
.ops-explorer-sub{font-size:12px;color:var(--muted);margin-top:4px}
.ops-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}
.ops-summary-metric{padding:10px 11px;border-radius:12px;background:#fff;border:1px solid var(--border)}
.ops-summary-metric .k{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.ops-summary-metric .v{font-size:16px;font-weight:900;color:var(--navy);margin-top:2px}
.ops-summary-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.ops-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.ops-node-card{padding:14px;border-radius:18px;border:1px solid var(--border);background:#fff;cursor:pointer;transition:all .15s ease;box-shadow:0 8px 20px rgba(20,38,63,.05);text-align:left}
.ops-node-card:hover{border-color:var(--blue);transform:translateY(-1px);box-shadow:0 14px 28px rgba(20,38,63,.08)}
.ops-node-card.active{border-color:rgba(31,78,140,.34);background:linear-gradient(180deg,#fff 0%,#F4F9FF 100%);box-shadow:0 14px 30px rgba(31,78,140,.10)}
.ops-node-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.ops-node-type{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:var(--blue-soft);color:var(--blue);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.ops-node-title{font-size:14px;font-weight:800;color:var(--navy)}
.ops-node-sub{font-size:12px;color:var(--muted);margin-top:4px}
.ops-node-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.ops-node-actions .btn{min-height:34px;padding:8px 12px;font-size:11px}
.ops-section-block{margin-top:12px}
.ops-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.ops-section-head .sub{margin:0}
.ops-verify-list{display:grid;gap:10px}
.ops-verify-card{border:1px solid var(--border);border-radius:16px;background:#fff;padding:14px;box-shadow:0 8px 20px rgba(20,38,63,.04)}
.ops-verify-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.ops-verify-card-title{font-size:14px;font-weight:800;color:var(--navy)}
.ops-verify-card-sub{font-size:12px;color:var(--muted);margin-top:4px}
.ops-verify-controls{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:12px}
.ops-verify-field label{display:block;font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.ops-verify-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.ops-verify-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}
.ops-verify-summary .ops-summary-metric{background:#F8FAFC}
.ops-restock-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:12px}
.ops-restock-list{display:grid;gap:10px}
.ops-restock-card{border:1px solid var(--border);border-radius:16px;background:#fff;padding:14px;box-shadow:0 8px 20px rgba(20,38,63,.04)}
.ops-restock-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.ops-restock-title{font-size:14px;font-weight:800;color:var(--navy)}
.ops-restock-sub{font-size:12px;color:var(--muted);margin-top:4px}
.ops-restock-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}
.ops-restock-meta-item{padding:9px 10px;border-radius:12px;background:#F8FAFC;border:1px solid var(--border)}
.ops-restock-meta-item .k{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.ops-restock-meta-item .v{font-size:13px;font-weight:900;color:var(--navy);margin-top:2px}
.ops-restock-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.ops-runner-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}
.ops-runner-list{display:grid;gap:10px}
.ops-runner-card{border:1px solid var(--border);border-radius:16px;background:#fff;padding:14px;box-shadow:0 8px 20px rgba(20,38,63,.04)}
.ops-runner-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.ops-runner-title{font-size:14px;font-weight:800;color:var(--navy)}
.ops-runner-sub{font-size:12px;color:var(--muted);margin-top:4px}
.ops-runner-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}
.ops-runner-actions .fi{min-height:42px}
.ops-runner-footer{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.ops-kpi{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}
.ops-pane{display:none}
.ops-pane.active{display:block}
.ops-empty{padding:18px;border:1px dashed var(--border);border-radius:16px;color:var(--muted);font-size:12px;background:rgba(255,255,255,.7);text-align:center}
.ops-item-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px solid var(--border)}
.ops-item-row:last-child{border-bottom:none}
.ops-verify-row{display:grid;grid-template-columns:minmax(180px,1.1fr) 90px 90px 90px 1fr;gap:8px;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}
.ops-verify-row:last-child{border-bottom:none}
.ops-pill{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;font-size:11px;font-weight:700}
.ops-pill.low{background:var(--warning-soft);color:var(--warning)}
.ops-pill.bad{background:var(--danger-soft);color:var(--danger)}
.ops-pill.ok{background:var(--success-soft);color:var(--success)}
@media(max-width:980px){.ops-shell{grid-template-columns:1fr}.ops-kpi{grid-template-columns:repeat(2,minmax(0,1fr))}.ops-verify-row{grid-template-columns:1fr 1fr}.ops-summary-grid,.ops-verify-summary,.ops-restock-summary,.ops-restock-meta,.ops-runner-summary,.ops-runner-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.ops-verify-controls{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.ops-kpi{grid-template-columns:1fr}.ops-grid{grid-template-columns:1fr}.ops-verify-row{grid-template-columns:1fr}.ops-summary-grid,.ops-verify-summary,.ops-verify-controls,.ops-restock-summary,.ops-restock-meta,.ops-runner-summary,.ops-runner-actions{grid-template-columns:1fr}}
.fbe-field-row{display:flex;flex-direction:column;gap:10px;padding:12px;background:#F6F8FA;border:1px solid var(--border);border-radius:10px}
.fbe-field-top{display:flex;align-items:flex-start;gap:8px}
.fbe-field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.fbe-day-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}
.fbe-day-chip{display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 8px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:11px;font-weight:700;color:var(--navy);cursor:pointer}
.fbe-day-chip input{display:none}
.fbe-day-chip.active{border-color:var(--blue);background:var(--blue-soft);color:var(--blue)}
@media (max-width: 768px) {
  .form-builder-grid,.fbe-field-grid,.fbe-day-grid{grid-template-columns:1fr}
  .diag-grid{grid-template-columns:1fr}
}

/* ── UNIT MAP ── */
.umap{background:#F6F8FA;border-radius:12px;border:1px solid var(--border);padding:11px}
.corridor{background:var(--border);border-radius:8px;height:26px;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin:5px 0}
.bgrid{display:grid;gap:5px}
.bed{background:#fff;border-radius:8px;padding:6px 8px;cursor:pointer;border:2px solid transparent;transition:all .13s;position:relative}
.bed:hover{border-color:var(--blue)}.bed.ok{border-color:#97C459}.bed.warn{border-color:#EF9F27}.bed.crit{border-color:#E24B4A;background:#FFF8F8}.bed.empty{opacity:.4;cursor:default}
.bnum{font-size:9px;font-weight:700;color:var(--muted)}.bside{font-size:11px;font-weight:800;color:var(--navy);margin:1px 0}.btime{font-size:9px}
.bdot{position:absolute;top:5px;right:6px;width:6px;height:6px;border-radius:50%}
.dok{background:#63991a}.dwarn{background:#EF9F27}.dcrit{background:#E24B4A}.dempty{background:#B4B2A9}
.leg{display:flex;gap:10px;font-size:11px;color:var(--muted);margin-bottom:7px;flex-wrap:wrap}
.li{display:flex;align-items:center;gap:4px}
.ld{width:6px;height:6px;border-radius:50%}

/* ── SWITCH ── */
.swrap{display:flex;align-items:center;gap:6px}
.stxt{font-size:12px;font-weight:700;color:var(--muted);min-width:17px;text-align:center}
.switch{position:relative;display:inline-block;width:46px;height:25px}
.switch input{opacity:0;width:0;height:0}
.ssl{position:absolute;cursor:pointer;inset:0;background:#D7DEE7;transition:.18s;border-radius:999px}
.ssl:before{position:absolute;content:'';height:17px;width:17px;left:4px;top:4px;background:#fff;transition:.18s;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.15)}
input:checked+.ssl{background:var(--success)}
input:checked+.ssl:before{transform:translateX(21px)}

/* ── TEMP BAR ── */
.tbar{height:6px;border-radius:8px;background:#E9EEF3;overflow:hidden;flex:1}
.tfill{height:100%;border-radius:3px}
.fok{background:#63991a}.fwarn{background:#EF9F27}.fcrit{background:#E24B4A}

/* ── NFC SIM ── */
.nfc-sim{border:2px dashed var(--border);border-radius:12px;padding:16px;text-align:center;cursor:pointer;color:var(--muted);transition:all .13s}
.nfc-sim:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft)}
.nfc-sim.tapped{border-color:var(--success);background:var(--success-soft);color:var(--success)}

/* ── ALERT ROWS ── */
.arow{display:flex;align-items:flex-start;gap:8px;padding:8px;border-radius:8px;margin-bottom:6px}
.arow-crit{background:var(--danger-soft)}.arow-warn{background:var(--warning-soft)}

/* ── MASTER SPECIFIC ── */
.master-header{background:linear-gradient(135deg,#0d1a30 0%,#1a2d52 50%,#162448 100%);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px;color:#fff;border:1px solid rgba(255,255,255,.06);box-shadow:0 4px 24px rgba(0,0,0,.18)}
.mh-label{font-size:10.5px;font-weight:700;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px}
.mh-title{font-size:22px;font-weight:800;color:#fff;margin-bottom:3px;letter-spacing:-.3px}
.mh-sub{font-size:12.5px;color:rgba(255,255,255,.5);font-weight:400}
.mh-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px}
.mhs{background:rgba(255,255,255,.09);border-radius:10px;padding:12px;text-align:center;border:1px solid rgba(255,255,255,.07)}
.mhs-val{font-size:22px;font-weight:800;color:#fff;letter-spacing:-.4px}.mhs-label{font-size:10px;color:rgba(255,255,255,.45);margin-top:3px;font-weight:500}
.hospital-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow-xs);transition:var(--transition-card)}
.hospital-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.hc-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.hc-avatar{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--blue-soft),#ddeeff);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;color:var(--blue);flex-shrink:0}
.hc-name{font-size:14px;font-weight:800;color:var(--navy);letter-spacing:-.1px}
.hc-sub{font-size:11.5px;color:var(--muted);font-weight:400;margin-top:1px}
.module-toggle-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.module-toggle-row:last-child{border-bottom:none}
.prog-bar{height:6px;background:#E9EEF3;border-radius:8px;overflow:hidden;flex:1;margin:0 8px}
.prog-fill{height:100%;border-radius:8px;background:var(--blue)}

/* ── AUDIT CHARTS ── */
.audit-stat{background:#F6F8FA;border-radius:10px;padding:11px;text-align:center}
.as-val{font-size:24px;font-weight:800;color:var(--navy)}
.as-label{font-size:11px;color:var(--muted);margin-top:2px}
.compliance-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}
.compliance-row:last-child{border-bottom:none}
.cr-bar{height:8px;border-radius:8px;background:#E9EEF3;overflow:hidden;width:120px;flex-shrink:0}
.cr-fill{height:100%;border-radius:4px}

/* ── CHECKLIST BUILDER (Master) ── */
.cl-builder-card{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:14px;margin-bottom:8px;transition:border .12s}
.cl-builder-card:hover{border-color:var(--blue)}
.clb-header{display:flex;align-items:center;gap:9px;margin-bottom:8px}
.clb-drag{color:var(--muted);cursor:grab;font-size:16px;flex-shrink:0}
.clb-name{font-size:14px;font-weight:700;color:var(--navy);flex:1}
.tag-chip{display:inline-flex;align-items:center;gap:5px;background:var(--blue-soft);border:1px solid #B5D4F4;border-radius:10px;padding:3px 8px;font-size:11px;font-weight:700;color:var(--blue);margin:2px}

/* ── Edit / User / Billing modals ── */
.edit-modal-backdrop{position:fixed;inset:0;background:rgba(10,20,35,.45);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:8000;display:flex;align-items:center;justify-content:center;padding:20px}
.edit-modal{background:#fff;border-radius:18px;padding:24px 26px;width:100%;max-width:480px;box-shadow:0 24px 72px rgba(0,0,0,.2),0 4px 16px rgba(0,0,0,.08);position:relative;max-height:90vh;overflow-y:auto;border:1px solid rgba(255,255,255,.6)}
.edit-modal-title{font-size:16px;font-weight:800;color:var(--navy);margin-bottom:16px;display:flex;align-items:center;gap:10px;letter-spacing:-.15px}
.edit-modal-close{position:absolute;top:16px;right:16px;background:var(--surface-2);border:1px solid var(--border);font-size:16px;color:var(--muted);cursor:pointer;line-height:1;padding:5px 8px;border-radius:8px;transition:all .14s}
.edit-modal-close:hover{background:var(--border);color:var(--navy);transform:scale(1.05)}
.edit-modal-actions{display:flex;gap:8px;margin-top:18px;padding-top:16px;border-top:1px solid var(--border-light)}
.pw-reset-note{font-size:13px;color:var(--muted);line-height:1.55;margin-bottom:12px}
.pw-reset-err{display:none;font-size:12px;font-weight:700;color:var(--danger);background:var(--danger-soft);border-radius:8px;padding:8px 10px;margin-bottom:10px}
.pw-reset-actions{display:flex;gap:8px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}

/* ── Billing cards ── */
.bill-card{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:10px}
.bill-card-hdr{padding:13px 15px;display:flex;align-items:center;gap:11px;cursor:pointer;transition:background .12s}
.bill-card-hdr:hover{background:#F8FAFC}
.bill-hc-avatar{width:34px;height:34px;border-radius:10px;background:var(--purple-soft);color:var(--purple);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;flex-shrink:0}
.bill-hosp-name{font-size:14px;font-weight:800;color:var(--navy)}
.bill-hosp-sub{font-size:11px;color:var(--muted);margin-top:1px}
.bill-total{font-size:16px;font-weight:800;color:var(--blue);white-space:nowrap}
.bill-total-label{font-size:10px;font-weight:400;color:var(--muted)}
.bill-chevron{font-size:12px;color:var(--muted);transition:transform .2s;margin-left:4px}
.bill-chevron.open{transform:rotate(180deg)}
.bill-body{display:none;border-top:1px solid var(--border);padding:0}
.bill-body.open{display:block}
.bill-mod-row{display:flex;align-items:center;padding:9px 15px;border-bottom:1px solid var(--border);gap:10px;font-size:12px}
.bill-mod-row:last-child{border-bottom:none}
.bill-mod-name{flex:1;font-weight:600;color:var(--navy)}
.bill-mod-units{color:var(--muted);min-width:70px}
.bill-mod-rate{color:var(--muted);min-width:80px}
.bill-mod-sub{font-weight:700;color:var(--blue);min-width:70px;text-align:right}
.bill-mod-toggle{width:28px;height:16px;border-radius:8px;border:none;cursor:pointer;flex-shrink:0;transition:background .15s;position:relative}
.bill-mod-toggle.on{background:#2F9E44}
.bill-mod-toggle.off{background:var(--border)}
.bill-mod-toggle::after{content:'';position:absolute;width:12px;height:12px;border-radius:50%;background:#fff;top:2px;transition:left .15s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.bill-mod-toggle.on::after{left:14px}
.bill-mod-toggle.off::after{left:2px}
.bill-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 15px;background:#F6F8FA;font-size:12px}
.bill-summary-total{font-size:16px;font-weight:800;color:var(--navy)}

/* NFC tag row actions */
.nfc-row-actions{display:flex;gap:5px;flex-shrink:0}

/* ── Editable global rate cards ── */
.mod-rate-card{background:#F6F8FA;border-radius:10px;border:1.5px solid var(--border);overflow:hidden;transition:border-color .15s,box-shadow .15s;position:relative}
.mod-rate-card:hover{border-color:rgba(59,130,246,.4)}
.mod-rate-card.editing{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.1)}
.mod-rate-view{padding:12px}
.mod-rate-name{font-size:12px;font-weight:800;color:var(--navy);margin-bottom:2px}
.mod-rate-price{font-size:20px;font-weight:800;color:var(--blue);line-height:1.1}
.mod-rate-per{font-size:11px;font-weight:400;color:var(--muted)}
.mod-rate-actions{display:flex;gap:4px;margin-top:8px}
.mod-edit-form{padding:12px;background:#fff;border-top:1px solid var(--border)}
.mod-edit-row{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}
.mod-edit-row label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.mod-edit-input{border:1px solid var(--border);border-radius:10px;padding:6px 9px;font-size:13px;color:var(--navy);background:#fff;width:100%;box-sizing:border-box;outline:none;transition:border-color .15s}
.mod-edit-input:focus{border-color:var(--blue);box-shadow:0 0 0 2px rgba(59,130,246,.12)}
.mod-edit-btns{display:flex;gap:5px;margin-top:4px}
.mod-add-card{background:#F6F8FA;border-radius:10px;border:1.5px dashed var(--border);padding:14px 12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;cursor:pointer;transition:border-color .15s,background .15s;min-height:110px}
.mod-add-card:hover{border-color:var(--blue);background:var(--blue-soft)}
.mod-add-card-form{background:#F6F8FA;border-radius:10px;border:1.5px solid var(--blue);padding:12px;box-shadow:0 0 0 3px rgba(59,130,246,.1)}
.mod-color-swatches{display:flex;gap:5px;flex-wrap:wrap;margin-top:3px}
.mod-color-swatch{width:20px;height:20px;border-radius:8px;cursor:pointer;border:2px solid transparent;transition:border-color .12s,transform .12s}
.mod-color-swatch:hover{transform:scale(1.15)}
.mod-color-swatch.selected{border-color:var(--navy)}
.nfc-assign-row{display:flex;align-items:center;gap:8px;padding:7px 9px;background:#F6F8FA;border-radius:8px;margin-top:6px;font-size:12px}

@media(max-width:768px){.sidebar{display:none}.metrics{grid-template-columns:1fr 1fr}.two-col,.three-col{grid-template-columns:1fr}}

/* ── UNIT DASHBOARD BUILDER ── */
.ud-task-pill{display:inline-flex;align-items:center;gap:5px;background:var(--blue-soft);border:1px solid #B5D4F4;border-radius:18px;padding:3px 10px 3px 9px;font-size:12px;font-weight:600;color:var(--blue-mid);margin:2px}
.ud-task-pill button{background:none;border:none;cursor:pointer;color:var(--muted);font-size:11px;padding:0;line-height:1;margin-left:2px}
.ud-task-pill button:hover{color:var(--danger)}
.ud-bed-chip{display:inline-flex;align-items:center;gap:6px;background:#F6F8FA;border:1.5px solid var(--border);border-radius:10px;padding:5px 9px;font-size:12px;font-weight:700;color:var(--navy);margin:3px;cursor:default;transition:border-color .12s}
.ud-bed-chip:hover{border-color:var(--blue)}
.ud-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ud-bed-chip.ok .ud-chip-dot{background:var(--success)}.ud-bed-chip.warn .ud-chip-dot{background:var(--warning)}.ud-bed-chip.crit .ud-chip-dot{background:var(--danger)}.ud-bed-chip.empty .ud-chip-dot{background:#C4C4C0}
.ud-bed-chip button{background:none;border:none;cursor:pointer;color:var(--muted);font-size:11px;padding:0 0 0 3px;line-height:1}
.ud-bed-chip button:hover{color:var(--danger)}
/* TV OVERLAY */
#ud-tv-overlay{display:none;position:fixed;inset:0;z-index:9999;background:#14263F;flex-direction:column;overflow:hidden;font-family:var(--font-ui)}
#ud-tv-topbar{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:64px;background:#1B3557;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;gap:12px;box-shadow:0 4px 16px rgba(0,0,0,.2)}
#ud-tv-left{display:flex;flex-direction:column;min-width:180px}
.udtv-unit-name{font-size:15px;font-weight:800;color:#fff;letter-spacing:.3px}
.udtv-hosp-name{font-size:11px;color:rgba(255,255,255,.38);margin-top:1px}
#ud-tv-center{text-align:center;flex:1}
#ud-tv-clock{font-size:30px;font-weight:700;color:#fff;letter-spacing:2px;font-variant-numeric:tabular-nums}
#ud-tv-date{font-size:11px;color:rgba(255,255,255,.38);margin-top:1px}
#ud-tv-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.udtv-legend{display:flex;gap:12px;align-items:center}
.udtv-leg{display:flex;align-items:center;gap:5px;font-size:11px;color:rgba(255,255,255,.4)}
.udtv-leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.udtv-leg-ok{background:#22c55e}.udtv-leg-warn{background:#f59e0b}.udtv-leg-crit{background:#ef4444}.udtv-leg-empty{background:rgba(255,255,255,.18)}
#ud-tv-exit{padding:6px 16px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:999px;color:rgba(255,255,255,.55);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
#ud-tv-exit:hover{background:rgba(255,255,255,.14);color:#fff;transform:translateY(-1px)}
#ud-tv-reset-btn{padding:6px 16px;background:rgba(59,130,246,.18);border:1px solid rgba(59,130,246,.35);border-radius:999px;color:#93c5fd;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
#ud-tv-reset-btn:hover{background:rgba(59,130,246,.32);transform:translateY(-1px)}
/* ── TV map container ── */
#ud-tv-map{flex:1;overflow:auto;display:none;padding:20px 24px;background:#14263F;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:40px 40px}
#ud-tv-map::-webkit-scrollbar{width:4px;height:4px}
#ud-tv-map::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
/* TV map canvas wrapper — applied to cloned canvas */
.udtv-map-wrap{position:relative;transform-origin:top left}
/* Room dark-mode overrides */
.udtv-map-wrap .udm-room{cursor:default!important;user-select:none}
.udtv-map-wrap .udm-pt{background:rgba(31,78,140,.38);border-color:#3b82f6}
.udtv-map-wrap .udm-nurse{background:rgba(15,110,86,.38);border-color:#22c55e}
.udtv-map-wrap .udm-med{background:rgba(217,119,6,.38);border-color:#f59e0b}
.udtv-map-wrap .udm-supply{background:rgba(83,74,183,.38);border-color:#818cf8}
.udtv-map-wrap .udm-break{background:rgba(15,118,110,.3);border-color:#2dd4bf}
.udtv-map-wrap .udm-clean{background:rgba(71,85,105,.35);border-color:#94a3b8}
.udtv-map-wrap .udm-hall{background:rgba(30,41,59,.55);border-color:#475569}
.udtv-map-wrap .udm-room-label{color:#fff;font-size:12px;font-weight:800}
.udtv-map-wrap .udm-room-sub{color:rgba(255,255,255,.45)}
/* Bed dark-mode overrides */
.udtv-map-wrap .udm-bed{background:#1B3557;border-color:rgba(255,255,255,.1);cursor:default!important}
.udtv-map-wrap .udm-bed.ok{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.55);box-shadow:0 0 0 1px rgba(34,197,94,.15)}
.udtv-map-wrap .udm-bed.warn{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.55);box-shadow:0 0 0 1px rgba(245,158,11,.15)}
.udtv-map-wrap .udm-bed.crit{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.65);box-shadow:0 0 0 1px rgba(239,68,68,.2)}
.udtv-map-wrap .udm-bed.empty{background:#14263F;border-color:rgba(255,255,255,.07);opacity:.6}
.udtv-map-wrap .udm-bed-id{color:#fff;font-size:11px;font-weight:800}
.udtv-map-wrap .udm-bed-time{font-size:10px;color:rgba(255,255,255,.4)}
.udtv-map-wrap .udm-bed-time.warn{color:#fbbf24;font-weight:700}
.udtv-map-wrap .udm-bed-time.crit{color:#f87171;font-weight:700}
/* Hide edit controls in TV mode */
.udtv-map-wrap .udm-del-btn,.udtv-map-wrap .udm-resize{display:none!important}
/* ── Unified TV display ──
   Two-panel layout: unit map (left, ~60%) + tasks (right, ~40%).
   The old Bed Status + Room Board panels were removed so the TV only
   shows the glanceable unit map and the outstanding task queue.
   Grid rules for the retired panels (#udtv-panel-beds,
   #udtv-panel-rooms) are gone on purpose; if they're ever revived,
   re-add them here AND in the overlay markup. */
#ud-tv-unified{flex:1;display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);grid-template-rows:1fr;gap:1px;background:rgba(255,255,255,.06);overflow:hidden;min-height:0}
#udtv-panel-map{grid-column:1;grid-row:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;background:#14263F}
#udtv-panel-tasks{grid-column:2;grid-row:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;background:#14263F}
.udtv-panel-hdr{padding:8px 16px;background:#1B3557;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:8px;flex-shrink:0}
.udtv-panel-title{font-size:10px;font-weight:800;color:rgba(255,255,255,.36);text-transform:uppercase;letter-spacing:.1em}
.udtv-panel-stat{font-size:10px;font-weight:700;padding:1px 7px;border-radius:8px;margin-left:auto}
.udtv-panel-body{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;position:relative}
.udtv-panel-body::-webkit-scrollbar{width:3px}
.udtv-panel-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.07);border-radius:2px}
/* Compact beds in unified */
#udtv-ubeds-inner{padding:10px 12px;display:grid;gap:7px;align-content:start;height:100%;box-sizing:border-box}
.udtv-ubed{background:#1B3557;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:10px 12px;display:flex;flex-direction:column;gap:4px;transition:border-color .2s,box-shadow .2s}
.udtv-ubed.ok{border-color:rgba(34,197,94,.4);background:rgba(34,197,94,.08)}
.udtv-ubed.warn{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.06)}
.udtv-ubed.crit{border-color:rgba(239,68,68,.55);background:rgba(239,68,68,.08);animation:tvCritPulse 2.5s ease-in-out infinite}
.udtv-ubed.empty{opacity:.38}
@keyframes tvCritPulse{0%,100%{box-shadow:none}50%{box-shadow:0 0 14px rgba(239,68,68,.28)}}
.udtv-ubed-top{display:flex;align-items:center;gap:6px}
.udtv-ubed-id{font-size:12px;font-weight:800;color:#fff;flex:1}
.udtv-ubed-pill{font-size:9px;font-weight:700;padding:1px 7px;border-radius:8px;letter-spacing:.04em;white-space:nowrap}
.udtv-ubed-pill.ok{background:rgba(34,197,94,.18);color:#86efac}
.udtv-ubed-pill.warn{background:rgba(245,158,11,.18);color:#fde68a}
.udtv-ubed-pill.crit{background:rgba(239,68,68,.22);color:#fca5a5}
.udtv-ubed-pill.empty{background:rgba(255,255,255,.06);color:rgba(255,255,255,.28)}
.udtv-ubed-timer{font-size:10px;color:rgba(255,255,255,.3);font-weight:600}
.udtv-ubed-timer.warn{color:#fbbf24}.udtv-ubed-timer.crit{color:#f87171;font-weight:700}
.udtv-ubed-tasks{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px}
.udtv-ubed-tdot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.12);cursor:pointer;transition:background .12s;flex-shrink:0}
.udtv-ubed-tdot.done{background:#22c55e}
/* Compact rooms */
#udtv-urooms-inner{padding:8px 12px}
.udtv-uroom{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:background .1s}
.udtv-uroom:last-child{border-bottom:none}
.udtv-uroom.simple{opacity:.9}
.udtv-uroom-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.udtv-uroom-dot.clean{background:#22c55e}.udtv-uroom-dot.dirty{background:#ef4444}.udtv-uroom-dot.pending{background:#f59e0b}
.udtv-uroom-name{font-size:12px;font-weight:700;color:#fff;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.udtv-uroom-env{font-size:10px;color:rgba(255,255,255,.35);white-space:nowrap}
.udtv-uroom-tdots{display:flex;gap:3px;flex-shrink:0}
.udtv-uroom-tdot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.1)}
.udtv-uroom-tdot.done{background:#22c55e}
.udtv-uroom-cleanbtn{font-size:10px;font-weight:700;padding:2px 8px;border-radius:8px;border:1px solid rgba(47,158,68,.4);background:rgba(47,158,68,.1);color:#86efac;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.udtv-uroom-cleanbtn:hover{background:rgba(47,158,68,.25)}
/* Compact tasks */
#udtv-utasks-inner{padding:8px 12px}
.udtv-utask-group{margin-bottom:10px}
.udtv-utask-gname{font-size:10px;font-weight:800;color:rgba(255,255,255,.32);text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px;display:flex;align-items:center;justify-content:space-between}
.udtv-utask-prog{font-size:9px;color:rgba(255,255,255,.2)}
.udtv-utask-item{display:flex;align-items:center;gap:7px;padding:4px 6px;border-radius:8px;cursor:pointer;transition:background .1s}
.udtv-utask-item:hover{background:rgba(255,255,255,.04)}
.udtv-utask-cb{width:13px;height:13px;border-radius:8px;border:1.5px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.udtv-utask-cb.done{background:#22c55e;border-color:#22c55e}
.udtv-utask-cb.done svg{opacity:1}
.udtv-utask-cb svg{opacity:0;transition:opacity .1s}
.udtv-utask-text{font-size:11px;color:rgba(255,255,255,.55);flex:1}
.udtv-utask-text.done{color:rgba(255,255,255,.2);text-decoration:line-through}
.udtv-utask-time{font-size:9px;color:rgba(255,255,255,.18)}
.udtv-utask-empty{padding:16px 6px;text-align:center;font-size:11px;color:rgba(255,255,255,.2)}
/* ── Room Board ── */
.rb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;padding:16px 0}
.rb-card{background:rgba(255,255,255,.9);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .15s,box-shadow .15s;position:relative;box-shadow:var(--shadow-sm);backdrop-filter:blur(14px)}
.rb-card.clean{border-color:rgba(47,158,68,.5);box-shadow:0 0 0 2px rgba(47,158,68,.08)}
.rb-card.dirty{border-color:rgba(201,42,42,.35)}
.rb-card.pending-clean{border-color:rgba(217,119,6,.45)}
.rb-card-header{padding:10px 12px 7px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}
.rb-room-icon{width:28px;height:28px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rb-room-name{font-size:13px;font-weight:800;color:var(--navy);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rb-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.rb-status-dot.clean{background:#2F9E44}
.rb-status-dot.dirty{background:#C53030}
.rb-status-dot.pending{background:#D97706}
.rb-card-body{padding:10px 12px}
.rb-env-row{display:flex;gap:10px;margin-bottom:8px}
.rb-env-chip{display:flex;align-items:center;gap:5px;background:var(--light);border:1px solid var(--border);border-radius:8px;padding:4px 8px;font-size:12px;font-weight:600;color:var(--navy)}
.rb-env-chip svg{flex-shrink:0}
.rb-env-chip.warn{background:var(--warning-soft);border-color:rgba(217,119,6,.3);color:var(--warning)}
.rb-clean-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:8px}
.rb-clean-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:8px;white-space:nowrap}
.rb-clean-badge.clean{background:var(--success-soft);color:var(--success)}
.rb-clean-badge.dirty{background:var(--danger-soft);color:var(--danger)}
.rb-clean-badge.pending{background:var(--warning-soft);color:var(--warning)}
.rb-clean-time{font-size:10px;color:var(--muted)}
.rb-tasks{border-top:1px solid var(--border);padding-top:8px;margin-top:4px}
.rb-task-row{display:flex;align-items:center;gap:7px;padding:3px 0;font-size:12px;color:var(--text)}
.rb-task-cb{width:15px;height:15px;border-radius:8px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all .15s}
.rb-task-cb.done{background:var(--success);border-color:var(--success)}
.rb-task-cb.done svg{opacity:1}
.rb-task-cb svg{opacity:0;transition:opacity .15s}
.rb-task-name{flex:1}
.rb-task-time{font-size:10px;color:var(--muted)}
.rb-mark-clean-btn{width:100%;border:1px solid rgba(47,158,68,.4);background:var(--success-soft);color:var(--success);border-radius:10px;padding:6px;font-size:12px;font-weight:700;cursor:pointer;margin-top:8px;transition:all .15s}
.rb-mark-clean-btn:hover{background:var(--success);color:#fff}
.rb-mark-clean-btn:disabled{opacity:.45;cursor:default}
.rb-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.rb-filter-btn{padding:5px 12px;border:1px solid var(--border);background:#fff;border-radius:10px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .12s}
.rb-filter-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
/* Room board TV display */
.rb-tv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;padding:16px 20px}
.rb-tv-card{background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.08);border-radius:var(--radius-md);overflow:hidden;transition:border-color .15s,transform .15s}
.rb-tv-card.clean{border-color:rgba(47,158,68,.55);background:rgba(47,158,68,.05)}
.rb-tv-card.dirty{border-color:rgba(201,42,42,.4);background:rgba(201,42,42,.04)}
.rb-tv-card.pending-clean{border-color:rgba(217,119,6,.4);background:rgba(217,119,6,.04)}
.rb-tv-card-hdr{padding:9px 11px 7px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:space-between}
.rb-tv-room-name{font-size:13px;font-weight:800;color:#fff}
.rb-tv-status{font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px}
.rb-tv-status.clean{background:rgba(47,158,68,.25);color:#86efac}
.rb-tv-status.dirty{background:rgba(201,42,42,.25);color:#fca5a5}
.rb-tv-status.pending{background:rgba(217,119,6,.25);color:#fde68a}
.rb-tv-card-body{padding:8px 11px}
.rb-tv-env{display:flex;gap:8px;margin-bottom:6px}
.rb-tv-env-val{font-size:12px;font-weight:700;color:rgba(255,255,255,.85)}
.rb-tv-env-label{font-size:10px;color:rgba(255,255,255,.4)}
.rb-tv-tasks{display:flex;flex-direction:column;gap:3px}
.rb-tv-task{display:flex;align-items:center;gap:6px;font-size:11px;color:rgba(255,255,255,.55)}
.rb-tv-task.done{color:rgba(47,158,68,.85)}
.rb-tv-task-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.2);flex-shrink:0}
.rb-tv-task.done .rb-tv-task-dot{background:#2F9E44}
/* TV map no-content state */
.udtv-map-empty{display:flex;align-items:center;justify-content:center;height:100%;flex-direction:column;gap:10px;color:rgba(255,255,255,.22);font-size:14px;text-align:center;line-height:1.6}
/* Grid mode */
#ud-tv-grid{flex:1;overflow-y:auto;padding:14px 16px;display:none;gap:10px;align-content:start}
#ud-tv-grid::-webkit-scrollbar{width:4px}
#ud-tv-grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
/* TV Tasks panel */
#ud-tv-tasks{flex:1;overflow-y:auto;padding:16px 20px;display:none;background:#14263F}
#ud-tv-tasks::-webkit-scrollbar{width:4px}
#ud-tv-tasks::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.udtv-tasks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;align-content:start}
.udtv-tpanel{background:#1B3557;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.15)}
.udtv-tpanel-hdr{padding:12px 16px;display:flex;align-items:center;gap:10px;background:#243D5E;border-bottom:1px solid rgba(255,255,255,.06)}
.udtv-tpanel-icon{width:28px;height:28px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.udtv-tpanel-title{font-size:13px;font-weight:800;color:#fff;flex:1}
.udtv-tpanel-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:8px;letter-spacing:.04em}
.udtv-tpanel-badge.done{background:rgba(47,158,68,.25);color:#86efac}
.udtv-tpanel-badge.pending{background:rgba(217,119,6,.2);color:#fcd34d}
.udtv-tpanel-badge.overdue{background:rgba(201,42,42,.28);color:#fca5a5}
.udtv-titem{padding:9px 14px;border-top:1px solid rgba(255,255,255,.04);display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .12s}
.udtv-titem:hover{background:rgba(255,255,255,.04)}
.udtv-titem-cb{width:18px;height:18px;border-radius:8px;border:1.5px solid rgba(255,255,255,.18);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.udtv-titem-cb.done{background:rgba(47,158,68,.3);border-color:#2f9e44;color:#86efac;font-size:11px}
.udtv-titem-text{font-size:12.5px;color:rgba(255,255,255,.75);flex:1;line-height:1.35}
.udtv-titem-text.done{text-decoration:line-through;color:rgba(255,255,255,.28)}
.udtv-titem-time{font-size:10px;color:rgba(255,255,255,.22);white-space:nowrap}
.udtv-tpanel-footer{padding:8px 14px;background:rgba(255,255,255,.03);font-size:11px;color:rgba(255,255,255,.3);display:flex;align-items:center;justify-content:space-between}
.udtv-tasks-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:rgba(255,255,255,.18);font-size:13px;text-align:center;gap:12px}
.udtv-bed-summary-row{padding:7px 14px;border-top:1px solid rgba(255,255,255,.04);display:flex;align-items:center;gap:9px}
.udtv-bed-pill{font-size:10px;font-weight:700;padding:2px 6px;border-radius:3px}
.udtv-bed-pill.ok{background:rgba(34,197,94,.2);color:#86efac}
.udtv-bed-pill.warn{background:rgba(245,158,11,.2);color:#fcd34d}
.udtv-bed-pill.crit{background:rgba(239,68,68,.25);color:#fca5a5}
.udtv-bed-pill.empty{background:rgba(255,255,255,.07);color:rgba(255,255,255,.3)}
.udtv-bed{border-radius:10px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s}
.udtv-bed-ok{background:#0c2116;border:1px solid rgba(34,197,94,.18)}
.udtv-bed-warn{background:#211908;border:1px solid rgba(245,158,11,.22)}
.udtv-bed-crit{background:#1c0909;border:1px solid rgba(239,68,68,.28);animation:udtv-pulse 2.2s ease-in-out infinite}
.udtv-bed-empty{background:#111620;border:1px solid rgba(255,255,255,.06)}
@keyframes udtv-pulse{0%,100%{border-color:rgba(239,68,68,.28)}50%{border-color:rgba(239,68,68,.6)}}
.udtv-bed-header{display:flex;align-items:center;justify-content:space-between;padding:10px 13px 5px}
.udtv-bed-id{font-size:15px;font-weight:800;color:#fff;letter-spacing:.4px}
.udtv-status-pill{font-size:10px;font-weight:700;padding:3px 8px;border-radius:18px;letter-spacing:.5px}
.udtv-pill-ok{background:rgba(34,197,94,.18);color:#4ade80;border:1px solid rgba(34,197,94,.28)}
.udtv-pill-warn{background:rgba(245,158,11,.18);color:#fbbf24;border:1px solid rgba(245,158,11,.28)}
.udtv-pill-crit{background:rgba(239,68,68,.22);color:#f87171;border:1px solid rgba(239,68,68,.38)}
.udtv-pill-empty{background:rgba(255,255,255,.05);color:rgba(255,255,255,.28);border:1px solid rgba(255,255,255,.09)}
.udtv-turn-row{display:flex;align-items:center;justify-content:space-between;padding:0 13px 3px;font-size:11px;color:rgba(255,255,255,.38)}
.udtv-timer{padding:3px 13px 8px;font-size:13px;font-weight:700;letter-spacing:.2px}
.udtv-timer-ok{color:#4ade80}.udtv-timer-warn{color:#fbbf24}.udtv-timer-crit{color:#f87171}.udtv-timer-empty{color:rgba(255,255,255,.18)}
.udtv-divider{height:1px;background:rgba(255,255,255,.05);margin:0 13px}
.udtv-tasks{padding:8px 10px 6px;flex:1;display:flex;flex-direction:column;gap:3px}
.udtv-task{display:flex;align-items:center;gap:7px;padding:4px 5px;border-radius:8px;font-size:11px;color:rgba(255,255,255,.6);cursor:pointer;transition:background .1s;user-select:none}
.udtv-task:hover{background:rgba(255,255,255,.05)}
.udtv-task.done{color:rgba(255,255,255,.25)}
.udtv-task.done .udtv-task-text{text-decoration:line-through}
.udtv-task-cb{width:15px;height:15px;border-radius:8px;border:1.5px solid rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:9px;flex-shrink:0;transition:all .13s}
.udtv-task.done .udtv-task-cb{background:#16a34a;border-color:#16a34a;color:#fff}
.udtv-empty-msg{display:flex;flex:1;align-items:center;justify-content:center;padding:14px;font-size:11px;color:rgba(255,255,255,.18);font-style:italic}
.udtv-task-footer{padding:3px 13px 8px;font-size:10px;color:rgba(255,255,255,.2)}

/* ── UNIT DASHBOARD SUB-TABS ── */
.ud-subtabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}
.ud-subtab{padding:8px 18px;font-size:12px;font-weight:800;color:var(--muted);cursor:pointer;border-radius:999px;border:1px solid var(--border);background:#fff;transition:all .14s ease}
.ud-subtab:hover{color:var(--navy);border-color:rgba(31,78,140,.3)}
.ud-subtab.active{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border-color:transparent;box-shadow:0 10px 22px rgba(31,78,140,.18)}

/* ── AERIAL MAP BUILDER ── */
#ud-map-wrap{display:flex;gap:0;min-height:520px;border:1px solid var(--border);border-radius:var(--radius-card);overflow:hidden;background:#fff;box-shadow:var(--shadow-card)}
#ud-map-sidebar{width:210px;min-width:210px;background:linear-gradient(180deg,#F8FAFC 0%,#F1F5F9 100%);border-right:1px solid var(--border);padding:14px;display:flex;flex-direction:column;gap:0;overflow-y:auto}
.udm-sec-title{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:12px 0 6px}
.udm-palette-item{background:#fff;border:1.5px dashed var(--border);border-radius:var(--radius-sm);padding:8px 10px;margin-bottom:6px;cursor:grab;font-size:12px;font-weight:600;display:flex;align-items:center;gap:8px;user-select:none;transition:all .14s;box-shadow:var(--shadow-xs)}
.udm-palette-item:hover{border-color:var(--blue);border-style:solid;transform:translateY(-1px);box-shadow:var(--shadow-sm)}
#ud-map-canvas-wrap{flex:1;overflow:auto;padding:16px;background:var(--bg,#F6F8FA);position:relative}
#ud-map-canvas{min-width:760px;min-height:460px;position:relative}
.udm-room{position:absolute;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:move;user-select:none;transition:box-shadow .14s,transform .14s;min-width:80px;min-height:54px}
.udm-room:hover,.udm-bed:hover{box-shadow:0 0 0 2px var(--blue),0 8px 20px rgba(31,78,140,.12);transform:scale(1.02)}
.udm-room.selected,.udm-bed.selected{box-shadow:0 0 0 2px var(--blue),var(--shadow-md);z-index:20}
.udm-room.room-simple{justify-content:flex-start;padding-top:8px}
.udm-room-label{font-size:10px;font-weight:800;color:var(--navy);text-align:center;padding:2px 5px;pointer-events:none}
.udm-room-sub{font-size:9px;color:var(--muted);text-align:center;pointer-events:none}
.udm-pt{background:#EEF4FB;border:2px solid #93C5FD}
.udm-nurse{background:#EAF7EE;border:2px solid #86EFAC}
.udm-med{background:#FFFBEB;border:2px solid #FCD34D}
.udm-supply{background:#EEEDFE;border:2px solid #C4B5FD}
.udm-break{background:#E1F5EE;border:2px solid #6EE7B7}
.udm-clean{background:#FEF9EE;border:2px solid #FDE68A}
.udm-hall{background:#F1F5F9;border:2px solid #CBD5E1}
.udm-bed{position:absolute;border-radius:var(--radius-sm);min-width:72px;min-height:58px;cursor:move;user-select:none;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff;border:2px solid var(--border);transition:all .14s;box-shadow:var(--shadow-xs)}
.udm-bed.ok{border-color:var(--success);background:var(--success-soft)}
.udm-bed.warn{border-color:var(--warning);background:var(--warning-soft)}
.udm-bed.crit{border-color:var(--danger);background:var(--danger-soft);animation:udm-pulse 2s ease-in-out infinite}
.udm-bed.empty{border-color:var(--border);background:#F6F8FA;opacity:.7}
@keyframes udm-pulse{0%,100%{border-color:var(--danger)}50%{border-color:#EF4444;box-shadow:0 0 0 3px rgba(239,68,68,.15)}}
.udm-bed-id{font-size:10px;font-weight:800;color:var(--navy);pointer-events:none}
.udm-bed-time{font-size:9px;color:var(--muted);margin-top:2px;pointer-events:none}
.udm-bed-time.warn{color:var(--warning);font-weight:700}
.udm-bed-time.crit{color:var(--danger);font-weight:700}
.udm-del-btn{position:absolute;top:-8px;right:-8px;width:17px;height:17px;background:var(--danger);border-radius:50%;border:none;color:#fff;font-size:10px;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:30;line-height:1}
.udm-resize{position:absolute;bottom:2px;right:2px;width:11px;height:11px;cursor:se-resize;opacity:.4;display:none}
.udm-resize::after{content:'';display:block;width:8px;height:8px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted)}
.udm-editing .udm-room:hover .udm-del-btn,
.udm-editing .udm-bed:hover .udm-del-btn{display:flex}
.udm-editing .udm-resize{display:block}
.udm-legend{display:flex;flex-wrap:wrap;gap:8px;padding:10px 14px;border-top:1px solid var(--border);background:linear-gradient(180deg,#F8FAFC,#F1F5F9);border-radius:0 0 var(--radius-card) var(--radius-card)}
.udm-leg{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--muted)}
.udm-leg-dot{width:8px;height:8px;border-radius:8px;flex-shrink:0}

/* ── Map read-only notice (clinical users) ── */
#udm-readonly-notice{display:none;align-items:center;gap:8px;padding:10px 14px;background:var(--blue-soft);border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-md);font-size:12px;font-weight:600;color:var(--blue);margin-bottom:12px}

/* ── TV PREVIEW PANEL ── */
.ud-preview-panel{background:#14263F;border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;min-height:360px;box-shadow:var(--shadow-card)}
.ud-preview-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#1B3557;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}
.ud-preview-unitname{font-size:13px;font-weight:800;color:#fff}
.ud-preview-title{font-size:10px;font-weight:700;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}
.ud-preview-badge{font-size:9px;font-weight:700;background:rgba(59,130,246,.18);color:#60a5fa;border:1px solid rgba(59,130,246,.35);border-radius:8px;padding:2px 7px;letter-spacing:.07em;text-transform:uppercase}
.ud-preview-grid{flex:1;padding:10px;display:grid;gap:6px;align-content:start;overflow-y:auto}
.ud-preview-grid::-webkit-scrollbar{width:3px}
.ud-preview-grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.udpv-bed{background:#1B3557;border:1px solid rgba(255,255,255,.07);border-radius:var(--radius-sm);padding:10px 11px}
.udpv-bed.ok{border-color:rgba(47,158,68,.4)}
.udpv-bed.warn{border-color:rgba(217,119,6,.45)}
.udpv-bed.crit{border-color:rgba(201,42,42,.6);background:rgba(201,42,42,.07)}
.udpv-bed.empty{opacity:.45}
.udpv-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
.udpv-id{font-size:11px;font-weight:800;color:#fff}
.udpv-pill{font-size:9px;font-weight:700;padding:1px 5px;border-radius:8px;letter-spacing:.03em}
.udpv-ok{background:rgba(47,158,68,.25);color:#86efac}
.udpv-warn{background:rgba(217,119,6,.25);color:#fcd34d}
.udpv-crit{background:rgba(201,42,42,.3);color:#fca5a5}
.udpv-empty{background:rgba(255,255,255,.06);color:rgba(255,255,255,.28)}
.udpv-tasks{font-size:9px;color:rgba(255,255,255,.28);margin-top:1px}
.udpv-tasks.all-done{color:rgba(47,158,68,.7)}
.ud-preview-empty{color:rgba(255,255,255,.2);font-size:12px;text-align:center;padding:40px 12px;line-height:1.5}
/* Preview panel mode toggle */
.udpv-toggle{display:flex;gap:2px;background:rgba(255,255,255,.06);border-radius:8px;padding:2px}
.udpv-toggle-btn{font-size:9px;font-weight:700;padding:3px 8px;border-radius:8px;color:rgba(255,255,255,.35);cursor:pointer;letter-spacing:.04em;text-transform:uppercase;transition:all .15s;user-select:none}
.udpv-toggle-btn.active{background:rgba(255,255,255,.14);color:#fff}
/* Map preview inside the preview panel */
.ud-preview-map{flex:1;overflow:hidden;position:relative;background:#14263F;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:32px 32px;display:none}
.ud-preview-map.active{display:block}
.ud-preview-grid.active{display:grid}

/* ── UNIT COMMAND CENTER ── */
.udcc-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.udcc-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px 15px;box-shadow:0 4px 14px rgba(20,38,63,.04)}
.udcc-card.dark{background:linear-gradient(180deg,#14263F 0%,#1B3557 100%);border-color:#203A61;color:#fff}
.udcc-label{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.udcc-card.dark .udcc-label{color:rgba(255,255,255,.55)}
.udcc-value{font-size:28px;font-weight:900;color:var(--navy);margin-top:7px;line-height:1}
.udcc-card.dark .udcc-value{color:#fff}
.udcc-note{font-size:12px;color:var(--muted);margin-top:7px;line-height:1.4}
.udcc-card.dark .udcc-note{color:rgba(255,255,255,.7)}
.udcc-value.ok{color:var(--success)}.udcc-value.warn{color:#D97706}.udcc-value.crit{color:var(--danger)}
.udcc-grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(320px,.9fr);gap:12px}
.udcc-map-card{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;min-height:360px}
.udcc-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px 12px;border-bottom:1px solid var(--border)}
.udcc-card-title{font-size:15px;font-weight:800;color:var(--navy)}
.udcc-card-sub{font-size:12px;color:var(--muted);margin-top:3px}
.udcc-badges{display:flex;gap:6px;flex-wrap:wrap}
.udcc-badge{font-size:10px;font-weight:800;padding:4px 8px;border-radius:999px;letter-spacing:.04em}
.udcc-badge.live{background:#EAF2FB;color:#1F4E8C}
.udcc-badge.good{background:#EAF7EE;color:#0F6E56}
.udcc-badge.alert{background:#FDEEEE;color:#C53030}
.udcc-map-wrap{position:relative;flex:1;overflow:hidden;background:linear-gradient(rgba(20,38,63,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(20,38,63,.04) 1px,transparent 1px);background-size:32px 32px;background-color:#F8FAFC}
.udcc-map-empty{display:flex;align-items:center;justify-content:center;height:100%;padding:24px;text-align:center;color:var(--muted);font-size:13px;line-height:1.6}
.udcc-map-inner{position:absolute;transform-origin:top left}
.udcc-side{display:grid;gap:12px}
.udcc-queue{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden}
.udcc-filter-row{display:flex;gap:6px;flex-wrap:wrap;padding:0 16px 12px}
.udcc-filter-btn{font-size:11px;font-weight:700;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#F6F8FA;color:var(--muted);cursor:pointer;transition:all .15s}
.udcc-filter-btn.active,.udcc-filter-btn:hover{border-color:#1F4E8C;color:#1F4E8C;background:#EEF4FB}
.udcc-list{padding:0 16px 16px;display:flex;flex-direction:column;gap:8px;max-height:420px;overflow:auto}
.udcc-item{border:1px solid var(--border);border-radius:12px;padding:11px 12px;background:#fff;cursor:pointer;transition:all .15s}
.udcc-item:hover{border-color:#1F4E8C;box-shadow:0 6px 16px rgba(31,78,140,.08)}
.udcc-item-head{display:flex;align-items:center;gap:8px}
.udcc-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.udcc-dot.ok{background:#2F9E44}.udcc-dot.warn{background:#D97706}.udcc-dot.crit{background:#C53030}.udcc-dot.neutral{background:#AEB8C2}
.udcc-item-title{font-size:13px;font-weight:800;color:var(--navy);flex:1}
.udcc-item-meta{font-size:11px;color:var(--muted);margin-top:6px;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}
.udcc-item-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.udcc-chip{font-size:10px;font-weight:800;padding:4px 7px;border-radius:999px;background:#F6F8FA;color:#607080}
.udcc-chip.good{background:#EAF7EE;color:#0F6E56}
.udcc-chip.warn{background:#FFF4DD;color:#9C6500}
.udcc-chip.crit{background:#FDEEEE;color:#C53030}
.udcc-chip.live{background:#EEF4FB;color:#1F4E8C}
.udcc-empty{padding:18px;text-align:center;color:var(--muted);font-size:12px}
.udcc-rooms{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.udcc-room{background:#fff;border:1px solid var(--border);border-radius:14px;padding:13px;cursor:pointer;transition:all .15s}
.udcc-room:hover{border-color:#1F4E8C;transform:translateY(-1px);box-shadow:0 8px 16px rgba(20,38,63,.06)}
.udcc-room.room-simple{background:#FBFCFD}
.udcc-room-head{display:flex;align-items:center;gap:8px}
.udcc-room-name{font-size:14px;font-weight:800;color:var(--navy);flex:1}
.udcc-room-sub{font-size:11px;color:var(--muted);margin-top:2px}
.udcc-room-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}
.udcc-room-stat{padding:8px;border-radius:10px;background:#F6F8FA}
.udcc-room-stat .k{font-size:10px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.udcc-room-stat .v{font-size:15px;font-weight:800;color:var(--navy);margin-top:3px}
.udcc-room-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px;font-size:11px;color:var(--muted)}

/* ── ROOM DETAIL DRAWER ── */
#ud-room-drawer{position:fixed;inset:0;display:none;align-items:stretch;justify-content:flex-end;background:rgba(20,38,63,.34);z-index:9700}
#ud-room-drawer.open{display:flex}
.udrd-panel{width:min(540px,100%);height:100%;background:#fff;box-shadow:-18px 0 50px rgba(20,38,63,.18);display:flex;flex-direction:column}
.udrd-head{padding:18px 18px 14px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.udrd-title{font-size:20px;font-weight:900;color:var(--navy)}
.udrd-sub{font-size:12px;color:var(--muted);margin-top:4px}
.udrd-close{border:none;background:#F6F8FA;color:#607080;border-radius:10px;width:36px;height:36px;cursor:pointer;font-size:18px;line-height:1}
.udrd-body{padding:18px;overflow:auto;display:grid;gap:14px}
.udrd-section{border:1px solid var(--border);border-radius:14px;background:#fff;padding:14px}
.udrd-section h4{font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#607080;margin:0 0 12px}
.udrd-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.udrd-metric{padding:10px;border-radius:12px;background:#F6F8FA}
.udrd-metric .k{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.udrd-metric .v{font-size:18px;font-weight:900;color:var(--navy);margin-top:4px}
.udrd-list{display:flex;flex-direction:column;gap:8px}
.udrd-row{border:1px solid var(--border);border-radius:12px;padding:11px 12px}
.udrd-row-head{display:flex;align-items:center;gap:8px}
.udrd-row-title{font-size:13px;font-weight:800;color:var(--navy);flex:1}
.udrd-row-sub{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.5}
.udrd-pill{font-size:10px;font-weight:800;padding:4px 8px;border-radius:999px}
.udrd-pill.ok{background:#EAF7EE;color:#0F6E56}
.udrd-pill.warn{background:#FFF4DD;color:#9C6500}
.udrd-pill.crit{background:#FDEEEE;color:#C53030}
.udrd-pill.neutral{background:#EEF1F4;color:#607080}

@media (max-width:1100px){
  .udcc-summary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .udcc-grid{grid-template-columns:1fr}
}
@media (max-width:720px){
  .udcc-summary{grid-template-columns:1fr}
  .udrd-metrics{grid-template-columns:1fr 1fr}
}

/* ── TASK MANAGER ── */
.tm-task-card{background:#fff;border-radius:12px;border:1px solid var(--border);padding:12px 14px;margin-bottom:8px;transition:all .15s}
.tm-task-card:hover{border-color:var(--blue);box-shadow:0 2px 8px rgba(31,78,140,.07)}
.tm-task-card.tm-complete{border-color:var(--success)!important;background:var(--success-soft)}
.tm-task-card.tm-overdue{border-color:var(--danger)!important;background:var(--danger-soft)}
.tm-task-card.tm-in-progress{border-color:var(--warning)!important;background:var(--warning-soft)}
.tm-card-hdr{display:flex;align-items:center;gap:9px;cursor:pointer}
.tm-sdot{width:10px;height:10px;border-radius:50%;flex-shrink:0;transition:background .2s}
.tm-sdot-pending{background:var(--border)}.tm-sdot-progress{background:var(--warning)}.tm-sdot-complete{background:var(--success)}.tm-sdot-overdue{background:var(--danger)}
.tm-tname{font-size:14px;font-weight:700;color:var(--navy);flex:1}
.tm-tbadge{font-size:10px;padding:2px 8px;border-radius:8px;font-weight:700;white-space:nowrap}
.tm-b-crash{background:#FDEEEE;color:var(--danger);border:1px solid #F7C1C1}
.tm-b-temp{background:var(--blue-soft);color:var(--blue);border:1px solid #B5D4F4}
.tm-b-checklist{background:var(--purple-soft);color:var(--purple);border:1px solid #C4B5FD}
.tm-b-nfc{background:var(--teal-soft);color:var(--teal);border:1px solid #6EE7B7}
.tm-b-custom{background:#F6F8FA;color:var(--muted);border:1px solid var(--border)}
.tm-tmeta{display:flex;align-items:center;gap:10px;margin-top:4px;font-size:11px;color:var(--muted)}
.tm-chevron{color:var(--muted);font-size:11px;transition:transform .2s}
.tm-chevron.open{transform:rotate(180deg)}
.tm-expand{max-height:0;overflow:hidden;transition:max-height .28s ease}
.tm-expand.open{max-height:700px}
.tm-expand-inner{padding:10px 0 4px;border-top:1px solid var(--border);margin-top:9px}
.tm-nfc-tap{border:2px dashed var(--border);border-radius:10px;padding:14px;text-align:center;cursor:pointer;color:var(--muted);transition:all .13s;margin-bottom:8px}
.tm-nfc-tap:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft)}
.tm-nfc-tap.tapped{border-color:var(--success);background:var(--success-soft);color:var(--success);cursor:default}
.tm-cl-item{display:flex;align-items:center;gap:9px;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.tm-cl-item:last-child{border-bottom:none}
.tm-cl-item input{accent-color:var(--success);width:14px;height:14px;cursor:pointer;flex-shrink:0}
.tm-cl-item label{flex:1;cursor:pointer}
.tm-cl-item.done label{text-decoration:line-through;color:var(--muted)}
.tm-complete-btn{width:100%;border:none;border-radius:10px;padding:10px;font-weight:700;font-size:13px;cursor:pointer;margin-top:8px;transition:all .15s}
.tm-cbtn-pending{background:var(--blue-soft);color:var(--blue)}.tm-cbtn-pending:hover{background:var(--blue);color:#fff}
.tm-cbtn-done{background:var(--success-soft);color:var(--success);cursor:default}
.tm-progress-bar{height:5px;background:var(--border);border-radius:8px;overflow:hidden;margin:6px 0}
.tm-progress-fill{height:100%;border-radius:8px;background:var(--success);transition:width .3s}

/* ── ROOM BEDS — beds nested inside rooms on aerial map ── */
.udm-room-beds{display:flex;flex-wrap:wrap;gap:3px;padding:4px 3px 2px;justify-content:center;pointer-events:auto;margin-top:3px}
.udm-room-bed{width:32px;height:28px;border-radius:8px;border:1.5px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;font-size:7px;font-weight:800;line-height:1.1;transition:all .15s;position:relative;user-select:none}
.udm-room-bed:hover{filter:brightness(.9);transform:scale(1.06);z-index:5}
.udm-room-bed.bed-ok{background:#EAF7EE;border-color:#6FCF97;color:#0F6E56}
.udm-room-bed.bed-warn{background:#FFFBEB;border-color:#FCD34D;color:#92620A}
.udm-room-bed.bed-crit{background:#FDEEEE;border-color:#F7A0A0;color:#C53030;animation:bed-pulse 1.8s ease-in-out infinite}
.udm-room-bed.bed-clean{background:#EEF4FB;border-color:#93C5FD;color:#1F4E8C}
.udm-room-bed.bed-empty{background:#F6F8FA;border-color:#DDE3EA;color:#B4B2A9;opacity:.65}
@keyframes bed-pulse{0%,100%{border-color:#F7A0A0}50%{border-color:#E24B4A;box-shadow:0 0 0 3px rgba(201,42,42,.15)}}
.udm-room-bed-label{font-size:6px;line-height:1;opacity:.75;margin-top:1px}
.udm-add-bed-btn{width:30px;height:26px;border-radius:8px;border:1.5px dashed var(--border);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:16px;line-height:1;transition:all .15s}
.udm-add-bed-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft)}

/* ── BED ACTION MODAL ── */
#bed-action-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.44);z-index:9500;align-items:center;justify-content:center;padding:20px}
#bed-action-modal.open{display:flex}
.bam-card{background:#fff;border-radius:16px;padding:20px 22px;width:100%;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,.24)}
.bam-title{font-size:15px;font-weight:800;color:var(--navy);margin-bottom:3px}
.bam-sub{font-size:12px;color:var(--muted);margin-bottom:14px}
.bam-status-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.bam-opt{border:2px solid var(--border);border-radius:10px;padding:11px 8px;text-align:center;cursor:pointer;transition:all .15s}
.bam-opt:hover{opacity:.85;transform:translateY(-1px)}
.bam-opt.selected{transform:translateY(-1px);box-shadow:0 3px 10px rgba(0,0,0,.12)}
.bam-opt.bam-ok{border-color:#6FCF97;background:#EAF7EE}.bam-opt.bam-ok.selected{box-shadow:0 3px 10px rgba(47,158,68,.25)}
.bam-opt.bam-warn{border-color:#FCD34D;background:#FFFBEB}.bam-opt.bam-warn.selected{box-shadow:0 3px 10px rgba(217,119,6,.22)}
.bam-opt.bam-crit{border-color:#F7A0A0;background:#FDEEEE}.bam-opt.bam-crit.selected{box-shadow:0 3px 10px rgba(201,42,42,.22)}
.bam-opt.bam-clean{border-color:#93C5FD;background:#EEF4FB}.bam-opt.bam-clean.selected{box-shadow:0 3px 10px rgba(31,78,140,.2)}
.bam-opt.bam-empty{border-color:var(--border);background:#F6F8FA;grid-column:1/-1}
.bam-opt-icon{font-size:20px;margin-bottom:4px}
.bam-opt-label{font-size:11px;font-weight:800;color:var(--navy)}
.bam-opt-sub{font-size:10px;color:var(--muted);margin-top:1px}
.bam-note-field{width:100%;border:1px solid var(--border);border-radius:8px;padding:7px 9px;font-size:12px;color:var(--navy);resize:none;outline:none;margin-bottom:12px;font-family:inherit}
.bam-note-field:focus{border-color:var(--blue);box-shadow:0 0 0 2px rgba(31,78,140,.07)}
.bam-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--border)}
.bam-hist{font-size:11px;color:var(--muted);padding:7px 9px;background:var(--light);border-radius:8px;margin-bottom:12px;max-height:70px;overflow-y:auto;line-height:1.6}

/* ── TIME SCHEDULER (Task Manager) ── */
.sched-builder{background:#F6F8FA;border-radius:10px;border:1px solid var(--border);padding:10px 12px}
.sched-type-tabs{display:flex;gap:0;margin-bottom:10px;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff}
.sched-type-tab{flex:1;padding:5px 4px;font-size:10px;font-weight:700;color:var(--muted);cursor:pointer;text-align:center;border:none;background:transparent;transition:all .15s;border-right:1px solid var(--border)}
.sched-type-tab:last-child{border-right:none}
.sched-type-tab.active{background:var(--blue);color:#fff}
.sched-row{display:flex;gap:7px;align-items:center;margin-bottom:7px;flex-wrap:wrap}
.sched-row label{font-size:11px;font-weight:700;color:var(--muted);min-width:36px}
.sched-row input[type=time],.sched-row input[type=date],.sched-row input[type=number],.sched-row select{border:1px solid var(--border);border-radius:10px;padding:5px 8px;font-size:12px;color:var(--navy);background:#fff;outline:none;font-family:inherit}
.sched-row input:focus,.sched-row select:focus{border-color:var(--blue)}
.sched-day-btns{display:flex;gap:4px;flex-wrap:wrap}
.sched-day-btn{border:1px solid var(--border);border-radius:8px;padding:3px 7px;font-size:10px;font-weight:700;color:var(--muted);cursor:pointer;background:#fff;transition:all .15s}
.sched-day-btn.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.sched-summary{font-size:11px;color:var(--blue);font-style:italic;margin-top:6px;padding:5px 8px;background:var(--blue-soft);border-radius:8px;display:none}
.sched-summary.show{display:block}
.sched-time-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.sched-chip{display:inline-flex;align-items:center;gap:5px;background:var(--blue-soft);border:1px solid #B5D4F4;border-radius:8px;padding:2px 8px;font-size:11px;font-weight:700;color:var(--blue)}
.sched-chip button{background:none;border:none;cursor:pointer;color:var(--muted);font-size:10px;padding:0;line-height:1}
.sched-chip button:hover{color:var(--danger)}

/* ── HOSPITAL SETTINGS ── */
.hs-url-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.hs-url-seg{font-size:12px;color:var(--muted);white-space:nowrap;font-family:monospace}
.hs-slug-input{flex:1;min-width:100px;font-family:monospace;font-size:13px;border:1.5px solid var(--blue);border-radius:8px;padding:7px 10px;outline:none;color:var(--navy)}
.hs-slug-input:focus{box-shadow:0 0 0 3px rgba(31,78,140,.1)}
.hs-pa-row{display:flex;align-items:center;gap:8px;padding:9px 11px;border:1px solid var(--border);border-radius:10px;margin-bottom:7px;background:#fff}
.hs-pa-row:hover{background:var(--light)}
.hs-pa-type-badge{font-size:10px;font-weight:800;padding:2px 7px;border-radius:8px;background:var(--blue-soft);color:var(--blue);white-space:nowrap}
.hs-pa-url-display{flex:1;font-family:monospace;font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── SCHEDULED REPORTS ── */
.sr-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:13px 14px;margin-bottom:9px;display:flex;align-items:flex-start;gap:12px}
.sr-card:hover{border-color:#B5D4F4}
.sr-icon{width:38px;height:38px;border-radius:10px;background:var(--blue-soft);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:var(--blue);text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}
.sr-body{flex:1;min-width:0}
.sr-name{font-size:13px;font-weight:800;color:var(--navy);margin-bottom:2px}
.sr-meta{font-size:11px;color:var(--muted);line-height:1.5}
.sr-actions{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}
.sr-toggle{width:36px;height:20px;border-radius:10px;background:var(--border);border:none;cursor:pointer;position:relative;flex-shrink:0;transition:background .15s;margin-top:2px}
.sr-toggle.on{background:var(--success)}
.sr-toggle::after{content:'';position:absolute;width:16px;height:16px;border-radius:8px;background:#fff;top:2px;left:2px;transition:left .15s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.sr-toggle.on::after{left:18px}
.sr-empty{text-align:center;padding:30px 16px;color:var(--muted);font-size:13px}

/* ── UNIT MAP AERIAL PANEL (tab-unit) ── */
.umap-view-toggle{display:flex;gap:0;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff;margin-bottom:12px;width:fit-content}
.umap-view-btn{padding:6px 14px;font-size:12px;font-weight:700;color:var(--muted);cursor:pointer;border:none;background:transparent;transition:all .15s}
.umap-view-btn.active{background:var(--blue);color:#fff}
#umap-aerial-wrap{overflow:auto;border-radius:10px;border:1px solid var(--border);background:linear-gradient(rgba(20,38,63,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(20,38,63,.04) 1px,transparent 1px);background-size:30px 30px;background-color:#F8FAFC;min-height:280px;position:relative}
#umap-aerial-canvas{min-width:600px;min-height:300px;position:relative}
.umap-aerial-empty{padding:60px 20px;text-align:center;color:var(--muted);font-size:13px}

/* ── Password field with show/hide + generate ── */
.pass-field-wrap{position:relative;display:flex;gap:6px;align-items:center}
.pass-field-wrap .fi{flex:1;padding-right:44px;margin-bottom:0}
.pass-eye-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;color:var(--muted);display:flex;align-items:center;transition:color .15s}
.pass-eye-btn:hover{color:var(--navy)}
.pass-gen-row{display:flex;gap:6px;align-items:center;margin-top:5px}
.pass-gen-btn{border:1px solid var(--border);background:#fff;border-radius:8px;padding:6px 11px;font-size:12px;font-weight:700;color:var(--blue);cursor:pointer;white-space:nowrap;transition:all .15s}
.pass-gen-btn:hover{background:var(--blue-soft);border-color:var(--blue)}
.pass-strength{height:4px;border-radius:8px;flex:1;background:var(--border);overflow:hidden}
.pass-strength-fill{height:100%;border-radius:8px;transition:width .25s,background .25s}
.pass-cur-show{font-size:11px;color:var(--muted);margin-top:3px;word-break:break-all;padding:5px 8px;background:var(--light);border-radius:8px;border:1px solid var(--border);display:none}

/* ── Email Preview Modal ── */
.email-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.48);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px}
.email-modal-box{background:#fff;border-radius:16px;width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 70px rgba(0,0,0,.28);overflow:hidden}
.email-modal-hdr{padding:18px 22px 0;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.email-modal-title{font-size:16px;font-weight:800;color:var(--navy)}
.email-modal-close{background:none;border:none;font-size:18px;color:var(--muted);cursor:pointer;padding:2px 8px;border-radius:8px;transition:background .12s}
.email-modal-close:hover{background:var(--border);color:var(--navy)}
.email-tab-bar{display:flex;gap:4px;padding:12px 22px 0;border-bottom:1px solid var(--border);flex-shrink:0}
.email-tab-btn{padding:7px 14px;border:none;background:none;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s;border-radius:6px 6px 0 0}
.email-tab-btn.active{color:var(--blue);border-bottom-color:var(--blue)}
.email-tab-btn:hover:not(.active){color:var(--navy);background:var(--light)}
.email-modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column}
.email-view-bar{display:flex;gap:4px;padding:10px 22px;background:var(--light);border-bottom:1px solid var(--border);flex-shrink:0}
.email-view-btn{padding:5px 12px;border:1px solid var(--border);background:#fff;border-radius:10px;font-size:11px;font-weight:700;color:var(--muted);cursor:pointer;transition:all .12s}
.email-view-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.email-content-area{flex:1;overflow-y:auto;padding:0}
.email-preview-frame{width:100%;height:440px;border:none;background:#f5f5f5}
.email-code-area{width:100%;flex:1;font-family:"Courier New",monospace;font-size:11.5px;line-height:1.5;padding:18px 22px;border:none;outline:none;resize:none;color:var(--text);background:#FAFBFC;min-height:440px}
.email-modal-footer{padding:12px 22px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0;background:#fff;align-items:flex-start;flex-wrap:wrap}
.email-send-note{font-size:11px;color:var(--muted);flex:1 1 260px;display:block;line-height:1.45;white-space:pre-wrap;word-break:break-word;max-height:96px;overflow:auto;min-width:0}

/* ── NFC tag billing type ── */
.nfc-tag-type-row{display:flex;gap:6px;align-items:center;margin-top:6px}

/* ── Security Verification Widget ── */
.sec-verify-wrap{margin:10px 0 4px;display:flex;align-items:center;gap:10px;padding:10px 13px;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;user-select:none;transition:border-color .2s,background .2s,box-shadow .2s,transform .16s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.sec-verify-wrap:hover:not(.verified):not(.verifying),.sec-verify-wrap:focus-visible{border-color:rgba(31,78,140,.46);box-shadow:0 0 0 3px rgba(31,78,140,.10);outline:none}
.sec-verify-wrap.verified{border-color:rgba(47,158,68,.42);background:rgba(47,158,68,.07);cursor:default;box-shadow:0 8px 22px rgba(47,158,68,.10)}
.sec-verify-wrap.verifying{border-color:rgba(59,130,246,.6);background:var(--blue-soft);cursor:default}
.sec-verify-wrap.pulse-err{border-color:var(--danger)!important;background:var(--danger-soft)!important;animation:svPulse .4s ease}
@keyframes svPulse{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
.sec-verify-cb{width:20px;height:20px;border-radius:8px;border:1.5px solid var(--border);background:#fff;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .25s;position:relative;overflow:hidden}
.sec-verify-wrap.verified .sec-verify-cb{background:#2F9E44;border-color:#2F9E44;color:#fff;box-shadow:0 0 0 4px rgba(47,158,68,.12)}
.sec-verify-wrap.verifying .sec-verify-cb{background:var(--blue-soft);border-color:var(--blue)}
.sec-verify-tick{opacity:0;transform:scale(0);transition:opacity .2s .1s,transform .2s .1s}
.sec-verify-wrap.verified .sec-verify-tick{opacity:1;transform:scale(1)}
.sec-verify-spinner{position:absolute;width:13px;height:13px;border:1.5px solid transparent;border-top-color:var(--blue);border-radius:50%;opacity:0;animation:svSpin .65s linear infinite}
.sec-verify-wrap.verifying:not(.verified) .sec-verify-spinner{opacity:1}
@keyframes svSpin{to{transform:rotate(360deg)}}
.sec-verify-label{font-size:12.5px;color:var(--muted);flex:1;line-height:1.3;transition:color .2s}
.sec-verify-wrap.verified .sec-verify-label{color:#1E8449;font-weight:800}
.sec-verify-wrap.pulse-err .sec-verify-label{color:var(--danger)!important}
.sec-verify-shield{flex-shrink:0;opacity:.35;transition:opacity .2s,color .2s}
.sec-verify-wrap.verified .sec-verify-shield{opacity:1;color:#2F9E44}

/* ══════════════════════════════════════════════════════════
   DESIGN SYSTEM v3 — Refined, Mobile-first, Production-ready
══════════════════════════════════════════════════════════ */

/* Global scrollbar */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(100,116,139,.2);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(100,116,139,.38)}

/* Data rows */
.dr{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light);font-size:13px}
.dr:last-child{border-bottom:none}

/* Badges — refined */
.badge{display:inline-flex;align-items:center;font-size:11px;padding:2px 8px;border-radius:18px;font-weight:600;letter-spacing:.02em;gap:4px}
.b-ok{background:var(--success-soft);color:var(--success)}
.b-warn{background:var(--warning-soft);color:var(--warning)}
.b-crit{background:var(--danger-soft);color:var(--danger)}
.b-blue{background:var(--blue-soft);color:var(--blue)}
.b-gray{background:var(--surface-2);color:var(--muted);border:1px solid var(--border)}
.b-purple{background:var(--purple-soft);color:var(--purple)}
.b-teal{background:var(--teal-soft);color:var(--teal)}

/* Improved card hover */
.card{transition:var(--transition-card)}
.card:hover{box-shadow:var(--shadow-card-hover)}

/* Metric card polish */
.metric:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}

/* Hospital card */
.hospital-card{transition:var(--transition-card)}

/* Section card title */
.ct{letter-spacing:.08em}

/* Improved form builder */
.fbe-field-row{border-radius:12px;border:1.5px solid var(--border);background:var(--surface-2)}
.fbe-field-row:hover{border-color:rgba(31,78,140,.25)}

/* Tables — clean and modern */
table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;background:#fff;border:1px solid rgba(20,38,63,.08);border-radius:14px;overflow:hidden}
thead th{padding:11px 12px;text-align:left;font-size:10.5px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.09em;background:linear-gradient(180deg,#F8FAFD 0%,#F1F5F9 100%);border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0;z-index:1}
tbody td{padding:11px 12px;border-bottom:1px solid var(--border-light);color:var(--text);vertical-align:top;background:#fff}
tbody tr:hover td{background:#FAFCFF}
tbody tr:last-child td{border-bottom:none}

/* ── NFC sim & tap elements ── */
.nfc-sim{border-radius:12px;transition:all .15s ease}
.nfc-sim:hover{border-color:var(--blue);background:var(--blue-soft)}
.nfc-sim.tapped{border-color:var(--success);background:var(--success-soft)}

/* Task manager card polish */
.tm-task-card{border-radius:12px;border:1.5px solid var(--border);transition:all .15s ease}
.tm-task-card:hover{border-color:rgba(31,78,140,.3);box-shadow:var(--shadow-sm)}

/* Module rate cards */
.mod-rate-card{border-radius:12px;background:#fff;border:1.5px solid var(--border)}
.mod-rate-card:hover{border-color:rgba(31,78,140,.3);box-shadow:var(--shadow-sm)}

/* Billing cards */
.bill-card{border-radius:var(--radius-card);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-xs)}
.bill-card-hdr:hover{background:var(--surface-2)}

/* Scheduled report cards */
.sr-card{border-radius:var(--radius-card);border:1px solid var(--border);box-shadow:var(--shadow-xs);transition:var(--transition-card)}
.sr-card:hover{border-color:#B5D4F4;box-shadow:var(--shadow-sm);transform:translateY(-1px)}

/* Progress bars */
.prog-bar{height:5px;border-radius:8px;background:var(--border-light)}
.prog-fill{border-radius:8px;background:linear-gradient(90deg,var(--blue),#3B6FB6)}

/* ── More Drawer ── */
#mob-drawer-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1100;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
#mob-drawer-backdrop.open{display:block}
#mob-drawer{position:fixed;bottom:0;left:0;right:0;background:#0C1A2E;z-index:1200;border-radius:24px 24px 0 0;padding:0 0 env(safe-area-inset-bottom,16px);box-shadow:0 -12px 60px rgba(0,0,0,.5);transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);max-height:82vh;overflow:hidden;display:flex;flex-direction:column;border-top:1px solid rgba(255,255,255,.07)}
#mob-drawer.open{transform:translateY(0)}
.mob-drawer-handle{width:36px;height:4px;background:rgba(255,255,255,.18);border-radius:8px;margin:14px auto 2px;flex-shrink:0}
.mob-drawer-header{padding:8px 20px 10px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.05)}
.mob-drawer-title{font-size:10.5px;font-weight:700;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.12em}
.mob-drawer-close{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.45);cursor:pointer;font-size:14px;width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .14s}
.mob-drawer-close:hover{background:rgba(255,255,255,.14);color:#fff}
.mob-drawer-scroll{overflow-y:auto;padding:6px 12px 24px;-webkit-overflow-scrolling:touch}
.mob-drawer-scroll::-webkit-scrollbar{display:none}
.mob-drawer-section{font-size:9.5px;font-weight:700;color:rgba(255,255,255,.22);text-transform:uppercase;letter-spacing:.12em;padding:12px 8px 6px}
.mob-drawer-item{display:flex;align-items:center;gap:14px;padding:13px 14px;border-radius:12px;color:rgba(255,255,255,.58);cursor:pointer;transition:all .14s;font-size:14px;font-weight:600;margin-bottom:2px;-webkit-tap-highlight-color:transparent}
.mob-drawer-item:active{background:rgba(96,165,250,.2);color:#E0EDFF}
.mob-drawer-item.active{background:rgba(96,165,250,.18);color:#60A5FA}
.mob-drawer-item svg{width:18px;height:18px;flex-shrink:0;opacity:.6}
.mob-drawer-item.active svg{opacity:1}
.mob-drawer-divider{height:1px;background:rgba(255,255,255,.05);margin:6px 4px}

/* ── Mobile responsive overrides ── */
@media(max-width:768px){
  .content{padding:16px 14px 22px}
  .main{padding-bottom:84px}
  .ph-title{font-size:18px}
  .ph-sub{font-size:12.5px}
  .ph{margin-bottom:14px}
  .card{padding:16px 14px;border-radius:14px}
  .metrics{grid-template-columns:1fr 1fr;gap:9px}
  .two-col,.three-col{grid-template-columns:1fr;gap:10px}
  .dr{padding:10px 0}
  select,.fi{font-size:16px!important} /* prevent iOS auto-zoom */
  .topbar{display:none}
  .edit-modal{max-height:96vh;border-radius:22px 22px 0 0;margin:0;max-width:100%;align-self:flex-end}
  .edit-modal-backdrop{align-items:flex-end;padding:0}
  .mh-stats{grid-template-columns:1fr 1fr}
  .bill-mod-units,.bill-mod-rate{min-width:unset;font-size:11px}
  .bill-mod-row{flex-wrap:wrap;gap:5px}
  .bill-card-hdr{gap:8px;padding:11px 12px}
  table{font-size:12px;display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  thead,tbody,tr{width:100%}
  thead th{padding:9px 10px}
  tbody td{padding:10px 10px}
  .login-card{border-radius:20px}
  .btn{min-height:46px;padding:0 14px}
  .btn-sm{min-height:38px;padding:0 12px}
  .three-col{grid-template-columns:1fr 1fr}
  .mh-stats{grid-template-columns:1fr 1fr}
  .two-col .card:first-child{order:2}
  .two-col .card:last-child{order:1}
  .metric{padding:12px 14px}
  .mval{font-size:20px}
  .hospital-card{padding:12px 14px}
  .sb-item,.mt-btn,.mob-drawer-item{touch-action:manipulation}
}
@media(max-width:480px){
  .metrics{grid-template-columns:1fr 1fr}
  .three-col{grid-template-columns:1fr}
  .content{padding:14px 12px 20px}
  .mval{font-size:18px}
  .ph-title{font-size:17px}
  .card{padding:14px 12px}
  .topbar-title{font-size:13px}
  /* Hide the inline search on narrow widths to keep the topbar uncluttered.
     Users can still reach assets/checklists via their normal sections. */
  .topbar-search{display:none}
  .topbar-user-menu{right:8px;left:8px;min-width:auto}
}

/* ── Focus visible accessibility ── */
*:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:4px}

/* ══════════════════════════════════════════════════════════════════════════════
   IN-APP MESSAGING
   ══════════════════════════════════════════════════════════════════════════════ */

/* Bell button */
.msg-bell{position:relative;background:none;border:1px solid var(--border);border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--navy);transition:background .14s,border-color .14s;flex-shrink:0}
.msg-bell:hover{background:var(--bg);border-color:var(--blue);color:var(--blue)}
.msg-bell-badge{position:absolute;top:-5px;right:-5px;background:#E53E3E;color:#fff;border-radius:10px;font-size:10px;font-weight:800;min-width:16px;height:16px;padding:0 3px;display:flex;align-items:center;justify-content:center;border:2px solid #fff;line-height:1}

/* Inbox slide-in panel */
.inbox-panel{position:fixed;top:0;right:-400px;width:380px;max-width:calc(100vw - 20px);height:100vh;background:#fff;z-index:4000;display:flex;flex-direction:column;box-shadow:-4px 0 32px rgba(0,0,0,.14);transition:right .25s cubic-bezier(.4,0,.2,1);border-left:1px solid var(--border)}
.inbox-panel.open{right:0}
.inbox-hdr{padding:18px 20px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.inbox-title{font-size:16px;font-weight:800;color:var(--navy)}
.inbox-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-height:0}

/* Tab bar inside inbox */
.msg-tab-bar{display:flex;gap:2px;padding:10px 12px 0;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap;align-items:center}
.msg-tab{padding:6px 12px;border:none;background:none;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s;border-radius:4px 4px 0 0}
.msg-tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.msg-tab:hover:not(.active){color:var(--navy);background:var(--bg)}
.msg-compose-btn{margin-left:auto;padding:5px 10px;border:1px solid var(--blue);background:none;color:var(--blue);border-radius:8px;font-size:11px;font-weight:700;cursor:pointer;transition:background .12s;white-space:nowrap}
.msg-compose-btn:hover{background:var(--blue);color:#fff}

/* Message list */
.msg-list{flex:1;overflow-y:auto;padding:8px 0}
.msg-item{padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}
.msg-item:hover{background:var(--bg)}
.msg-item.unread{background:#F0F6FF}
.msg-item.unread .msg-item-from{font-weight:800;color:var(--navy)}
.msg-item.unread .msg-item-subject{font-weight:700;color:var(--navy)}
.msg-item-top{display:flex;align-items:center;gap:6px;margin-bottom:3px}
.msg-item-from{font-size:12px;font-weight:600;color:var(--navy);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msg-item-time{font-size:11px;color:var(--muted);flex-shrink:0}
.msg-item-subject{font-size:12px;font-weight:600;color:var(--navy);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msg-item-preview{font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Type chips */
.msg-chip{font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;flex-shrink:0}
.msg-chip-broadcast{background:#EEF4FF;color:#1F4E8C}
.msg-chip-support{background:#FEF3C7;color:#92400E}

/* Empty / loading states */
.msg-empty{flex:1;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--muted);padding:32px;text-align:center}
.msg-loading{flex:1;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--muted);padding:32px}

/* Thread view */
.msg-thread-header{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0;background:var(--bg)}
.msg-back-btn{background:none;border:1px solid var(--border);border-radius:8px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;color:var(--navy);white-space:nowrap;transition:background .12s}
.msg-back-btn:hover{background:var(--border)}
.msg-thread-subject{font-size:13px;font-weight:700;color:var(--navy);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msg-thread-body{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px;min-height:0}
.msg-bubble{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px 14px;max-width:95%}
.msg-bubble.mine{background:#EEF4FF;border-color:rgba(31,78,140,.15);align-self:flex-end}
.msg-bubble-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.msg-bubble-name{font-size:11px;font-weight:700;color:var(--navy)}
.msg-bubble-time{font-size:10px;color:var(--muted)}
.msg-bubble-body{font-size:13px;color:var(--navy);line-height:1.5;word-break:break-word}

/* Reply bar */
.msg-reply-bar{padding:10px 14px;border-top:1px solid var(--border);display:flex;gap:8px;align-items:flex-end;flex-shrink:0;background:#fff}
.msg-reply-input{flex:1;resize:none;font-family:inherit;font-size:13px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;outline:none;transition:border-color .14s;background:#fff;color:var(--navy)}

/* Checklists Studio */
.checklists-studio-shell{max-width:1440px;margin:0 auto;padding:0 20px 32px}
.checklists-studio-view{min-height:560px;animation:tfStudioFade .18s ease-out}

/* Soft fade-in for the Studio view + cards so re-renders (tab switches,
   wizard step jumps, edit-template hydration) don't snap-replace. Keeps
   form inputs from "blinking" when the user clicks Save → re-opens.
   Field rows use the existing border/background transition (line below). */
@keyframes tfStudioFade { from { opacity:.55; transform:translateY(2px) } to { opacity:1; transform:none } }
.checklists-studio-card{transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}
.checklists-studio-section-card{animation:tfStudioFade .14s ease-out}
.checklists-studio-field-row[aria-expanded="true"]{transition:border-color .12s ease,background .12s ease,box-shadow .12s ease,transform .12s ease;transform:translateZ(0)}
.checklists-studio-field-row > .checklists-studio-field-label{transition:opacity .12s ease}
.checklists-studio-preview-card{transition:opacity .14s ease}
/* Compact pill tab bar — replaced the old big-card grid that duplicated
   the page-header nav. Single horizontal strip with subtle active state.
   Wraps cleanly on narrow viewports and stays accessible (role=tablist). */
.checklists-studio-tabs{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 18px;padding:5px;background:#F1F5F9;border:1px solid var(--border);border-radius:14px;width:fit-content;max-width:100%}
.checklists-studio-tab{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:10px;border:none;background:transparent;color:#475569;cursor:pointer;font-size:13px;font-weight:600;text-align:left;transition:background .16s ease,color .16s ease,box-shadow .16s ease,transform .12s ease;min-height:38px;will-change:transform}
.checklists-studio-tab:hover{background:rgba(255,255,255,.7);color:#0F172A}
.checklists-studio-tab.is-active{background:#fff;color:#0F172A;font-weight:700;box-shadow:0 2px 6px rgba(15,23,42,.08),0 0 0 1px rgba(31,78,140,.12)}
.checklists-studio-tab:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
.checklists-studio-tab-label{display:inline-block;line-height:1.2;white-space:nowrap}
@media (max-width:680px){
  .checklists-studio-tabs{width:100%;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .checklists-studio-tab{flex:0 0 auto}
}
.checklists-studio-library{display:flex;flex-direction:column;gap:16px}
.checklists-studio-library-filters{display:grid;grid-template-columns:minmax(220px,1.6fr) repeat(3,minmax(140px,1fr));gap:12px}
.checklists-studio-shell select{-webkit-appearance:none;appearance:none;padding-right:40px!important;border:1px solid rgba(31,78,140,.18)!important;border-radius:12px!important;background-color:#fff!important;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3.5 5.25 7 8.75l3.5-3.5' fill='none' stroke='%231F4E8C' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")!important;background-repeat:no-repeat!important;background-position:right 12px center!important;background-size:14px 14px!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.95),0 8px 22px rgba(20,38,63,.04);transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}
.checklists-studio-shell select:hover{border-color:rgba(31,78,140,.34)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.98),0 12px 26px rgba(20,38,63,.08)}
.checklists-studio-shell select:focus{outline:none;border-color:rgba(31,78,140,.58)!important;box-shadow:0 0 0 4px rgba(31,78,140,.12),0 14px 30px rgba(20,38,63,.1)}
.checklists-studio-workspace-shell{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.8fr);gap:18px;align-items:start}
.checklists-studio-workspace-main{min-width:0}
.checklists-studio-workspace{display:flex;flex-direction:column;gap:18px;padding-bottom:112px}
.checklists-studio-card{border:1px solid var(--border);border-radius:18px;background:rgba(255,255,255,.97);box-shadow:0 16px 34px rgba(20,38,63,.06)}
.checklists-studio-meta-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,320px);gap:18px;align-items:start}
.checklists-studio-meta-stack{display:flex;flex-direction:column;gap:14px}
.checklists-studio-meta-card{overflow:hidden}
.checklists-studio-details summary::-webkit-details-marker{display:none}
.checklists-studio-sections{display:flex;flex-direction:column;gap:16px}
.checklists-studio-sections-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.checklists-studio-sections-list{display:flex;flex-direction:column;gap:14px}
.checklists-studio-section-card{scroll-margin-bottom:132px}
.checklists-studio-section-top{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;margin-bottom:10px}
.checklists-studio-section-top input[type=text]{width:100%;min-width:0}
.checklists-studio-section-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.checklists-studio-field-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 12px;border:1px solid var(--border);margin-top:8px;cursor:pointer;transition:border-color .12s,background .12s,box-shadow .12s}
.checklists-studio-field-label{flex:1 1 220px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.checklists-studio-field-actions{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-left:auto}
.checklists-studio-preview{position:sticky;top:18px}
.checklists-studio-preview-card{border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,#fff 0%,#F8FBFF 100%);box-shadow:0 18px 36px rgba(20,38,63,.08);overflow:hidden}
.checklists-studio-preview-topbar{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:18px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.9)}
.checklists-studio-preview-kicker{font-size:11px;font-weight:800;color:var(--primary);text-transform:uppercase;letter-spacing:.08em}
.checklists-studio-preview-title{font-size:18px;font-weight:800;color:#0F172A;margin-top:4px}
.checklists-studio-preview-subtitle{font-size:12px;color:var(--muted);margin-top:4px}
.checklists-studio-preview-progress{padding:16px 18px 0}
.checklists-studio-preview-progress-meta{display:flex;justify-content:space-between;gap:10px;align-items:center;font-size:12px;color:#334155}
.checklists-studio-preview-progress-meta strong{font-size:12px;color:#0F172A}
.checklists-studio-preview-progress-bar{height:10px;border-radius:999px;background:#E2E8F0;overflow:hidden;margin-top:8px}
.checklists-studio-preview-progress-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(135deg,#14263F,#1F4E8C)}
.checklists-studio-preview-banner{margin:16px 18px 0;padding:12px 14px;border-radius:14px;background:#EEF4FB;border:1px solid rgba(31,78,140,.14);font-size:12px;line-height:1.5;color:#1E3A5F}
.checklists-studio-preview-banner.is-read-do{background:#EEF2FF;border-color:#C7D2FE;color:#3730A3}
.checklists-studio-preview-banner.is-batch{background:#F0F9FF;border-color:#BAE6FD;color:#075985}
.checklists-studio-preview-run{padding:18px;display:flex;flex-direction:column;gap:14px;max-height:calc(100vh - 180px);overflow:auto}
.checklists-studio-preview-section{border:1px solid var(--border);border-radius:16px;background:#fff;overflow:hidden}
.checklists-studio-preview-section-head{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border-light);background:#F8FAFC;font-size:12px;color:#475569}
.checklists-studio-preview-section-head strong{font-size:13px;color:#0F172A}
.checklists-studio-preview-section-head span:last-child{margin-left:auto}
.checklists-studio-preview-section-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}
.checklists-studio-preview-item{padding:14px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:10px}
.checklists-studio-preview-item:first-of-type{border-top:none}
.checklists-studio-preview-item.is-locked{background:#F8FAFC}
.checklists-studio-preview-item-head{display:flex;align-items:flex-start;gap:10px;justify-content:space-between}
.checklists-studio-preview-item-label{font-size:13px;font-weight:700;color:#0F172A;line-height:1.45}
.checklists-studio-preview-item-type{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}
.checklists-studio-preview-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:#334155}
.checklists-studio-preview-choice-row{display:flex;gap:8px;flex-wrap:wrap}
.checklists-studio-preview-choice{padding:9px 12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:#334155;font-size:12px;font-weight:700;cursor:pointer}
.checklists-studio-preview-choice.is-pass{background:#ECFDF5;border-color:#BBF7D0;color:#15803D}
.checklists-studio-preview-choice.is-fail{background:#FEF2F2;border-color:#FECACA;color:#B91C1C}
.checklists-studio-preview-input-stack{display:flex;flex-direction:column;gap:6px}
.checklists-studio-preview-meta{font-size:11px;color:var(--muted);line-height:1.45}
.checklists-studio-preview-note{padding:11px 12px;border-radius:12px;background:#F8FAFC;border:1px dashed var(--border);font-size:12px;line-height:1.55;color:#475569}
.checklists-studio-preview-notes{border:1px solid var(--border);border-radius:16px;background:#fff;padding:14px;display:flex;flex-direction:column;gap:10px}
.checklists-studio-preview-submitbar{display:flex;gap:10px;justify-content:flex-end;align-items:center;flex-wrap:wrap}
.checklists-studio-savebar{position:sticky;bottom:16px;z-index:12;display:flex;flex-direction:column;gap:10px;padding:16px 18px;border:1px solid rgba(148,163,184,.35);border-radius:18px;background:rgba(255,255,255,.96);backdrop-filter:blur(16px);box-shadow:0 20px 40px rgba(20,38,63,.12)}
.checklists-studio-savebar-body{display:flex;gap:12px;justify-content:space-between;align-items:center;flex-wrap:wrap}
.checklists-studio-savebar-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-left:auto}
.studio-builder-modal{position:fixed;inset:0;z-index:9800;display:none;align-items:center;justify-content:center;padding:clamp(10px,2vw,24px)}
.studio-builder-modal.open{display:flex}
.studio-builder-modal-backdrop{position:absolute;inset:0;background:rgba(20,38,63,.46);backdrop-filter:blur(4px)}
.studio-builder-modal-panel{position:relative;width:min(1280px,calc(100vw - 32px));height:min(920px,calc(100dvh - 32px));display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(216,222,230,.95);border-radius:20px;background:var(--surface,#fff);box-shadow:0 24px 60px rgba(20,38,63,.24)}
.studio-builder-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:1px solid var(--border,#D8DEE6);background:linear-gradient(180deg,#fff 0%,#F8FBFF 100%)}
.studio-builder-modal-copy{min-width:0}
.studio-builder-modal-kicker{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--primary,#1F4E8C)}
.studio-builder-modal-title{margin:3px 0 0;font-family:var(--font-heading,inherit);font-size:22px;line-height:1.2;color:var(--text-primary,#14263F)}
.studio-builder-modal-subtitle{margin:6px 0 0;max-width:780px;font-size:13px;line-height:1.45;color:var(--text-secondary,#5E6B78)}
.studio-builder-modal-close{min-height:44px;padding:0 16px;border:1px solid var(--border,#D8DEE6);border-radius:12px;background:#fff;color:var(--text-primary,#14263F);font-size:13px;font-weight:800;cursor:pointer;box-shadow:0 8px 18px rgba(20,38,63,.06)}
.studio-builder-modal-close:focus-visible{outline:3px solid rgba(31,78,140,.22);outline-offset:2px}
.studio-builder-modal-body{flex:1;min-height:0;overflow:auto;padding:18px;background:var(--bg,#F6F8FA);-webkit-overflow-scrolling:touch}
body.studio-builder-modal-open{overflow:hidden}
.studio-builder-modal-body .checklists-studio-workspace-shell{height:100%;min-height:0}
.studio-builder-modal-body .checklists-studio-workspace-main{min-height:0}
.studio-builder-modal-body .checklists-studio-preview{top:0}
.studio-builder-modal-body .checklists-studio-preview-run{max-height:calc(100dvh - 310px)}
.wf-builder-modal{position:fixed;inset:0;z-index:9800;display:none;align-items:center;justify-content:center;padding:clamp(10px,2vw,24px)}
.wf-builder-modal.open{display:flex}
.wf-builder-modal-backdrop{position:absolute;inset:0;background:rgba(20,38,63,.46);backdrop-filter:blur(4px)}
.wf-builder-modal-panel{position:relative;width:min(1280px,calc(100vw - 32px));height:min(920px,calc(100dvh - 32px));display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(216,222,230,.95);border-radius:20px;background:var(--surface,#fff);box-shadow:0 24px 60px rgba(20,38,63,.24)}
.wf-builder-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:1px solid var(--border,#D8DEE6);background:linear-gradient(180deg,#fff 0%,#F8FBFF 100%)}
.wf-builder-modal-copy{min-width:0}
.wf-builder-modal-kicker{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--primary,#1F4E8C)}
.wf-builder-modal-title{margin:3px 0 0;font-family:var(--font-heading,inherit);font-size:22px;line-height:1.2;color:var(--text-primary,#14263F)}
.wf-builder-modal-subtitle{margin:6px 0 0;max-width:780px;font-size:13px;line-height:1.45;color:var(--text-secondary,#5E6B78)}
.wf-builder-modal-close{min-height:44px;padding:0 16px;border:1px solid var(--border,#D8DEE6);border-radius:12px;background:#fff;color:var(--text-primary,#14263F);font-size:13px;font-weight:800;cursor:pointer;box-shadow:0 8px 18px rgba(20,38,63,.06)}
.wf-builder-modal-close:focus-visible{outline:3px solid rgba(31,78,140,.22);outline-offset:2px}
.wf-builder-modal-body{flex:1;min-height:0;overflow:auto;padding:18px;background:var(--bg,#F6F8FA);-webkit-overflow-scrolling:touch}
body.wf-builder-modal-open{overflow:hidden}
.checklists-studio-inventory-card{display:flex;flex-direction:column;gap:12px;padding:14px;border:1px solid rgba(31,78,140,.14);border-radius:16px;background:linear-gradient(180deg,#FFFFFF 0%,#F8FBFF 100%)}
.checklists-studio-inventory-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.checklists-studio-inventory-title{font-size:12px;font-weight:800;color:#1F4E8C;text-transform:uppercase;letter-spacing:.08em}
.checklists-studio-inventory-mode{display:inline-flex;align-items:center;gap:6px;padding:4px;border-radius:999px;background:#EAF1FB;border:1px solid rgba(31,78,140,.12)}
.checklists-studio-inventory-mode button{border:none;background:transparent;color:#49637F;font-size:12px;font-weight:800;padding:8px 12px;border-radius:999px;cursor:pointer;transition:background .14s ease,color .14s ease,box-shadow .14s ease}
.checklists-studio-inventory-mode button.is-active{background:linear-gradient(135deg,#14263F,#1F4E8C);color:#fff;box-shadow:0 10px 18px rgba(31,78,140,.2)}
.checklists-studio-inventory-stack{display:flex;flex-direction:column;gap:10px}
.checklists-studio-inventory-helper{font-size:11px;line-height:1.5;color:#5B7088}
.checklists-studio-inventory-helper.is-warning{padding:10px 12px;border-radius:12px;background:#FFF7ED;border:1px solid #FED7AA;color:#9A3412}
.checklists-studio-inventory-summary{display:flex;flex-direction:column;gap:8px;padding:12px 14px;border-radius:14px;background:#fff;border:1px solid rgba(31,78,140,.12);box-shadow:0 10px 22px rgba(20,38,63,.05)}
.checklists-studio-inventory-summary-title{font-size:13px;font-weight:800;color:#0F172A}
.checklists-studio-inventory-summary-meta,.checklists-studio-inventory-summary-stats{display:flex;gap:8px;flex-wrap:wrap}
.checklists-studio-inventory-summary-meta span,.checklists-studio-inventory-summary-stats span{display:inline-flex;align-items:center;gap:4px;padding:5px 9px;border-radius:999px;background:#F8FAFC;border:1px solid var(--border-light);font-size:11px;color:#475569}
.checklists-studio-inventory-createbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding-top:4px}

@media (max-width:1180px){
  .checklists-studio-library-filters{grid-template-columns:repeat(2,minmax(0,1fr))}
  .checklists-studio-meta-grid{grid-template-columns:1fr}
  .checklists-studio-workspace-shell{grid-template-columns:1fr}
  .checklists-studio-preview{position:static}
  .checklists-studio-preview-run{max-height:none}
}

@media (max-width:820px){
  .checklists-studio-shell{padding:0 14px 28px}
  .studio-builder-modal{padding:0;align-items:stretch}
  .studio-builder-modal-panel{width:100vw;height:100dvh;border-radius:0;border-left:none;border-right:none}
  .studio-builder-modal-head{padding:14px;align-items:center}
  .studio-builder-modal-title{font-size:18px}
  .studio-builder-modal-subtitle{display:none}
  .studio-builder-modal-body{padding:12px}
  .studio-builder-modal-body .checklists-studio-workspace-shell{height:auto}
  .studio-builder-modal-body .checklists-studio-preview-run{max-height:none}
  .wf-builder-modal{padding:0;align-items:stretch}
  .wf-builder-modal-panel{width:100vw;height:100dvh;border-radius:0;border-left:none;border-right:none}
  .wf-builder-modal-head{padding:14px;align-items:center}
  .wf-builder-modal-title{font-size:18px}
  .wf-builder-modal-subtitle{display:none}
  .wf-builder-modal-body{padding:12px}
  .checklists-studio-section-top{grid-template-columns:minmax(0,1fr)}
  .checklists-studio-section-actions{justify-content:flex-start}
  .checklists-studio-field-actions{margin-left:0}
}

@media (max-width:640px){
  .checklists-studio-library-filters{grid-template-columns:1fr}
  .checklists-studio-workspace{padding-bottom:136px}
  .checklists-studio-field-label{flex-basis:100%;white-space:normal}
  .checklists-studio-inventory-head,
  .checklists-studio-inventory-createbar{flex-direction:column;align-items:stretch}
  .checklists-studio-inventory-mode{width:100%;justify-content:space-between}
  .checklists-studio-inventory-mode button{flex:1 1 0}
  .checklists-studio-preview-topbar,
  .checklists-studio-preview-item-head,
  .checklists-studio-preview-progress-meta{flex-direction:column;align-items:flex-start}
  .checklists-studio-preview-submitbar .btn,
  .checklists-studio-preview-submitbar button{flex:1 1 100%}
  .checklists-studio-savebar{left:0;right:0;bottom:10px;padding:14px}
  .checklists-studio-savebar-actions{width:100%;margin-left:0}
  .checklists-studio-savebar-actions .btn,
  .checklists-studio-savebar-actions button{flex:1 1 100%}
}
.msg-reply-input:focus{border-color:var(--blue)}

/* Compose form */
.msg-compose-panel{display:flex;flex-direction:column;flex:1;min-height:0}
.msg-compose-form{padding:14px 16px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:10px}
.msg-field{display:flex;flex-direction:column;gap:4px}
.msg-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}

@media(max-width:480px){
  .inbox-panel{width:100vw;right:-100vw}
}
