/* Infinity Worker Control Plane — console theme, aligned to fixia.it
   (Plus Jakarta Sans, purple→coral brand gradient, light surfaces). */
:root{
  /* brand (from fixia.it) */
  --purple-deep:#3D1844; --purple:#51255F; --purple-light:#7F2E62;
  --rose:#B43A5C; --coral-deep:#E63B49; --coral:#F14A54; --salmon:#F8A8AD;
  --gradient-brand:linear-gradient(135deg,#3D1844 0%,#51255F 22%,#7F2E62 42%,#B43A5C 62%,#E63B49 82%,#F14A54 100%);

  /* surfaces */
  --page:#F5F3F5; --card:#FFFFFF; --card2:#FAF8FA;
  --ink:#1A0A16; --ink2:#6B5A65;
  --line:rgba(61,24,68,.10); --line-strong:rgba(61,24,68,.16);
  --accent:#E63B49;

  /* status */
  --ok:#0FA968; --warn:#D9920B; --bad:#E63B49; --partner:#7F2E62; --custom:#1C7C9C;
  --surface:#FFFFFF; --surface-glass:rgba(255,255,255,.92); --map-bg:#e6edf2;

  --radius:14px; --radius-sm:10px;
  --shadow:0 1px 2px rgba(26,10,22,.04),0 10px 30px rgba(26,10,22,.07);
  --shadow-sm:0 1px 2px rgba(26,10,22,.05);
  --font:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font:14px/1.5 var(--font);background:var(--page);color:var(--ink);
  -webkit-font-smoothing:antialiased}
.hidden{display:none !important}
.muted{color:var(--ink2)}
.brand{font-weight:800;letter-spacing:.2px;font-size:16px;display:flex;align-items:center;gap:9px}
.brand-logo{height:22px;width:auto;display:block}
.login-card .brand-logo{height:30px}
.brand span{background:var(--gradient-brand);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent}

button{background:var(--gradient-brand);color:#fff;border:0;border-radius:10px;padding:9px 16px;
  font-weight:700;font-family:var(--font);cursor:pointer;transition:filter .2s,transform .05s}
button:hover{filter:brightness(1.06)} button:active{transform:translateY(1px)}
button.ghost{background:var(--surface);border:1px solid var(--line-strong);color:var(--ink);font-weight:600}
button.ghost:hover{background:var(--card2);filter:none}
input,select,textarea{background:var(--surface);border:1px solid var(--line-strong);color:var(--ink);
  border-radius:10px;padding:9px 11px;width:100%;font-family:var(--font);font-size:14px}
textarea{resize:vertical;line-height:1.4}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(241,74,84,.12)}
input::placeholder,textarea::placeholder{color:#a99daa}

/* login */
.login-body{display:grid;place-items:center;height:100vh;
  background:var(--gradient-brand)}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:20px;
  padding:30px 32px;width:330px;display:flex;flex-direction:column;gap:12px;box-shadow:0 30px 80px rgba(26,10,22,.35)}
.login-card .brand{font-size:18px}
.login-card h1{margin:6px 0 8px;font-size:21px;font-weight:800}
.login-card label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--ink2);font-weight:600}
.login-card .hint{color:var(--ink2);font-size:12px;margin:2px 0 0}
.login-card .err{color:var(--bad);font-size:13px;margin:0;font-weight:600}

/* topbar */
.topbar{display:flex;align-items:center;gap:16px;height:60px;padding:0 20px;
  background:var(--card);border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm)}
.topbar .spacer{flex:1}
.who{color:var(--ink2);font-weight:600}
.inline{display:inline}
.badge{background:rgba(230,59,73,.12);color:var(--bad);font-weight:800;font-size:11px;letter-spacing:.6px;
  padding:5px 10px;border-radius:999px}
.toggle{display:flex;align-items:center;gap:7px;color:var(--ink2);font-size:13px;font-weight:600;cursor:pointer}
.toggle input{width:auto}

/* account / profile menu */
.profile{position:relative}
.profile-btn{display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line-strong);
  border-radius:999px;padding:4px 11px 4px 4px;cursor:pointer;color:var(--ink)}
.profile-btn:hover{background:var(--card2);filter:none}
.avatar-sm{flex:none;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;
  color:#fff;font-weight:800;font-size:12px;background:var(--gradient-brand)}
.avatar-sm.lg{width:38px;height:38px;font-size:15px}
.profile-meta{display:flex;flex-direction:column;line-height:1.15;text-align:left;min-width:0}
.profile-meta b{font-size:13px;font-weight:700;color:var(--ink)}
.profile-meta small{font-size:11px;color:var(--ink2);text-transform:capitalize}
.profile .caret{color:var(--ink2);font-size:11px}
.profile-menu{position:absolute;right:0;top:calc(100% + 8px);min-width:210px;background:var(--surface);
  border:1px solid var(--line-strong);border-radius:12px;box-shadow:var(--shadow);padding:8px;z-index:1200}
.profile-head{display:flex;align-items:center;gap:10px;padding:6px 8px 11px;border-bottom:1px solid var(--line);margin-bottom:6px}
.menu-item{width:100%;background:transparent;border:none;color:var(--ink);font-weight:600;font-size:13px;
  text-align:left;padding:9px 10px;border-radius:8px;cursor:pointer}
.menu-item:hover{background:var(--card2);filter:none}
.menu-item.danger{color:var(--bad)}
.menu-item.danger:hover{background:rgba(230,59,73,.08)}

/* refresh button — bigger glyph, proportionate to the pill */
.refresh-btn{font-size:19px;width:34px;height:34px;line-height:1}

/* view-mode menu (Dev / View / View Lite) */
.modemenu{position:relative}
.mode-btn{display:flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line-strong);
  border-radius:999px;padding:7px 13px;cursor:pointer;color:var(--ink);font-weight:700;font-size:13px;white-space:nowrap}
.mode-btn:hover{background:var(--card2);filter:none}
.mode-btn .caret{color:var(--ink2);font-size:11px}
.mode-list{position:absolute;right:0;top:calc(100% + 8px);min-width:236px;background:var(--surface);
  border:1px solid var(--line-strong);border-radius:12px;box-shadow:var(--shadow);padding:8px;z-index:1200}
.mode-list .menu-item{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:1px;padding:9px 28px 9px 11px}
.mode-list .menu-item small{font-weight:500;color:var(--ink2);font-size:11px}
.mode-list .menu-item.current{background:var(--card2)}
.mode-list .menu-item.current::after{content:'✓';position:absolute;right:11px;top:10px;color:var(--accent);font-weight:800}

/* layout — fills the viewport; sidebar scrolls, map stretches */
.layout{display:grid;grid-template-columns:1fr 400px;gap:18px;padding:18px;height:100%}
.panel-title{font-weight:700;margin:0 0 12px;display:flex;align-items:center;gap:12px;font-size:15px}
.panel-title .filters{margin-left:auto}
.dot,.sq{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:4px;vertical-align:-1px}
.sq{border-radius:3px;background:var(--partner)}
.sq.custom{background:var(--custom)}
.dot.ok{background:var(--ok)} .dot.warn{background:var(--warn)} .dot.bad{background:var(--bad)}

.mapcol{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;display:flex;flex-direction:column;min-height:0;box-shadow:var(--shadow-sm)}
.mapwrap{position:relative;flex:1;min-height:0;display:flex}
.map{flex:1;min-height:0;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
/* globe client markers: glass pin (single) / city badge (cluster) + ground stem */
.gmark{display:flex;flex-direction:column;align-items:center;transform:translate(-50%,-100%);
  pointer-events:none;transition:opacity .25s}
/* only the badge is clickable — names/stems are click-through, so a label
   overlapping another marker never blocks the badge underneath it */
.gmark-badge{pointer-events:auto;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;height:42px;min-width:42px;
  padding:7px 9px;border-radius:13px;background:rgba(13,9,24,.78);backdrop-filter:blur(2px);
  border:1.5px solid;box-sizing:border-box;transition:transform .15s}
.gmark-badge svg{width:25px;height:25px;flex:none}
.gmark-badge b{color:#fff;font-size:14px;font-weight:800;line-height:1}
.gmark:hover .gmark-badge{transform:scale(1.18)}
.gmark.partner .gmark-badge{border-color:#C06CA8;color:#E3A8D2;box-shadow:0 0 12px rgba(180,58,140,.55)}
.gmark.custom .gmark-badge{border-color:#3FB8DD;color:#9FE2F7;box-shadow:0 0 12px rgba(63,184,221,.5)}
.gmark.mixed .gmark-badge{color:#E3A8D2;border-color:#9C8CD8;box-shadow:0 0 12px rgba(140,120,210,.55)}
.gmark-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  font-size:11.5px;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.9);margin:3px 0 1px}
.gmark-stem{width:1.5px;height:12px}

/* VPS pin on the globe: server-rack badge, status-colored */
.gmark.vps.ok .gmark-badge{border-color:var(--ok);color:#6FE0AE;box-shadow:0 0 12px rgba(15,169,104,.5)}
.gmark.vps.warn .gmark-badge{border-color:var(--warn);color:#F2C063;box-shadow:0 0 12px rgba(217,146,11,.5)}
.gmark.vps.bad .gmark-badge{border-color:var(--bad);color:#F08792;box-shadow:0 0 12px rgba(230,59,73,.55)}
.gmark.vps.ok .gmark-stem{background:linear-gradient(to bottom,var(--ok),transparent)}
.gmark.vps.warn .gmark-stem{background:linear-gradient(to bottom,var(--warn),transparent)}
.gmark.vps.bad .gmark-stem{background:linear-gradient(to bottom,var(--bad),transparent)}
.gmark.partner .gmark-stem{background:linear-gradient(to bottom,#C06CA8,transparent)}
.gmark.custom .gmark-stem{background:linear-gradient(to bottom,#3FB8DD,transparent)}
.gmark.mixed .gmark-stem{background:linear-gradient(to bottom,#9C8CD8,transparent)}

/* transient notice (globe fallback etc.) — never a blocking alert() */
.gtoast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,12px);z-index:3000;
  background:rgba(20,14,28,.94);color:#fff;font-size:13px;font-weight:600;padding:10px 16px;
  border-radius:11px;border:1px solid rgba(255,255,255,.16);box-shadow:0 10px 30px rgba(0,0,0,.4);
  opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
.gtoast.show{opacity:1;transform:translate(-50%,0)}

/* absolute inside .mapwrap: the WebGL canvas can never influence page layout */
.globe{position:absolute;inset:0;border-radius:12px;overflow:hidden;border:1px solid var(--line);
  background:radial-gradient(ellipse at 50% 40%,#1b1130 0%,#0e0918 55%,#070510 100%)}
.globe.blue{background:radial-gradient(ellipse at 50% 40%,#101a36 0%,#090f20 55%,#04070f 100%)}
.globe-loading{position:absolute;inset:0;display:grid;place-items:center;color:#cbb8d6;font-size:13px;font-weight:600}
.globe canvas{outline:none}
.globe.hidden,.map.hidden{display:none}
.map-legend{position:absolute;right:12px;top:12px;z-index:600;display:flex;flex-direction:column;gap:5px;
  background:var(--surface-glass);border:1px solid var(--line-strong);border-radius:10px;
  padding:8px 11px;font-size:11.5px;font-weight:600;color:var(--ink2);box-shadow:var(--shadow-sm)}
.leg-group{display:flex;align-items:center;gap:9px;white-space:nowrap}

/* unified map controls (zoom +/− and reset) — shown over both 2D and 3D */
.mapctrls{position:absolute;left:12px;top:12px;z-index:700;display:flex;flex-direction:column;gap:6px}
.mapctrls button{width:34px;height:34px;padding:0;display:grid;place-items:center;
  background:var(--surface-glass);border:1px solid var(--line-strong);border-radius:9px;color:var(--ink);
  cursor:pointer;box-shadow:var(--shadow-sm);transition:background .15s}
.mapctrls button:hover{background:var(--card2)}
.mapctrls button svg,.refresh-btn svg{width:18px;height:18px;display:block;fill:none;
  stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* 2D client cluster badge — flat-map mirror of the 3D "city" badge */
.cluster-marker{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;
  background:rgba(13,9,24,.82);border:2px solid #C06CA8;color:#fff;font-weight:800;font-size:13px;
  box-shadow:0 0 12px rgba(180,58,140,.5)}
.cluster-marker.custom{border-color:#3FB8DD;box-shadow:0 0 12px rgba(63,184,221,.5)}
.cluster-marker.mixed{border-color:#9C8CD8;box-shadow:0 0 12px rgba(140,120,210,.5)}
.cluster-marker span{pointer-events:none}

/* floating on-map panel listing the clients inside a cluster (2D + 3D) */
.cluster-pop{position:absolute;z-index:800;min-width:152px;max-width:240px;max-height:244px;overflow:auto;
  background:var(--surface-glass);border:1px solid var(--line-strong);border-radius:11px;
  box-shadow:0 12px 32px rgba(0,0,0,.4);padding:8px;backdrop-filter:blur(5px)}
.cluster-pop.hidden{display:none}
.cluster-pop-h{display:flex;align-items:center;justify-content:space-between;gap:8px;
  font-size:11px;font-weight:800;color:var(--ink2);text-transform:uppercase;letter-spacing:.04em;margin:0 2px 6px}
.cluster-pop-x{cursor:pointer;border:none;background:transparent;color:var(--ink2);font-size:17px;line-height:1;padding:0 2px}
.cluster-pop-x:hover{color:var(--ink)}
.cluster-pop-row{display:flex;align-items:center;gap:8px;padding:5px 7px;border-radius:7px;cursor:pointer;
  font-size:12.5px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cluster-pop-row:hover{background:var(--card2)}
.cluster-pop-dot{width:8px;height:8px;border-radius:50%;flex:none}
.cluster-pop-dot.partner{background:var(--partner)}
.cluster-pop-dot.custom{background:var(--custom)}

/* red/blue hue toggle tints the 2D basemap tiles (borders included) */
.map.tint-red .leaflet-tile-pane{filter:sepia(.32) saturate(1.5) hue-rotate(-28deg)}
.map.tint-blue .leaflet-tile-pane{filter:sepia(.32) saturate(1.6) hue-rotate(178deg)}

/* fleet KPI summary */
.summary{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 14px}
.kpi{flex:1;min-width:84px;display:flex;align-items:center;gap:10px;background:var(--card2);
  border:1px solid var(--line);border-radius:12px;padding:11px 13px}
.kpi-body{display:flex;flex-direction:column;min-width:0}
.kpi-body b{font-size:21px;font-weight:800;line-height:1.1;color:var(--ink)}
.kpi-body b small{font-size:13px;font-weight:700;color:var(--ink2)}
.kpi-body span{color:var(--ink2);font-size:10px;text-transform:uppercase;letter-spacing:.5px;font-weight:700;white-space:nowrap}
.kpi.warn .kpi-body b{color:var(--warn)}
.kpi-lead{flex:1.5;border-color:transparent;background:linear-gradient(135deg,rgba(15,169,104,.13),rgba(15,169,104,.03))}
.kpi-lead.bad{background:linear-gradient(135deg,rgba(230,59,73,.14),rgba(230,59,73,.03))}
.kpi-lead .kpi-body b{color:var(--ok)} .kpi-lead.bad .kpi-body b{color:var(--bad)}
.kpi-dot{flex:none;width:11px;height:11px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 4px rgba(15,169,104,.18)}
.kpi-lead.bad .kpi-dot{background:var(--bad);box-shadow:0 0 0 4px rgba(230,59,73,.18)}

/* sidebar cards — clearly separated white surfaces */
.sidecol{display:flex;flex-direction:column;gap:12px;overflow:auto;min-height:0;padding-right:2px}

/* sidebar tabs */
.tabs{display:flex;gap:4px;flex:none;background:var(--card2);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:4px}
.tab{flex:1;background:transparent;border:none;color:var(--ink2);font-weight:700;font-size:13px;
  padding:7px 10px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}
.tab:hover{color:var(--ink);filter:none}
.tab.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}
.tab-count{font-size:11px;font-weight:700;color:var(--ink2);background:var(--line);
  border-radius:999px;padding:0 6px;min-width:18px;text-align:center}
.tabpane{display:none;flex:1;min-height:0;overflow:auto;padding-right:2px}
.tabpane.active{display:flex;flex-direction:column;gap:16px}

/* map kind filter pills */
.filters{display:flex;gap:4px;background:var(--card2);border:1px solid var(--line);
  border-radius:999px;padding:3px}
.fpill{background:transparent;border:none;color:var(--ink2);font-weight:700;font-size:11.5px;
  padding:4px 11px;border-radius:999px;cursor:pointer}
.fpill:hover{color:var(--ink);filter:none}
.fpill.active{background:var(--purple);color:#fff;box-shadow:var(--shadow-sm)}

/* client search box */
.search{width:100%;margin:0 0 10px;padding:8px 11px;font-size:13px;border-radius:var(--radius-sm)}

/* client-kind avatar tint */
.pavatar.custom{background:var(--custom)}
.pavatar.partner{background:var(--partner)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow)}
.card-h{font-weight:700;font-size:13px;margin:-2px 0 12px;padding-bottom:10px;
  border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.detail h3{margin:0 0 12px;font-size:16px;font-weight:800;display:flex;align-items:center;gap:8px}
.kv{display:flex;justify-content:space-between;gap:10px;border-bottom:1px solid var(--line);padding:7px 0}
.kv:last-child{border:0}
.kv.sub{border:0;padding:0 0 7px;font-size:12px}
.kv span{color:var(--ink2)} .kv b{color:var(--ink);font-weight:700}

.pill{font-size:11px;padding:3px 9px;border-radius:999px;font-weight:800;letter-spacing:.3px}
.pill.ok{background:rgba(15,169,104,.13);color:var(--ok)}
.pill.warn{background:rgba(217,146,11,.15);color:var(--warn)}
.pill.bad{background:rgba(230,59,73,.13);color:var(--bad)}

/* partner list (modern rows) */
.plist{display:flex;flex-direction:column;gap:8px}
.empty{color:var(--ink2);font-size:13px;padding:6px 2px}
.prow{display:flex;flex-direction:column;gap:9px;padding:11px 13px;min-width:0;
  background:var(--card2);border:1px solid var(--line);border-radius:12px;transition:border-color .15s,box-shadow .15s}
.prow:hover{border-color:var(--line-strong);box-shadow:var(--shadow-sm)}
.prow-top{display:flex;align-items:center;gap:10px;min-width:0;cursor:pointer}
.prow-bot{display:flex;align-items:center;gap:6px;min-width:0;border-top:1px solid var(--line);padding-top:8px}
.pchips{display:flex;align-items:center;gap:6px;flex:1;min-width:0;flex-wrap:wrap}
.pavatar{flex:none;width:31px;height:31px;border-radius:9px;display:grid;place-items:center;
  color:#fff;font-weight:800;font-size:13px;background:var(--gradient-brand)}
.pname{display:flex;flex-direction:column;min-width:0;flex:1;font-weight:700;line-height:1.25}
.pname b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13.5px}
.pname small{color:var(--ink2);font-weight:500;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prow-top .chip{flex:none}
.pact{flex:none;display:flex;gap:4px}
.chip{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:999px;white-space:nowrap;
  background:rgba(61,24,68,.06);color:var(--ink2)}
.chip-on{background:rgba(127,46,98,.13);color:var(--partner)}
.chip-off{background:rgba(61,24,68,.05);color:#a99daa}
.pact{display:flex;gap:4px;flex:none}
.icon-btn{display:grid;place-items:center;width:30px;height:30px;padding:0;border-radius:9px;
  background:var(--surface);border:1px solid var(--line);color:var(--ink2);cursor:pointer;transition:all .15s}
.icon-btn:hover{color:var(--purple);border-color:var(--line-strong);background:var(--card2);filter:none}
.icon-btn.danger:hover{color:var(--bad);border-color:rgba(230,59,73,.4);background:rgba(230,59,73,.06)}

/* small inline button + header actions */
.btn-sm{padding:5px 11px;font-size:12px;border-radius:8px;font-weight:700}
.card-h-actions{display:flex;align-items:center;gap:10px}
.grow{flex:1;min-width:0}
input.locked{background:var(--card2);color:var(--ink2);cursor:not-allowed}

/* command form */
.pform{display:flex;flex-direction:column;gap:9px}

/* modal (dedicated edit/new panel) */
.modal{position:fixed;inset:0;z-index:2000;display:grid;place-items:center;padding:20px;
  background:rgba(26,10,22,.45);backdrop-filter:blur(3px)}
.modal-card{width:min(440px,100%);max-height:90vh;display:flex;flex-direction:column;background:var(--card);
  border:1px solid var(--line);border-radius:18px;box-shadow:0 30px 80px rgba(26,10,22,.4);overflow:hidden;animation:pop .16s ease}
.modal-b{overflow:auto}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
.modal-h{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.modal-h h3{margin:0;font-size:16px;font-weight:800}
.modal-x{background:transparent;border:0;color:var(--ink2);font-size:15px;cursor:pointer;
  width:30px;height:30px;border-radius:8px;padding:0}
.modal-x:hover{background:var(--card2);color:var(--ink);filter:none}
.modal-b{display:flex;flex-direction:column;gap:13px;padding:20px}
.field{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:700;color:var(--ink2)}
.field input{font-weight:500;color:var(--ink)}
.field-row{display:flex;gap:12px}.field-row .field{flex:1}
.modal-f{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}
.cmdout{margin:12px 0 0;background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:11px;
  max-height:220px;overflow:auto;white-space:pre-wrap;color:var(--ink);
  font:12px/1.45 ui-monospace,SFMono-Regular,Menlo,monospace}

/* deployment detail: sections, host meters, container list */
.dsection{margin:14px 0 2px;font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--ink2)}
.dep-row{cursor:pointer;border-radius:8px;margin:0 -6px;padding-left:6px;padding-right:6px}
.dep-row:hover{background:var(--card2)}
.chev{color:var(--ink2);font-weight:800}
.metric{display:flex;flex-direction:column;gap:5px;padding:6px 0;border-bottom:1px solid var(--line);font-size:12px;color:var(--ink2)}
.metric b{color:var(--ink)}
.meter{height:7px;border-radius:999px;background:var(--line);overflow:hidden}
.meter i{display:block;height:100%;border-radius:999px}
.meter i.ok{background:var(--ok)} .meter i.warn{background:var(--warn)} .meter i.bad{background:var(--bad)}
.clist{display:flex;flex-direction:column;gap:4px;margin-top:6px}
.crow{display:flex;align-items:center;gap:8px;justify-content:space-between;
  background:var(--card2);border:1px solid var(--line);border-radius:8px;padding:5px 9px}
.cname{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;color:var(--ink);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.cmeta{flex:none;display:flex;align-items:center;gap:6px}
b .bad,.bad{color:var(--bad)}

/* leaflet (light basemap) */
.leaflet-container{background:var(--map-bg);font:inherit}
.hq-marker{background:var(--partner);border:2px solid #fff;border-radius:3px;
  box-shadow:0 0 0 1px rgba(127,46,98,.5),0 1px 3px rgba(26,10,22,.3)}
.hq-marker.custom{background:var(--custom);box-shadow:0 0 0 1px rgba(28,124,156,.5),0 1px 3px rgba(26,10,22,.3)}
.chip.kind-partner{background:rgba(127,46,98,.12);color:var(--partner)}
.chip.kind-custom{background:rgba(28,124,156,.14);color:var(--custom)}
.leaflet-tooltip.maplabel{background:var(--surface);border:1px solid var(--line-strong);color:var(--ink);
  font-weight:700;font-size:12px;box-shadow:var(--shadow-sm);padding:3px 8px;border-radius:7px}
.leaflet-tooltip.maplabel::before{display:none}
.leaflet-control-attribution{background:rgba(255,255,255,.8)!important;color:var(--ink2)!important;font-size:10px}
.leaflet-control-attribution a{color:var(--accent)!important}
.leaflet-bar a{background:var(--surface)!important;color:var(--ink)!important;border-color:var(--line)!important;font-weight:700}
.leaflet-bar a:hover{background:var(--card2)!important}

/* ===== Nexus: top-nav, views, VPS, Work, Gantt ===== */
.spacer{flex:1}
.topnav{display:flex;gap:2px;margin-left:6px}
.navlink{background:transparent;border:0;color:var(--ink2);font-weight:700;font-size:13.5px;padding:8px 14px;border-radius:9px;cursor:pointer}
.navlink:hover{color:var(--ink);filter:none;background:var(--card2)}
.navlink.active{color:var(--ink);background:var(--card2);box-shadow:inset 0 -2px 0 var(--accent)}
.refresh-hint{color:var(--ink2);font-size:11.5px;font-weight:600;white-space:nowrap}

.main{height:calc(100vh - 60px);overflow:hidden}
.view{display:none;height:100%}
.view.active{display:block}
#view-overview{overflow:hidden}
#view-vps.active,#view-clients.active,#view-work.active,#view-client.active,#view-tempi.active{overflow:auto;padding:20px 22px}

/* VPS section: list + sticky detail column (mirrors the Overview right column) */
.vps-layout{display:grid;grid-template-columns:1fr 380px;gap:18px;align-items:start}
.vps-side{position:sticky;top:0;display:flex;flex-direction:column;gap:12px}
.vcard{cursor:pointer}
.vcard.selected{border-color:var(--purple);box-shadow:0 0 0 1px var(--purple),var(--shadow-sm)}
.vcard .dep-row,.vcard button{cursor:pointer}
.detail-back{margin-bottom:10px}
.back-arrow{background:transparent;border:none;color:var(--ink2);font-size:18px;font-weight:800;
  cursor:pointer;padding:0 4px 0 0;line-height:1;vertical-align:middle}
.back-arrow:hover{color:var(--purple)}
/* selected marker on the 3D globe (VPS or client) — gold.
   !important beats the higher-specificity status/kind badge rules above. */
.gmark.selected .gmark-badge{border-color:#FFC83D!important;
  box-shadow:0 0 0 2px #FFC83D,0 0 20px rgba(255,200,61,.9)!important;transform:scale(1.15)}
/* selected client marker on the 2D map — gold */
.hq-marker.selected{box-shadow:0 0 0 2px #FFC83D,0 0 12px rgba(255,200,61,.85)}
.cluster-marker.selected{border-color:#FFC83D;box-shadow:0 0 0 2px #FFC83D,0 0 14px rgba(255,200,61,.7)}
@media(max-width:900px){.vps-layout{grid-template-columns:1fr}.vps-side{position:static}}

.viewhead{display:flex;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.vh-title{margin:0;font-size:19px;font-weight:800;display:flex;align-items:center;gap:8px}
.vh-count{font-size:13px;font-weight:700;color:var(--ink2);background:var(--card2);border:1px solid var(--line);border-radius:999px;padding:1px 9px}
.vh-search{width:auto;min-width:200px;margin:0}

.plist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:10px;align-items:start}

/* status pills (timeline) */
.pill.todo{background:rgba(61,24,68,.07);color:var(--ink2)}
.pill.in_progress{background:rgba(217,146,11,.15);color:var(--warn)}
.pill.blocked{background:rgba(230,59,73,.13);color:var(--bad)}
.pill.done{background:rgba(15,169,104,.14);color:var(--ok)}

/* VPS cards */
.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px}
.vcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}
.vcard-h{display:flex;align-items:center;justify-content:space-between;font-weight:800}
.vname{font-size:15px}
.vmeta{display:grid;grid-template-columns:1fr 1fr;gap:9px 14px}
.vmeta>div{display:flex;flex-direction:column;min-width:0}
.vmeta small{color:var(--ink2);font-size:10px;text-transform:uppercase;letter-spacing:.4px;font-weight:700}
.vmeta b{font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis}
.vdeps{display:flex;flex-direction:column;border-top:1px solid var(--line);padding-top:4px}
.vdeps:empty{display:none}
.vcard-act{display:flex;gap:8px;justify-content:flex-end}
.danger-btn{background:var(--surface);border:1px solid var(--line-strong);color:var(--bad)}
.danger-btn:hover{background:rgba(230,59,73,.08);filter:none}
.detail-act{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}

/* Client Workspace */
.cw-grid{display:grid;grid-template-columns:340px 1fr;gap:14px;margin-bottom:14px;align-items:start}
@media(max-width:820px){.cw-grid{grid-template-columns:1fr}}
.svc-body{display:flex;flex-direction:column;gap:13px}
.svc-group{display:flex;flex-direction:column;gap:4px}
.svc-h{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--ink2)}
.svc-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:7px 11px;
  background:var(--card2);border:1px solid var(--line);border-radius:9px}
.svc-row[data-dep]{cursor:pointer}
.svc-row[data-dep]:hover{border-color:var(--line-strong)}
.svc-label{font-size:12.5px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.svc-label a.svc-link{text-decoration:none;font-weight:800;color:var(--accent);margin-left:4px}
.svc-empty{font-size:12px;color:var(--ink2);padding:2px 11px}
.svc-row .icon-btn{width:24px;height:24px;margin-left:4px}
#cwTitle .chip{font-size:11px;vertical-align:2px}

/* Work view */
.subtabs{display:flex;gap:4px;background:var(--card2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:4px}
.subtab{background:transparent;border:0;color:var(--ink2);font-weight:700;font-size:13px;padding:6px 14px;border-radius:8px;cursor:pointer}
.subtab:hover{color:var(--ink);filter:none}
.subtab.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}
.workbody{display:flex;flex-direction:column;gap:14px}
.wchips{display:flex;gap:8px;flex-wrap:wrap}
.wchip{background:var(--card2);border:1px solid var(--line);color:var(--ink2);font-weight:700;font-size:12.5px;padding:6px 13px;border-radius:999px;cursor:pointer}
.wchip:hover{color:var(--ink);filter:none}
.wchip.active{background:var(--purple);color:#fff;border-color:var(--purple)}
.work-split{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:14px;align-items:start}
@media(max-width:900px){.work-split{grid-template-columns:1fr}}

/* Gantt */
.gantt{display:flex;flex-direction:column;gap:6px;margin:8px 0 18px}
.g-row{display:grid;grid-template-columns:200px 1fr;gap:10px;align-items:center;cursor:pointer}
.g-label{font-size:12px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.g-label small{color:var(--ink2);font-weight:700;margin-right:4px}
.g-track{position:relative;height:22px;background:var(--card2);border:1px solid var(--line);border-radius:7px;overflow:hidden}
.g-row:hover .g-track{border-color:var(--line-strong)}
.g-bar{position:absolute;top:3px;height:16px;border-radius:5px;font-size:9px;font-weight:800;color:#fff;display:flex;align-items:center;padding:0 6px;overflow:hidden;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;min-width:16px}
.g-bar.todo{background:#8a8597}
.g-bar.in_progress{background:var(--warn)}
.g-bar.blocked{background:var(--bad)}
.g-bar.done{background:var(--ok)}
.g-today{position:absolute;top:0;bottom:0;width:2px;background:rgba(230,59,73,.6);z-index:1}

/* timeline list */
.tlist{display:flex;flex-direction:column;gap:6px}
.titem{display:grid;grid-template-columns:84px 1fr auto auto;gap:10px;align-items:center;cursor:pointer;background:var(--card2);border:1px solid var(--line);border-radius:9px;padding:8px 11px}
.titem:hover{border-color:var(--line-strong)}
.tcat{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--ink2);background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:3px 6px;text-align:center}
.tcat.deadline{color:var(--bad)} .tcat.delivery{color:var(--custom)} .tcat.milestone{color:var(--partner)}
.tmain{display:flex;flex-direction:column;min-width:0}
.tmain b{font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tmain small{font-size:11px;color:var(--ink2)}
.tdate{font-size:12px;font-weight:700;color:var(--ink2);white-space:nowrap}
.danger-link{background:transparent;border:0;color:var(--bad);font-weight:700;font-size:13px;cursor:pointer;padding:9px 4px}

/* work head (view toggle + filters) */
.work-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}
/* gantt milestone flag */
.g-flag{position:absolute;top:50%;transform:translate(-50%,-50%);color:var(--warn);line-height:0}
.g-flag svg{width:15px;height:15px;display:block}
.g-flag.overdue{color:var(--bad)} .g-flag.done{color:var(--ok)}
.g-legend svg{width:12px;height:12px;vertical-align:-2px;color:var(--warn)}
/* person chip (assignee) */
.pchip{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:700;color:var(--pc,var(--ink2))}
.pchip-av{display:inline-grid;place-items:center;width:17px;height:17px;border-radius:50%;background:var(--pc,#888);color:#fff;font-size:9px;font-weight:800}
/* per-person board */
.pboard{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:6px}
.pcol{background:var(--card2);border:1px solid var(--line);border-radius:11px;padding:10px;display:flex;flex-direction:column;gap:7px;min-height:60px}
.pcol-h{display:flex;align-items:center;gap:7px;font-weight:800;font-size:13px;padding-bottom:6px;border-bottom:2px solid var(--pc,var(--line));}
.pcol-h small{margin-left:auto;font-weight:700}
.pcol-empty{color:var(--ink2);font-size:12px;padding:4px 2px}
.wcard{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--line-strong);border-radius:8px;padding:7px 9px;cursor:pointer;transition:border-color .15s}
.wcard:hover{border-color:var(--line-strong)}
.wcard.in_progress{border-left-color:var(--warn)} .wcard.blocked{border-left-color:var(--bad)} .wcard.todo{border-left-color:#8a8597}
.wcard-t{font-size:12.5px;font-weight:700;line-height:1.25}
.wcard-m{display:flex;justify-content:space-between;gap:8px;font-size:11px;color:var(--ink2);margin-top:3px}
/* team manager */
.team-list{display:flex;flex-direction:column;gap:6px}
.team-row{display:flex;align-items:center;gap:9px;padding:8px 10px;background:var(--card2);border:1px solid var(--line);border-radius:9px;cursor:pointer}
.team-row:hover{border-color:var(--line-strong)}
.team-row .grow{flex:1}

/* nav alert dots */
.navdot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--bad);
  box-shadow:0 0 0 3px rgba(230,59,73,.18);margin-left:2px;vertical-align:1px}

/* gantt: month axis, gridlines, legend */
.g-axisrow{cursor:default}
.g-axis{position:relative;height:16px}
.g-tick{position:absolute;top:0;font-size:10px;font-weight:700;color:var(--ink2);transform:translateX(2px)}
.g-grid{position:absolute;top:0;bottom:0;width:1px;background:var(--line)}
.g-bar.overdue{outline:2px solid var(--bad);outline-offset:1px}
.g-legend{display:flex;gap:14px;align-items:center;font-size:11px;font-weight:600;color:var(--ink2);margin:2px 0 14px}

/* timeline list groups + priority */
.tgroup{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--ink2);
  margin:10px 0 2px;padding-bottom:4px;border-bottom:1px solid var(--line)}
.tgroup.bad{color:var(--bad)} .tgroup.done{color:var(--ok)}
.prio-high{color:var(--warn);font-weight:700} .prio-urgent{color:var(--bad);font-weight:800}
.tdate.bad{color:var(--bad)}

/* internal areas (admin / special) */
.pavatar.internal{background:var(--ink2)}
.chip.kind-internal{background:rgba(107,90,101,.14);color:var(--ink2)}

/* effort tag + project chip on work items */
.eff{display:inline-block;font-size:9.5px;font-weight:800;line-height:1;padding:3px 5px;border-radius:5px;
  background:var(--card2);border:1px solid var(--line);color:var(--ink2);vertical-align:1px}
.eff-S{color:var(--ok);border-color:rgba(15,169,104,.3)}
.eff-M{color:var(--warn);border-color:rgba(217,146,11,.3)}
.eff-L{color:var(--bad);border-color:rgba(230,59,73,.3)}
.projtag{display:inline-block;font-size:10px;font-weight:700;padding:2px 7px;border-radius:999px;
  background:rgba(28,124,156,.12);color:var(--custom);vertical-align:1px}

/* projects card (client workspace) */
.proj-body{display:flex;flex-direction:column;gap:7px}
.proj-row{padding:9px 11px;background:var(--card2);border:1px solid var(--line);border-radius:9px;cursor:pointer;transition:border-color .15s}
.proj-row:hover{border-color:var(--line-strong)}
.proj-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.proj-name{font-size:13px;font-weight:700;color:var(--ink);flex:1;min-width:0}
.proj-sub{font-size:11.5px;color:var(--ink2);margin-top:4px;line-height:1.4}
.proj-repo{margin-top:5px}
.repo-link{font-size:11px;color:var(--accent,#3b82f6);text-decoration:none;border:1px solid var(--line);border-radius:6px;padding:2px 7px;display:inline-block}
.repo-link:hover{border-color:var(--accent,#3b82f6)}
.phase-chip{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px;
  background:rgba(127,46,98,.1);color:var(--purple-light)}

/* activity journal */
.act-add{display:flex;gap:8px;margin:4px 0 10px}
.act-add input{flex:1}
.act-body{display:flex;flex-direction:column;gap:8px}
.act-row{display:flex;gap:9px;align-items:flex-start;padding:8px 10px;background:var(--card2);
  border:1px solid var(--line);border-radius:9px}
.act-i{flex:none;font-size:14px;line-height:1.3}
.act-main{min-width:0;flex:1}
.act-main>div{font-size:12.5px;color:var(--ink);line-height:1.4}
.act-main small{font-size:10.5px}

body.dark .eff,body.dark .proj-row,body.dark .act-row{background:var(--card)}
body.dark .chip.kind-internal{background:rgba(255,255,255,.07)}

/* MCP token field (person modal) */
.mcp-field{display:flex;flex-direction:column;gap:6px}
.mcp-field>span{font-size:12px;color:var(--ink2);font-weight:600}
.mcp-row{display:flex;gap:8px;align-items:center}
.mcp-row input{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}
.mcp-row .btn-sm{white-space:nowrap}
#pnTokenHint{font-size:11px}

/* time tracking panel */
.time-totals{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.time-chip{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--card2);
  border:1px solid var(--line);color:var(--ink2)}
.time-chip.total{background:rgba(28,124,156,.12);color:var(--custom);border-color:transparent}
.time-chip b{color:var(--ink)}
.time-list{display:flex;flex-direction:column;gap:6px}
.time-row{display:flex;align-items:center;gap:10px;padding:7px 10px;background:var(--card2);
  border:1px solid var(--line);border-radius:9px;cursor:pointer}
.time-row:hover{border-color:var(--line-strong)}
.time-min{flex:none;min-width:58px;font-weight:800;font-size:12.5px;color:var(--custom);text-align:right}
.time-main{min-width:0;display:flex;flex-direction:column;line-height:1.3}
.time-main b{font-size:12.5px}
body.dark .time-chip,body.dark .time-row{background:var(--card)}

/* Timesheets view (Clockify-lite report) */
.trep-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
@media(max-width:900px){.trep-grid{grid-template-columns:1fr}}
.trep-total{font-size:18px;font-weight:800;color:var(--custom)}
.trep-bars{display:flex;flex-direction:column;gap:9px;margin-top:4px}
.trep-row{display:grid;grid-template-columns:130px 1fr auto;align-items:center;gap:10px}
.trep-label{font-size:12.5px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.trep-bar{height:14px;background:var(--card2);border-radius:7px;overflow:hidden;border:1px solid var(--line)}
.trep-bar i{display:block;height:100%;background:var(--gradient-brand);border-radius:7px}
.trep-val{font-size:12.5px;font-weight:700;white-space:nowrap}
.trep-group{margin-bottom:9px}
/* per-group breakdown (Dettaglio) */
.trep-subs{margin:5px 0 2px 8px;padding-left:10px;border-left:2px solid var(--line);display:flex;flex-direction:column;gap:5px}
.trep-sub{display:grid;grid-template-columns:14px 116px 1fr auto;align-items:center;gap:8px}
.trep-subdot{width:9px;height:9px;border-radius:50%}
.trep-sublabel{font-size:11.5px;color:var(--ink2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.trep-subbar{height:8px;background:var(--card2);border-radius:5px;overflow:hidden;border:1px solid var(--line)}
.trep-subbar i{display:block;height:100%;border-radius:5px;opacity:.85}
.trep-subval{font-size:11.5px;font-weight:700;white-space:nowrap}
body.dark .trep-bar,body.dark .trep-subbar{background:var(--card)}

/* item modal: segmented controls + quick dates */
#itemModal .modal-card{width:min(560px,100%)}
.seg{display:flex;gap:5px;flex-wrap:wrap}
.seg button{background:var(--card2);border:1px solid var(--line);color:var(--ink2);font-weight:700;
  font-size:12px;padding:7px 12px;border-radius:9px;cursor:pointer}
.seg button:hover{color:var(--ink);filter:none}
.seg button.active{background:var(--purple);color:#fff;border-color:var(--purple)}
.quickdates{display:flex;gap:6px;align-items:center;font-size:12px;margin-top:-6px}
.quickdates button{background:var(--card2);border:1px solid var(--line);color:var(--ink2);
  font-weight:700;font-size:11px;padding:4px 10px;border-radius:999px;cursor:pointer}
.quickdates button:hover{color:var(--ink);filter:none}

/* glance / vps metrics / cmd toggle */
.cmdargs{display:flex;gap:8px;min-width:0}
.cmdargs select{flex:1;min-width:0}
.cmdargs input[type=number]{flex:none;width:84px}
.cmdargs input:not([type=number]){flex:1;min-width:0}
.cmd-toggle{cursor:pointer;margin-bottom:0;user-select:none}
.cmd-toggle:hover{color:var(--ink)}
#cmdBody:not(.hidden){margin-top:12px}
.vmeta b.warn{color:var(--warn)} .vmeta b.bad{color:var(--bad)}
.wchip .dot{width:8px;height:8px;margin-right:6px}

/* ===== dark theme (Operations Control Room) — toggled from the profile menu ===== */
body.dark{
  --page:#141019; --card:#1D1722; --card2:#272030; --ink:#F2ECF2; --ink2:#A99BAA;
  --line:rgba(255,255,255,.09); --line-strong:rgba(255,255,255,.18);
  --surface:#272030; --surface-glass:rgba(29,23,34,.92); --map-bg:#191320;
  --shadow:0 8px 28px rgba(0,0,0,.45); --shadow-sm:0 2px 10px rgba(0,0,0,.35);
}
body.dark .chip{background:rgba(255,255,255,.07)}
body.dark .chip-off{color:#7d7286}
body.dark .tcat{background:var(--card)}
body.dark .modal{background:rgba(0,0,0,.6)}
body.dark .leaflet-control-attribution{background:rgba(20,16,25,.8)!important;color:var(--ink2)!important}
