/* ── Reset & Base ── */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--bg);font-size:13px;-webkit-font-smoothing:antialiased;color:var(--text)}

:root{
  --surface:#fff;
  --bg:#F5F4F0;
  --hover:#F2F2EF;
  --border:rgba(0,0,0,0.08);
  --border-md:rgba(0,0,0,0.12);
  --text:#0D1E36;
  --muted:#6B6B65;
  --faint:#A8A8A0;
  --subtle:#FDF0F4;
  --accent:#ED005E;
  --accent-light:#FDF0F4;
  --accent-muted:#F8C0D4;
  --sw:220px;
  --sc:52px;
  --tr:.22s cubic-bezier(.4,0,.2,1)
}

/* ── Login ── */
#auth{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:99;transition:opacity .3s}
#auth.gone{opacity:0;pointer-events:none}
.acard{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:2.25rem 2.5rem 2rem;width:350px;box-shadow:0 4px 28px rgba(0,0,0,0.07)}
.alogo{display:flex;align-items:center;gap:10px;margin-bottom:2rem}
.alogo-text{font-size:18px;font-weight:500;letter-spacing:-.3px}
.amark{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.atitle{font-size:21px;font-weight:500;letter-spacing:-.5px;margin-bottom:5px}
.asub{font-size:12px;color:var(--muted);margin-bottom:1.75rem}
.flabel{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:5px}
.fwrap{margin-bottom:13px}
.finput{width:100%;height:40px;border:1px solid var(--border-md);border-radius:8px;padding:0 12px;font-size:13px;font-family:inherit;color:var(--text);background:var(--surface);outline:none;transition:border .15s,box-shadow .15s}
.finput:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(237,0,94,.1)}
.finput::placeholder{color:var(--faint)}
.abtn{width:100%;height:40px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;margin-top:4px;transition:opacity .15s}
.abtn:hover{opacity:.88}
.aerr{font-size:11px;color:#C0392B;min-height:16px;margin-top:7px}
.demo-creds{background:var(--subtle);border:1px solid var(--accent-muted);border-radius:8px;padding:10px 14px;margin-top:14px;text-align:left;color:var(--muted);font-size:11px;line-height:1.6}
.demo-creds-label{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:5px}
.demo-creds strong{color:var(--text)}

/* ── App shell ── */
#app{display:none;height:100vh}
#app.show{display:flex}

/* ── Sidebar ── */
.sbwrap{position:relative;flex-shrink:0}
.sb{width:var(--sw);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;transition:width var(--tr);overflow:hidden}
.sb.col{width:var(--sc)}
.sbhead{height:52px;display:flex;align-items:center;padding:0 13px;gap:10px;border-bottom:1px solid var(--border);flex-shrink:0}
.lmark{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.lname-wrap{display:flex;flex-direction:column;gap:1px;overflow:hidden;transition:opacity var(--tr)}
.lname{font-size:14px;font-weight:600;letter-spacing:-.3px;white-space:nowrap}
.lsub{font-size:9px;font-weight:400;color:var(--muted);white-space:nowrap;letter-spacing:.01em}
.sb.col .lname-wrap{opacity:0}
.sbnav{flex:1;padding:10px 0;overflow-y:auto;overflow-x:hidden}
.sbnav::-webkit-scrollbar{width:3px}
.sbnav::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:4px}
.seclabel{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.6px;color:var(--faint);padding:8px 14px 4px;white-space:nowrap;transition:opacity var(--tr)}
.seclabel--toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;border-radius:6px;padding-right:10px}
.seclabel--toggle:hover{color:var(--muted)}
.seclabel-chevron{opacity:.5;flex-shrink:0}
.sb.col .seclabel{opacity:0}
.nitem{display:flex;align-items:center;gap:9px;padding:8px 13px;cursor:pointer;position:relative;white-space:nowrap;transition:background .1s}
.nitem:hover{background:var(--subtle)}
.nitem.act{background:var(--subtle)}
.nitem.act .nlabel{color:var(--accent);font-weight:500}
.nitem.act .nico{color:var(--accent)}
.nbar{position:absolute;left:0;top:5px;bottom:5px;width:2.5px;background:var(--accent);border-radius:0 2px 2px 0}
.nico{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--muted)}
.nlabel{font-size:13px;color:var(--muted);transition:opacity var(--tr)}
.sb.col .nlabel{opacity:0}
.sb.col .nsoon{opacity:0;pointer-events:none}
.sbfoot{padding:10px 12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:9px;flex-shrink:0;cursor:pointer;position:relative}
.avatar{width:28px;height:28px;border-radius:50%;background:var(--subtle);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--accent);flex-shrink:0}
.uinfo{overflow:hidden;transition:opacity var(--tr)}
.sb.col .uinfo{opacity:0}
.uname{font-size:12px;font-weight:500;white-space:nowrap}
.urole{font-size:11px;color:var(--faint);white-space:nowrap}
.logoutbtn{margin-left:auto;cursor:pointer;color:var(--faint);transition:color .15s;flex-shrink:0}
.logoutbtn:hover{color:var(--accent)}
.togbtn{position:absolute;right:-11px;top:50%;transform:translateY(-50%);width:22px;height:22px;background:var(--surface);border:1px solid var(--border);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;box-shadow:0 1px 6px rgba(0,0,0,.07)}

/* ── Main area ── */
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{height:52px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--surface);flex-shrink:0}
.tbadge{font-size:11px;padding:3px 10px;border-radius:20px;background:var(--subtle);color:var(--accent);font-weight:500}
.content-bc{font-size:11px;color:var(--faint);margin-bottom:6px;line-height:1}
.content-bc span[onclick]{cursor:pointer;transition:color .15s}
.content-bc span[onclick]:hover{color:var(--accent)}
.content{flex:1;padding:28px 32px;overflow-y:auto}

/* ── Page titles ── */
.ptitle{font-size:22px;font-weight:500;letter-spacing:-.5px;margin-bottom:5px}
.psub{font-size:13px;color:var(--muted);margin-bottom:20px}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}
.page-header .psub{margin-bottom:0}

/* ── Tabs ── */
.tabnav{display:flex;gap:2px;margin-bottom:0;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:3px;width:fit-content}
.tabitem{height:30px;padding:0 16px;border:none;border-radius:7px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;background:transparent;color:var(--muted);transition:background .15s,color .15s}
.tabitem:hover{color:var(--text)}
.tabitem.act{background:var(--bg);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.07)}
.tabpanel{display:none}
.tabpanel.act{display:block}

/* ── Quarter filter ── */
.qfilter{display:flex;gap:4px;margin-bottom:20px}
.qfilter-btn{height:30px;padding:0 14px;border:1px solid var(--border-md);border-radius:7px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;background:var(--surface);color:var(--muted);transition:all .15s}
.qfilter-btn.act{border-color:var(--accent);background:var(--subtle);color:var(--accent)}

/* ── Filter bar ── */
.filterbar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.filterbar select{height:30px;border:1px solid var(--border-md);border-radius:7px;padding:0 28px 0 10px;font-size:12px;font-family:inherit;color:var(--muted);background:var(--surface);outline:none;cursor:pointer;transition:border .15s,color .15s;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23A8A8A0' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}
.filterbar select:hover{border-color:var(--border-strong,#c0c0c0)}
.filterbar select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px rgba(237,0,94,.08)}
.filterbar select.active{border-color:var(--accent);color:var(--text)}
/* ── Custom dropdown (replaces native <select> in filter bars) ── */
.rnx-dd{position:relative;display:inline-block;vertical-align:top}
.rnx-dd-btn{height:30px;min-width:120px;max-width:170px;padding:0 26px 0 10px;border:1px solid var(--border-md);border-radius:7px;font-size:12px;font-family:inherit;color:var(--muted);background:var(--surface);cursor:pointer;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;outline:none;transition:border-color .15s,color .15s,box-shadow .15s;position:relative}
.rnx-dd-btn::after{content:'';position:absolute;right:8px;top:50%;transform:translateY(-50%);width:10px;height:6px;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23A8A8A0' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;pointer-events:none;transition:transform .15s}
.rnx-dd-btn:hover{border-color:var(--border-strong,#c0c0c0)}
.rnx-dd.open .rnx-dd-btn{border-color:var(--accent);box-shadow:0 0 0 3px rgba(237,0,94,.08);color:var(--text)}
.rnx-dd.open .rnx-dd-btn::after{transform:translateY(-50%) rotate(180deg)}
.rnx-dd.active .rnx-dd-btn{border-color:var(--accent);color:var(--text)}
.rnx-dd-menu{display:none;max-height:220px;overflow-y:auto;background:var(--surface);border:1px solid var(--border-md);border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.13);z-index:9100;padding:4px 0}
.rnx-dd.open .rnx-dd-menu{display:block}
.rnx-dd-opt{padding:7px 14px;font-size:12px;font-family:inherit;color:var(--text);cursor:pointer;white-space:nowrap;transition:background .08s,color .08s}
.rnx-dd-opt:hover{background:rgba(237,0,94,.06);color:var(--accent)}
.rnx-dd-opt.sel{color:var(--accent);font-weight:600}
.rnx-dd-opt[data-val=""]{color:var(--muted);font-weight:400}
.filter-reset{height:30px;padding:0 12px;border:1px solid var(--border-md);border-radius:7px;font-size:12px;font-family:inherit;color:var(--muted);background:none;cursor:pointer;transition:color .15s,border-color .15s}
.filter-reset:hover{color:var(--accent);border-color:var(--accent)}
.filterbar-search{height:30px;width:200px;border:1px solid var(--border-md);border-radius:7px;padding:0 10px;font-size:12px;font-family:inherit;color:var(--text);background:var(--surface);outline:none;transition:border .15s}
.filterbar-search::placeholder{color:var(--muted)}
.filterbar-search:focus{border-color:var(--accent)}
.filterbar-search::-webkit-search-cancel-button{cursor:pointer}

/* ── Cards grid ── */
.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:24px}
.mcard{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px}
.mlabel{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);margin-bottom:8px}
.mlabel-sub{font-weight:400;text-transform:none;letter-spacing:0;color:var(--faint)}
.mval{font-size:26px;font-weight:500;letter-spacing:-.5px}
.sc-badges{display:flex;gap:5px;margin-top:10px;flex-wrap:wrap}
.sc-badge{font-size:11px;font-weight:500;padding:2px 8px;border-radius:20px}
.sc-donut-row{display:flex;align-items:flex-start;gap:16px;margin-top:10px}
.sc-donut-legend{display:flex;flex-direction:column;gap:9px;flex:1;min-width:0}
.sc-legend-item{display:flex;align-items:center;justify-content:space-between;gap:8px}
.sc-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;display:inline-block}
.sc-legend-name{font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sc-legend-left{display:flex;align-items:center;gap:6px;min-width:0}
.sc-legend-pills{display:flex;gap:3px;flex-shrink:0}
/* ── Analysis collapsable wrapper ── */
.rnx-analysis-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;overflow:hidden}
.rnx-analysis-hd{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;cursor:pointer;user-select:none;transition:background .12s}
.rnx-analysis-hd:hover{background:var(--bg)}
.rnx-analysis-hd-left{display:flex;align-items:center;gap:8px}
.rnx-analysis-hd-title{font-size:12px;font-weight:600;color:var(--text)}
.rnx-analysis-hd-sub{font-size:11px;color:var(--muted)}
.rnx-analysis-chev{background:none;border:none;cursor:pointer;color:var(--muted);display:flex;padding:0;transition:transform .2s;line-height:0}
.rnx-analysis-body{border-top:1px solid var(--border);padding:16px 16px 8px}
/* ── Analysis row (total card + grouped chart card side by side) ── */
.rnx-analysis-row{display:flex;gap:12px;margin-bottom:8px;align-items:stretch}
.rnx-analysis-total{flex-shrink:0;width:180px}
.rnx-analysis-total .mcard{height:100%;box-sizing:border-box;border:none;background:var(--surface);border-radius:8px}
/* ── Grouped analysis card ── */
.rnx-grouped-card{display:flex;flex:1;min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;min-height:220px}
.rnx-grouped-tabs{display:flex;flex-direction:column;width:210px;flex-shrink:0;border-right:1px solid var(--border);background:var(--surface)}
.rnx-gtab{display:flex;flex-direction:column;gap:6px;padding:14px 16px;border:none;background:var(--surface);cursor:pointer;text-align:left;border-bottom:1px solid var(--border);transition:background .15s;font-family:inherit}
.rnx-gtab:last-child{border-bottom:none}
.rnx-gtab:hover{background:var(--bg)}
.rnx-gtab.act{background:var(--bg);border-left:3px solid var(--accent)}
.rnx-gtab-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.rnx-gtab.act .rnx-gtab-label{color:var(--accent)}
.rnx-gtab-count{font-size:16px;font-weight:500;color:var(--text);letter-spacing:-.3px}
.rnx-gtab-badges{display:flex;gap:4px;flex-wrap:wrap}
.rnx-grouped-chart{flex:1;padding:16px 20px;min-width:0;position:relative}

/* ── Tables ── */
.twrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.thead-row{padding:13px 18px;border-bottom:1px solid var(--border);font-size:13px;font-weight:500}
table{width:100%;border-collapse:collapse}
th{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);padding:10px 18px;text-align:left;border-bottom:1px solid var(--border)}
td{padding:12px 18px;border-bottom:1px solid var(--border);color:var(--text)}
tr:last-child td{border-bottom:none}
tr:hover td{background:#FAFAF8}

/* ── Status pills ── */
.pill{display:inline-flex;align-items:center;font-size:11px;font-weight:500;padding:3px 10px;border-radius:20px}
.ds-wrap{position:relative;display:inline-flex;align-items:center;cursor:pointer}
.ds-wrap:hover .ds-pill{opacity:.85}
.ds-pill{pointer-events:none}
.ds-select{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%}
.ds-gray{background:#EDEDF0;color:#8E8E93}
.ds-green{background:#E6F5EA;color:#2EAD4B}
.ds-yellow{background:#FFF3D0;color:#E5A100}
.ds-red{background:#FDEBEE;color:#E5243B}
.ds-orange{background:#FFF4E5;color:#C2410C}
.ds-blue{background:#E0F2FE;color:#0284C7}
.rnx-status-chip{border-color:transparent;opacity:0.5}
.rnx-status-chip.act{border-color:currentColor !important;opacity:1}

/* ── Kanban ── */
.kanban{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.kancol{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.kancol-head{padding:12px 14px;border-bottom:1px solid var(--border);font-size:12px;font-weight:500;display:flex;align-items:center;justify-content:space-between}
.kancol-count{font-size:11px;color:var(--faint);background:var(--bg);border-radius:20px;padding:1px 8px}
.kancol-body{padding:10px;display:flex;flex-direction:column;gap:8px}
.kancard{background:#fff;border:1px solid var(--border);border-radius:8px;padding:11px 12px;display:flex;flex-direction:column;gap:5px}
.kancard-title{font-size:12px;font-weight:500;line-height:1.4;color:var(--text)}
.kancard-tags{font-size:10px;color:var(--faint)}
.kancard-leads{display:flex;gap:10px}
.kancard-lead-item{font-size:11px;color:var(--muted)}
.kancard-lead-label{font-size:10px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.3px}
.kancard-driver{font-size:11px;color:var(--muted)}
.kancard-footer{display:flex;align-items:center;justify-content:space-between}

/* ── Link popup & init cells ── */
.init-cell{display:flex;align-items:center;gap:5px}
.init-title{color:inherit;text-decoration:none}
a.init-title:hover{text-decoration:underline;color:var(--accent)}
.link-btn{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;cursor:pointer;color:var(--faint);opacity:0;transition:opacity .15s,color .15s,background .15s;flex-shrink:0;border:none;background:none;padding:0}
tr:hover .link-btn,.link-btn.has-link{opacity:1;color:var(--accent)}
.link-btn:hover{background:var(--subtle)}
.link-popup{position:fixed;background:var(--surface);border:1px solid var(--border-md);border-radius:10px;padding:14px;box-shadow:0 4px 24px rgba(0,0,0,0.12);z-index:999;width:300px;display:none}
.link-popup.show{display:block}
.link-popup-title{font-size:12px;font-weight:500;margin-bottom:10px}
.link-popup-row{display:flex;gap:6px}
.link-popup-row input{flex:1;height:34px;border:1px solid var(--border-md);border-radius:7px;padding:0 10px;font-size:12px;font-family:inherit;outline:none;color:var(--text);min-width:0}
.link-popup-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(237,0,94,.1)}
.link-popup-open{height:34px;width:34px;display:inline-flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border-md);border-radius:7px;cursor:pointer;color:var(--muted);flex-shrink:0;transition:border-color .15s,color .15s}
.link-popup-open:hover{border-color:var(--accent);color:var(--accent)}
.link-popup-open:disabled{opacity:.3;cursor:default;pointer-events:none}
.link-popup-save{height:34px;padding:0 12px;background:var(--accent);color:#fff;border:none;border-radius:7px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;flex-shrink:0}
.link-popup-save:hover{opacity:.88}
.link-popup-clear{height:34px;padding:0 10px;background:none;border:1px solid var(--border-md);border-radius:7px;font-size:12px;font-family:inherit;cursor:pointer;color:var(--muted);flex-shrink:0}
.link-popup-clear:hover{border-color:var(--accent);color:var(--accent)}

/* ── Gantt ── */
.gantt-group-toggle{display:flex;align-items:center;gap:6px;margin-bottom:14px}
.gantt-group-label{font-size:11px;color:var(--faint)}
.gantt-group-btn{font-size:11px;padding:3px 10px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;font-weight:500;font-family:inherit;transition:all .15s}
.gantt-group-btn.act{border-color:var(--accent);background:var(--accent);color:#fff}
.gantt-legend{display:flex;gap:14px;margin-bottom:14px;font-size:11px;color:var(--muted)}
.gantt-legend-item{display:flex;align-items:center;gap:5px}
.gantt-legend-dot{width:10px;height:7px;border-radius:2px;display:inline-block}
.gantt-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 20px;overflow-x:auto;position:relative}
.gantt-table{width:100%;min-width:780px;border-collapse:collapse}
.gantt-th{padding:8px;text-align:center;font-size:12px;font-weight:500;color:var(--text);border-bottom:1px solid var(--border);border-left:0.5px solid var(--border)}
.gantt-th-name{width:260px;min-width:260px;padding:8px 8px 8px 0;text-align:left;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--faint);border-bottom:1px solid var(--border)}
.gantt-th-current{background:rgba(237,0,94,0.04)}
.gantt-group-row td{padding:10px 8px 6px 0;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);border-bottom:0.5px solid var(--border);background:var(--bg)}
.gantt-name-cell{padding:8px 8px 8px 0;vertical-align:middle;border-bottom:0.5px solid var(--border)}
.gantt-name-title{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px}
.gantt-name-meta{font-size:10px;color:var(--faint);margin-top:2px}
.gantt-name-meta span{color:var(--muted)}
.gantt-cell{padding:4px;vertical-align:middle;border-bottom:0.5px solid var(--border);border-left:0.5px solid var(--border)}
.gantt-cell-current{background:rgba(237,0,94,0.04)}
.gantt-bar{height:24px;border-radius:4px;margin:0 2px;cursor:default;position:relative}
#gantt-tooltip,#rnx-gantt-tooltip{display:none;position:absolute;z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 14px;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.1);max-width:240px}
.gantt-tooltip-title{font-size:12px;font-weight:500;color:var(--text);margin-bottom:6px}
.gantt-tooltip-body{font-size:11px;color:var(--muted);display:flex;flex-direction:column;gap:3px}
.gantt-tooltip-label{color:var(--faint)}

/* ── ROI section ── */
.roi-chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:16px}
.roi-chart-label{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);margin-bottom:12px}
.roi-chart-canvas{position:relative;width:100%;height:280px}
.roi-grid{display:grid;grid-template-columns:160px repeat(3,minmax(0,1fr));gap:16px;margin-bottom:16px}
.roi-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:14px}
.roi-card-label{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--faint)}
.roi-card-big{font-size:24px;font-weight:500}
.roi-card-small{font-size:11px;color:var(--muted);margin-top:2px}
.roi-card-sep{height:1px;background:var(--border)}
.roi-bar-header{display:grid;grid-template-columns:1fr auto auto;gap:8px;padding:8px 0;border-bottom:0.5px solid var(--border)}
.roi-bar-header div{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--faint);text-align:right;min-width:48px}
.roi-bar-header div:first-child{text-align:left}
.roi-bar-row{display:grid;grid-template-columns:1fr auto auto;gap:8px;padding:10px 0;align-items:center}
.roi-bar-row:not(:last-child){border-bottom:0.5px solid var(--border)}
.roi-bar-val{font-size:12px;font-weight:500;text-align:right;min-width:80px}
.roi-bar-pct{font-size:12px;font-weight:500;text-align:right;min-width:48px}

/* ── Quarterly progress ── */
.qp-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}
.qp-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.qp-card-head{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.qp-card-q{font-size:12px;font-weight:500}
.qp-card-count{font-size:11px;color:var(--faint);background:var(--bg);border-radius:20px;padding:1px 8px}
.qp-card-bars{padding:10px 14px 4px}
.qp-bar-track{display:flex;height:6px;border-radius:4px;overflow:hidden;gap:1px}
.qp-bar-seg-gray{background:#8E8E93}
.qp-bar-seg-green{background:#2EAD4B}
.qp-bar-seg-blue{background:#0EA5E9}
.qp-bar-seg-yellow{background:#E5A100}
.qp-bar-seg-red{background:#E5243B}
.qp-bar-seg-empty{background:var(--bg)}
.qp-card-meta{font-size:10px;color:var(--faint);margin-top:4px}
.qp-card-roi{padding:6px 14px 12px;border-top:1px solid var(--border);margin-top:8px}
.qp-card-roi-label{font-size:10px;color:var(--faint)}
.qp-card-roi-val{font-size:14px;font-weight:500;color:var(--accent)}
.qp-card-roi-sub{font-size:11px;font-weight:400;color:var(--muted)}

/* ── Capacity ── */
.cap-scorecard{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px}
.cap-scorecard-label{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);margin-bottom:8px}
.cap-scorecard-val{font-size:24px;font-weight:500}
.cap-scorecard-sub{font-size:11px;color:var(--muted);margin-top:2px}
.cap-team-block{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:16px;overflow:hidden}
.cap-team-head{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.cap-team-name{font-size:14px;font-weight:500;color:var(--text)}
.cap-team-meta{font-size:11px;color:var(--muted);background:var(--bg);padding:2px 10px;border-radius:20px}
.cap-team-body{padding:16px 20px}
.cap-bar-row{display:grid;grid-template-columns:90px 1fr 80px;gap:14px;align-items:center;padding:8px 0}
.cap-bar-row:not(:first-child){border-top:0.5px solid var(--border)}
.cap-bar-label{font-size:12px;color:var(--muted)}
.cap-bar-track{height:20px;background:var(--bg);border-radius:5px;overflow:hidden}
.cap-bar-fill{height:100%;border-radius:5px;display:flex;align-items:center;padding-left:8px;min-width:32px}
.cap-bar-fill-text{font-size:10px;font-weight:500;color:#fff}
.cap-bar-over{position:relative}
.cap-bar-over .cap-bar-track{overflow:visible}
.cap-bar-budget-line{position:absolute;top:-4px;bottom:-4px;width:1.5px;background:var(--faint);z-index:2}
.cap-bar-budget-label{position:absolute;top:-12px;font-size:9px;color:var(--faint);transform:translateX(-50%)}
.cap-bar-over-hatch{position:absolute;right:0;top:0;height:20px;background:repeating-linear-gradient(45deg,#E5243B22,#E5243B22 3px,transparent 3px,transparent 6px);border-radius:0 5px 5px 0}
.cap-bar-over-badge{font-size:11px;font-weight:500;color:#E5243B;background:#FDEBEE;padding:2px 8px;border-radius:12px;white-space:nowrap;flex-shrink:0}
.cap-bar-stats{text-align:right;font-size:12px}
.cap-bar-stats-val{font-weight:500}
.cap-bar-stats-of{font-size:11px;color:var(--faint)}
.cap-legend{display:flex;gap:16px;padding:4px 0}
.cap-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted)}
.cap-legend-dot{width:8px;height:8px;border-radius:2px}
.cap-leader-block{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:16px;overflow:hidden}
.cap-leader-head{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.cap-leader-name{font-size:14px;font-weight:500;color:var(--text)}
.cap-leader-role{font-size:11px;color:var(--faint)}
.cap-leader-body{padding:0 20px 16px}
.cap-empty{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:48px 32px;text-align:center;font-size:13px;color:var(--faint)}

/* ── Data source link ── */
.datasource-link{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:11px;color:var(--muted);text-decoration:none;font-weight:500;white-space:nowrap;transition:border-color .15s,color .15s;flex-shrink:0;margin-top:4px}
.datasource-link:hover{border-color:var(--accent);color:var(--accent)}

/* ── Loader ── */
@keyframes ld-spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes ld-fade{0%,26%{opacity:0;transform:translateY(6px)}7%,19%{opacity:1;transform:translateY(0)}22%{opacity:0;transform:translateY(-6px)}}
.loader-wrap{display:flex;align-items:center;justify-content:center;height:70vh;flex-direction:column;gap:20px}
.loader-spinner{width:32px;height:32px;border:2.5px solid var(--border-md);border-top-color:var(--accent);border-radius:50%;animation:ld-spin .8s linear infinite}
.loader-phrases{position:relative;height:20px;width:360px;overflow:hidden}
.ld-phrase{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;animation:ld-fade 9s infinite;font-size:13px;font-weight:500;color:var(--muted);letter-spacing:-.2px}

/* ── Badge helper ── */
.badge{display:inline-block;font-size:11px;font-weight:500;padding:2px 9px;border-radius:20px;white-space:nowrap}
.mini-pill{font-size:11px;font-weight:500;padding:2px 7px;border-radius:20px}

/* ── Topbar admin button + dropdown ── */
.tb-admin-wrap{position:relative}
.tb-admin-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:border-color .15s,color .15s,background .15s}
.tb-admin-btn:hover{border-color:var(--border-md);color:var(--text);background:var(--subtle)}
.tb-admin-dd{position:absolute;top:calc(100% + 8px);right:0;min-width:190px;background:var(--surface);border:1px solid var(--border-md);border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,.10);z-index:9200;overflow:hidden;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .15s,transform .15s}
.tb-admin-dd.open{opacity:1;transform:translateY(0);pointer-events:auto}
.tb-admin-dd-item{display:flex;align-items:center;gap:9px;padding:10px 14px;font-size:13px;color:var(--text);cursor:pointer;transition:background .1s}
.tb-admin-dd-item:hover{background:var(--subtle);color:var(--accent)}
.tb-admin-dd-item svg{color:var(--muted);flex-shrink:0}
.tb-admin-dd-item:hover svg{color:var(--accent)}

/* ── Nav accordion children ── */
.nchildren{padding-left:8px;border-left:1.5px solid var(--border);margin:2px 0 4px 22px}
.nchild{padding:6px 10px 6px 10px;font-size:12px}
.nchild .nlabel{font-size:12px}

/* ── Admin users form inputs ── */
.au-inp::placeholder{color:var(--faint);opacity:1}

/* ── Viewer mode (data-roadmap-role="viewer") ── */
[data-roadmap-role=viewer] .rnx-ii{pointer-events:none!important;background:transparent!important;border-color:transparent!important;cursor:default!important}
[data-roadmap-role=viewer] .rnx-av-wrap{pointer-events:none!important;cursor:default!important}
[data-roadmap-role=viewer] .rnx-av-btn{pointer-events:none!important;cursor:default!important}
[data-roadmap-role=viewer] .rnx-edit-btn{display:none!important}
[data-roadmap-role=viewer] [data-rnxedit]{display:none!important}
[data-roadmap-role=viewer] .rnx-del-btn{display:none!important}
[data-roadmap-role=viewer] .rnx-roi-cta{display:none!important}
[data-roadmap-role=viewer] .rnx-link-btn{pointer-events:none!important;opacity:.4}

/* ── Assumptions viewer mode (.snx-viewer on #snx-page) ── */
.snx-viewer .snx-act{display:none!important}
.snx-viewer .snx-new-row{display:none!important}
.snx-viewer .snx-ei{pointer-events:none!important;cursor:default!important}
.snx-viewer .snx-drop-btn.snx-ei{pointer-events:none!important;cursor:default!important}
