/*#region Category cards */
.cat-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    align-items: start;
    gap: 10px;

    @media (max-width: 540px) {
        grid-template-columns: 1fr;
    }
}

.cat-cards-col {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cat-card {
    border: 1px solid var(--gray-darker);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.cat-card-header {
    background-color: var(--black-lighter);
    color: var(--white);
    padding: 10px 14px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
}

.cat-card-name {
    font-weight: bold;
}

.cat-card-years {
    font-size: var(--font-small);
    color: var(--gray-dark);
    background-color: var(--black);
    padding: 2px 9px;
    border-radius: 10px;
    white-space: nowrap;
    flex-shrink: 0;
}

.cat-card-body {
    padding: 6px 14px;
}

.cat-card-row {
    display: flex;
    align-items: baseline;
    gap: 10px;
    padding: 5px 0;
    border-bottom: 1px solid var(--gray-lighter);
    font-size: var(--font-small);
}

.cat-card-row:last-child {
    border-bottom: none;
}

.cat-card-label {
    font-weight: bold;
    font-size: var(--font-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--gray-dark);
    min-width: 90px;
    flex-shrink: 0;
}

.cat-card-competitions {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.cat-card-empty {
    font-size: var(--font-small);
    color: var(--gray-dark);
    margin: 0;
    padding: 4px 0;
}

.cat-card-competition-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    border: 1px solid var(--gray-darker);
    border-radius: var(--radius);
    background-color: var(--gray);
    color: var(--black);
    text-decoration: none;
    gap: 8px;
    transition: background-color var(--transition-fast) ease;
}

.cat-card-competition-btn:hover {
    background-color: var(--gray-darker);
}

.cat-card-competition-btn--live {
    border-color: var(--red);
}

.cat-card-competition-btn--scheduled {
    border-color: var(--blue);
}

.cat-card-competition-btn--scheduled .comp-btn-status-text {
    color: var(--blue);
}

.cat-card-competition-btn--next {
    border-color: #6e9428;
}

.cat-card-competition-btn--next .comp-btn-status-text {
    color: #6e9428;
}

.cat-card-competition-btn--completed {
    border-color: var(--gray-dark);
}

.comp-btn-content {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}

.comp-btn-label {
    font-weight: 600;
    font-size: var(--font-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.comp-btn-tatami {
    font-size: var(--font-xs);
    color: var(--gray-dark);
}

.comp-btn-meta {
    display: flex;
    align-items: center;
    gap: 6px;
}

.comp-btn-live {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-xs);
    color: var(--red);
    font-weight: 600;
}

.comp-btn-live-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: var(--red);
    flex-shrink: 0;
}

.comp-btn-status-text {
    font-size: var(--font-xs);
    color: var(--gray-dark);
}

.comp-btn-right {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
    color: var(--gray-dark);
}

.comp-btn-players {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: var(--font-xs);
}

.comp-btn-players .icon {
    width: 13px;
    height: 13px;
}

.comp-btn-arrow {
    font-size: 1.2em;
    line-height: 1;
}
.competition-match-list {
    margin-top: 24px;
}

.tatami-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 20px;
}
.tatami-bar-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--gray);
    border: 1px solid var(--gray-darker);
    border-radius: 8px;
    text-decoration: none;
    color: var(--black);
    font-size: var(--font-small);
    font-weight: 500;
    transition: background var(--transition-fast);
}
.tatami-bar-btn:hover {
    background: var(--gray-darker);
}
.tatami-bar-name {
    font-weight: 600;
}

.standings-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.standings-table {
    display: grid;
    grid-template-columns: 32px auto auto 40px 40px 56px 44px;
}
.standings-row {
    display: grid;
    grid-column: 1 / -1;
    grid-template-columns: subgrid;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: var(--radius-lg);
}
.standings-row--header {
    font-size: var(--font-small);
    color: var(--gray-dark);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.standings-row:not(.standings-row--header):nth-child(even) {
    background: var(--gray-lighter);
}
.standings-col-rank {
    color: var(--gray-dark);
    font-size: var(--font-small);
}
.standings-col-name {
    font-weight: 500;
    white-space: nowrap;
}
.standings-col-club {
    font-size: var(--font-small);
    color: var(--gray-dark);
    white-space: nowrap;
}
.standings-col-stat {
    text-align: center;
    font-variant-numeric: tabular-nums;
}

.standings-col-stat--wins {
    font-weight: 600;
    color: var(--gray-darkest, #1a1a1a);
}

.bracket {
    display: flex;
    gap: 0;
    overflow-x: auto;
    padding: 0 4px 12px 4px;
    align-items: stretch;
    min-height: 400px;  /* fallback (== r1=4); see .bracket--r1-* variants */
}

/* Per-round-1-count height variants. Single-elimination round-1 sizes are
   powers of 2 (1, 2, 4, 8, 16, 32, 64) covering brackets of 2–128 players.
   Each match needs ~100px of vertical space. */
.bracket--r1-1  { min-height: 100px; }
.bracket--r1-2  { min-height: 200px; }
.bracket--r1-4  { min-height: 400px; }
.bracket--r1-8  { min-height: 800px; }
.bracket--r1-16 { min-height: 1600px; }
.bracket--r1-32 { min-height: 3200px; }
.bracket--r1-64 { min-height: 6400px; }
.bracket-round {
    display: flex;
    flex-direction: column;
    min-width: 240px;
    flex: 1;
    padding: 0 8px;
    border-left: 1px solid var(--black-lighter);
}
.bracket-round:first-child {
    border-left: none;
    padding-left: 0;
}
.bracket-round-label {
    font-size: var(--font-small);
    color: var(--gray-dark);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding-bottom: 8px;
    flex-shrink: 0;
}
.bracket-matches {
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    flex: 1;
    gap: 12px;
}
.bracket-final-group {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.bracket-final-group .bracket-matches {
    flex: 0;
    justify-content: flex-start;
    gap: 0;
}
.bracket-third-place {
    flex-shrink: 0;
    padding-top: 32px;
}
.bracket-match-label {
    font-size: 0.7em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 2px 8px;
    text-align: center;
    color: var(--gray-dark);
    background: var(--bracket-border);
}
.bracket-match {
    display: flex;
    flex-direction: column;
    border: 2px solid var(--bracket-border);
    border-radius: var(--radius-lg);
    overflow: visible;
    text-decoration: none;
    transition: border-color var(--transition-fast);
}
.bracket-match:hover {
    border-color: var(--bracket-border-hover);
}
.bracket-match--bye {
    pointer-events: none;
    border-color: var(--bracket-border-bye);
    opacity: 0.5;
}
.bracket-match[data-status="2"] {
    border-color: var(--bracket-border-scheduled);
}
.bracket-match[data-status="2"]:hover {
    border-color: var(--bracket-border-scheduled-hover);
}
.bracket-match[data-status="3"] {
    border-color: var(--bracket-border-live);
}
.bracket-match[data-status="3"]:hover {
    border-color: var(--bracket-border-live-hover);
}
.bracket-match[data-status="4"] {
    border-color: var(--bracket-border-done);
}
.bracket-match[data-status="4"]:hover {
    border-color: var(--bracket-border-done-hover);
}
.bracket-match-status {
    font-size: 0.7em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 2px 8px;
    text-align: center;
    transition: background var(--transition-fast);
}
.bracket-match[data-status="1"] .bracket-match-status {
    background: var(--bracket-border);
}
.bracket-match[data-status="1"]:hover .bracket-match-status {
    background: var(--bracket-border-hover);
}
.bracket-match[data-status="2"] .bracket-match-status {
    color: #fff;
    background: var(--bracket-border-scheduled);
}
.bracket-match[data-status="2"]:hover .bracket-match-status {
    background: var(--bracket-border-scheduled-hover);
}
.bracket-match[data-status="3"] .bracket-match-status {
    color: #fff;
    background: var(--bracket-border-live);
}
.bracket-match[data-status="3"]:hover .bracket-match-status {
    background: var(--bracket-border-live-hover);
}
.bracket-match[data-status="4"] .bracket-match-status {
    color: #fff;
    background: var(--bracket-border-done);
}
.bracket-match[data-status="4"]:hover .bracket-match-status {
    background: var(--bracket-border-done-hover);
}
.bracket-match[data-status="5"] .bracket-match-status {
    color: var(--gray-dark);
    background: var(--bracket-border);
}
.bracket-match[data-status="5"]:hover .bracket-match-status {
    background: var(--bracket-border-hover);
    color: #fff;
}
.bracket-competitor--empty {
    background: var(--gray);
}
.bracket-competitor--empty .bracket-competitor-name { color: var(--gray-dark); }
.bracket-competitor {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    font-size: var(--font-xs);
    color: var(--black);
    background: var(--bracket-card-bg);
    /* border-bottom: 1px solid var(--gray); */
    transition: background var(--transition-fast);
}
.bracket-match:hover .bracket-competitor {
    background: var(--bracket-card-bg-hover);
}
.bracket-competitor:last-child {
    border-bottom: none;
}
.bracket-competitor--winner {
    background: var(--bracket-card-bg-winner);
}
.bracket-match:hover .bracket-competitor--winner {
    background: var(--bracket-card-bg-winner-hover);
}
.bracket-competitor--winner .bracket-competitor-name {
    color: var(--primary);
    font-weight: 600;
}
.bracket-competitor--loser {
    background: var(--bracket-card-bg-loser);
}
.bracket-match:hover .bracket-competitor--loser {
    background: var(--bracket-card-bg-loser-hover);
}
.bracket-competitor--loser .bracket-competitor-score {
    opacity: 0.6;
}
.bracket-competitor-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}.bracket-competitor-score {
    flex-shrink: 0;
    font-weight: 500;
    font-variant-numeric: tabular-nums;
    color: var(--gray-dark);
}
.top3 {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 28px;
}
.top3-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    border-radius: var(--radius-lg);
    background: var(--gray-lighter);
}
.top3-row--first {
    background: rgba(212, 175, 55, 0.12);
}
.top3-row--second {
    background: rgba(160, 160, 160, 0.12);
}
.top3-row--third {
    background: rgba(176, 110, 55, 0.1);
}
.top3-rank {
    width: 20px;
    flex-shrink: 0;
    font-size: var(--font-small);
    color: var(--gray-dark);
    font-weight: 600;
    text-align: center;
}
.top3-name {
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}
.top3-club {
    font-size: var(--font-small);
    color: var(--gray-dark);
    flex-shrink: 0;
}
/*#endregion */
/*#region Matches tab (event detail) */
.competition-profile-hero {
    padding-bottom: 0;
}
.competition-profile-hero .event-hero-logo,
.competition-profile-hero .event-hero-logo-placeholder {
    width: 80px;
    height: 120px;
}

.competition-hero-title {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.competition-hero-meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: var(--font-small);
    font-weight: 400;
    color: var(--white);
}
.competition-hero-meta-row {
    display: flex;
    align-items: center;
    gap: 8px;
}

.match-row {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    grid-template-rows: auto auto;
    column-gap: 20px;
    row-gap: 4px;
    padding: 8px 12px;
    border-radius: var(--radius-lg);
    text-decoration: none;
    color: var(--black);
    background: var(--gray);
    border: 1px solid var(--gray-darker);
    transition: background var(--transition-fast);
}
.match-row:hover {
    background: var(--gray-darker);
}
.match-row--status-0 { border-left: 3px solid var(--gray-dark); }
.match-row--status-1 { border-left: 3px solid var(--gray-dark); }
.match-row--status-2 { border-left: 3px solid var(--blue); }
.match-row--status-3 { border-left: 3px solid var(--green); }
.match-row--status-4 { border-left: 3px solid var(--red); }
.match-row--status-5 { border-left: 3px solid var(--gray-dark); }.match-row--round-start { margin-top: 16px; }

.match-list-section-divider {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 0 4px;
    margin-top: 16px;
    font-size: var(--font-xs);
    font-weight: 600;
    color: var(--gray-dark);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-top: 1px solid var(--border);
}
.match-list-section-done {
    font-size: var(--font-xs);
    font-weight: 500;
    color: var(--gray-dark);
    text-transform: none;
    letter-spacing: 0;
    opacity: 0.7;
}
.match-list-section-divider--sub {
    margin-top: 8px;
    border-top: none;
    padding-top: 4px;
    opacity: 0.7;
}
.match-list-section-meta {
    margin-left: 4px;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    opacity: 0.7;
}

.match-row-round-label {
    grid-column: 1;
    grid-row: 1;
    font-size: var(--font-xs);
    color: var(--gray-dark);
    align-self: center;
}
.match-row-status {
    grid-column: 3;
    grid-row: 1;
    justify-self: end;
    align-self: center;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 6px;
}
.match-row-tatami-chip {
    font-size: var(--font-xs);
    font-weight: 500;
    color: var(--gray-dark);
    background: var(--border);
    padding: 1px 5px;
    border-radius: 3px;
    text-transform: none;
    letter-spacing: 0;
}

.match-row-name {
    font-size: var(--font-normal);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    grid-row: 2;
    align-self: center;
}
.match-row-name--left {
    text-align: right;
    grid-column: 1;
}
.match-row-name--right {
    text-align: left;
    grid-column: 3;
}
.match-row-name--winner {
    color: var(--primary);
    font-weight: 500;
}
.match-row-name[data-participant-id=""] { color: var(--gray-dark); }
.match-row--status-5 .match-row-name:not(.match-row-name--winner) {
    opacity: 0.5;
}

.match-row-score-numbers {
    grid-column: 2;
    grid-row: 2;
    justify-self: center;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: var(--font-large);
    font-weight: 500;
    font-variant-numeric: tabular-nums;
}
.match-row-score-sep {
    color: var(--gray-dark);
}
.match-row-status-state {
    display: inline-block;
    padding: 1px 6px;
    border-radius: 3px;
    background: var(--gray-darker);
    color: var(--gray-dark);
    font-size: 0.7em;
    font-weight: 700;
    letter-spacing: 0.03em;
    line-height: 1.4;
    text-transform: uppercase;
}
.match-row--status-1 .match-row-status-state { background: var(--bracket-border); }
.match-row--status-2 .match-row-status-state { background: var(--bracket-border-scheduled); color: #fff; }
.match-row--status-3 .match-row-status-state { background: var(--bracket-border-live); color: #fff; }
.match-row--status-4 .match-row-status-state { background: var(--bracket-border-done); color: #fff; }
.match-row--status-5 .match-row-status-state { background: var(--bracket-border); color: var(--gray-dark); }

@keyframes match-highlight-pulse {
    0%, 40% {
        box-shadow: 0 0 0 3px var(--primary), 0 0 24px var(--primary);
        background-color: rgba(var(--primary-rgb), 0.12);
    }
    100% {
        box-shadow: none;
        background-color: transparent;
    }
}
.match-highlight,
.bracket-match.match-highlight {
    animation: match-highlight-pulse 2.4s ease-out forwards;
}

/*#endregion */
