: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%}}
