/* GapGuard — cockpit page (decision ledger + in-browser chain verification) */

.cockpit-head { padding: 44px 0 28px; }

/* status card */
.status {
  display: flex; align-items: center; gap: 28px; flex-wrap: wrap;
  padding: 20px 24px; margin-bottom: 16px;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
}
.status-main { display: flex; align-items: center; gap: 13px; min-width: 230px; }
.status-dot {
  width: 11px; height: 11px; border-radius: 50%; flex: none;
  background: var(--accent); box-shadow: 0 0 0 4px var(--accent-wash), 0 0 14px var(--accent);
}
.status.bad .status-dot { background: var(--alert); box-shadow: 0 0 0 4px var(--alert-wash), 0 0 14px var(--alert); }
.status-headline { font-size: 17px; font-weight: 600; letter-spacing: -0.01em; }
.status.bad .status-headline { color: var(--alert); }
.status-sub { color: var(--ink-3); font-size: 12.5px; margin-top: 1px; }
.status-spacer { flex: 1 1 24px; }
.stat-inline { display: flex; flex-direction: column; gap: 3px; }
.stat-inline .k { font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-3); }
.stat-inline .v { font-size: 15px; font-weight: 600; }
.stat-inline .v.mono { font-family: var(--mono); font-weight: 500; font-size: 13.5px; color: var(--ink-2); }

/* ledger panel */
.panel { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.panel-head {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 16px 20px; border-bottom: 1px solid var(--line);
}
.panel-head .title { display: flex; align-items: baseline; gap: 10px; }
.panel-head .title h2 { margin: 0; font-size: 14px; font-weight: 600; letter-spacing: -0.01em; }
.panel-head .title .count { color: var(--ink-3); font-size: 12.5px; font-family: var(--mono); }

/* toggle */
.toggle { display: inline-flex; align-items: center; gap: 10px; cursor: pointer; user-select: none; font-size: 13px; color: var(--ink-2); }
.toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.track { width: 38px; height: 21px; border-radius: 999px; background: #2a2c34; border: 1px solid var(--line); position: relative; transition: background 0.15s, border-color 0.15s; }
.track::after { content: ""; position: absolute; top: 2px; left: 2px; width: 15px; height: 15px; border-radius: 50%; background: var(--ink-2); transition: transform 0.15s, background 0.15s; }
.toggle input:checked + .track { background: var(--alert-wash); border-color: var(--alert-line); }
.toggle input:checked + .track::after { transform: translateX(17px); background: var(--alert); }
.toggle input:focus-visible + .track { box-shadow: 0 0 0 3px var(--accent-wash); }

/* table */
.scroll { overflow-x: auto; }
table.ledger { width: 100%; border-collapse: collapse; min-width: 760px; }
table.ledger thead th {
  text-align: left; padding: 11px 16px; border-bottom: 1px solid var(--line);
  font-size: 11px; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink-3);
  white-space: nowrap; background: var(--surface);
}
table.ledger tbody td { padding: 13px 16px; border-bottom: 1px solid var(--line-soft); white-space: nowrap; color: var(--ink-2); }
table.ledger tbody tr:last-child td { border-bottom: none; }
table.ledger tbody tr:hover td { background: var(--surface-hi); }
.num { text-align: right; font-family: var(--mono); font-size: 13px; color: var(--ink); }
.strong { color: var(--ink); font-weight: 600; }

.session { display: inline-flex; align-items: center; gap: 8px; color: var(--ink-2); }
.session .live { width: 6px; height: 6px; border-radius: 50%; background: var(--ink-3); flex: none; }
.session.open .live { background: var(--accent); box-shadow: 0 0 8px var(--accent); }

.signal { display: inline-flex; align-items: center; gap: 7px; color: var(--ink); }
.signal .arrow { width: 1.1em; color: var(--ink-3); font-size: 11px; }
.signal .conf { color: var(--ink-3); font-family: var(--mono); font-size: 12px; }

.act { font-weight: 600; color: var(--ink); }
.act.muted { color: var(--ink-3); font-weight: 500; }
.act.realize { color: var(--accent); }

.integ { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 12.5px; color: var(--ink-3); }
.integ .tick { color: var(--accent); }
table.ledger tr.broken td { background: var(--alert-wash); box-shadow: inset 3px 0 0 var(--alert); }
table.ledger tr.broken .integ { color: var(--alert); }
table.ledger tr.broken .integ .tick { color: var(--alert); }

/* empty / error state */
.drop {
  margin: 8px 0; padding: 56px 32px; text-align: center;
  border: 1.5px dashed var(--line); border-radius: var(--radius); background: var(--surface);
  transition: border-color 0.15s, background 0.15s;
}
.drop.hot { border-color: var(--accent-line); background: var(--accent-wash); }
.drop .glyph { color: var(--ink-3); opacity: 0.7; margin-bottom: 16px; display: flex; justify-content: center; }
.drop .glyph svg { height: 30px; width: auto; }
.drop h3 { margin: 0 0 6px; font-size: 15px; font-weight: 600; color: var(--ink); }
.drop p { margin: 0 0 18px; color: var(--ink-3); font-size: 13px; }
.drop input { display: none; }
.drop.err-state { border-color: var(--alert-line); }
.drop .err { color: var(--alert); }
