:root{
  --bg:#f7f6f2; --surface:#fff; --surface-2:#fbfaf7; --surface-hover:#f6f5f1;
  --border:#e8e6df; --border-strong:#ddd9cf; --border-faint:#f0eee8;
  --ink:#1c1b18; --ink-2:#6c6a62; --ink-3:#9b988d; --ink-4:#b9b6aa;
  --ok:#4f8a63; --ok-soft:#ecf2ee; --warn:#b08433; --warn-soft:#f5efe2;
  --bad:#b1554d; --bad-soft:#f5eae8; --neutral-soft:#f3f2ec;
  --sans:"Geist",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --mono:"Geist Mono",ui-monospace,"SF Mono",Menlo,monospace;
  --r-card:12px; --r-md:9px; --r-sm:6px;
  --shadow-card:0 1px 2px rgba(28,27,24,.04);
  --sidebar-w:236px; --maxw:1380px;
  /* laser-planet brand green accent */
  --accent:#36a05a; --accent-press:#2f8d4e; --accent-soft:#e9f5ee; --accent-border:#cae6d4;
}
[data-theme="dark"]{
  --bg:#16161a; --surface:#1d1d22; --surface-2:#232329; --surface-hover:#26262d;
  --border:#32323a; --border-strong:#3d3d46; --border-faint:#27272d;
  --ink:#ecebe6; --ink-2:#a6a49c; --ink-3:#76746c; --ink-4:#5a5953;
  --ok:#6fb487; --ok-soft:#1d2a22; --warn:#cfa257; --warn-soft:#2c2718;
  --bad:#d07a72; --bad-soft:#2c1d1b; --neutral-soft:#25252b;
  --shadow-card:0 1px 2px rgba(0,0,0,.4);
  /* dark green accent */
  --accent:#5ec47d; --accent-press:#6dd08b; --accent-soft:#16271c; --accent-border:#2b4631;
}

*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--sans);font-size:13.5px;line-height:1.45;color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-weight:400;letter-spacing:-.005em;}
.mono{font-family:var(--mono);font-feature-settings:"ss01","zero";letter-spacing:-.01em}
.num{font-variant-numeric:tabular-nums}
.muted{color:var(--ink-2)} .muted-2{color:var(--ink-3)} .medium{font-weight:500}
a{color:inherit;text-decoration:none}
svg{display:block}

.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;max-width:var(--maxw);margin:0 auto}

/* ---------- sidebar ---------- */
.side{border-right:1px solid var(--border);display:flex;flex-direction:column;padding:14px 12px;gap:2px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:9px;padding:6px 8px 14px}
.brand .mark{width:26px;height:26px;border-radius:7px;background:var(--accent);display:grid;place-items:center;color:#fff;flex:none}
.brand .mark svg{width:15px;height:15px}
.brand .name{font-weight:500;letter-spacing:-.02em;font-size:14.5px}
.brand .tag{font-size:10.5px;color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase;margin-left:auto}
.nav{display:flex;flex-direction:column;gap:1px;margin-top:2px}
.nav a{display:flex;align-items:center;gap:10px;padding:7px 9px;border-radius:var(--r-sm);color:var(--ink-2);transition:background .12s ease,color .12s ease}
.nav a svg{width:16px;height:16px;color:var(--ink-4);flex:none;transition:color .12s ease}
.nav a:hover{background:var(--surface-hover);color:var(--ink)}
.nav a:hover svg{color:var(--ink-3)}
.nav a.active{background:var(--accent-soft);color:var(--ink);font-weight:500}
.nav a.active svg{color:var(--accent)}
.nav a .count{margin-left:auto;font-size:11.5px;color:var(--ink-3)}
.nav .grouplabel{font-size:10px;color:var(--ink-4);letter-spacing:.13em;text-transform:uppercase;padding:12px 9px 5px}
.side .spacer{flex:1}
.botcard{border:1px solid var(--border);border-radius:var(--r-md);padding:9px 10px;display:flex;flex-direction:column;gap:2px;background:var(--surface-2)}
.botcard .row1{display:flex;align-items:center;gap:7px}
.dot{width:7px;height:7px;border-radius:50%;background:var(--ok);flex:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--ok) 18%,transparent)}
.botcard .bn{font-size:12.5px;font-weight:500}
.botcard .bs{font-size:11px;color:var(--ink-3)}
.userrow{display:flex;align-items:center;gap:9px;padding:8px 4px 2px;margin-top:8px}
.avatar{width:28px;height:28px;border-radius:50%;background:var(--ink);color:var(--bg);display:grid;place-items:center;font-size:12px;font-weight:500;flex:none}
.userrow .un{font-size:12.5px;font-weight:500;line-height:1.2}
.userrow .ur{font-size:11px;color:var(--ink-3)}
.iconbtn{width:28px;height:28px;border-radius:var(--r-sm);border:1px solid transparent;background:transparent;color:var(--ink-3);display:grid;place-items:center;cursor:pointer;transition:background .12s ease,color .12s ease}
.iconbtn:hover{background:var(--surface-hover);color:var(--ink)}
.iconbtn svg{width:15px;height:15px}

/* ---------- main ---------- */
.main{padding:22px 26px 60px;min-width:0}
.head{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}
.page-title{font-size:21px;font-weight:500;letter-spacing:-.025em;margin:0}
.page-sub{color:var(--ink-2);font-size:13px;margin-top:3px}
.head .actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:6px 10px;font-size:12.5px;color:var(--ink-2);background:var(--surface);cursor:pointer}
.pill .medium{color:var(--ink)}
.pill svg{width:13px;height:13px;color:var(--ink-3)}

.seclabel{font-size:10.5px;color:var(--ink-3);letter-spacing:.13em;text-transform:uppercase;margin:24px 2px 11px}

.grid6{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);box-shadow:var(--shadow-card)}
.metric{padding:14px 15px 15px}
.metric .label{font-size:12.5px;color:var(--ink-2);display:flex;align-items:center;gap:6px}
.metric .label svg{width:13px;height:13px;color:var(--ink-4)}
.metric .value{font-size:27px;font-weight:500;letter-spacing:-.03em;margin-top:9px;line-height:1;font-variant-numeric:tabular-nums}
.metric .value .unit{font-size:15px;color:var(--ink-3);font-weight:400;margin-left:3px;letter-spacing:0}
.metric .sub{font-size:12px;color:var(--ink-3);margin-top:9px;display:flex;align-items:center;gap:5px}
.up{color:var(--ok);font-weight:500;display:inline-flex;align-items:center;gap:2px}
.up svg{width:11px;height:11px}
.warnc{color:var(--warn)}

.two{display:grid;grid-template-columns:1.85fr 1fr;gap:14px;margin-top:24px}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);box-shadow:var(--shadow-card)}
.panel .ph{display:flex;align-items:center;gap:8px;padding:15px 16px 0}
.panel .pt{font-size:14px;font-weight:500;letter-spacing:-.01em}
.panel .pmeta{font-size:12px;color:var(--ink-3)}
.viewall{margin-left:auto;font-size:12px;color:var(--ink-2);display:inline-flex;align-items:center;gap:3px}
.viewall:hover{color:var(--accent)} .viewall svg{width:12px;height:12px}
.legend{display:flex;gap:14px;font-size:12px;color:var(--ink-2);margin-left:auto;align-items:center}
.legend span{display:inline-flex;align-items:center;gap:5px}
.legend i{width:9px;height:9px;border-radius:2px;display:inline-block}

.chartwrap{padding:8px 14px 14px}
.chartwrap svg{width:100%;height:auto}

/* top creators panel */
.rows{padding:6px 8px 8px}
.crow{display:flex;align-items:center;gap:11px;padding:9px 8px;border-radius:var(--r-sm)}
.crow:hover{background:var(--surface-hover)}
.crow .ca{width:30px;height:30px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-size:12px;font-weight:500;flex:none}
.crow .cn{font-size:13px;font-weight:500;line-height:1.25}
.crow .cp{font-size:11.5px;color:var(--ink-3)}
.crow .right{margin-left:auto;text-align:right;min-width:108px}
.crow .cv{font-size:13px;font-weight:500;font-variant-numeric:tabular-nums}
.crow .cu{font-size:11px;color:var(--ink-3)}
.bar{height:4px;border-radius:3px;background:var(--border-faint);margin-top:6px;overflow:hidden}
.bar i{display:block;height:100%;border-radius:3px;background:var(--accent)}

/* recent clicks */
.rtable{width:100%;border-collapse:collapse;font-size:12.5px}
.rtable th{text-align:left;font-weight:400;color:var(--ink-3);font-size:11px;letter-spacing:.04em;text-transform:uppercase;padding:6px 16px;border-bottom:1px solid var(--border-faint)}
.rtable td{padding:10px 16px;border-bottom:1px solid var(--border-faint)}
.rtable tr:last-child td{border-bottom:none}
.rtable tr:hover td{background:var(--surface-hover)}
.pf{display:inline-flex;align-items:center;gap:6px}
.pf .pi{width:16px;height:16px;border-radius:4px;display:grid;place-items:center;font-size:9px;font-weight:500;color:#fff}
.chip{display:inline-block;font-size:11px;padding:1px 7px;border-radius:var(--r-sm);background:var(--neutral-soft);color:var(--ink-2)}

.themepicker{display:flex;align-items:center;gap:6px}
.swbtn{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border-strong);cursor:pointer;padding:0}
.swbtn[data-on="1"]{border-color:var(--ink)}

/* ---------- badge / status pills ---------- */
.badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:var(--r-sm);font-weight:500}
.badge-ok{background:var(--ok-soft);color:var(--ok)}
.badge-warn{background:var(--warn-soft);color:var(--warn)}
.badge-neutral{background:var(--neutral-soft);color:var(--ink-2)}
.badge-bad{background:var(--bad-soft);color:var(--bad)}
.badge-accent{background:var(--accent-soft);color:var(--accent)}

/* ---------- login screen ---------- */
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);box-shadow:var(--shadow-card);padding:32px 28px;width:320px;display:flex;flex-direction:column;gap:16px}
.login-brand{display:flex;align-items:center;gap:9px;margin-bottom:4px}
.login-brand .mark{width:30px;height:30px;border-radius:8px;background:var(--accent);display:grid;place-items:center;color:#fff;flex:none}
.login-brand .mark svg{width:17px;height:17px}
.login-brand .name{font-weight:500;font-size:16px;letter-spacing:-.02em}
.login-card label{font-size:12px;color:var(--ink-2);display:block;margin-bottom:4px}
.login-card input{width:100%;border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:8px 10px;font-size:13.5px;font-family:var(--sans);background:var(--surface);color:var(--ink);outline:none;transition:border-color .12s}
.login-card input:focus{border-color:var(--accent)}
.login-card .field{display:flex;flex-direction:column}
.login-btn{width:100%;padding:9px;border-radius:var(--r-sm);background:var(--accent);color:#fff;border:none;font-size:13.5px;font-family:var(--sans);font-weight:500;cursor:pointer;transition:background .12s}
.login-btn:hover{background:var(--accent-press)}
.login-err{font-size:12px;color:var(--bad);min-height:16px}

/* ---------- placeholder / empty state ---------- */
.placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--ink-3);text-align:center;gap:10px}
.placeholder svg{width:36px;height:36px;opacity:.4}
.placeholder .ph-title{font-size:14px;font-weight:500;color:var(--ink-2)}
.placeholder .ph-sub{font-size:12.5px}

/* ---------- toast ---------- */
.toast-wrap{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:9999}
.toast{background:var(--ink);color:var(--bg);padding:10px 16px;border-radius:var(--r-md);font-size:13px;box-shadow:0 4px 16px rgba(0,0,0,.18);animation:toastin .18s ease}
@keyframes toastin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- form inputs (UI.input / UI.select) ---------- */
.lp-field{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}
.lp-field label{font-size:12px;color:var(--ink-2)}
.lp-input{width:100%;border:1px solid var(--border-strong);border-radius:var(--r-md);padding:8px 11px;font-size:13px;
  font-family:var(--sans);background:var(--surface);color:var(--ink);outline:none;transition:border-color .12s}
.lp-input:focus{border-color:var(--accent)}
.lp-select{cursor:pointer;appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239b988d' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}
.lp-hint{font-size:11px;color:var(--ink-3)}

/* ---------- buttons ---------- */
.lp-btn{display:inline-flex;align-items:center;gap:6px;border-radius:var(--r-sm);padding:8px 14px;font-size:13px;
  font-family:var(--sans);font-weight:500;cursor:pointer;border:1px solid transparent;transition:background .12s,border-color .12s}
.lp-btn:disabled{opacity:.55;cursor:default}
.lp-btn-primary{background:var(--accent);color:#fff}
.lp-btn-primary:hover:not(:disabled){background:var(--accent-press)}
.lp-btn-ghost{background:var(--surface);color:var(--ink-2);border-color:var(--border-strong)}
.lp-btn-ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--ink)}
.lp-btn svg{width:14px;height:14px}

/* small inline icon button (copy / delete in tables) */
.lp-iconbtn{width:26px;height:26px;border-radius:var(--r-sm);border:1px solid transparent;background:transparent;
  color:var(--ink-3);display:inline-grid;place-items:center;cursor:pointer;transition:background .12s,color .12s;flex:none}
.lp-iconbtn:hover{background:var(--surface-hover);color:var(--ink)}
.lp-iconbtn.danger:hover{background:var(--bad-soft);color:var(--bad)}
.lp-iconbtn svg{width:14px;height:14px}

/* ---------- modal (UI.modal) ---------- */
.lp-modal-backdrop{position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;
  padding:24px;background:rgba(20,19,16,.42);animation:lpfade .14s ease}
[data-theme="dark"] .lp-modal-backdrop{background:rgba(0,0,0,.58)}
.lp-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);box-shadow:0 12px 40px rgba(0,0,0,.22);
  width:440px;max-width:100%;max-height:88vh;display:flex;flex-direction:column;animation:lprise .16s ease}
.lp-modal-head{display:flex;align-items:center;gap:8px;padding:16px 18px;border-bottom:1px solid var(--border-faint)}
.lp-modal-title{font-size:15px;font-weight:500;letter-spacing:-.01em}
.lp-modal-x{margin-left:auto;width:26px;height:26px;border:none;background:transparent;color:var(--ink-3);font-size:20px;
  line-height:1;cursor:pointer;border-radius:var(--r-sm)}
.lp-modal-x:hover{background:var(--surface-hover);color:var(--ink)}
.lp-modal-body{padding:16px 18px;overflow-y:auto}
.lp-modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:14px 18px;border-top:1px solid var(--border-faint)}
@keyframes lpfade{from{opacity:0}to{opacity:1}}
@keyframes lprise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---------- utility ---------- */
.is-hidden{display:none}

@media(max-width:1180px){.grid6{grid-template-columns:repeat(3,1fr)}.grid4{grid-template-columns:repeat(2,1fr)}.two{grid-template-columns:1fr}}
