/* ============================================================
   CS2 Loadout Builder — in-game loadout screen redesign.
   All rules scoped under .rsk-lb so nothing leaks to other pages.
   Tokens map to the theme/plugin --rsk-* vars where present, with
   prototype values as fallbacks.
   ============================================================ */
.rsk-lb{
  --lb-bg:var(--rsk-bg,hsl(220 20% 7%));
  --lb-elev:var(--rsk-bg-elev,hsl(220 18% 10%));
  --lb-elev-2:hsl(220 18% 12%);
  --lb-border:var(--rsk-border,hsl(220 15% 18%));
  --lb-border-soft:hsl(220 15% 18% / .55);
  --lb-red:var(--rsk-red,hsl(0 80% 50%));
  --lb-green:hsl(145 65% 42%);
  --lb-gold:hsl(45 90% 55%);
  --lb-fg:var(--rsk-fg,hsl(0 0% 95%));
  --lb-fg-2:var(--rsk-fg-2,hsl(0 0% 78%));
  --lb-fg-muted:hsl(220 10% 55%);
  --lb-r-sm:.5rem;
  --lb-r:.75rem;
  --lb-r-lg:1rem;
  --lb-head:var(--rsk-font-head,'Rajdhani',system-ui,sans-serif);
  --lb-mono:var(--rsk-font-mono,'JetBrains Mono',ui-monospace,Menlo,monospace);
}
.rsk-lb *,.rsk-lb *::before,.rsk-lb *::after{box-sizing:border-box}

.rsk-lb-lede{max-width:780px;color:var(--lb-fg-2);font-size:1rem;line-height:1.7;margin:0 0 8px}
.rsk-lb-lede strong{color:var(--lb-fg);font-weight:600}

/* ───────── Control bar ───────── */
.rsk-lb-controls{
  display:flex;flex-wrap:wrap;align-items:center;gap:14px 22px;
  padding:16px 18px;margin:22px 0 18px;
  background:linear-gradient(145deg,hsl(220 18% 12%),hsl(220 18% 8%));
  border:1px solid var(--lb-border);border-radius:var(--lb-r-lg);
}
.rsk-lb-ctl{display:flex;align-items:center;gap:10px}
.rsk-lb-ctl-lbl{font-family:var(--lb-head);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--lb-fg-muted)}
.rsk-lb-budgets{display:flex;gap:6px;flex-wrap:wrap}
.rsk-lb-pill{padding:7px 13px;border-radius:var(--lb-r-sm);border:1px solid var(--lb-border);background:var(--lb-elev);color:var(--lb-fg-2);font-weight:600;font-size:13px;font-family:var(--lb-mono);transition:all .18s;cursor:pointer}
.rsk-lb-pill:hover{border-color:hsl(0 80% 50% / .5);color:var(--lb-fg)}
.rsk-lb-pill.is-active{background:var(--lb-red);border-color:var(--lb-red);color:#fff;box-shadow:0 0 14px hsl(0 80% 50% / .4)}
.rsk-lb-unlim{border-color:hsl(45 90% 55% / .5);color:#f5c451}
.rsk-lb-unlim.is-active{background:var(--lb-red);border-color:var(--lb-red);color:#fff}
.rsk-lb-colors{display:flex;gap:7px;flex-wrap:wrap}
.rsk-lb-dot{width:26px;height:26px;border-radius:50%;border:2px solid var(--lb-border);cursor:pointer;transition:all .18s;padding:0}
.rsk-lb-dot:hover{transform:scale(1.12)}
.rsk-lb-dot.is-active{border-color:#fff;box-shadow:0 0 0 2px var(--lb-bg),0 0 12px hsl(0 0% 100% / .35)}
.rsk-lb-spacer{flex:1}
.rsk-lb-actions{display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.rsk-lb-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:var(--lb-r-sm);font-weight:600;font-size:13px;border:1px solid var(--lb-border);background:var(--lb-elev);color:var(--lb-fg);transition:all .18s;cursor:pointer}
.rsk-lb-btn:hover{border-color:hsl(0 80% 50% / .5);background:hsl(220 15% 16%)}
.rsk-lb-btn svg{width:15px;height:15px}
.rsk-lb-btn.is-primary{background:linear-gradient(135deg,hsl(0 80% 45%),hsl(0 90% 55%));border-color:transparent;color:#fff;box-shadow:0 0 16px hsl(0 80% 50% / .35)}
.rsk-lb-btn.is-primary:hover{filter:brightness(1.1)}
.rsk-lb-total{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1;margin-left:6px}
.rsk-lb-total-lbl{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--lb-fg-muted);font-weight:600}
.rsk-lb-total-val{font-family:var(--lb-mono);font-weight:700;font-size:22px;color:var(--lb-green)}
.rsk-lb-total-val.is-over{color:var(--lb-red)}

/* ───────── Side toggle ───────── */
.rsk-lb-sidewrap{display:flex;justify-content:center;margin:0 0 16px}
.rsk-lb-seg{display:flex;background:var(--lb-elev);border:1px solid var(--lb-border);border-radius:var(--lb-r);padding:5px;gap:5px}
.rsk-lb-seg-btn{padding:9px 26px;border:none;background:transparent;color:var(--lb-fg-muted);font-family:var(--lb-head);font-weight:700;font-size:15px;letter-spacing:.06em;text-transform:uppercase;border-radius:var(--lb-r-sm);transition:all .2s;cursor:pointer}
.rsk-lb-seg-btn.is-active{background:var(--lb-red);color:#fff;box-shadow:0 0 16px hsl(0 80% 50% / .4)}

/* ───────── Loadout panel ───────── */
.rsk-lb-panel{
  position:relative;
  background:
    radial-gradient(120% 90% at 50% 0%, hsl(0 60% 12% / .35), transparent 60%),
    linear-gradient(145deg,hsl(220 18% 11%),hsl(220 20% 7%));
  border:2px solid hsl(0 80% 50% / .55);
  border-radius:var(--lb-r-lg);
  box-shadow:0 0 40px hsl(0 80% 50% / .12), inset 0 0 60px hsl(0 0% 0% / .4);
  padding:26px;
  overflow:hidden;
}
.rsk-lb-panel::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,hsl(0 0% 100% / .05) 1px,transparent 0);background-size:34px 34px;pointer-events:none}
.rsk-lb-corner{position:absolute;width:26px;height:26px;border-color:var(--lb-red);z-index:2}
.rsk-lb-corner.tl{top:10px;left:10px;border-top:2px solid;border-left:2px solid}
.rsk-lb-corner.tr{top:10px;right:10px;border-top:2px solid;border-right:2px solid}
.rsk-lb-corner.bl{bottom:10px;left:10px;border-bottom:2px solid;border-left:2px solid}
.rsk-lb-corner.br{bottom:10px;right:10px;border-bottom:2px solid;border-right:2px solid}

.rsk-lb-panel-inner{position:relative;z-index:1;display:flex;gap:26px;align-items:stretch}
.rsk-lb-panel-inner.t-side{flex-direction:row-reverse}

/* figure + equip rail */
.rsk-lb-figure{display:flex;gap:14px;flex-shrink:0}
.rsk-lb-rail{display:flex;flex-direction:column;gap:14px;justify-content:center}
.rsk-lb-eslot{width:128px;height:104px;border-radius:var(--lb-r-sm);border:1px solid var(--lb-border);background:radial-gradient(80% 80% at 50% 38%,hsl(220 16% 15%),hsl(220 18% 9%));display:flex;align-items:center;justify-content:center;position:relative;transition:transform .2s,box-shadow .2s,border-color .2s;overflow:hidden;cursor:pointer;padding:0}
.rsk-lb-eslot:hover{border-color:hsl(0 80% 50% / .7);transform:translateY(-3px);box-shadow:0 8px 22px hsl(0 80% 50% / .22)}
.rsk-lb-eslot img{width:100%;height:100%;object-fit:contain;padding:18px 10px 12px}
.rsk-lb-es-empty{display:flex;flex-direction:column;align-items:center;gap:5px;color:var(--lb-fg-muted)}
.rsk-lb-es-empty svg{width:22px;height:22px}
.rsk-lb-es-empty span{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.rsk-lb-es-tag{position:absolute;top:6px;left:8px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--lb-fg-2);z-index:2}
.rsk-lb-es-price{position:absolute;bottom:5px;right:8px;font-size:10px;font-family:var(--lb-mono);color:var(--lb-green);font-weight:700;z-index:2;background:hsl(220 22% 5% / .72);padding:2px 6px;border-radius:5px}

.rsk-lb-stage{position:relative;width:248px;border-radius:var(--lb-r);border:1px solid var(--lb-border-soft);background:radial-gradient(80% 70% at 50% 30%,hsl(210 30% 18% / .6),hsl(220 22% 6%));overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center}
.rsk-lb-equip-label{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:3;background:hsl(220 18% 10% / .9);border:1px solid var(--lb-red);color:#fff;font-family:var(--lb-head);font-weight:700;font-size:14px;letter-spacing:.1em;padding:6px 18px;border-radius:var(--lb-r-sm);box-shadow:0 0 14px hsl(0 80% 50% / .35);white-space:nowrap}
.rsk-lb-agent{position:relative;z-index:2;max-width:100%;max-height:400px;width:auto;object-fit:contain;padding:48px 12px 12px}
/* picked agents are bust portraits (Steam has no full-body render) — fade the
   hard bottom edge into the stage so it reads as an intentional portrait. */
.rsk-lb-agent.is-portrait{max-height:360px;padding:40px 12px 0;-webkit-mask-image:linear-gradient(to bottom,#000 74%,transparent 100%);mask-image:linear-gradient(to bottom,#000 74%,transparent 100%)}

/* weapon columns */
.rsk-lb-cols{flex:1;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;min-width:0}
.rsk-lb-wcol{display:flex;flex-direction:column;gap:9px;min-width:0}
.rsk-lb-wcol-head{display:flex;align-items:center;gap:7px;padding-bottom:2px}
.rsk-lb-funnel{width:13px;height:13px;color:var(--lb-red);flex-shrink:0}
.rsk-lb-wcol-head h3{font-family:var(--lb-head);font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--lb-fg-2);margin:0;white-space:nowrap}
.rsk-lb-wcol-sub{font-family:var(--lb-head);font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--lb-fg-muted);margin:6px 0 1px;display:flex;align-items:center;gap:6px}
.rsk-lb-wcol-sub::before{content:"";width:13px;height:1px;background:var(--lb-border)}
.rsk-lb-wcol-sub::after{content:"";flex:1;height:1px;background:var(--lb-border)}

/* weapon slot */
.rsk-lb-wslot{position:relative;border-radius:var(--lb-r-sm);border:1px solid var(--lb-border);background:radial-gradient(80% 80% at 50% 38%,hsl(220 16% 15%),hsl(220 18% 9%));aspect-ratio:16/9;overflow:hidden;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s,border-color .2s;cursor:pointer;display:block;width:100%;padding:0;text-align:left}
.rsk-lb-wslot:hover{transform:translateY(-3px);border-color:hsl(0 80% 50% / .7);box-shadow:0 8px 22px hsl(0 80% 50% / .22)}
.rsk-lb-wslot.is-starter{border-color:hsl(45 90% 55% / .45);box-shadow:inset 0 0 0 1px hsl(45 90% 55% / .12)}
.rsk-lb-ws-img{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:9px 9px 8px}
.rsk-lb-ws-img img{max-width:100%;max-height:100%;object-fit:contain;filter:drop-shadow(0 3px 6px hsl(0 0% 0% / .55))}
.rsk-lb-ws-price{position:absolute;top:5px;right:6px;font-family:var(--lb-mono);font-weight:700;font-size:10px;color:var(--lb-green);z-index:3;background:hsl(220 22% 5% / .72);padding:2px 6px;border-radius:5px;backdrop-filter:blur(2px)}
.rsk-lb-ws-clear{position:absolute;top:5px;left:6px;z-index:4;width:18px;height:18px;border-radius:50%;background:hsl(220 18% 6% / .8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;line-height:1;opacity:0;transition:opacity .15s}
.rsk-lb-wslot:hover .rsk-lb-ws-clear,.rsk-lb-eslot:hover .rsk-lb-ws-clear{opacity:1}
.rsk-lb-ws-over{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:14px 8px 7px 8px;background:linear-gradient(to top,hsl(220 24% 4% / .92) 30%,transparent);transform:translateY(101%);transition:transform .2s ease;display:flex;flex-direction:column;gap:1px}
.rsk-lb-wslot:hover .rsk-lb-ws-over{transform:translateY(0)}
.rsk-lb-ws-name{font-family:var(--lb-head);font-weight:700;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--lb-fg-muted);line-height:1.1}
.rsk-lb-ws-skin{font-size:11px;font-weight:600;color:var(--lb-fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
.rsk-lb-ws-bar{position:absolute;left:0;right:0;bottom:0;height:3px;z-index:4}
.rsk-lb-wslot.is-empty{background:linear-gradient(160deg,hsl(220 14% 11%),hsl(220 16% 8%));border-style:dashed}
.rsk-lb-ws-add{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--lb-fg-muted)}
.rsk-lb-ws-add svg{width:18px;height:18px}
.rsk-lb-ws-wn{font-family:var(--lb-head);font-weight:700;font-size:11px;letter-spacing:.05em;text-transform:uppercase}
.rsk-lb-ws-ad{font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;opacity:.7}
.rsk-lb-wslot.is-empty:hover .rsk-lb-ws-add{color:var(--lb-red)}

/* loading state */
.rsk-lb.is-loading{opacity:.55;pointer-events:none;transition:opacity .15s}

/* ───────── Picker modal ───────── */
.rsk-lb-modal{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:24px}
.rsk-lb-modal[hidden]{display:none}
.rsk-lb-modal-bg{position:absolute;inset:0;background:hsl(220 25% 3% / .75);backdrop-filter:blur(4px)}
.rsk-lb-modal-box{position:relative;width:min(620px,100%);max-height:84vh;display:flex;flex-direction:column;background:linear-gradient(145deg,hsl(220 18% 12%),hsl(220 18% 8%));border:1px solid var(--lb-border);border-radius:var(--lb-r-lg);box-shadow:0 30px 80px hsl(0 0% 0% / .6),0 0 40px hsl(0 80% 50% / .12);overflow:hidden}
.rsk-lb-modal-head{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--lb-border);flex:0 0 auto}
.rsk-lb-modal-head strong{font-family:var(--lb-head);font-weight:700;font-size:18px;letter-spacing:.02em;color:#fff;white-space:nowrap}
.rsk-lb-modal-head strong span{color:var(--lb-red)}
.rsk-lb-modal-search{flex:1;min-width:0;padding:9px 12px;border-radius:var(--lb-r-sm);border:1px solid var(--lb-border);background:var(--lb-bg);color:var(--lb-fg);font-family:inherit;font-size:14px}
.rsk-lb-modal-search:focus{outline:none;border-color:hsl(0 80% 50% / .6)}
.rsk-lb-modal-x{width:32px;height:32px;flex-shrink:0;border-radius:var(--lb-r-sm);border:1px solid var(--lb-border);background:var(--lb-elev);color:var(--lb-fg-2);font-size:20px;line-height:1;cursor:pointer}
.rsk-lb-modal-x:hover{border-color:var(--lb-red);color:var(--lb-fg)}
.rsk-lb-modal-grid{flex:1 1 auto;min-height:0;overflow-y:auto;padding:14px 18px;display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:max-content;align-content:start;gap:10px}
.rsk-lb-pick-img{flex:0 0 auto}
@media(max-width:620px){.rsk-lb-modal-grid{grid-template-columns:repeat(2,1fr)}}
.rsk-lb-pick{display:flex;flex-direction:column;border-radius:var(--lb-r-sm);border:1px solid var(--lb-border);background:var(--lb-elev);overflow:hidden;transition:all .18s;text-align:left;cursor:pointer;padding:0}
.rsk-lb-pick:hover{border-color:hsl(0 80% 50% / .6);transform:translateY(-2px)}
.rsk-lb-pick.is-sel{border-color:var(--lb-red);box-shadow:0 0 0 1px var(--lb-red)}
.rsk-lb-pick-img{height:84px;display:flex;align-items:center;justify-content:center;padding:8px;background:radial-gradient(70% 70% at 50% 40%,hsl(220 16% 16%),hsl(220 18% 9%))}
.rsk-lb-pick-img img{max-width:100%;max-height:100%;object-fit:contain}
.rsk-lb-pick-img svg{width:30px;height:30px;color:var(--lb-fg-muted)}
.rsk-lb-pick-b{padding:8px 10px;display:flex;flex-direction:column;gap:2px}
.rsk-lb-pick-n{font-weight:600;font-size:13px;color:var(--lb-fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rsk-lb-pick-p{font-family:var(--lb-mono);font-weight:700;font-size:12px;color:var(--lb-green)}
.rsk-lb-pick.is-vanilla .rsk-lb-pick-p{color:var(--lb-fg-muted)}
.rsk-lb-modal-foot{padding:12px 18px;text-align:center;border-top:1px solid var(--lb-border);flex:0 0 auto}
.rsk-lb-more{cursor:pointer;padding:9px 18px;border-radius:var(--lb-r-sm);border:1px solid var(--lb-border);background:transparent;color:#fff;font-weight:600}
.rsk-lb-more:hover{border-color:var(--lb-red)}
.rsk-lb-modal-empty{grid-column:1/-1;text-align:center;color:var(--lb-fg-muted);padding:30px;font-size:13px}

/* ───────── Toast ───────── */
.rsk-lb-toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--lb-elev-2);border:1px solid hsl(145 65% 42% / .5);color:var(--lb-fg);padding:12px 20px;border-radius:var(--lb-r);font-weight:600;font-size:14px;box-shadow:0 12px 40px hsl(0 0% 0% / .5);opacity:0;pointer-events:none;transition:all .3s;z-index:100000}
.rsk-lb-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ───────── Intro (above builder) ───────── */
.rsk-lb-intro{max-width:780px;margin:0 0 8px}
.rsk-lb-intro p{color:var(--lb-fg-2);font-size:1rem;line-height:1.7;margin:0 0 12px}
.rsk-lb-intro p:last-child{margin-bottom:0}

/* ───────── SEO content + FAQ (below builder) ───────── */
.rsk-lb-seo{margin-top:48px}
.rsk-lb-seo .rsk-seo-inner{max-width:820px}
.rsk-lb-seo h2{font-family:var(--lb-head);font-weight:700;font-size:clamp(1.4rem,2.4vw,1.85rem);letter-spacing:-.01em;color:var(--lb-fg);margin:34px 0 12px}
.rsk-lb-seo h2:first-child{margin-top:0}
.rsk-lb-seo h3{font-family:var(--lb-head);font-weight:700;font-size:1.12rem;letter-spacing:.01em;color:var(--lb-fg);margin:24px 0 8px}
.rsk-lb-seo p{color:var(--lb-fg-2);font-size:1rem;line-height:1.7;margin:0 0 12px}
.rsk-lb-seo strong{color:var(--lb-fg);font-weight:600}
.rsk-lb-seo ul{margin:0 0 14px;padding-left:0;list-style:none}
.rsk-lb-seo ul li{position:relative;color:var(--lb-fg-2);font-size:1rem;line-height:1.6;padding:0 0 0 20px;margin:0 0 8px}
.rsk-lb-seo ul li::before{content:"";position:absolute;left:2px;top:.62em;width:6px;height:6px;border-radius:50%;background:var(--lb-red)}
/* FAQ uses the theme's global accordion design (.rs-faq-item / .rs-faq-trigger / .rs-faq-answer). */
.rsk-lb-faq{max-width:760px;margin-top:8px}

/* ───────── Responsive ───────── */
@media(max-width:1080px){
  .rsk-lb-cols{grid-template-columns:repeat(2,1fr)}
  .rsk-lb-panel-inner,.rsk-lb-panel-inner.t-side{flex-direction:column;align-items:center}
  .rsk-lb-figure{flex-direction:row;width:100%;justify-content:center}
  .rsk-lb-stage{width:min(280px,60vw)}
}
@media(max-width:680px){
  .rsk-lb-panel{padding:16px}
  .rsk-lb-cols{grid-template-columns:repeat(2,1fr);gap:10px}
  .rsk-lb-rail{flex-direction:row;flex-wrap:wrap;justify-content:center}
  .rsk-lb-figure{flex-direction:column;align-items:center}
  .rsk-lb-total{margin-left:0}
}
