/* ── BeaconBeagle — dark threat-intel theme ─────────────────────── */

:root {
  --bg:        #0f1117;
  --bg-card:   #181b23;
  --bg-input:  #1e2230;
  --bg-hover:  #232838;
  --bg-thead:  #1a1e2a;
  --border:    #2a2f3e;
  --text:      #d1d5e0;
  --text-dim:  #7a8194;
  --text-head: #e4e7f0;
  --accent:    #6c8cff;
  --accent-h:  #8aa4ff;
  --green:     #3dd68c;
  --orange:    #f0a050;
  --red:       #f06060;
  --mono:      ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans:      system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --radius:    8px;
}

*, *::before, *::after { box-sizing: border-box; }

html { font-size: 15px; }

body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--text);
  margin: 0;
  padding: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ── topbar ──────────────────────────────────────────────────── */

.topbar {
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  padding: 10px 24px;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  position: sticky;
  top: 0;
  z-index: 100;
}

.topbar .brand {
  font-weight: 700;
  font-size: 17px;
  color: var(--accent);
  margin-right: 12px;
  text-decoration: none;
}
.topbar .brand:hover { color: var(--accent-h); }

.topbar .nav-link {
  padding: 5px 10px;
  border-radius: var(--radius);
  color: var(--text-dim);
  text-decoration: none;
  font-size: 14px;
  transition: background .15s, color .15s;
}
.topbar .nav-link:hover,
.topbar .nav-link.active {
  background: var(--bg-hover);
  color: var(--text);
}

.topbar .spacer { flex: 1; }

.topbar .search-box {
  display: flex;
  gap: 6px;
}
.topbar .search-box input {
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  padding: 5px 10px;
  font-size: 13px;
  width: 180px;
}
.topbar .search-box input::placeholder { color: var(--text-dim); }

/* ── layout ──────────────────────────────────────────────────── */

main {
  flex: 1;
  padding: 24px;
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
}

footer {
  border-top: 1px solid var(--border);
  padding: 14px 24px;
  font-size: 12px;
  color: var(--text-dim);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
}
footer a { color: var(--text-dim); text-decoration: none; }
footer a:hover { color: var(--text); }

/* ── typography ──────────────────────────────────────────────── */

h1 { font-size: 22px; font-weight: 700; margin: 0 0 6px 0; color: var(--text-head); }
h2 { font-size: 17px; font-weight: 600; margin: 20px 0 10px 0; color: var(--text-head); }
h3 { font-size: 15px; font-weight: 600; margin: 16px 0 8px 0; color: var(--text-head); }

p { line-height: 1.6; }

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-h); text-decoration: underline; }

.mono { font-family: var(--mono); }
.sub  { color: var(--text-dim); margin: 0 0 16px 0; }
.lead { font-size: 16px; color: var(--text-dim); }

/* ── buttons ─────────────────────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-card);
  color: var(--text);
  font-size: 13px;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s, border-color .15s;
}
.btn:hover {
  background: var(--bg-hover);
  border-color: var(--accent);
  text-decoration: none;
}

.btn-primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.btn-primary:hover {
  background: var(--accent-h);
  border-color: var(--accent-h);
  color: #fff;
}

.btn-sm { padding: 3px 8px; font-size: 12px; }

/* ── cards ────────────────────────────────────────────────────── */

.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px;
  margin-bottom: 16px;
}

.card-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-head);
  margin: 0 0 10px 0;
}

/* ── tables ───────────────────────────────────────────────────── */

.table-wrap { overflow-x: auto; }

table {
  border-collapse: collapse;
  width: 100%;
  font-size: 13px;
}

th, td {
  border: 1px solid var(--border);
  padding: 8px 10px;
  vertical-align: top;
  text-align: left;
}

th {
  background: var(--bg-thead);
  color: var(--text-head);
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .5px;
  white-space: nowrap;
}

tr:hover td { background: var(--bg-hover); }

td.mono, th.mono { font-family: var(--mono); }

td.ellipsis {
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.table-compact td, .table-compact th { padding: 6px 8px; font-size: 12px; }

/* ── forms / filters ─────────────────────────────────────────── */

.filters {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: end;
  margin: 12px 0 18px 0;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

label {
  font-size: 11px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: .4px;
  font-weight: 500;
}

input, select, textarea {
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-input);
  color: var(--text);
  font-size: 13px;
  min-width: 150px;
  font-family: inherit;
}
input::placeholder { color: var(--text-dim); }
input:focus, select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(108,140,255,.15);
}

input.mono { font-family: var(--mono); font-size: 13px; }

select.multi { min-width: 280px; }

.hint { font-size: 11px; color: var(--text-dim); margin-top: 4px; }

/* ── badges ──────────────────────────────────────────────────── */

.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
}
.badge-default { background: var(--bg-hover); color: var(--text-dim); border: 1px solid var(--border); }
.badge-green   { background: rgba(61,214,140,.12); color: var(--green); border: 1px solid rgba(61,214,140,.25); }
.badge-orange  { background: rgba(240,160,80,.12); color: var(--orange); border: 1px solid rgba(240,160,80,.25); }
.badge-accent  { background: rgba(108,140,255,.12); color: var(--accent); border: 1px solid rgba(108,140,255,.25); }

/* ── details / collapsible ───────────────────────────────────── */

details { margin-top: 6px; }
details > summary {
  cursor: pointer;
  color: var(--accent);
  font-size: 13px;
}
details > summary:hover { color: var(--accent-h); }

/* ── pre / code ──────────────────────────────────────────────── */

pre {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px;
  overflow-x: auto;
  font-family: var(--mono);
  font-size: 13px;
  line-height: 1.5;
  color: var(--text);
}

code { font-family: var(--mono); color: var(--accent); }

/* ── alert ───────────────────────────────────────────────────── */

.alert {
  border-radius: var(--radius);
  padding: 12px 16px;
  margin-bottom: 16px;
  font-size: 14px;
}
.alert-info {
  background: rgba(108,140,255,.08);
  border: 1px solid rgba(108,140,255,.2);
  color: var(--accent);
}
.alert-warn {
  background: rgba(240,160,80,.08);
  border: 1px solid rgba(240,160,80,.2);
  color: var(--orange);
}

/* ── grid helpers ────────────────────────────────────────────── */

.row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.wrap  { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; margin: 10px 0; }
.text-center { text-align: center; }

/* SuperSearch filter lines */
.filterline { display: grid; grid-template-columns: 1fr 1fr auto; gap: 10px; align-items: end; }

/* ── responsive ──────────────────────────────────────────────── */

@media (max-width: 900px) {
  main { padding: 14px; }
  .row-2, .row-3 { grid-template-columns: 1fr; }
  .filterline { grid-template-columns: 1fr; }
  input, select { min-width: 100%; }
  select.multi { min-width: 100%; }
  th { position: static; }
}

/* ── hero (index page) ───────────────────────────────────────── */

.hero {
  text-align: center;
  padding: 30px 0 20px 0;
}
.hero img { margin-bottom: 16px; border-radius: 12px; }
.hero h1 { font-size: 28px; margin-bottom: 8px; }

/* ── ul inside cards ─────────────────────────────────────────── */
ul.clean { list-style: none; padding: 0; margin: 6px 0 0 0; }
ul.clean li { padding: 3px 0; }
ul.clean li::before { content: "› "; color: var(--accent); font-weight: 700; }
