/* components.css — buttons, cards, stats, tables, badges */

.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 0.95rem;
  padding: 13px 26px;
  border-radius: var(--radius);
  border: 1.5px solid var(--ink);
  background: var(--ink);
  color: #fff;
  cursor: pointer;
  transition: transform .2s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
.btn:hover { background: var(--red); border-color: var(--red); color: #fff; transform: translateY(-2px); }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
.btn--red { background: var(--red); border-color: var(--red); }
.btn--red:hover { background: var(--red-dark); border-color: var(--red-dark); }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: var(--space-3);
}
.eyebrow::before {
  content: "";
  width: 28px; height: 2px;
  background: var(--red);
}

.lead {
  font-size: clamp(1.05rem, 1.6vw, 1.3rem);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 60ch;
}

/* ---- Cards ---- */
.card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--space-4);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  display: flex;
  flex-direction: column;
  height: 100%;
}
.card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 40px -22px rgba(0,0,0,.35);
  border-color: var(--ink);
}
.card .mono { margin-bottom: var(--space-2); }
.card h3 { margin-bottom: var(--space-2); }
.card p { font-size: 0.96rem; color: var(--ink-soft); margin-bottom: var(--space-3); flex: 1; }
.card .card-link {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--red);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.card .card-link svg { width: 14px; height: 14px; transition: transform .25s var(--ease); }
.card:hover .card-link svg { transform: translateX(4px); }

.card--feature {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.card--feature h3 { color: #fff; }
.card--feature p { color: #c4c4c8; }

/* ---- Stat blocks (swiss) ---- */
.stat-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--ink);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--ink);
  gap: 1px;
}
.stat {
  background: var(--paper);
  padding: var(--space-4);
}
.stat .num {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(2rem, 4.4vw, 3.1rem);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.stat .num .unit { color: var(--red); }
.stat .label {
  font-family: var(--ff-display);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mono);
  margin-top: var(--space-2);
  display: block;
}

/* ---- Data table ---- */
.table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius); }
table.data {
  width: 100%;
  border-collapse: collapse;
  font-variant-numeric: tabular-nums;
  min-width: 540px;
}
table.data th, table.data td {
  padding: 13px 16px;
  text-align: left;
  border-bottom: 1px solid var(--line);
  font-size: 0.94rem;
}
table.data thead th {
  font-family: var(--ff-display);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mono);
  background: var(--paper-2);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}
table.data thead th .arrow { color: var(--red); font-size: 0.7rem; }
table.data tbody tr { transition: background .2s var(--ease); }
table.data tbody tr:hover { background: var(--paper-2); }
table.data td.num, table.data th.num { text-align: right; font-family: var(--ff-display); }
table.data .rank {
  font-family: var(--ff-display);
  font-weight: 700;
  color: var(--red);
}

/* progress bar inside cells */
.bar {
  height: 8px;
  background: var(--paper-3);
  border-radius: 99px;
  overflow: hidden;
  min-width: 90px;
}
.bar > span {
  display: block;
  height: 100%;
  background: var(--red);
  border-radius: 99px;
}

/* ---- Badge / flag chips ---- */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--ff-display);
  font-size: 0.82rem;
  font-weight: 600;
  padding: 6px 12px;
  border: 1px solid var(--line);
  border-radius: 99px;
  background: var(--paper);
}
.chip .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--red); }
.chip-row { display: flex; flex-wrap: wrap; gap: var(--space-2); }

/* ---- Article / longform ---- */
.prose { max-width: 70ch; }
.prose h2 { margin-top: var(--space-6); }
.prose h3 { margin-top: var(--space-5); }
.prose p { color: var(--ink-soft); }
.prose blockquote {
  margin: var(--space-5) 0;
  padding: var(--space-3) var(--space-4);
  border-left: 4px solid var(--red);
  background: var(--paper-2);
  font-family: var(--ff-display);
  font-size: 1.15rem;
  line-height: 1.45;
  color: var(--ink);
}
.prose figure { margin: var(--space-5) 0; }
.prose figcaption {
  font-size: 0.82rem;
  color: var(--mono);
  margin-top: var(--space-2);
  font-family: var(--ff-display);
  letter-spacing: 0.04em;
}

.pull-stat {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  padding: var(--space-4) 0;
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  margin: var(--space-5) 0;
}
.pull-stat .big {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(2.6rem, 7vw, 4.5rem);
  line-height: 1;
  color: var(--red);
  letter-spacing: -0.03em;
}
.pull-stat .desc { font-family: var(--ff-display); font-weight: 500; color: var(--ink-soft); }

/* ---- xG bars ---- */
.xg-row {
  display: grid;
  grid-template-columns: 130px 1fr 56px;
  align-items: center;
  gap: var(--space-3);
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}
.xg-row .team { font-family: var(--ff-display); font-weight: 600; font-size: 0.95rem; }
.xg-row .track {
  height: 16px;
  background: var(--paper-3);
  border-radius: 3px;
  overflow: hidden;
}
.xg-row .track > span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--red), var(--red-dark));
  border-radius: 3px;
  transition: width 1.2s var(--ease);
}
.xg-row .val { text-align: right; font-family: var(--ff-display); font-weight: 700; font-variant-numeric: tabular-nums; }

/* ---- Cookie banner ---- */
.cookie {
  position: fixed;
  left: var(--space-4);
  right: var(--space-4);
  bottom: var(--space-4);
  z-index: 80;
  max-width: 560px;
  margin: 0 auto;
  background: var(--ink);
  color: #e7e7e9;
  border-radius: var(--radius);
  padding: var(--space-4);
  box-shadow: 0 24px 60px -20px rgba(0,0,0,.6);
  display: none;
}
.cookie.show { display: block; animation: cookieIn .45s var(--ease); }
@keyframes cookieIn { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }
.cookie p { font-size: 0.9rem; margin-bottom: var(--space-3); color: #c9c9cc; }
.cookie a { color: #fff; text-decoration: underline; }
.cookie-actions { display: flex; gap: var(--space-2); }
.cookie .btn { padding: 10px 18px; font-size: 0.88rem; }

/* ---- Misc ---- */
.divider-num {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 0.78rem;
  color: var(--red);
  letter-spacing: 0.1em;
}
.tag-list { display: flex; flex-wrap: wrap; gap: var(--space-2); list-style: none; padding: 0; }
.tag-list li {
  font-family: var(--ff-display);
  font-size: 0.78rem;
  padding: 4px 10px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  margin: 0;
}

.note {
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-left: 4px solid var(--red);
  border-radius: var(--radius);
  padding: var(--space-4);
}

@media (max-width: 760px) {
  .stat-strip { grid-template-columns: repeat(2, 1fr); }
  .xg-row { grid-template-columns: 100px 1fr 48px; }
}
@media (max-width: 460px) {
  .stat-strip { grid-template-columns: 1fr 1fr; }
}
