/* Scoped to plugin only */
.fpl-lp { font-family: inherit; }

.fpl-lp-topbar{
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 18px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  margin-bottom:14px;
}

.fpl-lp-brand{ font-size:14px; color:#111; }
.fpl-lp-pills{ display:flex; gap:10px; flex-wrap:wrap; }
.fpl-pill{
  background:#f5f7fb;
  border:1px solid rgba(0,0,0,.08);
  color:#111;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:600;
}

.fpl-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  overflow:hidden;
}

.fpl-card-hd{
  display:flex; justify-content:space-between; align-items:center;
  padding:16px 18px;
  border-bottom:1px solid rgba(0,0,0,.08);
}

.fpl-title-name{
  color:#111 !important;
  font-weight:800;
  font-size:16px;
  line-height:1.1;
}
.fpl-title-sub{
  color:#556;
  font-weight:600;
  font-size:12px;
  margin-top:4px;
}

.fpl-actions .fpl-btn{
  appearance:none;
  border:1px solid rgba(0,0,0,.12);
  background:#111;
  color:#fff;
  padding:8px 12px;
  border-radius:10px;
  font-weight:700;
  cursor:pointer;
}

.fpl-grid{
  display:grid;
  gap:12px;
  padding:14px 18px;
}
.fpl-grid-4{ grid-template-columns: repeat(4, minmax(0,1fr)); }
.fpl-grid-3{ grid-template-columns: repeat(3, minmax(0,1fr)); }

.fpl-kpi, .fpl-box{
  background:#f7f9fc;
  border:1px solid rgba(0,0,0,.07);
  border-radius:14px;
  padding:12px 12px;
}

.kpi-label{ font-size:12px; font-weight:700; color:#667; }
.kpi-value{ font-size:20px; font-weight:900; color:#111; margin-top:4px; }
.kpi-sub{ font-size:12px; color:#667; margin-top:4px; }

.fpl-box{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.box-title{ font-size:13px; font-weight:800; color:#111; }
.box-right{ font-size:18px; font-weight:900; color:#111; }
.box-sub{ font-size:12px; color:#667; }

.fpl-divider{ height:1px; background:rgba(0,0,0,.08); }

.fpl-section{ padding:14px 18px; }
.fpl-section-hd{ display:flex; justify-content:space-between; align-items:center; gap:10px; }
.fpl-section-title{ font-weight:900; color:#111; }
#fplLpStatus{ font-size:12px; color:#667; font-weight:700; }

/* League tools (search) */
.fpl-league-tools{ margin-top:10px; }
.fpl-league-tools-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.fpl-search{
  display:flex;
  align-items:center;
  gap:8px;
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  border-radius:12px;
  padding:8px 10px;
  min-width: 240px;
  flex: 1 1 280px;
}
.fpl-search-ico{ font-size:13px; opacity:.7; }
#fplLpLeagueSearch{
  border:none !important;
  outline:none !important;
  width:100%;
  font-size:13px;
  color:#111;
  background:transparent;
}
.fpl-search-clear{
  border:none;
  background:transparent;
  font-size:18px;
  line-height:1;
  cursor:pointer;
  opacity:.55;
}
.fpl-search-clear:hover{ opacity:1; }
.fpl-league-tools-note{
  font-size:12px;
  font-weight:800;
  color:#667;
}

/* NEW: League header snapshot */
.fpl-league-meta{
  margin-top:12px;
  background:#f7f9fc;
  border:1px solid rgba(0,0,0,.07);
  border-radius:14px;
  padding:12px;
}
.fpl-league-meta-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.fpl-league-meta-left{ min-width: 240px; flex: 1 1 320px; }
.fpl-league-meta-title{
  font-size:14px;
  font-weight:900;
  color:#111;
  line-height:1.2;
}
.fpl-league-meta-sub{
  margin-top:6px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  font-size:12px;
  color:#667;
  font-weight:800;
}
.fpl-league-chip{
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  border-radius:999px;
  padding:4px 10px;
  color:#111;
  font-weight:900;
}
.fpl-league-dot{ opacity:.55; }
.fpl-league-meta-right{
  display:grid;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  gap:10px;
  flex: 1 1 360px;
}
.fpl-league-stat{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:12px;
  padding:10px;
}
.fpl-league-stat-label{
  font-size:11px;
  color:#667;
  font-weight:900;
}
.fpl-league-stat-value{
  margin-top:4px;
  font-size:14px;
  font-weight:900;
  color:#111;
}

/* Tabs */
.fpl-league-tabs{
  display:flex; flex-wrap:wrap; gap:8px;
  margin-top:12px;
}
.fpl-tab{
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
  color:#111;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  cursor:pointer;

  display:inline-flex;
  align-items:center;
  gap:8px;
  max-width: 100%;
}
.fpl-tab-name{
  max-width: 320px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.fpl-tab-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 26px;
  height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  background:#f5f7fb;
  border:1px solid rgba(0,0,0,.10);
  font-size:11px;
  font-weight:900;
  color:#111;
}
.fpl-tab-star{
  margin-left: 2px;
  font-size: 13px;
  line-height: 1;
  opacity: .35;
  transform: translateY(-.5px);
  user-select:none;
}
.fpl-tab-star.is-on{ opacity: 1; }
.fpl-tab:hover .fpl-tab-star{ opacity: .75; }

.fpl-tab.is-active{
  background:#111;
  color:#fff;
  border-color:#111;
}
.fpl-tab.is-active .fpl-tab-badge{
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.20);
  color:#fff;
}
.fpl-tab.is-active .fpl-tab-star{ opacity: .95; }

/* Table */
.fpl-table-wrap{ padding:0 18px 18px 18px; overflow:auto; }
.fpl-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  min-width:640px;
}
.fpl-table thead th{
  text-align:left;
  font-size:12px;
  color:#667;
  font-weight:900;
  padding:10px 10px;
  border-bottom:1px solid rgba(0,0,0,.10);
}
.fpl-table tbody td{
  padding:10px 10px;
  border-bottom:1px solid rgba(0,0,0,.06);
  font-size:13px;
  color:#111;
}
.fpl-table tbody tr:hover{
  background:#f5f7fb;
  cursor:pointer;
}
.fpl-table .muted{ color:#667; text-align:center; padding:18px 10px; }

.fpl-row .team{ font-weight:900; }
.fpl-row .mgr{ color:#445; font-weight:700; }
.fpl-row.is-me{ background:#eef5ff; }

.clickable{ cursor:pointer; }

/* Pager */
.fpl-pager{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:flex-end;
  padding: 0 18px 18px 18px;
  flex-wrap: wrap;
}
.fpl-pager-meta{
  font-size: 12px;
  font-weight: 800;
  color: #667;
  margin-left: auto;
}
.fpl-btn-light{
  background:#fff !important;
  color:#111 !important;
  border:1px solid rgba(0,0,0,.12) !important;
}
.fpl-pager .fpl-btn[disabled]{
  opacity:.45;
  cursor:not-allowed;
}

/* Responsive */
@media (max-width: 980px){
  .fpl-grid-4{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .fpl-grid-3{ grid-template-columns: repeat(1, minmax(0,1fr)); }
  .fpl-card-hd{ flex-direction:column; align-items:flex-start; gap:10px; }
  .fpl-actions{ width:100%; }
  .fpl-actions .fpl-btn{ width:100%; }
  .fpl-tab-name{ max-width: 220px; }

  .fpl-league-meta-right{ grid-template-columns: repeat(3, minmax(110px, 1fr)); }
}

@media (max-width: 520px){
  .fpl-pager{ justify-content:stretch; }
  .fpl-pager .fpl-btn{ flex: 1 1 auto; }
  .fpl-pager-meta{ width:100%; margin-left:0; text-align:center; }
  .fpl-tab-name{ max-width: 180px; }

  .fpl-league-meta-right{ grid-template-columns: 1fr; }
}
