/* ═══════════════════════════════════════════════════
   AgriPeople – CRM + HRMS for Agri/Pesticide Industry
   By Green Vision Technical Services, Nashik
   Sora + DM Serif Display · Terracotta + Olive
   ═══════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Sora:wght@300;400;500;600;700;800&display=swap');

:root{
  /* Brand */
  --terra:#c2410c;--terra-light:#fff7ed;--terra-dark:#7c2d12;
  --olive:#4d7c0f;--olive-light:#ecfccb;--olive-dark:#365314;
  --gold:#b45309;--gold-light:#fef3c7;
  /* Neutral */
  --warm-50:#faf8f6;--warm-100:#f3f0ec;--warm-200:#e8e2db;--warm-300:#d4ccc2;
  --warm-400:#a39e96;--warm-500:#78716c;--warm-600:#57534e;--warm-700:#44403c;
  --warm-800:#292524;--warm-900:#1c1917;--warm-950:#0c0a09;
  /* Accents */
  --blue:#2563eb;--purple:#7c3aed;--cyan:#0891b2;--red:#dc2626;--green:#16a34a;
  /* Layout */
  --bg:#f7f5f2;--card:#fff;--sb-w:255px;--radius:12px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Sora',sans-serif;background:var(--bg);color:var(--warm-800);overflow-x:hidden}

/* ── SIDEBAR ───────────────────── */

/* ═══ SETTINGS TABS ═══ */
.tabs{display:flex;gap:2px;flex-wrap:wrap;border-bottom:2px solid var(--warm-200);margin-bottom:1rem;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tabs::-webkit-scrollbar{display:none}
.tab{padding:.45rem .9rem;font-size:.7rem;font-weight:600;color:var(--warm-500);cursor:pointer;border-radius:8px 8px 0 0;border:1px solid transparent;border-bottom:none;white-space:nowrap;transition:all .15s;user-select:none}
.tab:hover{color:var(--warm-800);background:var(--warm-50)}
.tab.active{color:var(--terra);background:var(--card);border-color:var(--warm-200);border-bottom:2px solid var(--card);margin-bottom:-2px;font-weight:700}
.tab-content{display:none}
.tab-content.active{display:block}

.sb{position:fixed;top:0;left:0;bottom:0;width:var(--sb-w);background:var(--warm-950);z-index:600;display:flex;flex-direction:column;overflow-y:auto}
.sb::-webkit-scrollbar{width:3px}
.sb::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}
.sb-brand{padding:1.1rem 1.2rem;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.06)}
.sb-brand .ico{width:34px;height:34px;background:linear-gradient(135deg,var(--terra),var(--gold));border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.8rem}
.sb-brand h6{color:#fff;font-weight:800;font-size:.82rem;margin:0;letter-spacing:-.3px}
.sb-brand small{display:block;color:rgba(255,255,255,.3);font-size:.5rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}
.sb-sec{padding:.7rem 1.2rem .2rem;font-size:.48rem;text-transform:uppercase;letter-spacing:1.8px;color:rgba(255,255,255,.18);font-weight:700}
.sb a{display:flex;align-items:center;gap:10px;padding:.48rem 1.1rem;color:rgba(255,255,255,.42);font-size:.76rem;font-weight:500;text-decoration:none;transition:all .15s;margin:1px 8px;border-radius:8px}
.sb a:hover{color:#fff;background:rgba(255,255,255,.05)}
.sb a.act{color:#fff;background:var(--terra);font-weight:600}
.sb a i{width:17px;text-align:center;font-size:.8rem}
.sb-foot{margin-top:auto;padding:.8rem 1.2rem;border-top:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:10px}
.sb-foot .av{width:30px;height:30px;border-radius:50%;background:var(--terra);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700}
.sb-foot .nm{color:#fff;font-size:.7rem;font-weight:600}
.sb-foot .rl{color:rgba(255,255,255,.28);font-size:.52rem;text-transform:uppercase;letter-spacing:.5px}
.sb-foot .lo{margin-left:auto;color:rgba(255,255,255,.22);text-decoration:none;font-size:.8rem;transition:color .2s}
.sb-foot .lo:hover{color:#fff}

/* ── MAIN ──────────────────────── */
.mn{margin-left:var(--sb-w);min-height:100vh}

/* ── TOPBAR ────────────────────── */
.tb{padding:.75rem 1.6rem;display:flex;align-items:center;justify-content:space-between;background:var(--card);border-bottom:1px solid var(--warm-200)}
.tb h4{font-size:1rem;font-weight:700;color:var(--warm-900);display:flex;align-items:center;gap:8px}
.tb .dt{font-size:.68rem;color:var(--warm-400)}
.tb-r{display:flex;align-items:center;gap:.7rem}
.tb-ico{width:33px;height:33px;border-radius:9px;background:var(--warm-50);border:1px solid var(--warm-200);display:flex;align-items:center;justify-content:center;color:var(--warm-500);font-size:.8rem;cursor:pointer;transition:all .15s;position:relative}
.tb-ico:hover{background:var(--terra-light);color:var(--terra);border-color:var(--terra-light)}
.tb-ico .dot{position:absolute;top:4px;right:4px;width:6px;height:6px;background:var(--red);border-radius:50%;border:1.5px solid var(--card)}

/* ── CONTENT ───────────────────── */
.ct{padding:1.2rem 1.6rem}

/* ── SEARCH ────────────────────── */
.srch{position:relative}
.srch input{background:var(--warm-50);border:1px solid var(--warm-200);border-radius:9px;padding:.4rem .8rem .4rem 1.8rem;font-size:.73rem;width:200px;outline:none;font-family:'Sora';transition:all .2s}
.srch input:focus{border-color:var(--terra);box-shadow:0 0 0 3px rgba(194,65,12,.07)}
.srch i{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--warm-400);font-size:.72rem}

/* ── CARD ──────────────────────── */
.cd{background:var(--card);border-radius:var(--radius);border:1px solid var(--warm-200);overflow:hidden}
.cd-h{padding:.75rem 1.1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--warm-100)}
.cd-h h6{font-size:.78rem;font-weight:700;color:var(--warm-800);display:flex;align-items:center;gap:6px;margin:0}
.cd-h .bsm{font-size:.52rem;background:var(--terra-light);color:var(--terra-dark);padding:.14rem .4rem;border-radius:5px;font-weight:700}
.cd-h a,.cd-h button{font-size:.62rem;color:var(--terra);text-decoration:none;font-weight:600;background:none;border:none;cursor:pointer}

/* ── TABLE ─────────────────────── */
.tbl{width:100%;font-size:.72rem;border-collapse:collapse}
.tbl th{text-align:left;padding:.55rem 1.1rem;font-size:.52rem;text-transform:uppercase;letter-spacing:.7px;color:var(--warm-400);font-weight:600;background:var(--warm-50);border-bottom:1px solid var(--warm-200)}
.tbl td{padding:.48rem 1.1rem;border-bottom:1px solid var(--warm-100);color:var(--warm-600);vertical-align:middle}
.tbl tr:hover td{background:var(--warm-50)}
.nm{font-weight:600;color:var(--warm-800)}
.mt{color:var(--warm-400);font-size:.6rem}

/* ── BADGES ────────────────────── */
.bg{font-size:.52rem;padding:.16rem .42rem;border-radius:5px;font-weight:700;display:inline-flex;align-items:center;gap:3px}
.bg-g{background:var(--olive-light);color:var(--olive-dark)}
.bg-r{background:#fee2e2;color:#991b1b}
.bg-a{background:var(--gold-light);color:var(--gold)}
.bg-b{background:#dbeafe;color:#1e40af}
.bg-p{background:#f3e8ff;color:#6b21a8}
.bg-t{background:var(--terra-light);color:var(--terra-dark)}
.bg-c{background:#cffafe;color:#155e75}

/* ── STAT CARDS ────────────────── */
.st{background:var(--card);border-radius:var(--radius);padding:.95rem 1rem;border:1px solid var(--warm-200);position:relative;overflow:hidden;transition:all .2s}
.st:hover{transform:translateY(-2px);box-shadow:0 6px 25px rgba(0,0,0,.04)}
.st .st-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}
.st .st-label{font-size:.58rem;color:var(--warm-400);font-weight:600;text-transform:uppercase;letter-spacing:.7px}
.st .st-ico{width:33px;height:33px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.85rem}
.st .st-val{font-size:1.4rem;font-weight:800;color:var(--warm-900);line-height:1;margin-bottom:.15rem}
.st .st-sub{font-size:.6rem;color:var(--warm-400)}
.st .st-sub .up{color:var(--olive);font-weight:700}
.st .st-sub .dn{color:var(--red);font-weight:700}

/* ── FORMS ─────────────────────── */
.form-control,.form-select{font-size:.76rem;border-radius:8px;border:1px solid var(--warm-200);padding:.42rem .7rem;font-family:'Sora';outline:none;transition:all .2s;width:100%;background:var(--card)}
.form-control:focus,.form-select:focus{border-color:var(--terra);box-shadow:0 0 0 3px rgba(194,65,12,.07)}
.form-label{font-size:.65rem;font-weight:600;color:var(--warm-600);margin-bottom:3px;display:block}
.btn-brand{background:linear-gradient(135deg,var(--terra),var(--gold));color:#fff;border:none;border-radius:8px;font-weight:700;font-size:.76rem;padding:.48rem 1.1rem;cursor:pointer;font-family:'Sora';transition:all .2s}
.btn-brand:hover{opacity:.9;transform:translateY(-1px)}
.btn-sm{font-size:.68rem;padding:.32rem .7rem}
.btn-outline{background:none;border:1px solid var(--warm-200);color:var(--warm-600);border-radius:8px;font-size:.68rem;padding:.32rem .7rem;cursor:pointer;font-family:'Sora';transition:all .15s}
.btn-outline:hover{border-color:var(--terra);color:var(--terra)}
.btn-olive{background:var(--olive);color:#fff;border:none;border-radius:8px;font-weight:700;font-size:.76rem;padding:.48rem 1.1rem;cursor:pointer;font-family:'Sora'}

/* ── GRID ──────────────────────── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:1rem}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.8rem;margin-bottom:1rem}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-bottom:1rem}
.g5{display:grid;grid-template-columns:repeat(5,1fr);gap:.8rem;margin-bottom:1rem}
.g23{display:grid;grid-template-columns:2fr 1fr;gap:.8rem;margin-bottom:1rem}
.g32{display:grid;grid-template-columns:1fr 2fr;gap:.8rem;margin-bottom:1rem}

/* ── MODAL ─────────────────────── */

/* ── FEED ──────────────────────── */
.feed-i{display:flex;gap:9px;padding:.5rem 1.1rem;transition:background .15s}
.feed-i:hover{background:var(--warm-50)}
.feed-i .fi{width:27px;height:27px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.68rem;flex-shrink:0}
.feed-i .ft{font-size:.68rem;color:var(--warm-600);line-height:1.45}
.feed-i .ft strong{color:var(--warm-800)}
.feed-i .tm{font-size:.52rem;color:var(--warm-400);margin-top:1px}

/* ── PROGRESS BAR ──────────────── */
.prog-bar{height:5px;background:var(--warm-100);border-radius:3px;overflow:hidden}
.prog-bar .fill{height:100%;border-radius:3px}

/* ── AVATAR ROW ────────────────── */
.av-sm{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700;color:#fff}

/* ── EMPTY STATE ───────────────── */
.empty{text-align:center;padding:2rem 1rem;color:var(--warm-400)}
.empty i{font-size:1.8rem;margin-bottom:.5rem;display:block}
.empty p{font-size:.75rem}

/* ── TOAST ─────────────────────── */
#toast-container{position:fixed;top:1rem;right:1rem;z-index:9999}
.toast{padding:.5rem .9rem;border-radius:8px;font-size:.72rem;font-weight:600;color:#fff;margin-bottom:.4rem;display:flex;align-items:center;gap:5px;animation:fadeIn .25s ease;min-width:180px}
.toast-ok{background:var(--olive)}
.toast-err{background:var(--red)}
.toast-warn{background:var(--gold)}

/* ── LOGIN ─────────────────────── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--warm-950) 0%,var(--terra-dark) 50%,var(--warm-950) 100%)}
.login-card{max-width:380px;width:100%;background:var(--card);border-radius:14px;padding:2.2rem;box-shadow:0 20px 70px rgba(0,0,0,.25)}

/* ── PIPELINE ──────────────────── */
.pipeline{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.pipe-col{background:var(--warm-50);border:1px solid var(--warm-200);border-radius:10px;min-height:200px}
.pipe-head{padding:.6rem .8rem;font-size:.65rem;font-weight:700;color:var(--warm-700);border-bottom:1px solid var(--warm-200);display:flex;justify-content:space-between;align-items:center}
.pipe-head .cnt{font-size:.55rem;background:var(--warm-200);padding:.1rem .4rem;border-radius:4px;font-weight:700}
.pipe-body{padding:.5rem}
.pipe-card{background:var(--card);border:1px solid var(--warm-200);border-radius:8px;padding:.6rem .7rem;margin-bottom:.4rem;transition:all .15s;cursor:grab}
.pipe-card:hover{box-shadow:0 3px 12px rgba(0,0,0,.06);border-color:var(--terra)}
.pipe-card .pc-name{font-size:.7rem;font-weight:600;color:var(--warm-800);margin-bottom:2px}
.pipe-card .pc-sub{font-size:.55rem;color:var(--warm-400)}
.pipe-card .pc-val{font-size:.72rem;font-weight:800;color:var(--terra);margin-top:4px}

/* ── ANIMATION ─────────────────── */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.an{animation:fadeIn .4s ease-out both}



/* ═══ PROFESSIONAL MODALS ═══ */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(10,9,8,.55);z-index:550;align-items:center;justify-content:center;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.modal-bg.show{display:flex;align-items:center;justify-content:center;animation:modalFadeIn .2s ease}
@keyframes modalFadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}

.modal-box{
  background:var(--card);border-radius:16px;width:92%;max-width:560px;max-height:88vh;
  overflow-y:auto;box-shadow:0 25px 80px rgba(0,0,0,.25),0 0 0 1px rgba(0,0,0,.05);
  animation:slideUp .25s ease;
}
/* Wide modal for leads, employees, orders etc */
.modal-box.wide{max-width:720px}
/* Extra wide for complex forms */
.modal-box.xwide{max-width:900px}

.modal-box::-webkit-scrollbar{width:4px}
.modal-box::-webkit-scrollbar-thumb{background:var(--warm-200);border-radius:4px}

/* Section headers inside modals */
.sec-h{font-size:.6rem;font-weight:800;color:var(--olive);text-transform:uppercase;letter-spacing:1px;padding:.5rem 0 .3rem;border-bottom:2px solid var(--olive-light);margin-bottom:.5rem;margin-top:.4rem}
.sec-div{font-size:.6rem;font-weight:800;color:var(--terra);text-transform:uppercase;letter-spacing:1px;padding:.5rem 0 .3rem;border-bottom:2px solid var(--terra-light);margin-bottom:.5rem;grid-column:1/-1}

/* Header */
.modal-h,.modal-head{
  padding:.9rem 1.2rem;border-bottom:1px solid var(--warm-100);
  display:flex;justify-content:space-between;align-items:center;
  background:linear-gradient(135deg,var(--warm-50),transparent);
  border-radius:16px 16px 0 0;position:sticky;top:0;z-index:1;
}
.modal-h h6,.modal-head h6{font-size:.85rem;font-weight:700;margin:0;display:flex;align-items:center;gap:8px}
.modal-h h6 i,.modal-head h6 i{color:var(--terra)}
.modal-x,.modal-head .close{
  background:var(--warm-100);border:none;width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;cursor:pointer;color:var(--warm-500);transition:all .15s;
}
.modal-x:hover,.modal-head .close:hover{background:var(--warm-200);color:var(--warm-800)}

/* Body */
.modal-body{padding:1.1rem 1.2rem}

/* Footer */
.modal-foot{
  padding:.8rem 1.2rem;border-top:1px solid var(--warm-100);
  display:flex;justify-content:flex-end;gap:.5rem;
  background:var(--warm-50);border-radius:0 0 16px 16px;
  position:sticky;bottom:0;
}

/* Form labels inside modals */
.fl{font-size:.62rem;font-weight:600;color:var(--warm-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px;display:block}

/* Form grid helper */
.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem .8rem;font-size:.72rem}
.modal-grid.cols-1{grid-template-columns:1fr}
.modal-grid.cols-3{grid-template-columns:1fr 1fr 1fr}
.modal-grid .span-2{grid-column:span 2}

/* Section divider inside modals */
.modal-section{font-size:.6rem;font-weight:700;color:var(--terra);text-transform:uppercase;letter-spacing:1px;padding:.6rem 0 .3rem;border-bottom:1px solid var(--warm-100);margin-bottom:.5rem;grid-column:span 2}

/* Confirmation modals */
.modal-confirm{text-align:center;padding:2rem 1.5rem}
.modal-confirm i{font-size:2.5rem;margin-bottom:.8rem;display:block}
.modal-confirm h5{font-size:1rem;font-weight:700;margin-bottom:.3rem}
.modal-confirm p{color:var(--warm-500);font-size:.75rem;margin-bottom:1.2rem}

/* ═══ MOBILE RESPONSIVE — COMPLETE FIX ═══ */

/* Sidebar overlay — separate div, receives clicks */
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:350;-webkit-tap-highlight-color:transparent}
.sb-overlay.show{display:block}

@media(max-width:768px){
  /* Sidebar: slide from left, full height, proper width */
  .sb{
    transform:translateX(-100%);
    z-index:400;
    position:fixed;
    top:0;left:0;bottom:0;
    width:280px;
    max-width:85vw;
    transition:transform .25s ease;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .sb.show{transform:translateX(0);box-shadow:0 0 50px rgba(0,0,0,.5)}
  
  /* Remove the broken ::after overlay */
  .sb.show::after{display:none!important}
  
  /* Main content: no left margin on mobile */
  .mn{margin-left:0!important;padding-bottom:60px}
  
  /* Sticky top bar */
  .tb{
    position:sticky;top:0;z-index:200;
    backdrop-filter:blur(12px);
    background:rgba(250,248,246,.95);
    border-bottom:1px solid var(--warm-200);
    padding:.5rem .8rem!important;
  }
  .tb h4{font-size:.82rem!important}
  .tb-r{gap:6px!important}
  
  /* Hamburger button always visible */
  .tb-ico{
    display:flex!important;
    width:38px;height:38px;
    align-items:center;justify-content:center;
    border-radius:8px;background:var(--warm-100);
    cursor:pointer;font-size:1.1rem;
    -webkit-tap-highlight-color:transparent;
  }
  
  /* Content padding */
  .ct{padding:.6rem!important}
  
  /* Stats grid: 2 columns on mobile */
  .g2,.g3,.g4,.g5,.g23,.g32{
    grid-template-columns:1fr 1fr!important;
    gap:.4rem!important;
  }
  /* Single column for layout grids */
  .g23,.g32{grid-template-columns:1fr!important}
  .st{padding:.5rem!important}
  .st-val{font-size:1rem!important}
  .st-label{font-size:.52rem!important}
  .st-ico{width:28px!important;height:28px!important}
  .st-ico i{font-size:.7rem!important}
  
  /* Tables: horizontal scroll */
  table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  
  /* Modals: slide from bottom on mobile */
  .modal-bg.show{align-items:flex-end!important}
  .modal-box{
    width:100%!important;max-width:none!important;
    margin:0!important;
    border-radius:16px 16px 0 0!important;
    max-height:92vh;overflow-y:auto;
  }
  
  /* Form inputs: bigger for touch (prevents iOS zoom) */
  .fi,input,select,textarea{font-size:16px!important;padding:.55rem!important;min-height:44px}
  button,.btn-terra,.btn-olive,.btn-brand,.btn-outline{min-height:44px;font-size:.72rem!important}
  .btn-xs,.btn-sm{min-height:36px!important}
  
  /* Feed items: more tappable */
  .feed-i{padding:.7rem 0!important;gap:8px!important}
  .feed-i .fi{width:36px!important;height:36px!important;flex-shrink:0}
  
  /* Tab bar: horizontal scroll on mobile */
  .tab-bar{
    overflow-x:auto!important;
    flex-wrap:nowrap!important;
    -webkit-overflow-scrolling:touch;
    padding-bottom:4px;
    gap:3px!important;
    scrollbar-width:none;
  }
  .tab-bar::-webkit-scrollbar{display:none}
  .tab-btn{white-space:nowrap;flex-shrink:0;padding:.35rem .6rem!important;font-size:.62rem!important}
  
  /* Cards */
  .cd{border-radius:10px!important}
  .cd-h{font-size:.75rem!important;padding:.6rem!important}
  
  /* Pipeline kanban: horizontal scroll */
  .pipeline{overflow-x:auto;flex-wrap:nowrap!important;-webkit-overflow-scrolling:touch}
  .pipe-col{min-width:220px!important;flex-shrink:0}
  
  /* Chat/WhatsApp inbox: stack on mobile */
  #chatList{width:100%!important;max-height:200px;border-right:none!important;border-bottom:1px solid var(--warm-100)}
  
  /* Hide less important things */
  .hide-mobile,.dt{display:none!important}
}

/* Small phones: topbar buttons collapse to icon-only — text hidden, icon stays visible */
@media(max-width:380px){
  .sb{width:100vw!important;max-width:100vw!important}
  [style*="grid-template-columns"]{grid-template-columns:1fr!important}
  .tab-btn{font-size:.55rem!important;padding:.25rem .4rem!important}
  /* Collapse ALL topbar buttons to icon-only — never font-size:0 which hides icons too */
  .tb-r .btn-terra span,.tb-r .btn-olive span,.tb-r .btn-brand span,.tb-r .btn-outline span{display:none}
  .tb-r .btn-terra,.tb-r .btn-olive,.tb-r .btn-brand,.tb-r .btn-outline{
    font-size:.7rem!important;padding:.3rem .45rem!important;min-width:32px;min-height:32px;
    white-space:nowrap;overflow:hidden;max-width:34px;
  }
}
/* Between 380-600px: show icon + short label, hide long text via span.hide-sm */
@media(max-width:600px){
  .tb-r{flex-wrap:nowrap;overflow-x:auto;gap:4px!important;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .tb-r::-webkit-scrollbar{display:none}
  .hide-sm{display:none!important}
}

/* Tablet: collapsed sidebar with icons only */
@media(min-width:769px) and (max-width:1024px){
  :root{--sb-w:60px}
  .sb a span,.sb .sb-sec,.sb-foot .nm,.sb-foot .rl,.sb-brand small,.sb-brand h6{display:none}
  .sb a{justify-content:center;padding:.6rem}
  .sb a i{font-size:1.1rem;width:auto}
  .sb-brand{justify-content:center;padding:.8rem}
  .mn{margin-left:60px}
  .tb-ico{display:none!important}
}

/* Desktop: hide hamburger */
@media(min-width:1025px){
  .tb-ico{display:none!important}
}

/* Touch devices: remove hover effects */
@media(hover:none){
  .cd:hover,.pipe-card:hover,.feed-i:hover{transform:none!important;box-shadow:none!important}
  .cd:active,.feed-i:active{transform:scale(.98);transition:transform .1s}
}

/* Safe area for notched phones */
@supports(padding-top:env(safe-area-inset-top)){
  .tb{padding-top:calc(.5rem + env(safe-area-inset-top))!important}
  .sb{padding-top:env(safe-area-inset-top)}
  .mn{padding-bottom:calc(60px + env(safe-area-inset-bottom))}
}

/* ═══ USER DROPDOWN ═══ */
.user-dd{position:relative;display:inline-block}
.user-dd-btn{display:flex;align-items:center;gap:6px;cursor:pointer;padding:3px 8px;border-radius:8px;transition:all .15s}
.user-dd-btn:hover{background:var(--warm-100)}
.user-dd-btn .av{width:28px;height:28px;border-radius:50%;background:var(--terra);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700}
.user-dd-btn .nm{font-size:.68rem;font-weight:600;color:var(--warm-700);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-dd-btn .rl{font-size:.48rem;color:var(--warm-400)}
.user-dd-btn i.bi-chevron-down{font-size:.5rem;color:var(--warm-400);transition:transform .2s}
.user-dd.open .bi-chevron-down{transform:rotate(180deg)}
.user-dd-menu{display:none;position:absolute;right:0;top:calc(100% + 6px);background:var(--card);border:1px solid var(--warm-200);border-radius:10px;box-shadow:0 10px 40px rgba(0,0,0,.12);min-width:200px;z-index:500;overflow:hidden;padding:6px 0}
.user-dd.open .user-dd-menu{display:block}
.user-dd-menu .dd-head{padding:.6rem .8rem;border-bottom:1px solid var(--warm-100);font-size:.65rem}
.user-dd-menu .dd-head strong{display:block;font-size:.72rem;color:var(--warm-800)}
.user-dd-menu .dd-head small{color:var(--warm-400);font-size:.55rem}
.user-dd-menu a{display:flex;align-items:center;gap:8px;padding:.45rem .8rem;font-size:.68rem;color:var(--warm-700);text-decoration:none;transition:background .1s}
.user-dd-menu a:hover{background:var(--warm-50)}
.user-dd-menu a i{width:16px;text-align:center;color:var(--warm-400)}
.user-dd-menu .dd-div{height:1px;background:var(--warm-100);margin:4px 0}
.user-dd-menu a.logout{color:var(--red)}
.user-dd-menu a.logout i{color:var(--red)}

@media(max-width:768px){
  .user-dd-btn .nm,.user-dd-btn .rl{display:none}
  .user-dd-menu{right:-20px;min-width:180px}
}

/* ═══ DROPDOWN FIX — match JS class names ═══ */
.dd-info{display:flex;flex-direction:column;align-items:flex-end}
.dd-name{font-size:.68rem;font-weight:600;color:var(--warm-700);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dd-role{font-size:.48rem;color:var(--warm-400);text-transform:capitalize}
.dd-av{width:28px;height:28px;border-radius:50%;background:var(--terra);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700}
.dd-arrow{font-size:.5rem;color:var(--warm-400);transition:transform .2s}
.user-dd.open .dd-arrow{transform:rotate(180deg)}
.dd-header{padding:.7rem .8rem;border-bottom:1px solid var(--warm-100)}
.dd-h-name{font-size:.75rem;font-weight:700;color:var(--warm-800)}
.dd-h-email{font-size:.55rem;color:var(--warm-400)}
.dd-menu-item{display:flex;align-items:center;gap:8px;padding:.5rem .8rem;font-size:.68rem;color:var(--warm-700);text-decoration:none;transition:background .1s;border:none;background:none;width:100%;cursor:pointer;font-family:'Sora'}
.dd-menu-item:hover{background:var(--warm-50)}
.dd-menu-item i{width:16px;text-align:center;color:var(--warm-400);font-size:.75rem}
.dd-menu-item.danger{color:var(--red)}
.dd-menu-item.danger i{color:var(--red)}
.dd-sep{height:1px;background:var(--warm-100);margin:4px 0}
@media(max-width:768px){.dd-info{display:none}}

/* ═══ PROFESSIONAL FORM OVERRIDES v3.0 ═══ */
input.fi:focus, select.fi:focus, textarea.fi:focus,
input:focus, select:focus, textarea:focus {
    border-color: var(--olive) !important;
    box-shadow: 0 0 0 3px rgba(77, 124, 15, 0.12) !important;
}
select.fi, select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%2378716c' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 32px;
    cursor: pointer;
    -webkit-appearance: none;
    /* AUDIT38: ensure dropdowns are wide enough to read product names */
    min-width: 100%;
    width: 100%;
}
select.fi option {
    /* AUDIT38: bigger option rows in the dropdown panel */
    padding: 8px 12px;
    font-size: 13px;
    min-height: 32px;
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.form-grid .full-width,.form-grid-3 .full-width{grid-column:1/-1}
.form-section-title{font-size:12px;font-weight:800;color:var(--olive);padding-bottom:6px;margin-bottom:12px;border-bottom:2px solid #dcfce7;display:flex;align-items:center;gap:6px}
.btn-olive{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;font-size:13px;font-weight:700;border:none;border-radius:10px;cursor:pointer;background:linear-gradient(135deg,var(--olive),#3f6b0b);color:#fff;box-shadow:0 2px 8px rgba(77,124,15,.25);transition:all .2s}
.btn-olive:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(77,124,15,.35)}
.btn-terra{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;font-size:13px;font-weight:700;border:none;border-radius:10px;cursor:pointer;background:linear-gradient(135deg,var(--terra),#a93b0a);color:#fff;box-shadow:0 2px 8px rgba(194,65,12,.25);transition:all .2s}
.btn-terra:hover{transform:translateY(-1px)}
.btn-outline{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:600;border:1.5px solid #d6d3d1;border-radius:10px;cursor:pointer;background:#fff;color:#57534e;transition:all .2s}
.btn-outline:hover{border-color:var(--olive);color:var(--olive);background:#f0fdf4}
.toast{position:fixed;bottom:24px;right:24px;background:#1c1917;color:#fff;padding:12px 20px;border-radius:12px;font-size:13px;font-weight:600;z-index:99999;box-shadow:0 8px 24px rgba(0,0,0,.2);animation:toastIn .3s}
.toast.err{background:#dc2626}.toast.success{background:#15803d}
@keyframes toastIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.call-btn{width:32px;height:32px;border-radius:8px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s}
.call-btn-phone{background:#dbeafe;color:#2563eb}
.call-btn-phone:hover{background:#2563eb;color:#fff;transform:scale(1.1)}
.call-btn-wa{background:#dcfce7;color:#16a34a}
.call-btn-wa:hover{background:#25D366;color:#fff;transform:scale(1.1)}
.empty-state{text-align:center;padding:40px 20px;color:#a8a29e}
.empty-state i{font-size:48px;display:block;margin-bottom:12px;opacity:.5}
.spinner{width:24px;height:24px;border:3px solid #e7e5e4;border-top-color:var(--olive);border-radius:50%;animation:spin .6s linear infinite;margin:20px auto}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:768px){.form-grid,.form-grid-3{grid-template-columns:1fr}}

/* ── FIELD GROUP (used in modals without modal-grid) ── */
.fg{display:flex;flex-direction:column;gap:3px;margin-bottom:.5rem}
.fg label{font-size:.62rem;font-weight:600;color:var(--warm-500);text-transform:uppercase;letter-spacing:.5px}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
@media(max-width:768px){.fg2{grid-template-columns:1fr}}
@media(max-width:768px){
  [style*="text-align:center;padding:.5rem"]{
    font-size:.45rem!important;
    padding:.4rem .6rem!important;
    line-height:1.6!important;
  }
}
/* Prevent long org names clipping welcome banner */
#orgName{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}
@media(max-width:380px){#orgName{max-width:130px}}

/* ══════════════════════════════════════════════════════
   PATCH v20260407 — Fix class name mismatches + mobile
   ══════════════════════════════════════════════════════ */

/* Sidebar item alias: JS uses .sb-item, CSS had .sb a only */
.sb-item{display:flex;align-items:center;gap:10px;padding:.48rem 1.1rem;color:rgba(255,255,255,.42);font-size:.76rem;font-weight:500;text-decoration:none;transition:all .15s;margin:1px 8px;border-radius:8px}
.sb-item:hover{color:#fff;background:rgba(255,255,255,.06)}
.sb-item.active,.sb-item.act{color:#fff;background:var(--terra);font-weight:600}
.sb-item i{width:17px;text-align:center;font-size:.8rem}
.sb-item span{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Sidebar section label alias: JS uses .sb-section, CSS had .sb-sec only */
.sb-section{padding:.7rem 1.2rem .2rem;font-size:.48rem;text-transform:uppercase;letter-spacing:1.8px;color:rgba(255,255,255,.18);font-weight:700}

/* Sidebar close button (mobile hamburger X) */
.sb-close{background:none;border:none;color:rgba(255,255,255,.4);font-size:1rem;cursor:pointer;padding:.2rem;margin-left:auto;border-radius:6px;transition:color .15s;line-height:1}
.sb-close:hover{color:#fff}

/* main-content alias: dashboard uses this, CSS had .mn only */
.main-content{margin-left:var(--sb-w);min-height:100vh}

/* Sidebar overlay for mobile tap-to-close */
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:350;-webkit-tap-highlight-color:transparent}
.sb-overlay.show{display:block}

/* ── Mobile fixes for sidebar item aliases ── */
@media(max-width:768px){
  .main-content{margin-left:0!important;padding-bottom:60px}
  .sb-item span,.sb-section{display:block}
  .sb.show .sb-item,.sb.show .sb-section{display:flex}
  .sb-item{display:flex}
}
@media(min-width:769px) and (max-width:1024px){
  .sb-item span,.sb-section{display:none}
  .sb-item{justify-content:center;padding:.6rem}
  .sb-item i{font-size:1.1rem;width:auto}
  .main-content{margin-left:60px}
}

/* ── Dashboard mobile grid fixes ── */
@media(max-width:768px){
  .dash-grid,.kpi-bar{padding:.4rem!important}
  .kpi-chip{min-width:75px!important;padding:.3rem .4rem!important}
  .kv{font-size:.9rem!important}
  .kl{font-size:.45rem!important}
}

/* Required field marker */
.req { color: var(--red); font-size: .8em; }

/* Call outcome buttons (lead-detail call modal) */
.outcome-btn {
  border: 2px solid var(--warm-200);
  border-radius: 10px;
  padding: .6rem;
  background: var(--card);
  cursor: pointer;
  font-size: .68rem;
  font-weight: 600;
  transition: all .15s;
  text-align: center;
}
.outcome-btn:hover { border-color: var(--olive); background: var(--olive-light); }
.outcome-btn.selected { border-color: var(--olive); background: var(--olive-light); color: var(--olive); }

/* ═══════════════════════════════════════════════════
   AUDIT71 — Compatibility classes for new pages
   wa-bot-monitor, llm-cost, opt-out, kb, abandoned-carts,
   wa-agent, email-routing, support-admin, benchmark, privacy
   ═══════════════════════════════════════════════════ */

.main {
  margin-left: var(--sb-w, 255px);
  padding: 1rem 1.2rem;
  min-height: 100vh;
  background: var(--bg, #f7f5f2);
  transition: margin-left .2s;
}
@media(max-width:900px){ .main{ margin-left:0; padding:.8rem } }

.page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  flex-wrap: wrap;
  gap: .8rem;
}
.page-header h1 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--warm-800, #292524);
  margin: 0;
  display: flex;
  align-items: center;
  gap: .5rem;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .5rem .85rem;
  border: 1px solid var(--warm-200, #e8e2db);
  border-radius: 8px;
  font-size: .82rem;
  font-weight: 500;
  cursor: pointer;
  background: white;
  color: var(--warm-700, #44403c);
  text-decoration: none;
  transition: all .15s;
}
.btn:hover { background: var(--warm-50, #faf8f6); }
.btn-sm { padding: .35rem .7rem; font-size: .75rem; }
.btn-xs { padding: .2rem .5rem; font-size: .68rem; }

.btn-primary { background: var(--olive, #4d7c0f); color: white; border-color: var(--olive); }
.btn-primary:hover { background: var(--olive-dark, #365314); }
.btn-danger { background: var(--red, #dc2626); color: white; border-color: var(--red); }
.btn-danger:hover { background: #b91c1c; }
.btn-secondary { background: var(--warm-600, #57534e); color: white; border-color: var(--warm-600); }

