/* ============================================================================
   StreamOnSport — French football magazine design system
   Direction: navy + tricolore bands + art-nouveau curves, Parisian street-poster
   register. Spectral display serif + Inter humanist sans. All classes prefixed `so-`.
   ============================================================================ */

:root {
  /* Surfaces — paper cream + deep navy */
  --so-bg:           #f7f5ef;
  --so-bg-paper:    #ece6d8;
  --so-bg-card:     #ffffff;
  --so-bg-deep:     #003366;
  --so-bg-deep-2:   #001f47;

  /* Brand accents — tricolore */
  --so-blue:         #003366;
  --so-blue-mid:     #1e4d8a;
  --so-blue-soft:    #6f8cb5;
  --so-white:        #ffffff;
  --so-red:          #cc0000;
  --so-red-dark:     #8b0000;
  --so-gold:         #c89b3c;
  --so-ink:          #1a1f2b;
  --so-ink-soft:     #34384a;
  --so-muted:        #6c7186;
  --so-rule:         #c5c1b4;
  --so-rule-soft:    #e2dfd3;

  /* Type */
  --so-font-serif: "Spectral", "Cormorant Garamond", Georgia, "Iowan Old Style", serif;
  --so-font-sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  /* Spacing */
  --so-s1:  4px;
  --so-s2:  8px;
  --so-s3: 12px;
  --so-s4: 16px;
  --so-s5: 24px;
  --so-s6: 32px;
  --so-s7: 48px;
  --so-s8: 64px;
  --so-s9: 96px;

  /* Layout */
  --so-container:        1180px;
  --so-container-narrow:  720px;
  --so-shadow-card: 0 1px 2px rgba(0, 31, 71, 0.06), 0 6px 20px rgba(0, 31, 71, 0.10);
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--so-font-sans);
  font-size: 16px;
  line-height: 1.65;
  color: var(--so-ink);
  background: var(--so-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, picture, svg { display: block; max-width: 100%; height: auto; }
button { font: inherit; cursor: pointer; border: 0; background: transparent; padding: 0; color: inherit; }

/* Typography */
h1, h2, h3, h4 {
  font-family: var(--so-font-serif);
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: -0.005em;
  color: var(--so-ink);
  margin: 0 0 var(--so-s4);
}
h1 { font-size: 44px; letter-spacing: -0.012em; }
h2 { font-size: 30px; margin-top: var(--so-s7); }
h3 { font-size: 22px; margin-top: var(--so-s6); }
h4 { font-size: 17px; margin-top: var(--so-s5); }
@media (max-width: 720px) {
  h1 { font-size: 32px; }
  h2 { font-size: 24px; }
  h3 { font-size: 19px; }
}
p { margin: 0 0 var(--so-s4); }
ul, ol { margin: 0 0 var(--so-s4); padding-left: var(--so-s5); }
li { margin: var(--so-s1) 0; }
a { color: var(--so-blue-mid); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
a:hover { color: var(--so-red); text-decoration-thickness: 2px; }
hr { border: 0; border-top: 1px solid var(--so-rule); margin: var(--so-s7) 0; }
blockquote {
  margin: var(--so-s5) 0;
  padding: var(--so-s4) var(--so-s5);
  background: var(--so-bg-paper);
  font-family: var(--so-font-serif);
  font-style: italic;
  font-size: 18px;
  color: var(--so-ink-soft);
}

/* Layout primitives */
.so-container { max-width: var(--so-container); margin: 0 auto; padding: 0 var(--so-s5); }
.so-container--narrow { max-width: var(--so-container-narrow); margin: 0 auto; padding: 0 var(--so-s5); }
@media (max-width: 720px) {
  .so-container, .so-container--narrow { padding: 0 var(--so-s4); }
}
.so-main { padding-bottom: var(--so-s8); }

/* Disclaimer banner */
.so-disclaimer {
  background: #f0eedf;
  padding: var(--so-s3) 0;
}
.so-disclaimer__inner { display: flex; justify-content: center; }
.so-disclaimer__text {
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
  color: #555036;
  max-width: 86ch;
}
.so-disclaimer__text strong { color: var(--so-ink); }
.so-disclaimer__text a { color: var(--so-red-dark); }

/* Header */
.so-header {
  background: var(--so-bg-deep);
  color: #f5f5f0;
  position: relative;
}
.so-header::after {
  content: "";
  display: block;
  height: 6px;
  background: linear-gradient(to right,
    var(--so-blue) 0%, var(--so-blue) 33.33%,
    var(--so-white) 33.33%, var(--so-white) 66.66%,
    var(--so-red) 66.66%, var(--so-red) 100%);
}
.so-header__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: var(--so-s4);
  padding: var(--so-s5) var(--so-s5);
}
.so-logo { display: flex; flex-direction: column; text-decoration: none; color: #f5f5f0; }
.so-logo:hover { color: #f5f5f0; text-decoration: none; }
.so-logo__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--so-red);
  color: #fff;
  font-family: var(--so-font-serif);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 0.06em;
  width: 44px;
  height: 44px;
  margin-bottom: var(--so-s2);
}
.so-logo__wordmark {
  font-family: var(--so-font-serif);
  font-weight: 800;
  font-size: 30px;
  line-height: 1;
  letter-spacing: -0.005em;
}
.so-logo__tagline {
  font-family: var(--so-font-sans);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--so-gold);
  margin-top: 4px;
}
.so-nav { display: flex; gap: var(--so-s5); align-items: center; }
.so-nav__link {
  font-family: var(--so-font-sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #f5f5f0;
  text-decoration: none;
  padding: var(--so-s2) 0;
  position: relative;
  transition: color 0.15s;
}
.so-nav__link::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 2px;
  background: transparent;
  transition: background 0.15s;
}
.so-nav__link:hover { color: var(--so-gold); text-decoration: none; }
.so-nav__link:hover::after { background: var(--so-gold); }
.so-nav__link--active { color: var(--so-red); }
.so-nav__link--active::after { background: var(--so-red); }
.so-nav-toggle { display: none; width: 44px; height: 44px; flex-direction: column; align-items: center; justify-content: center; }
.so-nav-toggle span { display: block; width: 24px; height: 2px; background: #f5f5f0; margin: 3px 0; }

@media (max-width: 860px) {
  .so-nav-toggle { display: flex; }
  .so-nav {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--so-bg-deep);
    flex-direction: column;
    padding: var(--so-s3) var(--so-s5);
    gap: 0;
    z-index: 10;
  }
  .so-nav--open { display: flex; }
  .so-nav__link { padding: var(--so-s3) 0; width: 100%; min-height: 44px; display: flex; align-items: center; }
}

/* Breadcrumb */
.so-breadcrumb {
  font-size: 13px;
  color: var(--so-muted);
  padding: var(--so-s3) 0;
  background: var(--so-bg-paper);
}
.so-breadcrumb ol { display: flex; flex-wrap: wrap; gap: var(--so-s2); list-style: none; padding: 0; margin: 0; }
.so-breadcrumb li { margin: 0; display: flex; align-items: center; gap: var(--so-s2); }
.so-breadcrumb li:not(:last-child)::after { content: "/"; color: var(--so-muted); opacity: 0.55; }
.so-breadcrumb a { color: var(--so-muted); text-decoration: none; }
.so-breadcrumb a:hover { color: var(--so-blue-mid); text-decoration: underline; }
.so-breadcrumb li:last-child { color: var(--so-ink-soft); font-weight: 600; }

/* Home hero — Parisian poster vibe with tricolore band beneath */
.so-home-hero {
  padding: var(--so-s8) 0 var(--so-s7);
  background: var(--so-bg-paper);
  position: relative;
  overflow: hidden;
}
.so-home-hero::before {
  /* Art-nouveau decorative curve, navy outline */
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='800' height='400' viewBox='0 0 800 400'><path d='M0,200 C200,120 400,300 600,180 S800,260 800,200' fill='none' stroke='%23003366' stroke-width='1.5' opacity='0.10'/><path d='M0,260 C200,180 400,360 600,240 S800,320 800,260' fill='none' stroke='%23cc0000' stroke-width='1' opacity='0.08'/></svg>");
  background-size: 800px 400px;
  background-repeat: repeat-x;
  background-position: center;
  pointer-events: none;
}
.so-home-hero > * { position: relative; }
.so-home-hero__kicker {
  font-family: var(--so-font-sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--so-red);
  margin: 0 0 var(--so-s3);
}
.so-home-hero__title {
  font-size: 56px;
  line-height: 1.05;
  margin: 0 0 var(--so-s4);
  max-width: 18ch;
}
.so-home-hero__lede {
  font-family: var(--so-font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.45;
  color: var(--so-ink-soft);
  max-width: 60ch;
  margin: 0;
}
.so-home-hero__bands {
  display: flex;
  margin-top: var(--so-s5);
  width: 180px;
  height: 6px;
}
.so-home-hero__band { flex: 1; }
.so-home-hero__band--blue { background: var(--so-blue); }
.so-home-hero__band--white { background: var(--so-white); border-top: 1px solid var(--so-rule); border-bottom: 1px solid var(--so-rule); }
.so-home-hero__band--red { background: var(--so-red); }
@media (max-width: 720px) { .so-home-hero__title { font-size: 36px; } .so-home-hero__lede { font-size: 18px; } }

.so-section-title {
  font-family: var(--so-font-serif);
  font-size: 26px;
  font-weight: 700;
  margin: var(--so-s7) 0 var(--so-s4);
  padding-bottom: var(--so-s2);
  border-bottom: 2px solid var(--so-blue);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--so-s4);
}
.so-section-title a {
  font-family: var(--so-font-sans);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--so-red);
  text-decoration: none;
}
.so-section-title a:hover { text-decoration: underline; }
.so-section-lede {
  font-family: var(--so-font-serif);
  font-style: italic;
  color: var(--so-muted);
  max-width: 70ch;
  margin: 0 0 var(--so-s5);
  font-size: 17px;
}

/* Article single — hero with art-nouveau curve overlay */
.so-article { padding: var(--so-s7) 0; }
.so-hero {
  margin: 0;
  aspect-ratio: 1180 / 620;
  position: relative;
  overflow: hidden;
  box-shadow: var(--so-shadow-card);
  background: var(--so-bg-paper);
}
.so-hero img, .so-hero picture { display: block; width: 100%; height: 100%; object-fit: cover; }
.so-hero__curve {
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  width: 100%;
  height: 60px;
  display: block;
}
.so-hero__bands {
  display: flex;
  width: 220px;
  margin: 0 auto;
  height: 5px;
}
.so-hero__band { flex: 1; }
.so-hero__band--blue { background: var(--so-blue); }
.so-hero__band--white { background: var(--so-white); border-top: 1px solid var(--so-rule); border-bottom: 1px solid var(--so-rule); }
.so-hero__band--red { background: var(--so-red); }

.so-article__meta {
  font-family: var(--so-font-sans);
  font-size: 13px;
  color: var(--so-muted);
  display: flex;
  flex-wrap: wrap;
  gap: var(--so-s4);
  margin: var(--so-s6) 0 var(--so-s3);
  align-items: center;
}
.so-article__meta time { font-variant-numeric: tabular-nums; }
.so-article__author { font-weight: 700; color: var(--so-ink); text-transform: uppercase; letter-spacing: 0.08em; font-size: 11px; }
.so-article__title { font-size: 44px; line-height: 1.08; max-width: 22ch; }
.so-article__lede {
  font-family: var(--so-font-serif);
  font-style: italic;
  font-size: 20px;
  color: var(--so-ink-soft);
  margin: var(--so-s4) 0 var(--so-s6);
  max-width: 62ch;
  line-height: 1.45;
}
@media (max-width: 720px) { .so-article__title { font-size: 30px; } .so-article__lede { font-size: 17px; } }

.so-content { max-width: 68ch; }
.so-content > * + * { margin-top: var(--so-s4); }
.so-content h2 {
  margin-top: var(--so-s7);
  padding-top: var(--so-s3);
  background-image: linear-gradient(to right, var(--so-blue) 0%, var(--so-blue) 33%, var(--so-white) 33%, var(--so-white) 66%, var(--so-red) 66%, var(--so-red) 100%);
  background-size: 60px 3px;
  background-repeat: no-repeat;
  background-position: 0 0;
}
.so-content h3 { margin-top: var(--so-s6); }
.so-content p:first-of-type::first-letter {
  font-family: var(--so-font-serif);
  font-size: 56px;
  font-weight: 700;
  float: left;
  line-height: 0.95;
  margin: 4px 8px 0 0;
  color: var(--so-blue);
}
.so-content table { border-collapse: collapse; width: 100%; margin: var(--so-s4) 0; font-size: 14px; }
.so-content th, .so-content td { border-bottom: 1px solid var(--so-rule-soft); padding: var(--so-s3); text-align: left; }
.so-content th { background: var(--so-bg-paper); font-weight: 700; font-size: 13px; }

/* Soccer-widget container */
.so-soccer-widget {
  margin: var(--so-s6) 0;
  padding: var(--so-s4);
  background: var(--so-bg-card);
  position: relative;
  box-shadow: var(--so-shadow-card);
}
.so-soccer-widget::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(to right,
    var(--so-blue) 0%, var(--so-blue) 33.33%,
    var(--so-white) 33.33%, var(--so-white) 66.66%,
    var(--so-red) 66.66%, var(--so-red) 100%);
}
soccer-widget { display: block; min-height: 320px; }
soccer-widget:not(:defined) {
  display: block;
  background: var(--so-bg-paper);
  min-height: 320px;
  position: relative;
}
soccer-widget:not(:defined)::before {
  content: "Chargement des matchs…";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--so-muted);
  font-family: var(--so-font-serif);
  font-style: italic;
  font-size: 16px;
}
.so-soccer-widget__fallback { padding: var(--so-s4); font-size: 14px; }
.so-soccer-widget__fallback h3 { margin: 0 0 var(--so-s3); font-size: 16px; }
.so-fixtures-static { list-style: none; padding: 0; margin: 0; }
.so-fixture { display: flex; gap: var(--so-s3); padding: var(--so-s2) 0; border-bottom: 1px dashed var(--so-rule-soft); }
.so-fixture time { font-variant-numeric: tabular-nums; color: var(--so-muted); }
.so-fixture__league { color: var(--so-muted); margin-left: auto; }

/* Broadcaster cards — poster-card with art-nouveau accent */
.so-broadcaster-grid {
  display: grid;
  gap: var(--so-s4);
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  margin: var(--so-s5) 0;
}
.so-broadcaster-card {
  background: var(--so-bg-card);
  padding: var(--so-s5);
  display: flex;
  flex-direction: column;
  gap: var(--so-s3);
  position: relative;
  overflow: hidden;
  box-shadow: var(--so-shadow-card);
  transition: transform 0.18s, box-shadow 0.18s;
}
.so-broadcaster-card:hover { transform: translateY(-2px); box-shadow: 0 4px 24px rgba(0, 31, 71, 0.16); }
.so-broadcaster-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 6px;
  background: var(--so-blue);
}
.so-broadcaster-card::after {
  /* art-nouveau curving accent line */
  content: "";
  position: absolute;
  top: 6px; left: 0; right: 0;
  height: 18px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='260' height='18' viewBox='0 0 260 18'><path d='M0,9 C40,2 80,16 130,9 S220,2 260,9' fill='none' stroke='%23c89b3c' stroke-width='1' opacity='0.55'/></svg>");
  background-size: 260px 18px;
  background-repeat: repeat-x;
  pointer-events: none;
}
.so-broadcaster-card > * { position: relative; }
.so-broadcaster-card__country {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--so-red);
  margin: var(--so-s3) 0 0;
}
.so-broadcaster-card__name { font-family: var(--so-font-serif); font-size: 22px; margin: 0; }
.so-broadcaster-card__tagline { font-size: 14px; color: var(--so-muted); margin: 0; line-height: 1.5; }
.so-broadcaster-card__carries { list-style: none; padding: 0; margin: 0; font-size: 13px; }
.so-broadcaster-card__carries li {
  padding: var(--so-s2) 0;
  border-top: 1px dashed var(--so-rule);
  display: flex;
  justify-content: space-between;
  gap: var(--so-s2);
  margin: 0;
}
.so-broadcaster-card__label { color: var(--so-muted); }
.so-broadcaster-card__value { font-weight: 700; color: var(--so-ink); }
.so-broadcaster-card__cta {
  margin-top: auto;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--so-red);
  text-decoration: none;
  padding-top: var(--so-s3);
}
.so-broadcaster-card__cta:hover { color: var(--so-red-dark); text-decoration: underline; }

/* News rail */
.so-news-rail { background: var(--so-bg-paper); padding: var(--so-s7) 0; margin-top: var(--so-s8); }
.so-news-list {
  display: grid;
  gap: var(--so-s4);
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
  list-style: none;
  padding: 0;
  margin: 0;
}
.so-news-list li { margin: 0; }
.so-news-card {
  display: flex;
  flex-direction: column;
  gap: var(--so-s2);
  padding: var(--so-s5);
  background: var(--so-bg-card);
  text-decoration: none;
  height: 100%;
  position: relative;
  transition: transform 0.18s, box-shadow 0.18s;
  box-shadow: var(--so-shadow-card);
}
.so-news-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--so-gold);
}
.so-news-card:hover { transform: translateY(-2px); box-shadow: 0 4px 24px rgba(0, 31, 71, 0.16); text-decoration: none; }
.so-news-card__title { font-family: var(--so-font-serif); font-size: 20px; line-height: 1.2; color: var(--so-ink); margin: 0; }
.so-news-card__desc {
  font-size: 14px;
  color: var(--so-muted);
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.so-news-card__meta { font-size: 11px; color: var(--so-muted); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }

/* Section list */
.so-section-list {
  display: grid;
  gap: var(--so-s3);
  list-style: none;
  padding: 0;
  margin: var(--so-s5) 0;
}
.so-section-list li { margin: 0; }
.so-section-list a {
  display: block;
  padding: var(--so-s4);
  background: var(--so-bg-card);
  color: var(--so-ink);
  text-decoration: none;
  position: relative;
  box-shadow: var(--so-shadow-card);
  transition: transform 0.15s, box-shadow 0.15s;
}
.so-section-list a::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--so-rule);
  transition: background 0.15s;
}
.so-section-list a:hover { transform: translateX(2px); box-shadow: 0 4px 18px rgba(0, 31, 71, 0.12); text-decoration: none; }
.so-section-list a:hover::before { background: var(--so-red); }
.so-section-list__title { font-family: var(--so-font-serif); font-weight: 700; font-size: 18px; margin: 0 0 4px; color: var(--so-ink); }
.so-section-list__desc { font-size: 13px; color: var(--so-muted); margin: 0; }

/* Related pages — poster-card with art-nouveau accent line */
.so-related {
  margin: var(--so-s8) 0 var(--so-s6);
  padding-top: var(--so-s6);
  position: relative;
}
.so-related::before {
  content: "";
  display: block;
  height: 4px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='4' viewBox='0 0 200 4'><path d='M0,2 C30,0 70,4 100,2 S170,0 200,2' fill='none' stroke='%23003366' stroke-width='1.5'/></svg>");
  background-size: 200px 4px;
  background-repeat: repeat-x;
  margin-bottom: var(--so-s5);
}
.so-related__heading { font-family: var(--so-font-serif); font-size: 28px; margin: 0 0 var(--so-s5); }
.so-related__list { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--so-s4); }
.so-related-card {
  position: relative;
  background: var(--so-bg-deep);
  color: #f5f5f0;
  padding: var(--so-s5) var(--so-s5) var(--so-s5) var(--so-s7);
  overflow: hidden;
  transition: transform 0.18s, box-shadow 0.18s;
  box-shadow: 0 4px 14px rgba(0, 31, 71, 0.20);
}
.so-related-card::before {
  /* art-nouveau curving accent line */
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 14px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='14' viewBox='0 0 400 14'><path d='M0,7 C60,1 140,13 200,7 S340,1 400,7' fill='none' stroke='%23c89b3c' stroke-width='1.2' opacity='0.7'/></svg>");
  background-size: 400px 14px;
  background-repeat: repeat-x;
}
.so-related-card:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(0, 31, 71, 0.34); }
.so-related-card__chip {
  position: absolute;
  top: var(--so-s5);
  left: var(--so-s5);
  font-family: var(--so-font-sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: var(--so-bg-paper);
  color: var(--so-bg-deep);
  padding: 4px 10px;
}
.so-related-card--club .so-related-card__chip       { background: var(--so-red); color: #fff; }
.so-related-card--diffuseur .so-related-card__chip   { background: var(--so-gold); color: var(--so-bg-deep); }
.so-related-card--compétition .so-related-card__chip { background: var(--so-white); color: var(--so-bg-deep); }
.so-related-card--édito .so-related-card__chip       { background: var(--so-blue-soft); color: var(--so-bg-deep); }
.so-related-card__link { display: block; text-decoration: none; color: inherit; padding-top: var(--so-s5); }
.so-related-card__link:hover { text-decoration: none; }
.so-related-card__title {
  display: block;
  font-family: var(--so-font-serif);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.2;
  color: #f5f5f0;
  margin-bottom: 6px;
}
.so-related-card:hover .so-related-card__title { color: var(--so-gold); }
.so-related-card__label {
  display: block;
  font-family: var(--so-font-serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.45;
  color: rgba(245, 245, 240, 0.78);
}

/* FAQ block */
.so-faq {
  padding-top: var(--so-s6);
  margin: var(--so-s7) 0 var(--so-s6);
  position: relative;
}
.so-faq::before {
  content: "";
  display: block;
  height: 4px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='4' viewBox='0 0 200 4'><path d='M0,2 C30,0 70,4 100,2 S170,0 200,2' fill='none' stroke='%23003366' stroke-width='1.5'/></svg>");
  background-size: 200px 4px;
  background-repeat: repeat-x;
  margin-bottom: var(--so-s5);
}
.so-faq__heading { font-family: var(--so-font-serif); font-size: 28px; margin: 0 0 var(--so-s5); }
.so-faq__item { border-bottom: 1px solid var(--so-rule-soft); padding: var(--so-s4) 0; }
.so-faq__item summary {
  cursor: pointer;
  font-family: var(--so-font-serif);
  font-weight: 700;
  font-size: 18px;
  color: var(--so-ink);
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--so-s2) 0;
}
.so-faq__item summary::-webkit-details-marker { display: none; }
.so-faq__item summary::after { content: "+"; color: var(--so-red); font-size: 24px; font-family: var(--so-font-sans); }
.so-faq__item[open] summary::after { content: "−"; }
.so-faq__answer { padding: 0 0 var(--so-s3); margin: 0; color: var(--so-ink-soft); font-size: 16px; line-height: 1.6; }

/* Footer — 3-column matchday-style */
.so-footer {
  background: var(--so-bg-deep);
  color: rgba(245, 245, 240, 0.75);
  padding: var(--so-s8) 0 var(--so-s5);
  margin-top: var(--so-s8);
  font-size: 14px;
  position: relative;
}
.so-footer::before {
  content: "";
  display: block;
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 6px;
  background: linear-gradient(to right,
    var(--so-blue-mid) 0%, var(--so-blue-mid) 33.33%,
    var(--so-white) 33.33%, var(--so-white) 66.66%,
    var(--so-red) 66.66%, var(--so-red) 100%);
}
.so-footer__top { margin-bottom: var(--so-s7); padding-top: var(--so-s4); }
.so-footer__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--so-s7);
}
@media (max-width: 720px) { .so-footer__grid { grid-template-columns: 1fr; gap: var(--so-s5); } }
.so-footer__col h4 {
  color: #f5f5f0;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  margin: 0 0 var(--so-s3);
  font-family: var(--so-font-sans);
  font-weight: 700;
}
.so-footer__col ul { list-style: none; padding: 0; margin: 0; }
.so-footer__col li { margin: var(--so-s2) 0; }
.so-footer__col a { color: rgba(245, 245, 240, 0.75); text-decoration: none; font-size: 14px; }
.so-footer__col a:hover { color: var(--so-gold); text-decoration: underline; }
.so-footer__bottom {
  border-top: 1px solid rgba(245, 245, 240, 0.12);
  padding-top: var(--so-s4);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--so-s3);
  font-size: 12px;
  color: rgba(245, 245, 240, 0.55);
}
.so-footer__pledge {
  font-size: 11px;
  background: rgba(204, 0, 0, 0.18);
  color: #ffd1d1;
  padding: 4px 10px;
  letter-spacing: 0.08em;
  font-weight: 700;
}

/* Touch + Print */
@media (max-width: 720px) {
  a, button { min-height: 44px; }
  .so-nav__link, .so-breadcrumb a { min-height: 44px; display: inline-flex; align-items: center; }
}
@media print {
  .so-header, .so-footer, .so-disclaimer, soccer-widget, .so-nav-toggle { display: none !important; }
  body { color: #000; background: #fff; }
  a { color: inherit; text-decoration: none; }
}
