/* =====================================================
   LBL - Liga Brasileira dos Low Elo
   Custom Styles (complementa TailwindCSS CDN)
   ===================================================== */

:root {
  --lbl-gold:       #C89B3C;
  --lbl-gold-light: #F0E6C8;
  --lbl-dark:       #0A1428;
  --lbl-dark-2:     #0D1B36;
  --lbl-dark-3:     #162035;
  --lbl-dark-card:  #1A2744;
  --lbl-border:     rgba(200,155,60,0.25);
  --lbl-text:       #C8AA6E;
}

/* Fundo geral */
body {
  background-color: var(--lbl-dark);
  color: #B8C0CC;
  font-family: 'Inter', 'Segoe UI', sans-serif;
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--lbl-dark-2); }
::-webkit-scrollbar-thumb { background: var(--lbl-gold); border-radius: 3px; }

/* Cards */
.lbl-card {
  background: var(--lbl-dark-card);
  border: 1px solid var(--lbl-border);
  border-radius: 0.75rem;
}

.lbl-card-shine {
  background: linear-gradient(135deg, var(--lbl-dark-card) 0%, rgba(200,155,60,0.04) 100%);
  border: 1px solid var(--lbl-border);
  border-radius: 0.75rem;
}

/* Botões */
.btn-lbl {
  background: linear-gradient(135deg, #C89B3C 0%, #A07830 100%);
  color: #0A1428;
  font-weight: 700;
  padding: 0.5rem 1.25rem;
  border-radius: 0.375rem;
  transition: all 0.2s;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.btn-lbl:hover { filter: brightness(1.15); transform: translateY(-1px); }

.btn-lbl-outline {
  background: transparent;
  color: var(--lbl-gold);
  border: 1px solid var(--lbl-gold);
  padding: 0.5rem 1.25rem;
  border-radius: 0.375rem;
  transition: all 0.2s;
  cursor: pointer;
}
.btn-lbl-outline:hover { background: rgba(200,155,60,0.1); }

.btn-danger {
  background: linear-gradient(135deg, #C0392B 0%, #962D22 100%);
  color: #fff;
  font-weight: 700;
  padding: 0.5rem 1.25rem;
  border-radius: 0.375rem;
  transition: all 0.2s;
  border: none;
  cursor: pointer;
}
.btn-danger:hover { filter: brightness(1.15); }

/* Formulários */
.lbl-input {
  background: rgba(10,20,40,0.8);
  border: 1px solid rgba(200,155,60,0.3);
  color: #C8AA6E;
  border-radius: 0.375rem;
  padding: 0.5rem 0.75rem;
  width: 100%;
  transition: border-color 0.2s;
}
.lbl-input:focus {
  outline: none;
  border-color: var(--lbl-gold);
  box-shadow: 0 0 0 2px rgba(200,155,60,0.15);
}
.lbl-input::placeholder { color: rgba(200,170,110,0.4); }

.lbl-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--lbl-gold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.375rem;
}

.lbl-select {
  background: rgba(10,20,40,0.8);
  border: 1px solid rgba(200,155,60,0.3);
  color: #C8AA6E;
  border-radius: 0.375rem;
  padding: 0.5rem 0.75rem;
  width: 100%;
}
.lbl-select:focus { outline: none; border-color: var(--lbl-gold); }
.lbl-select option { background: #0D1B36; }

/* Tabelas */
.lbl-table { width: 100%; border-collapse: collapse; }
.lbl-table th {
  background: rgba(200,155,60,0.1);
  color: var(--lbl-gold);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.625rem 0.875rem;
  text-align: left;
  border-bottom: 1px solid var(--lbl-border);
}
.lbl-table td {
  padding: 0.625rem 0.875rem;
  border-bottom: 1px solid rgba(200,155,60,0.08);
  vertical-align: middle;
  font-size: 0.875rem;
}
.lbl-table tr:hover td { background: rgba(200,155,60,0.04); }
.lbl-table tr:last-child td { border-bottom: none; }

/* Sidebar */
.lbl-sidebar {
  background: var(--lbl-dark-2);
  border-right: 1px solid var(--lbl-border);
  width: 260px;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  transition: transform 0.28s cubic-bezier(.4,0,.2,1);
  overflow-y: auto;
  overscroll-behavior: contain;
  /* Desktop: always visible */
  transform: translateX(0);
}
#sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 9998;
  cursor: pointer;
}
#sidebar-backdrop.show { display: block; }
.sidebar-link {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.625rem 1rem;
  border-radius: 0.375rem;
  color: rgba(200,170,110,0.7);
  transition: all 0.2s;
  font-size: 0.875rem;
  text-decoration: none;
}
.sidebar-link:hover,
.sidebar-link.active {
  background: rgba(200,155,60,0.1);
  color: var(--lbl-gold);
  border-left: 2px solid var(--lbl-gold);
  padding-left: calc(1rem - 2px);
}

/* Logo hero */
.lbl-logo-text {
  background: linear-gradient(135deg, #F0D080 0%, #C89B3C 50%, #8B6420 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Dividers decorativos */
.lbl-divider {
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--lbl-gold), transparent);
  margin: 1.5rem 0;
}

/* Stat Cards */
.stat-card {
  background: var(--lbl-dark-card);
  border: 1px solid var(--lbl-border);
  border-radius: 0.75rem;
  padding: 1.25rem;
  position: relative;
  overflow: hidden;
}
.stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--lbl-gold), transparent);
}

/* Position badges */
.pos-top     { color: #E04040; }
.pos-jungle  { color: #40C040; }
.pos-mid     { color: #8040C0; }
.pos-adc     { color: #4080C0; }
.pos-support { color: #40C0C0; }
.pos-fill    { color: #C09040; }

/* Animações */
@keyframes lbl-pulse-gold {
  0%, 100% { box-shadow: 0 0 8px rgba(200,155,60,0.3); }
  50%       { box-shadow: 0 0 20px rgba(200,155,60,0.7); }
}
.live-indicator { animation: lbl-pulse-gold 1.5s infinite; }

/* Nav pública */
.public-nav {
  background: rgba(10,20,40,0.96);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--lbl-border);
  position: sticky;
  top: 0;
  z-index: 100;
}

/* Hero section */
.hero-bg {
  background: radial-gradient(ellipse at 50% 0%, rgba(200,155,60,0.12) 0%, transparent 70%),
              linear-gradient(180deg, var(--lbl-dark-2) 0%, var(--lbl-dark) 100%);
}

/* Responsive */
@media (max-width: 767px) {
  /* Hide sidebar off-screen by default on mobile */
  .lbl-sidebar {
    transform: translateX(-260px) !important;
  }
  /* When opened via JS, slide in */
  .lbl-sidebar.sidebar-open {
    transform: translateX(0) !important;
  }
  .lbl-main-content { margin-left: 0 !important; }
}

/* ===================== Coach Portal ===================== */
.coach-card {
  background: #0D1B2E;
  border: 1px solid #1E3A5F;
  border-radius: 0.75rem;
  padding: 1rem;
}

.lbl-btn-sm {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.875rem;
  border-radius: 0.5rem;
  background: #C89B3C;
  color: #0A1428;
  font-size: 0.8125rem;
  font-weight: 700;
  text-decoration: none;
  transition: background 0.15s;
  border: none;
  cursor: pointer;
}
.lbl-btn-sm:hover { background: #d9ad4a; }
