/* PPHS dashboard — wellness-app style, mobile-first. */

.pphs-app, .pphs-app * { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
.pphs-app {
  --bg:        #FFFFFF;
  --ink:       #1B2436;
  --body:      #5B657A;
  --muted:     #A0AAB9;
  --hair:      #F0F2F5;
  --tile:      #F4F5F8;
  --c1:        #3DBE9F;
  --c1-deep:   #2FA388;
  --c1-soft:   #E8F8F2;
  --c2:        #7B6FE2;
  --c2-deep:   #6357D4;
  --c2-soft:   #EEEBFB;
  --c3:        #FB9F51;
  --c3-deep:   #E08443;
  --c3-soft:   #FEF1E6;
  --safe-top:  env(safe-area-inset-top, 0);
  --safe-bot:  env(safe-area-inset-bottom, 0);
  --safe-l:    env(safe-area-inset-left, 0);
  --safe-r:    env(safe-area-inset-right, 0);

  background: var(--bg);
  color: var(--ink);
  font-family: Arial, Helvetica, sans-serif;
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  margin: 0;
}

/* ---------- Sticky topbar ---------- */
.pphs-app .pphs-sticky {
  position: sticky; top: 0; z-index: 30;
  padding: calc(var(--safe-top) + 12px) calc(var(--safe-r) + 20px) 12px calc(var(--safe-l) + 20px);
  background: rgba(255, 255, 255, 0.86);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  backdrop-filter: saturate(180%) blur(16px);
  border-bottom: 1px solid var(--hair);
}
.pphs-app .pphs-sticky .row1 {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
}
.pphs-app .pphs-sticky .show-name {
  flex: 1; min-width: 0;
  font-family: inherit;
  font-size: 14px; font-weight: 700; color: var(--ink);
  letter-spacing: -0.01em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pphs-app .pphs-sticky button.refresh {
  flex: 0 0 auto;
  width: 36px; height: 36px;
  background: var(--bg); border: 1px solid var(--hair);
  color: var(--body); border-radius: 50%;
  padding: 0; display: grid; place-items: center; cursor: pointer;
  transition: transform .15s, background .15s;
}
.pphs-app .pphs-sticky button.refresh:active {
  background: var(--c1-soft); border-color: var(--c1);
  color: var(--c1-deep); transform: scale(0.94);
}
.pphs-app .pphs-sticky button.refresh svg { width: 16px; height: 16px; }
.pphs-app .pphs-sticky button.refresh.refreshing svg { animation: pphsSpin .9s linear infinite; color: var(--c1-deep); }
@keyframes pphsSpin { to { transform: rotate(360deg); } }
.pphs-app .pphs-sticky .pulse {
  display: inline-block;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--c1-deep);
  margin-right: 6px; vertical-align: 1px;
  box-shadow: 0 0 0 0 rgba(47,163,136,0.45);
  animation: pphsPulse 2.2s cubic-bezier(.4,0,.6,1) infinite;
}
.pphs-app .pphs-sticky .pulse.stale { background: var(--muted); animation: none; box-shadow: none; }
.pphs-app .pphs-sticky .pulse.error { background: #c75c5c; animation: none; box-shadow: none; }
@keyframes pphsPulse {
  0%   { box-shadow: 0 0 0 0 rgba(47,163,136,0.45); }
  70%  { box-shadow: 0 0 0 6px rgba(47,163,136,0); }
  100% { box-shadow: 0 0 0 0 rgba(47,163,136,0); }
}
.pphs-app .pphs-sticky .row2 {
  margin-top: 6px;
  font-size: 12px; color: var(--body); font-weight: 500;
  font-family: inherit; letter-spacing: 0; text-transform: none;
  display: flex; align-items: center; gap: 8px;
}
.pphs-app .pphs-sticky .row2 b { color: var(--ink); font-weight: 600; }
.pphs-app .pphs-sticky .row2 .sep { color: var(--muted); }

/* ---------- Body container ---------- */
.pphs-app .pphs-container {
  max-width: 880px; margin: 0 auto;
  padding: 28px calc(var(--safe-r) + 24px) calc(var(--safe-bot) + 60px) calc(var(--safe-l) + 24px);
}

/* ---------- Rider section (transparent wrapper) ---------- */
.pphs-app .pphs-rider {
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0 0 24px;
  display: block;
}

/* ---------- Rider HERO card (colored, contains head + stats) ---------- */
.pphs-app .pphs-hero {
  border-radius: 22px;
  padding: 22px 22px 18px;
  color: #fff;
  background: var(--c1);
  margin-bottom: 16px;
}
.pphs-app .pphs-rider:nth-of-type(3n+1) .pphs-hero { background: var(--c1); }
.pphs-app .pphs-rider:nth-of-type(3n+2) .pphs-hero { background: var(--c2); }
.pphs-app .pphs-rider:nth-of-type(3n+3) .pphs-hero { background: var(--c3); }

.pphs-app .rider-head {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 18px;
}
.pphs-app .rider-avatar {
  flex: 0 0 44px; width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.20);
  color: #fff; font-weight: 700; font-size: 15px;
  letter-spacing: 0.01em; text-transform: uppercase;
  display: grid; place-items: center;
  font-family: inherit;
}
.pphs-app .rider-who { flex: 1; min-width: 0; }
.pphs-app .rider-name {
  font-family: inherit;
  font-size: 22px; font-weight: 800;
  letter-spacing: -0.02em; line-height: 1.1;
  color: #fff; margin: 0 0 2px;
}
.pphs-app .rider-meta {
  font-size: 13px; color: rgba(255,255,255,0.78);
  font-weight: 500; font-family: inherit;
  letter-spacing: 0; text-transform: none;
}

/* Stats inside hero — 3 white-translucent tiles */
.pphs-app .pphs-hero .stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  background: transparent;
  border: 0;
  border-radius: 0;
  overflow: visible;
  margin: 0;
}
@media (max-width: 380px) {
  .pphs-app .pphs-hero .stats { grid-template-columns: repeat(2, 1fr); }
}
.pphs-app .pphs-hero .stat {
  background: rgba(255,255,255,0.16);
  border-radius: 14px;
  padding: 14px 12px 12px;
  text-align: left;
  position: static;
}
.pphs-app .pphs-hero .stat + .stat::before { display: none; }
.pphs-app .pphs-hero .stat .v {
  font-family: inherit;
  font-size: 24px; font-weight: 800;
  color: #fff; line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.pphs-app .pphs-hero .stat .l {
  font-family: inherit;
  font-size: 11px; font-weight: 600;
  color: rgba(255,255,255,0.82);
  letter-spacing: 0.02em; text-transform: uppercase;
  margin-top: 6px;
}
.pphs-app .pphs-hero .stat.bumped { background: rgba(255,255,255,0.32); }

/* Hide legacy podium + heights on the colored hero (data is conveyed by stats + list) */
.pphs-app .pphs-hero .podium,
.pphs-app .pphs-hero .heights { display: none; }

/* ---------- Class list card (white, beneath hero) ---------- */
.pphs-app .pphs-list-card {
  background: var(--bg);
  border: 1px solid var(--hair);
  border-radius: 18px;
  padding: 4px 20px;
}
.pphs-app .pphs-rider .section-title {
  display: flex; align-items: baseline; justify-content: space-between;
  margin: 0;
  padding: 14px 0 6px;
  font-family: inherit;
  font-size: 11px; font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.06em; text-transform: uppercase;
  gap: 0;
}
.pphs-app .pphs-rider .section-title::after { display: none; }

/* Row */
.pphs-app .pphs-rider .row {
  display: block;
  padding: 12px 0;
  border-top: 1px solid var(--hair);
  border-bottom: 0;
  min-height: 44px;
}
.pphs-app .pphs-rider .row:first-of-type { border-top: 0; }

/* Class number badge — replaces the emoji ribbon. The PHP outputs emoji + <b>N</b>;
   we hide the emoji glyph and show only the class number in a rounded tile. */
.pphs-app .pphs-rider .row .ribbon {
  width: 38px; height: 38px; border-radius: 12px;
  background: var(--tile); color: var(--body);
  font-size: 0; line-height: 0;
  display: grid; place-items: center;
  align-self: center; padding: 0;
  font-family: inherit;
}
.pphs-app .pphs-rider .row .ribbon b {
  display: inline; font-family: inherit;
  font-size: 13px; font-weight: 700; line-height: 1;
  color: var(--ink); margin: 0;
  font-variant-numeric: tabular-nums;
}
/* When the row is in the "Placed" list, tint the ribbon tile green */
.pphs-app .pphs-rider [data-placed-list] .row .ribbon { background: var(--c1-soft); }
.pphs-app .pphs-rider [data-placed-list] .row .ribbon b { color: var(--c1-deep); }

.pphs-app .pphs-rider .row .body { min-width: 0; }
.pphs-app .pphs-rider .row .cls {
  font-family: inherit; font-size: 11.5px;
  color: var(--muted); font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
  margin-bottom: 2px;
  font-variant-numeric: tabular-nums;
}
.pphs-app .pphs-rider .row .name {
  font-family: inherit; font-size: 14.5px;
  color: var(--ink); font-weight: 600;
  line-height: 1.3; margin-bottom: 0;
}
.pphs-app .pphs-rider .row .name .h {
  display: inline-block; font-family: inherit;
  font-size: 11.5px; font-weight: 500;
  color: var(--muted); padding: 0;
  background: transparent; border: 0; border-radius: 0;
  margin-left: 6px;
  letter-spacing: 0;
}
.pphs-app .pphs-rider .row .stats-line {
  font-family: inherit;
  font-size: 12px; color: var(--muted);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
  margin-top: 2px;
}
.pphs-app .pphs-rider .row .stats-line b { color: var(--ink); font-weight: 600; }
.pphs-app .pphs-rider .row .stats-line .sep { color: var(--muted); margin: 0 6px; }
.pphs-app .pphs-rider .row .empty {
  color: var(--muted); font-style: italic; font-size: 12px;
}

/* New-row entrance */
.pphs-app .pphs-rider .row.is-new {
  animation: pphsRowIn .45s cubic-bezier(.2,.7,.3,1) both;
}
@keyframes pphsRowIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Empty state */
.pphs-app .pphs-empty {
  background: var(--bg);
  border: 1px dashed var(--hair);
  border-radius: 18px;
  padding: 28px 20px; text-align: center;
  color: var(--muted); font-size: 14px; font-style: italic;
  font-family: inherit;
}

/* Footer */
.pphs-app footer {
  margin-top: 18px; text-align: center;
  font-family: inherit;
  font-size: 12px; color: var(--muted); font-weight: 500;
  letter-spacing: 0; text-transform: none;
}

/* ---------- Tablet / phone (≤ 640px) ---------- */
@media (max-width: 640px) {
  .pphs-app .pphs-container {
    padding: 20px calc(var(--safe-r) + 16px) calc(var(--safe-bot) + 56px) calc(var(--safe-l) + 16px);
  }
  .pphs-app .pphs-sticky {
    padding: calc(var(--safe-top) + 10px) calc(var(--safe-r) + 16px) 10px calc(var(--safe-l) + 16px);
  }
  .pphs-app .pphs-sticky .show-name { font-size: 13px; }
  .pphs-app .pphs-sticky button.refresh { width: 34px; height: 34px; }

  .pphs-app .pphs-hero { padding: 18px 18px 14px; border-radius: 18px; }
  .pphs-app .pphs-hero::after { width: 130px; height: 130px; right: -30px; top: -30px; }
  .pphs-app .rider-head { gap: 12px; margin-bottom: 14px; }
  .pphs-app .rider-avatar { flex-basis: 40px; width: 40px; height: 40px; font-size: 14px; }
  .pphs-app .rider-name { font-size: 19px; }
  .pphs-app .rider-meta { font-size: 12px; }
  .pphs-app .pphs-hero .stats { gap: 6px; }
  .pphs-app .pphs-hero .stat { padding: 12px 10px 10px; border-radius: 12px; }
  .pphs-app .pphs-hero .stat .v { font-size: 22px; }
  .pphs-app .pphs-hero .stat .l { font-size: 10px; margin-top: 4px; }

  .pphs-app .pphs-list-card { padding: 2px 16px; border-radius: 16px; }
  .pphs-app .pphs-rider .section-title { padding: 12px 0 4px; font-size: 10px; }
  .pphs-app .pphs-rider .row { padding: 10px 0; min-height: auto; }
  .pphs-app .pphs-rider .row .name { font-size: 14px; line-height: 1.3; }
  .pphs-app .pphs-rider .row .name .h { font-size: 11px; margin-left: 5px; }
  .pphs-app .pphs-rider .row .stats-line { font-size: 11.5px; margin-top: 3px; }
  .pphs-app .pphs-rider .row .stats-line .sep { margin: 0 4px; }
}

/* ---------- Narrower phone (≤ 480px) ---------- */
@media (max-width: 480px) {
  .pphs-app .pphs-container {
    padding: 16px calc(var(--safe-r) + 12px) calc(var(--safe-bot) + 48px) calc(var(--safe-l) + 12px);
  }
  .pphs-app .pphs-hero { padding: 16px 16px 12px; }
  .pphs-app .pphs-hero::after { display: none; }
  .pphs-app .rider-name { font-size: 18px; }
  .pphs-app .rider-meta { font-size: 11.5px; }

  /* 2x2 stats grid on small phones (was kicking in only at 380px). */
  .pphs-app .pphs-hero .stats { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .pphs-app .pphs-hero .stat { padding: 12px 12px 10px; }
  .pphs-app .pphs-hero .stat .v { font-size: 22px; }

  .pphs-app .pphs-list-card { padding: 2px 14px; }
  .pphs-app .pphs-rider .row .stats-line { font-size: 11px; }
  .pphs-app .pphs-rider .row .stats-line .sep { margin: 0 3px; }

  .pphs-app .pphs-matchup-card { padding: 2px 14px 10px; margin-top: 12px; }
  .pphs-app .pphs-matchup-card .section-title { padding: 12px 0 4px; }
  .pphs-app .pphs-matchup-card .pphs-mu-sub { display: none; }
}

/* ---------- Small phone (≤ 380px) ---------- */
@media (max-width: 380px) {
  .pphs-app .pphs-container {
    padding: 14px calc(var(--safe-r) + 10px) calc(var(--safe-bot) + 44px) calc(var(--safe-l) + 10px);
  }
  .pphs-app .pphs-hero { padding: 14px 14px 10px; border-radius: 16px; }
  .pphs-app .rider-name { font-size: 17px; letter-spacing: -0.01em; }
  .pphs-app .rider-avatar { flex-basis: 36px; width: 36px; height: 36px; font-size: 13px; }
  .pphs-app .pphs-hero .stat .v { font-size: 20px; }
  .pphs-app .pphs-hero .stat .l { font-size: 10px; }
  .pphs-app .pphs-list-card { padding: 2px 12px; }
  .pphs-app .pphs-rider .row { padding: 9px 0; }
  .pphs-app .pphs-rider .row .name { font-size: 13.5px; }
  /* Stack stats line below name on tiny phones */
  .pphs-app .pphs-rider .row .stats-line {
    white-space: normal; line-height: 1.45;
  }

  /* Rider switcher dropdown gets a tighter look on tiny phones */
  .pphs-rider-switcher { padding: 8px 10px; gap: 8px; margin-bottom: 10px; }
  .pphs-rider-switcher label { font-size: 11px; }
}

/* --- Rider switcher (only rendered when 2+ riders) --- */
.pphs-rider-switcher {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 14px;
  padding: 10px 14px;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  font-family: Arial, Helvetica, sans-serif;
}
.pphs-rider-switcher label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #6b7280;
}
.pphs-rider-switcher select {
  flex: 1;
  font-size: 16px;
  font-weight: 600;
  padding: 8px 10px;
  border: 1px solid #d1d5db;
  border-radius: 10px;
  background: #fff;
  color: #111827;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
}


/* =========================================================
   v0.1.54  Spectacular pass - ADDITIVE styles only.
   No grid/layout changes; this layer enriches the visuals.
   ========================================================= */

/* Richer hero gradients */
.pphs-app .pphs-rider:nth-of-type(3n+1) .pphs-hero {
  background: linear-gradient(135deg, var(--c1) 0%, color-mix(in srgb, var(--c1) 78%, #134e3b) 100%);
}
.pphs-app .pphs-rider:nth-of-type(3n+2) .pphs-hero {
  background: linear-gradient(135deg, var(--c2) 0%, color-mix(in srgb, var(--c2) 75%, #2a1d6f) 100%);
}
.pphs-app .pphs-rider:nth-of-type(3n+3) .pphs-hero {
  background: linear-gradient(135deg, var(--c3) 0%, color-mix(in srgb, var(--c3) 75%, #8a3a14) 100%);
}

.pphs-app .pphs-hero {
  box-shadow: 0 6px 24px -8px rgba(15, 23, 42, 0.22),
              0 2px 6px -2px rgba(15, 23, 42, 0.10);
  position: relative;
  overflow: hidden;
}
.pphs-app .pphs-hero::after {
  content: "";
  position: absolute;
  right: -40px; top: -40px;
  width: 180px; height: 180px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  pointer-events: none;
}

.pphs-app .rider-name { text-shadow: 0 1px 0 rgba(0,0,0,0.08); }
.pphs-app .rider-avatar {
  box-shadow: 0 0 0 3px rgba(255,255,255,0.14),
              0 2px 8px rgba(0,0,0,0.14);
}

.pphs-app .pphs-hero .stat {
  transition: background 200ms ease, transform 200ms ease;
}
.pphs-app .pphs-hero .stat:hover {
  background: rgba(255,255,255,0.22);
  transform: translateY(-1px);
}
.pphs-app .pphs-hero .stat .v { font-size: 26px; }

.pphs-app .pphs-list-card {
  box-shadow: 0 1px 0 rgba(15,23,42,0.02), 0 2px 14px -8px rgba(15,23,42,0.12);
}

.pphs-app .pphs-rider .section-title > span:first-child::before {
  content: "";
  display: inline-block;
  width: 6px; height: 6px;
  background: var(--c1-deep, #137a5a);
  border-radius: 50%;
  margin-right: 8px;
  vertical-align: middle;
}

/* Medal-style ribbon tints for 1st/2nd/3rd */
.pphs-app .pphs-rider .row[data-place="1"] .ribbon {
  background: linear-gradient(135deg, #fde68a 0%, #f59e0b 100%);
  box-shadow: 0 2px 6px rgba(245,158,11,0.35);
}
.pphs-app .pphs-rider .row[data-place="1"] .ribbon b { color: #7c4a05; }
.pphs-app .pphs-rider .row[data-place="2"] .ribbon {
  background: linear-gradient(135deg, #e5e7eb 0%, #9ca3af 100%);
  box-shadow: 0 2px 6px rgba(156,163,175,0.30);
}
.pphs-app .pphs-rider .row[data-place="2"] .ribbon b { color: #374151; }
.pphs-app .pphs-rider .row[data-place="3"] .ribbon {
  background: linear-gradient(135deg, #fcd5b5 0%, #d97706 100%);
  box-shadow: 0 2px 6px rgba(217,119,6,0.28);
}
.pphs-app .pphs-rider .row[data-place="3"] .ribbon b { color: #6b3410; }

/* Medal emoji before class name on top-3 rows */
.pphs-app .pphs-rider .row[data-place="1"]  .name::before { content: "\01F947\00A0"; }
.pphs-app .pphs-rider .row[data-place="2"]  .name::before { content: "\01F948\00A0"; }
.pphs-app .pphs-rider .row[data-place="3"]  .name::before { content: "\01F949\00A0"; }
/* Keycap emoji for 4th-10th so non-podium placings still get a visual marker. */
.pphs-app .pphs-rider .row[data-place="4"]  .name::before { content: "4\FE0F\20E3\00A0"; }
.pphs-app .pphs-rider .row[data-place="5"]  .name::before { content: "5\FE0F\20E3\00A0"; }
.pphs-app .pphs-rider .row[data-place="6"]  .name::before { content: "6\FE0F\20E3\00A0"; }
.pphs-app .pphs-rider .row[data-place="7"]  .name::before { content: "7\FE0F\20E3\00A0"; }
.pphs-app .pphs-rider .row[data-place="8"]  .name::before { content: "8\FE0F\20E3\00A0"; }
.pphs-app .pphs-rider .row[data-place="9"]  .name::before { content: "9\FE0F\20E3\00A0"; }
.pphs-app .pphs-rider .row[data-place="10"] .name::before { content: "\1F51F\00A0"; }

.pphs-app .pphs-rider .row { transition: background 150ms ease; }
.pphs-app .pphs-rider .row:hover { background: rgba(15,23,42,0.02); }
.pphs-app .pphs-rider .row .stats-line b { color: var(--ink); font-weight: 700; }

.pphs-app .pphs-rider .row.is-new:nth-of-type(2n) { animation-delay: .05s; }
.pphs-app .pphs-rider .row.is-new:nth-of-type(3n) { animation-delay: .10s; }


/* =========================================================
   Leaderboard - [pphs_leaderboard]
   ========================================================= */
.pphs-leaderboard .pphs-container { max-width: 880px; }
.pphs-app .pphs-lb-title {
  font-family: inherit; font-size: 28px; font-weight: 800;
  letter-spacing: -0.02em; margin: 0 0 4px;
  color: var(--ink, #111);
}
.pphs-app .pphs-lb-sub {
  font-size: 13px; color: var(--muted, #6b7280); margin: 0 0 18px;
}
.pphs-leaderboard .pphs-lb-table {
  background: var(--bg, #fff);
  border: 1px solid var(--hair, #e5e7eb);
  border-radius: 18px;
  /* overflow:hidden intentionally omitted - it would prevent the sticky head from leaving the table card. */
}
.pphs-leaderboard .pphs-lb-head,
.pphs-leaderboard .pphs-lb-row {
  display: grid;
  grid-template-columns: 48px minmax(0, 1.7fr) repeat(7, minmax(0, 0.65fr));
  column-gap: 8px;
  align-items: center;
  padding: 12px 16px;
}
.pphs-leaderboard .pphs-lb-row .col-name {
  display: flex; flex-direction: column; gap: 2px;
}
.pphs-leaderboard .lb-name-line { font-size: 15px; font-weight: 600; color: var(--ink, #111); }
.pphs-leaderboard .lb-blurb {
  font-size: 11px; font-weight: 400; color: var(--muted, #6b7280);
  line-height: 1.35; font-style: italic;
}
.pphs-leaderboard .pphs-lb-foot {
  margin: 10px 4px 0; font-size: 11px; color: var(--muted, #6b7280);
  line-height: 1.4;
}
.pphs-leaderboard .pphs-lb-head {
  position: sticky;
  top: 0;
  z-index: 10;
  background: #f7f7f9;
  font-size: 11px; font-weight: 700; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--muted, #6b7280);
  border-bottom: 1px solid var(--hair, #e5e7eb);
  border-radius: 18px 18px 0 0;
  box-shadow: 0 2px 8px -6px rgba(15, 23, 42, 0.15);
}
.pphs-leaderboard .pphs-lb-row {
  border-top: 1px solid var(--hair, #e5e7eb);
  font-family: inherit;
}
.pphs-leaderboard .pphs-lb-row:first-of-type { border-top: 0; }
.pphs-leaderboard .pphs-lb-row:last-of-type { border-radius: 0 0 18px 18px; }
.pphs-leaderboard .pphs-lb-row .col-name {
  font-size: 15px; font-weight: 600; color: var(--ink, #111);
}
.pphs-leaderboard .pphs-lb-row .col-stat {
  font-family: inherit; font-size: 14px; font-weight: 600;
  color: var(--ink, #111); font-variant-numeric: tabular-nums;
  text-align: center;
}
.pphs-leaderboard .pphs-lb-row .col-stat.hot {
  color: #b45309; font-weight: 800; font-size: 16px;
}
.pphs-leaderboard .pphs-lb-row .col-best {
  color: var(--muted, #6b7280); font-weight: 500;
}
.pphs-leaderboard .rank-badge {
  display: inline-grid; place-items: center;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--tile, #f3f4f6); color: var(--ink, #111);
  font-weight: 800; font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.pphs-leaderboard .rank-badge.gold {
  background: linear-gradient(135deg,#fde68a 0%,#f59e0b 100%);
  color: #7c4a05; box-shadow: 0 2px 6px rgba(245,158,11,.35);
}
.pphs-leaderboard .rank-badge.silver {
  background: linear-gradient(135deg,#e5e7eb 0%,#9ca3af 100%);
  color: #374151;
}
.pphs-leaderboard .rank-badge.bronze {
  background: linear-gradient(135deg,#fcd5b5 0%,#d97706 100%);
  color: #6b3410;
}

/* ---- Mobile: card layout, not a table. ---- */
@media (max-width: 640px) {
  .pphs-leaderboard .pphs-lb-title { font-size: 22px; }
  .pphs-leaderboard .pphs-lb-sub { font-size: 13px; }

  /* Header row hidden - data-label on each stat provides context per card. */
  .pphs-leaderboard .pphs-lb-head { display: none; }

  /* Row becomes a flex card: rank | name+blurb | big Heat on top,
     stats strip below via a flex-basis:100% pseudo line break. */
  .pphs-leaderboard .pphs-lb-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    column-gap: 12px;
    row-gap: 8px;
    padding: 14px 14px;
    min-height: 64px;
  }

  .pphs-leaderboard .pphs-lb-row .col-rank {
    flex: 0 0 40px;
    order: 1;
    align-self: center;
  }
  .pphs-leaderboard .pphs-lb-row .col-name {
    flex: 1 1 0;
    min-width: 0;
    order: 2;
  }
  .pphs-leaderboard .lb-name-line { font-size: 16px; }
  .pphs-leaderboard .lb-blurb { font-size: 12px; line-height: 1.4; }

  /* Heat: big number on right of row 1, with small HEAT label. */
  .pphs-leaderboard .pphs-lb-row .col-stat.hot {
    flex: 0 0 auto;
    order: 3;
    font-size: 28px;
    font-weight: 800;
    line-height: 1;
    color: #b45309;
    text-align: right;
    padding-left: 4px;
  }
  .pphs-leaderboard .pphs-lb-row .col-stat.hot::after {
    content: "HEAT";
    display: block;
    margin-top: 2px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--muted, #6b7280);
  }

  /* Forced row break so the rest of the stats wrap to a new line. */
  .pphs-leaderboard .pphs-lb-row::before {
    content: "";
    flex-basis: 100%;
    height: 0;
    order: 4;
    margin: 0;
  }

  /* Stats strip: every non-Heat stat as a labeled inline pill. */
  .pphs-leaderboard .pphs-lb-row .col-stat:not(.hot) {
    flex: 0 0 auto;
    order: 5;
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
    font-size: 13px;
    font-weight: 700;
    color: var(--ink, #111);
    text-align: left;
    white-space: nowrap;
  }
  .pphs-leaderboard .pphs-lb-row .col-stat:not(.hot)::before {
    content: attr(data-label);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted, #6b7280);
  }

  /* Hide low-priority stats on phones. */
  .pphs-leaderboard .pphs-lb-row .col-stat[data-label="Win %"],
  .pphs-leaderboard .pphs-lb-row .col-stat[data-label="Shows"] {
    display: none;
  }
}

/* Even narrower phones: also drop Lvl, shrink Heat. */
@media (max-width: 380px) {
  .pphs-leaderboard .pphs-lb-row .col-stat[data-label="Lvl"] { display: none; }
  .pphs-leaderboard .pphs-lb-row .col-stat.hot { font-size: 24px; }
  .pphs-leaderboard .pphs-lb-row { padding: 12px 12px; column-gap: 10px; }
  .pphs-leaderboard .lb-name-line { font-size: 15px; }
}

/* dashboard -> leaderboard link in the sticky header */
.pphs-app .pphs-sticky .row2 a.pphs-lb-link {
  color: var(--c1-deep, #137a5a);
  font-weight: 700;
  text-decoration: none;
}
.pphs-app .pphs-sticky .row2 a.pphs-lb-link:hover { text-decoration: underline; }

/* ---------- Matchup card ("Beat the board") ---------- */
.pphs-app .pphs-matchup-card {
  background: var(--bg);
  border: 1px solid var(--hair);
  border-radius: 18px;
  padding: 4px 20px 12px;
  margin-top: 16px;
}
.pphs-app .pphs-matchup-card .section-title {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 14px 0 6px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--muted);
  gap: 8px;
}
.pphs-app .pphs-matchup-card .pphs-mu-sub {
  letter-spacing: 0; text-transform: none; font-weight: 500;
  font-size: 11px; color: var(--muted);
}
.pphs-app .pphs-mu-list { display: flex; flex-direction: column; }
.pphs-app .pphs-mu-row {
  display: grid;
  grid-template-columns: 1fr 130px;
  gap: 12px;
  align-items: center;
  padding: 10px 0;
  border-top: 1px solid var(--hair);
}
.pphs-app .pphs-mu-row:first-child { border-top: 0; }
.pphs-app .pphs-mu-name { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.pphs-app .pphs-mu-line {
  font-size: 14px; font-weight: 600; color: var(--ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.pphs-app .pphs-mu-basis {
  font-size: 11px; color: var(--body); font-weight: 500;
  display: inline-flex; align-items: center; gap: 6px;
}
.pphs-app .conf-dot {
  display: inline-block;
  width: 7px; height: 7px; border-radius: 50%;
  flex: 0 0 7px;
}
.pphs-app .conf-dot.conf-high { background: var(--c1-deep); }
.pphs-app .conf-dot.conf-med  { background: var(--c3-deep); }
.pphs-app .conf-dot.conf-low  { background: var(--muted); }

.pphs-app .pphs-mu-prob {
  display: flex; align-items: center; gap: 8px;
  justify-self: end; width: 100%;
}
.pphs-app .pphs-mu-bar {
  flex: 1; height: 8px; border-radius: 999px;
  background: var(--tile); overflow: hidden;
  position: relative;
}
.pphs-app .pphs-mu-bar span {
  display: block; height: 100%;
  background: var(--muted);
  transition: width .4s ease;
  border-radius: 999px;
}
.pphs-app .pphs-mu-good .pphs-mu-bar span { background: var(--c1-deep); }
.pphs-app .pphs-mu-even .pphs-mu-bar span { background: var(--c3-deep); }
.pphs-app .pphs-mu-bad  .pphs-mu-bar span { background: #c75c5c; }
.pphs-app .pphs-mu-pct {
  font-size: 14px; font-weight: 800; color: var(--ink);
  font-variant-numeric: tabular-nums;
  min-width: 40px; text-align: right;
}
.pphs-app .pphs-mu-good .pphs-mu-pct { color: var(--c1-deep); }
.pphs-app .pphs-mu-bad  .pphs-mu-pct { color: #a64242; }

.pphs-app .pphs-mu-foot {
  margin: 10px 0 0;
  font-size: 11px; color: var(--muted); line-height: 1.4;
}

/* Compact stack on phones */
@media (max-width: 480px) {
  .pphs-app .pphs-mu-row {
    grid-template-columns: 1fr 110px;
    gap: 10px;
  }
  .pphs-app .pphs-mu-line { font-size: 13px; }
  .pphs-app .pphs-mu-basis { font-size: 10px; }
  .pphs-app .pphs-matchup-card { padding: 4px 16px 12px; }
}

/* ---------- Narrow-phone sticky overflow guard ---------- */
@media (max-width: 480px) {
  .pphs-app .pphs-sticky .row2 { flex-wrap: wrap; row-gap: 4px; }
  .pphs-app .pphs-sticky .row2 .sep:last-of-type { display: none; }
}

/* ---------- Entered (DNP / upcoming) section ---------- */
.pphs-app .pphs-rider .section-title.section-title-entered {
  padding-top: 18px;
  color: var(--muted);
  border-top: 1px solid var(--hair);
  margin-top: 4px;
}
.pphs-app .pphs-rider .section-title.section-title-entered > span:first-child::before {
  background: var(--c3-deep, #E08443);
}
.pphs-app .pphs-rider .pphs-didnot-list .row .ribbon {
  background: var(--c3-soft, #FEF1E6);
}
.pphs-app .pphs-rider .pphs-didnot-list .row .ribbon b {
  color: var(--c3-deep, #E08443);
}
.pphs-app .pphs-rider .pphs-didnot-list .row .name {
  color: var(--body);
}
/* Entered rows are slightly dimmer than placed */
.pphs-app .pphs-rider .pphs-didnot-list .row {
  opacity: 0.92;
}
.pphs-app .pphs-rider .pphs-didnot-list .row .stats-line {
  font-size: 11.5px;
}
/* On phones the Entered section heading stays clear */
@media (max-width: 480px) {
  .pphs-app .pphs-rider .section-title.section-title-entered { padding-top: 14px; }
}

/* ---------- Ribbon dropped (v0.1.68) ---------- */
.pphs-app .pphs-rider .row .ribbon { display: none; }

/* New: small muted "Class N" tag at the front of the stats line. */
.pphs-app .pphs-rider .row .stats-line .cls-tag {
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: 10.5px;
  color: var(--muted);
}
.pphs-app .pphs-rider .row .stats-line .cls-tag b {
  font-weight: 700;
  color: var(--ink);
  letter-spacing: 0;
}

/* Body now spans the full row; medal emoji prefix on .name still does the
   podium signaling. Add a subtle left-border accent for top-3 placements
   so the visual hierarchy survives without the tile. */
.pphs-app .pphs-rider .row {
  position: relative;
  border-radius: 8px;
  /* No more margin-left bleed: keeps the row symmetric inside the card padding so
     left and right margins read as equal on phones. The colored accent below is
     painted via ::before instead. */
}
.pphs-app .pphs-rider .row::before {
  content: "";
  position: absolute;
  left: -6px;
  top: 6px;
  bottom: 6px;
  width: 3px;
  border-radius: 2px;
  background: transparent;
}
.pphs-app .pphs-rider .row[data-place="1"]::before { background: #f59e0b; }
.pphs-app .pphs-rider .row[data-place="2"]::before { background: #9ca3af; }
.pphs-app .pphs-rider .row[data-place="3"]::before { background: #d97706; }
.pphs-app .pphs-rider .row[data-place="1"] { background: linear-gradient(90deg, rgba(245,158,11,0.06) 0%, transparent 60%); }
.pphs-app .pphs-rider .row[data-place="2"] { background: linear-gradient(90deg, rgba(156,163,175,0.06) 0%, transparent 60%); }
.pphs-app .pphs-rider .row[data-place="3"] { background: linear-gradient(90deg, rgba(217,119,6,0.06) 0%, transparent 60%); }

/* Entered rows: subtle amber accent matching the Entered section header. */
.pphs-app .pphs-rider .pphs-didnot-list .row::before { background: rgba(224,132,67,0.4); }


/* ---------- Leaderboard header (title + back-to-dashboard link + search) ---------- */
.pphs-app .pphs-lb-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 4px;
}
.pphs-app .pphs-lb-header .pphs-lb-title { margin: 0; }

.pphs-app .pphs-db-link {
  font-size: 13px;
  font-weight: 700;
  color: var(--c1-deep, #137a5a);
  text-decoration: none;
  white-space: nowrap;
  flex: 0 0 auto;
}
.pphs-app .pphs-db-link:hover { text-decoration: underline; }

.pphs-leaderboard .pphs-lb-search {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 12px 0 14px;
}
.pphs-leaderboard .pphs-lb-search input[type="search"] {
  flex: 1;
  font-family: inherit;
  font-size: 15px;
  font-weight: 500;
  padding: 10px 14px;
  border: 1px solid var(--hair, #e5e7eb);
  border-radius: 12px;
  background: var(--bg, #fff);
  color: var(--ink, #111);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  -webkit-appearance: none;
}
.pphs-leaderboard .pphs-lb-search input[type="search"]:focus {
  border-color: var(--c1-deep, #137a5a);
  box-shadow: 0 0 0 3px rgba(47,163,136,0.18);
}
.pphs-leaderboard .pphs-lb-search input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
  height: 16px; width: 16px;
  background: var(--muted, #a0aab9);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M6 6l12 12M18 6L6 18' stroke='black' stroke-width='3' stroke-linecap='round'/></svg>") no-repeat center;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M6 6l12 12M18 6L6 18' stroke='black' stroke-width='3' stroke-linecap='round'/></svg>") no-repeat center;
  cursor: pointer;
}
.pphs-leaderboard .pphs-lb-search-count {
  font-size: 12px;
  color: var(--muted, #a0aab9);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  min-width: 60px;
  text-align: right;
}
.pphs-leaderboard .pphs-lb-empty {
  background: var(--tile, #f4f5f8);
  border: 1px dashed var(--hair, #e5e7eb);
  border-radius: 14px;
  padding: 18px 16px;
  text-align: center;
  color: var(--muted, #a0aab9);
  font-size: 14px;
  font-style: italic;
  margin-bottom: 12px;
}

@media (max-width: 480px) {
  .pphs-app .pphs-lb-header {
    flex-direction: row;
    align-items: center;
    gap: 8px;
  }
  .pphs-app .pphs-db-link { font-size: 12px; }
  .pphs-leaderboard .pphs-lb-search input[type="search"] {
    font-size: 16px; /* keep ≥16px to prevent iOS zoom on focus */
    padding: 10px 12px;
  }
  .pphs-leaderboard .pphs-lb-search-count { display: none; }
}

/* ---------- Heat formula legend card (top of leaderboard) ---------- */
.pphs-app .pphs-lb-legend {
  background: var(--c1-soft, #E8F8F2);
  border-left: 3px solid var(--c1-deep, #2FA388);
  border-radius: 0 14px 14px 0;
  padding: 12px 16px;
  margin: 4px 0 14px;
}
.pphs-leaderboard .pphs-lb-legend strong {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c1-deep, #2FA388);
  margin-bottom: 4px;
}
.pphs-leaderboard .pphs-lb-legend p {
  margin: 0;
  font-size: 13px;
  color: var(--ink, #1B2436);
  line-height: 1.5;
}
@media (max-width: 480px) {
  .pphs-leaderboard .pphs-lb-legend { padding: 10px 14px; margin-bottom: 12px; }
  .pphs-leaderboard .pphs-lb-legend p { font-size: 12px; }
}

/* ---------- Leaderboard group section headings (Jumpers / Non-Jumpers) ---------- */
.pphs-leaderboard .pphs-lb-group {
  font-family: inherit;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--c1-deep, #137a5a);
  margin: 28px 0 10px;
  padding: 8px 14px;
  background: var(--c1-soft, #E8F8F2);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.pphs-leaderboard .pphs-lb-group:first-of-type { margin-top: 8px; }
.pphs-leaderboard .pphs-lb-group-count {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--muted, #6b7280);
  background: rgba(255,255,255,0.7);
  padding: 3px 9px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
}

/* Second section ("Non-Jumpers") uses the amber accent so the two groups read distinctly. */
.pphs-leaderboard .pphs-lb-group + .pphs-lb-table + .pphs-lb-group,
.pphs-leaderboard .pphs-lb-group:nth-of-type(2) {
  color: var(--c3-deep, #E08443);
  background: var(--c3-soft, #FEF1E6);
}

/* Tables in groups: tighten spacing between them. */
.pphs-leaderboard .pphs-lb-table { margin-bottom: 4px; }

@media (max-width: 480px) {
  .pphs-leaderboard .pphs-lb-group {
    font-size: 13px;
    padding: 7px 12px;
    margin: 22px 0 8px;
  }
  .pphs-leaderboard .pphs-lb-group:first-of-type { margin-top: 4px; }
}

/* ---------- Phone-number login box ([pphs_login]) ---------- */
.pphs-login-box {
  max-width: 380px;
  margin: 32px auto;
  padding: 26px 24px 22px;
  background: #fff;
  border: 1px solid var(--hair, #F0F2F5);
  border-radius: 18px;
  box-shadow: 0 6px 30px -16px rgba(15,23,42,0.18);
  font-family: Arial, Helvetica, sans-serif;
}
.pphs-login-eyebrow {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c1-deep, #2FA388);
  text-align: center;
  margin-bottom: 8px;
}
.pphs-login-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pphs-login-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted, #A0AAB9);
  margin-top: 8px;
}
.pphs-login-form input[type="tel"] {
  font-family: inherit;
  font-size: 18px;
  font-weight: 600;
  padding: 14px 16px;
  border: 1px solid var(--hair, #F0F2F5);
  border-radius: 14px;
  background: var(--bg, #fff);
  color: var(--ink, #1B2436);
  outline: none;
  letter-spacing: 0.02em;
  transition: border-color .15s, box-shadow .15s;
  -webkit-appearance: none;
  appearance: none;
}
.pphs-login-form input[type="tel"]:focus {
  border-color: var(--c1-deep, #2FA388);
  box-shadow: 0 0 0 3px rgba(47,163,136,0.18);
}
.pphs-login-submit {
  font-family: inherit;
  font-size: 15px;
  font-weight: 700;
  padding: 14px 18px;
  background: var(--c1-deep, #2FA388);
  color: #fff;
  border: 0;
  border-radius: 14px;
  cursor: pointer;
  margin-top: 4px;
  transition: transform .15s, background .15s;
  -webkit-appearance: none;
  appearance: none;
}
.pphs-login-submit:hover { background: #1f7a5e; }
.pphs-login-submit:active { transform: scale(0.98); }
.pphs-login-help {
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--muted, #A0AAB9);
  text-align: center;
  line-height: 1.5;
}
.pphs-login-error {
  padding: 10px 12px;
  background: #fbeaea;
  border: 1px solid #f5c8c8;
  color: #a02020;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 500;
}

/* Already-signed-in state */
.pphs-login-welcomed {
  text-align: center;
}
.pphs-login-welcomed .pphs-login-line {
  font-size: 18px;
  font-weight: 700;
  color: var(--ink, #1B2436);
  margin: 8px 0 12px;
}
.pphs-login-out {
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  color: var(--body, #5B657A);
  text-decoration: none;
  padding: 8px 14px;
  border-radius: 10px;
  border: 1px solid var(--hair, #F0F2F5);
  transition: background .15s;
}
.pphs-login-out:hover { background: var(--tile, #F4F5F8); }

/* ---------- Switcher card responsive tuning ---------- */
/* Two switcher cards (Show + Rider) stacked on mobile add a lot of vertical
   weight before the hero appears. Tighten padding/margins and collapse the
   gap between them when both are present. */
@media (max-width: 640px) {
  .pphs-rider-switcher {
    padding: 8px 12px;
    margin: 0 0 10px;
    border-radius: 12px;
    box-shadow: none;
    border: 1px solid var(--hair, #F0F2F5);
    gap: 8px;
  }
  .pphs-rider-switcher label {
    font-size: 11px;
  }
  .pphs-rider-switcher select {
    font-size: 16px; /* iOS zoom-prevention threshold */
    padding: 7px 8px;
    border-radius: 9px;
  }
  /* When two switchers stack, pull the second one snug against the first
     so they read as one grouped control instead of two floating cards. */
  .pphs-rider-switcher + .pphs-rider-switcher {
    margin-top: -6px; /* visually attaches it to the previous switcher */
  }
}

/* Even tighter on narrow phones. */
@media (max-width: 380px) {
  .pphs-rider-switcher {
    padding: 7px 10px;
    margin: 0 0 8px;
  }
  .pphs-rider-switcher label {
    font-size: 10px;
  }
  .pphs-rider-switcher select {
    padding: 6px 8px;
  }
}


/* =========================================================
   Navigation spinner (login + dashboard<->leaderboard links)
   ========================================================= */
.pphs-nav-overlay {
  position: fixed; inset: 0;
  background: rgba(255,255,255,0.78);
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events: none;
}
.pphs-nav-overlay.is-on {
  display: flex;
  opacity: 1;
  pointer-events: auto;
}
.pphs-nav-spinner {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 3px solid rgba(0,0,0,0.10);
  border-top-color: var(--c1-deep, #137a5a);
  animation: pphsSpin .9s linear infinite;
}
.pphs-nav-overlay .pphs-nav-label {
  position: absolute;
  margin-top: 78px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted, #6b7280);
}
@media (prefers-reduced-motion: reduce) {
  .pphs-nav-spinner { animation: none; border-top-color: var(--muted, #6b7280); }
}


/* =========================================================
   Live tracking legend (dashboard) - lives inside .pphs-lb-legend
   exactly like the leaderboard's "How Heat is calculated" block.
   ========================================================= */
.pphs-app .pphs-lb-legend strong .pulse,
.pphs-app .pphs-lb-legend p .pulse {
  display: inline-block; width: 9px; height: 9px; border-radius: 50%;
  background: #21a05a; /* solid green = polling on */
  margin-right: 7px; vertical-align: 1px;
  animation: none;
}
.pphs-app .pphs-lb-legend .pulse.off { background: #c0392b; /* solid red = polling off */ }

.pphs-app .pphs-lb-legend p b {
  color: var(--ink, #111); font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.pphs-app .pphs-lb-legend p .sep { color: var(--muted, #a0aab9); margin: 0 4px; }

.pphs-app .pphs-lb-legend p button.refresh {
  appearance: none; -webkit-appearance: none;
  background: var(--bg, #fff); border: 1px solid var(--hair, #e5e7eb);
  width: 28px; height: 28px; border-radius: 8px;
  padding: 0; display: inline-grid; place-items: center; cursor: pointer;
  vertical-align: -8px;
  margin-left: 8px;
  color: var(--ink, #111);
  transition: background-color .15s, color .15s;
}
.pphs-app .pphs-lb-legend p button.refresh:active { background: var(--tile, #f4f5f8); }
.pphs-app .pphs-lb-legend p button.refresh svg { width: 14px; height: 14px; }
.pphs-app .pphs-lb-legend p button.refresh.refreshing svg { animation: pphsSpin .9s linear infinite; color: var(--c1-deep, #137a5a); }

/* Use the same heading typography on the dashboard's show name as the
   leaderboard's "Who's Hot" title. */
.pphs-app .pphs-lb-header h2.pphs-lb-title[data-show-name] {
  font-size: 28px;
}
@media (max-width: 640px) {
  .pphs-app .pphs-lb-header h2.pphs-lb-title[data-show-name] { font-size: 22px; }
}

/* Force all option text in the dashboard switchers to uppercase. */
.pphs-app .pphs-rider-switcher select option,
.pphs-app .pphs-rider-switcher select {
  text-transform: uppercase;
}


/* =========================================================
   Dashboard content box - mirror of .pphs-lb-table:
   1px border, 18px radius, zero internal padding so the
   inner cards sit flush against the box edge.
   ========================================================= */
.pphs-app .pphs-dash-content {
  background: var(--bg, #fff);
  border: 1px solid var(--hair, #e5e7eb);
  border-radius: 18px;
  padding: 0;
  overflow: hidden;
}
/* Inner rider sections drop their outer rounding so the hero/list cards
   fill the bounded box from edge to edge, no nested-frame look. */
.pphs-app .pphs-dash-content .pphs-rider {
  margin: 0;
}
.pphs-app .pphs-dash-content .pphs-rider + .pphs-rider {
  border-top: 1px solid var(--hair, #e5e7eb);
}
.pphs-app .pphs-dash-content .pphs-hero {
  border-radius: 0;
  margin-bottom: 0;
  padding: 18px 22px 14px;
}
/* Roomy horizontal padding so the row text never crashes into the bordered
   container's rounded edge. */
.pphs-app .pphs-dash-content .pphs-list-card {
  border: 0;
  border-radius: 0;
  padding: 4px 22px;
}
.pphs-app .pphs-dash-content .pphs-matchup-card {
  border: 0;
  border-radius: 0;
  padding-left: 22px;
  padding-right: 22px;
}
/* Pull the left-edge accent stripe inside the container so overflow:hidden
   doesn't clip it. */
.pphs-app .pphs-dash-content .pphs-rider .row::before { left: 4px; }
/* Empty state slot inside the bounded box. */
.pphs-app .pphs-dash-content .pphs-empty {
  padding: 24px 16px;
  text-align: center;
  color: var(--muted, #6b7280);
  font-style: italic;
}

@media (max-width: 480px) {
  .pphs-app .pphs-dash-content { border-radius: 14px; }
  .pphs-app .pphs-dash-content .pphs-hero { padding: 14px 18px 12px; }
  .pphs-app .pphs-dash-content .pphs-list-card { padding: 2px 18px; }
  .pphs-app .pphs-dash-content .pphs-matchup-card { padding-left: 18px; padding-right: 18px; }
}


/* =========================================================
   Overflow guards - prevent horizontal scroll on mobile.
   The dashboard's class names + blurbs can be longer than
   the leaderboard's short AI snippets and were pushing rows
   wider than the viewport.
   ========================================================= */
.pphs-app {
  overflow-x: hidden;
  max-width: 100vw;
}
.pphs-app .pphs-container {
  box-sizing: border-box;
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
.pphs-app .pphs-lb-table {
  max-width: 100%;
  overflow: hidden;
}
.pphs-app .pphs-lb-row,
.pphs-app .pphs-lb-head {
  max-width: 100%;
  min-width: 0;
}
.pphs-app .pphs-lb-row .col-name,
.pphs-app .pphs-lb-head .col-name {
  min-width: 0;
  overflow: hidden;
}
.pphs-app .lb-name-line {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.pphs-app .lb-blurb {
  overflow-wrap: anywhere;
  word-break: break-word;
  /* Cap to two lines so a single long class name can't push the row. */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.pphs-app .pphs-lb-row .col-stat {
  min-width: 0;
}


/* =========================================================
   Dashboard row grid - 5 stat columns instead of leaderboard's 7,
   so content fills the row edge to edge with nothing empty on the
   right. Scoped via the [data-pphs-app] attribute that only the
   dashboard container carries.
   ========================================================= */
.pphs-container[data-pphs-app] .pphs-lb-head,
.pphs-container[data-pphs-app] .pphs-lb-row {
  grid-template-columns: 48px minmax(0, 1.7fr) repeat(5, minmax(0, 0.85fr));
}


/* =========================================================
   Dropdown lockdown - the show <select> on the dashboard had
   long option text (uppercase show names) and was being auto-
   sized by the browser to fit the widest option, forcing the
   switcher wider than the container. Lock everything.
   ========================================================= */
.pphs-app .pphs-rider-switcher {
  max-width: 100% !important;
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}
.pphs-app .pphs-rider-switcher select {
  max-width: 100% !important;
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  flex: 1 1 0 !important;
}
.pphs-app .pphs-rider-switcher select option {
  /* Options open in a popup, no width contribution to the closed select. */
  max-width: 100vw;
}


/* All page titles uppercase, consistent across dashboard + leaderboard. */
.pphs-app .pphs-lb-title {
  text-transform: uppercase;
}


/* Responsive title sizing - dashboard's show names can be much longer than
   the leaderboard's "WHO'S HOT", so scale down hard on small screens. */
.pphs-app .pphs-lb-title {
  line-height: 1.15;
  overflow-wrap: anywhere;
  word-break: break-word;
}
@media (max-width: 640px) {
  .pphs-app .pphs-lb-title,
  .pphs-app .pphs-lb-header h2.pphs-lb-title[data-show-name] { font-size: 20px !important; }
}
@media (max-width: 480px) {
  .pphs-app .pphs-lb-title,
  .pphs-app .pphs-lb-header h2.pphs-lb-title[data-show-name] { font-size: 17px !important; }
}
@media (max-width: 380px) {
  .pphs-app .pphs-lb-title,
  .pphs-app .pphs-lb-header h2.pphs-lb-title[data-show-name] { font-size: 15px !important; }
}
