




/* ============================================================
   HERO BANNER
============================================================ */



/* status + category row */
.hero-badges { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; flex-wrap: wrap; animation: fade-up .4s .05s both; }
.badge-status {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: var(--radius-pill);
  font-size: 11px; font-weight: 800; letter-spacing: .8px; text-transform: uppercase;
}
.badge-upcoming { background: rgba(255,200,53,.14); border: 1px solid rgba(255,200,53,.32); color: var(--accent-gold); }
.badge-live     { background: rgba(255,45,120,.14); border: 1px solid rgba(255,45,120,.32); color: var(--accent-pink); }
.badge-status .b-dot { width: 6px; height: 6px; border-radius: 50%; }
.badge-upcoming .b-dot { background: var(--accent-gold); }
.badge-live     .b-dot { background: var(--accent-pink); animation: pulse-dot 1.1s ease-in-out infinite; }
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.5)} }
.badge-cat { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: var(--radius-pill); font-size: 11px; font-weight: 700; letter-spacing: .5px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); color: var(--text-muted); }

.hero-title { font-family: var(--font-display); font-size: clamp(28px, 5vw, 60px); font-weight: 900; letter-spacing: -1.5px; line-height: 1; color: #fff; margin-bottom: 14px; text-shadow: 0 4px 40px rgba(255,200,53,.25); animation: fade-up .4s .12s both; }
.hero-tagline { font-size: 16px; color: rgba(226,234,255,.6); max-width: 520px; line-height: 1.6; margin-bottom: 30px; animation: fade-up .4s .2s both; }

/* hero CTA row */
.hero-cta-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; animation: fade-up .4s .28s both; }
.btn-register {
  display: inline-flex; align-items: center; gap: 9px;
  background: linear-gradient(135deg, var(--t-accent), var(--t-accent-2));
  color: #06080f; font-weight: 800; font-size: 14px; letter-spacing: .3px;
  padding: 13px 28px; border-radius: var(--radius-pill);
  box-shadow: 0 4px 28px rgba(255,200,53,.35);
  transition: transform .2s, box-shadow .2s;
  position: relative; overflow: hidden;
}
.btn-register::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,.18), transparent); opacity: 0; transition: opacity .2s; }
.btn-register:hover { transform: translateY(-2px); box-shadow: 0 8px 36px rgba(255,200,53,.45); }
.btn-register:hover::before { opacity: 1; }
.btn-register svg { width: 16px; height: 16px; }
.btn-share-hero { display: inline-flex; align-items: center; gap: 7px; background: rgba(255,255,255,.06); border: 1.5px solid rgba(255,255,255,.1); color: var(--text-muted); font-weight: 600; font-size: 13px; padding: 12px 20px; border-radius: var(--radius-pill); transition: all .2s; }
.btn-share-hero:hover { background: rgba(255,255,255,.1); color: var(--text-primary); }
.btn-share-hero svg { width: 15px; height: 15px; }

@keyframes fade-up { from{opacity:0;transform:translateY(16px);} to{opacity:1;transform:translateY(0);} }

/* ============================================================
   QUICK STATS STRIP
============================================================ */
.stats-strip { position: relative; z-index: 2; background: rgba(10,14,28,.98); border-bottom: 1px solid var(--border); backdrop-filter: blur(10px); }
.stats-inner { max-width: 1280px; margin: 0 auto; padding: 0 24px; display: flex; align-items: stretch; overflow-x: auto; scrollbar-width: none; }
.stats-inner::-webkit-scrollbar { display: none; }
.stat-item { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; padding: 18px 32px; border-right: 1px solid var(--border); flex-shrink: 0; }
.stat-item:last-child { border-right: none; }
.stat-val { font-family: var(--font-display); font-size: 20px; font-weight: 700; color: var(--text-primary); letter-spacing: .5px; }
.stat-val.gold { color: var(--accent-gold); }
.stat-val.cyan { color: var(--accent-cyan); }
.stat-val.green { color: var(--accent-green); }
.stat-val.orange { color: var(--accent-orange); }
.stat-lbl { font-size: 10px; color: var(--text-muted); letter-spacing: .6px; text-transform: uppercase; font-weight: 600; }

/* ============================================================
   MAIN LAYOUT
============================================================ */

/* ============================================================
   SHARED CARD
============================================================ */
.card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-card); overflow: hidden; margin-bottom: 24px; }
.card:last-child { margin-bottom: 0; }
.card-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border); }
.card-title { font-family: var(--font-display); font-size: 11px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; color: var(--text-dim); display: flex; align-items: center; gap: 8px; }
.ct-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--t-accent); }
.card-action { font-size: 12px; color: var(--text-muted); transition: color .15s; }
.card-action:hover { color: var(--accent-cyan); }

/* ============================================================
   ABOUT CARD
============================================================ */
.about-text { padding: 18px 20px; font-size: 14px; line-height: 1.8; color: rgba(226,234,255,.7); border-bottom: 1px solid var(--border); }
.about-text p + p { margin-top: 12px; }
.about-text strong { color: var(--text-primary); }

/* ============================================================
   PRIZE BREAKDOWN
============================================================ */
.prize-podium { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0; border-bottom: 1px solid var(--border); }
.pp-item { padding: 20px 16px; text-align: center; border-right: 1px solid var(--border); display: flex; flex-direction: column; align-items: center; gap: 6px; }
.pp-item:last-child { border-right: none; }
.pp-medal { font-size: 28px; }
.pp-pos { font-size: 11px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--text-dim); }
.pp-prize { font-family: var(--font-display); font-size: 16px; font-weight: 700; }
.pp-prize.gold { color: var(--accent-gold); }
.pp-prize.silver { color: #94a3b8; }
.pp-prize.bronze { color: #c08040; }
.pp-sub { font-size: 11px; color: var(--text-muted); }

.prize-table { }
.pt-row { display: flex; align-items: center; justify-content: space-between; padding: 12px 20px; border-bottom: 1px solid rgba(255,255,255,.04); transition: background .15s; }
.pt-row:last-child { border-bottom: none; }
.pt-row:hover { background: rgba(255,255,255,.02); }
.pt-pos-label { font-size: 13px; color: var(--text-muted); }
.pt-pos-label strong { color: var(--text-primary); font-weight: 600; }
.pt-prize-val { font-size: 13px; font-weight: 700; color: var(--accent-gold); }
.pt-prize-val.muted { color: var(--text-muted); font-weight: 500; }

/* ============================================================
   HOW IT WORKS
============================================================ */
.steps-list { padding: 4px 0; }
.step-row { display: flex; align-items: flex-start; gap: 16px; padding: 14px 20px; border-bottom: 1px solid rgba(255,255,255,.04); transition: background .15s; }
.step-row:last-child { border-bottom: none; }
.step-row:hover { background: rgba(255,255,255,.02); }
.step-num { flex-shrink: 0; width: 30px; height: 30px; border-radius: 8px; background: linear-gradient(135deg, rgba(var(--t-accent-rgb),.2), rgba(var(--t-accent-rgb),.08)); border: 1px solid rgba(var(--t-accent-rgb),.25); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 11px; font-weight: 700; color: var(--t-accent); margin-top: 2px; }
.step-body {}
.step-title { font-size: 14px; font-weight: 700; color: var(--text-primary); margin-bottom: 3px; }
.step-desc { font-size: 13px; color: var(--text-muted); line-height: 1.6; }

/* ============================================================
   RULES CARD
============================================================ */
.rules-list { padding: 8px 20px 16px; display: flex; flex-direction: column; gap: 10px; }
.rule-item { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--text-muted); line-height: 1.6; }
.rule-ico { flex-shrink: 0; width: 18px; height: 18px; border-radius: 50%; background: rgba(var(--t-accent-rgb),.1); border: 1px solid rgba(var(--t-accent-rgb),.2); display: flex; align-items: center; justify-content: center; margin-top: 1px; }
.rule-ico svg { width: 10px; height: 10px; color: var(--t-accent); }
.rule-item strong { color: var(--text-primary); font-weight: 600; }

/* ============================================================
   LEADERBOARD PREVIEW
============================================================ */
.lb-rows {}
.lb-row { display: grid; grid-template-columns: 36px 1fr 90px 100px; align-items: center; padding: 11px 20px; border-bottom: 1px solid rgba(255,255,255,.04); transition: background .15s; }
.lb-row:last-child { border-bottom: none; }
.lb-row:hover { background: rgba(255,255,255,.02); }
.lb-row.my-row { background: rgba(0,229,255,.04) !important; position: relative; }
.lb-row.my-row::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--accent-cyan); border-radius: 0 2px 2px 0; }
.lb-col-heads { display: grid; grid-template-columns: 36px 1fr 90px 100px; padding: 10px 20px; background: rgba(255,255,255,.02); border-bottom: 1px solid var(--border); }
.lbch { font-size: 10px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--text-dim); }
.lbch.r { text-align: right; }
.lb-pos { font-family: var(--font-display); font-size: 13px; font-weight: 700; color: var(--text-dim); }
.lb-pos.p1 { color: var(--accent-gold); }
.lb-pos.p2 { color: #94a3b8; }
.lb-pos.p3 { color: #c08040; }
.lb-pos.pme { color: var(--accent-cyan); }
.lb-player { display: flex; align-items: center; gap: 10px; }
.lb-av { width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: #fff; flex-shrink: 0; }
.lb-phone { font-size: 13px; font-weight: 600; color: var(--text-primary); letter-spacing: .4px; }
.lb-phone.me { color: var(--accent-cyan); }
.lb-score { font-family: var(--font-display); font-size: 12px; font-weight: 700; color: var(--text-muted); text-align: right; }
.lb-row.my-row .lb-score { color: var(--accent-cyan); }
.lb-prize { font-size: 12px; font-weight: 600; color: var(--text-muted); text-align: right; }
.lb-prize.has { color: var(--accent-gold); }

/* ============================================================
   PARTICIPANTS STRIP
============================================================ */
.participants-wrap { padding: 16px 20px; }
.participants-avatars { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.p-av { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: #fff; border: 2px solid var(--bg-card); transition: transform .2s; cursor: default; }
.p-av:hover { transform: scale(1.1); z-index: 2; position: relative; }
.p-av-more { background: rgba(255,255,255,.06); border: 2px solid var(--border); color: var(--text-muted); font-size: 11px; font-weight: 700; }
.participants-meta { font-size: 13px; color: var(--text-muted); }
.participants-meta strong { color: var(--text-primary); }
/* capacity bar */
.capacity-bar { margin-top: 12px; }
.cap-row { display: flex; justify-content: space-between; font-size: 12px; color: var(--text-muted); margin-bottom: 6px; }
.cap-track { height: 6px; border-radius: 3px; background: rgba(255,255,255,.07); overflow: hidden; }
.cap-fill { height: 100%; border-radius: 3px; background: linear-gradient(90deg, var(--t-accent), var(--t-accent-2)); transition: width 1s cubic-bezier(.4,0,.2,1); }

/* ============================================================
   RIGHT SIDEBAR
============================================================ */
.sidebar-col { display: flex; flex-direction: column; gap: 0; position: sticky; top: calc(var(--nav-h) + 20px); }

/* Registration card */
.reg-card { background: var(--bg-card-2); border: 1px solid rgba(var(--t-accent-rgb),.2); border-radius: 16px; overflow: hidden; margin-bottom: 20px; }
.reg-card-top { padding: 20px; border-bottom: 1px solid rgba(var(--t-accent-rgb),.1); }
.reg-countdown-label { font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--text-dim); margin-bottom: 10px; display: flex; align-items: center; gap: 6px; }
.rcd-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--t-accent); }
.reg-countdown { display: flex; gap: 8px; align-items: center; margin-bottom: 16px; }
.rcd-seg { display: flex; flex-direction: column; align-items: center; gap: 2px; background: rgba(255,200,53,.06); border: 1px solid rgba(255,200,53,.15); border-radius: 8px; padding: 8px 10px; min-width: 44px; }
.rcd-num { font-family: var(--font-display); font-size: 20px; font-weight: 700; color: var(--t-accent); line-height: 1; }
.rcd-lbl { font-size: 9px; font-weight: 600; letter-spacing: .6px; text-transform: uppercase; color: var(--text-dim); }
.rcd-colon { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: var(--text-dim); align-self: flex-start; padding-top: 6px; }
.reg-prize-row { display: flex; align-items: center; justify-content: space-between; }
.reg-prize-label { font-size: 12px; color: var(--text-muted); }
.reg-prize-val { font-family: var(--font-display); font-size: 20px; font-weight: 900; color: var(--accent-gold); text-shadow: 0 0 16px rgba(255,200,53,.3); }

.reg-card-body { padding: 16px 20px 20px; }
/* mini slot bar */
.slot-row { display: flex; justify-content: space-between; font-size: 12px; color: var(--text-muted); margin-bottom: 7px; }
.slot-row strong { color: var(--text-primary); }
.slot-track { height: 5px; border-radius: 3px; background: rgba(255,255,255,.07); overflow: hidden; margin-bottom: 16px; }
.slot-fill { height: 100%; border-radius: 3px; background: linear-gradient(90deg, var(--t-accent), var(--t-accent-2)); }
.btn-reg {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  width: 100%; background: linear-gradient(135deg, var(--t-accent), var(--t-accent-2));
  color: #06080f; font-weight: 800; font-size: 15px; padding: 14px;
  border-radius: 12px; box-shadow: 0 4px 24px rgba(255,200,53,.3);
  transition: transform .2s, box-shadow .2s; position: relative; overflow: hidden;
}
.btn-reg::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,.18), transparent); opacity: 0; transition: opacity .2s; }
.btn-reg:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(255,200,53,.4); }
.btn-reg:hover::before { opacity: 1; }
.btn-reg svg { width: 17px; height: 17px; }
.reg-note { text-align: center; font-size: 11px; color: var(--text-dim); margin-top: 10px; }
.reg-note strong { color: var(--text-muted); }

/* Game card */
.game-sidebar-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-card); overflow: hidden; margin-bottom: 20px; }
.gsc-banner { height: 300px; display: flex; align-items: center; justify-content: center; font-size: 48px; position: relative; overflow: hidden; background: linear-gradient(160deg, #402000, #ff2d78, #ff8c00); cursor: pointer; transition: filter .2s; }
.gsc-banner:hover { filter: brightness(1.1); }
.gsc-play-over { position: absolute; inset: 0; background: rgba(0,0,0,.4); display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .2s; }
.gsc-banner:hover .gsc-play-over { opacity: 1; }
.play-circle { width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,.15); backdrop-filter: blur(6px); border: 1.5px solid rgba(255,255,255,.3); display: flex; align-items: center; justify-content: center; }
.play-circle::after { content: ''; width: 0; height: 0; border-style: solid; border-width: 7px 0 7px 14px; border-color: transparent transparent transparent rgba(255,255,255,.9); margin-left: 3px; }
.gsc-info { padding: 14px 16px; }
.gsc-label { font-size: 10px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--text-dim); margin-bottom: 4px; }
.gsc-name { font-family: var(--font-display); font-size: 14px; font-weight: 700; color: var(--text-primary); margin-bottom: 6px; }
.gsc-meta { display: flex; gap: 14px; font-size: 12px; color: var(--text-muted); }
.gsc-meta span { display: flex; align-items: center; gap: 4px; }
.gsc-meta svg { width: 12px; height: 12px; color: var(--text-dim); }

/* Organiser card */
.org-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-card); padding: 16px 18px; margin-bottom: 20px; }
.org-label { font-size: 10px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--text-dim); margin-bottom: 12px; }
.org-row { display: flex; align-items: center; gap: 12px; }
.org-icon { width: 40px; height: 40px; border-radius: 10px; background: linear-gradient(135deg, var(--t-accent), var(--t-accent-2)); display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.org-name { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.org-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 10px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; background: rgba(0,229,255,.08); border: 1px solid rgba(0,229,255,.2); border-radius: 4px; padding: 2px 7px; color: var(--accent-cyan); margin-top: 3px; }

/* Share card */
.share-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-card); padding: 16px 18px; }
.share-label { font-size: 10px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--text-dim); margin-bottom: 12px; }
.share-btns { display: flex; gap: 8px; }
.share-btn { flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px; padding: 9px 0; border-radius: 9px; font-size: 12px; font-weight: 700; background: rgba(255,255,255,.04); border: 1px solid var(--border); color: var(--text-muted); transition: all .2s; }
.share-btn:hover { background: rgba(255,255,255,.08); color: var(--text-primary); }
.share-btn svg { width: 14px; height: 14px; }

/* ============================================================
   RELATED TOURNAMENTS
============================================================ */
.related-section { position: relative; z-index: 1; border-top: 1px solid var(--border); padding: 48px 0 64px; }
.rel-inner { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.rel-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 24px; }
.rel-title-group .eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; color: var(--text-dim); margin-bottom: 6px; display: flex; align-items: center; gap: 7px; }
.e-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--t-accent); }
.rel-title { font-family: var(--font-display); font-size: 22px; font-weight: 700; color: var(--text-primary); }
.see-all { display: flex; align-items: center; gap: 5px; font-size: 13px; font-weight: 600; color: var(--text-muted); padding: 7px 14px; border-radius: var(--radius-pill); border: 1px solid var(--border); transition: all .2s; }
.see-all:hover { color: var(--text-primary); border-color: rgba(255,255,255,.14); background: rgba(255,255,255,.04); }
.see-all svg { width: 14px; height: 14px; }
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.rel-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-card); overflow: hidden; cursor: pointer; transition: transform .2s, box-shadow .2s, border-color .2s; }
.rel-card:hover { transform: translateY(-4px); box-shadow: 0 14px 40px rgba(0,0,0,.4); border-color: rgba(255,200,53,.2); }
.rc-banner { height: 80px; display: flex; align-items: center; justify-content: center; font-size: 32px; position: relative; }
.rc-status { position: absolute; top: 8px; left: 8px; display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: var(--radius-pill); font-size: 10px; font-weight: 800; letter-spacing: .7px; text-transform: uppercase; }
.rc-status.live { background: rgba(255,45,120,.15); border: 1px solid rgba(255,45,120,.3); color: var(--accent-pink); }
.rc-status.up   { background: rgba(255,200,53,.12); border: 1px solid rgba(255,200,53,.28); color: var(--accent-gold); }
.rc-status .rd { width: 5px; height: 5px; border-radius: 50%; }
.rc-status.live .rd { background: var(--accent-pink); animation: pulse-dot 1.1s ease-in-out infinite; }
.rc-status.up   .rd { background: var(--accent-gold); }
.rc-body { padding: 14px 16px; }
.rc-name { font-family: var(--font-display); font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 6px; line-height: 1.3; }
.rc-meta { display: flex; justify-content: space-between; font-size: 11px; color: var(--text-muted); }
.rc-prize { color: var(--accent-gold); font-weight: 700; }
.rc-footer { padding: 0 16px 14px; display: flex; gap: 8px; }
.rc-btn { flex: 1; display: flex; align-items: center; justify-content: center; padding: 8px; border-radius: 8px; font-size: 12px; font-weight: 700; transition: all .2s; }
.rc-btn.pink { background: linear-gradient(135deg, var(--accent-pink), #b500a8); color: #fff; box-shadow: 0 2px 12px rgba(255,45,120,.25); }
.rc-btn.gold { background: linear-gradient(135deg, var(--accent-gold), var(--accent-orange)); color: #06080f; box-shadow: 0 2px 12px rgba(255,200,53,.2); }
.rc-btn:hover { transform: translateY(-1px); }
.rc-detail { display: flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 8px; background: rgba(255,255,255,.04); border: 1px solid var(--border); color: var(--text-muted); transition: all .2s; flex-shrink: 0; }
.rc-detail:hover { background: rgba(255,255,255,.08); color: var(--text-primary); }
.rc-detail svg { width: 14px; height: 14px; }

/* ============================================================
   MOBILE FOOTER
============================================================ */
.mob-footer { display: none; position: fixed; bottom: 0; left: 0; right: 0; z-index: 90; height: 64px; background: rgba(12,17,32,.97); backdrop-filter: blur(20px); border-top: 1px solid var(--border); flex-direction: row; align-items: stretch; }
.mob-tab { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; font-size: 10px; font-weight: 600; letter-spacing: .5px; text-transform: uppercase; color: var(--text-muted); cursor: pointer; transition: color .2s; position: relative; }
.mob-tab svg { width: 22px; height: 22px; }
.mob-tab.active { color: var(--accent-pink); }
.mob-tab.active::after { content: ''; position: absolute; top: 0; left: 25%; right: 25%; height: 2px; background: var(--accent-pink); border-radius: 0 0 2px 2px; }

/* banner bg helpers */
.gb-t1 { background: linear-gradient(160deg, #1a0a40, #3b0080, #7c1aff); }
.gb-t2 { background: linear-gradient(160deg, #0a2040, #0070f3, #00c9a7); }
.gb-t3 { background: linear-gradient(160deg, #400a20, #ff2d78, #ff8c00); }
.gb-t5 { background: linear-gradient(160deg, #2a0a40, #a855f7, #3b82f6); }
.gb-t6 { background: linear-gradient(160deg, #402000, #f97316, #eab308); }
.gb-t8 { background: linear-gradient(160deg, #0a2a20, #14b8a6, #84cc16); }
/* av colours */
.av-red    { background: linear-gradient(135deg, #ff2d78, #7c1aff); }
.av-teal   { background: linear-gradient(135deg, #00c9a7, #0070f3); }
.av-orange { background: linear-gradient(135deg, #ff8c00, #ff2d78); }
.av-purple { background: linear-gradient(135deg, #a855f7, #3b82f6); }
.av-green  { background: linear-gradient(135deg, #10b981, #0891b2); }
.av-yellow { background: linear-gradient(135deg, #f97316, #eab308); }
.av-blue   { background: linear-gradient(135deg, #06b6d4, #8b5cf6); }
.av-pink   { background: linear-gradient(135deg, #ec4899, #f97316); }
.av-lime   { background: linear-gradient(135deg, #84cc16, #14b8a6); }
.av-indigo { background: linear-gradient(135deg, #6366f1, #ec4899); }

/* ============================================================
   RESPONSIVE
============================================================ */
@media(max-width:1024px) {
  .page-body { grid-template-columns: 1fr; }
  .sidebar-col { position: static; display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 20px; }
  .reg-card { grid-column: 1 / -1; }
  .related-grid { grid-template-columns: repeat(2, 1fr); }
}
@media(max-width:768px) {
  
  .sidebar-col { grid-template-columns: 1fr; }
  .related-grid { grid-template-columns: 1fr; }
  .lb-col-heads, .lb-row { grid-template-columns: 36px 1fr 80px; }
  .lbch:last-child, .lb-prize { display: none; }
  .prize-podium { grid-template-columns: 1fr 1fr 1fr; }
}
@media(max-width:640px) {
  body { padding-bottom: 70px; }
  .nav-inner { grid-template-columns: auto 1fr auto; }
  .nav-search { display: none; }
  .nav-logo .logo-text { display: none; }
  .hamburger { display: flex; }
  .mob-search-btn { display: flex !important; }
  .mob-footer { display: flex; }
  .hero-title { font-size: 28px; }
  .stat-item { padding: 14px 20px; }
  .hero-cta-row { flex-direction: column; align-items: flex-start; }
  .btn-register, .btn-share-hero { width: 100%; justify-content: center; }
  .page-body { padding: 28px 16px 40px; }
}
