*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%}
body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
img,picture,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;cursor:pointer;color:inherit}

:root{
  --bg:#F2EDE4;
  --paper:#FBF7EE;
  --ink:#14130F;
  --ink-soft:#3A3730;
  --muted:#807A6E;
  --rule:#D9D0BD;
  --rule-soft:#E8E0CE;
  --navy:#0A2540;
  --hot:#C8102E;
  --pitch:#2A5A3D;
  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Bricolage Grotesque',ui-sans-serif,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',monospace;
  --max:1240px;
  --gutter:clamp(1.1rem,3.5vw,2.25rem);
}

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.55;
  font-feature-settings:"ss01","ss02","cv11";
}
::selection{background:var(--ink);color:var(--bg)}

.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
.wrap.narrow{max-width:760px}

a:hover{color:var(--hot)}
a:focus-visible{outline:2px solid var(--navy);outline-offset:3px;border-radius:2px}

h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.05;letter-spacing:-0.015em;font-variation-settings:"opsz" 144}
h2{font-size:clamp(1.85rem,3.6vw,2.85rem)}
h3{font-size:1.35rem;font-variation-settings:"opsz" 36}
h4{font-size:1.05rem;font-variation-settings:"opsz" 14}

.tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.kicker{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--hot)}
.num{font-family:var(--mono);font-feature-settings:"tnum"}

.dateline{border-bottom:1px solid var(--rule);background:var(--bg);font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.dateline .row{display:flex;justify-content:space-between;align-items:center;padding:.65rem 0;gap:1rem;flex-wrap:wrap}
.dateline strong{color:var(--ink);font-weight:500}

header.site{border-bottom:1px solid var(--rule);background:var(--bg);position:sticky;top:0;z-index:50;backdrop-filter:saturate(120%) blur(6px)}
header.site .row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.1rem 0}
.brand{font-family:var(--display);font-size:1.55rem;font-weight:700;letter-spacing:-.02em;font-variation-settings:"opsz" 36;display:flex;align-items:baseline;gap:.45rem}
.brand .dot{width:.42rem;height:.42rem;background:var(--hot);border-radius:50%;display:inline-block;transform:translateY(-.05rem)}
nav.primary{display:flex;gap:1.65rem;font-size:.92rem}
nav.primary a{color:var(--ink-soft);font-weight:500;position:relative;padding:.35rem 0}
nav.primary a:hover{color:var(--ink)}
nav.primary a[aria-current="page"]{color:var(--ink)}
nav.primary a[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--hot)}
@media (max-width:780px){nav.primary{display:none}}

.hero{padding:clamp(2.5rem,7vw,5.25rem) 0 clamp(2.5rem,5vw,4rem)}
.hero .grid{display:grid;grid-template-columns:1.4fr .9fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:end}
@media(max-width:920px){.hero .grid{grid-template-columns:1fr;gap:2rem}}

.issue{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.4rem;padding-bottom:1rem;border-bottom:1px solid var(--rule)}
.issue .num-box{background:var(--ink);color:var(--bg);padding:.35rem .55rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.2em}

.hero h1{font-family:var(--display);font-size:clamp(3.2rem,8.4vw,7.6rem);font-weight:600;letter-spacing:-.035em;line-height:.92;font-variation-settings:"opsz" 144,"SOFT" 50;margin-bottom:.9rem}
.hero h1 em{font-style:italic;font-weight:500;color:var(--hot)}

.hero .lede{font-family:var(--display);font-variation-settings:"opsz" 24;font-size:clamp(1.05rem,1.6vw,1.22rem);line-height:1.45;color:var(--ink-soft);max-width:34em;font-weight:400}

.hero .side{border-left:1px solid var(--rule);padding-left:clamp(1.25rem,2.5vw,2rem);align-self:end}
.hero .side dl{display:grid;gap:1.05rem;margin-top:.6rem}
.hero .side dt{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:.15rem}
.hero .side dd{font-family:var(--display);font-size:1.45rem;font-weight:500;font-variation-settings:"opsz" 24;color:var(--ink);line-height:1.1}
.hero .side dd small{font-family:var(--sans);font-size:.85rem;color:var(--muted);font-weight:400;display:block;margin-top:.15rem}

.hero .cta{display:inline-flex;align-items:center;gap:.55rem;margin-top:1.6rem;padding:.85rem 1.15rem;background:var(--ink);color:var(--bg);font-weight:500;font-size:.95rem;border-radius:2px;transition:background .2s ease,transform .2s ease}
.hero .cta:hover{background:var(--hot);color:#fff;transform:translateY(-1px)}
.hero .cta .arrow{transition:transform .2s ease}
.hero .cta:hover .arrow{transform:translateX(3px)}

.lead{padding:clamp(2.5rem,5vw,4rem) 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);background:var(--paper)}
.lead .grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
@media(max-width:880px){.lead .grid{grid-template-columns:1fr}}
.lead figure{position:relative;background:var(--rule-soft);aspect-ratio:4/3;overflow:hidden;border-radius:2px}
.lead figure img{width:100%;height:100%;object-fit:cover}
.lead figure figcaption{position:absolute;left:.85rem;bottom:.85rem;background:rgba(20,19,15,.85);color:var(--bg);padding:.35rem .55rem;font-family:var(--mono);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase}
.lead .body .kicker{margin-bottom:.9rem;display:block}
.lead .body h2{margin-bottom:1rem;font-variation-settings:"opsz" 144,"SOFT" 30}
.lead .body p{font-size:1.05rem;color:var(--ink-soft);max-width:34em;margin-bottom:.9rem}
.lead .body p:last-of-type{margin-bottom:1.5rem}
.lead .meta{display:flex;align-items:center;gap:1rem;padding-top:1rem;border-top:1px solid var(--rule);font-family:var(--mono);font-size:.75rem;color:var(--muted);letter-spacing:.05em}
.lead .read-more{font-family:var(--sans);font-weight:500;font-size:.95rem;color:var(--ink);border-bottom:1.5px solid var(--ink);padding-bottom:1px;letter-spacing:0}
.lead .read-more:hover{color:var(--hot);border-color:var(--hot)}

.section{padding:clamp(2.75rem,5.5vw,4.5rem) 0}
.section.alt{background:var(--paper);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}

.shead{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:2rem;padding-bottom:1.1rem;border-bottom:1.5px solid var(--ink);flex-wrap:wrap}
.shead h2{margin:0}
.shead .sub{color:var(--muted);font-family:var(--mono);font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;flex-shrink:0}

.section-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:500;font-size:.95rem;border-bottom:1.5px solid var(--ink);padding-bottom:1px;margin-top:1.75rem}
.section-link:hover{color:var(--hot);border-color:var(--hot)}

.clubs{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
@media(max-width:1080px){.clubs{grid-template-columns:repeat(4,1fr)}}
@media(max-width:740px){.clubs{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.clubs{grid-template-columns:repeat(2,1fr)}}

.club{background:var(--paper);padding:1.15rem 1rem 1.05rem;display:flex;flex-direction:column;gap:.45rem;position:relative;transition:background .25s ease;min-height:170px}
.club::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--club-color,var(--ink))}
.club:hover{background:#fff;z-index:1}
.club .abbr{font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.12em;color:var(--muted);margin-bottom:.5rem}
.club .name{font-family:var(--display);font-weight:600;font-size:1.18rem;line-height:1.05;letter-spacing:-.01em;font-variation-settings:"opsz" 24;color:var(--ink)}
.club .city{font-size:.82rem;color:var(--ink-soft)}
.club .stadium{font-size:.77rem;color:var(--muted);margin-top:auto;padding-top:.55rem;border-top:1px solid var(--rule-soft);display:flex;justify-content:space-between;align-items:baseline;gap:.4rem}
.club .cap{font-family:var(--mono);font-size:.72rem;color:var(--ink-soft)}
.club.excluded{opacity:.55}
.club.excluded::after{content:"exclu";font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--hot);position:absolute;top:.7rem;right:.85rem}

.stadia{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media(max-width:980px){.stadia{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.stadia{grid-template-columns:1fr}}
.stade{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--ink);border-radius:2px;display:block}
.stade img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.6,.2,1);opacity:.95}
.stade:hover img{transform:scale(1.04);opacity:1}
.stade .cap{position:absolute;left:0;right:0;bottom:0;padding:1rem .95rem .9rem;color:#fff;background:linear-gradient(to top,rgba(0,0,0,.78),rgba(0,0,0,0))}
.stade .cap .nm{font-family:var(--display);font-weight:600;font-size:1.1rem;line-height:1.1;font-variation-settings:"opsz" 24}
.stade .cap .lc{font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;opacity:.85;margin-top:.3rem}

.mag{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.5vw,2rem)}
@media(max-width:880px){.mag{grid-template-columns:1fr}}
.story{display:flex;flex-direction:column;gap:.85rem}
.story figure{aspect-ratio:5/3;overflow:hidden;background:var(--rule-soft);border-radius:2px}
.story figure img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.6,.2,1)}
.story:hover figure img{transform:scale(1.03)}
.story .kicker{margin-top:.2rem}
.story h3{font-size:1.4rem;line-height:1.1;font-variation-settings:"opsz" 36}
.story:hover h3{color:var(--hot)}
.story p{color:var(--ink-soft);font-size:.95rem;line-height:1.5}
.story .byline{font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:auto}

.palm{display:grid;grid-template-columns:1fr;gap:0;border-top:1.5px solid var(--ink)}
.palm .row{display:grid;grid-template-columns:80px 1fr 1fr;align-items:baseline;padding:.85rem 0;gap:1rem;border-bottom:1px solid var(--rule);transition:background .2s ease}
.palm .row:hover{background:var(--paper)}
.palm .yr{font-family:var(--mono);font-size:.85rem;color:var(--muted);font-weight:500}
.palm .ch{font-family:var(--display);font-size:1.25rem;font-weight:600;font-variation-settings:"opsz" 24;letter-spacing:-.005em}
.palm .meta{font-size:.85rem;color:var(--ink-soft);text-align:right}
@media(max-width:560px){.palm .row{grid-template-columns:60px 1fr}.palm .meta{display:none}}

.about{padding:clamp(2.75rem,5vw,4rem) 0;border-top:1px solid var(--rule)}
.about .grid{display:grid;grid-template-columns:1fr 2fr;gap:clamp(1.5rem,4vw,3.5rem)}
@media(max-width:780px){.about .grid{grid-template-columns:1fr}}
.about h2{font-size:clamp(1.85rem,3.4vw,2.5rem);max-width:11ch}
.about .cols{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:680px){.about .cols{grid-template-columns:1fr}}
.about .col h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--hot);margin-bottom:.5rem;font-weight:500}
.about .col p{color:var(--ink-soft);font-size:.95rem;line-height:1.55}

footer.site{background:var(--ink);color:var(--bg);padding:clamp(2.75rem,5vw,4rem) 0 1.75rem;margin-top:0}
footer.site .top{display:grid;grid-template-columns:1.4fr 3fr;gap:clamp(1.5rem,4vw,3rem);padding-bottom:2.25rem;border-bottom:1px solid rgba(255,255,255,.12)}
@media(max-width:840px){footer.site .top{grid-template-columns:1fr;gap:2rem}}
footer.site .brand{color:var(--bg);font-size:1.85rem;margin-bottom:.6rem}
footer.site .tag-line{color:rgba(242,237,228,.7);font-size:.95rem;max-width:30ch;line-height:1.5}
footer.site nav{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
@media(max-width:720px){footer.site nav{grid-template-columns:repeat(2,1fr)}}
footer.site nav h5{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,237,228,.55);margin-bottom:.85rem;font-weight:500}
footer.site nav ul{list-style:none;padding:0;display:grid;gap:.5rem}
footer.site nav a{color:var(--bg);font-size:.9rem;opacity:.9;transition:opacity .2s,color .2s}
footer.site nav a:hover{opacity:1;color:#fff}
footer.site .bottom{display:flex;justify-content:space-between;align-items:center;padding-top:1.5rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(242,237,228,.55);flex-wrap:wrap;gap:1rem}

/* Subpage shared components */
.page-head{padding:clamp(2.5rem,5vw,4rem) 0 clamp(1.5rem,3vw,2.5rem);border-bottom:1px solid var(--rule)}
.page-head .crumbs{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:1.4rem}
.page-head .crumbs a{color:var(--muted)}
.page-head .crumbs a:hover{color:var(--hot)}
.page-head .crumbs span{margin:0 .5em}
.page-head h1{font-family:var(--display);font-size:clamp(2.4rem,5.6vw,4.6rem);font-weight:600;letter-spacing:-.025em;line-height:.96;font-variation-settings:"opsz" 144;margin-bottom:.8rem}
.page-head h1 em{font-style:italic;font-weight:500;color:var(--hot)}
.page-head .dek{font-family:var(--display);font-size:clamp(1.1rem,1.7vw,1.35rem);line-height:1.4;color:var(--ink-soft);max-width:42em;font-variation-settings:"opsz" 24;font-weight:400}
.page-head .byline{margin-top:1.4rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);display:flex;gap:1rem;flex-wrap:wrap}
.page-head .byline strong{color:var(--ink);font-weight:500}

.meta-strip{background:var(--paper);border-bottom:1px solid var(--rule);padding:1rem 0;font-family:var(--mono);font-size:.75rem;letter-spacing:.06em}
.meta-strip .row{display:flex;flex-wrap:wrap;gap:1.5rem 2.5rem}
.meta-strip dt{color:var(--muted);text-transform:uppercase;letter-spacing:.18em;font-size:.65rem;margin-bottom:.2rem}
.meta-strip dd{color:var(--ink);font-weight:500}

.prose{padding:clamp(2rem,4vw,3.5rem) 0}
.prose .body{max-width:38em;margin:0 auto;font-size:1.05rem;line-height:1.65;color:var(--ink-soft)}
.prose .body.wide{max-width:46em}
.prose .body p{margin-bottom:1.1rem}
.prose .body p:first-child::first-letter{font-family:var(--display);font-weight:600;font-size:3.6rem;float:left;line-height:.9;margin:.3rem .55rem -.2rem 0;color:var(--ink)}
.prose .body h2{font-size:clamp(1.6rem,2.6vw,2.05rem);margin:2.2rem 0 .9rem;color:var(--ink);font-variation-settings:"opsz" 36}
.prose .body h3{font-size:1.25rem;margin:1.6rem 0 .65rem;color:var(--ink)}
.prose .body strong{color:var(--ink);font-weight:500}
.prose .body em{font-style:italic}
.prose .body a{color:var(--ink);border-bottom:1px solid var(--rule);transition:border-color .2s,color .2s}
.prose .body a:hover{color:var(--hot);border-color:var(--hot)}
.prose .body ul,.prose .body ol{padding-left:1.4rem;margin-bottom:1.1rem}
.prose .body li{margin-bottom:.4rem}
.prose .body blockquote{font-family:var(--display);font-style:italic;font-weight:400;font-size:1.4rem;line-height:1.4;color:var(--ink);margin:1.8rem 0;padding-left:1.1rem;border-left:3px solid var(--hot);font-variation-settings:"opsz" 36}
.prose .body figure{margin:1.8rem 0}
.prose .body figure img{width:100%;height:auto;border-radius:2px}
.prose .body figcaption{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:var(--muted);margin-top:.5rem;text-transform:uppercase}
.prose .body hr{border:0;border-top:1px solid var(--rule);margin:2rem 0}

.hero-img{aspect-ratio:5/3;overflow:hidden;background:var(--rule-soft);margin-top:1.5rem}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-img.wide{aspect-ratio:16/9}

.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.5vw,2rem)}
@media(max-width:920px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.card-grid{grid-template-columns:1fr}}
.card-grid.two{grid-template-columns:repeat(2,1fr)}
@media(max-width:720px){.card-grid.two{grid-template-columns:1fr}}

.entry{display:flex;flex-direction:column;gap:.7rem;padding:1.4rem 0;border-top:1px solid var(--rule)}
.entry:first-child{border-top:1.5px solid var(--ink)}
.entry .kicker{font-size:.7rem}
.entry h3{font-size:1.25rem;line-height:1.15;font-variation-settings:"opsz" 24}
.entry:hover h3{color:var(--hot)}
.entry p{color:var(--ink-soft);font-size:.95rem;max-width:38em}
.entry .byline{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

.standings{width:100%;border-collapse:collapse;font-size:.92rem;margin-top:.5rem;font-variant-numeric:tabular-nums}
.standings th,.standings td{padding:.55rem .7rem;text-align:left;border-bottom:1px solid var(--rule)}
.standings th{font-family:var(--mono);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:500;background:var(--paper)}
.standings td.num,.standings th.num{text-align:right;font-family:var(--mono)}
.standings tbody tr:hover{background:var(--paper)}
.standings .pos{width:2.5em;color:var(--muted);font-family:var(--mono);font-size:.85rem}
.standings .promo td{background:rgba(42,90,61,.06)}
.standings .promo td:first-child{box-shadow:inset 3px 0 var(--pitch)}
.standings .play td{background:rgba(255,199,44,.12)}
.standings .play td:first-child{box-shadow:inset 3px 0 #B5921A}
.standings .rel td{background:rgba(200,16,46,.06)}
.standings .rel td:first-child{box-shadow:inset 3px 0 var(--hot)}
.standings .legend{display:flex;flex-wrap:wrap;gap:1.2rem;margin-top:1rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;color:var(--muted)}
.standings .legend span::before{content:"";display:inline-block;width:.75rem;height:.75rem;margin-right:.4rem;vertical-align:-1px;border-radius:1px}
.standings .legend .l-up::before{background:var(--pitch)}
.standings .legend .l-pl::before{background:#B5921A}
.standings .legend .l-dn::before{background:var(--hot)}

.club-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;background:var(--paper);border-top:1.5px solid var(--ink);border-bottom:1px solid var(--rule);padding:1.1rem 0}
@media(max-width:680px){.club-meta{grid-template-columns:repeat(2,1fr)}}
.club-meta dt{font-family:var(--mono);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.25rem}
.club-meta dd{font-family:var(--display);font-size:1.15rem;font-weight:500;font-variation-settings:"opsz" 24}

.kit-bars{display:flex;height:1.4rem;border:1px solid var(--rule);border-radius:2px;overflow:hidden;margin-top:.4rem}
.kit-bars span{flex:1;display:block}

.deflist dt{font-family:var(--display);font-weight:600;font-size:1.15rem;font-variation-settings:"opsz" 24;color:var(--ink);margin-top:1.5rem;letter-spacing:-.005em}
.deflist dt:first-child{margin-top:0}
.deflist dd{margin:.4rem 0 0;color:var(--ink-soft);max-width:42em}
.deflist dd + dd{margin-top:.5rem}

.honours{display:grid;grid-template-columns:1fr;gap:0;border-top:1.5px solid var(--ink)}
.honours li{display:grid;grid-template-columns:120px 1fr;gap:1rem;padding:.7rem 0;border-bottom:1px solid var(--rule);list-style:none;font-size:.95rem}
.honours li b{font-family:var(--mono);font-size:.78rem;color:var(--muted);font-weight:500}

.aside-block{padding:1.2rem 1.3rem;background:var(--paper);border-left:3px solid var(--hot);margin:1.5rem 0;font-size:.95rem;color:var(--ink-soft)}
.aside-block h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--hot);margin-bottom:.4rem;font-weight:500}

.related{padding:clamp(2.5rem,5vw,4rem) 0;background:var(--paper);border-top:1px solid var(--rule)}
.related h3{font-family:var(--mono);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem;font-weight:500}

.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(1.5rem,4vw,3rem)}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
.contact-grid h2{margin-bottom:.5rem}
.contact-grid .channels{display:grid;gap:1.2rem;margin-top:1rem}
.contact-grid .channels h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem;font-weight:500}
.contact-grid .channels a{font-family:var(--display);font-size:1.2rem;font-weight:500;color:var(--ink);border-bottom:1.5px solid var(--ink)}
.contact-grid .channels a:hover{color:var(--hot);border-color:var(--hot)}

/* Stadium thumbnail placeholder (when no photo is available) */
.stade-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;background:linear-gradient(155deg,var(--ink) 0%,#1f1c16 60%,#2a261d 100%);color:var(--bg)}
.stade-placeholder .ph-initials{font-family:var(--display);font-weight:600;font-size:clamp(2.2rem,5vw,3.4rem);letter-spacing:-.02em;line-height:1;color:#FBF7EE}
.stade-placeholder .ph-city{font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(251,247,238,.55)}

/* Leaflet map + Wikimedia photo block */
.leaflet-map{width:100%;height:clamp(320px,42vw,460px);border-radius:2px;border:1px solid var(--rule);background:var(--rule-soft);overflow:hidden;z-index:1}
.leaflet-map .leaflet-container{font-family:var(--sans)}
.map-section{padding:clamp(2rem,4vw,3rem) 0;background:var(--paper);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.map-section h2{font-size:clamp(1.4rem,2.4vw,1.85rem);margin-bottom:1rem}
.map-credit{margin-top:.7rem;font-size:.8rem;color:var(--muted)}
.map-credit a{color:var(--ink-soft);border-bottom:1px solid var(--rule)}
.map-credit a:hover{color:var(--hot);border-color:var(--hot)}
.hero-img figcaption.wiki-credit{margin-top:.55rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;color:var(--muted);text-transform:none}
.hero-img figcaption.wiki-credit a{color:var(--ink-soft);border-bottom:1px solid var(--rule)}
.hero-img figcaption.wiki-credit a:hover{color:var(--hot);border-color:var(--hot)}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}
