/* Global nav */
.global-nav { display: flex; gap: 0.75rem; margin-bottom: 1rem; }
/* Site header */
.site-header { display: flex; flex-direction: column; gap: 0.6rem; padding: 0.5rem 1rem 1.25rem; }
.header-top { display: flex; align-items: center; justify-content: space-between; }
.header-title { margin: 0; font-size: 1.5rem; color: var(--text); font-weight: 600; }
.logo-link { display:inline-flex; align-items:center; padding:0.35rem; border-radius:0.9rem; background:var(--bg1); border:1px solid rgba(var(--fg-rgb),0.15); box-shadow:none; }
.logo-img { height:48px; width:auto; display:block; border-radius:0.75rem; }
.logo-img--xl { height: 300px; width: auto; border-radius: 0.75rem; }
@media (max-width: 640px) { .logo-img--xl { height: 64px; } }
.nav-link {
  padding: 0.55rem 1.4rem; border-radius: 999px; text-decoration: none; font-weight: 600;
  color: var(--primary); border: 1px solid rgba(var(--primary-rgb), 0.3); background: var(--bg1);
  box-shadow: none; transition: color 0.2s ease, border-color 0.2s ease;
}
.nav-link:hover { transform: none; border-color: var(--primary); }

/* Layout + panels */
.layout { max-width: 120rem; margin: 0 auto; }
.panel { background: var(--card-bg); border-radius: 1rem; box-shadow: 0 6px 18px rgba(var(--bg4-rgb), 0.25); border: 1px solid rgba(var(--fg2-rgb), 0.2); transition: border-color 0.2s ease; }
.panel:hover { transform: none; box-shadow: 0 6px 18px rgba(var(--bg4-rgb), 0.25); border-color: rgba(var(--fg1-rgb), 0.35); }
.panel .content { padding: 0 2rem 2rem; }
.panel--padded { padding: clamp(1rem, 2.5vw, 2rem); }
.panel-header { padding: 1rem 2rem 0; display: flex; justify-content: space-between; align-items: center; }
.view-nav { display:flex; align-items:center; gap:0.5rem; }
.view-link { color: var(--muted); text-decoration: none; font-weight: 600; padding: 0.5rem 1rem; border-radius: 0.5rem; transition: color 0.2s ease, background 0.2s ease; }
.view-link:hover { color: var(--primary); background: rgba(var(--primary-rgb), 0.12); }
.view-link.active { color: var(--primary); background: rgba(var(--primary-rgb), 0.12); }
.detail-card { margin-top: 1rem; }
.messages-container { max-width: 800px; margin: 0 auto; }

/* Forms */
.form-grid { display: grid; gap: 0.75rem; }
label { font-weight: 600; color: var(--muted); }
input[type="text"],
input[type="email"],
input[type="password"],
input[type="date"],
input[type="number"] {
  padding: 0.85rem 1rem;
  border-radius: 0.9rem;
  border: 1px solid var(--border);
  background: var(--bg1);
  color: var(--text);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
input[type="text"]:focus,
input[type="password"]:focus,
input[type="date"]:focus,
input[type="number"]:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.2);
  outline: none;
}
button { padding: 0.85rem 1.5rem; border-radius: 999px; border: none; font-weight: 600; background: var(--primary); color: var(--bg); cursor: pointer; transition: background 0.2s ease; }
button:hover { transform: none; background: var(--secondary); box-shadow: none; }

/*************************
 * Connection list styles *
 *************************/
.connection-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.55rem; }
.connection-item { display: flex; align-items: center; gap: 0.6rem; border: 1px solid var(--border); border-radius: 0.9rem; padding: 0.65rem 0.9rem; background: var(--bg1); transition: border-color 0.2s ease, background 0.2s ease; }
.connection-item:hover { border-color: var(--primary); background: var(--bg2); transform: none; box-shadow: none; }
.connection-item.active { border-color: var(--primary); background: rgba(var(--primary-rgb),0.12); }
.connection-body { display: flex; align-items: center; gap: 0.55rem; flex: 1; min-width: 0; }
.connection-link { color: var(--fg); text-decoration: none; font-weight: 600; letter-spacing: 0.2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.connection-link:hover { color: var(--primary); }
/* Left color accents by token */
.connection-item--aqua { border-left: 4px solid var(--aqua); }
.connection-item--yellow { border-left: 4px solid var(--yellow); }
.connection-item--blue { border-left: 4px solid var(--blue); }
.connection-item--purple { border-left: 4px solid var(--purple); }
.connection-item--green { border-left: 4px solid var(--green); }
.connection-item--red { border-left: 4px solid var(--red); }
.connection-item--orange { border-left: 4px solid var(--orange); }
/* Color chip */
.conn-chip { display:inline-block; width:0.75rem; height:0.75rem; border-radius:999px; margin-right:0.4rem; border:1px solid rgba(var(--fg-rgb),0.2); vertical-align:middle; box-shadow: 0 0 6px rgba(var(--bg-rgb),0.45) inset; }
.conn-chip--aqua { background: var(--aqua); }
.conn-chip--yellow { background: var(--yellow); }
.conn-chip--blue { background: var(--blue); }
.conn-chip--purple { background: var(--purple); }
.conn-chip--green { background: var(--green); }
.conn-chip--red { background: var(--red); }
.conn-chip--orange { background: var(--orange); }

/* Tables */
.table-controls { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1rem; gap: 1rem; }
.table-controls input[type="text"] { padding: 0.6rem 0.75rem; border-radius: 0.6rem; border: 1px solid var(--border); background: var(--bg1); color: var(--text); }
.table-controls input[type="text"]:focus { border-color: var(--primary); outline: none; box-shadow: 0 0 0 3px rgba(var(--primary-rgb),0.2); }
.table-controls select:focus { border-color: var(--primary); outline: none; box-shadow: 0 0 0 3px rgba(var(--primary-rgb),0.2); }

.gruvbox-select {
  background: var(--bg1);
  color: var(--fg);
  border-radius: 0.75rem;
  border: 1px solid rgba(var(--fg2-rgb), 0.3);
  padding: 0.55rem 2rem 0.55rem 0.85rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  box-shadow: none;
}
.gruvbox-select option {
  background: var(--bg2);
  color: var(--fg);
}


.sortable-table { width: 100%; border-collapse: collapse; margin-bottom: 1rem; }
.sortable-table th { position: relative; background: var(--bg); padding: 0.75rem; text-align: left; border-bottom: 2px solid var(--border); cursor: pointer; user-select: none; }
.sortable-table th:hover { background: rgba(var(--primary-rgb), 0.15); }
.sortable-table th[data-dir="asc"]::after { content: "▲"; position: absolute; right: 0.6rem; color: var(--muted); font-size: 0.8rem; }
.sortable-table th[data-dir="desc"]::after { content: "▼"; position: absolute; right: 0.6rem; color: var(--muted); font-size: 0.8rem; }
.sortable-table td { padding: 0.75rem; border-bottom: 1px solid var(--border); }
.sortable-table a { color: var(--primary); text-decoration: none; }
.sortable-table a:hover { text-decoration: underline; }
.sortable-table .th-group { text-align: center; cursor: default; border-bottom: 1px solid var(--border); }
.sortable-table .col-group-start { border-left: 2px solid var(--border); }
.sortable-table .col-group-start-subtle { border-left: 2px solid var(--border); }

.category-pill-row { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.category-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(var(--fg-rgb), 0.25);
  background: rgba(var(--bg2-rgb), 0.6);
  color: var(--fg);
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 0.2rem 0.65rem;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.category-pill:hover,
.category-pill:focus {
  background: rgba(var(--primary-rgb), 0.2);
  border-color: var(--primary);
  color: var(--primary);
  outline: none;
}
.category-pill--solid {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--bg);
  font-weight: 700;
  letter-spacing: 0.08em;
}

.exchange-pill-row { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.exchange-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: rgba(var(--aqua-rgb), 0.2);
  color: var(--aqua);
  border: 1px solid rgba(var(--aqua-rgb), 0.4);
  text-decoration: none;
}
.exchange-pill:hover,
.exchange-pill:focus {
  background: rgba(var(--aqua-rgb), 0.3);
  border-color: var(--aqua);
  color: var(--bg);
  outline: none;
}

.asset-pill-row { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.asset-pill {
  display: inline-flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.25rem;
  border-radius: 0.9rem;
  border: 1px solid rgba(var(--fg-rgb), 0.2);
  background: var(--bg1);
  color: var(--fg);
  padding: 0.35rem 0.75rem;
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease;
}
.asset-pill:hover,
.asset-pill:focus {
  border-color: var(--primary);
  background: rgba(var(--primary-rgb), 0.12);
  outline: none;
}
.asset-pill__content {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.asset-pill__name {
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.01em;
}
.asset-pill .asset-logo {
  width: 20px;
  height: 20px;
  border-radius: 50%;
}
.asset-pill__exchange {
  font-size: 0.7rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.message-pill-row { display: flex; flex-wrap: wrap; gap: 0.3rem; }
.message-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--fg-rgb), 0.25);
  background: rgba(var(--bg2-rgb), 0.6);
  color: var(--fg);
  font-size: 0.75rem;
  text-decoration: none;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.message-pill:hover,
.message-pill:focus {
  border-color: var(--primary);
  color: var(--primary);
  outline: none;
}

/* Pagination */
.pagination { display: flex; justify-content: center; align-items: center; gap: 1rem; }
.pagination button, .pagination .page-btn { padding: 0.5rem 1rem; border: 1px solid var(--border); background: var(--bg); border-radius: 0.5rem; cursor: pointer; transition: background 0.2s ease; color: var(--text); text-decoration: none; }
.pagination button:hover, .pagination .page-btn:hover { background: rgba(var(--primary-rgb), 0.12); }

/* Delisted assets */
.delisted { opacity: 0.9; background: var(--bg3); }
.asset-pill.delisted { opacity: 0.9; background: rgba(var(--bg3-rgb), 0.9); }

/* Deleted rows */
.deleted { opacity: 0.9; background: var(--bg3); }
.badge { background: var(--red); color: white; padding: 0.1rem 0.3rem; border-radius: 0.2rem; font-size: 0.6rem; margin-left: 0.3rem; display: inline-block; }

/* Messages */
.messages-filter-form {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: flex-end;
  margin-bottom: 1.5rem;
  padding: 1rem 1.25rem;
  border: 1px solid rgba(var(--fg2-rgb), 0.2);
  border-radius: 1rem;
  background: var(--bg1);
  box-shadow: 0 8px 20px rgba(var(--bg4-rgb), 0.2);
}
.messages-filter-form__fields {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  flex: 1 1 15rem;
}
.messages-filter-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: min(220px, 100%);
}
.messages-filter-form__field--inline {
  flex-direction: row;
  align-items: center;
  gap: 0.6rem;
  min-width: auto;
}
.messages-filter-form__field--inline .messages-filter-form__label {
  margin: 0;
}
.toggle-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  user-select: none;
}
.toggle-pill input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.toggle-pill__track {
  width: 2.4rem;
  height: 1.35rem;
  border-radius: 999px;
  background: rgba(var(--fg2-rgb), 0.25);
  border: 1px solid rgba(var(--fg2-rgb), 0.35);
  position: relative;
  transition: background 0.2s ease, border-color 0.2s ease;
}
.toggle-pill__thumb {
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 50%;
  background: var(--bg1);
  border: 1px solid rgba(var(--fg2-rgb), 0.4);
  position: absolute;
  top: 0.1rem;
  left: 0.15rem;
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}
.toggle-pill__text {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--muted);
  letter-spacing: 0.02em;
}
.toggle-pill input:checked + .toggle-pill__track {
  background: rgba(var(--primary-rgb), 0.35);
  border-color: rgba(var(--primary-rgb), 0.6);
}
.toggle-pill input:checked + .toggle-pill__track .toggle-pill__thumb {
  transform: translateX(1.05rem);
  background: var(--primary);
  border-color: rgba(var(--primary-rgb), 0.8);
}
.toggle-pill input:checked ~ .toggle-pill__text {
  color: var(--primary);
}
.messages-filter-form__label {
  font-size: 0.85rem;
  letter-spacing: 0.02em;
}
.messages-filter-form__actions {
  display: flex;
  gap: 0.65rem;
  align-items: center;
  flex-wrap: wrap;
}
.messages-filter-form__actions .page-btn {
  border-radius: 0.75rem;
  padding: 0.55rem 1.2rem;
  border: 1px solid rgba(var(--fg2-rgb), 0.25);
  background: var(--bg2);
  color: var(--fg);
}
.messages-filter-form__actions .page-btn:hover {
  background: rgba(var(--primary-rgb), 0.12);
  border-color: var(--primary);
}
.messages-refresh-toggle {
  margin-left: 0.25rem;
}
.messages-poll-status {
  font-size: 0.82rem;
  margin-left: 0.25rem;
}
.messages-filter-form input[type="date"] {
  font-weight: 600;
  letter-spacing: 0.01em;
}
.messages-filter-form input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(50%) sepia(10%) saturate(200%);
  cursor: pointer;
  border-radius: 0.4rem;
  padding: 0.15rem;
}
.messages-filter-form input[type="date"]::-webkit-calendar-picker-indicator:hover {
  background: rgba(var(--primary-rgb), 0.15);
}
.custom-select {
  position: relative;
}
.custom-select__control {
  width: 100%;
  border-radius: 0.9rem;
  border: 1px solid rgba(var(--fg2-rgb), 0.3);
  background: var(--bg1);
  color: var(--fg);
  padding: 0.8rem 1rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}
.custom-select__control:hover {
  border-color: var(--primary);
}
.custom-select__chevron {
  font-size: 0.9rem;
  color: var(--muted);
}
.custom-select__panel {
  position: absolute;
  top: calc(100% + 0.35rem);
  left: 0;
  right: 0;
  z-index: 10;
  background: var(--bg1);
  border: 1px solid rgba(var(--fg2-rgb), 0.3);
  border-radius: 0.9rem;
  box-shadow: 0 12px 30px rgba(var(--bg4-rgb), 0.35);
  padding: 0.6rem;
  display: none;
}
.custom-select__panel[data-open="true"] {
  display: block;
}
.custom-select__search {
  width: 100%;
  margin-bottom: 0.5rem;
}
.custom-select__options {
  max-height: 220px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.custom-select__option {
  border: 1px solid transparent;
  background: transparent;
  color: var(--fg);
  text-align: left;
  padding: 0.35rem 0.5rem;
  border-radius: 0.6rem;
  cursor: pointer;
}
.custom-select__option:hover,
.custom-select__option[data-active="true"] {
  border-color: rgba(var(--primary-rgb), 0.4);
  background: rgba(var(--primary-rgb), 0.12);
}
@media (max-width: 640px) {
  .messages-filter-form { flex-direction: column; align-items: stretch; }
  .messages-filter-form__actions { justify-content: flex-end; }
}
.messages-list { display: flex; flex-direction: column; gap: 1rem; }
.message-bubble { background: var(--card-bg); border-radius: 1rem; padding: 1rem; box-shadow: none; border: 1px solid var(--border); position: relative; }
.message-bubble.real-time { border-color: var(--primary); background: rgba(var(--primary-rgb), 0.08); }
.message-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.5rem; font-size: 0.9rem; gap: 0.75rem; flex-wrap: wrap; }
.channel-name { font-weight: 600; color: var(--primary); }
.message-type {
  background: rgba(var(--yellow-rgb), 0.25);
  color: var(--yellow);
  padding: 0.1rem 0.5rem;
  border-radius: 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.message-time { color: var(--muted); }
.message-time__relative {
  margin-left: 0.35rem;
  color: var(--fg2);
  font-size: 0.8rem;
}
.message-text { line-height: 1.5; white-space: pre-wrap; }
.message-tags { margin-top: 0.5rem; display: flex; gap: 0.5rem; flex-wrap: wrap; }
.tag { display: inline-flex; align-items: center; gap: 0.25rem; background: var(--bg3); color: var(--fg); padding: 0.25rem 0.6rem; border-radius: 999px; font-size: 0.8rem; font-weight: 600; border: 1px solid rgba(var(--fg-rgb),0.15); }
.tag--labels { background: var(--aqua); color: var(--bg); }
.tag--events { background: var(--yellow); color: var(--bg); }
.action-link { color: var(--primary); text-decoration: none; font-weight: 600; }
.action-link:hover { text-decoration: underline; }

/* Status */
.status { padding: 0.75rem 1rem; border-radius: 0.9rem; }
.status.success { background: rgba(var(--success-rgb), 0.15); color: var(--green); }
.status.error { background: rgba(var(--danger-rgb), 0.18); color: var(--red); }

/* Cards / details */
.info-card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 0.75rem; padding: 1.5rem; margin-bottom: 2rem; box-shadow: none; position: relative; }
.info-card::before { display: none; }
.info-card:hover { transform: none; box-shadow: none; border-color: rgba(var(--fg2-rgb),0.25); }
.labels-container { display: flex; flex-direction: column; gap: 1.5rem; }
.label-section { border: 1px solid rgba(var(--fg2-rgb),0.2); border-radius: 0.75rem; padding: 1.5rem; background: var(--bg1); position: relative; overflow: hidden; }
.message-content-grid { display: grid; gap: 0.75rem; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); }
.message-body-card { background: var(--bg1); }
.message-meta-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.message-meta-block {
  padding: 0.85rem;
  border-radius: 0.85rem;
  border: 1px solid rgba(var(--fg2-rgb), 0.2);
  background: var(--bg1);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.message-meta-block--accent {
  border-color: rgba(var(--yellow-rgb), 0.4);
  background: rgba(var(--yellow-rgb), 0.12);
}
.message-meta-block--accent h5 {
  margin: 0 0 0.4rem;
  color: var(--yellow);
  letter-spacing: 0.02em;
}
.id-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.3rem 0.65rem;
  border-radius: 0.45rem;
  background: var(--bg2);
  border: 1px solid rgba(var(--fg2-rgb), 0.2);
  font-family: monospace;
  font-size: 0.95em;
  line-height: 1.5;
  max-width: 100%;
}
.id-chip__value {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.id-chip__copy {
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.1rem;
  color: var(--fg2);
  font-size: 0.85em;
  line-height: 1;
  border-radius: 0.25rem;
  transition: color 0.15s, background 0.15s;
}
.id-chip__copy:hover {
  color: var(--fg);
  background: rgba(var(--fg2-rgb), 0.15);
}
.message-text-highlight {
  padding: 0.95rem 1.1rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(var(--orange-rgb), 0.4);
  background: rgba(var(--orange-rgb),0.25);
  box-shadow: none;
  color: var(--fg);
  font-size: 1.05rem;
}
.message-text-highlight strong {
  color: var(--orange);
  letter-spacing: 0.02em;
}
.message-build-grid {
  display: grid;
  gap: 0.65rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.label-columns {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(3, minmax(220px, 1fr));
  align-items: start;
}
@media (max-width: 1100px) {
  .label-columns { grid-template-columns: repeat(2, minmax(220px, 1fr)); }
}
@media (max-width: 700px) {
  .label-columns { grid-template-columns: 1fr; }
}
.label-grid {
  display: grid;
  grid-template-columns: minmax(160px, 220px) 1fr;
  gap: 0.35rem 1rem;
  margin-bottom: 0;
}
.label-grid dt {
  font-weight: 600;
  color: var(--primary);
}
.label-grid dd {
  margin: 0;
}
.label-reasoning h6 {
  margin: 0 0 0.5rem;
  font-size: 0.9rem;
  letter-spacing: 0.03em;
  color: var(--accent);
}
.reasoning-highlight {
  padding: 0.75rem 0.85rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(var(--accent-rgb), 0.35);
  background: rgba(var(--accent-rgb),0.2);
  color: var(--fg);
  line-height: 1.45;
  box-shadow: none;
}
.reasoning-highlight strong {
  color: var(--accent);
}
.timing-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}
.timing-card__summary {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
  font-weight: 600;
  color: var(--fg1);
}
.timing-details {
  padding-top: 0.75rem;
}
.timing-details summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: 0.65rem;
  list-style: none;
}
.timing-details summary::-webkit-details-marker {
  display: none;
}
.timing-details[open] summary {
  margin-bottom: 0.85rem;
}
.timing-track {
  display: flex;
  flex-wrap: nowrap;
  border: 1px solid rgba(var(--fg2-rgb), 0.2);
  /* border-radius: 0.75rem; */
  /* overflow-x: auto; */
  /* overflow-y: hidden; */
  margin-bottom: 1.25rem;
  height: 2rem;
}
.timing-segment {
  min-width: 0;
  min-height: 100%;
  border-right: 1px solid rgba(var(--bg-rgb), 0.25);
}
.timing-chip {
  display: inline-flex;
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 0.25rem;
  margin-right: 0.5rem;
  vertical-align: middle;
  border: 1px solid rgba(var(--bg-rgb), 0.25);
}
.timing-segment--color-0,
.timing-chip--color-0 {
  background: rgba(var(--blue-rgb), 0.85);
}
.timing-segment--color-1,
.timing-chip--color-1 {
  background: rgba(var(--aqua-rgb), 0.8);
}
.timing-segment--color-2,
.timing-chip--color-2 {
  background: rgba(var(--orange-rgb), 0.82);
}
.timing-segment--color-3,
.timing-chip--color-3 {
  background: rgba(var(--purple-rgb), 0.8);
}
.timing-segment--color-4,
.timing-chip--color-4 {
  background: rgba(var(--yellow-rgb), 0.75);
}
.timing-segment--color-5,
.timing-chip--color-5 {
  background: rgba(var(--green-rgb), 0.78);
}
.timing-table-wrapper {
  overflow-x: auto;
}
.timing-table td,
.timing-table th {
  white-space: nowrap;
}
.profile-header {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 1.5rem;
}
.profile-filter-form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  border: 1px solid rgba(var(--fg2-rgb), 0.2);
  border-radius: 0.9rem;
  background: var(--bg1);
  margin-bottom: 1.5rem;
}
.profile-filter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.75rem;
}
.profile-filter-form label {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: 0.85rem;
  color: var(--muted);
}
.profile-filter-form input,
.profile-filter-form select {
  width: 100%;
  border-radius: 0.65rem;
  border: 1px solid rgba(var(--fg2-rgb), 0.3);
  padding: 0.5rem 0.75rem;
  background: var(--bg);
  color: var(--fg);
}
.profile-filter-form button {
  align-self: flex-start;
  border-radius: 0.65rem;
  padding: 0.6rem 1.8rem;
}
.profile-summary-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  margin-bottom: 1.5rem;
}
.profile-summary-card {
  border: 1px solid rgba(var(--fg2-rgb), 0.25);
  border-radius: 0.9rem;
  padding: 1rem;
  background: var(--bg1);
}
.profile-summary-card h4 {
  margin: 0;
  font-size: 0.9rem;
  color: var(--muted);
}
.profile-summary-value {
  margin: 0.3rem 0;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--primary);
}
.profile-chart {
  margin-bottom: 1.5rem;
}
.profile-timeline-card {
  margin-bottom: 1.5rem;
}
.profile-timeline-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
  margin-bottom: 1rem;
}
.timeline-bar-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.timeline-bar-row {
  display: grid;
  grid-template-columns: 120px 1fr auto;
  gap: 0.75rem;
  align-items: center;
}
.timeline-bar-row__date {
  font-weight: 600;
  color: var(--fg1);
}
.timeline-bar-row__bar {
  position: relative;
  height: 0.65rem;
  border-radius: 999px;
  background: rgba(var(--fg2-rgb), 0.2);
  overflow: hidden;
}
.timeline-bar-row__bar span {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--secondary), var(--accent));
}
.timeline-bar-row__value {
  font-weight: 600;
}
.profile-chart-list {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-top: 0.75rem;
}
.profile-chart-row {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  grid-template-areas:
    "label duration"
    "track track";
  gap: 0.35rem 0.75rem;
  padding: 0.4rem 0;
}
.profile-chart-label {
  grid-area: label;
  font-weight: 600;
  white-space: normal;
  overflow: visible;
}
.profile-chart-track {
  grid-area: track;
  position: relative;
  height: 0.85rem;
  border-radius: 999px;
  background: rgba(var(--fg2-rgb), 0.15);
  overflow: hidden;
}
.profile-chart-bar {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--blue), var(--purple));
}
.profile-chart-duration {
  grid-area: duration;
  font-weight: 600;
  text-align: right;
}
.profile-table-wrapper {
  overflow-x: auto;
}
.positions-compare th { text-align: center; }
.positions-compare td { text-align: center; }
.positions-compare__id { font-weight: 700; color: var(--accent); text-align: left !important; }
.positions-compare .before-group,
.positions-compare .before-heading {
  background: rgba(var(--primary-rgb),0.25);
  color: var(--fg);
}
.positions-compare .after-group,
.positions-compare .after-heading {
  background: rgba(var(--yellow-rgb),0.3);
  color: var(--fg);
}
.positions-compare td.before-cell {
  background: rgba(var(--primary-rgb),0.12);
  border-left: 1px solid rgba(var(--primary-rgb),0.35);
}
.positions-compare td.after-cell {
  background: rgba(var(--yellow-rgb),0.18);
  border-left: 1px solid rgba(var(--orange-rgb),0.35);
}
.positions-compare td.before-cell.muted,
.positions-compare td.after-cell.muted {
  color: var(--muted);
}

/* Detail page */
.detail-page { background: var(--card-bg); border-radius: 1.1rem; box-shadow: none; padding: clamp(2rem, 5vw, 4rem); width: min(34rem, 100%); border: 1px solid var(--border); margin: 0 auto; }
.detail-header { display:flex; justify-content: space-between; align-items:center; gap: 0.75rem; margin-bottom: 1rem; }
.primary-text { color: var(--primary); }

/* Data table styles (used in message_details) */
.data-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; border-radius: 0.5rem; overflow: hidden; box-shadow: none; }
.data-table th { background: var(--bg2); color: var(--fg); padding: 1rem 0.75rem; text-align: left; font-weight: 600; }
.data-table th::after { display: none; }
.data-table td { padding: 0.75rem; border-bottom: 1px solid rgba(var(--fg3-rgb),0.2); }
.data-table tr:nth-child(even) { background: rgba(var(--bg2-rgb),0.3); }
.data-table tr:hover { background: rgba(var(--bg2-rgb),0.45); }

/* Titles */
.label-title { margin: 0 0 1rem; color: var(--primary); font-size: 1.2rem; font-weight: 700; }

/*****************************
 * Top connections nav styles *
 *****************************/
.connections-nav { display: flex; justify-content: center; padding: 0.25rem 0 0.4rem; }
.connections-nav__list { display: flex; gap: 0.5rem; list-style: none; padding: 0; margin: 0; flex-wrap: wrap; }
.connections-nav__item { }
.connections-nav__item.active .connection-pill { border-color: var(--primary); background: rgba(var(--primary-rgb),0.15); box-shadow: none; color: var(--fg); transform: none; }
.connection-pill { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.5rem 0.8rem; border-radius: 999px; text-decoration: none; color: var(--fg); background: var(--bg1); border: 1px solid var(--border); transition: background 0.2s ease, border-color 0.2s ease; }
.connection-pill:hover { background: var(--bg2); border-color: var(--primary); transform: none; box-shadow: none; }

/***********************
 * View selector pills *
 ***********************/
.views-nav { display: flex; justify-content: center; padding: 0 0 0.6rem; }
.views-nav__list { display: flex; gap: 0.5rem; list-style: none; padding: 0; margin: 0; flex-wrap: wrap; }
.views-nav__item { }
.view-pill {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.45rem 0.9rem; border-radius: 999px;
  text-decoration: none; color: var(--fg); background: var(--bg1);
  border: 1px solid var(--border);
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
  font-weight: 600;
}
.view-pill:hover { background: var(--bg2); border-color: var(--primary); transform: none; }
.views-nav__item.active .view-pill {
  border-color: var(--primary);
  background: rgba(var(--primary-rgb),0.15);
  box-shadow: none;
}


.asset-logo {
  width: 32px;
  height: 32px;
  object-fit: contain;
  border-radius: 50%;
  background: rgba(var(--bg-rgb), 0.85);
}
