/* Universal Project Picker (DH #409) — token-driven; .ctx-* re-tones the same component. */
.pp {
  --pp-panel: var(--bg-panel); --pp-deep: var(--bg-deep); --pp-sub: var(--bg-sub);
  --pp-row-hover: var(--bg-row-hover); --pp-row-sel: var(--bg-row-sel);
  --pp-line: var(--line); --pp-line-soft: var(--line-soft); --pp-line-strong: var(--line-strong);
  --pp-fg: var(--fg); --pp-fg-strong: var(--fg-strong); --pp-fg-mute: var(--fg-mute);
  --pp-fg-dim: var(--fg-dim); --pp-fg-faint: var(--fg-faint);
  display: flex; flex-direction: column; background: var(--pp-panel);
  border: 1px solid var(--pp-line); border-radius: 10px; box-shadow: var(--float);
  overflow: hidden; font-family: var(--ui); color: var(--pp-fg);
}
/* DH #408 — re-toned cockpit grey: flatter cool neutrals, teal unchanged */
.pp.ctx-sspt {
  --pp-panel: #313338; --pp-deep: #232529; --pp-sub: #3a3d42;
  --pp-row-hover: #383b40; --pp-row-sel: #2f3d45;
  --pp-line: #43474d; --pp-line-soft: #393c41; --pp-line-strong: #51555c;
}
.pp-head { flex-shrink: 0; padding: 10px 10px 9px; border-bottom: 1px solid var(--pp-line-soft); }
.pp-search { display: flex; align-items: center; gap: 9px; height: 36px; padding: 0 9px 0 11px; border-radius: 7px;
             background: var(--pp-deep); border: 1px solid var(--pp-line-strong); box-shadow: inset 0 1px 2px rgba(0,0,0,.4); }
.pp-compact .pp-search { height: 32px; }
.pp-search:focus-within { border-color: var(--teal-line); box-shadow: inset 0 1px 2px rgba(0,0,0,.4), 0 0 0 3px var(--teal-glow); }
.pp-search > svg { color: var(--pp-fg-dim); flex-shrink: 0; }
.pp-q { flex: 1; min-width: 0; border: 0; background: transparent; outline: 0; color: var(--pp-fg); font-family: var(--ui); font-size: 13.5px; }
.pp-compact .pp-q { font-size: 12.5px; }
.pp-q::placeholder { color: var(--pp-fg-dim); }
.pp-clear { width: 20px; height: 20px; flex-shrink: 0; border: 0; background: transparent; color: var(--pp-fg-dim);
            cursor: pointer; display: inline-flex; align-items: center; justify-content: center; border-radius: 4px; }
.pp-clear:hover { color: var(--pp-fg); background: var(--pp-sub); }
.pp-headmeta { display: flex; align-items: center; justify-content: space-between; margin-top: 9px; padding: 0 2px; }
.pp-count { font-family: var(--mono); font-size: 10px; letter-spacing: .03em; color: var(--pp-fg-dim); }
.pp-count b { color: var(--pp-fg-mute); font-weight: 600; }
.pp-star-inline { color: var(--teal); display: inline-flex; vertical-align: -1px; margin: 0 1px; }
.pp-sortseg { display: inline-flex; height: 22px; border: 1px solid var(--pp-line); border-radius: 6px; overflow: hidden; background: var(--pp-deep); }
.pp-sortseg > button { border: 0; background: transparent; cursor: pointer; font-family: var(--mono); font-size: 9.5px;
                       letter-spacing: .06em; color: var(--pp-fg-dim); padding: 0 9px; }
.pp-sortseg > button:first-child { border-right: 1px solid var(--pp-line); }
.pp-sortseg > button:hover { color: var(--pp-fg-mute); }
.pp-sortseg > button.on { background: var(--pp-sub); color: var(--pp-fg-strong); }
.pp-list { overflow-y: auto; padding: 4px 6px; }
.pp-row { position: relative; display: flex; align-items: center; gap: 11px; padding: 0 6px 0 11px; border-radius: 7px; cursor: pointer; }
.pp-row:hover { background: var(--pp-row-hover); }
.pp-row.active { background: var(--pp-row-hover); box-shadow: inset 0 0 0 1px var(--pp-line-strong); }
.pp-row.current { background: var(--pp-row-sel); }
.pp-rail { position: absolute; left: 0; top: 8px; bottom: 8px; width: 3px; border-radius: 0 2px 2px 0; background: var(--teal); }
.pp-tile { width: 30px; height: 30px; flex-shrink: 0; border-radius: 7px; display: inline-flex; align-items: center;
           justify-content: center; position: relative; background: var(--pp-sub); border: 1px solid var(--pp-line); overflow: hidden; }
.pp-compact .pp-tile { width: 26px; height: 26px; border-radius: 6px; }
.pp-tile::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--dot); }
.pp-code { font-family: var(--mono); font-size: 9px; font-weight: 700; letter-spacing: .01em; color: var(--pp-fg-mute); padding-left: 3px; }
.pp-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.pp-namerow { display: flex; align-items: center; gap: 8px; min-width: 0; }
.pp-name { font-size: 13px; color: var(--pp-fg-strong); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pp-compact .pp-name { font-size: 12.5px; }
.pp-now { font-family: var(--mono); font-size: 8px; letter-spacing: .14em; color: var(--teal); flex-shrink: 0; }
.pp-sub { display: flex; align-items: center; gap: 7px; font-family: var(--mono); font-size: 9.5px; color: var(--pp-fg-dim); }
.pp-when { display: inline-flex; align-items: center; gap: 4px; }
.pp-when > svg { opacity: .75; }
.pp-dotsep { width: 3px; height: 3px; border-radius: 50%; background: var(--pp-fg-faint); flex-shrink: 0; }
.pp-open { color: var(--pp-fg-mute); }
.pp-open.zero { color: var(--pp-fg-faint); }
.pp-role { color: var(--pp-fg-dim); }
.pp-star { width: 26px; height: 26px; flex-shrink: 0; border: 0; background: transparent; color: var(--pp-fg-faint);
           cursor: pointer; display: inline-flex; align-items: center; justify-content: center; border-radius: 6px;
           opacity: 0; transition: opacity .12s, color .12s, background .12s; }
.pp-row:hover .pp-star, .pp-row.active .pp-star { opacity: 1; }
.pp-star:hover { color: var(--pp-fg); background: var(--pp-sub); }
.pp-star.on { opacity: 1; color: var(--teal); }
.pp-skel { display: flex; align-items: center; gap: 11px; padding: 0 11px; }
.pp-skel-tile { width: 30px; height: 30px; border-radius: 7px; background: var(--pp-sub); animation: pp-pulse 1.3s ease-in-out infinite; flex-shrink: 0; }
.pp-skel-lines { flex: 1; display: flex; flex-direction: column; gap: 7px; }
.pp-skel-lines i { height: 9px; border-radius: 3px; background: var(--pp-sub); animation: pp-pulse 1.3s ease-in-out infinite; }
@keyframes pp-pulse { 50% { opacity: .4; } }
.pp-blank { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 24px 30px; gap: 7px; }
.pp-blank-ico { width: 46px; height: 46px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center;
                background: var(--pp-deep); border: 1px solid var(--pp-line); color: var(--pp-fg-dim); margin-bottom: 5px; }
.pp-blank-t { font-size: 13.5px; color: var(--pp-fg-strong); }
.pp-blank-s { font-size: 11.5px; color: var(--pp-fg-dim); line-height: 1.5; max-width: 250px; }
.pp-blank-s .mono { font-family: var(--mono); color: var(--pp-fg-mute); }
.pp-blank-btn { margin-top: 10px; height: 28px; padding: 0 12px; border-radius: 6px; border: 1px solid var(--pp-line-strong);
                background: var(--pp-sub); color: var(--pp-fg); font-family: var(--ui); font-size: 12px; cursor: pointer; }
.pp-blank-btn:hover { border-color: var(--pp-fg-dim); }
.pp-foot { flex-shrink: 0; border-top: 1px solid var(--pp-line-soft); padding: 7px; display: flex; flex-direction: column; gap: 3px; }
.pp-create { display: flex; align-items: center; gap: 11px; width: 100%; padding: 8px 10px; border-radius: 7px;
             border: 1px solid transparent; background: transparent; cursor: pointer; font-family: var(--ui); transition: background .14s, border-color .14s; }
.pp-create:hover { background: var(--teal-bg); border-color: var(--teal-line); }
.pp-create-tile { width: 28px; height: 28px; border-radius: 7px; display: inline-flex; align-items: center; justify-content: center;
                  background: var(--teal-bg); border: 1px solid var(--teal-line); color: var(--teal); flex-shrink: 0; }
.pp-compact .pp-create-tile { width: 26px; height: 26px; }
.pp-create-t { flex: 1; text-align: left; font-size: 13px; color: var(--teal); }
.pp-create-chip { font-family: var(--mono); font-size: 9px; letter-spacing: .16em; color: var(--teal);
                  border: 1px solid var(--teal-line); background: var(--teal-bg); border-radius: 3px; padding: 2px 7px; }
.pp-keys { display: flex; align-items: center; gap: 13px; padding: 3px 6px 2px; }
.pp-keys span { display: inline-flex; align-items: center; gap: 5px; font-size: 9.5px; color: var(--pp-fg-faint); }
.pp-keys kbd { font-family: var(--mono); font-size: 9px; min-width: 15px; height: 15px; padding: 0 3px; display: inline-flex;
               align-items: center; justify-content: center; background: var(--pp-deep); border: 1px solid var(--pp-line);
               border-bottom-width: 2px; border-radius: 3px; color: var(--pp-fg-mute); }
