/*
  Sidebar, ranks and accuracy module.
  Extracted from the former modules/30-market-economy.css; keep after 31-economy-widgets.css.
*/

/* === Sidebar auto-hide (Stage 2.6.4) === */
.grid > aside{
  transition: opacity .18s ease, transform .18s ease;
  will-change: opacity, transform;
}
html.sidebar-hidden .grid,
body.sidebar-hidden .grid{
  grid-template-columns: 1fr !important;
}
html.sidebar-hidden .grid > aside,
body.sidebar-hidden .grid > aside{
  display: none !important;
  opacity: 0 !important;
  transform: translateX(14px) !important;
  pointer-events: none !important;
  width: 0 !important;
  max-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

/* === Sidebar drawer (Stage 2.6.5) === */
html.sidebar-lock, html.sidebar-lock body{ overflow: hidden; }

.sidebarOverlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease;
  z-index: 45;
}

@media (max-width: 980px){
  html.sidebar-drawer-enabled .grid{ grid-template-columns: 1fr !important; }

  html.sidebar-drawer-enabled .grid > aside{
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(420px, 92vw);
    max-width: 92vw;
    padding: 14px;
    margin: 0;
    overflow: auto;
    background: var(--bg800);
    border-left: 1px solid var(--border);
    box-shadow: -14px 0 30px rgba(0,0,0,.35);
    transform: translateX(110%);
    opacity: 1;
    pointer-events: auto;
    z-index: 50;
  }

  html.sidebar-drawer-enabled.sidebar-drawer-open .grid > aside{ transform: translateX(0); }
  html.sidebar-drawer-enabled.sidebar-drawer-open .sidebarOverlay{ opacity: 1; pointer-events: auto; }

  /* When auto-hide class is present on mobile, do not hard-zero the drawer */
  html.sidebar-drawer-enabled.sidebar-hidden .grid > aside{
    width: min(420px, 92vw) !important;
    max-width: 92vw !important;
    padding: 14px !important;
    border-left: 1px solid var(--border) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    margin: 0 !important;
    overflow: auto !important;
    transform: translateX(110%) !important;
  }
}

/* === Sidebar drawer on mobile (Stage 2.6.5) === */
html.sidebar-lock{ overflow: hidden; }

.sidebarOverlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease;
  z-index: 90;
}

html.sidebar-drawer-enabled .sidebarOverlay[aria-hidden="false"]{
  opacity: 1;
  pointer-events: auto;
}

@media (max-width: 980px){
  /* Force the right panel to be off-canvas on mobile */
  html.sidebar-drawer-enabled .grid{
    grid-template-columns: 1fr !important;
  }
  html.sidebar-drawer-enabled .grid > aside{
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(420px, 92vw);
    max-width: 92vw;
    padding: 16px;
    margin: 0;
    overflow: auto;
    background: rgba(17, 19, 24, .92);
    border-left: 1px solid var(--border);
    box-shadow: -18px 0 60px rgba(0,0,0,.35);
    transform: translateX(110%);
    opacity: 1;
    pointer-events: auto;
    z-index: 100;
  }
  html.sidebar-drawer-enabled.sidebar-drawer-open .grid > aside{
    transform: translateX(0);
  }
  /* When drawer mode is enabled, ignore desktop auto-hide width=0 tweaks */
  html.sidebar-drawer-enabled.sidebar-hidden .grid > aside{
    width: min(420px, 92vw) !important;
    max-width: 92vw !important;
    padding: 16px !important;
    overflow: auto !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    border: 0 !important;
    border-left: 1px solid var(--border) !important;
  }
}

/* Р СћР С›Р Сџ Р С—Р С• РЎР‚Р С•Р В»РЎРЏР С */
.roleGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:12px 0 14px}
.roleCard{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);background:var(--bg800);border-radius:14px;cursor:pointer;text-align:left;color:var(--text);appearance:none}
.roleCard:focus{outline:none}
.roleCard:focus-visible{outline:2px solid var(--focus-ring); outline-offset:2px; box-shadow:0 0 0 4px var(--focus-ring-soft);}
.roleCard::-moz-focus-inner{border:0}
.roleCard:hover{border-color:rgba(255,255,255,.18)}
.roleCard.is-active{border-color:var(--accent);box-shadow:0 0 0 1px rgba(196,59,47,.35) inset}
.roleCard__icon{width:34px;height:34px;flex:0 0 34px;object-fit:contain;filter:drop-shadow(0 2px 10px rgba(0,0,0,.35))}
.roleCard__icon--fallback{border-radius:10px;background:rgba(255,255,255,.08)}
.roleCard__label{font-weight:800;font-size:14px;line-height:1.1}
.roleCard__desc{margin-top:2px;font-size:12px;color:var(--text700);line-height:1.2}

/* Premium Top UI */
.topRole{margin-top:8px;padding:14px;border:1px solid var(--border);background:var(--surface);border-radius:18px;box-shadow: var(--shadow);}
.topRole__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.topRole__kicker{font-weight:800;font-size:12px;color:var(--text700);letter-spacing:.02em;text-transform:uppercase}
.topRole__name{font-weight:900;font-size:22px;line-height:1.1;margin-top:2px}
.topRole__meta{margin-top:6px;font-size:12px;color:var(--text700)}
.topRole__actions{display:flex;gap:8px;align-items:center}

.topSearch{position:relative;display:flex;align-items:center;gap:6px;min-width:220px;max-width:320px}
.topSearch__input{width:100%;padding-right:34px;}
.topSearch__input::placeholder{ color: var(--text700); }
.topSearch__input:focus{ box-shadow: 0 0 0 4px var(--focus-ring-soft); }
.topSearch__clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:10px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.06);color:var(--text);cursor:pointer}
.topSearch__clear:hover{background:rgba(255,255,255,.10)}

.topRole__podium{display:grid;grid-template-columns:1fr 1.15fr 1fr;gap:10px;align-items:stretch;margin-top:10px}
.podiumCard{position:relative;display:flex;align-items:center;gap:12px;padding:12px 12px 12px 66px;border:1px solid var(--border);background:rgba(0,0,0,.22);border-radius:16px;cursor:pointer;min-height:84px;overflow:hidden}
.podiumCard:hover{border-color:rgba(255,255,255,.18)}
.podiumCard__rank{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-weight:1000;font-size:34px;line-height:1;letter-spacing:-.6px;color:rgba(255,255,255,.18);text-shadow:0 10px 24px rgba(0,0,0,.55);pointer-events:none}
.podiumCard--pos1 .podiumCard__rank{color:rgba(var(--top1-rgb),.95);text-shadow:0 10px 26px rgba(0,0,0,.55),0 0 22px rgba(var(--top1-rgb),.26)}
.podiumCard--pos2 .podiumCard__rank{color:rgba(var(--top2-rgb),.92);text-shadow:0 10px 26px rgba(0,0,0,.55),0 0 22px rgba(var(--top2-rgb),.22)}
.podiumCard--pos3 .podiumCard__rank{color:rgba(var(--top3-rgb),.93);text-shadow:0 10px 26px rgba(0,0,0,.55),0 0 22px rgba(var(--top3-rgb),.24)}
.podiumCard--pos1{box-shadow:0 0 0 1px rgba(var(--top1-rgb),.14) inset, 0 12px 36px rgba(0,0,0,.32)}
.podiumCard--pos2{box-shadow:0 0 0 1px rgba(var(--top2-rgb),.12) inset, 0 12px 36px rgba(0,0,0,.32)}
.podiumCard--pos3{box-shadow:0 0 0 1px rgba(var(--top3-rgb),.13) inset, 0 12px 36px rgba(0,0,0,.32)}
.podiumCard__ava{width:48px;height:48px;border-radius:14px;overflow:hidden;flex:0 0 48px;box-shadow:0 12px 28px rgba(0,0,0,.35)}
.podiumCard__ava img{width:100%;height:100%;object-fit:cover}
.podiumCard__name{font-weight:900;font-size:14px;line-height:1.1}
.podiumCard__id{font-size:11px;color:var(--text700)}
.podiumCard__sub{display:flex;align-items:center;gap:10px;justify-content:space-between}
.podiumCard__val{margin-left:auto;text-align:right}
.podiumCard__num{font-weight:950;font-size:20px;line-height:1}
.podiumCard__lbl{font-size:11px;color:var(--text700);margin-top:3px}
.podiumCard--first{transform:translateY(-6px);border-color:rgba(196,59,47,.55);box-shadow:0 0 0 1px rgba(196,59,47,.25) inset, 0 20px 60px rgba(0,0,0,.35)}
.podiumCard--first::after{content:"";position:absolute;inset:-60px -40px auto auto;width:160px;height:160px;background:radial-gradient(circle, rgba(196,59,47,.25), transparent 60%);pointer-events:none}

.topRole__list{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.statsEmptyState{
  min-height:220px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.statsEmptyState .state__body{
  max-width:420px;
  margin:0 auto;
}
.rankRow{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--border);background:rgba(0,0,0,.18);border-radius:14px;cursor:pointer}
.rankRow:hover{border-color:rgba(255,255,255,.18)}
.rankRow__pos{width:26px;text-align:center;font-weight:950;font-size:12px;color:var(--text700)}
.rankRow__ava{width:34px;height:34px;border-radius:12px;overflow:hidden;flex:0 0 34px}
.rankRow__ava img{width:100%;height:100%;object-fit:cover}
.rankRow__name{font-weight:850;font-size:13px;line-height:1.1}
.rankRow__id{font-size:11px;color:var(--text700)}
.rankRow__val{margin-left:auto;text-align:right}
.rankRow__num{font-weight:950}
.rankRow__bar{height:4px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;margin-top:6px}
.rankRow__bar > i{display:block;height:100%;background:rgba(196,59,47,.55)}


/* Stats: tiles under podium */
.rankTiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.prSentinel{height:1px;width:100%;opacity:0;pointer-events:none;grid-column:1/-1;flex-basis:100%}
.vgSpacer{height:0;width:100%;opacity:0;pointer-events:none;grid-column:1/-1;}
.rankTile{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--border);background:rgba(0,0,0,.18);border-radius:14px;cursor:pointer;text-align:left}
.rankTile:hover{border-color:rgba(255,255,255,.18)}
.rankTile__pos{font-weight:950;font-size:12px;color:var(--text700);padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.06)}
.rankTile__ava{width:34px;height:34px;border-radius:12px;overflow:hidden;flex:0 0 34px}
.rankTile__ava img{width:100%;height:100%;object-fit:cover}
.rankTile__body{min-width:0;flex:1}
.rankTile__name{font-weight:850;font-size:13px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rankTile__id{font-size:11px;color:var(--text700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rankTile__sub{display:flex;align-items:center;gap:10px;justify-content:space-between}
.rankTile__val{width:92px;text-align:right}
.rankTile__num{font-weight:950}
.rankTile__bar{height:4px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;margin-top:6px}
.rankTile__bar > i{display:block;height:100%;background:rgba(196,59,47,.55)}

.likeMini{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--text700);padding:2px 8px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);flex:0 0 auto}
.likeMini b{font-weight:950;color:var(--text)}
.likeMini--podium{margin-left:auto}

.likeMini--btn{cursor:pointer;user-select:none;transition:transform .12s ease,background .12s ease,border-color .12s ease,opacity .12s ease}
.likeMini--btn:hover{transform:translateY(-1px)}
.likeMini--btn.is-on{background:rgba(196,59,47,.12);border-color:rgba(196,59,47,.26);color:var(--text)}
.likeMini--btn.is-on b{color:var(--text)}
.likeMini--btn.is-disabled{cursor:not-allowed;opacity:.55;transform:none}
.likeMini--btn.is-loading{opacity:.7}
.likeMini--tiny{font-size:10px;padding:2px 6px;gap:5px}
.telemetryRow .likeMini--tiny,.homeOnlineRow .likeMini--tiny{margin-left:auto}


.topRole__more{display:flex;justify-content:center;margin-top:12px}

@media (max-width: 720px){
  .topRole__podium{grid-template-columns:1fr;}
  .podiumCard--first{transform:none}
  .podiumCard{padding-left:56px;min-height:76px}
  .podiumCard__rank{left:14px;font-size:28px}
  .podiumCard__ava{width:44px;height:44px;border-radius:13px;flex-basis:44px}

  .topSearch{min-width:160px;max-width:100%}
}


/* --- Stage3 Premium Top Roles: ensure readable text regardless of custom CSS --- */
.topRoles, .topRoles * { color: var(--text) !important; }
.topRoles .muted, .topRoles .hint { color: var(--text700) !important; }
.topRoles a { color: var(--text) !important; }



/* --- Stage3 Player Tabs: force readable button text even if browser/override styles --- */
.playerPage{ color: var(--text); }
.playerTabs .playerTabBtn{ color: var(--text) !important; }




/* ---------------------------------
   Accuracy tab v2 (HitRate images) РІР‚вЂќ alignment
----------------------------------*/
.playerAccuracy--v2{
  grid-template-columns: minmax(560px, 1fr) minmax(420px, 520px);
  align-items: start;
}
.playerAccuracy--v2 .accuracyCard{ min-width: 0; }
.playerAccuracy--v2 .accMeter{ --size: 180px; }

/* When the right block is removed, let the left card occupy full width */
.playerAccuracy--v2 .accuracyCard--left{ grid-column: 1 / -1; }

/* Compact overall accuracy pill (we intentionally don't show shots/hits/misses) */
.accTop{ display:flex; justify-content:flex-end; margin-bottom: 10px; }
.accPill{
  display:inline-flex;
  align-items:baseline;
  gap:10px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.12);
  box-shadow: 0 10px 30px rgba(0,0,0,0.20);
}
.accPill b{ font-weight:1100; font-size:14px; }
.accPill span{ font-weight:900; font-size:12px; opacity:.8; text-transform:uppercase; letter-spacing:.4px; }

.accViz{
  position: relative;
  border: 1px solid rgba(255,255,255,0.08);
  background: radial-gradient(110% 120% at 50% 0%, rgba(255,255,255,0.06), rgba(0,0,0,0.12));
  border-radius: 18px;
  padding: 10px;
  overflow: hidden;
  /* Keep the preview size consistent with admin editor to avoid \"different window\" effect */
  max-width: 720px;
  margin: 0 auto;
}
.accViz__img{
  width: 100%;
  height: auto;
  max-height: 290px;
  object-fit: contain;
  display: block;
  margin: 0 auto;
  filter: drop-shadow(0 8px 24px rgba(0,0,0,0.45));
}

/* Accuracy: overlay labels (no red frames; positions are configurable via admin) */
.accViz{
  position: relative;
  /* defaults (can be overridden by CSS variables on this element) */
  --acc-head-top: 9%;
  --acc-head-left: 62%;
  --acc-head-width: 32%;
  --acc-chest-top: 46%;
  --acc-chest-left: 65%;
  --acc-chest-width: 29%;
  --acc-legs-top: 78%;
  --acc-legs-left: 65%;
  --acc-legs-width: 29%;
  --acc-arms-top: 22%;
  --acc-arms-left: 6%;
  --acc-arms-width: 30%;
  --acc-stomach-top: 46%;
  --acc-stomach-left: 6%;
  --acc-stomach-width: 30%;
}

/* Plain text labels (no border) */
.accBox{
  position: absolute;
  display: flex;
  align-items: baseline;
  justify-content: flex-end;
   gap: 6px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: .3px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.92);
  text-shadow: 0 1px 10px rgba(0,0,0,0.85), 0 1px 1px rgba(0,0,0,0.85);
  pointer-events: none;
  flex-wrap: nowrap;
  white-space: nowrap;
}
.accBox span{ opacity:.92; }
.accBox b{ font-weight: 1100; opacity: .98; }
.accBox--arms, .accBox--stomach{ justify-content:flex-start; }
.accBox--arms b, .accBox--stomach b{ margin-right:0; }


/* Positions controlled by CSS variables */
.accBox--head{ top: var(--acc-head-top); left: var(--acc-head-left); width: var(--acc-head-width); }
.accBox--chest{ top: var(--acc-chest-top); left: var(--acc-chest-left); width: var(--acc-chest-width); }
.accBox--legs{ top: var(--acc-legs-top); left: var(--acc-legs-left); width: var(--acc-legs-width); }
.accBox--arms{ top: var(--acc-arms-top); left: var(--acc-arms-left); width: var(--acc-arms-width); }
.accBox--stomach{ top: var(--acc-stomach-top); left: var(--acc-stomach-left); width: var(--acc-stomach-width); }


.accList{ margin-top: 12px; }
.accStatTiles{ margin-top: 14px; }
.accHint{ margin-top: 12px; opacity: .8; }

@media (max-width: 1100px){
  .playerAccuracy--v2{ grid-template-columns: 1fr; }
  .accViz__img{ max-height: 320px; }
}


/* Accuracy: widen KPI tiles so labels/values never clip */
.accStatTiles{
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 12px;
}
.accStatTiles .statTile{
  padding: 12px 14px;
  min-height: 60px;
}
.accStatTiles .statTile__value{
  font-size: 16px;
  white-space: nowrap;
}
.accStatTiles .statTile__label{
  white-space: nowrap;
}




