:root {
  --bg: #0b0d10;
  --panel: #111419;
  --panel-2: #171b21;
  --text: #e6e8eb;
  --muted: #9aa3ad;
  --accent: #4f8cff;
  --accent-2: #6ee7b7;
  --border: #222831;
  --chip: #1f2530;
}
@media (prefers-color-scheme: light) {
  :root {
    --bg: #ffffff;
    --panel: #f7f8fa;
    --panel-2: #f0f2f5;
    --text: #0b1220;
    --muted: #5a6472;
    --accent: #2563eb;
    --accent-2: #059669;
    --border: #e5e7eb;
    --chip: #eef2f7;
  }
}

html, body { height: 100%; }
body {
  margin: 0; background: var(--bg); color: var(--text);
  font: 14px/1.6 system-ui, -apple-system, "Segoe UI", Roboto, Ubuntu, Cantarell, "Noto Sans", Arial, "Apple Color Emoji", "Segoe UI Emoji";
}
.wrap { max-width: 1100px; margin: 0 auto; padding: 24px; }
header {
  background: linear-gradient(135deg, rgba(79,140,255,.15), rgba(110,231,183,.12));
  border: 1px solid var(--border);
  border-radius: 16px; padding: 20px 20px 16px 20px; margin-bottom: 16px;
}
h1 { font-size: 22px; margin: 0 0 6px 0; letter-spacing: .2px; }
.sub { color: var(--muted); margin: 0; font-size: 13px; }

.toolbar {
  display: grid; grid-template-columns: 1fr auto auto; gap: 10px; align-items: center;
  background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 10px; margin: 14px 0 18px;
}
.search {
  display: flex; gap: 8px; align-items: center; background: var(--panel-2); border: 1px solid var(--border);
  border-radius: 10px; padding: 8px 10px;
}
.search input { flex: 1; background: transparent; border: 0; color: var(--text); outline: none; font-size: 14px; }
.btn, button.btn {
  appearance: none; border: 1px solid var(--border); background: var(--panel-2); color: var(--text);
  padding: 8px 12px; border-radius: 10px; font-size: 13px; cursor: pointer; transition: transform .06s ease;
}
.btn:hover { border-color: var(--accent); }
.btn:active { transform: translateY(1px); }
.count { color: var(--muted); font-size: 12px; }

.filters { display: flex; flex-wrap: wrap; gap: 8px; }
.chip { border: 1px solid var(--border); background: var(--chip); color: var(--text); padding: 6px 10px; border-radius: 999px; font-size: 12px; cursor: pointer; }
.chip[aria-pressed="true"] { outline: 2px solid var(--accent); }

table { width: 100%; border-collapse: separate; border-spacing: 0; overflow: hidden; border: 1px solid var(--border);
  border-radius: 12px; background: var(--panel); }
thead th {
  position: sticky; top: 0; background: var(--panel);
  text-align: left; font-weight: 600; font-size: 12px; letter-spacing: .3px; text-transform: uppercase; color: var(--muted);
  border-bottom: 1px solid var(--border); padding: 10px 12px;
}
tbody td { padding: 10px 12px; border-bottom: 1px solid var(--border); vertical-align: top; }
tbody tr:last-child td { border-bottom: 0; }
tbody tr:hover { background: var(--panel-2); }
.fingerprints { display: flex; flex-wrap: wrap; gap: 6px; }
.badge { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 12px; background: var(--chip); border: 1px solid var(--border); padding: 4px 8px; border-radius: 8px; }
.provider { font-weight: 600; }
.meta { color: var(--muted); font-size: 12px; }

mark { background: color-mix(in oklab, var(--accent) 30%, transparent); padding: 0 .15em; border-radius: 3px; }

footer { margin-top: 18px; color: var(--muted); font-size: 12px; }
.small { font-size: 12px; color: var(--muted); }

@media (max-width: 720px) {
  .toolbar { grid-template-columns: 1fr; }
  .meta-hide { display: none; }
}

/* layout fixes for homepage */
.wrap { display: flex; flex-direction: column; min-height: 100vh; }
main { flex: 1; display: block; }

/* move inline grid style into CSS to avoid conflicts */
#grid { display: grid; gap: 12px; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }

/* give footer room */
footer { margin-top: 24px; }

/* --- readability + anti-scroll --- */
table { width: 100%; border-collapse: separate; border-spacing: 0;
  border: 1px solid var(--border); border-radius: 12px; background: var(--panel);
  table-layout: fixed;  /* prevent overflow; allow wrapping */
}
thead th { text-align: left; font-weight: 600; font-size: 12px; letter-spacing: .3px;
  text-transform: uppercase; color: var(--muted);
  border-bottom: 1px solid var(--border); padding: 8px 10px;  /* tighter */
}
tbody td { padding: 8px 10px; border-bottom: 1px solid var(--border);
  vertical-align: top; overflow-wrap: anywhere; white-space: normal;
}
tbody tr:nth-child(even) td { background: color-mix(in oklab, var(--panel-2) 50%, transparent); }
tbody tr:hover td { background: var(--panel-2); }

/* monospace that wraps nicely */
.mono, .mono * { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.mono-wrap { overflow-wrap: anywhere; white-space: normal; }

/* sections that should span the full grid width */
.span-all { grid-column: 1 / -1; }

/* compact data tables */
.table-tight thead th, .table-tight tbody td { padding: 6px 8px; font-size: 12px; }

/* home/inspect layout helpers */
.wrap { display: flex; flex-direction: column; min-height: 100vh; }
main { flex: 1; display: block; }
footer { margin-top: 24px; }

/* grid used by inspection page */
.grid2 { display: grid; gap: 12px; grid-template-columns: repeat(2, minmax(320px, 1fr)); }
@media (max-width: 900px) { .grid2 { grid-template-columns: 1fr; } }

/* grid & cards */
#grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  align-items: stretch;          /* stretch items to row height */
}
.tool {                           /* the <a> wrapper */
  display: block;                 /* ensure it's a block-level grid item */
  min-width: 0;                   /* allow inner content to wrap instead of overflow */
}
.tool > div {                     /* the visual card */
  height: auto;                   /* don't force a % height */
  box-sizing: border-box;
}

/* tighten for small phones */
@media (max-width: 480px) {
  #grid { grid-template-columns: 1fr; } /* force single column */
}

/* (optional) global box-sizing to avoid sizing surprises */
*, *::before, *::after { box-sizing: border-box; }
