/* Tech Spot ERP — dashboard styles. Depends on ../colors_and_type.css */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-sans);background:var(--neutral-100);color:var(--fg-1);overflow:hidden}
button{font-family:inherit;cursor:pointer}
.icon{width:20px;height:20px;display:inline-flex;flex:none}
.app{display:grid;grid-template-columns:248px 1fr;height:100vh}

/* ---------- SIDEBAR ---------- */
.sidebar{background:var(--spot-blue-900);color:#fff;display:flex;flex-direction:column;overflow:hidden}
.sb-logo{padding:22px 22px 18px;display:flex;align-items:center;gap:10px}
.logo{font-family:var(--font-display);font-weight:900;letter-spacing:-.03em;font-size:23px;line-height:1;display:inline-flex;align-items:center}
.logo .t{color:#fff} .logo .pill{background:#fff;color:var(--spot-blue-900);border-radius:999px;padding:.08em .4em .16em;display:inline-block}
.logo .sfx{font-family:var(--font-display);font-weight:800;font-size:13px;color:var(--spot-blue-300);letter-spacing:.12em;text-transform:uppercase;margin-left:6px;align-self:center}
.sb-search{margin:4px 16px 14px;display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.08);border:1px solid var(--border-on-ink);border-radius:11px;padding:9px 13px;color:var(--spot-blue-200)}
.sb-search input{flex:1;background:none;border:0;outline:none;color:#fff;font-size:13.5px;font-family:inherit}
.sb-search input::placeholder{color:var(--spot-blue-300)}
.sb-search kbd{font-family:var(--font-mono);font-size:11px;background:rgba(255,255,255,.1);padding:2px 6px;border-radius:5px;color:var(--spot-blue-200)}
.sb-nav{flex:1;overflow-y:auto;padding:6px 12px 16px}
.sb-group{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--spot-blue-300);padding:14px 12px 7px}
.sb-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;color:var(--spot-blue-100);font-size:14.5px;font-weight:600;border:0;background:none;width:100%;text-align:left;transition:background .14s,color .14s;position:relative}
.sb-item:hover{background:rgba(255,255,255,.07);color:#fff}
.sb-item.active{background:var(--spot-blue-500);color:#fff}
.sb-item .badge{margin-left:auto;background:var(--spot-orange-500);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.sb-item.active .badge{background:#fff;color:var(--spot-blue-700)}
.sb-foot{padding:14px 16px;border-top:1px solid var(--border-on-ink);display:flex;align-items:center;gap:11px}
.avatar{width:38px;height:38px;border-radius:999px;background:var(--spot-orange-500);color:#fff;font-family:var(--font-display);font-weight:800;font-size:15px;display:flex;align-items:center;justify-content:center;flex:none}
.sb-foot .nm{font-size:13.5px;font-weight:700;color:#fff;line-height:1.2}
.sb-foot .rl{font-size:12px;color:var(--spot-blue-300)}

/* ---------- MAIN ---------- */
.main{display:flex;flex-direction:column;overflow:hidden;background:var(--neutral-100)}
.topbar{height:64px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 28px;flex:none}
.topbar h1{font-family:var(--font-display);font-weight:800;font-size:22px;letter-spacing:-.02em}
.crumb{font-size:13px;color:var(--fg-3);font-weight:600}
.tb-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.tbtn{width:40px;height:40px;border-radius:11px;background:var(--neutral-100);border:0;display:flex;align-items:center;justify-content:center;color:var(--fg-1);position:relative;transition:background .14s}
.tbtn:hover{background:var(--neutral-200)}
.tbtn .dot{position:absolute;top:9px;right:9px;width:8px;height:8px;border-radius:999px;background:var(--spot-orange-500);border:2px solid #fff}
.content{flex:1;overflow-y:auto;padding:26px 28px 40px}

/* buttons */
.btn{font-weight:700;border:0;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .14s,background .16s,box-shadow .16s;white-space:nowrap}
.btn:active{transform:scale(.97)}
.btn-pri{background:var(--spot-blue-500);color:#fff;box-shadow:var(--shadow-blue);padding:11px 18px;font-size:14px}
.btn-pri:hover{background:var(--spot-blue-600)}
.btn-acc{background:var(--spot-orange-500);color:#fff;box-shadow:var(--shadow-orange);padding:11px 18px;font-size:14px}
.btn-ghost{background:#fff;color:var(--fg-1);box-shadow:inset 0 0 0 1px var(--border);padding:10px 16px;font-size:14px}
.btn-ghost:hover{background:var(--neutral-50)}
.btn .icon{width:17px;height:17px}

/* KPI cards */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:22px}
.kpi{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}
.kpi .top{display:flex;align-items:center;justify-content:space-between}
.kpi .ic{width:42px;height:42px;border-radius:12px;background:var(--spot-blue-50);color:var(--spot-blue-600);display:flex;align-items:center;justify-content:center}
.kpi.o .ic{background:var(--spot-orange-50);color:var(--spot-orange-600)}
.kpi.g .ic{background:var(--success-bg);color:var(--success)}
.kpi.p .ic{background:#F1ECFB;color:#7C5CD6}
.kpi .delta{font-size:12.5px;font-weight:700;padding:3px 9px;border-radius:999px;display:inline-flex;align-items:center;gap:3px}
.kpi .delta.up{background:var(--success-bg);color:var(--success)}
.kpi .delta.down{background:var(--danger-bg);color:var(--danger)}
.kpi .val{font-family:var(--font-display);font-weight:900;font-size:30px;letter-spacing:-.02em;margin-top:16px;line-height:1}
.kpi .lbl{font-size:13.5px;color:var(--fg-2);margin-top:6px;font-weight:600}

/* layout grids */
.grid-2{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;margin-bottom:22px}
.grid-2b{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:22px}
.panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.panel .ph{padding:18px 22px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.panel .ph h3{font-family:var(--font-display);font-weight:800;font-size:17px;letter-spacing:-.01em}
.panel .ph .sub{font-size:12.5px;color:var(--fg-3);margin-top:2px}
.panel .pb{padding:22px}
.link{font-size:13px;font-weight:700;color:var(--spot-blue-600);display:inline-flex;align-items:center;gap:5px;background:none;border:0}

/* chart */
.chart{display:flex;align-items:flex-end;gap:14px;height:220px;padding-top:10px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}
.bar-stack{width:100%;max-width:38px;display:flex;flex-direction:column;justify-content:flex-end;gap:3px;height:100%}
.bar{width:100%;border-radius:6px 6px 0 0;transition:height .5s cubic-bezier(.2,.7,.2,1)}
.bar.b1{background:var(--spot-blue-500)}
.bar.b2{background:var(--spot-orange-400)}
.bar-x{font-size:12px;color:var(--fg-3);font-weight:600}
.legend{display:flex;gap:18px;margin-top:4px}
.legend span{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--fg-2);font-weight:600}
.legend i{width:11px;height:11px;border-radius:4px;display:inline-block}

/* donut */
.donut-wrap{display:flex;align-items:center;gap:26px}
.donut{width:148px;height:148px;border-radius:999px;flex:none;position:relative;display:flex;align-items:center;justify-content:center}
.donut::after{content:'';position:absolute;width:96px;height:96px;background:#fff;border-radius:999px}
.donut .ctr{position:relative;z-index:1;text-align:center}
.donut .ctr .n{font-family:var(--font-display);font-weight:900;font-size:24px;letter-spacing:-.02em}
.donut .ctr .l{font-size:11px;color:var(--fg-3);font-weight:600}
.dleg{display:flex;flex-direction:column;gap:12px;flex:1}
.dleg .it{display:flex;align-items:center;gap:10px;font-size:13.5px}
.dleg .it .dot{width:11px;height:11px;border-radius:4px;flex:none}
.dleg .it .nm{font-weight:600;color:var(--fg-1)}
.dleg .it .vv{margin-left:auto;font-weight:700;color:var(--fg-2)}

/* tables */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--fg-3);padding:0 16px 12px}
.tbl td{padding:13px 16px;border-top:1px solid var(--border);font-size:14px;color:var(--fg-1);vertical-align:middle}
.tbl tr:hover td,.tbl tbody tr:hover td{background:var(--neutral-50)}
.tbl .strong{font-weight:700}
.tbl .muted{color:var(--fg-2);font-size:13px}
.tag{font-size:12px;font-weight:700;padding:4px 11px;border-radius:999px;display:inline-flex;align-items:center;gap:5px}
.tag.paid{background:var(--success-bg);color:var(--success)}
.tag.pending{background:var(--warning-bg);color:#B5790F}
.tag.overdue{background:var(--danger-bg);color:var(--danger)}
.tag.draft{background:var(--neutral-100);color:var(--fg-2)}
.tag.stock-ok{background:var(--success-bg);color:var(--success)}
.tag.stock-low{background:var(--warning-bg);color:#B5790F}
.tag.stock-out{background:var(--danger-bg);color:var(--danger)}
.cellico{width:34px;height:34px;border-radius:9px;background:var(--neutral-100);display:inline-flex;align-items:center;justify-content:center;color:var(--spot-blue-500);margin-right:10px;vertical-align:middle;flex:none}
.cust{display:flex;align-items:center}
.miniav{width:32px;height:32px;border-radius:999px;color:#fff;font-weight:700;font-size:13px;display:inline-flex;align-items:center;justify-content:center;margin-right:10px;flex:none;font-family:var(--font-display)}

/* progress */
.prog{height:8px;background:var(--neutral-100);border-radius:999px;overflow:hidden;min-width:90px}
.prog i{display:block;height:100%;border-radius:999px;background:var(--spot-blue-500)}

/* module placeholder (CRM pipeline) */
.pipe{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.pcol{background:var(--neutral-50);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;min-height:300px}
.pcol .ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.pcol .ch .t{font-weight:700;font-size:14px}
.pcol .ch .c{font-size:12px;font-weight:700;color:var(--fg-3);background:#fff;border:1px solid var(--border);padding:2px 9px;border-radius:999px}
.deal{background:#fff;border:1px solid var(--border);border-radius:11px;padding:13px;margin-bottom:10px;box-shadow:var(--shadow-xs);cursor:grab}
.deal:hover{box-shadow:var(--shadow-md)}
.deal .co{font-weight:700;font-size:13.5px}
.deal .amt{font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--spot-blue-600);margin-top:6px}
.deal .meta{display:flex;align-items:center;justify-content:space-between;margin-top:9px}
.deal .meta .who{font-size:12px;color:var(--fg-3)}

/* segmented */
.seg{display:inline-flex;background:var(--neutral-100);border-radius:10px;padding:3px}
.seg button{border:0;background:none;font-size:13px;font-weight:700;color:var(--fg-2);padding:7px 14px;border-radius:8px}
.seg button.on{background:#fff;color:var(--spot-blue-700);box-shadow:var(--shadow-xs)}

/* activity feed */
.feed{display:flex;flex-direction:column}
.feed .it{display:flex;gap:13px;padding:14px 0;border-top:1px solid var(--border)}
.feed .it:first-child{border-top:0;padding-top:0}
.feed .fi{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:none;background:var(--spot-blue-50);color:var(--spot-blue-600)}
.feed .fi.o{background:var(--spot-orange-50);color:var(--spot-orange-600)}
.feed .fi.g{background:var(--success-bg);color:var(--success)}
.feed .ft{font-size:13.5px;line-height:1.45}
.feed .ft b{font-weight:700}
.feed .fd{font-size:12px;color:var(--fg-3);margin-top:2px}

.coming{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 20px;color:var(--fg-3)}
.coming .ic{width:72px;height:72px;border-radius:20px;background:var(--spot-blue-50);color:var(--spot-blue-500);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.coming h2{font-family:var(--font-display);font-weight:800;font-size:24px;color:var(--fg-1);letter-spacing:-.01em}
.coming p{font-size:15px;margin-top:8px;max-width:380px;line-height:1.55}

@media(max-width:1100px){.kpi-row{grid-template-columns:1fr 1fr}.grid-2,.grid-2b{grid-template-columns:1fr}.pipe{grid-template-columns:1fr 1fr}}
