  /************************************************************
   * NASCAR Pool 2026 — Player Portal CSS
   ************************************************************/

  /* ==========================================================
     Base + theme tokens
     ========================================================== */

  html{
    scrollbar-gutter: stable;
  }
  @supports not (scrollbar-gutter: stable){
    html{ overflow-y: scroll; }
  }

  :root{
    --cardA: 0.78;
    --microA: 0.72;    --stroke:#e5e7eb;    --nav:#000000;    --black:#000000;    --bg:#020b12;
    --card:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
    --text:#ffffff;
    --muted:rgba(255,255,255,.72);
    --line:rgba(255,255,255,.12);

    --blue:#007AC2;
    --red:#E4002B;    --yellow:#FFD659;    --green:#4DD21D;
    --greenfade:#4DD21DBF;

    --pad:12px;
    --radius:16px;
    --radius2:14px;

    --h2:24px;
    --big:20px;
    --body:14px;

    --micro:8px;

    --mmPad:6px;
    --mmGap:6px;
    --mmHeaderGap:4px;

    --vvb:0px;
    --navH:75px;

    --wmShift:0px;

    --glassBlue14: rgba(0,122,194,.14);
    --glassBlue20: rgba(0,122,194,.20);
    --glassBlue22: rgba(0,122,194,.22);
    --glassBlue42: rgba(0,122,194,.42);
    --glassBlue55: rgba(0,122,194,.55);

    --white06: rgba(255,255,255,.06);
    --white10: rgba(255,255,255,.10);
    --white12: rgba(255,255,255,.12);
    --white14: rgba(255,255,255,.14);

    --black75: rgba(0,0,0,.75);
    --winnerGreen: #16a34a;
  }

  *{ box-sizing:border-box; }

  body{
    font-size: var(--body);
    font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Helvetica,Arial,sans-serif;
    padding: var(--pad);
    max-width: 808px;
    margin: 0 auto;
    background: var(--bg);
    color: var(--text);
    padding-bottom: calc(var(--navH) + env(safe-area-inset-bottom) + var(--vvb));
    position: relative;
    overflow-x: hidden;
  }

  h2{ margin:0 0 6px 0; font-size: var(--h2); letter-spacing:-0.3px; }

  body::before{
    content:"";
    position: fixed;
    inset: 0;
    background-image: url("nascar-logo.png");
    background-repeat: no-repeat;
    background-size: 300px;
    background-position: 50% calc(50% + var(--wmShift));
    opacity: 0.2;
    pointer-events: none;
    z-index: 0;
  }

  /* ==========================================================
     Shared layout + utility pieces
     ========================================================== */

  .sub{
    color: var(--muted);
    font-size: 13px;
    margin-bottom: 6px;
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
  }

  .pill{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:6px 8px;
    border-radius:999px;
    background: rgba(255,214,89,.14);
    border:1px solid rgba(255,214,89,.40);
    color: var(--yellow);
    font-size:12px;
    font-weight:800;
  }

  .card{
    position: relative;
    z-index: 3;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 12px;
    margin: 6px 0;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
  }

  button{
    border: 1px solid var(--line);
    cursor:pointer;
    font-weight:700;
    border-radius: 12px;
    padding: 6px 6px;
    font-size: 12px;
  }
  button.primary{
    border: 1px solid rgba(255,255,255,.32);
    background:#020b12;
    color:#fff;
    margin-top: 3px;
  }
  button.secondary{ background:#334155; color:#fff; }
  button.topactions{
    background: rgba(228, 0, 43, .4);
    color: var(--text);
    border: 1px solid var(--line);
  }
  button:disabled{ opacity:.55; cursor:not-allowed; }

  label{
    display:block;
    font-size:13px;
    margin:10px 0 6px;
    color: rgba(255,255,255,.9);
  }
  select, input{
    width:fit-content;
    font-size:14px;
    color: var(--text);
    padding: var(--mmPad);
    border-radius: 12px;
    border:1px solid var(--line);
    background: var(--glassBlue14);
  }

  .big{ font-size: var(--big); font-weight:900; letter-spacing:-0.2px; }
  .muted{ color: var(--muted); font-size:13px; }

  .status{ margin-top:10px; font-size: var(--body); white-space: pre-wrap; }
  #duesStatus{ white-space: normal; }
  #standingsArea{ white-space: normal; }

  .titleRow{
    display:flex;
    align-items:baseline;
    justify-content:space-between;
    gap:8px;
    position:relative;
    z-index:3;
  }

  .titleRow h2{ margin:0; }

  #welcomeName{
    text-align:right;
    font-weight:800;
    color: var(--muted);
    font-size:13px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 52%;
  }

  .subRow{
    position:relative;
    z-index:3;
  }

  .subRowRight{
    margin-left:auto;
    display:flex;
    gap:8px;
    align-items:center;
    flex-wrap:wrap;
    justify-content:flex-end;
  }

  .topBar{
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
    position:relative;
    z-index:3;
  }

  .topBarRight{
    margin-left:auto;
    display:flex;
    gap:8px;
    align-items:center;
  }

  .spoilerToggle{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:6px 10px;
    height:30px;
    border-radius:12px;
    background: rgba(0,122,194,.16);
    border:1px solid var(--line);
    color: var(--text);
    cursor:pointer;
  }

  .spoilerToggle .label{
    font-weight:900;
  }

  .spoilerToggle .track{
    position:relative;
    width:54px;
    height:20px;
    border-radius:999px;
    background: rgba(0,0,0,.35);
    border:1px solid var(--line);
    overflow:hidden;
  }

  .spoilerToggle .thumb{
    position:absolute;
    top:2px;
    left:3px;
    width:14px;
    height:14px;
    border-radius:999px;
  }

  .spoilerToggle .state{
    color: var(--muted);
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    font-weight:800;
    font-size:11px;
    letter-spacing:.3px;
    pointer-events:none;
    padding:0 6px;
    line-height:1;
  }

  .spoilerToggle[aria-checked="true"] .state{
    justify-content:flex-start;
    padding-right:20px;
  }

  .spoilerToggle[aria-checked="false"] .state{
    justify-content:flex-end;
    padding-left:20px;
  }
  
  .buschPopup[hidden]{
  display:none !important;
}

.buschPopup{
  position:fixed;
  inset:0;
  z-index:10000;
}

.buschPopupBackdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}

.buschPopupCard{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  width:min(92vw, 520px);
  max-height:88vh;
  padding:12px;
  border-radius:18px;
  background:rgba(2,11,18,.95);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 20px 60px rgba(0,0,0,.45);
}

.buschPopupImg{
  display:block;
  width:100%;
  height:auto;
  max-height:78vh;
  object-fit:contain;
  border-radius:12px;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
}

.buschPopupClose{
  position:absolute;
  top:8px;
  right:8px;
  width:32px;
  height:32px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.08);
  color:#fff;
  font-size:20px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}

.buschLogoTrigger,
.buschPopup,
.buschPopupCard,
.buschPopupImg,
.buschPopupClose{
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

  /* ==========================================================
     Current race / matchup view
     ========================================================== */

  .raceHeaderRow{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:6px;
    line-height:1;
    margin-top:0;
  }
  #currentHeader{ font-size: var(--big); font-weight:900; letter-spacing:-0.2px; margin-bottom:0;}
  #currentSub{ font-size:13px; color: var(--muted); margin-top:0; line-height:1}
  
  .matchupCard{
    border:1px solid var(--line);
    border-radius: var(--radius2);
    background: var(--glassBlue14);
    padding: var(--micro);
    margin-top: 6px;
  }

  .matchupCard.youRow{
    background: var(--glassBlue42);
    border: 2px solid var(--glassBlue55);
  }
  .matchupRow{
    display:grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 10px;
    align-items:center;
  }

  .side{
    display:flex;
    flex-direction:column;
    gap:2px;
    min-width:0;
  }
  .side.right{ text-align:right; align-items:flex-end; }

  .pName{
    font-weight:900;
    font-size:15px;
    line-height:1.1;
    margin:0;
    position:relative;
    display:inline-block;
    overflow:visible;
  }

  .nameWrap{
    position:relative;
    display:inline-block;
    max-width:100%;
    overflow:visible;
    vertical-align:middle;
  }

  .nameText{
    display:inline-block;
    max-width:100%;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    vertical-align:middle;
  }

  .pMeta{
    font-size:12px;
    color: var(--yellow);
    line-height:1.2;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .driverWinner{
    color: var(--winnerGreen);
    font-weight: 800;
  }

  .driverWinner .winFlag{
    display:inline-block;
    margin-right: 4px;
    font-size: 12px;
    line-height: 1;
    transform: translateY(-1px);
    opacity: 0.95;
  }

  .vsBadge{
    font-weight:800;
    font-size:10px;
    padding:2px 2px;
    border-radius:5px;
    background:#e5e7eb;
    color:#111;
    letter-spacing:0.4px;
  }

  .winPill{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:2px 6px;
    border-radius:999px;
    font-size:10px;
    font-weight:900;
    letter-spacing:.4px;
    color: var(--winnerGreen);
    border:1px solid rgba(22,163,74,.35);
    background: rgba(22,163,74,.12);
    position:absolute;
    top:50%;
    left:100%;
    transform: translate(6px, -50%);
    white-space:nowrap;
    margin:0;
  }

  @media (min-width:700px){
    .side.right .nameWrap .winPill{
      left:auto;
      right:100%;
      transform: translate(-6px, -50%);
    }
  }
  /* ==========================================================
     Responsive rules
     ========================================================== */

  @media (max-width:700px){
    .matchupRow{ grid-template-columns:1fr; gap:6px; text-align:center; }
    .side.right{ text-align:center; align-items:center; }
    .vsBadge{ margin:2px auto; }
    .pMeta{ white-space:normal; }
    #welcomeName{ max-width: 100%; }
  }

  #bracketTournamentPick{
    width:auto;
    min-width:140px;
    max-width:140px;
    flex:0 0 auto;
  }

  @media (max-width:700px){

    #bracketTournamentPick{
      min-width:140px;
      max-width:140px;
    }
  }
  /* ==========================================================
     Bracket view
     ========================================================== */

  .bracketGrid{
    display:grid;
    grid-template-columns: repeat(4, 185px);
    overflow-x:auto;
    -webkit-overflow-scrolling: touch;
    gap:6px;
    width:100%;
  }

  .bracketCol{
    min-width:0;
    border:1px solid var(--line);
    border-radius: 12px;
    background: var(--glassBlue14);
    padding: 6px;
  }

  .bracketHdr{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:6px;
    margin-bottom:6px;
  }

  .roundTag{
    display:inline-block;
    font-weight:900;
    font-size:10px;
    letter-spacing:.5px;
    padding:3px 7px;
    border-radius:999px;
    background: rgba(255,214,89,.14);
    border:1px solid rgba(255,214,89,.14);
    color: var(--yellow);
    line-height:1;
  }

  .raceTag{
    display:inline-block;
    font-weight:800;
    font-size:10px;
    letter-spacing:.5px;
    padding:3px 7px;
    border-radius:999px;
    background: rgba(255,255,255,.10);
    border:1px solid rgba(255,214,89,.14);
    color: var(--muted);
    line-height:1;
  }

  .title{ display:flex; align-items:center; gap:6px; min-width:0; }
  .race{
    font-size:11px;
    color: var(--muted);
    font-weight:800;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    min-width:0;
  }

  .ticket{
    border:1px solid var(--line);
    border-radius: 12px;
    color:#fff;
    overflow:hidden;
    margin: 4px 0;
  }

  .ticketRow{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:6px;
    padding:5px 7px;
    min-width:0;
  }
  .ticketRow + .ticketRow{
    border-top:1px solid rgba(255,255,255,0.10);
  }

  .sideLeft{
    display:flex;
    align-items:center;
    gap:6px;
    flex: 1 1 auto;
    min-width:0;
    overflow:hidden;
    font-weight:900;
    font-size:11px;
    line-height:1.1;
  }

  .nameText{
    flex: 1 1 auto;
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    display:block;
  }

  .seedBadge{
    flex:0 0 auto;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:18px;
    height:16px;
    padding:0 5px;
    border-radius:999px;
    background: rgba(255,255,255,0.12);
    border:1px solid rgba(255,255,255,0.12);
    font-size:10px;
    font-weight:900;
    font-variant-numeric: tabular-nums;
  }

  .sideRight{
    display:flex;
    align-items:center;
    gap:4px;
    flex: 0 0 auto;
  }

  .winSlot{
    width:8px;
    display:flex;
    align-items:center;
    justify-content:center;
  }

  .winDot{
    width:8px;
    height:8px;
    border-radius:999px;
    background: var(--winnerGreen);
    box-shadow: 0 0 0 2px rgba(22,163,74,0.18);
  }

  .raceDot{
    width:8px;
    height:8px;
    border-radius:999px;
    background: var(--blue);
    box-shadow: 0 0 0 2px rgba(0,122,194,0.18);
  }
    
  .legendRow{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:10px;
    line-height:1;
    margin-top:0;
  }

  .bracketLegend{
    display:flex;
    align-items:center;
    gap:8px;
    font-size:11px;
    font-weight:400;
    color: var(--muted);
    white-space:nowrap;
    line-heigh:1;
  }

  .legendItem{
    display:inline-flex;
    align-items:center;
    gap:4px;
  }

  .legendSep{
    opacity:.5;
  }

  .avgBox{
    font-variant-numeric: tabular-nums;
    font-weight:900;
    font-size:11px;
    padding:3px 7px;
    border-radius:10px;
    background: rgba(255,255,255,0.12);
    border:1px solid rgba(255,255,255,0.12);
    line-height:1;
  }

  .bracketWrap{ position: relative; margin-top:10px; }

  .bracketSticky{
    position: sticky;
    top: 0;
    z-index: 20;
    display:none !important;
    gap:10px;
    padding: 6px 10px;
    margin: 0 0 6px 0;
    background: var(--black75);
    backdrop-filter: blur(10px);
    border: 1px solid var(--line);
    border-radius: 12px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
  }

  .bracketSticky .chip{
    flex:0 0 auto;
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:4px 8px;
    border-radius:999px;
    border:1px solid var(--white12);
    background: var(--white06);
    font-size:11px;
    font-weight:900;
    color: var(--text);
    scroll-snap-align: start;
  }

  .bracketSticky .chip .small{
    font-size:10px;
    font-weight:800;
    color: var(--muted);
  }

  .bracketFade{
    pointer-events:none;
    position:absolute;
    top:0;
    bottom:0;
    width:18px;
    z-index:15;
    border-radius: 12px;
  }
  .bracketFade.left{
    left:0;
    background: linear-gradient(90deg, var(--glassBlue14) 0%, rgba(0,122,194,0) 100%);
  }
  .bracketFade.right{
    right:0;
    background: linear-gradient(270deg, var(--glassBlue14) 0%, rgba(0,122,194,0) 100%);
  }

  @media (max-width:900px){
    .bracketGrid{ scroll-snap-type: x proximity; }
    .bracketCol{ scroll-snap-align: start; }
  }

  .mmWrap{ margin-top:6px; }

  .mmHeader{
    font-weight:900;
    font-size:14px;
    margin: 0 0 var(--mmHeaderGap) 0;
    line-height:1.2;
  }

  .microBox{
    border:1px solid var(--line);
    border-radius:12px;
    padding: var(--mmPad);
    background: var(--glassBlue14);
  }

  .youBox{
    border:2px solid var(--winnerGreen);
    background: var(--glassBlue14);
  }

  .microTitle{
    font-weight:900;
    font-size:14px;
    margin:0 0 2px 0;
    line-height:1.15;
  }

  .microMeta{
    font-size:14px;
    font-weight:900;
    color: var(--yellow);
    margin:0;
    line-height:1.2;
  }

  .centerVS{
    text-align:center;
    font-weight:900;
    font-size:12px;
    color: var(--red);
    margin: var(--mmGap) 0;
    letter-spacing:.5px;
  }

  .bottomNav{
    position: fixed;
    left:0; right:0; bottom:0;
    padding: 10px 10px calc(10px + env(safe-area-inset-bottom));
    background: rgba(2,11,18,.92);
    backdrop-filter: blur(10px);
    border-top: 1px solid rgba(255,255,255,.10);
    z-index: 9999;
  }

  .navInner{
    max-width: 920px;
    margin:0 auto;
    display:flex;
    gap:8px;
    align-items:center;
    overflow-x:auto;
    -webkit-overflow-scrolling: touch;
  }

  .navInner::before,
  .navInner::after{
    content:"";
    flex: 1 0 auto;
  }

  .navBtn{
    flex:0 0 auto;
    min-width:98px;
    background: var(--white06);
    color:#fff;
    border:1px solid var(--white10);
    border-radius:18px;
    padding:6px 8px;
    font-weight:800;
    font-size:12px;
    cursor:pointer;
    display:flex;
    gap:6px;
    align-items:center;
    justify-content:center;
    text-align:center;
    white-space:nowrap;
  }

  .navBtn.active{
    background: var(--glassBlue22);
    border-color: var(--glassBlue55);
  }

  .navBtn .ico{ font-size:14px; }

  /* ==========================================================
     Standings / stats view
     ========================================================== */

  .statsModes{
    display:flex;
    flex-wrap: nowrap;
    gap:8px;
    margin-top:8px;
    overflow-x:auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom:4px;
  }
  .statsModes::-webkit-scrollbar{ height:2px; }
  .statsModes::-webkit-scrollbar-thumb{
    background: var(--white14);
    border-radius:999px;
  }

  .statsModes button.secondary{
    flex: 0 0 auto;
    width:auto;
    padding:8px 12px;
    border-radius:12px;
    background: var(--glassBlue22);
  }
  .statsModes button.secondary.active{
    background: var(--glassBlue42);
    border:1px solid var(--glassBlue55);
  }

  .statsPanel{ margin-top:6px; }

  .statsRow{
    display:flex;
    align-items:center;
    gap:10px;
    padding:4px 6px;
    border-radius:12px;
    border:1px solid var(--line);
    background: var(--glassBlue20);
    margin-top:3px;
  }

  .statsLeft{
    flex:0 0 auto;
    display:flex;
    align-items:center;
    gap:10px;
    min-width:0;
  }

  .rankBadge{
    flex:0 0 auto;
    min-width:32px;
    height:24px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-weight:400;
    font-variant-numeric: tabular-nums;
    background: rgba(255,255,255,.10);
    border:1px solid var(--white12);
    font-size:14px;
  }

  .statsName{
    font-weight:400;
    color: var(--text);
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    font-size:14px;
  }

  .statsBadges{
    flex: 1 1 auto;
    display:flex;
    gap:6px;
    flex-wrap:wrap;
    justify-content:flex-end;
    min-width:0;
  }

  .miniPill{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:4px 8px;
    border-radius:999px;
    border:1px solid var(--white12);
    background: var(--white06);
    font-size:11px;
    font-weight:900;
    color: var(--text);
    font-variant-numeric: tabular-nums;
  }
  .miniPill .k{ color: var(--muted); font-weight:800; }

  .statsRow.overallRow{
    display:grid;
    grid-template-columns: auto var(--overallNameW, max-content) 1fr;
    align-items:center;
    gap:10px;
  }

  .statsRow.overallRow .statsName{
    width: var(--overallNameW, max-content);
    white-space:nowrap;
    overflow: visible;
    text-overflow: clip;
  }

  .statsRow.overallRow .statsBadges{
    justify-content:flex-start;
    flex-wrap:nowrap;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling: touch;
    white-space:nowrap;
  }
  .statsRow.overallRow .statsBadges .miniPill{ flex:0 0 auto; }

  .statsControls{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    align-items:center;
    margin-top:8px;
  }
  .statsControls label{ margin:0; }
  .statsControls select{
    width:auto;
    min-width:220px;
    padding: var(--mmPad);
  }

  .tiles{
    display:grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap:10px;
    margin-top:8px;
  }
  .tile{
    border:1px solid var(--line);
    border-radius:14px;
    padding:10px;
    background: rgba(0,122,194,.10);
  }
  .tile .tLabel{ color: var(--muted); font-weight:800; font-size:12px; }
  .tile .tVal{ font-weight:900; font-size:22px; margin-top:4px; }

  @media (max-width:520px){
    .tiles{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .statsControls select{ width:100%; }
    .statsModes{ flex-wrap: nowrap !important; overflow-x:auto !important; }
  }

  .statsRow.paidRow{ border:1px solid var(--greenfade); }
  .statsRow.youRow{
    background: var(--glassBlue42);
    border-color: var(--glassBlue55);
  }
  .statsRow.paidRow.youRow{ border:1px solid var(--greenfade); }

  .sponsor-container{
    position: fixed;
    bottom: var(--navH);
    left:0;
    right:0;
    display:flex;
    flex-direction:column;
    align-items:center;
    z-index: 2;
    pointer-events:none;
  }

  .presented-by{
    font-size:11px;
    opacity:0.5;
    font-weight:bold;
    color: var(--muted);
    letter-spacing:.2px;
    margin-bottom:6px;
    text-transform: uppercase;
  }

  .sponsor-logo{
    height:80px;
    width:auto;
    opacity:0.5;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }
  
  .buschLogoTrigger{
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: calc(var(--navH) + 10px);
  width: 220px;
  height: 110px;
  z-index: 100;
  background: transparent;
  pointer-events: auto;
}

  *::-webkit-scrollbar{ height:10px; width:10px; }
  *::-webkit-scrollbar-track{
    background: var(--white06);
    border-radius:999px;
  }
  *::-webkit-scrollbar-thumb{
    background: rgba(0,122,194,.40);
    border-radius:999px;
    border:2px solid rgba(0,0,0,.35);
  }
  *::-webkit-scrollbar-thumb:hover{ background: rgba(0,122,194,.60); }
  *::-webkit-scrollbar-corner{ background: transparent; }

  #playerPortalPill{
    user-select:none;
    -webkit-user-select:none;
    touch-action:manipulation;
  }

  /* ==========================================================
     Admin modals + controls
     ========================================================== */

  .adminBackdrop,
  .adminOverlay{
    position:fixed;
    inset:0;
    z-index:9999;
    background:rgba(2,11,18,.72);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    padding:
    14px
    14px
    calc(14px + env(safe-area-inset-bottom) + 90px);
  }

  .adminBackdrop{
    display:flex;
    align-items:center;
    justify-content:center;
    padding:18px;
  }

.adminBackdrop[hidden],
.adminOverlay[hidden]{
  display:none !important;
}
  .adminPinModal,
  .adminSheet{
    width:min(100%, 760px);
    margin:0 auto;
    padding:14px;
    padding-bottom: calc(20px + env(safe-area-inset-bottom) + 40px);
    border:1px solid var(--line);
    background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
    border-radius:20px;
    box-shadow:0 20px 60px rgba(0,0,0,.45);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    max-height: none;
    overflow:visible;
  }

  .adminPinModal{
    padding:16px;
  }

  .adminPinModal .muted{
    display:block;
    margin:0 0 8px 0;
  }

  .adminModalTitle{
    font-size:20px;
    font-weight:900;
    margin-bottom:6px;
  }

  .adminSheetHeader{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:10px;
    margin-bottom:12px;
  }

  .adminHeaderBtns{
    display:flex;
    gap:8px;
  }

  .adminContextBar{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin-bottom:12px;
  }

  .adminField{
    display:flex;
    flex-direction:column;
    gap:6px;
  }

  .adminField select,
  .adminField input,
  #adminPinInput{
    width:100%;
    display:block;
    font-size:16px !important;
    line-height:1.0;
    padding:10px 12px;
    border-radius:12px;
    border:1px solid var(--line);
    background:rgba(0,122,194,.14);
    color:var(--text);
    margin:0 0 8px 0;
    -webkit-text-size-adjust:100%;
  }

  .adminField select,
  .adminField input{
    margin: 0 0 0 0;
  }

  .adminPinModal .adminRow{
    display:flex;
    gap:14px;
    margin-top:0;
  }

  .adminPinModal .adminRow button{
    flex:1 1 0;
    width:100%;
    min-width:0;
    margin:0;
    padding:8px 10px;
    font-size:12px;
    line-height:1.0;
    border-radius:16px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }

  #adminPinCancel{
    background:#41506b;
    color:#fff;
  }

  #adminPinSubmit{
    background:#020b12;
    color:#fff;
    border:1px solid rgba(255,255,255,.32);
  }

  .adminTabs{
    display:flex;
    gap:8px;
    margin-bottom:12px;
    flex-wrap:wrap;
  }

  .adminTab{
    background:rgba(255,255,255,.08);
    color:var(--text);
    border:1px solid var(--line);
    padding:8px 12px;
  }

  .adminTab.active{
    background:rgba(228,0,43,.28);
    border-color:rgba(228,0,43,.42);
  }

  .adminTabPane{ display:none; }
  .adminTabPane.active{ display:block; }

  .adminCardGrid{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
  }

  .adminRow{
    display:flex;
    gap:8px;
    margin-top:10px;
  }

  .adminRow > *{
    flex:1;
  }

  .adminStatus{
    margin-top:10px;
    font-size:13px;
    color:var(--muted);
    white-space:pre-wrap;
  }

  .adminSeedsGrid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:8px;
  }

  .adminSeedRow{
    display:grid;
    grid-template-columns:40px 1fr;
    gap:8px;
    align-items:center;
  }

  .adminSeedNum{
    font-size:12px;
    text-align:center;
    font-weight:900;
    color:var(--yellow);
    border:1px solid rgba(255,214,89,.28);
    background:rgba(255,214,89,.08);
    border-radius:12px;
    padding:6px;
  }

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

  .adminSeedsGrid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:8px;
  }

  .adminSeedRow{
    grid-template-columns:40px 1fr;
    gap:6px;
    align-items:center;
  }

  .adminSeedNum{
    padding:8px 6px;
    font-size:12px;
  }

  .adminSeedSelect{
    min-width:0;
    width:100%;
    font-size:12px;
  }
}
