/* serverz — tema: "claude blu 2" (tweakcn) · 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.5800 0.1300 152);
  --yellow:oklch(0.6800 0.1400 75);
  --red:oklch(0.5772 0.2100 27.3);
  --purple:oklch(0.5500 0.1700 290);
  --cyan:oklch(0.6000 0.1000 230);
  --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;
}
[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.7200 0.1500 152);
  --yellow:oklch(0.7900 0.1400 75);
  --red:oklch(0.6368 0.2078 25.3313);
  --purple:oklch(0.7000 0.1500 290);
  --cyan:oklch(0.7200 0.1000 230);
  --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:60px;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}

.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}
.btn.sm{padding:5px 10px;font-size:12px}
.btn.danger{background:transparent;color:var(--red);border-color:transparent}
.btn.danger:hover{background:color-mix(in oklch,var(--red) 14%,transparent)}
.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}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;padding:20px 24px}
.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.purple .n{color:var(--purple)}

.filters{display:flex;flex-wrap:wrap;gap:10px;padding:0 24px 16px}
.filters input,.filters select{background:var(--popover);border:1px solid var(--border);color:var(--foreground);
  padding:9px 12px;border-radius:var(--radius);font-size:13px;outline:none;font-family:inherit}
.filters input:focus,.filters select:focus{border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in oklch,var(--ring) 25%,transparent)}
#search{flex:1;min-width:220px}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px;padding:0 24px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;display:flex;flex-direction:column;gap:10px;transition:.15s;box-shadow:var(--shadow-sm)}
.card:hover{box-shadow:var(--shadow-md);border-color:var(--ring)}
.card .head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.card .name{font-size:15px;font-weight:700;color:var(--card-foreground);letter-spacing:-0.02em}
.card .prov{font-size:12px;color:var(--muted-foreground)}
.card .free{font-size:13px;color:var(--foreground);background:var(--muted);padding:8px 10px;border-radius:var(--radius);border:1px solid var(--border)}
.tags{display:flex;flex-wrap:wrap;gap:6px}
.tag{font-size:11px;padding:3px 8px;border-radius:20px;border:1px solid var(--border);color:var(--muted-foreground);background:var(--secondary)}
.tag.dur{color:var(--cyan);border-color:color-mix(in oklch,var(--cyan) 40%,transparent)}
.tag.diff-easy{color:var(--green);border-color:color-mix(in oklch,var(--green) 40%,transparent)}
.tag.diff-medium{color:var(--yellow);border-color:color-mix(in oklch,var(--yellow) 40%,transparent)}
.tag.diff-hard{color:var(--red);border-color:color-mix(in oklch,var(--red) 40%,transparent)}
.tag.credit{color:var(--purple);border-color:color-mix(in oklch,var(--purple) 40%,transparent)}
.card .link{font-size:12px;color:var(--primary);text-decoration:none;word-break:break-all}
.card .link:hover{text-decoration:underline}

.statusbar{display:flex;align-items:center;gap:8px;padding-top:10px;border-top:1px solid var(--border);flex-wrap:wrap}
.pill{font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px}
.pill.s-not-started{background:var(--muted);color:var(--muted-foreground)}
.pill.s-planned{background:color-mix(in oklch,var(--primary) 15%,transparent);color:var(--primary)}
.pill.s-applied{background:color-mix(in oklch,var(--yellow) 18%,transparent);color:var(--yellow)}
.pill.s-active{background:color-mix(in oklch,var(--green) 18%,transparent);color:var(--green)}
.pill.s-rejected{background:color-mix(in oklch,var(--red) 15%,transparent);color:var(--red)}
.pill.s-expired{background:var(--muted);color:var(--muted-foreground)}

.editbtn{margin-left:auto;font-size:12px;color:var(--primary);background:none;border:none;cursor:pointer;font-family:inherit}
.edit{display:none;flex-direction:column;gap:8px;padding-top:10px;border-top:1px solid var(--border)}
.edit.open{display:flex}
.edit label{font-size:11px;color:var(--muted-foreground);display:block;margin-bottom:3px}
.edit input,.edit select,.edit textarea{width:100%;background:var(--popover);border:1px solid var(--border);
  color:var(--foreground);padding:7px 9px;border-radius:var(--radius);font-size:13px;outline:none;font-family:inherit}
.edit input:focus,.edit select:focus,.edit textarea:focus{border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in oklch,var(--ring) 25%,transparent)}
.edit textarea{resize:vertical;min-height:48px}
.edit .row{display:flex;gap:8px}
.edit .row>div{flex:1}
.edit .savebar{display:flex;gap:8px;justify-content:flex-end}

.empty{text-align:center;color:var(--muted-foreground);padding:60px}
.foot{display:flex;justify-content:space-between;padding:24px;color:var(--muted-foreground);font-size:12px;margin-top:20px;flex-wrap:wrap;gap:8px}
.foot b{color:var(--foreground)}
.tracked{box-shadow:inset 3px 0 0 var(--primary),var(--shadow-sm)}
.toggle{position:relative;display:inline-block;width:38px;height:22px;flex:0 0 auto}
.toggle input{opacity:0;width:0;height:0;position:absolute}
.toggle .slider{position:absolute;inset:0;background:var(--primary);border-radius:22px;transition:.2s;cursor:pointer}
.toggle .slider:before{content:"";position:absolute;height:18px;width:18px;left:2px;top:2px;background:#fff;
  border-radius:50%;transition:.2s;box-shadow:0 1px 2px rgba(0,0,0,.3)}
.toggle input:not(:checked)+.slider{background:var(--muted-foreground)}
.toggle input:checked+.slider:before{transform:translateX(16px)}
@media(max-width:600px){.topbar,.filters,.grid,.stats{padding-left:14px;padding-right:14px}}
