:root{
  --bg:#0f1117; --panel:#171a23; --panel2:#1e2230; --line:#2a2f40;
  --txt:#e7e9ee; --muted:#9aa1b2; --accent:#fbbf24;
  --busy:#ef4444; --prefer:#22c55e; --fixed:#a855f7; --visa:#f97316;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--txt);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;}
a{color:var(--accent)}
.wrap{max-width:1180px;margin:0 auto;padding:26px 20px 80px}
header.top{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:4px}
header.top h1{font-size:26px;margin:0;letter-spacing:-.5px}
header.top .sub{color:var(--muted);font-size:14px}
.tagline{color:var(--muted);font-size:13px;margin:6px 0 22px}

.grid2{display:grid;grid-template-columns:1.55fr 1fr;gap:20px;align-items:start}
@media(max-width:880px){.grid2{grid-template-columns:1fr}}

.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.card h2{margin:0 0 12px;font-size:15px;letter-spacing:.3px;text-transform:uppercase;color:var(--muted)}

/* recommendation */
.rec{display:flex;flex-direction:column;gap:10px}
.recItem{background:var(--panel2);border:1px solid var(--line);border-left:4px solid var(--accent);
  border-radius:10px;padding:12px 14px}
.recItem.top{border-left-color:var(--prefer);box-shadow:0 0 0 1px rgba(34,197,94,.25)}
.recItem .dates{font-size:17px;font-weight:600}
.recItem .meta{color:var(--muted);font-size:13px;margin-top:3px;line-height:1.5}
.pill{display:inline-block;font-size:11px;padding:2px 8px;border-radius:20px;background:#2a2f40;color:var(--muted);margin-right:6px}
.pill.good{background:rgba(34,197,94,.16);color:#7be3a0}
.pill.warn{background:rgba(249,115,22,.16);color:#f9a86a}

/* candidate availability roster */
.recItem .avline{font-size:14px;font-weight:600;color:var(--txt);margin-top:3px}
.recItem .avline small{color:var(--muted);font-weight:400;font-size:12px}
.pavlist{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.pav{font-size:12px;padding:3px 9px;border-radius:20px;border:1px solid var(--line);
  display:inline-flex;gap:5px;align-items:center;white-space:nowrap}
.pav.ok{background:rgba(34,197,94,.13);color:#86e6a8;border-color:rgba(34,197,94,.32)}
.pav.no{background:rgba(239,68,68,.11);color:#f19aa0;border-color:rgba(239,68,68,.30)}
.pav.warn{background:rgba(249,115,22,.13);color:#f9b27a;border-color:rgba(249,115,22,.34)}
.pav.pending{background:var(--panel2);color:var(--muted)}
.pav .rsn{opacity:.75;font-size:11px}

/* calendar */
.calwrap{display:flex;flex-direction:column;gap:18px}
.month h3{margin:0 0 8px;font-size:14px;color:var(--txt)}
.dow,.days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.dow span{font-size:10px;color:var(--muted);text-align:center;padding-bottom:2px}
.day{position:relative;aspect-ratio:1/1;border-radius:7px;background:var(--panel2);
  border:1px solid transparent;font-size:11px;display:flex;align-items:flex-start;justify-content:flex-end;
  padding:3px 4px;cursor:default;transition:transform .08s}
.day.empty{background:transparent}
.day .num{opacity:.75}
.day .dots{position:absolute;left:3px;bottom:3px;display:flex;gap:2px;flex-wrap:wrap;max-width:80%}
.day .dot{width:5px;height:5px;border-radius:50%}
.day.prefer{outline:2px solid var(--prefer);outline-offset:-2px}
.day.hasbusy{background:#241a1f}
.day.fixedday{background:#221a2b}
.day.visaday{background:#241f16}
.day.candidate{border-top:2px solid var(--accent)}
.day.candidate .num{color:var(--accent);opacity:1}
.day.today{border-color:var(--accent)}
.day:hover{transform:scale(1.08);z-index:5;border-color:var(--line)}
.day .avail{position:absolute;left:3px;top:3px;font-size:9px;color:var(--muted)}

/* tooltip */
#tip{position:fixed;z-index:50;pointer-events:none;background:#0b0d13;border:1px solid var(--line);
  border-radius:10px;padding:10px 12px;font-size:12px;max-width:260px;display:none;box-shadow:0 8px 30px rgba(0,0,0,.5)}
#tip b{color:var(--accent)}
#tip .row{margin-top:5px;line-height:1.4}

/* people */
.person{background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:12px 13px;margin-bottom:10px}
.person .head{display:flex;align-items:center;gap:9px}
.person .ava{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.person .nm{font-weight:600}
.person .home{font-size:12px;color:var(--muted)}
.status{margin-left:auto;font-size:11px;padding:3px 9px;border-radius:20px;font-weight:600}
.status.confirmed{background:rgba(34,197,94,.16);color:#7be3a0}
.status.pending{background:rgba(249,115,22,.16);color:#f9a86a}
.person .prof{font-size:12px;color:var(--muted);margin-top:8px;line-height:1.5}
.clist{list-style:none;margin:9px 0 0;padding:0;display:flex;flex-direction:column;gap:5px}
.clist li{font-size:12px;display:flex;gap:8px;align-items:baseline}
.tag{font-size:10px;font-weight:700;padding:1px 7px;border-radius:5px;text-transform:uppercase;flex-shrink:0;letter-spacing:.3px}
.tag.busy{background:rgba(239,68,68,.18);color:#f59ca0}
.tag.prefer{background:rgba(34,197,94,.18);color:#86e6a8}
.tag.fixed{background:rgba(168,85,247,.18);color:#cda6f5}
.tag.visa{background:rgba(249,115,22,.18);color:#f9b27a}
.clist .lbl{color:var(--txt)} .clist .dt{color:var(--muted)}

.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--muted);margin:2px 0 14px}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:-1px}

.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
button.btn{background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:9px;
  padding:8px 13px;font-size:13px;cursor:pointer}
button.btn:hover{border-color:var(--accent)}
.progress{font-size:12px;color:var(--muted);margin-top:4px}
.barwrap{height:7px;background:var(--panel2);border-radius:6px;overflow:hidden;margin-top:6px}
.bar{height:100%;background:linear-gradient(90deg,#22c55e,#fbbf24)}
