
:root{
  /* accent (light green) */
  --green-300:#8BF2BC;--green-400:#5BE49B;--green-500:#33CB80;--green-600:#1FA968;
  --green-glow:rgba(91,228,155,.35);--green-soft:rgba(91,228,155,.12);--green-line:rgba(91,228,155,.30);
  --skrime-blue:#293b95;--skrime-blue-soft:rgba(41,59,149,.18);
  /* surfaces */
  --coal-1000:#08090C;--coal-950:#0B0C10;--coal-900:#0F1014;--coal-850:#131419;
  --surface-800:#15171C;--surface-750:#1A1D24;--surface-700:#202430;--surface-650:#272C39;--surface-600:#323847;
  --line-subtle:rgba(255,255,255,.06);--line:rgba(255,255,255,.10);--line-strong:rgba(255,255,255,.16);
  /* text */
  --text-strong:#F5F7FB;--text:#C9CFDA;--text-muted:#8B93A4;--text-faint:#5B6375;--text-on-accent:#052015;
  /* semantic */
  --success:#5BE49B;--warning:#F1C40F;--warning-soft:rgba(241,196,15,.14);--danger:#E74C3C;--danger-soft:rgba(231,76,60,.14);--info:#4D7CFF;--info-soft:rgba(77,124,255,.14);
  --presence-online:#2ECA8B;--presence-idle:#F1C40F;--presence-dnd:#E74C3C;--presence-offline:#5B6375;
  /* aliases */
  --accent:var(--green-400);--accent-fg:var(--text-on-accent);
  --radius-sm:9px;--radius-md:12px;--radius-lg:16px;--radius-xl:22px;--radius-pill:999px;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);--shadow-md:0 6px 18px rgba(0,0,0,.45);--shadow-lg:0 18px 40px rgba(0,0,0,.55);--shadow-xl:0 32px 70px rgba(0,0,0,.65);
  --glow-accent-lg:0 8px 30px rgba(91,228,155,.28);
  --ease-out:cubic-bezier(.22,1,.36,1);--ease-spring:cubic-bezier(.34,1.56,.64,1);
  --font-display:'Space Grotesk','Plus Jakarta Sans',system-ui,sans-serif;
  --font-sans:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--coal-900);color:var(--text);font-family:var(--font-sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--surface-650);border-radius:99px;border:2px solid var(--coal-900)}
::-webkit-scrollbar-track{background:transparent}

/* ── layout ─────────────────────────────────────────────── */
.layout{display:flex;height:100vh;overflow:hidden}
.sidebar{width:256px;flex:none;background:var(--coal-950);border-right:1px solid var(--line-subtle);display:flex;flex-direction:column;padding:18px 14px}
.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 18px}
.brand .logo{width:42px;height:42px;border-radius:13px;background:linear-gradient(150deg,var(--skrime-blue),var(--green-600));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:20px;color:#fff}
.brand .b-title{font-family:var(--font-display);font-weight:700;color:var(--text-strong);font-size:15px;line-height:1.1}
.brand .b-sub{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:6px;margin-top:3px}
.dot{width:8px;height:8px;border-radius:50%;background:var(--presence-online);box-shadow:0 0 0 3px rgba(46,202,139,.18)}
.nav{display:flex;flex-direction:column;gap:2px;margin-top:8px;overflow-y:auto}
.nav .eyebrow{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);padding:14px 10px 6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:12px;color:var(--text-muted);cursor:pointer;font-weight:500;font-size:14px;transition:background var(--dur-fast,.12s) var(--ease-out),color .12s}
.nav-item:hover{background:var(--surface-800);color:var(--text)}
.nav-item.active{background:var(--green-soft);color:var(--accent);font-weight:600}
.nav-item .ico{width:20px;display:flex;align-items:center;justify-content:center;font-size:17px;line-height:1}
.sidebar-foot{margin-top:auto;padding:12px 8px 4px;border-top:1px solid var(--line-subtle);font-size:12px;color:var(--text-muted)}
.sidebar-foot .mono{font-family:var(--font-mono);font-size:11px;color:var(--text-faint);margin-top:4px}

.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{height:64px;flex:none;display:flex;align-items:center;gap:16px;padding:0 28px;background:rgba(11,12,16,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-subtle);position:sticky;top:0;z-index:5}
.crumb{font-family:var(--font-display);font-weight:600;color:var(--text-strong);font-size:16px}
.crumb .glyph{color:var(--accent);margin-right:6px}
.spacer{flex:1}
.search{display:flex;align-items:center;gap:8px;width:260px;max-width:32vw;height:38px;padding:0 12px;background:var(--surface-650);border:1px solid var(--line-strong);border-radius:12px}
.search input{flex:1;background:none;border:none;outline:none;color:var(--text-strong);font-family:var(--font-sans);font-size:14px;min-width:0}
.userchip{display:flex;align-items:center;gap:9px;cursor:pointer}
.userchip .u-name{font-size:13px;font-weight:600;color:var(--text-strong);line-height:1.1}
.userchip .u-role{font-size:11px;color:var(--text-muted)}

.view{flex:1;overflow-y:auto;padding:28px 32px 64px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.page-head h1{font-family:var(--font-display);font-weight:700;font-size:30px;letter-spacing:-.02em;color:var(--text-strong);margin-top:4px}
.page-head p{color:var(--text-muted);font-size:14px;margin-top:4px;max-width:560px}

/* ── grid / cards ───────────────────────────────────────── */
.grid{display:grid;gap:16px}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.split{grid-template-columns:1.55fr 1fr}
@media(max-width:1100px){.grid.cols-4{grid-template-columns:repeat(2,1fr)}.grid.split,.grid.cols-3,.grid.cols-2{grid-template-columns:1fr}}
.card{position:relative;background:var(--surface-750);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:20px;overflow:hidden}.card.overflow-v{overflow:visible}
.card.accent::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent 70%)}
.card.pad-0{padding:0}
.card h3{font-family:var(--font-display);font-size:16px;color:var(--text-strong);font-weight:600}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line-subtle)}
.stat{background:var(--surface-750);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:18px}
.stat .s-label{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-muted);font-weight:600}
.stat .s-ico{width:32px;height:32px;border-radius:9px;background:var(--green-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:17px;line-height:1}
.stat .s-val{font-family:var(--font-display);font-size:27px;font-weight:700;color:var(--text-strong);margin-top:10px;letter-spacing:-.02em}
.stat .s-sub{font-size:12px;color:var(--text-faint);margin-top:2px}

/* ── buttons ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 18px;font-family:var(--font-sans);font-weight:600;font-size:14.5px;line-height:1;letter-spacing:-.01em;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;transition:transform .12s var(--ease-out),filter .12s var(--ease-out);background:var(--surface-600);color:var(--text-strong)}
.btn:hover{filter:brightness(1.08)}.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn--primary{background:var(--accent);color:var(--accent-fg);box-shadow:var(--glow-accent-lg)}
.btn--secondary{background:var(--surface-600);color:var(--text-strong);border-color:var(--line-strong);box-shadow:var(--shadow-sm)}
.btn--ghost{background:transparent;color:var(--text)}
.btn--danger{background:var(--danger);color:#fff}
.btn--sm{height:32px;padding:0 12px;font-size:13px;border-radius:var(--radius-sm)}
.btn--block{width:100%}

/* ── badges / pills ─────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 9px;font-size:11.5px;font-weight:600;border-radius:var(--radius-pill);white-space:nowrap;border:1px solid var(--line-strong);background:rgba(255,255,255,.06);color:var(--text-muted)}
.badge.accent{background:var(--green-soft);color:var(--accent);border-color:var(--green-line)}
.badge.success{background:var(--green-soft);color:var(--success);border-color:var(--green-line)}
.badge.warning{background:var(--warning-soft);color:var(--warning);border-color:rgba(241,196,15,.3)}
.badge.danger{background:var(--danger-soft);color:var(--danger);border-color:rgba(231,76,60,.3)}
.badge.info{background:var(--info-soft);color:var(--info);border-color:rgba(77,124,255,.3)}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.tab{height:34px;padding:0 14px;display:inline-flex;align-items:center;border-radius:var(--radius-pill);background:var(--surface-750);border:1px solid var(--line);color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer}
.tab.active{background:var(--green-soft);color:var(--accent);border-color:var(--green-line)}
.chip{display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 8px 0 10px;border-radius:var(--radius-pill);background:var(--surface-700);border:1px solid var(--line);font-size:12px;color:var(--text)}
.chip .x{cursor:pointer;color:var(--text-faint);font-weight:700}
.chip .x:hover{color:var(--danger)}
.chip .swatch{width:9px;height:9px;border-radius:50%}

/* ── forms ──────────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:12.5px;font-weight:600;color:var(--text-muted)}
.input,select.input,textarea.input{width:100%;background:var(--surface-650);border:1px solid var(--line-strong);border-radius:var(--radius-md);color:var(--text-strong);font-family:var(--font-sans);font-size:14.5px;padding:10px 12px;outline:none;transition:border-color .12s,box-shadow .12s}
.input:focus,select.input:focus,textarea.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--green-soft)}
textarea.input{resize:vertical;min-height:90px}
.switch{position:relative;display:inline-block;width:44px;height:24px;flex:none}
.switch input{display:none}
.switch .track{position:absolute;inset:0;border-radius:var(--radius-pill);background:var(--surface-600);box-shadow:inset 0 1px 2px rgba(0,0,0,.4);transition:background .2s var(--ease-out)}
.switch .knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.45);transition:left .2s var(--ease-spring)}
.switch input:checked+.track{background:var(--accent);box-shadow:var(--glow-accent-lg)}
.switch input:checked+.track+.knob{left:23px;background:var(--accent-fg)}
.row-inline{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* ── table ──────────────────────────────────────────────── */
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);font-weight:700;padding:12px 14px;border-bottom:1px solid var(--line-subtle)}
.table td{padding:11px 14px;border-bottom:1px solid var(--line-subtle);color:var(--text);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tbody tr:hover{background:var(--surface-700)}
.cellname{display:flex;align-items:center;gap:9px}
.mono{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}

/* ── avatar / presence ──────────────────────────────────── */
.avatar{width:32px;height:32px;border-radius:50%;background:var(--surface-700);border:1px solid var(--line);object-fit:cover;flex:none}
.avatar.lg{width:72px;height:72px}
.pres{display:inline-block;width:9px;height:9px;border-radius:50%;flex:none}
.pres.online{background:var(--presence-online)}.pres.idle{background:var(--presence-idle)}.pres.dnd{background:var(--presence-dnd)}.pres.offline{background:var(--presence-offline)}

/* ── misc ───────────────────────────────────────────────── */
.muted{color:var(--text-muted)}.faint{color:var(--text-faint)}.strong{color:var(--text-strong)}
.empty{padding:40px;text-align:center;color:var(--text-faint)}
.list{display:flex;flex-direction:column}
.list-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line-subtle)}
.list-row:last-child{border-bottom:none}
.list-row:hover{background:var(--surface-700)}
.bar{height:6px;border-radius:99px;background:var(--surface-600);overflow:hidden;margin-top:6px}
.bar>span{display:block;height:100%;background:var(--accent);border-radius:99px}
.spin{width:26px;height:26px;border:3px solid var(--surface-600);border-top-color:var(--accent);border-radius:50%;animation:sp 1s linear infinite;margin:40px auto}
@keyframes sp{to{transform:rotate(360deg)}}
.msg{padding:10px 14px;border-bottom:1px solid var(--line-subtle);border-left:3px solid transparent}
.msg.deleted{border-left-color:var(--danger);opacity:.7}
.msg .m-head{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);margin-bottom:3px}
.msg .m-body{font-size:14px;color:var(--text);white-space:pre-wrap;word-break:break-word}
.kv{display:grid;grid-template-columns:140px 1fr;gap:6px 12px;font-size:13.5px}
.kv .k{color:var(--text-muted)}

/* ── modal ──────────────────────────────────────────────── */
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}
.modal{background:var(--surface-750);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:88vh;overflow-y:auto}
.modal .m-top{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line-subtle)}
.modal .m-top h3{font-family:var(--font-display);font-size:18px;color:var(--text-strong)}
.modal .m-body{padding:20px 22px}
.modal .m-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--line-subtle)}
.x-btn{cursor:pointer;color:var(--text-faint);font-size:16px;line-height:1;display:inline-flex;align-items:center}
.x-btn:hover{color:var(--text-strong)}

/* ── toast ──────────────────────────────────────────────── */
.toasts{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:10px;z-index:90}
.toast{background:var(--surface-700);border:1px solid var(--line-strong);border-left:3px solid var(--accent);border-radius:12px;box-shadow:var(--shadow-lg);padding:12px 16px;font-size:14px;color:var(--text-strong);min-width:240px;max-width:360px;animation:slidein .25s var(--ease-out)}
.toast.err{border-left-color:var(--danger)}
@keyframes slidein{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}

/* ── logs viewer ────────────────────────────────────────── */
.suggest{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--surface-650);border:1px solid var(--line-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:260px;overflow-y:auto;z-index:20}
.suggest>div{padding:9px 12px;cursor:pointer;font-size:13.5px;border-bottom:1px solid var(--line-subtle)}
.suggest>div:hover{background:var(--surface-700)}
.atts{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.att-img-wrap{display:inline-flex}.att-img{max-width:140px;max-height:140px;border-radius:var(--radius-sm);border:1px solid var(--line);cursor:zoom-in}
.att-file{display:inline-block;padding:6px 10px;background:var(--surface-700);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:13px;color:var(--text)}
.hist{margin-top:8px;border-top:1px solid var(--line-subtle);padding-top:6px}
.hist summary{cursor:pointer;font-size:12.5px;color:var(--text-muted)}
.hist-row{padding:8px 0;border-bottom:1px solid var(--line-subtle)}
.hist-row:last-child{border-bottom:none}
.rx-box{margin-top:6px}
table.rx{width:auto;min-width:340px;margin-top:6px;background:var(--surface-700);border-radius:var(--radius-sm)}
table.rx th,table.rx td{padding:6px 12px}

/* ── login ──────────────────────────────────────────────── */
.login{height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(800px 400px at 80% -10%,rgba(91,228,155,.10),transparent 60%),var(--coal-900)}
.login .box{width:100%;max-width:400px;background:var(--surface-750);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:32px}
.login .logo{width:54px;height:54px;border-radius:16px;background:linear-gradient(150deg,var(--skrime-blue),var(--green-600));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:26px;color:#fff;margin-bottom:18px}
.login h1{font-family:var(--font-display);font-size:24px;color:var(--text-strong);letter-spacing:-.02em}
.login p{color:var(--text-muted);font-size:14px;margin:8px 0 22px}
.login .code-in{text-transform:uppercase;letter-spacing:.18em;font-family:var(--font-mono);text-align:center;font-size:18px}
.login .err{color:var(--danger);font-size:13px;margin-top:10px;min-height:18px}
.hide{display:none!important}

/* ── nav toggle / mobile drawer ─────────────────────────── */
.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--text-strong);font-size:22px;padding:7px 9px;border-radius:var(--radius-sm);line-height:1;flex:none;-webkit-tap-highlight-color:transparent}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:39}
.nav-overlay.visible{display:block}

/* ── responsive ≤768px ───────────────────────────────────── */
@media(max-width:768px){
  .sidebar{position:fixed;inset:0 auto 0 0;width:260px;z-index:40;transform:translateX(-100%);transition:transform .25s var(--ease-out);box-shadow:var(--shadow-xl)}
  .sidebar.open{transform:none}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .search{display:none}
  .u-name,.u-role{display:none}
  .topbar{padding:0 14px;gap:10px;height:56px}
  .view{padding:16px 14px 72px}
  .grid.cols-4{grid-template-columns:1fr}
  .page-head{flex-direction:column;align-items:flex-start;gap:10px}
  .page-head>div:last-child{display:flex;flex-wrap:wrap;gap:8px;width:100%}
  .modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-width:100%;max-height:92vh}
  .backdrop{align-items:flex-end;padding:0}
  .toasts{left:12px;right:12px;bottom:16px}
  .toast{min-width:unset;max-width:none}
  .kv{grid-template-columns:90px 1fr}
  .table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .row-inline{flex-wrap:wrap}
}
@media(max-width:480px){
  .topbar{padding:0 10px}
  .view{padding:12px 10px 72px}
  .modal .m-body{padding:16px}
  .modal .m-top{padding:14px 16px}
  .modal .m-foot{padding:12px 16px}
  .stat .s-val{font-size:22px}
}
