/* The Knoxfield Group — portal theme (Executive Aubergine, dark) */
:root{
  --bg:#0b0712; --bg2:#120a1f; --card:#1c1133; --card2:#251a40;
  --line:rgba(180,150,235,.14); --pl:#3C1F5C; --pl2:#b79cf2; --pl3:#cdb1ff;
  --txt:#f4f0fb; --mut:#a99dc6; --mut2:#7d7299;
  --up:#46d6a6; --amber:#f5b94d; --down:#ff6f8b;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;font-size:14px}
a{color:var(--pl3);text-decoration:none}
.muted{color:var(--mut)}

/* ---- top bar ---- */
.topbar{display:flex;align-items:center;gap:14px;padding:13px 22px;
  background:linear-gradient(90deg,#1a0f2e,#241141);border-bottom:1px solid var(--line)}
.topbar .brand{font-weight:700;font-size:15px;letter-spacing:.2px}
.topbar .brand span{color:var(--pl3)}
.topbar .sub{color:var(--mut);font-size:12px}
.topbar .spacer{flex:1}
.chip{background:rgba(183,156,242,.14);color:var(--pl3);border:1px solid var(--line);
  border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}
.chip.role{text-transform:capitalize}
.topbar a.logout{color:var(--mut);font-size:12px}

/* ---- tabs ---- */
.tabs{display:flex;gap:6px;padding:12px 22px 0}
.tabs button{background:transparent;border:0;color:var(--mut);font:inherit;font-size:13px;
  font-weight:600;padding:9px 16px;border-radius:9px 9px 0 0;cursor:pointer}
.tabs button.on{background:var(--card);color:var(--txt);border:1px solid var(--line);border-bottom:0}
.wrap{padding:18px 22px 40px}
.pane{display:none}.pane.on{display:block}
h2.section{font-size:15px;font-weight:600;margin:0 0 4px}
.lead{color:var(--mut);font-size:12.5px;margin:0 0 16px}

/* ---- kanban ---- */
.kb-board{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kcol{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:10px}
.khead{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;
  font-weight:700;color:#fff;padding:7px 10px;border-radius:8px;margin-bottom:10px}
.kcount{background:rgba(0,0,0,.28);border-radius:10px;padding:1px 8px;font-size:11px}
.kcol-list{min-height:140px;display:flex;flex-direction:column;gap:8px}
.kcard{background:var(--card2);border:1px solid var(--line);border-radius:9px;
  padding:9px 10px;cursor:grab;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.kcard:active{cursor:grabbing}
.kcard .t{font-size:12px;font-weight:600;line-height:1.35}
.kcard .meta{display:flex;align-items:center;gap:7px;margin-top:8px;font-size:10.5px;color:var(--mut)}
.kcard .ob{display:inline-flex;width:19px;height:19px;border-radius:50%;align-items:center;
  justify-content:center;font-size:9px;font-weight:700;background:#4a3a6e;color:var(--pl3);flex:0 0 auto}
.kcard .ob.jv{background:#1f4a5e;color:#7fd3ec}
.kcard .tag{font-size:9px;font-weight:700;padding:1px 6px;border-radius:6px;margin-left:auto}
.kcard .tag.over{background:rgba(255,111,139,.16);color:var(--down)}
.kcard .tag.blk{background:rgba(245,185,77,.16);color:var(--amber)}
.kcard .tag.ms{background:rgba(183,156,242,.16);color:var(--pl3)}
.kghost{opacity:.35}
.saved{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:#1f3b30;
  color:var(--up);border:1px solid rgba(70,214,166,.3);padding:8px 16px;border-radius:20px;
  font-size:12px;font-weight:600;opacity:0;transition:opacity .25s;pointer-events:none;z-index:50}
.saved.show{opacity:1}
.saved.err{background:#3b1f28;color:var(--down);border-color:rgba(255,111,139,.3)}

/* ---- gantt ---- */
.gantt{overflow-x:auto;border:1px solid var(--line);border-radius:12px;background:var(--bg2);padding:12px}
.g-axis{display:flex;font-size:10px;color:var(--mut2);position:sticky;top:0}
.g-axis .pad{flex:0 0 var(--lbl);position:sticky;left:0;background:var(--bg2);z-index:3}
.g-axis .d{flex:0 0 var(--dayw);text-align:center;border-left:1px solid rgba(255,255,255,.05);padding-bottom:4px}
.g-axis .d.wk{color:var(--pl3)}
.g-grp{margin-top:10px}
.g-grphdr{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--pl3);
  padding:5px 0 6px;position:sticky;left:0}
.g-grphdr .cl{color:var(--mut);font-weight:600}
.g-grphdr .ob{display:inline-flex;width:18px;height:18px;border-radius:50%;align-items:center;
  justify-content:center;font-size:9px;font-weight:700;background:#4a3a6e;color:var(--pl3)}
.g-grphdr .rag{width:9px;height:9px;border-radius:50%}
.rag.green{background:var(--up)}.rag.amber{background:var(--amber)}.rag.red{background:var(--down)}
.g-area{position:relative}
.g-row{display:flex;align-items:center;height:30px}
.g-lab{flex:0 0 var(--lbl);font-size:11.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  padding-right:10px;position:sticky;left:0;background:var(--bg2);z-index:2}
.g-lab.crit{color:#ffd2dc}
.g-track{position:relative;height:30px;flex:0 0 auto}
.g-bar{position:absolute;top:5px;height:20px;border-radius:6px;background:#3a2f55;cursor:grab;
  display:flex;align-items:center;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.3);touch-action:none}
.g-bar:active{cursor:grabbing}
.g-bar.done{background:#2c5a48}.g-bar.done .fill{background:var(--up)}
.g-bar.doing{background:#4a3a6e}.g-bar.doing .fill{background:var(--pl2)}
.g-bar.review{background:#4a3a6e}.g-bar.review .fill{background:var(--pl3)}
.g-bar.todo .fill{background:#7c5cc4}
.g-bar.crit{outline:1.5px solid rgba(255,111,139,.55)}
.g-bar .fill{position:absolute;left:0;top:0;bottom:0;border-radius:6px;opacity:.9}
.g-bar .bl{position:relative;z-index:2;font-size:9.5px;color:#fff;font-weight:600;padding:0 7px;white-space:nowrap}
.g-bar.ms{background:transparent;box-shadow:none;justify-content:center}
.g-bar.ms .dia{width:14px;height:14px;background:var(--pl3);transform:rotate(45deg);border-radius:2px}
.g-dep{position:absolute;top:0;pointer-events:none;overflow:visible;z-index:1}
.g-today{position:absolute;top:0;border-left:2px dashed var(--down);z-index:4}
.g-legend{display:flex;gap:14px;font-size:10.5px;color:var(--mut);margin-top:12px;flex-wrap:wrap}
.g-legend span{display:inline-flex;align-items:center;gap:5px}
.g-legend i{width:11px;height:11px;border-radius:3px;display:inline-block}

/* ---- client read-only ---- */
.csurface{max-width:880px;margin:0 auto}
.chero{background:linear-gradient(120deg,#2a1542,#3C1F5C);border-radius:16px;padding:24px 26px;margin-bottom:18px}
.chero h1{margin:0 0 6px;font-size:22px}
.chero p{margin:0;color:#e7defb;font-size:13px}
.cbar{height:9px;background:rgba(255,255,255,.15);border-radius:6px;margin-top:16px;overflow:hidden}
.cbar i{display:block;height:100%;background:var(--pl3);border-radius:6px}
.snap{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.snap .s{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.snap .s .v{font-size:24px;font-weight:700;color:var(--pl3)}
.snap .s .l{font-size:11.5px;color:var(--mut);margin-top:3px}
.cproj{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:14px}
.cproj h3{margin:0 0 2px;font-size:14px}
.cproj .due{color:var(--mut);font-size:11.5px;margin-bottom:12px}
.mile{display:flex;align-items:center;gap:11px;padding:7px 0;border-top:1px solid var(--line);font-size:13px}
.mile:first-of-type{border-top:0}
.mile .ic{width:20px;height:20px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;
  justify-content:center;font-size:11px;font-weight:700}
.ic.done{background:rgba(70,214,166,.16);color:var(--up)}
.ic.doing{background:rgba(183,156,242,.18);color:var(--pl3)}
.ic.todo{background:rgba(169,157,198,.12);color:var(--mut)}
.mile .md{color:var(--mut2);font-size:11px;margin-left:auto}
.note{color:var(--mut2);font-size:11px;text-align:center;margin-top:18px}

/* ---- login ---- */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login .box{background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:30px 28px;width:340px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.login .brand{font-size:18px;font-weight:700;margin-bottom:4px}
.login .brand span{color:var(--pl3)}
.login .tag{color:var(--mut);font-size:12px;margin-bottom:22px}
.login label{display:block;font-size:11.5px;color:var(--mut);margin:12px 0 5px}
.login input{width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:9px;
  padding:10px 12px;color:var(--txt);font:inherit}
.login button{width:100%;margin-top:20px;background:var(--pl);color:#fff;border:0;border-radius:9px;
  padding:11px;font:inherit;font-weight:600;cursor:pointer}
.login button:hover{background:#4d2873}
.login .err{background:rgba(255,111,139,.14);color:var(--down);border-radius:8px;
  padding:8px 12px;font-size:12px;margin-bottom:14px}
.login .demo{margin-top:18px;font-size:11px;color:var(--mut2);line-height:1.6;border-top:1px solid var(--line);padding-top:14px}
.login .demo code{color:var(--pl3)}
