/**
 * MBOAFOOT Core — Frontend Styles
 * BEM naming: .mboafoot-{block}__{element}--{modifier}
 * CSS custom properties pour surcharge facile par le thème.
 */

/* ── Custom Properties ──────────────────────────────────────────────────── */
:root {
  --mboafoot-primary:        #1a6b35;
  --mboafoot-primary-dark:   #124d26;
  --mboafoot-accent:         #f5a623;
  --mboafoot-bg:             #ffffff;
  --mboafoot-bg-alt:         #f8f9fa;
  --mboafoot-border:         #e0e4e8;
  --mboafoot-text:           #1a1a2e;
  --mboafoot-text-muted:     #6c757d;
  --mboafoot-live:           #e53935;
  --mboafoot-win:            #2e7d32;
  --mboafoot-draw:           #f9a825;
  --mboafoot-lose:           #c62828;
  --mboafoot-promotion:      rgba(46,125,50,.12);
  --mboafoot-relegation:     rgba(198,40,40,.12);
  --mboafoot-radius:         8px;
  --mboafoot-shadow:         0 2px 8px rgba(0,0,0,.08);
  --mboafoot-font:           inherit;
}

/* Thème sombre */
.mboafoot-scores--sombre,
.mboafoot-classement--sombre,
.mboafoot-africa--sombre {
  --mboafoot-bg:         #1e1e2e;
  --mboafoot-bg-alt:     #2a2a3e;
  --mboafoot-border:     #3a3a4e;
  --mboafoot-text:       #e0e0f0;
  --mboafoot-text-muted: #9090a8;
}

/* ── Reset minimal pour les blocs ──────────────────────────────────────── */
.mboafoot-scores,
.mboafoot-classement,
.mboafoot-africa,
.mboafoot-fallback {
  box-sizing: border-box;
  font-family: var(--mboafoot-font);
  color: var(--mboafoot-text);
  background: var(--mboafoot-bg);
  border: 1px solid var(--mboafoot-border);
  border-radius: var(--mboafoot-radius);
  padding: 1rem;
  box-shadow: var(--mboafoot-shadow);
  overflow: hidden;
}

.mboafoot-scores *,
.mboafoot-classement *,
.mboafoot-africa * {
  box-sizing: border-box;
}

/* ── Header commun ──────────────────────────────────────────────────────── */
.mboafoot-scores__header,
.mboafoot-classement__header,
.mboafoot-africa__header {
  display: flex;
  align-items: center;
  gap: .5rem;
  border-bottom: 2px solid var(--mboafoot-primary);
  padding-bottom: .5rem;
  margin-bottom: 1rem;
}

.mboafoot-scores__title,
.mboafoot-classement__title,
.mboafoot-africa__title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--mboafoot-primary);
  flex: 1;
}

.mboafoot-scores__season,
.mboafoot-classement__season,
.mboafoot-africa__season {
  font-size: .8rem;
  color: var(--mboafoot-text-muted);
  background: var(--mboafoot-bg-alt);
  padding: .15rem .5rem;
  border-radius: 20px;
}

/* ── SCORES ─────────────────────────────────────────────────────────────── */
.mboafoot-scores__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.mboafoot-scores__item {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto;
  align-items: center;
  gap: .5rem;
  padding: .5rem .75rem;
  background: var(--mboafoot-bg-alt);
  border-radius: 6px;
  border-left: 3px solid transparent;
  font-size: .9rem;
}

.mboafoot-scores__item--live {
  border-left-color: var(--mboafoot-live);
  background: rgba(229,57,53,.05);
}

.mboafoot-scores__team {
  display: flex;
  align-items: center;
  gap: .4rem;
}

.mboafoot-scores__team--home { justify-content: flex-end; }
.mboafoot-scores__team--away { justify-content: flex-start; }

.mboafoot-scores__logo {
  width: 24px;
  height: 24px;
  object-fit: contain;
  flex-shrink: 0;
}

.mboafoot-scores__team-name {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 110px;
}

.mboafoot-scores__score {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--mboafoot-primary);
  min-width: 60px;
  justify-content: center;
}

.mboafoot-scores__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  font-size: .75rem;
  color: var(--mboafoot-text-muted);
  gap: .15rem;
}

.mboafoot-scores__live-badge {
  background: var(--mboafoot-live);
  color: #fff;
  padding: .1rem .4rem;
  border-radius: 3px;
  font-weight: 700;
  font-size: .72rem;
  animation: mboafoot-pulse 1.5s infinite;
}

@keyframes mboafoot-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .6; }
}

/* ── CLASSEMENT ──────────────────────────────────────────────────────────── */
.mboafoot-classement__table-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.mboafoot-classement__table {
  width: 100%;
  border-collapse: collapse;
  font-size: .85rem;
}

.mboafoot-classement__table th,
.mboafoot-classement__table td {
  padding: .45rem .6rem;
  text-align: center;
  border-bottom: 1px solid var(--mboafoot-border);
  white-space: nowrap;
}

.mboafoot-classement__table th {
  background: var(--mboafoot-bg-alt);
  color: var(--mboafoot-text-muted);
  font-weight: 600;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.mboafoot-classement__col--team {
  text-align: left;
  min-width: 130px;
}

.mboafoot-classement__team-logo {
  width: 20px;
  height: 20px;
  object-fit: contain;
  vertical-align: middle;
  margin-right: .35rem;
}

.mboafoot-classement__col--points strong {
  color: var(--mboafoot-primary);
  font-size: 1rem;
}

.mboafoot-classement__row--promotion { background: var(--mboafoot-promotion); }
.mboafoot-classement__row--relegation { background: var(--mboafoot-relegation); }

.mboafoot-form-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin: 0 1px;
}
.mboafoot-form--win  { background: var(--mboafoot-win); }
.mboafoot-form--draw { background: var(--mboafoot-draw); }
.mboafoot-form--lose { background: var(--mboafoot-lose); }

/* ── AFRICA DASHBOARD ────────────────────────────────────────────────────── */
.mboafoot-africa {
  padding: 1rem;
}

.mboafoot-africa__nav {
  margin-bottom: 1rem;
}

.mboafoot-africa__nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}

.mboafoot-africa__nav-link {
  display: inline-block;
  padding: .25rem .65rem;
  background: var(--mboafoot-bg-alt);
  border: 1px solid var(--mboafoot-border);
  border-radius: 20px;
  font-size: .8rem;
  color: var(--mboafoot-text);
  text-decoration: none;
  transition: background .2s, color .2s;
}
.mboafoot-africa__nav-link:hover,
.mboafoot-africa__nav-link:focus {
  background: var(--mboafoot-primary);
  color: #fff;
  border-color: var(--mboafoot-primary);
}

.mboafoot-africa__body {
  display: grid;
  gap: 1.25rem;
}

@media (min-width: 768px) {
  .mboafoot-africa__body {
    grid-template-columns: 1fr 280px;
  }
}

.mboafoot-africa__country {
  border: 1px solid var(--mboafoot-border);
  border-radius: var(--mboafoot-radius);
  padding: .75rem 1rem;
  background: var(--mboafoot-bg);
  margin-bottom: .75rem;
}

.mboafoot-africa__country-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--mboafoot-primary-dark);
  margin: 0 0 .6rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}

.mboafoot-africa__leagues {
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

.mboafoot-africa__league-name {
  font-size: .88rem;
  font-weight: 600;
  margin: 0 0 .4rem;
  color: var(--mboafoot-primary);
}

.mboafoot-africa__league-type {
  font-size: .72rem;
  font-weight: 400;
  color: var(--mboafoot-text-muted);
  margin-left: .35rem;
}

.mboafoot-africa__fixtures {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .35rem;
}

.mboafoot-africa__fixture {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto;
  align-items: center;
  gap: .4rem;
  font-size: .82rem;
  padding: .3rem .5rem;
  background: var(--mboafoot-bg-alt);
  border-radius: 4px;
}

.mboafoot-africa__fixture--live {
  border-left: 2px solid var(--mboafoot-live);
}

.mboafoot-africa__fixture-score {
  font-weight: 700;
  color: var(--mboafoot-primary);
  display: flex;
  align-items: center;
  gap: .25rem;
}

.mboafoot-africa__live-dot {
  width: 6px;
  height: 6px;
  background: var(--mboafoot-live);
  border-radius: 50%;
  display: inline-block;
  animation: mboafoot-pulse 1.2s infinite;
}

.mboafoot-africa__fixture-date {
  font-size: .73rem;
  color: var(--mboafoot-text-muted);
}

.mboafoot-africa__no-data {
  font-size: .82rem;
  color: var(--mboafoot-text-muted);
  font-style: italic;
  margin: 0;
}

.mboafoot-africa__team-logo {
  width: 16px;
  height: 16px;
  object-fit: contain;
  vertical-align: middle;
}

/* ── RSS ─────────────────────────────────────────────────────────────────── */
.mboafoot-africa__rss {
  background: var(--mboafoot-bg-alt);
  border: 1px solid var(--mboafoot-border);
  border-radius: var(--mboafoot-radius);
  padding: .75rem 1rem;
}

.mboafoot-africa__rss-title {
  font-size: .95rem;
  margin: 0 0 .75rem;
  color: var(--mboafoot-primary);
}

.mboafoot-africa__rss-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

.mboafoot-africa__rss-item {
  display: flex;
  gap: .6rem;
  align-items: flex-start;
}

.mboafoot-africa__rss-thumb {
  width: 70px;
  height: 47px;
  object-fit: cover;
  border-radius: 4px;
  flex-shrink: 0;
}

.mboafoot-africa__rss-content {
  display: flex;
  flex-direction: column;
  gap: .2rem;
}

.mboafoot-africa__rss-link {
  font-size: .85rem;
  font-weight: 600;
  color: var(--mboafoot-text);
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.mboafoot-africa__rss-link:hover { color: var(--mboafoot-primary); text-decoration: underline; }

.mboafoot-africa__rss-summary {
  font-size: .78rem;
  color: var(--mboafoot-text-muted);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.mboafoot-africa__rss-date {
  font-size: .72rem;
  color: var(--mboafoot-text-muted);
}

/* ── Fallback ─────────────────────────────────────────────────────────────── */
.mboafoot-fallback {
  text-align: center;
  padding: 2rem 1rem;
  color: var(--mboafoot-text-muted);
}

.mboafoot-fallback__icon {
  font-size: 2.5rem;
  display: block;
  margin-bottom: .5rem;
  filter: grayscale(1) opacity(.4);
}

.mboafoot-fallback__message {
  font-size: .95rem;
  font-weight: 600;
  margin: 0 0 .3rem;
}

.mboafoot-fallback__hint {
  font-size: .82rem;
  margin: 0;
}

/* ── Error ────────────────────────────────────────────────────────────────── */
.mboafoot-error {
  background: #fff3cd;
  border: 1px solid #ffc107;
  border-radius: 6px;
  padding: .75rem 1rem;
  font-size: .88rem;
  color: #664d03;
}

.mboafoot-error p { margin: 0; }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .mboafoot-scores__team-name { max-width: 70px; }
  .mboafoot-scores__item      { font-size: .8rem; }
  .mboafoot-africa__fixture   { font-size: .77rem; }
  .mboafoot-classement__table { font-size: .78rem; }
  .mboafoot-classement__table th,
  .mboafoot-classement__table td { padding: .3rem .4rem; }
}
