/* SLOP.game — Pro pricing: nav pill + credit chip + pricing modal. */

/* ---- nav pill + credit chip ---- */
.nav-pro-slot { display: inline-flex; align-items: center; gap: 8px; }

.nav-pro {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 13px; letter-spacing: -0.01em;
  color: #fff; background: linear-gradient(120deg, var(--pk), var(--el));
  border: 2px solid var(--ink); border-radius: 100px;
  padding: 7px 15px; cursor: pointer; white-space: nowrap;
  box-shadow: 3px 3px 0 var(--ink); transition: transform .12s, box-shadow .12s, filter .15s;
}
.nav-pro:hover { transform: translate(-1px, -1px); box-shadow: 4px 4px 0 var(--ink); filter: brightness(1.06); }
.np-spark { font-size: 12px; line-height: 1; }
.nav-credits {
  display: inline-flex; align-items: center; gap: 3px;
  font-family: 'Space Mono', monospace; font-weight: 700; font-size: 12.5px;
  color: var(--ink); background: var(--y);
  border: 2.5px solid var(--ink); border-radius: 100px;
  padding: 5px 11px; cursor: pointer; white-space: nowrap;
  box-shadow: 2px 2px 0 var(--ink);
}
.nav-credits:hover { transform: translate(-1px, -1px); }
.nav-pro-badge {
  font-family: 'Space Grotesk', sans-serif; font-size: 12px; letter-spacing: .04em;
  color: #fff; background: linear-gradient(120deg, var(--pk), var(--el));
  border: 2.5px solid var(--ink); border-radius: 100px; padding: 4px 11px;
  cursor: pointer; box-shadow: 2px 2px 0 var(--ink);
}
@media (max-width: 720px) {
  .nav-pro { font-size: 12px; padding: 6px 12px; }
}

/* ---- pricing modal ---- */
.pr-modal {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(26, 26, 46, .66); backdrop-filter: blur(6px);
  display: grid; place-items: center; padding: 20px; overflow-y: auto;
}
.pr-modal.hidden { display: none; }
.pr-sheet {
  position: relative; width: 100%; max-width: 440px;
  background: var(--cr); border: var(--bw) solid var(--ink); border-radius: 24px;
  box-shadow: var(--shb); padding: 26px 24px 20px; max-height: calc(100vh - 40px); overflow-y: auto;
}
.pr-close {
  position: absolute; top: 14px; right: 14px; width: 34px; height: 34px;
  border: 2.5px solid var(--ink); border-radius: 11px; background: var(--wh);
  font-size: 21px; line-height: 1; cursor: pointer; box-shadow: 2px 2px 0 var(--ink);
}
.pr-head { text-align: center; margin-bottom: 16px; }
.pr-kicker { font-family: 'Space Mono', monospace; font-size: 11px; font-weight: 700; color: var(--soft); text-transform: lowercase; }
.pr-kicker b { color: var(--pk); }
.pr-title { font-family: 'Space Grotesk', sans-serif; font-size: 38px; margin: 4px 0 6px; }
.pr-grad { background: linear-gradient(120deg, var(--pk), var(--el)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.pr-price { display: flex; align-items: baseline; justify-content: center; gap: 6px; flex-wrap: wrap; }
.pr-price s { font-size: 20px; font-weight: 800; color: var(--soft); opacity: .7; }
.pr-price b { font-family: 'Space Grotesk', sans-serif; font-size: 34px; color: var(--ink); }
.pr-price span { font-weight: 800; color: var(--soft); }
.pr-tag {
  font-family: 'Space Mono', monospace; font-size: 10px; font-weight: 700; font-style: normal;
  text-transform: uppercase; letter-spacing: .04em; background: var(--y); color: var(--ink);
  border: 2px solid var(--ink); border-radius: 6px; padding: 2px 7px; margin-left: 4px;
}
.pr-perks { list-style: none; margin: 0 0 16px; padding: 14px 16px; display: flex; flex-direction: column; gap: 9px;
  background: var(--wh); border: 2.5px solid var(--ink); border-radius: 16px; }
.pr-perks li { font-size: 14px; font-weight: 700; color: var(--soft); line-height: 1.35; }
.pr-perks b { color: var(--ink); }
.pr-body { display: flex; flex-direction: column; gap: 12px; }
.pr-balance { text-align: center; font-family: 'Space Mono', monospace; font-weight: 700; color: var(--ink); }
.pr-balance b { font-size: 18px; }
.pr-cta {
  width: 100%; font-family: 'Space Grotesk', sans-serif; font-size: 18px; padding: 14px;
  border: var(--bw) solid var(--ink); border-radius: 100px; background: var(--pk); color: #fff;
  cursor: pointer; box-shadow: var(--sh); transition: transform .12s, box-shadow .12s;
}
.pr-cta:hover { transform: translate(-2px, -2px); box-shadow: var(--shb); }
.pr-cta[disabled] { opacity: .6; cursor: default; transform: none; }
.pr-note { text-align: center; font-size: 12px; font-weight: 700; color: var(--soft); margin: 0; }
.pr-topups { border-top: 2px dashed rgba(26,26,46,.2); padding-top: 12px; }
.pr-topups-h, .pr-ref-h { font-size: 12px; font-weight: 800; color: var(--soft); margin-bottom: 8px; text-transform: uppercase; letter-spacing: .04em; }
.pr-topups-row { display: flex; gap: 8px; }
.pr-topup {
  flex: 1; font-family: 'Nunito', sans-serif; font-weight: 800; font-size: 13px; color: var(--ink);
  background: var(--mt); border: 2.5px solid var(--ink); border-radius: 12px; padding: 10px 8px;
  cursor: pointer; box-shadow: 2px 2px 0 var(--ink); position: relative;
}
.pr-topup:hover { transform: translate(-1px, -1px); }
.pr-best { display: block; font-family: 'Space Mono', monospace; font-size: 8.5px; font-weight: 700; color: var(--soft); margin-top: 2px; }
.pr-ref { border-top: 2px dashed rgba(26,26,46,.2); padding-top: 12px; }
.pr-ref-row { display: flex; gap: 8px; }
.pr-ref-link {
  flex: 1; min-width: 0; font-family: 'Space Mono', monospace; font-size: 11.5px; font-weight: 700;
  border: 2.5px solid var(--ink); border-radius: 10px; padding: 8px 10px; background: var(--wh); color: var(--ink);
}
.pr-ref-copy {
  font-family: 'Nunito', sans-serif; font-weight: 800; font-size: 13px; color: var(--ink);
  background: var(--y); border: 2.5px solid var(--ink); border-radius: 10px; padding: 0 14px; cursor: pointer; box-shadow: 2px 2px 0 var(--ink);
}
.pr-youre-pro { text-align: center; font-size: 16px; font-weight: 800; color: var(--ink); padding: 6px 0; }
.pr-disclosure { font-size: 11px; font-weight: 600; color: var(--soft); text-align: center; margin: 14px 0 0; line-height: 1.45; }

/* hide any static ad slots for Pro members */
body.slop-pro .ad-slot { display: none !important; }
