:root{--navy:#062b63;--navy2:#0a3a82;--gold:#ffc928;--bg:#eef3f8;--card:#fff;--text:#12213f;--muted:#64748b;--line:#dfe8f3;--male:#1d4ed8;--female:#c026d3;--green:#0f7a3a;--orange:#9a6700;--red:#b42318;--gray:#475569}*{box-sizing:border-box}body{margin:0;background:var(--bg);font-family:'Noto Sans Bengali',Arial,sans-serif;color:var(--text);font-size:13px}.app-header{position:sticky;top:0;z-index:20;background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff;padding:9px 12px;display:flex;justify-content:space-between;align-items:center;gap:8px;box-shadow:0 5px 16px rgba(6,43,99,.18)}.brand{display:flex;align-items:center;gap:8px;min-width:0}.brand-icon{width:34px;height:34px;border-radius:12px;background:var(--gold);color:var(--navy);display:grid;place-items:center;font-weight:900;font-size:13px;flex:0 0 auto}.brand h1{font-size:15px;margin:0;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand p{font-size:10px;margin:1px 0 0;color:#dbeafe}.header-actions{display:flex;gap:6px}.app{max-width:1140px;margin:8px auto;padding:0 7px}.customer-shell,.admin-shell{background:var(--card);border:1px solid rgba(223,232,243,.9);border-radius:16px;padding:9px;box-shadow:0 10px 26px rgba(6,43,99,.08);margin-bottom:10px}.hero-panel{border-radius:14px;padding:11px;background:linear-gradient(135deg,#07306f,#0d4698);color:white;display:flex;justify-content:space-between;align-items:center;gap:10px;overflow:hidden;position:relative}.hero-panel:after{content:"";position:absolute;right:-50px;top:-65px;width:150px;height:150px;border-radius:50%;background:rgba(255,201,40,.18)}.hero-panel h2{font-size:18px;margin:2px 0}.hero-panel p{font-size:11px;margin:0;color:#dce8ff;line-height:1.4}.kicker{font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;color:var(--gold)}.kicker.dark{color:var(--navy)}.live-pill{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:6px 9px;font-size:10px;font-weight:900;white-space:nowrap}.control-panel{display:grid;grid-template-columns:1fr 1fr 52px 52px;gap:6px;margin-top:8px;align-items:end}label{font-size:11px;font-weight:800;color:#344563;display:block;margin-bottom:3px}input,select,textarea{width:100%;border:1px solid #cfdae8;border-radius:9px;background:#fff;padding:7px 8px;font:inherit;font-size:12px}input,select{height:35px}textarea{min-height:72px;resize:vertical;line-height:1.45}.btn{height:35px;border:0;border-radius:9px;background:var(--navy);color:#fff;font:inherit;font-weight:800;padding:7px 10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.btn.ghost{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.35);color:#fff}.btn.light{background:#e9eff7;color:var(--navy)}.btn.danger{background:#dc2626}.tab-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin:8px 0}.tab{height:35px;border:1px solid var(--line);background:#f8fbff;border-radius:10px;font:inherit;font-size:12px;font-weight:900;color:var(--navy);cursor:pointer}.tab.active{background:var(--navy);color:white;border-color:var(--navy)}.tab b{font-size:11px;background:rgba(6,43,99,.09);border-radius:999px;padding:2px 6px;margin-left:3px}.tab.active b{background:rgba(255,255,255,.18)}.stats-line{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:8px}.stats-line div{border:1px solid var(--line);border-radius:11px;background:#f9fbff;padding:7px;min-height:52px}.stats-line span{display:block;color:var(--muted);font-size:10px;font-weight:800}.stats-line b{display:block;color:var(--navy);font-size:18px;line-height:1.1}.schedule-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin:5px 0 7px}.schedule-head h3{margin:0;color:var(--navy);font-size:14px}.schedule-head span{font-size:10px;font-weight:800;background:#eef4ff;color:var(--navy);border-radius:999px;padding:4px 7px}.timeline-list{display:grid;gap:6px}.schedule-item{display:grid;grid-template-columns:78px 1fr auto;gap:8px;align-items:center;border:1px solid var(--line);border-radius:12px;background:#fff;padding:8px;box-shadow:0 4px 12px rgba(18,33,63,.04);position:relative;overflow:hidden}.schedule-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}.schedule-item.male:before{background:var(--male)}.schedule-item.female:before{background:var(--female)}.time-box{font-weight:900;color:var(--navy);font-size:13px;line-height:1.2;padding-left:2px}.time-box small{display:block;color:var(--muted);font-size:10px;font-weight:700;margin-top:2px}.info-box{min-width:0}.row-one{display:flex;gap:5px;align-items:center;flex-wrap:wrap}.pill{font-size:10px;font-weight:900;color:white;border-radius:999px;padding:3px 7px}.pill.male{background:var(--male)}.pill.female{background:var(--female)}.status{font-size:10px;font-weight:900;border-radius:999px;padding:3px 7px}.Available{background:#e8f8ed;color:var(--green)}.Limited{background:#fff5d6;color:var(--orange)}.FullBook{background:#ffe5e8;color:var(--red)}.Closed{background:#e9ecef;color:#495057}.details{font-size:11px;color:#40516d;line-height:1.35;margin-top:4px;white-space:pre-wrap}.slot-side{text-align:right;min-width:55px}.slot-side b{display:block;color:var(--navy);font-size:18px;line-height:1}.slot-side span{display:block;color:var(--muted);font-size:10px;font-weight:800}.empty{text-align:center;padding:15px;border:1px dashed #b8c5d8;border-radius:10px;color:var(--muted);font-weight:800}.admin-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px}.admin-top h2{font-size:17px;margin:0;color:var(--navy)}.admin-mini-stats{display:flex;gap:6px}.admin-mini-stats div{border:1px solid var(--line);background:#f9fbff;border-radius:10px;padding:6px 10px;min-width:62px}.admin-mini-stats span{display:block;font-size:9px;color:var(--muted);font-weight:800}.admin-mini-stats b{font-size:16px;color:var(--navy)}.form-card{background:#f8fbff;border:1px solid var(--line);border-radius:12px;padding:8px;margin-bottom:8px}.form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}.wide{grid-column:1/-1}.form-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:7px}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px}table{width:100%;min-width:1050px;border-collapse:collapse;background:#fff}th,td{padding:8px 9px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap;font-size:11px}td:nth-child(9){white-space:normal;min-width:160px;max-width:260px}th{background:var(--navy);color:#fff}.center{text-align:center}.row-actions{display:flex;gap:5px;flex-wrap:wrap}.row-actions .btn{height:29px;font-size:11px;padding:5px 8px}.hidden{display:none!important}.modal{position:fixed;inset:0;background:rgba(8,18,38,.62);display:flex;align-items:center;justify-content:center;padding:14px;z-index:1000}.login-box,.reserve-box{width:100%;background:#fff;border-radius:15px;padding:14px;box-shadow:0 20px 60px rgba(0,0,0,.25)}.login-box{max-width:330px}.reserve-box{max-width:720px;max-height:92vh;overflow:auto}.login-box h2,.reserve-box h2{font-size:17px;margin:0 0 10px;color:var(--navy)}.reserve-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.reserve-head p{margin:0 0 8px;color:var(--muted);font-size:11px}.reserve-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:7px}.reserve-list{border:1px solid var(--line);border-radius:10px;overflow:hidden}.reserve-row{display:grid;grid-template-columns:1fr 90px auto;gap:6px;align-items:center;padding:7px;border-bottom:1px solid var(--line);font-size:11px}.reserve-row:last-child{border-bottom:0}.reserve-row b{color:var(--navy)}.error{font-size:11px;font-weight:900;color:var(--red)}footer{text-align:center;color:var(--muted);font-size:10px;padding:12px}@media(max-width:720px){.app{margin:6px auto}.customer-shell,.admin-shell{border-radius:13px}.hero-panel{padding:9px}.hero-panel h2{font-size:15px}.hero-panel p{font-size:10px}.control-panel{grid-template-columns:1fr 1fr}.control-panel .btn{width:100%}.stats-line{gap:5px}.stats-line div{padding:6px;min-height:48px}.stats-line b{font-size:16px}.schedule-item{grid-template-columns:70px 1fr 48px;padding:7px;gap:6px}.time-box{font-size:12px}.slot-side b{font-size:16px}.form-grid{grid-template-columns:repeat(2,1fr)}.brand h1{font-size:14px}.brand p{display:none}.app-header{padding:8px}.brand-icon{width:31px;height:31px}.live-pill{display:none}.reserve-grid{grid-template-columns:1fr 1fr}.reserve-grid .wide{grid-column:1/-1}.reserve-row{grid-template-columns:1fr 80px}.reserve-row .row-actions{grid-column:1/-1}}@media(max-width:380px){.stats-line{grid-template-columns:repeat(2,1fr)}.schedule-item{grid-template-columns:1fr auto}.time-box{grid-column:1/-1;display:flex;gap:6px}.time-box small{margin-top:0}.slot-side{align-self:end}}

/* V3 Polish: customer card right side count spacing + cleaner schedule cards */
.schedule-item{
  grid-template-columns:78px minmax(0,1fr) 72px;
  padding-right:10px;
}
.slot-side{
  background:#f8fbff;
  border:1px solid var(--line);
  border-radius:10px;
  padding:6px 7px;
  margin-right:2px;
  min-width:68px;
}
.slot-side b{
  font-size:17px;
}
.slot-side span{
  line-height:1.15;
}
.schedule-item .info-box{
  padding-right:4px;
}
.schedule-item{
  transition:transform .12s ease, box-shadow .12s ease;
}
.schedule-item:hover{
  transform:translateY(-1px);
  box-shadow:0 7px 18px rgba(18,33,63,.08);
}
.reserve-head{
  border-bottom:1px solid var(--line);
  padding-bottom:8px;
  margin-bottom:9px;
}
.reserve-box h3{
  font-size:14px;
  margin:12px 0 7px;
  color:var(--navy);
}
.reserve-row{
  background:#fff;
}
.reserve-row:nth-child(even){
  background:#f8fbff;
}
@media(max-width:720px){
  .schedule-item{
    grid-template-columns:70px minmax(0,1fr) 64px;
    padding-right:8px;
  }
  .slot-side{
    min-width:62px;
    padding:5px 5px;
    margin-right:1px;
  }
}
@media(max-width:380px){
  .schedule-item{
    grid-template-columns:1fr 64px;
  }
  .slot-side{
    justify-self:end;
  }
}


/* V4: reservation names chip + toast list */
.name-chip{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:999px;padding:4px 7px;background:#f8fbff;color:var(--navy);font-size:10px;font-weight:900;max-width:130px}.name-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.more-chip{border:0;border-radius:999px;padding:4px 7px;background:var(--gold);color:var(--navy);font-size:10px;font-weight:900;cursor:pointer}.names-toast{position:fixed;right:12px;bottom:12px;z-index:2000;width:min(320px,calc(100vw - 24px))}.names-box{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 50px rgba(8,18,38,.22);overflow:hidden}.names-head{background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff;display:flex;justify-content:space-between;align-items:center;gap:8px;padding:9px 10px;font-size:12px}.names-head button{width:26px;height:26px;border:0;border-radius:8px;background:rgba(255,255,255,.15);color:#fff;font-size:18px;cursor:pointer}.names-list{max-height:270px;overflow:auto;padding:8px}.name-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;padding:7px;border:1px solid var(--line);border-radius:10px;margin-bottom:6px;background:#f8fbff;font-size:11px}.name-row:last-child{margin-bottom:0}.name-row b{color:var(--navy)}.name-row small{color:var(--muted);font-weight:800}.group-note{font-size:10px;color:var(--muted);margin-top:4px}@media(max-width:720px){.names-toast{left:12px;right:12px;bottom:10px;width:auto}}


/* V5: Customer side reservation names with reserved count */
.public-reserve{
  margin-top:6px;
  display:flex;
  gap:5px;
  align-items:center;
  flex-wrap:wrap;
}
.public-reserve-title{
  font-size:10px;
  color:var(--muted);
  font-weight:900;
}
.reserve-chip{
  display:inline-flex;
  align-items:center;
  gap:4px;
  border:1px solid #d9e3ef;
  background:#f8fbff;
  color:var(--navy);
  border-radius:999px;
  padding:3px 7px;
  font-size:10px;
  font-weight:900;
  max-width:130px;
}
.reserve-chip .r-name{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.reserve-chip .r-count{
  background:var(--gold);
  color:var(--navy);
  border-radius:999px;
  padding:1px 5px;
  min-width:18px;
  text-align:center;
}
.public-more{
  border:0;
  border-radius:999px;
  padding:3px 7px;
  background:var(--navy);
  color:#fff;
  font-size:10px;
  font-weight:900;
  cursor:pointer;
}
@media(max-width:720px){
  .reserve-chip{
    max-width:105px;
    padding:3px 6px;
  }
}


/* V6 Agent system */
.agent-login-box{
  max-width:420px;
}
.login-subtitle{
  margin:0 0 10px;
  color:var(--muted);
  font-size:11px;
}
.login-tabs{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:6px;
  margin:8px 0 10px;
}
.login-tab{
  border:1px solid var(--line);
  background:#f8fbff;
  color:var(--navy);
  border-radius:9px;
  height:32px;
  font:inherit;
  font-size:11px;
  font-weight:900;
  cursor:pointer;
}
.login-tab.active{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;
}
.login-section{
  display:none;
}
.login-section.active{
  display:block;
}
.login-section label{
  margin-top:6px;
}
.group-note{
  font-size:10px;
  color:var(--muted);
  font-weight:700;
  margin-top:4px;
}
.agent-badge{
  display:inline-flex;
  align-items:center;
  border:1px solid var(--line);
  background:#f8fbff;
  color:var(--navy);
  border-radius:999px;
  padding:3px 7px;
  font-size:10px;
  font-weight:900;
}
.agent-own{
  background:#ecfdf3;
  color:#0f7a3a;
}
@media(max-width:720px){
  .login-tabs{
    grid-template-columns:1fr;
  }
  .reserve-grid{
    grid-template-columns:1fr 1fr;
  }
}


/* V7 Group Code / Group Info display */
.group-info-badge{
  display:inline-flex;
  align-items:center;
  border:1px solid #d9e3ef;
  background:#fff8db;
  color:#735300;
  border-radius:999px;
  padding:3px 7px;
  font-size:10px;
  font-weight:900;
  max-width:150px;
}
.group-info-badge span{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.agent-card-note{
  display:block;
  color:var(--muted);
  font-size:10px;
  font-weight:800;
  margin-top:2px;
}
.reserve-row .group-info-badge{
  margin-top:4px;
}


/* V8 Agent delete + PIN config */
.agent-manage-card{margin-top:10px;border-top:1px solid var(--line);padding-top:10px}
.agent-manage-head{margin-top:0}
.agent-manage-table{min-width:640px}
.danger-note{display:block;color:var(--red);font-size:10px;font-weight:800;margin-top:3px}
.pin-help{display:block;color:var(--muted);font-size:10px;margin-top:3px}


/* V10 QR Pass System */
.qr-manage-box{width:100%;max-width:720px;max-height:92vh;overflow:auto;background:#fff;border-radius:15px;padding:14px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.qr-status-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin:8px 0}.qr-status-grid div{border:1px solid var(--line);background:#f8fbff;border-radius:11px;padding:8px}.qr-status-grid span{display:block;color:var(--muted);font-size:10px;font-weight:800}.qr-status-grid b{display:block;color:var(--navy);font-size:15px}
.qr-reader-box{margin-top:10px;border:1px solid var(--line);border-radius:12px;padding:8px;background:#f8fbff}#qrReader{width:100%}.hint-text{color:var(--muted);font-size:11px;line-height:1.4}.qr-ok{background:#e8f8ed;color:var(--green)}.qr-missing{background:#fff5d6;color:var(--orange)}
.pass-capture-wrap{position:fixed;left:-10000px;top:0;width:390px;height:820px;z-index:-1;pointer-events:none}.pass-screen{width:390px;height:820px;position:relative;overflow:hidden;border-radius:28px;background:linear-gradient(180deg,#e7f1ef 0%,#f4f0f0 54%,#e9f1f0 100%);box-shadow:0 24px 70px rgba(0,0,0,.16);font-family:Arial,Helvetica,sans-serif;color:#151515}.pass-topbar{position:absolute;top:0;left:0;right:0;height:112px;padding:30px 30px 0;display:flex;justify-content:space-between;align-items:flex-start;font-size:20px;color:#222;z-index:20}.pass-close{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.38);display:grid;place-items:center;font-size:31px;font-weight:200;line-height:1}.pass-topName{padding-top:8px}.pass-card{position:absolute;left:18px;right:18px;top:126px;height:500px;overflow:hidden;background:rgba(255,255,255,.78);border-radius:20px;box-shadow:0 7px 24px rgba(0,0,0,.045);text-align:center;z-index:2}.pass-date{position:absolute;top:42px;left:0;right:0;font-size:34px;font-weight:500;letter-spacing:.2px}.pass-time{position:absolute;top:88px;left:0;right:0;font-size:28px;font-weight:300;color:#555b61}.pass-ticketCut{position:absolute;top:229px;width:6px;height:18px;background:linear-gradient(180deg,#f4f0f0,#e9f1f0);z-index:5}.pass-ticketCut.pass-left{left:-3px;border-radius:0 10px 10px 0}.pass-ticketCut.pass-right{right:-3px;border-radius:10px 0 0 10px}.pass-qrSideLine{position:absolute;top:238px;height:0;border-top:2px dashed rgba(130,137,143,.55);z-index:1}.pass-qrSideLine.pass-left{left:0;right:50%;margin-right:84px}.pass-qrSideLine.pass-right{right:0;left:50%;margin-left:84px}.pass-qrWrap{position:absolute;top:158px;left:50%;transform:translateX(-50%);width:160px;height:160px;border-radius:14px;background:rgba(238,238,238,.78);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px rgba(0,0,0,.045);z-index:4}#passQrCanvas{width:130px!important;height:130px!important;background:#fff;display:grid;place-items:center}#passQrCanvas canvas,#passQrCanvas img{width:130px!important;height:130px!important}.pass-qrPlaceholder{font-size:27px;font-weight:800;color:#99a1a7;letter-spacing:1px}.pass-serial{position:absolute;top:336px;left:0;right:0;font-size:26px;font-weight:400;letter-spacing:.4px}.pass-avatar{position:absolute;top:386px;left:50%;transform:translateX(-50%);width:52px;height:52px;border-radius:50%;background:rgba(226,222,222,.76);display:grid;place-items:center;font-size:25px;color:#111}.pass-name{position:absolute;top:442px;left:0;right:0;font-size:18px;color:#2b2e32}.pass-message{position:absolute;left:18px;right:18px;top:470px;font-size:16px;line-height:1.28;color:#1f2327;text-align:center;min-height:38px}.pass-bottomArea{position:absolute;left:0;right:0;bottom:42px;text-align:center;z-index:10}.pass-cancel{font-size:18px;color:#a90f15;text-decoration:underline;text-underline-offset:3px;margin-bottom:28px}.pass-warn{font-size:16px;color:#343a40;margin-bottom:16px;display:flex;align-items:center;justify-content:center}.pass-warnIcon{display:inline-flex;align-items:center;justify-content:center;margin-right:6px;line-height:0}.pass-actionBtn{width:310px;height:54px;margin:0 auto;border-radius:28px;background:linear-gradient(180deg,#555e64,#424a50);color:#fff;display:flex;align-items:center;justify-content:center;gap:10px;font-size:18px;font-weight:500;box-shadow:0 6px 18px rgba(0,0,0,.16)}.pass-navIcon{display:inline-flex;align-items:center;justify-content:center;line-height:0;transform:rotate(-13deg);margin-right:2px}.pass-home{position:absolute;bottom:17px;left:50%;transform:translateX(-50%);width:126px;height:5px;background:#3f474d;border-radius:999px;opacity:.38}


/* V11 Per-email QR list */
.per-email-list{
  display:grid;
  gap:6px;
  margin-top:8px;
}
.qr-email-row{
  display:grid;
  grid-template-columns:64px 1fr auto;
  gap:7px;
  align-items:center;
  border:1px solid var(--line);
  background:#fff;
  border-radius:11px;
  padding:7px;
}
.qr-email-row.active{
  border-color:var(--navy);
  box-shadow:0 0 0 2px rgba(6,43,99,.10);
}
.qr-email-row.saved{
  background:#f8fff9;
}
.qr-email-serial{
  font-weight:900;
  color:var(--navy);
  font-size:13px;
}
.qr-email-info b{
  color:var(--navy);
  font-size:11px;
}
.qr-email-info small{
  display:block;
  color:var(--muted);
  font-size:10px;
  font-weight:800;
}
.qr-row-actions{
  display:flex;
  gap:5px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.qr-row-actions .btn{
  height:29px;
  font-size:10px;
  padding:5px 7px;
}
.qr-list-title{
  font-size:14px;
  margin:12px 0 4px;
  color:var(--navy);
}
.qr-status-grid{
  grid-template-columns:repeat(4,1fr);
}
.pass-close{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  line-height:42px!important;
  padding:0!important;
  transform:none!important;
}
@media(max-width:720px){
  .qr-status-grid{grid-template-columns:repeat(2,1fr)}
  .qr-email-row{grid-template-columns:52px 1fr}
  .qr-row-actions{grid-column:1/-1;justify-content:flex-start}
}


/* V12 Auto scan + agent per-serial download list */
.scan-ready{display:inline-flex;align-items:center;border-radius:999px;padding:3px 7px;background:#ecfdf3;color:#0f7a3a;font-size:10px;font-weight:900;border:1px solid #bbf7d0}
.scan-missing{display:inline-flex;align-items:center;border-radius:999px;padding:3px 7px;background:#f1f5f9;color:#64748b;font-size:10px;font-weight:900;border:1px solid #d9e3ef}
.btn.disabled-look{background:#d6dbe3!important;color:#6b7280!important;cursor:not-allowed;box-shadow:none!important}
.qr-auto-note{font-size:11px;color:var(--muted);padding:7px 8px;border:1px solid var(--line);border-radius:10px;background:#f8fbff;margin:7px 0}
.qr-row-actions .btn.danger{background:#dc2626;color:#fff}
.pass-close{display:flex!important;align-items:center!important;justify-content:center!important;text-align:center!important;line-height:42px!important;padding:0!important;transform:none!important}


/* V13 Agent grouped download list */
.agent-group-card{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  padding:8px;
}
.agent-group-card:hover{
  box-shadow:0 7px 18px rgba(18,33,63,.08);
}
.agent-group-title{
  font-weight:900;
  color:var(--navy);
}
.agent-group-meta{
  display:flex;
  gap:5px;
  flex-wrap:wrap;
  margin-top:4px;
}
.agent-mini-badge{
  border:1px solid #d9e3ef;
  background:#f8fbff;
  color:var(--navy);
  border-radius:999px;
  padding:2px 6px;
  font-size:10px;
  font-weight:900;
}
.downloaded-red{
  background:#ffe5e8!important;
  border-color:#ffc8ce!important;
}
.downloaded-red .qr-email-serial,
.downloaded-red .qr-email-info b{
  color:#b42318!important;
}
.red-mark{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:3px 7px;
  background:#ffe5e8;
  color:#b42318;
  font-size:10px;
  font-weight:900;
  border:1px solid #ffc8ce;
}
.green-mark{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:3px 7px;
  background:#ecfdf3;
  color:#0f7a3a;
  font-size:10px;
  font-weight:900;
  border:1px solid #bbf7d0;
}
.gray-mark{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:3px 7px;
  background:#f1f5f9;
  color:#64748b;
  font-size:10px;
  font-weight:900;
  border:1px solid #d9e3ef;
}
.btn.red-disabled{
  background:#fee2e2!important;
  color:#b42318!important;
  border:1px solid #fecaca!important;
  cursor:not-allowed;
}
.agent-group-box{
  max-width:760px;
}
.pass-close{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  line-height:1!important;
  padding:0!important;
}


/* V14: Agent download active / instant downloaded color */
.btn.download-active{
  background:linear-gradient(135deg,#0f7a3a,#16a34a)!important;
  color:#fff!important;
  border:1px solid #15803d!important;
  box-shadow:0 6px 14px rgba(22,163,74,.22)!important;
}
.btn.download-active:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 18px rgba(22,163,74,.28)!important;
}
.qr-email-row{
  transition:background .15s ease,border-color .15s ease,box-shadow .15s ease;
}
.qr-email-row.ready-highlight{
  background:#f0fdf4!important;
  border-color:#86efac!important;
}
.qr-email-row.just-downloaded,
.qr-email-row.downloaded-red{
  background:#fff1f2!important;
  border-color:#fb7185!important;
  box-shadow:0 0 0 2px rgba(244,63,94,.10)!important;
}
.qr-email-row.just-downloaded .qr-email-serial,
.qr-email-row.just-downloaded .qr-email-info b{
  color:#be123c!important;
}
.btn.red-disabled,
.btn.downloaded-blocked{
  background:#fee2e2!important;
  color:#b42318!important;
  border:1px solid #fca5a5!important;
  cursor:not-allowed!important;
  box-shadow:none!important;
}
.green-mark{
  background:#dcfce7!important;
  color:#166534!important;
  border-color:#86efac!important;
}
.red-mark{
  background:#ffe4e6!important;
  color:#be123c!important;
  border-color:#fb7185!important;
}


/* V15 Clean agent table/category alignment */
.agent-clean-sub{
  display:block;
  color:var(--muted);
  font-size:10px;
  font-weight:800;
  margin-top:2px;
}
.qr-email-info small.clean-line{
  color:var(--muted);
  font-weight:800;
}
.agent-group-title{
  line-height:1.2;
}


/* V16: Agent reserved email range display */
.email-range-badge{
  display:inline-flex;
  align-items:center;
  border:1px solid #bfdbfe;
  background:#eff6ff;
  color:#0b4f8a;
  border-radius:999px;
  padding:4px 8px;
  font-size:11px;
  font-weight:900;
  max-width:220px;
}
.email-range-badge span{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.range-count-note{
  display:block;
  margin-top:3px;
  color:var(--muted);
  font-size:10px;
  font-weight:800;
}
.agent-range-line{
  display:inline-flex;
  gap:5px;
  flex-wrap:wrap;
  align-items:center;
}


/* V17: Load More / Pagination for large lists */
.load-more-box{
  display:flex;
  justify-content:center;
  padding:10px 0 4px;
  grid-column:1/-1;
}
.load-more-row td{
  text-align:center!important;
  background:#f8fbff!important;
  padding:10px!important;
}
.load-more-btn{
  min-width:160px;
  border:1px solid #d9e3ef!important;
  font-weight:900!important;
}
.table-wrap{
  max-height:70vh;
  overflow:auto;
}
.reserve-list,
.per-email-list,
.timeline-list{
  scroll-behavior:smooth;
}
.qr-manage-box,
.agent-group-box,
.reserve-box{
  max-height:92vh;
  overflow:auto;
}


/* V18 Admin scan reminder highlight */
.admin-scan-reminder{
  background:linear-gradient(90deg,#fff1f2,#fff7ed)!important;
  outline:2px solid #fb7185;
  outline-offset:-2px;
  animation:adminScanPulse 1.35s ease-in-out infinite;
  cursor:pointer;
}
.admin-scan-reminder td{
  background:transparent!important;
}
.admin-scan-reminder td:first-child{
  border-left:5px solid #dc2626;
}
.admin-scan-reminder .btn[data-qr]{
  background:#dc2626!important;
  color:#fff!important;
  box-shadow:0 5px 14px rgba(220,38,38,.22)!important;
}
.scan-reminder-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  border-radius:999px;
  padding:3px 7px;
  background:#dc2626;
  color:#fff;
  font-size:10px;
  font-weight:900;
  margin-left:4px;
  white-space:nowrap;
}
.scan-reminder-muted{
  display:block;
  margin-top:3px;
  color:#b42318;
  font-size:10px;
  font-weight:900;
}
@keyframes adminScanPulse{
  0%,100%{box-shadow:0 0 0 rgba(220,38,38,0)}
  50%{box-shadow:0 0 0 4px rgba(220,38,38,.10)}
}


/* V19 Saudi-time two-step admin QR reminder */
.admin-scan-reminder{
  background:#fff7ed!important;
  outline:2px solid #fb923c!important;
  box-shadow:0 0 0 3px rgba(251,146,60,.16)!important;
  cursor:pointer;
}
.admin-scan-reminder:hover{
  background:#ffedd5!important;
}
.scan-reminder-badge{
  display:inline-flex;
  align-items:center;
  margin-left:5px;
  border-radius:999px;
  padding:3px 7px;
  background:#f97316;
  color:#fff;
  font-size:10px;
  font-weight:900;
  white-space:nowrap;
}
.scan-reminder-badge.second-reminder{
  background:#dc2626;
  animation:reminderPulse 1.1s ease-in-out infinite;
}
.scan-reminder-muted{
  display:block;
  margin-top:4px;
  color:#9a3412;
  font-size:10px;
  font-weight:900;
}
@keyframes reminderPulse{
  0%,100%{opacity:1; transform:scale(1)}
  50%{opacity:.75; transform:scale(1.03)}
}


/* V20 WhatsApp reminder */
.agent-whatsapp-card{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:10px;
  align-items:center;
  border:1px solid var(--line);
  background:#f8fbff;
  border-radius:13px;
  padding:10px;
  margin:8px 0 10px;
}
.agent-whatsapp-card b{display:block;color:var(--navy);font-size:13px}
.agent-whatsapp-card span{display:block;color:var(--muted);font-size:10px;font-weight:800;margin-top:2px}
.agent-whatsapp-form{display:flex;gap:7px;align-items:center}
.agent-whatsapp-form input{height:38px;font-size:12px}
.agent-whatsapp-status{grid-column:1/-1;margin:0;color:#0f7a3a;font-size:11px;font-weight:800}
.whatsapp-btn,.btn.whatsapp-btn{
  background:#16a34a!important;
  color:#fff!important;
  border:1px solid #15803d!important;
}
.whatsapp-box{max-width:760px}
.whatsapp-group-list{display:grid;gap:7px;margin-top:8px}
.whatsapp-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  padding:8px;
}
.whatsapp-row.ready{background:#f0fdf4;border-color:#86efac}
.whatsapp-row.missing{background:#fff7ed;border-color:#fed7aa}
.whatsapp-title{font-weight:900;color:var(--navy);font-size:13px}
.whatsapp-meta{display:flex;gap:5px;flex-wrap:wrap;margin-top:4px}
.whatsapp-meta span{border:1px solid #d9e3ef;border-radius:999px;padding:2px 6px;font-size:10px;font-weight:900;color:var(--navy);background:#f8fbff}
.whatsapp-note{display:block;color:var(--muted);font-size:10px;font-weight:800;margin-top:4px}
@media(max-width:720px){
  .agent-whatsapp-card{grid-template-columns:1fr}
  .agent-whatsapp-form{flex-direction:column;align-items:stretch}
  .whatsapp-row{grid-template-columns:1fr}
}


/* V21 Agent browser reminder */
.agent-reminder-card{
  margin:8px 0 10px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  border:1px solid #d9e3ef;
  background:#f8fbff;
  border-radius:13px;
  padding:10px;
}
.agent-reminder-card b{display:block;color:var(--navy);font-size:13px}
.agent-reminder-card span{display:block;color:var(--muted);font-size:10px;font-weight:800;margin-top:3px}
.agent-alarm-list{display:grid;gap:6px;margin:8px 0 10px}
.agent-alarm-item{
  border:1px solid #f59e0b;
  background:#fff7ed;
  border-radius:12px;
  padding:9px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
  box-shadow:0 8px 18px rgba(245,158,11,.12);
}
.agent-alarm-item b{display:block;color:#9a3412;font-size:13px}
.agent-alarm-item span{display:block;color:#7c2d12;font-size:10px;font-weight:800;margin-top:3px}
tr.agent-reminder-due td{
  background:#fff7ed!important;
  border-top:1px solid #fdba74!important;
  border-bottom:1px solid #fdba74!important;
}
.agent-reminder-badge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:3px 7px;
  background:#f97316;
  color:#fff;
  font-size:10px;
  font-weight:900;
  margin-top:4px;
}
.agent-reminder-pulse{
  animation:agentReminderPulse 1.3s ease-in-out infinite;
}
@keyframes agentReminderPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(249,115,22,.35)}
  50%{box-shadow:0 0 0 5px rgba(249,115,22,0)}
}
@media(max-width:720px){.agent-reminder-card,.agent-alarm-item{grid-template-columns:1fr}.agent-reminder-card .btn,.agent-alarm-item .btn{width:100%}}


/* V22 Saudi reminder fix */
.agent-reminder-active{
  background:#fff7ed!important;
  border-color:#fb923c!important;
  box-shadow:0 0 0 2px rgba(251,146,60,.16)!important;
}
.agent-reminder-active .agent-group-title{
  color:#c2410c!important;
}
.reminder-badge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:3px 8px;
  background:#fed7aa;
  color:#9a3412;
  font-size:10px;
  font-weight:900;
  border:1px solid #fdba74;
  margin-left:4px;
}
.reminder-alert-bar{
  margin:8px 0;
  padding:8px 10px;
  border-radius:12px;
  background:#fff7ed;
  color:#9a3412;
  border:1px solid #fdba74;
  font-size:12px;
  font-weight:900;
}


/* V23 fixed agent download-ready reminder */
.agent-reminder-due{
  background:#fff7ed!important;
  border-color:#fb923c!important;
  box-shadow:0 0 0 2px rgba(251,146,60,.16)!important;
}
.agent-reminder-due td{
  background:#fff7ed!important;
}
.agent-reminder-badge,.reminder-badge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:3px 8px;
  margin-left:6px;
  background:#fed7aa;
  color:#9a3412;
  font-size:10px;
  font-weight:900;
  border:1px solid #fdba74;
}
.agent-alarm-list{display:grid;gap:6px;margin:8px 0}.agent-alarm-item{display:flex;justify-content:space-between;gap:8px;align-items:center;border:1px solid #fdba74;background:#fff7ed;color:#9a3412;border-radius:12px;padding:8px}.agent-alarm-item b{display:block}.agent-alarm-item span{font-size:11px}.agent-reminder-pulse{animation:agentPulse 1.4s infinite alternate}@keyframes agentPulse{from{box-shadow:0 0 0 0 rgba(251,146,60,.12)}to{box-shadow:0 0 0 4px rgba(251,146,60,.22)}}


/* V25 WhatsApp group message system */
.agent-whatsapp-card{
  display:none;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:center;
  border:1px solid var(--line);
  background:#f8fbff;
  border-radius:14px;
  padding:10px;
  margin:8px 0 10px;
}
.agent-whatsapp-card b{display:block;color:var(--navy);font-size:13px}
.agent-whatsapp-card span{display:block;color:var(--muted);font-size:11px;margin-top:2px}
.agent-whatsapp-form{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.agent-whatsapp-form input{min-width:210px}
.agent-whatsapp-status{grid-column:1/-1;margin:0;color:#0f7a3a;font-size:11px;font-weight:800}
.whatsapp-box{max-width:840px}
.whatsapp-row{
  display:grid;
  grid-template-columns:1fr 270px;
  gap:10px;
  border:1px solid var(--line);
  border-radius:13px;
  background:#fff;
  padding:10px;
  margin-bottom:8px;
}
.whatsapp-row.ready{background:#f8fff9;border-color:#bbf7d0}
.whatsapp-row.missing{background:#fff7ed;border-color:#fed7aa}
.whatsapp-title{font-size:13px;font-weight:900;color:var(--navy);margin-bottom:4px}
.whatsapp-meta{display:flex;gap:5px;flex-wrap:wrap;margin:4px 0}
.whatsapp-meta span{border:1px solid #d9e3ef;background:#f8fbff;color:var(--navy);border-radius:999px;padding:2px 6px;font-size:10px;font-weight:900}
.whatsapp-note{display:block;color:var(--muted);font-size:10px;font-weight:800;margin:4px 0}
.whatsapp-details{
  width:100%;
  min-height:108px;
  resize:vertical;
  border:1px solid #d9e3ef;
  border-radius:10px;
  padding:8px;
  font-size:12px;
  line-height:1.4;
}
.whatsapp-side{display:grid;gap:7px;align-content:start}
.whatsapp-side input{width:100%}
.whatsapp-btn{background:#0f8f4d!important;color:#fff!important;border:1px solid #0f7a3a!important}
@media(max-width:720px){.whatsapp-row{grid-template-columns:1fr}.agent-whatsapp-card{grid-template-columns:1fr}.agent-whatsapp-form input{min-width:0;width:100%}}


/* V26 timing / scan / whatsapp fixes */
.btn.whatsapp-locked,
.btn.disabled-whatsapp{
  background:#e5e7eb!important;
  color:#6b7280!important;
  border:1px solid #cbd5e1!important;
  box-shadow:none!important;
  cursor:not-allowed!important;
}
.btn.whatsapp-active{
  background:linear-gradient(135deg,#16a34a,#0f7a3a)!important;
  color:#fff!important;
  border:1px solid #15803d!important;
  box-shadow:0 7px 18px rgba(22,163,74,.22)!important;
}
.scan-reminder-badge,
.agent-reminder-badge{
  animation:reminderPulseV26 1s infinite alternate;
}
@keyframes reminderPulseV26{
  from{filter:brightness(1)}
  to{filter:brightness(1.18)}
}
.qr-scan-live-note{
  display:inline-flex;
  margin-left:6px;
  border-radius:999px;
  padding:3px 7px;
  background:#dcfce7;
  color:#166534;
  font-size:10px;
  font-weight:900;
  border:1px solid #86efac;
}


/* V27 WhatsApp label + smart sound */
.whatsapp-locked{
  opacity:.72;
}
.whatsapp-active{
  font-weight:900;
}


/* V30: Generated pass time font weight fix */
.pass-time,
#passShowTime{
  font-size:28px!important;
  font-weight:400!important;
  font-family:Arial, Helvetica, sans-serif!important;
  letter-spacing:.1px!important;
  color:#555b61!important;
  line-height:1.15!important;
  -webkit-font-smoothing:antialiased;
  text-rendering:geometricPrecision;
}


/* V31: Generated pass time — thinner + black */
.pass-time,
#passShowTime{
  font-size:28px!important;
  font-weight:300!important;
  font-family:Arial, Helvetica, sans-serif!important;
  color:#000!important;
  letter-spacing:.05px!important;
  line-height:1.15!important;
  -webkit-font-smoothing:antialiased!important;
  text-rendering:geometricPrecision!important;
}


/* V32: Airport-style voice reminder before scan-ready time */
.voice-reminder-card{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:center;
  border:1px solid #d9e3ef;
  background:#f8fbff;
  border-radius:13px;
  padding:10px 12px;
  margin:0 0 10px;
}
.voice-reminder-card b{
  display:block;
  color:var(--navy);
  font-size:13px;
}
.voice-reminder-card span{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:800;
  margin-top:2px;
}
.admin-voice-reminder{
  background:#eef6ff!important;
  box-shadow:0 0 0 2px rgba(14,116,144,.12)!important;
}
.voice-reminder-badge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:3px 8px;
  background:#dbeafe;
  color:#075985;
  font-size:10px;
  font-weight:900;
  border:1px solid #93c5fd;
  margin-left:4px;
}
@media(max-width:720px){
  .voice-reminder-card{grid-template-columns:1fr}
}


/* V33: Voice announcement fix */
.voice-btn-row{
  display:flex;
  gap:7px;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
}
.voice-btn-row .btn{
  white-space:nowrap;
}
.voice-reminder-card.voice-active{
  border-color:#86efac!important;
  background:#f0fdf4!important;
}
.voice-reminder-card.voice-test{
  border-color:#93c5fd!important;
  background:#eff6ff!important;
}


/* V34 reliable voice controls */
.voice-btn-row{display:flex;gap:6px;flex-wrap:wrap}
.voice-btn-row .btn{min-width:92px}
.voice-active{border-color:#86efac!important;background:#f0fdf4!important}
.voice-error{border-color:#fca5a5!important;background:#fff1f2!important}


/* V38 Arabic soft-tone fallback */
.voice-fallback-note{
  display:block;
  margin-top:5px;
  font-size:10px;
  color:#735300;
  font-weight:800;
}


/* V39: three sound + auto print report */
.voice-reminder-badge{
  background:#fff1cc!important;
  color:#7a4b00!important;
  border-color:#ffd36e!important;
}
.print-report-note{
  font-size:11px;
  color:#475569;
  margin-top:4px;
}


/* V40 reliable print reminder */
.voice-reminder-badge{background:#fef3c7!important;color:#92400e!important;border:1px solid #f59e0b!important;border-radius:999px;padding:3px 7px;font-size:10px;font-weight:900;display:inline-flex;margin-left:4px;}
.admin-voice-reminder{background:#fff7ed!important;box-shadow:inset 3px 0 0 #f97316!important;}


/* V47 sound-only cleanup */
.voice-reminder-badge{background:#0f766e!important;color:#fff!important;}
button[onclick*="printScheduleReport"],
button[onclick*="openAutoPrintReport"],
button[onclick*="schedulePrintReportHtml"],
.print-option,
.auto-print-note{display:none!important;}


/* V48 exact 2h15 sound-only cleanup */
.voice-reminder-badge{background:#16a34a!important;color:#fff!important;border-radius:999px;padding:3px 7px;font-size:10px;font-weight:800;}
.scan-reminder-badge,.scan-reminder-muted{display:none!important;}
button[onclick*="printScheduleReport"],
button[onclick*="openAutoPrintReport"],
button[onclick*="schedulePrintReportHtml"],
.print-option,
.auto-print-note{display:none!important;}


/* V49 auto sound keep-alive cleanup */
.voice-reminder-badge{background:#15803d!important;color:#fff!important;border-radius:999px;padding:3px 7px;font-size:10px;font-weight:900;}
.scan-reminder-badge,.scan-reminder-muted{display:none!important;}
button[onclick*="printScheduleReport"],button[onclick*="openAutoPrintReport"],button[onclick*="schedulePrintReportHtml"],.print-option,.auto-print-note{display:none!important;}

/* V50 correct time only */
.voice-reminder-badge{background:#166534!important;color:#fff!important;border-radius:999px;padding:3px 7px;font-size:10px;font-weight:900;}
.scan-reminder-badge,.scan-reminder-muted,.whatsapp-reminder-badge{display:none!important;}


/* V51 exact Saudi 2h15 cleanup */
.voice-reminder-badge{background:#15803d!important;color:#fff!important;border-radius:999px;padding:3px 7px;font-size:10px;font-weight:900;}
.scan-reminder-badge,.scan-reminder-muted{display:none!important;}
button[onclick*="printScheduleReport"],button[onclick*="openAutoPrintReport"],button[onclick*="schedulePrintReportHtml"],.print-option,.auto-print-note{display:none!important;}

/* V52 clean exact Saudi 2h15 */
.scan-reminder-badge,.scan-reminder-muted{display:none!important}
.voice-reminder-badge{background:#15803d!important;color:#fff!important;border-radius:999px;padding:3px 7px;font-size:10px;font-weight:900}
button[onclick*="printScheduleReport"],button[onclick*="openAutoPrintReport"],button[onclick*="schedulePrintReportHtml"],.print-option,.auto-print-note{display:none!important}


/* V62 clean reminder + sound on open */
#adminVoiceReminderCard,#enableAdminVoiceBtn,#testAdminVoiceBtn,#testDingVoiceBtn{display:none!important;}
.voice-reminder-badge,.rj-v62-badge{background:#dc2626!important;color:#fff!important;border-radius:999px!important;padding:5px 10px!important;font-size:11px!important;font-weight:900!important;animation:rjV62Pulse 1s infinite!important;}
.rj-v62-due-card{outline:4px solid #dc2626!important;border-color:#dc2626!important;box-shadow:0 0 0 8px rgba(220,38,38,.15),0 18px 45px rgba(220,38,38,.30)!important;animation:rjV62CardPulse 1s infinite!important;background:#fff7ed!important;}
@keyframes rjV62Pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@keyframes rjV62CardPulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.08)}}
#rjV62Alert{position:fixed;inset:0;z-index:999999;display:none;align-items:center;justify-content:center;background:rgba(10,20,35,.76);padding:18px;}
.rjv62-card{width:min(460px,96vw);background:#fff;border-radius:24px;box-shadow:0 28px 90px rgba(0,0,0,.42);padding:26px;text-align:center;border:4px solid #dc2626;animation:rjV62AlertPulse 1.1s infinite;}
.rjv62-bell{font-size:46px;line-height:1;margin-bottom:5px;animation:rjV62Bell .8s infinite;}
.rjv62-title{font-size:32px;font-weight:900;color:#991b1b;margin-bottom:10px;}
.rjv62-body{font-size:16px;line-height:1.65;color:#111827;margin:8px 0 18px;}
.rjv62-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.rjv62-actions button{border:0;border-radius:12px;padding:12px 18px;font-weight:900;cursor:pointer;background:#dc2626;color:#fff;}
.rjv62-actions button:last-child{background:#334155;}
@keyframes rjV62AlertPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.015)}}
@keyframes rjV62Bell{0%,100%{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}


/* V64 built-in sound only + 15 minute highlight */
#adminVoiceReminderCard,#enableAdminVoiceBtn,#testAdminVoiceBtn,#testDingVoiceBtn{display:none!important;}
.voice-reminder-badge,.rj-v64-badge{background:#dc2626!important;color:#fff!important;border-radius:999px!important;padding:5px 10px!important;font-size:11px!important;font-weight:900!important;animation:rjV64Pulse 1s infinite!important;}
.rj-v64-due-card{outline:4px solid #dc2626!important;border-color:#dc2626!important;box-shadow:0 0 0 8px rgba(220,38,38,.15),0 18px 45px rgba(220,38,38,.30)!important;animation:rjV64CardPulse 1s infinite!important;background:#fff7ed!important;}
@keyframes rjV64Pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@keyframes rjV64CardPulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.08)}}
#rjV64Alert{position:fixed;inset:0;z-index:999999;display:none;align-items:center;justify-content:center;background:rgba(10,20,35,.76);padding:18px;}
.rjv64-card{width:min(460px,96vw);background:#fff;border-radius:24px;box-shadow:0 28px 90px rgba(0,0,0,.42);padding:26px;text-align:center;border:4px solid #dc2626;animation:rjV64AlertPulse 1.1s infinite;}
.rjv64-bell{font-size:46px;line-height:1;margin-bottom:5px;animation:rjV64Bell .8s infinite;}
.rjv64-title{font-size:32px;font-weight:900;color:#991b1b;margin-bottom:10px;}
.rjv64-body{font-size:16px;line-height:1.65;color:#111827;margin:8px 0 18px;}
.rjv64-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.rjv64-actions button{border:0;border-radius:12px;padding:12px 18px;font-weight:900;cursor:pointer;background:#dc2626;color:#fff;}
@keyframes rjV64AlertPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.015)}}
@keyframes rjV64Bell{0%,100%{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}


/* V65 sound priority + 15 minute highlight */
#adminVoiceReminderCard,#enableAdminVoiceBtn,#testAdminVoiceBtn,#testDingVoiceBtn{display:none!important;}
.voice-reminder-badge,.rj-v65-badge{background:#dc2626!important;color:#fff!important;border-radius:999px!important;padding:5px 10px!important;font-size:11px!important;font-weight:900!important;animation:rjV65Pulse 1s infinite!important;}
.rj-v65-due-card{outline:4px solid #dc2626!important;border-color:#dc2626!important;box-shadow:0 0 0 8px rgba(220,38,38,.15),0 18px 45px rgba(220,38,38,.30)!important;animation:rjV65CardPulse 1s infinite!important;background:#fff7ed!important;}
@keyframes rjV65Pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@keyframes rjV65CardPulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.08)}}
#rjV65Alert{position:fixed;inset:0;z-index:999999;display:none;align-items:center;justify-content:center;background:rgba(10,20,35,.76);padding:18px;}
.rjv65-card{width:min(460px,96vw);background:#fff;border-radius:24px;box-shadow:0 28px 90px rgba(0,0,0,.42);padding:26px;text-align:center;border:4px solid #dc2626;animation:rjV65AlertPulse 1.1s infinite;}
.rjv65-bell{font-size:46px;line-height:1;margin-bottom:5px;animation:rjV65Bell .8s infinite;}
.rjv65-title{font-size:32px;font-weight:900;color:#991b1b;margin-bottom:10px;}
.rjv65-body{font-size:16px;line-height:1.65;color:#111827;margin:8px 0 18px;}
.rjv65-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.rjv65-actions button{border:0;border-radius:12px;padding:12px 18px;font-weight:900;cursor:pointer;background:#dc2626;color:#fff;}
.rjv65-actions button:last-child{background:#334155;}
@keyframes rjV65AlertPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.015)}}
@keyframes rjV65Bell{0%,100%{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}


/* V67 audio file on top of V65 */
#adminVoiceReminderCard,#enableAdminVoiceBtn,#testAdminVoiceBtn,#testDingVoiceBtn{display:none!important;}
.voice-reminder-badge,.rj-v67-badge{background:#dc2626!important;color:#fff!important;border-radius:999px!important;padding:5px 10px!important;font-size:11px!important;font-weight:900!important;animation:rjV67Pulse 1s infinite!important;}
@keyframes rjV67Pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}


/* Schedule Requirement Count Module */
.requirement-card{
  margin:18px 0;
  padding:18px;
  border-radius:22px;
  background:linear-gradient(180deg,#ffffff,#f8fafc);
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 18px 50px rgba(15,23,42,.08);
}
.requirement-head{align-items:flex-start;gap:12px}
.requirement-sub{margin:6px 0 0;color:#64748b;font-size:13px}
.requirement-form{
  margin-top:14px;
  padding:14px;
  border-radius:18px;
  background:#f1f5f9;
  border:1px solid rgba(15,23,42,.08);
}
.requirement-filter{
  margin:14px 0;
  display:flex;
  flex-wrap:wrap;
  align-items:end;
  gap:10px;
  padding:12px;
  border-radius:16px;
  background:#fff7ed;
  border:1px solid rgba(251,146,60,.30);
}
.requirement-filter label{display:block;font-size:12px;font-weight:800;color:#9a3412;margin-bottom:5px}
.requirement-filter input{min-width:190px}
.requirement-table .req-date{font-weight:900;color:#0f172a}
.req-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  padding:5px 9px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
}
.req-male{background:#dbeafe;color:#1d4ed8}
.req-female{background:#fce7f3;color:#be185d}
.req-total{background:#dcfce7;color:#15803d}
.req-remain{background:#fee2e2;color:#b91c1c}
.req-ok{background:#e0f2fe;color:#0369a1}
.req-small{display:block;font-size:11px;color:#64748b;margin-top:4px}
.req-actions{display:flex;gap:6px;flex-wrap:wrap}
.req-actions button{padding:7px 10px;border-radius:10px;border:0;font-weight:800;cursor:pointer}
.req-edit{background:#e0f2fe;color:#075985}
.req-delete{background:#fee2e2;color:#991b1b}
@media(max-width:720px){
  .requirement-card{padding:12px;border-radius:16px}
  .requirement-filter{display:grid}
  .requirement-filter input{min-width:100%}
  .requirement-table{font-size:12px}
}


/* Demand Group Count Module V5 */
.requirement-card{
  margin:18px 0;
  padding:18px;
  border-radius:22px;
  background:linear-gradient(180deg,#ffffff,#f8fafc);
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 18px 50px rgba(15,23,42,.08);
}
.requirement-head{align-items:flex-start;gap:12px}
.requirement-sub{margin:6px 0 0;color:#64748b;font-size:13px}
.requirement-form{margin-top:14px;padding:14px;border-radius:18px;background:#f1f5f9;border:1px solid rgba(15,23,42,.08)}
.requirement-filter{margin:14px 0;display:flex;flex-wrap:wrap;align-items:end;gap:10px;padding:12px;border-radius:16px;background:#fff7ed;border:1px solid rgba(251,146,60,.30)}
.requirement-filter label{display:block;font-size:12px;font-weight:800;color:#9a3412;margin-bottom:5px}
.requirement-filter input{min-width:190px}
.requirement-table .req-date{font-weight:900;color:#0f172a}
.req-pill{display:inline-flex;align-items:center;justify-content:center;min-width:34px;padding:5px 9px;border-radius:999px;font-weight:900;font-size:12px}
.req-male{background:#dbeafe;color:#1d4ed8}
.req-female{background:#fce7f3;color:#be185d}
.req-total{background:#dcfce7;color:#15803d}
.req-small{display:block;font-size:11px;color:#64748b;margin-top:4px}
.req-actions{display:flex;gap:6px;flex-wrap:wrap}
.req-actions button{padding:7px 10px;border-radius:10px;border:0;font-weight:800;cursor:pointer}
.req-edit{background:#e0f2fe;color:#075985}
.req-delete{background:#fee2e2;color:#991b1b}
@media(max-width:720px){.requirement-card{padding:12px;border-radius:16px}.requirement-filter{display:grid}.requirement-filter input{min-width:100%}.requirement-table{font-size:12px}}


/* Simple Mobile Email Map V7 */
.simple-map-card{margin:18px 0;padding:18px;border-radius:22px;background:#fff;border:1px solid rgba(15,23,42,.10);box-shadow:0 18px 50px rgba(15,23,42,.08)}
.simple-map-sub{margin:6px 0 0;color:#64748b;font-size:13px}
.simple-map-controls{margin:14px 0;padding:12px;border-radius:16px;background:#f8fafc;border:1px solid rgba(15,23,42,.08);display:flex;flex-wrap:wrap;gap:10px;align-items:end}
.simple-map-controls label{display:block;font-size:12px;font-weight:800;color:#334155;margin-bottom:5px}
.simple-map-controls input,.simple-map-controls select{min-width:120px}
.simple-map-legend{display:flex;flex-wrap:wrap;gap:12px;margin:10px 0 14px;font-size:12px;font-weight:800;color:#334155}
.simple-map-legend span{display:inline-flex;align-items:center;gap:6px}
.smap-dot{width:18px;height:18px;border:2px solid #111;border-radius:50%;display:inline-block}
.smap-empty{background:#fff;border-style:dotted}
.smap-account{background:#fff;box-shadow:inset 0 0 0 3px #111}
.smap-reserved{background:#111}
.simple-map-print-area{background:#fff;border:1px solid rgba(15,23,42,.12);padding:12px;border-radius:16px}
.simple-map-title{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;font-size:15px}
.simple-map-title span{font-size:12px;color:#64748b}
.simple-map-grid{display:grid;grid-template-columns:repeat(40,1fr);gap:4px}
.simple-map-cell{width:100%;aspect-ratio:1/1;border:1.5px dotted #999;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;line-height:1;background:#fff;color:#111;break-inside:avoid}
.simple-map-cell b{font-weight:900;font-size:7.5px}
.simple-map-cell.smap-account{border:1.6px solid #111;box-shadow:inset 0 0 0 3px #111;background:#fff}
.simple-map-cell.smap-reserved{border:1.6px solid #111;background:#111;color:#fff}
@media(max-width:900px){.simple-map-grid{grid-template-columns:repeat(25,1fr)}}
@media(max-width:560px){.simple-map-grid{grid-template-columns:repeat(16,1fr)}.simple-map-cell b{font-size:7px}}
@media print{
  body *{visibility:hidden!important}
  #simpleEmailMapPrintArea,#simpleEmailMapPrintArea *{visibility:visible!important}
  #simpleEmailMapPrintArea{position:absolute;left:0;top:0;width:100%;border:0;padding:8mm;border-radius:0}
  .simple-map-grid{grid-template-columns:repeat(40,1fr);gap:3px}
  .simple-map-cell{border:1.2px dotted #777!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .simple-map-cell.smap-account{border:1.4px solid #000!important;box-shadow:inset 0 0 0 3px #000!important;background:#fff!important;color:#000!important}
  .simple-map-cell.smap-reserved{border:1.4px solid #000!important;background:#000!important;color:#fff!important}
}


/* V8 A4 one-page print fix for Simple Email Map */
.simple-map-print-info{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin:0 0 8px;
  padding:8px 10px;
  border:1px solid rgba(15,23,42,.18);
  border-radius:12px;
  background:#f8fafc;
  font-size:12px;
}
.smpi-left{display:flex;flex-direction:column;gap:2px;color:#0f172a}
.smpi-left span{font-size:11px;color:#334155}
.smpi-legend{display:flex;flex-wrap:wrap;gap:10px;font-weight:900;color:#111827}
.smpi-legend span{display:inline-flex;align-items:center;gap:5px;font-size:11px}

@media print{
  @page{size:A4 portrait;margin:4mm}
  html,body{
    width:210mm!important;
    height:297mm!important;
    margin:0!important;
    padding:0!important;
    overflow:hidden!important;
    background:#fff!important;
  }
  body *{display:none!important}
  #simpleEmailMapPrintArea,
  #simpleEmailMapPrintArea *{
    display:revert!important;
    visibility:visible!important;
  }
  #simpleEmailMapPrintArea{
    position:fixed!important;
    left:0!important;
    top:0!important;
    width:202mm!important;
    height:289mm!important;
    margin:0!important;
    padding:3mm!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    background:#fff!important;
    overflow:hidden!important;
    page-break-after:avoid!important;
    page-break-before:avoid!important;
    page-break-inside:avoid!important;
  }
  .simple-map-title{
    display:flex!important;
    justify-content:space-between!important;
    align-items:center!important;
    margin:0 0 2.5mm!important;
    padding:0!important;
    font-size:13px!important;
    line-height:1.1!important;
    border-bottom:1px solid #000!important;
    padding-bottom:1.5mm!important;
  }
  .simple-map-title b{font-size:14px!important}
  .simple-map-title span{font-size:10px!important;color:#000!important}
  .simple-map-print-info{
    display:flex!important;
    justify-content:space-between!important;
    align-items:center!important;
    gap:2mm!important;
    margin:0 0 2.5mm!important;
    padding:1.5mm 2mm!important;
    border:1px solid #000!important;
    border-radius:0!important;
    background:#fff!important;
    font-size:9px!important;
    line-height:1.1!important;
    page-break-inside:avoid!important;
  }
  .smpi-left{display:flex!important;flex-direction:column!important;gap:.6mm!important}
  .smpi-left b{font-size:10px!important}
  .smpi-left span{font-size:8.5px!important;color:#000!important}
  .smpi-legend{
    display:flex!important;
    flex-wrap:wrap!important;
    gap:2.5mm!important;
    font-size:8.5px!important;
    color:#000!important;
  }
  .smpi-legend span{display:inline-flex!important;align-items:center!important;gap:1mm!important;font-size:8.5px!important}
  .smap-dot{width:3.8mm!important;height:3.8mm!important;border:1px solid #000!important;border-radius:50%!important;display:inline-block!important}
  .smap-dot.smap-empty{background:#fff!important;border-style:dotted!important}
  .smap-dot.smap-account{background:#fff!important;box-shadow:inset 0 0 0 1mm #000!important}
  .smap-dot.smap-reserved{background:#000!important}
  .simple-map-grid{
    display:grid!important;
    grid-template-columns:repeat(40, 1fr)!important;
    gap:.45mm!important;
    width:100%!important;
    height:auto!important;
    page-break-inside:avoid!important;
  }
  .simple-map-cell{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    width:100%!important;
    aspect-ratio:1/1!important;
    border:.35mm dotted #777!important;
    border-radius:50%!important;
    background:#fff!important;
    color:#000!important;
    box-shadow:none!important;
    font-size:5.2pt!important;
    line-height:1!important;
    page-break-inside:avoid!important;
    break-inside:avoid!important;
    -webkit-print-color-adjust:exact!important;
    print-color-adjust:exact!important;
  }
  .simple-map-cell b{
    display:block!important;
    font-size:5.2pt!important;
    line-height:1!important;
    font-weight:900!important;
  }
  .simple-map-cell.smap-account{
    border:.35mm solid #000!important;
    box-shadow:inset 0 0 0 .8mm #000!important;
    background:#fff!important;
    color:#000!important;
  }
  .simple-map-cell.smap-reserved{
    border:.35mm solid #000!important;
    background:#000!important;
    color:#fff!important;
  }
}


/* V9 PRINT VISIBLE FIX - must be last */
.simple-print-clone-v9{display:none}
@media print{
  @page{size:A4 portrait;margin:4mm}

  html,body{
    width:210mm!important;
    min-height:297mm!important;
    margin:0!important;
    padding:0!important;
    background:#fff!important;
    overflow:hidden!important;
  }

  /* Hide normal page by visibility, not display; display:none on parents causes blank print. */
  body *{
    visibility:hidden!important;
  }

  #simplePrintCloneV9,
  #simplePrintCloneV9 *{
    visibility:visible!important;
  }

  #simplePrintCloneV9{
    display:block!important;
    position:fixed!important;
    left:0!important;
    top:0!important;
    width:202mm!important;
    height:289mm!important;
    margin:0!important;
    padding:3mm!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    background:#fff!important;
    overflow:hidden!important;
    page-break-before:avoid!important;
    page-break-after:avoid!important;
    page-break-inside:avoid!important;
  }

  #simplePrintCloneV9 .simple-map-title{
    display:flex!important;
    justify-content:space-between!important;
    align-items:center!important;
    margin:0 0 2mm!important;
    padding:0 0 1.3mm!important;
    border-bottom:1px solid #000!important;
    font-size:13px!important;
    line-height:1.1!important;
  }
  #simplePrintCloneV9 .simple-map-title b{font-size:14px!important}
  #simplePrintCloneV9 .simple-map-title span{font-size:10px!important;color:#000!important}

  #simplePrintCloneV9 .simple-map-print-info{
    display:flex!important;
    justify-content:space-between!important;
    align-items:center!important;
    gap:2mm!important;
    margin:0 0 2mm!important;
    padding:1.4mm 2mm!important;
    border:1px solid #000!important;
    border-radius:0!important;
    background:#fff!important;
    font-size:9px!important;
    line-height:1.1!important;
    page-break-inside:avoid!important;
  }

  #simplePrintCloneV9 .smpi-left{display:flex!important;flex-direction:column!important;gap:.5mm!important}
  #simplePrintCloneV9 .smpi-left b{font-size:10px!important}
  #simplePrintCloneV9 .smpi-left span{font-size:8.5px!important;color:#000!important}
  #simplePrintCloneV9 .smpi-legend{display:flex!important;flex-wrap:wrap!important;gap:2.5mm!important;color:#000!important}
  #simplePrintCloneV9 .smpi-legend span{display:inline-flex!important;align-items:center!important;gap:1mm!important;font-size:8.5px!important}

  #simplePrintCloneV9 .smap-dot{
    width:3.8mm!important;
    height:3.8mm!important;
    border:1px solid #000!important;
    border-radius:50%!important;
    display:inline-block!important;
  }
  #simplePrintCloneV9 .smap-dot.smap-empty{background:#fff!important;border-style:dotted!important}
  #simplePrintCloneV9 .smap-dot.smap-account{background:#fff!important;box-shadow:inset 0 0 0 1mm #000!important}
  #simplePrintCloneV9 .smap-dot.smap-reserved{background:#000!important}

  #simplePrintCloneV9 .simple-map-grid{
    display:grid!important;
    grid-template-columns:repeat(40, 1fr)!important;
    gap:.42mm!important;
    width:100%!important;
    page-break-inside:avoid!important;
    break-inside:avoid!important;
  }

  #simplePrintCloneV9 .simple-map-cell{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    width:100%!important;
    aspect-ratio:1/1!important;
    border:.32mm dotted #777!important;
    border-radius:50%!important;
    background:#fff!important;
    color:#000!important;
    box-shadow:none!important;
    font-size:5pt!important;
    line-height:1!important;
    page-break-inside:avoid!important;
    break-inside:avoid!important;
    -webkit-print-color-adjust:exact!important;
    print-color-adjust:exact!important;
  }

  #simplePrintCloneV9 .simple-map-cell b{
    display:block!important;
    font-size:5pt!important;
    line-height:1!important;
    font-weight:900!important;
  }

  #simplePrintCloneV9 .simple-map-cell.smap-account{
    border:.32mm solid #000!important;
    box-shadow:inset 0 0 0 .75mm #000!important;
    background:#fff!important;
    color:#000!important;
  }

  #simplePrintCloneV9 .simple-map-cell.smap-reserved{
    border:.32mm solid #000!important;
    background:#000!important;
    color:#fff!important;
  }
}


/* V10 BIG A4 PRINT + SERVER CHECK DETAILS - must be last */
@media print{
  @page{size:A4 portrait;margin:4mm}
  html,body{
    width:210mm!important;
    min-height:297mm!important;
    margin:0!important;
    padding:0!important;
    background:#fff!important;
    overflow:hidden!important;
  }
  body *{visibility:hidden!important}
  #simplePrintCloneV9,
  #simplePrintCloneV9 *{visibility:visible!important}

  #simplePrintCloneV9{
    display:block!important;
    position:fixed!important;
    left:0!important;
    top:0!important;
    width:202mm!important;
    height:289mm!important;
    margin:0!important;
    padding:3mm!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    background:#fff!important;
    overflow:hidden!important;
    page-break-inside:avoid!important;
    break-inside:avoid!important;
  }

  #simplePrintCloneV9 .simple-map-title{
    display:flex!important;
    justify-content:space-between!important;
    align-items:center!important;
    margin:0 0 1.5mm!important;
    padding:0 0 1mm!important;
    border-bottom:1px solid #000!important;
    line-height:1.05!important;
  }
  #simplePrintCloneV9 .simple-map-title b{font-size:12.5pt!important}
  #simplePrintCloneV9 .simple-map-title span{font-size:8.5pt!important;color:#000!important}

  #simplePrintCloneV9 .simple-map-print-info{
    display:flex!important;
    justify-content:space-between!important;
    align-items:center!important;
    gap:2mm!important;
    margin:0 0 2mm!important;
    padding:1.2mm 1.6mm!important;
    border:1px solid #000!important;
    border-radius:0!important;
    background:#fff!important;
    line-height:1.1!important;
    page-break-inside:avoid!important;
  }
  #simplePrintCloneV9 .smpi-left{
    display:flex!important;
    flex-direction:column!important;
    gap:.4mm!important;
    max-width:112mm!important;
  }
  #simplePrintCloneV9 .smpi-left b{font-size:8.5pt!important}
  #simplePrintCloneV9 .smpi-left span{font-size:7pt!important;color:#000!important;display:block!important}
  #simplePrintCloneV9 .smpi-legend{
    display:flex!important;
    flex-wrap:wrap!important;
    justify-content:flex-end!important;
    gap:2.2mm!important;
    color:#000!important;
    max-width:82mm!important;
  }
  #simplePrintCloneV9 .smpi-legend span{
    display:inline-flex!important;
    align-items:center!important;
    gap:.8mm!important;
    font-size:7pt!important;
    white-space:nowrap!important;
  }
  #simplePrintCloneV9 .smap-dot{
    width:3.6mm!important;
    height:3.6mm!important;
    border:1px solid #000!important;
    border-radius:50%!important;
    display:inline-block!important;
  }
  #simplePrintCloneV9 .smap-dot.smap-empty{background:#fff!important;border-style:dotted!important}
  #simplePrintCloneV9 .smap-dot.smap-account{background:#fff!important;box-shadow:inset 0 0 0 .85mm #000!important}
  #simplePrintCloneV9 .smap-dot.smap-reserved{background:#000!important}

  /* 25 columns × 32 rows = 800; uses almost full A4 height with larger circles */
  #simplePrintCloneV9 .simple-map-grid{
    display:grid!important;
    grid-template-columns:repeat(25, 1fr)!important;
    gap:.42mm!important;
    width:100%!important;
    page-break-inside:avoid!important;
    break-inside:avoid!important;
  }
  #simplePrintCloneV9 .simple-map-cell{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    width:100%!important;
    aspect-ratio:1/1!important;
    border:.35mm dotted #777!important;
    border-radius:50%!important;
    background:#fff!important;
    color:#000!important;
    box-shadow:none!important;
    font-size:6.1pt!important;
    line-height:1!important;
    page-break-inside:avoid!important;
    break-inside:avoid!important;
    -webkit-print-color-adjust:exact!important;
    print-color-adjust:exact!important;
  }
  #simplePrintCloneV9 .simple-map-cell b{
    display:block!important;
    font-size:6.1pt!important;
    line-height:1!important;
    font-weight:900!important;
  }
  #simplePrintCloneV9 .simple-map-cell.smap-account{
    border:.35mm solid #000!important;
    box-shadow:inset 0 0 0 .9mm #000!important;
    background:#fff!important;
    color:#000!important;
  }
  #simplePrintCloneV9 .simple-map-cell.smap-reserved{
    border:.35mm solid #000!important;
    background:#000!important;
    color:#fff!important;
  }
}


/* V10 screen preview also follows A4 25-column layout */
.simple-map-grid{grid-template-columns:repeat(25,1fr)!important}
@media(max-width:900px){.simple-map-grid{grid-template-columns:repeat(20,1fr)!important}}
@media(max-width:560px){.simple-map-grid{grid-template-columns:repeat(12,1fr)!important}}


/* Agent Billing V13 */
.billing-card{margin:18px 0;padding:18px;border-radius:22px;background:#fff;border:1px solid rgba(15,23,42,.10);box-shadow:0 18px 50px rgba(15,23,42,.08)}
.billing-sub{margin:6px 0 0;color:#64748b;font-size:13px}
.billing-controls{margin:14px 0;padding:12px;border-radius:16px;background:#f8fafc;border:1px solid rgba(15,23,42,.08);display:flex;flex-wrap:wrap;gap:10px;align-items:end}
.billing-controls label{display:block;font-size:12px;font-weight:800;color:#334155;margin-bottom:5px}
.billing-controls input,.billing-controls select{min-width:145px}
.billing-doc{border:1px solid rgba(15,23,42,.10);border-radius:16px;padding:12px;background:#fff}
.billing-doc-title{font-size:18px;font-weight:900;color:#0f172a;margin-bottom:5px}
.billing-summary-line{font-size:12px;font-weight:700;color:#334155;margin-bottom:10px}
.billing-list-wrap{margin-top:14px}
.bill-status{display:inline-flex;padding:5px 9px;border-radius:999px;font-size:11px;font-weight:900}
.bill-status.due{background:#fee2e2;color:#991b1b}
.bill-status.paid{background:#dcfce7;color:#166534}
.bill-due-row{background:#fff7f7}
.bill-paid-row{background:#f0fdf4}
.billing-due-box{margin:10px 0}
.billing-due-alert{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:12px;border-radius:14px;background:#fee2e2;color:#991b1b;font-weight:900}
.billing-ok{padding:12px;border-radius:14px;background:#ecfdf5;color:#166534;font-weight:900}
#billingPrintCloneV13{display:none}
@media print{
  body *{visibility:hidden!important}
  #billingPrintCloneV13,#billingPrintCloneV13 *{visibility:visible!important}
  #billingPrintCloneV13{display:block!important;position:absolute!important;left:0!important;top:0!important;width:100%!important;background:#fff!important;padding:8mm!important;color:#000!important}
  .billing-print-doc h2{margin:0 0 3mm;font-size:18pt}
  .billing-print-head{border-bottom:1px solid #000;margin-bottom:4mm;padding-bottom:3mm}
  .billing-print-head p{font-size:10pt;margin:0 0 2mm}
  .billing-print-head small{font-size:8pt}
  .billing-print-doc table{width:100%;border-collapse:collapse;font-size:8pt}
  .billing-print-doc th,.billing-print-doc td{border:1px solid #000;padding:2mm;text-align:left;vertical-align:top}
  .billing-print-doc th{background:#eee!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
}


/* Group Booking Billing V14 */
.bill-status.none{background:#e5e7eb;color:#374151}
.group-billing-ok-box{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:14px;border-radius:16px;background:#f8fafc;border:1px solid rgba(15,23,42,.10);margin-bottom:12px}
.group-billing-ok-box div{display:flex;flex-direction:column;gap:4px}
.group-billing-ok-box span{font-size:13px;color:#334155;font-weight:700}
.group-billing-ok-box small{font-size:12px;color:#64748b}
.simple-email-list-preview{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.simple-email-list-preview span{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:#111;color:#fff;font-size:11px;font-weight:900}


/* Billing Edit/Delete + Print Fix V15 */
.bill-action-wrap{display:flex;flex-wrap:wrap;gap:6px}
#gbPrintAreaV15{display:none}
@media print{
  body > :not(#gbPrintAreaV15){display:none!important}
  #gbPrintAreaV15{
    display:block!important;
    visibility:visible!important;
    position:static!important;
    width:100%!important;
    padding:8mm!important;
    background:#fff!important;
    color:#000!important;
  }
  #gbPrintAreaV15 *{
    visibility:visible!important;
    color:#000!important;
  }
  #gbPrintAreaV15 .billing-print-doc{display:block!important;width:100%!important}
  #gbPrintAreaV15 .billing-print-head{display:block!important;border-bottom:1px solid #000!important;margin-bottom:5mm!important;padding-bottom:3mm!important}
  #gbPrintAreaV15 h2{display:block!important;margin:0 0 2mm!important;font-size:18pt!important}
  #gbPrintAreaV15 p{display:block!important;margin:0 0 1.5mm!important;font-size:10pt!important}
  #gbPrintAreaV15 small{display:block!important;font-size:8pt!important}
  #gbPrintAreaV15 table{display:table!important;width:100%!important;border-collapse:collapse!important;font-size:8.5pt!important}
  #gbPrintAreaV15 thead{display:table-header-group!important}
  #gbPrintAreaV15 tbody{display:table-row-group!important}
  #gbPrintAreaV15 tr{display:table-row!important}
  #gbPrintAreaV15 th,#gbPrintAreaV15 td{display:table-cell!important;border:1px solid #000!important;padding:2mm!important;text-align:left!important;vertical-align:top!important}
  #gbPrintAreaV15 th{font-weight:900!important;background:#eee!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}
  #gbPrintAreaV15 .bill-status{display:inline!important;background:transparent!important;border:0!important;padding:0!important;color:#000!important}
}


/* Billing Delete + Print Money Fix V16 */
#gbPrintAreaV16{display:none}
@media print{
  @page{size:A4 portrait;margin:6mm}
  html,body{
    margin:0!important;
    padding:0!important;
    width:210mm!important;
    background:#fff!important;
    overflow:visible!important;
  }
  body > :not(#gbPrintAreaV16){display:none!important}
  body > #gbPrintAreaV16{
    display:block!important;
    visibility:visible!important;
    position:static!important;
    width:198mm!important;
    max-width:198mm!important;
    margin:0 auto!important;
    padding:0!important;
    box-sizing:border-box!important;
    background:#fff!important;
    color:#000!important;
    overflow:visible!important;
  }
  #gbPrintAreaV16 *{
    visibility:visible!important;
    box-sizing:border-box!important;
    color:#000!important;
  }
  #gbPrintAreaV16 .billing-print-doc{
    display:block!important;
    width:100%!important;
    max-width:100%!important;
    overflow:visible!important;
  }
  #gbPrintAreaV16 .gb-print-header-v16{
    display:block!important;
    border:1px solid #000!important;
    padding:4mm!important;
    margin:0 0 4mm!important;
    page-break-inside:avoid!important;
  }
  #gbPrintAreaV16 .gb-print-title-row{
    display:flex!important;
    justify-content:space-between!important;
    align-items:flex-start!important;
    gap:4mm!important;
    border-bottom:1px solid #000!important;
    padding-bottom:3mm!important;
    margin-bottom:3mm!important;
  }
  #gbPrintAreaV16 h2{
    display:block!important;
    margin:0 0 1.5mm!important;
    font-size:18pt!important;
    line-height:1.1!important;
    word-break:break-word!important;
  }
  #gbPrintAreaV16 p{
    display:block!important;
    margin:0 0 1mm!important;
    font-size:9.5pt!important;
    line-height:1.35!important;
    word-break:break-word!important;
  }
  #gbPrintAreaV16 small{
    display:block!important;
    font-size:8pt!important;
    line-height:1.3!important;
  }
  #gbPrintAreaV16 .gb-print-seal-v16{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    width:25mm!important;
    height:25mm!important;
    border:1.5px solid #000!important;
    border-radius:50%!important;
    text-align:center!important;
    font-size:7pt!important;
    font-weight:900!important;
    line-height:1.1!important;
    flex:0 0 25mm!important;
  }
  #gbPrintAreaV16 .gb-print-total-grid-v16{
    display:grid!important;
    grid-template-columns:repeat(5, 1fr)!important;
    gap:2mm!important;
  }
  #gbPrintAreaV16 .gb-print-total-grid-v16 > div{
    display:flex!important;
    flex-direction:column!important;
    gap:1mm!important;
    border:1px solid #000!important;
    padding:2mm!important;
    min-height:12mm!important;
  }
  #gbPrintAreaV16 .gb-print-total-grid-v16 span{
    display:block!important;
    font-size:7.5pt!important;
    line-height:1.1!important;
  }
  #gbPrintAreaV16 .gb-print-total-grid-v16 b{
    display:block!important;
    font-size:10pt!important;
    line-height:1.15!important;
    font-weight:900!important;
    word-break:break-word!important;
  }
  #gbPrintAreaV16 .gb-bdt-total-v16 b{font-size:12pt!important}
  #gbPrintAreaV16 .gb-print-note-v16{
    display:block!important;
    border:1px dashed #000!important;
    padding:2mm!important;
    margin-bottom:3mm!important;
    font-size:8.5pt!important;
    line-height:1.35!important;
    word-break:break-word!important;
  }
  #gbPrintAreaV16 table{
    display:table!important;
    width:100%!important;
    max-width:100%!important;
    table-layout:fixed!important;
    border-collapse:collapse!important;
    font-size:7.2pt!important;
    line-height:1.25!important;
  }
  #gbPrintAreaV16 thead{display:table-header-group!important}
  #gbPrintAreaV16 tbody{display:table-row-group!important}
  #gbPrintAreaV16 tr{display:table-row!important;page-break-inside:avoid!important}
  #gbPrintAreaV16 th,#gbPrintAreaV16 td{
    display:table-cell!important;
    border:1px solid #000!important;
    padding:1.4mm!important;
    text-align:left!important;
    vertical-align:top!important;
    overflow-wrap:anywhere!important;
    word-break:break-word!important;
    white-space:normal!important;
  }
  #gbPrintAreaV16 th:nth-child(1),#gbPrintAreaV16 td:nth-child(1){width:19mm!important}
  #gbPrintAreaV16 th:nth-child(2),#gbPrintAreaV16 td:nth-child(2){width:32mm!important}
  #gbPrintAreaV16 th:nth-child(3),#gbPrintAreaV16 td:nth-child(3){width:66mm!important}
  #gbPrintAreaV16 th:nth-child(4),#gbPrintAreaV16 td:nth-child(4){width:25mm!important}
  #gbPrintAreaV16 th:nth-child(5),#gbPrintAreaV16 td:nth-child(5){width:16mm!important;text-align:center!important}
  #gbPrintAreaV16 th:nth-child(6),#gbPrintAreaV16 td:nth-child(6){width:22mm!important;text-align:center!important}
  #gbPrintAreaV16 th{
    font-weight:900!important;
    background:#eee!important;
    -webkit-print-color-adjust:exact!important;
    print-color-adjust:exact!important;
  }
  #gbPrintAreaV16 .bill-status{
    display:inline!important;
    background:transparent!important;
    border:0!important;
    padding:0!important;
    font-size:7.2pt!important;
  }
}


/* Agent Schedule Restore V17 */
.group-billing-ok-box.restore-v17{
  margin-bottom:12px;
  border:1px solid rgba(15,23,42,.12);
  background:#f8fafc;
}
.group-billing-ok-box.restore-v17 .btn[disabled]{
  opacity:.65;
  cursor:not-allowed;
}


/* Agent Experience Clean V18 */
.agent-billing-clean-card{
  margin:14px 0 18px;
  padding:16px;
  border-radius:20px;
  background:linear-gradient(180deg,#ffffff,#f8fafc);
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 12px 35px rgba(15,23,42,.06);
}
.agent-billing-clean-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
}
.agent-billing-clean-head h3{margin:3px 0 3px;font-size:20px;color:#0f172a}
.agent-billing-clean-head p{margin:0;color:#64748b;font-size:13px}
.agent-billing-mini-stats{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.agent-billing-mini-stats div{
  min-width:92px;
  padding:10px 12px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  text-align:center;
}
.agent-billing-mini-stats span{display:block;font-size:11px;color:#64748b;font-weight:800}
.agent-billing-mini-stats b{display:block;font-size:17px;color:#0f172a;margin-top:2px}
.agent-billing-clean-status{margin-top:10px}
.agent-billing-clean-status .billing-ok.compact,
.agent-billing-clean-status .billing-due-alert.compact{
  padding:10px 12px;
  border-radius:14px;
}
.agent-billing-clean-actions{
  display:flex;
  gap:8px;
  justify-content:flex-end;
  margin-top:10px;
}
.agent-billing-detail-panel{
  margin-top:12px;
  padding-top:12px;
  border-top:1px dashed rgba(15,23,42,.18);
}
.agent-billing-detail-panel.hidden{display:none!important}
.group-billing-ok-box.restore-v17{
  border-radius:16px;
  background:#f8fafc;
  border:1px solid rgba(15,23,42,.12);
}
@media(max-width:760px){
  .agent-billing-clean-head{align-items:flex-start;flex-direction:column}
  .agent-billing-mini-stats{width:100%;justify-content:stretch}
  .agent-billing-mini-stats div{flex:1;min-width:80px}
  .agent-billing-clean-actions{justify-content:stretch}
  .agent-billing-clean-actions .btn{flex:1}
}



/* Professional UI Layer V19 - screen only, does not touch print logic */
@media screen{
  :root{
    --v19-bg:#f4f7fb;
    --v19-surface:#ffffff;
    --v19-surface-2:#f8fafc;
    --v19-ink:#0f172a;
    --v19-muted:#64748b;
    --v19-soft:#e2e8f0;
    --v19-border:rgba(15,23,42,.10);
    --v19-primary:#0f766e;
    --v19-primary-2:#115e59;
    --v19-accent:#f59e0b;
    --v19-danger:#dc2626;
    --v19-success:#16a34a;
    --v19-blue:#2563eb;
    --v19-shadow:0 18px 45px rgba(15,23,42,.08);
    --v19-shadow-soft:0 10px 30px rgba(15,23,42,.06);
    --v19-radius:22px;
    --v19-radius-sm:14px;
  }

  body.pro-v19{
    background:
      radial-gradient(circle at 10% 0%, rgba(15,118,110,.14), transparent 28rem),
      radial-gradient(circle at 90% 12%, rgba(245,158,11,.16), transparent 30rem),
      linear-gradient(180deg,#f8fafc 0%,var(--v19-bg) 42%,#eef4f8 100%)!important;
    color:var(--v19-ink)!important;
    font-family:"Noto Sans Bengali",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif!important;
    letter-spacing:-.01em;
  }

  body.pro-v19 *{box-sizing:border-box}

  body.pro-v19 .app-header{
    position:sticky;
    top:0;
    z-index:50;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    margin:0 auto;
    padding:14px clamp(14px,3vw,34px)!important;
    background:rgba(255,255,255,.86)!important;
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    border-bottom:1px solid rgba(15,23,42,.08)!important;
    box-shadow:0 8px 26px rgba(15,23,42,.06)!important;
  }

  body.pro-v19 .brand{
    display:flex!important;
    align-items:center!important;
    gap:13px!important;
  }

  body.pro-v19 .brand-icon{
    width:46px!important;
    height:46px!important;
    border-radius:16px!important;
    display:grid!important;
    place-items:center!important;
    color:#fff!important;
    font-weight:900!important;
    letter-spacing:.02em!important;
    background:linear-gradient(135deg,var(--v19-primary),#0f3d4a)!important;
    box-shadow:0 12px 25px rgba(15,118,110,.22)!important;
    border:1px solid rgba(255,255,255,.45)!important;
  }

  body.pro-v19 .brand h1{
    margin:0!important;
    font-size:clamp(18px,2.4vw,24px)!important;
    line-height:1.1!important;
    color:var(--v19-ink)!important;
    font-weight:900!important;
  }
  body.pro-v19 .brand p{
    margin:3px 0 0!important;
    font-size:12px!important;
    color:var(--v19-muted)!important;
    font-weight:700!important;
  }

  body.pro-v19 .app{
    width:min(1240px,calc(100% - 28px))!important;
    margin:22px auto 48px!important;
    padding:0!important;
  }

  body.pro-v19 .customer-shell,
  body.pro-v19 .admin-shell{
    background:rgba(255,255,255,.82)!important;
    border:1px solid var(--v19-border)!important;
    border-radius:28px!important;
    box-shadow:var(--v19-shadow)!important;
    padding:clamp(14px,2vw,24px)!important;
    overflow:hidden;
  }

  body.pro-v19 .hero-panel{
    border-radius:26px!important;
    padding:clamp(18px,3vw,32px)!important;
    background:
      linear-gradient(135deg,rgba(15,118,110,.96),rgba(15,61,74,.96)),
      radial-gradient(circle at 90% 20%,rgba(245,158,11,.45),transparent 22rem)!important;
    color:#fff!important;
    border:1px solid rgba(255,255,255,.16)!important;
    box-shadow:0 18px 45px rgba(15,118,110,.16)!important;
    position:relative;
    overflow:hidden;
  }
  body.pro-v19 .hero-panel:after{
    content:"";
    position:absolute;
    inset:auto -50px -110px auto;
    width:260px;
    height:260px;
    border-radius:50%;
    background:rgba(255,255,255,.10);
  }
  body.pro-v19 .hero-panel .kicker,
  body.pro-v19 .kicker{
    display:inline-flex!important;
    align-items:center!important;
    gap:6px!important;
    padding:6px 10px!important;
    border-radius:999px!important;
    background:rgba(15,118,110,.10)!important;
    color:var(--v19-primary-2)!important;
    font-size:11px!important;
    font-weight:900!important;
    letter-spacing:.03em!important;
    text-transform:uppercase;
  }
  body.pro-v19 .hero-panel .kicker{
    background:rgba(255,255,255,.16)!important;
    color:#fff!important;
  }
  body.pro-v19 .kicker.dark{
    background:rgba(15,118,110,.09)!important;
    color:var(--v19-primary-2)!important;
  }
  body.pro-v19 .hero-panel h2{
    margin:12px 0 8px!important;
    font-size:clamp(24px,4vw,40px)!important;
    line-height:1.08!important;
    font-weight:900!important;
    color:#fff!important;
  }
  body.pro-v19 .hero-panel p{
    margin:0!important;
    max-width:680px!important;
    color:rgba(255,255,255,.86)!important;
    font-weight:600!important;
  }
  body.pro-v19 .live-pill{
    background:#fff!important;
    color:var(--v19-primary-2)!important;
    border:0!important;
    padding:9px 13px!important;
    border-radius:999px!important;
    box-shadow:0 12px 24px rgba(15,23,42,.14)!important;
    font-weight:900!important;
  }

  body.pro-v19 .control-panel,
  body.pro-v19 .form-card,
  body.pro-v19 .requirement-card,
  body.pro-v19 .billing-card,
  body.pro-v19 .agent-billing-clean-card,
  body.pro-v19 .agent-whatsapp-card,
  body.pro-v19 .agent-reminder-card,
  body.pro-v19 .agent-manage-card,
  body.pro-v19 .simple-email-map-card{
    background:var(--v19-surface)!important;
    border:1px solid var(--v19-border)!important;
    border-radius:var(--v19-radius)!important;
    box-shadow:var(--v19-shadow-soft)!important;
  }

  body.pro-v19 .control-panel{
    margin:18px 0!important;
    padding:14px!important;
    display:flex!important;
    align-items:end!important;
    gap:12px!important;
    flex-wrap:wrap!important;
  }

  body.pro-v19 label{
    color:#334155!important;
    font-size:12px!important;
    font-weight:900!important;
    margin-bottom:6px!important;
  }

  body.pro-v19 input,
  body.pro-v19 select,
  body.pro-v19 textarea{
    background:#fff!important;
    border:1px solid rgba(15,23,42,.14)!important;
    color:var(--v19-ink)!important;
    border-radius:14px!important;
    padding:11px 12px!important;
    outline:none!important;
    transition:border-color .15s ease,box-shadow .15s ease,background .15s ease!important;
    box-shadow:inset 0 1px 0 rgba(15,23,42,.03)!important;
    min-height:42px;
  }
  body.pro-v19 textarea{min-height:92px}
  body.pro-v19 input:focus,
  body.pro-v19 select:focus,
  body.pro-v19 textarea:focus{
    border-color:rgba(15,118,110,.58)!important;
    box-shadow:0 0 0 4px rgba(15,118,110,.12)!important;
  }

  body.pro-v19 .btn{
    border:0!important;
    border-radius:14px!important;
    min-height:40px!important;
    padding:10px 14px!important;
    font-weight:900!important;
    color:#fff!important;
    background:linear-gradient(135deg,var(--v19-primary),var(--v19-primary-2))!important;
    box-shadow:0 10px 20px rgba(15,118,110,.18)!important;
    transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease!important;
  }
  body.pro-v19 .btn:hover{transform:translateY(-1px);box-shadow:0 14px 26px rgba(15,118,110,.22)!important}
  body.pro-v19 .btn:active{transform:translateY(0)}
  body.pro-v19 .btn.light,
  body.pro-v19 .btn.ghost{
    color:var(--v19-ink)!important;
    background:#fff!important;
    border:1px solid rgba(15,23,42,.12)!important;
    box-shadow:0 8px 18px rgba(15,23,42,.06)!important;
  }
  body.pro-v19 .btn.danger,
  body.pro-v19 .danger .btn,
  body.pro-v19 button.danger{
    background:linear-gradient(135deg,#ef4444,var(--v19-danger))!important;
    color:#fff!important;
    box-shadow:0 10px 20px rgba(220,38,38,.18)!important;
  }
  body.pro-v19 .btn.download-active{background:linear-gradient(135deg,#22c55e,#15803d)!important}
  body.pro-v19 .downloaded-blocked,
  body.pro-v19 .btn.disabled-look{
    opacity:.72!important;
    background:#e2e8f0!important;
    color:#334155!important;
    box-shadow:none!important;
  }

  body.pro-v19 .tab-row{
    display:flex!important;
    gap:10px!important;
    flex-wrap:wrap!important;
    margin:16px 0!important;
  }
  body.pro-v19 .tab{
    border:1px solid rgba(15,23,42,.12)!important;
    background:#fff!important;
    color:#334155!important;
    border-radius:999px!important;
    padding:10px 14px!important;
    font-weight:900!important;
    box-shadow:0 8px 18px rgba(15,23,42,.05)!important;
  }
  body.pro-v19 .tab.active{
    background:linear-gradient(135deg,var(--v19-primary),var(--v19-primary-2))!important;
    color:#fff!important;
    border-color:transparent!important;
  }
  body.pro-v19 .tab b{
    background:rgba(255,255,255,.24)!important;
    padding:2px 8px!important;
    border-radius:999px!important;
    margin-left:5px!important;
  }

  body.pro-v19 .stats-line,
  body.pro-v19 .admin-mini-stats,
  body.pro-v19 .agent-billing-mini-stats{
    gap:10px!important;
  }
  body.pro-v19 .stats-line > div,
  body.pro-v19 .admin-mini-stats > div,
  body.pro-v19 .agent-billing-mini-stats > div{
    background:#fff!important;
    border:1px solid rgba(15,23,42,.10)!important;
    border-radius:18px!important;
    padding:12px 14px!important;
    box-shadow:0 8px 20px rgba(15,23,42,.05)!important;
  }
  body.pro-v19 .stats-line span,
  body.pro-v19 .admin-mini-stats span,
  body.pro-v19 .agent-billing-mini-stats span{
    color:var(--v19-muted)!important;
    font-weight:900!important;
  }
  body.pro-v19 .stats-line b,
  body.pro-v19 .admin-mini-stats b,
  body.pro-v19 .agent-billing-mini-stats b{
    color:var(--v19-ink)!important;
    font-weight:900!important;
  }

  body.pro-v19 .schedule-head,
  body.pro-v19 .admin-top,
  body.pro-v19 .billing-head,
  body.pro-v19 .requirement-head,
  body.pro-v19 .agent-manage-head{
    display:flex!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:14px!important;
    margin:18px 0 14px!important;
  }
  body.pro-v19 .schedule-head h3,
  body.pro-v19 .admin-top h2,
  body.pro-v19 .billing-head h2,
  body.pro-v19 .agent-billing-clean-head h3{
    color:var(--v19-ink)!important;
    font-weight:900!important;
    letter-spacing:-.02em!important;
  }

  body.pro-v19 .timeline-list{
    display:grid!important;
    gap:12px!important;
  }
  body.pro-v19 .schedule-item{
    background:#fff!important;
    border:1px solid rgba(15,23,42,.10)!important;
    border-radius:22px!important;
    box-shadow:0 12px 30px rgba(15,23,42,.06)!important;
    overflow:hidden!important;
    transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease!important;
  }
  body.pro-v19 .schedule-item:hover{
    transform:translateY(-2px);
    box-shadow:0 18px 38px rgba(15,23,42,.08)!important;
    border-color:rgba(15,118,110,.22)!important;
  }
  body.pro-v19 .time-box{
    background:linear-gradient(180deg,#f8fafc,#eef2f7)!important;
    color:var(--v19-ink)!important;
    border-right:1px solid rgba(15,23,42,.08)!important;
    font-weight:900!important;
  }
  body.pro-v19 .time-box small{color:var(--v19-muted)!important;font-weight:800!important}
  body.pro-v19 .info-box{padding:16px!important}
  body.pro-v19 .slot-side{
    background:#f8fafc!important;
    border-left:1px solid rgba(15,23,42,.08)!important;
    color:var(--v19-ink)!important;
  }
  body.pro-v19 .slot-side b{color:var(--v19-primary-2)!important;font-weight:900!important}
  body.pro-v19 .slot-side span{color:var(--v19-muted)!important;font-weight:800!important}

  body.pro-v19 .pill,
  body.pro-v19 .status,
  body.pro-v19 .name-chip,
  body.pro-v19 .reserve-chip,
  body.pro-v19 .email-range-badge,
  body.pro-v19 .group-info-badge,
  body.pro-v19 .agent-badge,
  body.pro-v19 .bill-status{
    border-radius:999px!important;
    font-weight:900!important;
    border:1px solid rgba(15,23,42,.08)!important;
  }
  body.pro-v19 .pill.male,
  body.pro-v19 .Male,
  body.pro-v19 .male{--_pill:#2563eb}
  body.pro-v19 .pill.female,
  body.pro-v19 .Female,
  body.pro-v19 .female{--_pill:#db2777}
  body.pro-v19 .pill{background:rgba(37,99,235,.10)!important;color:#1d4ed8!important}
  body.pro-v19 .pill.female{background:rgba(219,39,119,.10)!important;color:#be185d!important}
  body.pro-v19 .status.Available,
  body.pro-v19 .status.qr-ok,
  body.pro-v19 .bill-status.paid{background:#dcfce7!important;color:#166534!important}
  body.pro-v19 .status.Limited{background:#fef3c7!important;color:#92400e!important}
  body.pro-v19 .status.FullBook,
  body.pro-v19 .bill-status.due{background:#fee2e2!important;color:#991b1b!important}
  body.pro-v19 .status.Closed,
  body.pro-v19 .status.qr-missing{background:#e2e8f0!important;color:#334155!important}

  body.pro-v19 .form-card,
  body.pro-v19 .billing-controls{
    padding:16px!important;
  }
  body.pro-v19 .form-grid{
    gap:13px!important;
  }
  body.pro-v19 .form-actions{
    padding-top:10px!important;
    gap:10px!important;
  }

  body.pro-v19 .table-wrap{
    border:1px solid rgba(15,23,42,.10)!important;
    border-radius:18px!important;
    overflow:auto!important;
    background:#fff!important;
    box-shadow:0 10px 25px rgba(15,23,42,.05)!important;
  }
  body.pro-v19 table{
    width:100%!important;
    border-collapse:separate!important;
    border-spacing:0!important;
  }
  body.pro-v19 thead th{
    position:sticky;
    top:0;
    z-index:2;
    background:#f8fafc!important;
    color:#475569!important;
    text-transform:uppercase;
    letter-spacing:.03em;
    font-size:11px!important;
    font-weight:900!important;
    border-bottom:1px solid rgba(15,23,42,.10)!important;
    padding:12px!important;
    white-space:nowrap!important;
  }
  body.pro-v19 tbody td{
    padding:12px!important;
    border-bottom:1px solid rgba(15,23,42,.07)!important;
    color:#1e293b!important;
    vertical-align:middle!important;
  }
  body.pro-v19 tbody tr:hover td{background:#f8fafc!important}
  body.pro-v19 tbody tr:last-child td{border-bottom:0!important}

  body.pro-v19 .agent-billing-clean-card{
    background:linear-gradient(180deg,#ffffff,#f8fafc)!important;
    border-radius:22px!important;
    padding:16px!important;
  }
  body.pro-v19 .agent-billing-clean-head h3{font-weight:900!important}
  body.pro-v19 .agent-billing-clean-actions .btn{min-width:110px}

  body.pro-v19 .billing-due-alert{
    background:#fff7ed!important;
    color:#9a3412!important;
    border:1px solid rgba(249,115,22,.18)!important;
    border-radius:16px!important;
  }
  body.pro-v19 .billing-ok{
    background:#ecfdf5!important;
    color:#166534!important;
    border:1px solid rgba(22,163,74,.18)!important;
    border-radius:16px!important;
  }

  body.pro-v19 .modal{
    background:rgba(15,23,42,.55)!important;
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
  }
  body.pro-v19 .login-box,
  body.pro-v19 .reserve-box,
  body.pro-v19 .qr-manage-box{
    border-radius:28px!important;
    background:#fff!important;
    border:1px solid rgba(255,255,255,.40)!important;
    box-shadow:0 28px 80px rgba(15,23,42,.24)!important;
  }
  body.pro-v19 .reserve-head{
    border-bottom:1px solid rgba(15,23,42,.08)!important;
    padding-bottom:12px!important;
    margin-bottom:14px!important;
  }

  body.pro-v19 .qr-email-row,
  body.pro-v19 .reserve-row,
  body.pro-v19 .whatsapp-row,
  body.pro-v19 .name-row,
  body.pro-v19 .agent-alarm-item{
    background:#fff!important;
    border:1px solid rgba(15,23,42,.10)!important;
    border-radius:16px!important;
    box-shadow:0 8px 18px rgba(15,23,42,.04)!important;
  }
  body.pro-v19 .qr-email-row.ready-highlight{
    border-color:rgba(22,163,74,.28)!important;
    background:#f0fdf4!important;
  }
  body.pro-v19 .qr-email-row.downloaded-red{
    border-color:rgba(220,38,38,.20)!important;
    background:#fff1f2!important;
  }

  body.pro-v19 .simple-map-grid{
    gap:7px!important;
  }
  body.pro-v19 .simple-map-cell{
    border-radius:50%!important;
    box-shadow:0 6px 14px rgba(15,23,42,.04)!important;
  }

  body.pro-v19 .empty,
  body.pro-v19 .center{
    color:var(--v19-muted)!important;
    font-weight:800!important;
  }

  body.pro-v19 .hidden{display:none!important}

  body.pro-v19::-webkit-scrollbar,
  body.pro-v19 .table-wrap::-webkit-scrollbar{height:10px;width:10px}
  body.pro-v19::-webkit-scrollbar-thumb,
  body.pro-v19 .table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}
  body.pro-v19::-webkit-scrollbar-track,
  body.pro-v19 .table-wrap::-webkit-scrollbar-track{background:#f1f5f9}

  @media(max-width:880px){
    body.pro-v19 .app{width:min(100% - 18px,1240px)!important;margin-top:12px!important}
    body.pro-v19 .app-header{padding:12px 12px!important}
    body.pro-v19 .brand h1{font-size:18px!important}
    body.pro-v19 .brand p{font-size:11px!important}
    body.pro-v19 .brand-icon{width:40px!important;height:40px!important;border-radius:14px!important}
    body.pro-v19 .header-actions{display:flex!important;gap:8px!important}
    body.pro-v19 .btn{padding:9px 11px!important;font-size:13px!important}
    body.pro-v19 .customer-shell,
    body.pro-v19 .admin-shell{border-radius:22px!important;padding:12px!important}
    body.pro-v19 .hero-panel{border-radius:22px!important}
    body.pro-v19 .control-panel{align-items:stretch!important}
    body.pro-v19 .control-panel > *,
    body.pro-v19 .date-control,
    body.pro-v19 .status-control{width:100%!important}
    body.pro-v19 .stats-line{display:grid!important;grid-template-columns:repeat(2,1fr)!important}
    body.pro-v19 .schedule-item{display:grid!important;grid-template-columns:1fr!important}
    body.pro-v19 .time-box,
    body.pro-v19 .slot-side{
      border:0!important;
      border-bottom:1px solid rgba(15,23,42,.08)!important;
      padding:12px!important;
    }
    body.pro-v19 .slot-side{border-top:1px solid rgba(15,23,42,.08)!important;border-bottom:0!important}
    body.pro-v19 .admin-top,
    body.pro-v19 .schedule-head,
    body.pro-v19 .agent-billing-clean-head{
      align-items:flex-start!important;
      flex-direction:column!important;
    }
    body.pro-v19 .admin-mini-stats,
    body.pro-v19 .agent-billing-mini-stats{
      width:100%!important;
      display:grid!important;
      grid-template-columns:repeat(2,1fr)!important;
    }
    body.pro-v19 .agent-billing-mini-stats{grid-template-columns:repeat(3,1fr)!important}
    body.pro-v19 .row-actions{display:flex!important;gap:6px!important;flex-wrap:wrap!important}
    body.pro-v19 .modal .login-box,
    body.pro-v19 .modal .reserve-box,
    body.pro-v19 .modal .qr-manage-box{
      width:calc(100% - 18px)!important;
      max-height:88vh!important;
      overflow:auto!important;
      border-radius:22px!important;
    }
  }

  @media(max-width:520px){
    body.pro-v19 .stats-line,
    body.pro-v19 .admin-mini-stats,
    body.pro-v19 .agent-billing-mini-stats{grid-template-columns:1fr!important}
    body.pro-v19 .tab-row{display:grid!important;grid-template-columns:1fr 1fr!important}
    body.pro-v19 .tab-row .tab:first-child{grid-column:1/-1}
    body.pro-v19 .brand p{display:none!important}
    body.pro-v19 .hero-panel h2{font-size:24px!important}
    body.pro-v19 .live-pill{align-self:flex-start!important}
  }
}
