@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=Schibsted+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  --space:#0A0D15; --space-2:#0E121C;
  --panel:#11151F; --panel-2:#161B29; --panel-3:#1C2233;
  --line:rgba(255,255,255,.07); --line-2:rgba(255,255,255,.12);
  --ink:#EAEDF5; --dim:#9AA2B8; --faint:#5E6678;
  --amber:#F2A93C; --amber-bright:#FFC15E;
  --cyan:#54DDD0; --blue:#5B8DEF; --violet:#9B86F2; --green:#57D98C; --red:#F0707A;
  --sans:'Schibsted Grotesk',system-ui,sans-serif;
  --disp:'Syne',system-ui,sans-serif;
  --mono:'JetBrains Mono',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--space);-webkit-font-smoothing:antialiased;overflow:hidden}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(620px 380px at 8% -6%,rgba(242,169,60,.10),transparent 60%),
             radial-gradient(700px 460px at 100% 0%,rgba(84,221,208,.07),transparent 55%);}
.hidden{display:none !important}

/* ---------- login ---------- */
.login{position:fixed;inset:0;z-index:5;display:grid;place-items:center}
.login-card{width:360px;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:18px;padding:34px 30px;box-shadow:0 30px 80px -30px #000}
.login-card .logo{display:flex;justify-content:center;margin-bottom:18px}
.login-card h1{font-family:var(--disp);font-weight:800;font-size:22px;text-align:center;letter-spacing:-.5px}
.login-card h1 b{color:var(--amber)}
.login-card p{text-align:center;color:var(--dim);font-size:13px;margin:6px 0 22px}
.field{margin-bottom:13px}
.field label{display:block;font-size:11px;font-family:var(--mono);letter-spacing:.6px;color:var(--faint);text-transform:uppercase;margin-bottom:6px}
.field input{width:100%;padding:11px 13px;border:1px solid var(--line-2);border-radius:10px;background:var(--space-2);color:var(--ink);font-family:var(--sans);font-size:14px}
.field input:focus{outline:none;border-color:var(--amber)}
.login button{width:100%;margin-top:8px;padding:12px;border:none;border-radius:10px;background:var(--amber);color:#1a1206;font-weight:700;font-size:14px;cursor:pointer}
.login .err{color:var(--red);font-size:12.5px;text-align:center;margin-top:12px;min-height:16px}
.login .hint{margin-top:18px;font-size:11px;color:var(--faint);text-align:center;font-family:var(--mono);line-height:1.6}

/* ---------- app shell ---------- */
.app{position:relative;z-index:1;height:100vh;display:flex;flex-direction:column}
.topbar{height:58px;flex:0 0 auto;display:flex;align-items:center;gap:18px;padding:0 18px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--panel-2),var(--panel))}
.brand{display:flex;align-items:center;gap:11px}
.brand .name{font-family:var(--disp);font-weight:800;font-size:19px;letter-spacing:-.5px}
.brand .name b{color:var(--amber)}
.ws{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;padding:7px 13px;border:1px solid var(--line-2);border-radius:9px;background:var(--panel-3);cursor:default}
.search{flex:1;max-width:560px;display:flex;align-items:center;gap:10px;padding:9px 14px;border:1px solid var(--line);border-radius:10px;background:var(--space-2)}
.search input{flex:1;background:none;border:none;color:var(--ink);font-family:var(--sans);font-size:13.5px}
.search input:focus{outline:none}
.search input::placeholder{color:var(--faint)}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.status{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--dim);font-family:var(--mono)}
.dot{width:8px;height:8px;border-radius:50%}
.dot.on{background:var(--green)}
.user{display:flex;align-items:center;gap:9px;padding:5px 11px 5px 6px;border:1px solid var(--line-2);border-radius:30px;background:var(--panel-3);cursor:pointer}
.ava{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--amber),#C9742A);display:grid;place-items:center;font-weight:700;font-size:12px;color:#1a1206}
.user .u-name{font-size:12.5px;font-weight:600;line-height:1.15}
.user .u-role{font-size:10.5px;color:var(--amber);font-family:var(--mono)}
.logout{font-size:11px;color:var(--faint);cursor:pointer;border:none;background:none;font-family:var(--mono)}
.logout:hover{color:var(--ink)}

.body{flex:1;display:grid;grid-template-columns:264px 1fr 326px;min-height:0}
@media (max-width:1180px){.body{grid-template-columns:240px 1fr}.detail{display:none}}

/* sidebar */
.side{border-right:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column;min-height:0}
.side .find{margin:14px 14px 8px;display:flex;align-items:center;gap:9px;padding:8px 11px;border:1px solid var(--line);border-radius:9px;background:var(--space-2);color:var(--faint);font-size:12.5px}
.tree{flex:1;overflow:auto;padding:6px 8px 14px}
.tree::-webkit-scrollbar{width:8px}.tree::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}
.grp{margin:10px 6px 4px;display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10.5px;letter-spacing:1.2px;color:var(--faint);text-transform:uppercase}
.grp .ct{margin-left:auto;color:var(--faint);background:var(--panel-3);border-radius:20px;padding:1px 7px;font-size:10px}
.node{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;color:var(--dim);font-size:13.5px}
.node:hover{background:var(--panel-2);color:var(--ink)}
.node.sel{background:var(--panel-3);color:var(--ink)}
.badge{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;flex:0 0 auto}
.badge svg{width:14px;height:14px}
.t-SSH{background:rgba(242,169,60,.14);color:var(--amber)}
.t-DOCKER{background:rgba(84,221,208,.14);color:var(--cyan)}
.t-KUBERNETES{background:rgba(91,141,239,.14);color:var(--blue)}
.t-PROXMOX{background:rgba(155,134,242,.15);color:var(--violet)}
.t-RDP,.t-VNC,.t-REMOTE_DESKTOP{background:rgba(87,217,140,.14);color:var(--green)}
.node .nm{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.node .lat{font-family:var(--mono);font-size:10.5px;color:var(--faint)}
.side .foot{border-top:1px solid var(--line);padding:11px 14px;display:flex;align-items:center;gap:9px;font-size:11.5px;color:var(--dim);font-family:var(--mono)}

/* main */
.main{overflow:auto;padding:20px 24px 28px;min-height:0;position:relative}
.main::-webkit-scrollbar{width:9px}.main::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:9px}
.m-head{display:flex;align-items:flex-end;gap:14px;margin-bottom:6px}
.m-head h1{font-family:var(--disp);font-weight:700;font-size:24px;letter-spacing:-.5px}
.m-head .sub{color:var(--dim);font-size:13px;margin-bottom:3px}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin:16px 0 18px}
.chip{padding:6px 13px;border-radius:30px;border:1px solid var(--line-2);background:var(--panel);color:var(--dim);font-size:12.5px;cursor:pointer;font-weight:500}
.chip.on{background:var(--ink);color:var(--space);border-color:var(--ink);font-weight:600}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:14px}
.card{border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--panel-2),var(--panel));padding:15px;cursor:pointer;transition:transform .18s,border-color .18s,box-shadow .18s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent,transparent);opacity:0;transition:opacity .18s}
.card:hover{transform:translateY(-3px);border-color:var(--line-2);box-shadow:0 14px 34px -18px rgba(0,0,0,.8)}
.card:hover::before{opacity:.9}
.card.sel{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}
.card.sel::before{opacity:1}
.c-top{display:flex;align-items:center;gap:11px;margin-bottom:13px}
.c-top .badge{width:34px;height:34px;border-radius:9px}
.c-top .badge svg{width:18px;height:18px}
.c-name{font-weight:700;font-size:15px;line-height:1.1}
.c-host{font-family:var(--mono);font-size:11.5px;color:var(--dim);margin-top:2px}
.c-stat{margin-left:auto;font-size:11px;font-family:var(--mono);color:var(--dim)}
.c-acc{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:13px;min-height:22px}
.perm{font-size:10.5px;font-family:var(--mono);padding:2px 8px;border-radius:20px;border:1px solid var(--line-2);color:var(--dim)}
.perm.you{color:var(--amber);border-color:rgba(242,169,60,.4);background:rgba(242,169,60,.08)}
.perm.ro{color:var(--cyan);border-color:rgba(84,221,208,.35)}
.c-actions{display:flex;gap:8px}
.btn{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:8px;border-radius:8px;font-size:12.5px;font-weight:600;cursor:pointer;border:1px solid var(--line-2);background:var(--panel-3);color:var(--ink)}
.btn.primary{background:var(--accent,var(--amber));color:#0a0d15;border-color:transparent}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn svg{width:14px;height:14px}

/* detail panel */
.detail{border-left:1px solid var(--line);background:var(--panel);overflow:auto;min-height:0}
.detail::-webkit-scrollbar{width:8px}.detail::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}
.empty{padding:40px 24px;text-align:center;color:var(--faint);font-size:13px}
.d-hero{padding:20px 18px 16px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,rgba(242,169,60,.06),transparent)}
.d-hero .badge{width:42px;height:42px;border-radius:11px;margin-bottom:12px}
.d-hero .badge svg{width:22px;height:22px}
.d-hero h2{font-family:var(--disp);font-weight:700;font-size:20px}
.d-hero .h{font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:4px}
.sec{padding:16px 18px;border-bottom:1px solid var(--line)}
.sec h3{font-family:var(--mono);font-size:10.5px;letter-spacing:1.4px;text-transform:uppercase;color:var(--faint);margin-bottom:13px}
.kv{display:flex;justify-content:space-between;font-size:12.5px;padding:5px 0;color:var(--dim)}
.kv b{color:var(--ink);font-weight:500;font-family:var(--mono);font-size:12px}
.role{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px dashed var(--line)}
.role:last-child{border-bottom:none}
.r-ava{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;font-size:11px;font-weight:700;font-family:var(--mono);background:var(--panel-3);color:var(--dim)}
.r-meta{flex:1;line-height:1.2}
.r-name{font-size:13px;font-weight:600}
.r-sub{font-size:11px;color:var(--faint)}
.r-perm{font-size:10.5px;font-family:var(--mono);padding:3px 9px;border-radius:20px;font-weight:600}
.p-ADMIN{background:rgba(242,169,60,.14);color:var(--amber)}
.p-CONNECT{background:rgba(91,141,239,.14);color:var(--blue)}
.p-READ_ONLY{background:rgba(84,221,208,.13);color:var(--cyan)}
.audit{display:flex;gap:11px;padding:8px 0;font-size:12px}
.a-line{width:1px;background:var(--line-2);position:relative;flex:0 0 auto;margin-left:4px}
.a-line::before{content:"";position:absolute;left:-3px;top:3px;width:7px;height:7px;border-radius:50%;background:var(--cyan)}
.a-body{flex:1;line-height:1.35;color:var(--dim)}
.a-body b{color:var(--ink);font-weight:600}
.a-time{font-family:var(--mono);font-size:10.5px;color:var(--faint);margin-top:2px}

/* terminal overlay */
.term-ov{position:fixed;inset:0;z-index:20;background:rgba(6,8,13,.78);backdrop-filter:blur(4px);display:grid;place-items:center}
.term-win{width:min(960px,92vw);height:min(620px,86vh);background:#0c0f17;border:1px solid var(--line-2);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 40px 100px -30px #000}
.term-bar{height:42px;display:flex;align-items:center;gap:10px;padding:0 14px;border-bottom:1px solid var(--line);background:var(--panel-2)}
.term-bar .dots{display:flex;gap:6px}
.term-bar .dots i{width:11px;height:11px;border-radius:50%;display:block}
.term-bar .title{font-family:var(--mono);font-size:12.5px;color:var(--dim)}
.term-bar .x{margin-left:auto;color:var(--faint);cursor:pointer;font-size:18px;background:none;border:none;padding:0 4px}
.term-bar .x:hover{color:var(--ink)}
.term-host{flex:1;padding:8px 10px;min-height:0}
