@import url("https://fonts.googleapis.com/css2?family=Public+Sans:wght@400;500;600;700&display=swap");

:root {
  --bg: #f7f5ef;
  --panel: #fffdf8;
  --text: #121212;
  --muted: #5f665f;
  --line: #d8d3c6;
  --accent: #215a40;
  --success: #215a40;
  --warning: #8a6100;
  --failed: #ff6c6c;
  --soft-accent: #b5dc79;
  --soft-warning: #f1e4b2;
  --heading: "Mattone", "Public Sans", "Segoe UI", Tahoma, Arial, sans-serif;
  --sans: "Public Sans", "Segoe UI", Tahoma, Arial, sans-serif;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg: #181b18;
    --panel: #1f2420;
    --text: #ecebe6;
    --muted: #aeb5ae;
    --line: #394139;
    --accent: #b5dc79;
    --success: #b5dc79;
    --warning: #f1e4b2;
    --failed: #ff8b8b;
    --soft-accent: #2a3b2f;
    --soft-warning: #3a3426;
  }
}

* { box-sizing: border-box; }
html { color-scheme: light dark; }
body {
  margin: 0;
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.35;
  background: var(--bg);
  color: var(--text);
}

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

.explorer-tabs {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 0 0 18px;
  flex-wrap: wrap;
}

.explorer-tab {
  appearance: none;
  min-width: 120px;
  border: 2px solid var(--text);
  border-radius: 0;
  padding: 5px 22px;
  background: var(--panel);
  color: var(--text);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 4px 3px 0 var(--line);
}

.explorer-tab.is-active::before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-right: 8px;
  border: 2px solid var(--text);
  border-radius: 50%;
  background: var(--accent);
  vertical-align: -1px;
}

.explorer-tab:hover {
  transform: translate(1px, 1px);
  box-shadow: 3px 2px 0 var(--line);
}

.explorer-tab:active {
  transform: translate(3px, 2px);
  box-shadow: 1px 1px 0 var(--line);
}

.row-detail-trigger {
  color: var(--accent);
  cursor: pointer;
  font-size: 1.15em;
  font-weight: 700;
  line-height: 1;
}

.row-detail-grid {
  display: grid;
  grid-template-columns: minmax(180px, 28%) 1fr;
  border-top: 1px solid var(--line);
}

.row-detail-grid dt,
.row-detail-grid dd {
  margin: 0;
  padding: 8px 10px;
  border-bottom: 1px solid var(--line);
}

.row-detail-grid dt {
  color: var(--muted);
  font-weight: 600;
  border-right: 1px solid var(--line);
}

.row-detail-grid dd {
  overflow-wrap: anywhere;
}

.row-detail-grid pre {
  margin: 0;
  white-space: pre-wrap;
  font-family: var(--mono);
}

.explorer-filter-row {
  display: grid;
  grid-template-columns: minmax(160px, 220px) minmax(110px, 140px) minmax(240px, 1fr);
  gap: 8px;
  margin-bottom: 8px;
}

#explorer-form .explorer-filter-row select,
#explorer-form .explorer-filter-row input,
#explorer-form.panel textarea {
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 6px 8px;
  background: var(--panel);
  color: var(--text);
}

.explorer-controls-row {
  display: flex;
  align-items: end;
  gap: 14px;
  margin: 16px 0;
  flex-wrap: wrap;
}

.explorer-sort-control {
  flex: 0 1 33%;
  min-width: 240px;
}

.explorer-sort-control span {
  display: block;
  margin-bottom: 4px;
}

#explorer-form .explorer-sort-control select,
#explorer-form .explorer-number-control input {
  width: 100%;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 6px 8px;
  background: var(--panel);
  color: var(--text);
}

.explorer-checkbox-control {
  padding-bottom: 7px;
}

.explorer-number-control {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 4px;
  width: 7rem;
}

.button-primary {
  border: 1px solid var(--accent);
  background: var(--accent);
  color: var(--bg);
  border-radius: 6px;
  padding: 7px 12px;
  font-weight: 600;
}

.container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 24px 12px 12px;
}

header.app-header {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 18px;
  margin-bottom: 14px;
  padding-bottom: 8px;
}

.app-title-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
}

.app-title-wrap h1 {
  display: flex;
  align-items: center;
  margin: 0;
}

header.app-header h1 {
  margin: 0;
  font-family: var(--heading);
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.1;
}

header.app-header h1 a:hover {
  text-decoration: none;
}

.app-title-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.app-logo {
  width: 25px;
  height: 25px;
  display: block;
  fill: currentColor;
  flex-shrink: 0;
}

.relais-logo-mask {
  background: currentColor;
  -webkit-mask: var(--relais-logo-url) center / contain no-repeat;
  mask: var(--relais-logo-url) center / contain no-repeat;
}

nav.app-nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  flex: 1;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  min-height: 38px;
}

nav.app-nav a {
  color: var(--muted);
}

.homepage-view-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0;
  min-height: 34px;
  padding: 1px;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel) 96%, transparent);
}

.homepage-view-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 3px 11px;
  border-radius: 999px;
  color: var(--muted) !important;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.homepage-view-link:hover {
  text-decoration: none;
  color: var(--text) !important;
}

.homepage-view-link.is-active {
  background: color-mix(in srgb, var(--soft-accent) 14%, var(--panel));
  color: var(--accent) !important;
}

.homepage-view-separator {
  color: color-mix(in srgb, var(--line) 82%, transparent);
  font-size: 9px;
  font-weight: 700;
  padding: 0 1px;
}

.app-nav-admin {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  margin-left: 8px;
}

.nav-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--soft-accent) 32%, var(--panel));
  color: var(--accent) !important;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: none;
  white-space: nowrap;
}

.title-badges {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.title-badge {
  min-height: 32px;
  margin-top: 0;
  padding: 2px 9px;
  font-size: 10px;
  border-color: color-mix(in srgb, var(--accent) 20%, var(--line));
  background: color-mix(in srgb, var(--soft-accent) 22%, var(--panel));
}

.nav-badge:hover {
  text-decoration: none;
  background: color-mix(in srgb, var(--soft-accent) 48%, var(--panel));
}

h1, h2, h3 {
  margin: 0 0 8px 0;
  font-family: var(--heading);
  font-weight: 700;
  letter-spacing: 0.015em;
}
h1 { font-size: 18px; line-height: 1.15; }
h2 { font-size: 15px; margin-top: 18px; line-height: 1.2; }
h3 { font-size: 13px; line-height: 1.2; }

.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: 10px;
  margin-bottom: 12px;
}

.panel-soft {
  background: transparent;
  border: none;
  padding: 0;
}

.provider-section {
  padding: 8px 10px 6px;
}

.list-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
}

.list-toolbar-title {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.filter-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.filter-toggle.is-active {
  border-color: var(--accent);
  color: var(--accent);
  background: color-mix(in srgb, var(--soft-accent) 22%, var(--panel));
}

.shortcut-hint {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.4rem;
  padding: 1px 6px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
}

.provider-heading {
  margin: 0 0 8px 0;
  color: var(--muted);
  font-size: 12px;
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.groups-filters-row {
  display: flex;
  align-items: end;
  gap: 12px;
  margin-bottom: 12px;
}

.groups-filters-row label {
  display: grid;
  gap: 4px;
  min-width: 10rem;
}

.groups-filters-row span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.groups-filters-row select {
  width: 100%;
}

.inventory-items-table-groups .mono {
  font-size: 13px;
}

.key-title {
  font-family: var(--heading);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: 0.015em;
}

.item-header-panel {
  padding: 12px;
}

.item-header-top {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
  margin-bottom: 12px;
}

.item-homepage {
  margin-top: 4px;
  font-size: 13px;
  word-break: break-word;
}

.item-description {
  max-width: 68ch;
  line-height: 1.4;
}

.item-header-actions {
  flex-shrink: 0;
}

.section-heading {
  margin: 0 0 10px 0;
  font-family: var(--heading);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.015em;
}

.issue-panel-heading {
  margin-bottom: 0;
}

.item-summary-table,
.files-table {
  width: 100%;
}

.item-summary-table th,
.item-summary-table td,
.files-table th,
.files-table td {
  vertical-align: middle;
}

.current-badge {
  display: inline-block;
  padding: 2px 8px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--soft-accent) 20%, var(--panel));
  color: var(--accent);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
  gap: 8px 16px;
  margin-bottom: 12px;
}

.meta-row {
  display: grid;
  grid-template-columns: 8rem 1fr;
  gap: 8px;
  align-items: start;
  font-size: 13px;
}

.meta-label {
  color: var(--muted);
}

.file-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px 16px;
  margin-bottom: 12px;
}

.file-detail-cell {
  display: grid;
  gap: 4px;
  min-width: 0;
  font-size: 13px;
}

.file-detail-cell-full {
  grid-column: 1 / -1;
}

.detail-link-wrap {
  display: block;
  width: 100%;
  min-width: 0;
  overflow: hidden;
}

.detail-link {
  display: block;
  width: 100%;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.actions-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.nowrap-upload {
  flex-wrap: nowrap;
}

.nowrap-upload input[type="file"] {
  min-width: 18rem;
}

.file-trigger {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text);
  padding: 6px 10px;
  cursor: pointer;
  white-space: nowrap;
  margin: 0;
}

.file-trigger:hover {
  background: color-mix(in srgb, var(--soft-accent) 30%, var(--panel));
}

.file-trigger input[type="file"] {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 4px; }
input, select, textarea, button { font: inherit; }
input[type="text"], input[type="number"], input[type="file"], select, textarea {
  width: 100%;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--text);
  padding: 6px;
}

button {
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text);
  padding: 6px 10px;
  cursor: pointer;
}
button:hover {
  background: color-mix(in srgb, var(--soft-accent) 30%, var(--panel));
}
button.primary {
  border-color: var(--accent);
  color: var(--accent);
}

.inventory-items-table button,
.inventory-items-table .file-trigger {
  padding: 4px 8px;
  border-color: transparent;
  background: transparent;
}

.inventory-items-table button:hover,
.inventory-items-table .file-trigger:hover {
  background: color-mix(in srgb, var(--soft-accent) 18%, transparent);
  border-color: transparent;
}

.messages {
  list-style: none;
  padding: 0;
  margin: 0 0 12px 0;
}

.messages li {
  border: 1px solid var(--line);
  background: var(--panel);
  padding: 8px 10px;
  margin-bottom: 6px;
  font-size: 13px;
}

.messages li.success {
  border-left: 4px solid var(--success);
  background: color-mix(in srgb, var(--soft-accent) 18%, var(--panel));
}
.messages li.error,
.message.error {
  border-left: 4px solid var(--failed);
  background: color-mix(in srgb, var(--failed) 7%, var(--panel));
}

.message.error {
  border-top: 1px solid var(--line);
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 8px 10px;
  margin: 8px 0;
  font-size: 13px;
}
.messages li.warning {
  border-left: 4px solid var(--warning);
  background: color-mix(in srgb, var(--soft-warning) 35%, var(--panel));
}
.messages li.info {
  border-left: 4px solid var(--accent);
  background: color-mix(in srgb, var(--soft-accent) 14%, var(--panel));
}

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

.inventory-items-table {
  width: 100%;
  table-layout: fixed;
  font-size: 12px;
}

.inventory-items-table .col-source { width: 46%; }
.inventory-items-table .col-automation { width: 10%; }
.inventory-items-table .col-last-checked { width: 13%; }
.inventory-items-table .col-check { width: 6%; }
.inventory-items-table .col-collect { width: 6%; }
.inventory-items-table .col-validate { width: 6%; }
.inventory-items-table .col-actions { width: 13%; }

.inventory-items-table-groups .col-level { width: 12%; }
.inventory-items-table-groups .col-object-type { width: 12%; }
.inventory-items-table-groups .col-source-groups { width: auto; }
.inventory-items-table-groups .col-last-checked-groups { width: 13%; }
.inventory-items-table-groups .col-check-narrow { width: 6%; }
.inventory-items-table-groups .col-actions-groups { width: 10%; }

.inventory-items-table th,
.inventory-items-table td {
  vertical-align: middle;
}

th, td {
  border-bottom: 1px solid var(--line);
  padding: 4px 6px;
  vertical-align: top;
  text-align: left;
}

.inventory-items-table thead th {
  padding-top: 2px;
  padding-bottom: 4px;
}

.inventory-items-table tbody td {
  padding-top: 2px;
  padding-bottom: 2px;
}

th {
  color: var(--muted);
  font-weight: 700;
  text-transform: none;
}

.center {
  text-align: center;
}

tbody tr:last-child td { border-bottom: none; }

tr.click-row { cursor: pointer; }
tr.click-row:hover { background: color-mix(in srgb, var(--soft-accent) 22%, transparent); }

.item-summary-table tbody tr:hover,
.files-table tbody tr:hover {
  background: color-mix(in srgb, var(--soft-accent) 14%, transparent);
}

.status-dot {
  font-size: 14px;
  line-height: 1;
}

.status-success { color: var(--success); }
.status-failed { color: var(--failed); }
.status-warning { color: var(--warning); }
.status-neutral { color: var(--muted); }
.muted { color: var(--muted); }
.mono { font-family: var(--mono); }

.json-dump {
  margin: 0;
  overflow-x: auto;
  font-family: var(--mono);
  font-size: 12px;
  white-space: pre-wrap;
}

.json-dump-inline {
  display: inline;
  white-space: pre;
}

.inventory-items-table td.mono {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.inventory-items-table-groups th:nth-child(1),
.inventory-items-table-groups td:nth-child(1),
.inventory-items-table-groups th:nth-child(2),
.inventory-items-table-groups td:nth-child(2) {
  white-space: nowrap;
}

.inventory-items-table-groups th:nth-child(5),
.inventory-items-table-groups th:nth-child(6),
.inventory-items-table-groups th:nth-child(7),
.inventory-items-table-groups td:nth-child(5),
.inventory-items-table-groups td:nth-child(6),
.inventory-items-table-groups td:nth-child(7) {
  text-align: center;
}

.issue-list {
  display: grid;
  gap: 10px;
}

.issue-box {
  border: 1px solid var(--line);
  border-left: 4px solid var(--warning);
  padding: 10px;
  background: color-mix(in srgb, var(--soft-warning) 20%, var(--panel));
}

.issue-box-warning {
  border-left-color: var(--warning);
}

.issue-box-critical {
  border-left-color: var(--failed);
  background: color-mix(in srgb, var(--failed) 7%, var(--panel));
}

.issue-box-info {
  border-left-color: var(--accent);
  background: color-mix(in srgb, var(--soft-accent) 14%, var(--panel));
}

.issue-title {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  margin-bottom: 10px;
}

.severity-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 3px 8px;
  border: 1px solid currentColor;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.severity-warning {
  color: var(--warning);
  background: color-mix(in srgb, var(--soft-warning) 60%, transparent);
}

.severity-critical {
  color: var(--failed);
  background: color-mix(in srgb, var(--failed) 12%, transparent);
}

.severity-info {
  color: var(--accent);
  background: color-mix(in srgb, var(--soft-accent) 30%, transparent);
}

ul.compact-list {
  margin: 6px 0 0 18px;
  padding: 0;
}

pre {
  background: color-mix(in srgb, var(--bg) 85%, #0000);
  border: 1px solid var(--line);
  padding: 8px;
  overflow: auto;
  max-height: 240px;
  font-family: var(--mono);
  font-size: 12px;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.reader-arguments {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 4px 6px;
}

.item-homepage .reader-arguments-json {
  display: inline;
  margin: 0;
  padding: 1px 4px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  border-radius: 4px;
  background: color-mix(in srgb, var(--bg) 55%, transparent);
  overflow: visible;
  max-height: none;
  font-size: 12px;
  line-height: 1.25;
  white-space: pre;
  overflow-wrap: normal;
}

.reader-arguments-hint {
  color: var(--muted);
  font-size: 13px;
}

.reader-arguments-hint::before {
  content: "— ";
}

.reader-arguments-file-type::before {
  content: "";
}

.file-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.file-list li {
  padding: 6px 0;
  border-bottom: 1px solid var(--line);
  font-size: 13px;
}

.file-list li:last-child {
  border-bottom: none;
}

@media (max-width: 900px) {
  .file-detail-grid {
    grid-template-columns: 1fr;
  }

  .file-detail-cell-full {
    grid-column: auto;
  }
}
