@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

*{box-sizing:border-box;margin:0;padding:0;}

:root{
  --g1:#B8881E;--g2:#D4A832;--g3:#8B6414;--g4:#F5E4B0;
  --d0:#EDE8DF;--d1:#FDFAF4;--d2:#FFFFFF;--d3:#F5F0E6;--d4:#DDD5C3;--d5:#C4B89A;
  --wh:#1C1814;--mu:#6B5F50;--mu2:#9E9080;
  --grn:#1A6E35;--grn-bg:#E6F4ED;--grn-bd:#A8D8B8;
  --red:#B83228;--red-bg:#FDEEED;--red-bd:#F0B8B2;
  --blu:#1A5490;--blu-bg:#EAF1FB;--blu-bd:#A8C8E8;
  --amb:#906010;--amb-bg:#FDF4E3;--amb-bd:#E8C890;
  --pur:#5A3A90;--pur-bg:#F0EAF8;--pur-bd:#C8A8E8;
  --shadow-xs:0 1px 2px rgba(0,0,0,.06);
  --shadow-sm:0 1px 4px rgba(0,0,0,.07),0 2px 8px rgba(0,0,0,.05);
  --shadow-md:0 4px 16px rgba(0,0,0,.1),0 2px 6px rgba(0,0,0,.06);
  --shadow-lg:0 12px 32px rgba(0,0,0,.14),0 4px 12px rgba(0,0,0,.08);
  --r:12px;--r-sm:8px;--r-xs:6px;
}

body{font-family:'DM Sans',sans-serif;background:var(--d0);min-height:100vh;color:var(--wh);-webkit-font-smoothing:antialiased;}

/* ── LAYOUT ─────────────────────────────────── */
.dash{display:flex;height:100vh;overflow:hidden;min-width:800px;}

/* ── SIDEBAR ─────────────────────────────────── */
.sb{
  width:210px;flex-shrink:0;
  background:var(--d1);
  border-right:1px solid var(--d4);
  display:flex;flex-direction:column;height:100%;
  box-shadow:2px 0 12px rgba(0,0,0,.04);
}

.sb-logo{padding:20px 16px 16px;border-bottom:1px solid var(--d4);}
.sb-ring{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--g1),var(--g2));
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:14px;font-weight:700;color:#fff;
  margin-bottom:10px;
  box-shadow:0 3px 10px rgba(184,136,30,.4);
}
.sb-name{font-family:'Playfair Display',serif;font-size:14px;font-weight:700;color:var(--g1);line-height:1.2;}
.sb-role{font-size:10px;color:var(--mu2);letter-spacing:1px;text-transform:uppercase;margin-top:3px;}

.sb-nav{padding:10px 0 6px;flex:1;overflow-y:auto;}
.sb-nav::-webkit-scrollbar{display:none;}

.sb-sec{
  font-size:10px;color:var(--mu2);letter-spacing:1.2px;text-transform:uppercase;
  padding:12px 18px 5px;font-weight:500;
}

.ni{
  display:flex;align-items:center;gap:10px;
  padding:10px 18px;
  cursor:pointer;border-left:3px solid transparent;
  text-decoration:none;transition:all .15s ease;
  margin:1px 0;
}
.ni:hover{background:var(--d3);}
.ni.on{
  background:linear-gradient(90deg,rgba(184,136,30,.13) 0%,rgba(184,136,30,.03) 100%);
  border-left-color:var(--g1);
}
.ni.on svg{stroke:var(--g1);}
.ni.on .nl{color:var(--g1);font-weight:600;}
.ni svg{width:16px;height:16px;stroke:var(--mu2);stroke-width:1.8;fill:none;flex-shrink:0;transition:stroke .15s;}
.nl{font-size:13px;color:var(--mu);font-weight:400;transition:color .15s;}
.ni:hover .nl{color:var(--wh);}
.ni:hover svg{stroke:var(--wh);}

.sb-foot{
  padding:14px 16px;border-top:1px solid var(--d4);
  display:flex;align-items:center;gap:10px;
  background:var(--d3);
}
.sb-av{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--g1),var(--g2));
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;flex-shrink:0;
  box-shadow:0 2px 6px rgba(184,136,30,.35);
}

/* ── MAIN ────────────────────────────────────── */
.main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;}

/* ── TOPBAR ──────────────────────────────────── */
.topbar{
  height:56px;flex-shrink:0;
  background:linear-gradient(95deg,var(--g3) 0%,var(--g1) 45%,var(--g2) 100%);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;
  box-shadow:0 3px 12px rgba(0,0,0,.18);
  position:relative;z-index:30;
}
.tb-title{font-size:17px;font-weight:600;color:#fff;letter-spacing:.2px;}
.tb-right{display:flex;align-items:center;gap:10px;}

.tb-btn{
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.28);
  border-radius:var(--r-sm);padding:8px 16px;
  font-size:13px;color:#fff;cursor:pointer;
  font-family:'DM Sans',sans-serif;
  display:flex;align-items:center;gap:6px;
  transition:background .15s;
}
.tb-btn svg{width:14px;height:14px;stroke:#fff;stroke-width:1.8;fill:none;}
.tb-btn:hover{background:rgba(255,255,255,.26);}

.tb-gold{
  background:#fff;border:none;border-radius:var(--r-sm);
  padding:8px 18px;font-size:13px;font-weight:600;color:var(--g1);
  cursor:pointer;font-family:'DM Sans',sans-serif;
  box-shadow:0 2px 10px rgba(0,0,0,.18);
  transition:all .15s;
}
.tb-gold:hover{background:#fffbf0;box-shadow:0 4px 14px rgba(0,0,0,.22);transform:translateY(-1px);}

.tb-notif{position:relative;}
.tb-dot{
  position:absolute;top:3px;right:3px;
  width:7px;height:7px;border-radius:50%;
  background:#FF4D4D;border:1.5px solid rgba(255,255,255,.9);
}

/* ── PAGE BODY ───────────────────────────────── */
.page-body{flex:1;overflow-y:auto;padding:22px 26px 28px;}
.page-body::-webkit-scrollbar{width:4px;}
.page-body::-webkit-scrollbar-thumb{background:var(--d4);border-radius:4px;}

/* ── KPI CARDS ───────────────────────────────── */
.kpi-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px;}
.kpi-row.c3{grid-template-columns:repeat(3,minmax(0,1fr));}

.kpi{
  background:var(--d2);border-radius:var(--r);
  padding:18px 20px;border:1px solid var(--d4);
  box-shadow:var(--shadow-sm);
  transition:box-shadow .2s,transform .2s;
  position:relative;overflow:hidden;
}
.kpi::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--g1),var(--g2));
  border-radius:var(--r) var(--r) 0 0;
}
.kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}

.kpi-l{font-size:11px;color:var(--mu);text-transform:uppercase;letter-spacing:.9px;font-weight:500;}
.kpi-v{font-size:32px;font-weight:600;color:var(--g1);margin:8px 0 5px;line-height:1;font-variant-numeric:tabular-nums;}
.kpi-d{font-size:12px;font-weight:400;}
.up{color:var(--grn);}
.dn{color:var(--red);}

/* ── GRID LAYOUTS ────────────────────────────── */
.g2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px;margin-bottom:14px;}
.g3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:14px;}

.card{
  background:var(--d2);border-radius:var(--r);
  padding:20px;border:1px solid var(--d4);
  margin-bottom:14px;box-shadow:var(--shadow-sm);
}
.card:last-child{margin-bottom:0;}

/* ── SECTION HEADER ──────────────────────────── */
.sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.sh-t{font-size:15px;font-weight:600;color:var(--wh);}

.sh-pills{display:flex;gap:6px;}
.pill{
  background:var(--d3);border:1px solid var(--d4);
  border-radius:20px;padding:5px 14px;
  font-size:11px;color:var(--mu);cursor:pointer;
  transition:all .15s;font-weight:500;
}
.pill.on{background:var(--g1);color:#fff;border-color:var(--g1);}
.pill:hover:not(.on){border-color:var(--g1);color:var(--g1);}

/* ── TABLE ───────────────────────────────────── */
.tbl{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed;}

.tbl thead{background:var(--d3);}
.tbl th{
  font-size:11px;color:var(--g1);font-weight:600;
  text-align:left;padding:11px 14px;
  border-bottom:1px solid var(--d4);
  text-transform:uppercase;letter-spacing:.7px;
}
.tbl td{
  color:var(--wh);padding:13px 14px;
  border-bottom:1px solid var(--d4);
  vertical-align:middle;
}
.tbl tr:last-child td{border-bottom:none;}
.tbl tbody tr{transition:background .12s;}
.tbl tbody tr:hover td{background:#FDF8EE;cursor:pointer;}

/* ── BUTTONS ─────────────────────────────────── */
.ta{
  background:none;border:1px solid var(--d4);
  border-radius:var(--r-xs);padding:6px 13px;
  font-size:12px;color:var(--mu);cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:all .15s;font-weight:500;
}
.ta:hover{border-color:var(--g1);color:var(--g1);background:rgba(184,136,30,.05);}

.tag{
  background:var(--g1);border:none;
  border-radius:var(--r-xs);padding:6px 13px;
  font-size:12px;font-weight:600;color:#fff;
  cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;
}
.tag:hover{background:var(--g2);}

/* ── BADGES ──────────────────────────────────── */
.b{
  display:inline-flex;align-items:center;
  padding:4px 11px;border-radius:20px;
  font-size:11px;font-weight:600;white-space:nowrap;letter-spacing:.2px;
}
.bg{background:var(--grn-bg);color:var(--grn);border:1px solid var(--grn-bd);}
.br{background:var(--red-bg);color:var(--red);border:1px solid var(--red-bd);}
.ba{background:var(--amb-bg);color:var(--amb);border:1px solid var(--amb-bd);}
.bb{background:var(--blu-bg);color:var(--blu);border:1px solid var(--blu-bd);}
.bp{background:var(--pur-bg);color:var(--pur);border:1px solid var(--pur-bd);}
.bgo{background:var(--amb-bg);color:var(--g1);border:1px solid var(--amb-bd);}

/* ── FILTER BAR ──────────────────────────────── */
.fbar{display:flex;gap:10px;margin-bottom:16px;align-items:center;}

.sbox{
  flex:1;background:var(--d2);
  border:1px solid var(--d4);border-radius:var(--r-sm);
  padding:9px 14px;display:flex;align-items:center;gap:8px;
  transition:border-color .15s,box-shadow .15s;
  box-shadow:var(--shadow-xs);
}
.sbox:focus-within{border-color:var(--g1);box-shadow:0 0 0 3px rgba(184,136,30,.12);}
.sbox svg{width:15px;height:15px;stroke:var(--mu2);stroke-width:1.8;fill:none;flex-shrink:0;}
.sbox input{
  background:none;border:none;color:var(--wh);
  font-size:13px;font-family:'DM Sans',sans-serif;
  width:100%;outline:none;
}
.sbox input::placeholder{color:var(--mu2);}

.fsel{
  background:var(--d2);border:1px solid var(--d4);
  border-radius:var(--r-sm);padding:9px 14px;
  font-size:13px;color:var(--mu);
  font-family:'DM Sans',sans-serif;outline:none;
  box-shadow:var(--shadow-xs);cursor:pointer;
  transition:border-color .15s;
}
.fsel:focus{border-color:var(--g1);}

/* ── CHART BARS ──────────────────────────────── */
.bwrap{display:flex;align-items:flex-end;gap:5px;height:80px;margin:8px 0 6px;}
.bar{flex:1;border-radius:3px 3px 0 0;background:var(--g1);min-width:8px;}
.blbs{display:flex;gap:5px;}
.blb{flex:1;font-size:9px;color:var(--mu2);text-align:center;overflow:hidden;white-space:nowrap;}

/* ── SPARKLINE ───────────────────────────────── */
.spark-wrap{height:70px;margin:6px 0 4px;position:relative;}

/* ── PROGRESS BAR ────────────────────────────── */
.pbar{height:7px;background:var(--d3);border-radius:4px;overflow:hidden;margin-top:6px;}
.pfill{height:100%;border-radius:4px;background:var(--g1);transition:width .5s ease;}

/* ── LEGEND ──────────────────────────────────── */
.lgd{display:flex;align-items:center;gap:8px;margin-bottom:9px;}
.ldot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.llab{font-size:13px;color:var(--wh);flex:1;}
.lpct{font-size:13px;color:var(--mu);min-width:36px;text-align:right;font-weight:500;}
.lbar{flex:2;height:5px;background:var(--d3);border-radius:3px;overflow:hidden;}
.lfill{height:100%;border-radius:3px;}

/* ── TIMELINE ────────────────────────────────── */
.tl-r{
  display:flex;gap:12px;align-items:flex-start;
  padding-bottom:14px;position:relative;
}
.tl-r:not(:last-child)::after{
  content:'';position:absolute;left:4px;top:12px;bottom:0;
  width:1px;background:var(--d4);
}
.tl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:3px;}

/* ── AVATAR ──────────────────────────────────── */
.av{
  width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;flex-shrink:0;
}

/* ── ACTIONS ROW ─────────────────────────────── */
.act-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.pay-link-btn{font-size:11px !important;padding:5px 10px !important;display:inline-flex;align-items:center;gap:4px;}

/* ── RAZORPAY PAYMENT MODAL ──────────────────── */
.rzp-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:80;opacity:0;pointer-events:none;transition:opacity .2s;}
.rzp-backdrop.open{opacity:1;pointer-events:auto;}

.rzp-modal{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-48%);
  background:var(--d2);border:1px solid var(--d4);border-radius:var(--r);
  width:92%;max-width:480px;z-index:81;
  box-shadow:0 20px 60px rgba(0,0,0,.18);
  opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;
}
.rzp-modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%);}

.rzp-modal-head{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:20px 24px 16px;border-bottom:1px solid var(--d4);
}
.rzp-modal-title{font-size:15px;font-weight:700;color:var(--wh);}
.rzp-modal-sub{font-size:13px;color:var(--g1);font-weight:600;margin-top:2px;}
.rzp-close{background:none;border:none;cursor:pointer;color:var(--mu2);padding:2px;display:flex;}
.rzp-close:hover{color:var(--wh);}

.rzp-modal-body{padding:24px;}

.rzp-amount-box{
  background:linear-gradient(135deg,var(--g1),var(--g2));
  color:#fff;border-radius:var(--r-sm);
  padding:16px 20px;font-size:24px;font-weight:700;
  text-align:center;margin-bottom:16px;
  letter-spacing:.02em;
}

.rzp-notify-row{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;}
.rzp-notify-item{
  flex:1;min-width:110px;
  display:flex;align-items:center;gap:6px;
  background:var(--d3);border:1px solid var(--d4);
  border-radius:var(--r-sm);padding:8px 10px;
  font-size:11px;color:var(--mu);font-weight:500;
}
.rzp-notify-item svg{stroke:var(--g1);flex-shrink:0;}

.rzp-btn-generate{
  width:100%;background:linear-gradient(135deg,var(--g1),var(--g2));
  border:none;border-radius:var(--r-sm);padding:13px;
  font-size:14px;font-weight:600;color:#fff;cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:opacity .15s;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.rzp-btn-generate:hover{opacity:.9;}
.rzp-btn-generate:disabled{opacity:.6;cursor:not-allowed;}
.rzp-btn-generate svg{stroke:#fff;}

.rzp-success-icon{
  width:56px;height:56px;background:var(--grn-bg);border:2px solid var(--grn-bd);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;
}
.rzp-success-icon svg{stroke:var(--grn);}

.rzp-link-box{
  display:flex;align-items:center;gap:10px;
  background:var(--d3);border:1px solid var(--d4);
  border-radius:var(--r-sm);padding:12px 14px;
  margin-bottom:14px;
}
.rzp-copy-btn{
  background:var(--g1);border:none;border-radius:var(--r-sm);
  padding:6px 12px;font-size:11px;font-weight:600;color:#fff;
  cursor:pointer;white-space:nowrap;font-family:'DM Sans',sans-serif;
  display:flex;align-items:center;gap:5px;flex-shrink:0;
}
.rzp-link-actions{display:flex;gap:10px;}
.rzp-btn-outline,.rzp-btn-check{
  flex:1;padding:10px;border-radius:var(--r-sm);
  font-size:13px;font-weight:500;cursor:pointer;
  font-family:'DM Sans',sans-serif;
  display:flex;align-items:center;justify-content:center;gap:6px;
  transition:all .15s;
}
.rzp-btn-outline{background:none;border:1px solid var(--d4);color:var(--mu);text-decoration:none;}
.rzp-btn-outline:hover{border-color:var(--g1);color:var(--g1);}
.rzp-btn-check{background:var(--d3);border:1px solid var(--d4);color:var(--mu);}
.rzp-btn-check:hover{border-color:var(--g1);color:var(--g1);}
.rzp-btn-check svg,.rzp-btn-outline svg{stroke:currentColor;}

.rzp-status-result{
  margin-top:14px;padding:12px 14px;border-radius:var(--r-sm);
  font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;
}
.rzp-status-result.ok{background:var(--grn-bg);color:var(--grn);border:1px solid var(--grn-bd);}
.rzp-status-result.ok svg{stroke:var(--grn);}
.rzp-status-result.pending{background:var(--d3);color:var(--mu);border:1px solid var(--d4);}
.rzp-status-result.pending svg{stroke:var(--mu);}

@media(max-width:600px){
  .rzp-modal{width:96%;max-height:90vh;overflow-y:auto;}
  .rzp-notify-row{flex-direction:column;}
  .rzp-link-actions{flex-direction:column;}
}

/* ── SETTINGS PAGE ──────────────────────────── */
.set-wrap{max-width:860px;}
.set-section-title{font-size:11px;font-weight:700;color:var(--mu2);text-transform:uppercase;letter-spacing:.06em;margin:20px 0 12px;}
.set-req{color:var(--red);margin-left:2px;}

/* Provider logo badges */
.set-provider-logo{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.rzp-logo{background:linear-gradient(135deg,#072654,#1a59a0);}
.brevo-logo{background:linear-gradient(135deg,#0070f3,#00c6ff);}
.wa-logo{background:linear-gradient(135deg,#25d366,#128c7e);}
.sr-logo{background:linear-gradient(135deg,#e8521a,#f5943c);}

/* Info hint box */
.set-info-box{display:flex;align-items:flex-start;gap:8px;background:var(--d3);border:1px solid var(--d4);border-radius:var(--r-sm);padding:12px 14px;font-size:12px;color:var(--mu);line-height:1.6;}
.set-info-box strong{color:var(--wh);}
.set-info-box code{background:var(--d4);padding:1px 5px;border-radius:3px;font-size:11px;font-family:monospace;}

/* Carrier tags */
.set-carriers{display:flex;flex-wrap:wrap;gap:8px;}
.set-carrier{background:var(--d3);border:1px solid var(--d4);border-radius:20px;padding:4px 12px;font-size:11px;color:var(--mu);font-weight:500;}

@keyframes spin{to{transform:rotate(360deg);}}

.set-tabs{display:flex;gap:4px;margin-bottom:22px;background:var(--d2);border:1px solid var(--d4);border-radius:var(--r);padding:5px;box-shadow:var(--shadow-xs);}
.set-tab{flex:1;padding:10px 14px;border-radius:var(--r-sm);font-size:13px;font-weight:500;color:var(--mu);cursor:pointer;border:none;background:none;font-family:'DM Sans',sans-serif;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px;text-align:center;}
.set-tab:hover{background:var(--d3);color:var(--wh);}
.set-tab.active{background:var(--g1);color:#fff;box-shadow:0 2px 8px rgba(184,136,30,.35);}
.set-tab svg{width:16px;height:16px;stroke:currentColor;stroke-width:1.8;fill:none;flex-shrink:0;}

.set-panel{display:none;}
.set-panel.active{display:block;}

.set-card{background:var(--d2);border:1px solid var(--d4);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:16px;}
.set-card:last-child{margin-bottom:0;}

.set-card-head{padding:20px 24px;border-bottom:1px solid var(--d4);display:flex;align-items:center;justify-content:space-between;gap:16px;}
.set-card-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.set-card-icon svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;}
.set-card-title{font-size:15px;font-weight:700;color:var(--wh);}
.set-card-sub{font-size:12px;color:var(--mu);margin-top:2px;}

.set-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600;}
.set-badge.configured{background:var(--grn-bg);color:var(--grn);border:1px solid var(--grn-bd);}
.set-badge.configured::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--grn);flex-shrink:0;}
.set-badge.empty{background:var(--d3);color:var(--mu2);border:1px solid var(--d4);}
.set-badge.empty::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--mu2);flex-shrink:0;}

.set-body{padding:24px;}
.set-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.set-grid.c1{grid-template-columns:1fr;}
.set-field{display:flex;flex-direction:column;gap:5px;}
.set-field.full{grid-column:1/-1;}
.set-label{font-size:12px;font-weight:600;color:var(--mu);}
.set-hint{font-size:11px;color:var(--mu2);margin-top:2px;}

.set-input-wrap{position:relative;display:flex;}
.set-input{width:100%;background:var(--d3);border:1px solid var(--d4);border-radius:var(--r-sm);padding:10px 14px;font-size:13px;color:var(--wh);font-family:'DM Sans',sans-serif;outline:none;transition:border-color .15s,background .15s;}
.set-input:focus{border-color:var(--g1);background:#fff;box-shadow:0 0 0 3px rgba(184,136,30,.1);}
.set-input.has-eye{padding-right:42px;}
.set-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--mu2);padding:2px;display:flex;align-items:center;}
.set-eye:hover{color:var(--g1);}
.set-eye svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8;}

.mode-toggle{display:flex;gap:0;border:1px solid var(--d4);border-radius:var(--r-sm);overflow:hidden;width:fit-content;}
.mode-btn{padding:9px 20px;font-size:13px;font-weight:500;border:none;background:var(--d3);color:var(--mu);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;}
.mode-btn.active{background:var(--g1);color:#fff;}

.set-footer{padding:16px 24px;border-top:1px solid var(--d4);background:var(--d3);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.set-test-result{font-size:12px;font-weight:500;display:flex;align-items:center;gap:6px;}
.set-test-result.ok{color:var(--grn);}
.set-test-result.fail{color:var(--red);}
.set-test-result svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5;}

.set-actions{display:flex;gap:10px;align-items:center;}
.set-save-btn{background:var(--g1);border:none;border-radius:var(--r-sm);padding:10px 22px;font-size:13px;font-weight:600;color:#fff;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;}
.set-save-btn:hover{background:var(--g2);}
.set-save-btn:disabled{opacity:.6;cursor:not-allowed;}
.set-test-btn{background:none;border:1px solid var(--d4);border-radius:var(--r-sm);padding:10px 18px;font-size:13px;font-weight:500;color:var(--mu);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;display:flex;align-items:center;gap:6px;}
.set-test-btn:hover{border-color:var(--g1);color:var(--g1);}
.set-test-btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;}

/* Webhook URL box */
.set-code{background:var(--d3);border:1px solid var(--d4);border-radius:var(--r-sm);padding:10px 14px;font-size:12px;font-family:monospace;color:var(--mu);word-break:break-all;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.set-copy{background:none;border:none;cursor:pointer;color:var(--mu2);font-size:11px;white-space:nowrap;font-family:'DM Sans',sans-serif;transition:color .15s;}
.set-copy:hover{color:var(--g1);}

@media(max-width:480px){
  .set-tabs{flex-wrap:wrap;}
  .set-tab{flex:1 1 calc(50% - 4px);font-size:12px;padding:9px 8px;gap:5px;}
  .set-grid{grid-template-columns:1fr;}
  .set-field.full{grid-column:1;}
  .set-footer{flex-direction:column;align-items:stretch;}
  .set-actions{flex-direction:column;}
  .set-save-btn,.set-test-btn{width:100%;justify-content:center;}
  .set-provider-logo{width:36px;height:36px;}
}

/* ── BULK UPLOAD MODAL ───────────────────────── */
.upload-drop{
  border:2px dashed var(--d4);border-radius:var(--r-sm);
  padding:28px 20px;text-align:center;
  cursor:pointer;position:relative;
  transition:border-color .15s,background .15s;
  background:var(--d3);
}
.upload-drop:hover,.upload-drop.dragover{
  border-color:var(--g1);background:rgba(184,136,30,.06);
}
.upload-drop input[type="file"]{
  position:absolute;inset:0;opacity:0;
  cursor:pointer;width:100%;height:100%;
}
.upload-drop svg{stroke:var(--mu2);fill:none;margin-bottom:10px;display:block;margin-left:auto;margin-right:auto;}
.upload-drop.has-file svg{stroke:var(--g1);}
.upload-fname{font-size:13px;color:var(--mu2);line-height:1.4;}
.upload-fname.selected{color:var(--wh);font-weight:500;}

.upload-result{
  border-radius:var(--r-sm);padding:14px 16px;
  font-size:13px;margin-bottom:4px;
}
.upload-stat{display:flex;align-items:center;gap:10px;padding:6px 0;}
.upload-stat-num{font-size:22px;font-weight:700;min-width:36px;line-height:1;}
.upload-stat-lbl{font-size:12px;color:var(--mu);}
.upload-err-list{
  max-height:120px;overflow-y:auto;
  background:var(--red-bg);border:1px solid var(--red-bd);
  border-radius:var(--r-xs);padding:10px 12px;
  font-size:11px;color:var(--red);line-height:1.7;
  margin-top:8px;
}

/* ══════════════════════════════════════════════
   MOBILE — HAMBURGER & SIDEBAR OVERLAY
══════════════════════════════════════════════ */
.tb-ham{
  display:none;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.28);
  border-radius:var(--r-sm);
  padding:9px 10px;
  cursor:pointer;flex-shrink:0;
  align-items:center;justify-content:center;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  user-select:none;-webkit-user-select:none;
}
.tb-ham svg{width:18px;height:18px;stroke:#fff;stroke-width:2;fill:none;}
.tb-ham:hover,.tb-ham:active{background:rgba(255,255,255,.32);}

/* Sidebar close button (mobile) */
.sb-close{
  display:none;
  background:var(--d3);border:1px solid var(--d4);
  border-radius:50%;width:28px;height:28px;
  align-items:center;justify-content:center;
  cursor:pointer;color:var(--mu);
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  flex-shrink:0;
}

.sb-overlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  z-index:49;
  transition:opacity .28s ease;
}
.sb-overlay.open{display:block;}

/* ══════════════════════════════════════════════
   BREAKPOINT — TABLET  ≤ 1024px
══════════════════════════════════════════════ */
@media(max-width:1024px){
  .sb{width:188px;}
  .page-body{padding:18px 18px 24px;}
  .kpi-v{font-size:28px;}
}

/* ══════════════════════════════════════════════
   BREAKPOINT — MOBILE  ≤ 480px
   (phones are 360-430px; desktop windows are always wider)
══════════════════════════════════════════════ */
@media(max-width:480px){

  /* Sidebar becomes slide-in drawer */
  .sb{
    position:fixed;left:0;top:0;bottom:0;
    z-index:50;width:240px;
    transform:translateX(-100%);
    transition:transform .28s cubic-bezier(.4,0,.2,1);
    box-shadow:none;
  }
  .sb.open{
    transform:translateX(0);
    box-shadow:8px 0 32px rgba(0,0,0,.22);
  }

  /* Hamburger + sidebar close button visible on mobile */
  .tb-ham{display:flex;}
  .sb-close{display:flex;}

  /* Hard-prevent any horizontal overflow on mobile */
  html,body{overflow-x:hidden;max-width:100vw;}

  /* Reset desktop min-width — sidebar is position:fixed on mobile so .main fills full viewport */
  .dash{min-width:0 !important;width:100%;overflow:hidden;}
  .main{width:100% !important;max-width:100vw;min-width:0;overflow-x:hidden;}
  .page-body{overflow-x:hidden;}

  /* Search boxes: full width, no fixed width from inline styles */
  .sbox{width:100% !important;min-width:0 !important;box-sizing:border-box;}

  /* Topbar — compact, hide Add Retailer (too crowded at 375px) */
  .topbar{height:52px;padding:0 12px;gap:6px;}
  .tb-title{font-size:15px;}
  .tb-btn-lbl{display:none;}
  .tb-gold{display:none;}

  /* Page body */
  .page-body{padding:14px 12px 28px;}

  /* KPI grid → 2 cols (important to beat inline grid-template-columns styles) */
  .kpi-row{grid-template-columns:repeat(2,1fr) !important;gap:10px;margin-bottom:14px;}
  .kpi-row.c3{grid-template-columns:repeat(2,1fr) !important;}
  .kpi{padding:14px 14px;}
  .kpi-v{font-size:24px;}
  .kpi-l{font-size:10px;}
  .kpi-d{font-size:11px;}

  /* 2-col / 3-col grids → single column */
  .g2{grid-template-columns:1fr;gap:12px;}
  .g3{grid-template-columns:1fr;}

  /* Cards */
  .card{padding:14px;margin-bottom:12px;}

  /* Tables: scroll horizontally inside card, never overflow the page */
  .card{overflow-x:auto !important;}
  .tbl{min-width:480px;max-width:none;table-layout:auto;}
  .tbl th,.tbl td{padding:9px 10px;font-size:12px;white-space:nowrap;}
  .tbl th{font-size:10px;}

  /* Section headers */
  .sh-t{font-size:14px;}
  .sh{margin-bottom:12px;}

  /* Filter bar → CSS grid: sbox spans full width, selects side-by-side below */
  .fbar{display:grid !important;grid-template-columns:1fr 1fr;gap:8px;align-items:center;}
  .fbar>.sbox{grid-column:1/-1;}  /* search box spans both columns */
  .fbar>.fsel,.fbar>select{width:100%;}

  /* Buttons */
  .tag,.ta{padding:5px 11px;font-size:11px;}

  /* Badges */
  .b{font-size:10px;padding:3px 9px;}

  /* Avatar */
  .av{width:26px;height:26px;font-size:10px;}

  /* Progress bar */
  .pbar{height:6px;}

  /* Slide-over panels */
  .ov-panel{width:94vw;max-width:380px;}

  /* Modals */
  .mod{padding:18px;width:calc(100vw - 24px);}
  .mod-t{font-size:15px;}
  .mod-s{font-size:12px;}
}

/* ══════════════════════════════════════════════
   BREAKPOINT — SMALL PHONE  ≤ 360px
══════════════════════════════════════════════ */
@media(max-width:360px){
  .topbar{height:50px;}
  .tb-title{font-size:13px;}

  /* Single-col KPIs on very small phones */
  .kpi-row{grid-template-columns:1fr;}
  .kpi-v{font-size:22px;}

  /* Narrower sidebar */
  .sb{width:220px;}

  /* Full-width modal */
  .mod{width:calc(100vw - 24px);padding:18px;}

  /* Full-width slide-over */
  .ov-panel{width:100%;max-width:100%;}

  /* Stack action buttons */
  .act-row{flex-wrap:wrap;}

  /* Pill spacing */
  .pill{padding:4px 10px;font-size:10px;}

  /* Table slightly smaller */
  .tbl{min-width:480px;}
  .tbl th,.tbl td{padding:9px 10px;}
}

/* ── DETAIL SLIDE-OVER ───────────────────────── */
.ov-bg{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.45);z-index:40;
  align-items:flex-start;justify-content:flex-end;
  backdrop-filter:blur(3px);
}
.ov-bg.open{display:flex;}

.ov-panel{
  width:340px;height:100%;background:var(--d2);
  border-left:1px solid var(--d4);
  overflow-y:auto;display:flex;flex-direction:column;
  box-shadow:-10px 0 30px rgba(0,0,0,.14);
}
.ov-panel::-webkit-scrollbar{width:3px;}
.ov-panel::-webkit-scrollbar-thumb{background:var(--d4);}

.ov-head{padding:20px;border-bottom:1px solid var(--d4);display:flex;align-items:center;gap:12px;}
.ov-x{
  width:28px;height:28px;border-radius:50%;
  background:var(--d3);border:1px solid var(--d4);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:background .15s;
}
.ov-x:hover{background:var(--d4);}
.ov-x svg{width:13px;height:13px;stroke:var(--mu);stroke-width:2;fill:none;}

.ov-body{padding:20px;flex:1;}
.or{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid var(--d4);}
.or:last-child{border-bottom:none;}
.ol{font-size:12px;color:var(--mu);font-weight:500;}
.ov{font-size:13px;color:var(--wh);font-weight:500;}

/* ── MODAL ───────────────────────────────────── */
.mod-bg{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.55);z-index:60;
  align-items:center;justify-content:center;
  backdrop-filter:blur(4px);
}
.mod-bg.open{display:flex;}

.mod{
  background:var(--d2);border-radius:16px;
  border:1px solid var(--d4);
  padding:28px;width:380px;max-width:90vw;
  box-shadow:var(--shadow-lg);
}
.mod-t{font-size:17px;font-weight:700;color:var(--wh);margin-bottom:5px;}
.mod-s{font-size:13px;color:var(--mu);margin-bottom:20px;}

.mf{margin-bottom:14px;}
.ml{font-size:12px;color:var(--mu);margin-bottom:5px;font-weight:500;}
.mi{
  width:100%;background:var(--d3);
  border:1px solid var(--d4);border-radius:var(--r-sm);
  padding:10px 13px;font-size:13px;color:var(--wh);
  font-family:'DM Sans',sans-serif;outline:none;
  transition:border-color .15s,background .15s;
}
.mi:focus{border-color:var(--g1);background:#fff;box-shadow:0 0 0 3px rgba(184,136,30,.12);}

.mrow{display:flex;gap:10px;margin-top:20px;}
.mc{
  flex:1;background:none;border:1px solid var(--d4);
  border-radius:var(--r-sm);padding:11px;
  font-size:13px;color:var(--mu);cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:all .15s;font-weight:500;
}
.mc:hover{border-color:var(--mu);color:var(--wh);}
.mk{
  flex:2;background:var(--g1);border:none;
  border-radius:var(--r-sm);padding:11px;
  font-size:13px;font-weight:700;color:#fff;
  cursor:pointer;font-family:'DM Sans',sans-serif;
  transition:all .15s;
}
.mk:hover{background:var(--g2);}
