:root {
--squid-sonar-bg: #f8fafb;
--squid-sonar-surface: #ffffff;
--squid-sonar-surface-muted: #f2f5f7;
--squid-sonar-surface-raised: #fbfcfd;
--squid-sonar-border: #d9e1e8;
--squid-sonar-border-strong: #aeb9c6;
--squid-sonar-text: #111827;
--squid-sonar-muted: #5f6b7a;
--squid-sonar-accent: #8061d8;
--squid-sonar-accent-muted: #f3efff;
--squid-sonar-badge-bg: #ffffff;
--squid-sonar-alert-bg: #fff7ed;
--squid-sonar-alert-border: #fed7aa;
--squid-sonar-danger: #9a5650;
--squid-sonar-warning: #896d3e;
--squid-sonar-success: #4d7862;
--squid-sonar-waiting: #76679c;
--squid-sonar-running: #8061d8;
}
html.squid-sonar-document,
body.squid-sonar-document {
background: #f8fafb;
margin: 0;
min-height: 100%;
}
body.squid-sonar-document:has(.squid-sonar-theme-dark) {
background: #191c22;
}
@media (prefers-color-scheme: dark) {
body.squid-sonar-document:has(.squid-sonar-theme-system) {
background: #191c22;
}
}
.squid-sonar-shell *,
.squid-sonar-shell *::before,
.squid-sonar-shell *::after {
box-sizing: border-box;
}
.squid-sonar-shell {
background: var(--squid-sonar-bg);
box-sizing: border-box;
color: var(--squid-sonar-text);
font-family:
-apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif;
min-height: 100dvh;
padding: 0;
}
.squid-sonar-shell.squid-sonar-theme-dark {
--squid-sonar-bg: #191c22;
--squid-sonar-surface: #21252b;
--squid-sonar-surface-muted: #282c34;
--squid-sonar-surface-raised: #252a31;
--squid-sonar-border: #363c46;
--squid-sonar-border-strong: #505868;
--squid-sonar-text: #f1f3f5;
--squid-sonar-muted: #9aa3af;
--squid-sonar-accent: #8061d8;
--squid-sonar-accent-muted: #332b4a;
--squid-sonar-badge-bg: #21252b;
--squid-sonar-alert-bg: #312826;
--squid-sonar-alert-border: #57423e;
--squid-sonar-danger: #c3847e;
--squid-sonar-warning: #b69a69;
--squid-sonar-success: #7da894;
--squid-sonar-waiting: #9a91b8;
--squid-sonar-running: #8061d8;
}
@media (prefers-color-scheme: dark) {
.squid-sonar-shell.squid-sonar-theme-system {
--squid-sonar-bg: #191c22;
--squid-sonar-surface: #21252b;
--squid-sonar-surface-muted: #282c34;
--squid-sonar-surface-raised: #252a31;
--squid-sonar-border: #363c46;
--squid-sonar-border-strong: #505868;
--squid-sonar-text: #f1f3f5;
--squid-sonar-muted: #9aa3af;
--squid-sonar-accent: #8061d8;
--squid-sonar-accent-muted: #332b4a;
--squid-sonar-badge-bg: #21252b;
--squid-sonar-alert-bg: #312826;
--squid-sonar-alert-border: #57423e;
--squid-sonar-danger: #c3847e;
--squid-sonar-warning: #b69a69;
--squid-sonar-success: #7da894;
--squid-sonar-waiting: #9a91b8;
--squid-sonar-running: #8061d8;
}
}
.squid-sonar-topbar {
align-items: center;
background: var(--squid-sonar-surface);
border-bottom: 1px solid var(--squid-sonar-border);
display: flex;
gap: 16px;
justify-content: space-between;
min-height: 58px;
padding: 0 max(24px, calc((100vw - 1400px) / 2 + 24px));
position: sticky;
top: 0;
z-index: 10;
}
.squid-sonar-brand,
.squid-sonar-topbar-actions {
align-items: center;
display: flex;
}
.squid-sonar-brand {
gap: 10px;
min-width: 0;
}
.squid-sonar-brand-link {
color: inherit;
text-decoration: none;
}
.squid-sonar-brand-link h1 {
transition: color 120ms ease;
}
.squid-sonar-brand-link:hover h1 {
color: var(--squid-sonar-accent);
}
.squid-sonar-topbar-actions {
gap: 10px;
}
.squid-sonar-theme-switcher {
background: var(--squid-sonar-surface-muted);
border: 1px solid var(--squid-sonar-border);
border-radius: 7px;
display: inline-flex;
gap: 2px;
padding: 2px;
}
.squid-sonar-topbar h1 {
font-size: 17px;
font-weight: 650;
line-height: 1.2;
margin: 0;
}
.squid-sonar-eyebrow {
color: var(--squid-sonar-muted);
font-size: 11px;
font-weight: 800;
letter-spacing: 0;
margin: 0 0 2px;
text-transform: uppercase;
}
.squid-sonar-icon-button {
align-items: center;
background: var(--squid-sonar-surface-muted);
border: 1px solid var(--squid-sonar-border);
border-radius: 7px;
color: var(--squid-sonar-text);
cursor: pointer;
display: inline-flex;
height: 34px;
justify-content: center;
padding: 0;
transition:
background-color 120ms ease,
border-color 120ms ease,
color 120ms ease;
width: 34px;
}
.squid-sonar-icon-button:focus-visible,
.squid-sonar-nav-item:focus-within,
.squid-sonar-run-link:focus-visible,
.squid-sonar-pagination button:focus-visible,
.squid-sonar-page-size select:focus-visible {
outline: 2px solid var(--squid-sonar-accent);
outline-offset: 2px;
}
.squid-sonar-icon-button svg {
height: 17px;
width: 17px;
}
.squid-sonar-icon-button:hover {
background: var(--squid-sonar-accent-muted);
border-color: var(--squid-sonar-accent);
color: var(--squid-sonar-accent);
}
.squid-sonar-icon-button.is-active {
background: var(--squid-sonar-surface);
border-color: var(--squid-sonar-border-strong);
color: var(--squid-sonar-accent);
}
.squid-sonar-theme-switcher .squid-sonar-icon-button {
background: transparent;
border-color: transparent;
height: 30px;
width: 30px;
}
.squid-sonar-theme-switcher .squid-sonar-icon-button:hover,
.squid-sonar-theme-switcher .squid-sonar-icon-button.is-active {
background: var(--squid-sonar-surface);
border-color: var(--squid-sonar-border);
}
.squid-sonar-refresh {
background: var(--squid-sonar-surface);
border-color: var(--squid-sonar-accent);
color: var(--squid-sonar-accent);
}
.squid-sonar-refresh:hover {
background: var(--squid-sonar-accent-muted);
border-color: var(--squid-sonar-accent);
color: var(--squid-sonar-accent);
}
.squid-sonar-refresh.phx-click-loading {
cursor: progress;
}
.squid-sonar-refresh.phx-click-loading svg {
animation: squid-sonar-spin 700ms linear infinite;
}
@keyframes squid-sonar-spin {
to {
transform: rotate(360deg);
}
}
.squid-sonar-content {
margin: 0 auto;
max-width: 1400px;
padding: 20px 24px 38px;
}
.squid-sonar-run-title {
align-items: center;
display: flex;
}
.squid-sonar-search span,
.squid-sonar-page-size span {
color: var(--squid-sonar-muted);
display: block;
font-size: 11px;
font-weight: 800;
margin-bottom: 6px;
text-transform: uppercase;
}
.squid-sonar-search {
display: block;
flex: 0 1 520px;
min-width: 360px;
}
.squid-sonar-page-size select,
.squid-sonar-search input {
background: var(--squid-sonar-surface-muted);
border: 1px solid var(--squid-sonar-border);
border-radius: 7px;
box-sizing: border-box;
color: var(--squid-sonar-text);
font: inherit;
font-size: 13px;
height: 34px;
padding: 0 10px;
}
.squid-sonar-page-size select {
min-width: 76px;
}
.squid-sonar-search input {
width: 100%;
}
.squid-sonar-search input:focus {
border-color: var(--squid-sonar-accent);
outline: 2px solid var(--squid-sonar-accent-muted);
}
.squid-sonar-workspace {
display: grid;
gap: 18px;
grid-template-columns: 196px minmax(0, 1fr);
margin-top: 0;
padding-bottom: 20px;
}
.squid-sonar-sidebar {
align-self: start;
background: var(--squid-sonar-surface);
border: 1px solid var(--squid-sonar-border);
border-radius: 8px;
padding: 7px;
position: sticky;
top: 78px;
}
.squid-sonar-sidebar-heading {
align-items: center;
display: flex;
min-height: 32px;
padding: 0 10px;
}
.squid-sonar-sidebar-heading h2 {
color: var(--squid-sonar-muted);
font-size: 11px;
font-weight: 800;
margin: 0;
text-transform: uppercase;
}
.squid-sonar-nav-item {
align-items: center;
border: 1px solid transparent;
border-radius: 6px;
color: var(--squid-sonar-muted);
cursor: pointer;
display: flex;
font-size: 13px;
font-weight: 650;
gap: 10px;
justify-content: space-between;
min-height: 36px;
padding: 0 10px;
transition:
background-color 120ms ease,
color 120ms ease;
}
.squid-sonar-nav-item input {
opacity: 0;
pointer-events: none;
position: absolute;
}
.squid-sonar-nav-label span {
text-transform: capitalize;
}
.squid-sonar-nav-item strong {
align-items: center;
background: var(--squid-sonar-surface-muted);
border: 1px solid var(--squid-sonar-border);
border-radius: 999px;
color: inherit;
display: inline-flex;
font-size: 12px;
font-weight: 750;
height: 22px;
justify-content: center;
min-width: 30px;
padding: 0 8px;
}
.squid-sonar-nav-item:hover {
background: var(--squid-sonar-surface-muted);
color: var(--squid-sonar-text);
}
.squid-sonar-nav-item.is-active {
background: var(--squid-sonar-accent-muted);
border-color: transparent;
color: var(--squid-sonar-accent);
}
.squid-sonar-nav-item.is-active strong {
background: var(--squid-sonar-surface);
border-color: var(--squid-sonar-accent);
}
.squid-sonar-panel {
background: var(--squid-sonar-surface);
border: 1px solid var(--squid-sonar-border);
border-radius: 8px;
min-width: 0;
overflow: hidden;
}
.squid-sonar-panel-heading {
align-items: center;
background: var(--squid-sonar-surface);
border-bottom: 1px solid var(--squid-sonar-border);
display: flex;
gap: 14px;
justify-content: space-between;
min-height: 64px;
padding: 13px 14px;
}
.squid-sonar-panel-actions {
flex: 0 1 520px;
}
.squid-sonar-panel-actions .squid-sonar-search {
min-width: 0;
width: 100%;
}
.squid-sonar-panel-tools {
align-items: center;
display: flex;
gap: 8px;
}
.squid-sonar-panel h2,
.squid-sonar-empty h3,
.squid-sonar-alert h2 {
font-size: 14px;
line-height: 1.4;
margin: 0;
}
.squid-sonar-panel p,
.squid-sonar-alert p {
color: var(--squid-sonar-muted);
font-size: 12px;
line-height: 1.5;
margin: 1px 0 0;
}
.squid-sonar-table-wrap {
overflow-x: auto;
}
.squid-sonar-table {
border-collapse: collapse;
min-width: 820px;
width: 100%;
}
.squid-sonar-table th,
.squid-sonar-table td {
border-bottom: 1px solid var(--squid-sonar-border);
font-size: 13px;
padding: 13px 14px;
text-align: left;
vertical-align: middle;
}
.squid-sonar-table th {
background: var(--squid-sonar-surface-muted);
color: var(--squid-sonar-muted);
font-size: 11px;
font-weight: 750;
text-transform: uppercase;
}
.squid-sonar-table tbody tr {
transition: background-color 120ms ease;
}
.squid-sonar-table tbody tr:hover {
background: var(--squid-sonar-surface-raised);
}
.squid-sonar-table tbody tr:last-child td {
border-bottom: 0;
}
.squid-sonar-primary,
.squid-sonar-secondary {
display: block;
max-width: 380px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.squid-sonar-primary {
font-weight: 620;
}
.squid-sonar-secondary {
color: var(--squid-sonar-muted);
font-size: 12px;
margin-top: 3px;
}
.squid-sonar-run-link {
color: inherit;
min-width: 0;
text-decoration: none;
}
.squid-sonar-run-link:hover .squid-sonar-primary {
color: var(--squid-sonar-accent);
}
.squid-sonar-run-title {
min-width: 0;
}
.squid-sonar-empty,
.squid-sonar-alert {
padding: 24px;
}
.squid-sonar-alert {
background: var(--squid-sonar-alert-bg);
border: 1px solid var(--squid-sonar-alert-border);
border-radius: 8px;
margin: 20px;
}
.squid-sonar-badge {
background: transparent;
border: 1px solid var(--squid-sonar-border);
border-radius: 999px;
color: var(--squid-sonar-muted);
display: inline-flex;
font-size: 11px;
font-weight: 750;
line-height: 1;
padding: 5px 9px;
text-transform: uppercase;
}
.squid-sonar-badge-completed {
border-color: var(--squid-sonar-success);
color: var(--squid-sonar-success);
}
.squid-sonar-badge-failed {
border-color: var(--squid-sonar-danger);
color: var(--squid-sonar-danger);
}
.squid-sonar-badge-retrying {
border-color: var(--squid-sonar-warning);
color: var(--squid-sonar-warning);
}
.squid-sonar-badge-paused {
border-color: var(--squid-sonar-waiting);
color: var(--squid-sonar-waiting);
}
.squid-sonar-badge-running {
border-color: var(--squid-sonar-accent);
color: var(--squid-sonar-accent);
}
.squid-sonar-pagination {
align-items: center;
border-top: 1px solid var(--squid-sonar-border);
color: var(--squid-sonar-muted);
display: flex;
font-size: 12px;
font-weight: 700;
justify-content: space-between;
padding: 14px;
}
.squid-sonar-pagination-summary {
align-items: center;
display: flex;
flex-wrap: wrap;
gap: 8px;
}
.squid-sonar-pagination-summary strong {
color: var(--squid-sonar-text);
font-size: 12px;
}
.squid-sonar-pagination-summary span {
font-size: 12px;
}
.squid-sonar-pagination-controls {
align-items: center;
display: flex;
gap: 8px;
}
.squid-sonar-pagination .squid-sonar-page-size {
align-items: center;
display: inline-flex;
gap: 8px;
}
.squid-sonar-pagination .squid-sonar-page-size span {
margin-bottom: 0;
}
.squid-sonar-pagination button {
background: var(--squid-sonar-surface);
border: 1px solid var(--squid-sonar-border);
border-radius: 7px;
color: var(--squid-sonar-text);
cursor: pointer;
font: inherit;
font-weight: 800;
padding: 7px 10px;
}
.squid-sonar-pagination button:not(:disabled):hover {
background: var(--squid-sonar-surface-muted);
border-color: var(--squid-sonar-border-strong);
}
.squid-sonar-pagination button:disabled {
color: var(--squid-sonar-muted);
cursor: not-allowed;
opacity: 0.5;
}
.squid-sonar-detail {
padding-top: 16px;
}
.squid-sonar-detail-header,
.squid-sonar-detail-panel,
.squid-sonar-detail-item {
background: var(--squid-sonar-surface);
border: 1px solid var(--squid-sonar-border);
border-radius: 9px;
}
.squid-sonar-detail-header {
align-items: flex-start;
display: flex;
justify-content: space-between;
padding: 18px 20px;
}
.squid-sonar-back-link {
color: var(--squid-sonar-accent);
display: inline-flex;
font-size: 12px;
font-weight: 800;
margin-bottom: 8px;
text-decoration: none;
}
.squid-sonar-detail-header h2 {
font-size: 20px;
font-weight: 650;
margin: 0;
}
.squid-sonar-detail-header p,
.squid-sonar-muted-line {
color: var(--squid-sonar-muted);
font-size: 12px;
margin: 4px 0 0;
}
.squid-sonar-detail-grid {
display: grid;
gap: 12px;
grid-template-columns: repeat(4, minmax(0, 1fr));
margin-top: 12px;
}
.squid-sonar-detail-item {
padding: 13px 14px;
}
.squid-sonar-detail-item span {
color: var(--squid-sonar-muted);
display: block;
font-size: 11px;
font-weight: 800;
margin-bottom: 6px;
text-transform: uppercase;
}
.squid-sonar-detail-item strong,
.squid-sonar-detail-item code {
display: block;
font-size: 13px;
overflow-wrap: anywhere;
}
.squid-sonar-detail-item code {
font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
font-weight: 500;
line-height: 1.45;
}
.squid-sonar-detail-columns {
align-items: stretch;
display: grid;
gap: 14px;
grid-template-columns: minmax(0, 2fr) minmax(260px, 1fr);
margin-top: 12px;
}
.squid-sonar-detail-columns > .squid-sonar-detail-panel {
align-self: stretch;
height: 100%;
min-width: 0;
}
.squid-sonar-detail-columns > .squid-sonar-detail-panel + .squid-sonar-detail-panel {
margin-top: 0;
}
.squid-sonar-detail-panel {
padding: 16px;
}
.squid-sonar-detail-columns + .squid-sonar-detail-panel {
margin-top: 14px;
}
.squid-sonar-detail-panel + .squid-sonar-detail-panel {
margin-top: 14px;
}
.squid-sonar-detail-panel h3 {
font-size: 14px;
font-weight: 650;
margin: 0 0 12px;
}
.squid-sonar-detail-panel > .squid-sonar-muted-line {
margin-top: 8px;
}
.squid-sonar-detail-panel .squid-sonar-detail-item + .squid-sonar-detail-item {
margin-top: 8px;
}
.squid-sonar-workflow-graph {
background: var(--squid-sonar-bg);
border: 1px solid var(--squid-sonar-border);
border-radius: 8px;
margin-top: 12px;
min-height: 190px;
overflow: auto;
padding: 18px 20px 22px;
}
.squid-sonar-workflow-graph-heading {
align-items: flex-start;
color: var(--squid-sonar-text);
display: flex;
justify-content: space-between;
margin-bottom: 22px;
min-width: max-content;
}
.squid-sonar-workflow-graph-heading strong,
.squid-sonar-workflow-graph-heading span {
display: block;
}
.squid-sonar-workflow-graph-heading strong {
font-size: 14px;
line-height: 1.3;
}
.squid-sonar-workflow-graph-heading span {
color: var(--squid-sonar-muted);
font-size: 12px;
font-weight: 700;
margin-top: 4px;
}
.squid-sonar-workflow-stage {
min-width: max-content;
position: relative;
}
.squid-sonar-workflow-edge-segment {
background: var(--squid-sonar-border);
position: absolute;
z-index: 1;
}
.squid-sonar-workflow-edge-segment-horizontal {
border-radius: 999px;
}
.squid-sonar-workflow-edge-segment-vertical {
border-radius: 999px;
}
.squid-sonar-workflow-port {
background: var(--squid-sonar-muted);
border: 2px solid var(--squid-sonar-bg);
border-radius: 999px;
height: 12px;
margin-left: -6px;
margin-top: -6px;
position: absolute;
width: 12px;
z-index: 3;
}
.squid-sonar-workflow-node {
align-items: center;
background: var(--squid-sonar-surface);
border: 1px solid var(--squid-sonar-border);
border-radius: 8px;
box-sizing: border-box;
display: flex;
gap: 10px;
justify-content: space-between;
min-width: 0;
padding: 0 12px;
position: absolute;
transition:
border-color 160ms ease,
background-color 160ms ease;
z-index: 2;
}
.squid-sonar-workflow-node:hover {
background: var(--squid-sonar-surface-muted);
border-color: var(--squid-sonar-border-strong);
}
.squid-sonar-workflow-node-current {
background: var(--squid-sonar-accent-muted);
border-color: var(--squid-sonar-accent);
}
.squid-sonar-workflow-node-main {
align-items: center;
display: flex;
gap: 8px;
min-width: 0;
}
.squid-sonar-workflow-node-terminal {
background: var(--squid-sonar-surface);
}
.squid-sonar-workflow-node-waiting,
.squid-sonar-workflow-node-pending {
background: var(--squid-sonar-surface);
}
.squid-sonar-workflow-node strong {
display: block;
font-size: 12px;
line-height: 1.25;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.squid-sonar-workflow-status-icon {
border: 2px solid var(--squid-sonar-muted);
border-radius: 999px;
flex: 0 0 auto;
height: 14px;
position: relative;
width: 14px;
}
.squid-sonar-workflow-status-icon-completed {
background: #1f7a3b;
border-color: #1f7a3b;
}
.squid-sonar-workflow-status-icon-completed::after {
border-bottom: 2px solid #ffffff;
border-right: 2px solid #ffffff;
content: "";
height: 6px;
left: 3px;
position: absolute;
top: 2px;
transform: rotate(45deg);
width: 3px;
}
.squid-sonar-workflow-status-icon-failed,
.squid-sonar-workflow-status-icon-cancelled {
background: var(--squid-sonar-danger);
border-color: var(--squid-sonar-danger);
}
.squid-sonar-workflow-status-icon-failed::before,
.squid-sonar-workflow-status-icon-failed::after,
.squid-sonar-workflow-status-icon-cancelled::before,
.squid-sonar-workflow-status-icon-cancelled::after {
background: #ffffff;
content: "";
height: 2px;
left: 2.5px;
position: absolute;
top: 4px;
width: 6px;
}
.squid-sonar-workflow-status-icon-failed::before,
.squid-sonar-workflow-status-icon-cancelled::before {
transform: rotate(45deg);
}
.squid-sonar-workflow-status-icon-failed::after,
.squid-sonar-workflow-status-icon-cancelled::after {
transform: rotate(-45deg);
}
.squid-sonar-workflow-status-icon-running,
.squid-sonar-workflow-status-icon-retrying {
border-color: var(--squid-sonar-warning);
}
.squid-sonar-workflow-status-icon-running::after,
.squid-sonar-workflow-status-icon-retrying::after {
background: var(--squid-sonar-warning);
border-radius: 999px;
content: "";
height: 6px;
left: 2px;
position: absolute;
top: 2px;
width: 6px;
}
.squid-sonar-workflow-node-status {
color: var(--squid-sonar-muted);
flex: 0 0 auto;
font-size: 11px;
font-weight: 700;
}
@media (max-width: 920px) {
.squid-sonar-workspace {
display: grid;
grid-template-columns: 1fr;
}
.squid-sonar-panel-heading {
align-items: stretch;
display: block;
}
.squid-sonar-search {
display: block;
margin-top: 10px;
min-width: 0;
}
.squid-sonar-sidebar {
align-items: center;
display: flex;
gap: 6px;
overflow-x: auto;
position: static;
}
.squid-sonar-sidebar-heading {
flex: 0 0 auto;
min-height: 34px;
}
.squid-sonar-nav-item {
flex: 0 0 auto;
gap: 16px;
min-width: 118px;
}
.squid-sonar-detail-grid,
.squid-sonar-detail-columns {
grid-template-columns: 1fr;
}
.squid-sonar-detail-columns > .squid-sonar-detail-panel {
height: auto;
}
.squid-sonar-panel {
margin-top: 0;
}
}
@media (max-width: 760px) {
.squid-sonar-topbar {
align-items: stretch;
flex-direction: column;
padding-bottom: 12px;
padding-top: 12px;
}
.squid-sonar-topbar-actions {
justify-content: space-between;
}
.squid-sonar-content {
padding-left: 12px;
padding-right: 12px;
}
.squid-sonar-sidebar-heading {
display: none;
}
}