:root{
  --gold:#d6b23a;
  --board:#F3F0D7;
  --ink:#141414;
  --rail:#111;
  --card:#fffdf4;
  --accent:#d61f2a;
  --money:#1f7a3a;
  --blue:#0b3d91;
  --shadow: 0 10px 30px rgba(0,0,0,.12);
  --radius: 18px;
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family: 'Trebuchet MS', Verdana, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--ink);
  background:
    linear-gradient(90deg, rgba(0,0,0,.04) 1px, transparent 1px),
    linear-gradient(0deg, rgba(0,0,0,.04) 1px, transparent 1px),
    radial-gradient(circle at 12% 10%, rgba(31,122,58,.10), transparent 38%),
    radial-gradient(circle at 88% 18%, rgba(216,59,59,.08), transparent 42%),
    var(--board);
  background-size: 44px 44px, 44px 44px, auto, auto, auto;
}
.wrap{max-width:1120px;margin:26px auto;padding:0 18px}
.authwrap{max-width:560px;margin:44px auto;padding:0 18px}
.card{
  background:var(--card);
  border:3px solid var(--rail);
  border-radius:var(--radius);
  box-shadow: var(--shadow);
  padding:16px;
}
.grid{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width: 980px){ .grid{grid-template-columns:1.1fr .9fr;} }
.topbar{
  display:flex;align-items:center;justify-content:flex-start;gap:14px;
  margin-bottom:18px;
}
.brand{display:flex;align-items:center;gap:12px}
.logo{
  width:44px;height:44px;border-radius:12px;
  background: linear-gradient(135deg, #f8f2d2, #e7d89a);
  border: 3px solid var(--rail);
  box-shadow: var(--shadow);
}
.title{font-weight:900;font-size:20px;letter-spacing:.3px}
.subtitle{color:rgba(0,0,0,.55);font-size:13px}
.nav{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-start;align-items:center}
.navlink{
  text-decoration:none;
  border:2px solid var(--rail);
  border-bottom-width:4px;
  border-radius:14px;
  padding:8px 12px;
  background:#fff;
}
.navlink.active{background:rgba(47,85,151,.12)}
h1,h2{margin:0 0 10px}
.muted{color:rgba(0,0,0,.55)}
.small{font-size:13px}
.btn{
  display:inline-block;
  border:2px solid var(--rail);
  border-bottom-width:4px;
  border-radius:14px;
  padding:8px 12px;
  background:#fff;
  text-decoration:none;
  cursor:pointer;
}
.btn.primary{background:rgba(31,122,58,.14)}
.btn.danger{background:rgba(216,59,59,.12)}
.input{width:100%;padding:10px;border:2px solid var(--rail);border-radius:12px;background:#fff}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.row > *{flex:1}
table{border-collapse:collapse;width:100%;margin-top:10px}
th,td{border:2px solid var(--rail);padding:10px}
th{background:rgba(47,85,151,.10);text-align:left}
.right{text-align:right}
tr:nth-child(even) td{background:rgba(0,0,0,.03)}
.badge{
  display:inline-block;padding:3px 10px;border-radius:999px;
  border:2px solid var(--rail); background:#fff; font-size:12px;
}
.badge.red{background:rgba(216,59,59,.12)}
.badge.green{background:rgba(31,122,58,.12)}
hr.sep{border:0;border-top:2px dashed rgba(0,0,0,.25);margin:14px 0}

.logo{position:relative}
.logo:after{content:'';position:absolute;inset:10px;border-radius:10px;border:2px solid rgba(0,0,0,.35)}

/* --- v3.1 UI upgrades --- */
.hero{display:flex;gap:14px;align-items:center;margin:4px 0 16px}
.hero-board{
  width:86px;height:86px;border-radius:18px;
  background:
    linear-gradient(90deg, rgba(0,0,0,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(0,0,0,.08) 1px, transparent 1px),
    linear-gradient(135deg, rgba(31,122,58,.18), rgba(216,59,59,.12)),
    #fff;
  background-size: 18px 18px, 18px 18px, auto, auto;
  border:3px solid var(--rail);
  box-shadow: var(--shadow);
}
.hero-title{font-size:28px;font-weight:900;letter-spacing:.3px}
.hero-sub{color:rgba(0,0,0,.55);font-size:14px}
.podium{margin:10px 0 12px}
.podium-grid{display:grid;grid-template-columns:1fr;gap:10px}
@media (min-width: 860px){ .podium-grid{grid-template-columns:repeat(3,1fr);} }
.podium-card{
  background:#fff;border:2px solid var(--rail);border-bottom-width:4px;
  border-radius:18px;padding:12px;box-shadow:0 10px 20px rgba(0,0,0,.08);
}
.podium-medal{font-size:22px}
.podium-name{font-weight:900;font-size:18px;margin-top:4px}
.podium-meta{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}
.pill{
  display:inline-block;padding:4px 10px;border-radius:999px;
  border:2px solid var(--rail);background:#fff;font-size:12px;
}
.charts{display:grid;grid-template-columns:1fr;gap:12px;margin-top:10px;align-items:start}
@media (min-width: 980px){ .charts{grid-template-columns: 1fr 1fr;} .chartcard.span2{grid-column: 1 / -1;} }
.chartcard{
  background:#fff;border:2px solid var(--rail);border-bottom-width:4px;
  border-radius:18px;padding:10px;
}
.charttitle{
  font-weight:900;font-size:14px;letter-spacing:.2px;
  padding:4px 4px 8px;
}
.chartbox{padding:2px 0 0}
.section{margin-top:14px}
.section-head{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.tablewrap{overflow:auto}
@media (max-width: 520px){
  .wrap{padding:0 12px}
  .topbar{flex-direction:column;align-items:flex-start}
  .nav{justify-content:flex-start}
  .hero{flex-direction:column;align-items:flex-start}
  .hero-title{font-size:24px}
  th,td{padding:8px}
  .navlink{padding:7px 10px}
}

/* --- standings mobile --- */
.standings-cards{display:grid;grid-template-columns:1fr;gap:10px;margin-top:10px}
.standcard{
  background:#fff;border:2px solid var(--rail);border-bottom-width:4px;
  border-radius:18px;padding:12px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.stand-left{display:flex;align-items:center;gap:10px}
.rank{
  width:36px;height:36px;border-radius:12px;
  border:2px solid var(--rail);display:flex;align-items:center;justify-content:center;
  font-weight:900;background:rgba(47,85,151,.10);
}
.stand-name{font-weight:900}
.stand-metrics{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.metric{border:2px solid var(--rail);border-radius:999px;padding:4px 10px;background:#fff;font-size:12px}
.money-icon{font-size:18px}
.rich-card{
  background:rgba(31,122,58,.10);
  border:2px solid var(--rail);border-bottom-width:4px;border-radius:18px;
  padding:12px;margin-top:10px;
  display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;
}
.rulebar{margin:10px 0 0;display:flex;gap:8px;flex-wrap:wrap}
.rulepill{display:inline-block;padding:6px 10px;border-radius:999px;border:2px solid var(--rail);background:#fff;font-size:12px}
.tablewrap{overflow:auto}
/* ranklogo will be added later */

.ranklogo:after{
  content:'';
  position:absolute; inset:10px;
  background: rgba(0,0,0,.80);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'><path d='M14 12h20a6 6 0 0 1 6 6v20a6 6 0 0 1-6 6H14a6 6 0 0 1-6-6V18a6 6 0 0 1 6-6zm6 8a3 3 0 1 0 0 6 3 3 0 0 0 0-6zm16 0a3 3 0 1 0 0 6 3 3 0 0 0 0-6zm-16 16a3 3 0 1 0 0 6 3 3 0 0 0 0-6zm16 16a3 3 0 1 0 0 6 3 3 0 0 0 0-6z'/><path d='M44 22h10a4 4 0 0 1 4 4v18a8 8 0 0 1-8 8H36a10 10 0 0 0 8-10V22z'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'><path d='M14 12h20a6 6 0 0 1 6 6v20a6 6 0 0 1-6 6H14a6 6 0 0 1-6-6V18a6 6 0 0 1 6-6zm6 8a3 3 0 1 0 0 6 3 3 0 0 0 0-6zm16 0a3 3 0 1 0 0 6 3 3 0 0 0 0-6zm-16 16a3 3 0 1 0 0 6 3 3 0 0 0 0-6zm16 16a3 3 0 1 0 0 6 3 3 0 0 0 0-6z'/><path d='M44 22h10a4 4 0 0 1 4 4v18a8 8 0 0 1-8 8H36a10 10 0 0 0 8-10V22z'/></svg>") center/contain no-repeat;
  opacity:.95;
}

.chartcard{min-height: unset}

/* --- v3.5 page frame (like overview) --- */
.pageframe{
  background:var(--card);
  border:3px solid var(--rail);
  border-radius:22px;
  box-shadow: var(--shadow);
  padding:16px;
}
