/* DevTrack — a thin layer over Bootstrap. One accent, quiet everywhere else. */
:root {
    --dt-accent: #2f5bea;
    --dt-ink: #1b2431;
    --dt-muted: #6b7684;
    --dt-line: #e6e9ef;
}

body {
    background: #f6f7f9;
    color: var(--dt-ink);
}

.navbar-brand {
    font-weight: 700;
    letter-spacing: -0.02em;
}

.brand-dot {
    display: inline-block;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--dt-accent);
    margin-right: 6px;
    vertical-align: middle;
}

.card {
    border: 1px solid var(--dt-line);
    border-radius: 12px;
}

.stat-card .stat-value {
    font-size: 1.9rem;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
}

.stat-card .stat-label {
    color: var(--dt-muted);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.table > :not(caption) > * > * {
    padding: 0.7rem 0.75rem;
}

.table thead th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--dt-muted);
    border-bottom: 2px solid var(--dt-line);
}

.badge-status {
    font-weight: 600;
    letter-spacing: 0.01em;
}

.timeline {
    list-style: none;
    margin: 0;
    padding-left: 1rem;
    border-left: 2px solid var(--dt-line);
}

.timeline li {
    position: relative;
    padding: 0 0 1rem 1rem;
}

.timeline li::before {
    content: "";
    position: absolute;
    left: -1.42rem;
    top: 0.35rem;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid var(--dt-accent);
}

.empty-state {
    text-align: center;
    color: var(--dt-muted);
    padding: 3rem 1rem;
}

/* Always-visible keyboard focus. */
a:focus-visible,
button:focus-visible,
.form-control:focus-visible {
    outline: 3px solid rgba(47, 91, 234, 0.35);
    outline-offset: 1px;
}

.reason-note {
    font-size: 0.85rem;
    color: var(--dt-muted);
}

.priority-tag {
    font-variant-numeric: tabular-nums;
    color: var(--dt-muted);
    font-weight: 600;
}
