/*
 * StackWyrm — Industrial dark theme overrides
 *
 * Bootstrap 5.3 dark mode is the base. These overrides add:
 * - Monospace fonts for data/code
 * - Muted, utilitarian color palette
 * - Clear borders and compact spacing
 * - Status indicator colors
 */

/* ── Root variables ────────────────────────────────────────────── */
:root[data-bs-theme="dark"] {
    --sw-bg-primary: #1a1d21;
    --sw-bg-surface: #22262b;
    --sw-border: #343a40;
    --sw-text-muted: #8b949e;
    --sw-accent: #58a6ff;
    --sw-success: #3fb950;
    --sw-warning: #d29922;
    --sw-danger: #f85149;
    --sw-font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", "Consolas", monospace;
}

/* ── Global ────────────────────────────────────────────────────── */
body {
    background-color: var(--sw-bg-primary);
    font-size: 0.9rem;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

main {
    flex: 1;
}

/* ── Navbar ────────────────────────────────────────────────────── */
.sw-navbar {
    background-color: var(--sw-bg-surface);
    border-color: var(--sw-border) !important;
}

.sw-brand {
    font-family: var(--sw-font-mono);
    letter-spacing: 0.05em;
    color: var(--sw-accent);
}

/* ── Cards ─────────────────────────────────────────────────────── */
.card {
    background-color: var(--sw-bg-surface);
    border-color: var(--sw-border);
}

.card-header {
    background-color: rgba(0, 0, 0, 0.2);
    border-color: var(--sw-border);
    font-family: var(--sw-font-mono);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ── Tables ────────────────────────────────────────────────────── */
.table {
    --bs-table-bg: transparent;
    font-size: 0.875rem;
}

.table th {
    font-family: var(--sw-font-mono);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--sw-text-muted);
    border-color: var(--sw-border);
}

.table td {
    border-color: var(--sw-border);
    vertical-align: middle;
}

/* ── Data display (monospace) ──────────────────────────────────── */
.sw-mono,
.sw-data,
code,
pre,
.sw-log-output {
    font-family: var(--sw-font-mono);
    font-size: 0.85rem;
}

.sw-log-output {
    background-color: #0d1117;
    border: 1px solid var(--sw-border);
    border-radius: 4px;
    padding: 0.75rem;
    max-height: 500px;
    overflow-y: auto;
    white-space: pre-wrap;
    word-break: break-all;
    color: #c9d1d9;
}

/* ── Status badges ─────────────────────────────────────────────── */
.badge-running {
    background-color: var(--sw-success) !important;
    color: #000;
}

.badge-stopped {
    background-color: var(--sw-danger) !important;
    color: #fff;
}

.badge-paused {
    background-color: var(--sw-warning) !important;
    color: #000;
}

.badge-unknown {
    background-color: #6c757d !important;
    color: #fff;
}

/* ── Action buttons ────────────────────────────────────────────── */
.btn-action {
    font-family: var(--sw-font-mono);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 0.25rem 0.75rem;
}

/* ── HTMX loading indicators ──────────────────────────────────── */
.htmx-indicator {
    display: none;
}

.htmx-request .htmx-indicator {
    display: inline-block;
}

.htmx-request.htmx-indicator {
    display: inline-block;
}

/* Spinner for loading states */
.sw-spinner {
    width: 1rem;
    height: 1rem;
    border: 2px solid var(--sw-text-muted);
    border-right-color: transparent;
    border-radius: 50%;
    animation: sw-spin 0.6s linear infinite;
    display: inline-block;
}

@keyframes sw-spin {
    to { transform: rotate(360deg); }
}

/* ── Forms ─────────────────────────────────────────────────────── */
.form-control,
.form-select {
    background-color: var(--sw-bg-primary);
    border-color: var(--sw-border);
    font-size: 0.875rem;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--sw-accent);
    box-shadow: 0 0 0 0.2rem rgba(88, 166, 255, 0.15);
}

/* ── Alerts ────────────────────────────────────────────────────── */
.alert {
    font-size: 0.875rem;
    border-radius: 4px;
}

/* ── Config / YAML preview (ingress, diagnostics) ─────────────── */
.sw-configblock {
    background-color: #0d1117;
    border: 1px solid var(--sw-border);
    border-radius: 4px;
    padding: 1rem;
    font-family: var(--sw-font-mono);
    font-size: 0.8rem;
    white-space: pre-wrap;
    color: #c9d1d9;
    max-height: 600px;
    overflow-y: auto;
}

/* ── Editable inline values ────────────────────────────────────── */
.sw-editable {
    border: 1px dashed var(--sw-border);
    border-radius: 4px;
    padding: 1px 6px;
    cursor: pointer;
    transition: border-color 0.15s, background-color 0.15s;
    display: inline-block;
}

.sw-editable:hover {
    border-color: var(--sw-accent);
    border-style: solid;
    background-color: rgba(88, 166, 255, 0.06);
}

/* ── Compact utility ───────────────────────────────────────────── */
.sw-compact .card-body {
    padding: 0.75rem;
}

/* ── Breadcrumb ────────────────────────────────────────────────── */
.breadcrumb {
    font-size: 0.85rem;
    background: none;
    padding: 0;
    margin-bottom: 0.5rem;
}

.breadcrumb-item a {
    color: var(--sw-accent);
    text-decoration: none;
}

.breadcrumb-item.active {
    color: var(--sw-text-muted);
}

/* ── Operator UI primitives (web parity) ───────────────────────── */
.sw-stat-card {
    border-color: var(--sw-border);
}

.sw-stat-card .sw-stat-label {
    font-family: var(--sw-font-mono);
    font-size: 0.7rem;
    letter-spacing: 0.06em;
}

.sw-stat-card .sw-stat-value {
    word-break: break-word;
}

.sw-empty-state {
    border: 1px dashed var(--sw-border);
    border-radius: 6px;
    background: rgba(0, 0, 0, 0.15);
}

.sw-section-card .card-header {
    font-size: 0.8rem;
}

.sw-table-wrapper > table {
    margin-bottom: 0;
}
