/* =====================================================================
   CLASH+  ·  clashplus.eu  ·  redesign v2
   Tmavý, ostrý, výrazný design pro Clash MMA
   ===================================================================== */

:root{
  --bg:#09090a;
  --bg-2:#0e0e10;
  --card:#141416;
  --card-2:#1a1a1e;
  --card-3:#222227;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.15);
  --text:#f4f4f5;
  --muted:#a1a1aa;
  --dim:#71717a;
  --accent:#ff2d3f;
  --accent-2:#ff5460;
  --accent-ink:#ff7079;
  --gold:#f5c451;
  --gold-ink:#1c1606;
  --win:#27d796;
  --loss:#ff5d6c;
  --r:8px;
  --r-sm:5px;
  --maxw:1200px;
  --header-h:66px;
  --shadow:0 18px 50px rgba(0,0,0,.5);
  --shadow-sm:0 8px 24px rgba(0,0,0,.4);
  --fd:"Archivo",system-ui,sans-serif;       /* display */
  --fb:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--fb);background:var(--bg);color:var(--text);
  line-height:1.6;-webkit-font-smoothing:antialiased;
  background-image:linear-gradient(180deg,#0d0d0f,var(--bg) 420px);
  background-repeat:no-repeat;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0 0 .5em;line-height:1.05}
p{margin:0 0 1em}
::selection{background:var(--accent);color:#fff}

/* horní akcentový proužek */
body::before{content:"";position:fixed;top:0;left:0;right:0;height:3px;z-index:200;
  background:linear-gradient(90deg,var(--accent),var(--accent-2) 40%,var(--gold))}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:56px 0}
.section-sm{padding:34px 0}
.skip-link{position:absolute;left:-999px;top:0;background:var(--accent);color:#fff;padding:10px 16px;z-index:300}
.skip-link:focus{left:8px;top:8px}

/* ---------- typografické prvky ---------- */
.kicker,.section-kicker{display:inline-block;font-family:var(--fd);font-weight:700;
  text-transform:uppercase;letter-spacing:.22em;font-size:.74rem;color:var(--accent)}
.section-title{font-family:var(--fd);font-weight:900;text-transform:uppercase;
  letter-spacing:-.01em;font-size:clamp(1.5rem,3.6vw,2.4rem);margin:.15em 0 0}
.section-title .ac{color:var(--accent)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:26px}
.link-more{font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  font-size:.82rem;color:var(--muted);border-bottom:2px solid transparent;padding-bottom:2px}
.link-more:hover{color:#fff;border-color:var(--accent)}

/* ---------- tlačítka ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--fd);font-weight:800;
  font-size:.92rem;letter-spacing:.04em;text-transform:uppercase;padding:12px 22px;border-radius:var(--r-sm);
  background:var(--accent);color:#fff;border:0;cursor:pointer;transition:transform .12s,filter .15s,background .15s}
.btn:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-ghost{background:transparent;border:1px solid var(--line-2);color:var(--text)}
.btn-ghost:hover{border-color:var(--accent);color:#fff;background:rgba(255,45,63,.08)}
.btn-gold{background:var(--gold);color:var(--gold-ink)}
.btn-sm{padding:9px 15px;font-size:.8rem}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(9,9,10,.78);
  backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:22px;height:var(--header-h)}
.brand{flex:0 0 auto}
.brand-mark{font-family:var(--fd);font-weight:900;font-size:1.7rem;letter-spacing:-.02em;
  text-transform:uppercase;color:#fff;line-height:1;display:inline-block}
.brand-plus{color:var(--accent)}
.main-nav{display:flex;align-items:center;gap:4px;margin-left:auto}
.main-nav a{font-family:var(--fd);font-weight:700;font-size:.95rem;letter-spacing:.04em;
  text-transform:uppercase;color:var(--muted);padding:9px 13px;border-radius:var(--r-sm);transition:.15s}
.main-nav a:hover{color:#fff;background:var(--card-2)}
.main-nav a.is-active{color:#fff;background:var(--card-2)}
.main-nav a.is-active::after{content:"";display:block;height:2px;background:var(--accent);margin-top:4px}
.nav-search{margin-left:8px}
.nav-search input{background:var(--card-2);border:1px solid var(--line);color:var(--text);
  padding:9px 14px;border-radius:999px;font-size:.88rem;width:180px;outline:none;transition:.2s}
.nav-search input:focus{border-color:var(--accent);width:210px}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.nav-toggle span{width:26px;height:3px;background:#fff;border-radius:2px;transition:.2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- HERO (home) ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center top;opacity:.18}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(9,9,10,.4),var(--bg) 94%),linear-gradient(90deg,var(--bg) 10%,transparent 60%)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.25fr .85fr;gap:42px;align-items:center;padding:62px 0 56px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:9px;background:var(--accent);color:#fff;
  font-family:var(--fd);font-weight:800;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;
  padding:6px 13px;border-radius:999px;margin-bottom:18px}
.hero-eyebrow.past{background:var(--card-3);color:var(--muted)}
.hero-title{font-family:var(--fd);font-weight:900;text-transform:uppercase;letter-spacing:-.02em;
  font-size:clamp(2.4rem,6.2vw,4.6rem);margin:0 0 14px}
.hero-meta{color:var(--muted);font-size:1.08rem;margin-bottom:26px}
.hero-meta b{color:var(--text);font-weight:600}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-media{position:relative}
.poster-card{display:block;background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow);transition:transform .18s,border-color .18s}
.poster-card:hover{transform:translateY(-4px);border-color:var(--accent)}
.poster-card img{width:100%;aspect-ratio:1/1;object-fit:cover}
.poster-card .pc-body{padding:14px 16px}
.poster-card .pc-label{font-family:var(--fd);font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-size:.74rem}
.poster-card .pc-title{font-family:var(--fd);font-weight:800;font-size:1.3rem;margin:.2em 0 .1em;text-transform:uppercase}
.poster-card .pc-meta{color:var(--muted);font-size:.9rem}

/* ---------- statistiky ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px 18px;text-align:center;
  position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}
.stat .n{font-family:var(--fd);font-weight:900;font-size:2.3rem;line-height:1}
.stat .n .ac{color:var(--accent)}
.stat .l{font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:.78rem;margin-top:8px}
a.stat{transition:border-color .15s,transform .15s}
a.stat:hover{border-color:var(--accent);transform:translateY(-3px)}

/* ---------- mřížky ---------- */
.grid{display:grid;gap:18px}
.grid-events{grid-template-columns:repeat(auto-fill,minmax(255px,1fr))}
.grid-fighters{grid-template-columns:repeat(auto-fill,minmax(185px,1fr))}

/* ---------- karta eventu ---------- */
.event-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .15s,border-color .15s}
.event-card:hover{transform:translateY(-4px);border-color:var(--accent)}
.event-card .poster-wrap{position:relative;aspect-ratio:1/1;background:var(--card-2)}
.event-card .poster-wrap img{width:100%;height:100%;object-fit:cover}
.badge-date{position:absolute;left:11px;top:11px;background:rgba(9,9,10,.85);border:1px solid var(--line-2);
  border-radius:6px;padding:5px 9px;text-align:center;line-height:1;backdrop-filter:blur(4px)}
.badge-date .d{font-family:var(--fd);font-weight:900;font-size:1.2rem;display:block}
.badge-date .m{font-family:var(--fd);font-weight:700;text-transform:uppercase;font-size:.66rem;letter-spacing:.1em;color:var(--muted)}
.pill{position:absolute;right:11px;top:11px;font-family:var(--fd);font-weight:800;text-transform:uppercase;
  letter-spacing:.07em;font-size:.68rem;padding:5px 10px;border-radius:999px}
.pill-upcoming{background:var(--accent);color:#fff}
.pill-past{background:rgba(9,9,10,.8);color:var(--muted);border:1px solid var(--line-2)}
.event-card .ec-body{padding:14px 16px 18px}
.event-card h3{font-family:var(--fd);font-weight:800;font-size:1.22rem;text-transform:uppercase;letter-spacing:-.01em;margin:0 0 .35em}
.event-card .ec-meta{color:var(--muted);font-size:.86rem;display:flex;flex-direction:column;gap:3px}

/* ---------- karta zápasníka ---------- */
.fighter-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;transition:transform .15s,border-color .15s}
.fighter-card:hover{transform:translateY(-4px);border-color:var(--accent)}
.fighter-card .fc-img{position:relative;aspect-ratio:4/5;background:var(--card-2) center/cover}
.fighter-card .fc-img img{width:100%;height:100%;object-fit:cover}
.fighter-card .fc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 42%,rgba(9,9,10,.94))}
.fighter-card .fc-info{position:absolute;left:0;right:0;bottom:0;padding:12px 14px}
.fighter-card .fc-nick{font-family:var(--fd);font-weight:700;color:var(--accent-ink);font-size:.76rem;text-transform:uppercase;letter-spacing:.06em}
.fighter-card .fc-name{font-family:var(--fd);font-weight:800;font-size:1.14rem;line-height:1.04;text-transform:uppercase;margin-top:2px}
.fighter-card .fc-rec{display:inline-flex;align-items:center;gap:6px;margin-top:8px;font-size:.78rem;color:#d6d6da;
  background:rgba(0,0,0,.45);border:1px solid var(--line-2);padding:3px 9px;border-radius:999px}
.fighter-card .fc-rec b{color:var(--win);font-weight:700}
.crown{position:absolute;left:10px;top:10px;background:var(--gold);color:var(--gold-ink);width:30px;height:30px;
  border-radius:6px;display:grid;place-items:center;font-size:.95rem;z-index:2;box-shadow:var(--shadow-sm)}
.deceased{position:absolute;right:10px;top:10px;background:rgba(0,0,0,.65);border:1px solid var(--line-2);
  padding:3px 8px;border-radius:999px;font-size:.68rem;color:var(--muted);z-index:2}

/* ---------- page head (podstránky) ---------- */
.page-head{border-bottom:1px solid var(--line);background:
  radial-gradient(80% 140% at 0% 0%,rgba(255,45,63,.10),transparent 60%),var(--bg-2);padding:40px 0 34px}
.page-head h1{font-family:var(--fd);font-weight:900;text-transform:uppercase;letter-spacing:-.02em;
  font-size:clamp(2rem,5.4vw,3.4rem);margin:0}
.page-head p{color:var(--muted);margin:.5em 0 0;max-width:64ch;font-size:1.02rem}
.breadcrumb{font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  font-size:.78rem;color:var(--dim);margin-bottom:14px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb i{color:var(--dim);font-style:normal}
.breadcrumb [aria-current]{color:var(--text)}

/* ---------- toolbar / filtry ---------- */
.toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:26px}
.toolbar input[type=search],.toolbar select{background:var(--card-2);border:1px solid var(--line-2);color:var(--text);
  padding:11px 14px;border-radius:var(--r-sm);font-size:.95rem;outline:none}
.toolbar input[type=search]{min-width:230px;flex:1}
.toolbar input:focus,.toolbar select:focus{border-color:var(--accent)}
.count-note{margin-left:auto;color:var(--dim);font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.8rem}

/* ---------- event detail ---------- */
.event-layout{display:grid;grid-template-columns:330px 1fr;gap:36px;align-items:start}
.event-poster{border-radius:var(--r);overflow:hidden;border:1px solid var(--line-2)}
.event-poster img{width:100%;aspect-ratio:1/1;object-fit:cover}
.event-aside{position:sticky;top:calc(var(--header-h) + 16px)}
.fact-list{list-style:none;margin:16px 0 0;padding:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.fact-list li{display:flex;justify-content:space-between;gap:12px;padding:11px 15px;background:var(--card);border-top:1px solid var(--line)}
.fact-list li:first-child{border-top:0}
.fact-list .k{color:var(--muted);font-size:.88rem}
.fact-list .v{font-weight:600;text-align:right}
.event-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.rich{color:#d9d9de;font-size:1.04rem}
.rich p{margin:0 0 1em}
.rich h2{font-family:var(--fd);font-weight:800;text-transform:uppercase;font-size:1.4rem;margin:1.3em 0 .5em}
.rich h3{font-family:var(--fd);font-weight:800;font-size:1.18rem;margin:1.1em 0 .4em}
.rich a{color:var(--accent-ink);text-decoration:underline;text-underline-offset:3px}
.rich ul,.rich ol{margin:0 0 1em;padding-left:1.3em}
.rich blockquote{border-left:3px solid var(--accent);margin:1.2em 0;padding:.3em 0 .3em 16px;color:var(--muted)}

/* ---------- fight card ---------- */
.fightcard{display:flex;flex-direction:column;gap:12px}
.fight-row{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:15px 16px;transition:border-color .15s}
.fight-row:hover{border-color:var(--line-2)}
.fight-row.is-main{border-color:var(--accent);box-shadow:0 0 0 1px rgba(255,45,63,.28)}
.fight-row.is-title{background:linear-gradient(180deg,rgba(245,196,81,.07),var(--card))}
.fight-head{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.tag{font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;
  padding:4px 9px;border-radius:5px;background:var(--card-3);color:var(--muted)}
.tag-main{background:var(--accent);color:#fff}
.tag-title{background:var(--gold);color:var(--gold-ink)}
.tag-canc{background:#3a1c20;color:var(--loss)}
.fight-grid{display:grid;grid-template-columns:1fr 58px 1fr;align-items:center;gap:10px}
.fc-side{display:flex;align-items:center;gap:12px;min-width:0}
.fc-side.right{flex-direction:row-reverse;text-align:right}
.fc-side .ava{width:56px;height:56px;border-radius:8px;object-fit:cover;background:var(--card-2);flex:0 0 auto}
.fc-side .who{min-width:0}
.fc-side .who .nm{font-family:var(--fd);font-weight:800;font-size:1.08rem;line-height:1.06;text-transform:uppercase;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fc-side .who .nm a:hover{color:var(--accent)}
.fc-side .who .sub{color:var(--muted);font-size:.8rem;font-variant-numeric:tabular-nums}
.fc-mid{display:flex;flex-direction:column;align-items:center;gap:3px}
.fc-mid .vs{font-family:var(--fd);font-weight:900;color:var(--dim);font-size:1rem}
.wl{width:26px;height:26px;border-radius:6px;display:grid;place-items:center;font-family:var(--fd);font-weight:800;font-size:.82rem;flex:0 0 auto}
.wl-win{background:var(--win);color:#04130c}
.wl-loss{background:var(--card-3);color:var(--muted)}
.wl-draw{background:var(--gold);color:var(--gold-ink)}
.fight-foot{margin-top:12px;padding-top:10px;border-top:1px solid var(--line);display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:.85rem}
.fight-foot b{color:var(--text);font-weight:600}
.team-fight .members{display:flex;flex-wrap:wrap;gap:5px 10px;margin-top:5px}
.team-fight .members a{font-size:.86rem;color:var(--muted)}
.team-fight .members a:hover{color:var(--accent)}

/* historie zápasů – nadpis eventu */
.fh-event{margin:8px 0 -4px;font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}
.fh-event a{color:var(--muted)}
.fh-event a:hover{color:var(--accent)}

/* ---------- sub-events ---------- */
.subevents{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px}
.sub-item{background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);padding:12px 14px}
.sub-item .t{font-weight:600;font-size:.94rem}
.sub-item .t a{color:var(--accent-ink)}
.sub-item .d{color:var(--muted);font-size:.8rem;margin-top:3px}

/* ---------- fighter profile ---------- */
.profile{display:grid;grid-template-columns:330px 1fr;gap:36px;align-items:start}
.profile-aside{position:sticky;top:calc(var(--header-h) + 16px)}
.profile-photo{border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;background:var(--card-2) center/cover;aspect-ratio:4/5}
.profile-photo img{width:100%;height:100%;object-fit:cover}
.belt{display:flex;align-items:center;gap:8px;margin-top:14px;background:linear-gradient(90deg,rgba(245,196,81,.16),transparent);
  border:1px solid rgba(245,196,81,.4);border-radius:var(--r-sm);padding:10px 13px;color:var(--gold);font-weight:600;font-size:.9rem}
.record-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px}
.record-cards .rc{background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);padding:12px 6px;text-align:center}
.record-cards .rc .n{font-family:var(--fd);font-weight:900;font-size:1.8rem;line-height:1}
.record-cards .rc .l{font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-size:.7rem;margin-top:4px}
.record-cards .win .n{color:var(--win)}
.record-cards .loss .n{color:var(--loss)}
.record-cards .draw .n{color:var(--gold)}
.stat-rows{list-style:none;margin:16px 0 0;padding:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.stat-rows li{display:flex;justify-content:space-between;padding:10px 15px;background:var(--card);border-top:1px solid var(--line);font-size:.92rem}
.stat-rows li:first-child{border-top:0}
.stat-rows .k{color:var(--muted)}
.socials{display:flex;gap:8px;margin-top:14px}
.socials a{flex:1;text-align:center;background:var(--card-2);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:10px;font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.82rem}
.socials a:hover{border-color:var(--accent);color:#fff}
.profile-name{font-family:var(--fd);font-weight:900;text-transform:uppercase;letter-spacing:-.02em;
  font-size:clamp(1.9rem,4.6vw,3rem);margin:.1em 0 .1em}
.profile-nick{font-family:var(--fd);font-weight:700;color:var(--accent-ink);text-transform:uppercase;letter-spacing:.05em;font-size:1rem}
.bio p{white-space:pre-line}

/* ---------- žebříčky ---------- */
.div-nav{position:sticky;top:calc(var(--header-h));z-index:40;display:flex;gap:8px;flex-wrap:wrap;
  padding:14px 0;background:rgba(9,9,10,.9);backdrop-filter:blur(8px);margin-bottom:8px;border-bottom:1px solid var(--line)}
.div-nav a{font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;
  padding:8px 14px;border-radius:999px;background:var(--card-2);border:1px solid var(--line-2);color:var(--muted)}
.div-nav a:hover{color:#fff;border-color:var(--accent)}
.division{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:26px;scroll-margin-top:130px}
.division-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:18px 20px;
  border-bottom:1px solid var(--line);background:linear-gradient(90deg,rgba(255,45,63,.08),transparent)}
.division-head h2{font-family:var(--fd);font-weight:900;text-transform:uppercase;font-size:1.4rem;margin:0}
.division-head .meta{color:var(--dim);font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.07em;font-size:.76rem}
.champ-row{display:flex;align-items:center;gap:16px;padding:18px 20px;
  background:linear-gradient(90deg,rgba(245,196,81,.12),transparent)}
.champ-row .belt-tag{font-family:var(--fd);font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);font-size:.78rem}
.champ-row .photo{width:74px;height:74px;border-radius:8px;object-fit:cover;background:var(--card-2);border:2px solid var(--gold);flex:0 0 auto}
.champ-row .nm{font-family:var(--fd);font-weight:900;text-transform:uppercase;font-size:1.5rem;line-height:1}
.champ-row .nm a:hover{color:var(--accent)}
.champ-row .rec{color:var(--muted);font-size:.9rem;margin-top:3px}
.champ-row .rec b{color:var(--win)}
.rank-list{list-style:none;margin:0;padding:0}
.rank-row{display:flex;align-items:center;gap:14px;padding:12px 20px;border-top:1px solid var(--line)}
.rank-pos{font-family:var(--fd);font-weight:900;width:34px;text-align:center;color:var(--dim);font-size:1.15rem;flex:0 0 auto}
.rank-ava{width:46px;height:46px;border-radius:7px;object-fit:cover;background:var(--card-2);flex:0 0 auto}
.rank-name{font-family:var(--fd);font-weight:800;font-size:1.08rem;text-transform:uppercase;line-height:1.05}
.rank-name a:hover{color:var(--accent)}
.rank-name .sub{display:block;font-family:var(--fb);font-weight:400;text-transform:none;color:var(--muted);font-size:.82rem;margin-top:1px}
.rank-rec{margin-left:auto;color:var(--muted);font-size:.88rem;font-variant-numeric:tabular-nums;text-align:right}
.rank-rec b{color:var(--win);font-weight:700}

/* ---------- rekordy ---------- */
.leaderboards{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:16px;margin-bottom:40px}
.leader{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column}
.leader-head{padding:13px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px;
  font-family:var(--fd);font-weight:800;text-transform:uppercase;letter-spacing:.05em;font-size:.84rem}
.leader-head .ic{color:var(--accent)}
.leader-top{display:flex;align-items:center;gap:14px;padding:16px}
.leader-top .photo{width:64px;height:64px;border-radius:8px;object-fit:cover;background:var(--card-2);flex:0 0 auto}
.leader-top .who .nm{font-family:var(--fd);font-weight:800;text-transform:uppercase;font-size:1.18rem;line-height:1.05}
.leader-top .who .nm a:hover{color:var(--accent)}
.leader-top .big{margin-left:auto;font-family:var(--fd);font-weight:900;font-size:2.2rem;color:var(--accent);line-height:1}
.leader-list{list-style:none;margin:0;padding:0 16px 14px}
.leader-list li{display:flex;align-items:center;gap:10px;padding:8px 0;border-top:1px solid var(--line);font-size:.92rem}
.leader-list .p{font-family:var(--fd);font-weight:800;color:var(--dim);width:20px}
.leader-list .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.leader-list .nm a:hover{color:var(--accent)}
.leader-list .v{margin-left:auto;font-variant-numeric:tabular-nums;font-weight:700}

.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r);background:var(--card)}
table.records{width:100%;border-collapse:collapse;min-width:680px}
table.records th,table.records td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
table.records thead th{font-family:var(--fd);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;
  color:var(--muted);cursor:pointer;user-select:none;position:sticky;top:0;background:var(--card-2)}
table.records th[data-sort]:hover{color:#fff}
table.records th.sort-asc::after{content:" ▲";color:var(--accent)}
table.records th.sort-desc::after{content:" ▼";color:var(--accent)}
table.records tbody tr:hover{background:var(--card-2)}
table.records td.rank{font-family:var(--fd);font-weight:800;color:var(--dim);width:46px}
table.records .name-cell{display:flex;align-items:center;gap:10px}
table.records .name-cell img{width:36px;height:36px;border-radius:7px;object-fit:cover;background:var(--card-2)}
table.records .name-cell a{font-weight:600}
table.records .name-cell a:hover{color:var(--accent)}
table.records .num{font-variant-numeric:tabular-nums;text-align:center}
.w-pos{color:var(--win);font-weight:700}
.l-pos{color:var(--loss);font-weight:700}
.bar{height:7px;border-radius:4px;background:var(--card-3);overflow:hidden;min-width:90px}
.bar>i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2))}

/* ---------- empty ---------- */
.empty-state{text-align:center;padding:64px 20px;color:var(--muted)}
.empty-state h1{font-family:var(--fd);font-weight:900;font-size:3.2rem;color:#fff}
.note{color:var(--dim);font-size:.82rem;text-align:center;margin-top:30px}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--line);background:var(--bg-2);margin-top:50px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.6fr;gap:30px;padding:46px 22px 30px}
.footer-brand .brand-mark{font-size:1.5rem}
.footer-brand p{color:var(--muted);margin:10px 0 0;font-size:.9rem}
.footer-brand .footer-disclaimer{color:var(--dim);font-size:.82rem}
.footer-col h4{font-family:var(--fd);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.86rem;color:var(--muted);margin-bottom:12px}
.footer-col a{display:block;color:var(--text);padding:4px 0;font-size:.93rem}
.footer-col a:hover{color:var(--accent)}
.footer-col p{color:var(--muted);font-size:.85rem}
.footer-col p a{color:var(--accent-ink)}
.footer-bottom{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding:16px 22px;color:var(--dim);font-size:.84rem}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:26px}
  .hero-media{max-width:360px}
  .event-layout{grid-template-columns:1fr}
  .event-aside{position:static}
  .profile{grid-template-columns:1fr}
  .profile-aside{position:static;max-width:360px}
  .stats{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .nav-toggle{display:flex}
  .main-nav{position:fixed;inset:var(--header-h) 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--bg-2);border-bottom:1px solid var(--line-2);padding:8px 18px 16px;margin:0;
    transform:translateY(-130%);transition:transform .25s ease;box-shadow:var(--shadow)}
  .main-nav.open{transform:translateY(0)}
  .main-nav a{padding:13px 6px;font-size:1.1rem;border-bottom:1px solid var(--line)}
  .nav-search{margin:12px 0 0}
  .nav-search input{width:100%}
  .footer-grid{grid-template-columns:1fr 1fr}
  .fc-side .ava{width:46px;height:46px}
  .fc-side .who .nm{font-size:.98rem}
}
@media (max-width:520px){
  .footer-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .fight-grid{grid-template-columns:1fr 38px 1fr}
  .champ-row{flex-wrap:wrap}
}
