/* =========================================
   Juveon Stats — Design Tokens
   ========================================= */
:root{
  /* surfaces */
  --bg-0:#070A0F;
  --bg-1:#0B1017;
  --bg-2:#121823;
  --bg-3:#1A2230;
  --bg-4:#222C3D;

  /* ink */
  --ink-0:#F3F6FC;
  --ink-1:#C8D0DE;
  --ink-2:#8892A4;
  --ink-3:#5A6476;
  --ink-4:#3A4354;

  /* lines */
  --line-1:#1F2836;
  --line-2:#2A3547;

  /* brand / accents */
  --brand:        oklch(0.76 0.17 230);   /* electric blue */
  --brand-soft:   oklch(0.76 0.17 230 / .14);
  --brand-wash:   oklch(0.76 0.17 230 / .06);
  --violet:       oklch(0.70 0.19 295);
  --violet-soft:  oklch(0.70 0.19 295 / .16);

  --win:          oklch(0.78 0.17 150);   /* green */
  --win-soft:     oklch(0.78 0.17 150 / .16);
  --loss:         oklch(0.70 0.20 25);    /* red  */
  --loss-soft:    oklch(0.70 0.20 25 / .16);
  --draw:         oklch(0.82 0.15 85);    /* amber */
  --draw-soft:    oklch(0.82 0.15 85 / .16);

  /* typography */
  --font-display:"Space Grotesk", ui-sans-serif, system-ui, sans-serif;
  --font-body:"Geist", ui-sans-serif, system-ui, sans-serif;
  --font-mono:"JetBrains Mono", ui-monospace, monospace;

  --r-sm:8px; --r-md:12px; --r-lg:18px; --r-xl:24px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  background:var(--bg-0);
  color:var(--ink-0);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
  min-height:100vh;
}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
a{color:inherit;text-decoration:none}

/* ambient bg with subtle grid + glow */
body::before{
  content:"";
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(60% 40% at 70% 0%, oklch(0.76 0.17 230 / 0.10), transparent 60%),
    radial-gradient(40% 30% at 10% 20%, oklch(0.70 0.19 295 / 0.08), transparent 60%),
    linear-gradient(180deg, #070A0F 0%, #05080C 100%);
}
body::after{
  content:"";
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at 50% 0%, #000 20%, transparent 70%);
}
#root{position:relative;z-index:1}

/* ============ App layout ============ */
.app{
  max-width:1360px;
  margin:0 auto;
  padding:22px 32px 80px;
}

/* ============ Top nav ============ */
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 0 22px;
  border-bottom:1px solid var(--line-1);
  margin-bottom:28px;
}
.nav-left{display:flex;align-items:center;gap:14px}
.logo{
  width:40px;height:40px;border-radius:10px;
  background:linear-gradient(135deg, var(--brand), var(--violet));
  display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;color:#fff;
  box-shadow:0 0 0 1px rgba(255,255,255,.06), 0 8px 24px oklch(0.76 0.17 230 / .35);
}
.brand-name{font-family:var(--font-display);font-weight:700;letter-spacing:.02em;font-size:16px}
.brand-sub{color:var(--ink-2);font-size:12px;margin-top:2px}
.nav-links{display:flex;gap:4px;margin-left:28px}
.nav-link{
  padding:8px 14px;border-radius:999px;color:var(--ink-2);
  font-size:13.5px;font-weight:500;
  transition:.15s ease;
}
.nav-link:hover{color:var(--ink-0);background:var(--bg-2)}
.nav-link.active{color:var(--ink-0);background:var(--bg-2)}
.nav-right{display:flex;align-items:center;gap:10px}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px 7px 10px;border-radius:999px;
  background:var(--bg-2);border:1px solid var(--line-1);
  font-size:12.5px;color:var(--ink-1);
}
.pill-dot{width:8px;height:8px;border-radius:50%;background:var(--win);box-shadow:0 0 0 3px var(--win-soft)}

/* ============ Hero ============ */
.hero{
  position:relative;
  border-radius:var(--r-xl);
  padding:28px 32px;
  background:
    linear-gradient(180deg, rgba(18,24,35,0.85), rgba(11,16,23,0.85)),
    radial-gradient(80% 120% at 100% 0%, oklch(0.76 0.17 230 / .24), transparent 60%),
    radial-gradient(60% 120% at 0% 100%, oklch(0.70 0.19 295 / .16), transparent 60%);
  border:1px solid var(--line-1);
  overflow:hidden;
  margin-bottom:22px;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.02) 0 1px, transparent 1px 24px);
  pointer-events:none;
}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;position:relative}
.crest{
  width:92px;height:92px;
  border-radius:22px;
  background:
    linear-gradient(145deg, var(--brand), var(--violet) 70%, #3D2A7A);
  position:relative;
  display:grid;place-items:center;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.08),
    0 20px 60px -10px oklch(0.76 0.17 230 / .45),
    inset 0 1px 0 rgba(255,255,255,.15);
  flex:none;
}
.crest::after{
  content:"";position:absolute;inset:6px;border-radius:17px;
  border:1px dashed rgba(255,255,255,.22);
}
.crest span{font-family:var(--font-display);font-weight:700;font-size:40px;color:#fff;letter-spacing:-.04em}
.hero-title-block{display:flex;flex-direction:column;gap:14px;flex:1;min-width:0}
.hero-title-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.club-name{
  font-family:var(--font-display);
  font-size:64px;line-height:1;
  font-weight:700;letter-spacing:-.03em;
  margin:0;
  background:linear-gradient(180deg,#fff,#9AA6BA);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.club-tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px;border-radius:999px;
  background:var(--brand-soft);
  border:1px solid oklch(0.76 0.17 230 / .30);
  color:#A9D8FF;
  font-size:11.5px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
}
.hero-meta{display:flex;flex-wrap:wrap;gap:10px 22px;color:var(--ink-2);font-size:13px}
.hero-meta span{display:inline-flex;align-items:center;gap:6px}
.hero-meta b{color:var(--ink-0);font-weight:500}
.meta-dot{width:4px;height:4px;border-radius:50%;background:var(--ink-3)}

.hero-right{display:flex;flex-direction:column;gap:14px;align-items:flex-end;min-width:260px}
.form-label{
  font-size:10.5px;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;font-weight:600;
}
.form-row{display:flex;gap:6px}
.form-chip{
  width:36px;height:36px;border-radius:11px;
  display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;font-size:14px;
  border:1px solid transparent;
  position:relative;
  cursor:default;
}
.form-chip.W{background:var(--win-soft);color:var(--win);border-color:oklch(0.78 0.17 150 / .30)}
.form-chip.L{background:var(--loss-soft);color:var(--loss);border-color:oklch(0.70 0.20 25 / .30)}
.form-chip.D{background:var(--draw-soft);color:var(--draw);border-color:oklch(0.82 0.15 85 / .30)}
.form-chip:hover::after{
  content:attr(data-tip);
  position:absolute;top:-32px;left:50%;transform:translateX(-50%);
  white-space:nowrap;background:var(--bg-3);border:1px solid var(--line-2);
  padding:4px 8px;border-radius:6px;font-size:11px;color:var(--ink-0);
  font-family:var(--font-body);font-weight:500;
}

/* Hero stat strip under the title */
.hero-strip{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--line-1);
  border-radius:14px;overflow:hidden;margin-top:26px;
  border:1px solid var(--line-1);
  position:relative;
}
.strip-cell{
  background:linear-gradient(180deg, rgba(26,34,48,.8), rgba(18,24,35,.8));
  padding:14px 18px;
  display:flex;flex-direction:column;gap:6px;
}
.strip-cell .k{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);font-weight:600}
.strip-cell .v{font-family:var(--font-mono);font-weight:600;font-size:22px;color:var(--ink-0);letter-spacing:-.02em}
.strip-cell .s{font-size:11.5px;color:var(--ink-2)}

/* ============ KPI Grid ============ */
.kpi-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:14px;
  margin-bottom:22px;
}
.kpi-card{
  position:relative;
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--line-1);
  border-radius:var(--r-lg);
  padding:18px 18px 14px;
  overflow:hidden;
  transition:.2s ease;
}
.kpi-card:hover{transform:translateY(-2px);border-color:var(--line-2);box-shadow:0 12px 32px -12px rgba(0,0,0,.6)}
.kpi-card .accent{
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--bar-color, var(--brand)), transparent);
  opacity:.7;
}
.kpi-card .glow{
  position:absolute;inset:-40% -20% auto auto;width:160px;height:160px;border-radius:50%;
  background:var(--bar-color, var(--brand));opacity:.08;filter:blur(40px);
  pointer-events:none;
}
.kpi-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.kpi-label{
  font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-2);font-weight:600;
}
.kpi-delta{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 7px;border-radius:999px;font-size:11px;font-weight:600;
  font-family:var(--font-mono);
}
.kpi-delta.up{background:var(--win-soft);color:var(--win)}
.kpi-delta.down{background:var(--loss-soft);color:var(--loss)}
.kpi-value{
  font-family:var(--font-mono);
  font-size:38px;font-weight:700;letter-spacing:-.03em;
  color:var(--ink-0);line-height:1;margin:4px 0 2px;
}
.kpi-value .unit{font-size:16px;color:var(--ink-2);margin-left:4px;font-weight:500}
.kpi-sub{font-size:12px;color:var(--ink-2)}
.kpi-spark{height:40px;margin-top:10px}

/* wide KPI card */
.kpi-card.wide{grid-column:span 2}
.ratio-track{
  display:flex;height:10px;border-radius:999px;overflow:hidden;margin-top:12px;
  background:var(--bg-3);
}
.ratio-seg{height:100%;position:relative;transition:.3s}
.ratio-seg.w{background:linear-gradient(90deg, var(--win), oklch(0.78 0.17 150 / .7))}
.ratio-seg.d{background:linear-gradient(90deg, var(--draw), oklch(0.82 0.15 85 / .7))}
.ratio-seg.l{background:linear-gradient(90deg, var(--loss), oklch(0.70 0.20 25 / .7))}
.ratio-legend{display:flex;gap:18px;margin-top:10px;font-size:12px;color:var(--ink-1)}
.ratio-legend b{font-family:var(--font-mono);color:var(--ink-0);margin-right:4px}
.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}

/* ============ Main Grid ============ */
.main-grid{
  display:grid;
  grid-template-columns: 1fr 360px;
  gap:22px;
  align-items:start;
}

/* ============ Panel (generic card) ============ */
.panel{
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--line-1);
  border-radius:var(--r-lg);
  overflow:hidden;
}
.panel-head{
  padding:18px 22px 14px;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
  border-bottom:1px solid var(--line-1);
}
.panel-title{font-family:var(--font-display);font-size:17px;font-weight:600;letter-spacing:-.01em;margin:0}
.panel-sub{font-size:12px;color:var(--ink-2);margin-top:3px}
.panel-body{padding:18px 22px 22px}

/* segmented tabs */
.seg{
  display:inline-flex;padding:3px;border-radius:10px;
  background:var(--bg-3);border:1px solid var(--line-1);
  gap:2px;
}
.seg button{
  padding:6px 12px;border-radius:7px;font-size:12.5px;color:var(--ink-2);
  font-weight:500;transition:.15s ease;
}
.seg button:hover{color:var(--ink-0)}
.seg button.on{background:var(--bg-4);color:var(--ink-0);box-shadow:0 1px 0 rgba(255,255,255,.06) inset}

/* ============ Goals Chart ============ */
.chart-frame{position:relative;width:100%;height:260px}
.chart-legend{display:flex;gap:18px;margin-top:6px;font-size:12px;color:var(--ink-1)}
.chart-legend .sw{width:14px;height:4px;border-radius:2px;display:inline-block;margin-right:8px;vertical-align:middle}

/* ============ Bars (comparison) ============ */
.bars{display:flex;flex-direction:column;gap:14px;margin-top:4px}
.bar-row{display:grid;grid-template-columns:120px 1fr 52px;align-items:center;gap:14px}
.bar-row .lbl{font-size:13px;color:var(--ink-1)}
.bar-row .lbl .pos{color:var(--ink-3);font-size:11px;margin-left:6px}
.bar-track{height:12px;background:var(--bg-3);border-radius:999px;overflow:hidden;position:relative}
.bar-fill{height:100%;border-radius:999px;position:relative;transition:.6s cubic-bezier(.2,.9,.2,1)}
.bar-fill::after{
  content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  animation:shine 3s infinite;
}
@keyframes shine{0%,100%{transform:translateX(-100%)}50%{transform:translateX(100%)}}
.bar-val{font-family:var(--font-mono);font-size:13px;color:var(--ink-0);text-align:right;font-weight:600}

/* ============ Player Table ============ */
.filters{display:flex;gap:6px;flex-wrap:wrap}
.chip-filter{
  padding:6px 12px;border-radius:999px;
  background:var(--bg-3);border:1px solid var(--line-1);
  font-size:12px;color:var(--ink-2);font-weight:500;
  transition:.15s ease;
}
.chip-filter:hover{color:var(--ink-0);border-color:var(--line-2)}
.chip-filter.on{background:var(--brand-soft);color:#BCE0FF;border-color:oklch(0.76 0.17 230 / .30)}

.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:13.5px}
.tbl thead th{
  text-align:left;font-weight:600;
  font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-2);
  padding:12px 10px;border-bottom:1px solid var(--line-1);
  user-select:none;cursor:pointer;
  white-space:nowrap;
}
.tbl thead th.num{text-align:right}
.tbl thead th:hover{color:var(--ink-0)}
.tbl thead th .arrow{display:inline-block;margin-left:4px;opacity:.4;font-size:10px}
.tbl thead th.sorted .arrow{opacity:1;color:var(--brand)}
.tbl tbody td{
  padding:13px 10px;border-bottom:1px solid var(--line-1);
  color:var(--ink-1);
  font-variant-numeric:tabular-nums;
}
.tbl tbody tr{transition:.15s ease}
.tbl tbody tr:hover td{background:rgba(255,255,255,.015)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl td.num{text-align:right;font-family:var(--font-mono);color:var(--ink-0)}
.tbl td.player-cell{display:flex;align-items:center;gap:10px}
.avatar{
  width:30px;height:30px;border-radius:50%;
  background:linear-gradient(145deg, var(--bg-4), var(--bg-3));
  display:grid;place-items:center;font-size:11px;color:var(--ink-1);font-weight:600;
  border:1px solid var(--line-2);font-family:var(--font-mono);
  flex:none;
}
.player-name{color:var(--ink-0);font-weight:500}
.player-name .star{color:var(--draw);margin-left:4px;font-size:11px}
.pos-tag{
  font-family:var(--font-mono);font-size:10.5px;font-weight:700;
  padding:3px 7px;border-radius:6px;letter-spacing:.04em;
}
.pos-tag.KAL{background:var(--loss-soft);color:var(--loss)}
.pos-tag.DEF{background:var(--win-soft);color:var(--win)}
.pos-tag.ORT{background:var(--brand-soft);color:#8ECBFF}
.pos-tag.FOR{background:var(--violet-soft);color:#C8A7FF}
.rating{
  font-family:var(--font-mono);font-weight:700;font-size:12.5px;
  padding:3px 8px;border-radius:6px;display:inline-block;min-width:42px;text-align:center;
}
.rating.hi{background:var(--win-soft);color:var(--win)}
.rating.mid{background:var(--draw-soft);color:var(--draw)}
.rating.lo{background:var(--loss-soft);color:var(--loss)}
.pct-cell{display:flex;align-items:center;gap:8px;justify-content:flex-end}
.pct-mini{width:46px;height:4px;background:var(--bg-3);border-radius:999px;overflow:hidden}
.pct-mini i{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--violet));border-radius:999px}

/* ============ Matches list ============ */
.match-row{
  display:grid;grid-template-columns:36px 1fr auto;gap:12px;align-items:center;
  padding:14px 16px;
  border-radius:12px;
  transition:.15s ease;cursor:pointer;
  border:1px solid transparent;
}
.match-row + .match-row{margin-top:4px}
.match-row:hover{background:var(--bg-3);border-color:var(--line-2)}
.m-result{
  width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;font-size:14px;
}
.m-result.W{background:var(--win-soft);color:var(--win)}
.m-result.L{background:var(--loss-soft);color:var(--loss)}
.m-result.D{background:var(--draw-soft);color:var(--draw)}
.m-opp{font-size:13.5px;color:var(--ink-0);font-weight:500}
.m-meta{font-size:11.5px;color:var(--ink-2);margin-top:2px}
.m-score{font-family:var(--font-mono);font-size:16px;font-weight:700;color:var(--ink-0)}

/* ============ Radar ============ */
.radar-wrap{display:flex;align-items:center;gap:18px}
.radar-legend{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--ink-1);flex:1;min-width:0}
.radar-legend .row{display:flex;justify-content:space-between;gap:12px;padding:4px 0;border-bottom:1px dashed var(--line-1)}
.radar-legend .row:last-child{border-bottom:0}
.radar-legend .row b{font-family:var(--font-mono);color:var(--ink-0);font-weight:600}

/* ============ Top scorers sparks ============ */
.spark-item{
  display:grid;grid-template-columns:28px 1fr 50px;align-items:center;gap:12px;
  padding:10px 0;border-bottom:1px solid var(--line-1);
}
.spark-item:last-child{border-bottom:0}
.spark-rank{font-family:var(--font-mono);font-size:12px;color:var(--ink-3);font-weight:600}
.spark-name{font-size:13px;color:var(--ink-0)}
.spark-sub{font-size:11px;color:var(--ink-2);margin-top:2px}
.spark-val{font-family:var(--font-mono);font-size:15px;color:var(--ink-0);text-align:right;font-weight:700}

/* ============ Footer ============ */
.foot{
  margin-top:44px;padding-top:20px;border-top:1px solid var(--line-1);
  display:flex;justify-content:space-between;color:var(--ink-3);font-size:12px;
}

/* ============ Tweaks Panel ============ */
.tweaks{
  position:fixed;right:20px;bottom:20px;z-index:50;
  width:300px;background:linear-gradient(180deg, var(--bg-3), var(--bg-2));
  border:1px solid var(--line-2);
  border-radius:14px;padding:16px;
  box-shadow:0 24px 60px -10px rgba(0,0,0,.6);
  font-size:12.5px;
}
.tweaks h4{margin:0 0 12px;font-family:var(--font-display);font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-0)}
.tweak-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:10px}
.tweak-row label{color:var(--ink-2)}
.swatch-row{display:flex;gap:6px}
.swatch{width:22px;height:22px;border-radius:7px;cursor:pointer;border:2px solid transparent;transition:.15s}
.swatch.on{border-color:#fff}
.tweak-seg{display:inline-flex;background:var(--bg-1);border:1px solid var(--line-1);border-radius:8px;padding:2px}
.tweak-seg button{padding:4px 10px;border-radius:6px;font-size:11.5px;color:var(--ink-2)}
.tweak-seg button.on{background:var(--bg-4);color:var(--ink-0)}

/* condensed mode */
.app.dense .kpi-card{padding:14px}
.app.dense .panel-body{padding:14px 18px}
.app.dense .kpi-value{font-size:32px}

/* responsive */
@media (max-width:1100px){
  .main-grid{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .kpi-card.wide{grid-column:span 2}
  .club-name{font-size:44px}
  .crest{width:72px;height:72px}
  .crest span{font-size:32px}
}
@media (max-width:640px){
  .app{padding:18px}
  .hero{padding:20px}
  .hero-top{flex-direction:column}
  .hero-right{align-items:flex-start;min-width:0}
  .kpi-grid{grid-template-columns:1fr}
  .kpi-card.wide{grid-column:span 1}
  .hero-strip{grid-template-columns:repeat(2,1fr)}
  .nav-links{display:none}
  .club-name{font-size:36px}
}
