/* =====================================================================
 * GrowData Track — dashboard theme (light, brand-aligned)
 * Primary: #e3814e
 * =================================================================== */
:root{
  --orange:#e3814e;
  --orange-d:#c96a3a;
  --orange-tint:#fdf1e9;
  --orange-tint2:#fbe5d6;
  --green:#5ba150;
  --blue:#4a90d9;
  --amber:#f2c14e;
  --grey:#9aa5b1;

  --bg:#f4f5f7;
  --panel:#ffffff;
  --panel-2:#fafbfc;
  --line:#e6e8ec;
  --line-2:#eef0f3;
  --txt:#1f2933;
  --txt-2:#52606d;
  --muted:#8a94a3;
  --shadow:0 1px 2px rgba(16,24,40,.04),0 4px 14px rgba(16,24,40,.06);
  --radius:14px;
  --sidebar:248px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);color:var(--txt);
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  font-size:14px;-webkit-font-smoothing:antialiased;
}

/* ---- layout ------------------------------------------------------- */
.layout{display:flex;min-height:100vh}
.sidebar{
  width:var(--sidebar);flex:0 0 var(--sidebar);
  background:var(--panel);border-right:1px solid var(--line);
  display:flex;flex-direction:column;
}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.content{padding:22px 26px 40px;max-width:1600px;width:100%;margin:0 auto}

/* ---- sidebar ------------------------------------------------------ */
.brand-wrap{padding:20px 20px 16px;border-bottom:1px solid var(--line-2)}
.brand-logo{display:flex;align-items:center;gap:10px}
.brand-logo img{height:30px;width:auto}
.brand-fallback{font-weight:800;font-size:1.15rem;letter-spacing:-.01em}
.brand-fallback .g{color:var(--txt)}
.brand-fallback .t{color:var(--orange)}
.brand-sub{font-size:.7rem;color:var(--muted);margin-top:6px;text-transform:uppercase;letter-spacing:.12em}

.nav{padding:12px 12px;display:flex;flex-direction:column;gap:2px;flex:1}
.nav-label{font-size:.66rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);padding:14px 12px 6px}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;
  color:var(--txt-2);text-decoration:none;font-weight:500;cursor:pointer;
  border:1px solid transparent;transition:.15s;
}
.nav-item:hover{background:var(--panel-2);color:var(--txt)}
.nav-item.active{background:var(--orange-tint);color:var(--orange-d);border-color:var(--orange-tint2);font-weight:600}
.nav-item .ico{width:18px;height:18px;flex:0 0 18px;opacity:.9}
.nav-item.active .ico{color:var(--orange)}
.sidebar-foot{padding:14px 20px;border-top:1px solid var(--line-2);font-size:.72rem;color:var(--muted)}

/* ---- topbar ------------------------------------------------------- */
.topbar{
  background:var(--panel);border-bottom:1px solid var(--line);
  padding:14px 26px;display:flex;align-items:center;justify-content:space-between;gap:16px;
  position:sticky;top:0;z-index:30;
}
.page-title h1{font-size:1.18rem;margin:0;font-weight:700;letter-spacing:-.01em}
.page-title p{margin:3px 0 0;color:var(--muted);font-size:.8rem;max-width:640px}
.topbar-right{display:flex;align-items:center;gap:14px;color:var(--txt-2);font-size:.8rem}
.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green);margin-right:6px;box-shadow:0 0 0 3px rgba(91,161,80,.18)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.8rem}

/* ---- filter bar --------------------------------------------------- */
.filterbar{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:12px 14px;margin-bottom:20px;
  display:flex;flex-wrap:wrap;align-items:flex-end;gap:14px;
}
.flt{display:flex;flex-direction:column;gap:5px;min-width:140px}
.flt label{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600}
.flt select{
  appearance:none;background:var(--panel-2) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a94a3' stroke-width='2.4'><path d='M6 9l6 6 6-6'/></svg>") no-repeat right 10px center;
  border:1px solid var(--line);border-radius:9px;padding:8px 30px 8px 11px;
  font-size:.84rem;color:var(--txt);cursor:pointer;min-width:140px;font-family:inherit;
}
.flt select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-tint2)}
.flt-seg{display:flex;background:var(--panel-2);border:1px solid var(--line);border-radius:9px;overflow:hidden}
.flt-seg button{background:none;border:none;padding:8px 12px;font-size:.8rem;color:var(--txt-2);cursor:pointer;font-family:inherit}
.flt-seg button.active{background:var(--orange);color:#fff;font-weight:600}
.reset-btn{
  margin-left:auto;background:var(--panel-2);border:1px solid var(--line);border-radius:9px;
  padding:8px 14px;font-size:.82rem;color:var(--txt-2);cursor:pointer;font-family:inherit;
}
.reset-btn:hover{border-color:var(--orange);color:var(--orange-d)}

/* ---- KPI cards ---------------------------------------------------- */
.kpi-grid{display:grid;gap:14px;margin-bottom:20px;
  grid-template-columns:repeat(auto-fit,minmax(178px,1fr))}
.kpi{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:16px 16px 14px;position:relative;overflow:hidden;
}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--orange);opacity:.85}
.kpi .k-label{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600}
.kpi .k-val{font-size:1.7rem;font-weight:750;line-height:1.1;margin-top:8px;letter-spacing:-.02em}
.kpi .k-unit{font-size:.8rem;color:var(--muted);font-weight:600;margin-left:3px}
.kpi .k-sub{font-size:.72rem;margin-top:7px;display:flex;align-items:center;gap:5px;color:var(--muted)}
.k-trend{font-weight:700}
.k-trend.up{color:var(--green)}
.k-trend.down{color:#d94a6a}
.kpi.alt::before{background:var(--blue)}
.kpi.alt2::before{background:var(--green)}
.kpi.alt3::before{background:var(--amber)}

/* ---- chart cards -------------------------------------------------- */
.grid{display:grid;gap:16px;margin-bottom:18px}
.g-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.g-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.span-2{grid-column:span 2}
@media(max-width:1100px){.g-2,.g-3{grid-template-columns:1fr}.span-2{grid-column:auto}}

.card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:16px 18px;
}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;gap:10px}
.card-title{font-size:.9rem;font-weight:700;letter-spacing:-.01em}
.card-note{font-size:.72rem;color:var(--muted);font-weight:500}
.chart{width:100%;height:300px}
.chart.tall{height:360px}
.chart.short{height:240px}

/* ---- map ---------------------------------------------------------- */
.map-wrap{position:relative;width:100%;height:520px;border-radius:12px;overflow:hidden;background:#e9edf0;border:1px solid var(--line)}
.deck-host{position:absolute;inset:0;z-index:0}
.deck-host canvas{position:absolute;inset:0;outline:none}
.map-fallback{position:absolute;inset:0;z-index:6;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--muted);font-size:.85rem;line-height:1.5;padding:24px;background:#eef1f4}
.map-legend{position:absolute;right:12px;top:12px;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:.74rem;box-shadow:var(--shadow);z-index:5}
.map-legend .row{display:flex;align-items:center;gap:7px;margin:3px 0}
.map-legend .sw{width:11px;height:11px;border-radius:3px}
.map-attrib{position:absolute;left:8px;bottom:6px;font-size:.62rem;color:#5a6470;background:rgba(255,255,255,.78);padding:1px 6px;border-radius:4px;z-index:5}
.map-ctrls{position:absolute;right:12px;bottom:12px;z-index:5;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:10px;padding:9px 11px;box-shadow:var(--shadow);display:flex;gap:14px;align-items:center;font-size:.76rem}
.map-ctrls label{display:flex;align-items:center;gap:5px;cursor:pointer;color:var(--txt-2)}

/* ---- table -------------------------------------------------------- */
.tbl{width:100%;border-collapse:collapse;font-size:.82rem}
.tbl th,.tbl td{padding:9px 12px;text-align:left;border-bottom:1px solid var(--line-2)}
.tbl th{font-size:.66rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
.tbl tbody tr:hover{background:var(--panel-2)}
.tbl td.num,.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}
.bar-cell{position:relative}
.bar-cell .fill{position:absolute;left:0;top:50%;transform:translateY(-50%);height:60%;background:var(--orange-tint2);border-radius:4px;z-index:0}
.bar-cell span{position:relative;z-index:1}
.pill{display:inline-block;padding:2px 9px;border-radius:20px;font-size:.7rem;font-weight:600}

.section-title{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700;margin:6px 0 12px}
.hidden{display:none!important}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:#d4d8de;border-radius:6px}

/* ==== responsive (Bootstrap) ==== */
/* mobile top bar */
.mobile-topbar{display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:1030;
  background:var(--panel);border-bottom:1px solid var(--line);padding:10px 14px}
.mobile-topbar .mobile-brand{font-weight:800;font-size:1.05rem;letter-spacing:-.01em}
.mobile-topbar .mobile-brand .g{color:var(--txt)}
.mobile-topbar .mobile-brand .t{color:var(--orange)}
.btn-burger{background:var(--panel-2);border:1px solid var(--line);border-radius:9px;
  width:40px;height:40px;display:grid;place-items:center;color:var(--txt);cursor:pointer;padding:0}

/* custom date inputs */
.flt-date{appearance:none;background:var(--panel-2);border:1px solid var(--line);border-radius:9px;
  padding:7px 10px;font-size:.84rem;color:var(--txt);font-family:inherit;min-width:150px}
.flt-date:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-tint2)}

/* sidebar as a static panel at lg+ (override Bootstrap offcanvas) */
@media (min-width:992px){
  #sidebar.offcanvas{position:sticky;top:0;height:100vh;width:var(--sidebar);
    transform:none!important;visibility:visible!important;
    background:var(--panel)!important;border-right:1px solid var(--line);
    z-index:auto;transition:none}
  #sidebar.offcanvas .btn-close{display:none}
}

/* sidebar as a slide-in drawer below lg */
@media (max-width:991.98px){
  #sidebar.offcanvas{--bs-offcanvas-width:272px}
  .content{padding:16px 14px 40px}
  .topbar{position:static;padding:12px 16px}
  .page-title h1{font-size:1.08rem}
  .page-title p{display:none}
  .filterbar{gap:10px;padding:10px 12px}
  .flt{min-width:0;flex:1 1 46%}
  .flt select,.flt-date{min-width:0;width:100%}
  .flt-seg{width:100%}
  .reset-btn{margin-left:0;width:100%}
  .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .kpi .k-val{font-size:1.4rem}
  .chart{height:260px}
  .chart.tall{height:300px}
  .map-wrap{height:380px}
  .map-ctrls{flex-wrap:wrap;gap:8px;font-size:.72rem}
}
@media (max-width:520px){
  .kpi-grid{grid-template-columns:1fr}
}
