/* ========================================================
   Beijing Orion — Design System
   Premium navy + electric blue + champagne gold
   ======================================================== */
:root{
  /* Colors */
  --navy-950:#050B18;
  --navy-900:#0A1628;
  --navy-850:#0C1A30;
  --navy-800:#0F1E38;
  --navy-700:#17294A;
  --navy-600:#1F3660;
  --line:rgba(255,255,255,.06);
  --line-strong:rgba(255,255,255,.12);
  --line-bright:rgba(255,255,255,.2);

  --blue-500:#2E6BFF;      /* electric */
  --blue-400:#5B8BFF;
  --blue-300:#8FB0FF;
  --blue-glow:rgba(46,107,255,.3);

  --gold:#C9A961;          /* champagne */
  --gold-bright:#E4C77A;
  --gold-glow:rgba(201,169,97,.25);

  --text:#E8EEFA;
  --text-dim:#9AA9C4;
  --text-mute:#5E6E8C;

  /* Type — modular scale 1.25 (major third) */
  --font-display:"Playfair Display", "Noto Serif SC", Georgia, serif;
  --font-body:"Inter", -apple-system, "PingFang SC", "Microsoft YaHei", sans-serif;
  --fs-xs:11px;     /* overline / caption */
  --fs-sm:13px;     /* secondary body */
  --fs-base:15px;   /* body */
  --fs-md:17px;     /* emphasized */
  --fs-lg:21px;     /* card title */
  --fs-xl:26px;     /* section sub */
  --fs-2xl:32px;    /* h3 / KPI value */
  --fs-3xl:40px;    /* h2 */
  --fs-4xl:52px;    /* hero sub */
  --fs-5xl:68px;    /* hero */
  --lh-tight:1.2;
  --lh-snug:1.4;
  --lh-body:1.65;

  /* Space — 4/8/12/16/24/32/40/56/80 (generous magazine rhythm) */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px;
  --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;

  /* Card padding tiers */
  --card-pad:32px;      /* magazine-spacious standard */
  --card-pad-sm:24px;   /* compact utility cards */
  --card-gap:24px;      /* grid gap */

  /* Radius — standardized (only 3 sizes used across system) */
  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px;

  /* Shadows — 3 elevation levels */
  --shadow-1:0 2px 8px rgba(0,0,0,.25);
  --shadow-2:0 12px 32px rgba(0,0,0,.4);
  --shadow-3:0 24px 72px rgba(0,0,0,.55);
  --shadow-glow:0 0 48px var(--blue-glow);
  --shadow-lift:var(--shadow-3);

  /* Motion */
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--navy-950);color:var(--text);font-family:var(--font-body);
  -webkit-font-smoothing:antialiased;line-height:1.5}
html{background:var(--navy-950)}
body{
  background:transparent;
  min-height:100vh;
  position:relative;
  overflow-x:hidden;
}
/* ========================================================
   Universe background — persistent, parallax, all pages
   ======================================================== */
.universe{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  overflow:hidden;
  background:linear-gradient(180deg,var(--navy-950) 0%,var(--navy-900) 100%);
}
/* All main content sits on top of .universe */
.nav, section, header, footer, .modal-mask{position:relative;z-index:1}
.universe-layer{
  position:absolute;inset:0;
  contain:strict;
}
/* Nebula blobs — subtle tint layers, reduced for performance */
.universe-nebula{
  position:absolute;border-radius:50%;
  filter:blur(60px);
  mix-blend-mode:screen;
  opacity:.25;
  contain:strict;
}
.universe-nebula.n1{
  top:-10%;left:-5%;width:60vw;height:60vw;
  background:radial-gradient(circle, rgba(80,130,255,.12), transparent 60%);
  animation-delay:0s;
}
.universe-nebula.n2{
  top:30%;right:-10%;width:50vw;height:50vw;
  background:radial-gradient(circle, rgba(140,90,255,.08), transparent 60%);
  animation-delay:-8s;
}
.universe-nebula.n3{
  top:65%;left:10%;width:55vw;height:55vw;
  background:radial-gradient(circle, rgba(60,180,255,.06), transparent 60%);
  animation-delay:-16s;
}
/* n4/n5 removed — 3 nebulae are enough with real photos */
/* Starfield SVG — subtle accents over real photo, not the main star source */
.universe-stars{
  position:absolute;inset:0;width:100%;height:100%;
  opacity:.4; /* toned down: real NASA photo has thousands of real stars */
}
.universe-stars .star{fill:#fff}
.universe-stars .star-sm{opacity:.6}
.universe-stars .star-md{opacity:.8}
.universe-stars .star-lg{
  filter:drop-shadow(0 0 3px rgba(200,220,255,.5));
}
.universe-stars .star-xl{
  fill:#fff;
  filter:drop-shadow(0 0 4px rgba(180,210,255,.6));
  animation:uni-breathe 8s ease-in-out infinite;
}
@keyframes uni-breathe{0%,100%{opacity:.7}50%{opacity:1}}
.universe-stars .twinkle{animation:uni-twinkle 5s ease-in-out infinite}
.universe-stars .twinkle.d1{animation-delay:1s}
.universe-stars .twinkle.d2{animation-delay:2s}
.universe-stars .twinkle.d3{animation-delay:3s}
.universe-stars .twinkle.d4{animation-delay:4s}
.universe-stars .twinkle.d5{animation-delay:5s}
@keyframes uni-twinkle{0%,100%{opacity:.3}50%{opacity:1}}

/* ========================================================
   Sky — fixed sub-page backdrop
   User-provided Orion material pack panorama, 1672 x 941.
   ======================================================== */
.sky-milky-way{
  position:fixed;
  inset:0;
  background-image:url('../img/backgrounds/orion-deep-space-panorama.png');
  background-size:cover;
  background-position:center 36%;
  background-repeat:no-repeat;
  background-attachment:fixed;
  pointer-events:none;
  opacity:.62;
  /* Vignette: soft edges so text stays readable */
  mask-image:linear-gradient(180deg,
    rgba(0,0,0,.15) 0%,
    rgba(0,0,0,.7) 10%,
    rgba(0,0,0,1)  30%,
    rgba(0,0,0,1)  70%,
    rgba(0,0,0,.6) 90%,
    rgba(0,0,0,.15) 100%);
  -webkit-mask-image:linear-gradient(180deg,
    rgba(0,0,0,.15) 0%,
    rgba(0,0,0,.7) 10%,
    rgba(0,0,0,1)  30%,
    rgba(0,0,0,1)  70%,
    rgba(0,0,0,.6) 90%,
    rgba(0,0,0,.15) 100%);
  filter:saturate(1.02) contrast(1.08) brightness(.72);
  z-index:0;
}
/* When NASA sky is active (sub-pages), remove universe's opaque bg
   so the real photo shows through the nebula/star overlays */
.sky-milky-way ~ .universe{
  background:transparent;
}

/* ========================================================
   Earth horizon — only on first page hero, sits at bottom
   ======================================================== */
.sky-earth{
  position:fixed;
  inset:0;
  background-image:url('../img/backgrounds/orion-deep-space-panorama.png');
  background-size:cover;
  background-position:center 56%;
  background-repeat:no-repeat;
  background-attachment:fixed;
  pointer-events:none;
  opacity:.55;
  mask-image:linear-gradient(180deg,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0) 30%,
    rgba(0,0,0,.4) 50%,
    rgba(0,0,0,1) 78%,
    rgba(0,0,0,1) 100%);
  -webkit-mask-image:linear-gradient(180deg,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0) 30%,
    rgba(0,0,0,.4) 50%,
    rgba(0,0,0,1) 78%,
    rgba(0,0,0,1) 100%);
  filter:saturate(1.02) contrast(1.08) brightness(.72);
  z-index:0;
}

/* ========================================================
   Moon + Earthrise — hero backdrop photograph
   Full-bleed focal image used ONLY on the home page hero.
   The moon arc becomes a natural horizon line; logo + title
   sit in the pure-black sky region above it.
   ======================================================== */
.hero .hero-moon{
  position:absolute;
  inset:0;
  background-image:url('../img/backgrounds/moon-earthrise.jpg');
  background-size:cover;
  background-position:center 60%;
  background-repeat:no-repeat;
  z-index:0;
  pointer-events:none;
  /* Subtle Ken Burns breath so the hero feels alive without being distracting */
  animation:moon-breath 22s ease-in-out infinite;
  will-change:transform,opacity;
}
@keyframes moon-breath{
  0%,100%{transform:scale(1.04) translateY(0);opacity:.92}
  50%   {transform:scale(1.08) translateY(-6px);opacity:1}
}
/* Vignette so the moon never competes with text */
.hero .hero-moon::after{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 65% at 50% 20%, rgba(5,11,24,.15) 0%, rgba(5,11,24,.7) 60%, rgba(5,11,24,.92) 100%),
    linear-gradient(180deg, rgba(5,11,24,.82) 0%, rgba(5,11,24,.18) 28%, rgba(5,11,24,.18) 60%, rgba(5,11,24,.95) 100%);
  mix-blend-mode:multiply;
}

/* iOS Safari fallback — fixed bg breaks under iframes/scroll */
@supports (-webkit-touch-callout:none){
  .sky-milky-way,.sky-earth{background-attachment:scroll}
}

@media (max-width:768px){
  .sky-milky-way{opacity:.42}
  .sky-earth{display:none}  /* perf: skip on mobile */
}
@media (prefers-reduced-motion:reduce){
  .sky-milky-way,.sky-earth{background-attachment:scroll}
  .hero .hero-moon{animation:none}
  .hero-bg{animation:none;opacity:.55}
  .hero-row{animation:none}
  .hero::after{animation:none;opacity:.7}
  .hero-name{animation:none}
  .hero-logo{animation:none}
  .hero-stars .twinkle,.hero-stars .star-xl{animation:none;opacity:.8}
  .universe-nebula{animation:none}
  .universe-stars .twinkle,.universe-stars .star-xl{animation:none;opacity:.8}
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* Layout */
.container{max-width:1280px;margin:0 auto;padding:0 var(--s-6)}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  background:rgba(5,11,24,.72);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;
  padding:var(--s-4) var(--s-6);max-width:1440px;margin:0 auto;gap:var(--s-4)}
.brand{display:flex;align-items:center;gap:var(--s-3)}
.brand img{width:40px;height:40px;border-radius:50%;object-fit:cover;
  box-shadow:0 0 0 1px var(--line-strong), 0 0 20px var(--blue-glow)}
.brand-name{display:flex;flex-direction:column;line-height:1.1}
.brand-cn{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:.02em}
.brand-en{font-size:10px;letter-spacing:.3em;color:var(--text-mute);text-transform:uppercase}
.nav-links{display:flex;gap:4px;align-items:center;min-width:0}
.nav:not(.auth-ready) [data-auth]{display:none}
.nav-auth{display:flex;gap:4px;align-items:center;justify-content:flex-end;order:3;min-width:172px}

/* Unified nav item with icon + label */
.nav-item{
  display:inline-flex;align-items:center;gap:7px;
  font-size:13px;color:var(--text-dim);
  padding:8px 12px;border-radius:var(--r-sm);
  position:relative;
  white-space:nowrap;word-break:keep-all;flex-shrink:0;
  transition:color .2s var(--ease), background .2s var(--ease);
  text-decoration:none;
}
.nav-item .nav-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:16px;height:16px;flex-shrink:0;
  opacity:.75;transition:opacity .2s var(--ease);
}
.nav-item .nav-icon svg{width:100%;height:100%;display:block}
.nav-item .nav-label{line-height:1;letter-spacing:.02em;white-space:nowrap;word-break:keep-all}
.nav-item:hover{
  color:var(--text);
  background:rgba(255,255,255,.04);
}
.nav-item:hover .nav-icon{opacity:1}
.nav-item.active{
  color:#fff;
  background:rgba(46,107,255,.12);
}
.nav-item.active .nav-icon{opacity:1;color:var(--blue-400)}
.nav-item.active::after{
  content:"";position:absolute;left:12px;right:12px;bottom:2px;
  height:1.5px;background:linear-gradient(90deg,transparent,var(--blue-400),transparent);
}
/* Admin link — gold tint */
.nav-item.admin-link{color:var(--gold)}
.nav-item.admin-link:hover{color:var(--gold-bright);background:rgba(201,169,97,.1)}
.nav-item.admin-link.active{color:var(--gold-bright);background:rgba(201,169,97,.14)}
.nav-item.admin-link .nav-icon{color:var(--gold)}

/* User greeting */
.nav-hello{
  font-size:12px;color:var(--text-dim);
  padding:0 6px 0 10px;margin-left:6px;
  border-left:1px solid var(--line);
  letter-spacing:.02em;
}
.nav-hello-prefix{color:var(--text-mute)}

/* Icon-only nav buttons (login / logout / join) */
.nav-iconbtn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;font-size:12px;
  white-space:nowrap;flex-shrink:0;
}
.nav-iconbtn .nav-icon{
  width:14px;height:14px;display:inline-flex;opacity:.9;
}
.nav-iconbtn .nav-icon svg{width:100%;height:100%}

/* Legacy fallback for non-refactored pages */
.nav-links a:not(.nav-item){
  font-size:14px;color:var(--text-dim);padding:var(--s-2) 0;
  position:relative;transition:color .2s var(--ease);
}
.nav-links a:not(.nav-item):hover,
.nav-links a.active:not(.nav-item){color:var(--text)}

/* Tablet / compact desktop: keep labels horizontal and move nav to a clean second row. */
@media (max-width: 1180px) {
  .nav-inner{
    flex-wrap:wrap;
    align-items:center;
    justify-content:flex-start;
    row-gap:10px;
    column-gap:14px;
    padding:12px var(--s-5) 10px;
  }
  .brand{flex:0 0 auto}
  .brand img{width:42px;height:42px}
  .brand-cn{font-size:17px}
  .brand-en{font-size:9px;letter-spacing:.26em}
  .nav-auth{
    order:1;
    min-width:0;
    margin-left:auto;
    gap:3px;
  }
  .nav-hello{
    max-width:88px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .nav-hello-prefix{display:none}
  .nav-iconbtn{padding:7px 11px}
  .nav-links{
    order:2;
    width:100%;
    justify-content:flex-start;
    gap:8px;
    overflow-x:auto;
    scrollbar-width:none;
    padding-bottom:4px;
  }
  .nav-links::-webkit-scrollbar{display:none}
  .nav-item{
    padding:8px 11px;
    min-height:36px;
  }
}

/* ---------- Hero (home) — Netflix-style tilted flowing wall ---------- */
.hero{
  min-height:calc(100vh - 73px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:var(--s-9) var(--s-6) var(--s-7);position:relative;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:-10% -10%;
  display:flex;flex-direction:column;gap:18px;
  z-index:1;pointer-events:none;
  /* Static 3D tilt — gives spatial depth */
  transform:perspective(1400px) rotateX(16deg) rotateZ(-6deg);
  transform-origin:center center;
  /* Independent scale property for breath animation, won't conflict with transform */
  scale:1.04;
  animation:hero-breath 11s ease-in-out infinite;
  will-change:scale, opacity;
  /* Blended onto the moon backdrop — screen lightens photos, mix lets moon show through */
  mix-blend-mode:screen;
  opacity:.55;
}
@keyframes hero-breath{
  0%,100%{scale:1.02;opacity:.48}
  50%{scale:1.06;opacity:.62}
}
.hero-row{
  display:flex;gap:18px;flex-shrink:0;
  animation:flow 60s linear infinite;
  will-change:transform;
  contain:layout style;
}
.hero-row.reverse{animation-direction:reverse;animation-duration:80s}
.hero-row.slow{animation-duration:100s}
.hero-row img{
  width:280px;height:170px;object-fit:cover;border-radius:6px;
  flex-shrink:0;
  box-shadow:0 8px 24px rgba(0,0,0,.6);
  /* Screen blend mode looks best when source has punchy contrast */
  filter:saturate(1.15) contrast(1.08) brightness(.95);
  content-visibility:auto;
}
@keyframes flow{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
  background:
    radial-gradient(ellipse 75% 55% at 50% 38%, rgba(5,11,24,.12) 0%, rgba(5,11,24,.55) 55%, rgba(5,11,24,.9) 100%),
    linear-gradient(180deg, rgba(5,11,24,.6) 0%, rgba(5,11,24,.2) 22%, transparent 45%, transparent 60%, rgba(5,11,24,.92) 100%);
}
/* Nebula - slow breathing glow behind title (static blur, animate opacity+transform only) */
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
  background:
    radial-gradient(ellipse 50% 45% at 50% 50%, rgba(80,130,255,.22), transparent 60%),
    radial-gradient(ellipse 35% 30% at 42% 45%, rgba(140,90,255,.16), transparent 70%),
    radial-gradient(ellipse 30% 25% at 60% 55%, rgba(60,180,255,.14), transparent 70%);
  filter:blur(20px);
  animation:nebula 9s ease-in-out infinite;
  mix-blend-mode:screen;
  will-change:transform,opacity;
}
@keyframes nebula{
  0%,100%{opacity:.55;transform:scale(1)}
  50%{opacity:.85;transform:scale(1.08)}
}
.hero > *:not(.hero-bg):not(.hero-stars):not(.hero-moon){position:relative;z-index:4}
.hero-stars{z-index:3}
.hero-name{
  text-shadow:0 0 40px rgba(80,130,255,.45), 0 0 80px rgba(60,100,255,.25);
  /* Glow pulse via filter:brightness — GPU-accelerated, avoids text-shadow repaint */
  animation:glow 6s ease-in-out infinite;
  will-change:filter;
}
@keyframes glow{
  0%,100%{filter:brightness(1) drop-shadow(0 0 0 transparent)}
  50%{filter:brightness(1.15) drop-shadow(0 0 20px rgba(100,160,255,.3))}
}

/* Starfield + Orion constellation */
.hero-stars{
  position:absolute;inset:0;width:100%;height:100%;
  z-index:1;pointer-events:none;
}
.hero-stars .star{fill:#fff}
.hero-stars .star-sm{opacity:.8}
.hero-stars .star-md{opacity:1;filter:drop-shadow(0 0 3px rgba(200,220,255,.9))}
.hero-stars .star-lg{
  filter:drop-shadow(0 0 6px rgba(200,220,255,.9)) drop-shadow(0 0 14px rgba(140,180,255,.7));
}
.hero-stars .star-xl{
  fill:#fff;
  filter:
    drop-shadow(0 0 6px rgba(220,235,255,1))
    drop-shadow(0 0 18px rgba(160,200,255,.95))
    drop-shadow(0 0 36px rgba(100,150,255,.8))
    drop-shadow(0 0 60px rgba(60,120,255,.5));
  animation:breathe 5s ease-in-out infinite;
}
@keyframes breathe{0%,100%{opacity:.85;transform-box:fill-box;transform-origin:center}50%{opacity:1}}
.hero-stars .twinkle{animation:twinkle 3s ease-in-out infinite}
.hero-stars .twinkle.d1{animation-delay:.6s}
.hero-stars .twinkle.d2{animation-delay:1.2s}
.hero-stars .twinkle.d3{animation-delay:1.8s}
.hero-stars .twinkle.d4{animation-delay:2.4s}
@keyframes twinkle{0%,100%{opacity:.3}50%{opacity:1}}
.hero-logo{
  width:140px;height:140px;border-radius:50%;object-fit:cover;
  box-shadow:0 0 0 2px var(--line-strong), 0 0 60px var(--blue-glow);
  animation:float 6s ease-in-out infinite;
  position:relative;z-index:1;
  will-change:transform;
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

.hero-name{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(42px,7vw,88px);letter-spacing:.02em;
  margin-top:var(--s-6);
  background:linear-gradient(180deg,#fff 20%,#8FB0FF 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  position:relative;z-index:1;
}
.hero-en{
  font-size:12px;letter-spacing:.6em;color:var(--blue-300);
  text-transform:uppercase;margin-top:var(--s-3);
  position:relative;z-index:1;
}
.hero-tag{color:#D8E1F2;font-size:15px;margin-top:var(--s-4);
  max-width:600px;position:relative;z-index:1;
  text-shadow:0 2px 16px rgba(5,11,24,.95), 0 0 28px rgba(80,130,255,.35), 0 0 4px rgba(5,11,24,1);
  font-weight:400;letter-spacing:.02em}

.stats{
  display:flex;gap:var(--s-10);margin-top:var(--s-9);
  position:relative;z-index:1;flex-wrap:wrap;justify-content:center;
}
.stat{text-align:center}
.stat-num{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(72px,12vw,160px);line-height:1;
  background:linear-gradient(180deg,var(--gold-bright),var(--gold) 60%,#8a7440);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:-.02em;
}
.stat-label{
  font-size:11px;letter-spacing:.4em;color:var(--text-mute);
  text-transform:uppercase;margin-top:var(--s-3);
}
.stat-divider{width:1px;background:var(--line-strong);align-self:stretch}

/* ---------- Section header ---------- */
.section{padding:var(--s-10) 0}
.section-head{margin-bottom:var(--s-7)}
.eyebrow{font-size:11px;letter-spacing:.4em;color:var(--blue-400);
  text-transform:uppercase;margin-bottom:var(--s-3)}
.section-title{font-family:var(--font-display);font-size:clamp(32px,4vw,48px);
  font-weight:600;letter-spacing:.01em}
.section-sub{color:var(--text-mute);margin-top:var(--s-3);font-size:15px}

/* ========================================================
   TYPOGRAPHIC THEATRE — section header staging system
   ========================================================
   Every section-head can be upgraded to a "theatre" which
   places four named regions on an 8px baseline grid:

     [numeral] | [main      ]
               | [rule      ]

   - numeral: roman anchor (I. II. III.), anchors the eye
   - main:    eyebrow + title + sub, editorial stack
   - rule:    hairline + accent dot for rhythm
   The grid breaks at <=720px to a stacked single column.
   ======================================================== */
.section-head.theatre{
  display:grid;
  grid-template-columns:minmax(80px,130px) minmax(0,1fr);
  grid-template-areas:
    "numeral main"
    "numeral rule";
  column-gap:clamp(24px,4vw,56px);
  row-gap:var(--s-3);
  align-items:start;
  position:relative;
  padding-top:var(--s-4);
  margin-bottom:var(--s-7);
}
.section-head.theatre::before{
  /* Ultra-thin top rail, the "stage edge" */
  content:"";
  grid-column:1 / -1;
  height:1px;
  background:linear-gradient(90deg,var(--gold) 0%, rgba(201,169,97,.2) 18%, transparent 100%);
  margin-bottom:var(--s-4);
}
.theatre-numeral{
  grid-area:numeral;
  font-family:var(--font-display);
  font-size:clamp(64px,8vw,120px);
  font-weight:600;
  line-height:.8;
  letter-spacing:-.02em;
  background:linear-gradient(180deg,var(--gold-bright) 0%, var(--gold) 60%, rgba(201,169,97,.25) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  text-shadow:0 6px 30px rgba(201,169,97,.2);
  position:relative;
  font-feature-settings:"ss01","salt";
  transform:translateY(-8px);
}
.theatre-numeral::after{
  /* Orbiting dot, anchors the numeral like a baseball home plate */
  content:"";
  position:absolute;
  right:-14px;bottom:14px;
  width:8px;height:8px;border-radius:50%;
  background:var(--gold-bright);
  box-shadow:0 0 14px var(--gold-glow), 0 0 0 1px rgba(228,199,122,.35);
}
.theatre-main{
  grid-area:main;
  display:flex;
  flex-direction:column;
  gap:var(--s-3);
  padding-top:var(--s-3);
  min-width:0;
}
.theatre-main .eyebrow{
  margin-bottom:0;
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-size:11px;
  letter-spacing:.38em;
  color:var(--blue-300);
}
.theatre-main .eyebrow::before{
  content:"";
  display:inline-block;
  width:28px;height:1px;
  background:var(--blue-400);
  opacity:.7;
}
.theatre-main .section-title{
  font-family:var(--font-display);
  font-size:clamp(32px,5vw,58px);
  font-weight:600;
  letter-spacing:.005em;
  line-height:1.05;
  text-wrap:balance;
}
.theatre-main .section-title .en{
  display:block;
  font-family:var(--font-body);
  font-size:clamp(11px,1vw,13px);
  letter-spacing:.45em;
  color:var(--text-mute);
  font-weight:500;
  text-transform:uppercase;
  margin-top:var(--s-3);
}
.theatre-main .section-sub{
  color:var(--text-dim);
  font-size:15px;
  max-width:52ch;
  text-wrap:pretty;
  line-height:1.65;
  margin-top:var(--s-2);
}
.theatre-rule{
  grid-area:rule;
  display:flex;
  align-items:center;
  gap:14px;
  margin-top:var(--s-4);
  color:var(--text-mute);
  font-size:10px;
  letter-spacing:.4em;
  text-transform:uppercase;
}
.theatre-rule::before{
  content:"";
  flex:0 0 64px;
  height:1px;
  background:linear-gradient(90deg,var(--blue-400) 0%, rgba(91,139,255,.15) 100%);
}
.theatre-rule::after{
  content:"Beijing Orion \00B7 Est. 2013";
  flex:0 1 auto;
  color:var(--text-mute);
  opacity:.65;
}
/* Alt variant - centered, no numeral (used on HoF / players hero) */
.section-head.theatre.center{
  grid-template-columns:1fr;
  grid-template-areas:"main";
  text-align:center;
  justify-items:center;
}
.section-head.theatre.center .theatre-numeral,
.section-head.theatre.center .theatre-rule{display:none}
.section-head.theatre.center .theatre-main{align-items:center}
.section-head.theatre.center .theatre-main .eyebrow::before{display:none}
.section-head.theatre.center .section-sub{text-align:center}
/* Responsive collapse */
@media (max-width:720px){
  .section-head.theatre{
    grid-template-columns:1fr;
    grid-template-areas:
      "numeral"
      "main"
      "rule";
    row-gap:var(--s-4);
  }
  .theatre-numeral{font-size:72px}
  .theatre-numeral::after{right:auto;left:50px;bottom:20px}
  .theatre-rule::after{display:none}
}
/* "did not bat" marker in line score */
.linescore .did-not-bat{color:var(--text-mute);opacity:.55;font-style:italic}
.linescore tr.us td:first-child{color:var(--gold-bright);font-weight:600}
.linescore tr.us .rhe{background:rgba(201,169,97,.12)}
.ls-team{display:block;font-size:14px;font-weight:500}
.ls-side{display:block;font-size:9px;letter-spacing:.2em;color:var(--text-mute);text-transform:uppercase;margin-top:2px}
.team-us{font-size:10px;letter-spacing:.2em;color:var(--gold-bright);margin-left:6px;opacity:.85}
.score-meta-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;margin-right:8px;background:rgba(46,107,255,.08);border:1px solid rgba(91,139,255,.22);border-radius:999px;font-size:12px;color:var(--text-dim);letter-spacing:.02em}
.section-eyebrow{font-size:10px;letter-spacing:.4em;color:var(--blue-400);text-transform:uppercase;margin-bottom:var(--s-2)}
.team-col-heading{
  font-family:var(--font-display);font-size:22px;font-weight:600;
  color:var(--text-dim);margin-bottom:var(--s-3);
  display:flex;align-items:baseline;gap:10px;
}
.team-col-heading.winner{color:var(--gold-bright)}
.team-col-side{font-size:9px;letter-spacing:.3em;color:var(--text-mute);
  text-transform:uppercase;font-weight:500;font-family:var(--font-body);margin-left:auto}

/* ---------- Poster wall (Netflix-style) ---------- */
.wall{
  display:flex;gap:var(--s-4);overflow-x:auto;
  padding:var(--s-6) var(--s-6) var(--s-8);
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
}
.wall::-webkit-scrollbar{display:none}
.poster{
  flex:0 0 280px;aspect-ratio:16/10;border-radius:var(--r-md);
  overflow:hidden;position:relative;scroll-snap-align:start;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), z-index 0s .5s;
  cursor:pointer;
  box-shadow:0 10px 30px rgba(0,0,0,.4);
}
.poster img{width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--ease), filter .5s var(--ease);
  filter:brightness(.85) saturate(1.05);
}
.poster::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(5,11,24,.9) 100%);
  opacity:.6;transition:opacity .4s var(--ease);
}
.poster-caption{
  position:absolute;left:var(--s-4);right:var(--s-4);bottom:var(--s-4);
  font-size:13px;color:var(--text);z-index:2;
  opacity:0;transform:translateY(8px);transition:all .4s var(--ease);
}
.poster:hover{
  transform:scale(1.18);z-index:10;
  box-shadow:var(--shadow-lift), var(--shadow-glow);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), z-index 0s 0s;
}
.poster:hover img{transform:scale(1.06);filter:brightness(1) saturate(1.1)}
.poster:hover::after{opacity:1}
.poster:hover .poster-caption{opacity:1;transform:translateY(0)}

/* ---------- Cards grid ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--s-5)}
.card{
  position:relative;
  background:
    radial-gradient(120% 80% at 50% -20%, rgba(46,107,255,.16) 0%, transparent 55%),
    linear-gradient(165deg, rgba(20,40,80,.92) 0%, rgba(8,18,40,.96) 60%, rgba(5,11,24,.98) 100%);
  border:1px solid rgba(228,199,122,.16);border-radius:var(--r-lg);
  overflow:hidden;transition:all .3s var(--ease);
  cursor:pointer;
  box-shadow:
    0 8px 20px rgba(0,0,0,.4),
    inset 0 1px 0 rgba(255,255,255,.05),
    inset 0 0 0 1px rgba(46,107,255,.06);
}
/* 顶部 holographic 微光斜条（hover 变亮） */
.card::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:1;
  background:linear-gradient(115deg,
    transparent 0%, transparent 38%,
    rgba(255,255,255,.04) 48%,
    rgba(228,199,122,.06) 50%,
    rgba(255,255,255,.04) 52%,
    transparent 62%, transparent 100%);
  opacity:.5;transition:opacity .3s var(--ease);
}
.card>*{position:relative;z-index:2}
.card:hover{
  border-color:rgba(228,199,122,.4);
  transform:translateY(-5px);
  box-shadow:
    0 18px 44px rgba(0,0,0,.6),
    0 0 28px rgba(228,199,122,.14),
    inset 0 1px 0 rgba(255,255,255,.08);
}
.card:hover::after{opacity:1}
.card-img{aspect-ratio:16/9;overflow:hidden;position:relative}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card-img img{transform:scale(1.05)}
.card-body{padding:var(--s-5)}
.card-tag{display:inline-block;font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--blue-400);
  padding:4px 10px;border:1px solid var(--blue-500);border-radius:999px;
  margin-bottom:var(--s-3)}
.card-title{font-family:var(--font-display);font-size:22px;font-weight:600;
  margin-bottom:var(--s-2)}
.card-meta{font-size:13px;color:var(--text-mute);display:flex;gap:var(--s-4);
  margin-top:var(--s-3)}

/* ---------- Quick-link cards (index facade) ---------- */
.quick-links{grid-template-columns:repeat(4,1fr);gap:var(--s-5)}
.quick-card{display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:var(--s-7) var(--s-5);text-decoration:none;color:var(--text)}
.quick-card .quick-icon{font-size:40px;margin-bottom:var(--s-4)}
.quick-card .card-title{margin-bottom:var(--s-2)}
.quick-card:hover{border-color:var(--blue-500);box-shadow:0 0 20px var(--blue-glow);transform:translateY(-4px)}

/* ---------- Tabs ---------- */
.tabs{display:flex;gap:var(--s-2);border-bottom:1px solid var(--line);
  margin-bottom:var(--s-6)}
.tab{padding:var(--s-3) var(--s-5);font-size:14px;color:var(--text-dim);
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:all .2s var(--ease)}
.tab:hover{color:var(--text)}
.tab.active{color:var(--text);border-color:var(--blue-500)}
.sub-tabs{display:flex;gap:var(--s-2);flex-wrap:wrap;margin-bottom:var(--s-6)}
.chip{padding:var(--s-2) var(--s-4);font-size:12px;color:var(--text-dim);
  border:1px solid var(--line-strong);border-radius:999px;
  transition:all .2s var(--ease)}
.chip:hover{color:var(--text);border-color:var(--blue-500)}
.chip.active{background:var(--blue-500);border-color:var(--blue-500);color:#fff}

/* ---------- Score box (game) ---------- */
.scorebox{
  background:linear-gradient(180deg,var(--navy-800),var(--navy-900));
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s-6);margin-bottom:var(--s-6);
}
.score-header{display:flex;justify-content:space-between;align-items:flex-start;
  flex-wrap:wrap;gap:var(--s-4);margin-bottom:var(--s-5)}
.score-title{font-family:var(--font-display);font-size:28px;font-weight:600}
.score-meta{color:var(--text-mute);font-size:13px;margin-top:var(--s-2)}
.final{display:flex;align-items:center;gap:var(--s-6)}
.team-final{text-align:center}
.team-name{font-size:14px;color:var(--text-dim);letter-spacing:.05em}
.team-runs{font-family:var(--font-display);font-size:64px;font-weight:700;
  line-height:1;color:var(--text)}
.team-runs.win{background:linear-gradient(180deg,var(--gold-bright),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.vs{font-size:12px;color:var(--text-mute);letter-spacing:.3em}

/* Tables */
.table-wrap{overflow-x:auto;margin-top:var(--s-5)}
table.stats-table{width:100%;border-collapse:collapse;font-size:13px;min-width:600px}
.stats-table th,.stats-table td{padding:var(--s-3) var(--s-3);text-align:right;
  border-bottom:1px solid var(--line)}
.stats-table th:first-child,.stats-table td:first-child{text-align:left}
.stats-table thead th{color:var(--blue-400);font-weight:500;font-size:11px;
  letter-spacing:.1em;text-transform:uppercase}
.stats-table tbody tr:hover{background:rgba(46,107,255,.06)}
.stats-table .totals{font-weight:600;color:var(--gold-bright)}
.stats-table .totals td{border-top:1px solid var(--line-strong);border-bottom:none}

.linescore{overflow-x:auto}
.linescore table{font-size:13px;border-collapse:collapse;min-width:100%}
.linescore th,.linescore td{padding:var(--s-2) var(--s-3);text-align:center;
  border-bottom:1px solid var(--line)}
.linescore th:first-child,.linescore td:first-child{text-align:left;
  color:var(--text-dim)}
.linescore thead th{font-size:11px;color:var(--text-mute);font-weight:500}
.linescore .rhe{background:rgba(46,107,255,.08);color:var(--gold-bright);
  font-weight:600}

/* Highlight cards */
.highlights{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:var(--s-4);margin-top:var(--s-5)}
.hl{
  background:var(--navy-800);border:1px solid var(--line);
  border-radius:var(--r-md);overflow:hidden;
  transition:all .3s var(--ease);
}
.hl:hover{border-color:var(--blue-500);box-shadow:var(--shadow-glow)}
.hl-thumb{aspect-ratio:16/9;background:var(--navy-700);position:relative;
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.hl-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}
.hl-play{width:56px;height:56px;border-radius:50%;
  background:rgba(46,107,255,.9);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;z-index:1;
  box-shadow:var(--shadow-glow)}
.hl-play::before{content:"";border:10px solid transparent;
  border-left:14px solid #fff;margin-left:4px}
.hl-body{padding:var(--s-4)}
.hl-title{font-size:15px;font-weight:600}
.hl-meta{font-size:12px;color:var(--text-mute);margin-top:var(--s-2)}

/* Forms (contact) */
.form{
  width:100%;max-width:560px;
  display:grid;gap:var(--s-4);margin-top:var(--s-6);
  min-width:0;
}
.field{
  display:flex;flex-direction:column;gap:var(--s-2);
  min-width:0;  /* allow shrinking below intrinsic size in flex parents */
}
.field label{font-size:12px;letter-spacing:.1em;color:var(--text-mute);
  text-transform:uppercase}
.field input,.field textarea,.field select{
  width:100%;max-width:100%;min-width:0;  /* hard width override */
  background:var(--navy-800);border:1px solid var(--line-strong);
  border-radius:var(--r-sm);padding:var(--s-3) var(--s-4);
  color:var(--text);font:inherit;transition:all .2s var(--ease);
  box-sizing:border-box;
}
.field input:focus,.field textarea:focus{outline:none;
  border-color:var(--blue-500);box-shadow:0 0 0 3px var(--blue-glow)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:var(--s-3) var(--s-6);border-radius:var(--r-sm);
  background:var(--blue-500);color:#fff;font-weight:500;font-size:14px;
  letter-spacing:.05em;transition:all .2s var(--ease);
  box-shadow:0 8px 24px var(--blue-glow);
}
.btn:hover{background:var(--blue-400);transform:translateY(-1px)}
.btn.ghost{background:transparent;border:1px solid var(--line-strong);box-shadow:none}
.btn.ghost:hover{border-color:var(--blue-500);background:rgba(46,107,255,.1)}

/* Contact info */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-8);
  align-items:start}
@media (max-width:800px){.contact-grid{grid-template-columns:1fr}}
.info-list{display:grid;gap:var(--s-5);margin-top:var(--s-6)}
.info-item{display:flex;gap:var(--s-4);align-items:flex-start}
.info-icon{width:40px;height:40px;border-radius:var(--r-sm);
  background:rgba(46,107,255,.12);border:1px solid var(--blue-500);
  display:flex;align-items:center;justify-content:center;
  color:var(--blue-400);font-size:18px;flex-shrink:0}
.info-label{font-size:11px;letter-spacing:.2em;color:var(--text-mute);
  text-transform:uppercase}
.info-val{font-size:15px;margin-top:2px}

/* Footer */
.footer{border-top:1px solid var(--line);padding:var(--s-7) 0;
  text-align:center;color:var(--text-mute);font-size:12px;
  margin-top:var(--s-9)}
.footer-brand{letter-spacing:.3em;text-transform:uppercase;margin-bottom:var(--s-3)}
.footer-links,
.footer-report-links,
.footer-meta{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  gap:6px 12px;color:var(--text-dim)}
.footer-links{margin-bottom:8px}
.footer-report-links{margin-bottom:10px;font-size:11px;color:var(--text-mute)}
.footer-links a,
.footer-report-links a{
  display:inline-flex;align-items:center;gap:6px;min-height:24px;
}
.footer-report-links span{color:rgba(154,169,196,.72)}
.footer-report-link span:last-child{color:inherit}
.footer-report-mark{
  position:relative;display:inline-grid;place-items:center;
  height:18px;min-width:31px;padding:0 5px;border-radius:6px;
  border:1px solid rgba(143,176,255,.30);
  background:linear-gradient(145deg,rgba(9,22,48,.86),rgba(22,45,86,.58));
  color:rgba(232,238,250,.88)!important;
  font-size:9px;font-weight:700;letter-spacing:.03em;line-height:1;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 0 12px rgba(46,107,255,.10);
  flex:0 0 auto;
}
.report-mark-cac{
  min-width:36px;border-color:rgba(228,199,122,.32);
  color:rgba(255,238,184,.92)!important;
  background:linear-gradient(145deg,rgba(41,32,15,.80),rgba(80,63,26,.46));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 0 12px rgba(228,199,122,.10);
}
.report-mark-police{
  min-width:28px;border-radius:50% 50% 44% 44% / 42% 42% 56% 56%;
  border-color:rgba(143,176,255,.34);
  color:rgba(205,221,255,.94)!important;
}
.footer-links span,.footer-links a,
.footer-report-links span,.footer-report-links a,
.footer-meta span,.footer-meta a{white-space:nowrap}
.footer-dot{width:3px;height:3px;border-radius:50%;background:rgba(228,199,122,.42)}
.footer-links a,
.footer-report-links a,
.footer-meta a{color:var(--text-dim);text-decoration:none;transition:color .2s var(--ease)}
.footer-links a:hover,
.footer-report-links a:hover,
.footer-meta a:hover{color:var(--blue-300)}
@media (max-width:520px){
  .footer-links,.footer-report-links,
  .footer-meta{flex-direction:column;gap:6px}
  .footer-dot{display:none}
}

/* Back link */
.back{display:inline-flex;align-items:center;gap:var(--s-2);color:var(--text-dim);
  font-size:13px;margin-bottom:var(--s-5);transition:color .2s var(--ease)}
.back:hover{color:var(--blue-400)}

/* Utility */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-6)}
@media (max-width:900px){.two-col{grid-template-columns:1fr}}

/* Legal docs */
.legal-page{
  position:relative;
  z-index:1;
  max-width:1180px;
  margin:0 auto;
  padding:96px var(--s-5) var(--s-8);
}
.legal-hero{
  padding-top:var(--s-8);
  padding-bottom:var(--s-6);
}
.legal-lead{
  max-width:900px;
  margin-top:var(--s-4);
  color:var(--text-dim);
  font-size:15px;
  line-height:1.8;
}
.legal-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px 12px;
  margin-top:var(--s-5);
}
.legal-meta span{
  border:1px solid var(--line-strong);
  border-radius:999px;
  padding:6px 10px;
  color:var(--text-dim);
  background:rgba(255,255,255,.035);
  font-size:12px;
}
.legal-layout{
  display:grid;
  grid-template-columns:220px minmax(0, 1fr);
  gap:var(--s-5);
  align-items:start;
}
.legal-toc{
  position:sticky;
  top:92px;
  display:grid;
  gap:6px;
  padding:12px;
  border:1px solid var(--line-strong);
  border-radius:var(--r-sm);
  background:rgba(10,22,40,.72);
  backdrop-filter:blur(10px);
}
.legal-toc a{
  color:var(--text-dim);
  text-decoration:none;
  font-size:13px;
  line-height:1.4;
  padding:8px 10px;
  border-radius:6px;
}
.legal-toc a:hover{
  color:var(--text);
  background:rgba(46,107,255,.12);
}
.legal-doc{
  display:grid;
  gap:var(--s-5);
}
.legal-card{
  border:1px solid var(--line-strong);
  border-radius:var(--r-md);
  background:linear-gradient(180deg, rgba(15,30,56,.88), rgba(10,22,40,.84));
  box-shadow:var(--shadow-2);
  padding:var(--s-6);
}
.legal-card h2{
  font-family:var(--font-display);
  font-size:26px;
  margin-bottom:var(--s-4);
}
.legal-card h3{
  margin-top:var(--s-5);
  margin-bottom:var(--s-2);
  color:var(--gold-bright);
  font-size:15px;
}
.legal-card p,
.legal-card li{
  color:var(--text-dim);
  font-size:14px;
  line-height:1.85;
}
.legal-card a{
  color:var(--gold-bright);
}
.legal-table-wrap{
  overflow:auto;
  margin-top:var(--s-4);
  border:1px solid var(--line);
  border-radius:var(--r-sm);
}
.legal-table{
  width:100%;
  min-width:760px;
  border-collapse:collapse;
  background:rgba(5,11,24,.28);
}
.legal-table th,
.legal-table td{
  padding:12px 14px;
  border-bottom:1px solid var(--line);
  vertical-align:top;
  text-align:left;
}
.legal-table th{
  color:var(--text);
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  background:rgba(46,107,255,.10);
}
.legal-table td{
  color:var(--text-dim);
  font-size:13px;
  line-height:1.75;
}
.legal-list{
  display:grid;
  gap:10px;
  padding-left:18px;
}
@media (max-width:900px){
  .legal-page{padding-left:var(--s-4);padding-right:var(--s-4)}
  .legal-layout{grid-template-columns:1fr}
  .legal-toc{position:relative;top:auto;grid-template-columns:repeat(2, minmax(0,1fr))}
}
@media (max-width:560px){
  .legal-page{padding-top:82px}
  .legal-card{padding:var(--s-5)}
  .legal-toc{grid-template-columns:1fr}
}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(20px);transition:all .8s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}

/* Smooth scroll */
html{scroll-behavior:smooth;scroll-padding-top:73px}

/* Section anchor offset */
section[id]{scroll-margin-top:73px}

/* ---------- Modal ---------- */
.modal-mask{
  position:fixed;inset:0;z-index:100;
  background:rgba(2,6,16,.75);backdrop-filter:blur(8px);
  display:none;align-items:flex-start;justify-content:center;
  padding:var(--s-5);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  animation:fade .3s var(--ease);
}
.modal-mask.open{display:flex}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{
  width:100%;
  max-width:min(440px, calc(100vw - 32px));  /* never exceed viewport */
  background:linear-gradient(180deg,var(--navy-800),var(--navy-900));
  border:1px solid var(--line-strong);border-radius:var(--r-lg);
  padding:var(--s-6) var(--s-6);  /* slightly tighter than s-7 */
  box-shadow:var(--shadow-lift),var(--shadow-glow);
  position:relative;
  margin:auto;
  min-width:0;
  overflow:hidden;  /* clip any rogue overflow */
}
#authModal.auth-registering .modal{
  max-width:min(720px, calc(100vw - 32px));
}
/* Bulletproof: any form control inside any modal must fill its column */
.modal input,
.modal select,
.modal textarea{
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
}
/* And the form itself never exceeds the modal */
.modal .form{width:100%;max-width:100%;min-width:0}
.modal-close{position:absolute;top:var(--s-3);right:var(--s-3);
  width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;color:var(--text-dim);
  font-size:18px;transition:all .2s var(--ease);z-index:2}
.modal-close:hover{background:rgba(255,255,255,.12);color:#fff}
.modal h3{font-family:var(--font-display);font-size:24px;font-weight:600;
  margin-bottom:var(--s-2)}
.modal-sub{color:var(--text-mute);font-size:13px;margin-bottom:var(--s-5)}
.modal-tabs{display:flex;gap:var(--s-4);margin-bottom:var(--s-5);
  border-bottom:1px solid var(--line)}
.modal-tab{padding:var(--s-2) 0;color:var(--text-dim);font-size:14px;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:all .2s var(--ease)}
.modal-tab.active{color:var(--text);border-color:var(--blue-500)}

.captcha-row{display:flex;gap:var(--s-3);align-items:flex-end;min-width:0}
.captcha-row .field{flex:1 1 0;min-width:0}
.captcha-img{
  flex:0 0 110px;
  width:110px;height:44px;border-radius:var(--r-sm);
  background:linear-gradient(135deg,#1a2c50,#0f1e38);
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;font-size:20px;
  letter-spacing:.18em;color:#7FA0E0;
  cursor:pointer;user-select:none;
  text-shadow:0 0 8px rgba(120,160,255,.6);
  position:relative;overflow:hidden;
}
.captcha-img::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(255,255,255,.04) 4px,rgba(255,255,255,.04) 6px);
}

.reg-mode-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.reg-mode-card{
  text-align:left;
  padding:12px 13px;
  border-radius:8px;
  border:1px solid var(--line-strong);
  background:rgba(255,255,255,.025);
  color:var(--text-dim);
  transition:all .18s var(--ease);
}
.reg-mode-card strong{
  display:block;
  color:var(--text);
  font-size:13px;
  margin-bottom:5px;
}
.reg-mode-card span{
  display:block;
  color:var(--text-mute);
  font-size:11px;
  line-height:1.5;
}
.reg-mode-card.active{
  border-color:rgba(228,199,122,.48);
  background:rgba(228,199,122,.08);
  box-shadow:inset 0 0 0 1px rgba(228,199,122,.16);
}
.reg-account-grid{
  display:grid;
  grid-template-columns:1fr 1.35fr;
  gap:12px;
  align-items:start;
}
.reg-bind-panel{
  display:grid;
  gap:var(--s-4);
  padding:12px;
  border:1px solid rgba(91,139,255,.22);
  border-radius:8px;
  background:rgba(46,107,255,.055);
}
.reg-bind-hint{
  color:var(--text-dim);
  font-size:12px;
  line-height:1.55;
}
.auth-legal-panel{
  display:grid;
  gap:10px;
  padding:12px;
  border:1px solid rgba(228,199,122,.28);
  border-radius:8px;
  background:linear-gradient(180deg, rgba(228,199,122,.075), rgba(46,107,255,.045));
}
.auth-legal-panel.compact{
  margin-top:2px;
}
.auth-legal-head{
  display:grid;
  gap:3px;
}
.auth-legal-head strong{
  color:var(--text);
  font-size:13px;
  letter-spacing:.04em;
}
.auth-legal-head span,
.auth-legal-copy{
  color:var(--text-dim);
  font-size:12px;
  line-height:1.65;
}
.auth-legal-links{
  display:flex;
  flex-wrap:wrap;
  gap:8px 12px;
}
.auth-legal-links a{
  color:var(--gold-bright);
  font-size:12px;
  text-decoration:none;
  border-bottom:1px dashed rgba(228,199,122,.42);
}
.auth-legal-links a:hover{
  color:#fff1b8;
}
.auth-legal-public-note{
  color:var(--text);
  font-size:12px;
  line-height:1.6;
  padding:9px 10px;
  border:1px solid rgba(91,139,255,.24);
  border-radius:8px;
  background:rgba(46,107,255,.10);
}
.auth-legal-detail{
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px;
  background:rgba(5,11,24,.28);
  overflow:hidden;
}
.auth-legal-detail summary{
  cursor:pointer;
  padding:10px 12px;
  color:var(--text-dim);
  font-size:12px;
  user-select:none;
}
.auth-legal-detail[open] summary{
  border-bottom:1px solid rgba(255,255,255,.08);
  color:var(--text);
}
.auth-legal-copy{
  display:grid;
  gap:8px;
  max-height:220px;
  overflow:auto;
  padding:10px 12px 12px;
}
.auth-legal-copy strong{
  color:var(--text);
}
.auth-legal-check{
  display:grid;
  grid-template-columns:18px 1fr;
  gap:9px;
  align-items:start;
  color:var(--text-dim);
  font-size:12px;
  line-height:1.55;
}
.auth-legal-check input{
  width:16px;
  height:16px;
  margin-top:2px;
  accent-color:var(--gold-bright);
}
.reg-target-help{
  margin-top:6px;
}
.auth-search-dropdown{
  position:static;
  max-height:280px;
  overflow-y:auto;
  background:var(--navy-800);
  border:1px solid var(--line-strong);
  border-radius:8px;
  margin-top:6px;
  box-shadow:0 12px 28px rgba(0,0,0,.42);
}
.auth-player-option{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 10px;
  color:var(--text);
  text-align:left;
  border-bottom:1px solid var(--line);
}
.auth-player-option:hover{background:rgba(46,107,255,.1)}
.auth-player-option img{
  width:34px;
  height:34px;
  border-radius:50%;
  object-fit:cover;
  background:var(--navy-700);
  flex:0 0 auto;
}
.auth-player-option span{display:flex;flex-direction:column;gap:2px;min-width:0}
.auth-player-option strong{font-size:13px}
.auth-player-option em{font-style:normal;color:var(--text-mute);font-size:11px}
.auth-player-empty{
  padding:12px;
  color:var(--text-mute);
  font-size:12px;
}
.auth-mini-link{
  text-align:center;
  color:var(--text-mute);
  font-size:12px;
}
.auth-mini-link a{
  color:var(--gold-bright);
  text-decoration:none;
  border-bottom:1px dashed rgba(228,199,122,.38);
}

/* ---------- Dashboard ---------- */
.dash-hero{
  background:linear-gradient(180deg,var(--navy-800),var(--navy-900));
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s-7);margin-bottom:var(--s-6);
  display:flex;gap:var(--s-6);align-items:center;flex-wrap:wrap;
}
.dash-avatar{
  width:96px;height:96px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue-500),#7B2FFF);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:36px;font-weight:700;color:#fff;
  box-shadow:var(--shadow-glow);flex-shrink:0;
}
.dash-info h2{font-family:var(--font-display);font-size:28px;font-weight:600}
.dash-info .meta{color:var(--text-mute);font-size:13px;margin-top:4px}
.dash-badges{display:flex;gap:var(--s-2);margin-top:var(--s-3);flex-wrap:wrap}
.badge{
  font-size:11px;padding:4px 10px;border-radius:999px;
  background:rgba(46,107,255,.12);border:1px solid var(--blue-500);
  color:var(--blue-300);letter-spacing:.05em;
}
.badge.gold{background:rgba(201,169,97,.15);border-color:var(--gold);color:var(--gold-bright)}

/* KPI grid — 3 columns on desktop, 2 on tablet */
.kpi-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:var(--s-5);
  margin-bottom:var(--s-7);
}
.kpi{
  background:linear-gradient(180deg,var(--navy-800),var(--navy-850));
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:24px 28px;
  position:relative;
  transition:all .3s var(--ease);
  cursor:help;
  overflow:hidden;
}
.kpi::before{
  /* Subtle gradient accent at top */
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--blue-500),transparent);
  opacity:0;transition:opacity .3s var(--ease);
}
.kpi:hover{
  border-color:var(--line-bright);
  transform:translateY(-2px);
  box-shadow:var(--shadow-1);
}
.kpi:hover::before{opacity:.6}
.kpi-label{
  font-size:10px;color:var(--text-mute);letter-spacing:.18em;
  text-transform:uppercase;font-weight:500;
  display:flex;align-items:center;gap:5px;
}
.kpi-label::after{
  content:"?";display:inline-flex;align-items:center;justify-content:center;
  width:14px;height:14px;border-radius:50%;
  background:rgba(255,255,255,.05);color:var(--text-mute);
  font-size:9px;font-weight:600;margin-left:2px;
  transition:all .2s var(--ease);
}
.kpi:hover .kpi-label::after{background:var(--blue-500);color:#fff}
.kpi-val{
  font-family:var(--font-display);font-size:36px;font-weight:600;
  margin-top:10px;color:var(--gold-bright);
  line-height:1.05;letter-spacing:-.01em;
}
.kpi-trend{
  font-size:11px;color:var(--text-mute);
  margin-top:6px;letter-spacing:.03em;
}

/* ---------- Tournament overview page ---------- */
.tournament-hero{
  display:grid;
  grid-template-columns:minmax(240px,360px) 1fr;
  gap:var(--s-6);
  margin-bottom:var(--s-7);
  padding:var(--s-6);
  background:linear-gradient(180deg,var(--navy-800),var(--navy-850));
  border:1px solid var(--line);border-radius:var(--r-lg);
}
.th-cover{
  aspect-ratio:16/9;overflow:hidden;border-radius:var(--r-md);
  background:var(--navy-900);
}
.th-cover img{width:100%;height:100%;object-fit:cover}
.th-info{display:flex;flex-direction:column;justify-content:center;gap:var(--s-3)}
.th-type{
  font-size:11px;letter-spacing:.22em;color:var(--blue-400);
  text-transform:uppercase;font-weight:500;
}
.th-title{
  font-family:var(--font-display);font-size:clamp(28px,3.6vw,42px);
  font-weight:600;color:var(--text);line-height:1.2;letter-spacing:.005em;
}
.th-desc{color:var(--text-dim);font-size:14px;line-height:1.7}
.th-meta{
  display:flex;gap:var(--s-5);color:var(--text-mute);font-size:12px;
  margin-top:var(--s-2);
}

/* Team record cards row */
.tournament-stats-row{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:var(--s-5);
  margin-bottom:var(--s-7);
}
.ts-card{
  background:linear-gradient(180deg,var(--navy-800),var(--navy-850));
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:24px 28px;text-align:center;
  transition:all .3s var(--ease);
}
.ts-card:hover{border-color:var(--line-strong);transform:translateY(-2px);box-shadow:var(--shadow-1)}
.ts-label{
  font-size:10px;color:var(--text-mute);letter-spacing:.22em;
  text-transform:uppercase;font-weight:500;margin-bottom:10px;
}
.ts-val{
  font-family:var(--font-display);font-size:36px;font-weight:600;
  color:var(--gold-bright);line-height:1;letter-spacing:-.01em;
}
.ts-val.hot{color:var(--gold-bright)}
.ts-sub{font-size:11px;color:var(--text-mute);margin-top:8px;letter-spacing:.02em}

/* Tournament insights — 4 张图表卡片 grid */
.insights-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:var(--s-5);
  margin-top:var(--s-5);
}
@media (max-width:720px){.insights-grid{grid-template-columns:1fr}}
.insight-card{
  background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01));
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:18px 20px 14px;
  transition:all .25s var(--ease);
}
.insight-card:hover{
  border-color:rgba(228,199,122,.25);
  background:linear-gradient(180deg, rgba(228,199,122,.04), rgba(255,255,255,.01));
}
.insight-title{
  font-family:var(--font-display);
  font-size:14px;
  color:var(--gold-bright);
  margin:0 0 12px;
  letter-spacing:.04em;
}
.insight-card .chart-wrap{
  position:relative;
  height:240px;
}
.chart-empty{
  height:240px;display:flex;align-items:center;justify-content:center;
  color:var(--text-mute);font-size:13px;border:1px dashed var(--line);
  border-radius:var(--r-sm);
}

/* Leaderboard tabs */
.lb-tabs{
  display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap;
}
.lb-tab{
  font-size:11px;padding:6px 14px;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid var(--line-strong);
  color:var(--text-dim);letter-spacing:.08em;
  transition:all .2s var(--ease);cursor:pointer;
  font-family:var(--font-body);font-weight:500;
}
.lb-tab:hover{color:var(--text);border-color:var(--blue-400)}
.lb-tab.active{
  background:var(--blue-500);color:#fff;border-color:var(--blue-500);
  box-shadow:0 2px 12px var(--blue-glow);
}

/* Leaderboard table */
.game-log.leaderboard thead th{
  font-size:11px;letter-spacing:.12em;
}
.game-log.leaderboard tbody td{
  font-size:12px;padding:10px 12px;
}
.game-log.leaderboard tbody td:first-child{
  width:48px;color:var(--text-mute);font-weight:600;
  font-family:var(--font-display);font-size:14px;
}
.game-log.leaderboard tbody td:first-child.hot{
  color:var(--gold-bright);
}
.game-log.leaderboard tbody td.hot{color:var(--gold-bright);font-weight:600}

/* 排行榜列头排序（tournament.html 击球榜） */
.game-log.leaderboard th.sortable{
  cursor:pointer;user-select:none;transition:color .15s var(--ease);position:relative;
}
.game-log.leaderboard th.sortable:hover{color:var(--gold-bright)}
.game-log.leaderboard th.sortable.active{color:var(--gold-bright)}
.game-log.leaderboard th.sortable.active::after{
  content:" ▼";font-size:9px;margin-left:2px;opacity:.85;
}
.game-log.leaderboard th.sortable.active.asc::after{content:" ▲"}

/* HR 列：表头加金色框，单元格里有 HR 时高亮 + 闪电图标 */
.game-log.leaderboard th.hr-col{
  background:linear-gradient(180deg, rgba(228,199,122,.18), rgba(228,199,122,.04));
  color:var(--gold-bright);
  border-left:1px solid rgba(228,199,122,.25);
  border-right:1px solid rgba(228,199,122,.25);
  font-weight:700;
  letter-spacing:.06em;
}
.game-log.leaderboard td.hr-cell{
  border-left:1px solid rgba(228,199,122,.12);
  border-right:1px solid rgba(228,199,122,.12);
}
.game-log.leaderboard td.hr-cell.hot-hr{
  color:#ffe28a;
  font-family:var(--font-display);
  font-size:15px;
  font-weight:700;
  background:linear-gradient(180deg, rgba(228,199,122,.22), rgba(228,199,122,.08));
  text-shadow:0 0 8px rgba(228,199,122,.5);
  letter-spacing:.02em;
}

/* ========== 能力剖面图 (Capability Profile) ========== */
.cap-profile{
  background:linear-gradient(180deg, rgba(15,30,56,.55), rgba(10,22,40,.85));
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:var(--s-6) var(--s-6) var(--s-5);
  margin:var(--s-5) 0 var(--s-7);
  position:relative;
  overflow:hidden;
}
.cap-profile::before{
  content:"A2";position:absolute;top:18px;right:24px;
  font-size:11px;letter-spacing:.2em;color:var(--text-mute);font-weight:500;
}
.cap-head{margin-bottom:var(--s-5)}
.cap-eyebrow{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-bright);font-weight:500;margin-bottom:8px;
}
.cap-head .cap-eyebrow::after{
  content:" · 能力剖面图";color:var(--text);letter-spacing:0;font-size:18px;
  margin-left:4px;font-weight:600;font-family:var(--font-display);
}
.cap-sub{font-size:12px;color:var(--text-mute);letter-spacing:.05em}

/* Radar with centered OPS overlay */
.cap-radar-wrap{
  position:relative;height:340px;margin:var(--s-3) auto var(--s-5);
  max-width:480px;
}
.cap-radar-center{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  pointer-events:none;text-align:center;z-index:2;
}
.cap-ops{
  font-family:var(--font-display);
  font-size:48px;letter-spacing:.06em;color:var(--text);
  font-weight:600;line-height:1;
}
.cap-ops-label{
  font-size:11px;letter-spacing:.3em;color:var(--text-mute);
  margin-top:6px;text-transform:uppercase;
}

/* Slash line: 3 main rate stats */
.cap-slash{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--s-3);
  padding:var(--s-4) 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-bottom:var(--s-5);
}
.cap-slash-cell{text-align:center}
.cap-slash-val{
  font-family:var(--font-display);
  font-size:32px;letter-spacing:.04em;color:var(--gold-bright);
  font-weight:600;line-height:1;
}
.cap-slash-label{
  font-size:11px;letter-spacing:.18em;color:var(--text-mute);
  margin-top:8px;text-transform:uppercase;
}

/* 5-axis breakdown table */
.cap-breakdown{display:flex;flex-direction:column;gap:8px;margin-bottom:var(--s-4)}
.cap-row{
  display:grid;
  grid-template-columns:60px 60px 1fr 60px;
  align-items:baseline;
  font-size:13px;letter-spacing:.05em;
  padding:6px 4px;
}
.cap-row-cat{color:var(--text)}
.cap-row-code{color:var(--text-mute);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.cap-row-val{color:var(--gold-bright);font-family:var(--font-display);font-size:16px;text-align:right;letter-spacing:.04em}
.cap-row-pct{color:var(--blue-400);text-align:right;font-size:11px;letter-spacing:.16em;font-weight:500}
.cap-row-na .cap-row-val,
.cap-row-na .cap-row-pct{color:var(--text-mute);opacity:.6}

.cap-splits-note{
  font-size:11px;color:var(--text-mute);font-style:italic;
  text-align:center;padding-top:var(--s-3);border-top:1px solid var(--line);
}

@media (max-width: 640px){
  .cap-profile{padding:var(--s-5) var(--s-4) var(--s-4)}
  .cap-radar-wrap{height:280px}
  .cap-ops{font-size:38px}
  .cap-slash-val{font-size:24px}
  .cap-row{grid-template-columns:48px 48px 1fr 50px;font-size:12px}
}

/* Scope bar — "当前范围" pill */
.scope-bar{
  display:inline-block;
  font-size:11px;color:var(--blue-400);
  letter-spacing:.16em;text-transform:uppercase;font-weight:500;
  padding:8px 18px;border-radius:999px;
  background:rgba(46,107,255,.08);
  border:1px solid rgba(46,107,255,.25);
  margin-bottom:var(--s-6);
}

/* Section title with vertical accent dot */
.stats-section-title{
  display:flex;align-items:center;gap:12px;
  font-size:13px;color:var(--text-dim);font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:18px;margin-top:32px;
}
.stats-section-title:first-child,
.stats-section-title.first{margin-top:0}
.stats-section-title .dot{
  display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--blue-500);
  box-shadow:0 0 12px var(--blue-glow);
}

/* Small KPI grid variant — tighter, 3 cards per row for advanced stats */
.kpi-grid-sm{
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:var(--s-4);
}
.kpi-grid-sm .kpi{padding:20px 24px}
.kpi-grid-sm .kpi-val{font-size:28px}

/* Game log table */
.game-log-wrap{
  background:linear-gradient(180deg,var(--navy-800),var(--navy-850));
  border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;overflow-x:auto;
}
.game-log{
  width:100%;border-collapse:collapse;font-size:13px;
  table-layout:auto;
}
.game-log thead th{
  background:rgba(46,107,255,.06);
  padding:14px 16px;
  font-size:10px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-mute);
  border-bottom:1px solid var(--line-strong);
  text-align:center;cursor:help;
  white-space:nowrap;
}
.game-log thead th:first-child,
.game-log thead th:nth-child(2){text-align:left}
.game-log tbody td{
  padding:12px 16px;
  border-bottom:1px solid var(--line);
  text-align:center;
  color:var(--text-dim);
  font-family:'SF Mono',ui-monospace,monospace;
  font-size:13px;
}
.game-log tbody td:first-child,
.game-log tbody td:nth-child(2){
  text-align:left;
  font-family:var(--font-body);
  color:var(--text);
}
.game-log tbody tr:last-child td{border-bottom:none}
.game-log tbody tr:hover{background:rgba(46,107,255,.04)}
.game-log tbody td a{
  color:var(--blue-300);
  border-bottom:1px dashed rgba(139,176,255,.3);
}
.game-log tbody td a:hover{color:var(--blue-400)}
.game-log tbody td.hot{
  color:var(--gold-bright);font-weight:600;
}

/* Chart cards */
.chart-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);
}
@media(max-width:900px){.chart-grid{grid-template-columns:1fr}}
.chart-card{
  background:linear-gradient(180deg,var(--navy-800),var(--navy-850));
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:24px 28px;
  transition:border-color .3s var(--ease);
}
.chart-card:hover{border-color:var(--line-strong)}
.chart-card h4{
  font-size:13px;font-weight:500;color:var(--text-dim);
  margin-bottom:20px;
  letter-spacing:.08em;text-transform:uppercase;
  display:flex;align-items:center;gap:8px;
}
.chart-card h4::before{
  content:"";display:inline-block;width:4px;height:14px;
  background:linear-gradient(180deg,var(--blue-400),var(--blue-500));
  border-radius:2px;
}
.chart-wrap{position:relative;height:260px}
.chart-wrap canvas{position:absolute;inset:0;width:100%!important;height:100%!important}

/* Dashboard avatar photo */
.dash-avatar.photo{
  background:#0F1E38;overflow:hidden;padding:0;
}
.dash-avatar.photo img{width:100%;height:100%;object-fit:cover}

/* Player link in tables */
.stats-table td a.player-link{
  color:var(--text);border-bottom:1px dashed rgba(139,176,255,.4);
  transition:all .2s var(--ease);
}
.stats-table td a.player-link:hover{
  color:var(--blue-300);border-color:var(--blue-400);
}

/* Field help */
.field .hint{font-size:11px;color:var(--text-mute);margin-top:2px}
.field .err{font-size:12px;color:#ff8a8a;margin-top:4px;min-height:14px}
.field .ok{font-size:12px;color:#6ee7a7;margin-top:4px}
.field input:invalid:not(:placeholder-shown){border-color:rgba(255,120,120,.4)}
.pwd-strength{display:flex;gap:4px;margin-top:6px}
.pwd-bar{flex:1;height:3px;background:var(--line-strong);border-radius:2px;transition:all .3s var(--ease)}
.pwd-bar.s1{background:#ff6b6b}
.pwd-bar.s2{background:#ffa94d}
.pwd-bar.s3{background:#ffd43b}
.pwd-bar.s4{background:#51cf66}

/* Toast */
.toast-wrap{position:fixed;top:90px;right:24px;z-index:200;
  display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{
  background:linear-gradient(180deg,var(--navy-700),var(--navy-800));
  border:1px solid var(--line-strong);border-radius:var(--r-md);
  padding:14px 20px;color:var(--text);font-size:14px;
  box-shadow:var(--shadow-lift);min-width:240px;
  animation:slideIn .3s var(--ease);
  border-left:3px solid var(--blue-500);
}
.toast.success{border-left-color:#51cf66}
.toast.error{border-left-color:#ff6b6b}
@keyframes slideIn{from{transform:translateX(400px);opacity:0}to{transform:translateX(0);opacity:1}}

/* Admin layout */
.admin-layout{display:grid;grid-template-columns:220px 1fr;gap:var(--s-6);margin-top:var(--s-5)}
.admin-sidebar{
  background:var(--navy-800);border:1px solid var(--line);
  border-radius:var(--r-md);padding:var(--s-4);height:fit-content;
  position:sticky;top:90px;
}
.admin-sidebar a{
  display:block;padding:10px 14px;font-size:13px;color:var(--text-dim);
  border-radius:var(--r-sm);transition:all .2s var(--ease);
  margin-bottom:2px;cursor:pointer;
}
.admin-sidebar a:hover{background:rgba(46,107,255,.08);color:var(--text)}
.admin-sidebar a.active{background:var(--blue-500);color:#fff;font-weight:500}
@media(max-width:1080px){
  .admin-layout{grid-template-columns:1fr;gap:var(--s-4)}
  .admin-sidebar{
    position:relative;top:auto;
    display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:8px;overflow-x:auto;
    padding:var(--s-3);
    scrollbar-width:none;
  }
  .admin-sidebar::-webkit-scrollbar{display:none}
  .admin-sidebar a{display:flex;align-items:center;justify-content:center;min-height:44px;white-space:nowrap;margin-bottom:0;text-align:center}
}

/* 主区顶部子页 chip 条 — 用户管理同款 pill 风格 */
.admin-subtabs{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;
  margin-bottom:var(--s-5);
  padding:8px;
  background:linear-gradient(180deg,rgba(15,30,56,.86),rgba(10,22,40,.82));
  border:1px solid var(--line-strong);
  border-radius:8px;
  box-shadow:0 14px 34px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.05);
}
.admin-subtabs .subtab{
  background:transparent;border:none;
  color:var(--text-dim);
  padding:12px 18px;
  border-radius:6px;
  font:inherit;font-size:13px;
  cursor:pointer;
  transition:all .2s var(--ease);
  letter-spacing:.04em;
  text-align:center;
}
.admin-subtabs .subtab:hover{
  background:rgba(228,199,122,.06);
  color:var(--text);
}
.admin-subtabs .subtab.active{
  background:linear-gradient(135deg, var(--blue-500), #5b8bff);
  color:#fff;
  font-weight:600;
  border:1px solid rgba(170,200,255,.48);
  box-shadow:0 8px 24px rgba(46,107,255,.25);
  padding:11px 17px; /* 减 1px 抵消 border */
}

.people-toolbar input{
  flex:1;min-width:240px;
  padding:10px 13px;
  background:var(--navy-900);
  border:1px solid var(--line-strong);
  border-radius:8px;
  color:var(--text);
  font:inherit;font-size:13px;
}
.people-segment{
  display:inline-flex;gap:4px;padding:4px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:8px;
}
.people-segment button{
  padding:7px 12px;border-radius:6px;
  color:var(--text-dim);font-size:12px;
  transition:all .2s var(--ease);
}
.people-segment button.active{
  background:rgba(228,199,122,.14);
  color:var(--gold-bright);
  box-shadow:inset 0 0 0 1px rgba(228,199,122,.32);
}
.people-row{
  display:flex;gap:14px;align-items:center;
  padding:12px 14px;
  background:linear-gradient(180deg,rgba(10,22,40,.95),rgba(5,11,24,.92));
  border:1px solid var(--line);
  border-radius:8px;
  flex-wrap:wrap;
  transition:border-color .15s var(--ease), background .15s var(--ease);
}
.people-row:hover{border-color:rgba(91,139,255,.28)}
.admin-panel-tools{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px;
  margin-bottom:22px;
  max-width:720px;
}
.admin-panel-tools .btn,
.admin-tools-menu summary{
  min-height:50px;
  display:flex;align-items:center;justify-content:center;
}
.admin-tools-menu{position:relative}
.admin-tools-menu summary{
  list-style:none;cursor:pointer;
  border:1px solid var(--line-strong);
  border-radius:8px;
  background:rgba(10,22,40,.82);
  color:var(--text);
  font-weight:700;
  transition:border-color .2s var(--ease), background .2s var(--ease), color .2s var(--ease);
}
.admin-tools-menu summary::-webkit-details-marker{display:none}
.admin-tools-menu[open] summary,
.admin-tools-menu summary:hover{
  border-color:rgba(228,199,122,.45);
  color:var(--gold-bright);
  background:rgba(228,199,122,.08);
}
.admin-tools-dropdown{
  position:absolute;left:0;top:calc(100% + 8px);z-index:30;
  width:min(240px, calc(100vw - 48px));
  display:grid;gap:6px;
  padding:8px;
  background:rgba(5,11,24,.98);
  border:1px solid var(--line-strong);
  border-radius:8px;
  box-shadow:0 18px 44px rgba(0,0,0,.4);
}
.admin-tools-dropdown button{
  text-align:left;
  padding:10px 12px;border-radius:6px;
  color:var(--text-dim);
}
.admin-tools-dropdown button:hover{
  background:rgba(46,107,255,.14);
  color:#fff;
}
.pool-slogan{
  margin-top:6px;color:var(--gold-bright);
  font-size:12px;font-family:var(--font-display);
  line-height:1.35;
}
.pool-title-line{
  margin-top:4px;color:var(--text-dim);
  font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pool-mini-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:5px;margin-top:10px;width:100%;
}
.pool-mini-stats span{
  padding:5px 4px;border-radius:6px;
  background:rgba(255,255,255,.035);
  border:1px solid var(--line);
  color:var(--text-dim);
  font-size:10px;text-align:center;
}
.audit-row{
  display:grid;grid-template-columns:110px 1fr auto;
  gap:10px;align-items:center;
  padding:9px 12px;
  background:rgba(5,11,24,.55);
  border:1px solid var(--line);
  border-radius:8px;
  font-size:12px;
}

.admin-panel{
  background:var(--navy-800);border:1px solid var(--line);
  border-radius:var(--r-md);padding:var(--s-6);
}
.admin-panel h3{font-family:var(--font-display);font-size:22px;margin-bottom:var(--s-4)}

.points-admin-panel{
  padding:clamp(24px,3.2vw,40px);
  background:
    radial-gradient(circle at 12% 0, rgba(46,107,255,.16), transparent 34%),
    linear-gradient(180deg, rgba(15,30,56,.96), rgba(10,22,40,.94));
}
.points-admin-panel h3{
  font-size:clamp(26px,3vw,36px);
  margin-bottom:14px;
}
.points-lede{
  max-width:940px;
  line-height:1.85;
  padding-bottom:18px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.points-tabs{
  gap:8px;
  border-bottom:0;
  padding:6px;
  border:1px solid var(--line-strong);
  border-radius:8px;
  background:rgba(5,11,24,.32);
  overflow-x:auto;
  scrollbar-width:none;
}
.points-tabs::-webkit-scrollbar{display:none}
.points-tabs .tab{
  flex:1 0 180px;
  border:1px solid transparent;
  border-radius:6px;
  margin:0;
  text-align:center;
  white-space:nowrap;
}
.points-tabs .tab.active{
  border-color:rgba(91,139,255,.56);
  background:linear-gradient(135deg, rgba(46,107,255,.42), rgba(91,139,255,.18));
  box-shadow:0 10px 26px rgba(46,107,255,.18);
}
.points-workflow{
  display:block;
  padding-top:8px;
}
.points-search-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  max-width:1080px;
  margin-bottom:18px;
}
.points-search-grid .field{
  max-width:none !important;
  margin-bottom:0 !important;
}
.points-quickbar{
  max-width:1080px;
  padding:10px;
  border:1px solid rgba(255,255,255,.07);
  border-radius:8px;
  background:rgba(5,11,24,.22);
}
.points-quickbar .btn{
  border-radius:999px;
  min-height:34px;
}
.points-submit-row{
  max-width:820px !important;
  padding:14px;
  border:1px solid rgba(255,255,255,.07);
  border-radius:8px;
  background:rgba(5,11,24,.20);
}
.points-att-controls{
  max-width:760px;
  padding:14px;
  border:1px solid rgba(255,255,255,.07);
  border-radius:8px;
  background:rgba(5,11,24,.20);
}
.points-att-toolbar{
  align-items:center;
  padding:10px;
  border:1px solid rgba(255,255,255,.07);
  border-radius:8px;
  background:rgba(5,11,24,.18);
}
.points-att-roster{
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr)) !important;
  gap:10px !important;
  max-height:430px !important;
  padding:14px !important;
}
.points-record-row{
  display:grid;
  grid-template-columns:minmax(110px,.9fr) minmax(120px,1fr) 78px minmax(170px,1.4fr) minmax(150px,auto) auto;
  gap:14px;
  align-items:center;
  padding:12px 14px;
  background:rgba(255,255,255,.025);
  border:1px solid var(--line);
  border-radius:8px;
  margin-bottom:8px;
}
.points-att-group{
  background:rgba(255,255,255,.025);
  border:1px solid var(--line);
  border-radius:8px;
  padding:14px 16px;
  margin-bottom:10px;
}
.points-overview-row{
  display:grid;
  grid-template-columns:40px auto minmax(0,1fr) auto auto;
  gap:12px;
  align-items:center;
  padding:12px 14px;
  background:rgba(255,255,255,.025);
  border:1px solid var(--line);
  border-radius:8px;
}
.points-overview-row.is-top{
  background:rgba(228,199,122,.06);
  border-color:rgba(228,199,122,.2);
}

/* Player pool grid */
.pool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--s-3)}
.pool-card{
  background:var(--navy-700);border:1px solid var(--line);
  border-radius:var(--r-md);padding:var(--s-3);text-align:center;
  transition:all .2s var(--ease);position:relative;
}
.pool-card:hover{border-color:var(--blue-500);transform:translateY(-2px)}
.pool-card .photo{
  width:72px;height:72px;border-radius:50%;object-fit:cover;
  margin:0 auto var(--s-2);border:2px solid var(--line-strong);
  background:var(--navy-900);display:block;
}
.pool-card .name{font-size:13px;font-weight:500}
.pool-card .num{font-size:11px;color:var(--text-mute);margin-top:2px}
.pool-card .pos{font-size:10px;color:var(--blue-300);margin-top:2px;letter-spacing:.05em}
.pool-card .actions{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:6px;margin-top:var(--s-2);justify-content:center;width:100%;
}
.pool-card .actions button{
  font-size:10px;padding:3px 8px;border-radius:4px;
  background:rgba(46,107,255,.2);color:var(--blue-300);
  border:1px solid var(--blue-500);
  min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;word-break:keep-all;
}
.pool-card .actions button:hover{background:var(--blue-500);color:#fff}
.pool-card .actions button.danger{
  background:rgba(255,100,100,.1);color:#ff8a8a;border-color:rgba(255,100,100,.4);
}
.player-admin-grid{
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:18px;
  align-items:stretch;
}
.player-admin-card{
  overflow:visible;
  min-height:360px;
  padding:20px 18px 18px;
  display:flex;flex-direction:column;align-items:center;
  background:
    radial-gradient(circle at 50% -10%,rgba(91,139,255,.26),transparent 42%),
    linear-gradient(180deg,rgba(25,50,90,.88),rgba(8,18,36,.96));
  border-color:rgba(91,139,255,.24);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.035),0 18px 48px rgba(0,0,0,.24);
}
.player-admin-card::before{
  content:"";position:absolute;left:14px;right:14px;top:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold-bright),var(--blue-400),transparent);
  opacity:.75;border-radius:999px;
}
.player-admin-card.is-casual{
  background:
    radial-gradient(circle at 50% -10%,rgba(46,107,255,.32),transparent 42%),
    linear-gradient(180deg,rgba(22,48,91,.86),rgba(8,18,36,.96));
}
.pool-status-pill{
  position:absolute;top:12px;right:12px;
  border-radius:999px;padding:4px 10px;
  font-size:11px;line-height:1;
  border:1px solid rgba(228,199,122,.38);
  background:rgba(228,199,122,.14);
  color:var(--gold-bright);
  box-shadow:0 8px 18px rgba(0,0,0,.18);
}
.pool-status-pill.tryout{
  border-color:rgba(91,139,255,.45);
  background:rgba(46,107,255,.16);
  color:var(--blue-300);
}
.pool-card-photo-wrap{
  width:116px;height:116px;border-radius:50%;
  padding:4px;margin:2px auto 14px;
  background:linear-gradient(135deg,var(--gold-bright),rgba(91,139,255,.75));
  box-shadow:0 0 28px rgba(91,139,255,.20);
}
.player-admin-card .photo{
  width:100%;height:100%;
  border:0;margin:0;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}
.player-admin-card .name{
  font-family:var(--font-display);
  font-size:22px;font-weight:700;
  line-height:1.15;color:#fff;
}
.pool-card-meta{
  display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;
  min-height:34px;margin-top:8px;
  color:var(--blue-300);font-size:13px;letter-spacing:.04em;
}
.pool-alias-line{
  max-width:100%;
  margin-top:6px;
  font-size:12px;color:var(--blue-300);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.player-admin-card .pool-mini-stats{
  margin-top:16px;
  gap:8px;
}
.player-admin-card .pool-mini-stats span{
  padding:9px 6px;
  font-size:12px;
  border-color:rgba(255,255,255,.10);
  background:rgba(255,255,255,.045);
}
.pool-card-actions{
  width:100%;
  margin-top:auto;
  padding-top:16px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  position:relative;
  min-width:0;
}
.pool-action,
.pool-more summary{
  min-height:38px;
  display:flex;align-items:center;justify-content:center;
  border-radius:7px;
  border:1px solid rgba(91,139,255,.48);
  background:rgba(46,107,255,.14);
  color:var(--blue-300);
  font-size:12px;font-weight:600;
  white-space:nowrap;word-break:keep-all;
  min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;
  padding:0 8px;
  box-sizing:border-box;
}
.pool-action.primary{
  color:#fff;
  background:linear-gradient(135deg,var(--blue-500),var(--blue-400));
  border-color:rgba(91,139,255,.85);
  box-shadow:0 8px 18px rgba(46,107,255,.20);
}
.pool-action:hover,
.pool-more summary:hover{background:rgba(46,107,255,.28);color:#fff}
.pool-more{position:relative}
.pool-more summary{
  list-style:none;cursor:pointer;
  width:100%;
}
.pool-more summary::-webkit-details-marker{display:none}
.pool-more[open] summary{
  border-color:rgba(228,199,122,.45);
  color:var(--gold-bright);
  background:rgba(228,199,122,.10);
}
.pool-more-menu{
  position:absolute;right:0;bottom:calc(100% + 8px);z-index:35;
  min-width:150px;
  display:grid;gap:5px;
  padding:8px;
  background:rgba(5,11,24,.98);
  border:1px solid var(--line-strong);
  border-radius:8px;
  box-shadow:0 18px 44px rgba(0,0,0,.42);
}
.pool-more-menu button{
  text-align:left;
  padding:9px 10px;
  border-radius:6px;
  color:var(--text-dim);
  font-size:12px;
}
.pool-more-menu button:hover{
  background:rgba(46,107,255,.14);
  color:#fff;
}
.pool-more-menu button.danger{
  color:#ff8a8a;
}
.pool-more-menu button.danger:hover{
  background:rgba(255,100,100,.10);
}

/* Bind code list */
.code-list{display:flex;flex-direction:column;gap:var(--s-2)}
.code-item{
  background:var(--navy-700);border:1px solid var(--line);
  border-radius:var(--r-sm);padding:var(--s-3) var(--s-4);
  display:flex;align-items:center;gap:var(--s-4);flex-wrap:wrap;
}
.code-item code{
  font-family:'SF Mono',Monaco,monospace;font-size:13px;
  color:var(--gold-bright);letter-spacing:.08em;
  background:rgba(201,169,97,.08);padding:4px 10px;border-radius:4px;
}
.code-item .meta{font-size:12px;color:var(--text-mute);flex:1}
.code-item .status{font-size:11px;padding:3px 10px;border-radius:999px}
.code-item .status.unused{background:rgba(46,107,255,.15);color:var(--blue-300)}
.code-item .status.used{background:rgba(100,100,100,.15);color:var(--text-mute)}

/* ---------- Players roster page ---------- */
.players-hero{
  text-align:center;padding:var(--s-9) 0 var(--s-6);
  background:radial-gradient(ellipse at center, rgba(46,107,255,.12), transparent 60%);
  border-bottom:1px solid var(--line);
  margin-bottom:var(--s-6);
}
.players-title{
  font-family:var(--font-display);font-size:clamp(40px,6vw,72px);
  background:linear-gradient(180deg,#fff 20%,#8FB0FF 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:.02em;margin-bottom:var(--s-3);
}
.players-sub{color:var(--text-mute);font-size:14px;max-width:520px;margin:0 auto var(--s-6)}
.players-filter-bar{
  max-width:720px;margin:var(--s-6) auto 0;
  display:flex;flex-direction:column;gap:var(--s-3);align-items:center;
}
.players-filter-bar input[type=search]{
  width:100%;max-width:420px;
  background:var(--navy-800);border:1px solid var(--line-strong);
  border-radius:999px;padding:12px 20px;color:var(--text);font:inherit;font-size:14px;
  transition:all .2s var(--ease);
}
.players-filter-bar input[type=search]:focus{
  outline:none;border-color:var(--blue-500);box-shadow:0 0 0 3px var(--blue-glow);
}
.pos-chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.pos-chip{
  font-size:12px;padding:6px 14px;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid var(--line-strong);
  color:var(--text-dim);transition:all .2s var(--ease);cursor:pointer;
}
.pos-chip:hover{color:var(--text);border-color:var(--blue-400)}
.pos-chip.active{background:var(--blue-500);color:#fff;border-color:var(--blue-500);
  box-shadow:0 4px 12px var(--blue-glow)}

.players-stats-bar{
  display:flex;gap:var(--s-6);justify-content:center;
  margin-bottom:var(--s-6);padding:var(--s-5);
  background:var(--navy-800);border:1px solid var(--line);border-radius:var(--r-lg);
  flex-wrap:wrap;
}
.psb-item{text-align:center;min-width:80px}
.psb-num{font-family:var(--font-display);font-size:32px;font-weight:600;
  color:var(--gold-bright);line-height:1}
.psb-label{font-size:10px;letter-spacing:.2em;color:var(--text-mute);
  text-transform:uppercase;margin-top:6px}

/* ---------- Player card — HOF-inspired centered layout ---------- */
.players-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:var(--s-5);
}
.player-card{
  background:linear-gradient(180deg,rgba(46,107,255,.04),transparent 60%),var(--navy-800);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:var(--s-6);  /* 32px generous padding, matches HOF card */
  text-align:center;
  transition:all .35s var(--ease);
  position:relative;
  cursor:pointer;
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;
}
.player-card::before{
  content:"";position:absolute;inset:-1px;border-radius:var(--r-lg);
  background:linear-gradient(135deg,transparent,rgba(46,107,255,.25),transparent);
  opacity:0;transition:opacity .4s var(--ease);z-index:-1;
}
.player-card:hover{
  transform:translateY(-6px);
  border-color:var(--line-bright);
  box-shadow:var(--shadow-2), 0 0 60px rgba(46,107,255,.18);
}
.player-card:hover::before{opacity:1}

/* Circular photo — centered, blue rim (gold is reserved for HOF) */
.pc-photo{
  width:120px;height:120px;border-radius:50%;
  object-fit:cover;object-position:center 20%;
  margin:0 auto var(--s-4);
  border:2px solid rgba(46,107,255,.35);
  box-shadow:0 0 32px rgba(46,107,255,.18), inset 0 0 0 1px rgba(255,255,255,.04);
  background:var(--navy-900);
  transition:all .4s var(--ease);
}
.player-card:hover .pc-photo{
  border-color:var(--blue-400);
  box-shadow:0 0 48px rgba(46,107,255,.35), inset 0 0 0 1px rgba(255,255,255,.08);
}

/* Public identity privacy layer: use a stable blur plus lightweight glass shimmer.
   The shimmer animates opacity only; blur/filter/scale stay static for frame rate. */
.identity-avatar-wrap,
.podium-photo-clip{
  position:relative;
  place-items:center;
  border-radius:50%;
  overflow:hidden;
  background:var(--navy-900);
  line-height:0;
  -webkit-mask-image:radial-gradient(circle at center,#000 98%,transparent 100%);
  mask-image:radial-gradient(circle at center,#000 98%,transparent 100%);
}
.identity-avatar-wrap{
  display:inline-grid;
  flex-shrink:0;
}
.pp-photo-wrap.is-frosted-avatar{
  border-radius:50%;
  overflow:hidden;
  display:inline-grid;
  -webkit-mask-image:radial-gradient(circle at center,#000 98%,transparent 100%);
  mask-image:radial-gradient(circle at center,#000 98%,transparent 100%);
}
.identity-avatar-wrap > img,
.podium-photo-clip > img,
.pp-photo-wrap > img{
  display:block;
  width:100%!important;
  height:100%!important;
  max-width:none;
  object-fit:cover;
  border-radius:inherit;
  box-sizing:border-box;
  margin:0!important;
  transform-origin:center;
}
.identity-avatar-wrap > img{
  border:0!important;
  box-shadow:none!important;
}
.player-card .identity-avatar-wrap .pc-photo{
  width:100%;
  height:100%;
  margin:0!important;
}
.identity-avatar-wrap.is-frosted-avatar::after,
.podium-photo-clip.is-frosted-avatar::after,
.pp-photo-wrap.is-frosted-avatar::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  z-index:2;
  background:
    linear-gradient(135deg,rgba(255,255,255,.30),rgba(190,212,255,.08) 38%,rgba(255,255,255,.17) 70%,rgba(48,73,118,.14)),
    radial-gradient(circle at 28% 18%,rgba(255,255,255,.26),transparent 34%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.30),
    inset 0 -14px 24px rgba(5,14,32,.22);
  animation:publicIdentityGlint 5.8s ease-in-out infinite;
}
.identity-frosted-avatar{
  filter:blur(4px) saturate(.80) contrast(.92) brightness(.90);
  -webkit-clip-path:circle(50% at 50% 50%);
  clip-path:circle(50% at 50% 50%);
  contain:paint;
}
.identity-avatar-wrap.is-frosted-avatar > .identity-frosted-avatar{
  transform:scale(1.075);
}
.rank-mini-avatar.identity-avatar-wrap{
  box-shadow:
    inset 0 0 0 2px var(--line-strong),
    0 0 18px rgba(46,107,255,.14);
}
.rank-mini-avatar.identity-avatar-wrap > .rank-mini-photo{
  width:44px!important;
  height:44px!important;
  aspect-ratio:1 / 1;
}
.player-card .identity-avatar-wrap{
  box-shadow:
    inset 0 0 0 2px rgba(46,107,255,.35),
    0 0 32px rgba(46,107,255,.18);
}
}
.public-identity-name.identity-frosted-name,
.player-link .public-identity-name.identity-frosted-name{
  display:inline-block;
  filter:blur(2px);
  opacity:.82;
  color:inherit;
  text-shadow:0 0 8px rgba(232,238,250,.34),0 3px 12px rgba(0,0,0,.58);
  animation:publicIdentityNameTwinkle 5.8s ease-in-out infinite;
  user-select:none;
}
@keyframes publicIdentityGlint{
  0%,100%{opacity:.56}
  42%{opacity:.86}
  64%{opacity:.64}
}
@keyframes publicIdentityNameTwinkle{
  0%,100%{opacity:.76}
  45%{opacity:.9}
  62%{opacity:.70}
}
@media (prefers-reduced-motion:reduce){
  .identity-avatar-wrap.is-frosted-avatar::after,
  .podium-photo-clip.is-frosted-avatar::after,
  .pp-photo-wrap.is-frosted-avatar::after,
  .public-identity-name.identity-frosted-name{
    animation:none!important;
  }
}

/* Name */
.pc-name{
  font-family:var(--font-display);
  font-size:22px;font-weight:600;
  color:var(--text);
  line-height:1.2;letter-spacing:.005em;
}
/* Slogan chip — small highlighted pill right under name, only when set */
.pc-slogan{
  display:inline-block;
  margin-top:8px;
  font-size:11px;line-height:1.4;
  padding:3px 10px;border-radius:999px;
  background:linear-gradient(135deg,rgba(201,169,97,.15),rgba(46,107,255,.08));
  color:var(--gold-bright);
  border:1px solid rgba(201,169,97,.28);
  font-style:normal;letter-spacing:.01em;
  max-width:100%;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
/* Meta line — #number · position · bats/throws */
.pc-meta{
  font-size:10px;letter-spacing:.18em;
  color:var(--text-mute);
  text-transform:uppercase;font-weight:500;
  margin:10px 0 10px;
  line-height:1.4;
}
.pc-meta .num{color:var(--blue-400);font-weight:600}
.pc-meta .sep{margin:0 6px;opacity:.4}
.pc-meta .handed{color:var(--text-dim)}

/* Titles row — small gold chips */
.pc-titles{
  display:flex;flex-wrap:wrap;gap:5px;justify-content:center;
  margin-bottom:12px;min-height:22px;
}
.pc-title-chip{
  font-size:9px;letter-spacing:.08em;
  padding:3px 8px;border-radius:4px;
  background:rgba(201,169,97,.08);
  color:var(--gold);
  border:1px solid rgba(201,169,97,.22);
  font-weight:500;
}
.pc-title-chip.primary{
  background:rgba(201,169,97,.18);color:var(--gold-bright);
  border-color:rgba(201,169,97,.5);
}
.pc-titles-empty{
  font-size:9px;color:var(--text-mute);opacity:.5;
  letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:12px;min-height:22px;display:flex;align-items:center;justify-content:center;
}

/* Stats row — 4 columns, top border separator */
.pc-stats{
  display:flex;justify-content:space-around;
  margin-top:auto;padding-top:var(--s-4);
  border-top:1px solid var(--line);
  gap:4px;
}
.pc-stats > div{text-align:center;flex:1;min-width:0}
.pc-stats .pc-stat-v{
  font-family:var(--font-display);font-size:19px;font-weight:600;
  color:var(--gold-bright);line-height:1;letter-spacing:-.01em;
}
.pc-stats .pc-stat-k{
  font-size:9px;letter-spacing:.18em;color:var(--text-mute);
  text-transform:uppercase;margin-top:4px;font-weight:500;
}

/* Dashboard filter bar */
.dash-filter-bar{
  background:var(--navy-800);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:var(--s-4) var(--s-5);
  margin-bottom:var(--s-5);
  display:flex;gap:var(--s-4);align-items:center;flex-wrap:wrap;
}
.dash-filter-bar > label{
  font-size:11px;letter-spacing:.2em;color:var(--text-mute);
  text-transform:uppercase;flex-shrink:0;
}
.dash-filter-bar select{
  background:var(--navy-900);border:1px solid var(--line-strong);
  border-radius:var(--r-sm);padding:8px 14px;color:var(--text);
  font:inherit;font-size:13px;cursor:pointer;min-width:160px;
  transition:all .2s var(--ease);
}
.dash-filter-bar select:hover{border-color:var(--blue-400)}
.dash-filter-bar select:focus{outline:none;border-color:var(--blue-500);
  box-shadow:0 0 0 2px var(--blue-glow)}
.dash-filter-bar .filter-reset{
  font-size:12px;color:var(--text-mute);text-decoration:underline;
  background:none;border:none;cursor:pointer;margin-left:auto;
}
.dash-filter-bar .filter-reset:hover{color:var(--blue-400)}

/* Slogan on dashboard — slim band variant */
.player-slogan-card{
  background:linear-gradient(135deg,rgba(201,169,97,.05),rgba(46,107,255,.02));
  border:1px solid rgba(201,169,97,.18);
  border-radius:999px;  /* pill — narrow band */
  padding:10px 20px 10px 24px;
  margin-bottom:var(--s-5);
  display:flex;align-items:center;gap:var(--s-3);
  min-height:44px;
}
.player-slogan-card .quote{
  font-size:18px;color:var(--gold);font-family:Georgia,serif;
  line-height:1;flex-shrink:0;opacity:.7;
  margin-top:-2px;
}
.player-slogan-card .content{flex:1;min-width:0;overflow:hidden}
.player-slogan-card .content .text{
  font-size:13px;color:var(--text-dim);font-style:italic;
  line-height:1.4;
  white-space:nowrap;text-overflow:ellipsis;overflow:hidden;
}
.player-slogan-card .content .empty{color:var(--text-mute);font-style:normal;opacity:.6}
.player-slogan-card button.edit-slogan{
  font-size:10px;padding:4px 10px;border-radius:999px;
  background:transparent;color:var(--gold);
  border:1px solid rgba(201,169,97,.3);
  flex-shrink:0;
  letter-spacing:.05em;
}
.player-slogan-card button.edit-slogan:hover{
  background:rgba(201,169,97,.08);color:var(--gold-bright);
}

/* Password reveal toggle */
.pwd-wrap{position:relative;width:100%;display:block}
.pwd-wrap input{padding-right:42px;width:100%}
.pwd-toggle{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  width:32px;height:32px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-mute);font-size:16px;cursor:pointer;
  transition:all .2s var(--ease);
}
.pwd-toggle:hover{color:var(--text);background:rgba(255,255,255,.05)}

/* HOF page */
.hof-hero{
  text-align:center;padding:var(--s-9) 0 var(--s-7);
  background:radial-gradient(ellipse at center, rgba(201,169,97,.1), transparent 60%);
  border-bottom:1px solid var(--line);
  margin-bottom:var(--s-7);
}
.hof-title{
  font-family:var(--font-display);font-size:clamp(40px,6vw,72px);
  background:linear-gradient(180deg,var(--gold-bright),var(--gold) 60%,#8a7440);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:.02em;
}
.hof-sub{font-size:13px;color:var(--text-mute);letter-spacing:.3em;
  text-transform:uppercase;margin-top:var(--s-3)}
.hof-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--s-5)}
.hof-card{
  background:linear-gradient(180deg,rgba(201,169,97,.06),transparent 60%),var(--navy-800);
  border:1px solid rgba(201,169,97,.25);border-radius:var(--r-lg);
  padding:var(--s-6);text-align:center;
  transition:all .4s var(--ease);position:relative;
  cursor:pointer;
}
.hof-card::before{
  content:"";position:absolute;inset:-1px;border-radius:var(--r-lg);
  background:linear-gradient(135deg,transparent,rgba(201,169,97,.3),transparent);
  opacity:0;transition:opacity .4s;z-index:-1;
}
.hof-card:hover{
  transform:translateY(-6px);
  border-color:var(--gold);
  box-shadow:0 20px 60px rgba(0,0,0,.5), 0 0 60px rgba(201,169,97,.2);
}
.hof-photo{
  width:120px;height:120px;border-radius:50%;object-fit:cover;
  margin:0 auto var(--s-4);border:3px solid var(--gold);
  box-shadow:0 0 40px rgba(201,169,97,.3);
  background:var(--navy-900);
}
.hof-photo-wrap{
  width:120px;
  height:120px;
  margin:0 auto var(--s-4);
  border:3px solid var(--gold);
  box-shadow:0 0 40px rgba(201,169,97,.3);
}
.hof-photo-wrap .hof-photo{
  width:100%;
  height:100%;
  margin:0;
  border:0;
  box-shadow:none;
}
.hof-name{font-family:var(--font-display);font-size:26px;font-weight:600;color:var(--gold-bright)}
.hof-year{font-size:11px;letter-spacing:.3em;color:var(--text-mute);
  text-transform:uppercase;margin:var(--s-2) 0 var(--s-3)}
.hof-reason{font-size:13px;color:var(--text-dim);line-height:1.6}

/* Game mini stats */
.mvp-card{
  background:linear-gradient(135deg,rgba(201,169,97,.15),rgba(46,107,255,.05));
  border:1px solid var(--gold);border-radius:var(--r-lg);
  padding:var(--s-5);display:flex;gap:var(--s-5);align-items:center;
  margin-bottom:var(--s-6);
}
.mvp-photo{
  width:96px;height:96px;border-radius:50%;object-fit:cover;
  border:3px solid var(--gold);flex-shrink:0;
}
.mvp-label{font-size:11px;letter-spacing:.3em;color:var(--gold-bright);
  text-transform:uppercase}
.mvp-name{font-family:var(--font-display);font-size:28px;font-weight:600;
  margin-top:4px}
.mvp-note{color:var(--text-dim);font-size:13px;margin-top:6px}

/* Video embed in highlight detail */
.video-embed{
  aspect-ratio:16/9;border-radius:var(--r-md);overflow:hidden;
  background:#000;border:1px solid var(--line);
}
.video-embed iframe{width:100%;height:100%;border:0}

/* Empty state */
.empty{
  padding:var(--s-7);text-align:center;color:var(--text-mute);
  font-size:14px;border:1px dashed var(--line-strong);
  border-radius:var(--r-md);
}

/* Login button in nav */
.btn-nav{
  padding:8px 18px;font-size:13px;border-radius:var(--r-sm);
  background:var(--blue-500);color:#fff;font-weight:500;
  box-shadow:0 4px 16px var(--blue-glow);transition:all .2s var(--ease);
}
.btn-nav:hover{background:var(--blue-400);transform:translateY(-1px)}
.btn-nav.ghost{background:transparent;border:1px solid var(--line-strong);
  box-shadow:none;color:var(--text-dim)}
.btn-nav.ghost:hover{color:#fff;border-color:var(--blue-500)}

/* ---------- Contact people ---------- */
.contact-people{
  display:flex;flex-direction:column;gap:var(--s-4);
  background:var(--navy-800);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:var(--s-5);
}
.contact-person{
  display:flex;align-items:center;gap:var(--s-4);
  padding:var(--s-3);border-radius:var(--r-md);
  transition:background .2s var(--ease);
}
.contact-person:hover{background:rgba(46,107,255,.06)}
.cp-avatar{
  width:56px;height:56px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue-500),var(--blue-400));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:24px;font-weight:600;color:#fff;
  box-shadow:0 0 24px var(--blue-glow);
}
.cp-avatar.img{
  background:var(--navy-900);object-fit:cover;
  box-shadow:0 0 0 2px rgba(255,255,255,.06), 0 0 24px var(--blue-glow);
}
.cp-info{flex:1;min-width:0}
.cp-name{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}
.cp-handles{display:flex;flex-wrap:wrap;gap:6px}
.cp-tag{
  font-size:11px;padding:3px 10px;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid var(--line-strong);
  color:var(--text-dim);font-family:'SF Mono',ui-monospace,monospace;
}
.cp-tag.wx{border-color:rgba(7,193,96,.4);color:#7CD8A6}
.cp-tag.xhs{border-color:rgba(255,90,90,.4);color:#FF8A8A}
.cp-tag.mail{border-color:rgba(96,165,250,.42);color:#93C5FD}
.contact-tip{
  font-size:12px;color:var(--text-mute);text-align:center;
  padding-top:var(--s-3);border-top:1px dashed var(--line);
}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-7)}

/* Card source link badge */
.card-source{
  display:inline-block;margin-top:var(--s-3);font-size:11px;
  color:#FF8A8A;border:1px solid rgba(255,138,138,.3);
  padding:4px 10px;border-radius:999px;
  transition:all .2s var(--ease);
}
.card-source:hover{background:rgba(255,138,138,.08);color:#FFA8A8}

/* ---------- Events admin specific ---------- */
.event-list{display:flex;flex-direction:column;gap:var(--s-3)}
.event-item{
  display:flex;gap:var(--s-4);padding:var(--s-3);
  background:var(--navy-800);border:1px solid var(--line);
  border-radius:var(--r-md);align-items:center;
}
.event-item img{width:88px;height:60px;object-fit:cover;border-radius:var(--r-sm);flex-shrink:0}
.event-item .meta{flex:1;min-width:0}
.event-item .meta strong{display:block;font-size:14px;color:var(--text);margin-bottom:4px}
.event-item .meta .sub{font-size:12px;color:var(--text-mute)}
.event-item .actions{display:flex;gap:6px;flex-shrink:0}
.event-item .actions button{
  font-size:11px;padding:5px 10px;border-radius:var(--r-sm);
  background:var(--navy-700);color:var(--text-dim);border:1px solid var(--line);
}
.event-item .actions button:hover{color:#fff;border-color:var(--blue-500)}
.event-item .actions .danger:hover{color:#FF8A8A;border-color:#FF6868}

/* File picker styled */
.file-picker{
  display:block;border:2px dashed var(--line-strong);
  border-radius:var(--r-md);padding:var(--s-5);text-align:center;
  cursor:pointer;background:rgba(46,107,255,.04);
  transition:all .2s var(--ease);
}
.file-picker:hover{border-color:var(--blue-500);background:rgba(46,107,255,.08)}
.file-picker.dragover{border-color:var(--gold-bright);background:rgba(255,206,84,.12);transform:scale(1.01)}

/* Game detail — sortable stat tables + per-table charts */
.stats-table th.sortable{cursor:pointer;user-select:none;transition:color .15s var(--ease)}
.stats-table th.sortable:hover{color:var(--gold-bright)}
.stats-table th.sortable.active{color:var(--gold-bright)}
.stats-table th.sortable.active::after{content:" ▼";font-size:9px;margin-left:2px;opacity:.85}
.stats-table th.sortable.active.asc::after{content:" ▲"}
.sort-hint{font-size:11px;color:var(--text-mute);margin:6px 0 8px;font-style:italic}
.stats-chart-wrap{margin-top:var(--s-3);background:rgba(255,255,255,.025);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s-3)}
.stats-chart-wrap h5{margin:0 0 8px;font-size:12px;color:var(--gold-bright);font-weight:500;letter-spacing:.5px}
.stats-chart-wrap .chart-wrap-inner{height:220px;position:relative}
.file-picker .icon{font-size:32px;display:block;margin-bottom:6px}
.file-picker .label{font-size:13px;color:var(--text-dim)}
.file-picker .hint{font-size:11px;color:var(--text-mute);margin-top:4px}
.file-picker input[type=file]{display:none}
.file-preview{
  margin-top:var(--s-3);display:flex;flex-wrap:wrap;gap:8px;
}
.file-preview{align-items:flex-start}
.file-preview .thumb{
  width:80px;height:80px;border-radius:var(--r-sm);overflow:hidden;
  position:relative;border:1px solid var(--line);
}
.file-preview .thumb img{width:100%;height:100%;object-fit:cover}
.file-preview .cover-thumb{
  border:1px solid var(--blue-500);box-shadow:0 0 0 1px var(--blue-glow);
}
.file-preview .thumb button{
  position:absolute;top:2px;right:2px;width:20px;height:20px;
  background:rgba(0,0,0,.7);color:#fff;border-radius:50%;
  font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;
}

/* Big paste textarea for Xiaohongshu import */
.xhs-import{
  background:linear-gradient(135deg,rgba(255,90,90,.06),rgba(46,107,255,.04));
  border:1px solid rgba(255,138,138,.2);border-radius:var(--r-md);
  padding:var(--s-4);margin-bottom:var(--s-4);
}
.xhs-import-head{
  display:flex;align-items:center;gap:8px;margin-bottom:var(--s-3);
  font-size:13px;color:#FF8A8A;font-weight:500;
}
.xhs-import textarea{
  width:100%;min-height:100px;background:var(--navy-900);
  border:1px solid var(--line-strong);border-radius:var(--r-sm);
  padding:var(--s-3);color:var(--text);font:inherit;font-size:13px;
  resize:vertical;
}
.xhs-import .btn-row{display:flex;gap:8px;margin-top:var(--s-3)}
.xhs-import .btn-row button{
  font-size:12px;padding:6px 14px;border-radius:var(--r-sm);
  background:rgba(255,138,138,.15);color:#FF8A8A;
  border:1px solid rgba(255,138,138,.4);
}
.xhs-import .btn-row button:hover{background:rgba(255,138,138,.25)}

/* ========================================================
   Tooltip — pure CSS, usage: <el data-tooltip="text">
   Optional data-tooltip-sub for secondary line.
   Optional data-tooltip-formula for mono formula line.
   ======================================================== */
[data-tooltip]{position:relative}
[data-tooltip]:not([data-no-cursor])::before{content:none}
[data-tooltip]::after{
  /* Bubble */
  content:attr(data-tooltip) "\A" attr(data-tooltip-sub) "\A" attr(data-tooltip-formula);
  white-space:pre-line;
  position:absolute;
  bottom:calc(100% + 14px);
  left:50%;
  transform:translateX(-50%) translateY(6px);
  background:linear-gradient(180deg,var(--navy-800),var(--navy-900));
  color:var(--text);
  font-family:var(--font-body);
  font-size:12px;line-height:1.55;font-weight:400;
  padding:12px 16px;
  border-radius:var(--r-md);
  border:1px solid var(--line-strong);
  box-shadow:0 18px 48px rgba(0,0,0,.6), 0 0 0 1px rgba(46,107,255,.08);
  width:max-content;max-width:260px;
  pointer-events:none;opacity:0;
  transition:opacity .22s var(--ease), transform .22s var(--ease);
  transition-delay:0s;
  z-index:9999;
  text-align:left;
}
[data-tooltip]:hover::after,
[data-tooltip]:focus-visible::after{
  opacity:1;transform:translateX(-50%) translateY(0);
  transition-delay:.35s;
}
/* Downward variant */
[data-tooltip-pos="bottom"]::after{
  bottom:auto;top:calc(100% + 14px);
  transform:translateX(-50%) translateY(-6px);
}
[data-tooltip-pos="bottom"]:hover::after{transform:translateX(-50%) translateY(0)}

/* ========================================================
   Base card — shared surface for all card variants
   ======================================================== */
.card-base{
  background:linear-gradient(180deg,var(--navy-800),var(--navy-850));
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  transition:border-color .3s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease);
}
.card-base:hover{
  border-color:var(--line-strong);
}

/* ---------- Mobile (≤768px) ---------- */
@media (max-width: 768px) {
  :root{
    --s-9:60px; --s-10:80px;
  }
  .reg-mode-grid,
  .reg-account-grid{grid-template-columns:1fr}
  .container{padding:0 var(--s-4)}
  .nav-inner{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    padding:10px 0 0;
    gap:8px 10px;
    max-width:none;
    width:100%;
    box-sizing:border-box;
  }
  .brand{min-width:0;padding-left:12px}
  .brand-name{min-width:0}
  .nav-auth{order:1;gap:4px;padding-right:12px;margin-left:0;min-width:0;max-width:calc(100vw - 170px)}
  .nav-auth .btn-nav{font-size:12px;padding:6px 10px}
  .nav-auth .nav-hello{
    display:inline-flex;
    align-items:center;
    max-width:76px;
    min-height:30px;
    box-sizing:border-box;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    margin-left:0;
    padding:6px 9px;
    border-left:0;
    border:1px solid rgba(201,169,97,.35);
    border-radius:999px;
    background:rgba(201,169,97,.08);
    color:var(--gold-bright);
    line-height:1;
  }
  .nav-auth .nav-hello-prefix{display:none}
  .nav-links{
    grid-column:1 / -1;
    width:100%;order:2;gap:8px;justify-content:flex-start;
    overflow-x:auto;scrollbar-width:none;padding:0 12px 8px;
    flex-wrap:nowrap;
    scroll-snap-type:x proximity;
    max-width:100vw;
    box-sizing:border-box;
    -webkit-overflow-scrolling:touch;
  }
  .nav-links::-webkit-scrollbar{display:none}
  .nav-links a{font-size:13px;white-space:nowrap;flex-shrink:0}
  .nav-item{
    min-height:40px;
    padding:9px 12px;
    background:rgba(255,255,255,.025);
    scroll-snap-align:start;
  }
  .nav-item .nav-label{white-space:nowrap;word-break:keep-all}
  .brand-cn{font-size:16px}
  .brand-en{font-size:9px}

  /* Hero */
  .hero{min-height:auto;padding:var(--s-7) var(--s-4) var(--s-7)}
  .hero-row img{width:200px;height:120px}
  .hero-logo{width:96px;height:96px}
  .hero-name{font-size:44px;margin-top:var(--s-4)}
  .hero-en{font-size:10px;letter-spacing:.4em}
  .hero-tag{font-size:13px;padding:0 var(--s-3)}
  .stats{gap:var(--s-6);margin-top:var(--s-7)}
  .stat-num{font-size:64px}
  .stat-divider{display:none}

  /* Sections */
  .section{padding:var(--s-7) 0}
  .section-title{font-size:28px}
  .grid{grid-template-columns:1fr;gap:var(--s-4)}
  .quick-links{grid-template-columns:repeat(2,1fr);gap:var(--s-4)}
  .quick-card{padding:var(--s-5) var(--s-4)}
  .wall{padding:var(--s-4) var(--s-4) var(--s-7)}
  .poster{flex:0 0 240px}

  /* Contact */
  .contact-grid{grid-template-columns:1fr;gap:var(--s-5)}

  /* Modals */
  .modal{max-width:calc(100vw - 32px);padding:var(--s-5) !important}
  .captcha-row{flex-direction:column;align-items:stretch}
  .captcha-img{align-self:flex-start}

  /* Dashboard */
  .dash-hero{flex-direction:column;text-align:center}
  .dash-info{text-align:center}
  .dash-badges{justify-content:center}
  .dash-filter-bar{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    padding:var(--s-4);
    max-width:100%;
  }
  .dash-filter-bar > label{justify-self:start}
  .dash-filter-bar select{
    width:100%;
    min-width:0;
  }
  .dash-filter-bar .filter-reset{
    margin-left:0;
    justify-self:start;
  }
  .player-slogan-card{
    border-radius:var(--r-lg);
    align-items:flex-start;
    padding:18px 18px;
  }
  .player-slogan-card .content .text{
    white-space:normal;
    overflow:visible;
  }
  .notice-card{
    align-items:stretch;
  }
  .notice-card-actions{
    width:100%;
  }
  .notice-card-actions .btn,
  .notice-card-actions .btn.ghost{
    flex:1 1 140px;
  }
  .kpi-grid{grid-template-columns:repeat(2,1fr) !important}
  .charts-grid{grid-template-columns:1fr !important}
  .chart-wrap{height:240px}

  /* Game detail */
  .score-board{flex-direction:column !important;align-items:stretch !important}
  table{font-size:12px}
  th,td{padding:6px 4px !important}

  /* Admin */
  .admin-layout{grid-template-columns:1fr !important}
  .admin-sidebar{position:relative !important;top:0 !important;
    display:grid;grid-template-columns:repeat(4,minmax(142px,1fr));overflow-x:auto;gap:8px;padding:var(--s-3) !important}
  .admin-sidebar a{display:flex;align-items:center;justify-content:center;min-height:44px;white-space:nowrap;text-align:center}
  .points-admin-panel{padding:22px 16px}
  .points-tabs .tab{flex-basis:190px}
  .points-search-grid{grid-template-columns:1fr;gap:14px}
  .points-submit-row{
    grid-template-columns:1fr !important;
    max-width:none !important;
  }
  .points-att-controls{
    grid-template-columns:1fr !important;
    max-width:none;
  }
  .points-att-controls .field{grid-column:auto !important}
  .points-att-toolbar{align-items:stretch}
  .points-att-toolbar input{min-width:0 !important;width:100%}
  .points-att-roster{
    grid-template-columns:1fr !important;
    max-height:none !important;
  }
  .points-record-row,
  .points-overview-row{
    grid-template-columns:1fr;
    gap:8px;
    align-items:start;
  }
  .points-record-row .btn,
  .points-overview-row .btn{
    width:max-content;
  }

  /* HOF */
  .hof-grid{grid-template-columns:1fr}
  .hof-title{font-size:36px}

  /* Pool grid */
  .pool-grid{grid-template-columns:repeat(2,1fr) !important;gap:var(--s-3) !important}
  .pool-card{padding:var(--s-3) !important}
  .pool-card img{width:60px !important;height:60px !important}
  .player-admin-grid{grid-template-columns:1fr !important;gap:16px !important}
  .player-admin-card{padding:18px !important;min-height:0}
  .player-admin-card .photo{width:100% !important;height:100% !important}
  .pool-card-photo-wrap{width:108px;height:108px}
  .pool-card-actions{grid-template-columns:repeat(3,minmax(0,1fr))}

  /* Event detail modal — mobile column layout */
  .evt-modal .evt-body{flex-direction:column}
  .evt-gallery{max-width:100%;height:50vw;min-height:240px}
  .evt-content{padding:var(--s-4)}

  /* Tournament page — mobile */
  .tournament-hero{
    grid-template-columns:1fr !important;
    padding:var(--s-4);gap:var(--s-4);
  }
  .th-cover{max-height:200px}
  .th-title{font-size:22px !important}
  .th-desc{font-size:13px}
  .th-meta{flex-direction:column;gap:var(--s-2)}
  .tournament-stats-row{
    grid-template-columns:repeat(2,1fr);gap:var(--s-3);
  }
  .ts-card{padding:16px 12px}
  .ts-val{font-size:24px}
  .ts-label{font-size:9px;letter-spacing:.15em}

  /* Leaderboard table scroll */
  .game-log-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .leaderboard{min-width:600px}
}

@media (max-width: 480px) {
  .hero-name{font-size:36px}
  .stat-num{font-size:52px}
  .pool-grid{grid-template-columns:1fr !important}
  .nav-links{gap:var(--s-3)}
  .brand img{width:32px;height:32px}
  .tournament-stats-row{grid-template-columns:1fr 1fr}
  .ts-val{font-size:22px}
}

/* ========================================================
   Event Detail Modal — Xiaohongshu-style photo + text
   ======================================================== */
.evt-modal .modal{
  max-width:860px;
  padding:0 !important;
  overflow:hidden;
}
.evt-body{
  display:flex;
  min-height:460px;
}
.evt-gallery{
  flex:0 0 55%;
  position:relative;
  background:#0a0e1a;
  overflow:hidden;
}
.evt-gallery img{
  width:100%;height:100%;
  object-fit:cover;
  position:absolute;inset:0;
  opacity:0;transition:opacity .4s ease;
}
.evt-gallery img.active{opacity:1}
.evt-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:36px;height:36px;border-radius:50%;
  background:rgba(0,0,0,.45);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;cursor:pointer;z-index:2;
  backdrop-filter:blur(4px);transition:background .2s;
}
.evt-arrow:hover{background:rgba(0,0,0,.7)}
.evt-arrow.prev{left:12px}
.evt-arrow.next{right:12px}
.evt-dots{
  position:absolute;bottom:12px;left:50%;transform:translateX(-50%);
  display:flex;gap:6px;z-index:2;
}
.evt-dot{
  width:7px;height:7px;border-radius:50%;
  background:rgba(255,255,255,.4);cursor:pointer;
  transition:all .2s;
}
.evt-dot.active{background:#fff;transform:scale(1.3)}
.evt-content{
  flex:1;padding:var(--s-6);
  display:flex;flex-direction:column;
  overflow-y:auto;max-height:560px;
}
.evt-tag{
  display:inline-block;font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--blue-400);
  background:rgba(100,160,255,.1);padding:4px 10px;
  border-radius:20px;margin-bottom:var(--s-3);
  align-self:flex-start;
}
.evt-title{
  font-family:var(--font-display);font-size:22px;font-weight:600;
  margin-bottom:var(--s-4);line-height:1.3;
}
.evt-desc{
  color:var(--text-dim);font-size:14px;line-height:1.8;
  margin-bottom:var(--s-5);white-space:pre-line;
}
.evt-meta-list{
  margin-top:auto;padding-top:var(--s-4);
  border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:var(--s-2);
  font-size:13px;color:var(--text-mute);
}
