.ax-table-wrap {
width: 100%;
overflow-x: auto;
border: 1px solid var(--ax-border);
border-radius: var(--ax-radius-lg);
background: var(--ax-surface);
}
.ax-table {
width: 100%;
border-collapse: collapse;
color: var(--ax-text);
font-size: 0.9rem;
}
.ax-table th,
.ax-table td {
padding: 0.8rem 0.9rem;
border-bottom: 1px solid var(--ax-border-subtle);
text-align: left;
vertical-align: middle;
}
.ax-table [data-align='center'] {
text-align: center;
}
.ax-table [data-align='right'] {
text-align: right;
}
.ax-table-wrap[data-density='sm'] .ax-table th,
.ax-table-wrap[data-density='sm'] .ax-table td {
padding: 0.58rem 0.72rem;
font-size: 0.82rem;
}
.ax-table-wrap[data-density='lg'] .ax-table th,
.ax-table-wrap[data-density='lg'] .ax-table td {
padding: 1rem 1.05rem;
}
.ax-table th {
color: var(--ax-text-muted);
font-size: 0.74rem;
font-weight: 800;
letter-spacing: 0.12em;
text-transform: uppercase;
background: color-mix(in srgb, var(--ax-surface-2) 78%, transparent);
}
.ax-table__caption {
padding: 0.82rem 0.9rem;
border-bottom: 1px solid var(--ax-border-subtle);
color: var(--ax-text-muted);
font-size: 0.82rem;
font-weight: 750;
text-align: left;
}
.ax-table tr:last-child td {
border-bottom: 0;
}
.ax-table-wrap[data-zebra='true'] .ax-table tbody tr:nth-child(even) {
background: color-mix(in srgb, var(--ax-surface-2) 54%, transparent);
}
.ax-table tbody tr:hover {
background: color-mix(in srgb, var(--ax-primary) 8%, transparent);
}
.ax-empty-state {
display: grid;
justify-items: center;
gap: var(--ax-space-sm);
padding: clamp(2rem, 6vw, 4rem);
border: 1px dashed var(--ax-border-strong);
border-radius: var(--ax-radius-xl);
background:
radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--ax-primary) 12%, transparent), transparent 44%),
var(--ax-surface);
color: var(--ax-text-soft);
text-align: center;
}
.ax-empty-state__icon {
display: grid;
place-items: center;
width: 3rem;
height: 3rem;
border: 1px solid var(--ax-border);
border-radius: var(--ax-radius-lg);
background: var(--ax-surface-2);
color: var(--ax-primary);
}
.ax-empty-state__title {
color: var(--ax-text);
font-weight: 850;
font-size: 1.15rem;
letter-spacing: -0.03em;
}
.ax-empty-state__description {
max-width: 36rem;
margin: 0;
line-height: 1.7;
}
.ax-empty-state__actions {
display: flex;
align-items: center;
justify-content: center;
flex-wrap: wrap;
gap: var(--ax-space-sm);
margin-top: var(--ax-space-sm);
}
.ax-skeleton {
display: block;
width: var(--ax-skeleton-width, 100%);
height: var(--ax-skeleton-height, 1rem);
border-radius: var(--ax-skeleton-radius, var(--ax-radius-md));
background:
linear-gradient(
90deg,
var(--ax-surface-2),
color-mix(in srgb, var(--ax-primary) 12%, var(--ax-surface-2)),
var(--ax-surface-2)
);
background-size: 220% 100%;
animation: ax-skeleton-pulse 1.4s ease-in-out infinite;
}
.ax-skeleton[data-shape='circle'] {
--ax-skeleton-width: 2.5rem;
--ax-skeleton-height: 2.5rem;
--ax-skeleton-radius: 999px;
}
.ax-skeleton[data-shape='card'] {
--ax-skeleton-height: 8rem;
--ax-skeleton-radius: var(--ax-radius-lg);
}
.ax-progress {
display: grid;
gap: 0.45rem;
}
.ax-progress__meta {
display: flex;
justify-content: space-between;
gap: var(--ax-space-md);
color: var(--ax-text-muted);
font-size: 0.78rem;
font-weight: 750;
}
.ax-progress__native {
width: 100%;
height: 0.72rem;
overflow: hidden;
border: 1px solid var(--ax-border);
border-radius: 999px;
background: var(--ax-surface-2);
color: var(--ax-primary);
appearance: none;
}
.ax-progress__native::-webkit-progress-bar {
background: var(--ax-surface-2);
}
.ax-progress__native::-webkit-progress-value {
border-radius: inherit;
background:
linear-gradient(90deg, var(--ax-primary), color-mix(in srgb, var(--ax-primary) 76%, white));
box-shadow: 0 0 24px color-mix(in srgb, var(--ax-primary) 28%, transparent);
}
.ax-progress__native::-moz-progress-bar {
border-radius: inherit;
background:
linear-gradient(90deg, var(--ax-primary), color-mix(in srgb, var(--ax-primary) 76%, white));
box-shadow: 0 0 24px color-mix(in srgb, var(--ax-primary) 28%, transparent);
}
@keyframes ax-skeleton-pulse {
0% {
background-position: 180% 0;
}
100% {
background-position: -40% 0;
}
}