/* ===========================================================================
   Pixel Gaming — dark neon esports theme
   =========================================================================== */
:root {
    --bg-0: #07070f;
    --bg-1: #0c0c18;
    --bg-2: #121226;
    --panel: rgba(20, 20, 38, 0.78);
    --panel-solid: #14142a;
    --border: rgba(124, 92, 255, 0.22);
    --border-strong: rgba(124, 92, 255, 0.55);

    --neon-purple: #a855f7;
    --neon-violet: #7c5cff;
    --neon-cyan: #22e6ff;
    --neon-magenta: #ff2bd6;

    --text: #e8e8f5;
    --text-dim: #9a9ab8;

    --grad-main: linear-gradient(135deg, #7c5cff 0%, #b026ff 45%, #ff2bd6 100%);
    --grad-cyan: linear-gradient(135deg, #22e6ff 0%, #7c5cff 100%);

    --radius: 14px;
    --font-head: 'Orbitron', sans-serif;
    --font-body: 'Rajdhani', 'Segoe UI', sans-serif;
    --font-pixel: 'Press Start 2P', monospace;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    background-color: var(--bg-0);
    background-image:
        radial-gradient(900px 500px at 12% -10%, rgba(124, 92, 255, 0.18), transparent 60%),
        radial-gradient(800px 480px at 100% 0%, rgba(255, 43, 214, 0.12), transparent 55%),
        linear-gradient(180deg, var(--bg-1), var(--bg-0));
    color: var(--text);
    font-family: var(--font-body);
    font-size: 1.05rem;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

a { color: var(--neon-cyan); text-decoration: none; transition: color .15s ease; }
a:hover { color: #fff; }

h1, h2, h3, h4, h5 { font-family: var(--font-head); letter-spacing: .5px; color: #fff; }

.pg-main { flex: 1 0 auto; padding-bottom: 3rem; }

.text-dim { color: var(--text-dim); }
.pg-section-title {
    font-family: var(--font-head);
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 2px;
}

/* ----------------------------- Navbar ----------------------------------- */
.pg-navbar {
    background: rgba(7, 7, 15, 0.82);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border);
    padding-top: .6rem;
    padding-bottom: .6rem;
}
.pg-brand { display: flex; align-items: center; gap: .6rem; }
.pg-logo-text {
    font-family: var(--font-head);
    font-weight: 900;
    font-size: 1.25rem;
    letter-spacing: 1px;
    color: #fff;
}
.pg-logo-accent {
    background: var(--grad-main);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
/* pixel logo mark — 3x3 glowing grid */
.pg-logo-mark {
    display: grid;
    grid-template-columns: repeat(3, 7px);
    grid-template-rows: repeat(3, 7px);
    gap: 2px;
}
.pg-logo-mark span {
    width: 7px; height: 7px; border-radius: 1px;
    background: var(--neon-violet);
    box-shadow: 0 0 6px rgba(124, 92, 255, .9);
}
.pg-logo-mark span:nth-child(2) { background: var(--neon-cyan); box-shadow: 0 0 6px var(--neon-cyan); }
.pg-logo-mark span:nth-child(4) { background: var(--neon-cyan); box-shadow: 0 0 6px var(--neon-cyan); }
.pg-logo-mark span:nth-child(5) { background: var(--neon-magenta); box-shadow: 0 0 8px var(--neon-magenta); }
.pg-logo-mark span:nth-child(6) { background: var(--neon-magenta); box-shadow: 0 0 6px var(--neon-magenta); }
.pg-logo-mark span:nth-child(8) { background: var(--neon-magenta); box-shadow: 0 0 6px var(--neon-magenta); }

.pg-navbar .nav-link {
    color: var(--text-dim);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .5px;
    font-size: .92rem;
    position: relative;
}
.pg-navbar .nav-link:hover { color: #fff; }
.pg-navbar .nav-link.pg-admin-link { color: var(--neon-magenta); }
.pg-greeting { color: var(--neon-cyan); font-weight: 600; letter-spacing: .5px; }
.navbar-toggler { border-color: var(--border-strong); border-radius: 8px; padding: .35rem .55rem; }
.navbar-toggler:focus { box-shadow: 0 0 0 .15rem rgba(34,230,255,.35); }
.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%2322e6ff' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* ----------------------------- Buttons ---------------------------------- */
.pg-btn-neon, .pg-btn-ghost {
    font-family: var(--font-head);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: 10px;
    padding: .55rem 1.25rem;
    transition: transform .12s ease, box-shadow .2s ease, filter .2s ease;
}
.pg-btn-neon {
    background: var(--grad-main);
    color: #fff;
    border: none;
    box-shadow: 0 0 18px rgba(176, 38, 255, .45);
}
.pg-btn-neon:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 0 28px rgba(255, 43, 214, .6); filter: brightness(1.08); }
.pg-btn-ghost {
    background: transparent;
    color: var(--neon-cyan);
    border: 1px solid var(--border-strong);
}
.pg-btn-ghost:hover { color: #fff; border-color: var(--neon-cyan); box-shadow: 0 0 16px rgba(34, 230, 255, .4); transform: translateY(-2px); }
.btn-sm.pg-btn-neon, .btn-sm.pg-btn-ghost { padding: .35rem .85rem; font-size: .8rem; }
.pg-btn-danger {
    background: transparent; border: 1px solid rgba(255, 70, 90, .6); color: #ff6076;
    font-family: var(--font-head); text-transform: uppercase; letter-spacing: .5px;
    border-radius: 10px; padding: .35rem .85rem; font-size: .8rem; font-weight: 700;
}
.pg-btn-danger:hover { background: rgba(255, 70, 90, .15); color: #fff; }
.pg-btn-success {
    background: transparent; border: 1px solid rgba(43,255,136,.6); color: #2bff88;
    font-family: var(--font-head); text-transform: uppercase; letter-spacing: .5px;
    border-radius: 10px; padding: .35rem .85rem; font-size: .8rem; font-weight: 700;
}
.pg-btn-success:hover { background: rgba(43,255,136,.15); color: #fff; }

/* ------------------------------ Hero ------------------------------------ */
.pg-hero {
    position: relative;
    overflow: hidden;
    padding: 6rem 0 5rem;
    border-bottom: 1px solid var(--border);
    background:
        linear-gradient(180deg, rgba(7,7,15,.2), rgba(7,7,15,.85)),
        repeating-linear-gradient(0deg, rgba(124,92,255,.06) 0 1px, transparent 1px 40px),
        repeating-linear-gradient(90deg, rgba(124,92,255,.06) 0 1px, transparent 1px 40px);
}
.pg-hero::after {
    content: "";
    position: absolute; inset: 0;
    background: radial-gradient(600px 300px at 70% 30%, rgba(255,43,214,.18), transparent 60%);
    pointer-events: none;
}
.pg-hero-content { position: relative; z-index: 2; }
.pg-hero-tag {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-family: var(--font-pixel);
    font-size: .6rem;
    line-height: 1;
    color: var(--neon-cyan);
    border: 1px solid var(--border-strong);
    border-radius: 999px;
    padding: .55rem .9rem;
    margin-bottom: 1.4rem;
    text-transform: uppercase;
    box-shadow: 0 0 14px rgba(34,230,255,.25);
}
/* arrow comes from a fallback font; center it on the pixel text instead of its own baseline */
.pg-hero-tag .tri { font-size: .9em; line-height: 1; display: inline-flex; }
.pg-hero h1 {
    font-weight: 900;
    font-size: clamp(2.4rem, 6vw, 4.5rem);
    line-height: 1.02;
    text-transform: uppercase;
    text-shadow: 0 0 30px rgba(124,92,255,.5);
}
.pg-hero h1 .grad {
    background: var(--grad-main);
    -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.pg-hero p.lead { color: var(--text-dim); font-size: 1.25rem; max-width: 620px; margin-top: 1rem; }
.pg-hero-actions { margin-top: 2rem; display: flex; gap: 1rem; flex-wrap: wrap; }

.pg-stats { display: flex; gap: 2.5rem; margin-top: 3rem; flex-wrap: wrap; }
.pg-stat .num { font-family: var(--font-head); font-weight: 900; font-size: 2rem; color: #fff; }
.pg-stat .num .grad { background: var(--grad-cyan); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.pg-stat .label { color: var(--text-dim); text-transform: uppercase; letter-spacing: 1px; font-size: .8rem; }

/* ------------------------- Tournament cards ----------------------------- */
.pg-card {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: transform .18s ease, box-shadow .25s ease, border-color .25s ease;
    backdrop-filter: blur(6px);
}
.pg-card:hover {
    transform: translateY(-6px);
    border-color: var(--border-strong);
    box-shadow: 0 12px 40px rgba(124, 92, 255, .28);
}
.pg-card-media {
    position: relative;
    aspect-ratio: 16 / 9;
    background: var(--grad-main);
    overflow: hidden;
}
.pg-card-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pg-card-media .pg-game-chip {
    position: absolute; top: .7rem; left: .7rem;
    background: rgba(7,7,15,.78); border: 1px solid var(--border-strong);
    color: var(--neon-cyan); font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .5px;
    padding: .25rem .6rem; border-radius: 6px;
}
.pg-card-media .pg-badge { position: absolute; top: .7rem; right: .7rem; background: rgba(7,7,15,.78); }
.pg-card-body { padding: 1.1rem 1.2rem 1.3rem; display: flex; flex-direction: column; gap: .55rem; flex: 1; }
.pg-card-title { font-size: 1.2rem; font-weight: 700; line-height: 1.15; }
.pg-card-title a { color: #fff; }
.pg-card-title a:hover { color: var(--neon-cyan); }
.pg-card-meta { color: var(--text-dim); font-size: .9rem; display: flex; flex-wrap: wrap; gap: .25rem .9rem; }
.pg-card-meta .icon { color: var(--neon-violet); }
.pg-card-foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: .5rem; padding-top: .6rem; }
.pg-prize { font-family: var(--font-head); font-weight: 700; color: #fff; }
.pg-prize .grad { background: var(--grad-cyan); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* --------------------------- Status badges ------------------------------ */
.pg-badge {
    font-family: var(--font-head);
    font-size: .68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1px;
    padding: .3rem .65rem; border-radius: 999px;
    border: 1px solid currentColor;
    display: inline-flex; align-items: center; gap: .35rem;
}
.pg-badge::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; box-shadow: 0 0 8px currentColor; }
.pg-badge.upcoming { color: #ffcf4d; }
.pg-badge.open { color: #2bff88; }
.pg-badge.closed { color: #ff6076; }
.pg-badge.finished { color: #9a9ab8; }
.pg-badge.pending { color: #ffcf4d; }
.pg-badge.accepted { color: #2bff88; }
.pg-badge.rejected { color: #ff6076; }

/* ----------------------------- Filters ---------------------------------- */
.pg-filter-bar {
    background: var(--panel); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 1rem 1.2rem; margin-bottom: 1.8rem;
}

/* ------------------------- Panels / forms ------------------------------- */
.pg-panel {
    background: var(--panel); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 1.6rem 1.7rem;
    backdrop-filter: blur(6px);
}
.pg-auth-wrap {
    max-width: 440px;
    margin: 0 auto;
    min-height: calc(100vh - 230px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 2.5rem 0;
}

.form-label { color: var(--text-dim); text-transform: uppercase; font-size: .8rem; letter-spacing: .5px; font-weight: 600; }
.form-control, .form-select {
    background: rgba(7,7,15,.6);
    border: 1px solid var(--border);
    color: var(--text);
    border-radius: 10px;
    padding: .6rem .85rem;
    color-scheme: dark; /* dark native date/time pickers + select dropdowns */
}
.form-control:focus, .form-select:focus {
    background: rgba(7,7,15,.8);
    border-color: var(--neon-violet);
    color: var(--text);
    box-shadow: 0 0 0 .2rem rgba(124, 92, 255, .25);
}
.form-control::placeholder { color: #5b5b7a; }
.form-select option { background: var(--panel-solid); color: var(--text); }
.form-check-input { background-color: rgba(7,7,15,.6); border-color: var(--border-strong); }
.form-check-input:checked { background-color: var(--neon-violet); border-color: var(--neon-violet); }
.text-danger, .field-validation-error { color: #ff6076 !important; font-size: .85rem; }
.validation-summary-errors { color: #ff6076; }
.validation-summary-errors ul { margin: 0; padding-left: 1.1rem; }

/* Themed file picker (was an unstyled light-gray native control) */
input[type="file"].form-control { padding: .35rem .45rem; }
input[type="file"].form-control::file-selector-button {
    font-family: var(--font-head); text-transform: uppercase; letter-spacing: .5px;
    font-weight: 700; font-size: .74rem; color: var(--neon-cyan);
    background: rgba(7,7,15,.7); border: 1px solid var(--border-strong);
    border-radius: 8px; padding: .4rem .85rem; margin-right: .8rem; cursor: pointer;
    transition: color .15s, border-color .15s, box-shadow .15s;
}
input[type="file"].form-control::file-selector-button:hover {
    color: #fff; border-color: var(--neon-cyan); box-shadow: 0 0 12px rgba(34,230,255,.35);
}

/* Drop the native number spinners for a cleaner, on-theme look */
input[type="number"] { -moz-appearance: textfield; }
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* Extra-small buttons for dense action rows (admin tables) */
.pg-btn-xs.pg-btn-ghost, .pg-btn-xs.pg-btn-neon,
.pg-btn-xs.pg-btn-danger, .pg-btn-xs.pg-btn-success { padding: .28rem .6rem; font-size: .72rem; }

/* ------------------------------ Alerts ---------------------------------- */
.pg-alert { border-radius: 10px; border: 1px solid; font-weight: 600; }
.pg-alert-success { background: rgba(43,255,136,.08); border-color: rgba(43,255,136,.5); color: #57ff9e; }
.pg-alert-error { background: rgba(255,70,90,.08); border-color: rgba(255,70,90,.5); color: #ff8090; }

/* --------------------------- Details page ------------------------------- */
.pg-detail-hero {
    position: relative; border-radius: var(--radius); overflow: hidden;
    border: 1px solid var(--border); margin-bottom: 1.6rem;
    aspect-ratio: 21 / 9; background: var(--grad-main);
}
.pg-detail-hero img { width: 100%; height: 100%; object-fit: cover; }
.pg-detail-hero .overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 30%, rgba(7,7,15,.92));
    display: flex; align-items: flex-end; padding: 1.6rem 1.8rem;
}
.pg-slots-bar { height: 12px; border-radius: 999px; background: rgba(255,255,255,.08); overflow: hidden; border: 1px solid var(--border); }
.pg-slots-fill { height: 100%; background: var(--grad-main); box-shadow: 0 0 12px rgba(176,38,255,.6); }
.pg-info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 1rem; }
.pg-info-cell { background: rgba(7,7,15,.5); border: 1px solid var(--border); border-radius: 10px; padding: .9rem 1rem; }
.pg-info-cell .label { color: var(--text-dim); font-size: .72rem; text-transform: uppercase; letter-spacing: 1px; }
.pg-info-cell .value { font-family: var(--font-head); font-weight: 700; font-size: 1.15rem; color: #fff; }

/* ------------------------------ Tables ---------------------------------- */
.pg-table { width: 100%; border-collapse: separate; border-spacing: 0 .5rem; }
.pg-table thead th {
    color: var(--text-dim); text-transform: uppercase; font-size: .75rem; letter-spacing: 1px;
    font-family: var(--font-head); padding: .4rem .9rem; border: none;
}
.pg-table tbody tr { background: var(--panel); }
.pg-table tbody td { padding: .85rem .9rem; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); vertical-align: middle; color: var(--text); }
.pg-table tbody td:first-child { border-left: 1px solid var(--border); border-radius: 10px 0 0 10px; }
.pg-table tbody td:last-child { border-right: 1px solid var(--border); border-radius: 0 10px 10px 0; }
.pg-table tbody tr:hover { background: rgba(124,92,255,.10); }
.pg-thumb { width: 64px; height: 40px; object-fit: cover; border-radius: 6px; border: 1px solid var(--border); }

/* ------------------------------ Footer ---------------------------------- */
.pg-footer {
    flex-shrink: 0;
    border-top: 1px solid var(--border);
    background: rgba(7,7,15,.7);
    padding: 1.4rem 0;
    color: var(--text-dim);
    margin-top: auto;
}
.pg-footer-brand, .pg-footer-note { font-size: .9rem; }
.pg-footer-brand { font-family: var(--font-head); font-weight: 900; color: #fff; }
.pg-footer-link { color: var(--text-dim); }
.pg-footer-link:hover { color: var(--neon-cyan); }

/* ------------------------- Language switcher ---------------------------- */
.pg-lang { font-family: var(--font-head); font-weight: 700; letter-spacing: 1px; font-size: .82rem; }
.pg-lang-link { color: var(--text-dim); padding: 0 .2rem; }
.pg-lang-link:hover { color: #fff; }
.pg-lang-link.active { color: var(--neon-cyan); text-shadow: 0 0 8px rgba(34,230,255,.6); }
.pg-lang-sep { color: var(--border-strong); }

/* ----------------------------- Teams ------------------------------------ */
.pg-emblem {
    width: 84px; height: 84px; border-radius: 14px; object-fit: cover;
    border: 1px solid var(--border-strong); background: rgba(7,7,15,.5);
    box-shadow: 0 0 16px rgba(124,92,255,.3);
}
.pg-emblem-sm { width: 40px; height: 40px; border-radius: 8px; object-fit: cover; border: 1px solid var(--border); }
.pg-emblem-placeholder {
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--font-head); font-weight: 900; color: #fff;
    background: var(--grad-main);
}
.pg-roster { display: flex; flex-direction: column; gap: .4rem; }
.pg-roster-row {
    display: flex; align-items: center; justify-content: space-between; gap: .6rem;
    background: rgba(7,7,15,.5); border: 1px solid var(--border);
    border-radius: 10px; padding: .5rem .75rem;
}
.pg-roster-row .who { display: flex; align-items: center; gap: .5rem; }
.pg-roster-empty {
    border: 1px dashed var(--border-strong); border-radius: 10px;
    padding: .5rem .75rem; color: var(--text-dim);
}
.pg-roster-count { font-family: var(--font-head); font-weight: 700; }
.pg-roster-bar { height: 8px; border-radius: 999px; background: rgba(255,255,255,.08); overflow: hidden; border: 1px solid var(--border); }
.pg-roster-fill { height: 100%; background: var(--grad-cyan); }

.pg-invite-box {
    display: flex; gap: .5rem; align-items: stretch;
}
.pg-invite-box input {
    font-family: var(--font-body); font-size: .9rem;
    background: rgba(7,7,15,.7); border: 1px solid var(--border);
    color: var(--neon-cyan); border-radius: 8px; padding: .5rem .7rem; width: 100%;
}
.pg-qr {
    background: #fff; padding: 10px; border-radius: 12px; display: inline-block; line-height: 0;
    box-shadow: 0 0 20px rgba(34,230,255,.25);
}
.pg-qr img { width: 160px; height: 160px; image-rendering: pixelated; }
.pg-tag-chip {
    font-family: var(--font-head); font-weight: 700; font-size: .75rem;
    color: var(--neon-cyan); border: 1px solid var(--border-strong);
    border-radius: 6px; padding: .1rem .4rem; letter-spacing: .5px;
}
.pg-medal { font-weight: 900; font-family: var(--font-head); }
.pg-medal.gold { color: #ffd23f; text-shadow: 0 0 10px rgba(255,210,63,.45); }
.pg-medal.silver { color: #9fb2d6; text-shadow: 0 0 10px rgba(159,178,214,.45); }
.pg-medal.bronze { color: #e08a4f; text-shadow: 0 0 10px rgba(224,138,79,.4); }
.pg-score { font-family: var(--font-head); font-weight: 900; font-size: 1.05rem; }
.pg-result-w { color: #2bff88; font-weight: 700; }
.pg-result-l { color: #ff6076; font-weight: 700; }
.pg-result-d { color: #ffcf4d; font-weight: 700; }

/* ----------------------- Round-robin crosstable ------------------------- */
.pg-rr-grid {
    border-collapse: separate;
    border-spacing: 4px;
    font-family: var(--font-head);
}
.pg-rr-grid th, .pg-rr-grid td {
    text-align: center;
    vertical-align: middle;
    min-width: 52px;
    height: 44px;
    border-radius: 8px;
    font-size: .85rem;
    font-weight: 700;
}
.pg-rr-grid thead th {
    color: var(--neon-cyan);
    background: rgba(7, 7, 15, .55);
    border: 1px solid var(--border);
    letter-spacing: .5px;
}
.pg-rr-grid th.corner { background: transparent; border: none; min-width: 150px; }
.pg-rr-grid th.rowhead {
    text-align: left;
    color: #fff;
    background: rgba(7, 7, 15, .55);
    border: 1px solid var(--border);
    padding: 0 .6rem;
    white-space: nowrap;
}
.pg-rr-grid th.rowhead .nm { font-family: var(--font-body); font-weight: 600; margin-left: .25rem; }
.pg-rr-grid td { background: rgba(20, 20, 38, .6); border: 1px solid var(--border); color: var(--text-dim); }
.pg-rr-grid td.diag {
    background: repeating-linear-gradient(45deg, rgba(124,92,255,.10) 0 6px, transparent 6px 12px);
    border-color: transparent;
}
.pg-rr-grid td.sched { color: var(--text-dim); }
.pg-rr-grid td.empty { color: #44445e; }
.pg-rr-grid td.res { color: #fff; }
.pg-rr-grid td.res.w { background: rgba(43, 255, 136, .18); border-color: rgba(43,255,136,.5); color: #57ff9e; }
.pg-rr-grid td.res.l { background: rgba(255, 70, 90, .15); border-color: rgba(255,70,90,.45); color: #ff8090; }
.pg-rr-grid td.res.d { background: rgba(255, 207, 77, .15); border-color: rgba(255,207,77,.45); color: #ffcf4d; }
.pg-rr-legend { display: flex; gap: 1.2rem; flex-wrap: wrap; margin-top: .8rem; color: var(--text-dim); font-size: .8rem; }
.pg-rr-legend span { display: inline-flex; align-items: center; gap: .4rem; }
.pg-rr-legend i { width: 14px; height: 14px; border-radius: 4px; display: inline-block; border: 1px solid; }
.pg-rr-legend i.w { background: rgba(43,255,136,.18); border-color: rgba(43,255,136,.5); }
.pg-rr-legend i.l { background: rgba(255,70,90,.15); border-color: rgba(255,70,90,.45); }
.pg-rr-legend i.d { background: rgba(255,207,77,.15); border-color: rgba(255,207,77,.45); }
.pg-rr-legend i.sched { background: rgba(20,20,38,.6); border-color: var(--border); }

/* --------------------------- Fixtures grid ------------------------------ */
.pg-fixtures { display: flex; gap: 1rem; overflow-x: auto; padding-bottom: .5rem; }
.pg-fix-round { min-width: 250px; flex: 1 1 250px; }
.pg-fix-round-title {
    font-family: var(--font-head); font-weight: 700; color: var(--neon-cyan);
    text-transform: uppercase; letter-spacing: 1px; font-size: .78rem;
    border-bottom: 1px solid var(--border); padding-bottom: .35rem; margin-bottom: .6rem;
}
.pg-fix-card {
    display: flex; align-items: center; justify-content: space-between; gap: .5rem;
    background: var(--panel); border: 1px solid var(--border); border-radius: 10px;
    padding: .5rem .7rem; margin-bottom: .55rem;
}
.pg-fix-card.played { border-color: var(--border-strong); }
.pg-fix-card .side { display: flex; align-items: center; gap: .35rem; flex: 1; min-width: 0; color: var(--text-dim); font-size: .85rem; }
.pg-fix-card .side .nm { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pg-fix-card .side.away { justify-content: flex-end; text-align: right; }
.pg-fix-card .side.win { color: #fff; font-weight: 700; }
.pg-fix-card .sc { font-family: var(--font-head); font-weight: 900; color: #fff; white-space: nowrap; padding: 0 .2rem; }

/* ----------------------------- Utilities -------------------------------- */
.pg-empty {
    text-align: center; padding: 4rem 1rem; color: var(--text-dim);
    border: 1px dashed var(--border-strong); border-radius: var(--radius);
}
.pg-divider { height: 1px; background: var(--border); border: none; margin: 2.5rem 0; }

/* ============================ Single-elimination bracket ============================ */
.pg-bk-page { max-width: 1400px; margin-inline: auto; }

/* Title bar (the "BRACKET" header strip) */
.pg-bk-titlebar {
    display: flex; align-items: center; gap: .9rem; flex-wrap: wrap;
    background: linear-gradient(90deg, rgba(124,92,255,.16), rgba(34,230,255,.05) 60%, transparent);
    border: 1px solid var(--border); border-left: 0; border-right: 0;
    padding: .7rem 1rem; border-radius: 8px;
}
.pg-bk-titlebar .bar { width: 6px; height: 30px; border-radius: 3px; background: var(--grad-main); box-shadow: 0 0 12px rgba(176,38,255,.6); }
.pg-bk-titlebar h1 { font-family: var(--font-head); font-size: 1.5rem; margin: 0; letter-spacing: .06em; }
.pg-bk-titlebar .sub { color: var(--text-dim); font-size: .85rem; letter-spacing: .04em; }

.pg-bk-champ-banner {
    margin-top: 1rem; padding: .7rem 1rem; border-radius: 10px;
    background: linear-gradient(90deg, rgba(255,196,0,.16), rgba(255,196,0,.03));
    border: 1px solid rgba(255,196,0,.45); color: var(--text); font-size: 1.05rem;
}

/* Horizontal scroll wrapper so wide brackets never break the layout */
.pg-bk-scroll { overflow-x: auto; padding: 1.25rem .25rem 1.5rem; }
.pg-bk {
    display: flex; align-items: stretch; min-width: max-content;
    --bk-gap: 40px;                              /* connector gutter width between columns */
    --bk-line: rgba(124, 92, 255, .65);          /* neon-violet connector */
    --bk-line-glow: rgba(124, 92, 255, .35);
    --bk-line-w: 2px;
}

/* A round is a vertical column; flex:1 seeds split the height into equal slots
   so each round centres against the previous round's pairs automatically. */
.pg-bk-round {
    display: flex; flex-direction: column;
    flex: 0 0 234px; min-width: 234px;
    position: relative; padding-top: 1.8rem;
}
.pg-bk-round-label {
    position: absolute; top: 0; left: 2px;
    font-family: var(--font-head); font-size: .72rem; letter-spacing: .14em;
    text-transform: uppercase; color: var(--neon-cyan);
    text-shadow: 0 0 10px rgba(34, 230, 255, .45);
}
.pg-bk-round.is-final-round .pg-bk-round-label { color: var(--neon-magenta); text-shadow: 0 0 10px rgba(255, 43, 214, .5); }
.pg-bk-seed {
    flex: 1 1 0; display: flex; flex-direction: column; justify-content: center;
    position: relative; padding: 7px var(--bk-gap) 7px 0; /* vertical padding gives the boxes breathing room */
}

/* --- Connector lines (elbows) drawn in the right gutter of feeding rounds --- */
.pg-bk-round:not(.is-final-round):not(.is-champ-round) .pg-bk-seed::before {
    /* horizontal stub: match edge -> gutter centre, at the seed's own midline */
    content: ""; position: absolute; top: 50%; right: calc(var(--bk-gap) / 2);
    width: calc(var(--bk-gap) / 2); height: var(--bk-line-w); background: var(--bk-line);
    box-shadow: 0 0 6px var(--bk-line-glow);
}
.pg-bk-round:not(.is-final-round):not(.is-champ-round) .pg-bk-seed:nth-child(odd of .pg-bk-seed)::after,
.pg-bk-round:not(.is-final-round):not(.is-champ-round) .pg-bk-seed:nth-child(even of .pg-bk-seed)::after {
    content: ""; position: absolute; right: 0; width: calc(var(--bk-gap) / 2);
    box-shadow: 0 0 6px var(--bk-line-glow);
}
/* top seed of a pair: vertical from its centre down to the pair boundary, then right to next box */
.pg-bk-round:not(.is-final-round):not(.is-champ-round) .pg-bk-seed:nth-child(odd of .pg-bk-seed)::after {
    top: 50%; height: 50%;
    border-left: var(--bk-line-w) solid var(--bk-line);
    border-bottom: var(--bk-line-w) solid var(--bk-line);
}
/* bottom seed of a pair: vertical from the pair boundary up to its centre */
.pg-bk-round:not(.is-final-round):not(.is-champ-round) .pg-bk-seed:nth-child(even of .pg-bk-seed)::after {
    bottom: 50%; height: 50%;
    border-left: var(--bk-line-w) solid var(--bk-line);
}

/* --- The match box (dark neon panel) --- */
.pg-bk-match {
    background: linear-gradient(180deg, rgba(30, 30, 56, .94), rgba(15, 15, 32, .96));
    border: 1px solid var(--border); border-radius: 10px;
    overflow: hidden; box-shadow: 0 4px 18px rgba(0, 0, 0, .45);
    transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.pg-bk-match:hover {
    border-color: var(--border-strong);
    box-shadow: 0 6px 24px rgba(124, 92, 255, .28);
    transform: translateY(-1px);
}
.pg-bk-head {
    display: flex; justify-content: space-between; align-items: center;
    padding: 5px 10px; font-family: var(--font-head); font-size: .6rem; letter-spacing: .08em;
    background: linear-gradient(90deg, rgba(124, 92, 255, .32), rgba(34, 230, 255, .06));
    border-bottom: 1px solid var(--border);
}
.pg-bk-head .code { color: var(--neon-cyan); text-shadow: 0 0 8px rgba(34, 230, 255, .5); }
.pg-bk-head .time { color: var(--text-dim); font-family: var(--font-body); font-size: .72rem; letter-spacing: 0; }
.pg-bk-match.is-final .pg-bk-head { background: linear-gradient(90deg, rgba(255, 43, 214, .32), rgba(176, 38, 255, .08)); }
.pg-bk-match.is-final .pg-bk-head .code { color: var(--neon-magenta); text-shadow: 0 0 10px rgba(255, 43, 214, .6); }
.pg-bk-body { display: flex; flex-direction: column; }
.pg-bk-team {
    display: flex; justify-content: space-between; align-items: center; gap: .5rem;
    padding: 7px 10px; color: var(--text); font-size: .82rem;
    border-top: 1px solid rgba(124, 92, 255, .14);
}
.pg-bk-team:first-child { border-top: 0; }
.pg-bk-team .nm { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pg-bk-team .score { color: var(--text-dim); font-weight: 700; font-variant-numeric: tabular-nums; }
.pg-bk-team.win {
    background: linear-gradient(90deg, rgba(34, 230, 255, .16), transparent);
    color: #fff; font-weight: 700; box-shadow: inset 3px 0 0 var(--neon-cyan);
}
.pg-bk-team.win .score { color: var(--neon-cyan); text-shadow: 0 0 8px rgba(34, 230, 255, .55); }
.pg-bk-team.lose { color: var(--text-dim); }
.pg-bk-team.tbd { color: #6f6f93; font-style: italic; }
.pg-bk-match.is-bye .pg-bk-team.tbd { font-style: normal; letter-spacing: .1em; color: var(--neon-violet); }

/* Champion column */
.pg-bk-champ-round { justify-content: center; flex-basis: 210px; min-width: 210px; }
.pg-bk-champ {
    text-align: center; padding: 1.1rem .75rem; border-radius: 12px;
    background: linear-gradient(180deg, rgba(255, 196, 0, .16), rgba(124, 92, 255, .10));
    border: 1px solid rgba(255, 196, 0, .55); box-shadow: 0 0 26px rgba(255, 196, 0, .18);
}
.pg-bk-champ .trophy { font-size: 2rem; filter: drop-shadow(0 0 10px rgba(255, 196, 0, .6)); }
.pg-bk-champ .tag { color: var(--neon-cyan); font-size: .8rem; font-weight: 700; }
.pg-bk-champ .name { font-family: var(--font-head); font-size: 1.05rem; margin-top: .25rem; }

/* ===================== Visual-audit polish (responsive) ===================== */

/* Fill the hero's right-side negative space with a soft neon orb (desktop only) */
@media (min-width: 992px) {
    .pg-hero-content { max-width: 760px; }
    .pg-hero::before {
        content: ""; position: absolute; right: -130px; top: 50%;
        transform: translateY(-50%);
        width: 540px; height: 540px; border-radius: 50%;
        background:
            radial-gradient(circle at 50% 50%, rgba(255,43,214,.12), transparent 60%),
            conic-gradient(from 200deg, rgba(124,92,255,.18), rgba(34,230,255,.10), rgba(255,43,214,.18), rgba(124,92,255,.18));
        filter: blur(2px); opacity: .72; pointer-events: none; z-index: 1;
    }
}

/* On phones, turn wide admin data tables into stacked cards instead of scrolling */
@media (max-width: 768px) {
    .pg-table-cards thead { display: none; }
    .pg-table-cards, .pg-table-cards tbody, .pg-table-cards tr, .pg-table-cards td { display: block; width: 100%; }
    .pg-table-cards tr {
        background: var(--panel); border: 1px solid var(--border);
        border-radius: 12px; margin-bottom: .9rem; padding: .35rem .25rem;
    }
    .pg-table-cards td {
        display: flex; justify-content: space-between; align-items: center; gap: 1rem;
        padding: .55rem .9rem; border: none !important; text-align: right;
    }
    .pg-table-cards td::before {
        content: attr(data-label);
        font-family: var(--font-head); text-transform: uppercase;
        font-size: .68rem; letter-spacing: .5px; color: var(--text-dim);
        text-align: left; flex: 0 0 auto;
    }
    .pg-table-cards td[data-label=""]::before { content: none; }
    .pg-table-cards td .d-flex { justify-content: flex-end; }
}
