/* Container */
.gbi-wrap{
    max-width:1280px;
    margin:0 auto;
    padding:24px 16px;
}



/* KPI Block */
.gbi-kpis{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    gap:14px;
    margin-bottom:20px;
}

.gbi-kpi{
    background:#fff;
    border:1px solid #e6e6e6;
    border-radius:14px;
    padding:16px;
    text-align:center;
}

.gbi-kpi-value{
    font-size:1.6rem;
    font-weight:700;
}

.gbi-kpi-label{
    font-size:.85rem;
    color:#555;
}

/* Card around table */
.gbi-table-card{
    background:#fff;
    border:1px solid #e6e6e6;
    border-radius:14px;
    overflow:hidden;
}

/* Table */
.gbi-table-wrap{
    overflow-x:auto;
}

.gbi-table{
    width:100%;
    border-collapse:collapse;
    font-size:.98rem;
}

.gbi-table th,
.gbi-table td{
    padding:.75rem .9rem;
    text-align:left;
    border-top:1px solid #f0f0f0;
}

.gbi-table thead th{
    background:#f7f7f8;
    font-weight:700;
    border-bottom:1px solid #e6e6e6;
}

.gbi-table tbody tr {
  transition: background-color 0.18s ease, box-shadow 0.18s ease;
}

.gbi-table tbody tr:hover td {
  background-color: #eef4ff;
}

.gbi-table tbody tr:hover td:first-child {
  box-shadow: inset 3px 0 0 #1f5fbf;
}
/* Medal emphasis */
.gbi-medal{
    font-weight:600;
}

/* Source footer */
.gbi-source{
    font-size:.85rem;
    color:#475569;
    padding:.6rem .9rem;
    background:#f8fafc;
    border-top:1px solid #e2e8f0;
}

.gbi-table-filters {
  display: grid;
  grid-template-columns:
    1.6fr   /* competition */
    0.9fr   /* year */
    1.4fr   /* style */
    1.1fr   /* country */
    0.9fr   /* medal */
    1.8fr   /* search */
    auto;   /* reset */
  gap: 12px;
  align-items: center;
}

.gbi-table-filters select,
.gbi-table-filters input {
  width: 100%;
  height: 40px;
}

.gbi-table-filters input[type="search"] {
  min-width: 220px;
}

.gbi-table-filters button {
  height: 40px;
  white-space: nowrap;
}

.gbi-table-filters select,
.gbi-table-filters input {
  border: 1px solid #dcdcdc;
  background-color: #ffffff;
  transition: all 0.2s ease;
}

.gbi-table-filters select.active,
.gbi-table-filters input.active {
  border-color: #1e73be;
  background-color: #f3f8ff;
}

#gbi-table th{
    cursor:pointer;
}

#gbi-table th:hover{
    background:#eef2f7;
}

.gbi-pagination {
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:24px;
  flex-wrap:wrap;
}

.gbi-pagination button {
  min-width:40px;
  height:40px;
  padding:0 12px;
  border-radius:8px;
  border:1px solid #d0d7e2;
  background:#ffffff;
  color:#1f2937;          /* donkere tekst */
  cursor:pointer;
  font-weight:600;
  font-size:14px;
  transition:all 0.2s ease;
}

.gbi-pagination button:hover {
  background:#eef2f7;
}

.gbi-pagination button.active {
  background:#1f5fbf;
  color:#ffffff;
  border-color:#1f5fbf;
}

.gbi-competition-sources {
  margin-top: 18px;
  font-size: 14px;
  opacity: 0.8;
}

.gbi-competition-sources a {
  margin-right: 14px;
  text-decoration: none;
}

.gbi-competition-sources a:hover {
  text-decoration: underline;
}

.gbi-sources-label {
  margin-right: 10px;
  font-weight: 600;
}

@media (max-width: 1100px) {
  .gbi-table-filters {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

th.asc::after {
  content: " ▲";
  font-size: 11px;
}

th:not(.asc).sorted::after {
  content: " ▼";
  font-size: 11px;
}

.gbi-competition-footer {
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid #e6e6e6;
}

.gbi-competition-context-text {
  font-size: 14px;
  opacity: 0.85;
  margin-bottom: 12px;
}

.gbi-competition-trademark {
  font-size: 14px;
  opacity: 0.85;
  margin-bottom: 12px;
}

.gbi-competition-sources {
  font-size: 14px;
}

.gbi-competition-sources a {
  margin-right: 16px;
  text-decoration: none;
}

.gbi-competition-sources a:hover {
  text-decoration: underline;
}

.gbi-sources-label {
  font-weight: 600;
  margin-right: 10px;
}

.gbi-table-filters select {
  border: 1px solid #dcdcdc !important;
}

.gbi-table-filters select.active {
  border-color: #1e73be !important;
}

.gbi-style-link.is-variant {
    font-style: italic;
}

.gbi-top-cards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:18px;
  margin-bottom:24px;
}

.gbi-top-card{
  background:#fff;
  border:1px solid #e6e6e6;
  border-radius:14px;
  padding:16px 18px;
}

.gbi-top-card h3{
  font-size:1rem;
  margin:0 0 10px;
  color:#0a2b57;
}

.gbi-top-card ol{
  margin:0;
  padding-left:18px;
}

.gbi-top-card li{
  font-size:14px;
  margin-bottom:6px;
}

.gbi-top-card span{
  font-weight:600;
  color:#1f5fbf;
}

.gbi-top-card li strong {
  color:#1f5fbf;
}

.gbi-top-card li {
  line-height:1.5;
}

.gbi-table tbody tr:nth-child(even) {
  background-color: #fafbfd;
}

.gbi-table tbody tr:nth-child(odd) {
  background-color: #ffffff;
}

/* ---------- Mobile optimizations (filters + table) ---------- */
@media (max-width: 820px) {

  /* Filters: 2 columns */
  .gbi-table-filters{
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  /* Search over full width */
  #filter-search{
    grid-column: 1 / -1;
    min-width: 0 !important;
  }

  /* Reset over full width */
  #filter-reset{
    grid-column: 1 / -1;
    width: 100%;
  }

  /* Inputs a bit taller for touch */
  .gbi-table-filters select,
  .gbi-table-filters input,
  .gbi-table-filters button{
    height: 44px;
  }

  /* Reduce padding so it fits better */
  .gbi-table-card{
    border-radius: 12px;
  }

  .gbi-table th,
  .gbi-table td{
    padding: 10px 10px;
    font-size: 0.94rem;
  }
}

/* Extra small phones: 1 column filters */
@media (max-width: 520px){

  .gbi-table-filters{
    grid-template-columns: 1fr;
    gap: 10px;
  }

  #filter-search,
  #filter-reset{
    grid-column: auto;
  }

  /* Slightly smaller table text */
  .gbi-table{
    font-size: 0.92rem;
  }
}

/* Optional: keep header readable on scroll */
@media (max-width: 820px){
  .gbi-table thead th{
    white-space: nowrap;
  }
}

/* Center title */
.gbi-competition-module .gbi-section-title {
    text-align: center;
}

/* Center intro + footer text */
.gbi-competition-module .gbi-competition-disclaimer,
.gbi-competition-module .gbi-competition-context-text {
    text-align: center;
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
}

.gbi-competition-module .gbi-section-title {
    font-size: 2.2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: #0A2A66;
    margin-bottom: 1.5rem;
}

.gbi-competition-footer {
    text-align: center;
}

.gbi-competition-sources {
    justify-content: center;
}

.gbi-pagination .pagination-dots {
  padding: 0 6px;
  display: flex;
  align-items: center;
  font-weight: 600;
}