/* ============================================================
   loops.css — shared styles for SuperLoops and RegularLoops
   All sl-* layout/component classes live here so both pages
   render correctly without depending on each other's <style>.
   ============================================================ */

/* ── Page shell ── */
.sl-page {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 8rem);
    overflow: hidden;
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 var(--space-4);
}

/* ── Header row: title left, controls right ── */
.sl-header-row {
    flex: 0 0 auto;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: var(--space-3) 0 var(--space-2) 0;
    gap: 16px;
}
.sl-title {
    margin: 0 0 2px 0;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1.2;
}
.sl-header-controls {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
.sl-filter-bar {
    flex: 0 0 auto;
    min-height: 52px;
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    align-items: center;
    gap: 8px;
    padding: 6px 0 6px 0;
    scrollbar-width: none;
}
/* MudBlazor form controls default to width:100% — force them to shrink to their min-width in the filter bar */
.sl-filter-bar .mud-input-control {
    flex: 0 0 auto;
    width: auto !important;
}

/* ── Header surface: stat cards + estate bar ── */
.sl-header-surface {
    flex: 0 0 auto;
    background: var(--mud-palette-surface);
    border: 1px solid var(--riq-surface-border);
    border-radius: 8px;
    padding: 10px 14px 8px 14px;
    margin-top: 4px;
}

/* ── Summary bar ── */
.sl-summary-bar {
    display: flex;
    gap: 0;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--riq-surface-border);
}
.sl-stat-card {
    flex: 1;
    padding: 2px 16px;
    text-align: left;
}
.sl-stat-card + .sl-stat-card {
    border-left: 1px solid var(--riq-surface-border);
}
.sl-stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.1;
    color: var(--mud-palette-text-primary);
}
.sl-stat-label {
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--mud-palette-text-secondary);
    margin-top: 2px;
}
.sl-stat-green .sl-stat-value { color: #10b981; }
.sl-stat-amber .sl-stat-value { color: #f59e0b; }
.sl-stat-red   .sl-stat-value { color: #ef4444; }
.sl-stat-muted { opacity: 0.55; border-left-style: dashed !important; }
.sl-stat-value-muted { color: var(--mud-palette-text-secondary) !important; }

/* ── Estate capacity bar ── */
.sl-estate-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    padding-top: 7px;
}
.sl-estate-label {
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--mud-palette-text-secondary);
    white-space: nowrap;
    min-width: 110px;
}
.sl-estate-track {
    flex: 1;
    height: 6px;
    border-radius: 3px;
}
.sl-estate-pct {
    font-family: 'IBM Plex Mono', 'Courier New', monospace;
    font-size: 0.72rem;
    color: var(--mud-palette-text-primary);
    white-space: nowrap;
    text-align: right;
    min-width: 180px;
}

/* ── Tab bar ── */
.sl-tab-bar {
    flex: 0 0 auto;
    display: flex;
    align-items: flex-end;
    gap: 4px;
    padding: 6px 0 0 0;
    border-bottom: 1px solid var(--riq-surface-border);
    margin-bottom: 8px;
}
.sl-tab {
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    padding: 5px 14px;
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--mud-palette-text-secondary);
    cursor: pointer;
    margin-bottom: -1px;
    transition: color 0.15s, border-color 0.15s;
}
.sl-tab:hover { color: var(--mud-palette-text-primary); }
.sl-tab-active {
    color: #0097a7;
    border-bottom-color: #0097a7;
    font-weight: 600;
}
.sl-collapse-btn {
    padding: 0 2px !important;
    opacity: 0.55;
    margin-bottom: -1px;
}

/* ── Body wrapper (no-bounce layout) ── */
.sl-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.sl-body-scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
}

/* ── Status groups ── */
.sl-groups { display: block; }
.sl-loop-list { display: flex; flex-direction: column; }

.sl-group {
    margin-bottom: 6px;
    border: 1px solid var(--riq-surface-border);
    border-radius: 6px;
    overflow: hidden;
}
.sl-group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: var(--mud-palette-surface);
    border: none;
    border-left: 3px solid transparent;
    padding: 7px 12px;
    cursor: pointer;
    text-align: left;
}
.sl-group-header:hover { background: var(--mud-palette-background); }
.sl-group-header-left  { display: flex; align-items: center; gap: 8px; }
.sl-group-header-right { display: flex; align-items: center; gap: 10px; color: var(--mud-palette-text-secondary); font-size: 0.78rem; }
.sl-group-name  { font-size: 0.82rem; font-weight: 600; }
.sl-group-badge { background: var(--mud-palette-background); border: 1px solid var(--riq-surface-border); border-radius: 10px; padding: 1px 7px; font-size: 0.72rem; font-weight: 600; }
.sl-group-agg   { font-size: 0.75rem; }

/* ── Border accent classes (used on group headers) ── */
.border-green  { border-left-color: #10b981 !important; }
.border-amber  { border-left-color: #f59e0b !important; }
.border-red    { border-left-color: #ef4444 !important; }
.border-purple { border-left-color: #8b5cf6 !important; }
.border-gray   { border-left-color: #64748b !important; }

/* ── Shared column styles ── */
.col-id     { }
.col-loc    { }
.col-comp   { }
.col-lic    { text-align: center; font-family: 'IBM Plex Mono','Courier New',monospace; }
.col-ver    { }
.col-deploy { font-size: 0.72rem; }
.col-notes  { display: flex; align-items: center; }
.col-flags  { display: flex; gap: 3px; flex-wrap: wrap; align-items: center; }
.col-cap    { }

/* ── Loop ID ── */
.loop-id {
    font-family: 'IBM Plex Mono', 'Courier New', monospace;
    font-size: 0.8rem;
    font-weight: 600;
    color: #0097a7;
}

/* ── Composition pills ── */
.comp-pills { display: flex; flex-wrap: wrap; gap: 3px; }
.comp-pill {
    font-family: 'IBM Plex Mono','Courier New',monospace;
    font-size: 0.65rem;
    font-weight: 600;
    padding: 1px 5px;
    border-radius: 3px;
    background: var(--mud-palette-background);
    border: 1px solid var(--riq-surface-border);
    white-space: nowrap;
}
.comp-pill-ss      { border-color: #0097a7; color: #0097a7; }
.comp-pill-app     { border-color: #10b981; color: #10b981; }
.comp-pill-ingress { border-color: #f97316; color: #f97316; }
.comp-pill-d       { border-color: #8b5cf6; color: #8b5cf6; }
.comp-pill-r       { border-color: #64748b; color: #64748b; }
.comp-pill-inv     { border-color: #6366f1; color: #6366f1; }
.comp-pill-infra   { border-color: #64748b; color: #64748b; }

/* ── Version pill ── */
.ver-pill {
    font-family: 'IBM Plex Mono','Courier New',monospace;
    font-size: 0.68rem;
    padding: 1px 6px;
    border-radius: 3px;
    font-weight: 600;
}
.ver-current { background: rgba(16,185,129,0.12);  color: #10b981; border: 1px solid rgba(16,185,129,0.3); }
.ver-old     { background: rgba(245,158,11,0.12);  color: #d97706; border: 1px solid rgba(245,158,11,0.3); }
.ver-mixed   { background: rgba(239,68,68,0.12);   color: #ef4444; border: 1px solid rgba(239,68,68,0.3); }

/* ── Capacity bar ── */
.cap-bar-wrap { display: flex; align-items: center; gap: 5px; }
.cap-bar-track {
    flex: 1;
    height: 6px;
    border-radius: 3px;
    background: var(--mud-palette-background);
    border: 1px solid var(--riq-surface-border);
    overflow: hidden;
    min-width: 60px;
}
.cap-bar-fill { height: 100%; border-radius: 3px; transition: width 0.3s; }
.cap-fill-green { background: #10b981; }
.cap-fill-amber { background: #f59e0b; }
.cap-fill-red   { background: #ef4444; }
.cap-pct { font-family: 'IBM Plex Mono','Courier New',monospace; font-size: 0.68rem; white-space: nowrap; min-width: 32px; }

/* ── Flag icons ── */
.flag-icon {
    font-size: 16px !important;
    cursor: default;
}
.flag-healthy  { color: #10b981; }
.flag-critical { color: #ef4444; }
.flag-blocking { color: #8b5cf6; }
.flag-warning  { color: #f59e0b; }
.flag-advisory { color: #0097a7; }
.flag-info     { color: #64748b; }

/* ── Notes cell ── */
.notes-cell {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    cursor: pointer;
    padding: 2px 4px;
    border-radius: 4px;
    transition: background 0.12s;
}
.notes-cell:hover { background: var(--mud-palette-background); }
.notes-icon-active { font-size: 16px !important; color: #0097a7; }
.notes-icon-muted  { font-size: 16px !important; color: var(--mud-palette-text-secondary); opacity: 0.3; }
.notes-badge {
    font-size: 0.58rem;
    font-weight: 700;
    background: #0097a7;
    color: #fff;
    border-radius: 8px;
    padding: 0 4px;
    line-height: 1.5;
    min-width: 14px;
    text-align: center;
}

/* ── Severity badges on group headers ── */
.sl-sev-badge {
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    padding: 1px 5px;
    border-radius: 3px;
    text-transform: uppercase;
    white-space: nowrap;
}
.sl-sev-critical { background: rgba(239,68,68,0.12);   color: #ef4444; }
.sl-sev-blocking { background: rgba(139,92,246,0.12);  color: #8b5cf6; }
.sl-sev-high     { background: rgba(239,68,68,0.08);   color: #ef4444; border: 1px solid rgba(239,68,68,0.25); }
.sl-sev-warning  { background: rgba(245,158,11,0.12);  color: #f59e0b; }
.sl-sev-advisory { background: rgba(0,151,167,0.12);   color: #0097a7; }
.sl-sev-info     { background: rgba(100,116,139,0.12); color: #64748b; }

/* ── Notes drawer ── */
.sl-notes-drawer {
    display: flex;
    flex-direction: column;
    height: 100%;
}
.sl-notes-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 12px 10px 16px;
    border-bottom: 1px solid var(--riq-surface-border);
    flex: 0 0 auto;
}
.sl-notes-title {
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.2;
}
.sl-notes-subtitle {
    font-size: 0.78rem;
    color: var(--mud-palette-text-secondary);
    margin-top: 2px;
}
.sl-notes-add {
    padding: 12px 16px;
    border-bottom: 1px solid var(--riq-surface-border);
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.sl-save-btn { align-self: flex-end; }
.sl-notes-readonly {
    padding: 10px 16px;
    font-size: 0.75rem;
    font-style: italic;
    color: var(--mud-palette-text-secondary);
    border-bottom: 1px solid var(--riq-surface-border);
    flex: 0 0 auto;
}
.sl-notes-history {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 0 16px 16px 16px;
}
.sl-notes-empty {
    font-size: 0.78rem;
    color: var(--mud-palette-text-secondary);
    font-style: italic;
    text-align: center;
    padding: 24px 0;
}
.sl-note-item {
    padding: 10px 0;
    border-bottom: 1px solid var(--riq-surface-border);
}
.sl-note-item:last-child { border-bottom: none; }
.sl-note-meta {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 4px;
}
.sl-note-date   { font-size: 0.68rem; font-family: 'IBM Plex Mono','Courier New',monospace; color: var(--mud-palette-text-secondary); }
.sl-note-author { font-size: 0.68rem; color: var(--mud-palette-text-secondary); }
.sl-note-text   { font-size: 0.8rem; color: var(--mud-palette-text-primary); line-height: 1.4; }

/* ── Loading skeleton page ── */
.sl-skeleton-page {
    padding: var(--space-3) 0;
    max-width: 1600px;
    margin: 0 auto;
}

/* ── Footer row (count) ── */
.sl-footer-row {
    padding: 6px 12px;
    font-size: 0.72rem;
    font-weight: 500;
    color: var(--mud-palette-text-secondary);
    border-top: 1px solid var(--riq-surface-border);
    text-align: right;
}

/* ── Empty state ── */
.sl-empty-state {
    padding: 48px 16px;
    text-align: center;
}

/* ── Filter chip bar ── */
.filter-chip-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    padding: 4px 0 6px 0;
}
.filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(14,165,233,0.1);
    border: 1px solid rgba(14,165,233,0.3);
    border-radius: 4px;
    padding: 2px 6px;
    font-size: 0.72rem;
    font-weight: 500;
    color: var(--mud-palette-text-primary);
}
.filter-chip-label { white-space: nowrap; }
.filter-chip-remove {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--mud-palette-text-secondary);
    font-size: 0.9rem;
    line-height: 1;
    padding: 0;
    opacity: 0.7;
}
.filter-chip-remove:hover { opacity: 1; color: #ef4444; }
.filter-chip-clear {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.72rem;
    color: var(--mud-palette-text-secondary);
    padding: 2px 4px;
    border-radius: 3px;
    text-decoration: underline;
    opacity: 0.7;
}
.filter-chip-clear:hover { opacity: 1; }

/* ── Flag overflow badge ── */
.flag-overflow-badge {
    font-size: 0.68rem;
    color: var(--mud-palette-text-secondary);
    font-family: 'IBM Plex Mono','Courier New',monospace;
    margin-left: 2px;
    opacity: 0.8;
}
