
.knpos-root{
  /* Brand tokens */
  --kn-red: #ec1c24;
  --kn-yellow: #fdbd10;
  --kn-blue: #0066b2;
  --kn-orange: #ed7902;

  /* UI neutrals */
  --kn-bg: #f6f7f8;
  --kn-card: #ffffff;
  --kn-card-alt: #f9fafb;
  --kn-border: #e5e7eb;
  --kn-text: #111827;
  --kn-muted: #6b7280;

  /* Semantic */
  --kn-banner: var(--kn-yellow);
  --kn-btn-primary: var(--kn-blue);
  --kn-btn-danger: var(--kn-red);
  --kn-btn-warn: var(--kn-orange);
  --kn-pill-waiting: var(--kn-yellow);

  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  border:0;
  border-radius:12px;
  overflow:visible;
  background:var(--kn-bg);
}
.knpos-header{display:flex;gap:10px;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--kn-banner);border-bottom:1px solid rgba(0,0,0,.12);
  /* iOS (Add to Home Screen): with a translucent status bar, content can render under the status bar.
     We add safe-area padding so the header sits below the iPhone time/battery area.
     "constant()" is for older iOS; "env()" is the modern syntax.
  */
  padding-top: calc(8px + constant(safe-area-inset-top));
  padding-top: calc(8px + env(safe-area-inset-top));
}
.knpos-tabs{display:flex;gap:0;flex-wrap:wrap}
/* Tab order (mobile bottom bar uses flex order) */
.knpos-root[data-app="staff"] .knpos-tab[data-tab="settings"]{order:1}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="analysis"]{order:2}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="payroll"]{order:3}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="today"]{order:4}

.knpos-root[data-app="payroll"] .knpos-tab[data-tab="settings"]{order:1}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="w2"]{order:2}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="analysis"]{order:3}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="payroll"]{order:4}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="daily"]{order:5}

.knpos-tab{border:0;background:transparent;padding:6px 7px;cursor:pointer;font-weight:700;color:#333;border-radius:10px;line-height:1;font-size:12px}
.knpos-tab.is-active{background:#e7e7e7;color:var(--kn-text)}

/* Analysis numbers: keep compact on mobile */
.knpos-an-num{font-size:18px;font-weight:900}
@media (max-width: 480px){
  .knpos-an-num{font-size:15px}
}
.knpos-brand{display:flex;gap:10px;align-items:center}
.knpos-brandname{font-weight:700}
.knpos-brandstack{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}
.knpos-staffname{font-size:12px;color:var(--kn-muted);font-weight:700}
.knpos-cardhead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
@media (max-width:600px){.knpos-cardhead{flex-direction:column;align-items:stretch}.knpos-brandstack{align-items:flex-start}}

/* --- Staff header: logo centered on top, then welcome + menu under it --- */
.knpos-header--staff{flex-direction:column;align-items:stretch;justify-content:flex-start;gap:10px;position:relative}
.knpos-header--staff .knpos-stafftop{display:flex;justify-content:center;align-items:center;padding:2px 0}
.knpos-header--staff .knpos-logo{height:44px;width:auto;max-width:78vw;object-fit:contain;display:block}
.knpos-header--staff .knpos-logo--fallback{height:44px;width:44px;border-radius:999px;display:flex;align-items:center;justify-content:center;
  background:var(--kn-card);border:1px solid var(--kn-border);font-weight:900;color:var(--kn-text);letter-spacing:.5px}

/* Staff brand row: Welcome/Name on the left, Logout on the right (same row) */
.knpos-header--staff .knpos-brand{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px}
.knpos-header--staff .knpos-brandspacer{display:none}
.knpos-header--staff .knpos-welcome{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:2px;min-width:0;flex:1 1 auto}
.knpos-header--staff .knpos-logout{margin-left:auto;flex-shrink:0}

/* Staff hamburger menu button (before Welcome/Name) */
.knpos-menubtn--staff{
  width:44px;
  height:44px;
  padding:0;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.14);
  background:rgba(255,255,255,.55);
  color:var(--kn-text);
  font-size:18px;
  font-weight:950;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
}

/* Generic .knpos-menubtn is hidden by default; re-enable the staff hamburger button */
.knpos-root[data-app="staff"] .knpos-menubtn.knpos-menubtn--staff,
.knpos-root[data-app="payroll"] .knpos-menubtn.knpos-menubtn--staff{
  display:inline-flex;
}

/* IMPORTANT: generic .knpos-menubtn is hidden by default; re-enable for Staff/Payroll headers */
.knpos-root[data-app="staff"] .knpos-menubtn--staff,
.knpos-root[data-app="payroll"] .knpos-menubtn--staff{
  display:inline-flex;
}

/* Staff dropdown menu (anchor under the header row + safe-area) */
.knpos-root[data-app="staff"] #knstaffMenu{
  left:10px;
  right:auto;
  top: calc(64px + env(safe-area-inset-top));
  bottom:auto;
}

.knpos-header--staff .knpos-welcome__label{font-size:12px;font-weight:900;letter-spacing:.8px;text-transform:uppercase;color:#666;line-height:1}
.knpos-header--staff .knpos-welcome__name{font-size:clamp(18px, 4vw, 26px);font-weight:950;color:var(--kn-text);line-height:1.05;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}

/* Tabs: full-width segmented control (avoids the "floating centered" look) */
.knpos-header--staff .knpos-tabs{width:100%;justify-content:stretch;flex-wrap:nowrap;gap:6px;background:var(--kn-card);border:1px solid var(--kn-border);border-radius:14px;padding:4px}
.knpos-header--staff .knpos-tab{flex:1 1 0;text-align:center;font-size:13px;padding:10px 12px;border-radius:12px}
.knpos-header--staff .knpos-tab.is-active{background:#e7e7e7;color:var(--kn-text)}

/* STAFF: mobile-friendly bottom navigation + brand banner */
.knpos-root[data-app="staff"] > .knpos-header{background:var(--kn-banner);border-bottom:1px solid rgba(0,0,0,.10);position:relative}
.knpos-root[data-app="staff"] .knpos-header--staff .knpos-welcome__label{color:rgba(17,24,39,.75)}
.knpos-root[data-app="staff"] .knpos-header--staff .knpos-welcome__name{color:var(--kn-text)}
.knpos-root[data-app="staff"] .knpos-header--staff .knpos-logout{border-color:rgba(0,0,0,.14);background:rgba(255,255,255,.55);color:var(--kn-text);border-radius:0}

/* Offline: red banner */
body.knpos-is-offline .knpos-root[data-app="staff"] > .knpos-header{background:var(--kn-red)}
body.knpos-is-offline .knpos-root[data-app="staff"] .knpos-header--staff .knpos-welcome__label{color:rgba(255,255,255,.80)}
body.knpos-is-offline .knpos-root[data-app="staff"] .knpos-header--staff .knpos-welcome__name{color:#fff}
body.knpos-is-offline .knpos-root[data-app="staff"] .knpos-header--staff .knpos-logout{border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.12);color:#fff}

.knpos-root[data-app="staff"] .knpos-header--staff .knpos-tabs{position:fixed;left:0;right:0;bottom:0;z-index:1000;margin:0;border-radius:0;border-left:0;border-right:0;border-bottom:0;padding:6px 8px calc(6px + env(safe-area-inset-bottom));background:var(--kn-card)}
.knpos-root[data-app="staff"] .knpos-header--staff .knpos-tab{border-radius:0}
.knpos-root[data-app="staff"] .knpos-btn{border-radius:0}
.knpos-root[data-app="staff"] > .knpos-content{padding-bottom:96px}
.knpos-root[data-app="staff"] > .knpos-footer{padding-bottom:96px}

/* Staff: reuse payroll-style week strip (day chips) */
.knpos-root[data-app="staff"] .knpos-weekstrip{
  display:flex;
  align-items:stretch;
  gap:8px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding:2px 2px;
  scroll-snap-type:x mandatory;
  max-width:100%;
}
.knpos-root[data-app="staff"] .knpos-daychip{
  flex:0 0 auto;
  width:46px;
  height:46px;
  border:1px solid var(--kn-border);
  background:var(--kn-card);
  border-radius:14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  cursor:pointer;
  scroll-snap-align:center;
}
.knpos-root[data-app="staff"] .knpos-daychip__dow{font-size:10px;font-weight:950;color:#777;line-height:1}
.knpos-root[data-app="staff"] .knpos-daychip__num{font-size:16px;font-weight:950;color:var(--kn-text);line-height:1}
.knpos-root[data-app="staff"] .knpos-daychip.is-selected{background:var(--kn-banner);border-color:var(--kn-banner)}
.knpos-root[data-app="staff"] .knpos-daychip.is-selected .knpos-daychip__dow,
.knpos-root[data-app="staff"] .knpos-daychip.is-selected .knpos-daychip__num{color:#fff}
.knpos-root[data-app="staff"] .knpos-daychip.is-today{box-shadow:0 0 0 3px rgba(47,109,246,.14)}

/* Staff: compact totals row (similar to payroll block 2 metrics) */
.knpos-root[data-app="staff"] .knpos-b1-totals{display:flex;gap:10px;flex-wrap:nowrap}
.knpos-root[data-app="staff"] .knpos-b1-metric{flex:1 1 0;background:#f7f8fb;border:1px solid var(--kn-border);border-radius:14px;padding:10px;min-width:0}
.knpos-root[data-app="staff"] .knpos-b1-label{font-size:10px;font-weight:900;color:#777;text-transform:uppercase;letter-spacing:.7px}
.knpos-root[data-app="staff"] .knpos-b1-value{font-size:18px;font-weight:950;margin-top:2px}

@media (max-width:420px){
  .knpos-root[data-app="staff"] .knpos-b1-value{font-size:16px}
}

/* Staff: reuse Payroll daily weekstrip/day chips for date selection */
.knpos-root[data-app="staff"] .knpos-weekstrip{
  display:flex;
  align-items:stretch;
  gap:8px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding:2px 2px;
  scroll-snap-type:x mandatory;
  max-width:100%;
}
.knpos-root[data-app="staff"] .knpos-daychip{
  flex:0 0 auto;
  width:46px;
  height:46px;
  border:1px solid var(--kn-border);
  background:var(--kn-card);
  border-radius:14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  cursor:pointer;
  scroll-snap-align:center;
}
.knpos-root[data-app="staff"] .knpos-daychip__dow{font-size:10px;font-weight:950;color:#777;line-height:1}
.knpos-root[data-app="staff"] .knpos-daychip__num{font-size:16px;font-weight:950;color:var(--kn-text);line-height:1}
.knpos-root[data-app="staff"] .knpos-daychip.is-selected{background:var(--kn-banner);border-color:var(--kn-banner)}
.knpos-root[data-app="staff"] .knpos-daychip.is-selected .knpos-daychip__dow,
.knpos-root[data-app="staff"] .knpos-daychip.is-selected .knpos-daychip__num{color:#fff}
.knpos-root[data-app="staff"] .knpos-daychip.is-today{box-shadow:0 0 0 3px rgba(47,109,246,.14)}

/* Staff: compact payroll period switch (big buttons, elderly-friendly) */
.knpos-seg{
  display:flex;
  gap:6px;
  background:var(--kn-card);
  border:1px solid var(--kn-border);
  border-radius:14px;
  padding:4px;
}
.knpos-segbtn{
  flex:1 1 0;
  border-radius:12px;
  border:0;
  background:transparent;
  padding:10px 12px;
  font-weight:950;
  font-size:14px;
  cursor:pointer;
}
.knpos-segbtn.is-active{background:#e7e7e7}



/* PAYROLL: make header user (email) smaller for cleaner UI */
.knpos-root[data-app="payroll"] .knpos-header--staff .knpos-welcome__name{
  font-size:clamp(14px, 3.4vw, 18px);
  font-weight:900;
}

/* Brand header theme (POS): Yellow banner with dark text */
.knpos-root[data-app="pos"] .knpos-header{background:var(--kn-banner);border-bottom:1px solid rgba(0,0,0,.10)}
.knpos-root[data-app="pos"] .knpos-brandname,
.knpos-root[data-app="pos"] .knpos-topdate{color:var(--kn-text)}
.knpos-root[data-app="pos"] .knpos-tabs .knpos-tab{color:rgba(17,24,39,.86)}
.knpos-root[data-app="pos"] .knpos-tabs .knpos-tab.is-active{background:rgba(255,255,255,.55);color:var(--kn-text);border:1px solid rgba(0,0,0,.08)}
.knpos-root[data-app="pos"] .knpos-logout{border-color:rgba(0,0,0,.14);background:rgba(255,255,255,.55);color:var(--kn-text)}

/* Offline: switch banner to red for instant awareness */
body.knpos-is-offline .knpos-root[data-app="pos"] .knpos-header{background:var(--kn-red)}
body.knpos-is-offline .knpos-root[data-app="pos"] .knpos-brandname,
body.knpos-is-offline .knpos-root[data-app="pos"] .knpos-topdate{color:#fff}
body.knpos-is-offline .knpos-root[data-app="pos"] .knpos-tabs .knpos-tab{color:rgba(255,255,255,.9)}
body.knpos-is-offline .knpos-root[data-app="pos"] .knpos-tabs .knpos-tab.is-active{background:rgba(255,255,255,.18);color:#fff;border-color:transparent}
body.knpos-is-offline .knpos-root[data-app="pos"] .knpos-logout{border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.12);color:#fff}

/* POS mobile menu (hamburger) */
.knpos-menubtn{display:none;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.08);color:#fff;
  width:40px;height:40px;border-radius:12px;font-size:18px;font-weight:950;line-height:1;align-items:center;justify-content:center;
}
.knpos-menudrop{display:none;position:absolute;left:10px;top:56px;z-index:2000;
  background:var(--kn-card);border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 14px 36px rgba(0,0,0,.16);min-width:220px;
  padding:8px;
}
.knpos-menudrop.is-open{display:block}
.knpos-menuit{width:100%;text-align:left;border:0;background:transparent;padding:12px 12px;border-radius:12px;font-weight:900;cursor:pointer}
.knpos-menuit:active{background:#f3f4f6}
.knpos-menusep{height:1px;background:#e5e7eb;margin:6px 8px;border-radius:1px}

@media (max-width: 860px){
  .knpos-root[data-app="pos"] .knpos-tabs{display:none}
  .knpos-root[data-app="pos"] .knpos-menubtn{display:inline-flex}
  .knpos-root[data-app="pos"] .knpos-header{position:relative}
}

.knpos-root[data-app="payroll"] > .knpos-header{background:var(--kn-banner);border-bottom:1px solid rgba(0,0,0,.10)}
.knpos-root[data-app="payroll"] .knpos-header--staff .knpos-welcome__label{color:rgba(17,24,39,.75)}
.knpos-root[data-app="payroll"] .knpos-header--staff .knpos-welcome__name{color:var(--kn-text)}
.knpos-root[data-app="payroll"] .knpos-header--staff .knpos-logout{border-color:rgba(0,0,0,.14);background:rgba(255,255,255,.55);color:var(--kn-text)}

/* Offline: red banner */
body.knpos-is-offline .knpos-root[data-app="payroll"] > .knpos-header{background:var(--kn-red)}
body.knpos-is-offline .knpos-root[data-app="payroll"] .knpos-header--staff .knpos-welcome__label{color:rgba(255,255,255,.80)}
body.knpos-is-offline .knpos-root[data-app="payroll"] .knpos-header--staff .knpos-welcome__name{color:#fff}
body.knpos-is-offline .knpos-root[data-app="payroll"] .knpos-header--staff .knpos-logout{border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.12);color:#fff}

.knpos-root[data-app="checkin"] > .knpos-header{background:var(--kn-banner);border-bottom:1px solid rgba(0,0,0,.10)}
.knpos-root[data-app="checkin"] .knpos-checkinhead__title,
.knpos-root[data-app="checkin"] .knpos-checkinhead__sub{color:var(--kn-text)}
body.knpos-is-offline .knpos-root[data-app="checkin"] > .knpos-header{background:var(--kn-red)}
body.knpos-is-offline .knpos-root[data-app="checkin"] .knpos-checkinhead__title,
body.knpos-is-offline .knpos-root[data-app="checkin"] .knpos-checkinhead__sub{color:#fff}

/* PAYROLL: Role-based layout
   - payroll_admin: mobile-friendly blocks (cards + table-to-cards on small screens)
   - payroll_mod: PC-first (keep classic tables)
*/

/* PAYROLL: cleaner UI (remove excessive outer borders around blocks) */
.knpos-root[data-app="payroll"] .knpos-card{
  border:0;
  box-shadow:none;
}
.knpos-root[data-app="payroll"] .knpos-savenotice{
  border:0;
}
.knpos-root[data-app="payroll"] .knpos-table th,
.knpos-root[data-app="payroll"] .knpos-table td{
  border-bottom:0;
}
.knpos-root[data-app="payroll"] .knpos-table tbody tr:nth-child(odd){
  background:#fafafa;
}
.knpos-root[data-app="payroll"] .knpos-table tbody tr:hover{
  background:#f3f6ff;
}
/* PAYROLL Admin: compact grid tables (used for Daily report on mobile) */
.knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table--grid{
  border-collapse:collapse;
  width:100%;
  min-width:0;
  table-layout:fixed;
  background:var(--kn-card);
}
.knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table--grid th,
.knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table--grid td{
  /* Only horizontal separators on mobile/tablet (no vertical lines) */
  border-left:0;
  border-right:0;
  border-top:0;
  border-bottom:1px solid #e5e7eb;
  padding:12px 10px;
  font-size:14px;
  vertical-align:middle;
}
.knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table--grid th{
  font-weight:950;
  background:#f7f8fb;
}
.knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table--grid td b{
  font-weight:950;
}


/* Payroll Daily report: header controls + week scroller (mobile) */
.knpos-root[data-app="payroll"] .knpos-dailyhead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.knpos-root[data-app="payroll"] .knpos-dailyhead__ctrl{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin:0;
}
.knpos-root[data-app="payroll"] #kn_daily_pick{display:none}
.knpos-root[data-app="payroll"] .knpos-weekstrip{
  display:none; /* shown on payroll_admin mobile */
  align-items:stretch;
  gap:8px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding:2px 2px;
  scroll-snap-type:x mandatory;
  max-width:100%;
}
.knpos-root[data-app="payroll"] .knpos-daychip{
  flex:0 0 auto;
  width:46px;
  height:46px;
  border:1px solid var(--kn-border);
  background:var(--kn-card);
  border-radius:14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  cursor:pointer;
  scroll-snap-align:center;
}
.knpos-root[data-app="payroll"] .knpos-daychip__dow{
  font-size:10px;
  font-weight:950;
  color:#777;
  line-height:1;
}
.knpos-root[data-app="payroll"] .knpos-daychip__num{
  font-size:16px;
  font-weight:950;
  color:var(--kn-text);
  line-height:1;
}
.knpos-root[data-app="payroll"] .knpos-daychip.is-selected{
  background:var(--kn-banner);
  border-color:var(--kn-banner);
}
.knpos-root[data-app="payroll"] .knpos-daychip.is-selected .knpos-daychip__dow,
.knpos-root[data-app="payroll"] .knpos-daychip.is-selected .knpos-daychip__num{
  color:#fff;
}
.knpos-root[data-app="payroll"] .knpos-daychip.is-today{
  box-shadow:0 0 0 3px rgba(47,109,246,.14);
}

/* Staff Today: reuse the same week strip chips */
.knpos-root[data-app="staff"] .knpos-weekstrip{
  display:flex;
  align-items:stretch;
  gap:8px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding:2px 2px;
  scroll-snap-type:x mandatory;
  max-width:100%;
}
.knpos-root[data-app="staff"] .knpos-daychip{flex:0 0 auto;width:46px;height:46px;border:1px solid var(--kn-border);background:var(--kn-card);border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;scroll-snap-align:center;}
.knpos-root[data-app="staff"] .knpos-daychip__dow{font-size:10px;font-weight:950;color:#777;line-height:1;}
.knpos-root[data-app="staff"] .knpos-daychip__num{font-size:16px;font-weight:950;color:var(--kn-text);line-height:1;}
.knpos-root[data-app="staff"] .knpos-daychip.is-selected{background:var(--kn-banner);border-color:var(--kn-banner);}
.knpos-root[data-app="staff"] .knpos-daychip.is-selected .knpos-daychip__dow,
.knpos-root[data-app="staff"] .knpos-daychip.is-selected .knpos-daychip__num{color:#fff;}
.knpos-root[data-app="staff"] .knpos-daychip.is-today{box-shadow:0 0 0 3px rgba(47,109,246,.14);}

/* Staff: compact totals row in Today tab */
.knpos-root[data-app="staff"] .knpos-b1-totals{display:flex;gap:12px;justify-content:space-between;align-items:stretch;}
.knpos-root[data-app="staff"] .knpos-b1-metric{flex:1 1 0;background:#f7f8fb;border:1px solid var(--kn-border);border-radius:14px;padding:10px 10px;min-width:0;}
.knpos-root[data-app="staff"] .knpos-b1-label{font-size:11px;font-weight:950;color:#666;letter-spacing:.3px;}
.knpos-root[data-app="staff"] .knpos-b1-value{font-size:18px;font-weight:950;color:var(--kn-text);margin-top:4px;}

/* Summary blocks at the bottom of Daily report: show on mobile only */
.knpos-root[data-app="payroll"] .knpos-daily-summaries{display:none;margin-top:12px}
.knpos-root[data-app="payroll"] .knpos-sumlbl{font-size:12px;font-weight:950;color:#666;margin-bottom:2px}
.knpos-root[data-app="payroll"] .knpos-sumval{font-size:18px;font-weight:950}

/* Payroll Admin Daily: mobile blocks with page background (like iOS cards) */
.knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-dailywrap{
  /* Use ONLY ONE background: the page/content background (var(--kn-bg)).
     Keep this wrapper transparent so it doesn't create a second "frame" on mobile. */
  background:transparent;
  padding:0;
  border-radius:0;
}

/* Each section is a "block" area; the card inside is the light content */
.knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-payroll-block{
  background:transparent;
  padding:0;
  margin:0 0 18px 0;
}

.knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-payroll-block .knpos-card{
  background:#fff;
  border-radius:16px;
  margin:0;
  padding:14px;
  box-shadow:0 10px 22px rgba(0,0,0,.10);
}
/* Block 2: Daily Report summary + editable amounts */
.knpos-root[data-app="payroll"] .knpos-b1-totals{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.knpos-root[data-app="payroll"] .knpos-b1-metric{
  padding:10px;
  border-radius:14px;
  background:#f7f8fb;
}
.knpos-root[data-app="payroll"] .knpos-b1-label{
  font-size:12px;
  font-weight:950;
  color:#6b7280;
  margin:0 0 4px 0;
}
.knpos-root[data-app="payroll"] .knpos-b1-value{
  font-size:20px;
  font-weight:950;
  line-height:1.1;
}
.knpos-root[data-app="payroll"] .knpos-b1-inputs{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-top:10px;
}
.knpos-root[data-app="payroll"] .knpos-b1-bottom{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}
.knpos-root[data-app="payroll"] .knpos-b1-status{
  font-size:20px;
  font-weight:950;
}
.knpos-root[data-app="payroll"] .knpos-b1-status.is-ok{color:#16a34a}
.knpos-root[data-app="payroll"] .knpos-b1-status.is-short{color:#dc2626}
.knpos-root[data-app="payroll"] .knpos-b1-status.is-over{color:#f59e0b}
.knpos-root[data-app="payroll"] .knpos-b1-actions{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}

@media (max-width: 420px){
  .knpos-root[data-app="payroll"] .knpos-b1-metric{padding:8px;border-radius:12px}
  .knpos-root[data-app="payroll"] .knpos-b1-value{font-size:18px}
  .knpos-root[data-app="payroll"] .knpos-b1-inputs{gap:8px}
}

@media (max-width: 860px){
  /* Payroll Admin: move tab bar to bottom + reorder tabs (mobile friendly) */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-header--staff .knpos-tabs{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index:1000;
    margin:0;
    border-radius:0;
    border-left:0;
    border-right:0;
    border-bottom:0;
    padding:6px 8px calc(6px + env(safe-area-inset-bottom));
    background:var(--kn-card);
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-header--staff .knpos-tab{border-radius:0}
  .knpos-root[data-app="payroll"].knpos-payroll-admin > .knpos-content{padding-bottom:96px}
  .knpos-root[data-app="payroll"].knpos-payroll-admin > .knpos-footer{padding-bottom:96px}

  /* Order: setting (left) -> W2 -> Payroll -> Daily report (right) */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-root[data-app="payroll"].knpos-payroll-admin /* Show Daily report summaries only on mobile */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-daily-summaries{display:block}

  /* Daily report: week scroller on mobile (payroll_admin) */
  .knpos-root[data-app="payroll"].knpos-payroll-admin #kn_daily_pick{display:inline-flex}
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-weekstrip{display:flex;flex-wrap:nowrap}
  /* Keep the date input in-viewport (but invisible) so mobile browsers can open the native picker */
  /* iOS/Safari: date picker often won't open if the input is too tiny.
     Keep it in the viewport (still invisible) so button-triggered focus/click can open the native picker. */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-dailydate{position:fixed;left:0;top:0;width:160px;height:44px;opacity:0.01;pointer-events:auto;z-index:2147483647}
  .knpos-root[data-app="payroll"].knpos-payroll-admin #kn_daily_load{display:none}
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-dailyhead__ctrl{width:100%}
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-weekstrip{flex:1 1 auto}

  /* Remove vertical table lines (keep horizontal separators) across Payroll/W2/Settings/Daily */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel .knpos-table{border:0}
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel .knpos-table th,
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel .knpos-table td{
    border-left:0 !important;
    border-right:0 !important;
  }

  /* Payroll tab (mobile admin): per-staff card (light border, no dark frame) */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel[data-panel="payroll"] .knpos-table:not(.knpos-table--grid) tr{
    background:var(--kn-card);
    padding:12px;
    border-radius:16px;
    margin:12px 0;
    border:1px solid #e5e7eb;
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel[data-panel="payroll"] .knpos-table:not(.knpos-table--grid) td{
    background:transparent;
    border-radius:0;
    padding:10px 12px;
    color:var(--kn-text);
    position:relative;
    z-index:1;
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel[data-panel="payroll"] .knpos-table:not(.knpos-table--grid) td::before{
    color:#6b7280;
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel[data-panel="payroll"] .knpos-table:not(.knpos-table--grid) td:not(:first-child){
    border-top:1px solid rgba(0,0,0,.08);
    padding-top:12px;
    margin-top:0;
  }


  /* W2 tab (mobile admin): same light card style */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel[data-panel="w2"] .knpos-table:not(.knpos-table--grid) tr{
    background:var(--kn-card);
    padding:12px;
    border-radius:16px;
    margin:12px 0;
    color:var(--kn-text);
    border:1px solid #e5e7eb;
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel[data-panel="w2"] .knpos-table:not(.knpos-table--grid) td{
    background:transparent;
    padding:10px 12px;
    color:var(--kn-text);
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel[data-panel="w2"] .knpos-table:not(.knpos-table--grid) td::before{
    color:#6b7280;
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-panel[data-panel="w2"] .knpos-table:not(.knpos-table--grid) td:not(:first-child){
    border-top:1px solid rgba(0,0,0,.08);
    padding-top:12px;
    margin-top:0;
  }

  /* Table-to-cards: keep most tables mobile friendly, EXCEPT .knpos-table--grid */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table:not(.knpos-table--grid){
    display:block;
    width:100%;
    min-width:0;
    border-collapse:separate;
    border-spacing:0;
    table-layout:auto;
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table:not(.knpos-table--grid) thead{display:none}
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table:not(.knpos-table--grid) tbody,
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table:not(.knpos-table--grid) tr,
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table:not(.knpos-table--grid) td,
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table:not(.knpos-table--grid) th{
    display:block;
    width:100%;
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table:not(.knpos-table--grid) tr{
    border:1px solid #e5e7eb;
    border-radius:14px;
    padding:10px 12px;
    margin:10px 0;
    background:var(--kn-card);
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table:not(.knpos-table--grid) td{
    border-bottom:0;
    padding:6px 0;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    font-size:14px;
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table:not(.knpos-table--grid) td::before{
    content:attr(data-label);
    font-size:12px;
    font-weight:900;
    color:#666;
    flex:0 0 auto;
    max-width:46%;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-table:not(.knpos-table--grid) td > *{
    flex:1 1 auto;
    max-width:54%;
  }
  /* Make normal buttons easier on touch (keep icon buttons square) */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-btn:not(.knpos-iconbtn){
    padding:10px 12px;
  }
}

/* POS Report charts */
.knpos-barchart{display:flex;align-items:flex-end;gap:4px;height:130px;padding:10px 8px;border:1px solid var(--kn-border);border-radius:14px;background:#fafbff;overflow:hidden}
.knpos-barwrap{flex:1 1 0;min-width:6px;display:flex;flex-direction:column;align-items:center;gap:6px}
.knpos-bar{width:100%;border-radius:10px 10px 0 0;background:#d7ddeb;min-height:2px}
.knpos-bar.is-max{background:#9aa6bf}
.knpos-bar.is-min{background:#e2e6f2}
.knpos-barlabel{font-size:10px;font-weight:800;color:#666;line-height:1}
.knpos-hbarchart{display:flex;flex-direction:column;gap:10px}
.knpos-hbarrow{display:flex;align-items:center;gap:12px}
.knpos-hbarlbl{width:120px;min-width:120px;font-weight:950;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.knpos-hbartrack{flex:1 1 auto;height:14px;border-radius:999px;background:#eef0f6;overflow:hidden}
.knpos-hbarfill{height:100%;background:#b4bdd0;border-radius:999px}
.knpos-hbarfill.is-max{background:#8e9bb3}
.knpos-hbarfill.is-min{background:#cfd6e6}
.knpos-chart-legend{display:flex;align-items:center;gap:10px;margin:8px 0 0}
.knpos-chart-legend .knpos-legitem{display:flex;align-items:center;gap:6px;font-size:12px;color:#666;font-weight:900}
.knpos-chart-legend .knpos-legsw{width:14px;height:14px;border-radius:4px;background:#b4bdd0}
.knpos-chart-legend .knpos-legsw.big{background:#8e9bb3}
.knpos-chart-legend .knpos-legsw.small{background:#cfd6e6}
.knpos-stacktrack{border-radius:999px}
.knpos-stack-big{height:100%;background:#8e9bb3}
.knpos-stack-small{height:100%;background:#cfd6e6}

.knpos-online{font-size:12px;padding:4px 10px;border-radius:999px;background:rgba(255,255,255,.55);border:1px solid rgba(0,0,0,.12);font-weight:900;color:var(--kn-text)}
.knpos-online.is-offline{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.28);color:#fff}
.knpos-logout{border:1px solid #ffd5d5;background:var(--kn-card);border-radius:999px;padding:8px 10px;cursor:pointer}
.knpos-content{padding:12px;background:var(--kn-bg)}
.knpos-panel{display:none}
.knpos-panel.is-active{display:block}
.knpos-card{border:1px solid var(--kn-border);border-radius:12px;padding:12px;background:var(--kn-card);margin-bottom:12px}
.knpos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}
.knpos-input{width:100%;padding:9px 10px;border:1px solid var(--kn-border);border-radius:10px;background:var(--kn-card)}
.knpos-btn{border:1px solid var(--kn-border);background:var(--kn-card);border-radius:10px;padding:9px 12px;cursor:pointer;font-weight:700}
.knpos-btn.primary{background:var(--kn-btn-primary);color:#fff;border-color:var(--kn-btn-primary)}
.knpos-btn.warn{background:var(--kn-btn-warn);color:#111;border-color:var(--kn-btn-warn)}
.knpos-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:10px 0}
.knpos-table{width:100%;min-width:max-content;border-collapse:separate;border-spacing:0;table-layout:fixed}
.knpos-table th,.knpos-table td{border-bottom:1px solid #f0f1f5;padding:10px 8px;text-align:left;font-size:14px;vertical-align:top}
.knpos-pill{display:inline-block;padding:3px 10px;border-radius:999px;border:0;font-size:12px;line-height:1.2}
.knpos-pill.saved{background:#eef7ff;border-color:rgba(0,102,178,.22);color:var(--kn-text)}
.knpos-pill.waiting{background:rgba(253,189,16,.25);border-color:rgba(253,189,16,.55);color:var(--kn-text)}

/* Hold ticket card: make it visually louder */
.knpos-hcard.is-hold{border-color:#ff7a7a;background:var(--kn-card)3f3;box-shadow:0 12px 30px rgba(190,40,40,.18)}
.knpos-flash{animation:knposFlash 1.2s ease}
@keyframes knposFlash{0%{transform:scale(1)}20%{transform:scale(1.02)}100%{transform:scale(1)}}

.knpos-savenotice{margin:10px 0 12px 0;padding:10px 12px;border-radius:12px;border:1px solid #dfe3f2;background:#f7f8fb;font-size:13px;font-weight:700}
.knpos-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.35);z-index:9999}
.knpos-modal[aria-hidden="false"]{display:flex}
.knpos-modal__content{width:min(420px,92vw);background:var(--kn-card);border-radius:16px;padding:16px;border:1px solid #eee}
.knpos-error{color:#b00020;margin-top:8px;min-height:18px}
.knpos-hint{color:var(--kn-muted);font-size:12px;margin-top:10px}
.knpos-savenotice{margin:10px 0 0 0;padding:10px 12px;border-radius:12px;background:#f2f5ff;border:1px solid #dfe3f2;font-weight:700}


/* --- POS Home compact staff tiles --- */
.knpos-grid--tight{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}
.knpos-row--tight{gap:8px}
.knpos-staff{border:1px solid #eef0f6;border-radius:14px;padding:8px;background:var(--kn-card)}
.knpos-staff__head{display:flex;align-items:center;justify-content:space-between}
.knpos-staff__name{font-weight:800;font-size:14px;display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.knpos-staff__turn{font-weight:800;font-size:13px;padding:2px 8px;border-radius:999px;background:rgba(0,102,178,.08);border:1px solid rgba(0,102,178,.18);color:var(--kn-text)}
.knpos-input--compact{padding:8px 10px;border-radius:12px}
.knpos-total{margin-left:auto;border:1px solid #dfe3f2;border-radius:14px;padding:8px 12px;min-width:160px;background:#f7f8fb}
.knpos-total__label{font-size:12px;color:var(--kn-muted)}
.knpos-total__value{font-size:20px;font-weight:900}


/* --- POS Home header table (Name / Input / Sum) --- */
.knpos-table--homehead th,.knpos-table--homehead td{padding:8px 8px}
.knpos-table--homehead th,.knpos-table--homehead td{border-bottom:0}
.knpos-homehistory .knpos-table th,.knpos-homehistory .knpos-table td{border-bottom:0}
.knpos-homehistory tbody tr:nth-child(odd){background:#fafafa}
.knpos-homehistory tbody tr:hover{background:#f3f6ff}
.kn_cell{font-variant-numeric:tabular-nums}
.kn_td_label{color:#777;font-size:13px;white-space:nowrap}

/* Tip modal: allow long helper text to wrap instead of overflowing */
.knpos-tipmodal .kn_td_label{white-space:normal;overflow-wrap:anywhere;line-height:1.25}
.knpos-tipmodal .knpos-kbdmodal__panel{max-width:min(560px, 92vw)}

/* Hold confirm dialog: big square buttons for iPad */
.knpos-holddlg__btns{
  display:flex;
  gap:14px;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  padding-top:4px;
}
.knpos-squarebtn{
  width:160px;
  height:76px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  font-weight:800;
  border-radius:14px;
}


/* Center some dialogs (Tip / Hold) instead of bottom-sheet */
.knpos-tipmodal .knpos-kbdmodal__panel,
.knpos-holdmodal .knpos-kbdmodal__panel,
.knpos-holddlg .knpos-kbdmodal__panel{
  top:50%;
  bottom:auto;
  transform:translate(-50%,-50%);
  max-height:calc(100vh - 40px);
  overflow:auto;
}
.kn_th_staff,.kn_td_staff{text-align:left}
.kn_staffhead{display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden}
.kn_staffname{font-weight:800;overflow:hidden;text-overflow:ellipsis}
.kn_turn{display:inline-flex;align-items:baseline;gap:2px}
.kn_turn_big{font-weight:900;font-size:16px}
.kn_turn_div{opacity:.6;font-weight:400}
.kn_turn_small{font-weight:500;font-size:13px}

/* Amount styling in History: big turn (>= threshold) bold; small turn lighter */
.kn_amt{font-variant-numeric:tabular-nums}
.kn_amt--big{font-weight:900}
.kn_amt--small{font-weight:500;opacity:.85;font-size:13px}
.kn_td_sum{padding-top:6px;padding-bottom:6px}
.kn_sumrow{display:flex;gap:8px;align-items:center}
.kn_actions_head{display:flex;gap:8px;justify-content:flex-end}
.knpos-input--tiny{width:76px;padding:8px 10px;border-radius:10px}
.kn_hint{font-size:11px;color:#888;margin-top:4px;line-height:1.1;white-space:nowrap}
.kn_sep{color:#999;font-weight:400;}
.knpos-discount{display:flex;gap:6px;align-items:center}
.knpos-total--compact{min-width:140px}

/* --- POS Home scroll + sticky header (Name / Input / Sum stays on top) --- */
.knpos-home-scroll{overflow:auto;max-height:calc(100vh - 190px);-webkit-overflow-scrolling:touch}
.knpos-homehead{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid #f0f1f5}

/* Home header + history share the same colgroup; avoid visual "boxes" */
.knpos-table--homehead th,.knpos-table--homehead td{border-bottom:0}
.knpos-homehistory .knpos-table th,.knpos-homehistory .knpos-table td{border-bottom:0}
.knpos-input{border-color:#e6e8f0}
.knpos-input:focus{outline:none;border-color:#b9c7ff;box-shadow:0 0 0 3px rgba(47,109,246,.12)}

.knpos-total{border:0;background:transparent;padding:0;min-width:auto}
.knpos-total__value{font-size:18px}

/* Right action column: keep stable + lightweight */
.kn_actions,.kn_actions_head{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap;white-space:normal}
.kn_actions .knpos-btn,.kn_actions_head .knpos-btn{padding:4px 8px;font-size:12px;line-height:1.1}
.kn_col_status,.kn_th_status{width:62px}
.kn_col_action,.kn_th_action{width:156px}

@media (max-width: 860px){
  .kn_col_action,.kn_th_action{width:128px}
  .kn_actions .knpos-btn,.kn_actions_head .knpos-btn{padding:6px 8px}
}

.knpos-divider{height:1px;background:#eef0f6;margin:10px 0}

.knpos-batch{font-size:12px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:52vw}
.knpos-spacer{flex:1}

/* History compact header */
.knpos-card h3{font-size:14px;margin:0 0 8px 0}
.kn_col_time,.kn_th_time{width:clamp(78px,7vw,96px)}
.kn_col_staff,.kn_th_blank,.kn_th_staff{width:clamp(74px,8.2vw,112px)}
.kn_col_status,.kn_th_status{width:62px}
.kn_col_action,.kn_th_action{width:156px}

/* =============================
   Mockup Home (iPad-first)
   ============================= */
.knpos-home{padding:14px 14px 12px 14px;background:linear-gradient(180deg,#f7f7f9 0%, #ffffff 40%);border:0;box-shadow:0 10px 30px rgba(0,0,0,.06)}

.knpos-summary{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.75);backdrop-filter:saturate(180%) blur(8px);border:1px solid #eceef6}
.knpos-summary__left{flex:1;display:flex;gap:8px;align-items:center;flex-wrap:wrap;min-width:0}
.knpos-summary__right{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:4px;white-space:nowrap}
.knpos-summary__money{display:flex;align-items:baseline;gap:8px}
.knpos-summary__title{font-weight:800;color:#222;font-size:16px}
.knpos-summary__value{font-weight:950;font-size:22px}
.knpos-summary__discount{font-size:12px;color:var(--kn-muted);font-weight:700}
.knpos-topstaff{font-weight:700;color:#222}
.knpos-selchip{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:var(--kn-card);border:2px solid rgba(0,0,0,.18);font-weight:800;color:var(--kn-text);white-space:nowrap;box-shadow:0 6px 16px rgba(0,0,0,.10)}
.knpos-selchip b{font-weight:900}

.knpos-inputbar{display:flex;align-items:center;gap:10px;margin-top:12px;padding:10px;border-radius:14px;background:rgba(255,255,255,.85);border:1px solid #eceef6;flex-wrap:nowrap}
.knpos-iconbtn{width:44px;height:44px;border-radius:12px;border:1px solid var(--kn-border);background:var(--kn-card);font-weight:900;font-size:18px;cursor:pointer}
.knpos-input--big{font-size:20px;padding:12px 14px;border-radius:12px}
.knpos-input--short{width:120px;max-width:120px;text-align:right}
.knpos-inputbar__hint{flex:1;display:flex;align-items:center;gap:10px;color:#666;font-size:12px;white-space:nowrap;overflow:hidden}
.knpos-hinttext{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.knpos-discountbtn{border:1px dashed #d6d9e6;background:var(--kn-card);border-radius:999px;padding:4px 8px;font-weight:900;font-size:12px;cursor:pointer;white-space:nowrap}
.knpos-discountbtn:active{transform:scale(.99)}

/* Inline edit in history cards */
.knpos-hcard.is-editing{border-color:#b9c7ff;box-shadow:0 10px 24px rgba(47,109,246,.10)}
.knpos-editwrap{display:flex;flex-direction:column;gap:10px}
.knpos-editline{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:12px;border:1px solid #eef0f6;background:#fbfcff}
.knpos-editline.is-deleted{opacity:.72;background:var(--kn-card)6f6;border-color:#ffd5d5}
.knpos-editline__name{font-weight:900;color:#222;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}
.knpos-editline__amt{display:flex;align-items:center;gap:8px;justify-content:flex-end}
.knpos-editinput{width:92px;max-width:92px;padding:8px 10px;border:1px solid var(--kn-border);border-radius:10px;text-align:right;font-variant-numeric:tabular-nums}
.knpos-oldval{font-size:11px;opacity:.55}
.knpos-delmark{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:#ffe9e9;color:#7b1b1b;font-weight:900}
.knpos-editadd{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:8px 10px;border-radius:12px;border:1px dashed #e6e8f0;background:var(--kn-card)}
.knpos-editselect{min-width:160px;padding:8px 10px;border:1px solid var(--kn-border);border-radius:10px;background:var(--kn-card);font-weight:800}
/* Input actions (quick add / discount / hold / add)
   - Always keep in ONE horizontal row on iPad landscape
   - Allow horizontal scroll instead of wrapping (prevents layout overlap)
*/
.knpos-inputbar__actions{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:nowrap;
  margin-left:auto;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  white-space:nowrap;
  max-width:100%;
}
.knpos-inputbar__actions > *{flex:0 0 auto}

/* Compact action buttons so they fit better in landscape */
.knpos-inputbar__actions .knpos-btn{padding:8px 10px;font-size:12px}
.knpos-inputbar__actions .knpos-discountinput{padding:8px 10px}

/* Discount inputs (small) */
.knpos-discountinput{width:76px;max-width:76px;padding:10px 10px;border-radius:12px;font-weight:900;text-align:right}

/* Audit display in history cards */
.knpos-auditold{opacity:.55}
.knpos-auditx{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:#ffe9e9;color:#7b1b1b;font-weight:900;margin-left:6px}
.knpos-auditplus{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:#e8f0ff;color:#2f6df6;font-weight:950;margin-right:6px}

.knpos-staffgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-top:12px}
.knpos-stafftile{border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:12px 12px 10px 12px;text-align:left;cursor:pointer;box-shadow:0 6px 18px rgba(0,0,0,.06);transition:transform .08s ease, box-shadow .08s ease;min-height:104px}
.knpos-stafftile:active{transform:scale(.99)}
.knpos-stafftile.is-active{outline:3px solid rgba(47,109,246,.18);border-color:rgba(47,109,246,.35)}
.knpos-stafftile.is-selected{outline:4px solid rgba(0,102,178,.28);border-color:rgba(0,102,178,.65);box-shadow:0 10px 24px rgba(0,102,178,.16)}
/* Staff has amount in current draft (subtle indicator; does NOT "lock" selection) */
.knpos-stafftile.is-hasamt:not(.is-selected){border-style:solid;border-color:rgba(0,0,0,.12)}
.knpos-stafftile.is-lowturn{border-color:rgba(63,140,90,.45)}
.knpos-stafftile__name{font-weight:900;font-size:20px;color:#222;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.knpos-stafftile__turn{margin-top:6px;display:flex;flex-direction:column;gap:2px;color:#222}
.knpos-stafftile__turnbig{display:flex;align-items:baseline;gap:6px}
.knpos-stafftile__turnsmall{font-size:12px;opacity:.75;font-weight:700}
.knpos-stafftile__turnnum{font-weight:950;font-size:36px;line-height:1}
.knpos-stafftile__turnlbl{font-weight:700;font-size:18px;color:#333}
.knpos-stafftile__amt{display:none}

/* Pastel variants (close to mockup) */
.knpos-stafftile.is-green{background:linear-gradient(180deg,#eaf6ef 0%, #dff0e6 100%)}
.knpos-stafftile.is-green .knpos-stafftile__amt{background:rgba(63,140,90,.55)}
.knpos-stafftile.is-sand{background:linear-gradient(180deg,#f6f3e9 0%, #efe9d6 100%)}
.knpos-stafftile.is-sand .knpos-stafftile__amt{background:rgba(154,132,52,.55)}
.knpos-stafftile.is-gold{background:linear-gradient(180deg,#f8f0de 0%, #f1e1b5 100%)}
.knpos-stafftile.is-gold .knpos-stafftile__amt{background:rgba(193,135,21,.60)}
.knpos-stafftile.is-rose{background:linear-gradient(180deg,#f7e8ea 0%, #f1d3d8 100%)}
.knpos-stafftile.is-rose .knpos-stafftile__amt{background:rgba(186,75,94,.60)}
.knpos-stafftile.is-red{background:linear-gradient(180deg,#f6e7e7 0%, #efcfcf 100%)}
.knpos-stafftile.is-red .knpos-stafftile__amt{background:rgba(170,64,64,.62)}
.knpos-stafftile.is-pink{background:linear-gradient(180deg,#f7eaee 0%, #f0d3df 100%)}
.knpos-stafftile.is-pink .knpos-stafftile__amt{background:rgba(172,72,109,.58)}
.knpos-stafftile.is-purple{background:linear-gradient(180deg,#efeafb 0%, #e0d6f7 100%)}
.knpos-stafftile.is-purple .knpos-stafftile__amt{background:rgba(104,74,196,.55)}
.knpos-stafftile.is-blue{background:linear-gradient(180deg,#e8f0ff 0%, #d6e4ff 100%)}
.knpos-stafftile.is-blue .knpos-stafftile__amt{background:rgba(47,109,246,.62)}

.knpos-history{margin-top:12px}
.knpos-history__title{font-weight:900;font-size:16px;color:#333;margin:8px 2px}
.knpos-historygrid{display:grid;grid-template-columns:1fr;gap:10px}
.knpos-history__more{display:flex;justify-content:center;padding:10px 0 0}

.knpos-hcard{display:flex;gap:12px;align-items:stretch;background:rgba(255,255,255,.88);border:1px solid #eceef6;border-radius:14px;padding:12px;box-shadow:0 8px 20px rgba(0,0,0,.05)}
.knpos-hcard__left{min-width:88px;border-right:1px solid #eef0f6;padding-right:12px;display:flex;align-items:flex-start}
.knpos-htime{font-weight:700;color:#333;font-variant-numeric:tabular-nums}
.knpos-hcard__main{flex:1;min-width:0}
.knpos-hcard__right{display:flex;flex-direction:column;gap:8px;align-items:flex-end;min-width:120px}
.knpos-hactions{display:flex;gap:8px}
.knpos-hcardtotal{font-size:12px;font-weight:900;color:#222;opacity:.9}
.knpos-hcardtotal span{font-size:11px;font-weight:700;color:#666;margin-right:6px}
.knpos-hline{display:flex;gap:10px;align-items:flex-start;justify-content:space-between}
.knpos-hline + .knpos-hline{margin-top:10px}
.knpos-hline__title{font-weight:900;color:#222;white-space:nowrap}
.knpos-hmeta{font-size:12px;color:var(--kn-muted);font-weight:800;margin-bottom:8px}
.knpos-hline--holdwith .knpos-hline__title{font-size:16px}
.knpos-hline--holdwith .knpos-hline__title .knpos-hname{font-weight:900}
.knpos-hline--holdwith .knpos-hline__chips .knpos-moneychip{font-size:15px}
.knpos-hturn{font-weight:700;color:#666;margin-left:6px}
.knpos-hline__chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.knpos-moneychip{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:10px;background:#eef2ff;color:#1f3b8b;font-weight:800;font-size:14px;min-width:54px}
.knpos-moneychip.kn_amt--small{background:#f4f5f8;color:#333;font-weight:600}
.knpos-moneychip.kn_amt--big{background:#dce9ff;color:#163a94;font-weight:900}
.knpos-moneychip.knpos-tipchip{background:var(--kn-card)3d6;color:#6b4a00;font-weight:900}

.knpos-empty{padding:16px;color:#666}

/* History is always 1 column to avoid card overlap on iPad landscape */


/* Numeric keypad modal */
.knpos-kbdmodal{ position: fixed; inset: 0; z-index: 9999; }
.knpos-kbdmodal__backdrop{ position:absolute; inset:0; background: rgba(0,0,0,0.35); }
.knpos-kbdmodal__panel{
  position:absolute; left:50%; bottom:18px; transform:translateX(-50%);
  width: 360px; max-width: calc(100vw - 24px);
  background:var(--kn-card); border-radius:16px; padding:12px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.25);
}
.knpos-kbdmodal__display{
  width:100%; background:#f6f6f6; border-radius:12px;
  padding:10px 12px; font-size:22px; text-align:right; min-height:44px;
  margin-bottom:10px; box-sizing:border-box;
}
.knpos-kbdmodal__grid{
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap:10px;
}
.knpos-kbdkey{
  padding:14px 10px; border-radius:12px; border:1px solid #e2e2e2;
  font-size:20px; background:var(--kn-card);
}
.knpos-kbdkey--util{ background:#f7f7f7; }
.knpos-kbdkey--ok{ grid-column: span 2; background:#111; color:#fff; border-color:var(--kn-text); }
.knpos-kbdkey--wide{ grid-column: span 2; }

/* Audit summary shown on completed card */
.knpos-auditsummary{
  margin-top:10px; padding-top:10px; border-top:1px dashed #ddd;
  font-size:13px; color:#333;
}
.knpos-auditsummary__label{ font-weight:600; margin-bottom:6px; opacity:0.9; }
.knpos-auditsummary__item{ display:flex; gap:8px; align-items:baseline; padding:2px 0; flex-wrap:wrap; }
.knpos-auditsummary__name{ font-weight:600; }
.knpos-auditsummary__old{ opacity:0.6; }
.knpos-auditsummary__arrow{ opacity:0.7; }
.knpos-auditsummary__tag{ font-size:12px; padding:2px 8px; border-radius:999px; background:#f1f1f1; }
.knpos-auditsummary__tag.del{ background:#ffe8e8; color:#a40000; }
.knpos-auditsummary__tag.add{ background:#e9fff0; color:#0b6b2a; }


/* History header + search */
.knpos-history__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.knpos-history__search{display:flex;align-items:center;gap:6px}
.knpos-searchinput{width:220px;max-width:46vw;padding:8px 10px;border-radius:10px;border:1px solid #e6e9f2;background:var(--kn-card)}
.knpos-searchclear{width:34px;height:34px;border-radius:10px;border:1px solid #e6e9f2;background:var(--kn-card);font-weight:900;line-height:1}
.knpos-nosearch{padding:10px 12px;margin-top:10px;border-radius:12px;background:#fbfcff;border:1px dashed #e6e9f2;opacity:.75}

/* Edit line reset (☰) */
.knpos-resetbtn{width:34px;height:34px;border-radius:10px;border:1px solid #eef0f6;background:var(--kn-card);font-weight:900;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative;z-index:3;touch-action:manipulation}
.knpos-resetbtn:active{transform:scale(.98)}

/* Search highlight */
.knpos-searchhit{outline:2px solid #c7d2fe;box-shadow:0 0 0 4px rgba(199,210,254,.35)}


/* --- Settings section switch (subtabs) --- */
.knpos-subtabs{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 14px 0}
.knpos-subtab{border:1px solid var(--kn-border);background:var(--kn-card);border-radius:999px;padding:8px 12px;cursor:pointer;font-weight:900;font-size:12px;line-height:1;color:#222}
.knpos-subtab.is-active{background:#2f6df6;border-color:#2f6df6;color:#fff}
.knpos-ssection{display:none}
.knpos-ssection.is-active{display:block}
.knpos-inline{padding:8px 10px;border-radius:10px}
.knpos-inline:disabled{background:#f7f8fb;color:var(--kn-muted)}

/* Settings: allow long text to wrap (avoid overlap on iPad) */
.knpos-ssection .kn_hint,
.knpos-ssection .kn_td_label{white-space:normal;overflow-wrap:anywhere;line-height:1.25}
.knpos-ssection label{flex-wrap:wrap !important;align-items:flex-start !important}
.knpos-ssection label span{white-space:normal !important;overflow-wrap:anywhere;line-height:1.25}

/* Report badges (Đủ/Thiếu/Dư) */
.knpos-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:999px;font-weight:900;font-size:12px;margin-left:10px;background:#e9ecef;color:var(--kn-text)}
.knpos-badge.is-good{background:#d1e7dd;color:#0f5132}
.knpos-badge.is-bad{background:#f8d7da;color:#842029}
.knpos-badge.is-warn{background:#fff3cd;color:#664d03}

/* ---------------- Payroll Admin - Appointment tab (read-only) ---------------- */

.knpos-appt-head{position:sticky;top:0;z-index:3}
.knpos-appt-day{position:sticky;top:0;z-index:2;margin:10px 0 6px 0;padding:8px 10px;border-radius:12px;background:var(--kn-card);border:1px solid var(--kn-border);font-weight:900;display:flex;align-items:center;justify-content:space-between;gap:10px}
.knpos-appt-day small{font-weight:800;opacity:.7}
.knpos-appt-card{border:1px solid var(--kn-border);background:var(--kn-card);border-radius:14px;padding:10px 12px;margin:8px 0}
.knpos-appt-card.is-cancelled{opacity:.65}
.knpos-appt-card.is-expandable{cursor:pointer}
.knpos-appt-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.knpos-appt-time{font-weight:900}
.knpos-appt-name{margin-top:6px;font-weight:900;font-size:15px}
.knpos-appt-meta{margin-top:6px;display:flex;flex-direction:column;gap:4px;font-size:13px}
.knpos-muted{opacity:.7}
.knpos-appt-note{margin-top:2px;opacity:.9}

.knpos-appt-actions{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}
.knpos-appt-actions a.knpos-btn,.knpos-appt-actions button.knpos-btn{padding:7px 10px;font-size:13px}
.knpos-appt-extra{margin-top:8px;border-top:1px dashed var(--kn-border);padding-top:8px;display:none}
.knpos-appt-card.is-open .knpos-appt-extra{display:block}

/* Check-in order state pill (POS > Report) */
.knpos-statepill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-weight:900;font-size:11px;line-height:1;background:#e9ecef;color:var(--kn-text);white-space:nowrap}
.knpos-statepill.is-in{background:#d1e7dd;color:#0f5132}
.knpos-statepill.is-leave{background:var(--kn-card)3cd;color:#664d03}
.knpos-statepill.is-out{background:#f8d7da;color:#842029}



/* ===== Touch card pickers (replace dropdown/select) ===== */
.knpos-holdmodebadge{
  display:inline-block;
  margin-bottom:6px;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid #ddd;
  background:var(--kn-card)7e6;
  font-weight:900;
  font-size:12px;
}

.knpos-picktitle{
  font-weight:900;
  margin-bottom:6px;
}

.knpos-pickgrid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap:10px;
}

.knpos-pickcard{
  appearance:none;
  border:1px solid #eee;
  background:var(--kn-card);
  border-radius:14px;
  padding:12px 10px;
  text-align:center;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 1px 3px rgba(0,0,0,.05);
}

.knpos-pickcard:active{
  transform:scale(.98);
}

.knpos-pickcard.is-selected{
  border-color:var(--kn-text);
  box-shadow:0 0 0 2px rgba(0,0,0,.12);
}

.knpos-pickcard.is-disabled{
  opacity:.35;
  cursor:not-allowed;
  box-shadow:none;
}

.knpos-editpickgrid{
  max-height:160px;
  overflow:auto;
  border:1px solid #eee;
  border-radius:12px;
  padding:10px;
}

/* ===== Hold card layout tweaks ===== */
.knpos-hcard.is-hold .knpos-hline--ownergrp .knpos-hline__title{
  font-size:13px;
  font-weight:800;
  opacity:.82;
}

.knpos-hcard.is-hold .knpos-hline--ownergrp .knpos-moneychip{
  font-size:12px;
  padding:6px 9px;
  min-width:56px;
}

.knpos-hcard.is-hold .knpos-hline--holdwith .knpos-hline__title{
  font-size:19px;
  font-weight:900;
}

.knpos-hcard.is-hold .knpos-hline--holdwith .knpos-moneychip{
  font-size:16px;
  padding:8px 12px;
  min-width:72px;
}

/* =========================================================
   Theme isolation + iPad/iOS tap fixes
   - Fix theme overriding our button styles (layout drift)
   - Reduce iOS "first tap only hover" / double-tap-to-activate
   ========================================================= */

/* Make interactive elements behave like real buttons on iOS */
.knpos-root button,
.knpos-root .knpos-btn,
.knpos-root .knpos-iconbtn,
.knpos-root .knpos-searchclear,
.knpos-root .knpos-kbdkey,
.knpos-root .knpos-pickcard,
.knpos-root .knpos-stafftile,
.knpos-root .knpos-tab,
.knpos-root .knpos-logout{
  -webkit-appearance:none !important;
  appearance:none !important;
  -webkit-tap-highlight-color: rgba(0,0,0,0);
  touch-action: manipulation;
  user-select:none;
}

/* Force our button styling to win over theme button CSS */
.knpos-root .knpos-btn{
  border:1px solid var(--kn-border) !important;
  background:var(--kn-card) !important;
  color:var(--kn-text) !important;
  border-radius:10px !important;
  padding:9px 12px !important;
  font-weight:700 !important;
  line-height:1.1 !important;
}
.knpos-root .knpos-btn:hover{
  border-color:#e6e8f0 !important;
  background:var(--kn-card) !important;
  color:var(--kn-text) !important;
}
.knpos-root .knpos-btn.primary{
  background:#2f6df6 !important;
  border-color:#2f6df6 !important;
  color:#fff !important;
}
.knpos-root .knpos-btn.primary:hover{
  background:#2f6df6 !important;
  border-color:#2f6df6 !important;
  color:#fff !important;
}
.knpos-root .knpos-btn.warn{
  background:#f6b23f !important;
  border-color:#f6b23f !important;
  color:var(--kn-text) !important;
}
.knpos-root .knpos-btn.warn:hover{
  background:#f6b23f !important;
  border-color:#f6b23f !important;
  color:var(--kn-text) !important;
}

/* Consistent focus ring inside the POS (avoid theme red focus) */
.knpos-root .knpos-btn:focus,
.knpos-root .knpos-iconbtn:focus,
.knpos-root .knpos-stafftile:focus,
.knpos-root .knpos-pickcard:focus{
  outline:none !important;
  box-shadow:0 0 0 3px rgba(47,109,246,.18) !important;
}

/* Keep Hold/Add readable on iPad when wrapping */
.knpos-root #kn_hold,
.knpos-root #kn_add{
  min-width:120px;
}


/* --- Check-in page (iPad touch UI) --- */
.knpos-root[data-app="checkin"]{
  --kn-checkin-bg-image: none;
  --kn-checkin-card-alpha: .86;
  min-height:100vh;
  background-color:#f4f5f8;
  background-image: var(--kn-checkin-bg-image);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.knpos-root[data-app="checkin"]::before{
  content:"";
  position:fixed;
  inset:0;
  background:rgba(245,246,250,.55);
  pointer-events:none;
  z-index:0;
}
.knpos-root[data-app="checkin"] > .knpos-header,
.knpos-root[data-app="checkin"] > .knpos-content{
  position:relative;
  z-index:1;
}

.knpos-header--checkin{flex-direction:column;align-items:stretch;justify-content:flex-start;gap:10px}
.knpos-header--checkin .knpos-stafftop{display:flex;justify-content:center;align-items:center;padding:2px 0}
.knpos-header--checkin .knpos-logo{height:44px;width:auto;max-width:78vw;object-fit:contain;display:block}
.knpos-header--checkin .knpos-logo--fallback{height:44px;width:44px;border-radius:999px;display:flex;align-items:center;justify-content:center;
  font-weight:950;letter-spacing:.4px;background:var(--kn-card);border:1px solid rgba(0,0,0,.06)}
.knpos-checkinhead{text-align:center;display:flex;flex-direction:column;gap:2px}
.knpos-checkinhead__title{font-weight:950;font-size:18px;color:var(--kn-text);letter-spacing:.2px}
.knpos-checkinhead__sub{font-weight:800;font-size:12px;color:#666}

.knpos-root[data-app="checkin"] .knpos-panel[data-panel="checkin"] > .knpos-card{
  background:transparent;
  border:0;
  box-shadow:none;
  padding:0;
}

.knpos-checkingrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}
.knpos-checktile{border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:12px;text-align:left;cursor:pointer;box-shadow:0 8px 18px rgba(0,0,0,.06);
  min-height:120px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.knpos-checktile:active{transform:scale(.99)}
.knpos-checktile{background:rgba(255,255,255,var(--kn-checkin-card-alpha))}
.knpos-checktile.is-in{background:linear-gradient(180deg, rgba(198,255,220,var(--kn-checkin-card-alpha)) 0%, rgba(150,240,190,var(--kn-checkin-card-alpha)) 100%)}
.knpos-checktile.is-out{background:linear-gradient(180deg, rgba(236,240,250,var(--kn-checkin-card-alpha)) 0%, rgba(220,228,244,var(--kn-checkin-card-alpha)) 100%)}
.knpos-checktile.is-leave{background:linear-gradient(180deg, rgba(255,223,180,var(--kn-checkin-card-alpha)) 0%, rgba(255,195,130,var(--kn-checkin-card-alpha)) 100%)}

.knpos-checktile__top{display:flex;align-items:center;gap:10px;min-width:0}
.knpos-avatar{width:44px;height:44px;border-radius:999px;flex:0 0 auto;object-fit:cover;border:1px solid rgba(0,0,0,.08);background:var(--kn-card)}
.knpos-avatar--fallback{display:flex;align-items:center;justify-content:center;font-weight:950;color:var(--kn-text);letter-spacing:.6px}

.knpos-checktile__meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
/* Name is the primary information: always show clearly (wrap if needed). */
.knpos-checktile__name{font-weight:950;font-size:18px;color:var(--kn-text);white-space:normal;overflow:visible;text-overflow:clip;
  line-height:1.12;word-break:break-word}
/* State is secondary: smaller badge on its own line under the name. */
.knpos-checktile__state{align-self:flex-start;flex:0 0 auto;font-size:10px;font-weight:950;letter-spacing:.6px;text-transform:uppercase;
  padding:3px 8px;border-radius:999px;border:1px solid rgba(0,0,0,.16);background:rgba(255,255,255,.78)}
.knpos-checktile.is-in .knpos-checktile__state{background:rgba(34,139,84,.14);border-color:rgba(34,139,84,.60);color:#1b6b3d}
.knpos-checktile.is-leave .knpos-checktile__state{background:rgba(245,124,0,.14);border-color:rgba(245,124,0,.65);color:#a24b00}
.knpos-checktile.is-out .knpos-checktile__state{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.22);color:#333}

.knpos-checktile__turn{margin-top:10px;display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}
.knpos-checktile__turnbig{font-weight:950;font-size:32px;line-height:1;color:var(--kn-text)}
.knpos-checktile__turnlbl{font-weight:800;font-size:13px;color:#333}
.knpos-checktile__turnsmall{font-weight:800;font-size:12px;color:var(--kn-muted);opacity:.9}
.knpos-checktile__raw{font-size:11px;font-weight:800;color:#666;opacity:.9}

/* Check-in action modal */
.knpos-pinmodal .knpos-kbdmodal__panel{width:min(560px, calc(100vw - 24px));max-width:min(560px, 92vw);padding:16px;border-radius:18px}
.knpos-pinmodal__title{font-weight:950;font-size:22px;margin-bottom:6px}
.knpos-pinmodal__sub{font-weight:800;color:var(--kn-muted);font-size:12px;margin-bottom:10px}
.knpos-pinmodal__actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.knpos-pinmodal__actions .knpos-btn{padding:12px 16px;border-radius:14px;font-size:14px}
.knpos-pinmodal__actions .knpos-btn.primary{font-weight:950}
.knpos-pinmodal__pin{display:flex;justify-content:center;gap:10px;margin:10px 0 0}
.knpos-pindot{width:18px;height:18px;border-radius:999px;border:2px solid rgba(0,0,0,.18);background:transparent}
.knpos-pindot.is-on{background:#111;border-color:var(--kn-text)}

/* Big iPad-friendly PIN keypad */
.knpos-pinmodal .knpos-kbd{display:grid;grid-template-columns:repeat(3, 1fr);gap:14px;margin-top:14px}
.knpos-pinmodal .knpos-kbd__key{
  height:78px;
  border-radius:16px;
  border:1px solid #e2e2e2;
  background:rgba(255,255,255,.92);
  font-size:30px;
  font-weight:950;
  cursor:pointer;
  touch-action:manipulation;
  -webkit-tap-highlight-color: transparent;
}
.knpos-pinmodal .knpos-kbd__key:active{transform:scale(.99)}
.knpos-pinmodal .knpos-row .knpos-btn{padding:12px 16px;font-size:16px}

/* Staff Settings: avatar preview */
.knpos-avatarpreview{width:78px;height:78px;border-radius:999px;object-fit:cover;border:1px solid var(--kn-border);background:var(--kn-card)}

/* ===== Branding footer (all pages) ===== */
.knpos-footer{
  padding:14px 10px;
  text-align:center;
  font-size:12px;
  font-weight:800;
  opacity:0.55;
}

/* POS top date (before Online) */
.knpos-topdate{
  font-weight:900;
  font-size:12px;
  opacity:0.85;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(255,255,255,0.75);
  border:1px solid var(--kn-border);
}

/* Input error visual (login forms) */
.knpos-input.is-error,
#knposAdminPin.is-error,
#knposEmpId.is-error,
#knposStaffPass.is-error{
  border-color:#d93025 !important;
  box-shadow:0 0 0 3px rgba(217,48,37,.12);
}

/* ===== Home: bigger Add/Hold buttons for iPad ===== */
.knpos-inputbar__actions #kn_add,
.knpos-inputbar__actions #kn_hold,
.knpos-inputbar__actions #kn_openhold_cancel{
  padding:12px 14px;
  font-size:14px;
  font-weight:900;
  border-radius:12px;
  height:44px;
}

/* ===== History cards: 3-column right side (Total / Tip / Status+Edit) ===== */
.knpos-hcard__right{min-width:320px;align-items:stretch}
.knpos-hcardgrid{display:grid;grid-template-columns:1.35fr 1fr .9fr;gap:12px;align-items:stretch;width:100%}
.knpos-hcol{display:flex;flex-direction:column;gap:8px;align-items:stretch;min-width:0}
.knpos-hcol:not(:first-child){border-left:1px solid #eef0f6;padding-left:12px}
.knpos-hcol--total{justify-content:center}
.knpos-hcol--tip{justify-content:center}
.knpos-hcol--meta{justify-content:space-between}
.knpos-hcol--meta .knpos-hcardstatus{align-self:flex-end;margin-bottom:4px}
.knpos-hcard__right .knpos-pill{font-size:10px;padding:2px 8px;opacity:0.85}

.knpos-hcardtotal{font-size:20px;font-weight:950;opacity:1;text-align:right;font-variant-numeric:tabular-nums}
.knpos-hcardtotal span{display:block;font-size:12px;font-weight:800;opacity:0.75;margin:0 0 4px 0}

/* Discount row under Total (history cards) */
.knpos-hcarddiscount{font-size:14px;font-weight:950;opacity:0.95;text-align:right;font-variant-numeric:tabular-nums}
.knpos-hcarddiscount span{display:block;font-size:11px;font-weight:800;opacity:0.75;margin:0 0 3px 0}
.knpos-hcarddiscount small{font-size:11px;font-weight:800;opacity:0.7}

.knpos-btn--tip{padding:12px 14px;font-size:16px;font-weight:950;border-radius:12px;width:100%;min-height:54px}
.knpos-btn--edit{padding:10px 12px;font-size:13px;font-weight:900;border-radius:12px;width:100%}

.knpos-btn--danger{background:#ffe9e9;border-color:#ffd5d5;color:#7b1b1b;font-weight:950}
.knpos-btn--danger:hover{background:#ffdcdc}
.knpos-ico{margin-right:6px}
.knpos-hactions{display:flex;flex-direction:column;gap:8px;align-items:stretch;width:100%}
.knpos-hactions .knpos-btn{width:100%}

/* POS: prevent history cards from overflowing on small mobile screens */
@media (max-width: 640px){
  .knpos-root[data-app="pos"] .knpos-hcard{flex-direction:column;gap:10px}
  .knpos-root[data-app="pos"] .knpos-hcard__left{min-width:0;border-right:0;padding-right:0}
  .knpos-root[data-app="pos"] .knpos-hcard__right{min-width:0;align-items:stretch}
  .knpos-root[data-app="pos"] .knpos-hcardgrid{grid-template-columns:1fr;gap:10px}
  .knpos-root[data-app="pos"] .knpos-hcol:not(:first-child){border-left:0;padding-left:0;border-top:1px solid #eef0f6;padding-top:10px}
  .knpos-root[data-app="pos"] .knpos-hcardtotal,
  .knpos-root[data-app="pos"] .knpos-hcarddiscount{text-align:left}
}

/* ===== Edit UI: show staff lines in a horizontal grid on iPad ===== */
.knpos-editlines{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));
  gap:10px;
}

/* ===== Tip modal: bigger panel + bigger inputs ===== */
.knpos-tipmodal .knpos-kbdmodal__panel{width:min(680px, calc(100vw - 24px));max-width:min(680px, 92vw);padding:16px;border-radius:18px}
.knpos-tiprow{gap:10px;align-items:center;flex-wrap:wrap;margin:0}
.knpos-tiptotal{width:260px;max-width:260px;font-weight:950;text-align:right;font-variant-numeric:tabular-nums}
.knpos-tipinput{width:160px;max-width:160px;font-weight:950;text-align:right;font-variant-numeric:tabular-nums}
.knpos-tipline{padding:12px 12px}
.knpos-tipline__name{max-width:260px}
.knpos-tipline__amt{gap:10px}

/* ===== Report: labeled inputs on a single row (iPad) ===== */
.knpos-rptblock1head{justify-content:space-between}
.knpos-btn--sm{height:34px;padding:8px 10px;font-size:12px;font-weight:950;border-radius:10px;white-space:nowrap}
.knpos-rptinputrow{flex-wrap:nowrap;gap:12px;align-items:flex-end;overflow-x:visible}
/* Make the 3 inputs compact enough to fit iPad width (labels above inputs). */
.knpos-field-inline{display:flex;flex-direction:column;align-items:flex-start;gap:4px;flex:0 0 auto}
.knpos-fieldlbl{font-size:11px;font-weight:950;opacity:0.85;min-width:auto;line-height:1}
.knpos-field-inline .knpos-input{width:92px;max-width:92px;text-align:right;font-weight:900;font-variant-numeric:tabular-nums}

/* Report: small totals under the main staff total */
.knpos-rptsub{display:flex;align-items:baseline;gap:8px;padding:4px 8px;border-radius:12px;border:1px solid #eef0f6;background:rgba(255,255,255,0.7)}
.knpos-rptsub span{font-size:11px;font-weight:900;opacity:0.75;letter-spacing:0.2px}
.knpos-rptsub b{font-size:13px;font-weight:950;font-variant-numeric:tabular-nums}


/* ===== Payroll Daily report cards (mobile-friendly) ===== */
.knpos-dailycard__head{display:flex;align-items:center;justify-content:space-between;margin:0}
.knpos-dailycard__name{font-weight:950;font-size:16px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.knpos-dailycard__kpis{display:grid;grid-template-columns:1fr;gap:8px;margin-top:10px}
@media (min-width: 720px){
  .knpos-dailycard__kpis{grid-template-columns:1fr 1fr}
}

.knpos-kpi{
  border:1px solid #eef0f6;
  background:rgba(255,255,255,0.7);
  border-radius:12px;
  padding:10px 12px;
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:10px;
}

.knpos-kpi__label{font-size:11px;font-weight:900;opacity:0.75;letter-spacing:0.2px}
.knpos-kpi__value{font-size:16px;font-weight:950;font-variant-numeric:tabular-nums}

.knpos-dailycard__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}

.knpos-iconbtn{
  width:40px;
  min-width:40px;
  height:40px;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  font-weight:900;
  line-height:1;
}

.knpos-iconbtn--danger{background:#ffe9e9;border-color:#ffd5d5;color:#7b1b1b;font-weight:950}
.knpos-iconbtn--danger:hover{background:#ffdcdc}

/* Generic disabled state for compact icon buttons */
.knpos-iconbtn.is-disabled{
  opacity:.45;
  cursor:not-allowed;
}


/* --- Offline banner --- */
.knpos-offline-banner{
  position: fixed;
  left: 0; right: 0; top: 0;
  padding: 10px 12px;
  font-weight: 700;
  font-size: 13px;
  z-index: 2147483647;
  background: #fff3cd;
  border-bottom: 1px solid #ffe69c;
  color: #664d03;
  text-align: center;
}
body.knpos-is-offline{ padding-top: 42px; }

/* --- Date picker modal (reliable on mobile) --- */
.knpos-datemodal{ position: fixed; inset: 0; z-index: 2147483646; }
.knpos-datemodal__backdrop{ position:absolute; inset:0; background: rgba(0,0,0,0.35); }
.knpos-datemodal__panel{
  position:absolute;
  left:50%; top:50%;
  transform: translate(-50%,-50%);
  width: min(92vw, 360px);
  background: #fff;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.10);
  padding: 14px;
  box-shadow: 0 10px 35px rgba(0,0,0,0.25);
}
.knpos-datemodal__title{ font-weight: 800; margin-bottom: 10px; }
.knpos-datemodal__input{ width: 100%; height: 44px; font-size: 16px; }
.knpos-datemodal__actions{ display:flex; gap:10px; justify-content:flex-end; margin-top: 12px; }


/* Offline waiting badge in History */
.knpos-hbadge{display:inline-block;margin-top:6px;font-size:11px;padding:3px 10px;border-radius:999px;background:var(--kn-card)4e0;border:1px solid #f3d8aa;font-weight:900;white-space:nowrap}

/* Offline: never show waiting badge near time (only show in right status area) */
.knpos-hcard__left .knpos-hbadge{display:none !important;}
/* Hard-stop: never show status pills inside the left (time) column */
.knpos-hcard__left .knpos-pill,
.knpos-hcard__left .knpos-hcardstatus{display:none !important;}


/* Brand UI: discount separator */
.knpos-discountslash{display:inline-flex;align-items:center;justify-content:center;height:44px;min-width:22px;font-weight:900;color:#666;user-select:none}


/* === Brand UI adjustments v1.3.2 === */
/* Hide left-side status pills/badges in history cards; status shown near Edit only */
.knpos-hcard__left .knpos-hbadge,
.knpos-hcard__left .knpos-pill,
.knpos-hcard__left .knpos-hcardstatus{
  display:none !important;
}
/* Hold modal: no owner selection UI */
.knpos-holdmodal #kn_hold_owner_title,
.knpos-holdmodal #kn_hold_owner_cards{
  display:none !important;
}
/* Make Hold-with pick cards larger for iPad */
.knpos-holdmodal #kn_hold_with_cards .knpos-pickcard{
  min-height:64px;
  font-size:20px;
}
.knpos-holdmodal #kn_hold_with_cards .knpos-pickname{
  font-size:20px;
  font-weight:900;
}
/* Confirm dialog buttons larger */
.knpos-holdconfirm .knpos-btn{
  min-height:52px;
  font-size:18px;
  padding:12px 18px;
}


/* ===== KingPOS 1.3.10 - Mobile/report optimizations ===== */

/* Make report tables scroll safely on mobile (avoid overlap) */
.knpos-tablewrap{overflow:auto;-webkit-overflow-scrolling:touch;max-width:100%}

/* Check-in order: mobile cards */
.knpos-ckcards{display:flex;flex-direction:column;gap:10px}
.knpos-ckcard{background:var(--kn-card);border:1px solid rgba(0,0,0,.08);border-radius:14px;padding:10px 12px;box-shadow:0 1px 8px rgba(0,0,0,.05)}
.knpos-ckcard__top{display:flex;align-items:baseline;gap:10px}
.knpos-ckcard__idx{flex:0 0 auto;font-weight:950;color:var(--kn-muted);font-size:12px}
.knpos-ckcard__name{flex:1 1 auto;font-weight:950;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.knpos-ckcard__time{flex:0 0 auto;font-weight:950;font-size:13px;color:var(--kn-text)}
.knpos-ckcard__meta{display:flex;align-items:center;gap:10px;margin-top:8px;flex-wrap:wrap}
.knpos-ckcard__act{font-weight:900;font-size:12px;color:var(--kn-muted)}
.knpos-ckcard__upd{margin-left:auto;font-weight:900;font-size:12px;color:var(--kn-muted)}

/* Turns stacked bar: show numbers inside bars */
.knpos-stacktrack{position:relative;height:18px}
.knpos-stack-big,.knpos-stack-small{display:flex;align-items:center;justify-content:center;min-width:0}
.knpos-stack-num{font-size:11px;font-weight:950;line-height:1;opacity:.95;user-select:none;pointer-events:none}
.knpos-stack-big .knpos-stack-num{color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.25)}
.knpos-stack-small .knpos-stack-num{color:#111;text-shadow:0 1px 1px rgba(255,255,255,.35)}
.knpos-stack-total{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-size:11px;font-weight:950;line-height:1;
  padding:3px 7px;border-radius:999px;
  background:rgba(255,255,255,.78);border:1px solid rgba(0,0,0,.10);
  pointer-events:none
}

/* Hide segment numbers if bar too small (prevent crowding) */
@media (max-width: 640px){
  .knpos-stack-num{font-size:10px}
}


/* Report Tip block */
.knpos-rpttipblock .knpos-hcard{ margin-top:10px; }
.knpos-rpttipblock .knpos-htiptotal{ font-weight:800; }


/* Report Tip split list */
.knpos-tipsplit{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}
.knpos-tipsplit__item{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:999px;padding:4px 10px;font-size:12px;line-height:1.2}

/* Tab icons (Staff & Payroll) - use CSS so i18n .text() won't wipe icons */
.knpos-root[data-app="staff"] .knpos-header--staff .knpos-tab,
.knpos-root[data-app="payroll"] .knpos-header--staff .knpos-tab{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}

.knpos-root[data-app="staff"] .knpos-tab[data-tab="today"]::before{content:"📅";}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="payroll"]::before{content:"💵";}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="settings"]::before{content:"⚙️";}

.knpos-root[data-app="payroll"] .knpos-tab[data-tab="daily"]::before{content:"📅";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="payroll"]::before{content:"🧾";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="w2"]::before{content:"📄";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="settings"]::before{content:"⚙️";}

.knpos-root[data-app="staff"] .knpos-tab[data-tab]::before,
.knpos-root[data-app="payroll"] .knpos-tab[data-tab]::before{
  font-size:16px;
  line-height:1;
  opacity:.9;
}

/* Tab icons (Staff & Payroll) - use CSS so i18n .text() won't wipe icons */
.knpos-root[data-app="staff"] .knpos-header--staff .knpos-tab,
.knpos-root[data-app="payroll"] .knpos-header--staff .knpos-tab{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}

.knpos-root[data-app="staff"] .knpos-tab[data-tab="today"]::before{content:"📅";}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="payroll"]::before{content:"💵";}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="settings"]::before{content:"⚙️";}

.knpos-root[data-app="payroll"] .knpos-tab[data-tab="daily"]::before{content:"📅";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="payroll"]::before{content:"🧾";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="w2"]::before{content:"📄";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="settings"]::before{content:"⚙️";}

/* Keep icon size consistent */
.knpos-root[data-app="staff"] .knpos-tab::before,
.knpos-root[data-app="payroll"] .knpos-tab::before{
  font-size:16px;
  line-height:1;
}

/* Tab icons (Staff & Payroll) - use CSS so i18n .text() won't wipe icons */
.knpos-root[data-app="staff"] .knpos-header--staff .knpos-tab,
.knpos-root[data-app="payroll"] .knpos-header--staff .knpos-tab{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}

.knpos-root[data-app="staff"] .knpos-header--staff .knpos-tab::before,
.knpos-root[data-app="payroll"] .knpos-header--staff .knpos-tab::before{
  font-size:14px;
  line-height:1;
}

/* Staff tabs */
.knpos-root[data-app="staff"] .knpos-tab[data-tab="today"]::before{content:"📅";}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="payroll"]::before{content:"💵";}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="settings"]::before{content:"⚙️";}

/* Payroll admin/mod tabs */
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="daily"]::before{content:"📅";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="payroll"]::before{content:"🧾";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="w2"]::before{content:"📄";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="settings"]::before{content:"⚙️";}

/* Tab icons (Staff & Payroll) - use CSS so i18n .text() won't wipe icons */
.knpos-root[data-app="staff"] .knpos-header--staff .knpos-tab,
.knpos-root[data-app="payroll"] .knpos-header--staff .knpos-tab{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}

.knpos-root[data-app="staff"] .knpos-header--staff .knpos-tab::before,
.knpos-root[data-app="payroll"] .knpos-header--staff .knpos-tab::before{
  font-size:14px;
  line-height:1;
}

.knpos-root[data-app="staff"] .knpos-tab[data-tab="today"]::before{content:"📅";}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="payroll"]::before{content:"💵";}
.knpos-root[data-app="staff"] .knpos-tab[data-tab="settings"]::before{content:"⚙️";}

.knpos-root[data-app="payroll"] .knpos-tab[data-tab="daily"]::before{content:"📅";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="payroll"]::before{content:"🧾";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="w2"]::before{content:"📄";}
.knpos-root[data-app="payroll"] .knpos-tab[data-tab="settings"]::before{content:"⚙️";}


/* Payroll staff detail toggle */
.knpos-detail-toggle{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(0,0,0,0.03);
  cursor:pointer;
  user-select:none;
}
.knpos-detail-toggle:active{ transform:scale(0.99); }


/* PATCH 1.3.16.12: avoid double icons on tabs (icons are injected by JS setTabLabel) */
.knpos-root[data-app="staff"] .knpos-tab::before,
.knpos-root[data-app="payroll"] .knpos-tab::before{
  content:"" !important;
  display:none !important;
}


/* Check-in header menu (language) */
.knpos-menubtn--checkin{position:absolute;left:16px;top:58px}
@media (max-width: 520px){.knpos-menubtn--checkin{top:50px}}
.knpos-header--checkin{position:relative}
#kncheckinMenu{left:16px;top:108px}
#kncheckinMenu .knpos-menusec{font-weight:900;font-size:12px;opacity:.75;padding:8px 12px 2px}


/* ===== Payroll Admin: hamburger menu + drawer (mobile-first) ===== */
.knpos-root[data-app="payroll"] .knpos-ham{
  border:1px solid var(--kn-border);
  background:var(--kn-card);
  border-radius:12px;
  padding:8px 10px;
  font-weight:950;
  line-height:1;
  cursor:pointer;
  margin-right:10px;
}
.knpos-root[data-app="payroll"] .knpos-ham:active{transform:scale(0.98)}

.knpos-drawerback{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.35);
  z-index:1200;
  display:none;
}
.knpos-drawer{
  position:fixed;
  top:0;
  left:0;
  bottom:0;
  width:min(320px, 86vw);
  background:var(--kn-card);
  border-right:1px solid var(--kn-border);
  z-index:1250;
  transform:translateX(-105%);
  transition:transform .18s ease;
  display:flex;
  flex-direction:column;
  padding:14px;
}
.knpos-drawer.is-open{transform:translateX(0)}
.knpos-drawerback.is-open{display:block}

.knpos-drawer__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.knpos-drawer__close{
  border:1px solid var(--kn-border);
  background:transparent;
  border-radius:12px;
  padding:8px 10px;
  font-weight:950;
  cursor:pointer;
}
.knpos-drawer__body{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.knpos-drawer__item{
  width:100%;
  text-align:left;
  border:1px solid var(--kn-border);
  background:rgba(255,255,255,.55);
  padding:12px 12px;
  border-radius:14px;
  font-weight:900;
  cursor:pointer;
}
.knpos-drawer__item.is-active{
  background:rgba(0,0,0,.06);
}

@media (max-width: 860px){
  /* Payroll Admin: bottom menu shows only Income/Daily/Appointment */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-header--staff .knpos-tab[data-tab="settings"],
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-header--staff .knpos-tab[data-tab="w2"],
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-header--staff .knpos-tab[data-tab="analysis"]{
    display:none !important;
  }
  /* Keep logout + burger tidy */
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-brand--staff{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
  }
  .knpos-root[data-app="payroll"].knpos-payroll-admin .knpos-welcome{
    flex:1 1 auto;
    min-width:0;
  }
}


/* ===== Payroll Check# popover ===== */
.knpos-popover{
  background:#fff;
  border:1px solid rgba(0,0,0,0.12);
  border-radius:12px;
  padding:8px;
  box-shadow:0 10px 24px rgba(0,0,0,0.12);
}
.knpay-checkinp.is-editing{
  outline:2px solid rgba(0,0,0,0.15);
}

