/*
 * Canonical league classification and country identity.
 */

:root {
  --fbb-league-primary:#00b1ff;
  --fbb-league-secondary:#00ff87;

  --fbb-league-primary-rgb:
    0,177,255;

  --fbb-league-secondary-rgb:
    0,255,135;
}


/* =========================================================
   SUBTLE COUNTRY IDENTITY
   ========================================================= */

.fbb-league-themed-card {
  position:relative;
  overflow:hidden;

  border-top:
    3px solid
    var(--fbb-league-primary) !important;

  background:
    linear-gradient(
      135deg,
      rgba(
        var(--fbb-league-primary-rgb),
        .10
      ) 0%,
      rgba(30,30,30,.98) 31%,
      rgba(30,30,30,.98) 72%,
      rgba(
        var(--fbb-league-secondary-rgb),
        .055
      ) 100%
    ) !important;
}


.fbb-league-themed-card::after {
  content:"";

  position:absolute;
  z-index:0;
  top:0;
  right:0;

  width:150px;
  height:90px;

  pointer-events:none;

  background:
    radial-gradient(
      circle at top right,
      rgba(
        var(--fbb-league-secondary-rgb),
        .12
      ),
      transparent 68%
    );
}


.fbb-league-themed-card >
* {
  position:relative;
  z-index:1;
}


.fbb-league-identity {
  width:max-content;
  max-width:100%;

  margin:
    0 0 11px;

  padding:
    6px 10px;

  display:inline-flex;
  align-items:center;
  gap:7px;

  overflow:hidden;

  border:
    1px solid
    rgba(
      var(--fbb-league-primary-rgb),
      .42
    );

  border-radius:
    999px;

  color:#ffffff;

  background:
    linear-gradient(
      90deg,
      rgba(
        var(--fbb-league-primary-rgb),
        .18
      ),
      rgba(
        var(--fbb-league-secondary-rgb),
        .10
      )
    );

  font-size:11px;
  font-weight:900;
  line-height:1;
  letter-spacing:.04em;
  text-transform:uppercase;
}


.fbb-league-identity-flag {
  font-size:16px;
  line-height:1;
}


.fbb-league-identity-name {
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}


/* =========================================================
   CANONICAL POSITION SUMMARY
   ========================================================= */

#fbbCanonicalPositionSummary {
  margin:
    0 0 15px;

  padding:
    10px 12px;

  display:grid;
  grid-template-columns:
    minmax(0,1fr)
    auto
    minmax(0,1fr);

  align-items:center;
  gap:10px;

  border:
    1px solid
    rgba(
      var(--fbb-league-primary-rgb),
      .25
    );

  border-radius:
    12px;

  background:
    rgba(0,0,0,.22);
}


.fbb-position-team {
  min-width:0;

  display:flex;
  align-items:center;
  gap:8px;
}


.fbb-position-team:last-child {
  justify-content:flex-end;
  text-align:right;
}


.fbb-position-team img {
  width:25px;
  height:25px;
  min-width:25px;

  object-fit:contain;
}


.fbb-position-team-text {
  min-width:0;
}


.fbb-position-team-name {
  display:block;

  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;

  color:#ffffff;

  font-size:12px;
  font-weight:900;
}


.fbb-position-team-data {
  display:block;

  margin-top:2px;

  color:#aeb8c2;

  font-size:10px;
  font-weight:750;
}


.fbb-position-versus {
  color:
    var(--fbb-league-secondary);

  font-size:10px;
  font-weight:950;
  text-transform:uppercase;
}


/* =========================================================
   SAME CANONICAL TABLE SOURCE
   ========================================================= */

.fbb-canonical-league-table {
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;

  border-collapse:collapse;
  table-layout:fixed;
}


.fbb-canonical-league-table th,
.fbb-canonical-league-table td {
  padding:
    9px 6px;

  border-bottom:
    1px solid
    rgba(255,255,255,.07);

  color:#dfe6eb;

  font-size:11px;
  text-align:center;
}


.fbb-canonical-league-table th {
  color:
    var(--fbb-league-primary);

  background:
    rgba(0,0,0,.24);

  font-weight:950;
  white-space:nowrap;
}


.fbb-canonical-league-table
th:nth-child(2),

.fbb-canonical-league-table
td:nth-child(2) {
  text-align:left;
}


.fbb-canonical-league-table
.fbb-col-rank {
  width:36px;
}


.fbb-canonical-league-table
.fbb-col-team {
  width:auto;
}


.fbb-canonical-league-table
.fbb-col-form {
  width:110px;
}


.fbb-canonical-league-table
.fbb-col-small {
  width:43px;
}


.fbb-canonical-league-table
.fbb-col-goals {
  width:62px;
}


.fbb-canonical-league-table
.fbb-col-points {
  width:48px;
}


.fbb-canonical-team {
  min-width:0;

  display:flex;
  align-items:center;
  gap:7px;
}


.fbb-canonical-team img {
  width:21px;
  height:21px;
  min-width:21px;

  object-fit:contain;
}


.fbb-canonical-team span {
  min-width:0;

  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;

  color:#ffffff;
  font-weight:850;
}


.fbb-canonical-current-team td {
  background:
    linear-gradient(
      90deg,
      rgba(
        var(--fbb-league-primary-rgb),
        .15
      ),
      rgba(
        var(--fbb-league-secondary-rgb),
        .07
      )
    ) !important;
}


.fbb-canonical-current-team
.fbb-canonical-team span {
  color:
    var(--fbb-league-secondary);
}


.fbb-canonical-form {
  display:flex;
  justify-content:center;
  gap:3px;

  white-space:nowrap;
}


.fbb-canonical-form-chip {
  width:18px;
  height:18px;
  min-width:18px;

  display:inline-flex;
  align-items:center;
  justify-content:center;

  border-radius:5px;

  font-size:9px;
  font-weight:950;
  line-height:1;
}


.fbb-canonical-form-chip.is-win {
  color:#05140c;
  background:#00ff87;
}


.fbb-canonical-form-chip.is-draw {
  color:#1a1100;
  background:#ffbf3f;
}


.fbb-canonical-form-chip.is-loss {
  color:#ffffff;
  background:#e94f64;
}


/* =========================================================
   FULL RANKINGS CHART
   ========================================================= */

#fbbCanonicalLeagueRanking {
  margin:
    18px 0;

  padding:
    18px;

  border:
    1px solid
    rgba(255,255,255,.08);

  border-radius:
    16px;
}


.fbb-canonical-ranking-heading {
  margin-bottom:14px;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}


.fbb-canonical-ranking-heading h2 {
  margin:0;

  color:#ffffff;

  font-size:
    clamp(18px,2vw,24px);
}


.fbb-canonical-ranking-source {
  color:#84909b;

  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
}


.fbb-canonical-ranking-wrap {
  width:100%;
  max-width:100%;

  overflow-x:auto;

  -webkit-overflow-scrolling:
    touch;
}


#fbbCanonicalLeagueRanking
.fbb-canonical-league-table {
  min-width:720px;
}


/*
 * Old independent ranking source is hidden only after the canonical
 * table has rendered successfully.
 */
.fbb-old-ranking-hidden {
  display:none !important;
}


/* =========================================================
   MOBILE
   ========================================================= */

@media(max-width:650px) {
  #fbbCanonicalPositionSummary {
    grid-template-columns:
      minmax(0,1fr)
      minmax(0,1fr);

    gap:9px;
  }

  .fbb-position-versus {
    display:none;
  }

  .fbb-position-team:last-child {
    justify-content:flex-start;
    text-align:left;
  }

  .fbb-canonical-league-table
  .fbb-col-rank {
    width:30px;
  }

  .fbb-canonical-league-table
  .fbb-col-form {
    width:87px;
  }

  .fbb-canonical-league-table
  .fbb-col-small {
    width:36px;
  }

  .fbb-canonical-league-table
  .fbb-col-points {
    width:41px;
  }

  .fbb-canonical-league-table th,
  .fbb-canonical-league-table td {
    padding:
      8px 3px;

    font-size:10px;
  }

  .fbb-canonical-form {
    gap:2px;
  }

  .fbb-canonical-form-chip {
    width:15px;
    height:15px;
    min-width:15px;

    font-size:8px;
  }

  #fbbCanonicalLeagueRanking {
    padding:
      14px;
  }
}


/* =========================================================
   UNIVERSAL PREMIUM PALETTE OVERRIDE
   ========================================================= */

:root {
  --fbb-league-primary:#7dd3fc;
  --fbb-league-secondary:#a78bfa;
  --fbb-league-accent:#5eead4;

  --fbb-league-primary-rgb:
    125,211,252;

  --fbb-league-secondary-rgb:
    167,139,250;

  --fbb-league-accent-rgb:
    94,234,212;

  --fbb-premium-surface:
    #151922;

  --fbb-premium-surface-soft:
    #1b2130;

  --fbb-premium-border:
    rgba(148,163,184,.16);

  --fbb-premium-muted:
    #94a3b8;
}


.fbb-league-themed-card {
  border:
    1px solid
    var(--fbb-premium-border) !important;

  border-top:
    1px solid
    rgba(
      var(--fbb-league-primary-rgb),
      .38
    ) !important;

  box-shadow:
    0 18px 55px
    rgba(0,0,0,.22);

  background:
    linear-gradient(
      145deg,
      rgba(
        var(--fbb-league-primary-rgb),
        .055
      ) 0%,
      rgba(21,25,34,.985) 30%,
      rgba(21,25,34,.985) 68%,
      rgba(
        var(--fbb-league-secondary-rgb),
        .055
      ) 100%
    ) !important;
}


.fbb-league-themed-card::before {
  content:"";

  position:absolute;
  z-index:0;
  top:0;
  left:22px;
  right:22px;

  height:1px;

  background:
    linear-gradient(
      90deg,
      transparent,
      rgba(
        var(--fbb-league-primary-rgb),
        .7
      ),
      rgba(
        var(--fbb-league-secondary-rgb),
        .65
      ),
      transparent
    );
}


.fbb-league-themed-card::after {
  width:210px;
  height:150px;

  opacity:.72;

  background:
    radial-gradient(
      circle at top right,
      rgba(
        var(--fbb-league-secondary-rgb),
        .12
      ),
      transparent 68%
    );
}


.fbb-league-identity {
  padding:
    7px 11px;

  gap:8px;

  border:
    1px solid
    rgba(
      var(--fbb-league-primary-rgb),
      .24
    );

  color:#dbeafe;

  background:
    linear-gradient(
      90deg,
      rgba(
        var(--fbb-league-primary-rgb),
        .10
      ),
      rgba(
        var(--fbb-league-secondary-rgb),
        .08
      )
    );

  box-shadow:
    inset 0 1px 0
    rgba(255,255,255,.025);

  letter-spacing:.055em;
}


.fbb-league-identity-flag {
  display:none !important;
}


.fbb-league-identity-mark {
  width:7px;
  height:7px;
  min-width:7px;

  display:inline-block;

  border-radius:50%;

  background:
    linear-gradient(
      135deg,
      var(--fbb-league-primary),
      var(--fbb-league-secondary)
    );

  box-shadow:
    0 0 12px
    rgba(
      var(--fbb-league-primary-rgb),
      .55
    );
}


#fbbCanonicalPositionSummary {
  border:
    1px solid
    rgba(
      var(--fbb-league-primary-rgb),
      .15
    );

  background:
    linear-gradient(
      135deg,
      rgba(8,12,20,.62),
      rgba(20,24,34,.72)
    );

  box-shadow:
    inset 0 1px 0
    rgba(255,255,255,.025);
}


.fbb-position-versus {
  color:
    var(--fbb-league-primary);
}


.fbb-canonical-league-table th {
  color:#bae6fd;

  background:
    linear-gradient(
      180deg,
      rgba(
        var(--fbb-league-primary-rgb),
        .07
      ),
      rgba(8,12,20,.44)
    );
}


.fbb-canonical-league-table th,
.fbb-canonical-league-table td {
  border-bottom:
    1px solid
    rgba(148,163,184,.09);
}


.fbb-canonical-current-team td {
  background:
    linear-gradient(
      90deg,
      rgba(
        var(--fbb-league-primary-rgb),
        .12
      ),
      rgba(
        var(--fbb-league-secondary-rgb),
        .07
      )
    ) !important;
}


.fbb-canonical-current-team
.fbb-canonical-team span {
  color:
    var(--fbb-league-accent);
}


.fbb-canonical-ranking-heading h2 {
  background:
    linear-gradient(
      90deg,
      #ffffff,
      #bae6fd,
      #ddd6fe
    );

  -webkit-background-clip:text;
  background-clip:text;

  color:transparent;
}


.fbb-canonical-ranking-source {
  color:
    var(--fbb-premium-muted);
}


.fbb-canonical-form-chip.is-win {
  color:#042f2e;
  background:#5eead4;
}


.fbb-canonical-form-chip.is-draw {
  color:#261801;
  background:#fbbf24;
}


.fbb-canonical-form-chip.is-loss {
  color:#ffffff;
  background:#f43f5e;
}


#fbbCanonicalLeagueRanking {
  border:
    1px solid
    rgba(148,163,184,.14);

  box-shadow:
    0 22px 65px
    rgba(0,0,0,.18);
}


/* FBB SINGLE RANKING SAFETY */

#fbbCanonicalLeagueRanking,
[data-fbb-duplicate-ranking="1"],
[data-fbb-replaced-by-canonical="1"] {
  display:none !important;
}



/* =========================================================
   POSITION SUMMARY PLACEMENT
   ========================================================= */

#fbbLeagueIntelligence
#fbbCanonicalPositionSummary {
  width:100%;

  margin:
    14px 0 12px !important;

  padding:
    12px 14px;

  border:
    1px solid
    rgba(56,189,248,.14) !important;

  border-radius:
    13px;

  background:
    linear-gradient(
      135deg,
      rgba(56,189,248,.055),
      rgba(18,24,35,.78),
      rgba(139,92,246,.045)
    ) !important;

  box-shadow:
    inset 0 1px 0
    rgba(255,255,255,.025);
}


#fbbCanonicalPositionSummary
.fbb-position-team-name {
  color:#f8fafc !important;

  font-weight:800;
}


#fbbCanonicalPositionSummary
.fbb-position-team-data {
  color:#8a98aa !important;

  font-size:11px;
}


#fbbCanonicalPositionSummary
.fbb-position-versus {
  color:#38bdf8 !important;

  font-size:10px;
  font-weight:850;
  letter-spacing:.06em;
  text-transform:uppercase;
}


@media(max-width:620px) {
  #fbbLeagueIntelligence
  #fbbCanonicalPositionSummary {
    padding:
      10px 8px;
  }

  #fbbCanonicalPositionSummary
  .fbb-position-team-name {
    font-size:11px;
  }

  #fbbCanonicalPositionSummary
  .fbb-position-team-data {
    font-size:9px;
  }

  #fbbCanonicalPositionSummary
  .fbb-position-versus {
    font-size:8px;
  }
}
