/* ============================================================
   Nexus 2.0 — The Experience Lab design system
   Brand: orange #FF4000, charcoal "wet slate", yellow accent
   Type:  Bebas Neue (display) + Poppins (UI)
   ============================================================ */
:root{
  --orange:#F16622; --orange-600:#d34827; --orange-50:#fdeee5;
  --yellow:#FFC400;
  --ink:#222526; --slate:#3a3d3e; --slate-2:#5b6770; --grey:#888686;
  --line:#e9e6e4; --line-2:#f1eeec;
  --bg:#f6f4f2; --card:#ffffff; --muted:#8a8785;
  --good:#2e9e5b; --warn:#f0a300; --bad:#e53935;
  --radius:16px; --radius-sm:11px;
  --shadow:0 1px 2px rgba(20,18,16,.04), 0 8px 24px rgba(20,18,16,.06);
  --shadow-lg:0 12px 40px rgba(20,18,16,.14);
  --nav-w:230px; --header-h:62px;
  --sans:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --display:'Bebas Neue','Poppins',sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
svg.ic{width:18px;height:18px;flex:0 0 auto}
.search svg{width:16px;height:16px}
.btn svg.ic{width:15px;height:15px}
.profile .meta svg.ic,.crumb svg.ic{width:14px;height:14px;vertical-align:-2px}
.hamb svg{width:20px;height:20px}
body{
  font-family:var(--sans); color:var(--ink); background:var(--bg);
  font-size:14px; line-height:1.5; -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-weight:600;letter-spacing:-.01em}

/* ---------- Layout shell ---------- */
.shell{display:flex;min-height:100vh}
.side{
  width:var(--nav-w);flex:0 0 var(--nav-w);background:var(--ink);color:#cfccc9;
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:4px;
  padding:18px 14px;z-index:30;
}
.brand{display:flex;align-items:center;gap:10px;padding:10px 8px 16px;flex:0 0 auto}
.brand img{height:30px;width:auto;max-width:100%}
.nav{display:flex;flex-direction:column;gap:2px;margin-top:2px;flex:1 1 auto;min-height:0;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#46494b transparent}
.nav::-webkit-scrollbar{width:6px}
.nav::-webkit-scrollbar-thumb{background:#46494b;border-radius:3px}
.nav::-webkit-scrollbar-track{background:transparent}
.nav-sec{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:#6f6b67;font-weight:600;padding:14px 12px 5px}
.userbox{display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;background:#2c2f30;margin-bottom:8px}
.userbox:hover{background:#34373a}
.userbox .ub-meta{flex:1;min-width:0;line-height:1.25}
.userbox .ub-meta b{color:#fff;font-size:13px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.userbox .ub-meta small{color:#9a9692;font-size:11px}
.userbox .ic{width:16px;height:16px;color:#9a9692}
.nav a{
  display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:11px;
  color:#b9b5b1;font-weight:500;transition:.12s;
}
.nav a .ic{width:18px;height:18px;flex:0 0 18px;opacity:.85}
.nav a:hover{background:#2c2f30;color:#fff}
.nav a.on{background:var(--orange);color:#fff}
.nav a.on .ic{opacity:1}
.side .spacer{flex:0 0 8px}
.side .foot{font-size:11px;color:#6f6b67;padding:8px;border-top:1px solid #34373880;line-height:1.6}
.side .foot a{color:#9a9692;text-decoration:underline}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
  height:var(--header-h);display:flex;align-items:center;gap:14px;padding:0 22px;
  background:rgba(246,244,242,.85);backdrop-filter:saturate(1.4) blur(8px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;
}
.topbar h1{font-size:18px}
.topbar .crumb{color:var(--muted);font-size:12.5px;font-weight:500}
.search{flex:1;max-width:420px;margin-left:auto;position:relative}
.search input{
  width:100%;border:1px solid var(--line);background:#fff;border-radius:11px;
  padding:9px 12px 9px 34px;font-family:inherit;font-size:13.5px;color:var(--ink);
}
.search input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-50)}
.search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);opacity:.45}
.content{padding:22px;max-width:1320px;width:100%}
.hamb{display:none}

/* ---------- Bits ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;
  padding:3px 9px;border-radius:999px;background:#eee;color:#444;white-space:nowrap}
.pill .dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.pill.lead{background:var(--orange-50);color:var(--orange-600)}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:13px;
  padding:9px 15px;border-radius:11px;border:1px solid var(--line);background:#fff;
  color:var(--ink);cursor:pointer;transition:.12s}
.btn:hover{border-color:#d8d4d1;box-shadow:var(--shadow)}
.btn.primary{background:var(--orange);border-color:var(--orange);color:#fff}
.btn.primary:hover{background:var(--orange-600)}
.btn.ghost{background:transparent;border-color:transparent;color:var(--slate-2)}
.btn.danger{color:var(--bad)}
.btn.danger:hover{background:var(--bad);border-color:var(--bad);color:#fff}
.muted{color:var(--muted)}
.sec-title{font-family:var(--display);letter-spacing:.04em;font-size:15px;
  text-transform:uppercase;color:var(--slate-2);margin:26px 2px 12px}

/* ---------- Cards & grids ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.grid{display:grid;gap:16px}
/* Let grid/flex tracks shrink below their content's intrinsic width so nowrap
   text ellipses instead of forcing the whole card wider than the viewport. */
.grid>*,.fin-grid>*,.cs-body>*,.form-grid>*{min-width:0}
.kpis{grid-template-columns:repeat(4,1fr)}
.kpi{padding:18px 18px 16px;position:relative;overflow:hidden}
.kpi .lab{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.kpi .num{font-family:var(--display);font-size:48px;line-height:.95;margin-top:8px;color:var(--ink);white-space:nowrap}
.kpi .num.cur{font-size:34px;letter-spacing:.01em}
.kpi .sub{font-size:12px;color:var(--muted);margin-top:4px}
.kpi .accent{position:absolute;right:-18px;top:-18px;width:84px;height:84px;border-radius:50%;
  background:var(--orange-50)}
.kpi.k-orange .num{color:var(--orange)}
.cols-2{grid-template-columns:1.6fr 1fr}
.cols-3{grid-template-columns:repeat(3,1fr)}

/* ---------- Lists / rows ---------- */
.rowlist{display:flex;flex-direction:column}
.row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-top:1px solid var(--line-2)}
.row:first-child{border-top:0}
.row:hover{background:#fbfaf9}
.row .date-chip{flex:0 0 52px;text-align:center;background:#f4f1ef;border-radius:10px;padding:6px 4px}
.row .date-chip .d{font-family:var(--display);font-size:22px;line-height:1;color:var(--ink)}
.row .date-chip .m{font-size:10px;text-transform:uppercase;color:var(--muted);letter-spacing:.06em}
.row .main-txt{flex:1;min-width:0}
.row .main-txt b{display:block;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .main-txt small{color:var(--muted)}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:15px 16px;border-bottom:1px solid var(--line)}
.card-head h3{font-size:14.5px}
.card-head .count{font-size:12px;color:var(--muted)}

/* ---------- Alerts ---------- */
.alert-grp .row .ic{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex:0 0 28px}
.ic.warn{background:#fff6e0;color:#b07c00}
.ic.bad{background:#fde7e7;color:#c62828}
.ic.info{background:var(--orange-50);color:var(--orange-600)}
.empty{padding:26px 16px;text-align:center;color:var(--muted);font-size:13px}

/* ---------- Pipeline / board ---------- */
.legend{display:flex;flex-wrap:wrap;gap:14px;margin:4px 2px 0}
.legend span{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--slate-2)}
.legend i{width:10px;height:10px;border-radius:50%}
.board{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(270px,1fr);gap:14px;overflow-x:auto;padding-bottom:8px}
.col{background:#efece9;border-radius:14px;padding:10px;display:flex;flex-direction:column;gap:9px;min-height:120px}
.col-head{display:flex;align-items:center;justify-content:space-between;padding:4px 6px 2px}
.col-head .nm{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13px}
.col-head .tot{font-size:12px;color:var(--muted);background:#fff;border-radius:999px;padding:1px 9px}
.bk{background:#fff;border-radius:12px;padding:12px;box-shadow:var(--shadow);border:1px solid var(--line);transition:.12s;display:block}
.bk:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}
.bk .job{font-family:var(--display);font-size:18px;letter-spacing:.03em;color:var(--orange)}
.bk .cli{font-weight:600;margin:1px 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bk .meta{font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:4px 10px;margin-top:6px}
.bk .quote{font-weight:600;color:var(--ink)}
.col .more{text-align:center;font-size:12px;color:var(--muted);padding:4px}

/* ---------- Tables (actors / detail) ---------- */
.tbl{width:100%;border-collapse:collapse}
.tbl th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);text-align:left;padding:10px 14px;border-bottom:1px solid var(--line)}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--line-2);vertical-align:top}
.tbl tr:hover td{background:#fbfaf9}
.tbl th.sortable{cursor:pointer;user-select:none}
.tbl th.sortable:hover{color:var(--orange-600)}
.sort-ind{color:var(--orange);font-size:10px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex:0 0 34px}
.chips{display:flex;flex-wrap:wrap;gap:6px}

/* ---------- Booking detail ---------- */
.detail-head{display:flex;align-items:flex-start;gap:18px;flex-wrap:wrap}
.detail-head .job-badge{font-family:var(--display);font-size:40px;letter-spacing:.03em;color:#fff;background:var(--orange);border-radius:14px;padding:8px 18px;line-height:1}
.detail-head .ttl h1{font-size:23px}
.detail-head .ttl .sub{color:var(--muted);margin-top:3px}
.detail-head .actions{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-radius:14px;overflow:hidden;margin-top:18px}
.facts .f{background:#fff;padding:14px 16px}
.facts .f .k{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.facts .f .v{font-weight:600;margin-top:3px}
.svc{padding:0;overflow:hidden}
.svc .svc-top{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#faf8f6;border-bottom:1px solid var(--line)}
.svc .svc-top .num{font-family:var(--display);font-size:20px;color:var(--slate-2)}
.svc .svc-body{padding:6px 16px 14px}
.kv{display:flex;gap:8px;font-size:13px;padding:5px 0}
.kv .k{color:var(--muted);min-width:96px}
.team{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.team .m{display:flex;align-items:center;gap:10px;font-size:13px}
.team .m .role{color:var(--muted);font-size:12px}
.strike{text-decoration:line-through;opacity:.6}

/* ---------- Calendar ---------- */
#cal{--fc-border-color:var(--line);--fc-today-bg-color:var(--orange-50);background:#fff;border-radius:var(--radius);
  border:1px solid var(--line);box-shadow:var(--shadow);padding:14px}
.fc .fc-toolbar-title{font-family:var(--display);letter-spacing:.03em;font-weight:400;font-size:24px}
.fc .fc-button{background:#fff!important;border:1px solid var(--line)!important;color:var(--ink)!important;
  text-transform:capitalize;font-weight:600;box-shadow:none!important}
.fc .fc-button-primary:not(:disabled).fc-button-active{background:var(--orange)!important;border-color:var(--orange)!important;color:#fff!important}
.fc .fc-daygrid-day-number{color:var(--slate-2);font-weight:500}
.fc-event{border:none;border-radius:6px;padding:1px 5px;font-size:11.5px;font-weight:600;cursor:pointer}
.fc-event:hover{filter:brightness(.94)}

/* ---------- Money / finance ---------- */
.money-tile{padding:16px 18px}
.money-tile .lab{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.money-tile .big{font-family:var(--display);font-size:32px;margin-top:6px;color:var(--ink)}
.money-tile .big.in{color:var(--good)} .money-tile .big.out{color:var(--orange-600)}
.periods{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.periods a{padding:7px 13px;border-radius:999px;border:1px solid var(--line);background:#fff;font-size:12.5px;font-weight:600;color:var(--slate-2)}
.periods a.on{background:var(--orange);border-color:var(--orange);color:#fff}
.barchart{display:flex;align-items:flex-end;gap:10px;height:200px;padding:10px 4px 0}
.barchart .mb{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:3px;height:100%}
.barchart .pair{display:flex;align-items:flex-end;gap:3px;height:100%;width:100%;justify-content:center}
.barchart .bar{width:42%;border-radius:5px 5px 0 0;min-height:2px}
.barchart .bar.in{background:var(--good)} .barchart .bar.out{background:var(--orange)}
.barchart .mlab{font-size:10.5px;color:var(--muted);white-space:nowrap}
.fin-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:16px;margin-top:16px}

/* ---------- Actor cards ---------- */
.actor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.actor-card{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:18px 14px;text-align:center;transition:.12s;display:block}
.actor-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.headshot{width:84px;height:84px;border-radius:50%;object-fit:cover;background:var(--ink);margin:0 auto 10px;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--display);font-size:30px;overflow:hidden}
.headshot img{width:100%;height:100%;object-fit:cover;background:#fff}
/* Transparent circle PNGs: white backdrop so they match the opaque jpeg headshots
   (no grey rim where the circle is transparent inside the round clip). */
.headshot:has(img){background:#fff}
.actor-card .nm{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.actor-card .sub{font-size:12px;color:var(--muted);margin-top:2px}
.actor-card .badge{display:inline-block;margin-top:8px;font-size:11px;font-weight:600;color:var(--orange-600);background:var(--orange-50);border-radius:999px;padding:2px 10px}
.inactive-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#c0c0c0;margin-right:5px}

/* ---------- Profile header ---------- */
.profile{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.profile .headshot{width:110px;height:110px;font-size:40px;margin:0}
.profile h1{font-size:24px}
.profile .meta{display:flex;flex-wrap:wrap;gap:6px 16px;color:var(--slate-2);font-size:13px;margin-top:6px}
.profile .actions{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}

/* ---------- Forms ---------- */
.form-card{max-width:780px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px}
.fgroup{display:flex;flex-direction:column;gap:5px}
.fgroup.full{grid-column:1 / -1}
.fgroup label{font-size:12px;font-weight:600;color:var(--slate-2)}
.fgroup .help{font-size:11px;color:var(--muted)}
.fgroup .err{font-size:11.5px;color:var(--bad)}
.fld{width:100%;border:1px solid var(--line);border-radius:10px;padding:9px 11px;font-family:inherit;font-size:13.5px;background:#fff;color:var(--ink)}
.fld:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-50)}
textarea.fld{min-height:74px;resize:vertical}
.fld-check{width:18px;height:18px;accent-color:var(--orange)}
.check-row{display:flex;align-items:center;gap:9px;padding:6px 0}
.form-actions{display:flex;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--line)}
.msg{padding:11px 14px;border-radius:11px;margin-bottom:14px;font-size:13px;font-weight:500}
.msg.success{background:#e7f6ec;color:#1c7a3f} .msg.error{background:#fde7e7;color:#c62828}

/* ---------- Simple list pages ---------- */
.list-head{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.list-head .search{margin:0;max-width:320px}
.list-head .btn{margin-left:auto}
.formset-row{border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px;background:#fbfaf9}
.tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:1px solid var(--line)}
.tabs a{padding:9px 14px;font-weight:600;font-size:13px;color:var(--muted);border-bottom:2px solid transparent;cursor:pointer}
.tabs a.on{color:var(--orange-600);border-bottom-color:var(--orange)}

/* ---------- Call sheet ---------- */
.cs-row.cancelled{opacity:.6}
.cs-head{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#faf8f6;border-bottom:1px solid var(--line)}
.cs-date{flex:0 0 54px;text-align:center;background:var(--ink);color:#fff;border-radius:11px;padding:7px 4px}
.cs-date .d{font-family:var(--display);font-size:24px;line-height:1}
.cs-date .m{font-size:10px;text-transform:uppercase;letter-spacing:.06em}
.cs-date .y{font-size:9.5px;color:#b9b5b1;text-transform:uppercase}
.cs-fee{font-family:var(--display);font-size:22px;color:var(--orange-600);white-space:nowrap}
.cs-body{display:grid;grid-template-columns:1.3fr 1fr;gap:14px;padding:14px 16px}
.cs-times{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.cs-times>div{background:#f4f1ef;border-radius:9px;padding:6px 11px;font-weight:600;font-size:13px}
.cs-times>div span{display:block;font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
@media print{
  .side,.topbar,.periods,.list-head,.no-print{display:none!important}
  .content{padding:0;max-width:none}.shell{display:block}.main{display:block}
  body{background:#fff}
  .card{box-shadow:none;border:1px solid #ccc;break-inside:avoid}
  .travel-cards{grid-template-columns:1fr 1fr!important;gap:8px}
  .detail-head .job-badge{print-color-adjust:exact;-webkit-print-color-adjust:exact}
  .cs-fee,.headshot,.pill{print-color-adjust:exact;-webkit-print-color-adjust:exact}
  a[href]:after{content:""}
}

/* ---------- HR matrix table ---------- */
.hr-table{font-size:12.5px;white-space:nowrap}
.hr-table thead th{position:sticky;top:0;background:#fff;z-index:2;user-select:none}
.hr-table th.sortable{cursor:pointer}
.hr-table th.sortable:hover{color:var(--orange-600)}
.hr-table .sort-ind{color:var(--orange);font-size:10px}
.hr-table .filter-row td{position:sticky;top:35px;background:#fff;z-index:3;padding:5px 8px;overflow:visible}
.hr-table tbody td{max-width:240px;overflow:hidden;text-overflow:ellipsis}
.dd{position:relative}
.dd-btn{width:100%;min-width:96px;text-align:left;border:1px solid var(--line);border-radius:7px;background:#fff;padding:4px 22px 4px 8px;font-family:inherit;font-size:11.5px;color:var(--muted);cursor:pointer;white-space:nowrap;position:relative}
.dd-btn:after{content:"▾";position:absolute;right:7px;top:4px;color:var(--muted)}
.dd-btn.active{color:var(--orange-600);border-color:var(--orange);font-weight:600}
.dd-panel{position:absolute;top:calc(100% + 3px);left:0;z-index:40;width:230px;max-width:80vw;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-lg);padding:8px}
.dd-search{width:100%;border:1px solid var(--line);border-radius:7px;padding:5px 8px;font-family:inherit;font-size:12px;margin-bottom:6px}
.dd-list{max-height:230px;overflow:auto;display:flex;flex-direction:column;gap:1px}
.dd-list label{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:400;padding:3px 4px;border-radius:6px;cursor:pointer;white-space:nowrap}
.dd-list label:hover{background:#f4f1ef}
.dd-list input{accent-color:var(--orange)}
.dd-foot{border-top:1px solid var(--line);margin-top:6px;padding-top:6px;text-align:right}
.dd-clear{font-size:11.5px;color:var(--orange-600);cursor:pointer;font-weight:600}

/* ---------- Email actions ---------- */
.email-actions{display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px 10px;margin-top:10px;padding-top:12px;border-top:1px dashed var(--line)}
.email-btn{display:inline-flex;flex-direction:column;gap:3px}
.email-btn .sent-marker{text-align:center;min-height:13px}
.email-btn .sent{font-size:10.5px;color:var(--good);font-weight:600}
.email-btn .unsent{font-size:10.5px;color:var(--muted)}

/* ---------- Subscribe popover ---------- */
.subscribe{position:relative;display:inline-block}
.subscribe>summary{list-style:none;cursor:pointer}
.subscribe>summary::-webkit-details-marker{display:none}
.subscribe[open]>summary{border-color:var(--orange);color:var(--orange-600)}
.sub-pop{position:absolute;right:0;top:calc(100% + 6px);z-index:60;width:330px;max-width:86vw;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:14px}
.sub-pop input{width:100%}

/* ---------- Scroll to top ---------- */
#scrolltop{position:fixed;right:22px;bottom:22px;width:42px;height:42px;border-radius:50%;border:none;background:var(--ink);color:#fff;font-size:18px;cursor:pointer;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transform:translateY(8px);transition:.18s;z-index:50}
#scrolltop.show{opacity:1;pointer-events:auto;transform:translateY(0)}
#scrolltop:hover{background:var(--orange)}
@media print{#scrolltop{display:none}}

/* ---------- Calendar category toggles ---------- */
.cat-toggles{display:flex;flex-wrap:wrap;gap:8px;margin-left:auto}
.cat-chip{display:inline-flex;align-items:center;gap:7px;border:1.6px solid var(--c,#ccc);background:#fff;border-radius:999px;padding:6px 14px;font-family:inherit;font-size:12.5px;font-weight:600;color:var(--c,#888);cursor:pointer;transition:.12s}
.cat-chip:before{content:"";width:9px;height:9px;border-radius:50%;background:var(--c,#ccc)}
.cat-chip.on{background:var(--c,#ccc);color:#fff;border-color:var(--c,#ccc)}
.cat-chip.on:before{background:#fff}
.cat-chip:not(.on){opacity:.85}
.fc-ev{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11.5px}

/* ---------- Compare chart ---------- */
.compare-wrap{position:relative;height:300px}

/* ---------- Responsive ---------- */
/* Wide data tables get their own horizontal scroll on smaller screens instead
   of pushing the whole page sideways. Scoped to the card so the table keeps its
   normal layout and only the table scrolls. */
@media(max-width:820px){
  .tbl{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
  /* FullCalendar's toolbar (view buttons) wraps instead of overflowing */
  .fc .fc-header-toolbar{flex-wrap:wrap;gap:8px 12px}
  .fc .fc-toolbar-chunk{display:flex;flex-wrap:wrap;gap:6px}
}
@media(max-width:900px){
  :root{--nav-w:0px}
  .side{position:fixed;left:-260px;width:240px;flex-basis:240px;transition:.2s;box-shadow:var(--shadow-lg)}
  body.nav-open .side{left:0}
  .hamb{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;cursor:pointer}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .cols-2,.cols-3{grid-template-columns:1fr}
  .fin-grid,.cs-body,.form-grid{grid-template-columns:1fr}
  .facts{grid-template-columns:repeat(2,1fr)}
  .search{max-width:none}
  .scrim{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:25;display:none}
  body.nav-open .scrim{display:block}
}
@media(max-width:520px){
  .kpis{grid-template-columns:1fr 1fr}
  .kpi .num{font-size:38px}
  .kpi .num.cur{font-size:24px}
  .facts{grid-template-columns:1fr}
  .detail-head .job-badge{font-size:30px}
  .content{padding:16px}
  /* break long emails / handles instead of overflowing (not table number cells —
     those stay whole and the table scrolls instead) */
  .profile .meta span,.kv span{overflow-wrap:anywhere}
  .fc .fc-toolbar-title{font-size:20px}
}
