/* gmip — operator-tool styling. Server-rendered, no framework. */

:root {
  --fg:        #1a1a1a;
  --fg-muted:  #6b6b6b;
  --fg-soft:   #b0b0b0;
  --bg:        #fafaf8;
  --bg-panel:  #ffffff;
  --bd:        #d8d6d0;
  --bd-soft:   #ecebe6;
  --accent:    #0a5cc4;
  --bot:       #b03030;
  --human:     #2a7a3a;
  --neutral:   #6b6b6b;
  --override:  #8a5a00;
  --mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font: 14px/1.45 system-ui, -apple-system, "Segoe UI", sans-serif;
  color: var(--fg);
  background: var(--bg);
}

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

/* Top bar */
.topbar {
  border-bottom: 1px solid var(--bd);
  background: var(--bg-panel);
}
.topbar-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 10px 20px;
  display: flex;
  align-items: center;
  gap: 24px;
}
.brand {
  font-family: var(--mono);
  font-weight: 600;
  font-size: 16px;
  color: var(--fg);
}
.topbar nav {
  display: flex;
  gap: 18px;
  align-items: center;
  flex: 1;
}
.topbar nav a { color: var(--fg-muted); }
.topbar nav a:hover { color: var(--fg); text-decoration: none; }
.topbar nav .who {
  margin-left: auto;
  color: var(--fg-muted);
  font-family: var(--mono);
  font-size: 12px;
}

/* Layout */
.page {
  max-width: 1200px;
  margin: 0 auto;
  padding: 24px 20px 64px;
}
h1 { font-size: 22px; font-weight: 600; margin: 0 0 16px; }
h2 { font-size: 14px; font-weight: 600; margin: 32px 0 10px; color: var(--fg-muted); text-transform: uppercase; letter-spacing: 0.04em; }
h3 { font-size: 14px; font-weight: 600; margin: 0 0 8px; }

.panel {
  background: var(--bg-panel);
  border: 1px solid var(--bd);
  border-radius: 4px;
  padding: 16px;
  margin-bottom: 16px;
}

/* Forms */
form.search {
  display: flex;
  gap: 8px;
  margin-bottom: 24px;
}
form.search input[type=text] {
  flex: 1;
  font: 14px var(--mono);
  padding: 8px 10px;
  border: 1px solid var(--bd);
  border-radius: 3px;
  background: var(--bg-panel);
}
form.search input[type=text]:focus { outline: 2px solid var(--accent); border-color: var(--accent); }
form.search button, button.primary, .button {
  font: 14px system-ui;
  padding: 8px 14px;
  border: 1px solid var(--bd);
  border-radius: 3px;
  background: var(--bg-panel);
  cursor: pointer;
  color: var(--fg);
}
form.search button:hover, button.primary:hover, .button:hover { border-color: var(--fg-muted); }
button.primary { background: var(--accent); color: white; border-color: var(--accent); }
button.danger  { background: var(--bot);    color: white; border-color: var(--bot); }
button.linklike {
  background: none;
  border: none;
  color: var(--fg-muted);
  padding: 0;
  font: inherit;
  cursor: pointer;
}
button.linklike:hover { color: var(--fg); text-decoration: underline; }
form.inline { display: inline; }

/* Verdict block */
.verdict {
  display: flex;
  gap: 24px;
  align-items: center;
  padding: 14px 16px;
  border-radius: 4px;
  background: var(--bg-panel);
  border: 1px solid var(--bd);
}
.verdict .label { font-family: var(--mono); font-weight: 600; font-size: 16px; }
.verdict.bot   .label { color: var(--bot); }
.verdict.human .label { color: var(--human); }
.verdict.none  .label { color: var(--neutral); }
.verdict .conf { font-family: var(--mono); color: var(--fg-muted); }
.verdict .src  { font-family: var(--mono); font-size: 12px; color: var(--fg-muted); margin-left: auto; }
.verdict.override { border-color: var(--override); background: #fff7e8; }
.verdict.override .label { color: var(--override); }

/* Signal pills */
.signals { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.signal {
  font-family: var(--mono);
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--bd-soft);
  color: var(--fg);
  border: 1px solid var(--bd);
}
.signal.positive { background: #fbe6e2; border-color: #e8b4ad; color: var(--bot); }
.signal.negative { background: #e3f0e5; border-color: #b6d7bd; color: var(--human); }
.signal.override { background: #fff1d4; border-color: #e6c87a; color: var(--override); }

/* Tables */
table.data {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
table.data th, table.data td {
  text-align: left;
  padding: 6px 8px;
  border-bottom: 1px solid var(--bd-soft);
  vertical-align: top;
}
table.data th {
  font-weight: 600;
  color: var(--fg-muted);
  background: #f3f2ee;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
table.data td.mono, table.data td .mono { font-family: var(--mono); }
table.data tr:hover td { background: #f8f7f3; }
table.data td.bot   { color: var(--bot); }
table.data td.human { color: var(--human); }

/* Key/value detail panels */
dl.detail {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 6px 24px;
  margin: 0;
}
dl.detail dt {
  color: var(--fg-muted);
  font-size: 13px;
  font-family: var(--mono);
}
dl.detail dd {
  margin: 0;
  font-family: var(--mono);
  font-size: 13px;
  word-break: break-all;
}

.muted { color: var(--fg-muted); }
.mono  { font-family: var(--mono); }

/* Login */
.center-narrow {
  max-width: 360px;
  margin: 60px auto;
}
form.stack { display: flex; flex-direction: column; gap: 10px; }
form.stack label { font-size: 12px; color: var(--fg-muted); text-transform: uppercase; letter-spacing: 0.04em; }
form.stack input[type=email], form.stack input[type=password] {
  font: 14px var(--mono);
  padding: 8px 10px;
  border: 1px solid var(--bd);
  border-radius: 3px;
  background: var(--bg-panel);
}
.flash {
  background: #fce5e0;
  border: 1px solid #e8b4ad;
  color: var(--bot);
  padding: 8px 10px;
  border-radius: 3px;
  font-size: 13px;
  margin-bottom: 12px;
}

/* Dashboard tiles */
.tiles {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 12px;
}
.tiles.small { grid-template-columns: repeat(3, 1fr); }
.tile {
  background: var(--bg-panel);
  border: 1px solid var(--bd);
  border-radius: 4px;
  padding: 12px 14px;
}
.tile-label {
  font-size: 11px;
  color: var(--fg-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.tile-value {
  font-family: var(--mono);
  font-size: 22px;
  font-weight: 600;
  margin: 4px 0 2px;
}
.tile-sub {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-muted);
}
.tile.warn { border-color: var(--bot); }
.tile.warn .tile-value { color: var(--bot); }

/* Inline RDAP detail rows on /manage. Each ASN's main <tr> is
   followed by a sibling <tr class="rdap-detail"> initially hidden;
   the "rdap" button toggles .open on the detail row and fires an
   HTMX request once to fill the cell. */
tr.rdap-detail { display: none; }
tr.rdap-detail.open { display: table-row; }
tr.rdap-detail > td.rdap-cell {
  background: #f7f6f1;
  border-top: 1px dashed var(--bd);
  padding: 10px 14px;
  font-size: 12px;
  color: var(--fg);
}
.rdap-panel dl {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 4px 16px;
  margin: 0;
}
.rdap-panel dt {
  color: var(--fg-muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding-top: 1px;
}
.rdap-panel dd { margin: 0; }
.rdap-error { color: var(--bot); font-size: 12px; }
button.linklike.rdap-toggle { color: var(--accent); }
button.linklike.rdap-toggle:hover { text-decoration: underline; }

/* Two-column grid for "top ASNs / top paths" pair */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 900px) {
  .tiles, .tiles.small { grid-template-columns: 1fr 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
}

/* Inline bar chart cells inside table.chart */
table.chart td .bar {
  height: 14px;
  background: linear-gradient(to right, #c8d8eb, #c8d8eb);
  border-radius: 2px;
  position: relative;
  overflow: hidden;
}
table.chart td .bar .bar-bot {
  height: 100%;
  background: #e6a6a0;
}

/* ============================================================
   Public home page (/). Stand-alone styling — no topbar / nav.
   ============================================================ */
body.home {
  background: #f5f3ed;
  display: flex;
  min-height: 100vh;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.home-card {
  background: var(--bg-panel);
  border: 1px solid var(--bd);
  border-radius: 8px;
  padding: 36px 40px 28px;
  max-width: 560px;
  width: 100%;
  text-align: center;
  box-shadow: 0 2px 18px rgba(0, 0, 0, 0.04);
}
.home-label {
  margin: 0 0 14px;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.home-ip-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.home-ip {
  font-family: var(--mono);
  /* Scales from ~20px on narrow phones to 40px on wide screens. Full
     IPv6 strings (39 chars max) fit at ~20px in the 560px-wide card
     without wrapping. Switch to overflow-wrap:anywhere as a safety
     net for hypothetical exotic addresses. */
  font-size: clamp(20px, 4.2vw, 40px);
  font-weight: 600;
  user-select: all;
  overflow-wrap: anywhere;
}
.home-copy {
  font: 13px var(--mono);
  padding: 6px 14px;
  border: 1px solid var(--bd);
  border-radius: 4px;
  background: var(--bg-panel);
  color: var(--fg-muted);
  cursor: pointer;
  transition: all 0.15s ease;
}
.home-copy:hover {
  color: var(--fg);
  border-color: var(--fg-muted);
}
.home-copy.copied {
  background: var(--human);
  border-color: var(--human);
  color: #fff;
}
.home-meta {
  margin: 20px 0 0;
  font-size: 13px;
  color: var(--fg-muted);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.home-asn { font-family: var(--mono); font-size: 12px; }
