@font-face {
    font-family: "Space Grotesk";
    font-style: normal;
    font-weight: 400 600;
    font-display: swap;
    src: url("/fonts/space-grotesk-latin.woff2") format("woff2");
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: "Space Grotesk";
    font-style: normal;
    font-weight: 400 600;
    font-display: swap;
    src: url("/fonts/space-grotesk-latin-ext.woff2") format("woff2");
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
    font-family: "Spectral";
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("/fonts/spectral-400-latin.woff2") format("woff2");
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: "Spectral";
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("/fonts/spectral-400-latin-ext.woff2") format("woff2");
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
    font-family: "Spectral";
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("/fonts/spectral-600-latin.woff2") format("woff2");
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: "Spectral";
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("/fonts/spectral-600-latin-ext.woff2") format("woff2");
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root {
    --color-papier: #F4EDE1;
    --color-papier-warm: #ECE2CF;
    --color-paneel: #F4F6F1;
    --color-inkt: #1B1916;
    --color-inkt-zacht: #5B5448;
    --color-inkt-meta: #6A6356;
    --color-veldgroen: #1F5B3A;
    --color-veld-diep: #103D27;
    --color-krijt: #F4F6F1;
    --color-lijn: #CDC9C0;
    --color-lijn-warm: #D9CFBC;
    --color-hairline: #E0D4BE;
    --color-goud: #C8932F;
    --color-tramrood: #D23B2C;
    --color-groen-zacht-vlak: #EEF3EF;
    --font-serif: "Spectral", Georgia, serif;
    --font-grotesk: "Space Grotesk", Arial, sans-serif;
    --page-max: 760px;
    --screen-margin: 20px;
    --section-gap: 14px;
    --radius-panel: 10px;
}

* {
    box-sizing: border-box;
}

html {
    min-height: 100%;
    background: var(--color-papier);
    color: var(--color-inkt);
    font-family: var(--font-serif);
}

body {
    min-height: 100%;
    margin: 0;
    background: var(--color-papier);
    color: var(--color-inkt);
}

button,
input,
textarea,
select {
    font: inherit;
}

a {
    color: var(--color-veldgroen);
    text-underline-offset: 0.18em;
}

a:hover,
a:focus-visible {
    text-decoration-thickness: 0.12em;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: 2px solid var(--color-veldgroen);
    outline-offset: 3px;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}

.skip-link {
    position: fixed;
    top: 12px;
    left: 50%;
    z-index: 20;
    padding: 8px 12px;
    border: 1px solid var(--color-inkt);
    background: var(--color-paneel);
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 12px;
    font-weight: 600;
    transform: translate(-50%, -160%);
}

.skip-link:focus-visible {
    transform: translate(-50%, 0);
}

.app-shell {
    width: min(100%, var(--page-max));
    min-height: 100vh;
    margin: 0 auto;
    padding: 0 var(--screen-margin) calc(98px + env(safe-area-inset-bottom));
}

.site-masthead {
    padding: 20px 0 15px;
    border-bottom: 1px solid var(--color-inkt);
}

.brand-lockup {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--color-inkt);
    text-decoration: none;
}

.brand-lockup:hover,
.brand-lockup:focus-visible {
    text-decoration: underline;
}

.brand-mark {
    width: 34px;
    height: 34px;
    flex: 0 0 34px;
    display: block;
}

.brand-wordmark {
    font-family: var(--font-serif);
    font-size: 38px;
    font-weight: 600;
    line-height: 0.95;
}

.brand-signature {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin: 7px 0 0;
    color: var(--color-inkt-meta);
    font-family: var(--font-grotesk);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0;
    text-transform: uppercase;
}

.live-strip {
    margin-top: 10px;
    border-bottom: 1px solid var(--color-lijn-warm);
}

.live-strip-inner {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    padding: 8px 0 10px;
}

.live-strip-label {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--color-tramrood);
    font-family: var(--font-grotesk);
    font-size: 10px;
    font-weight: 600;
    line-height: 1;
    text-transform: uppercase;
}

.live-strip-label::before {
    width: 6px;
    height: 6px;
    content: "";
    border: 1px solid currentColor;
    border-radius: 50%;
}

.live-strip-list {
    display: flex;
    gap: 12px;
    margin: 0;
    padding: 0;
    overflow-x: auto;
    list-style: none;
}

.live-strip-match {
    display: inline-flex;
    gap: 7px;
    align-items: baseline;
    min-width: max-content;
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 12px;
    font-weight: 600;
    line-height: 1.25;
    text-decoration: none;
}

.live-strip-match:hover,
.live-strip-match:focus-visible {
    text-decoration: underline;
}

.live-strip-score {
    color: var(--color-inkt);
    font-family: var(--font-serif);
    font-size: 15px;
    line-height: 1;
}

.content-frame {
    padding: 22px 0;
}

.content-frame:focus {
    outline: none;
}

.section-intro {
    display: grid;
    gap: 10px;
    margin-bottom: 20px;
}

.kicker,
.meta-label {
    margin: 0;
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 11px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
}

h1,
h2,
p {
    margin-top: 0;
}

h1,
h2 {
    font-family: var(--font-serif);
    font-weight: 600;
    color: var(--color-inkt);
}

h1 {
    max-width: 12ch;
    margin-bottom: 0;
    font-size: 32px;
    line-height: 1.05;
}

h1:focus {
    outline: none;
}

h2 {
    margin-bottom: 6px;
    font-size: 21px;
    line-height: 1.05;
}

p {
    max-width: 48ch;
    color: var(--color-inkt-zacht);
    font-size: 16px;
    line-height: 1.55;
}

.search-form,
.system-state-panel,
.data-route-list,
.data-list {
    display: grid;
    gap: 8px;
    margin-top: var(--section-gap);
    padding: 16px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
}

.system-state-panel--warning,
.system-state-panel--error {
    border-color: var(--color-lijn);
}

.system-state-panel--success {
    border-color: var(--color-veldgroen);
}

.system-state-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    font-family: var(--font-grotesk);
    font-size: 13px;
}

.system-state-panel--loading {
    border-style: dashed;
}

.data-snapshot {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    overflow: hidden;
    margin-top: var(--section-gap);
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-lijn-warm);
}

.data-snapshot > div {
    display: grid;
    gap: 2px;
    min-width: 0;
    padding: 12px 8px;
    background: var(--color-paneel);
}

.data-snapshot-number {
    color: var(--color-inkt);
    font-family: var(--font-grotesk);
    font-size: 25px;
    font-weight: 600;
    line-height: 1;
}

.data-snapshot-label {
    color: var(--color-inkt-meta);
    font-family: var(--font-grotesk);
    font-size: 10px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
}

.data-route-list a,
.data-list-row {
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 14px;
    font-weight: 600;
}

.data-list-row {
    display: grid;
    grid-template-columns: minmax(24px, auto) minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    padding: 10px 0;
    border-top: 1px solid var(--color-lijn-warm);
    text-decoration: none;
}

.data-list-row:first-child {
    border-top: 0;
}

.data-list-row:hover,
.data-list-row:focus-visible,
.data-route-list a:hover,
.data-route-list a:focus-visible {
    text-decoration: underline;
}

.data-hub-grid {
    display: grid;
    gap: var(--section-gap);
    margin-top: var(--section-gap);
}

.data-hub-card {
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 16px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
    color: var(--color-veldgroen);
    text-decoration: none;
}

.data-hub-card:hover,
.data-hub-card:focus-visible {
    text-decoration: underline;
}

.data-hub-card-title {
    color: var(--color-veldgroen);
    overflow-wrap: anywhere;
    font-family: var(--font-grotesk);
    font-size: 16px;
    font-weight: 600;
    line-height: 1.15;
}

.data-hub-card-body {
    color: var(--color-inkt-zacht);
    font-family: var(--font-serif);
    font-size: 15px;
    line-height: 1.45;
}

.data-section {
    display: grid;
    gap: 12px;
    margin-top: var(--section-gap);
    padding: 14px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
}

.data-section-heading {
    display: grid;
    gap: 2px;
}

.data-section-heading h2 {
    margin-bottom: 0;
}

.data-mini-list {
    display: grid;
}

.data-mini-list a {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    min-width: 0;
    padding: 11px 0;
    border-top: 1px solid var(--color-hairline);
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
}

.data-mini-list a:first-child {
    padding-top: 0;
    border-top: 0;
}

.data-mini-list a:last-child {
    padding-bottom: 0;
}

.data-mini-list a:hover,
.data-mini-list a:focus-visible {
    text-decoration: underline;
}

.data-mini-list span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.data-mini-list span:last-child {
    color: var(--color-inkt-meta);
    font-size: 11px;
    line-height: 1.25;
    text-align: right;
}

.standings-panel {
    display: grid;
    gap: 10px;
    margin-top: var(--section-gap);
    padding: 12px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
}

.standings-panel-heading {
    display: grid;
    gap: 2px;
}

.standings-panel-heading h2 {
    margin-bottom: 0;
}

.competition-context-panel {
    display: grid;
    gap: 12px;
    margin-top: var(--section-gap);
    padding: 14px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
}

.competition-context-panel p {
    margin-bottom: 0;
    color: var(--color-inkt-zacht);
    font-family: var(--font-serif);
    font-size: 15px;
    line-height: 1.45;
}

.competition-snapshot {
    margin-top: 0;
}

.competition-matchdays {
    margin-top: var(--section-gap);
}

.competition-round-list {
    max-height: 360px;
    overflow: auto;
    padding-right: 2px;
}

.standings-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
    color: var(--color-inkt);
    font-family: var(--font-grotesk);
    font-size: 12px;
    line-height: 1.25;
}

.standings-table caption {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}

.standings-table th,
.standings-table td {
    padding: 9px 4px;
    border-top: 1px solid var(--color-hairline);
    vertical-align: middle;
}

.standings-table thead th {
    padding-top: 0;
    color: var(--color-inkt-meta);
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
}

.standings-table tbody tr:first-child th,
.standings-table tbody tr:first-child td {
    border-top-color: var(--color-lijn);
}

.standings-table-position {
    width: 32px;
}

.standings-table-number {
    width: 36px;
}

.standings-table-points {
    width: 42px;
}

.position-cell,
.numeric-cell {
    color: var(--color-inkt-meta);
    text-align: right;
    white-space: nowrap;
}

.position-cell {
    color: var(--color-inkt);
    font-weight: 600;
    text-align: left;
}

.club-cell {
    min-width: 0;
    color: var(--color-veldgroen);
    font-weight: 600;
    text-align: left;
}

.club-cell a {
    color: var(--color-veldgroen);
    overflow-wrap: anywhere;
    text-decoration: none;
}

.club-cell a:hover,
.club-cell a:focus-visible {
    text-decoration: underline;
}

.points-cell {
    color: var(--color-inkt);
    font-weight: 600;
}

.standings-table .optional-stat {
    display: none;
}

.club-header {
    display: grid;
    grid-template-columns: 74px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    margin-bottom: 18px;
}

.club-crest {
    display: grid;
    width: 74px;
    height: 74px;
    place-items: center;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 18px;
    font-weight: 600;
}

.club-heading {
    min-width: 0;
}

.club-heading h1 {
    max-width: 16ch;
}

.club-heading p:last-child {
    margin-bottom: 0;
}

.club-tabs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
    gap: 1px;
    overflow: hidden;
    margin-top: var(--section-gap);
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-lijn-warm);
}

.club-tabs a {
    display: grid;
    min-height: 44px;
    place-items: center;
    background: var(--color-paneel);
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
}

.club-tabs a:hover,
.club-tabs a:focus-visible {
    text-decoration: underline;
}

.club-data-panel {
    display: grid;
    gap: 12px;
    margin-top: var(--section-gap);
    padding: 14px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
}

.club-panel-heading {
    display: grid;
    gap: 2px;
}

.club-panel-heading h2 {
    margin-bottom: 0;
}

.club-standing-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1px;
    overflow: hidden;
    border: 1px solid var(--color-hairline);
    border-radius: 8px;
    background: var(--color-hairline);
}

.club-standing-grid > div {
    display: grid;
    gap: 2px;
    min-width: 0;
    padding: 12px 10px;
    background: var(--color-papier);
}

.club-stat-value {
    color: var(--color-inkt);
    font-family: var(--font-grotesk);
    font-size: 25px;
    font-weight: 600;
    line-height: 1;
}

.club-stat-label {
    color: var(--color-inkt-meta);
    font-family: var(--font-grotesk);
    font-size: 10px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
}

.club-panel-link {
    justify-self: start;
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 13px;
    font-weight: 600;
}

.club-match-list {
    display: grid;
}

.club-match-row {
    display: grid;
    gap: 5px;
    padding: 12px 0;
    border-top: 1px solid var(--color-hairline);
}

.club-match-row:first-child {
    padding-top: 0;
    border-top: 0;
}

.club-match-row:last-child {
    padding-bottom: 0;
}

.club-match-round,
.club-match-main,
.club-match-row p {
    font-family: var(--font-grotesk);
}

.club-match-round {
    justify-self: start;
    color: var(--color-veldgroen);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
}

.club-match-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 8px;
    align-items: center;
    color: var(--color-inkt);
    font-size: 13px;
    font-weight: 600;
}

.club-match-main a {
    min-width: 0;
    color: var(--color-veldgroen);
    overflow-wrap: anywhere;
    text-decoration: none;
}

.club-match-main a:last-child {
    text-align: right;
}

.club-match-main a:hover,
.club-match-main a:focus-visible,
.club-panel-link:hover,
.club-panel-link:focus-visible,
.club-match-round:hover,
.club-match-round:focus-visible {
    text-decoration: underline;
}

.club-match-main span,
.club-match-main .match-score-link {
    color: var(--color-inkt);
    font-family: var(--font-grotesk);
    font-size: 14px;
    font-weight: 600;
    white-space: nowrap;
}

.club-match-main .match-score-link {
    color: var(--color-veldgroen);
    text-align: center;
    text-decoration: none;
}

.club-match-row p {
    margin-bottom: 0;
    color: var(--color-inkt-meta);
    font-size: 11px;
    line-height: 1.25;
}

.squad-list {
    display: grid;
}

.squad-row {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    min-width: 0;
    padding: 11px 0;
    border-top: 1px solid var(--color-hairline);
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    text-decoration: none;
}

.squad-row:first-child {
    padding-top: 0;
    border-top: 0;
}

.squad-row:last-child {
    padding-bottom: 0;
}

.squad-row:hover,
.squad-row:focus-visible {
    text-decoration: underline;
}

.squad-number {
    display: grid;
    min-height: 34px;
    place-items: center;
    border: 1px solid var(--color-hairline);
    border-radius: 8px;
    background: var(--color-papier);
    color: var(--color-inkt);
    font-size: 14px;
    font-weight: 600;
}

.squad-player {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.squad-player span:first-child {
    overflow-wrap: anywhere;
    font-size: 14px;
    font-weight: 600;
}

.squad-player span:last-child {
    color: var(--color-inkt-meta);
    font-size: 11px;
    line-height: 1.25;
}

.player-header {
    display: grid;
    grid-template-columns: 74px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    margin-bottom: 18px;
}

.player-mark {
    display: grid;
    width: 74px;
    height: 74px;
    place-items: center;
    border: 1px solid var(--color-lijn-warm);
    border-radius: 50%;
    background: var(--color-paneel);
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 18px;
    font-weight: 600;
}

.player-photo-frame {
    display: grid;
    gap: 5px;
    margin: 0;
}

.player-photo-frame img {
    display: block;
    width: 74px;
    height: 74px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: 50%;
    background: var(--color-veld-diep);
    object-fit: cover;
}

.player-photo-frame figcaption {
    max-width: 74px;
    color: var(--color-inkt-meta);
    font-family: var(--font-grotesk);
    font-size: 9px;
    line-height: 1.2;
    text-transform: uppercase;
}

.player-heading {
    min-width: 0;
}

.player-heading h1 {
    max-width: 16ch;
}

.player-heading p:last-child {
    margin-bottom: 0;
}

.player-data-panel {
    display: grid;
    gap: 12px;
    margin-top: var(--section-gap);
    padding: 14px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
}

.player-panel-heading {
    display: grid;
    gap: 2px;
}

.player-panel-heading h2 {
    margin-bottom: 0;
}

.player-facts {
    display: grid;
    gap: 1px;
    overflow: hidden;
    border: 1px solid var(--color-hairline);
    border-radius: 8px;
    background: var(--color-hairline);
}

.player-facts > div {
    display: grid;
    gap: 2px;
    min-width: 0;
    padding: 11px 10px;
    background: var(--color-papier);
}

.player-fact-label,
.player-fact-value,
.player-club-links {
    font-family: var(--font-grotesk);
}

.player-fact-label {
    color: var(--color-inkt-meta);
    font-size: 10px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
}

.player-fact-value {
    color: var(--color-inkt);
    overflow-wrap: anywhere;
    font-size: 14px;
    font-weight: 600;
}

.player-club-links {
    display: grid;
}

.player-club-links a {
    display: grid;
    gap: 2px;
    min-width: 0;
    padding: 11px 0;
    border-top: 1px solid var(--color-hairline);
    color: var(--color-veldgroen);
    text-decoration: none;
}

.player-club-links a:first-child {
    padding-top: 0;
    border-top: 0;
}

.player-club-links a:last-child {
    padding-bottom: 0;
}

.player-club-links a:hover,
.player-club-links a:focus-visible {
    text-decoration: underline;
}

.player-club-links span:first-child {
    overflow-wrap: anywhere;
    font-size: 14px;
    font-weight: 600;
}

.player-club-links span:last-child {
    color: var(--color-inkt-meta);
    font-size: 11px;
    line-height: 1.25;
}

.portuguese-identity-panel {
    display: grid;
    gap: 12px;
    margin-top: var(--section-gap);
    padding: 14px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-groen-zacht-vlak);
}

.identity-stat-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    overflow: hidden;
    border: 1px solid var(--color-hairline);
    border-radius: 8px;
    background: var(--color-hairline);
}

.identity-stat-grid > div {
    display: grid;
    gap: 2px;
    min-width: 0;
    padding: 12px 10px;
    background: var(--color-papier);
}

.identity-stat-value {
    color: var(--color-inkt);
    font-family: var(--font-grotesk);
    font-size: 24px;
    font-weight: 600;
    line-height: 1;
}

.identity-stat-label {
    color: var(--color-inkt-meta);
    font-family: var(--font-grotesk);
    font-size: 10px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
}

.identity-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.identity-chip-list span {
    border: 1px solid var(--color-hairline);
    border-radius: 18px;
    background: var(--color-papier);
    color: var(--color-inkt);
    font-family: var(--font-grotesk);
    font-size: 11px;
    font-weight: 600;
    line-height: 1.2;
    padding: 5px 9px;
}

.identity-web-link {
    display: grid;
    gap: 2px;
    min-width: 0;
    padding-top: 10px;
    border-top: 1px solid var(--color-hairline);
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    text-decoration: none;
}

.identity-web-link:hover,
.identity-web-link:focus-visible {
    text-decoration: underline;
}

.identity-web-link span {
    color: var(--color-inkt-meta);
    font-size: 10px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
}

.identity-web-link strong {
    color: var(--color-veldgroen);
    overflow-wrap: anywhere;
    font-size: 14px;
    line-height: 1.25;
}

.matchday-index {
    display: grid;
    gap: var(--section-gap);
}

.matchday-card {
    display: grid;
    gap: 12px;
    margin-top: var(--section-gap);
    padding: 14px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
}

.matchday-index .matchday-card {
    margin-top: 0;
}

.matchday-card-heading {
    display: grid;
    gap: 2px;
}

.matchday-card-heading h2 {
    margin-bottom: 0;
}

.matchday-card-heading a {
    color: var(--color-veldgroen);
    text-decoration: none;
}

.matchday-card-heading a:hover,
.matchday-card-heading a:focus-visible {
    text-decoration: underline;
}

.match-list {
    display: grid;
}

.match-row {
    display: grid;
    gap: 5px;
    min-width: 0;
    padding: 12px 0;
    border-top: 1px solid var(--color-hairline);
}

.match-row:first-child {
    padding-top: 0;
    border-top: 0;
}

.match-row:last-child {
    padding-bottom: 0;
}

.match-row-meta,
.match-row-main,
.matchday-back-link {
    font-family: var(--font-grotesk);
}

.match-row-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    color: var(--color-inkt-meta);
    font-size: 10px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
}

.match-row-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 8px;
    align-items: center;
    color: var(--color-inkt);
    font-size: 13px;
    font-weight: 600;
}

.match-row-main a {
    min-width: 0;
    color: var(--color-veldgroen);
    overflow-wrap: anywhere;
    text-decoration: none;
}

.match-row-main a:last-child {
    text-align: right;
}

.match-row-main a:hover,
.match-row-main a:focus-visible,
.matchday-back-link:hover,
.matchday-back-link:focus-visible {
    text-decoration: underline;
}

.match-row-main span,
.match-row-main .match-score-link {
    color: var(--color-inkt);
    font-family: var(--font-grotesk);
    font-size: 14px;
    font-weight: 600;
    white-space: nowrap;
}

.match-row-main .match-score-link {
    color: var(--color-veldgroen);
    text-align: center;
    text-decoration: none;
}

.matchday-back-link {
    justify-self: start;
    color: var(--color-veldgroen);
    font-size: 13px;
    font-weight: 600;
}

.match-header {
    display: grid;
    gap: 8px;
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--color-inkt);
}

.match-header h1 {
    max-width: 15ch;
}

.match-header p:last-child {
    margin-bottom: 0;
}

.match-scoreboard {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1px;
    overflow: hidden;
    margin-top: var(--section-gap);
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-lijn-warm);
}

.match-team-card,
.match-score-card {
    display: grid;
    gap: 4px;
    min-width: 0;
    padding: 14px;
    background: var(--color-paneel);
}

.match-team-card a {
    color: var(--color-veldgroen);
    overflow-wrap: anywhere;
    font-family: var(--font-grotesk);
    font-size: 15px;
    font-weight: 600;
    line-height: 1.2;
    text-decoration: none;
}

.match-team-card a:hover,
.match-team-card a:focus-visible {
    text-decoration: underline;
}

.match-team-card span,
.match-score-label {
    color: var(--color-inkt-meta);
    font-family: var(--font-grotesk);
    font-size: 10px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
}

.match-score-card {
    align-content: center;
    text-align: center;
}

.match-score-value {
    color: var(--color-inkt);
    font-family: var(--font-serif);
    font-size: 36px;
    font-weight: 600;
    line-height: 0.95;
}

.match-detail-panel {
    display: grid;
    gap: 12px;
    margin-top: var(--section-gap);
    padding: 14px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
}

.match-web-links {
    display: grid;
    gap: 1px;
    overflow: hidden;
    border: 1px solid var(--color-lijn-warm);
    border-radius: 8px;
    background: var(--color-lijn-warm);
}

.match-web-links a {
    display: grid;
    gap: 2px;
    min-width: 0;
    padding: 11px 12px;
    background: var(--color-papier);
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    text-decoration: none;
}

.match-web-links a:hover,
.match-web-links a:focus-visible {
    text-decoration: underline;
}

.match-web-links span {
    color: var(--color-inkt-meta);
    font-size: 10px;
    line-height: 1.2;
    text-transform: uppercase;
}

.match-web-links strong {
    color: var(--color-veldgroen);
    overflow-wrap: anywhere;
    font-size: 14px;
    line-height: 1.25;
}

.news-edition-hero,
.edition-page-header,
.story-header {
    display: grid;
    gap: 8px;
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--color-inkt);
}

.news-edition-hero h1,
.edition-page-header h1 {
    max-width: none;
    font-size: 46px;
    line-height: 0.95;
}

.news-edition-hero p,
.edition-page-header p,
.story-header p {
    margin-bottom: 0;
}

.edition-link {
    justify-self: start;
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 13px;
    font-weight: 600;
}

.edition-link:hover,
.edition-link:focus-visible {
    text-decoration: underline;
}

.news-timeline {
    position: relative;
    display: grid;
    gap: var(--section-gap);
    margin-top: var(--section-gap);
    padding-left: 13px;
}

.news-timeline::before {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 2px;
    width: 1px;
    content: "";
    background: var(--color-hairline);
}

.news-card {
    position: relative;
    display: grid;
    gap: 8px;
    padding: 14px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
}

.news-card::before {
    position: absolute;
    top: 18px;
    left: -15px;
    width: 7px;
    height: 7px;
    content: "";
    border: 1px solid var(--color-veldgroen);
    border-radius: 50%;
    background: var(--color-papier);
}

.news-card-meta,
.news-card-footer,
.source-comparison-row span,
.source-link-list span,
.further-web-links span {
    font-family: var(--font-grotesk);
}

.news-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    color: var(--color-inkt-meta);
    font-size: 10px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
}

.news-card h2 {
    margin-bottom: 0;
}

.news-card h2 a {
    color: var(--color-inkt);
    text-decoration-color: var(--color-veldgroen);
}

.news-card p {
    margin-bottom: 0;
}

.news-card-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    font-size: 12px;
    font-weight: 600;
}

.story-page {
    display: grid;
    gap: 18px;
}

.story-header h1 {
    max-width: 14ch;
}

.story-figure {
    display: grid;
    gap: 6px;
    margin: 0;
}

.story-figure img {
    width: 100%;
    height: auto;
    border-radius: 4px;
}

.story-figure figcaption {
    color: var(--color-veldgroen);
    font-size: 12px;
}

.story-body {
    display: grid;
    gap: 12px;
}

.story-body p {
    margin-bottom: 0;
}

.story-lead {
    color: var(--color-inkt);
    font-size: 19px;
    font-weight: 600;
    line-height: 1.35;
}

.story-body h2,
.source-comparison h2,
.source-rule h2,
.further-web h2 {
    margin-bottom: 0;
}

.source-comparison,
.source-rule,
.further-web {
    display: grid;
    gap: 10px;
    padding-top: 14px;
    border-top: 1px solid var(--color-hairline);
}

.source-comparison-row {
    display: grid;
    gap: 3px;
    padding: 10px 0;
    border-top: 1px solid var(--color-hairline);
}

.source-comparison-row:first-of-type {
    border-top: 0;
}

.source-comparison-row span {
    color: var(--color-veldgroen);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
}

.source-comparison-row p {
    margin-bottom: 0;
}

.source-link-list {
    display: grid;
}

.source-link-list a {
    display: grid;
    gap: 2px;
    min-width: 0;
    padding: 11px 0;
    border-top: 1px solid var(--color-hairline);
    color: var(--color-veldgroen);
    text-decoration: none;
}

.source-link-list a:first-child {
    padding-top: 0;
    border-top: 0;
}

.source-link-list a:hover,
.source-link-list a:focus-visible {
    text-decoration: underline;
}

.source-link-list span {
    color: var(--color-inkt-meta);
    font-size: 10px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
}

.source-link-list strong {
    color: var(--color-veldgroen);
    overflow-wrap: anywhere;
    font-family: var(--font-grotesk);
    font-size: 14px;
    line-height: 1.25;
}

.further-web-links {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    overflow: hidden;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-lijn-warm);
}

.further-web-links a {
    display: grid;
    gap: 2px;
    min-width: 0;
    padding: 11px 12px;
    background: var(--color-paneel);
    color: var(--color-veldgroen);
    font-family: var(--font-grotesk);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
}

.further-web-links a:hover,
.further-web-links a:focus-visible {
    text-decoration: underline;
}

.further-web-links span {
    color: var(--color-inkt-meta);
    font-size: 10px;
    line-height: 1.2;
    text-transform: uppercase;
}

.saudade-register {
    padding-left: 14px;
    border-left: 2px solid var(--color-goud);
}

.saudade-register .kicker,
.saudade-panel .meta-label {
    color: var(--color-veldgroen);
}

.saudade-panel {
    background: var(--color-papier-warm);
}

.saudade-list {
    display: grid;
    gap: var(--section-gap);
}

.saudade-card {
    display: grid;
    gap: 12px;
    padding: 14px;
    border-left: 2px solid var(--color-goud);
    border-top: 1px solid var(--color-hairline);
    background: var(--color-papier);
}

.saudade-card--aged {
    background: var(--color-papier-warm);
}

.saudade-card-media {
    margin: 0;
}

.saudade-card-media img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-radius: 4px;
    background: var(--color-veld-diep);
}

.saudade-card-copy {
    display: grid;
    gap: 7px;
}

.saudade-card-copy h2 {
    margin-bottom: 0;
}

.saudade-card-copy h2 a {
    color: var(--color-inkt);
    text-decoration-color: var(--color-goud);
}

.saudade-card-copy p {
    margin-bottom: 0;
}

.saudade-card-links {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    font-family: var(--font-grotesk);
    font-size: 12px;
    font-weight: 600;
}

.saudade-article {
    display: grid;
    gap: 18px;
}

.saudade-article--aged {
    padding: 14px;
    border-left: 2px solid var(--color-goud);
    background: var(--color-papier-warm);
}

.saudade-article-header {
    display: grid;
    gap: 8px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--color-inkt);
}

.saudade-article-header .kicker,
.saudade-card .meta-label,
.saudade-further-web .meta-label {
    color: var(--color-veldgroen);
}

.saudade-article-header h1 {
    max-width: 13ch;
    font-style: italic;
}

.saudade-hero-media {
    display: grid;
    gap: 7px;
    margin: 0;
}

.saudade-hero-media img {
    display: block;
    width: 100%;
    max-height: 420px;
    object-fit: cover;
    border-radius: 4px;
    background: var(--color-veld-diep);
}

.saudade-hero-media figcaption {
    color: var(--color-inkt-meta);
    font-family: var(--font-grotesk);
    font-size: 10px;
    line-height: 1.3;
    text-transform: uppercase;
}

.saudade-body {
    display: grid;
    gap: 12px;
}

.saudade-body p,
.saudade-body blockquote {
    margin-bottom: 0;
}

.saudade-body p:first-of-type::first-letter {
    float: left;
    padding-right: 7px;
    color: var(--color-veldgroen);
    font-size: 56px;
    font-weight: 600;
    line-height: 0.9;
}

.saudade-body h2,
.saudade-body h3 {
    margin: 6px 0 0;
}

.saudade-body h3 {
    color: var(--color-inkt);
    font-family: var(--font-serif);
    font-size: 18px;
    font-weight: 600;
    line-height: 1.15;
}

.saudade-body blockquote {
    padding: 0 0 0 13px;
    border-left: 2px solid var(--color-goud);
    color: var(--color-inkt);
    font-size: 20px;
    font-style: italic;
    line-height: 1.35;
}

.saudade-list-item {
    position: relative;
    padding-left: 18px;
}

.saudade-list-item::before {
    position: absolute;
    left: 1px;
    content: "";
    width: 6px;
    height: 6px;
    margin-top: 10px;
    border-radius: 50%;
    background: var(--color-goud);
}

.search-form label {
    color: var(--color-inkt);
    font-family: var(--font-grotesk);
    font-size: 12px;
    font-weight: 600;
}

.search-form input {
    width: 100%;
    min-height: 46px;
    padding: 10px 12px;
    border: 1px solid var(--color-lijn);
    border-radius: 8px;
    background: var(--color-papier);
    color: var(--color-inkt);
    font: inherit;
}

.search-form-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
}

.search-form button {
    min-height: 46px;
    padding: 0 14px;
    border: 1px solid var(--color-veldgroen);
    border-radius: 8px;
    background: var(--color-veldgroen);
    color: var(--color-papier);
    font-family: var(--font-grotesk);
    font-size: 13px;
    font-weight: 700;
}

.search-form input:focus-visible,
.search-form button:focus-visible,
.search-result-card a:focus-visible {
    outline: 2px solid var(--color-veldgroen);
    outline-offset: 3px;
}

.search-form button:hover {
    filter: brightness(0.94);
}

.system-state-panel h2 {
    margin-bottom: 2px;
}

.search-scope-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.search-scope-list span {
    padding: 10px 12px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: 8px;
    background: var(--color-papier);
    color: var(--color-inkt);
    font-family: var(--font-grotesk);
    font-size: 13px;
    font-weight: 700;
}

.search-results {
    display: grid;
    gap: 14px;
    margin-top: var(--section-gap);
}

.search-results-heading {
    display: grid;
    gap: 2px;
}

.search-result-list {
    display: grid;
    gap: 10px;
}

.search-result-card {
    display: grid;
    gap: 8px;
    padding: 16px;
    border: 1px solid var(--color-lijn-warm);
    border-radius: var(--radius-panel);
    background: var(--color-paneel);
}

.search-result-card h3 {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 22px;
    line-height: 1.12;
}

.search-result-card a {
    color: var(--color-veldgroen);
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

.search-result-card a:hover {
    text-decoration-thickness: 2px;
}

.search-result-card p {
    margin: 0;
}

.search-result-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 10px;
    color: var(--color-inkt-meta);
    font-family: var(--font-grotesk);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.search-result-meta span:first-child {
    color: var(--color-inkt);
}

.bottom-tabs {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 10;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    width: min(100%, var(--page-max));
    margin: 0 auto;
    padding: 8px var(--screen-margin) calc(8px + env(safe-area-inset-bottom));
    border-top: 1px solid var(--color-inkt);
    background: color-mix(in srgb, var(--color-papier) 94%, white);
}

.bottom-tab {
    display: grid;
    min-width: 0;
    min-height: 54px;
    place-items: center;
    gap: 4px;
    color: var(--color-inkt-meta);
    font-family: var(--font-grotesk);
    font-size: 11px;
    font-weight: 600;
    text-decoration: none;
}

.bottom-tab:hover,
.bottom-tab:focus-visible {
    text-decoration: underline;
}

.bottom-tab.active,
.bottom-tab[aria-current="page"] {
    color: var(--color-veldgroen);
    text-decoration-line: underline;
    text-decoration-thickness: 0.12em;
    text-underline-offset: 0.42em;
}

.tab-icon {
    position: relative;
    display: inline-grid;
    width: 23px;
    height: 23px;
    place-items: center;
    color: currentColor;
    font-family: var(--font-serif);
    font-size: 18px;
    line-height: 1;
}

.tab-icon-news {
    border: 2px solid currentColor;
    border-radius: 50%;
    background: radial-gradient(circle at center, currentColor 0 2px, transparent 2.5px);
}

.tab-icon-news::before {
    position: absolute;
    inset: 5px;
    content: "";
    border: 1.5px solid currentColor;
    border-radius: 50%;
}

.tab-icon-news::after {
    position: absolute;
    top: 3px;
    left: 50%;
    width: 1.5px;
    height: 15px;
    content: "";
    background: currentColor;
    transform: translateX(-50%);
}

.bottom-tab.active .tab-icon-news,
.bottom-tab[aria-current="page"] .tab-icon-news {
    border-color: var(--color-veldgroen);
    background:
        radial-gradient(circle at center, var(--color-krijt) 0 2px, transparent 2.5px),
        var(--color-veldgroen);
}

.bottom-tab.active .tab-icon-news::before,
.bottom-tab[aria-current="page"] .tab-icon-news::before {
    border-color: var(--color-krijt);
}

.bottom-tab.active .tab-icon-news::after,
.bottom-tab[aria-current="page"] .tab-icon-news::after {
    background: var(--color-krijt);
}

.tab-icon-data {
    border-bottom: 2px solid currentColor;
}

.tab-icon-data::before,
.tab-icon-data::after {
    position: absolute;
    bottom: 0;
    width: 4px;
    content: "";
    border-radius: 3px 3px 0 0;
    background: currentColor;
}

.tab-icon-data::before {
    left: 5px;
    height: 13px;
}

.tab-icon-data::after {
    right: 5px;
    height: 19px;
}

.tab-icon-search {
    border: 2px solid currentColor;
    border-radius: 50%;
    transform: scale(0.78);
}

.tab-icon-search::after {
    position: absolute;
    right: -6px;
    bottom: -3px;
    width: 9px;
    height: 2px;
    content: "";
    border-radius: 2px;
    background: currentColor;
    transform: rotate(45deg);
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--color-veldgroen);
}

.invalid {
    outline: 1px solid var(--color-lijn);
}

.validation-message {
    color: var(--color-inkt-meta);
}

.blazor-error-boundary {
    padding: 1rem;
    border-left: 3px solid var(--color-lijn);
    background: var(--color-paneel);
    color: var(--color-inkt);
}

.blazor-error-boundary::after {
    content: "Er is een fout opgetreden.";
}

.darker-border-checkbox.form-check-input {
    border-color: var(--color-inkt-meta);
}

@media (min-width: 700px) {
    .app-shell {
        padding-right: 32px;
        padding-left: 32px;
    }

    .brand-wordmark {
        font-size: 44px;
    }

    h1 {
        max-width: 16ch;
        font-size: 42px;
    }

    .standings-panel {
        padding: 16px;
    }

    .standings-table {
        font-size: 13px;
    }

    .data-hub-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .standings-table .optional-stat {
        display: table-cell;
    }

    col.optional-stat {
        display: table-column;
    }

    .club-header {
        grid-template-columns: 90px minmax(0, 1fr);
        gap: 18px;
    }

    .club-crest {
        width: 90px;
        height: 90px;
    }

    .player-header {
        grid-template-columns: 90px minmax(0, 1fr);
        gap: 18px;
    }

    .player-mark {
        width: 90px;
        height: 90px;
    }

    .player-photo-frame img {
        width: 90px;
        height: 90px;
    }

    .player-photo-frame figcaption {
        max-width: 90px;
    }

    .club-standing-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .player-facts {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .match-scoreboard {
        grid-template-columns: minmax(0, 1fr) minmax(104px, auto) minmax(0, 1fr);
    }

    .match-team-card--away {
        text-align: right;
    }
}
