/* role-picker.css — role selection popup for cs.html (uses main.css tokens). */
.cs-role-pick { cursor:pointer; }

.rp-ov { position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:9600; display:flex; align-items:flex-start; justify-content:center; overflow:auto; padding:28px 14px; }
.rp-modal { background:#fff; width:100%; max-width:1040px; border:3px solid #111; box-shadow:0 12px 40px rgba(0,0,0,.5); }
.rp-head { display:flex; align-items:center; background:#111; color:#fff; font-family:var(--head, sans-serif); font-size:15px; letter-spacing:3px; text-transform:uppercase; padding:11px 16px; }
.rp-x { margin-left:auto; background:none; border:none; color:#bbb; font-size:15px; cursor:pointer; font-family:var(--mono, monospace); }
.rp-x:hover { color:#fff; }
.rp-body { padding:16px; }

/* base roles — horizontal poster carousel (portraits are 896×1837) */
.rp-carousel { position:relative; }
.rp-track { display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x proximity; padding:4px 2px 10px; scrollbar-width:thin; }
.rp-track::-webkit-scrollbar { height:8px; }
.rp-track::-webkit-scrollbar-thumb { background:#bbb; }
.rp-card { flex:0 0 clamp(240px,26vw,300px); height:min(64vh,580px); position:relative; scroll-snap-align:center; border:2px solid #111; overflow:hidden; cursor:pointer; background:#0d0d0e; padding:0; display:block; text-align:left; }
.rp-card-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .25s; }
.rp-card:hover .rp-card-img { transform:scale(1.05); }
.rp-card-ph { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--head, sans-serif); font-size:130px; color:#26262b; }
.rp-card-grad { position:absolute; left:0; right:0; bottom:0; top:30%; background:linear-gradient(to top, rgba(8,8,10,.96) 0%, rgba(8,8,10,.82) 38%, rgba(8,8,10,0) 100%); pointer-events:none; }
.rp-card-info { position:absolute; left:0; right:0; bottom:0; padding:14px 14px 16px; display:flex; flex-direction:column; gap:6px; color:#f2f2f2; }
.rp-card-name { font-family:var(--head, sans-serif); font-size:22px; letter-spacing:1px; text-transform:uppercase; color:#fff; line-height:1; }
.rp-card-sa { font-family:var(--mono, monospace); font-size:12px; color:#e2b53c; font-weight:bold; }
.rp-card-attrs { display:flex; gap:5px; flex-wrap:wrap; }
.rp-card-attrs i { font-style:normal; font-family:var(--head, sans-serif); font-size:10px; letter-spacing:1px; background:#fff; color:#111; padding:2px 7px; }
.rp-card-blurb { font-family:var(--mono, monospace); font-size:11.5px; line-height:1.45; color:#cfcfcf; }
.rp-card-meta { font-family:var(--mono, monospace); font-size:11px; color:#9a9a9a; }
.rp-card-skills { display:flex; gap:4px; flex-wrap:wrap; border-top:1px solid rgba(255,255,255,.18); padding-top:7px; }
.rp-card-skills em { font-style:normal; font-family:var(--mono, monospace); font-size:9.5px; color:#cfcfcf; border:1px solid rgba(255,255,255,.3); padding:1px 5px; }
.rp-nav { position:absolute; top:50%; transform:translateY(-50%); z-index:3; width:46px; height:46px; border-radius:50%; background:#fff; color:#111; border:2px solid #111; font-size:22px; line-height:1; display:flex; align-items:center; justify-content:center; cursor:pointer; box-shadow:0 4px 14px rgba(0,0,0,.25); transition:background .12s,color .12s,transform .12s; }
.rp-nav:hover { background:#111; color:#fff; transform:translateY(-50%) scale(1.08); }
.rp-nav:active { transform:translateY(-50%) scale(.96); }
.rp-nav-prev { left:-12px; }
.rp-nav-next { right:-12px; }

/* more-roles drawer */
.rp-more { display:block; width:100%; margin-top:16px; background:#f3f3f3; border:1px solid #111; font-family:var(--head, sans-serif); font-size:12px; letter-spacing:2px; text-transform:uppercase; padding:9px; cursor:pointer; }
.rp-more:hover { background:#111; color:#fff; }
.rp-others { margin-top:10px; }
.rp-search { width:100%; box-sizing:border-box; padding:8px 10px; border:1px solid #111; font-family:var(--mono, monospace); font-size:13px; margin-bottom:8px; }
.rp-others-list { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:5px; max-height:38vh; overflow:auto; }
.rp-row { display:flex; align-items:center; gap:8px; text-align:left; background:#fff; border:1px solid #ddd; padding:7px 10px; cursor:pointer; font-family:var(--mono, monospace); }
.rp-row:hover { background:#111; color:#fff; border-color:#111; }
.rp-row:hover .rp-row-sa, .rp-row:hover .rp-row-sal { color:#ccc; }
.rp-row-name { flex:1; font-size:13px; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.rp-row-sa { font-size:11px; color:#b8860b; white-space:nowrap; }
.rp-row-sal { font-size:11px; color:#888; }
.rp-empty { grid-column:1/-1; font-family:var(--mono, monospace); font-size:12px; color:#999; padding:14px; text-align:center; }

@media (max-width:560px) { .rp-grid { grid-template-columns:1fr 1fr; } }
