/* ===== Dashboard app shell ===== */
body.dash{background:var(--bg);overflow-x:hidden}
.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}

/* Sidebar */
.side{position:sticky;top:0;height:100vh;padding:1.2rem;display:flex;flex-direction:column;gap:.4rem;
  background:var(--glass-strong);backdrop-filter:blur(20px) saturate(150%);border-right:1px solid var(--glass-line);z-index:30}
.side .brand{padding:.4rem .6rem 1.2rem;display:flex;align-items:center;gap:.6rem}
.side .brand img{height:30px}
.side .seclbl{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:1rem .7rem .3rem}
.navitem{display:flex;align-items:center;gap:.75rem;padding:.7rem .8rem;border-radius:12px;color:var(--ink-2);
  font-size:.92rem;font-weight:500;cursor:pointer;border:0;background:transparent;width:100%;text-align:left;transition:.18s}
.navitem svg{width:19px;height:19px;flex:0 0 19px;color:var(--muted);transition:.18s}
.navitem:hover{background:var(--g-50);color:var(--g-700)}
.navitem:hover svg{color:var(--g-600)}
.navitem.on{background:var(--grad-hero);color:#fff;box-shadow:0 8px 18px -8px rgba(36,133,64,.5)}
.navitem.on svg{color:#fff}
.navitem .badge{margin-left:auto;background:var(--g-100);color:var(--g-700);font-size:.7rem;font-weight:700;padding:.1em .5em;border-radius:999px}
.navitem.on .badge{background:rgba(255,255,255,.25);color:#fff}
.side-foot{margin-top:auto;padding-top:1rem;border-top:1px solid var(--line)}
.side-user{display:flex;align-items:center;gap:.7rem;padding:.5rem}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--grad-hero);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.9rem}
.side-user .nm{font-size:.85rem;font-weight:600}.side-user .rl{font-size:.72rem;color:var(--muted)}

/* Main */
.main{min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:1rem;padding:1rem 1.8rem;
  background:rgba(246,248,246,.8);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.topbar h1{font-size:1.35rem}
.topbar .sub{font-size:.82rem;color:var(--muted)}
.top-search{margin-left:auto;position:relative;display:flex;align-items:center}
.top-search svg{position:absolute;left:12px;width:16px;color:var(--muted)}
.top-search input{border:1px solid var(--line);background:#fff;border-radius:999px;padding:.55em 1em .55em 2.3em;font-family:inherit;font-size:.88rem;width:220px}
.top-search input:focus{outline:0;border-color:var(--g-400);box-shadow:0 0 0 4px var(--g-100)}
.icon-btn{width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;color:var(--ink-2);position:relative}
.icon-btn .dot{position:absolute;top:9px;right:10px;width:8px;height:8px;border-radius:50%;background:#ff5d52;border:2px solid #fff}
.content{padding:1.8rem;flex:1}
.view{display:none;animation:fadeup .4s var(--ease)}
.view.on{display:block}
@keyframes fadeup{from{opacity:0;transform:translateY(12px)}}

/* KPI cards */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-bottom:1.4rem}
.kpi{padding:1.3rem;position:relative;overflow:hidden}
.kpi .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:1.2rem;background:var(--g-50);border:1px solid var(--g-100);margin-bottom:.9rem}
.kpi .v{font-family:var(--font-display);font-weight:800;font-size:1.7rem;letter-spacing:-.02em}
.kpi .k{font-size:.82rem;color:var(--muted);margin-top:.1rem}
.kpi .trend{position:absolute;top:1.3rem;right:1.3rem;font-size:.78rem;font-weight:700;padding:.2em .55em;border-radius:999px}
.trend.up{color:var(--g-700);background:var(--g-50)}
.trend.down{color:#c0392b;background:#fdecea}

/* grids */
.row{display:grid;gap:1.1rem;margin-bottom:1.1rem}
.row.c2{grid-template-columns:1.6fr 1fr}
.row.c2e{grid-template-columns:1fr 1fr}
.row.c3{grid-template-columns:repeat(3,1fr)}
.panel{padding:1.4rem}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem}
.panel-head h3{font-size:1.05rem}
.panel-head .link{font-size:.82rem;color:var(--g-600);font-weight:600;cursor:pointer}
.chart-box{position:relative;height:240px}
.chart-sm{height:180px}

/* segmented control */
.seg{display:inline-flex;background:var(--bg-2);border-radius:999px;padding:3px;font-size:.8rem;font-weight:600}
.seg button{border:0;background:transparent;color:var(--muted);padding:.35em .9em;border-radius:999px;cursor:pointer}
.seg button.on{background:#fff;color:var(--g-700);box-shadow:var(--shadow-sm)}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:.88rem}
.tbl th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;padding:.6rem .7rem;border-bottom:1px solid var(--line)}
.tbl td{padding:.75rem .7rem;border-bottom:1px solid var(--line-2)}
.tbl tr:last-child td{border-bottom:0}
.tbl tr.clickable{cursor:pointer;transition:.15s}
.tbl tr.clickable:hover td{background:var(--g-50)}
.cellname{display:flex;align-items:center;gap:.6rem;font-weight:600}
.mini-av{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:.78rem;font-weight:700;color:#fff;background:var(--grad-hero)}
.pill{font-size:.74rem;font-weight:600;padding:.25em .7em;border-radius:999px;display:inline-block}
.pill.green{background:var(--g-50);color:var(--g-700)}
.pill.amber{background:#fff5e0;color:#b67c00}
.pill.blue{background:#e8f1fe;color:#1f6fd6}
.pill.gray{background:var(--bg-2);color:var(--muted)}
.pill.red{background:#fdecea;color:#c0392b}

/* progress bar */
.bar{height:7px;border-radius:999px;background:var(--bg-2);overflow:hidden;min-width:80px}
.bar i{display:block;height:100%;background:var(--grad-hero);border-radius:999px}

/* activity feed */
.feed{display:flex;flex-direction:column;gap:.1rem}
.feed-item{display:flex;gap:.8rem;padding:.7rem 0;border-bottom:1px solid var(--line-2)}
.feed-item:last-child{border-bottom:0}
.feed-ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:.95rem;flex:0 0 34px;background:var(--g-50)}
.feed-item .t{font-size:.88rem}.feed-item .tm{font-size:.74rem;color:var(--muted);margin-top:.1rem}

/* sensor cards */
.sensor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-bottom:1.1rem}
.sensor{padding:1.2rem}
.sensor .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem}
.sensor .nm{font-weight:700;font-size:.95rem}
.sensor .loc{font-size:.76rem;color:var(--muted)}
.gauge{font-family:var(--font-display);font-weight:800;font-size:2rem;color:var(--g-700)}
.gauge small{font-size:.9rem;color:var(--muted);font-weight:600}
.sensor .spark{height:40px;padding:0;margin-top:.6rem}

/* product inventory list */
.inv-name{display:flex;align-items:center;gap:.6rem;font-weight:600}
.inv-ic{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;font-size:1rem;background:var(--g-50);border:1px solid var(--g-100)}

/* map placeholder */
.map-box{height:280px;border-radius:var(--radius);background:
  linear-gradient(rgba(54,163,77,.06),rgba(54,163,77,.06)),
  repeating-linear-gradient(0deg,transparent,transparent 28px,rgba(31,106,53,.06) 29px),
  repeating-linear-gradient(90deg,transparent,transparent 28px,rgba(31,106,53,.06) 29px),
  radial-gradient(circle at 30% 40%,#dcf3e0,transparent 40%),
  radial-gradient(circle at 70% 65%,#e3f3d6,transparent 45%);
  border:1px solid var(--line);position:relative;overflow:hidden}
.pin{position:absolute;transform:translate(-50%,-100%);text-align:center}
.pin .dotpin{width:18px;height:18px;border-radius:50% 50% 50% 0;background:var(--g-500);transform:rotate(-45deg);margin:0 auto;box-shadow:0 4px 10px rgba(36,133,64,.5);border:2px solid #fff}
.pin .lbl{font-size:.7rem;font-weight:700;background:#fff;border:1px solid var(--line);padding:.1em .45em;border-radius:6px;margin-top:6px;white-space:nowrap;box-shadow:var(--shadow-sm)}
.pin .ping{position:absolute;top:0;left:50%;transform:translate(-50%,-50%);width:18px;height:18px;border-radius:50%;background:rgba(54,163,77,.4);animation:ping 2.4s ease-out infinite}
@keyframes ping{0%{transform:translate(-50%,-50%) scale(1);opacity:.7}100%{transform:translate(-50%,-50%) scale(3.5);opacity:0}}

/* quote builder */
.quote-line{display:grid;grid-template-columns:1fr 80px 110px 110px 36px;gap:.6rem;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--line-2)}
.quote-line select,.quote-line input{border:1px solid var(--line);border-radius:10px;padding:.5em .6em;font-family:inherit;font-size:.85rem;width:100%}
.quote-total{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.9rem}
.quote-total.grand{font-family:var(--font-display);font-weight:800;font-size:1.3rem;border-top:2px solid var(--line);margin-top:.5rem;padding-top:.8rem}
.del-line{border:0;background:#fdecea;color:#c0392b;border-radius:9px;width:32px;height:32px;cursor:pointer}

.mobile-only{display:none}

/* table horizontal scroll wrapper (added around .tbl by JS on small screens) */
.tscroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -.2rem}
.kpi .v{overflow-wrap:anywhere}

@media(max-width:1100px){.kpis{grid-template-columns:1fr 1fr}.row.c2,.row.c2e,.row.c3,.sensor-grid{grid-template-columns:1fr}}

@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .side{position:fixed;left:-280px;width:260px;transition:.3s var(--ease);box-shadow:var(--shadow-lg)}
  .side.open{left:0}
  .side::after{content:"";position:fixed;inset:0;background:rgba(15,26,20,.35);opacity:0;pointer-events:none;transition:.3s;z-index:-1}
  .side.open::after{opacity:1;pointer-events:auto}
  .mobile-only{display:grid}
  .content{padding:1.1rem}
  .topbar{padding:.8rem 1rem;gap:.6rem}
  .topbar h1{font-size:1.1rem}
  .topbar .sub{font-size:.74rem}
  .top-search{margin-left:auto}
  .top-search input{width:120px}
  .panel{padding:1.15rem}
  .kpi{padding:1.1rem}
  .kpi .v{font-size:1.45rem}
  .kpi .k{font-size:.76rem}
  .kpis{gap:.7rem}
  .tscroll>.tbl{min-width:520px}
  .chart-box{height:220px}
}

@media(max-width:480px){
  .content{padding:.85rem}
  .kpis{grid-template-columns:1fr 1fr;gap:.6rem}
  .kpi{padding:.9rem}
  .kpi .ic{width:34px;height:34px;font-size:1rem;margin-bottom:.5rem}
  .kpi .v{font-size:1.3rem}
  .kpi .trend{position:static;display:inline-block;margin:0 0 .35rem}
  .panel{padding:1rem}
  .panel-head h3{font-size:1rem}
  .panel-head{flex-wrap:wrap;gap:.5rem}
  .top-search{display:none}
  /* quote builder: drop the unit-price column, keep product / qty / subtotal / delete */
  .quote-line{grid-template-columns:1.2fr 48px 1fr 30px;gap:.4rem;font-size:.8rem}
  .quote-line>:nth-child(3){display:none}
  .quote-line select,.quote-line input{padding:.45em .4em;font-size:.8rem}
  .del-line{width:28px;height:28px}
}
