/* networkz — tema: tweakcn cmmea3qbd (claude blu 2) · light+dark */
:root{
  --background:oklch(0.9581 0 0);
  --foreground:oklch(0.3134 0.0234 253.6270);
  --card:oklch(0.9774 0.0042 236.4961);
  --card-foreground:oklch(0.2022 0.0110 151.1628);
  --popover:oklch(1 0 0);
  --primary:oklch(0.6112 0.1217 248.9572);
  --primary-foreground:oklch(1 0 0);
  --secondary:oklch(0.9122 0.0111 243.6627);
  --secondary-foreground:oklch(0.4186 0.0133 235.1330);
  --muted:oklch(0.9209 0.0128 244.2626);
  --muted-foreground:oklch(0.6027 0.0062 211.0375);
  --accent:oklch(0.9122 0.0111 243.6627);
  --accent-foreground:oklch(0.2505 0.0149 235.6259);
  --border:oklch(0.8840 0.0067 208.7806);
  --input:oklch(0.7450 0.0121 252.1201);
  --ring:oklch(0.6112 0.1217 248.9572);
  --green:oklch(0.6112 0.1217 248.9572);
  --yellow:oklch(0.6800 0.1400 75);
  --red:oklch(0.5772 0.2100 27.3);
  --purple:oklch(0.5500 0.1000 256);
  --cyan:oklch(0.6400 0.1100 232);
  --radius:0.5rem;
  --shadow-sm:0px 2px 4px 0px hsl(0 0% 0% / 0.10), 0px 1px 2px -1px hsl(0 0% 0% / 0.10);
  --shadow-md:0px 2px 4px 0px hsl(0 0% 0% / 0.10), 0px 2px 4px -1px hsl(0 0% 0% / 0.10);
  --font-sans:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --mono:ui-monospace,SFMono-Regular,Menlo,monospace;
}
[data-theme="dark"]{
  --background:oklch(0.1776 0 0);
  --foreground:oklch(0.7905 0.0126 259.8241);
  --card:oklch(0.2638 0.0024 247.9155);
  --card-foreground:oklch(0.9755 0.0045 258.3245);
  --popover:oklch(0.3046 0.0023 247.9001);
  --primary:oklch(0.6576 0.1208 252.0832);
  --primary-foreground:oklch(1 0 0);
  --secondary:oklch(0.9774 0.0042 236.4961);
  --secondary-foreground:oklch(0.3046 0.0023 247.9001);
  --muted:oklch(0.2171 0.0025 247.9411);
  --muted-foreground:oklch(0.7559 0.0125 239.9659);
  --accent:oklch(0.2038 0.0067 258.3676);
  --accent-foreground:oklch(0.9590 0.0059 239.8204);
  --border:oklch(0.3506 0.0066 248.0169);
  --input:oklch(0.4217 0.0084 248.0280);
  --ring:oklch(0.6576 0.1208 252.0832);
  --green:oklch(0.6576 0.1208 252.0832);
  --yellow:oklch(0.7900 0.1400 75);
  --red:oklch(0.6368 0.2078 25.3313);
  --purple:oklch(0.7400 0.0900 256);
  --cyan:oklch(0.7400 0.1000 232);
  --shadow-sm:0px 4px 8px 0px hsl(0 0% 0% / 0.30), 0px 1px 2px -1px hsl(0 0% 0% / 0.30);
  --shadow-md:0px 4px 8px 0px hsl(0 0% 0% / 0.30), 0px 2px 4px -1px hsl(0 0% 0% / 0.30);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-sans);background:var(--background);color:var(--foreground);
  line-height:1.5;padding-bottom:50px;letter-spacing:-0.01em;-webkit-font-smoothing:antialiased}
h1{font-size:20px;font-weight:700;letter-spacing:-0.03em}

.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 24px;
  background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20;box-shadow:var(--shadow-sm)}
.brand{display:flex;align-items:center;gap:12px}
.logo{font-size:26px}
.brand p{font-size:12px;color:var(--muted-foreground)}
.actions{display:flex;gap:8px;align-items:center}
.actions .meta{font-size:11px;color:var(--muted-foreground);font-family:var(--mono)}

.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius);
  border:1px solid transparent;background:var(--primary);color:var(--primary-foreground);font-size:13px;font-weight:600;
  cursor:pointer;text-decoration:none;transition:.15s;font-family:inherit}
.btn:hover{filter:brightness(1.08)}
.btn.ghost{background:transparent;color:var(--foreground);border-color:var(--border)}
.btn.ghost:hover{background:var(--accent);filter:none}
.icon-btn{background:transparent;border:1px solid var(--border);color:var(--foreground);
  width:36px;height:36px;border-radius:var(--radius);cursor:pointer;font-size:16px;display:grid;place-items:center}
.icon-btn:hover{background:var(--accent)}
.fs-seg{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.fs-seg button{background:transparent;border:none;color:var(--muted-foreground);padding:7px 9px;font-size:12px;
  cursor:pointer;font-family:inherit;font-weight:600;letter-spacing:-0.01em}
.fs-seg button+button{border-left:1px solid var(--border)}
.fs-seg button:hover{background:var(--accent)}
.fs-seg button.active{background:var(--primary);color:var(--primary-foreground)}
html[data-fs="110"] body{zoom:1.10}
html[data-fs="120"] body{zoom:1.20}

/* host özet kartları */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;padding:20px 24px 8px}
.stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm)}
.stat .n{font-size:24px;font-weight:700;letter-spacing:-0.03em}
.stat .l{font-size:12px;color:var(--muted-foreground);margin-top:2px}
.stat.accent .n{color:var(--primary)}
.stat.green .n{color:var(--green)}
.stat.yellow .n{color:var(--yellow)}
.stat.red .n{color:var(--red)}
.stat.purple .n{color:var(--purple)}

/* grafikler */
.charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:12px;padding:8px 24px}
.chart-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm)}
.chart-card h3{font-size:13px;font-weight:700;letter-spacing:-0.02em;margin-bottom:12px;color:var(--card-foreground)}
.donut-wrap{display:flex;align-items:center;gap:14px}
.donut{width:128px;height:128px;flex:none}
.donut .center-v{font-size:15px;font-weight:700;fill:var(--card-foreground)}
.donut .center-k{font-size:8px;fill:var(--muted-foreground)}
.legend{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0;font-size:12px}
.legend .li{display:flex;align-items:center;gap:7px}
.legend .sw{width:10px;height:10px;border-radius:2px;flex:none}
.legend .ln{flex:1;color:var(--foreground);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.legend .lv{color:var(--muted-foreground);font-family:var(--mono);font-size:11px}
.hbars{display:flex;flex-direction:column;gap:9px}
.hbar{display:grid;grid-template-columns:96px 1fr auto;align-items:center;gap:8px}
.hbar .hl{font-size:12px;color:var(--foreground);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hbar .ht{position:relative;height:10px;background:var(--muted);border-radius:5px;overflow:hidden}
.hbar .ht > span{position:absolute;left:0;top:0;bottom:0;border-radius:5px;background:var(--primary);transition:width .4s}
.hbar .ht.yellow > span{background:var(--yellow)}
.hbar .ht.red > span{background:var(--red)}
.hbar .hv{font-size:11px;color:var(--muted-foreground);font-family:var(--mono);white-space:nowrap}

/* proje grupları */
.projects{padding:8px 24px 24px;display:flex;flex-direction:column;gap:14px}
.proj{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.proj.down{opacity:.55}
.proj-head{display:flex;align-items:center;gap:12px;padding:13px 16px;cursor:pointer;user-select:none}
.proj-head:hover{background:var(--accent)}
.proj-title{font-size:15px;font-weight:700;letter-spacing:-0.02em;display:flex;align-items:center;gap:8px}
.proj-title .dot{width:8px;height:8px;border-radius:50%;background:var(--green)}
.proj.down .dot{background:var(--red)}
.proj-sub{font-size:11px;color:var(--muted-foreground);font-family:var(--mono)}
.proj-spacer{flex:1}
.proj-totals{display:flex;gap:18px;align-items:center}
.tot{text-align:right}
.tot .v{font-size:13px;font-weight:700}
.tot .k{font-size:10px;color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.04em}
.chev{font-size:12px;color:var(--muted-foreground);transition:.15s}
.proj.collapsed .chev{transform:rotate(-90deg)}
.proj.collapsed .proj-body{display:none}

.proj-body{border-top:1px solid var(--border)}
table.ct{width:100%;border-collapse:collapse;font-size:13px}
table.ct th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted-foreground);
  font-weight:600;padding:8px 14px;border-bottom:1px solid var(--border)}
table.ct td{padding:9px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
table.ct tr:last-child td{border-bottom:none}
.cname{font-weight:600;color:var(--card-foreground)}
.cset{font-family:var(--mono);font-size:11px;color:var(--muted-foreground)}
.mono{font-family:var(--mono);font-size:12px}

/* kullanım çubukları */
.bar{position:relative;height:8px;background:var(--muted);border-radius:6px;overflow:hidden;min-width:90px;flex:1}
.bar > span{position:absolute;left:0;top:0;bottom:0;border-radius:6px;background:var(--primary);transition:width .4s}
.bar.green > span{background:var(--green)}
.bar.yellow > span{background:var(--yellow)}
.bar.red > span{background:var(--red)}
.cell-bar{display:flex;align-items:center;gap:8px;min-width:170px}
.bval{font-size:12px;font-weight:700;color:var(--foreground);font-family:var(--mono);min-width:54px;text-align:right;white-space:nowrap}
.bval.green{color:var(--green)}
.bval.yellow{color:var(--yellow)}
.bval.red{color:var(--red)}
.cell-bar .cap{font-size:11px;color:var(--muted-foreground);white-space:nowrap;font-family:var(--mono)}
.peak{font-size:10px;color:var(--muted-foreground);font-family:var(--mono)}

.foot{text-align:center;font-size:11px;color:var(--muted-foreground);padding:20px}

/* login */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}
.login-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-md);padding:32px;width:100%;max-width:360px}
.login-card h1{margin-bottom:4px}
.login-card p{font-size:12px;color:var(--muted-foreground);margin-bottom:20px}
.login-card label{font-size:12px;font-weight:600;display:block;margin-bottom:5px;margin-top:12px}
.login-card input{width:100%;background:var(--popover);border:1px solid var(--border);color:var(--foreground);
  padding:10px 12px;border-radius:var(--radius);font-size:14px;outline:none;font-family:inherit}
.login-card input:focus{border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in oklch,var(--ring) 25%,transparent)}
.login-card .btn{width:100%;justify-content:center;margin-top:20px}
.err{color:var(--red);font-size:12px;margin-top:10px;min-height:16px}
