/* ═══════════════════════════════════════
   shared.css  —  Common tokens & layout
   Dhanvitta Fintech Solutions Pvt. Ltd.
═══════════════════════════════════════ */
:root{
  --navy:#0B2045; --navy2:#163272;
  --blue:#2563EB; --blue-lt:#EFF4FF;
  --grn:#059669;  --grn-lt:#ECFDF5;
  --amb:#B45309;  --amb-lt:#FFFBEB;
  --ros:#BE123C;  --ros-lt:#FFF1F2;
  --vio:#6D28D9;  --vio-lt:#F5F3FF;
  --tea:#0E7490;  --tea-lt:#ECFEFF;
  --org:#C2410C;  --org-lt:#FFF7ED;
  --cor:#E84B27;  --cor-lt:#FEF0EB;
  --bg:#F0F4FA; --wh:#FFFFFF;
  --bd:#E2E8F0; --bd2:#F1F5F9;
  --tx:#1E293B; --tx2:#475569; --tx3:#94A3B8;
  --s1:0 1px 4px rgba(11,32,69,.07),0 1px 2px rgba(11,32,69,.04);
  --s2:0 4px 20px rgba(11,32,69,.10),0 2px 6px rgba(11,32,69,.05);
  --r:10px; --r2:14px;
  --f:'Outfit',sans-serif; --fm:'JetBrains Mono',monospace;
  --sw:230px; --hh:60px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;-webkit-font-smoothing:antialiased}
body{font-family:var(--f);background:var(--bg);color:var(--tx);min-height:100vh}

/* ── Layout shell ── */
.shell{display:flex;min-height:100vh}
.main{margin-left:var(--sw);flex:1;display:flex;flex-direction:column}

/* ── Sidebar ── */
.sidebar{
  width:var(--sw);background:var(--navy);
  position:fixed;top:0;left:0;bottom:0;
  display:flex;flex-direction:column;z-index:200;overflow:hidden;
}
.sb-accent{position:absolute;top:0;left:0;right:0;height:3px}
.sb-top{padding:20px 16px 16px;border-bottom:1px solid rgba(255,255,255,.09)}
.sb-logo{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.sb-em{width:38px;height:38px;border-radius:9px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;font-weight:800;color:#fff}
.sb-brand{font-size:.87rem;font-weight:700;color:#fff;line-height:1.25}
.sb-tag{font-size:.59rem;color:rgba(255,255,255,.28);letter-spacing:.07em;text-transform:uppercase;margin-top:5px}
.sb-sec{font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.24);padding:16px 16px 5px}
.sb-nav{flex:1;padding:5px 10px;overflow-y:auto}
.na{display:flex;align-items:center;gap:9px;padding:8px 10px;
  border-radius:7px;font-size:.81rem;font-weight:500;
  color:rgba(255,255,255,.48);cursor:pointer;transition:all .18s;margin-bottom:2px;
  text-decoration:none}
.na svg{width:15px;height:15px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2}
.na:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.85)}
.sb-foot{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08);
  font-size:.63rem;color:rgba(255,255,255,.28);line-height:1.7}
.sb-foot strong{color:rgba(255,255,255,.5)}

/* Dashboard switcher tabs in sidebar */
.db-switch{display:flex;gap:0;margin:14px 10px 2px;border:1px solid rgba(255,255,255,.12);
  border-radius:8px;overflow:hidden}
.db-tab{flex:1;text-align:center;padding:7px 4px;font-size:.72rem;font-weight:600;
  color:rgba(255,255,255,.45);cursor:pointer;transition:all .18s;text-decoration:none;
  letter-spacing:.01em}
.db-tab:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.06)}
.db-tab.on{color:#fff;font-weight:700}

/* ── Header ── */
.hdr{height:var(--hh);background:var(--wh);border-bottom:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;position:sticky;top:0;z-index:100;box-shadow:var(--s1)}
.hd-l h1{font-size:1.1rem;font-weight:700;color:var(--navy)}
.hd-l p{font-size:.7rem;color:var(--tx3);margin-top:1px}
.hd-r{display:flex;align-items:center;gap:8px}
.hbtn{border:1.5px solid var(--bd);background:var(--wh);border-radius:7px;
  padding:6px 14px;font-size:.74rem;font-weight:500;color:var(--tx2);
  cursor:pointer;font-family:var(--f);transition:all .18s}
.hbtn:hover{border-color:var(--blue);color:var(--blue)}
.hbtn.pri{border-color:var(--navy);background:var(--navy);color:#fff;font-weight:600}
.hbtn.pri:hover{background:var(--navy2)}
.live{display:flex;align-items:center;gap:5px;font-size:.68rem;font-weight:600;
  padding:4px 10px;border-radius:20px}
.ldot{width:6px;height:6px;border-radius:50%;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}

/* ── Filter bar ── */
.fbar{background:var(--wh);border-bottom:1px solid var(--bd);
  padding:11px 24px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.flbl{font-size:.67rem;font-weight:700;letter-spacing:.07em;
  text-transform:uppercase;color:var(--tx3);margin-right:2px;white-space:nowrap}
.fsel{border:1.5px solid var(--bd);background:var(--wh);border-radius:7px;
  padding:6px 28px 6px 10px;font-size:.75rem;font-weight:500;color:var(--tx);
  cursor:pointer;font-family:var(--f);outline:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%2394A3B8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 9px center;
  transition:border-color .18s;min-width:140px}
.fsel:focus,.fsel:hover{border-color:var(--blue)}
.fsel.act{font-weight:600}
.fsep{width:1px;height:22px;background:var(--bd);margin:0 3px}
.frst{border:1.5px solid var(--bd);background:var(--wh);border-radius:7px;
  padding:6px 12px;font-size:.72rem;font-weight:600;color:var(--tx3);
  cursor:pointer;font-family:var(--f);transition:all .18s}
.frst:hover{border-color:var(--ros);color:var(--ros)}
.ftag{margin-left:auto;font-size:.66rem;color:var(--tx3);background:var(--bg);
  border:1px solid var(--bd);padding:4px 10px;border-radius:20px;
  font-family:var(--fm);white-space:nowrap}
.ftag b{color:var(--navy)}

/* ── Content ── */
.body{padding:20px 24px;flex:1}
.sh{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.sh h2{font-size:.9rem;font-weight:700;color:var(--navy);white-space:nowrap}
.sh-ln{flex:1;height:1px;background:var(--bd2)}
.sh span{font-size:.64rem;color:var(--tx3);font-family:var(--fm);white-space:nowrap}

/* ── KPI Grid ── */
.kg{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:18px}
.kc{background:var(--wh);border:1px solid var(--bd);border-radius:var(--r2);
  padding:16px 16px 12px;box-shadow:var(--s1);
  transition:box-shadow .2s,transform .2s;
  animation:up .4s ease both;position:relative;overflow:hidden}
.kc:hover{box-shadow:var(--s2);transform:translateY(-2px)}
.kc::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px}
.kico{width:32px;height:32px;border-radius:7px;display:flex;align-items:center;
  justify-content:center;font-size:1rem;margin-bottom:10px}
.klbl{font-size:.61rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  color:var(--tx3);margin-bottom:4px}
.kval{font-size:1.5rem;font-weight:800;color:var(--navy);line-height:1;margin-bottom:3px}
.kunt{font-size:.63rem;color:var(--tx3);font-family:var(--fm);display:block;margin-bottom:8px}
.kchg{display:inline-flex;align-items:center;gap:3px;font-size:.68rem;font-weight:600;
  padding:2px 7px;border-radius:20px}
.cup{background:var(--grn-lt);color:var(--grn)}
.cdn{background:var(--ros-lt);color:var(--ros)}
.kc:nth-child(1){animation-delay:.03s}.kc:nth-child(2){animation-delay:.07s}
.kc:nth-child(3){animation-delay:.11s}.kc:nth-child(4){animation-delay:.15s}
.kc:nth-child(5){animation-delay:.19s}.kc:nth-child(6){animation-delay:.23s}

/* ── Chart cards ── */
.crow{display:grid;gap:14px;margin-bottom:14px}
.c3-2{grid-template-columns:3fr 2fr}
.c1-1{grid-template-columns:1fr 1fr}
.c2-1{grid-template-columns:2fr 1fr}
.cc{background:var(--wh);border:1px solid var(--bd);border-radius:var(--r2);
  padding:18px 20px;box-shadow:var(--s1);animation:up .45s ease both;
  animation-delay:.15s;transition:box-shadow .2s}
.cc:hover{box-shadow:var(--s2)}
.cchdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.cct{font-size:.88rem;font-weight:700;color:var(--navy);margin-bottom:2px}
.ccs{font-size:.67rem;color:var(--tx3)}
.tag{font-size:.61rem;font-weight:600;padding:3px 9px;border-radius:20px;white-space:nowrap;border:1px solid}
.tb{background:var(--blue-lt);color:var(--blue);border-color:#BFDBFE}
.tg{background:var(--grn-lt);color:var(--grn);border-color:#A7F3D0}
.ta{background:var(--amb-lt);color:var(--amb);border-color:#FDE68A}
.tr{background:var(--ros-lt);color:var(--ros);border-color:#FECDD3}
.tv{background:var(--vio-lt);color:var(--vio);border-color:#DDD6FE}
.tt{background:var(--tea-lt);color:var(--tea);border-color:#A5F3FC}
.to{background:var(--org-lt);color:var(--org);border-color:#FED7AA}
.tc2{background:var(--cor-lt);color:var(--cor);border-color:#FDBA9E}
.cw{position:relative}
.h220{height:220px}.h250{height:250px}.h270{height:270px}
.leg{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.li{display:flex;align-items:center;gap:5px;font-size:.67rem;color:var(--tx2)}
.ld{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ll{width:14px;height:3px;border-radius:2px;flex-shrink:0}

/* ── Tables ── */
.tc{background:var(--wh);border:1px solid var(--bd);border-radius:var(--r2);
  padding:18px 20px;box-shadow:var(--s1);animation:up .5s ease both;animation-delay:.2s}
table.dt{width:100%;border-collapse:collapse;font-size:.74rem}
table.dt th{text-align:left;font-size:.59rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--tx3);padding:0 8px 8px;
  border-bottom:2px solid var(--bd2);white-space:nowrap}
table.dt td{padding:8px 8px;color:var(--tx2);border-bottom:1px solid var(--bd2);vertical-align:middle}
table.dt tr:last-child td{border-bottom:none}
table.dt tbody tr:hover td{background:#F8FAFF}

/* Rank */
.rk{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;
  justify-content:center;font-size:.59rem;font-weight:700;font-family:var(--fm)}
.r1{background:#FEF9C3;color:#854D0E;border:1.5px solid #FDE047}
.r2{background:#F1F5F9;color:#475569;border:1.5px solid #CBD5E1}
.r3{background:#FFEDD5;color:#9A3412;border:1.5px solid #FED7AA}
.rn{background:var(--bg);color:var(--tx3);border:1px solid var(--bd)}

/* Category pill */
.cp{font-size:.60rem;font-weight:600;padding:2px 7px;border-radius:4px;white-space:nowrap}
.el{background:#EFF6FF;color:#1D4ED8}.ap{background:#F5F3FF;color:#6D28D9}
.hk{background:#ECFEFF;color:#0E7490}.sf{background:#ECFDF5;color:#047857}
.fg{background:#FFFBEB;color:#B45309}

/* Status / payment chips */
.stt{font-size:.61rem;font-weight:600;padding:2px 8px;border-radius:20px}
.s-ok{background:var(--grn-lt);color:var(--grn)}.s-bl{background:var(--blue-lt);color:var(--blue)}
.s-te{background:var(--tea-lt);color:var(--tea)}.s-rd{background:var(--ros-lt);color:var(--ros)}
.s-am{background:var(--amb-lt);color:var(--amb)}.s-vio{background:var(--vio-lt);color:var(--vio)}
.s-cn{background:var(--ros-lt);color:var(--ros)}

/* Supplier status */
.sup-pref{font-size:.60rem;font-weight:600;padding:2px 7px;border-radius:4px;background:var(--grn-lt);color:var(--grn)}
.sup-appr{font-size:.60rem;font-weight:600;padding:2px 7px;border-radius:4px;background:var(--blue-lt);color:var(--blue)}
.sup-rev {font-size:.60rem;font-weight:600;padding:2px 7px;border-radius:4px;background:var(--amb-lt);color:var(--amb)}

/* Mono */
.mn{font-family:var(--fm);font-size:.73rem}
.mn-s{font-family:var(--fm);font-size:.65rem;color:var(--tx3)}
.pname{font-weight:600;color:var(--navy);font-size:.76rem}
.gup{color:var(--grn);font-weight:600;font-family:var(--fm);font-size:.70rem}
.gdn{color:var(--ros);font-weight:600;font-family:var(--fm);font-size:.70rem}
.stars{color:#F59E0B;font-size:.65rem}

/* Progress bar */
.pb{height:5px;background:var(--bd2);border-radius:4px;overflow:hidden;margin-top:3px}
.pbf{height:100%;border-radius:4px;transition:width .6s ease}

/* Footer */
.footer{border-top:1px solid var(--bd);padding:12px 24px;
  display:flex;align-items:center;justify-content:space-between;
  font-size:.64rem;color:var(--tx3);background:var(--wh)}
.footer b{color:var(--navy)}

/* Animation */
@keyframes up{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bd);border-radius:4px}

@media(max-width:1300px){.c3-2{grid-template-columns:1fr}.kg{grid-template-columns:repeat(3,1fr)}}
@media(max-width:1080px){.c1-1,.c2-1{grid-template-columns:1fr}}

/* ── 4-tab dashboard switcher ── */
.db-switch{display:flex;gap:0;margin:12px 10px 4px;
  border:1px solid rgba(255,255,255,.12);border-radius:8px;overflow:hidden}
.db-tab{flex:1;text-align:center;padding:7px 2px;font-size:.66rem;font-weight:600;
  color:rgba(255,255,255,.42);cursor:pointer;transition:all .18s;
  text-decoration:none;letter-spacing:.01em;line-height:1.2}
.db-tab:hover{color:rgba(255,255,255,.82);background:rgba(255,255,255,.06)}
