/* ============================================================
 * Projects List redesign — page-scoped styles
 * ------------------------------------------------------------
 * All selectors are prefixed with .pl-screen so legacy pages
 * remain visually unaffected. Source: proposals/app-redesign/
 * project-list/ProjectsList.html.
 *
 * Generic table-shell rules (sticky thead, pager, empty state,
 * cards-fallback, action buttons, .pl-btn / .pl-iconbtn) live in
 * insync-tables.css. This file contains only what's specific to
 * the Projects list — page chrome, filter card, cell rendering,
 * and Syncfusion overrides.
 * ============================================================ */

/* ── Page shell ───────────────────────────────────────────── */
.pl-screen { padding: 22px 28px 60px; }

/* ── Page header ──────────────────────────────────────────── */
.pl-pagehead { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.pl-pagehead__crumb { display: flex; gap: 6px; align-items: center; font: 500 12px var(--is-font-sans); color: var(--is-fg-3); margin-bottom: 4px; }
.pl-pagehead__crumb a { color: inherit; text-decoration: none; }
.pl-pagehead__crumb a:hover { color: var(--is-action-blue); }
.pl-pagehead__crumb i { font-size: 9px; }
.pl-pagehead h1 { font: 700 26px/1.15 var(--is-font-sans); letter-spacing: -.01em; color: var(--is-fg-1); margin: 0; display: flex; align-items: center; gap: 12px; }
.pl-pagehead h1 .pl-count { font: 600 13px var(--is-font-sans); color: var(--is-fg-2); background: var(--is-bg-surface-3); border: 1px solid var(--is-border-1); padding: 2px 10px; border-radius: 999px; }
.pl-pagehead__sub { font: 500 13px var(--is-font-sans); color: var(--is-fg-3); margin-top: 4px; }
.pl-pagehead__actions { display: flex; gap: 10px; align-items: center; }

/* ── Load-duration chip (always visible, mono, small) ─────── */
.pl-loadchip { display: inline-flex; align-items: center; gap: 6px; height: 22px; padding: 0 9px; border-radius: 999px; background: var(--is-bg-surface-3); border: 1px solid var(--is-border-1); font: 500 11px var(--is-font-mono); color: var(--is-fg-3); user-select: all; cursor: help; transition: background .15s, color .15s, border-color .15s; }
.pl-loadchip:hover { background: #fff; color: var(--is-fg-1); border-color: var(--is-border-2); }
.pl-loadchip i { font-size: 9px; color: var(--is-fg-3); }
.pl-loadchip:hover i { color: var(--is-action-blue); }
.pl-loadchip b { color: var(--is-fg-2); font-weight: 600; }
.pl-loadchip:hover b { color: var(--is-fg-1); }
.pl-loadchip .pl-loadchip__sep { color: var(--is-fg-4); font-weight: 400; padding: 0 1px; }
.pl-loadchip__info { background: transparent; border: 0; color: var(--is-fg-3); cursor: pointer; padding: 0 2px; font-size: 10px; display: inline-flex; align-items: center; }
.pl-loadchip__info:hover { color: var(--is-action-blue); }
.pl-loadchip.is-slow { background: rgba(206, 134, 0, .08); border-color: rgba(206, 134, 0, .25); color: var(--is-warning); }
.pl-loadchip.is-slow b { color: var(--is-warning); }
.pl-loadchip.is-slow i { color: var(--is-warning); }

/* ── V1↔V2 switch link (subtle, in header) ───────────────── */
.pl-vlink { display: inline-flex; align-items: center; gap: 6px; padding: 7px 10px; font: 600 12px var(--is-font-sans); color: var(--is-fg-3); background: transparent; border: 0; border-radius: 6px; text-decoration: none; cursor: pointer; transition: background .15s, color .15s; }
.pl-vlink:hover { background: var(--is-bg-surface-3); color: var(--is-action-blue); }
.pl-vlink i { font-size: 10px; }

/* ── "New" / "Legacy" version chip next to title ─────────── */
.pl-vchip { display: inline-flex; align-items: center; gap: 5px; height: 22px; padding: 0 9px; border-radius: 999px; font: 700 10.5px var(--is-font-sans); letter-spacing: .04em; text-transform: uppercase; line-height: 1; }
.pl-vchip i { font-size: 9px; }
.pl-vchip--new { background: var(--is-brand-blue-100); color: var(--is-brand-blue-700); border: 1px solid var(--is-brand-blue-200); }

/* ── Filter card ──────────────────────────────────────────── */
.pl-filters { background: var(--is-bg-surface); border: 1px solid var(--is-border-1); border-radius: var(--is-radius-md); box-shadow: var(--is-shadow-1); padding: 12px 14px; margin-bottom: 14px; }
.pl-filters__row { display: grid; grid-template-columns: minmax(220px, 1.4fr) repeat(3, minmax(180px, 1fr)) auto; gap: 10px; align-items: center; }
.pl-search { position: relative; }
.pl-search > i { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--is-fg-3); font-size: 13px; }
.pl-search input { width: 100%; height: 38px; padding: 0 12px 0 34px; border: 1px solid var(--is-border-3); border-radius: var(--is-radius-sm); background: #fff; font: 400 14px var(--is-font-sans); color: var(--is-fg-1); }
.pl-search input:focus { outline: none; border-color: var(--is-action-blue); box-shadow: 0 0 0 3px rgba(0, 123, 255, .15); }
.pl-filters__actions { display: flex; gap: 6px; align-items: center; height: 38px; }

/* Active filter chips strip */
.pl-chipstrip { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; padding-top: 10px; border-top: 1px dashed var(--is-border-1); align-items: center; min-height: 0; }
.pl-chipstrip__label { font: 500 11px var(--is-font-sans); color: var(--is-fg-3); text-transform: uppercase; letter-spacing: .05em; margin-right: 4px; }
.pl-chip { display: inline-flex; align-items: center; gap: 6px; height: 24px; padding: 0 4px 0 9px; border-radius: 999px; background: var(--is-bg-surface-3); border: 1px solid var(--is-border-1); font: 600 12px var(--is-font-sans); color: var(--is-fg-1); }
.pl-chip i.pl-chip__lead { font-size: 10px; color: var(--is-fg-3); }
.pl-chip__close { width: 18px; height: 18px; border-radius: 999px; background: transparent; border: 0; color: var(--is-fg-3); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; font-size: 9px; }
.pl-chip__close:hover { background: var(--is-border-2); color: var(--is-fg-1); }
.pl-chipstrip__clear { margin-left: auto; background: transparent; border: 0; font: 600 12px var(--is-font-sans); color: var(--is-action-blue); cursor: pointer; padding: 4px 6px; }
.pl-chipstrip__clear:hover { text-decoration: underline; }

/* ── Project name cell (table) ────────────────────────────── */
.pl-name { display: flex; align-items: center; gap: 10px; min-width: 0; }
.pl-name__color { width: 6px; height: 32px; border-radius: 3px; flex: none; box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .06); }
.pl-name__main { min-width: 0; flex: 1; display: flex; flex-direction: column; gap: 2px; }
.pl-name__title { font: 600 14px var(--is-font-sans); color: var(--is-fg-1); display: flex; align-items: center; gap: 6px; min-width: 0; }
.pl-name__title a { color: inherit; text-decoration: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.pl-name__title a:hover { color: var(--is-brand-blue); }
.pl-name__sub { font: 500 12px var(--is-font-sans); color: var(--is-fg-3); display: flex; align-items: center; gap: 6px; }
.pl-name__sub i { font-size: 10px; }

/* Connected-project link icon (used in both table and card title) */
.pl-link-ic { font-size: 10px; color: var(--is-success); flex: none; }

/* ── Date range cell ──────────────────────────────────────── */
.pl-date { font-variant-numeric: tabular-nums; font: 500 13px var(--is-font-sans); color: var(--is-fg-1); }
.pl-date__sub { font: 500 11px var(--is-font-sans); color: var(--is-fg-3); margin-top: 1px; }

/* ── Country with flag dot ────────────────────────────────── */
.pl-country { display: inline-flex; align-items: center; gap: 8px; }
.pl-country__flag { width: 18px; height: 13px; border-radius: 2px; background: linear-gradient(0deg, var(--is-bg-surface-3), var(--is-bg-surface)); border: 1px solid var(--is-border-2); display: inline-flex; align-items: center; justify-content: center; font: 700 8px var(--is-font-mono); color: var(--is-fg-2); }
.pl-country__sub { font: 500 11px var(--is-font-sans); color: var(--is-fg-3); margin-left: 4px; }

/* ── Status pill ──────────────────────────────────────────── */
.pl-status { display: inline-flex; align-items: center; gap: 6px; padding: 3px 10px 3px 8px; border-radius: 999px; font: 600 11px var(--is-font-sans); letter-spacing: .01em; }
.pl-status::before { content: ""; width: 6px; height: 6px; border-radius: 999px; background: currentColor; box-shadow: 0 0 0 3px color-mix(in oklch, currentColor 18%, transparent); }
.pl-status--inprogress { background: rgba(31, 138, 91, .10); color: var(--is-success); }
.pl-status--new        { background: rgba(0, 123, 255, .10); color: var(--is-action-blue); }
.pl-status--paused     { background: rgba(206, 134, 0, .10); color: var(--is-warning); }
.pl-status--done       { background: rgba(118, 118, 126, .14); color: var(--is-fg-2); }
.pl-status--lost       { background: rgba(199, 59, 59, .10); color: var(--is-danger); }
.pl-status--na         { background: var(--is-bg-surface-3); color: var(--is-fg-3); }

/* ── Probability bar ──────────────────────────────────────── */
.pl-prob { display: flex; flex-direction: column; gap: 4px; min-width: 92px; }
.pl-prob__num { font: 600 12px var(--is-font-sans); font-variant-numeric: tabular-nums; color: var(--is-fg-1); }
.pl-prob__bar { height: 4px; background: var(--is-bg-surface-3); border-radius: 999px; overflow: hidden; }
.pl-prob__fill { height: 100%; border-radius: 999px; background: var(--is-brand-blue); }
.pl-prob__fill.is-low  { background: var(--is-danger); }
.pl-prob__fill.is-mid  { background: var(--is-warning); }
.pl-prob__fill.is-high { background: var(--is-success); }
.pl-prob.is-na .pl-prob__num { color: var(--is-fg-3); }
/* Inside card field: tighten spacing so the bar lines up under the label nicely */
.pl-card .pl-prob { gap: 3px; }
.pl-card .pl-prob__num { font-size: 13px; }

/* ── Employee count ──────────────────────────────────────── */
.pl-people { display: inline-flex; align-items: center; gap: 6px; font: 600 12px var(--is-font-sans); color: var(--is-fg-1); font-variant-numeric: tabular-nums; }
.pl-people i { font-size: 11px; color: var(--is-fg-3); }
.pl-people.is-zero { color: var(--is-fg-3); }

/* ── Category badge ──────────────────────────────────────── */
.pl-cat { display: inline-flex; align-items: center; justify-content: center; min-width: 26px; height: 22px; padding: 0 7px; border-radius: 6px; font: 700 11px var(--is-font-mono); color: var(--is-fg-2); background: var(--is-bg-surface-3); border: 1px solid var(--is-border-1); }
.pl-cat.is-integral { background: var(--is-brand-orange-100); border-color: oklch(86% .07 50); color: var(--is-brand-orange-700); }

/* ── Responsive: filter row reflow below 1440px / 720px ───── */
@media (max-width: 1439.98px) {
    .pl-screen { padding: 16px 16px 60px; }
    .pl-pagehead { flex-wrap: wrap; }
    .pl-pagehead__actions { flex-wrap: wrap; }
    .pl-filters__row { grid-template-columns: 1fr 1fr; gap: 8px; }
    .pl-filters__row > .pl-search { grid-column: 1 / -1; }
    .pl-filters__actions { grid-column: 1 / -1; justify-content: flex-end; }
}
@media (max-width: 720px) {
    .pl-filters__row { grid-template-columns: 1fr; }
    .pl-pagehead h1 { font-size: 22px; }
}

/* ── SfMultiSelect override (match pl-select look) ────────── */
.pl-screen .pl-filters__row { align-items: stretch; }
.pl-screen .pl-search { display: flex; align-items: center; height: 38px; }
.pl-screen .pl-sf-filter { position: relative; display: flex; align-items: stretch; height: 38px; }
.pl-screen .pl-sf-filter > .e-control-wrapper,
.pl-screen .pl-sf-filter > .e-input-group,
.pl-screen .pl-sf-filter .e-multiselect {
    margin: 0 !important;
    padding: 0 !important;
    height: 38px !important;
    width: 100% !important;
    flex: 1 1 auto;
}
.pl-screen .pl-sf-filter .e-multi-select-wrapper {
    border: 1px solid var(--is-border-3) !important;
    border-radius: var(--is-radius-sm) !important;
    background: #fff !important;
    height: 38px !important;
    min-height: 38px !important;
    padding-left: 32px !important;
    padding-right: 28px !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
}
.pl-screen .pl-sf-filter.e-input-focus .e-multi-select-wrapper,
.pl-screen .pl-sf-filter:focus-within .e-multi-select-wrapper {
    border-color: var(--is-action-blue) !important;
    box-shadow: 0 0 0 3px rgba(0, 123, 255, .15) !important;
}
.pl-screen .pl-sf-filter .e-chips-collection .e-chips {
    background: var(--is-brand-blue-100) !important;
    color: var(--is-brand-blue-700) !important;
    border-radius: 999px !important;
    font: 600 11px var(--is-font-sans) !important;
}
.pl-screen .pl-sf-filter > .pl-sf-lead {
    position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
    color: var(--is-fg-3); font-size: 12px; pointer-events: none; z-index: 5;
}
