/* ============================================================
   AtithiBot Admin — redesign stylesheet
   Look-and-feel only. Pair with index.html + app.js.
   ============================================================ */

:root{
  /* Accent (WhatsApp-tied green). Swap these 4 to re-theme everything. */
  --accent:#17915b; --accent-h:#0f7a4a; --accent-soft:#e4f3ea; --accent-on:#fff;

  /* Warm neutral surfaces */
  --bg:#eceae4; --workspace:#f4f2ec; --surface:#fff; --surface-2:#faf9f5;
  --line:#e9e6dd; --line-2:#e3e0d7; --line-soft:#f4f1e9;

  /* Text */
  --text:#1a1c1a; --text-2:#6a6f66; --text-3:#8a8f86; --text-4:#9a9f95;

  /* Sidebar (dark) */
  --side-bg:#181a19; --side-fg:#f3f2ef; --side-muted:#8b918c; --side-active:rgba(255,255,255,.09);

  /* Semantic */
  --info:#2f6fed; --info-bg:#eef4fb;
  --warn:#b4520f; --warn-bg:#fdeede;
  --danger:#c0391a; --danger-bg:#fde7e2;
  --pending:#b4520f; --pending-bg:#fdf6ec;

  --r-sm:8px; --r-md:10px; --r-lg:14px;
  --shadow-card:0 1px 2px rgba(0,0,0,.04);
  --shadow-pop:-8px 0 30px rgba(0,0,0,.14);
  --mono:'IBM Plex Mono',ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'IBM Plex Sans',system-ui,sans-serif;-webkit-font-smoothing:antialiased;color:var(--text);background:var(--bg)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
a{color:inherit}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#c9c6bd;border-radius:8px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:#b3afa3;background-clip:content-box}

/* ---- Icons: inline SVG, colored via currentColor ---- */
.icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0}
.icon svg{width:100%;height:100%;display:block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.icon.sm{width:15px;height:15px}
.icon.xs{width:13px;height:13px}
.icon.lg{width:22px;height:22px}

/* ============================ SHELL ============================ */
.app{display:flex;height:100vh;width:100%;overflow:hidden}
body[data-auth="login"] .app{display:none}

.sidebar{width:248px;flex-shrink:0;background:var(--side-bg);display:flex;flex-direction:column}
.brand{padding:22px 20px 18px;display:flex;align-items:center;gap:11px}
.brand-mark{width:34px;height:34px;border-radius:9px;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px rgba(0,0,0,.25);color:var(--accent-on)}
.brand-name{font-weight:700;font-size:15px;letter-spacing:-.2px;color:var(--side-fg);line-height:1.1}
.brand-sub{font-size:10.5px;letter-spacing:.7px;text-transform:uppercase;color:var(--side-muted);font-weight:600;margin-top:1px}

.nav{flex:1;overflow-y:auto;padding:6px 12px;display:flex;flex-direction:column;gap:2px}
.nav-group{font-size:10px;letter-spacing:.9px;text-transform:uppercase;color:#7f857f;font-weight:600;padding:14px 10px 6px}
.nav-item{display:flex;align-items:center;gap:11px;width:100%;padding:9px 11px;border-radius:9px;font-size:13.5px;font-weight:500;text-align:left;color:var(--side-muted);transition:background .12s}
.nav-item:hover{background:rgba(255,255,255,.06)}
.nav-item.active{background:var(--side-active);color:var(--side-fg)}
.nav-item .label{flex:1}
.nav-badge{font-size:11px;font-weight:600;border-radius:20px;padding:1px 7px;min-width:20px;text-align:center;background:var(--accent);color:var(--accent-on)}
.nav-badge.warn{background:var(--pending-bg);color:var(--warn)}

.side-foot{padding:12px;border-top:1px solid rgba(255,255,255,.07)}
.side-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px}
.side-user:hover{background:rgba(255,255,255,.06)}
.side-user .av{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#e9a23b,#d9772f);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:13px;flex-shrink:0}
.side-user .name{font-size:12.5px;font-weight:600;color:var(--side-fg);line-height:1.2}
.side-user .org{font-size:11px;color:var(--side-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.main{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--workspace)}
.topbar{height:60px;flex-shrink:0;background:var(--surface-2);border-bottom:1px solid var(--line-2);display:flex;align-items:center;padding:0 26px;gap:18px}
.page-title{font-size:16px;font-weight:600;letter-spacing:-.3px;line-height:1.15}
.page-sub{font-size:12px;color:var(--text-3);margin-top:1px}
.topbar-search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line-2);border-radius:9px;padding:7px 11px;width:280px;color:var(--text-4)}
.topbar-search input{border:none;outline:none;font-size:13px;width:100%;background:transparent;color:var(--text)}

.content{height:calc(100vh - 60px);overflow:hidden;position:relative}
.screen{height:100%;overflow-y:auto;padding:22px 26px}
.screen.flush{padding:0;display:flex}
.screen[hidden]{display:none}

/* ============================ CARDS / TABLES ============================ */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-card);overflow:hidden;flex-shrink:0}
.card + .card{margin-top:18px}
.card-head{padding:15px 20px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;gap:10px}
.card-head h3{font-size:14px;font-weight:600;flex:1}
.card-head .sub{font-size:12px;color:var(--text-3);margin-top:2px}
.count{font-size:11.5px;color:var(--text-4);background:var(--line-soft);border-radius:20px;padding:2px 9px;font-weight:500}

.tbl{width:100%;border-collapse:collapse}
.tbl th{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-4);font-weight:600;padding:11px 20px;text-align:left;background:var(--surface-2)}
.tbl td{padding:13px 20px;font-size:13px;border-top:1px solid var(--line-soft);vertical-align:middle}
.tbl tbody tr:hover td{background:var(--surface-2)}
.tbl tr.clickable{cursor:pointer}
.tbl .num{text-align:right;font-family:var(--mono)}
th.num{text-align:right}
.muted{color:var(--text-2)}
.mono{font-family:var(--mono)}
.strong{font-weight:600}
.sub2{font-size:11px;color:var(--text-4);margin-top:2px}

/* stat cards */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px}
.stat .k{font-size:12px;color:var(--text-3);font-weight:500}
.stat .v{font-size:26px;font-weight:600;font-family:var(--mono);margin-top:4px}
.stat .v.sm{font-size:24px}

/* pills */
.pill{display:inline-block;font-size:11.5px;font-weight:600;border-radius:6px;padding:3px 10px;white-space:nowrap}
.pill.neutral{background:var(--line-soft);color:#5a5f56}
.pill.ok{background:var(--accent-soft);color:var(--accent-h)}
.pill.info{background:var(--info-bg);color:var(--info)}
.pill.warn{background:var(--warn-bg);color:var(--warn)}
.pill.pending{background:var(--pending-bg);color:var(--pending)}
.pill.danger{background:var(--danger-bg);color:var(--danger)}
.pill.done{background:#eceae4;color:var(--text-2)}
.cutoff-pill{font-size:12px;font-weight:600;background:var(--line-soft);color:#5a5f56;border-radius:6px;padding:3px 9px;white-space:nowrap}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:7px;border-radius:9px;padding:9px 15px;font-size:13px;font-weight:600;transition:background .12s,filter .12s}
.btn-primary{background:var(--accent);color:var(--accent-on)}
.btn-primary:hover{background:var(--accent-h)}
.btn-soft{background:var(--accent-soft);color:var(--accent-h);border-radius:8px;padding:7px 12px;font-size:12.5px}
.btn-soft:hover{filter:brightness(.97)}
.btn-ghost{background:var(--surface);border:1px solid var(--line-2);color:#42463f}
.btn-ghost:hover{background:#f1efe8}
.btn-sm{padding:8px 13px;font-size:12.5px;border-radius:8px}
.btn-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--line-2);border-radius:8px;color:var(--text-2)}
.btn-icon:hover{background:#f1efe8}

/* forms */
.filter-bar{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;margin-bottom:18px}
.field{display:flex;flex-direction:column;gap:5px}
.field.grow{flex:1;min-width:160px}
.field label{font-size:11px;font-weight:600;color:var(--text-3)}
.field input,.field select,.field textarea{border:1px solid var(--line-2);border-radius:8px;padding:9px 11px;font-size:13px;background:var(--surface);color:var(--text)}
.tbl input,.tbl select{width:100%;border:1px solid var(--line-2);border-radius:8px;padding:9px 11px;font-size:13px;background:var(--surface);color:var(--text);font-family:inherit}
.field textarea{resize:vertical;line-height:1.5}
.field .search-input{display:flex;align-items:center;gap:8px;border:1px solid var(--line-2);border-radius:8px;padding:8px 11px;background:var(--surface);color:var(--text-4)}
.field .search-input input{border:none;outline:none;font-size:13px;width:100%;background:transparent;color:var(--text)}
.field.mono input{font-family:var(--mono)}
.spacer{flex:1}
.form-grid{padding:20px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.form-grid.two{grid-template-columns:1fr 1fr}
.span2{grid-column:span 2}

/* toggle */
.toggle{width:40px;height:23px;border-radius:20px;background:var(--accent);position:relative;flex-shrink:0}
.toggle .knob{position:absolute;top:2.5px;right:2.5px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.2)}
.toggle.off{background:#c9c6bd}
.toggle.off .knob{right:auto;left:2.5px}
.toggle-row{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.toggle-row .t{font-size:13px;font-weight:600}
.toggle-row .d{font-size:11.5px;color:var(--text-3);margin-top:2px}

/* ============================ CONVERSATIONS ============================ */
.convo-list{width:340px;flex-shrink:0;border-right:1px solid var(--line-2);display:flex;flex-direction:column;background:var(--surface-2)}
.convo-search{padding:14px 16px;border-bottom:1px solid var(--line);display:flex;gap:8px}
.convo-scroll{flex:1;overflow-y:auto}
.convo{display:flex;gap:11px;width:100%;padding:13px 16px;text-align:left;border-bottom:1px solid #f0ede5;position:relative;background:transparent}
.convo:hover{background:#f2f0e8}
.convo.active{background:var(--surface)}
.convo.active::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2.5px;background:var(--accent)}
.avatar{width:40px;height:40px;border-radius:11px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}
.avatar.sm{width:34px;height:34px;border-radius:9px;font-size:12px}
.convo .top{display:flex;align-items:center;gap:6px}
.convo .nm{font-weight:600;font-size:13.5px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.convo .tm{font-size:11px;color:var(--text-4);flex-shrink:0;font-family:var(--mono)}
.convo .last{font-size:12.5px;color:#7a7f76;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.convo .ph{font-size:10.5px;color:#a7aca2;margin-top:3px;font-family:var(--mono)}
.unread{font-size:11px;font-weight:600;background:var(--accent);color:#fff;border-radius:20px;padding:0 6px;min-width:18px;text-align:center;flex-shrink:0}

.chat{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--workspace)}
.chat-head{padding:13px 20px;border-bottom:1px solid var(--line-2);display:flex;align-items:center;gap:12px;background:var(--surface-2)}
.chat-body{flex:1;overflow-y:auto;padding:22px 26px;display:flex;flex-direction:column;gap:12px}
.day{text-align:center;font-size:11px;color:#a7aca2;font-weight:500;margin:4px 0}
.msg{max-width:64%;padding:9px 13px;font-size:13.5px;line-height:1.5;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.msg .t{font-size:10px;margin-top:4px;text-align:right;opacity:.6;font-family:var(--mono)}
.msg.in{align-self:flex-start;background:var(--surface);color:var(--text);border-radius:13px 13px 13px 4px}
.msg.out{align-self:flex-end;background:var(--accent);color:var(--accent-on);border-radius:13px 13px 4px 13px}
.chat-foot{padding:14px 20px;border-top:1px solid var(--line-2);background:var(--surface-2);display:flex;align-items:flex-end;gap:10px}
.reply{flex:1;background:var(--surface);border:1px solid var(--line-2);border-radius:12px;padding:10px 14px;font-size:13.5px;color:var(--text-4);min-height:42px}
.send{width:42px;height:42px;flex-shrink:0;border-radius:11px;background:var(--accent);color:var(--accent-on);display:flex;align-items:center;justify-content:center}
.send:hover{background:var(--accent-h)}

/* ============================ ACCORDION (catalog) ============================ */
.acc-row{border-top:1px solid var(--line-soft)}
.acc-head{display:flex;align-items:center;gap:14px;width:100%;text-align:left;padding:14px 20px;background:var(--surface)}
.acc-head:hover{background:var(--surface-2)}
.acc-head.open{background:var(--surface-2)}
.acc-head .chev{color:var(--text-4);transition:transform .18s ease}
.acc-head.open .chev{transform:rotate(90deg)}
.acc-head .nm{font-size:14px;font-weight:600;flex:1}
.acc-head .grp{font-size:12px;color:var(--text-3)}
.acc-head .cnt{font-size:12px;font-family:var(--mono);color:var(--text-4);min-width:66px;text-align:right}
.acc-body{background:var(--surface-2);border-top:1px solid var(--line-soft)}
.acc-item{display:flex;align-items:center;gap:12px;padding:11px 20px 11px 54px;border-top:1px solid #efece4;cursor:pointer}
.acc-item:hover{background:#f2f0e8}
.acc-item .dot{width:5px;height:5px;border-radius:50%;background:#c9c6bd;flex-shrink:0}
.acc-item .nm{font-size:13px;flex:1}
.acc-item .pr{font-size:13px;font-family:var(--mono);color:var(--text-2)}
.acc-add{padding:10px 20px 13px 54px;border-top:1px solid #efece4}

/* ============================ OVERLAY / DRAWER ============================ */
.overlay{position:fixed;inset:0;z-index:50;display:none}
.overlay.open{display:block}
.overlay .scrim{position:absolute;inset:0;background:rgba(24,26,25,.32)}
.drawer{position:absolute;top:0;right:0;bottom:0;background:var(--surface-2);box-shadow:var(--shadow-pop);display:flex;flex-direction:column;max-width:94vw}
.drawer.w420{width:420px}.drawer.w520{width:520px}.drawer.w560{width:560px}.drawer.w720{width:720px}
.modal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(420px,calc(100vw - 32px));background:var(--surface-2);border:1px solid var(--line-2);border-radius:12px;box-shadow:0 18px 48px rgba(0,0,0,.22);overflow:hidden}
.drawer-head{padding:16px 24px;border-bottom:1px solid var(--line-2);display:flex;align-items:center;gap:12px;background:var(--surface-2);flex-shrink:0}
.drawer .card{overflow:visible}
.drawer-head .eyebrow{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--text-4);font-weight:600}
.drawer-head .h{font-size:17px;font-weight:600;margin-top:1px}
.drawer-head .h.mono{font-family:var(--mono)}
.drawer-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:16px}
.drawer-foot{padding:14px 24px;border-top:1px solid var(--line-2);background:var(--surface-2);display:flex;gap:10px;flex-shrink:0}
.close-btn{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-2)}
.close-btn:hover{background:#efece4}
.sub-head{padding:13px 20px;border-bottom:1px solid var(--line-soft)}
.sub-head h3{font-size:13px;font-weight:600;color:var(--text-2)}

/* summary rows */
.sum{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;flex-shrink:0}
.sum .eyebrow{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--text-4);font-weight:600;margin-bottom:14px}
.sum-row{display:flex;justify-content:space-between;margin-bottom:11px;font-size:13px;color:var(--text-2)}
.sum-row .v{font-family:var(--mono);color:var(--text)}
.sum-total{display:flex;justify-content:space-between;padding:11px 0;border-top:1px solid #eeebe2;border-bottom:1px solid #eeebe2;margin-bottom:11px}
.sum-total .l{font-size:14px;font-weight:600}
.sum-total .v{font-size:16px;font-weight:600;font-family:var(--mono)}
.balance{display:flex;justify-content:space-between;align-items:center;background:var(--pending-bg);border:1px solid #f3e2c8;border-radius:var(--r-md);padding:11px 13px}
.balance .l{font-size:13px;font-weight:600;color:#8a5a12}
.balance .v{font-size:16px;font-weight:700;font-family:var(--mono);color:#8a5a12}

/* multi-select */
.ms{position:relative}
.ms-field{border:1px solid var(--line-2);border-radius:8px;padding:6px 11px;background:var(--surface);display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-height:40px;cursor:pointer}
.ms-placeholder{font-size:13px;color:var(--text-4)}
.chip{display:inline-flex;align-items:center;gap:4px;background:var(--accent-soft);color:var(--accent-h);border-radius:6px;padding:3px 4px 3px 9px;font-size:12px;font-weight:600}
.chip .x{display:inline-flex;padding:2px;border-radius:4px;cursor:pointer}
.chip .x:hover{background:rgba(0,0,0,.08)}
.ms-menu{position:absolute;top:100%;left:0;right:0;margin-top:6px;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-md);box-shadow:0 10px 28px rgba(0,0,0,.14);z-index:6;overflow-y:auto;max-height:260px;padding:5px;display:none}
.ms-menu.open{display:block}
.ms-opt{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border-radius:7px;cursor:pointer}
.ms-opt:hover{background:var(--surface-2)}
.ms-box{width:17px;height:17px;border-radius:5px;border:1.5px solid #c9c6bd;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ms-opt.on .ms-box{background:var(--accent);border-color:var(--accent)}
.ms-box{color:#fff}
.ms-opt .ms-box .icon{width:11px;height:11px;opacity:0}
.ms-opt.on .ms-box .icon{opacity:1}

/* catalog sync banner */
.sync-banner{display:flex;align-items:center;gap:16px;background:linear-gradient(100deg,var(--accent-h),var(--accent));border-radius:var(--r-lg);padding:20px 22px;margin-bottom:18px;color:#fff}
.sync-banner .ic{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sync-banner .status{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.16);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600}
.dot{width:7px;height:7px;border-radius:50%;background:#7ee6a8}

.two-col{display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:start;max-width:1200px}
.right{display:flex;justify-content:flex-end;margin-bottom:18px}
