/* ============================================================
   Mac Usta · Panic log list + detail + filter row
   Loaded by index.html via <link>.  See styles/_index.css for order.
   ============================================================ */

   17e. PANIC LOG VIEW
   ============================================================ */
.grid-panic {
  grid-template-columns: 1.1fr 1fr;
}
.panel-panic-list { padding-bottom: 10px; }

.filter-row {
  display: flex; align-items: end; gap: 12px; flex-wrap: wrap;
  padding: 4px 0 14px;
  border-bottom: 1px dashed rgba(14,27,48,.18);
}
.filter {
  display: grid; gap: 4px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.filter select {
  appearance: none;
  -webkit-appearance: none;
  background: var(--paper-0) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1 L5 5 L9 1' fill='none' stroke='%230E1B30' stroke-width='1.4'/></svg>") no-repeat right 10px center;
  border: 1px solid var(--ink);
  border-radius: var(--radius);
  padding: 7px 28px 7px 12px;
  font-family: var(--f-sans);
  font-size: 12.5px;
  color: var(--ink);
}
.filter-spacer { flex: 1; }

.panic-list { display: grid; gap: 4px; margin-top: 14px; }
.panic-row {
  display: grid;
  grid-template-columns: 130px 140px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 12px 14px;
  background: var(--paper-0);
  border: 1px solid var(--ink);
  border-left-width: 4px;
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: .03em;
  color: var(--ink);
  cursor: pointer;
  transition: all var(--t-fast);
}
.panic-row:hover { background: var(--paper-2); }
.panic-row.selected {
  background: var(--ink);
  color: var(--paper-0);
  border-left-color: var(--rust);
  box-shadow: 0 0 0 2px rgba(183,62,46,.16);
}
.panic-date { color: var(--ink-mute); }
.panic-row.selected .panic-date { color: var(--paper-3); }
.panic-type {
  font-family: var(--f-display);
  font-style: italic;
  font-size: 14.5px;
  font-variation-settings: "opsz" 72, "SOFT" 100, "WONK" 1;
}
.panic-proc { font-family: var(--f-mono); color: var(--ink-soft); }
.panic-row.selected .panic-proc { color: var(--paper-3); }
.panic-sev {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: .2em;
  padding: 3px 9px;
  border: 1px solid currentColor;
}
.sev-critical .panic-sev { color: var(--rust); background: rgba(183,62,46,.08); }
.sev-high     .panic-sev { color: var(--warn); background: rgba(199,107,30,.1); }
.sev-mid      .panic-sev { color: var(--spark); background: rgba(31,110,158,.1); }
.sev-low      .panic-sev { color: var(--ink-mute); }
.sev-critical { border-left-color: var(--rust); }
.sev-high     { border-left-color: var(--warn); }
.sev-mid      { border-left-color: var(--spark); }
.sev-low      { border-left-color: var(--ink-mute); }

/* detail */
.detail-head {
  display: flex; align-items: center; gap: 14px;
  padding-bottom: 12px;
  border-bottom: 1px dashed rgba(14,27,48,.18);
}
.detail-when {
  font-family: var(--f-mono);
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: .06em;
  margin-left: auto;
}
.detail-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin: 8px 0;
}
.detail-meta > div {
  display: grid;
  grid-template-columns: 90px 1fr;
  padding: 9px 0;
  border-bottom: 1px dashed rgba(14,27,48,.12);
  align-items: baseline;
}
.detail-meta > div:nth-child(odd)  { padding-right: 12px; border-right: 1px dashed rgba(14,27,48,.18); }
.detail-meta > div:nth-child(even) { padding-left: 12px; }
.detail-meta dt {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.detail-meta dd {
  font-family: var(--f-sans);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink);
}
.detail-meta dd.mono { font-family: var(--f-mono); font-size: 11px; color: var(--rust); }

.detail-title {
  margin: 16px 0 8px;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--rust);
}
.detail-summary {
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--ink-2);
}
.detail-summary strong { font-family: var(--f-display); font-style: italic; }
.detail-summary code { font-family: var(--f-mono); background: rgba(14,27,48,.06); padding: 1px 4px; font-size: 12px; color: var(--rust); }

.trace {
  margin: 0;
  padding: 14px 16px;
  background: var(--graphite);
  color: var(--paper-3);
  border: 1px solid var(--graphite);
  font-family: var(--f-mono);
  font-size: 11.5px;
  line-height: 1.55;
  letter-spacing: .02em;
  overflow-x: auto;
}
.trace code { color: inherit; background: transparent; padding: 0; font-family: inherit; }

.hints {
  display: grid; gap: 6px;
}
.hints li {
  padding: 8px 12px;
  background: var(--paper-0);
  border-left: 3px solid var(--brass);
  font-size: 12.5px;
  color: var(--ink-2);
  line-height: 1.5;
}
.hints li strong { color: var(--ink); font-weight: 500; }
.hints li code { font-family: var(--f-mono); background: rgba(14,27,48,.06); padding: 1px 4px; font-size: 11.5px; color: var(--rust); }

.detail-actions {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px dashed rgba(14,27,48,.18);
}

/* ============================================================
