/* ================================================
   LigaeFootball.com v2.0 - Mobile-First Frontend CSS
   Dark Theme with Gold Accent
   ================================================ */

/* ===== Reset ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }

:root {
    --bg: #080810; --bg-card: #0f0f1a; --bg-card-hover: #14142a; --bg-input: #0c0c18;
    --border: rgba(255,255,255,0.06); --border-light: rgba(255,255,255,0.1);
    --gold: #ffc832; --gold-dim: rgba(255,200,50,0.15);
    --cyan: #00b4ff; --cyan-dim: rgba(0,180,255,0.12);
    --green: #4caf50; --red: #ef5350; --yellow: #ffc107;
    --text: #e8e8ee; --text2: rgba(255,255,255,0.55); --text3: rgba(255,255,255,0.25);
    --radius: 12px; --radius-sm: 8px;
    --safe-bottom: env(safe-area-inset-bottom, 0px);
}

html { font-size:16px; -webkit-text-size-adjust:100%; }
body { font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif; background:var(--bg); color:var(--text); line-height:1.5; min-height:100vh; overflow-x:hidden; -webkit-font-smoothing:antialiased; }

::-webkit-scrollbar { width:3px; height:3px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.08); border-radius:3px; }

.fe-app { display:flex; flex-direction:column; min-height:100vh; }

/* ===== NAVBAR ===== */
.fe-navbar { position:sticky; top:0; z-index:1000; background:rgba(8,8,16,0.92); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); border-bottom:1px solid var(--border); }
.fe-navbar-inner { max-width:960px; margin:0 auto; padding:10px 16px; display:flex; align-items:center; justify-content:space-between; }
.fe-navbar-brand { display:flex; align-items:center; gap:8px; text-decoration:none; }
.fe-navbar-logo { width:28px; height:28px; border-radius:6px; object-fit:contain; }
.fe-navbar-text { font-weight:800; font-size:0.9rem; color:var(--gold); letter-spacing:-0.3px; }
.fe-navbar-actions { display:flex; align-items:center; gap:8px; }

/* ===== BUTTONS ===== */
.fe-btn { display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:8px 16px; border-radius:var(--radius-sm); font-size:0.8rem; font-weight:700; text-decoration:none; border:none; cursor:pointer; transition:all 0.2s; white-space:nowrap; }
.fe-btn:hover { transform:translateY(-1px); }
.fe-btn-sm { padding:6px 12px; font-size:0.75rem; }
.fe-btn-lg { padding:14px 28px; font-size:0.95rem; border-radius:var(--radius); }
.fe-btn-full { width:100%; }
.fe-btn-primary { background:linear-gradient(135deg,#0d47a1,#1976d2); color:#fff; }
.fe-btn-primary:hover { background:linear-gradient(135deg,#1565c0,#1e88e5); color:#fff; box-shadow:0 4px 15px rgba(13,71,161,0.4); }
.fe-btn-gold { background:linear-gradient(135deg,#e6a800,#ffc832); color:#000; font-weight:800; }
.fe-btn-gold:hover { box-shadow:0 4px 20px rgba(255,200,50,0.4); color:#000; }
.fe-btn-ghost { background:transparent; color:var(--text2); }
.fe-btn-ghost:hover { color:var(--text); background:rgba(255,255,255,0.05); }
.fe-btn-ghost-light { background:rgba(255,255,255,0.08); color:#fff; border:1px solid rgba(255,255,255,0.15); }
.fe-btn-ghost-light:hover { background:rgba(255,255,255,0.12); color:#fff; }
.fe-btn-outline { background:transparent; color:var(--text2); border:1.5px solid var(--border-light); }
.fe-btn-outline:hover { border-color:var(--cyan); color:var(--cyan); }
.fe-btn-wa { background:linear-gradient(135deg,#25d366,#128c7e); color:#fff; }
.fe-btn-wa:hover { box-shadow:0 4px 20px rgba(37,211,102,0.4); color:#fff; }

/* ===== HERO SECTION ===== */
.fe-hero { position:relative; background:var(--bg); overflow:hidden; }
.fe-hero-bg { position:relative; line-height:0; }
.fe-hero-img { width:100%; height:auto; display:block; }
.fe-hero-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, transparent 60%, rgba(8,8,16,0.6) 100%); pointer-events:none; }
.fe-hero-content { position:relative; padding:28px 20px 32px; text-align:center; }
.fe-hero-title { font-size:1.8rem; font-weight:900; color:var(--gold); line-height:1.1; margin-bottom:6px; }
.fe-hero-sub { font-size:0.85rem; color:var(--text2); margin-bottom:8px; }
.fe-hero-desc { font-size:0.75rem; color:var(--text3); max-width:400px; margin:0 auto 16px; line-height:1.6; }
.fe-hero-actions { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; }

/* ===== SECTIONS ===== */
.fe-body { flex:1; padding:16px; padding-bottom:calc(16px + var(--safe-bottom)); }
.fe-section { margin-bottom:24px; }
.fe-section-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; padding:0 2px; }
.fe-section-title { font-size:0.95rem; font-weight:800; color:var(--text); display:flex; align-items:center; gap:8px; }
.fe-section-icon { width:8px; height:8px; border-radius:50%; }
.fe-icon-live { background:var(--yellow); box-shadow:0 0 8px var(--yellow); animation:pulse 2s infinite; }
.fe-icon-open { background:var(--green); box-shadow:0 0 8px var(--green); }
.fe-icon-done { background:var(--cyan); }
@keyframes pulse { 0%,100%{opacity:1}50%{opacity:0.5} }
.fe-section-count { font-size:0.7rem; color:var(--text3); background:rgba(255,255,255,0.04); padding:3px 10px; border-radius:10px; font-weight:700; }

/* ===== TOURNAMENT CARDS ===== */
.fe-tournament-grid { display:flex; flex-direction:column; gap:12px; }
.fe-tournament-card { display:flex; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; text-decoration:none; color:inherit; transition:all 0.2s; }
.fe-tournament-card:hover { border-color:var(--border-light); transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,0.3); }
.fe-tournament-card:active { transform:scale(0.98); }

.fe-tc-image { position:relative; width:100px; flex-shrink:0; overflow:hidden; }
.fe-tc-image img { width:100%; height:100%; object-fit:cover; min-height:100px; }
.fe-tc-status { position:absolute; top:6px; left:6px; font-size:0.55rem; font-weight:800; padding:2px 6px; border-radius:4px; background:rgba(255,193,7,0.9); color:#000; text-transform:uppercase; letter-spacing:0.5px; }
.fe-tc-status-open { background:rgba(76,175,80,0.9); color:#fff; }
.fe-tc-status-done { background:rgba(0,180,255,0.9); color:#fff; }
.fe-tc-format { position:absolute; bottom:6px; left:6px; font-size:0.55rem; font-weight:700; padding:2px 6px; border-radius:4px; background:rgba(0,0,0,0.7); color:var(--text); backdrop-filter:blur(4px); }

.fe-tc-body { flex:1; padding:10px 12px; display:flex; flex-direction:column; justify-content:center; gap:4px; min-width:0; }
.fe-tc-name { font-size:0.85rem; font-weight:800; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fe-tc-desc { font-size:0.7rem; color:var(--text3); line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.fe-tc-meta { display:flex; flex-wrap:wrap; gap:6px; }
.fe-tc-meta-item { display:inline-flex; align-items:center; gap:3px; font-size:0.65rem; color:var(--text3); }
.fe-tc-paid { color:var(--red); }
.fe-tc-free { color:var(--green); }

.fe-tc-wa-bar { margin-top:6px; display:flex; align-items:center; gap:4px; font-size:0.65rem; font-weight:700; color:#25d366; text-decoration:none; }

/* Share button on tournament cards */
.fe-tc-share { display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:6px; border:none; background:rgba(255,255,255,0.06); color:var(--text3); cursor:pointer; transition:all 0.2s; flex-shrink:0; margin-left:auto; }
.fe-tc-share:hover { background:rgba(0,180,255,0.15); color:var(--cyan); }

/* Highlight / Advertise */
.fe-tc-highlighted { border-color:rgba(255,200,50,0.35)!important; box-shadow:0 0 20px rgba(255,200,50,0.08); }
.fe-tc-highlighted:hover { border-color:rgba(255,200,50,0.5)!important; box-shadow:0 0 30px rgba(255,200,50,0.15); }
.fe-highlight-badge { display:inline-flex; align-items:center; gap:4px; background:linear-gradient(135deg,#e6a800,#ffc832)!important; color:#000!important; font-size:0.6rem!important; font-weight:800!important; padding:3px 8px!important; border-radius:4px; text-transform:uppercase; letter-spacing:0.5px; animation:fe-hl-glow 2s ease-in-out infinite; }
@keyframes fe-hl-glow { 0%,100%{box-shadow:0 0 8px rgba(255,200,50,0.3)} 50%{box-shadow:0 0 16px rgba(255,200,50,0.6)} }

.fe-tc-ad-btn { display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:6px; border:none; background:rgba(255,200,50,0.12); color:var(--gold); cursor:pointer; transition:all 0.2s; flex-shrink:0; }
.fe-tc-ad-btn:hover { background:rgba(255,200,50,0.25); transform:scale(1.1); }

.fe-tc-ad-bar { margin-top:6px; display:flex; align-items:center; gap:4px; font-size:0.65rem; font-weight:700; color:var(--gold); }
.fe-tc-ad-bar a { display:flex; align-items:center; gap:4px; color:var(--gold); text-decoration:none; padding:4px 10px; border:1px dashed rgba(255,200,50,0.3); border-radius:6px; transition:all 0.2s; }
.fe-tc-ad-bar a:hover { background:rgba(255,200,50,0.12); border-color:var(--gold); }

/* Share bar on tournament detail */
.fe-share-bar { display:flex; gap:6px; margin-top:10px; justify-content:center; flex-wrap:wrap; }

.fe-tc-register .fe-tc-body { border-left:3px solid var(--green); }

/* ===== REGISTRATION CARDS (Vertical Design) ===== */
.fe-reg-grid { display:flex; flex-direction:column; gap:14px; }
.fe-reg-card { display:flex; flex-direction:column; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; text-decoration:none; color:inherit; transition:all 0.25s; }
.fe-reg-card:hover { border-color:rgba(76,175,80,0.3); transform:translateY(-2px); box-shadow:0 8px 28px rgba(0,0,0,0.35); }
.fe-reg-card:active { transform:scale(0.985); }

.fe-reg-img { position:relative; width:100%; max-height:220px; overflow:hidden; flex-shrink:0; background:var(--bg); display:flex; align-items:center; justify-content:center; }
.fe-reg-img img { width:100%; height:auto; max-height:220px; object-fit:contain; display:block; }
.fe-reg-img-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, transparent 40%, rgba(8,8,16,0.7) 100%); pointer-events:none; }

.fe-reg-badges { position:absolute; top:8px; left:8px; display:flex; gap:5px; align-items:center; flex-wrap:wrap; }
.fe-reg-format { font-size:0.55rem; font-weight:700; padding:2px 7px; border-radius:4px; background:rgba(0,0,0,0.7); color:var(--text); backdrop-filter:blur(4px); }

.fe-reg-img-info { position:absolute; bottom:8px; left:8px; display:flex; gap:6px; align-items:center; }
.fe-reg-slots { font-size:0.62rem; font-weight:700; padding:3px 8px; border-radius:5px; background:rgba(0,0,0,0.6); color:#fff; backdrop-filter:blur(4px); }
.fe-reg-price { font-size:0.58rem; font-weight:800; padding:2px 7px; border-radius:4px; text-transform:uppercase; letter-spacing:0.3px; }
.fe-reg-paid { background:rgba(239,83,80,0.85); color:#fff; }
.fe-reg-free { background:rgba(76,175,80,0.85); color:#fff; }

.fe-reg-body { padding:12px 14px; display:flex; flex-direction:column; gap:6px; border-top:2px solid rgba(76,175,80,0.2); }
.fe-reg-name { font-size:0.95rem; font-weight:800; color:var(--text); line-height:1.3; }
.fe-reg-desc { font-size:0.72rem; color:var(--text3); line-height:1.5; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.fe-reg-meta { display:flex; flex-wrap:wrap; gap:8px; }
.fe-reg-meta-item { display:inline-flex; align-items:center; gap:4px; font-size:0.68rem; color:var(--text3); }

.fe-reg-actions { display:flex; align-items:center; gap:8px; margin-top:4px; }
.fe-reg-wa-btn { display:inline-flex; align-items:center; gap:5px; padding:7px 14px; border-radius:var(--radius-sm); font-size:0.72rem; font-weight:700; color:#fff; background:linear-gradient(135deg,#25d366,#128c7e); cursor:pointer; transition:all 0.2s; flex:1; justify-content:center; }
.fe-reg-wa-btn:hover { box-shadow:0 4px 14px rgba(37,211,102,0.35); }
.fe-reg-share-btn { display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:var(--radius-sm); border:1px solid var(--border); background:rgba(255,255,255,0.04); color:var(--text3); cursor:pointer; transition:all 0.2s; flex-shrink:0; }
.fe-reg-share-btn:hover { background:rgba(0,180,255,0.12); color:var(--cyan); border-color:rgba(0,180,255,0.25); }
.fe-reg-ad-btn { display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:var(--radius-sm); border:1px dashed rgba(255,200,50,0.3); background:rgba(255,200,50,0.06); color:var(--gold); cursor:pointer; transition:all 0.2s; text-decoration:none; flex-shrink:0; }
.fe-reg-ad-btn:hover { background:rgba(255,200,50,0.15); border-color:var(--gold); }

/* ===== REGISTRATION DETAIL PAGE ===== */
.fe-reg-detail-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.fe-reg-detail-section { padding:16px; border-bottom:1px solid var(--border); }
.fe-reg-detail-section:last-of-type { border-bottom:none; }
.fe-reg-detail-heading { display:flex; align-items:center; gap:8px; font-size:0.85rem; font-weight:800; color:var(--text); margin-bottom:10px; }
.fe-reg-detail-heading svg { color:var(--cyan); flex-shrink:0; }
.fe-reg-detail-desc { font-size:0.82rem; color:var(--text2); line-height:1.7; white-space:pre-wrap; }
.fe-reg-detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.fe-reg-detail-item { display:flex; flex-direction:column; gap:3px; }
.fe-reg-detail-label { font-size:0.68rem; font-weight:600; color:var(--text3); text-transform:uppercase; letter-spacing:0.5px; }
.fe-reg-detail-value { font-size:0.85rem; font-weight:700; color:var(--text); }
.fe-text-red { color:var(--red)!important; }
.fe-text-green { color:var(--green)!important; }
.fe-reg-detail-cta { padding:20px 16px; text-align:center; background:rgba(76,175,80,0.04); }
.fe-reg-detail-status { font-size:0.9rem; font-weight:700; color:var(--green); margin-bottom:12px; }

/* ===== AUTH PAGES ===== */
.fe-auth-page { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:20px 16px; width:100%; max-width:420px; margin:0 auto; position:relative; }
.fe-auth-back { position:absolute; top:16px; left:16px; display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:var(--radius-sm); color:var(--text3); text-decoration:none; background:rgba(255,255,255,0.04); border:1px solid var(--border); transition:all 0.2s; }
.fe-auth-back:hover { color:var(--text); border-color:var(--border-light); background:rgba(255,255,255,0.08); }
.fe-auth-header { text-align:center; margin-bottom:20px; }
.fe-auth-logo { display:inline-flex; align-items:center; justify-content:center; width:150px; height:150px; border-radius:14px; background:rgba(255,200,50,0.08); border:1.5px solid rgba(255,200,50,0.15); margin-bottom:14px; }
.fe-auth-logo img { width:140px; height:140px; border-radius:8px; object-fit:contain; }
.fe-auth-title { font-size:1.5rem; font-weight:900; color:var(--gold); margin-bottom:4px; }
.fe-auth-sub { font-size:0.8rem; color:var(--text3); line-height:1.4; }
.fe-auth-card { width:100%; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:20px; }
.fe-auth-form { display:flex; flex-direction:column; gap:14px; }
.fe-auth-divider { text-align:center; margin:16px 0; position:relative; }
.fe-auth-divider::before { content:''; position:absolute; top:50%; left:0; right:0; height:1px; background:var(--border); }
.fe-auth-divider span { position:relative; background:var(--bg-card); padding:0 12px; color:var(--text3); font-size:0.75rem; }
.fe-auth-footer { text-align:center; font-size:0.68rem; color:var(--text3); margin-top:16px; line-height:1.4; }

/* ===== FORMS ===== */
.fe-form-group { margin-bottom:0; }
.fe-label { display:block; font-size:0.75rem; font-weight:700; color:var(--text2); margin-bottom:5px; }
.fe-input { width:100%; background:var(--bg-input); border:1px solid var(--border); color:var(--text); border-radius:var(--radius-sm); padding:11px 12px; font-size:0.85rem; font-family:inherit; transition:all 0.2s; box-sizing:border-box; -webkit-appearance:none; appearance:none; }
.fe-input:focus { outline:none; border-color:var(--cyan); box-shadow:0 0 0 3px rgba(0,180,255,0.15); }
.fe-input::placeholder { color:var(--text3); }
.fe-textarea { resize:vertical; min-height:80px; }
.fe-form-hint { display:block; font-size:0.65rem; color:var(--text3); margin-top:4px; }
.fe-row { display:flex; gap:12px; }
.fe-row > .fe-form-group { flex:1; }

/* ===== UPLOAD ===== */
.fe-upload-area { position:relative; }
.fe-upload-area input[type="file"] { position:absolute; opacity:0; width:100%; height:100%; cursor:pointer; }
.fe-upload-label { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; padding:24px; border:2px dashed var(--border-light); border-radius:var(--radius); color:var(--text3); cursor:pointer; transition:all 0.2s; text-align:center; }
.fe-upload-label:hover { border-color:var(--cyan); color:var(--cyan); }

/* ===== FORMAT SELECTOR ===== */
.fe-format-options { display:flex; flex-direction:column; gap:8px; }
.fe-format-option { display:flex; align-items:center; gap:12px; padding:14px; border:2px solid var(--border); border-radius:var(--radius); cursor:pointer; transition:all 0.2s; }
.fe-format-option input { display:none; }
.fe-format-option:hover { border-color:var(--border-light); }
.fe-format-option.selected { border-color:var(--cyan); background:var(--cyan-dim); }
.fe-format-icon { color:var(--text3); flex-shrink:0; }
.fe-format-option.selected .fe-format-icon { color:var(--cyan); }
.fe-format-info { flex:1; }
.fe-format-info strong { display:block; font-size:0.85rem; color:var(--text); margin-bottom:2px; }
.fe-format-info small { font-size:0.7rem; color:var(--text3); }

/* ===== TOGGLE GROUP ===== */
.fe-toggle-group { display:flex; gap:8px; }
.fe-toggle-option { flex:1; }
.fe-toggle-option input { display:none; }
.fe-toggle-label { display:flex; align-items:center; justify-content:center; gap:6px; padding:12px; border:2px solid var(--border); border-radius:var(--radius-sm); cursor:pointer; font-size:0.85rem; font-weight:700; color:var(--text3); transition:all 0.2s; }
.fe-toggle-option.selected .fe-toggle-label { border-color:var(--cyan); color:var(--cyan); background:var(--cyan-dim); }

/* ===== TOURNAMENT HEADER ===== */
.fe-tournament-header { background:var(--bg-card); border-bottom:1px solid var(--border); }
.fe-th-img { max-height:280px; display:flex; align-items:center; justify-content:center; background:var(--bg); overflow:hidden; }
.fe-th-img img { width:100%; height:auto; max-height:280px; object-fit:contain; display:block; }
.fe-th-info { padding:16px; }
.fe-th-name { font-size:1.3rem; font-weight:900; color:var(--gold); margin:8px 0 6px; }
.fe-th-meta { display:flex; flex-wrap:wrap; gap:6px; font-size:0.75rem; color:var(--text2); margin-bottom:12px; }
.fe-th-actions { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }

/* ===== CREATE FORM ===== */
.fe-create-section { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:20px; margin-bottom:16px; }
.fe-create-section-title { display:flex; align-items:center; gap:10px; font-size:0.95rem; font-weight:800; margin-bottom:16px; color:var(--text); }
.fe-create-step { display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:50%; background:linear-gradient(135deg,#0d47a1,#1976d2); color:#fff; font-size:0.8rem; font-weight:900; }

/* ===== USER MENU ===== */
.fe-user-menu { position:relative; cursor:pointer; display:flex; align-items:center; gap:4px; font-size:0.8rem; font-weight:700; color:var(--text2); padding:6px 10px; border-radius:var(--radius-sm); }
.fe-user-menu:hover { background:rgba(255,255,255,0.05); }
.fe-user-dropdown { display:none; position:absolute; top:100%; right:0; background:var(--bg-card); border:1px solid var(--border-light); border-radius:var(--radius-sm); min-width:120px; overflow:hidden; z-index:100; }
.fe-user-menu.open .fe-user-dropdown { display:block; }
.fe-user-dropdown a { display:block; padding:8px 14px; font-size:0.8rem; color:var(--text2); text-decoration:none; }
.fe-user-dropdown a:hover { background:rgba(255,255,255,0.05); color:var(--red); }

/* ===== DASHBOARD ===== */
.fe-back-link { display:inline-block; font-size:0.8rem; color:var(--text3); text-decoration:none; margin-bottom:12px; }
.fe-back-link:hover { color:var(--cyan); }
.fe-page-title { font-size:1.3rem; font-weight:900; margin-bottom:20px; }
.fe-dash-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; flex-wrap:wrap; gap:12px; }
.fe-dash-title { font-size:1.3rem; font-weight:900; }
.fe-dash-sub { font-size:0.8rem; color:var(--text3); }
.fe-dash-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:20px; }
.fe-dash-stat { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:14px 10px; text-align:center; }
.fe-dash-stat-val { font-size:1.4rem; font-weight:900; color:var(--gold); }
.fe-dash-stat-label { font-size:0.65rem; color:var(--text3); text-transform:uppercase; letter-spacing:0.5px; margin-top:2px; }
.fe-dash-list { display:flex; flex-direction:column; gap:10px; }
.fe-dash-card { display:flex; gap:12px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.fe-dash-card-img { width:70px; height:70px; flex-shrink:0; overflow:hidden; }
.fe-dash-card-img img { width:100%; height:100%; object-fit:cover; }
.fe-dash-card-body { flex:1; padding:10px 0; min-width:0; }
.fe-dash-card-top { display:flex; align-items:center; gap:8px; margin-bottom:4px; }
.fe-dash-card-name { font-size:0.85rem; font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fe-dash-card-info { font-size:0.7rem; color:var(--text3); display:flex; flex-wrap:wrap; gap:4px; margin-bottom:4px; }
.fe-dash-card-desc { font-size:0.68rem; color:var(--text3); display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden; }
.fe-dash-card-actions { display:flex; flex-direction:column; justify-content:center; gap:6px; padding:10px 12px; flex-shrink:0; }

/* ===== EMPTY STATE ===== */
.fe-empty { text-align:center; padding:40px 20px; }
.fe-empty-lg { padding:60px 20px; }
.fe-empty-icon { margin-bottom:16px; opacity:0.6; }
.fe-empty-title { font-size:1rem; font-weight:700; color:var(--text2); margin-bottom:6px; }
.fe-empty-sub { font-size:0.82rem; color:var(--text3); margin-bottom:16px; }

/* ===== TAB BAR ===== */
.fe-tabbar { display:flex; border-bottom:1px solid var(--border); background:rgba(15,15,26,0.95); backdrop-filter:blur(12px); position:sticky; top:0; z-index:100; }
.fe-tabbar-item { flex:1; display:flex; align-items:center; justify-content:center; gap:6px; padding:14px 0; text-decoration:none; color:var(--text3); font-size:0.8rem; font-weight:600; border-bottom:2.5px solid transparent; transition:all 0.2s; }
.fe-tabbar-item.active { color:var(--cyan); border-bottom-color:var(--cyan); }

/* ===== STANDINGS TABLE ===== */
.fe-standings-scroll { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:auto; -webkit-overflow-scrolling:touch; }
.fe-standings-table { width:100%; border-collapse:collapse; font-size:0.82rem; }
.fe-standings-table thead { position:sticky; top:0; z-index:10; }
.fe-standings-table thead th { background:#12122a; padding:10px 8px; font-size:0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--text3); white-space:nowrap; text-align:center; border-bottom:1px solid var(--border-light); }
.fe-standings-table thead .th-team { text-align:left; padding-left:14px; }
.fe-standings-table thead .th-pts { color:var(--gold); }
.fe-standings-table tbody td { padding:11px 8px; border-bottom:1px solid var(--border); text-align:center; vertical-align:middle; }
.fe-standings-table tbody tr:last-child td { border-bottom:none; }
.fe-standings-table tbody tr.row-top { background:rgba(255,200,50,0.02); }
.fe-standings-table tbody tr.row-top td:first-child { box-shadow:inset 3px 0 0 var(--gold); }
.td-pos { width:40px; padding-left:10px!important; }
.pos-badge { display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:7px; font-weight:800; font-size:0.72rem; }
.pos-gold { background:rgba(255,200,50,0.18); color:#ffc832; }
.pos-silver { background:rgba(192,192,192,0.12); color:#c0c0c0; }
.pos-bronze { background:rgba(205,127,50,0.12); color:#cd7f32; }
.pos-num { display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; font-weight:600; color:var(--text3); }
.td-team { text-align:left!important; padding-left:12px!important; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:200px; }
.td-stat { width:38px; font-weight:600; }
.td-muted { color:var(--text2); }
.td-green { color:var(--green); }
.td-red { color:var(--red); }
.td-yellow { color:var(--yellow); }
.td-gf { width:38px; font-weight:600; }
.td-ga { width:38px; font-weight:600; }
.td-gd { width:40px; font-weight:700; }
.td-pts { width:44px; font-weight:900; font-size:0.88rem; color:var(--gold); }

/* ===== MOBILE STANDINGS: compact fit, no truncation ===== */
@media (max-width:480px) {
    .fe-standings-scroll { overflow-x:auto; margin:0 -16px; border-radius:0; border-left:none; border-right:none; -webkit-overflow-scrolling:touch; }
    .fe-standings-table { font-size:0.7rem; table-layout:auto; width:100%; min-width:100%; }
    .fe-standings-table thead th { padding:8px 3px; font-size:0.56rem; letter-spacing:0.2px; }
    .fe-standings-table thead .th-team { padding-left:8px; text-align:left; }
    .fe-standings-table thead .th-pts { font-size:0.6rem; }
    .fe-standings-table tbody td { padding:9px 3px; }
    .td-pos { width:auto!important; padding-left:6px!important; }
    .pos-badge, .pos-num { width:20px; height:20px; font-size:0.58rem; border-radius:5px; }
    .td-team { max-width:none!important; padding-left:6px!important; font-size:0.66rem; white-space:nowrap; overflow:visible!important; text-overflow:clip!important; }
    .td-stat, .td-gf, .td-ga { width:auto!important; font-size:0.64rem; padding-left:3px!important; padding-right:3px!important; }
    .td-gd { width:auto!important; font-size:0.64rem; padding-left:3px!important; padding-right:3px!important; }
    .td-pts { width:auto!important; font-size:0.76rem; padding-left:4px!important; padding-right:6px!important; }
}

/* ===== GROUP LABEL ===== */
.fe-group-section { margin-bottom:16px; }
.fe-group-label { font-size:0.8rem; font-weight:800; color:var(--cyan); letter-spacing:1px; margin-bottom:8px; padding-left:4px; }

/* ===== LEGEND ===== */
.fe-legend { display:flex; gap:14px; padding:10px 4px 0; font-size:0.7rem; color:var(--text3); }
.dot { display:inline-block; width:7px; height:7px; border-radius:50%; margin-right:4px; vertical-align:middle; }
.dot-g { background:var(--green); } .dot-y { background:var(--yellow); } .dot-r { background:var(--red); }

/* ===== MATCHDAY SELECTOR ===== */
.fe-md-bar { margin-bottom:16px; }
.fe-md-scroll { display:flex; gap:8px; overflow-x:auto; -webkit-overflow-scrolling:touch; padding-bottom:4px; scrollbar-width:none; }
.fe-md-scroll::-webkit-scrollbar { display:none; }
.fe-md-chip { display:inline-flex; align-items:center; justify-content:center; min-width:56px; height:34px; padding:0 14px; border-radius:var(--radius-sm); font-size:0.76rem; font-weight:700; text-decoration:none; color:var(--text3); background:var(--bg-card); border:1px solid var(--border); white-space:nowrap; flex-shrink:0; }
.fe-md-chip.active { background:var(--cyan-dim); color:var(--cyan); border-color:rgba(0,180,255,0.25); }

/* ===== MATCH RESULT CARDS ===== */
.fe-results-list { display:flex; flex-direction:column; gap:12px; }
.fe-match-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.fe-match-teams { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; gap:8px; }
.fe-match-team { flex:1; font-weight:700; font-size:0.82rem; text-align:center; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; color:var(--text); min-width:0; }
.fe-match-team.team-win { color:var(--gold); }
.fe-match-team.team-lose { color:var(--text3); }
.fe-match-vs { font-size:0.65rem; font-weight:800; color:var(--text3); text-transform:uppercase; letter-spacing:1px; flex-shrink:0; }
.fe-match-score-big { font-size:1.1rem; font-weight:900; color:var(--text); flex-shrink:0; display:flex; align-items:center; gap:4px; }
.fe-match-agg { display:flex; align-items:center; justify-content:center; gap:8px; padding:8px 16px; font-size:0.72rem; color:var(--text2); background:rgba(0,0,0,0.2); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.fe-match-agg strong { color:var(--text); }
.agg-result { font-weight:700; font-size:0.68rem; padding:2px 8px; border-radius:10px; }
.agg-win { background:var(--gold-dim); color:var(--gold); }
.agg-draw { background:rgba(255,255,255,0.04); color:var(--text3); }
.fe-match-legs { display:flex; flex-direction:column; }
.fe-leg { padding:10px 16px; }
.fe-leg-tag { display:block; text-align:center; font-size:0.58rem; font-weight:800; text-transform:uppercase; letter-spacing:1.5px; color:var(--cyan); margin-bottom:6px; opacity:0.7; }
.fe-leg-body { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.fe-leg-team { flex:1; font-size:0.76rem; font-weight:600; color:var(--text2); text-align:center; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0; }
.fe-leg-team:first-child { text-align:right; }
.fe-leg-score { flex-shrink:0; display:flex; align-items:center; justify-content:center; gap:3px; min-width:50px; font-weight:800; font-size:0.88rem; }
.sc { color:var(--text2); min-width:18px; text-align:center; }
.sc-win { color:var(--gold); } .sc-lose { color:var(--text3); }
.sc-sep { color:var(--text3); font-size:0.78rem; }
.fe-leg-divider { height:1px; background:var(--border); margin:0 16px; }

/* ===== CUP BRACKET ===== */
.fe-cup-bracket-header { display:flex; align-items:center; gap:10px; padding:14px 16px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); margin-bottom:20px; }
.fe-cup-bracket-header svg { color:var(--gold); flex-shrink:0; }
.fe-cup-bracket-title { font-size:0.95rem; font-weight:800; color:var(--text); flex:1; }
.fe-cup-bracket-badge { display:inline-flex; align-items:center; gap:4px; padding:4px 10px; border-radius:20px; font-size:0.65rem; font-weight:700; background:rgba(255,200,50,0.1); color:var(--gold); border:1px solid rgba(255,200,50,0.2); }

.fe-cup-round { margin-bottom:24px; position:relative; }
.fe-cup-round-header { display:flex; align-items:center; gap:10px; margin-bottom:12px; padding:0 2px; }
.fe-cup-round-icon { width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,rgba(255,200,50,0.15),rgba(255,200,50,0.05)); border:1px solid rgba(255,200,50,0.2); }
.fe-cup-round-icon svg { color:var(--gold); }
.fe-cup-round-label { font-size:0.9rem; font-weight:800; color:var(--gold); letter-spacing:0.5px; }
.fe-cup-round-count { font-size:0.65rem; color:var(--text3); font-weight:600; margin-left:auto; }

.fe-cup-matches { display:grid; grid-template-columns:1fr; gap:10px; }
.fe-cup-match { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:all 0.25s; position:relative; }
.fe-cup-match:hover { border-color:var(--border-light); }
.fe-cup-match.cup-played { border-color:rgba(76,175,80,0.3); }
.fe-cup-match.cup-played::before { content:''; position:absolute; left:0; top:0; bottom:0; width:3px; background:linear-gradient(to bottom,var(--green),rgba(76,175,80,0.3)); border-radius:3px 0 0 3px; }
.fe-cup-match.cup-scheduled { border-color:rgba(0,180,255,0.2); }
.fe-cup-match.cup-scheduled::before { content:''; position:absolute; left:0; top:0; bottom:0; width:3px; background:linear-gradient(to bottom,var(--cyan),rgba(0,180,255,0.3)); border-radius:3px 0 0 3px; }

.fe-cup-match-num { position:absolute; top:8px; right:10px; font-size:0.55rem; font-weight:700; color:var(--text3); letter-spacing:0.5px; opacity:0.5; }

/* Single leg match layout */
.fe-cup-body { padding:14px 16px; }
.fe-cup-vs-row { display:flex; align-items:center; gap:8px; }
.fe-cup-team-block { flex:1; display:flex; align-items:center; gap:8px; min-width:0; }
.fe-cup-team-block.away { flex-direction:row-reverse; text-align:right; }
.fe-cup-team-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; background:var(--text3); transition:all 0.25s; }
.fe-cup-winner .fe-cup-team-dot { background:var(--gold); box-shadow:0 0 8px rgba(255,200,50,0.5); }
.fe-cup-loser .fe-cup-team-dot { background:var(--text3); opacity:0.3; }
.fe-cup-team-name { font-size:0.85rem; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; transition:color 0.25s; }
.fe-cup-winner .fe-cup-team-name { color:var(--gold); }
.fe-cup-loser .fe-cup-team-name { color:var(--text3); opacity:0.5; }
.fe-cup-vs-badge { display:flex; align-items:center; justify-content:center; width:30px; height:30px; border-radius:8px; background:rgba(255,255,255,0.04); border:1px solid var(--border); font-size:0.58rem; font-weight:800; color:var(--text3); letter-spacing:0.5px; flex-shrink:0; }
.fe-cup-score-row { display:flex; align-items:center; justify-content:center; gap:6px; margin-top:10px; padding:8px 0 2px; }
.fe-cup-score-box { display:inline-flex; align-items:center; justify-content:center; min-width:38px; height:32px; border-radius:6px; font-size:1rem; font-weight:900; background:rgba(255,255,255,0.04); border:1px solid var(--border); color:var(--text); }
.fe-cup-score-box.score-win { background:rgba(255,200,50,0.12); border-color:rgba(255,200,50,0.25); color:var(--gold); }
.fe-cup-score-box.score-lose { background:rgba(255,255,255,0.02); color:var(--text3); }
.fe-cup-score-box.score-draw { background:rgba(0,180,255,0.08); border-color:rgba(0,180,255,0.15); color:var(--cyan); }
.fe-cup-score-sep { font-size:0.8rem; font-weight:600; color:var(--text3); }
.fe-cup-score-dash { font-size:0.85rem; font-weight:700; color:var(--text3); }

.fe-cup-status-badge { display:inline-flex; align-items:center; gap:4px; padding:3px 10px; border-radius:20px; font-size:0.6rem; font-weight:700; letter-spacing:0.5px; }
.fe-cup-status-played { background:rgba(76,175,80,0.1); color:var(--green); }
.fe-cup-status-scheduled { background:rgba(0,180,255,0.08); color:var(--cyan); }

/* Two leg match layout */
.fe-cup-leg-section { padding:10px 16px; border-bottom:1px solid var(--border); }
.fe-cup-leg-section:last-of-type { border-bottom:none; }
.fe-cup-leg-tag { display:flex; align-items:center; gap:6px; margin-bottom:8px; }
.fe-cup-leg-tag span { display:inline-flex; align-items:center; gap:4px; padding:3px 8px; border-radius:4px; font-size:0.6rem; font-weight:800; text-transform:uppercase; letter-spacing:1px; color:var(--cyan); background:rgba(0,180,255,0.08); }
.fe-cup-leg-tag small { font-size:0.6rem; color:var(--text3); font-weight:600; }
.fe-cup-leg-row { display:flex; align-items:center; gap:6px; }
.fe-cup-leg-home { flex:1; font-size:0.78rem; font-weight:700; color:var(--text); text-align:right; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fe-cup-leg-away { flex:1; font-size:0.78rem; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fe-cup-leg-scores { display:flex; align-items:center; gap:4px; flex-shrink:0; }
.fe-cup-leg-sc { min-width:24px; height:24px; display:flex; align-items:center; justify-content:center; border-radius:4px; font-size:0.82rem; font-weight:800; background:rgba(255,255,255,0.04); color:var(--text); }
.fe-cup-leg-sc.lsc-win { background:rgba(255,200,50,0.12); color:var(--gold); }
.fe-cup-leg-sc.lsc-lose { color:var(--text3); }

.fe-cup-agg-bar { display:flex; align-items:center; justify-content:center; gap:8px; padding:10px 16px; background:rgba(255,200,50,0.04); border-top:1px solid var(--border); }
.fe-cup-agg-label { font-size:0.62rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--text3); }
.fe-cup-agg-score { font-size:0.9rem; font-weight:900; color:var(--text); display:flex; align-items:center; gap:3px; }
.fe-cup-agg-result { font-size:0.62rem; font-weight:800; padding:2px 8px; border-radius:10px; }
.cup-agg-winner { background:rgba(255,200,50,0.15); color:var(--gold); }
.cup-agg-draw { background:rgba(255,255,255,0.04); color:var(--text3); }

/* Cup match footer */
.fe-cup-match-footer { display:flex; align-items:center; justify-content:center; padding:8px 16px; border-top:1px solid var(--border); }

/* Responsive cup */
@media (min-width:768px) {
    .fe-cup-matches { grid-template-columns:repeat(2, 1fr); gap:12px; }
    .fe-cup-bracket-header { padding:16px 20px; }
}
@media (min-width:1024px) {
    .fe-cup-matches.round-final { grid-template-columns:1fr; max-width:400px; margin:0 auto; }
}
/* 3rd Place Match Styling */
.fe-cup-match.match-3rd-place { border-color:rgba(205,127,50,0.4); background:linear-gradient(135deg, var(--bg-card), rgba(205,127,50,0.05)); }
.fe-cup-match.match-3rd-place.cup-played { border-color:rgba(205,127,50,0.5); }
.fe-cup-match.match-3rd-place.cup-played::before { background:linear-gradient(to bottom, #cd7f32, rgba(205,127,50,0.3)); }
.fe-cup-match.match-3rd-place .fe-cup-match-num { color:#cd7f32; opacity:1; font-size:0.6rem; font-weight:800; letter-spacing:0.5px; }

/* ===== CHAMPIONS ===== */
.fe-champ-podium { display:flex; gap:0; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.fe-champ-card { flex:1; text-align:center; padding:18px 8px 16px; position:relative; }
.fe-champ-card:not(:last-child) { border-right:1px solid var(--border); }
.fe-champ-card.champ-first { background:rgba(255,200,50,0.03); }
.fe-champ-card.champ-first::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.fe-champ-medal { width:40px; height:40px; border-radius:50%; border:2px solid; display:inline-flex; align-items:center; justify-content:center; margin-bottom:8px; }
.fe-champ-pos-num { font-size:1.1rem; font-weight:900; line-height:1; }
.fe-champ-pos-label { font-size:0.65rem; font-weight:800; text-transform:uppercase; letter-spacing:1px; margin-bottom:6px; }
.fe-champ-name { font-size:0.82rem; font-weight:700; color:var(--text); margin-bottom:3px; word-break:break-word; }
.fe-champ-username { font-size:0.72rem; color:var(--cyan); font-weight:600; }

/* ===== PAGINATION ===== */
.fe-pagination { display:flex; flex-direction:column; align-items:center; gap:12px; margin-top:16px; padding:0 2px; }
.fe-pagination-info { font-size:0.72rem; color:var(--text3); font-weight:600; }
.fe-pagination-btns { display:flex; align-items:center; gap:6px; flex-wrap:wrap; justify-content:center; }
.fe-page-btn { display:inline-flex; align-items:center; justify-content:center; min-width:36px; height:36px; padding:0 10px; border-radius:var(--radius-sm); font-size:0.8rem; font-weight:700; text-decoration:none; color:var(--text2); background:var(--bg-card); border:1px solid var(--border); transition:all 0.2s; cursor:pointer; }
.fe-page-btn:hover { border-color:var(--cyan); color:var(--cyan); background:rgba(0,180,255,0.08); }
.fe-page-btn:active { transform:scale(0.95); }
.fe-page-btn-active { background:linear-gradient(135deg,#0d47a1,#1976d2)!important; color:#fff!important; border-color:transparent!important; box-shadow:0 2px 10px rgba(13,71,161,0.4); }
.fe-page-btn-active:hover { background:linear-gradient(135deg,#1565c0,#1e88e5)!important; color:#fff!important; }
.fe-page-ellipsis { display:inline-flex; align-items:center; justify-content:center; min-width:28px; height:36px; font-size:0.8rem; color:var(--text3); font-weight:600; letter-spacing:1px; }

/* ===== FOOTER ===== */
.fe-footer { text-align:center; padding:24px 16px; flex-shrink:0; }
.fe-footer-brand { display:inline-block; font-size:0.85rem; font-weight:800; color:var(--gold); letter-spacing:0.5px; margin-bottom:4px; text-decoration:none; }
.fe-footer-text { font-size:0.75rem; color:var(--text3); margin-bottom:2px; }
.fe-footer-sub { font-size:0.65rem; opacity:0.5; }

/* ===== ALERTS ===== */
.alert { border-radius:10px; border:none; font-size:0.85rem; }
.alert-danger { background:rgba(239,83,80,0.15); border:1px solid rgba(239,83,80,0.3); color:#ff6b6b; }
.alert-success { background:rgba(76,175,80,0.15); border:1px solid rgba(76,175,80,0.3); color:#81c784; }
.alert-warning { background:rgba(255,193,7,0.15); border:1px solid rgba(255,193,7,0.3); color:#ffd54f; }
.alert-info { background:rgba(0,180,255,0.15); border:1px solid rgba(0,180,255,0.3); color:#4fc3f7; }

/* ===== BADGES ===== */
.badge { font-weight:700; }

/* ===== DESKTOP ===== */
@media (min-width:768px) {
    .fe-app { max-width:none; }
    .fe-navbar-inner { padding:10px 24px; }
    .fe-hero { display:flex; flex-direction:column; align-items:center; }
    .fe-hero-bg { width:100%; max-width:800px; }
    .fe-hero-img { border-radius:var(--radius) var(--radius) 0 0; }
    .fe-hero-content { padding:32px 24px 40px; max-width:600px; }
    .fe-hero-title { font-size:2.4rem; }
    .fe-hero-desc { max-width:500px; }
    .fe-body { max-width:640px; margin:0 auto; }
    .fe-tournament-grid { grid-template-columns:1fr; }
    .fe-tournament-card { /* keep vertical on desktop too */ }
    .fe-tc-image { width:140px; }
    .fe-results-list { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
    .fe-dash-stats { grid-template-columns:repeat(4,1fr); }
}

@media (min-width:1024px) {
    .fe-tournament-grid { grid-template-columns:1fr 1fr; }
}

/* ===== ADMIN PANEL (kept for manage & admin pages) ===== */
.admin-body { overflow-x:hidden; }
.glass-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); }
.stat-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:20px; text-align:center; position:relative; overflow:hidden; transition:transform 0.2s,box-shadow 0.2s; }
.stat-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; border-radius:var(--radius) var(--radius) 0 0; }
.stat-card:hover { transform:translateY(-4px); box-shadow:0 12px 30px rgba(0,0,0,0.3); }
.stat-blue::before { background:linear-gradient(90deg,#0d47a1,#00b4ff); }
.stat-green::before { background:linear-gradient(90deg,#2e7d32,#66bb6a); }
.stat-orange::before { background:linear-gradient(90deg,#e65100,#ffa726); }
.stat-purple::before { background:linear-gradient(90deg,#6a1b9a,#ab47bc); }
.stat-icon { font-size:1.8rem; margin-bottom:8px; opacity:0.8; }
.stat-blue .stat-icon { color:#00b4ff; } .stat-green .stat-icon { color:#66bb6a; }
.stat-orange .stat-icon { color:#ffa726; } .stat-purple .stat-icon { color:#ab47bc; }
.stat-value { font-size:2rem; font-weight:800; line-height:1.1; letter-spacing:-1px; }
.stat-label { font-size:0.75rem; color:var(--text2); text-transform:uppercase; letter-spacing:1px; margin-top:4px; }

.match-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:20px; height:100%; }
.match-played { border-left:3px solid var(--green); }
.match-scheduled { border-left:3px solid var(--cyan); }
.match-team-name { font-size:0.85rem; }
.score-input { width:60px!important; text-align:center; font-size:1.3rem; font-weight:700; background:rgba(255,255,255,0.05)!important; border:2px solid rgba(255,255,255,0.1)!important; color:#fff!important; border-radius:10px!important; padding:6px!important; }
.score-input:focus { border-color:#0d47a1!important; box-shadow:0 0 0 3px rgba(13,71,161,0.3)!important; }
.score-input::-webkit-outer-spin-button,.score-input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.score-input[type=number] { -moz-appearance:textfield; }

.admin-sidebar { position:fixed;top:0;left:0;width:250px;height:100vh;background:linear-gradient(180deg,#0c0c20,#0a0a18);border-right:1px solid var(--border);z-index:1000;display:flex;flex-direction:column; }
.sidebar-brand { padding:25px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border); }
.sidebar-brand span { font-weight:800;font-size:1rem;line-height:1.3; }
.sidebar-nav .nav-link { color:var(--text2);padding:12px 20px;display:flex;align-items:center;gap:10px;border-left:3px solid transparent;font-size:0.9rem;text-decoration:none; }
.sidebar-nav .nav-link:hover { color:var(--text);background:rgba(255,255,255,0.03); }
.sidebar-nav .nav-link.active { color:var(--cyan);background:rgba(0,180,255,0.08);border-left-color:var(--cyan); }
.sidebar-footer { margin-top:auto;padding:15px 20px;border-top:1px solid var(--border); }
.admin-main { margin-left:250px;min-height:100vh; }
.admin-topbar { background:rgba(10,10,20,0.8);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:15px 24px;position:sticky;top:0;z-index:500; }
.admin-content { padding-top:10px; }

/* ===== Bootstrap 5 Dark Theme Overrides ===== */
.form-control { background-color:rgba(255,255,255,0.05)!important;border:1px solid rgba(255,255,255,0.1)!important;color:#e8e8ee!important;border-radius:10px;padding:10px 14px; }
.form-select { background-color:rgba(255,255,255,0.05)!important;background-image:none!important;border:1px solid rgba(255,255,255,0.1)!important;color:#e8e8ee!important;border-radius:10px;padding:10px 14px!important;appearance:auto!important;-webkit-appearance:auto!important;-moz-appearance:auto!important; }
.form-control:focus,.form-select:focus { background-color:rgba(255,255,255,0.08)!important;background-image:none!important;border-color:#0d47a1!important;box-shadow:0 0 0 3px rgba(13,71,161,0.15)!important;color:#fff!important; }
.form-control::placeholder { color:var(--text3)!important; }
textarea.form-control { resize:vertical; }
.form-select option { background:#1a1a2e!important; color:#e8e8ee!important; }

/* Ensure Bootstrap Icons font loads with fallback */
.bi { display:inline-block; font-family:'bootstrap-icons'!important; font-style:normal; font-weight:normal!important; font-variant:normal; text-rendering:auto; -webkit-font-smoothing:antialiased; }
.bi::before { display:inline-block; font-family:'bootstrap-icons'!important; font-style:normal; font-weight:normal!important; }
.form-label { color:var(--text2)!important; font-size:0.85rem; }
.form-check-input { background-color:rgba(255,255,255,0.08)!important; border-color:rgba(255,255,255,0.2)!important; }
.form-check-input:checked { background-color:#0d47a1!important; border-color:#0d47a1!important; }
.form-check-label { color:var(--text)!important; }

/* Nav Tabs - Dark Theme */
.nav-tabs { border-bottom-color:rgba(255,255,255,0.1)!important; }
.nav-tabs .nav-link { color:var(--text3)!important; background:transparent!important; border:none!important; border-bottom:2px solid transparent!important; padding:10px 16px; border-radius:8px 8px 0 0; font-size:0.85rem; font-weight:600; transition:all 0.2s; }
.nav-tabs .nav-link:hover { color:var(--text)!important; background:rgba(255,255,255,0.04)!important; border-bottom-color:rgba(255,255,255,0.2)!important; }
.nav-tabs .nav-link.active { color:var(--cyan)!important; background:rgba(0,180,255,0.08)!important; border-bottom:2px solid var(--cyan)!important; }

/* List Group - Dark Theme */
.list-group-item { background:transparent!important; color:var(--text)!important; border-color:rgba(255,255,255,0.06)!important; }
.list-group-item:hover { background:rgba(255,255,255,0.03)!important; }

/* Table Dark overrides */
.table-dark { --bs-table-bg:transparent; --bs-table-color:var(--text); --bs-table-border-color:rgba(255,255,255,0.06); }
.table-dark > :not(caption) > * > * { background-color:transparent; color:var(--text); border-color:rgba(255,255,255,0.06); }
.table-dark thead th { color:var(--text2)!important; }

/* Input Group */
.input-group-text { background:rgba(255,255,255,0.05)!important; color:var(--text2)!important; border-color:rgba(255,255,255,0.1)!important; }

/* Buttons */
.btn-primary { background:linear-gradient(135deg,#0d47a1,#1976d2)!important;border:none!important;border-radius:10px;padding:10px 20px;font-weight:600;color:#fff!important;text-decoration:none; }
.btn-primary:hover { background:linear-gradient(135deg,#1565c0,#1e88e5)!important;color:#fff!important; }
.btn-success { background:linear-gradient(135deg,#2e7d32,#43a047)!important;border:none!important;border-radius:10px;font-weight:600;color:#fff!important; }
.btn-success:hover { color:#fff!important; }
.btn-info { background:linear-gradient(135deg,#006064,#00838f)!important;border:none!important;color:#fff!important; }
.btn-info:hover { background:linear-gradient(135deg,#00838f,#0097a7)!important;color:#fff!important; }
.btn-outline-light,.btn-outline-danger,.btn-outline-info,.btn-outline-secondary { border-radius:10px;border-width:1.5px; }
.btn-outline-secondary { color:var(--text3)!important; border-color:rgba(255,255,255,0.15)!important; }
.btn-outline-secondary:hover { color:#fff!important; background:rgba(255,255,255,0.08)!important; }
.btn-link { color:var(--text)!important; }

/* Small text helpers */
.text-secondary { color:var(--text3)!important; }
small.text-secondary { color:var(--text3)!important; }

.standings-table { font-size:0.9rem; }
.standings-table thead { background:rgba(13,71,161,0.2); }
.standings-table thead th { border-bottom:2px solid #0d47a1;font-size:0.8rem;text-transform:uppercase;letter-spacing:0.5px;color:var(--text2);padding:12px 8px; }
.standings-table tbody td { padding:14px 8px;vertical-align:middle;border-bottom:1px solid rgba(255,255,255,0.04); }
.standings-row.top-three { background:rgba(255,200,50,0.03); }
.standings-row.top-three td:first-child { border-left:3px solid var(--gold); }

@media (max-width:767.98px) {
    .admin-sidebar { transform:translateX(-100%);width:280px;transition:transform 0.3s; }
    .admin-sidebar.show { transform:translateX(0); }
    .admin-main { margin-left:0; }
    .stat-value { font-size:1.5rem; }
    .score-input { width:48px!important;font-size:1.1rem;padding:4px!important; }
    .match-team-name { font-size:0.75rem; }
    .sidebar-footer { padding-bottom:30px; }
    .fe-dash-stats { grid-template-columns:repeat(2,1fr); }
    .fe-dash-card { flex-direction:column; }
    .fe-dash-card-img { width:100%; height:80px; }
    .fe-dash-card-actions { flex-direction:row; }
}
