/* =========================================================================
   VIRTUS — Fight Promotion Theme
   Identity: stark monochrome. White-on-black, hairline geometry, angular
   tech type echoing the helmet wordmark. Red is the only colour, used as a
   single accent (live / primary / urgency). No gold, no laurels.
   ========================================================================= */

:root{
  --ink:#08080A;      /* page base            */
  --ink-2:#0E0E11;    /* alternating section  */
  --panel:#131317;    /* cards                */
  --panel-2:#1A1A20;  /* raised card / hover  */
  --line:#23232A;     /* hairline             */
  --line-2:#34343E;   /* stronger border      */

  --white:#FFFFFF;
  --bone:#ECECEF;     /* body copy            */
  --fog:#A6A6B0;      /* secondary text       */
  --ash:#6C6C76;      /* tertiary / labels    */
  --mute:#50505A;

  --blood:#FF1F2D;    /* THE accent           */
  --blood-2:#D4101C;
  --gold:#FFFFFF;     /* legacy alias -> white */

  --f-poster:'Saira Condensed',"Arial Narrow",sans-serif;
  --f-ui:'Saira',system-ui,sans-serif;
  --f-brand:'Chakra Petch',ui-monospace,monospace;
  --f-body:'Inter',system-ui,sans-serif;

  --wrap:1240px;
}

/* ---- reset / base ---- */
*,*::before,*::after{ box-sizing:border-box; }
html{ background:var(--ink); -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--ink); color:var(--bone);
  font-family:var(--f-body); font-size:16px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; }
::selection{ background:var(--blood); color:#fff; }
h1,h2,h3,h4{ margin:0; }
section[id]{ scroll-margin-top:96px; }

::-webkit-scrollbar{ width:11px; height:11px; }
::-webkit-scrollbar-track{ background:var(--ink); }
::-webkit-scrollbar-thumb{ background:var(--line-2); border:3px solid var(--ink); }
::-webkit-scrollbar-thumb:hover{ background:var(--ash); }

/* ---- layout ---- */
.wrap{ max-width:var(--wrap); margin:0 auto; padding:0 clamp(1.2rem,4vw,2.4rem); }
.section{ padding:clamp(3.4rem,8vw,7rem) 0; border-top:1px solid var(--line); position:relative; }
.section--alt{ background:var(--ink-2); }

/* ---- section headers ---- */
.eyebrow{
  display:inline-flex; align-items:center; gap:.7rem; margin:0;
  font-family:var(--f-brand); font-weight:600; font-size:.72rem;
  letter-spacing:.26em; text-transform:uppercase; color:var(--ash);
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--blood); flex:none; }
.section__head{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:1.5rem 2rem; flex-wrap:wrap; margin-bottom:clamp(1.8rem,4vw,3rem);
}
.section__title{
  font-family:var(--f-poster); font-weight:800; text-transform:uppercase;
  font-size:clamp(2.1rem,5.5vw,3.7rem); line-height:.92; letter-spacing:-.01em;
  color:var(--white); margin-top:.7rem;
}
.section__title em{
  font-style:normal; color:transparent;
  -webkit-text-stroke:1.3px var(--fog); text-stroke:1.3px var(--fog);
}
.section__lead{ color:var(--fog); max-width:56ch; margin:1rem 0 0; font-size:1rem; }

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--f-ui); font-weight:600; font-size:.82rem;
  letter-spacing:.14em; text-transform:uppercase;
  padding:.95rem 1.6rem; border:1px solid transparent; cursor:pointer;
  transition:background .18s,border-color .18s,color .18s,transform .18s;
  white-space:nowrap;
}
.btn--gold{ background:var(--white); color:#08080A; }      /* primary  */
.btn--gold:hover{ background:var(--bone); transform:translateY(-1px); }
.btn--blood{ background:var(--blood); color:#fff; }         /* urgency  */
.btn--blood:hover{ background:var(--blood-2); transform:translateY(-1px); }
.btn--ghost{ background:transparent; border-color:var(--line-2); color:var(--white); }
.btn--ghost:hover{ border-color:var(--white); background:rgba(255,255,255,.05); }

/* ---- header ---- */
.site-head{
  position:sticky; top:0; z-index:60;
  background:rgba(8,8,10,.78); backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid var(--line);
}
.site-head .wrap{ display:flex; align-items:center; gap:2rem; height:72px; }
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand__mark{ width:auto; height:34px; filter:drop-shadow(0 0 0 transparent); }
.brand__type{
  font-family:var(--f-poster); font-weight:800; font-size:1.55rem;
  letter-spacing:.17em; text-transform:uppercase; color:var(--white);
  line-height:1; padding-left:.1em;
}
.nav{ margin-left:auto; display:flex; align-items:center; gap:1.9rem; }
.nav a{
  font-family:var(--f-ui); font-weight:600; font-size:.8rem;
  letter-spacing:.13em; text-transform:uppercase; color:var(--fog);
  position:relative; padding:.4rem 0; transition:color .15s;
}
.nav a:hover{ color:var(--white); }
.nav > a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-3px; height:2px;
  background:var(--blood); transition:right .22s;
}
.nav > a:hover::after{ right:0; }
.nav .btn{ margin-left:.3rem; }
.nav .btn::after{ display:none; }
.nav-toggle{
  display:none; margin-left:auto; background:none; border:1px solid var(--line-2);
  color:var(--white); padding:.4rem .45rem; cursor:pointer; line-height:0;
}

/* ---- hero ---- */
.hero{
  position:relative; overflow:hidden; border-bottom:1px solid var(--line);
  padding:clamp(3.6rem,11vw,8.5rem) 0 clamp(3rem,7vw,5.5rem);
}
.hero::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(120% 90% at 80% 10%, rgba(255,255,255,.04), transparent 55%),
    radial-gradient(80% 70% at 0% 100%, rgba(255,31,45,.05), transparent 60%);
}
.hero::after{
  content:""; position:absolute; right:-7%; top:50%; transform:translateY(-50%);
  width:min(58vw,680px); aspect-ratio:657/797; opacity:.045; pointer-events:none;
  background:url(../img/logo-mark.png) no-repeat center/contain;
}
.hero .wrap{ position:relative; z-index:2; }
.hero__tag{ margin-bottom:1.4rem; }
.hero__event{
  font-family:var(--f-poster); font-weight:900; text-transform:uppercase;
  font-size:clamp(3rem,11.5vw,8.4rem); line-height:.82; letter-spacing:-.02em;
  color:var(--white); margin:0;
}
.hero__meta{
  display:flex; flex-wrap:wrap; gap:.5rem 1.6rem; margin-top:1.5rem;
  font-family:var(--f-ui); font-size:.92rem; color:var(--fog); letter-spacing:.01em;
}
.hero__meta span{ display:inline-flex; align-items:center; gap:.5rem; }
.hero__meta span:not(:last-child)::after{ content:""; width:4px; height:4px; background:var(--line-2); transform:rotate(45deg); margin-left:1rem; }
.hero__meta b{ color:var(--white); font-weight:600; }
.hero__cta{ display:flex; gap:.8rem; flex-wrap:wrap; }

/* ---- VS lockup ---- */
.vs{
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center;
  gap:clamp(1rem,4vw,3rem); margin-top:clamp(2rem,5vw,3.4rem); max-width:900px;
}
.vs__name{
  font-family:var(--f-poster); font-weight:800; text-transform:uppercase;
  font-size:clamp(1.6rem,4.6vw,3rem); line-height:.9; color:var(--white);
  text-align:right; letter-spacing:.005em;
}
.vs__name--r{ text-align:left; }
.vs__mark{
  position:relative; display:grid; place-items:center; flex:none;
  width:clamp(54px,7vw,78px); height:clamp(54px,7vw,78px);
  border:1px solid var(--line-2);
}
.vs__mark::before,.vs__mark::after{
  content:""; position:absolute; background:var(--line-2);
}
.vs__mark::before{ width:1px; height:18px; top:-18px; left:50%; }
.vs__mark::after{ width:1px; height:18px; bottom:-18px; left:50%; }
.vs__mark span{
  font-family:var(--f-brand); font-weight:700; letter-spacing:.06em;
  font-size:clamp(.85rem,1.6vw,1.1rem); color:var(--blood);
}

/* ---- up next / countdown ---- */
.upnext{ display:grid; grid-template-columns:minmax(220px,300px) 1fr; border:1px solid var(--line); background:var(--panel); }
.upnext__poster{
  padding:clamp(1.6rem,3vw,2.2rem); border-right:1px solid var(--line);
  background:linear-gradient(155deg,var(--panel-2),var(--panel));
}
.upnext__date{ font-family:var(--f-poster); line-height:.78; }
.upnext__date .d{ display:block; font-size:clamp(3rem,6vw,4.2rem); font-weight:900; color:var(--white); }
.upnext__date .m{ font-size:1.4rem; font-weight:700; text-transform:uppercase; letter-spacing:.2em; color:var(--blood); }
.upnext__name{ font-family:var(--f-poster); font-weight:800; text-transform:uppercase; font-size:1.7rem; line-height:1; color:var(--white); margin:1.3rem 0 .4rem; }
.upnext__venue{ margin:0; color:var(--ash); font-size:.85rem; }
.upnext__body{ padding:clamp(1.6rem,3vw,2.2rem); display:flex; flex-direction:column; gap:1.4rem; justify-content:center; }
.countdown{ display:grid; grid-template-columns:repeat(4,1fr); gap:.6rem; }
.countdown > div{ border:1px solid var(--line); background:var(--ink); padding:.95rem .4rem; text-align:center; }
.countdown .n{ display:block; font-family:var(--f-poster); font-weight:800; font-size:clamp(1.7rem,4vw,2.2rem); line-height:1; color:var(--white); font-variant-numeric:tabular-nums; }
.countdown .l{ display:block; margin-top:.45rem; font-family:var(--f-brand); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ash); }

/* ---- fight card ---- */
.card-list{ border:1px solid var(--line); }
.bout{
  display:grid; grid-template-columns:minmax(108px,170px) 1fr auto 1fr minmax(108px,160px);
  align-items:center; gap:.6rem 1.2rem; padding:1.05rem 1.5rem;
  border-bottom:1px solid var(--line); transition:background .15s;
}
.bout:last-child{ border-bottom:0; }
.bout:hover{ background:var(--panel); }
.bout--main{ background:linear-gradient(90deg,rgba(255,31,45,.07),transparent 55%); }
.bout--main:hover{ background:linear-gradient(90deg,rgba(255,31,45,.10),var(--panel) 55%); }
.bout__class{ font-family:var(--f-brand); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ash); }
.bout--main .bout__class{ color:var(--blood); }
.bout__f{ font-family:var(--f-poster); font-weight:700; text-transform:uppercase; font-size:1.18rem; color:var(--fog); }
.bout__f--r{ text-align:right; }
.bout__f.win{ color:var(--white); }
.bout__vs{ font-family:var(--f-brand); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ash); text-align:center; }
.bout__method{ font-family:var(--f-ui); font-size:.78rem; letter-spacing:.03em; color:var(--fog); text-align:right; }
.bout__pro{ display:inline-block; margin-left:.45rem; font-family:var(--f-brand); font-weight:600; font-size:.54rem; letter-spacing:.14em; color:var(--blood); border:1px solid var(--blood); padding:.06rem .32rem; vertical-align:middle; line-height:1; }

/* ---- roster ---- */
.roster{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.fighter{
  position:relative; aspect-ratio:3/4; background:var(--panel); padding:1.3rem;
  display:flex; flex-direction:column; justify-content:flex-end; overflow:hidden;
  transition:background .2s; isolation:isolate;
}
.fighter:hover{ background:var(--panel-2); }
.fighter::after{ content:""; position:absolute; left:0; bottom:0; height:3px; width:0; background:var(--blood); transition:width .28s; z-index:3; }
.fighter:hover::after{ width:100%; }
.fighter__num{ position:absolute; top:.9rem; right:1.1rem; z-index:2; font-family:var(--f-poster); font-weight:800; font-size:1.05rem; color:var(--ash); }
.fighter__nick{ position:relative; z-index:2; font-family:var(--f-brand); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--blood); margin-bottom:.35rem; }
.fighter__name{ position:relative; z-index:2; font-family:var(--f-poster); font-weight:800; text-transform:uppercase; font-size:1.55rem; line-height:.92; color:var(--white); }
.fighter__meta{ position:relative; z-index:2; display:flex; flex-direction:column; gap:.1rem; margin-top:.6rem; font-size:.78rem; color:var(--fog); }
.fighter__meta .rec{ color:var(--white); letter-spacing:.02em; }

/* ---- power rankings ---- */
.ranks{ border:1px solid var(--line); }
.rank{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:1.4rem; padding:1.1rem 1.6rem; border-bottom:1px solid var(--line); transition:background .15s,padding .15s; }
.rank:last-child{ border-bottom:0; }
.rank:hover{ background:var(--panel); padding-left:1.95rem; }
.rank__pos{ font-family:var(--f-poster); font-weight:900; font-size:2.5rem; line-height:.85; min-width:1.5ch; color:transparent; -webkit-text-stroke:1.4px var(--line-2); text-stroke:1.4px var(--line-2); }
.rank:nth-child(1) .rank__pos{ -webkit-text-stroke-color:var(--blood); text-stroke-color:var(--blood); }
.rank__name{ font-family:var(--f-poster); font-weight:700; text-transform:uppercase; font-size:1.35rem; line-height:1; color:var(--white); }
.rank__div{ font-family:var(--f-brand); font-size:.64rem; letter-spacing:.15em; text-transform:uppercase; color:var(--ash); margin-top:.3rem; }
.rank__trend{ font-family:var(--f-ui); font-size:.88rem; color:var(--fog); font-variant-numeric:tabular-nums; }

/* ---- events ---- */
.events{ border:1px solid var(--line); }
.event-row{ display:grid; grid-template-columns:minmax(150px,230px) 1fr auto; align-items:center; gap:1.4rem; padding:1.2rem 1.6rem; border-bottom:1px solid var(--line); position:relative; transition:background .15s; }
.event-row:last-child{ border-bottom:0; }
.event-row::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:0; background:var(--blood); transition:width .2s; }
.event-row:hover{ background:var(--panel); }
.event-row:hover::before{ width:3px; }
.event-row__no{ display:flex; flex-direction:column; font-family:var(--f-poster); font-weight:800; text-transform:uppercase; font-size:1.3rem; line-height:1; color:var(--white); }
.event-row__no small{ font-family:var(--f-brand); font-weight:500; font-size:.62rem; letter-spacing:.18em; color:var(--ash); margin-top:.35rem; }
.event-row__main{ font-family:var(--f-ui); font-weight:600; color:var(--bone); }
.event-row__sub{ font-size:.8rem; color:var(--ash); margin-top:.2rem; }
.event-row__date{ font-family:var(--f-brand); font-size:.78rem; letter-spacing:.06em; color:var(--fog); text-align:right; white-space:nowrap; }

/* ---- news ---- */
.news{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.post{ background:var(--panel); padding:1.7rem; display:flex; flex-direction:column; gap:.7rem; min-height:210px; transition:background .18s; }
.post:hover{ background:var(--panel-2); }
.post__cat{ font-family:var(--f-brand); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--blood); }
.post__title{ font-family:var(--f-poster); font-weight:700; text-transform:uppercase; font-size:1.4rem; line-height:1; color:var(--white); }
.post__date{ font-family:var(--f-brand); font-size:.7rem; letter-spacing:.08em; color:var(--ash); margin-top:auto; }

/* ---- CTA band ---- */
.band{ position:relative; overflow:hidden; text-align:center; background:var(--ink-2); border-top:1px solid var(--line); padding:clamp(4rem,9vw,7rem) 0; }
.band::after{ content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:min(70vw,520px); aspect-ratio:657/797; opacity:.04; background:url(../img/logo-mark.png) no-repeat center/contain; pointer-events:none; }
.band .wrap{ position:relative; z-index:2; }
.band .eyebrow{ justify-content:center; }
.band h2{ font-family:var(--f-poster); font-weight:900; text-transform:uppercase; font-size:clamp(2.4rem,7vw,5rem); line-height:.9; color:var(--white); margin:.7rem auto 1rem; }
.band p{ color:var(--fog); max-width:58ch; margin:0 auto 2rem; }

/* ---- footer ---- */
.site-foot{ border-top:1px solid var(--line); background:var(--ink); padding:clamp(3rem,6vw,4.5rem) 0 2rem; }
.foot-grid{ display:grid; grid-template-columns:1.7fr 1fr 1fr 1.5fr; gap:2.4rem; }
.site-foot .brand{ margin-bottom:1rem; }
.site-foot .brand__mark{ height:30px; }
.site-foot .brand__type{ font-size:1.3rem; }
.foot-blurb{ color:var(--ash); font-size:.86rem; line-height:1.7; max-width:36ch; }
.site-foot h4{ font-family:var(--f-brand); font-weight:600; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--white); margin:0 0 1rem; }
.site-foot .foot-grid a{ color:var(--fog); display:block; padding:.26rem 0; font-size:.9rem; transition:color .15s; }
.site-foot .foot-grid a:hover{ color:var(--white); }
.socials{ display:flex; gap:.6rem; margin-top:1.1rem; }
.socials a{ width:38px; height:38px; padding:0; border:1px solid var(--line-2); display:grid; place-items:center; color:var(--fog); transition:.15s; }
.socials a:hover{ border-color:var(--white); color:var(--white); background:rgba(255,255,255,.05); }
.foot-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; margin-top:3rem; padding-top:1.6rem; border-top:1px solid var(--line); color:var(--ash); font-family:var(--f-brand); font-size:.72rem; letter-spacing:.08em; }

/* ---- long-form content (single posts / fighters / pages) ---- */
.entry-content{ max-width:72ch; color:var(--bone); }
.entry-content > * + *{ margin-top:1.1rem; }
.entry-content h2,.entry-content h3{ font-family:var(--f-poster); text-transform:uppercase; color:var(--white); letter-spacing:.01em; margin-top:2rem; }
.entry-content a{ color:var(--white); border-bottom:1px solid var(--blood); }
.entry-content strong{ color:var(--white); }
.mono{ font-family:var(--f-ui); font-variant-numeric:tabular-nums; }

/* ---- scroll reveal (content visible without JS; JS only enhances) ---- */
.reveal{ }
body.pf-js .reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s ease,transform .6s ease; }
body.pf-js .reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  body.pf-js .reveal{ opacity:1 !important; transform:none !important; }
  *{ scroll-behavior:auto !important; }
}

/* ---- responsive ---- */
@media (max-width:980px){
  .foot-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:860px){
  .nav{
    position:fixed; inset:72px 0 auto 0; flex-direction:column; align-items:stretch;
    gap:0; background:var(--ink); border-bottom:1px solid var(--line);
    padding:.6rem clamp(1.2rem,4vw,2.4rem) 1.4rem; transform:translateY(-135%);
    transition:transform .26s ease; margin-left:0;
  }
  .nav.open{ transform:none; }
  .nav > a{ padding:.95rem 0; border-bottom:1px solid var(--line); }
  .nav > a::after{ display:none; }
  .nav .btn{ width:100%; justify-content:center; margin:1rem 0 0; }
  .nav-toggle{ display:block; }
  .roster{ grid-template-columns:repeat(2,1fr); }
  .news{ grid-template-columns:1fr; }
  .upnext{ grid-template-columns:1fr; }
  .upnext__poster{ border-right:0; border-bottom:1px solid var(--line); }
  .bout{ grid-template-columns:1fr auto 1fr; gap:.5rem .8rem; padding:1rem 1.1rem; }
  .bout__class,.bout__method{ display:none; }
  .event-row{ grid-template-columns:1fr auto; }
  .event-row > div:nth-child(2){ grid-column:1 / -1; order:3; }
}
@media (max-width:520px){
  .foot-grid{ grid-template-columns:1fr; }
  .roster{ grid-template-columns:1fr 1fr; }
  .hero__meta span:not(:last-child)::after{ display:none; }
  .vs{ gap:.8rem; }
}

/* ---- header social cluster ---- */
.head-social{ display:flex; align-items:center; gap:.9rem; }
.head-social a{ color:var(--ash); line-height:0; transition:color .15s; }
.head-social a:hover{ color:var(--white); }
.head-social a::after{ display:none; }

/* ---- follow / social section ---- */
.social-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(248px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }
.social-card{ position:relative; overflow:hidden; display:flex; flex-direction:column; gap:.5rem; min-height:280px; padding:clamp(1.6rem,3vw,2.4rem); background:var(--panel); transition:background .2s; isolation:isolate; }
.social-card:hover{ background:var(--panel-2); }
.social-card__bg{ position:absolute; right:-30px; top:-34px; color:var(--white); opacity:.045; line-height:0; pointer-events:none; z-index:0; transition:opacity .25s,transform .35s; }
.social-card:hover .social-card__bg{ opacity:.08; transform:rotate(-6deg) scale(1.06); }
.social-card > *{ position:relative; z-index:1; }
.social-card__top{ display:flex; align-items:center; gap:.6rem; color:var(--fog); font-family:var(--f-brand); font-weight:600; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; }
.social-card--instagram:hover .social-card__top,
.social-card--instagram:hover .social-card__bg{ color:var(--white); }
.social-card__handle{ font-family:var(--f-poster); font-weight:800; font-size:clamp(1.9rem,4.2vw,2.9rem); line-height:.95; color:var(--white); margin-top:.3rem; }
.social-card__meta{ color:var(--fog); font-size:.9rem; }
.social-card__meta b{ color:var(--white); }
.social-card__cta{ margin-top:auto; display:inline-flex; align-items:center; gap:.5rem; font-family:var(--f-ui); font-weight:600; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--white); }
.social-card__cta svg{ transition:transform .2s; }
.social-card:hover .social-card__cta svg{ transform:translateX(4px); }
.social-card::after{ content:""; position:absolute; left:0; bottom:0; height:3px; width:0; background:var(--blood); transition:width .28s; z-index:2; }
.social-card:hover::after{ width:100%; }

@media (max-width:860px){
  .head-social{ padding:.4rem 0; border-bottom:1px solid var(--line); width:100%; }
}

/* ---- power rankings page ---- */
.pr-method{ border:1px solid var(--line); background:var(--panel); padding:clamp(1.4rem,3vw,2rem); margin-bottom:2.4rem; }
.pr-method h3{ font-family:var(--f-brand); font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--white); margin:0 0 1rem; }
.pr-method ul{ margin:0; padding:0; list-style:none; display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:.5rem 1.6rem; }
.pr-method li{ display:flex; justify-content:space-between; gap:1rem; font-size:.86rem; color:var(--fog); padding:.35rem 0; border-bottom:1px solid var(--line); }
.pr-method li b{ color:var(--white); font-family:var(--f-ui); font-variant-numeric:tabular-nums; white-space:nowrap; }
.pr-method p{ color:var(--ash); font-size:.84rem; margin:1rem 0 0; }

.pr-list{ display:flex; flex-direction:column; gap:1px; background:var(--line); border:1px solid var(--line); }
.pr-fighter{ background:var(--panel); padding:clamp(1.3rem,2.6vw,1.9rem); display:grid; grid-template-columns:auto 1fr auto; gap:1.2rem 1.6rem; align-items:start; position:relative; transition:background .18s; }
.pr-fighter:hover{ background:var(--panel-2); }
.pr-fighter--champ{ background:linear-gradient(100deg,rgba(255,31,45,.06),var(--panel) 60%); }
.pr-rankno{ font-family:var(--f-poster); font-weight:900; font-size:clamp(2.6rem,6vw,4rem); line-height:.8; color:transparent; -webkit-text-stroke:1.5px var(--line-2); text-stroke:1.5px var(--line-2); min-width:1.6ch; }
.pr-fighter--champ .pr-rankno{ -webkit-text-stroke-color:var(--blood); text-stroke-color:var(--blood); }
.pr-main{ min-width:0; }
.pr-name{ font-family:var(--f-poster); font-weight:800; text-transform:uppercase; font-size:clamp(1.5rem,3.4vw,2.2rem); line-height:.95; color:var(--white); }
.pr-tags{ display:flex; flex-wrap:wrap; gap:.5rem .8rem; margin:.5rem 0 .1rem; font-family:var(--f-brand); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ash); }
.pr-tags .belt{ color:var(--blood); }
.pr-records{ display:flex; flex-wrap:wrap; gap:.4rem 1.4rem; margin:.7rem 0; font-family:var(--f-ui); font-size:.86rem; color:var(--fog); font-variant-numeric:tabular-nums; }
.pr-records b{ color:var(--white); }
.pr-bio{ color:var(--fog); font-size:.92rem; line-height:1.6; margin:.5rem 0 .8rem; max-width:70ch; }
.pr-teamtop{ display:flex; flex-wrap:wrap; align-items:baseline; gap:.45rem 1.2rem; margin:.7rem 0 0; }
.pr-teamtop__h{ width:100%; font-family:var(--f-brand); font-size:.58rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ash); margin-bottom:.15rem; }
.pr-teamtop__f{ font-family:var(--f-poster); font-weight:700; text-transform:uppercase; font-size:.98rem; line-height:1; color:var(--bone); }
.pr-teamtop__f .pw{ font-family:var(--f-ui); font-weight:700; color:var(--blood); margin-left:.3rem; font-variant-numeric:tabular-nums; }
.pr-fighter:hover .pr-teamtop__f{ color:var(--white); }
.pr-virtus{ list-style:none; margin:.4rem 0 0; padding:0; display:flex; flex-direction:column; gap:.25rem; }
.pr-virtus li{ font-size:.82rem; color:var(--fog); }
.pr-virtus .res-w{ color:var(--white); font-family:var(--f-ui); font-weight:600; }
.pr-virtus .ev{ color:var(--ash); font-family:var(--f-brand); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; }
.pr-score{ text-align:right; }
.pr-score .n{ display:block; font-family:var(--f-poster); font-weight:900; font-size:clamp(2.2rem,5vw,3.2rem); line-height:.85; color:var(--white); font-variant-numeric:tabular-nums; }
.pr-score .l{ display:block; font-family:var(--f-brand); font-size:.58rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ash); margin-top:.35rem; }
.pr-fighter--champ .pr-score .n{ color:var(--blood); }
@media (max-width:720px){
  .pr-fighter{ grid-template-columns:auto 1fr; }
  .pr-score{ grid-column:1 / -1; text-align:left; display:flex; align-items:baseline; gap:.6rem; border-top:1px solid var(--line); padding-top:.8rem; }
  .pr-score .n{ font-size:2rem; }
  .pr-score .l{ margin-top:0; }
}

/* =========================================================================
   FIGHTER PROFILE
   ========================================================================= */
.fp-hero{ position:relative; overflow:hidden; border-bottom:1px solid var(--line); padding:clamp(3rem,8vw,6rem) 0 clamp(2rem,5vw,3.4rem); }
.fp-hero::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(85% 75% at 100% 0%, rgba(255,31,45,.07), transparent 60%); }
.fp-hero__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1fr minmax(220px,300px); gap:clamp(1.5rem,4vw,3rem); align-items:end; }
.fp-hero__rank{ margin-bottom:1rem; }
.fp-hero__nick{ font-family:var(--f-brand); font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--blood); margin:0 0 .5rem; font-size:.95rem; }
.fp-hero__name{ font-family:var(--f-poster); font-weight:900; text-transform:uppercase; font-size:clamp(2.6rem,8.5vw,5.8rem); line-height:.85; letter-spacing:-.02em; color:var(--white); }
.fp-champ{ display:inline-flex; align-items:center; gap:.5rem; margin:1.2rem 0 0; padding:.45rem .85rem; border:1px solid var(--blood); color:var(--blood);
  font-family:var(--f-brand); font-weight:600; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; }
.fp-champ__belt{ font-size:.85rem; line-height:1; }
.fp-gpchamp{ display:inline-flex; align-items:center; gap:.5rem; margin:1rem .8rem 0 0; padding:.45rem .85rem; border:1px solid #d9b65a;
  font-family:var(--f-brand); font-weight:600; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase;
  background:linear-gradient(100deg,#c9a64c 0%,#f3e0a6 32%,#fff6d4 50%,#f3e0a6 68%,#c9a64c 100%); background-size:220% auto; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; animation:fpGpShimmer 7s linear infinite; }
.fp-gpchamp__star{ -webkit-text-fill-color:#d9b65a; color:#d9b65a; font-size:.85rem; line-height:1; }
@media (prefers-reduced-motion: reduce){ .fp-gpchamp{ animation:none; } }
.fp-fan{ display:inline-flex; align-items:center; gap:.4rem; margin:1rem .8rem 0 0; padding:.32rem .7rem; border:1px solid var(--line-2);
  font-family:var(--f-brand); font-weight:600; font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--fog); background:transparent; }
.fp-fan__star{ color:var(--ash); font-size:.78rem; line-height:1; }
.fp-hero__meta{ display:flex; flex-wrap:wrap; gap:1rem 2.2rem; margin-top:1.5rem; font-family:var(--f-ui); color:var(--fog); font-size:.98rem; }
.fp-hero__meta i{ font-style:normal; color:var(--ash); font-family:var(--f-brand); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; display:block; margin-bottom:.2rem; }
.fp-hero__meta b{ color:var(--white); }
.fp-hero__img{ width:100%; border:1px solid var(--line); display:block; }
.fp-hero__mono{ aspect-ratio:3/4; border:1px solid var(--line); background:linear-gradient(160deg,var(--panel-2),var(--panel));
  display:grid; place-items:center; position:relative; overflow:hidden; }
.fp-hero__mono::after{ content:""; position:absolute; inset:0; background:url(../img/logo-mark.png) no-repeat center/contain; opacity:.05; }
.fp-hero__mono span{ font-family:var(--f-poster); font-weight:900; font-size:clamp(3rem,8vw,5rem); color:var(--line-2);
  letter-spacing:.04em; position:relative; z-index:1; }

.fp-statsec{ border-top:0; padding-top:clamp(2rem,5vw,3rem); }
.fp-stats{ display:grid; grid-template-columns:repeat(auto-fit,minmax(116px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }
.fp-stat{ background:var(--panel); padding:1.5rem 1rem; text-align:center; }
.fp-stat--key{ background:linear-gradient(160deg,rgba(255,31,45,.10),var(--panel) 72%); }
.fp-stat__n{ display:block; font-family:var(--f-poster); font-weight:900; font-size:clamp(2rem,5vw,2.9rem); line-height:.9; color:var(--white); font-variant-numeric:tabular-nums; }
.fp-stat__n--up{ color:var(--white); }
.fp-stat__n--down{ color:var(--ash); }
.fp-stat__sep{ color:var(--blood); margin:0 .08em; }
.fp-stat__n small{ font-size:.45em; color:var(--fog); margin-left:.05em; }
.fp-stat__l{ display:block; margin-top:.55rem; font-family:var(--f-brand); font-size:.58rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ash); }

.fp-methods{ margin-top:2rem; border:1px solid var(--line); background:var(--panel); padding:clamp(1.3rem,3vw,1.8rem); }
.fp-methods__title{ margin:0 0 1rem; font-family:var(--f-brand); font-weight:600; font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ash); }
.fp-methods__bar{ display:flex; height:16px; gap:2px; background:var(--ink); overflow:hidden; }
.fp-seg{ display:block; height:100%; min-width:2px; }
.fp-seg--ko{ background:var(--blood); }
.fp-seg--sub{ background:var(--white); }
.fp-seg--dec{ background:var(--line-2); }
.fp-methods__key{ display:flex; flex-wrap:wrap; gap:.8rem 2rem; margin:1.1rem 0 0; padding:0; list-style:none; font-family:var(--f-ui); font-size:.85rem; color:var(--fog); }
.fp-methods__key b{ color:var(--white); margin-left:.3rem; font-variant-numeric:tabular-nums; }
.fp-dot{ display:inline-block; width:10px; height:10px; margin-right:.5rem; vertical-align:middle; }
.fp-dot--ko{ background:var(--blood); }
.fp-dot--sub{ background:var(--white); }
.fp-dot--dec{ background:var(--line-2); }

.fp-log{ display:flex; flex-direction:column; gap:.6rem; }
.fp-bout{ display:grid; grid-template-columns:50px minmax(0,1fr) auto; align-items:center; gap:0 1.4rem;
  background:var(--panel); border:1px solid var(--line); padding:1.05rem 1.4rem; position:relative; overflow:hidden;
  transition:background .18s, border-color .18s, transform .18s; }
.fp-bout::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--line-2); transition:width .18s, background .18s; }
.fp-bout--w::before{ background:var(--blood); }
.fp-bout:hover{ background:#161616; border-color:var(--line-2); transform:translateX(2px); }
.fp-bout:hover::before{ width:7px; }
.fp-bout__res{ display:grid; place-items:center; width:50px; height:50px; font-family:var(--f-poster); font-weight:800; font-size:1.45rem; border:1px solid var(--line-2); color:var(--ash); }
.fp-bout--w .fp-bout__res{ background:var(--blood); border-color:var(--blood); color:#fff; }
.fp-bout--l .fp-bout__res{ color:var(--fog); }
.fp-bout--d::before{ background:var(--fog); }
.fp-bout--d .fp-bout__res{ background:var(--line-2); border-color:var(--fog); color:var(--white); }
.fp-bout--d .fp-bout__verb{ color:var(--fog); }
.fp-bout__main{ display:flex; flex-direction:column; gap:.28rem; min-width:0; }
.fp-bout__verb{ font-family:var(--f-brand); font-size:.58rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--ash); }
.fp-bout--w .fp-bout__verb{ color:var(--blood); }
.fp-bout__opp{ font-family:var(--f-poster); font-weight:700; font-size:1.4rem; line-height:1; text-transform:uppercase; letter-spacing:.01em; color:var(--white); }
.fp-bout__opp a{ color:var(--white); text-decoration:none; }
.fp-bout__opp a:hover{ color:var(--blood); }
.fp-bout__sub{ display:flex; flex-wrap:wrap; align-items:center; gap:.45rem .8rem; margin-top:.18rem; }
.fp-bout__method{ font-family:var(--f-ui); font-size:.82rem; color:var(--fog); }
.fp-bout--w .fp-bout__method{ color:var(--bone); }
.fp-bout__tags{ display:flex; flex-wrap:wrap; gap:.4rem; }
.fp-tag{ font-family:var(--f-brand); font-size:.55rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ash); border:1px solid var(--line-2); padding:.12rem .42rem; }
.fp-tag--title{ color:var(--white); border-color:var(--fog); }
.fp-tag--pro{ color:var(--blood); border-color:var(--blood); }

/* ---- complete career record ---- */
.fp-career__summary{ display:grid; grid-template-columns:repeat(auto-fit,minmax(124px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }
.fp-cstat{ background:var(--panel); padding:1.2rem 1.1rem; display:flex; flex-direction:column; gap:.5rem; }
.fp-cstat__n{ font-family:var(--f-poster); font-weight:800; font-size:clamp(1.5rem,3.4vw,2.2rem); line-height:1; color:var(--white); font-variant-numeric:tabular-nums; }
.fp-cstat__l{ font-family:var(--f-brand); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ash); }
.fp-form__row{ display:flex; gap:.3rem; }
.fp-form__d{ width:24px; height:24px; display:grid; place-items:center; font-family:var(--f-poster); font-weight:800; font-size:.74rem; }
.fp-form__d--w{ background:var(--white); color:#08080A; }
.fp-form__d--l{ background:var(--blood); color:#fff; }
.fp-form__d--d{ background:var(--fog); color:#08080A; }
.fp-filter{ display:flex; gap:.5rem; flex-wrap:wrap; margin:1.8rem 0 1rem; }
.fp-filter__btn{ background:transparent; border:1px solid var(--line-2); color:var(--fog); font-family:var(--f-ui); font-weight:600; font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; padding:.5rem .95rem; cursor:pointer; transition:.15s; }
.fp-filter__btn:hover{ color:var(--white); border-color:var(--white); }
.fp-filter__btn.is-on{ background:var(--white); color:#08080A; border-color:var(--white); }
.fp-record{ border:1px solid var(--line); }
.fp-rec{ display:flex; align-items:center; gap:1rem; padding:.95rem 1.4rem; border-bottom:1px solid var(--line); color:inherit; transition:background .15s; }
.fp-rec:last-child{ border-bottom:0; }
.fp-rec:hover{ background:var(--panel); }
.fp-rec--hide{ display:none; }
.fp-rec__res{ width:30px; height:30px; border-radius:50%; display:grid; place-items:center; font-family:var(--f-poster); font-weight:800; font-size:.84rem; flex:none; }
.fp-rec--w .fp-rec__res{ background:var(--white); color:#08080A; }
.fp-rec--l .fp-rec__res{ background:var(--blood); color:#fff; }
.fp-rec--d .fp-rec__res{ background:var(--fog); color:#08080A; }
.fp-rec__body{ flex:1; min-width:0; display:flex; flex-wrap:wrap; align-items:baseline; gap:.2rem 1.4rem; }
.fp-rec__opp{ font-size:.96rem; }
.fp-rec__verb{ color:var(--ash); font-size:.8rem; margin-right:.2rem; }
.fp-rec__opp b{ font-family:var(--f-ui); font-weight:600; color:var(--white); }
.fp-rec__meta{ display:flex; gap:.2rem 1.2rem; flex-wrap:wrap; margin-left:auto; color:var(--fog); font-size:.83rem; }
.fp-rec__meta a{ color:var(--fog); border-bottom:1px solid var(--line-2); }
.fp-rec__meta a:hover{ color:var(--white); }
.fp-rec__meta small{ font-family:var(--f-brand); letter-spacing:.05em; color:var(--ash); margin-left:.35rem; }
.fp-rec__tags{ display:flex; gap:.4rem; flex:none; }
.fp-tag--am{ color:var(--ash); border-color:var(--line-2); }
.fp-tag--virtus{ color:var(--blood); border-color:var(--blood); }
@media (max-width:640px){
  .fp-rec__meta{ margin-left:0; width:100%; }
  .fp-rec__tags{ margin-left:auto; }
}
.fp-bout__ev{ display:flex; flex-direction:column; text-align:right; align-items:flex-end; gap:.3rem; white-space:nowrap; padding-left:1.3rem; border-left:1px solid var(--line); }
.fp-bout__ev b{ font-family:var(--f-poster); font-weight:700; text-transform:uppercase; color:var(--white); font-size:1.05rem; line-height:1; letter-spacing:.02em; }
.fp-bout__ev small{ font-family:var(--f-brand); font-weight:500; font-size:.58rem; letter-spacing:.16em; color:var(--ash); }

.fp-bio{ max-width:74ch; color:var(--bone); font-size:1.06rem; line-height:1.75; }

.fp-nav__grid{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:1.5rem; }
.fp-nav__side{ display:flex; flex-direction:column; gap:.3rem; }
.fp-nav__side--r{ text-align:right; align-items:flex-end; }
.fp-nav__side span{ font-family:var(--f-brand); font-size:.58rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ash); }
.fp-nav__side b{ font-family:var(--f-poster); font-weight:700; text-transform:uppercase; color:var(--white); font-size:1.25rem; line-height:1; transition:color .15s; }
.fp-nav__side:hover b{ color:var(--blood); }

@media (max-width:720px){
  .fp-hero__grid{ grid-template-columns:1fr; }
  .fp-hero__media{ max-width:230px; order:-1; }
  .fp-bout{ grid-template-columns:42px minmax(0,1fr); gap:.5rem 1rem; padding:.95rem 1.1rem; }
  .fp-bout__res{ width:42px; height:42px; font-size:1.2rem; }
  .fp-bout__opp{ font-size:1.18rem; }
  .fp-bout__ev{ grid-column:1 / -1; flex-direction:row; gap:.6rem; align-items:center; text-align:left; border-left:0; padding-left:0; border-top:1px solid var(--line); padding-top:.7rem; }
  .fp-nav__grid{ grid-template-columns:1fr; text-align:center; }
  .fp-nav__side, .fp-nav__side--r{ align-items:center; text-align:center; }
}

/* ===== fighter profile extras ===== */
.fp-reign{ margin:.5rem 0 0; font-family:var(--f-ui); font-size:.82rem; color:var(--fog); }
.fp-follow{ display:flex; gap:.6rem; flex-wrap:wrap; margin-top:1.1rem; }
.fp-follow a{ font-family:var(--f-brand); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--fog); border:1px solid var(--line-2); padding:.45rem .8rem; transition:.15s; }
.fp-follow a:hover{ color:var(--white); border-color:var(--white); }
.fp-opp{ color:inherit; border-bottom:1px solid var(--line-2); transition:.15s; }
.fp-opp:hover{ color:var(--blood); border-color:var(--blood); }

/* next-fight banner */
.fp-next{ border-bottom:1px solid var(--line); background:var(--ink); }
.fp-next__grid{ display:grid; grid-template-columns:1fr auto; gap:1.6rem clamp(1.5rem,4vw,3rem); align-items:center; padding:clamp(1.6rem,4vw,2.4rem) 0; }
.fp-next__vs{ margin:.3rem 0 .45rem; font-family:var(--f-poster); font-weight:800; font-size:clamp(1.8rem,5vw,3rem); line-height:.95; color:var(--white); }
.fp-next__vs span{ color:var(--blood); }
.fp-next__flag{ color:var(--blood); }
.fp-next__ev{ margin:0; font-family:var(--f-ui); font-size:.92rem; color:var(--fog); }
.fp-next__ev a{ color:var(--white); border-bottom:1px solid var(--line-2); }
.fp-next__ev a:hover{ color:var(--blood); }
.fp-next .countdown{ min-width:min(360px,82vw); }
@media (max-width:680px){ .fp-next__grid{ grid-template-columns:1fr; } }

/* accolades */
.fp-accolades{ display:flex; flex-wrap:wrap; gap:.55rem; margin-bottom:1.7rem; }
.fp-acc{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--f-brand); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--white); border:1px solid var(--line-2); padding:.5rem .85rem; }
.fp-acc::before{ content:""; width:6px; height:6px; background:var(--blood); transform:rotate(45deg); flex:none; }

/* tale of the tape */
.fp-tape{ margin-top:2rem; display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }
.fp-tape__row{ background:var(--panel); padding:1rem 1.2rem; display:flex; flex-direction:column; gap:.35rem; }
.fp-tape__k{ font-family:var(--f-brand); font-size:.58rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ash); }
.fp-tape__v{ font-family:var(--f-ui); font-weight:600; color:var(--white); }

/* highlight reel */
.fp-reel__frame{ position:relative; aspect-ratio:16/9; border:1px solid var(--line); background:#000; }
.fp-reel__frame iframe{ position:absolute; inset:0; width:100%; height:100%; }

/* division rivals */
.fp-rivals__grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }
.fp-rival{ display:flex; align-items:center; gap:.9rem; background:var(--panel); padding:1.1rem 1.3rem; color:inherit; transition:background .15s; }
.fp-rival:hover{ background:var(--ink); }
.fp-rival__rk{ font-family:var(--f-poster); font-weight:800; color:var(--ash); font-size:1.1rem; flex:none; }
.fp-rival__id{ display:flex; flex-direction:column; min-width:0; flex:1; }
.fp-rival__name{ font-family:var(--f-ui); font-weight:600; color:var(--white); }
.fp-rival__nick{ font-size:.78rem; color:var(--ash); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fp-rival__rec{ font-size:.82rem; color:var(--fog); flex:none; }

/* ===== in the news ===== */
.fp-news__list{ list-style:none; margin:0; padding:0; border-top:1px solid var(--line); }
.fp-news__item{ border-bottom:1px solid var(--line); }
.fp-news__link{ display:flex; flex-direction:column; gap:.45rem; padding:1.15rem .2rem; color:inherit; transition:padding .15s, color .15s; }
.fp-news__link:hover{ padding-left:.8rem; }
.fp-news__title{ font-family:var(--f-ui); font-weight:600; font-size:1.02rem; line-height:1.32; color:var(--white); transition:color .15s; }
.fp-news__link:hover .fp-news__title{ color:var(--blood); }
.fp-news__meta{ display:flex; flex-wrap:wrap; gap:.4rem .9rem; align-items:center; font-family:var(--f-brand); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ash); }
.fp-news__src{ color:var(--fog); }
.fp-news__foot{ margin-top:1.3rem; font-family:var(--f-brand); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ash); }
.fp-news__note{ margin-top:1rem; padding:1.1rem 1.2rem; border:1px dashed var(--line-2); color:var(--fog); font-family:var(--f-ui); font-size:.9rem; line-height:1.5; }

/* ===== signed-to badge ===== */
.fp-signed{ display:inline-flex; align-items:center; gap:.65rem; margin:1rem 0 0; padding:.5rem .95rem .5rem .8rem; border:1px solid var(--line-2); border-left:3px solid var(--blood); background:var(--ink); }
.fp-signed__tag{ font-family:var(--f-brand); font-size:.56rem; font-weight:700; letter-spacing:.24em; text-transform:uppercase; color:var(--blood); }
.fp-signed__name{ font-family:var(--f-poster); font-weight:800; font-size:1.05rem; letter-spacing:.02em; line-height:1; text-transform:uppercase; color:var(--white); }

/* ===== power rankings: card links + stats leaderboard ===== */
.pr-fighter{ color:inherit; text-decoration:none; }
.pr-method--foot{ margin-bottom:0; }

.pr-board-wrap{ border:1px solid var(--line); overflow-x:auto; -webkit-overflow-scrolling:touch; }
.pr-board{ width:100%; border-collapse:collapse; font-family:var(--f-ui); min-width:680px; }
.pr-board th, .pr-board td{ padding:.9rem 1.05rem; text-align:left; border-bottom:1px solid var(--line); white-space:nowrap; }
.pr-board thead th{ font-family:var(--f-brand); font-size:.58rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--ash); background:var(--ink); }
.pr-board th.is-sortable{ cursor:pointer; user-select:none; }
.pr-board th.is-sortable:hover{ color:var(--white); }
.pr-board th.is-sortable::after{ content:'\2195'; opacity:.3; margin-left:.45em; font-size:.85em; }
.pr-board th.is-asc::after{ content:'\2191'; opacity:1; color:var(--blood); }
.pr-board th.is-desc::after{ content:'\2193'; opacity:1; color:var(--blood); }
.pr-board tbody tr{ background:var(--panel); transition:background .15s; }
.pr-board tbody tr:hover{ background:var(--ink); }
.pr-board tbody tr.is-champ{ background:linear-gradient(100deg,rgba(255,31,45,.07),var(--panel) 55%); }
.pr-board__rk{ font-family:var(--f-poster); font-weight:800; color:var(--ash); font-size:1.05rem; font-variant-numeric:tabular-nums; }
.pr-board tr.is-champ .pr-board__rk{ color:var(--blood); }
.pr-board__name{ font-family:var(--f-ui); font-weight:600; color:var(--white); }
.pr-board__name:hover{ color:var(--blood); }
.pr-board__sub{ display:block; font-family:var(--f-brand); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ash); margin-top:.2rem; }
.pr-board__vpi{ font-family:var(--f-poster); font-weight:800; font-size:1.1rem; color:var(--white); font-variant-numeric:tabular-nums; }
.pr-board .mono{ font-variant-numeric:tabular-nums; color:var(--fog); }

/* ===== Teams ===================================================== */
.fp-teamlink{color:var(--white);border-bottom:1px solid var(--line-2);transition:border-color .2s,color .2s}
.fp-teamlink:hover{color:var(--blood);border-color:var(--blood)}
.pr-board__team{display:block;font-family:var(--f-ui);font-size:.7rem;color:var(--ash);margin-top:.15rem}
a.pr-board__team:hover{color:var(--blood)}
.tm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}
.tm-card{display:flex;flex-direction:column;gap:.45rem;padding:clamp(1.1rem,2.4vw,1.6rem);background:var(--ink);transition:background .2s}
.tm-card:hover{background:var(--panel)}
.tm-card__rk{font-family:var(--f-poster);font-weight:800;font-size:.9rem;color:var(--ash)}
.tm-card__name{font-family:var(--f-poster);font-weight:800;font-size:clamp(1.3rem,2.6vw,1.7rem);line-height:1;text-transform:uppercase;color:var(--white)}
.tm-card:hover .tm-card__name{color:var(--blood)}
.tm-card__base{font-family:var(--f-ui);font-size:.74rem;color:var(--fog)}
.tm-card__stats{display:flex;flex-wrap:wrap;gap:.5rem 1.2rem;margin-top:.4rem;padding-top:.7rem;border-top:1px solid var(--line)}
.tm-card__stats span{display:flex;flex-direction:column;font-family:var(--f-ui);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ash)}
.tm-card__stats b{font-family:var(--f-poster);font-weight:800;font-size:1.15rem;letter-spacing:0;color:var(--white)}
.tm-card__meta{display:flex;flex-wrap:wrap;gap:.15rem .8rem;align-items:baseline}
.tm-card__coach{font-family:var(--f-ui);font-size:.72rem;color:var(--fog)}
.tm-card__coach i{font-style:normal;text-transform:uppercase;letter-spacing:.1em;font-size:.56rem;color:var(--ash);margin-right:.35rem}
.tm-card__top{display:flex;flex-direction:column;gap:.3rem;margin-top:.5rem;padding-top:.6rem;border-top:1px solid var(--line)}
.tm-card__top-h{font-family:var(--f-ui);font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ash)}
.tm-card__fighter{display:flex;justify-content:space-between;align-items:baseline;gap:.6rem}
.tm-card__fname{font-family:var(--f-ui);font-size:.82rem;color:var(--bone)}
.tm-card:hover .tm-card__fname{color:var(--white)}
.tm-card__fpwr{font-family:var(--f-poster);font-weight:800;font-size:.82rem;color:var(--blood)}
/* Single-team: top fighters band + champion accent */
.tm-hero__crest span{font-size:clamp(2.4rem,7vw,4rem)}
.tm-top__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}
.tm-top{display:flex;flex-direction:column;gap:.35rem;padding:clamp(1.1rem,2.6vw,1.7rem);background:var(--ink);text-decoration:none;transition:background .2s}
.tm-top:hover{background:var(--panel)}
.tm-top__pwr{display:flex;align-items:baseline;gap:.4rem}
.tm-top__pwr b{font-family:var(--f-poster);font-weight:800;font-size:clamp(2.2rem,5vw,3rem);line-height:.9;color:var(--blood)}
.tm-top__pwr i{font-style:normal;font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ash)}
.tm-top__name{font-family:var(--f-poster);font-weight:800;font-size:1.4rem;text-transform:uppercase;line-height:1;color:var(--white)}
.tm-top:hover .tm-top__name{color:var(--blood)}
.tm-top__belt{color:var(--blood);font-size:.9rem}
.tm-top__sub{display:flex;justify-content:space-between;gap:.6rem;font-family:var(--f-ui);font-size:.74rem;color:var(--fog)}
.fp-rival--champ{outline:1px solid color-mix(in srgb,var(--blood) 55%,transparent)}
.fp-rival--champ .fp-rival__rk{color:var(--blood)}
.tm-hero .fp-hero__mono img{width:100%;height:100%;object-fit:cover}

/* =========================================================================
 * CHAMPIONS PAGE — the gold. Scoped so the championship gold lives only here.
 * ====================================================================== */
.champions-page{ --gold:#d9b65a; --gold-2:#f1d893; --gold-deep:#8a6d23; }
.champ-hero{ position:relative; background:transparent; padding:clamp(2.6rem,6vw,5rem) 0 clamp(1.6rem,4vw,3rem); overflow:hidden; text-align:center; }
.champ-hero__glow{ position:absolute; left:50%; top:38%; width:min(120vw,1400px); height:120%; transform:translate(-50%,-50%); background:radial-gradient(ellipse at center, rgba(217,182,90,.20), rgba(217,182,90,.05) 38%, transparent 66%); pointer-events:none; }
.champ-hero__inner{ position:relative; }
.champ-hero__tag{ color:var(--gold); }
.champ-hero__title{ font-family:var(--f-poster); font-weight:900; text-transform:uppercase; font-size:clamp(3.4rem,13vw,9rem); line-height:.82; margin:.1em 0 .3em; color:#fff;
	background:linear-gradient(180deg,var(--gold-2),var(--gold) 45%,var(--gold-deep)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.champ-hero__lead{ max-width:54ch; margin:0 auto; color:var(--fog); font-size:1.05rem; line-height:1.55; }
.champ-hero__belt{ display:block; width:min(100%,1100px); margin:clamp(1.4rem,4vw,2.6rem) auto 0; height:auto; filter:drop-shadow(0 14px 40px rgba(217,182,90,.28)) drop-shadow(0 4px 14px rgba(0,0,0,.6)); }

.champ{ padding:clamp(2.2rem,6vw,4.5rem) 0; border-top:1px solid var(--line); }
.champ__grid{ display:grid; grid-template-columns:minmax(0,5fr) minmax(0,7fr); gap:clamp(1.6rem,4vw,3.5rem); align-items:center; }
.champ--alt .champ__grid{ grid-template-columns:minmax(0,7fr) minmax(0,5fr); }
.champ--alt .champ__media{ order:2; }
.champ__media{ position:relative; }
.champ__img{ width:100%; height:auto; display:block; border:1px solid var(--line-2); filter:grayscale(.15) contrast(1.03); }
.champ__mono{ aspect-ratio:4/5; display:grid; place-items:center; background:linear-gradient(160deg,#15130c,#0c0b08); border:1px solid var(--gold-deep); }
.champ__mono span{ font-family:var(--f-poster); font-weight:900; font-size:clamp(4rem,12vw,8rem); color:transparent; -webkit-text-stroke:2px var(--gold-deep); }
.champ__plate{ position:absolute; top:1rem; left:1rem; z-index:2; font-family:var(--f-brand); font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; color:#1a1407; background:linear-gradient(180deg,var(--gold-2),var(--gold)); padding:.4rem .7rem; font-weight:700; }
.champ__class{ font-family:var(--f-brand); font-weight:700; letter-spacing:.14em; text-transform:uppercase; font-size:.8rem; color:var(--gold); margin:0 0 .5rem; }
.champ__class em{ color:var(--ash); font-style:normal; letter-spacing:.1em; }
.champ__star{ color:var(--gold); }
.champ__name{ font-family:var(--f-poster); font-weight:900; text-transform:uppercase; font-size:clamp(2.4rem,6vw,4.4rem); line-height:.9; color:#fff; margin:0; }
.champ__nick{ font-family:var(--f-poster); font-weight:600; font-style:italic; color:var(--gold-2); font-size:clamp(1.1rem,2.4vw,1.5rem); margin:.2rem 0 0; }
.champ__won{ margin:1.1rem 0 0; padding:.85rem 1.1rem; background:rgba(217,182,90,.07); border-left:3px solid var(--gold); color:var(--bone); font-size:.95rem; line-height:1.5; }
.champ__won span{ display:block; font-family:var(--f-brand); font-size:.58rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:.25rem; }
.champ__won a{ color:var(--gold-2); }
.champ__won b{ color:#fff; }
.champ__stats{ display:flex; flex-wrap:wrap; gap:.6rem 2rem; margin:1.2rem 0; }
.champ__stats span{ display:flex; flex-direction:column; font-family:var(--f-brand); font-size:.58rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ash); }
.champ__stats b{ font-family:var(--f-poster); font-weight:800; font-size:1.7rem; line-height:1; letter-spacing:0; color:#fff; margin-bottom:.2rem; font-variant-numeric:tabular-nums; }
.champ__from{ color:var(--fog); font-size:.9rem; margin:0 0 1.2rem; }
.champ__from b{ color:var(--bone); }
.champ__btn{ background:linear-gradient(180deg,var(--gold-2),var(--gold)); color:#1a1407; border:0; }
.champ__btn:hover{ background:var(--gold-2); color:#0c0b08; }

.champ-vacant{ border-top:1px solid var(--line); }
.champ-vacant__grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }
.champ-vacant__row{ display:flex; flex-direction:column; gap:.55rem; padding:1.1rem 1.3rem; background:var(--ink); }
.champ-vacant__head{ display:flex; align-items:baseline; gap:.55rem; }
.champ-vacant__cls{ font-family:var(--f-poster); font-weight:800; text-transform:uppercase; font-size:1.2rem; line-height:1; color:var(--bone); }
.champ-vacant__lbs{ color:var(--ash); font-size:.78rem; }
.champ-vacant__tag{ margin-left:auto; font-family:var(--f-brand); font-size:.54rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); border:1px solid var(--gold-deep); padding:.2rem .5rem; white-space:nowrap; }
.champ-vacant__cands{ margin:0; font-family:var(--f-ui); font-size:.86rem; line-height:1.55; color:var(--bone); }
.champ-vacant__candl{ display:block; font-family:var(--f-brand); font-size:.54rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ash); margin-bottom:.2rem; }
.champ-vacant__cands a{ color:var(--gold-2); }
.champ-cta{ padding-top:clamp(1.4rem,4vw,2.4rem); }
@media(max-width:760px){
	.champ__grid, .champ--alt .champ__grid{ grid-template-columns:1fr; }
	.champ--alt .champ__media{ order:0; }
}

/* Champion marker — reused in the rankings & team rankings (championship gold) */
.champ-tag{ display:inline-flex; align-items:center; gap:.3em; font-family:var(--f-brand); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700; color:#1a1407; background:linear-gradient(180deg,#f1d893,#d9b65a); padding:.18rem .5rem; border-radius:2px; white-space:nowrap; }
.champ-tag--sm{ font-size:.5rem; padding:.12rem .38rem; }
.champ-star{ color:#d9b65a; }
.pr-board__belt{ display:inline-block; margin-top:.25rem; }

/* =========================================================================
 * CHAMPIONS PAGE — extras: reigns, belt nameplate, ladder, history, hall
 * ====================================================================== */
/* Hero cinematics */
.champ-hero__title{ background:linear-gradient(100deg,#8a6d23 0%,#d9b65a 28%,#fff7df 50%,#d9b65a 72%,#8a6d23 100%); background-size:220% auto; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; animation:champShimmer 7s linear infinite; }
@keyframes champShimmer{ to{ background-position:-220% center; } }
@keyframes champBeltIn{ from{ opacity:0; transform:translateY(28px) scale(.97); } to{ opacity:1; transform:none; } }
.champ-hero__belt[data-belt]{ animation:champBeltIn 1s cubic-bezier(.2,.7,.2,1) both; }
@media (prefers-reduced-motion: reduce){ .champ-hero__title{ animation:none; } .champ-hero__belt[data-belt]{ animation:none; } }
.champ-king{ display:inline-flex; align-items:center; gap:.5em; margin:.4rem auto 0; padding:.45rem .9rem; border:1px solid var(--gold-deep); border-radius:999px; font-family:var(--f-brand); font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-2); text-decoration:none; transition:background .2s; }
.champ-king:hover{ background:rgba(217,182,90,.1); }
.champ-king b{ color:#fff; font-weight:700; }
.champ-king__crown{ font-size:.95rem; }

/* Weight-class ladder */
.champ-ladder{ display:flex; flex-wrap:wrap; gap:.5rem; justify-content:center; padding-top:clamp(1rem,3vw,1.8rem); padding-bottom:.4rem; }
.champ-ladder__chip{ font-family:var(--f-brand); font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--fog); text-decoration:none; padding:.4rem .7rem; border:1px solid var(--line-2); border-radius:999px; transition:all .18s; }
.champ-ladder__chip:hover{ color:#fff; border-color:var(--ash); }
.champ-ladder__chip.is-held{ color:#1a1407; background:linear-gradient(180deg,#f1d893,#d9b65a); border-color:transparent; font-weight:700; }
.champ-ladder__chip .champ-star{ color:#1a1407; }

/* Champion media + belt nameplate */
.champ__media{ margin-bottom:1.6rem; }
.champions-page .champ__img{ filter:sepia(.45) saturate(1.25) brightness(.96) contrast(1.03); transition:filter .5s ease; }
.champ__media:hover .champ__img{ filter:none; }
.champ__king{ position:absolute; top:1rem; right:1rem; z-index:3; font-family:var(--f-brand); font-size:.56rem; letter-spacing:.16em; text-transform:uppercase; font-weight:700; color:#1a1407; background:linear-gradient(180deg,#f1d893,#d9b65a); padding:.3rem .55rem; border-radius:3px; }
.belt-plate{ position:absolute; left:50%; bottom:-18px; transform:translateX(-50%); z-index:4; width:min(86%,330px); padding:.6rem 1rem .7rem; text-align:center; display:flex; flex-direction:column; align-items:center; gap:.02rem; background:linear-gradient(180deg,#fbe8b8,#d9b65a 55%,#a8842f); border:2px solid #6e561d; border-radius:16px/46px; box-shadow:0 12px 26px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.55); }
.belt-plate__crown{ color:#5a4716; font-size:.95rem; line-height:1; }
.belt-plate__top{ font-family:var(--f-brand); font-size:.5rem; letter-spacing:.24em; text-transform:uppercase; color:#5a4716; }
.belt-plate__name{ font-family:var(--f-poster); font-weight:800; text-transform:uppercase; font-size:clamp(1rem,2.4vw,1.4rem); line-height:.95; color:#2a2008; text-shadow:0 1px 0 rgba(255,255,255,.4); }
.belt-plate__btm{ font-family:var(--f-brand); font-size:.46rem; letter-spacing:.22em; text-transform:uppercase; color:#5a4716; }

/* Reign clock */
.champ-reign{ margin:1rem 0 .2rem; padding:1rem 1.2rem; border:1px solid var(--gold-deep); border-radius:8px; background:linear-gradient(180deg,rgba(217,182,90,.08),transparent); }
.champ-reign__clock{ display:flex; align-items:baseline; gap:.6rem; }
.champ-reign__n{ font-family:var(--f-poster); font-weight:900; font-size:clamp(2.4rem,6vw,3.6rem); line-height:.85; color:var(--gold-2); font-variant-numeric:tabular-nums; }
.champ-reign__u{ font-family:var(--f-brand); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); }
.champ-reign__since{ margin:.4rem 0 0; color:var(--fog); font-size:.86rem; }
.champ-reign__since a{ color:var(--gold-2); }

/* Defenses */
.champ-def{ margin:1rem 0; }
.champ-def__h{ font-family:var(--f-brand); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin:0 0 .5rem; }
.champ-def__n{ font-family:var(--f-poster); font-weight:800; font-size:1.1rem; color:var(--gold-2); margin-right:.2rem; }
.champ-def__list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.4rem; }
.champ-def__list li{ color:var(--bone); font-size:.92rem; padding-left:1rem; border-left:2px solid var(--gold-deep); }
.champ-def__list b{ color:#fff; }
.champ-def__v{ color:var(--gold); font-family:var(--f-brand); font-size:.6rem; letter-spacing:.1em; text-transform:uppercase; margin-right:.3rem; }
.champ-def__ev{ color:var(--ash); font-size:.8rem; }

.champ__stats b[data-countup]{ font-variant-numeric:tabular-nums; }

/* Next defense + countdown */
.champ-next{ display:flex; flex-wrap:wrap; align-items:center; gap:1rem 1.6rem; margin:1.1rem 0; padding:1rem 1.2rem; background:var(--panel); border:1px solid var(--line-2); border-radius:8px; }
.champ-next__h{ font-family:var(--f-brand); font-size:.6rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin:0 0 .25rem; }
.champ-next__vs{ font-family:var(--f-poster); font-weight:800; text-transform:uppercase; font-size:1.4rem; margin:0; color:#fff; }
.champ-next__vs b{ color:var(--gold-2); }
.champ-next__ev{ margin:.2rem 0 0; color:var(--fog); font-size:.84rem; }
.champ-next__ev a{ color:var(--bone); }
.champ-countdown{ display:flex; gap:1rem; margin-left:auto; }
.champ-countdown > div{ text-align:center; }
.champ-countdown .n{ display:block; font-family:var(--f-poster); font-weight:900; font-size:1.9rem; line-height:1; color:var(--gold-2); font-variant-numeric:tabular-nums; }
.champ-countdown .l{ display:block; font-family:var(--f-brand); font-size:.5rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ash); margin-top:.25rem; }

/* Foot: view + contender */
.champ__foot{ display:flex; flex-wrap:wrap; align-items:center; gap:1rem 1.4rem; margin-top:1.2rem; }
.champ-contender{ font-family:var(--f-ui); font-size:.86rem; color:var(--fog); }
.champ-contender__l{ font-family:var(--f-brand); font-size:.56rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ash); margin-right:.4rem; }
.champ-contender a{ color:var(--gold-2); }

/* Title history */
.champ-history{ margin-top:1.3rem; border-top:1px solid var(--line); padding-top:.8rem; }
.champ-history summary{ cursor:pointer; font-family:var(--f-brand); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); list-style:none; }
.champ-history summary::-webkit-details-marker{ display:none; }
.champ-history summary::before{ content:"+ "; color:var(--gold-deep); }
.champ-history[open] summary::before{ content:"– "; }
.champ-history__lineage{ margin:.8rem 0; font-family:var(--f-poster); font-weight:700; text-transform:uppercase; color:var(--bone); font-size:1rem; letter-spacing:.02em; }
.champ-history__list{ list-style:none; margin:.4rem 0 0; padding:0; display:flex; flex-direction:column; gap:.5rem; }
.champ-history__list li{ display:grid; grid-template-columns:auto 1fr auto; gap:.4rem 1rem; align-items:baseline; padding:.5rem 0; border-bottom:1px solid var(--line); font-size:.9rem; color:var(--bone); }
.champ-history__yr{ color:var(--gold); }
.champ-history__txt b{ color:#fff; }
.champ-history__ev{ color:var(--ash); font-size:.78rem; text-align:right; }

/* Hall of champions */
.champ-hall__grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }
.champ-hall__row{ display:flex; align-items:baseline; gap:.7rem; padding:1rem 1.2rem; background:var(--ink); text-decoration:none; transition:background .18s; }
.champ-hall__row:hover{ background:var(--panel); }
.champ-hall__star{ color:var(--gold); }
.champ-hall__name{ font-family:var(--f-poster); font-weight:800; text-transform:uppercase; font-size:1.15rem; color:#fff; }
.champ-hall__titles{ margin-left:auto; font-family:var(--f-ui); font-size:.74rem; color:var(--fog); text-align:right; }
@media(max-width:760px){
	.champ-countdown{ margin-left:0; }
	.champ-history__list li{ grid-template-columns:1fr; }
	.champ-history__ev{ text-align:left; }
}

/* Power Rankings — leaderboard filters */
.pr-filters{ display:flex; flex-wrap:wrap; align-items:center; gap:.7rem 1rem; margin:0 0 1.2rem; }
.pr-filter{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--f-brand); font-size:.58rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ash); }
.pr-filter select{ font-family:var(--f-ui); font-size:.85rem; letter-spacing:0; text-transform:none; color:var(--white); background:var(--panel); border:1px solid var(--line-2); padding:.45rem .7rem; border-radius:4px; cursor:pointer; }
.pr-filter select:focus{ outline:none; border-color:var(--blood); }
.pr-filter__clear{ font-family:var(--f-brand); font-size:.56rem; letter-spacing:.14em; text-transform:uppercase; color:var(--fog); background:transparent; border:1px solid var(--line-2); padding:.5rem .8rem; border-radius:4px; cursor:pointer; transition:all .18s; }
.pr-filter__clear:hover{ color:#fff; border-color:var(--ash); }
.pr-filter__count{ margin-left:auto; font-family:var(--f-ui); font-size:.8rem; color:var(--ash); font-variant-numeric:tabular-nums; }

/* Grand Prix champion — gold badge + shimmering bio (fighter profile) */
.fp-gp{ display:inline-flex; align-items:center; gap:.4em; margin:.7rem 0 0; font-family:var(--f-brand); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; font-weight:700; color:#1a1407; background:linear-gradient(180deg,#f1d893,#d9b65a); padding:.38rem .75rem; border-radius:3px; box-shadow:0 4px 14px rgba(217,182,90,.25); }
.fp-bio--gp{ background:linear-gradient(100deg,#c9a64c 0%,#f3e0a6 30%,#fff6d4 50%,#f3e0a6 70%,#c9a64c 100%); background-size:220% auto; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; animation:fpGpShimmer 7s linear infinite; }
.fp-bio--gp a{ color:#fff4cf; }
@keyframes fpGpShimmer{ to{ background-position:-220% center; } }
@media (prefers-reduced-motion: reduce){ .fp-bio--gp{ animation:none; } }

/* ========================================================================
 * Fighter Portal (self-service profiles)
 * ===================================================================== */
.wrap--narrow{ max-width:960px; }
.vp-notice{ padding:.85rem 1.1rem; border-radius:10px; margin:0 0 1.4rem; font-weight:600; }
.vp-notice--ok{ background:rgba(46,160,67,.14); color:#9be8a8; border:1px solid rgba(46,160,67,.4); }
.vp-notice--err{ background:rgba(179,45,46,.14); color:#f0a8a8; border:1px solid rgba(179,45,46,.4); }
.vp-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.4rem; }
.vp-card{ background:var(--panel,#15151b); border:1px solid var(--line,rgba(255,255,255,.1)); border-radius:14px; padding:1.6rem 1.5rem; }
.vp-card--wide{ max-width:100%; }
.vp-card h3{ margin:0 0 .4rem; font-family:var(--f-poster,inherit); letter-spacing:.01em; }
.vp-lead{ color:var(--ash,#9a9aa5); margin:0 0 1.2rem; font-size:.95rem; }
.vp-muted{ color:var(--ash,#9a9aa5); }
.vp-form{ display:flex; flex-direction:column; gap:.9rem; }
.vp-form label{ display:flex; flex-direction:column; gap:.35rem; font-size:.82rem; text-transform:uppercase; letter-spacing:.06em; color:var(--ash,#9a9aa5); font-weight:600; }
.vp-form input,.vp-form select,.vp-form textarea{
	background:rgba(0,0,0,.3); border:1px solid var(--line,rgba(255,255,255,.14)); border-radius:9px;
	color:var(--bone,#f4f4f6); padding:.7rem .8rem; font:inherit; font-size:.95rem; text-transform:none; letter-spacing:0;
}
.vp-form input:focus,.vp-form select:focus,.vp-form textarea:focus{ outline:none; border-color:var(--gold,#d9a441); }
.vp-form .btn{ align-self:flex-start; margin-top:.3rem; }
.vp-form--grid{ display:grid; grid-template-columns:1fr 1fr; gap:.9rem 1.2rem; }
.vp-form--grid .vp-wide{ grid-column:1 / -1; }
@media (max-width:640px){ .vp-form--grid{ grid-template-columns:1fr; } }
.vp-hp{ position:absolute; left:-9999px; height:0; overflow:hidden; }
.vp-link{ color:var(--gold,#d9a441); text-decoration:none; font-size:.85rem; }
.vp-link:hover{ text-decoration:underline; }
.vp-foot{ margin-top:1.6rem; }
.vp-status{ display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; color:var(--ash,#9a9aa5); font-size:.9rem; margin-bottom:1rem; }
.vp-badge{ display:inline-block; padding:.2rem .6rem; border-radius:999px; font-size:.7rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; }
.vp-badge--wait{ background:rgba(217,164,65,.18); color:var(--gold,#d9a441); }
.vp-badge--live{ background:rgba(46,160,67,.18); color:#9be8a8; }

/* Fighter portal — added-fights + video extras */
.vp-linkbtn{ background:none; border:none; cursor:pointer; padding:0; font:inherit; }
.vp-resend{ margin-top:1rem; padding-top:1rem; border-top:1px solid var(--line,rgba(255,255,255,.1)); }
.vp-pendlist{ display:flex; flex-direction:column; gap:.5rem; margin-bottom:1.2rem; }
.vp-pendrow{ display:flex; align-items:center; justify-content:space-between; gap:1rem; background:rgba(0,0,0,.25); border:1px solid var(--line,rgba(255,255,255,.1)); border-radius:9px; padding:.6rem .85rem; font-size:.92rem; }
.fp-bout__play{ display:inline-block; margin-left:.4rem; color:var(--blood,#b32d2e); font-size:.8em; }

/* ========================================================================
 * Matchmaking board
 * ===================================================================== */
.vp-row2{ display:grid; grid-template-columns:1fr 1fr; gap:.9rem; }
.vp-check{ flex-direction:row !important; align-items:center; gap:.5rem !important; text-transform:none !important; letter-spacing:0 !important; font-weight:500 !important; color:var(--bone,#f4f4f6) !important; }
.vp-check input{ width:auto; }
.mm-board-title{ margin:2.4rem 0 1rem; font-family:var(--f-poster,inherit); }
.mm-board{ display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:1.1rem; }
.mm-card{ position:relative; background:var(--panel,#15151b); border:1px solid var(--line,rgba(255,255,255,.1)); border-radius:14px; padding:1.3rem 1.3rem 1.2rem; display:flex; flex-direction:column; gap:.5rem; }
.mm-card--match{ border-color:var(--gold,#d9a441); box-shadow:0 0 0 1px var(--gold,#d9a441) inset; }
.mm-card__badge{ position:absolute; top:-9px; right:14px; background:var(--gold,#d9a441); color:#15151b; font-size:.62rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; padding:.2rem .55rem; border-radius:999px; }
.mm-card__name{ font-family:var(--f-poster,inherit); font-weight:800; font-size:1.18rem; color:var(--bone,#f4f4f6); text-decoration:none; }
.mm-card__name:hover{ color:var(--gold,#d9a441); }
.mm-card__meta{ display:flex; flex-wrap:wrap; gap:.4rem .8rem; align-items:baseline; margin:0; color:var(--ash,#9a9aa5); font-size:.86rem; }
.mm-card__level{ display:inline-block; background:rgba(179,45,46,.18); color:#f0a8a8; padding:.12rem .5rem; border-radius:6px; font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; }
.mm-card__meta small{ opacity:.7; }
.mm-card__rec{ margin:0; font-size:.9rem; color:var(--bone,#f4f4f6); }
.mm-card__notes{ margin:0; font-size:.86rem; color:var(--ash,#9a9aa5); font-style:italic; }
.mm-card__state{ margin-top:.2rem; font-size:.82rem; color:var(--ash,#9a9aa5); font-weight:600; }
.mm-card__state--ok{ color:#9be8a8; }
.btn--sm{ padding:.5rem .9rem; font-size:.8rem; margin-top:.3rem; align-self:flex-start; }
@media (max-width:520px){ .vp-row2{ grid-template-columns:1fr; } }

/* Matchmaking — filters, tale-of-the-tape, warnings, homepage teaser */
.mm-filters{ display:flex; flex-wrap:wrap; gap:1rem; align-items:flex-end; margin-bottom:1.2rem; padding:1rem 1.1rem; background:var(--panel,#15151b); border:1px solid var(--line,rgba(255,255,255,.1)); border-radius:12px; }
.mm-filters label{ display:flex; flex-direction:column; gap:.3rem; font-size:.74rem; text-transform:uppercase; letter-spacing:.06em; color:var(--ash,#9a9aa5); font-weight:700; }
.mm-filters select,.mm-filters input{ background:rgba(0,0,0,.3); border:1px solid var(--line,rgba(255,255,255,.14)); border-radius:8px; color:var(--bone,#f4f4f6); padding:.5rem .6rem; font:inherit; font-size:.9rem; }
.mm-card__cat{ display:inline-block; color:var(--ash,#9a9aa5); font-size:.74rem; text-transform:uppercase; letter-spacing:.05em; }
.mm-card__warn{ margin:0; font-size:.78rem; font-weight:700; color:#e0a23a; }
.mm-tote{ margin-top:.2rem; }
.mm-tote summary{ cursor:pointer; color:var(--gold,#d9a441); font-size:.82rem; font-weight:600; }
.mm-tote__tbl{ width:100%; border-collapse:collapse; margin-top:.5rem; font-size:.82rem; }
.mm-tote__tbl th{ color:var(--ash,#9a9aa5); font-weight:600; text-transform:uppercase; letter-spacing:.05em; font-size:.66rem; text-align:center; padding:.25rem .4rem; }
.mm-tote__tbl thead th{ color:var(--bone,#f4f4f6); font-size:.8rem; text-transform:none; letter-spacing:0; }
.mm-tote__tbl td{ text-align:center; padding:.25rem .4rem; color:var(--bone,#f4f4f6); font-variant-numeric:tabular-nums; border-top:1px solid var(--line,rgba(255,255,255,.08)); }
.bouts-wanted .bw-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:.9rem; }
.bw-card{ display:flex; flex-direction:column; gap:.25rem; padding:1rem 1.1rem; background:var(--panel,#15151b); border:1px solid var(--line,rgba(255,255,255,.1)); border-radius:12px; text-decoration:none; transition:border-color .18s, transform .18s; }
.bw-card:hover{ border-color:var(--gold,#d9a441); transform:translateY(-2px); }
.bw-card__name{ font-family:var(--f-poster,inherit); font-weight:800; color:var(--bone,#f4f4f6); }
.bw-card__meta{ color:var(--ash,#9a9aa5); font-size:.8rem; }

/* Matchmaking — how it works explainer */
.mm-how{ background:var(--panel,#15151b); border:1px solid var(--line,rgba(255,255,255,.1)); border-radius:16px; padding:1.8rem 1.6rem; margin:0 0 2rem; }
.mm-how__title{ font-family:var(--f-poster,inherit); font-weight:800; margin:0 0 .25rem; color:var(--bone,#f4f4f6); }
.mm-how__lead{ color:var(--ash,#9a9aa5); margin:0 0 1.5rem; }
.mm-how__steps{ list-style:none; margin:0 0 1.5rem; padding:0; display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:1.1rem; counter-reset:none; }
.mm-how__step{ position:relative; padding:1.15rem 1.1rem 1.2rem; background:rgba(255,255,255,.02); border:1px solid var(--line,rgba(255,255,255,.08)); border-radius:12px; }
.mm-how__num{ position:absolute; top:-13px; left:14px; width:26px; height:26px; border-radius:50%; background:var(--gold,#d9a441); color:#15151b; font-weight:800; font-size:.85rem; display:flex; align-items:center; justify-content:center; }
.mm-how__icon{ display:block; color:var(--gold,#d9a441); margin:.4rem 0 .55rem; }
.mm-how__icon svg{ width:30px; height:30px; }
.mm-how__step h4{ margin:0 0 .3rem; font-size:1rem; color:var(--bone,#f4f4f6); }
.mm-how__step p{ margin:0; font-size:.86rem; color:var(--ash,#9a9aa5); line-height:1.5; }
.mm-how__cta{ display:flex; flex-wrap:wrap; align-items:center; gap:1rem; }
.mm-how__note{ color:var(--ash,#9a9aa5); font-size:.82rem; }
