/* Sightline InSight — operations console theme (Sightline brand)
   Charcoal structure, Athletic Gold accent, priority signals P0→P4. */
:root{
  --asphalt:#262626; --asphalt-2:#2e2e2e; --asphalt-3:#3b3b3b;
  --line:#4a4a4a; --ink:#ffffff; --ink-dim:#b8b8b8;
  --paint-yellow:#ffb400; --paint-white:#fafbfc;
  --p0:#a31621; --p1:#e5484d; --p2:#f0883e; --p3:#ffb400; --p4:#4caf6e;
  --mono:'IBM Plex Mono',monospace; --cond:'Barlow Condensed',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Barlow','Roboto','Open Sans',sans-serif;background:var(--asphalt);color:var(--ink);overflow:hidden}

/* ---------- header ---------- */
.topbar{display:flex;align-items:center;justify-content:space-between;height:58px;
  padding:0 18px;background:var(--asphalt-2);border-bottom:1px solid var(--line);position:relative}
.topbar::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;
  background:repeating-linear-gradient(90deg,var(--paint-yellow) 0 28px,transparent 28px 44px);opacity:.85}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{display:flex;flex-direction:column;gap:3px;width:30px}
.brand-mark span{height:4px;background:var(--paint-white);border-radius:1px}
.brand-mark span:nth-child(2){background:var(--paint-yellow);width:72%}
.brand-mark span:nth-child(3){width:46%}
.brand-name{font-weight:700;letter-spacing:.14em;font-size:15px}
.brand-name em{font-style:normal;color:var(--paint-yellow);letter-spacing:.04em;font-weight:600}
.brand-sub{font-size:12px;color:var(--ink-dim)}
.topbar-right{display:flex;align-items:center;gap:12px}
.vbtn{background:var(--asphalt-3);color:var(--ink-dim);border:1px solid var(--line);padding:7px 14px;font-family:'Barlow';font-size:13px;font-weight:500;cursor:pointer;border-radius:7px}
.vbtn:hover{color:var(--ink)}
.vbtn.solo.active{background:var(--paint-yellow);color:#1a1606;font-weight:600;border-color:var(--paint-yellow)}
.cycle-label{font-family:var(--cond);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim)}
.cycle-select,.filter-select{background:var(--asphalt-3);color:var(--ink);border:1px solid var(--line);
  border-radius:6px;padding:7px 10px;font-family:'Barlow';font-size:13px}
.btn-report{background:var(--paint-yellow);color:#1a1606;font-weight:600;font-size:13px;padding:8px 14px;border-radius:6px;text-decoration:none}

/* ---------- layout ---------- */
.layout{display:flex;height:calc(100% - 58px);position:relative}
.dash{width:330px;min-width:330px;background:var(--asphalt-2);border-right:1px solid var(--line);overflow-y:auto;padding:18px 16px 28px;z-index:1}
.view{flex:1;position:relative;z-index:0}
.map-wrap{background:#0c0f13}
#map{width:100%;height:100%;position:absolute;inset:0;z-index:0}

/* ---------- MCI gauge ---------- */
.mci-block{text-align:center;margin-bottom:14px}
.mci-gauge{position:relative;width:200px;margin:0 auto}
.mci-gauge svg{width:100%}
.gauge-track,.gauge-fill{fill:none;stroke-width:14;stroke-linecap:round}
.gauge-track{stroke:var(--asphalt-3)}
.gauge-fill{stroke:var(--paint-yellow);stroke-dasharray:251;stroke-dashoffset:251;transition:stroke-dashoffset .9s ease}
.mci-number{position:absolute;left:0;right:0;bottom:4px;font-family:var(--mono);font-weight:600;font-size:42px;line-height:1}
.mci-number small{font-size:14px;color:var(--ink-dim);font-weight:400}
.mci-caption{font-family:var(--cond);letter-spacing:.16em;text-transform:uppercase;font-size:12px;color:var(--ink-dim);margin-top:2px}
.mci-benchmark{font-size:12px;color:var(--ink-dim);margin-top:4px}
.mci-benchmark b{color:var(--p4);font-weight:600}

/* ---------- components ---------- */
.components{display:flex;flex-direction:column;gap:9px;margin:6px 0 18px}
.comp-row{display:grid;grid-template-columns:86px 1fr 38px;align-items:center;gap:8px}
.comp-name{font-family:var(--cond);font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-dim)}
.comp-bar{height:8px;background:var(--asphalt-3);border-radius:4px;overflow:hidden}
.comp-bar i{display:block;height:100%;width:0;background:var(--paint-white);border-radius:4px;transition:width .8s ease}
.comp-val{font-family:var(--mono);font-size:13px;text-align:right}

/* ---------- trend ---------- */
.dash-h{font-family:var(--cond);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);margin:4px 0 10px;display:flex;justify-content:space-between;align-items:baseline}
.dash-h-note{font-size:11px;letter-spacing:.04em;text-transform:none;color:var(--ink-dim);opacity:.7}
.trend-section{margin-bottom:18px}
.trend-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:8px}
.trend-cell{position:relative;background:var(--asphalt-3);border:1px solid var(--line);border-radius:8px;padding:10px 6px;text-align:center;cursor:pointer;font-family:'Barlow';color:var(--ink);transition:transform .12s,border-color .12s}
.trend-cell:hover{transform:translateY(-1px);border-color:var(--ink-dim)}
.trend-cell.current{border-color:var(--paint-yellow);box-shadow:0 0 0 1px var(--paint-yellow)}
.t-v{font-family:var(--mono);font-size:18px;font-weight:600}
.t-k{font-size:10.5px;color:var(--ink-dim);font-family:var(--cond);letter-spacing:.08em;text-transform:uppercase;margin-top:2px}
.t-d{position:absolute;top:6px;right:7px;font-size:10px;font-family:var(--mono)}
.t-d.up{color:var(--p4)} .t-d.down{color:var(--p1)}

/* ---------- priority chips ---------- */
.prio-chips{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:18px}
.chip{border:1px solid var(--line);border-radius:8px;padding:8px 4px;text-align:center;cursor:pointer;background:var(--asphalt-3);transition:transform .12s,border-color .12s}
.chip:hover{transform:translateY(-1px)}
.chip.active{border-color:var(--paint-white);box-shadow:0 0 0 1px var(--paint-white)}
.chip .dot{width:10px;height:10px;border-radius:50%;margin:0 auto 5px}
.chip .n{font-family:var(--mono);font-size:16px;font-weight:600}
.chip .lbl{font-size:10px;color:var(--ink-dim)}

/* ---------- filters ---------- */
.filters{margin-bottom:18px;display:flex;flex-direction:column;gap:8px}
.filter-label{font-family:var(--cond);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim)}
.check-filter{font-size:13px;color:var(--ink-dim);display:flex;gap:8px;align-items:center;cursor:pointer}
.check-filter input{accent-color:var(--paint-yellow)}

/* ---------- hot list ---------- */
.hot-list{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.hot-item{display:flex;align-items:center;gap:10px;background:var(--asphalt-3);border:1px solid var(--line);border-left:4px solid var(--p1);border-radius:6px;padding:8px 10px;cursor:pointer;transition:background .12s}
.hot-item:hover{background:#454545}
.hot-item.p0{border-left-color:var(--p0)}
.hot-name{font-size:12.5px;line-height:1.25;flex:1}
.hot-score{font-family:var(--mono);font-size:13px;color:var(--ink-dim)}
.hot-more{font-size:12px;color:var(--ink-dim);cursor:pointer;background:none;border:none;padding:6px;font-family:'Barlow'}
.hot-more:hover{color:var(--ink)}

/* ---------- quantities ---------- */
.qty-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.qty-cell{background:var(--asphalt-3);border:1px solid var(--line);border-radius:8px;padding:10px 8px;text-align:center}
.qty-cell.clickable{cursor:pointer;transition:transform .12s,border-color .12s}
.qty-cell.clickable:hover{transform:translateY(-1px);border-color:var(--paint-yellow)}
.qty-cell .v{font-family:var(--mono);font-size:15px;font-weight:600}
.qty-cell .k{font-size:10.5px;color:var(--ink-dim);margin-top:2px;text-transform:uppercase;letter-spacing:.06em;font-family:var(--cond)}
.qty-h{margin-bottom:2px}
.qty-sub{font-size:11px;color:var(--ink-dim);margin-bottom:10px;letter-spacing:.02em}
.qty-cost{font-family:var(--mono);font-size:12px;color:var(--paint-yellow);margin-top:4px;font-weight:600}

/* ---------- legend ---------- */
.legend{position:absolute;bottom:22px;left:14px;background:rgba(21,25,31,.92);border:1px solid var(--line);border-radius:8px;padding:10px 12px;display:flex;gap:12px;font-size:12px;z-index:1000;backdrop-filter:blur(4px);flex-wrap:wrap;max-width:60%}
.legend .li{display:flex;align-items:center;gap:6px}
.legend .dot{width:11px;height:11px;border-radius:50%;border:1.5px solid rgba(255,255,255,.7)}

/* ---------- right panel ---------- */
.panel{position:absolute;top:0;right:0;bottom:0;width:410px;background:var(--asphalt-2);border-left:1px solid var(--line);overflow-y:auto;z-index:1600;box-shadow:-12px 0 30px rgba(0,0,0,.45)}
.panel-close{position:sticky;top:8px;margin-left:calc(100% - 44px);width:34px;height:34px;border-radius:50%;background:var(--asphalt-3);color:var(--ink);border:1px solid var(--line);font-size:18px;cursor:pointer;z-index:3}
.panel-body{padding:0 20px 30px;margin-top:-26px}
.d-prio{display:inline-block;font-family:var(--cond);font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:5px;color:#fff;margin-bottom:10px}
.d-name{font-size:19px;font-weight:600;line-height:1.25;margin-bottom:2px}
.d-area{font-size:13px;color:var(--ink-dim);margin-bottom:14px}

/* panel tabs */
.ptabs{display:flex;gap:4px;margin-bottom:14px;border-bottom:1px solid var(--line)}
.ptab{background:none;border:none;color:var(--ink-dim);padding:9px 14px;font-family:'Barlow';font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.ptab.active{color:var(--paint-yellow);border-bottom-color:var(--paint-yellow)}
.ptab-pane{display:none} .ptab-pane.active{display:block}

.d-scores{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.d-score{background:var(--asphalt-3);border-radius:8px;padding:9px 6px;text-align:center}
.d-score .v{font-family:var(--mono);font-size:17px;font-weight:600}
.d-score .k{font-size:10px;font-family:var(--cond);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim)}
.d-sec{font-family:var(--cond);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);margin:16px 0 8px;border-bottom:1px solid var(--line);padding-bottom:5px}
.grade-table{width:100%;border-collapse:collapse;font-size:13px}
.grade-table td{padding:5px 2px;border-bottom:1px solid #333}
.grade-table td:last-child{text-align:right;font-family:var(--mono);font-size:12.5px}
.g-Excellent{color:var(--p4)} .g-Good{color:#9fd48a} .g-Fair{color:var(--p3)} .g-Poor{color:var(--p1)}
.g-Compliant{color:var(--p4)} .g-NonCompliant{color:var(--p1)} .g-null{color:var(--ink-dim)}
.d-flags{display:flex;flex-wrap:wrap;gap:6px}
.flag{font-size:12px;padding:4px 10px;border-radius:20px;border:1px solid var(--line);color:var(--ink-dim)}
.flag.on{background:var(--paint-yellow);border-color:var(--paint-yellow);color:#1a1606;font-weight:600}
.d-comments{font-size:13.5px;line-height:1.5;color:var(--ink);background:var(--asphalt-3);border-left:3px solid var(--paint-yellow);padding:10px 12px;border-radius:0 6px 6px 0}
.d-photos{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.photo-link{display:block;background:var(--asphalt-3);border:1px dashed var(--line);border-radius:8px;padding:18px 8px;text-align:center;color:var(--ink-dim);font-size:12.5px;text-decoration:none}
.photo-img{width:100%;border-radius:8px;display:block;aspect-ratio:4/3;object-fit:cover}
.d-qty{display:flex;gap:8px;flex-wrap:wrap}
.d-qty .qty-cell{flex:1;min-width:80px}

/* work-tracking form (mockup) */
.wt-row{margin-bottom:12px}
.wt-label{font-family:var(--cond);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);display:block;margin-bottom:5px}
.wt-input,.wt-select,.wt-text{width:100%;background:var(--asphalt-3);color:var(--ink);border:1px solid var(--line);border-radius:6px;padding:9px 10px;font-family:'Barlow';font-size:13px}
.wt-text{min-height:64px;resize:vertical}
.status-track{display:flex;gap:4px;margin-bottom:6px}
.status-step{flex:1;text-align:center;font-size:10.5px;font-family:var(--cond);letter-spacing:.04em;text-transform:uppercase;padding:7px 2px;background:var(--asphalt-3);border:1px solid var(--line);color:var(--ink-dim);cursor:pointer}
.status-step:first-child{border-radius:6px 0 0 6px} .status-step:last-child{border-radius:0 6px 6px 0}
.status-step.on{background:var(--paint-yellow);color:#1a1606;font-weight:600;border-color:var(--paint-yellow)}
.upload-slots{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.upload-slot{background:var(--asphalt-3);border:1px dashed var(--line);border-radius:8px;padding:20px 8px;text-align:center;color:var(--ink-dim);font-size:12px;cursor:pointer}
.upload-slot:hover{border-color:var(--paint-yellow);color:var(--ink)}
.upload-slot .ic{font-size:20px;display:block;margin-bottom:4px}
.flag-q{display:flex;align-items:center;gap:8px;background:rgba(229,72,77,.12);border:1px solid var(--p1);border-radius:6px;padding:9px 11px;font-size:12.5px;color:#ffb4b4;margin-bottom:12px;cursor:pointer}
.wt-save{width:100%;background:var(--paint-yellow);color:#1a1606;font-weight:600;border:none;border-radius:6px;padding:11px;font-family:'Barlow';font-size:14px;cursor:pointer;margin-top:4px}
.wt-note{font-size:11.5px;color:var(--ink-dim);text-align:center;margin-top:8px;font-style:italic}

/* quantity drill-down */
.qd-summary{font-family:var(--mono);font-size:26px;font-weight:600;color:var(--paint-yellow)}
.qd-sub{font-size:13px;color:var(--ink-dim);margin-bottom:14px}
.qd-chart{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.qd-bar-row{display:grid;grid-template-columns:120px 1fr 64px;align-items:center;gap:8px;font-size:12px}
.qd-bar-row .nm{color:var(--ink-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qd-bar{height:16px;background:var(--asphalt-3);border-radius:3px;overflow:hidden;display:flex}
.qd-bar i{height:100%;display:block}
.qd-bar .w{background:var(--paint-white)} .qd-bar .y{background:var(--paint-yellow)} .qd-bar .k{background:#555}
.qd-bar-row .vv{font-family:var(--mono);text-align:right}
.qd-list{list-style:none;margin-top:6px}
.qd-item{display:flex;justify-content:space-between;gap:8px;padding:8px 6px;border-bottom:1px solid #333;cursor:pointer;font-size:12.5px}
.qd-item:hover{background:var(--asphalt-3)}
.qd-item .qn{flex:1} .qd-item .qv{font-family:var(--mono);color:var(--ink-dim)}
.qd-grp{font-family:var(--cond);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--paint-yellow);margin:12px 0 2px}

/* ---------- layer switch (header) ---------- */
.layer-switch{display:flex;background:var(--asphalt-3);border:1px solid var(--line);border-radius:7px;overflow:hidden}
.lbtn{background:transparent;color:var(--ink-dim);border:none;border-right:1px solid var(--line);padding:7px 12px;font-family:'Barlow';font-size:12.5px;cursor:pointer}
.lbtn:last-child{border-right:none}
.lbtn:hover:not(:disabled){color:var(--ink)}
.lbtn.active{background:var(--paint-yellow);color:#1a1606;font-weight:600}
.lbtn:disabled{opacity:.4;cursor:not-allowed}

/* ---------- docked master checklist (narrow right index) ---------- */
.checklist-dock{position:absolute;top:0;right:0;bottom:0;width:340px;background:var(--asphalt-2);border-left:1px solid var(--line);z-index:1500;display:none;flex-direction:column;box-shadow:-12px 0 30px rgba(0,0,0,.4)}
.checklist-dock.open{display:flex}
.cd-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px}
.cd-title{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}
.cd-close{width:30px;height:30px;border-radius:50%;background:var(--asphalt-3);color:var(--ink);border:1px solid var(--line);font-size:17px;cursor:pointer}
.cd-controls{padding:0 16px 12px;border-bottom:1px solid var(--line)}
.cl-search{width:100%;background:var(--asphalt-3);color:var(--ink);border:1px solid var(--line);border-radius:6px;padding:8px 11px;font-family:'Barlow';font-size:13px;margin-bottom:8px}
.cd-row2{display:flex;gap:6px}
.cd-row2 .filter-select{flex:1;min-width:0;padding:7px 8px;font-size:12px}
.btn-ghost{background:transparent;color:var(--ink-dim);border:1px solid var(--line);border-radius:6px;padding:7px 11px;font-family:'Barlow';font-size:14px;cursor:pointer}
.btn-ghost:hover{color:var(--ink);border-color:var(--ink-dim)}
.cd-list{list-style:none;overflow-y:auto;flex:1;padding:8px 12px 20px}
.cd-item{display:flex;align-items:center;gap:10px;padding:9px 8px;border-bottom:1px solid #333;cursor:pointer}
.cd-item:hover{background:var(--asphalt-3)}
.cd-pdot{width:18px;text-align:center;font-family:var(--mono);font-size:12px;font-weight:600;color:#fff;border-radius:4px;padding:2px 0;flex-shrink:0}
.cd-nm{flex:1;font-size:12.5px;line-height:1.25;min-width:0}
.cd-st{font-size:10px;font-family:var(--cond);letter-spacing:.05em;text-transform:uppercase;padding:3px 8px;border-radius:20px;border:1px solid var(--line);color:var(--ink-dim);white-space:nowrap;flex-shrink:0}
.cd-group-wrap{margin-top:8px}
.cd-group-label{font-family:var(--cond);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:6px}
.cd-group-hint{font-size:10px;letter-spacing:.02em;text-transform:none;opacity:.7}
.cd-area-chips{display:flex;flex-wrap:wrap;gap:5px}
.cd-achip{background:var(--asphalt-3);border:1px solid var(--line);border-radius:20px;padding:4px 10px;font-size:11px;cursor:pointer;color:var(--ink-dim);transition:background .1s,border-color .1s;white-space:nowrap}
.cd-achip:hover{color:var(--ink)}
.cd-achip.sel{background:rgba(255,180,0,.18);border-color:var(--paint-yellow);color:var(--paint-yellow);font-weight:600}
.cd-totals{margin-top:10px;background:var(--asphalt-3);border:1px solid var(--paint-yellow);border-radius:8px;padding:10px 12px}
.cd-totals-title{font-family:var(--cond);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--paint-yellow);margin-bottom:8px}
.cd-totals-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.cd-tot{text-align:center}
.cd-tot .v{font-family:var(--mono);font-size:14px;font-weight:600}
.cd-tot .k{font-size:10px;color:var(--ink-dim);font-family:var(--cond);letter-spacing:.06em;text-transform:uppercase;margin-top:1px}
.cd-st.completed,.cd-st.verified{background:rgba(76,175,110,.15);border-color:var(--p4);color:#a8e0bd}
.cd-st.in-progress,.cd-st.scheduled{background:rgba(255,180,0,.12);border-color:var(--paint-yellow);color:var(--paint-yellow)}
.mock-badge{font-size:11px;font-weight:500;background:rgba(255,180,0,.15);color:var(--paint-yellow);border:1px solid var(--paint-yellow);border-radius:20px;padding:2px 9px;letter-spacing:.02em}
/* when checklist dock is open, detail panel sits to its left */
body.dock-open .panel{right:340px}

@media (max-width:900px){
  body{overflow:auto}
  .layout{flex-direction:column;height:auto}
  .dash{width:100%;min-width:0;order:2}
  .view{height:64vh;order:1}
  .panel,.checklist-dock{position:fixed;width:100%;top:auto;height:78vh;bottom:0;border-radius:14px 14px 0 0;z-index:1600}
  body.dock-open .panel{right:0}
  .topbar-right{gap:8px;flex-wrap:wrap}
}
@media (prefers-reduced-motion:reduce){.gauge-fill,.comp-bar i{transition:none}}
