/* ── Global ──────────────────────────────────────────────────── */
body {
  background-color: #0d0d14;
  color: #e0e0e0;
}

/* ── Article cards ───────────────────────────────────────────── */
.article-card {
  background-color: #16161e;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.article-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.5);
}

.article-card .card-body {
  padding: 0.5rem 0.6rem 0.25rem;
}

.article-card .card-footer {
  padding: 0.3rem 0.6rem 0.4rem;
}

.article-title {
  font-size: 0.82rem;
  line-height: 1.35;
  margin-bottom: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── Source badges ───────────────────────────────────────────── */
.source-badge {
  font-size: 0.65rem;
  background-color: #2a2a3a;
  color: #b0b0c0;
  border: 1px solid #3a3a4a;
  white-space: nowrap;
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Source-specific accent colours */
.src-dn           { background-color: #1a4080 !important; color: #fff !important; border-color: #1a4080 !important; }
.src-svd          { background-color: #0e2a5e !important; color: #fff !important; border-color: #0e2a5e !important; }
.src-aftonbladet  { background-color: #cc0000 !important; color: #fff !important; border-color: #cc0000 !important; }
.src-expressen    { background-color: #dd1111 !important; color: #fff !important; border-color: #dd1111 !important; }
.src-svt          { background-color: #006b5e !important; color: #fff !important; border-color: #006b5e !important; }
.src-sr           { background-color: #6b005e !important; color: #fff !important; border-color: #6b005e !important; }
.src-di           { background-color: #c05c00 !important; color: #fff !important; border-color: #c05c00 !important; }
.src-bbc          { background-color: #9a1111 !important; color: #fff !important; border-color: #9a1111 !important; }
.src-guardian     { background-color: #0a4a6e !important; color: #fff !important; border-color: #0a4a6e !important; }
.src-reuters      { background-color: #c07000 !important; color: #fff !important; border-color: #c07000 !important; }
.src-aljazeera    { background-color: #8b0000 !important; color: #fff !important; border-color: #8b0000 !important; }
.src-dw           { background-color: #1a1a60 !important; color: #fff !important; border-color: #1a1a60 !important; }
.src-ft           { background-color: #994400 !important; color: #fff !important; border-color: #994400 !important; }
.src-theverge     { background-color: #3a006b !important; color: #fff !important; border-color: #3a006b !important; }
.src-arstechnica  { background-color: #c04000 !important; color: #fff !important; border-color: #c04000 !important; }
.src-bbc_football        { background-color: #9a1111 !important; color: #fff !important; border-color: #9a1111 !important; }
.src-skysports_football  { background-color: #005094 !important; color: #fff !important; border-color: #005094 !important; }
.src-guardian_football   { background-color: #0a4a6e !important; color: #fff !important; border-color: #0a4a6e !important; }

/* ── Category badges ─────────────────────────────────────────── */
.cat-badge {
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  background-color: #5a5a7a !important; /* fallback for custom categories */
  color: #fff !important;
}

.cat-swedish   { background-color: #0d6efd !important; }
.cat-world     { background-color: #198754 !important; }
.cat-politics  { background-color: #856404 !important; color: #fff !important; }
.cat-business  { background-color: #0dcaf0 !important; color: #000 !important; }
.cat-football  { background-color: #dc3545 !important; }
.cat-sports    { background-color: #d63384 !important; }
.cat-tech      { background-color: #6f42c1 !important; }
.cat-culture   { background-color: #20c997 !important; color: #000 !important; }
.cat-general   { background-color: #495057 !important; }

/* ── Article thumbnail ───────────────────────────────────────── */
.article-img {
  height: 90px;
  object-fit: cover;
  border-radius: 4px 4px 0 0;
}

/* ── Category filter pills ───────────────────────────────────── */
.category-pill {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.25rem 0.75rem;
  border-radius: 2rem;
  border: none !important;
  color: #fff !important;
}

.category-pill.cat-all      { background-color: #444466 !important; }
.category-pill.cat-all.btn-primary { background-color: #6666aa !important; }

.category-pill.cat-swedish  { background-color: #1a5cc8 !important; }
.category-pill.cat-world    { background-color: #1a7a45 !important; }
.category-pill.cat-politics { background-color: #8a5a00 !important; }
.category-pill.cat-business { background-color: #0a7a9a !important; }
.category-pill.cat-football { background-color: #b02030 !important; }
.category-pill.cat-sports   { background-color: #a02070 !important; }
.category-pill.cat-tech     { background-color: #5a30a0 !important; }
.category-pill.cat-culture  { background-color: #0a8a6a !important; }

/* Active pill: brighter */
.category-pill.btn-primary.cat-swedish  { background-color: #2a7aff !important; }
.category-pill.btn-primary.cat-world    { background-color: #22aa5a !important; }
.category-pill.btn-primary.cat-politics { background-color: #c07800 !important; }
.category-pill.btn-primary.cat-business { background-color: #0aaed0 !important; }
.category-pill.btn-primary.cat-football { background-color: #e03040 !important; }
.category-pill.btn-primary.cat-sports   { background-color: #d040a0 !important; }
.category-pill.btn-primary.cat-tech     { background-color: #7a40d0 !important; }
.category-pill.btn-primary.cat-culture  { background-color: #10c090 !important; color: #000 !important; }

/* ── Standings table ─────────────────────────────────────────── */
.standings-table td, .standings-table th {
  font-size: 0.82rem;
  vertical-align: middle;
}

.cl-zone  { border-left: 3px solid #0d6efd; }
.el-zone  { border-left: 3px solid #f0ad00; }
.rel-zone { border-left: 3px solid #dc3545; }

.cl-dot::before  { content: '●'; color: #0d6efd; }
.el-dot::before  { content: '●'; color: #f0ad00; }
.rel-dot::before { content: '●'; color: #dc3545; }

/* ── Navbar ──────────────────────────────────────────────────── */
.navbar {
  box-shadow: 0 2px 8px rgba(0,0,0,0.5);
}

/* ── Cards (generic) ─────────────────────────────────────────── */
.card {
  background-color: #16161e;
}

.card-header {
  background-color: #1e1e2e !important;
}

/* ── List groups ─────────────────────────────────────────────── */
.list-group-item {
  background-color: #16161e;
  color: #e0e0e0;
}

/* ── Scrollbar (webkit) ──────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: #0d0d14; }
::-webkit-scrollbar-thumb { background: #2a2a3a; border-radius: 3px; }

/* ── Favourites page ─────────────────────────────────────────── */
.fav-title {
  font-size: 0.9rem;
  line-height: 1.45;
}

.notes-textarea {
  font-size: 0.8rem;
  resize: vertical;
  min-height: 56px;
}

.notes-textarea:focus {
  border-color: #4a4a6a !important;
  box-shadow: 0 0 0 2px rgba(100, 100, 200, 0.2);
}

.notes-status {
  font-size: 0.72rem;
  min-width: 4rem;
  text-align: right;
  transition: opacity 0.3s;
}

/* Bookmark button — filled = saved */
.save-btn.text-warning { opacity: 1; }
.save-btn.text-secondary { opacity: 0.55; }
.save-btn:hover { opacity: 1 !important; }

/* ── Filter bar ──────────────────────────────────────────────── */
.filter-scroll-row {
  overflow-x: auto;
  flex-wrap: nowrap;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 2px;
}
.filter-scroll-row::-webkit-scrollbar { display: none; }

/* Wrap on md+ so pills don't eat the whole row */
@media (min-width: 768px) {
  .filter-scroll-row { flex-wrap: wrap; overflow-x: visible; }
  .filter-search-form { max-width: 240px; }
}

/* ── Touch targets ───────────────────────────────────────────── */
.touch-target {
  min-width: 36px;
  min-height: 36px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
}

/* ── Mobile overrides (< 576px) ──────────────────────────────── */
@media (max-width: 575.98px) {
  /* Tighter page edges */
  .container-fluid { padding-left: 0.5rem !important; padding-right: 0.5rem !important; }

  /* Cards: keep compact but readable */
  .article-card .card-body  { padding: 0.45rem 0.5rem 0.2rem; }
  .article-card .card-footer{ padding: 0.25rem 0.5rem 0.35rem; }

  .article-title {
    font-size: 0.84rem;
    -webkit-line-clamp: 3;  /* allow 3 lines on small screens */
  }

  .article-img { height: 100px; }

  /* Slightly larger badge text on mobile */
  .source-badge { font-size: 0.62rem; }
  .cat-badge    { font-size: 0.58rem; }

  /* Standings: compact */
  .standings-table td, .standings-table th {
    font-size: 0.72rem;
    padding: 0.35rem 0.25rem;
  }

  /* Pagination: bigger tap area */
  .page-link { padding: 0.45rem 0.65rem; }

  /* Navbar brand smaller */
  .navbar-brand { font-size: 1rem; }
}
