*{box-sizing:border-box;margin:0;padding:0}
:root{
    --red:#CC0000;--blue:#7C3AED;--dark:#2E1A47;--sl:#3B2758;
    --li:#FAFAFF;--bo:#EDE8F5;--gr:#9B92B3;
    --fn:'Barlow',sans-serif;--fc:'Barlow Condensed',sans-serif;
  }
body{font-family:var(--fn);background:var(--li);color:var(--dark);font-size:14px;min-height:100vh}
.nav{background:var(--dark);display:flex;align-items:center;height:52px;padding:0 16px;gap:12px;position:sticky;top:0;z-index:200;box-shadow:0 2px 12px rgba(0,0,0,.45)}
.logo{display:flex;align-items:center;gap:9px;flex-shrink:0}
.bn{font-family:var(--fc);font-size:19px;font-weight:700;color:var(--dark);letter-spacing:1px}
.bt{font-size:9px;font-weight:600;letter-spacing:2px;color:rgba(255,255,255,.38);text-transform:uppercase}
.nls{display:flex;overflow-x:auto;scrollbar-width:none;flex:1;margin-left:16px}
.nls::-webkit-scrollbar{display:none}
.nl{padding:0 13px;height:52px;display:flex;align-items:center;font-size:11px;font-weight:700;color:rgba(255,255,255,.48);cursor:pointer;white-space:nowrap;border-bottom:3px solid transparent;letter-spacing:.5px;text-transform:uppercase;transition:color .15s,border-color .15s;user-select:none}
.nl:hover{color:rgba(255,255,255,.8)}.nl.on{color:#fff;border-bottom-color:var(--red)}
.project-badge{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:3px 10px;font-size:11px;font-weight:700;color:#fff;white-space:nowrap;cursor:pointer;margin-left:auto;flex-shrink:0}
.project-badge:hover{background:rgba(255,255,255,.18)}
.main{max-width:1320px;margin:0 auto;padding:20px 16px}
.pg{display:none}.pg.on{display:block}
.ph{margin-bottom:18px;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:10px}
.pt{font-family:var(--fc);font-size:24px;font-weight:700;line-height:1}.pt span{color:var(--red)}
.ps{font-size:12px;color:var(--gr);margin-top:3px}
.card{background:#fff;border:1px solid var(--bo);border-radius:10px;padding:18px}
.ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--bo)}
.ct{font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--sl)}
.mc{background:#fff;border:1px solid var(--bo);border-radius:10px;padding:14px 16px}
.ml{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--gr)}
.mv{font-size:26px;font-weight:700;font-family:var(--fc);color:var(--dark);line-height:1.1;margin:3px 0}
.ms{font-size:11px;color:var(--gr)}
.mc.ab{border-top:3px solid var(--blue)}.mc.ar{border-top:3px solid var(--red)}.mc.ag{border-top:3px solid #059669}.mc.aw{border-top:3px solid #d97706}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:860px){.g2{grid-template-columns:1fr}.g3{grid-template-columns:1fr 1fr}.g4{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.g3,.g4{grid-template-columns:1fr 1fr}}
.fr{display:flex;gap:10px;flex-wrap:wrap}
.fg{display:flex;flex-direction:column;gap:4px;flex:1;min-width:140px}.fg.w{min-width:100%;flex:none}
.lbl{font-size:11px;font-weight:700;color:var(--sl)}
input,select,textarea{border:1px solid var(--bo);border-radius:6px;padding:7px 10px;font-family:var(--fn);font-size:13px;color:var(--dark);background:#fff;outline:none;width:100%;transition:border-color .15s}
input:focus,select:focus,textarea:focus{border-color:var(--blue)}
/* Phase 1.A.3 — checkbox row utility. The global input rule above sets
   width:100% which mangles native checkboxes; .styled-cb explicitly resets
   size + alignment + brand color. .cb-row is the flex container for the
   checkbox + label text; wrap the text in <span> so both children are
   proper flex items. */
input[type="checkbox"].styled-cb{width:16px;height:16px;accent-color:var(--blue);cursor:pointer;margin:0;flex-shrink:0;padding:0}
.cb-row{display:flex;align-items:center;gap:10px;font-size:12px;cursor:pointer;user-select:none;white-space:nowrap}
.btn{padding:7px 16px;border-radius:6px;font-family:var(--fn);font-size:12.5px;font-weight:600;cursor:pointer;border:none;display:inline-flex;align-items:center;gap:5px;transition:opacity .15s,transform .1s;white-space:nowrap}
.btn:active{transform:scale(.97)}
.bp{background:var(--blue);color:#fff}.bp:hover{opacity:.88}
.br{background:var(--red);color:#fff}.br:hover{opacity:.88}
.bg{background:transparent;color:var(--blue);border:1px solid var(--blue)}.bg:hover{background:#eef3fb}
.bgg{background:transparent;color:#059669;border:1px solid #059669}.bgg:hover{background:#f0fdf4}
.sm{padding:5px 11px;font-size:11.5px}
.ic{padding:5px 7px;border-radius:6px;background:transparent;border:1px solid var(--bo);cursor:pointer;display:inline-flex;align-items:center;color:var(--gr);transition:all .15s;font-size:13px}
.ic:hover{background:var(--li);color:var(--dark)}
.tw{overflow-x:auto;border-radius:8px;border:1px solid var(--bo)}
table{width:100%;border-collapse:collapse;font-size:12.5px}
thead th{background:var(--li);color:var(--sl);font-weight:700;font-size:10.5px;letter-spacing:.5px;text-transform:uppercase;padding:9px 12px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--bo)}
tbody tr{border-bottom:1px solid #f0f2f8;transition:background .1s}
tbody tr:hover{background:#f8f9fd}tbody tr:last-child{border-bottom:none}
td{padding:9px 12px;vertical-align:middle}
.b{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10.5px;font-weight:700;white-space:nowrap}
.bb{background:#dbeafe;color:#1e40af}.bg2{background:#d1fae5;color:#065f46}.br2{background:#fee2e2;color:#b91c1c}
.ba{background:#fef3c7;color:#92400e}.bn{background:#f1f5f9;color:#475569}
.row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.btwn{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.div{height:1px;background:var(--bo);margin:14px 0}
.empty{text-align:center;padding:36px 20px;color:var(--gr)}.empty .ei{font-size:32px;margin-bottom:8px;opacity:.3}
.pill{display:flex;gap:6px;flex-wrap:wrap}
.jtab{padding:5px 13px;border-radius:20px;font-size:11.5px;font-weight:600;cursor:pointer;border:1px solid var(--bo);background:#fff;color:var(--gr);transition:all .15s;white-space:nowrap}
.jtab.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.toast{position:fixed;bottom:20px;right:20px;background:var(--dark);color:#fff;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:500;z-index:1000;display:none;gap:8px;align-items:center;box-shadow:0 4px 20px rgba(0,0,0,.3)}.toast.on{display:flex}
.mo{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;align-items:center;justify-content:center;padding:16px}.mo.on{display:flex}
/* Phase 1.A.3 — modals that open on top of another already-open modal
   (e.g. customer-edit on top of customer-detail). DOM order alone can't
   guarantee correct stacking once we have nested modal flows. */
.mo.mo-stack-top{z-index:510}
.md{background:#fff;border-radius:12px;padding:22px;width:100%;max-width:580px;max-height:92vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.25)}.md.wide{max-width:740px}.md.xl{max-width:900px}
.mh{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--bo)}
.mt{font-size:15px;font-weight:700}
.xb{cursor:pointer;font-size:18px;color:var(--gr);border:none;background:none;padding:0}
.gantt-outer{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:0 0 8px 8px}
.gh{display:flex;background:#fff;border-bottom:2px solid #111;min-width:max-content;position:sticky;top:0;z-index:12}
.gh-pin{position:sticky;left:0;z-index:13;flex-shrink:0;padding:7px 12px;border-right:0.5px solid #f1f5f9;font-size:10px;font-weight:500;letter-spacing:.5px;text-transform:uppercase;color:#94a3b8;background:#fff;display:flex;align-items:center}
.gh-days{display:flex;flex-shrink:0}
.gday{flex-shrink:0;border-right:1px solid #e8ecf5}
.gday-lbl{font-size:10px;font-weight:700;color:var(--sl);padding:3px 5px;border-bottom:1px solid #e8ecf5;white-space:nowrap;background:var(--li)}
.ghrs{display:flex}
.ghr{font-size:8.5px;color:var(--gr);text-align:center;border-right:1px solid #f0f3fa;padding:2px 0;flex-shrink:0}
.grow{display:flex;min-height:44px;border-bottom:0.5px solid #f1f5f9;min-width:max-content;border-left:2px solid transparent}
.grow:last-child{border-bottom:none}
.gpin{position:sticky;left:0;z-index:8;flex-shrink:0;padding:5px 10px;border-right:0.5px solid #f1f5f9;display:flex;flex-direction:column;justify-content:center;min-height:44px;background:#fff}
.grow:hover .gpin{background:#f8f9fd}
.gi-top{font-weight:500;font-size:11px;color:#111;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.gi-sub{font-size:9px;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.gi-time{font-size:10px;color:var(--blue);margin-top:1px;white-space:nowrap}
.garea{position:relative;overflow:hidden;min-height:44px;flex-shrink:0}
.wg-hdr{display:flex;background:#fafafa;border-bottom:0.5px solid #f1f5f9;min-width:max-content}
.wg-pin{position:sticky;left:0;z-index:8;flex-shrink:0;padding:6px 12px;font-size:10px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px;border-right:0.5px solid #f1f5f9;background:#fafafa;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gbar{position:absolute;top:8px;height:22px;border-radius:3px;display:flex;align-items:center;padding:0 8px;font-size:9px;font-weight:500;white-space:nowrap;overflow:hidden;cursor:pointer;opacity:.88;border-width:1.5px;border-style:solid;background:transparent;transition:opacity .15s}
.gbar:hover{filter:brightness(1.1)}
.gbar.done{opacity:.35!important;filter:grayscale(.5)}
.gbar.done .bl::before{content:'✓ '}
.today-ln{position:absolute;top:0;bottom:0;width:2px;background:var(--red);opacity:.4;pointer-events:none;z-index:2}
.vt-wrap{display:flex;gap:6px}
.vt{padding:5px 14px;border-radius:6px;font-size:11.5px;font-weight:600;cursor:pointer;border:1px solid var(--bo);background:#fff;color:var(--gr);transition:all .15s}
.vt.on{background:var(--sl);color:#fff;border-color:var(--sl)}
.tsh{background:var(--sl);color:#fff;padding:9px 14px;font-weight:700;font-size:12px;border-radius:6px 6px 0 0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none}
.tsh:hover{background:#16304f}
.tsh .ts-arrow{font-size:11px;opacity:.7;transition:transform .2s;display:inline-block}
.tsh.collapsed{border-radius:6px}
.tsh.collapsed .ts-arrow{transform:rotate(-90deg)}
.tsw{border:1px solid var(--bo);border-top:none;border-radius:0 0 8px 8px;overflow-x:auto;margin-bottom:16px;-webkit-overflow-scrolling:touch}
.tsw.collapsed{display:none;margin-bottom:6px}
.tsw table thead th{background:#eef3fb}
.tc input{width:46px;text-align:center;font-size:12px;padding:4px 3px}
.lot-card{background:#fff;border:1px solid var(--bo);border-radius:10px;overflow:hidden;margin-bottom:14px}
.lot-hdr{background:var(--sl);color:#fff;padding:10px 16px;display:flex;justify-content:space-between;align-items:center}
.unit-block{border-bottom:1px solid #f0f2f8}.unit-block:last-child{border-bottom:none}
.unit-row{display:grid;grid-template-columns:110px 1fr auto;gap:10px;align-items:center;padding:10px 16px;background:var(--li);cursor:pointer;transition:background .1s}.unit-row:hover{background:#e8edf8}
.pal-box{padding:0 16px;max-height:0;overflow:hidden;transition:max-height .3s ease}.pal-box.open{max-height:2000px}
.prow{display:grid;grid-template-columns:130px 100px 90px;gap:10px;padding:6px 0;border-bottom:1px solid #f5f6fb;font-size:12px}.prow:last-child{border-bottom:none}
.atabs{display:flex;gap:0;border-bottom:2px solid var(--bo);margin-bottom:14px;overflow-x:auto}
.atab{padding:8px 14px;font-size:12px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--gr);white-space:nowrap}.atab.on{color:var(--blue);border-bottom-color:var(--blue)}
.agrid{overflow-x:auto;-webkit-overflow-scrolling:touch}
.atbl{border-collapse:collapse;font-size:12px;min-width:500px;width:100%}
.atbl th{background:var(--li);padding:6px 8px;text-align:center;font-size:10px;font-weight:700;border:1px solid var(--bo)}
.atbl th.lh,.atbl th.fh{text-align:left}
.atbl td{padding:4px;border:1px solid #f0f2f8;vertical-align:middle}
.atbl td.ftd{padding:4px 8px;font-size:11px;font-weight:700;color:var(--sl);border:1px solid var(--bo);white-space:nowrap}
.atbl td.ltd{padding:4px 8px;font-size:11px;color:var(--gr);border:1px solid var(--bo);white-space:nowrap}
.ac input{width:50px;text-align:center;font-size:12px;padding:4px 3px;border:1px solid var(--bo);border-radius:4px}
.pass{background:#d1fae5!important}.fail{background:#fee2e2!important}
.pb{display:inline-block;padding:2px 7px;border-radius:3px;font-size:10px;font-weight:700}
.pb.p{background:#d1fae5;color:#065f46}.pb.f{background:#fee2e2;color:#b91c1c}.pb.n{background:#f1f5f9;color:#475569}
@media(max-width:600px){.ac input{width:42px;padding:3px 2px}}
.project-card{background:#fff;border:2px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;min-height:140px}
.project-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.25)}
.project-card.active{border-width:2px;box-shadow:0 0 0 2px rgba(124,58,237,.3),0 8px 24px rgba(0,0,0,.2)}
.project-card.active::after{content:'ACTIVE';position:absolute;top:10px;right:10px;font-size:9px;font-weight:700;letter-spacing:.8px;background:rgba(0,0,0,.45);color:#fff;padding:2px 7px;border-radius:10px;z-index:2;backdrop-filter:blur(4px)}
/* Illustrated job card — full-bleed PNG behind a gradient overlay */
.project-card.pc-illus{padding:14px;background:#0c0a1a}
.project-card.pc-illus .pc-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:0}
.project-card.pc-illus .pc-bg-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.55) 70%,rgba(0,0,0,.78) 100%);z-index:0;pointer-events:none}
.project-card.pc-illus .pc-num{text-shadow:0 1px 4px rgba(0,0,0,.65)}
.project-card.pc-illus .pc-name{text-shadow:0 1px 3px rgba(0,0,0,.7)}
.project-card.pc-illus .pc-meta{text-shadow:0 1px 3px rgba(0,0,0,.7)}
.pc-num{font-family:var(--fc);font-size:20px;font-weight:700;color:var(--sl)}
.pc-name{font-size:13px;font-weight:600;margin:3px 0}
.pc-meta{font-size:11px;color:var(--gr)}

/* ── SITE UPDATE TIMELINE ── */
.tl-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.tl-title{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:#94a3b8}
.tl-count{font-size:11px;color:#94a3b8;font-weight:500}
.tl-outer{position:relative}
.tl-scroll{max-height:520px;overflow-y:auto;overflow-x:hidden;padding-right:6px;scroll-behavior:smooth}
.tl-scroll::-webkit-scrollbar{width:5px}
.tl-scroll::-webkit-scrollbar-track{background:transparent}
.tl-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}
.tl-scroll::-webkit-scrollbar-thumb:hover{background:#94a3b8}
.tl-wrap{position:relative;padding-left:86px}
.tl-spine{position:absolute;left:70px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--sl) 0%,#cbd5e1 100%);border-radius:1px}
.tl-entry{position:relative;padding:0 0 24px 36px}
.tl-entry:last-child{padding-bottom:0}
.tl-dot{position:absolute;left:-16px;top:12px;width:10px;height:10px;border-radius:50%;border:2.5px solid #fff;z-index:2}
.tl-dot.sent{background:var(--blue);box-shadow:0 0 0 1.5px var(--blue)}
.tl-dot.draft{background:#d97706;box-shadow:0 0 0 1.5px #d97706}
.tl-dot.today{width:12px;height:12px;left:-17px;top:11px}
.tl-date{position:absolute;left:-84px;top:4px;width:56px;text-align:right}
.tl-day{font-size:22px;font-weight:800;color:var(--sl);line-height:1;font-family:var(--fc)}
.tl-dow{font-size:8px;font-weight:700;color:#94a3b8;letter-spacing:.6px;text-transform:uppercase;margin-top:2px}
.tl-panel{background:#fff;border:1px solid var(--bo);border-radius:8px;padding:12px 16px;transition:border-color .15s,box-shadow .15s;cursor:default}
.tl-panel:hover{border-color:#b4c4e0;box-shadow:0 2px 8px rgba(27,95,173,.06)}
.tl-entry:first-child .tl-panel{border-left:3px solid var(--red)}
.tl-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.tl-date-label{font-size:10px;font-weight:600;color:var(--gr);letter-spacing:.3px}
.tl-badge{font-size:8px;font-weight:700;padding:2px 8px;border-radius:2px;letter-spacing:.5px;text-transform:uppercase}
.tl-badge.sent{background:var(--sl);color:#fff}
.tl-badge.draft{background:#fef3c7;color:#92400e;border:1px solid #f59e0b}
.tl-ctrs{font-size:11px;color:var(--dark);font-weight:500;margin-bottom:3px;line-height:1.4}
.tl-meta{font-size:10px;color:#94a3b8;margin-bottom:8px}
.tl-actions{display:flex;gap:4px;flex-wrap:wrap}
.tl-btn{background:#f8fafc;border:1px solid var(--bo);border-radius:4px;padding:4px 10px;font-size:10px;color:#475569;cursor:pointer;font-weight:500;font-family:var(--fn);transition:all .12s}
.tl-btn:hover{background:#eef3fb;border-color:#b4c4e0;color:var(--sl)}
.tl-btn.del{border-color:#e2b4b4;color:#991b1b;background:#fff}
.tl-btn.del:hover{background:#fef2f2;border-color:#cc7a7a}
.tl-fade-top,.tl-fade-bot{pointer-events:none;position:absolute;left:0;right:0;height:28px;z-index:3}
.tl-fade-top{top:0;background:linear-gradient(180deg,var(--li) 0%,transparent 100%);display:none}
.tl-fade-bot{bottom:0;background:linear-gradient(0deg,var(--li) 0%,transparent 100%)}

/* ── INSTALL TRACKER ── */
/* TABS */
.dtabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;align-items:center}
.dtab{padding:8px 14px;border-radius:8px;border:2px solid var(--border);cursor:pointer;font-size:12px;font-weight:700;color:var(--gr);background:#fff;user-select:none}
.dtab.on{border-color:var(--blue);color:var(--blue);background:rgba(27,95,173,.06)}
.dtab-prog{font-size:10px;font-weight:400;margin-top:2px}

/* TOOLBAR */
.toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 14px;background:#fff;border:1px solid var(--border);border-radius:8px;margin-bottom:10px}
.mode-pill{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.4px}
.mode-view{background:#d1fae5;color:#065f46}
.mode-draw{background:#fee2e2;color:#b91c1c}

/* HINT BAR */
.hint-bar{display:none;align-items:center;gap:10px;padding:10px 14px;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;margin-bottom:8px;font-size:13px;color:#92400e}

/* GRID CONFIG */
.grid-cfg{display:none;align-items:flex-end;gap:10px;flex-wrap:wrap;padding:12px 14px;background:#f0f4ff;border:1px solid #c7d7f5;border-radius:8px;margin-bottom:8px}

/* DRAWING AREA  -  the key: position:relative wrapper with exact size */
#draw-wrap{
  position:relative;
  display:none;
  border:1px solid var(--border);
  border-radius:10px;
  overflow:auto;
  background:#e5e7eb;
  width:100%;
}
#draw-inner{
  position:relative;
  /* sized by JS to match image */
}
#bg-canvas{
  display:block;
  /* image drawn here */
}
#drag-canvas{
  position:absolute;
  top:0;left:0;
  /* drag rectangle drawn here */
  /* pointer-events set by JS */
}
#markers-div{
  position:absolute;
  top:0;left:0;
  /* bay/unit divs go here */
  pointer-events:none; /* toggled by JS */
}

/* LEGEND */
.legend{display:flex;gap:12px;flex-wrap:wrap;font-size:11px;padding:10px 14px;background:#fff;border:1px solid var(--border);border-radius:8px;margin-top:10px;align-items:center}
.sw{width:18px;height:13px;border-radius:2px;border:2px solid;display:inline-block;vertical-align:middle;margin-right:4px}

/* COMP LIST */
.comp-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;border:1px solid var(--border);background:#fafbff;margin-bottom:6px}
.comp-name{flex:1;font-size:13px}
.cbtns{display:flex;gap:4px}
.cbtn{padding:4px 9px;border-radius:5px;font-size:11px;font-weight:700;cursor:pointer;border:1px solid var(--border);background:#fff;color:var(--gr)}
.cbtn.done{background:#d1fae5;border-color:#059669;color:#065f46}
.cbtn.na{background:#f1f5f9;border-color:#94a3b8;color:#475569}
.cbtn.reset.active{background:#f1f5f9;border-color:#94a3b8;color:#475569}

/* CONV STAGES */
.cstage{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;border:2px solid var(--border);cursor:pointer;margin-bottom:6px}
.cstage.active{border-width:2px}
.cdot{width:14px;height:14px;border-radius:50%;flex-shrink:0;border:2px solid}

/* PROG */
.prog-wrap{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:6px}
.prog-fill{height:100%;border-radius:3px;transition:width .3s}

/* EMPTY */
.empty{text-align:center;padding:80px 20px;color:var(--gr)}

/* ── EDITORIAL NAV + SIDEBAR ── */
body{background:#f8fafc!important}
.nav{background:#fff!important;border-bottom:none!important;box-shadow:0 2px 0 0 #111!important}
.nls{display:none!important}
.bn{color:#111!important;font-style:normal!important}
.bt{color:#94a3b8!important}
.project-badge{background:#fff!important;border:1px solid #111!important;color:#111!important;border-radius:2px!important;font-size:10px!important;font-weight:500!important}
.project-badge:hover{background:#f8fafc!important}
.app-wrap{display:flex;min-height:calc(100vh - 52px)}
.sidebar{width:196px;flex-shrink:0;background:linear-gradient(180deg,rgba(124,58,237,0.12) 0%,rgba(124,58,237,0.06) 40%,rgba(124,58,237,0.03) 100%);border-right:0.5px solid #dbe8f8;display:flex;flex-direction:column;padding:8px 0;position:sticky;top:52px;height:calc(100vh - 52px);overflow-y:auto}
.sb-sec{font-size:9px;text-transform:uppercase;letter-spacing:1.2px;color:#5B21B6;font-weight:700;padding:14px 16px 5px}
.sb-item{display:flex;align-items:center;gap:9px;padding:8px 16px;font-size:11px;font-weight:500;color:#64748b;cursor:pointer;border-left:2px solid transparent;user-select:none;white-space:nowrap;transition:transform .12s ease,background .12s ease,color .12s ease}
.sb-item:hover:not(.sb-on){color:#7C3AED;background:rgba(27,95,173,0.05);transform:translateX(3px) scale(1.03);transform-origin:left center}
.sb-item.sb-on{color:#7C3AED;border-left-color:#7C3AED;background:rgba(27,95,173,0.06);font-weight:500}
.sb-main{flex:1;overflow:hidden}
.mc{border-radius:8px!important;border:0.5px solid #e5e7eb!important;padding:18px 16px!important}
.mc.ab{border-top:2px solid #111!important}.mc.ar{border-top:3px solid #CC0000!important}.mc.ag{border-top:2px solid #6aab89!important}.mc.aw{border-top:2px solid #d97706!important}
.ml{font-size:9px!important;letter-spacing:.7px!important;color:#374151!important;font-weight:700!important}
.mv{font-size:20px!important}.ms{color:#64748b!important;font-size:11px!important}
.card{border:0.5px solid #e5e7eb!important;border-radius:8px!important}
.ch{border-bottom:1px solid #e5e7eb!important;padding:10px 14px!important}
.ct{color:#374151!important;font-size:9px!important;font-weight:700!important}
.main{background:#f8fafc;padding:32px 32px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.ph{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}
.si-dot-wrap{position:relative;display:flex;align-items:center;gap:4px;cursor:default}
.si-dot-wrap .si-tip{position:fixed;background:#fff;border:0.5px solid #e5e7eb;font-size:9px;font-weight:600;padding:3px 8px;border-radius:3px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;z-index:9999;box-shadow:0 2px 6px rgba(0,0,0,.1)}
.si-dot-wrap .si-tip::after{display:none}
.si-dot-wrap:hover .si-tip{opacity:1}
.bom-logo-card{background:#fff;border:0.5px solid #e5e7eb;border-radius:10px;overflow:hidden;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}
.bom-logo-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.08)}
/* ── MODE SWITCHER ── */
.mode-sw{padding:10px 16px 6px;cursor:pointer;user-select:none;position:relative}
.mode-sw-label{font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:#5B21B6;display:flex;align-items:center;gap:5px;transition:color .15s}
.mode-sw:hover .mode-sw-label{color:#7C3AED}
.mode-sw-arrow{font-size:7px;opacity:.6;transition:transform .15s}
.mode-flyout{display:none;position:fixed;width:200px;background:#fff;border:0.5px solid #dbe8f8;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.12);z-index:9999;padding:6px 0}
.mode-flyout-item{padding:8px 14px;cursor:pointer;font-size:11px;font-weight:500;color:#374151;display:flex;align-items:center;gap:8px;transition:background .1s}
.mode-flyout-item:hover{background:rgba(27,95,173,0.06)}
.mode-flyout-item.active{color:#7C3AED;font-weight:600}
.mode-flyout-item .mode-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
/* ── COMMISSIONING ── */
.com-hidden{display:none!important}
.shuttle-grid{display:flex;gap:21px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:8px}
.aisle-col{display:flex;flex-direction:column-reverse;gap:4px;width:180px;flex-shrink:0}
.shuttle-card{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;border-radius:6px;overflow:hidden;width:180px}
.shuttle-card:hover{transform:translateY(-1px);box-shadow:0 3px 12px rgba(0,0,0,.1)}
.shuttle-card svg{display:block;width:180px}
.aisle-section{margin-bottom:28px}
.aisle-label{text-align:center;font-family:var(--fc);font-size:12px;font-weight:700;color:var(--sl);padding:6px 0 4px;letter-spacing:.5px}
.com-stat{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.com-stat .mc{flex:1;min-width:140px}
/* ── SHUTTLE MEDICAL RECORD ── */
.smr-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.smr-back{cursor:pointer;font-size:13px;color:var(--blue);font-weight:600;display:flex;align-items:center;gap:4px;border:none;background:none;font-family:var(--fn);padding:0}
.smr-back:hover{text-decoration:underline}
.smr-title{font-family:var(--fc);font-size:22px;font-weight:700}
.smr-shuttle-card{max-width:480px;margin-bottom:20px}
.test-timeline{position:relative;padding-left:24px}
.test-entry{position:relative;padding:12px 0;border-bottom:1px solid #f0f2f8}
.test-entry:last-child{border-bottom:none}
.test-dot{position:absolute;left:-20px;top:16px;width:8px;height:8px;border-radius:50%;border:2px solid}
.test-dot.pass{border-color:#059669;background:#d1fae5}
.test-dot.fail{border-color:#dc2626;background:#fee2e2}
.test-dot.note{border-color:#d97706;background:#fef3c7}
/* ── FAULT TEST GRID ── */
.ft-table{border-collapse:collapse;font-size:12px;width:100%}
.ft-table th{background:var(--li);padding:7px 8px;font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;border:1px solid var(--bo);white-space:nowrap;text-align:center}
.ft-table th.ft-shuttle-col{text-align:left;min-width:80px;position:sticky;left:0;z-index:2;background:var(--li)}
.ft-table td{padding:4px 6px;border:1px solid #f0f2f8;text-align:center;vertical-align:middle}
.ft-table td.ft-shuttle-td{text-align:left;font-weight:700;font-size:11px;color:var(--sl);position:sticky;left:0;z-index:1;background:#fff;white-space:nowrap}
.ft-table tbody tr:hover td{background:#f8f9fd}
.ft-table tbody tr:hover td.ft-shuttle-td{background:#f0f4ff}
.ft-cell-pass{background:#d1fae5!important;color:#065f46;font-weight:700;font-size:11px}
.ft-cell-fail{background:#fee2e2!important;color:#b91c1c;font-weight:700;font-size:11px}
.ft-cell-empty{color:#cbd5e1;font-size:10px}
.ft-input{width:60px;text-align:center;font-size:12px;padding:3px 4px;border:1px solid var(--bo);border-radius:4px;font-family:var(--fn)}

/* ── MOBILE HUB ── */
.mobile-hub{display:none}
.mobile-dash-view{display:none}
/* Mobile job-picker modal + chips — hidden on desktop (styles below only kick in at mobile widths) */
.m-jobsw,.m-jobsw-modal{display:none}

@media(max-width:768px){
  .mobile-hub{display:flex;flex-direction:column;min-height:calc(100vh - 52px);background:#0d1117;padding:24px 16px}
  .mobile-hub-header{text-align:center;margin-bottom:28px;padding-top:16px}
  .mobile-hub-title{font-family:'Michroma',sans-serif;font-size:20px;font-weight:400;color:#e6edf3;letter-spacing:5px}
  .mobile-hub-sub{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:#8b949e;margin-top:6px}
  .mobile-hub-cards{display:flex;flex-direction:column;gap:10px;max-width:400px;margin:0 auto;width:100%}
  .mobile-hub-section{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#7C3AED;padding:10px 4px 2px;border-top:1px solid #21262d;margin-top:4px}
  .mobile-hub-section:first-child{border-top:none;margin-top:0}
  .mobile-hub-card{background:#161b22;border:1px solid #30363d;border-radius:10px;padding:16px;display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;transition:transform .12s,border-color .15s}
  .mobile-hub-card:active{transform:scale(.98);border-color:#7C3AED}
  .mobile-hub-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#a78bfa;background:rgba(124,58,237,.1)}
  .mobile-hub-icon svg{width:20px;height:20px}
  .mobile-hub-card-title{font-family:var(--fc);font-size:15px;font-weight:700;color:#e6edf3}
  .mobile-hub-card-desc{font-size:11px;color:#8b949e;margin-top:2px}
  .mobile-hub-arrow{color:#30363d;font-size:20px;font-weight:300;margin-left:auto;flex-shrink:0}
  .mobile-hub-signout{text-align:center;margin-top:auto;padding-top:24px;padding-bottom:12px}
  .mobile-hub-signout button{background:none;border:1px solid #30363d;border-radius:8px;padding:10px 28px;font-size:12px;font-weight:600;color:#8b949e;cursor:pointer;font-family:var(--fn)}

  /* Global mobile job switcher — appears on hub + every dashboard drill-in */
  .m-jobsw{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#161b22;border:1px solid #30363d;border-radius:10px;padding:10px 14px;cursor:pointer;margin-bottom:14px}
  .m-jobsw-label{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#8b949e}
  .m-jobsw-name{font-family:var(--fc);font-size:14px;font-weight:700;color:#e6edf3;margin-top:2px}
  .m-jobsw-ic{color:#7C3AED;font-size:16px}
  .mobile-dash-bar .m-jobsw{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);margin-bottom:0;padding:6px 10px;flex:1}
  .mobile-dash-bar .m-jobsw-label{color:rgba(255,255,255,.7)}
  .mobile-dash-bar .m-jobsw-name{color:#fff;font-size:12px}

  /* Mobile job-picker modal */
  .m-jobsw-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:600;display:none;align-items:flex-end;justify-content:center}
  .m-jobsw-modal.on{display:flex}
  .m-jobsw-sheet{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:520px;max-height:72vh;overflow-y:auto;padding:14px 16px calc(16px + var(--safe-bot,0px));box-sizing:border-box}
  .m-jobsw-handle{width:40px;height:4px;background:#e5e7eb;border-radius:2px;margin:0 auto 10px}
  .m-jobsw-title{font-family:var(--fc);font-size:14px;font-weight:700;color:#111;margin-bottom:10px;letter-spacing:.5px}
  .m-jobsw-item{padding:14px 12px;border-bottom:1px solid #f0f2f8;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px}
  .m-jobsw-item:last-child{border-bottom:none}
  .m-jobsw-item.on{background:#f5f0ff}
  .m-jobsw-item-title{font-weight:700;font-size:14px;color:#111}
  .m-jobsw-item-sub{font-size:12px;color:#6b7280;margin-top:2px}
  .m-jobsw-dot{width:8px;height:8px;border-radius:50%;background:#7C3AED;flex-shrink:0}

  .app-wrap{display:none!important}
  .nav .project-badge{display:none}

  /* Mobile dashboard overlay */
  .mobile-dash-view{position:fixed;inset:0;z-index:500;background:#f8fafc;overflow-y:auto;display:none}
  .mobile-dash-view.active{display:block}
  .mobile-dash-bar{position:sticky;top:0;z-index:10;background:var(--dark);display:flex;align-items:center;padding:14px 16px;gap:12px}
  .mobile-dash-back{background:none;border:1px solid rgba(255,255,255,.25);border-radius:6px;color:#fff;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--fn)}
  .mobile-dash-title{font-family:var(--fc);font-size:17px;font-weight:700;color:#fff;letter-spacing:.5px}
  .mobile-dash-body{padding:16px}
  .mobile-dash-body .g4{grid-template-columns:repeat(2,1fr)!important}
  .mobile-dash-body .g2{grid-template-columns:1fr!important}
  .mobile-dash-body .dash-2col{grid-template-columns:1fr!important}
  .mobile-dash-body .ph{flex-direction:column}

  /* Hide "+ New Job" button on mobile — job creation is desktop-only */
  [onclick*="openJobModal"]{display:none!important}

  /* Settings modal — stack on mobile */
  #mo-settings .settings-md{max-height:100vh!important;height:100vh!important;width:100vw!important;max-width:100vw!important;border-radius:0!important}
  .settings-body{grid-template-columns:1fr!important}
  .settings-rail{display:flex!important;overflow-x:auto;padding:0!important;border-right:none!important;border-bottom:1px solid var(--bo)!important}
  .settings-rail-group{display:none}
  .settings-rail-item{white-space:nowrap;border-left:none!important;border-bottom:2px solid transparent;padding:12px 16px}
  .settings-rail-item.active{border-left:none!important;border-bottom-color:var(--blue)}
}

/* ── SETTINGS MODAL ── (styled to match monolith_settings_interactive_prototype.html) */
#mo-settings{padding:0}
#mo-settings .settings-md{max-width:1100px;width:95vw;padding:0;max-height:88vh;height:88vh;display:flex;flex-direction:column;overflow:hidden;border-radius:12px;background:#f7f7f5;border:0.5px solid rgba(0,0,0,0.08)}

/* Header — dark navy with brand mark + wordmark + crumb + search */
.settings-header{background:#7C3AED;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.settings-brand{display:flex;align-items:center;gap:12px;min-width:0}
.settings-diamond{width:24px;height:24px;flex-shrink:0;object-fit:contain;display:block}
.settings-wordmark{color:#fff;font-size:13px;letter-spacing:0.15em;font-weight:500;font-family:'Michroma',sans-serif}
/* Shared wordmark — use everywhere "MONOLITH" is rendered as a brand mark.
   Colors are set inline per context (dark on white, white on purple, etc.)
   so the typography stays identical app-wide. */
.brand-mark{font-family:'Michroma',sans-serif;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;line-height:1.05}
.brand-sub{font-family:'Michroma',sans-serif;font-weight:400;letter-spacing:0.6em;text-transform:uppercase;font-size:9px;opacity:.65;margin-top:6px;line-height:1}
/* Site Updates page — team rail + main scroll column */
.su-layout{display:grid;grid-template-columns:220px 1fr;gap:16px;align-items:start}
.su-team-rail{display:flex;flex-direction:column;gap:6px;position:sticky;top:0}
.su-team-rail-label{font-size:10px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--gr);padding:0 4px 4px}
.su-team-item{padding:12px 14px;background:#fff;border:1px solid var(--bo);border-radius:10px;cursor:pointer;transition:all .15s}
.su-team-item:hover{background:#faf9f5;border-color:#cdb8f3}
.su-team-item.active{background:rgba(124,58,237,.08);border-color:#7C3AED;box-shadow:0 0 0 1px rgba(124,58,237,.25)}
.su-team-name{font-size:13px;font-weight:600;color:var(--dark);line-height:1.2}
.su-team-item.active .su-team-name{color:#7C3AED}
.su-team-sub{font-size:11px;color:var(--gr);margin-top:3px;line-height:1.3}
@media (max-width:768px){
  .su-layout{grid-template-columns:1fr;gap:10px}
  .su-team-rail{flex-direction:row;overflow-x:auto;position:static;padding-bottom:4px}
  .su-team-rail-label{display:none}
  .su-team-item{flex:0 0 auto;min-width:160px}
  .su-team-sub{display:none}
}
.settings-crumb{color:rgba(255,255,255,0.45);font-size:11px;letter-spacing:0.1em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.settings-search{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,0.18);padding:6px 12px;border-radius:8px;font-size:12px;color:#fff;cursor:pointer;border:none;flex-shrink:0;margin-right:10px}
.settings-search:hover{background:rgba(255,255,255,0.26)}
.settings-search input{color:#fff}
.settings-search input::placeholder{color:rgba(255,255,255,0.9)}
.settings-kbd{background:rgba(255,255,255,0.22);padding:2px 6px;border-radius:4px;font-size:10px;color:#fff}
#mo-settings .settings-header .xb{color:rgba(255,255,255,.75);font-size:20px;background:transparent;border:none;cursor:pointer;padding:4px 8px;line-height:1}
#mo-settings .settings-header .xb:hover{color:#fff}

/* Body: rail + pane */
.settings-body{display:grid;grid-template-columns:220px 1fr;flex:1;min-height:0}
.settings-rail{background:#fff;border-right:0.5px solid rgba(0,0,0,0.08);overflow-y:auto;padding:16px 0}
.settings-rail-group{padding:0 16px 6px;font-size:10px;letter-spacing:0.1em;color:#888780;font-weight:500;text-transform:uppercase}
.settings-rail-group:not(:first-child){padding-top:16px}
.settings-rail-item{padding:8px 16px;font-size:13px;color:#5F5E5A;cursor:pointer;border-left:2px solid transparent;transition:background .12s,color .12s}
.settings-rail-item:hover{background:#f3f1ec}
.settings-rail-item.active{background:#EEEDFE;color:#3C3489;border-left-color:#A855F7;font-weight:500}
.settings-pane{overflow-y:auto;padding:28px 32px;background:#fff;min-width:0}
.settings-tab{display:none}
.settings-tab.active{display:block}
.settings-tab h3{margin:0 0 4px;font-family:var(--fc);font-size:20px;font-weight:500;color:#18182B}
.settings-tab h3 span{color:#A855F7}
.settings-tab .tab-sub{margin:0 0 20px;font-size:13px;color:#5F5E5A;line-height:1.5}
.settings-tab .card{margin-bottom:16px}
.settings-tab .card:last-child{margin-bottom:0}

/* ── ENTITY DETAIL MODAL — shared layout (Customer, Subcontractor, Contract, future entities) ──
   Per DESIGN-PRINCIPLES.md §3 ("Modals and detail surfaces use available screen space").
   Generic .settings-md width applies to all detail modals; #mo-settings keeps its existing
   override for the search bar / diamond logo layout. */
.settings-md{max-width:1200px;width:95vw;padding:0;max-height:88vh;height:88vh;display:flex;flex-direction:column;overflow:hidden;border-radius:12px;background:#fff;border:0.5px solid rgba(0,0,0,0.08)}

/* Title row at the top of the Overview pane: large name + meta on the left,
   status pill (COI / archived marker) on the right. */
.detail-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}
.detail-title-name{font-size:22px;font-weight:500;color:var(--dark);line-height:1.3;margin-bottom:2px}
.detail-title-meta{font-size:13px;color:#5F5E5A;line-height:1.4}
.detail-title-pill{flex-shrink:0}

/* 2-column field grid. Multi-line content (Address, Notes preview) spans both columns
   via .span-2. Last row's cells lose their bottom border via .no-border. */
.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-top:0.5px solid var(--bo)}
.detail-cell{padding:12px 16px 12px 0;border-bottom:0.5px solid var(--bo)}
.detail-cell.right{padding:12px 0 12px 16px;border-left:0.5px solid var(--bo)}
.detail-cell.span-2{grid-column:span 2;border-right:none;border-left:none;padding:12px 0}
.detail-cell.no-border{border-bottom:none}
.detail-label{font-size:11px;color:var(--gr);letter-spacing:0.3px;margin-bottom:4px;text-transform:uppercase;font-weight:500}
.detail-value{font-size:13px;color:var(--dark);line-height:1.5;word-break:break-word}

/* Footer with action buttons — Archive (or Edit when archived) on left, Edit (or Unarchive when archived) on right. */
.detail-footer-row{display:flex;align-items:center;justify-content:space-between;margin-top:24px;padding-top:16px;border-top:0.5px solid var(--bo)}

/* ── State-aware archived rendering ──
   Per DESIGN-PRINCIPLES.md §7. When a record's deleted_at is set, the modal's .md.settings-md
   element gets the .archived class and the visual hierarchy flips: gray header tone, ARCHIVED
   pill, banner, dimmed values, primary/secondary button swap. */
.settings-md.archived .settings-header{background:#6B7280}
.archived-badge{display:none;background:rgba(255,255,255,0.18);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:10px;letter-spacing:0.1em;margin-left:10px}
.settings-md.archived .archived-badge{display:inline-block}
.archived-banner{display:none;padding:10px 14px;background:#F3F4F6;color:#4B5563;font-size:12px;border:1px solid #E5E7EB;border-radius:6px;margin-bottom:16px;line-height:1.5}
.settings-md.archived .archived-banner{display:block}
.settings-md.archived .detail-value{color:#6B7280}
.settings-md.archived .detail-grid{background:#FAFAFA}

/* Mobile — every detail modal goes full-screen, not just mo-settings. */
@media (max-width:768px){
  .settings-md{max-height:100vh!important;height:100vh!important;width:100vw!important;max-width:100vw!important;border-radius:0!important}
  .detail-grid{grid-template-columns:1fr}
  .detail-cell{padding:12px 0!important;border-left:none!important;border-right:none!important}
  .detail-cell.right{padding:12px 0!important}
}

/* ── Shared typeahead dropdown (Backport D — project pickers; reusable for
   future entity pickers as they ship). Per DESIGN-PRINCIPLES.md §1: never
   use a plain <select> for any list that could exceed 20 items. The wrapper
   <div class="fg" style="position:relative"> anchors the dropdown. */
.ms-typeahead-dropdown{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--bo);border-radius:6px;box-shadow:0 4px 16px rgba(0,0,0,.1);max-height:240px;overflow-y:auto;z-index:10;margin-top:2px}
.ms-typeahead-row{padding:8px 12px;cursor:pointer;font-size:12px;color:var(--dark);border-bottom:1px solid #f0eee8}
.ms-typeahead-row:last-child{border-bottom:none}
.ms-typeahead-row:hover{background:#f7f5f0}
.ms-typeahead-row-title{font-weight:600}
.ms-typeahead-row-sub{font-size:10px;color:var(--gr);margin-top:1px}
.ms-typeahead-empty{padding:10px 14px;color:var(--gr);font-size:11px}

/* ── Contract status badges (Phase 1.B.4) ──
   Per DESIGN-PRINCIPLES.md §7: a draft record looks distinct from a final
   one. Each status carries its own color tone for fast scan-recognition.
   .cont-status-badge gets a status-suffix class set by JS (ds-Draft etc).
   Empty class = no badge rendered (a cont-edit-status-badge with no
   text doesn't display). */
.cont-status-badge{display:none;font-size:10px;font-weight:700;padding:3px 10px;border-radius:10px;letter-spacing:0.05em;text-transform:uppercase;line-height:1.2}
.cont-status-badge.ds-Draft{display:inline-block;background:#FEF3C7;color:#92400E}
.cont-status-badge.ds-Active{display:inline-block;background:#D1FAE5;color:#065F46}
.cont-status-badge.ds-Complete{display:inline-block;background:#DBEAFE;color:#1E40AF}
.cont-status-badge.ds-Cancelled{display:inline-block;background:#FEE2E2;color:#991B1B}
.cont-status-badge.ds-Archived{display:inline-block;background:#E5E7EB;color:#4B5563}

/* MODULES TAB — card grid */
.ms-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.ms-card{border:0.5px solid rgba(0,0,0,0.08);border-radius:12px;padding:14px;background:#fff;transition:border-color 120ms}
.ms-card:hover{border-color:rgba(0,0,0,0.16)}
.ms-card-row{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.ms-card-info{display:flex;gap:10px;align-items:flex-start;min-width:0;flex:1}
.ms-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#EEEDFE}
.ms-icon.off{background:#f3f1ec}
.ms-name{font-size:13px;font-weight:500;color:#18182B}
.ms-name.off{color:#5F5E5A}
.ms-tag{display:inline-block;font-size:9px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:#3C3489;background:#EEEDFE;padding:2px 6px;border-radius:4px;margin-left:6px;vertical-align:middle}
.ms-desc{font-size:11px;color:#5F5E5A;margin-top:2px;line-height:1.4}
.ms-desc.off{color:#888780}
.ms-toggle{width:30px;height:18px;background:#D3D1C7;border-radius:9px;position:relative;flex-shrink:0;cursor:pointer;transition:background 150ms;border:none;padding:0;display:inline-block}
.ms-toggle.on{background:#A855F7}
.ms-toggle::after{content:'';position:absolute;top:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:left 150ms;left:2px}
.ms-toggle.on::after{left:14px}
.ms-toggle[disabled]{opacity:0.5;cursor:not-allowed}
.ms-edit-inline{font-size:11px;color:#A855F7;padding:3px 8px;border:0.5px solid #CECBF6;border-radius:6px;background:transparent;cursor:pointer;font-weight:500;margin-right:8px;flex-shrink:0}
.ms-add-btn{font-size:12px;color:#A855F7;padding:6px 12px;border:0.5px solid #CECBF6;border-radius:8px;background:transparent;cursor:pointer;font-weight:500;margin-top:12px}
.ms-footer{margin-top:16px;padding:10px 14px;background:#f3f1ec;border-radius:8px;display:flex;align-items:center;justify-content:space-between;font-size:12px}
.ms-footer-count{color:#5F5E5A}
.ms-footer-count strong{color:#A855F7;font-weight:500}
.ms-footer-meta{color:#888780}
.ms-section-head{font-size:10px;letter-spacing:0.1em;color:#888780;font-weight:600;text-transform:uppercase;margin:18px 0 8px}
.ms-section-head:first-child{margin-top:0}

/* CUSTOMER PORTAL TAB — toggle pills + live preview */
.ms-portal-grid{display:grid;grid-template-columns:1fr 260px;gap:24px}
.ms-portal-toggles{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.ms-portal-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#f3f1ec;border-radius:8px;font-size:13px;cursor:pointer;transition:background 120ms}
.ms-portal-row.on{background:#EEEDFE}
.ms-portal-row span{color:#5F5E5A}
.ms-portal-row.on span{color:#3C3489;font-weight:500}
.ms-portal-row.locked{cursor:not-allowed;opacity:0.7}
.ms-portal-row .ms-toggle{width:26px;height:15px}
.ms-portal-row .ms-toggle::after{width:11px;height:11px}
.ms-portal-row .ms-toggle.on::after{left:13px}
.ms-preview{background:#18182B;border-radius:8px;padding:14px;min-height:340px}
.ms-preview-brand{color:#A855F7;font-size:9px;letter-spacing:0.15em;margin-bottom:12px;font-family:'Michroma',sans-serif}
.ms-preview-tab{color:rgba(255,255,255,0.7);font-size:11px;padding:7px 8px;border-radius:4px;margin-bottom:2px}
.ms-preview-tab.first{background:rgba(168,85,247,0.15);border-left:2px solid #A855F7;color:rgba(255,255,255,0.9)}
.ms-preview-foot{border-top:0.5px solid rgba(255,255,255,0.1);margin-top:10px;padding-top:10px;font-size:9px;color:rgba(255,255,255,0.4);letter-spacing:0.1em}
.ms-preview-label{font-size:10px;letter-spacing:0.1em;color:#888780;font-weight:500;margin-bottom:8px;text-transform:uppercase}

/* INTEGRATIONS TAB — filters + card grid */
.ms-filter-row{display:flex;gap:6px;margin-bottom:16px;font-size:12px;flex-wrap:wrap}
.ms-filter-row:empty{display:none;margin:0}
.ms-filter{padding:6px 12px;background:#f3f1ec;color:#5F5E5A;border-radius:999px;cursor:pointer;border:none;font-family:var(--fn)}
.ms-filter.active{background:#18182B;color:#fff;font-weight:500}
.ms-int-card{border:0.5px solid rgba(0,0,0,0.08);border-radius:12px;padding:14px;background:#fff}
.ms-int-row{display:flex;gap:12px;align-items:flex-start;margin-bottom:10px}
.ms-int-logo{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:500;font-size:13px;flex-shrink:0}
.ms-int-name-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ms-int-name{font-size:13px;font-weight:500;color:#18182B}
.ms-pill{font-size:10px;padding:2px 8px;border-radius:999px;font-weight:500}
.ms-pill.connected{background:#E1F5EE;color:#0F6E56}
.ms-pill.warn{background:#FAEEDA;color:#854F0B}
.ms-pill.avail{background:#f3f1ec;color:#5F5E5A}
.ms-int-desc{font-size:11px;color:#5F5E5A;margin-top:2px;line-height:1.4}
.ms-int-foot{font-size:11px;color:#888780;padding-top:8px;border-top:0.5px solid rgba(0,0,0,0.08)}
.ms-int-foot.warn{color:#854F0B}
.ms-connect{font-size:11px;color:#A855F7;font-weight:500;cursor:pointer;background:none;border:none;padding:0;font-family:var(--fn)}

/* Sidebar gear button */
.sb-gear{display:flex;align-items:center;gap:9px;padding:9px 16px;font-size:12px;font-weight:500;color:#64748b;cursor:pointer;background:transparent;border:none;width:100%;text-align:left;font-family:var(--fn);transition:color .12s,background .12s}
.sb-gear:hover{color:#A855F7;background:rgba(168,85,247,0.05)}
.sb-gear svg{flex-shrink:0}

/* 3.H (Phase 3, 2026-05-15): instant CSS tooltip for form-field help.
   Hover the .ms-tt element to show its data-tt attribute as a styled
   bubble. No native browser title= delay; appears immediately on hover.
   Pattern: <span class="ms-tt" data-tt="...">?</span> alongside a label. */
.ms-tt:hover::after{
  content:attr(data-tt);
  position:absolute;
  bottom:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%);
  background:#1f2937;
  color:#fff;
  font-size:11px;
  font-weight:400;
  letter-spacing:0;
  text-transform:none;
  line-height:1.4;
  padding:8px 12px;
  border-radius:6px;
  white-space:normal;
  width:max-content;
  max-width:260px;
  z-index:10000;
  pointer-events:none;
  box-shadow:0 4px 12px rgba(0,0,0,0.15);
  font-family:var(--fn);
}
.ms-tt:hover::before{
  content:'';
  position:absolute;
  bottom:calc(100% + 2px);
  left:50%;
  transform:translateX(-50%);
  border:6px solid transparent;
  border-top-color:#1f2937;
  z-index:10000;
  pointer-events:none;
}

