/* ===========================
   CalBoard – design system
   =========================== */

:root {
    /* Light theme tokens (default) */
    --cb-surface-bg: #fbfcfe;
    --cb-surface-alt: #f9fafb;
    --cb-body-bg: #eef2f7; /* cool gray-blue */
    --cb-border-subtle: rgba(15, 23, 42, 0.14);
    --cb-border-soft: rgba(15, 23, 42, 0.08);
    --cb-text-main: #0f172a;
    --cb-text-muted: #64748b;
    --cb-text-soft: #94a3b8;
    --cb-header-bg: #f3f6fb;
    --cb-header-text: #475569;
    --cb-cal-col-bg: #f3f6fb;
    --cb-row-hover-bg: rgba(37, 99, 235, 0.06);
    --cb-empty-text: #94a3b8;
    --cb-partial-bg: #fff3cd;
    --cb-complete-bg: #d4edda;
    --cb-assigned-bg: #e4efff;
    --cb-mine-outline: rgba(37, 99, 235, 0.9);
    --cb-pill-bg: #fbfcfe;
    --cb-pill-border: rgba(15, 23, 42, 0.10);
    --cb-pill-complete: #16a34a;
    --cb-pill-partial: #eab308;
    --cb-pill-assigned: #2563eb;
    --cb-pill-empty: #64748b;
    --cb-pill-mine: #7c3aed;
    --cb-shadow-soft: 0 1px 3px rgba(15, 23, 42, 0.08);
}

/* ===========================
   Global layout / shell
   =========================== */

body {
    background-color: var(--cb-body-bg);
    color: var(--cb-text-main);
}

/* ===========================
   Left panel (jobs)
   =========================== */

.calboard-left-panel {
    background: var(--cb-surface-bg);
    border: 1px solid var(--cb-border-soft);
    border-radius: 10px;
    box-shadow: var(--cb-shadow-soft);
    padding: 0.75rem;
}

/* Sticky only on md+ so phones don't get annoying */
@media (min-width: 768px) {
    .calboard-left-panel {
        position: sticky;
        top: 78px; /* below sticky navbar; tweak if your header height changes */
        max-height: calc(100vh - 90px);
        overflow: auto;
    }
}

/* Job tile button */
.calboard-job-tile {
    width: 100%;
    border: 1px solid var(--cb-border-soft);
    background: var(--cb-surface-bg);
    border-radius: 10px;
    padding: 0;
    overflow: hidden;
    text-align: center; /* centers label */
    box-shadow: var(--cb-shadow-soft);
}

    .calboard-job-tile:hover {
        transform: translateY(-1px);
        border-color: rgba(37, 99, 235, 0.25);
        box-shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
    }

    .calboard-job-tile.active {
        border-color: rgba(37, 99, 235, 0.55);
        box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.18);
        background: #ffffff;
    }

.calboard-job-thumb {
    height: 72px; /* wide tile header */
    border-radius: 10px 10px 0 0;
    overflow: hidden;
    background: #e7ecf5;
}

    .calboard-job-thumb img {
        width: 100%;
        height: 100%;
        object-fit: cover; /* CROPPED, NOT STRETCHED */
        object-position: center;
        display: block;
    }

.calboard-job-tile-img {
    width: 100%;
    height: 90px; /* tune this */
    object-fit: cover; /* crop, no stretching */
    display: block;
    background: var(--cb-surface-alt);
}

.calboard-job-tile-label {
    padding: 0.5rem 0.6rem;
    font-weight: 600;
    color: var(--cb-text-main);
    line-height: 1.2;
}

.calboard-job-tile.active {
    outline: 2px solid rgba(37, 99, 235, 0.35);
}

.calboard-job-link-btn {
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: 4px;
    background: rgba(15, 23, 42, 0.06);
    color: var(--cb-text-secondary, #64748b);
    text-decoration: none;
    font-weight: 500;
    line-height: 1.4;
}
.calboard-job-link-btn:hover {
    background: rgba(15, 23, 42, 0.12);
    color: var(--cb-text-main, #1e293b);
    text-decoration: none;
}
.calboard-job-tile-links {
    padding: 0 0.6rem 0.4rem;
}

/* ===========================
   Toolbar (summary + filters)
   =========================== */

.calboard-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem 1rem;
    align-items: center;
    justify-content: space-between;
    background: var(--cb-surface-bg);
    border: 1px solid var(--cb-border-soft);
    border-radius: 10px;
    padding: 0.55rem 0.75rem;
    box-shadow: var(--cb-shadow-soft);
}

.calboard-filters {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

    .calboard-filters label {
        margin-bottom: 0;
        cursor: pointer;
    }

/* ===========================
   Board container
   =========================== */

.calboard-container {
    margin-top: 0.5rem;
    padding-bottom: 0.75rem;
    overflow-x: auto;
    background-color: transparent;
    position: relative;
}

    /* Subtle right-edge fade to hint horizontal scroll */
    .calboard-container::after {
        content: "";
        position: absolute;
        top: 0;
        right: 0;
        width: 16px;
        height: 100%;
        pointer-events: none;
        background: linear-gradient(to left, var(--cb-body-bg), transparent);
    }

/* ===========================
   Component header
   =========================== */

.calboard-component-title {
    margin-top: 1.25rem;
    margin-bottom: 0.45rem;
    padding: 0.42rem 0.75rem;
    font-size: 0.98rem;
    font-weight: 750;
    border-radius: 10px;
    background: linear-gradient(90deg, rgba(37, 99, 235, 0.10), transparent);
    border: 1px solid var(--cb-border-soft);
    color: var(--cb-text-main);
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

    .calboard-component-title > span:first-of-type {
        flex: 1;
        text-align: center;
    }

.calboard-component-title-actions {
    display: flex;
    gap: 0.25rem;
    flex-shrink: 0;
}

/* Collapse/expand chevron */
.calboard-collapse-btn {
    background: none;
    border: none;
    padding: 0 0.35rem 0 0;
    font-size: 0.75rem;
    color: var(--cb-text-muted);
    cursor: pointer;
    line-height: 1;
    flex-shrink: 0;
}

    .calboard-collapse-btn:hover {
        color: var(--cb-text-main);
    }

/* Component complete pill */
.calboard-complete-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.1rem 0.5rem;
    border-radius: 999px;
    border: 1px solid rgba(22, 163, 74, 0.5);
    background: rgba(22, 163, 74, 0.08);
    color: #16a34a;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

/* ===========================
   Component gear button
   =========================== */

.calboard-gear-btn {
    padding: 0.18rem 0.45rem;
    line-height: 1;
    border-radius: 8px;
    border: 1px solid var(--cb-border-soft);
    background: rgba(148, 163, 184, 0.08);
    color: var(--cb-text-main);
}

    .calboard-gear-btn:hover {
        background: rgba(37, 99, 235, 0.10);
        border-color: rgba(37, 99, 235, 0.28);
    }

    .calboard-gear-btn:focus {
        box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.18);
        outline: none;
    }

/* ===========================
   Gear Modal
   =========================== */

.gear-modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 6000;
    background: rgba(0, 0, 0, 0.35);
    display: flex;
    align-items: center;
    justify-content: center;
}

.gear-modal {
    width: 460px;
    max-width: 94vw;
    max-height: 85vh;
    overflow-y: auto;
    background: var(--cb-surface-bg);
    border: 1px solid var(--cb-border-subtle);
    border-radius: 12px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.18);
    color: var(--cb-text-main);
    padding: 0;
}

.gear-modal-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    border-bottom: 1px solid var(--cb-border-soft);
    font-weight: 700;
    font-size: 1rem;
}

.gear-modal-close {
    background: none;
    border: none;
    font-size: 1.1rem;
    color: var(--cb-text-muted);
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 6px;
    line-height: 1;
}

    .gear-modal-close:hover {
        background: rgba(0, 0, 0, 0.06);
        color: var(--cb-text-main);
    }

.gear-modal-top-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 20px;
}

.gear-modal-add-cal {
    padding: 5px 14px;
    font-size: 0.82rem;
    font-weight: 600;
    border: 1px solid var(--cb-border-soft);
    border-radius: 8px;
    background: rgba(148, 163, 184, 0.06);
    color: var(--cb-text-main);
    cursor: pointer;
}

    .gear-modal-add-cal:hover {
        background: rgba(37, 99, 235, 0.10);
        border-color: rgba(37, 99, 235, 0.25);
    }

    .gear-modal-add-cal:disabled {
        opacity: 0.5;
        cursor: default;
    }

.gear-modal-complete {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.84rem;
    color: var(--cb-text-muted);
    cursor: pointer;
}

    .gear-modal-complete input {
        cursor: pointer;
    }

.gear-modal-divider {
    border: none;
    border-top: 1px solid var(--cb-border-soft);
    margin: 0;
}

.gear-modal-section-header {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--cb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 10px 20px 4px;
}

/* Analyst Roles grid */
.gear-modal-roles {
    padding: 0 20px 8px;
}

.gear-modal-roles-row {
    display: grid;
    grid-template-columns: 1fr 56px 56px;
    gap: 4px;
    align-items: center;
    padding: 3px 0;
    font-size: 0.84rem;
}

    .gear-modal-roles-row input[type="checkbox"] {
        margin: 0 auto;
        display: block;
        cursor: pointer;
    }

.gear-modal-roles-header span {
    font-size: 0.68rem;
    color: var(--cb-text-soft);
    text-align: center;
    font-weight: 600;
}

    .gear-modal-roles-header span:first-child {
        text-align: left;
    }

/* CALs list */
.gear-modal-cal-list {
    max-height: 260px;
    overflow-y: auto;
    padding: 4px 20px 16px;
}

.gear-modal-cal-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 0;
    border-bottom: 1px solid var(--cb-border-soft);
    font-size: 0.84rem;
}

    .gear-modal-cal-row:last-child {
        border-bottom: none;
    }

    .gear-modal-cal-row.voided {
        opacity: 0.5;
    }

    .gear-modal-cal-row.voided .gear-modal-cal-label {
        text-decoration: line-through;
        color: var(--cb-text-soft);
    }

.gear-modal-cal-actions {
    display: flex;
    gap: 6px;
}

.gear-modal-cal-empty {
    font-size: 0.82rem;
    color: var(--cb-text-soft);
    padding: 8px 0;
}

.gear-modal-btn {
    padding: 3px 10px;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 6px;
    border: 1px solid;
    cursor: pointer;
    background: none;
}

    .gear-modal-btn:disabled {
        opacity: 0.5;
        cursor: default;
    }

    .gear-modal-btn.void {
        color: #b45309;
        border-color: rgba(180, 83, 9, 0.3);
    }

        .gear-modal-btn.void:hover:not(:disabled) {
            background: rgba(180, 83, 9, 0.08);
        }

    .gear-modal-btn.delete {
        color: #dc2626;
        border-color: rgba(220, 38, 38, 0.3);
    }

        .gear-modal-btn.delete:hover:not(:disabled) {
            background: rgba(220, 38, 38, 0.08);
        }

    .gear-modal-btn.unvoid {
        color: var(--cb-pill-assigned);
        border-color: rgba(37, 99, 235, 0.3);
    }

        .gear-modal-btn.unvoid:hover:not(:disabled) {
            background: rgba(37, 99, 235, 0.08);
        }

    .gear-modal-btn.cancel {
        color: var(--cb-text-muted);
        border-color: var(--cb-border-soft);
    }

        .gear-modal-btn.cancel:hover:not(:disabled) {
            background: rgba(0, 0, 0, 0.04);
        }

.gear-modal-delete-confirm {
    background: rgba(220, 38, 38, 0.04);
    border-radius: 6px;
    padding: 6px 8px;
}

.gear-modal-delete-msg {
    font-size: 0.8rem;
    color: #dc2626;
    font-weight: 500;
}


/* ===========================
   Table
   =========================== */

.calboard-table {
    min-width: 640px;
    border-collapse: separate;
    border-spacing: 2px;
    font-size: 0.875rem;
    background-color: var(--cb-surface-bg);
    border-radius: 10px;
    box-shadow: var(--cb-shadow-soft);
    color: var(--cb-text-main);
    overflow: hidden;
}

    /* Header row */
    .calboard-table thead th {
        position: sticky;
        top: 0;
        z-index: 3;
        background: var(--cb-header-bg);
        color: var(--cb-header-text);
        text-transform: uppercase;
        letter-spacing: 0.06em;
        font-size: 0.68rem;
        font-weight: 700;
        padding: 0.42rem 0.6rem;
        white-space: nowrap;
    }

    .calboard-table thead th {
        text-align: center;
    }

        /* Make CAL header sticky with the column */
        .calboard-table thead th:first-child {
            position: sticky;
            left: 0;
            z-index: 4;
        }

    /* Cell spacing */
    .calboard-table tbody td {
        padding: 0.36rem 0.6rem;
        vertical-align: middle;
    }

/* CAL column: sticky + subtle background */
.calboard-cal-cell {
    font-weight: 800;
    white-space: nowrap;
    background-color: var(--cb-cal-col-bg);
    position: sticky;
    left: 0;
    z-index: 2;
    text-align: center;
    width: 64px; /* narrow now */
}

/* Tubes column */
.calboard-tubes-cell {
    width: 80px;
    white-space: nowrap;
    text-align: center;
    font-variant-numeric: tabular-nums;
}

/* Assignment cells */
.calboard-assignment-cell {
    text-align: center;
    vertical-align: middle;
    min-width: 60px;
    white-space: nowrap;
    border-radius: 3px;
}

    .calboard-assignment-cell.calboard-empty {
        color: #cccccc;
        font-style: italic;
    }

/* Row hover */
.calboard-table tbody tr:hover td.calboard-assignment-cell {
    background-color: var(--cb-row-hover-bg);
}

/* Incomplete (INC) */
.calboard-partial {
    background-color: #FFF9C4 !important;
    color: #F57F17;
    font-weight: 700;
    border-radius: 3px;
}

/* Complete */
.calboard-complete {
    background-color: #C8E6C9 !important;
    color: #1B5E20;
    font-weight: 700;
    border-radius: 3px;
}

/* Assigned (in-progress, claimed but not complete) */
.calboard-assigned {
    background-color: transparent;
    color: #333333;
    font-weight: 700;
}

/* Clickable state */
.calboard-assignment-cell.calboard-clickable {
    cursor: pointer;
}

    .calboard-assignment-cell.calboard-clickable:hover {
        box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.12) inset;
    }

.calboard-assignment-cell.calboard-saving {
    opacity: 0.6;
}

/* Highlight "my" slots */
.calboard-mine {
    box-shadow: 0 0 0 2px var(--cb-mine-outline) inset;
}

/* VOID cells */
.calboard-void-cell {
    background-color: #fde2e7 !important;
    color: #7a2b33;
    font-weight: 700;
    text-align: center;
    text-decoration: line-through;
    border-radius: 3px;
}

/* ===========================
   SUM data column (PROBE)
   =========================== */

.calboard-probe-col,
.calboard-probe-cell {
    width: 1%;
    white-space: nowrap;
}

.calboard-probe-cell {
    text-align: center;
    color: #333333;
}

/* ===========================
   Status + summary
   =========================== */

.calboard-status {
    font-size: 0.85rem;
    color: var(--cb-text-muted);
}

.calboard-lastupdated {
    font-size: 0.8rem;
    font-style: italic;
    color: var(--cb-text-soft);
}

.calboard-summary {
    font-size: 0.8rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
}

/* Summary pills */
.calboard-summary-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.12rem 0.45rem;
    border-radius: 999px;
    border: 1px solid var(--cb-pill-border);
    background-color: var(--cb-pill-bg);
    white-space: nowrap;
}

    .calboard-summary-pill .label {
        color: var(--cb-text-muted);
        text-transform: uppercase;
        letter-spacing: 0.05em;
        font-size: 0.68rem;
        font-weight: 800;
    }

    .calboard-summary-pill .value {
        font-weight: 900;
    }

    /* Variants */
    .calboard-summary-pill.complete {
        border-color: rgba(22, 163, 74, 0.6);
        color: var(--cb-pill-complete);
    }

    .calboard-summary-pill.partial {
        border-color: rgba(234, 179, 8, 0.6);
        color: var(--cb-pill-partial);
    }

    .calboard-summary-pill.assigned {
        border-color: rgba(37, 99, 235, 0.6);
        color: var(--cb-pill-assigned);
    }

    .calboard-summary-pill.empty {
        border-color: rgba(100, 116, 139, 0.45);
        color: var(--cb-pill-empty);
    }

    .calboard-summary-pill.mine {
        border-color: rgba(124, 58, 237, 0.6);
        color: var(--cb-pill-mine);
    }

    .calboard-summary-pill.components {
        border-color: rgba(22, 130, 60, 0.6);
    }

    .calboard-summary-pill.components .value {
            color: rgba(16, 100, 45, 0.95);
    }       


/* Component filter dropdown */
.calboard-component-pill-wrap {
    position: relative;
    display: inline-flex;
}

.calboard-component-dropdown {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    z-index: 3000;
    min-width: 220px;
    background: var(--cb-surface-bg);
    border: 1px solid var(--cb-border-subtle);
    border-radius: 10px;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
    padding: 0;
    overflow: hidden;
}

.calboard-component-dropdown-header {
    display: flex;
    justify-content: space-between;
    padding: 8px 12px;
    border-bottom: 1px solid var(--cb-border-soft);
    font-size: 0.78rem;
}

    .calboard-component-dropdown-header a {
        color: var(--cb-pill-assigned);
        text-decoration: none;
        font-weight: 600;
    }

        .calboard-component-dropdown-header a:hover {
            text-decoration: underline;
        }

.calboard-component-dropdown-list {
    max-height: 280px;
    overflow-y: auto;
    padding: 4px 0;
}

.calboard-component-dropdown-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 12px;
    font-size: 0.82rem;
    color: var(--cb-text-main);
    cursor: pointer;
    margin: 0;
}

    .calboard-component-dropdown-row:hover {
        background: rgba(37, 99, 235, 0.06);
    }

    .calboard-component-dropdown-row input[type="checkbox"] {
        margin: 0;
        flex-shrink: 0;
    }

/* ===========================
       Subtle "intentional" table animation
       =========================== */

/* initial state */
.calboard-table.calboard-animate-in thead th,
.calboard-table.calboard-animate-in tbody td {
    opacity: 0;
    transform: translateY(-3px);
}

/* animate into place */
.calboard-table.calboard-animate-in.is-ready thead th,
.calboard-table.calboard-animate-in.is-ready tbody td {
    opacity: 1;
    transform: none;
    transition: opacity 140ms ease, transform 140ms ease;
}

/* tiny stagger so headers/cells don't pop at once */
.calboard-table.calboard-animate-in.is-ready thead th {
    transition-delay: 20ms;
}

.calboard-table.calboard-animate-in.is-ready tbody td {
    transition-delay: 40ms;
}

/* respect reduced motion */
@media (prefers-reduced-motion: reduce) {
    .calboard-table.calboard-animate-in thead th,
    .calboard-table.calboard-animate-in tbody td {
        opacity: 1;
        transform: none;
        transition: none;
    }
}


/* ===========================
   Mobile layout polish
   =========================== */

@media (max-width: 992px) {
    .calboard-table {
        font-size: 0.82rem;
        min-width: 520px;
    }

        .calboard-table thead th,
        .calboard-table tbody td {
            padding: 0.32rem 0.48rem;
        }

    .calboard-summary {
        gap: 0.25rem;
    }

    .calboard-summary-pill {
        padding: 0.1rem 0.4rem;
    }

    .calboard-container + .small.text-muted {
        font-size: 0.7rem;
        line-height: 1.3;
    }

    /* Make job thumbs a bit shorter on smaller screens */
    .calboard-job-thumb {
        height: 62px;
    }
}

/* ===========================
   Analyst tooltip
   =========================== */

.calboard-assignment-cell[data-tooltip] {
    position: relative;
}

    .calboard-assignment-cell[data-tooltip]::after {
        content: attr(data-tooltip);
        position: absolute;
        bottom: calc(100% + 6px);
        left: 50%;
        transform: translateX(-50%);
        background: #1e293b;
        color: #f1f5f9;
        font-size: 0.72rem;
        font-weight: 500;
        white-space: nowrap;
        padding: 0.3rem 0.55rem;
        border-radius: 6px;
        box-shadow: 0 2px 8px rgba(15, 23, 42, 0.18);
        pointer-events: none;
        opacity: 0;
        transition: opacity 0.15s ease;
        z-index: 100;
    }

    .calboard-assignment-cell[data-tooltip]:hover::after {
        opacity: 1;
    }

/* Probe tooltip (standards info) */
.calboard-probe-cell[data-tooltip] {
    position: relative;
}

    .calboard-probe-cell[data-tooltip]::after {
        content: attr(data-tooltip);
        position: absolute;
        bottom: calc(100% + 6px);
        left: 50%;
        transform: translateX(-50%);
        background: #1e293b;
        color: #f1f5f9;
        font-size: 0.72rem;
        font-weight: 500;
        white-space: nowrap;
        padding: 0.3rem 0.55rem;
        border-radius: 6px;
        box-shadow: 0 2px 8px rgba(15, 23, 42, 0.18);
        pointer-events: none;
        opacity: 0;
        transition: opacity 0.15s ease;
        z-index: 100;
    }

    .calboard-probe-cell[data-tooltip]:hover::after {
        opacity: 1;
    }
