/* ═══════════════════════════════════════════════════════════════
   saloon.css  –  Mobile-First Saloon Manager
   Primary: 375px mobile. Desktop bonus at 768px+.
═══════════════════════════════════════════════════════════════ */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{font-size:16px;height:100%}
body{font-family:'Poppins',sans-serif;background:#f4f4f8;color:#222;min-height:100%;overscroll-behavior:none}

:root{
  --pr:#8e44ad;
  --prd:#7d3c98;
  --prl:#f5eaff;
  --dk:#1a1a2e;
  --card:#fff;
  --bd:#e5e5ed;
  --mu:#999;
  --ok:#00b894;
  --wn:#f39c12;
  --er:#e74c3c;
  --inf:#2980b9;
  --bnav:56px;
  --top:56px;
}

/* ── Login ──────────────────────────────────────────────────── */
#ls{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,#1a1a2e 0%,#2d1b4e 60%,#1a1a2e 100%);
  padding:20px;
}
.lc{
  background:#fff;border-radius:24px;
  padding:32px 24px;width:100%;max-width:400px;
  box-shadow:0 24px 64px rgba(0,0,0,.4);
}
.ll{text-align:center;margin-bottom:24px}
.lico{
  width:60px;height:60px;background:var(--pr);border-radius:18px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:26px;color:#fff;margin-bottom:10px;box-shadow:0 8px 20px rgba(142,68,173,.4);
}
.lc h1{font-size:20px;font-weight:700;color:var(--dk)}
.lp{color:var(--mu);font-size:13px;margin-top:3px}

/* Login tabs */
.ltabs{display:flex;gap:6px;margin-bottom:20px;background:#f5f5fb;padding:4px;border-radius:12px}
.ltab{
  flex:1;padding:10px 6px;border:none;border-radius:10px;
  font-size:13px;font-weight:500;cursor:pointer;background:transparent;
  color:#888;font-family:'Poppins',sans-serif;transition:all .2s;
  display:flex;align-items:center;justify-content:center;gap:5px;
}
.ltab.active{background:#fff;color:var(--pr);box-shadow:0 2px 8px rgba(0,0,0,.1);font-weight:600}

/* ── Forms ──────────────────────────────────────────────────── */
.fg{margin-bottom:14px}
.fg label{display:block;font-size:12px;font-weight:600;color:#555;margin-bottom:5px;letter-spacing:.3px}
.fg2c{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fc,.fsl{
  width:100%;padding:13px 14px;border:2px solid var(--bd);border-radius:12px;
  font-size:15px;font-family:'Poppins',sans-serif;outline:none;
  transition:border-color .2s,box-shadow .2s;background:#fff;color:#222;
}
.fc:focus,.fsl:focus{border-color:var(--pr);box-shadow:0 0 0 3px rgba(142,68,173,.12)}
textarea.fc{resize:none;min-height:72px;line-height:1.5}
.pwd-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#bbb;cursor:pointer;font-size:15px;padding:4px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:13px 20px;border:none;border-radius:12px;
  font-size:15px;font-weight:600;font-family:'Poppins',sans-serif;
  cursor:pointer;transition:all .15s;text-decoration:none;
  min-height:48px;
}
.btn:active{transform:scale(.97)}
.bpr{background:var(--pr);color:#fff;box-shadow:0 4px 14px rgba(142,68,173,.3)}
.bpr:hover{background:var(--prd)}
.bb{width:100%}
.bsm{padding:9px 16px;font-size:13px;min-height:38px}
.bot{background:transparent;border:2px solid var(--pr);color:var(--pr)}
.bot:hover{background:var(--pr);color:#fff}
.ber{background:var(--er);color:#fff}
.bok{background:var(--ok);color:#fff}
.bse{background:#eee;color:#555}
.bse:hover{background:#ddd}
.bwn{background:var(--wn);color:#fff}

.err-msg{
  color:var(--er);font-size:12px;margin-bottom:10px;
  padding:10px 12px;background:#fdf0ef;border-radius:10px;border-left:3px solid var(--er);
  line-height:1.4;
}

/* ── TOP BAR ────────────────────────────────────────────────── */
.topbar{
  height:var(--top);background:var(--card);
  border-bottom:1px solid var(--bd);
  display:flex;align-items:center;padding:0 16px;
  position:fixed;top:0;left:0;right:0;z-index:100;
  box-shadow:0 1px 8px rgba(0,0,0,.06);
}
.topbar-icon{width:36px;height:36px;background:var(--pr);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;flex-shrink:0}
.topbar-title{flex:1;margin-left:10px}
.topbar-title h2{font-size:16px;font-weight:700;color:var(--dk);line-height:1.2}
.topbar-title small{font-size:11px;color:var(--mu)}
.topbar-right{display:flex;align-items:center;gap:8px}
.topbar-av{
  width:34px;height:34px;background:var(--pr);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:13px;font-weight:700;flex-shrink:0;cursor:pointer;
}
.topbar-logout{
  width:36px;height:36px;border:none;background:var(--prl);
  border-radius:10px;cursor:pointer;color:var(--pr);font-size:14px;
  display:flex;align-items:center;justify-content:center;
}

/* ── BOTTOM NAV ─────────────────────────────────────────────── */
.bnav{
  position:fixed;bottom:0;left:0;right:0;height:var(--bnav);
  background:var(--card);border-top:1px solid var(--bd);
  display:flex;align-items:stretch;z-index:100;
  box-shadow:0 -2px 10px rgba(0,0,0,.06);
}
.bn-item{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:2px;cursor:pointer;border:none;background:transparent;
  color:var(--mu);font-size:10px;font-weight:500;font-family:'Poppins',sans-serif;
  transition:color .2s;padding:6px 2px;min-width:0;
}
.bn-item i{font-size:19px;transition:transform .2s}
.bn-item span{font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:58px}
.bn-item.active{color:var(--pr)}
.bn-item.active i{transform:translateY(-1px)}
.bn-fab{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;cursor:pointer;border:none;background:transparent;
  margin-top:-16px;
}
.bn-fab-inner{
  width:52px;height:52px;background:var(--pr);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:22px;box-shadow:0 4px 16px rgba(142,68,173,.45);
  transition:transform .2s,box-shadow .2s;
}
.bn-fab:active .bn-fab-inner{transform:scale(.93);box-shadow:0 2px 8px rgba(142,68,173,.3)}
.bn-fab span{font-size:10px;color:var(--pr);font-weight:600;margin-top:4px}

/* ── MAIN CONTENT ───────────────────────────────────────────── */
.main{
  margin-top:var(--top);
  padding-bottom:calc(var(--bnav) + 16px);
  min-height:calc(100vh - var(--top));
}
.pg{display:none;padding:14px 14px 0}
.pg.active{display:block}

.pg-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.pg-hd h2{font-size:18px;font-weight:700;color:var(--dk)}

/* ── CARDS ──────────────────────────────────────────────────── */
.card{background:var(--card);border-radius:16px;padding:16px;box-shadow:0 2px 10px rgba(0,0,0,.05);margin-bottom:14px}
.card-title{font-size:14px;font-weight:700;color:var(--dk);margin-bottom:12px;display:flex;align-items:center;gap:6px}

/* ── STAT GRID ──────────────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.stat-card{background:var(--card);border-radius:14px;padding:14px;box-shadow:0 2px 10px rgba(0,0,0,.05);display:flex;align-items:center;gap:10px}
.stat-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.stat-val{font-size:18px;font-weight:700;color:var(--dk);line-height:1}
.stat-lbl{font-size:11px;color:var(--mu);margin-top:3px}

/* ── SERVICE GRID (new-entry) ───────────────────────────────── */
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  max-height:280px;overflow-y:auto;padding:2px;
}
.svc-card{
  border:2px solid var(--bd);border-radius:12px;padding:10px 8px;
  cursor:pointer;transition:all .15s;background:#fff;text-align:center;
  user-select:none;
}
.svc-card:active{transform:scale(.95)}
.svc-card.selected{border-color:var(--pr);background:var(--prl)}
.svc-cat-icon{font-size:20px;margin-bottom:4px}
.svc-name{font-size:11px;font-weight:600;color:var(--dk);line-height:1.2;margin-bottom:3px}
.svc-price{font-size:13px;font-weight:700;color:var(--pr)}

/* ── CAT TABS ───────────────────────────────────────────────── */
.cat-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;margin-bottom:12px;scrollbar-width:none}
.cat-tabs::-webkit-scrollbar{display:none}
.ctab{
  flex-shrink:0;padding:7px 14px;border-radius:20px;border:2px solid var(--bd);
  background:#fff;font-size:12px;font-weight:500;cursor:pointer;
  transition:all .15s;color:#666;font-family:'Poppins',sans-serif;
}
.ctab.act{border-color:var(--pr);background:var(--pr);color:#fff}

/* ── BILL CART ──────────────────────────────────────────────── */
.cart-item{
  display:flex;align-items:center;gap:8px;
  padding:10px;background:#faf8ff;border-radius:12px;margin-bottom:8px;
}
.ci-name{flex:1;font-size:13px;font-weight:600;color:var(--dk);line-height:1.3}
.ci-qty{display:flex;align-items:center;gap:5px}
.qty-btn{
  width:28px;height:28px;border:1.5px solid var(--bd);border-radius:8px;
  background:#fff;cursor:pointer;font-size:16px;font-weight:700;
  display:flex;align-items:center;justify-content:center;color:var(--dk);
  transition:all .15s;
}
.qty-btn:active{background:var(--pr);color:#fff;border-color:var(--pr)}
.ci-price{font-size:14px;font-weight:700;color:var(--pr);min-width:52px;text-align:right}
.ci-del{width:30px;height:30px;border:none;background:transparent;cursor:pointer;color:#ddd;font-size:15px;display:flex;align-items:center;justify-content:center}
.ci-del:active{color:var(--er)}

.bill-total-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 0;border-top:1px solid var(--bd);margin-top:6px;
}
.bill-total-row span:first-child{font-size:14px;color:#666}
.bill-total-row span:last-child{font-size:18px;font-weight:700;color:var(--dk)}
.bill-row{display:flex;justify-content:space-between;font-size:13px;padding:3px 0;color:#666}
.bill-row.grand{font-size:16px;font-weight:700;color:var(--dk);border-top:1px solid var(--bd);padding-top:8px;margin-top:4px}

/* Payment mode pills */
.pay-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.pay-pill{
  flex:1;min-width:70px;padding:10px 6px;border-radius:12px;border:2px solid var(--bd);
  background:#fff;font-size:12px;font-weight:600;cursor:pointer;
  text-align:center;font-family:'Poppins',sans-serif;transition:all .15s;color:#666;
}
.pay-pill.sel{border-color:var(--pr);background:var(--prl);color:var(--pr)}

/* ── PHOTO UPLOAD ───────────────────────────────────────────── */
.photo-upload-box{
  width:100%;height:140px;border:2.5px dashed var(--bd);border-radius:14px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;overflow:hidden;background:#fafafa;position:relative;
}
.photo-upload-box:active{border-color:var(--pr);background:var(--prl)}
.photo-upload-box img{width:100%;height:100%;object-fit:cover;border-radius:12px}
.photo-ph{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  pointer-events:none;
}
.photo-clear{
  position:absolute;top:8px;right:8px;width:26px;height:26px;
  background:rgba(0,0,0,.55);border-radius:50%;border:none;cursor:pointer;
  color:#fff;font-size:12px;display:none;align-items:center;justify-content:center;
}

/* ── BILL LIST ITEM ─────────────────────────────────────────── */
.bill-item{
  display:flex;align-items:center;gap:12px;padding:12px;
  border-radius:14px;border:1.5px solid var(--bd);background:#fff;margin-bottom:8px;
  cursor:pointer;transition:border-color .15s;
}
.bill-item:active{border-color:var(--pr)}
.bill-av{
  width:44px;height:44px;border-radius:12px;overflow:hidden;flex-shrink:0;
  background:var(--prl);display:flex;align-items:center;justify-content:center;
  font-size:18px;color:var(--pr);font-weight:700;
}
.bill-av img{width:100%;height:100%;object-fit:cover}
.bill-info{flex:1;min-width:0}
.bill-name{font-size:14px;font-weight:600;color:var(--dk);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bill-meta{font-size:11px;color:var(--mu);margin-top:2px}
.bill-right{text-align:right;flex-shrink:0}
.bill-amt{font-size:15px;font-weight:700;color:var(--pr)}
.bill-status{font-size:10px;font-weight:600;margin-top:3px}

/* ── STAFF CARD ─────────────────────────────────────────────── */
.staff-card{
  background:var(--card);border-radius:16px;padding:16px;
  box-shadow:0 2px 10px rgba(0,0,0,.05);margin-bottom:10px;
  display:flex;align-items:center;gap:14px;
}
.staff-av{
  width:52px;height:52px;border-radius:14px;background:var(--prl);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;color:var(--pr);flex-shrink:0;overflow:hidden;
}
.staff-av img{width:100%;height:100%;object-fit:cover}
.staff-info{flex:1;min-width:0}
.staff-name{font-size:15px;font-weight:700;color:var(--dk)}
.staff-role{display:inline-block;font-size:10px;font-weight:700;padding:2px 9px;border-radius:20px;margin-top:3px}
.role-owner{background:#ffe8f9;color:#b8006e}
.role-manager{background:#e8f0ff;color:#3540be}
.role-stylist{background:#e8f8f5;color:var(--ok)}
.role-barber{background:#fff3ee;color:#c0580f}
.role-beautician{background:#f5eaff;color:var(--pr)}
.role-trainee{background:#fef9e7;color:var(--wn)}
.staff-meta{font-size:11px;color:var(--mu);margin-top:4px}
.staff-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}

/* ── CUSTOMER CARD ──────────────────────────────────────────── */
.cust-card{
  display:flex;align-items:center;gap:12px;padding:12px;
  background:var(--card);border-radius:14px;box-shadow:0 2px 8px rgba(0,0,0,.05);
  margin-bottom:8px;cursor:pointer;border:1.5px solid transparent;
  transition:border-color .15s;
}
.cust-card:active{border-color:var(--pr)}
.cust-av{
  width:44px;height:44px;border-radius:12px;background:var(--prl);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700;color:var(--pr);flex-shrink:0;overflow:hidden;
}
.cust-av img{width:100%;height:100%;object-fit:cover}
.cust-info{flex:1;min-width:0}
.cust-name{font-size:14px;font-weight:600;color:var(--dk)}
.cust-phone{font-size:12px;color:var(--mu);margin-top:2px}
.cust-stats-row{display:flex;gap:14px;margin-top:6px}
.cust-stat-item{text-align:center}
.cust-stat-item h5{font-size:13px;font-weight:700;color:var(--dk);line-height:1}
.cust-stat-item p{font-size:10px;color:var(--mu)}

/* ── SERVICE MGMT ITEM ──────────────────────────────────────── */
.svc-item{
  display:flex;align-items:center;gap:12px;padding:12px;
  background:var(--card);border-radius:14px;margin-bottom:8px;
  box-shadow:0 1px 6px rgba(0,0,0,.04);
}
.svc-item-icon{width:40px;height:40px;border-radius:12px;background:var(--prl);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.svc-item-info{flex:1}
.svc-item-name{font-size:14px;font-weight:600;color:var(--dk)}
.svc-item-meta{font-size:11px;color:var(--mu);margin-top:2px;text-transform:capitalize}
.svc-item-price{font-size:15px;font-weight:700;color:var(--pr);text-align:right;flex-shrink:0}
.svc-item-actions{display:flex;gap:6px;flex-shrink:0;margin-left:6px}

/* ── ATTENDANCE ITEM ────────────────────────────────────────── */
.att-item{
  display:flex;align-items:center;gap:12px;padding:12px;
  background:var(--card);border-radius:14px;margin-bottom:8px;
}
.att-status{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700}
.att-present{background:#e8f8f5;color:var(--ok)}
.att-absent{background:#fdf0ef;color:var(--er)}
.att-half_day{background:#fef9e7;color:var(--wn)}
.att-leave{background:#eee;color:#666}

/* ── PAGINATION ─────────────────────────────────────────────── */
.pagination{display:flex;gap:6px;justify-content:center;margin:16px 0;flex-wrap:wrap}
.pgbtn{width:36px;height:36px;border:2px solid var(--bd);border-radius:10px;background:#fff;cursor:pointer;font-size:13px;font-weight:600;font-family:'Poppins',sans-serif;transition:all .15s;display:flex;align-items:center;justify-content:center}
.pgbtn.active,.pgbtn:active{border-color:var(--pr);background:var(--pr);color:#fff}

/* ── SEARCH INPUT ───────────────────────────────────────────── */
.search-wrap{position:relative;margin-bottom:12px}
.search-wrap i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--mu);font-size:14px}
.search-inp{padding-left:40px !important}
.suggestions-box{
  position:absolute;top:calc(100% + 4px);left:0;right:0;
  background:#fff;border:1.5px solid var(--bd);border-radius:14px;
  box-shadow:0 8px 24px rgba(0,0,0,.1);z-index:50;max-height:220px;overflow-y:auto;
}
.sug-item{
  padding:12px 14px;cursor:pointer;font-size:13px;
  border-bottom:1px solid #f5f5f5;display:flex;align-items:center;gap:10px;
}
.sug-item:last-child{border-bottom:none}
.sug-item:active{background:var(--prl)}

/* ── MODALS ─────────────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;
  display:flex;align-items:flex-end;justify-content:center;
  padding:0;
}
.modal{
  background:#fff;border-radius:24px 24px 0 0;
  width:100%;max-height:92vh;overflow-y:auto;
  padding-bottom:env(safe-area-inset-bottom,0px);
  box-shadow:0 -8px 40px rgba(0,0,0,.15);
  animation:slideUp .25s ease;
}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
.mh{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px 14px;border-bottom:1px solid var(--bd);
  position:sticky;top:0;background:#fff;z-index:1;
  border-radius:24px 24px 0 0;
}
.mh h3{font-size:16px;font-weight:700;color:var(--dk);display:flex;align-items:center;gap:7px}
.close-btn{
  width:34px;height:34px;border:none;background:#f0f0f7;border-radius:50%;
  cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;color:#666;
}
.close-btn:active{background:var(--er);color:#fff}
.mb{padding:16px 20px}
.sheet-handle{width:36px;height:4px;background:#ddd;border-radius:2px;margin:10px auto 4px}

/* ── BADGE ──────────────────────────────────────────────────── */
.bge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700}
.bpaid{background:#e8f8f5;color:var(--ok)}
.bpend{background:#fef9e7;color:var(--wn)}
.bpart{background:#e8f0ff;color:#5050cc}
.bcash{background:#f0f0f0;color:#555}
.bupi{background:#e8f8f5;color:var(--ok)}
.bcard{background:#eaf5fb;color:var(--inf)}

/* ── EMPTY STATE ────────────────────────────────────────────── */
.empty-state{text-align:center;padding:40px 20px;color:var(--mu)}
.empty-state i{font-size:40px;margin-bottom:12px;opacity:.3;display:block}
.empty-state p{font-size:14px}

/* ── TOAST ──────────────────────────────────────────────────── */
.toast{
  position:fixed;bottom:calc(var(--bnav) + 12px);left:50%;
  transform:translateX(-50%) translateY(20px);
  background:#222;color:#fff;padding:11px 22px;border-radius:12px;
  font-size:13px;font-weight:500;opacity:0;transition:all .25s;z-index:999;
  white-space:nowrap;pointer-events:none;max-width:90vw;text-align:center;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{background:var(--ok)}.toast.err{background:var(--er)}.toast.info{background:var(--inf)}

/* ── MISC ───────────────────────────────────────────────────── */
.divider{height:1px;background:var(--bd);margin:12px 0}
.section-label{font-size:11px;font-weight:700;color:var(--mu);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}
.chip{display:inline-block;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600;background:var(--prl);color:var(--pr)}

/* ── DASHBOARD STAFF TABLE ──────────────────────────────────── */
.staff-perf-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--bd)}
.staff-perf-row:last-child{border-bottom:none}
.spr-rank{width:22px;height:22px;border-radius:50%;background:var(--prl);color:var(--pr);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.spr-name{flex:1;font-size:13px;font-weight:600;color:var(--dk)}
.spr-rev{font-size:13px;font-weight:700;color:var(--pr);text-align:right}
.spr-earn{font-size:11px;color:var(--ok);text-align:right}

/* ── BILL DETAIL SHEET ──────────────────────────────────────── */
.bd-biz{text-align:center;padding:12px 0 8px;border-bottom:1px dashed var(--bd);margin-bottom:12px}
.bd-biz h3{font-size:16px;font-weight:700}
.bd-biz .bd-billno{font-size:12px;color:var(--pr);font-weight:600;margin-top:2px}
.bd-cust{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding:10px;background:#faf8ff;border-radius:12px}
.bd-cust-photo{width:56px;height:56px;border-radius:10px;object-fit:cover;flex-shrink:0;border:2px solid var(--bd)}
.bd-svc-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--bd);font-size:13px}
.bd-svc-row:last-child{border-bottom:none}
.bd-totals{background:#f9f8ff;border-radius:12px;padding:12px;margin-top:12px}

/* ── REPORT ROWS ────────────────────────────────────────────── */
/* Period tab strip */
.rep-period-tabs{display:flex;gap:6px;background:#f1f0f8;border-radius:12px;padding:5px;margin-bottom:14px}
.rep-ptab{flex:1;padding:8px 6px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;color:var(--mu);background:transparent;transition:all .2s}
.rep-ptab.active{background:var(--pr);color:#fff;box-shadow:0 3px 10px rgba(142,68,173,.3)}

/* Staff card */
.rep-row{background:var(--card);border-radius:14px;padding:14px;margin-bottom:8px;box-shadow:0 1px 6px rgba(0,0,0,.05)}
.rep-row-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.rep-row-avatar{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--pr),#6c3483);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0}
.rep-row-meta{flex:1;min-width:0}
.rep-row-name{font-size:14px;font-weight:700;color:var(--dk)}
.rep-row-sub{font-size:11px;color:var(--mu);margin-top:1px}
.rep-pay-pill{background:#e8f5e9;color:#1b5e20;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:700;white-space:nowrap;border:1px solid #c8e6c9}
.rep-row-stats{display:flex;gap:0;border-radius:10px;overflow:hidden;border:1px solid var(--bd,#ede9f5);margin-bottom:8px}
.rep-stat{flex:1;text-align:center;padding:8px 4px;border-right:1px solid var(--bd,#ede9f5)}
.rep-stat:last-child{border-right:none}
.rep-stat h4{font-size:13px;font-weight:700;color:var(--dk);line-height:1;margin-bottom:2px}
.rep-stat p{font-size:10px;color:var(--mu)}
/* Commission bar */
.rep-row-bar-wrap{height:4px;background:#f0eaf7;border-radius:4px;overflow:hidden}
.rep-row-bar{height:4px;background:linear-gradient(90deg,var(--pr),#6c3483);border-radius:4px;transition:width .4s ease}
.rep-total-box{background:var(--dk);color:#fff;border-radius:14px;padding:14px;display:flex;gap:0;margin-top:4px;margin-bottom:14px}
.rep-total-item{flex:1;text-align:center}
.rep-total-item h4{font-size:15px;font-weight:700}
.rep-total-item p{font-size:10px;opacity:.7;margin-top:2px}

/* Compact custom date row */
.rep-custom-row{display:flex;align-items:flex-end;gap:8px;background:#f9f8ff;border-radius:12px;padding:10px 12px;margin-bottom:12px}
.rep-custom-field{flex:1;min-width:0}
.rep-custom-field label{display:block;font-size:11px;font-weight:600;color:var(--mu);margin-bottom:4px}
.rep-date-inp{width:100%;padding:8px 10px;border:1.5px solid var(--bd);border-radius:8px;font-size:13px;font-family:'Poppins',sans-serif;outline:none;background:#fff;box-sizing:border-box;color:var(--dk)}
.rep-date-inp:focus{border-color:var(--pr)}

/* Settle button on staff card */
.rep-settle-btn{width:100%;margin-top:9px;padding:8px;border:none;border-radius:9px;background:linear-gradient(135deg,#00b894,#00a381);color:#fff;font-size:12px;font-weight:700;font-family:'Poppins',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}

/* ── SALARY SETTLEMENT MODAL ────────────────────────────────── */
.settle-staff-banner{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:10px 12px;background:var(--prl);border-radius:10px}
.settle-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--pr),#6c3483);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0}
.settle-staff-banner span{font-size:15px;font-weight:700;color:var(--dk)}
.settle-period{text-align:center;margin-bottom:10px}
.settle-period-label{font-size:12px;color:var(--mu);background:#f0f0f8;padding:4px 14px;border-radius:20px}
.settle-stat-row{display:flex;gap:0;border-radius:10px;overflow:hidden;border:1px solid var(--bd);margin-bottom:14px}
.settle-stat{flex:1;text-align:center;padding:10px 4px;border-right:1px solid var(--bd)}
.settle-stat:last-child{border-right:none}
.settle-stat h4{font-size:14px;font-weight:700;color:var(--dk);line-height:1;margin-bottom:2px}
.settle-stat p{font-size:10px;color:var(--mu)}
.settle-history-title{font-size:11px;font-weight:700;color:var(--mu);text-transform:uppercase;letter-spacing:.6px;margin:16px 0 8px;padding-top:12px;border-top:1px solid var(--bd)}
.settle-hist-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--bd)}
.settle-hist-item:last-child{border-bottom:none}
.settle-hist-date{font-size:13px;font-weight:600;color:var(--dk)}
.settle-hist-period{font-size:11px;color:var(--mu);margin-top:2px}
.settle-hist-amt{font-size:14px;font-weight:700;color:var(--ok);text-align:right}
.settle-hist-mode{font-size:10px;font-weight:700;letter-spacing:.5px;padding:2px 8px;border-radius:10px;text-align:center;margin-top:3px;text-transform:uppercase}
.settle-hist-mode.cash{background:#e8f5e9;color:#1b5e20}
.settle-hist-mode.upi{background:#e3f2fd;color:#0d47a1}
.settle-hist-mode.bank{background:#fff3e0;color:#e65100}
.settle-hist-mode.other{background:#f5f5f5;color:#616161}

/* ── CUSTOMER DETAIL MODAL ──────────────────────────────────── */
.cust-detail-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.cust-detail-stats{display:flex;gap:12px;margin-bottom:14px;background:#f9f8ff;padding:12px;border-radius:12px}
.cust-detail-stat{flex:1;text-align:center}
.cust-detail-stat h4{font-size:15px;font-weight:700;color:var(--dk)}
.cust-detail-stat p{font-size:10px;color:var(--mu)}
.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-top:8px}
.photo-gallery img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;cursor:pointer;border:2px solid var(--bd)}

/* ── DESKTOP ENHANCEMENT (>768px) ──────────────────────────── */
@media(min-width:769px){
  .main{max-width:600px;margin-left:auto;margin-right:auto}
  .bnav{max-width:600px;left:50%;transform:translateX(-50%)}
  .topbar{max-width:600px;left:50%;transform:translateX(-50%)}
  .modal{border-radius:24px;max-width:520px;margin:auto}
  .modal-overlay{align-items:center}
  .svc-grid{grid-template-columns:repeat(4,1fr)}
  .stat-grid{grid-template-columns:repeat(4,1fr)}
}
