/* public/css/tournaments.css — public tournament listing page */

/* ── Hero ────────────────────────────────────────────────────────────────── */
.tl-hero {
    background: linear-gradient(135deg, #0a0f1a 0%, #0d1829 60%, #0a0f1a 100%);
    border-bottom: 1px solid rgba(255,255,255,.06);
    padding: 48px 20px 36px;
    text-align: center;
}
.tl-hero-inner { max-width: 640px; margin: 0 auto; }
.tl-hero-title { font-size: clamp(1.6rem, 5vw, 2.4rem); font-weight: 800; color: #fff; margin: 0 0 10px; }
.tl-hero-sub   { color: var(--text-muted, #8b949e); font-size: .95rem; margin: 0 0 22px; line-height: 1.6; }

.tl-manage-btn {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(0,217,255,.1); border: 1px solid rgba(0,217,255,.3);
    color: #00d9ff; padding: 9px 20px; border-radius: 9px;
    font-size: .85rem; font-weight: 600; text-decoration: none;
    transition: background .2s, box-shadow .2s;
}
.tl-manage-btn:hover {
    background: rgba(0,217,255,.18);
    box-shadow: 0 0 14px rgba(0,217,255,.2);
}

/* ── Wrap ────────────────────────────────────────────────────────────────── */
.tl-wrap { max-width: 1100px; margin: 0 auto; padding: 36px 20px 60px; }

/* ── Empty state ─────────────────────────────────────────────────────────── */
.tl-empty { text-align: center; padding: 80px 20px; color: var(--text-muted, #8b949e); }
.tl-empty-icon { font-size: 3rem; margin-bottom: 16px; }

/* ── Groups ──────────────────────────────────────────────────────────────── */
.tl-group { margin-bottom: 40px; }
.tl-group-label {
    font-size: .72rem; font-weight: 700; letter-spacing: .1em;
    text-transform: uppercase; color: var(--text-muted, #8b949e);
    margin-bottom: 14px; padding-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,.05);
}

/* ── Card grid ───────────────────────────────────────────────────────────── */
.tl-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 16px;
}

/* ── Card ────────────────────────────────────────────────────────────────── */
.tl-card {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 14px;
    padding: 18px 20px 16px;
    cursor: pointer;
    transition: border-color .2s, transform .15s, box-shadow .2s;
    display: flex; flex-direction: column; gap: 10px;
}
.tl-card:hover {
    border-color: rgba(0,217,255,.35);
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(0,0,0,.25);
}

.tl-card-head { display: flex; gap: 6px; flex-wrap: wrap; }

.tl-card-name {
    font-size: 1.05rem; font-weight: 700; color: #fff;
    line-height: 1.3;
}

.tl-card-desc {
    font-size: .8rem; color: var(--text-muted, #8b949e);
    margin: 0; line-height: 1.5;
}

/* ── Meta row ────────────────────────────────────────────────────────────── */
.tl-card-meta {
    display: flex; flex-wrap: wrap; gap: 10px;
    font-size: .75rem; color: var(--text-muted, #8b949e);
    margin-top: auto;
}
.tl-card-meta i { margin-right: 4px; color: rgba(0,217,255,.6); }

/* ── Footer row ──────────────────────────────────────────────────────────── */
.tl-card-foot {
    display: flex; gap: 8px; align-items: center;
    padding-top: 10px; border-top: 1px solid rgba(255,255,255,.05);
}

/* ── Pills ───────────────────────────────────────────────────────────────── */
.tl-pill {
    display: inline-block; font-size: .68rem; font-weight: 700;
    padding: 3px 9px; border-radius: 20px; letter-spacing: .03em;
}
.tl-pill-live   { background: rgba(244,67,54,.12);  color: #f44336; border: 1px solid rgba(244,67,54,.25); }
.tl-pill-reg    { background: rgba(0,217,255,.1);   color: #00d9ff; border: 1px solid rgba(0,217,255,.25); }
.tl-pill-active { background: rgba(76,175,80,.1);   color: #4caf50; border: 1px solid rgba(76,175,80,.25); }
.tl-pill-done   { background: rgba(255,255,255,.05);color: #8b949e; border: 1px solid rgba(255,255,255,.1); }
.tl-pill-mine   { background: rgba(76,175,80,.1);   color: #4caf50; border: 1px solid rgba(76,175,80,.25); }

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.tl-btn {
    padding: 6px 16px; border-radius: 8px; font-size: .8rem; font-weight: 600;
    text-decoration: none; transition: background .2s;
}
.tl-btn-view {
    background: rgba(255,255,255,.06); color: #fff; border: 1px solid rgba(255,255,255,.1);
}
.tl-btn-view:hover { background: rgba(255,255,255,.12); }

.tl-btn-reg {
    background: rgba(0,217,255,.12); color: #00d9ff; border: 1px solid rgba(0,217,255,.3);
}
.tl-btn-reg:hover { background: rgba(0,217,255,.22); }

.tl-full-badge {
    font-size: .75rem; color: #8b949e;
    padding: 4px 10px; border-radius: 8px;
    background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
}

/* ── Mobile ──────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .tl-wrap { padding: 24px 14px 50px; }
    .tl-grid { grid-template-columns: 1fr; }
}
