/* Picklary — design system
   Signature element: the DUPR rail (a rating-scale timeline for skills guides).
   Palette: deep teal #1E6F5C + amber #F4B400 on warm paper. Court-line motifs in CSS. */

:root {
  --main: #1E6F5C;
  --main-dark: #14513f;
  --main-tint: #e7f1ed;
  --sub: #F4B400;
  --sub-soft: #fbe9b0;
  --ink: #1d2421;
  --ink-soft: #4f5b56;
  --paper: #fbfaf5;
  --card: #ffffff;
  --line: #e3e1d6;
  --line-strong: #cfcdbf;
  --shadow: 0 1px 2px rgba(20,40,32,.05), 0 8px 28px -18px rgba(20,40,32,.28);
  --radius: 14px;
  --radius-sm: 9px;
  --wrap: 1080px;
  --measure: 68ch;
  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
}

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.65;
  font-size: 17px;
  /* faint court-line wash */
  background-image:
    linear-gradient(0deg, rgba(30,111,92,.025) 1px, transparent 1px);
  background-size: 100% 2.1rem;
}

h1, h2, h3, h4 { font-family: var(--font-display); line-height: 1.18; color: var(--ink); font-weight: 600; }
a { color: var(--main); text-underline-offset: 2px; }
a:hover { color: var(--main-dark); }
img { max-width: 100%; height: auto; }
hr { border: 0; border-top: 1px solid var(--line); margin: 2rem 0; }

.wrap { width: min(var(--wrap), 92vw); margin-inline: auto; }
.narrow { width: min(760px, 92vw); margin-inline: auto; }

.visually-hidden, .skip-link {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.skip-link:focus {
  position: fixed; top: .6rem; left: .6rem; width: auto; height: auto;
  clip: auto; padding: .6rem .9rem; background: var(--ink); color: #fff;
  border-radius: 8px; z-index: 1000;
}

/* ---------- focus visibility (a11y floor) ---------- */
:focus-visible { outline: 3px solid var(--sub); outline-offset: 2px; border-radius: 4px; }

/* ---------- buttons ---------- */
.btn {
  display: inline-block; font-family: var(--font-display); font-weight: 600;
  font-size: .98rem; padding: .68rem 1.15rem; border-radius: 999px;
  text-decoration: none; border: 1.5px solid transparent; cursor: pointer;
  transition: transform .12s ease, background .18s ease, border-color .18s ease;
}
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--main); color: #fff; }
.btn--primary:hover { background: var(--main-dark); color: #fff; }
.btn--ghost { background: transparent; color: var(--main); border-color: var(--line-strong); }
.btn--ghost:hover { border-color: var(--main); background: var(--main-tint); }

/* ---------- masthead ---------- */
.masthead { background: var(--paper); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 50; }
.masthead__inner { display: flex; align-items: center; gap: 1rem; padding: .75rem 0; flex-wrap: wrap; }
.brand { display: inline-flex; align-items: center; gap: .55rem; text-decoration: none; color: var(--ink); font-family: var(--font-display); font-weight: 700; }
.brand__name { font-size: 1.25rem; letter-spacing: -.01em; }
.brand__mark {
  width: 20px; height: 20px; border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, var(--sub) 0 35%, transparent 36%),
              var(--main);
  /* perforated-ball motif */
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.6);
  position: relative;
}
.nav { display: flex; gap: 1.15rem; margin-inline-start: auto; flex-wrap: wrap; }
.nav a { text-decoration: none; color: var(--ink-soft); font-weight: 500; font-size: .96rem; padding: .25rem 0; border-bottom: 2px solid transparent; }
.nav a:hover { color: var(--main); border-bottom-color: var(--sub); }
.nav-toggle { display: none; font-family: var(--font-display); font-weight: 600; background: transparent; border: 1.5px solid var(--line-strong); border-radius: 8px; padding: .4rem .7rem; cursor: pointer; }

.lang { display: inline-flex; align-items: center; gap: .35rem; }
.lang__icon { font-size: 1rem; }
.lang__select {
  font-family: var(--font-body); font-size: .92rem; color: var(--ink);
  background: var(--card); border: 1.5px solid var(--line-strong);
  border-radius: 999px; padding: .4rem 1.9rem .4rem .8rem; cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%231E6F5C' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right .7rem center;
}
[dir="rtl"] .lang__select { padding: .4rem .8rem .4rem 1.9rem; background-position: left .7rem center; }
[dir="rtl"] .nav { margin-inline-start: auto; }

/* ---------- hero ---------- */
.hero { padding: 3.2rem 0 2.4rem; border-bottom: 1px solid var(--line); background:
  radial-gradient(120% 80% at 100% 0%, var(--main-tint) 0%, transparent 55%); }
.hero__kicker { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .14em; font-size: .72rem; color: var(--main); margin: 0 0 .6rem; }
.hero__title { font-size: clamp(2rem, 5vw, 3.1rem); margin: 0 0 .8rem; letter-spacing: -.02em; }
.hero__lead { font-size: 1.12rem; color: var(--ink-soft); max-width: var(--measure); margin: 0 0 1.4rem; }
.hero__cta { display: flex; gap: .7rem; flex-wrap: wrap; margin-bottom: 2.4rem; }

/* ---------- DUPR rail (signature) ---------- */
.hero__rail { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem 1.5rem 1.2rem; box-shadow: var(--shadow); }
.hero__rail-label { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; color: var(--ink-soft); margin: 0 0 1.7rem; }
.hero__rail-note { font-size: .88rem; color: var(--ink-soft); margin: 1.9rem 0 0; }

.rail { position: relative; height: 56px; margin: 0 6px; }
.rail__line { position: absolute; top: 50%; left: 0; right: 0; height: 3px; background:
  repeating-linear-gradient(90deg, var(--main) 0 14px, transparent 14px 22px); border-radius: 2px; opacity: .55; }
.rail__tick { position: absolute; top: 50%; transform: translate(-50%, -50%); }
[dir="rtl"] .rail__tick, [dir="rtl"] .rail__pin { transform: translate(50%, -50%); }
.rail__tick::before { content: ""; display: block; width: 2px; height: 14px; background: var(--line-strong); margin: 0 auto; }
.rail__tick-label { position: absolute; top: 18px; left: 50%; transform: translateX(-50%); font-family: var(--font-mono); font-size: .7rem; color: var(--ink-soft); white-space: nowrap; }
[dir="rtl"] .rail__tick-label { left: auto; right: 50%; transform: translateX(50%); }

.rail__pin { position: absolute; top: 50%; transform: translate(-50%, -50%); text-decoration: none; z-index: 2; }
.rail__pin-dot { display: block; width: 16px; height: 16px; border-radius: 50%; background: var(--sub); border: 3px solid var(--card); box-shadow: 0 0 0 1.5px var(--sub); transition: transform .14s ease; }
.rail__pin:hover .rail__pin-dot, .rail__pin:focus-visible .rail__pin-dot { transform: scale(1.25); }
.rail__pin-label {
  position: absolute; bottom: 150%; left: 50%; transform: translateX(-50%);
  background: var(--ink); color: #fff; font-size: .76rem; line-height: 1.35;
  padding: .45rem .6rem; border-radius: 8px; width: max-content; max-width: 220px;
  opacity: 0; pointer-events: none; transition: opacity .14s ease; box-shadow: var(--shadow);
}
.rail__pin-label::after { content: ""; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border: 6px solid transparent; border-top-color: var(--ink); }
.rail__pin:hover .rail__pin-label, .rail__pin:focus-visible .rail__pin-label { opacity: 1; }

/* ---------- bands / sections ---------- */
.band { padding: 2.6rem 0; }
.band--alt { background: var(--main-tint); border-block: 1px solid var(--line); }
.band--brief { background: var(--ink); color: #f4f3ec; }
.band--brief .band__title, .band--brief a { color: #fff; }
.band--editor { background: var(--card); border-block: 1px solid var(--line); }
.band__title { font-size: 1.5rem; margin: 0 0 .4rem; }
.band__intro { color: var(--ink-soft); max-width: var(--measure); margin: 0 0 1.6rem; }
.band--brief .band__intro { color: #cfd6d2; }
.block { margin: 2.2rem 0; }

/* ---------- cards ---------- */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.1rem; }
.cards--two { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.card { position: relative; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.2rem 1.2rem 1.3rem; box-shadow: var(--shadow); transition: transform .14s ease, border-color .14s ease; }
.card:hover { transform: translateY(-3px); border-color: var(--main); }
.card__cat { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .1em; font-size: .68rem; color: var(--main); margin: 0 0 .5rem; }
.card__cat--column { color: var(--sub); }
.card--column { border-top: 3px solid var(--sub); }
.card__title { font-size: 1.16rem; margin: 0 0 .5rem; letter-spacing: -.01em; }
.card__link { text-decoration: none; color: var(--ink); }
.card__link::after { content: ""; position: absolute; inset: 0; }
.card:hover .card__title { color: var(--main); }
.card__summary { color: var(--ink-soft); font-size: .95rem; margin: 0 0 .7rem; }
.card__meta { font-size: .8rem; color: var(--ink-soft); display: flex; gap: .6rem; flex-wrap: wrap; }

/* ---------- topics (category index) ---------- */
.topics { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.1rem; list-style: none; padding: 0; margin: 0; }
.topic { position: relative; background: var(--card); border: 1px solid var(--line); border-left: 4px solid var(--main); border-radius: var(--radius-sm); padding: 1.1rem 1.2rem; box-shadow: var(--shadow); }
.topic h2, .topic h3 { margin: .1rem 0 .4rem; font-size: 1.2rem; }
.topic a { text-decoration: none; }
.topic a::after { content: ""; position: absolute; inset: 0; }
.topic__count { font-family: var(--font-mono); font-size: .72rem; color: var(--ink-soft); }
.topic__go { color: var(--main); font-weight: 600; font-size: .9rem; }
.topic__icon { display: inline-flex; align-items: center; justify-content: center; width: 50px; height: 50px; border-radius: 14px; margin-bottom: .7rem; background: var(--main-tint); color: var(--main-dark); }
.topic__icon svg { width: 29px; height: 29px; display: block; }
.topic--rules { border-left-color: #1E6F5C; }
.topic--rules .topic__icon { background: var(--main-tint); color: var(--main-dark); }
.topic--skills { border-left-color: #E8A800; }
.topic--skills .topic__icon { background: var(--sub-soft); color: #a9770a; }
.topic--gear { border-left-color: #2f6fed; }
.topic--gear .topic__icon { background: #e7eeff; color: #2f6fed; }
.topic--compete { border-left-color: #7b53e0; }
.topic--compete .topic__icon { background: #efe9fb; color: #6b46c6; }
.topic--scene { border-left-color: #d6455d; }
.topic--scene .topic__icon { background: #fbe7ea; color: #c23a52; }

/* ---------- page head ---------- */
.page-head { padding: 2.4rem 0 1.4rem; border-bottom: 1px solid var(--line); }
.page-head__eyebrow { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; color: var(--main); margin: 0 0 .5rem; }
.page-head h1 { font-size: clamp(1.7rem, 4vw, 2.5rem); margin: 0 0 .5rem; letter-spacing: -.02em; }
.page-head__intro { color: var(--ink-soft); max-width: var(--measure); margin: 0; }

/* ---------- breadcrumbs ---------- */
.crumbs { font-size: .82rem; color: var(--ink-soft); padding: .9rem 0; }
.crumbs a { color: var(--ink-soft); }
.crumbs a:hover { color: var(--main); }

/* ---------- post layout ---------- */
.page-post .post__head { padding: 2.2rem 0 1.2rem; }
.post__cat { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .1em; font-size: .72rem; color: var(--main); text-decoration: none; }
.post__title { font-size: clamp(1.8rem, 4.4vw, 2.7rem); margin: .5rem 0 .5rem; letter-spacing: -.02em; }
.post__subtitle { font-size: 1.15rem; color: var(--ink-soft); margin: 0 0 1rem; max-width: var(--measure); }
.post__byline { font-size: .85rem; color: var(--ink-soft); display: flex; gap: .6rem; flex-wrap: wrap; align-items: center; }
.post__grid { display: grid; grid-template-columns: 1fr; gap: 2rem; padding: 1.6rem 0 2.4rem; }
.post__aside { display: flex; flex-direction: column; gap: 1.2rem; }

/* ---------- prose ---------- */
.prose { max-width: var(--measure); }
.prose > * + * { margin-top: 1.05rem; }
.prose h2 { font-size: 1.5rem; margin-top: 2.2rem; scroll-margin-top: 5rem; }
.prose h3 { font-size: 1.2rem; margin-top: 1.6rem; }
.prose ul, .prose ol { padding-inline-start: 1.3rem; }
.prose li + li { margin-top: .35rem; }
.prose strong { color: var(--ink); }
.prose blockquote { margin: 1.4rem 0; padding: .4rem 0 .4rem 1.1rem; border-inline-start: 3px solid var(--sub); color: var(--ink-soft); font-style: italic; }
.prose code { font-family: var(--font-mono); font-size: .9em; background: var(--main-tint); padding: .1rem .35rem; border-radius: 5px; }

/* ---------- boxed components ---------- */
.toc { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 1rem 1.1rem; font-size: .92rem; }
.toc__title { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .1em; font-size: .72rem; color: var(--ink-soft); margin: 0 0 .6rem; }
.toc ol, .toc ul { margin: 0; padding-inline-start: 1.1rem; }
.toc li + li { margin-top: .35rem; }
.toc a { text-decoration: none; color: var(--ink-soft); }
.toc a:hover { color: var(--main); }

.takeaways, .mistakes, .checklist, .faq, .related { border-radius: var(--radius); padding: 1.2rem 1.3rem; }
.takeaways { background: var(--main-tint); border: 1px solid #cfe3db; }
.takeaways h2, .mistakes h2, .checklist h2, .faq h2, .related h2 { font-size: 1.15rem; margin: 0 0 .7rem; }
.mistakes { background: #fff6e2; border: 1px solid var(--sub-soft); }
.checklist { background: var(--card); border: 1px solid var(--line); }
.checklist ul { list-style: none; padding: 0; margin: 0; }
.checklist li { padding-inline-start: 1.7rem; position: relative; margin: .45rem 0; }
.checklist li::before { content: "✓"; position: absolute; inset-inline-start: 0; color: var(--main); font-weight: 700; }
.faq { background: var(--card); border: 1px solid var(--line); }
.faq dt { font-weight: 600; font-family: var(--font-display); margin-top: .9rem; }
.faq dd { margin: .3rem 0 0; color: var(--ink-soft); }
.related { background: transparent; padding-inline: 0; }

.tag { display: inline-block; font-family: var(--font-mono); font-size: .68rem; text-transform: uppercase; letter-spacing: .08em; color: var(--main); background: var(--main-tint); border-radius: 999px; padding: .15rem .6rem; }

.notice { background: #fff6e2; border: 1px solid var(--sub-soft); border-radius: var(--radius-sm); padding: .8rem 1rem; font-size: .92rem; color: var(--ink-soft); }
.notice--fallback { background: var(--main-tint); border-color: #cfe3db; }
.notice a { font-weight: 600; }

/* ---------- editor / author ---------- */
.editor-box { display: flex; gap: 1rem; align-items: flex-start; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.2rem; }
.editor-box__avatar { width: 52px; height: 52px; border-radius: 50%; background: var(--main); color: #fff; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; flex: 0 0 auto; }
.editor-box__name { font-family: var(--font-display); font-weight: 600; margin: 0 0 .2rem; }
.editor-box__bio { color: var(--ink-soft); font-size: .92rem; margin: 0; }
.principles { padding-inline-start: 1.2rem; color: var(--ink-soft); }
.principles li + li { margin-top: .4rem; }
.author-cta { background: var(--main-tint); border: 1px solid #cfe3db; border-radius: var(--radius); padding: 1.1rem 1.2rem; margin: 1.2rem 0; }
.author-cta__msg { margin: 0 0 .7rem; font-weight: 600; }

/* ---------- contact form ---------- */
.contact-form { display: grid; gap: .9rem; max-width: 520px; }
.contact-form label { display: grid; gap: .35rem; font-weight: 600; font-size: .92rem; }
.contact-form input, .contact-form textarea { font-family: var(--font-body); font-size: 1rem; padding: .65rem .8rem; border: 1.5px solid var(--line-strong); border-radius: var(--radius-sm); background: var(--card); color: var(--ink); }
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--main); outline: none; }
.contact-email { font-family: var(--font-mono); }

/* ---------- finder (paddle quiz) ---------- */
.finder { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.6rem; box-shadow: var(--shadow); max-width: 620px; }
.finder__q { font-family: var(--font-display); font-size: 1.25rem; font-weight: 600; margin: 0 0 1.1rem; }
.finder__progress { font-family: var(--font-mono); font-size: .72rem; color: var(--ink-soft); text-transform: uppercase; letter-spacing: .1em; margin: 0 0 .6rem; }
.finder__options { display: grid; gap: .7rem; }
.finder__opt { text-align: start; font-family: var(--font-body); font-size: 1rem; padding: .85rem 1rem; border: 1.5px solid var(--line-strong); border-radius: var(--radius-sm); background: var(--paper); cursor: pointer; transition: border-color .14s ease, background .14s ease; }
.finder__opt:hover { border-color: var(--main); background: var(--main-tint); }
.finder__result h3 { margin: 0 0 .6rem; }
.finder__recs { padding-inline-start: 1.2rem; }
.finder__recs li { margin: .4rem 0; }
.finder__actions { margin-top: 1.2rem; display: flex; gap: .6rem; }

/* ---------- The Brief edition ---------- */
.edition { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem 1.5rem; margin: 1.2rem 0; box-shadow: var(--shadow); }
.edition__title { font-size: 1.3rem; margin: 0 0 .4rem; }
.edition__lede { color: var(--ink-soft); margin: 0 0 1rem; }
.brief-list { list-style: none; padding: 0; margin: 0; }
.brief-list li { padding: .9rem 0; border-top: 1px solid var(--line); }
.brief-list li:first-child { border-top: 0; }
.brief-list__src { font-family: var(--font-mono); font-size: .72rem; color: var(--ink-soft); }

/* ---------- misc ---------- */
.link-more { font-weight: 600; text-decoration: none; }
.link-more::after { content: " →"; }
[dir="rtl"] .link-more::after { content: " ←"; }
.two-col { display: grid; grid-template-columns: 1fr; gap: 2rem; }

/* ---------- footer ---------- */
.site-foot { background: var(--ink); color: #cfd6d2; margin-top: 3rem; }
.site-foot__inner { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem; padding: 2.6rem 0; }
.site-foot__brand { font-family: var(--font-display); font-weight: 700; color: #fff; font-size: 1.2rem; }
.site-foot h4 { color: #fff; font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; font-family: var(--font-mono); font-weight: 500; margin: 0 0 .8rem; }
.site-foot__links { list-style: none; padding: 0; margin: 0; }
.site-foot__links li { margin: .4rem 0; }
.site-foot a { color: #cfd6d2; text-decoration: none; }
.site-foot a:hover { color: #fff; }
.site-foot__editor { color: #aab4b0; font-size: .9rem; }
.site-foot__legal { border-top: 1px solid rgba(255,255,255,.12); padding: 1.1rem 0; font-size: .82rem; color: #9aa6a1; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }

/* ---------- responsive ---------- */
@media (max-width: 860px) {
  .site-foot__inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  body { font-size: 16px; }
  .nav-toggle { display: inline-block; margin-inline-start: auto; order: 3; }
  .lang { order: 2; }
  .nav {
    flex-basis: 100%; order: 4; flex-direction: column; gap: 0;
    margin-inline-start: 0; display: none;
  }
  .nav.is-open { display: flex; }
  .nav a { padding: .6rem 0; border-bottom: 1px solid var(--line); }
  .site-foot__inner { grid-template-columns: 1fr; gap: 1.4rem; }
  .rail { height: 50px; }
  .rail__pin-label { max-width: 160px; font-size: .72rem; }
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .card:hover { transform: none; }
}

/* ---------- Picklary upgrade: side rail, level cards, comparison hubs ---------- */
.side-rail {
  display: none;
}
@media (min-width: 1280px) {
  .side-rail {
    display: block;
    position: fixed;
    left: max(12px, calc((100vw - var(--wrap)) / 2 - 112px));
    top: 92px;
    width: 92px;
    background: rgba(255,255,255,.9);
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: .75rem;
    box-shadow: var(--shadow);
    backdrop-filter: blur(8px);
    z-index: 35;
  }
  .side-rail__title {
    display: block;
    font-family: var(--font-mono);
    font-size: .65rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ink-soft);
    margin: 0 0 .55rem;
  }
  .side-rail a {
    display: block;
    text-decoration: none;
    font-size: .75rem;
    line-height: 1.2;
    color: var(--ink-soft);
    border-radius: 9px;
    padding: .38rem .42rem;
    margin: .08rem 0;
  }
  .side-rail a:hover { color: #fff; background: var(--main); }
  .side-rail__levels { display: grid; grid-template-columns: 1fr 1fr; gap: .1rem; margin-bottom: .5rem; }
  .side-rail__levels a { font-family: var(--font-mono); text-align: center; color: var(--main); background: var(--main-tint); }
  .side-rail__main { border-top: 1px solid var(--line); padding-top: .4rem; }
}

.hero--level { padding-bottom: 1.6rem; }
.hero__split, .two-col--wide { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(280px, .92fr); gap: 2rem; align-items: center; }
.hero-visual { margin: 0; }
.section-head { display: flex; justify-content: space-between; gap: 1rem; align-items: end; margin-bottom: 1.2rem; }
.section-head .band__intro { margin-bottom: 0; }

.visual-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: .75rem;
  box-shadow: var(--shadow);
  margin: 1rem 0 1.3rem;
}
.visual-card img { display: block; width: 100%; border-radius: 12px; }
.visual-card figcaption { margin: .65rem .25rem 0; color: var(--ink-soft); font-size: .88rem; }
.visual-card--article { margin-top: 1.1rem; }

.experiences { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; }
.experience {
  display: block;
  min-height: 100%;
  text-decoration: none;
  color: var(--ink);
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.25rem;
  box-shadow: var(--shadow);
  transition: transform .14s ease, border-color .14s ease;
}
.experience:hover { transform: translateY(-3px); border-color: var(--main); }
.experience__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 15px;
  background: var(--main-tint);
  color: var(--main-dark);
}
.experience__icon svg { width: 30px; height: 30px; display: block; }
.experience__icon--court { background: var(--main-tint); color: var(--main-dark); }
.experience__icon--paddles { background: var(--sub-soft); color: #a9770a; }
.experience__icon--players { background: #e7eeff; color: #2f6fed; }
.experience__icon--highlights { background: #efe9fb; color: #6b46c6; }
.experience h3 { margin: .75rem 0 .45rem; }
.experience p { margin: 0; color: var(--ink-soft); font-size: .95rem; }

.level-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1rem; }
.level-card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.level-card::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 5px; background: var(--sub); }
.level-card__link { display: block; text-decoration: none; color: var(--ink); padding: 1.15rem 1.15rem 1.2rem; min-height: 100%; }
.level-card__badge { display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px; border-radius: 50%; font-family: var(--font-mono); font-weight: 700; color: var(--main); background: var(--main-tint); border: 1px solid rgba(30,111,92,.18); }
.level-card h3 { margin: .8rem 0 .4rem; font-size: 1.12rem; }
.level-card p { color: var(--ink-soft); font-size: .94rem; margin: 0 0 .8rem; }
.level-card:hover { border-color: var(--main); }
.level-detail .visual-card { align-self: start; position: sticky; top: 90px; }
.level-actions, .source-buttons { display: flex; gap: .6rem; flex-wrap: wrap; margin: 1.4rem 0; }

.pills { display: flex; gap: .45rem; flex-wrap: wrap; margin: .65rem 0; }
.pill { display: inline-flex; align-items: center; border: 1px solid var(--line); background: var(--paper); border-radius: 999px; padding: .28rem .62rem; font-size: .79rem; color: var(--ink-soft); font-weight: 600; }
.pills--compact .pill { font-size: .73rem; padding: .22rem .52rem; }

.paddle-grid, .player-grid, .paddle-mini-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(245px, 1fr)); gap: 1rem; }
.paddle-mini-grid { margin: .8rem 0 1rem; }
.paddle-card, .player-card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  transition: transform .14s ease, border-color .14s ease;
}
.paddle-card:hover, .player-card:hover { transform: translateY(-2px); border-color: var(--main); }
.paddle-card__link, .player-card__link { display: block; text-decoration: none; color: var(--ink); padding: 1.1rem 1.15rem 1.2rem; min-height: 100%; }
.paddle-card__brand, .player-card__country { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--main); }
.paddle-card h3, .player-card h3 { margin: .45rem 0 .35rem; font-size: 1.08rem; }
.paddle-card__meta, .paddle-card__note, .player-card p { color: var(--ink-soft); font-size: .91rem; margin: 0 0 .65rem; }

.filter-panel {
  display: grid;
  grid-template-columns: auto repeat(3, minmax(160px, 1fr));
  align-items: end;
  gap: .8rem;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1rem;
  box-shadow: var(--shadow);
  margin-bottom: 1rem;
}
.filter-panel strong { font-family: var(--font-display); align-self: center; }
.filter-panel label { display: grid; gap: .25rem; font-size: .82rem; font-weight: 700; color: var(--ink-soft); }
.filter-panel select, .upload-card input, .upload-card select {
  width: 100%;
  font-family: var(--font-body);
  font-size: .96rem;
  color: var(--ink);
  background: var(--paper);
  border: 1.5px solid var(--line-strong);
  border-radius: var(--radius-sm);
  padding: .62rem .7rem;
}
.paddle-card.is-hidden { display: none; }

.spec-card, .upload-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.25rem;
}
.spec-table { width: 100%; border-collapse: collapse; font-size: .96rem; }
.spec-table th, .spec-table td { text-align: start; vertical-align: top; padding: .75rem .6rem; border-bottom: 1px solid var(--line); }
.spec-table th { width: 34%; color: var(--ink-soft); font-family: var(--font-mono); font-size: .76rem; text-transform: uppercase; letter-spacing: .08em; }

.highlight-demo { align-items: start; }
.upload-card { display: grid; gap: .85rem; }
.upload-card h2 { margin: 0 0 .25rem; }
.upload-card label { display: grid; gap: .35rem; font-weight: 700; font-size: .9rem; }
.leaderboard { display: grid; gap: .8rem; }
.highlight-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: .85rem;
  align-items: center;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: .9rem 1rem;
  box-shadow: var(--shadow);
}
.highlight-item__rank { font-family: var(--font-mono); font-weight: 700; color: var(--main); background: var(--main-tint); border-radius: 999px; padding: .35rem .55rem; }
.highlight-item h3 { font-size: 1rem; margin: 0 0 .15rem; }
.highlight-item p { margin: 0; color: var(--ink-soft); font-size: .86rem; }
.highlight-item__vote { white-space: nowrap; font-size: .86rem; padding-inline: .75rem; }

@media (max-width: 900px) {
  .hero__split, .two-col--wide { grid-template-columns: 1fr; }
  .section-head { align-items: start; flex-direction: column; }
  .filter-panel { grid-template-columns: 1fr; align-items: stretch; }
  .level-detail .visual-card { position: static; }
}

/* Enriched paddle/player cards */
.entity-card__media {
  position: relative;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, rgba(30,111,92,.08), rgba(242,184,75,.12));
  border: 1px solid var(--line);
  border-radius: 18px;
  margin: 0 0 .9rem;
  overflow: hidden;
  min-height: 210px;
}
.entity-card__media--player { min-height: 230px; }
.entity-card__img {
  width: min(100%, 280px);
  height: auto;
  display: block;
  border-radius: 16px;
}
.entity-card__media--paddle .entity-card__img { width: min(92%, 240px); }
.entity-card__media--player .entity-card__img { width: min(92%, 245px); }
.price-chip {
  position: absolute;
  right: .75rem;
  bottom: .75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 82px;
  padding: .42rem .65rem;
  border-radius: 999px;
  background: var(--sub);
  color: #1e211e;
  font-family: var(--font-mono);
  font-weight: 900;
  box-shadow: 0 10px 22px rgba(20,35,31,.18);
}
.player-card__bio {
  color: var(--ink-soft);
  font-size: .86rem !important;
  line-height: 1.55;
}
.entity-hero {
  display: grid;
  gap: .65rem;
  margin: 0;
  padding: .85rem;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.entity-hero__img {
  display: block;
  width: 100%;
  max-height: 520px;
  object-fit: contain;
  border-radius: 16px;
  background: #fff;
}
.entity-hero figcaption {
  color: var(--ink-soft);
  font-size: .84rem;
}
.page-head__intro--small {
  font-size: 1rem;
  margin-top: .7rem;
}
.rating-bars {
  display: grid;
  gap: .75rem;
  margin: 1rem 0;
}
.rating-row {
  display: grid;
  grid-template-columns: 110px minmax(120px, 1fr) 42px;
  gap: .65rem;
  align-items: center;
  font-size: .9rem;
}
.rating-row span { color: var(--ink-soft); font-weight: 800; }
.rating-row b {
  position: relative;
  display: block;
  height: 12px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--line);
}
.rating-row b i {
  display: block;
  width: var(--score);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--main), var(--sub));
}
.rating-row em {
  color: var(--ink);
  font-family: var(--font-mono);
  font-style: normal;
  font-weight: 900;
}
@media (max-width: 720px) {
  .entity-card__media { min-height: 180px; }
  .entity-card__media--player { min-height: 190px; }
  .rating-row { grid-template-columns: 92px 1fr 38px; }
}

/* ---------- DUPR level quick selector ---------- */
.rail__tick-link {
  color: var(--main);
  font-weight: 800;
  text-decoration: none;
  background: var(--main-tint);
  border: 1px solid rgba(30,111,92,.28);
  border-radius: 999px;
  padding: .12rem .34rem;
  transition: transform .14s ease, background .14s ease, color .14s ease, border-color .14s ease;
}
.rail__tick-link:hover,
.rail__tick-link:focus-visible {
  color: #fff;
  background: var(--main);
  border-color: var(--main);
  transform: translateX(-50%) translateY(-1px);
}
[dir="rtl"] .rail__tick-link:hover,
[dir="rtl"] .rail__tick-link:focus-visible { transform: translateX(50%) translateY(-1px); }
.level-quick-select {
  margin-top: 1.05rem;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
}
.level-quick-select__label {
  margin: 0 0 .55rem;
  font-weight: 800;
  color: var(--ink);
}
.level-quick-select__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}
.level-chip {
  display: inline-flex;
  min-width: 50px;
  min-height: 38px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
  background: var(--card);
  color: var(--main);
  font-family: var(--font-mono);
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 6px 14px rgba(15, 23, 42, .06);
}
.level-chip:hover,
.level-chip:focus-visible {
  background: var(--main);
  color: #fff;
  border-color: var(--main);
}
.level-quick-select__hint {
  margin: .65rem 0 0;
  font-size: .86rem;
  color: var(--ink-soft);
}

/* ---------- AdSense readiness: source panels ---------- */
.source-panel {
  margin: 1.6rem 0;
  padding: 1.15rem 1.2rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--main-tint);
  box-shadow: var(--shadow);
}
.source-panel h2 {
  margin: 0 0 .45rem;
  font-size: 1.08rem;
}
.source-panel p {
  margin: 0;
  color: var(--ink-soft);
}
.source-panel ul {
  margin: .8rem 0 0;
  padding-inline-start: 1.15rem;
}
.source-panel li {
  margin: .35rem 0;
}
.source-panel a {
  font-weight: 700;
}

/* ---------- Community boards: FAQ + Q&A ---------- */
.board-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem;
}
.board-card {
  display: block;
  min-height: 220px;
  padding: 1.35rem;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  color: var(--ink);
  text-decoration: none;
  transition: transform .14s ease, border-color .14s ease;
}
.board-card:hover,
.board-card:focus-visible {
  transform: translateY(-3px);
  border-color: var(--main);
}
.board-card__eyebrow {
  display: inline-flex;
  margin-bottom: .8rem;
  font-family: var(--font-mono);
  font-size: .75rem;
  font-weight: 800;
  color: var(--main);
  text-transform: uppercase;
  letter-spacing: .1em;
}
.board-card h3 { margin: 0 0 .55rem; }
.board-card p { margin: 0; color: var(--ink-soft); }
.board-cta-row { display: flex; flex-wrap: wrap; gap: .65rem; margin-top: 1.1rem; }
.board-filter { margin-bottom: 1.4rem; }
.board-level {
  margin: 1.6rem 0;
  padding: 1.2rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: var(--shadow);
}
.board-level.is-hidden { display: none; }
.faq-list { display: grid; gap: .7rem; }
.faq-row {
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--paper);
  overflow: hidden;
}
.faq-row summary {
  display: flex;
  align-items: center;
  gap: .55rem;
  padding: .85rem 1rem;
  cursor: pointer;
  font-weight: 800;
}
.faq-row p {
  margin: 0;
  padding: 0 1rem 1rem 1rem;
  color: var(--ink-soft);
}
.local-suggestion-list { display: grid; gap: .6rem; margin-top: .8rem; }
.local-suggestion {
  padding: .75rem .85rem;
  border: 1px dashed var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--paper);
}
.local-suggestion strong { display: block; }
.local-suggestion span { display: block; color: var(--ink-soft); font-size: .88rem; }
.board-demo { align-items: start; }
.board-qna-filter { grid-template-columns: auto minmax(180px, 1fr); }
.qna-board { display: grid; gap: 1rem; }
.qna-item {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.05rem;
}
.qna-item__head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: start;
}
.qna-item__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin: .35rem 0 .75rem;
}
.qna-item__status {
  font-family: var(--font-mono);
  font-size: .72rem;
  color: var(--main);
  background: var(--main-tint);
  border: 1px solid rgba(30,111,92,.18);
  border-radius: 999px;
  padding: .18rem .48rem;
}
.qna-item h3 { margin: 0; font-size: 1.08rem; }
.qna-item__question { margin: .65rem 0 1rem; color: var(--ink-soft); }
.qna-answers { display: grid; gap: .65rem; margin: .8rem 0; }
.qna-answer {
  border-left: 4px solid var(--sub);
  padding: .65rem .8rem;
  background: var(--paper);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}
.qna-answer p { margin: .25rem 0 0; }
.qna-answer__by { margin: 0; font-family: var(--font-mono); font-size: .75rem; color: var(--ink-soft); }
.qna-add-answer { display: grid; grid-template-columns: 1fr auto; gap: .55rem; align-items: end; margin-top: .8rem; }
.qna-add-answer textarea,
.contact-form textarea,
.upload-card textarea {
  width: 100%;
  font-family: var(--font-body);
  font-size: .96rem;
  color: var(--ink);
  background: var(--paper);
  border: 1.5px solid var(--line-strong);
  border-radius: var(--radius-sm);
  padding: .62rem .7rem;
}
.qna-item.is-hidden { display: none; }
@media (max-width: 720px) {
  .qna-item__head { display: grid; }
  .qna-add-answer { grid-template-columns: 1fr; }
  .board-qna-filter { grid-template-columns: 1fr; }
}

/* --- Update center ------------------------------------------------------ */
.update-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin: 0 0 1.35rem;
}
.update-tabs a {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: .45rem .78rem;
  background: var(--paper);
  color: var(--ink);
  font-weight: 800;
  font-size: .9rem;
}
.update-tabs a.is-active,
.update-tabs a:hover {
  background: var(--main);
  border-color: var(--main);
  color: #fff;
  text-decoration: none;
}
.update-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1rem;
}
.update-grid--home {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.update-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.05rem;
  display: grid;
  gap: .65rem;
}
.update-card__top {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
  align-items: center;
}
.update-card h3 { margin: 0; font-size: 1.08rem; }
.update-card p { margin: 0; color: var(--ink-soft); }
.update-card__action {
  border-top: 1px dashed var(--line-strong);
  padding-top: .65rem;
}
.update-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .2rem .5rem;
  font-family: var(--font-mono);
  font-size: .72rem;
  background: var(--main-tint);
  color: var(--main);
  border: 1px solid rgba(30,111,92,.18);
}
.update-chip--critical,
.update-chip--high {
  background: rgba(244,180,0,.14);
  border-color: rgba(244,180,0,.42);
  color: #6d4b00;
}
.update-workflow {
  border: 1px solid var(--line);
  background: var(--paper);
  border-radius: var(--radius);
  padding: 1rem;
  margin-bottom: 1.35rem;
}
.update-workflow h2 { margin-top: 0; }
.update-workflow ol { margin-bottom: 0; }
.source-watch-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: .85rem;
}
.source-watch {
  position: relative;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--card);
  padding: .9rem;
}
.source-watch h3 { margin: .2rem 0 .45rem; font-size: 1rem; }
.source-watch p { color: var(--ink-soft); margin: 0 0 .6rem; font-size: .9rem; }
.source-watch__status {
  display: inline-flex;
  border-radius: 999px;
  padding: .16rem .48rem;
  font-family: var(--font-mono);
  font-size: .68rem;
  background: var(--main-tint);
  color: var(--main);
}
.source-watch--disabled { opacity: .72; }
.source-watch--disabled .source-watch__status {
  background: var(--paper);
  color: var(--ink-soft);
  border: 1px solid var(--line-strong);
}

/* DUPR snapshot and paddle user-reaction upgrade */
.dupr-chip { display:inline-block; margin:.35rem 0 .15rem; padding:.22rem .55rem; border-radius:999px; background:rgba(0,131,116,.12); color:var(--main); font-family:var(--font-mono); font-size:.72rem; font-weight:700; }
.dupr-chip--muted { color:var(--muted); background:rgba(100,116,139,.12); }
.dupr-panel { border-color:rgba(0,131,116,.25); }
.reviewer-roundup { display:grid; gap:.75rem; }
.reviewer-row { display:flex; justify-content:space-between; gap:1rem; padding:.8rem; border:1px solid var(--border); border-radius:16px; background:var(--paper); }
.reviewer-row p { margin:.25rem 0 0; color:var(--ink-soft); font-size:.9rem; }
.reviewer-score { display:flex; flex-direction:column; align-items:flex-end; gap:.3rem; white-space:nowrap; font-family:var(--font-mono); font-size:.78rem; }
.paddle-engagement .btn.is-liked { box-shadow:0 0 0 3px rgba(0,131,116,.18); }
.mini-form { display:grid; gap:.75rem; margin-top:1rem; }
.mini-form label { display:grid; gap:.28rem; font-weight:700; }
.mini-form input, .mini-form textarea { width:100%; border:1px solid var(--border); border-radius:14px; padding:.75rem .85rem; font:inherit; background:var(--paper); color:var(--ink); }
.mini-form textarea { min-height:115px; resize:vertical; }
.local-reviews { display:grid; gap:.65rem; margin-top:1rem; }
.local-review { border-left:4px solid var(--main); padding:.7rem .85rem; background:rgba(0,131,116,.06); border-radius:12px; }
.local-review p { margin:.25rem 0 0; color:var(--ink-soft); }
@media (max-width: 720px) { .reviewer-row { flex-direction:column; } .reviewer-score { align-items:flex-start; } }

/* ---- tournament result recaps (verified, source-linked) ---- */
.recaps { display: flex; flex-direction: column; gap: 1.1rem; }
.recap { background: var(--card); border: 1px solid var(--line); border-left: 4px solid var(--main); border-radius: var(--radius); padding: 1.2rem 1.3rem; }
.recap__head { margin-bottom: .6rem; }
.recap__tier { display: inline-block; font: 700 .68rem var(--font-body); letter-spacing: .08em; text-transform: uppercase; color: var(--main-dark); background: var(--main-tint); border-radius: 999px; padding: .2rem .6rem; margin: 0 0 .4rem; }
.recap__title { font-family: var(--font-display); font-size: 1.25rem; margin: 0 0 .15rem; }
.recap__meta { color: var(--ink-soft); font-size: .9rem; margin: 0; }
.recap__summary { margin: .7rem 0 1rem; }
.recap__winners h3, .recap__story h3 { font-family: var(--font-display); font-size: 1rem; margin: 0 0 .5rem; }
.recap-win { list-style: none; margin: 0 0 1rem; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: .4rem .9rem; }
.recap-win li { display: flex; flex-direction: column; padding: .5rem .7rem; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-sm); }
.recap-win__div { font: 700 .72rem var(--font-body); text-transform: uppercase; letter-spacing: .04em; color: var(--ink-soft); }
.recap-win__champ { font-weight: 600; }
.recap__story { background: var(--sub-soft); border-radius: var(--radius-sm); padding: .8rem 1rem; margin-bottom: 1rem; }
.recap__story h3 { color: #7a5b12; }
.recap__story p { margin: 0; }

/* ---- active top-nav highlight ---- */
.nav a.is-active { color: var(--main-dark); font-weight: 600; position: relative; }
.nav a.is-active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -6px; height: 3px; border-radius: 3px; background: var(--sub); }
@media (max-width: 880px) { .nav a.is-active { background: var(--main-tint); border-radius: var(--radius-sm); } .nav a.is-active::after { display: none; } }

/* ---- DUPR pathway milestones (home rail): 4 distinct shapes + colours ---- */
.rail--interactive { padding-bottom: 1.4rem; }
.rail__tick--minor .rail__tick-label { opacity: .6; font-size: .78rem; }
.rail__ms { position: absolute; top: 50%; transform: translate(-50%, -50%); display: flex; flex-direction: column; align-items: center; gap: .25rem; background: none; border: 0; cursor: pointer; padding: 0; z-index: 3; }
.rail__ms-dot { width: 26px; height: 26px; border: 3px solid #fff; box-shadow: var(--shadow); transition: transform .12s ease; }
.rail__ms:hover .rail__ms-dot, .rail__ms[aria-expanded="true"] .rail__ms-dot { transform: scale(1.18); }
.rail__ms-num { font: 700 .78rem var(--font-mono); color: var(--ink); background: var(--card); border: 1px solid var(--line); border-radius: 999px; padding: 0 .35rem; }
/* m0=2.0 teal circle, m1=3.0 amber diamond, m2=4.0 blue square, m3=5.0 purple star */
.rail__ms--m0 .rail__ms-dot { background: #1E6F5C; border-radius: 50%; }
.rail__ms--m1 .rail__ms-dot { background: #F4B400; border-radius: 4px; transform: rotate(45deg); }
.rail__ms--m1:hover .rail__ms-dot, .rail__ms--m1[aria-expanded="true"] .rail__ms-dot { transform: rotate(45deg) scale(1.18); }
.rail__ms--m2 .rail__ms-dot { background: #2f6fed; border-radius: 4px; }
.rail__ms--m3 .rail__ms-dot { background: #7b53e0; border-radius: 50%; clip-path: polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%); border: 0; }

/* ---- milestone popup ---- */
.ms-pop { position: absolute; z-index: 60; width: min(330px, calc(100vw - 24px)); background: var(--card); border: 1px solid var(--line); border-top: 5px solid var(--main); border-radius: var(--radius); box-shadow: 0 12px 40px -12px rgba(20,40,32,.4); padding: 1rem 1.1rem 1.2rem; }
.ms-pop--m0 { border-top-color: #1E6F5C; }
.ms-pop--m1 { border-top-color: #F4B400; }
.ms-pop--m2 { border-top-color: #2f6fed; }
.ms-pop--m3 { border-top-color: #7b53e0; }
.ms-pop__close { position: absolute; top: .4rem; right: .5rem; background: none; border: 0; font-size: 1.4rem; line-height: 1; color: var(--ink-soft); cursor: pointer; }
.ms-pop__eyebrow { font: 700 .7rem var(--font-mono); letter-spacing: .06em; color: var(--main-dark); margin: 0 0 .15rem; }
.ms-pop__title { font-family: var(--font-display); font-size: 1.05rem; margin: 0 0 .4rem; }
.ms-pop__summary { font-size: .92rem; color: var(--ink-soft); margin: 0 0 .6rem; }
.ms-pop__focus { margin: 0 0 .9rem; padding-left: 1.1rem; font-size: .9rem; display: flex; flex-direction: column; gap: .25rem; }
.ms-pop__cta { width: 100%; text-align: center; }

/* ---- DUPR self-check quiz ---- */
.quiz__bar { display: flex; align-items: center; gap: .8rem; margin-bottom: .8rem; }
.quiz__count { font: 700 .85rem var(--font-mono); color: var(--main-dark); white-space: nowrap; }
.quiz__progress { flex: 1; height: 8px; background: var(--main-tint); border-radius: 999px; overflow: hidden; }
.quiz__progress span { display: block; height: 100%; background: var(--main); width: 0; transition: width .25s ease; }
.quiz__prompt { font-size: 1.05rem; font-weight: 600; margin: 0 0 .35rem; }
.quiz__incoming { color: var(--ink-soft); margin: 0 0 1rem; }
.quiz__layout { display: grid; grid-template-columns: minmax(0, 340px) minmax(0, 1fr); gap: 1.4rem; align-items: start; }
.quiz__court { position: sticky; top: 1rem; }
.court-svg { width: 100%; max-width: 340px; height: auto; display: block; margin: 0 auto; }
.court-zone { fill: transparent; stroke: rgba(30,111,92,.25); stroke-dasharray: 4 4; cursor: pointer; transition: fill .12s ease; }
.court-zone:hover { fill: rgba(244,180,0,.22); }
.court-zone.is-selected { fill: rgba(244,180,0,.55); stroke: #b58a00; stroke-dasharray: none; }
.court-dot { stroke: #fff; stroke-width: 2; }
.court-dot--you { fill: #1E6F5C; }
.court-dot--opp { fill: #e0653b; }
.court-dot--ball { fill: #F4B400; stroke: #14513f; }
.court-ballpath { stroke: #e0653b; stroke-width: 2.5; stroke-dasharray: 5 4; }
.court-legend { list-style: none; display: flex; flex-wrap: wrap; gap: .8rem; justify-content: center; margin: .6rem 0 0; padding: 0; font-size: .82rem; color: var(--ink-soft); }
.court-legend li { display: flex; align-items: center; gap: .35rem; }
.court-legend .dot { width: 12px; height: 12px; border-radius: 50%; display: inline-block; }
.court-legend .dot--you { background: #1E6F5C; }
.court-legend .dot--opp { background: #e0653b; }
.court-legend .dot--ball { background: #F4B400; }
.quiz__group { margin-bottom: 1rem; }
.quiz__group h3 { font-family: var(--font-display); font-size: .98rem; margin: 0 0 .5rem; }
.quiz__hint { font-size: .85rem; color: var(--ink-soft); margin: 0 0 .3rem; }
.quiz__zone-label { font-weight: 600; margin: 0; }
.opts { display: flex; flex-wrap: wrap; gap: .45rem; }
.opt { font: 500 .9rem var(--font-body); padding: .5rem .85rem; background: var(--paper); border: 1.5px solid var(--line-strong); border-radius: 999px; cursor: pointer; transition: all .12s ease; }
.opt:hover { border-color: var(--main); }
.opt.is-selected { background: var(--main); color: #fff; border-color: var(--main); }
.quiz__next { margin-top: .4rem; }
.quiz__next:disabled { opacity: .45; cursor: not-allowed; }
/* result */
.result-card { background: var(--card); border: 1px solid var(--line); border-top: 5px solid var(--main); border-radius: var(--radius); padding: 1.4rem 1.5rem; }
.result-card__eyebrow { font: 700 .8rem var(--font-mono); color: var(--main-dark); margin: 0 0 .2rem; }
.result-card__band { font-family: var(--font-display); font-size: 1.6rem; margin: 0 0 .4rem; }
.result-card__desc { margin: 0 0 1rem; }
.result-card__actions { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1rem; }
.result-card__review { font-family: var(--font-display); font-size: 1.1rem; margin: 1.2rem 0 .6rem; }
.qr-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .7rem; }
.qr { padding: .8rem 1rem; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-sm); }
.qr__q { font-weight: 600; margin: 0 0 .35rem; }
.qr__line { margin: .15rem 0; font-size: .9rem; }
.qr__pts { font: 700 .8rem var(--font-mono); color: var(--main-dark); }
.qr__best { color: var(--ink-soft); }
.qr__why { margin: .4rem 0 0; font-size: .88rem; color: var(--ink-soft); }
@media (max-width: 760px) { .quiz__layout { grid-template-columns: 1fr; } .quiz__court { position: static; } }

/* ---- rankings board (current leaders) ---- */
.rankings-board__note { color: var(--ink-soft); margin: 0 0 1rem; }
.rankings-board__note .muted { font: 600 .8rem var(--font-mono); color: var(--main-dark); }
.rank-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 1rem; margin-bottom: 1.1rem; }
.rank-card { background: var(--card); border: 1px solid var(--line); border-top: 4px solid var(--sub); border-radius: var(--radius); padding: 1rem 1.1rem; }
.rank-card__disc { font-family: var(--font-display); font-size: .82rem; letter-spacing: .04em; text-transform: uppercase; color: var(--main-dark); margin: 0 0 .7rem; }
.rank-card__leaders { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; margin-bottom: .6rem; }
.rank-amp { color: var(--ink-soft); font-weight: 600; }
.rank-person { display: inline-flex; align-items: center; gap: .5rem; text-decoration: none; color: var(--ink); font-weight: 600; }
a.rank-person:hover .rank-name { text-decoration: underline; }
.rank-avatar { width: 40px; height: 40px; border-radius: 50%; overflow: hidden; flex: 0 0 auto; background: var(--main-tint); border: 2px solid #fff; box-shadow: var(--shadow); display: grid; place-items: center; }
.rank-avatar__img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rank-avatar--ini { background: var(--main); }
.rank-avatar__ini { font: 700 .85rem var(--font-mono); color: #fff; }
.rank-name { font-size: .95rem; }
.rank-card__chasers { font-size: .85rem; margin: 0 0 .5rem; color: var(--ink-soft); }
.rank-card__chasers-label { font-weight: 700; color: var(--ink); }
.rank-card__chasers a { color: var(--main-dark); }
.rank-sep { margin: 0 .35rem; color: var(--line-strong); }
.rank-card__note { font-size: .88rem; margin: 0; color: var(--ink-soft); }

/* ---- DUPR self-check v2: power chip, ball path, nav, reveal ---- */
.quiz__power-chip { display: inline-block; font: 700 .72rem var(--font-mono); padding: .12rem .5rem; border-radius: 999px; vertical-align: middle; }
.quiz__power-chip--soft { background: #e7f1ed; color: #14513f; }
.quiz__power-chip--medium { background: #fbe9b0; color: #7a5b12; }
.quiz__power-chip--hard { background: #f7d7cb; color: #9c3a17; }
.court-ballpath { fill: none; }
.court-ballpath--soft { stroke: #2f9e7f; }
.court-ballpath--medium { stroke: #e0a900; }
.court-ballpath--hard { stroke: #e0653b; }
.court-arrow--soft { fill: #2f9e7f; }
.court-arrow--medium { fill: #e0a900; }
.court-arrow--hard { fill: #e0653b; }
.quiz__nav { display: flex; gap: .6rem; align-items: center; margin-top: .4rem; }
.quiz__back { flex: 0 0 auto; }
.quiz__next { flex: 1; }
.quiz__next:disabled { opacity: .45; cursor: not-allowed; }
.result-card__score { font: 600 .9rem var(--font-mono); color: var(--ink-soft); margin: 0 0 1rem; }
.result-card__band { font-variant-numeric: tabular-nums; }
.qr__reveal { margin: .2rem 0 0; font: 600 .82rem var(--font-body); color: var(--main-dark); background: var(--main-tint); border: 1px solid var(--main-tint); border-radius: 999px; padding: .3rem .7rem; cursor: pointer; }
.qr__reveal:hover { border-color: var(--main); }
.qr__reveal.is-open { background: var(--card); }
.qr__answer { margin-top: .5rem; border-top: 1px dashed var(--line-strong); padding-top: .5rem; }

/* ---- level quick-select: self-check link + per-1.0 colour ---- */
.level-quick-select__selfcheck { display: block; text-align: center; font: 700 .92rem var(--font-body); color: #fff; background: var(--main); border-radius: var(--radius-sm); padding: .55rem .8rem; margin-bottom: .7rem; text-decoration: none; }
.level-quick-select__selfcheck:hover { background: var(--main-dark); }
.level-chip { border: 2px solid var(--line-strong); }
.level-chip--b2 { background: #e7f1ed; border-color: #1E6F5C; color: #14513f; }
.level-chip--b3 { background: #fbecbe; border-color: #d9a400; color: #7a5b12; }
.level-chip--b4 { background: #e4ecfd; border-color: #2f6fed; color: #21409a; }
.level-chip--b4 { color: #21409a; }
.level-chip--b5 { background: #ece6fb; border-color: #7b53e0; color: #4f2fae; }
.level-chip:hover { filter: brightness(.97); transform: translateY(-1px); }

/* self-check CTA on the levels index page head */
.level-index-cta { margin: 1.1rem 0 0; }

/* cross-link callout between Tournaments and Update Center */
.cross-note { background: var(--main-tint); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem 1.5rem; }
.cross-note .band__title { margin-top: 0; }
.cross-note p { margin: .4rem 0 0; color: var(--ink-soft); max-width: 62ch; }
.cross-note p:last-child { margin-top: .9rem; }

/* subtle build stamp (helps confirm you're viewing the latest build) */
.site-foot__build { opacity: .45; font-size: .72rem; margin-left: .5rem; font-family: var(--font-mono); }
