/* Logo: header en footer zijn altijd donker, gebruik altijd logo-light.svg */

/* ============================================================
   badmintonline.nl — Layout
   ============================================================ */

/* --------------------------------------------------------------
   Logo dark/light mode
   -------------------------------------------------------------- */
.logo-light-mode { display: block; }
.logo-dark-mode  { display: none; }

[data-theme="dark"] .logo-light-mode { display: none; }
[data-theme="dark"] .logo-dark-mode  { display: block; }

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .logo-light-mode { display: none; }
    :root:not([data-theme="light"]) .logo-dark-mode  { display: block; }
}

/* Logo zichtbaarheid — hoge specificiteit */
.site-header__logo img.logo-light-mode        { display: block !important; }
.site-header__logo img.logo-dark-mode         { display: none  !important; }
.site-header__eredivisie img.logo-light-mode  { display: block !important; }
.site-header__eredivisie img.logo-dark-mode   { display: none  !important; }

[data-theme="dark"] .site-header__logo img.logo-light-mode        { display: none  !important; }
[data-theme="dark"] .site-header__logo img.logo-dark-mode         { display: block !important; }
[data-theme="dark"] .site-header__eredivisie img.logo-light-mode  { display: none  !important; }
[data-theme="dark"] .site-header__eredivisie img.logo-dark-mode   { display: block !important; }

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .site-header__logo img.logo-light-mode        { display: none  !important; }
    :root:not([data-theme="light"]) .site-header__logo img.logo-dark-mode         { display: block !important; }
    :root:not([data-theme="light"]) .site-header__eredivisie img.logo-light-mode  { display: none  !important; }
    :root:not([data-theme="light"]) .site-header__eredivisie img.logo-dark-mode   { display: block !important; }
}

/* --------------------------------------------------------------
   Main achtergrond
   -------------------------------------------------------------- */
body {
    background: var(--color-bg);
}

main#main-content {
    background: var(--color-bg);
    min-height: 50vh;
}

/* --------------------------------------------------------------
   Skip link
   -------------------------------------------------------------- */
.skip-link {
    position:   absolute;
    top:        -100%;
    left:       var(--space-4);
    padding:    var(--space-2) var(--space-4);
    background: var(--color-cta);
    color:      var(--color-cta-text);
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    font-weight:   var(--font-weight-medium);
    font-size:     var(--font-size-sm);
    z-index:       var(--z-toast);
    transition:    top var(--transition-fast);
}
.skip-link:focus { top: 0; }

/* --------------------------------------------------------------
   Breaking news ticker
   -------------------------------------------------------------- */
.breaking-news {
    background:  var(--color-breaking);
    color:       #ffffff;
    font-size:   var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    position:    relative;
    z-index:     calc(var(--z-header) + 1);
}
.breaking-news__inner {
    display:     flex;
    align-items: center;
    gap:         var(--space-3);
    min-height:  36px;
    padding:     var(--space-2) 0;
}
.breaking-news__label {
    background:     rgba(255,255,255,.2);
    padding:        2px var(--space-2);
    border-radius:  var(--radius-sm);
    font-size:      var(--font-size-xs);
    text-transform: uppercase;
    letter-spacing: .05em;
    flex-shrink:    0;
    font-weight:    var(--font-weight-bold);
}
.breaking-news__track { flex: 1; overflow: hidden; }
.breaking-news__text  { margin: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.breaking-news__link  { color: #ffffff; text-decoration: underline; text-underline-offset: 2px; }
.breaking-news__link:hover { color: rgba(255,255,255,.85); }
.breaking-news__close {
    flex-shrink:   0;
    color:         rgba(255,255,255,.7);
    padding:       var(--space-1);
    border-radius: var(--radius-sm);
    transition:    color var(--transition-fast), background var(--transition-fast);
}
.breaking-news__close:hover { color: #ffffff; background: rgba(255,255,255,.15); }

/* --------------------------------------------------------------
   Header
   -------------------------------------------------------------- */
.site-header {
    position:      sticky;
    top:           0;
    z-index:       var(--z-header);
    background:    var(--color-header-bg);
    border-bottom: 1px solid var(--color-header-border);
    height:        var(--header-height);
    transition:    box-shadow var(--transition-base);
}

.site-header.is-scrolled { box-shadow: var(--shadow-md); }

.site-header__inner {
    display:     flex;
    align-items: center;
    gap:         var(--space-4);
    height:      100%;
}

/* Logo links, nav vult ruimte, eredivisie + actions rechts */
.site-header__logo       { flex-shrink: 0; }
.site-nav                { flex: 1; min-width: 0; }
.site-header__eredivisie { flex-shrink: 0; margin-left: auto; }

/* Als nav verborgen is, neemt margin-left: auto de ruimte over */
@media (max-width: 767px) {
    .site-header__eredivisie { margin-left: auto; }
}

.site-header__actions {
    display:     flex;
    align-items: center;
    gap:         var(--space-1);
    flex-shrink: 0;
    margin-left: 0;
}

.site-header__logo {
    flex-shrink:     0;
    display:         flex;
    align-items:     center;
    text-decoration: none;
}

.site-header__logo img {
    display: block;
    height:  22px;
    width:   98px;
    object-fit: contain;
    object-position: left center;
}

.site-header__eredivisie {
    flex-shrink:     0;
    display:         flex;
    align-items:     center;
    opacity:         .85;
    transition:      opacity var(--transition-fast);
    text-decoration: none;
}
.site-header__eredivisie:hover { opacity: 1; }
.site-header__eredivisie img   { display: block; height: 22px; width: 50px; object-fit: contain; }

.site-nav__list {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-1);
}

.site-nav__link {
    display:       block;
    padding:       var(--space-2) var(--space-3);
    font-size:     var(--font-size-sm);
    font-weight:   var(--font-weight-medium);
    color:         var(--color-header-nav-text);
    border-radius: var(--radius-md);
    transition:    color var(--transition-fast), background var(--transition-fast);
    white-space:   nowrap;
}
.site-nav__link:hover             { color: var(--color-header-nav-hover); background: var(--color-header-nav-hover-bg); }
.site-nav__link[aria-current="page"] { color: var(--color-cta); font-weight: var(--font-weight-bold); }

.site-header__action-btn {
    display:         flex;
    align-items:     center;
    justify-content: center;
    width:           40px;
    height:          40px;
    border-radius:   var(--radius-md);
    color:           var(--color-header-nav-text);
    transition:      color var(--transition-fast), background var(--transition-fast);
}
.site-header__action-btn:hover { color: var(--color-header-nav-hover); background: var(--color-header-nav-hover-bg); }

.icon-sun  { display: block; }
.icon-moon { display: none; }

[data-theme="dark"] .icon-sun  { display: none; }
[data-theme="dark"] .icon-moon { display: block; }

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .icon-sun  { display: none; }
    :root:not([data-theme="light"]) .icon-moon { display: block; }
}

.icon-close { display: none; }
.site-header__hamburger[aria-expanded="true"] .icon-menu  { display: none; }
.site-header__hamburger[aria-expanded="true"] .icon-close { display: block; }
.site-header__hamburger { display: none; }

/* --------------------------------------------------------------
   Site intro
   -------------------------------------------------------------- */
.site-intro { padding: var(--space-4) 0 var(--space-2); }

.site-intro__inner {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    gap:             var(--space-4);
}

.site-intro__title {
    font-size:   var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color:       var(--color-text);
    line-height: var(--line-height-tight);
    display:     flex;
    align-items: center;
    gap:         var(--space-2);
    margin:      0;
    flex:        1;
}

.site-intro__title--short { display: none; }
.site-intro__title--full  { display: inline; }

.site-intro__title::before {
    content:       '';
    display:       inline-block;
    width:         4px;
    height:        1.1em;
    border-radius: var(--radius-sm);
    flex-shrink:   0;
    background:    var(--color-brand);
}

.site-intro__date {
    font-size:   var(--font-size-sm);
    color:       var(--color-text-tertiary);
    white-space: nowrap;
    flex-shrink: 0;
    margin:      0;
    text-align:  right;
}

@media (max-width: 767px) {
    .site-intro         { padding: var(--space-2) 0; }
    .site-intro__date   { display: none; }
    .site-intro__title  { font-size: var(--font-size-lg); }
    .site-intro__title--full  { display: none; }
    .site-intro__title--short { display: inline; }
}

/* --------------------------------------------------------------
   Section header
   -------------------------------------------------------------- */
.section-header {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    gap:             var(--space-4);
    margin-bottom:   var(--space-5);
}
.section-header__title {
    font-size:   var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color:       var(--color-text);
    line-height: var(--line-height-tight);
    display:     flex;
    align-items: center;
    gap:         var(--space-2);
    margin:      0;
}
.section-header__title::before {
    content:       '';
    display:       inline-block;
    width:         4px;
    height:        1.1em;
    border-radius: var(--radius-sm);
    flex-shrink:   0;
    background:    var(--section-accent, var(--color-brand));
}
.section-header__link {
    font-size:   var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color:       var(--color-text-tertiary);
    flex-shrink: 0;
    transition:  color var(--transition-fast);
    line-height: 1;
    align-self:  center;
}
.section-header__link:hover { color: var(--color-text); }

.section--nieuws     { --section-accent: var(--color-accent-nieuws); }
.section--video      { --section-accent: var(--color-accent-video); }
.section--kennisbank { --section-accent: var(--color-accent-kennisbank); }
.section--spelers    { --section-accent: var(--color-accent-spelers); }
.section--clubs      { --section-accent: var(--color-accent-clubs); }

/* --------------------------------------------------------------
   Secties
   -------------------------------------------------------------- */
.section          { padding-top: var(--space-10); padding-bottom: var(--space-10); border-top: 1px solid var(--color-border); }
.section--first   { padding-top: 0; border-top: none; }
.section--shaded  { background: var(--color-bg-secondary); }
.section--pattern {
    background-color: var(--color-bg-secondary);
    background-image: radial-gradient(var(--color-border) 1px, transparent 1px);
    background-size:  24px 24px;
}

/* --------------------------------------------------------------
   Hero artikel
   -------------------------------------------------------------- */
.hero-article {
    position:        relative;
    display:         block;
    border-radius:   var(--radius-md);
    overflow:        hidden;
    aspect-ratio:    16 / 9;
    min-height:      360px;
    width:           100%;
    max-width:       100%;
    background:      var(--color-bg-tertiary);
    text-decoration: none;
    color:           #ffffff;
}
.hero-article__img {
    position:   absolute;
    inset:      0;
    width:      100%;
    height:     100%;
    object-fit: cover;
    transition: transform 400ms ease;
}
.hero-article:hover .hero-article__img { transform: scale(1.04); }
.hero-article__overlay {
    position:   absolute;
    inset:      0;
    background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.4) 45%, transparent 75%);
    pointer-events: none;
}
.hero-article__body {
    position:        absolute;
    inset:           0;
    padding:         var(--space-6) var(--space-6);
    display:         flex;
    flex-direction:  column;
    gap:             var(--space-2);
    justify-content: flex-end;
}
.hero-article__date  { font-size: var(--font-size-xs); color: rgba(255,255,255,.7); margin: 0; }
.hero-article__title { font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold); color: #ffffff; line-height: var(--line-height-tight); margin: 0; text-shadow: 0 1px 3px rgba(0,0,0,.3); }
.hero-article__intro { font-size: var(--font-size-sm); color: rgba(255,255,255,.85); margin: 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

@media (max-width: 600px) {
    .hero-article__title { font-size: var(--font-size-xl); }
    .hero-article__body  { padding: var(--space-4); }
}

/* Home hero sidebar */
.home-hero__sidebar    { display: flex; flex-direction: column; gap: var(--space-3); }
.home-hero__all-news   { margin-top: var(--space-2); width: 100%; justify-content: space-between; }

/* --------------------------------------------------------------
   Player hero
   -------------------------------------------------------------- */
.player-hero {
    display:         block;
    position:        relative;
    border-radius: var(--radius-md);
    overflow:        hidden;
    background:      var(--color-accent-spelers-light);
    text-decoration: none;
    color:           #ffffff;
    min-height:      200px;
}
.player-hero__img {
    position:        absolute;
    inset:           0;
    width:           100%;
    height:          100%;
    object-fit:      cover;
    object-position: center top;
    transition:      transform 400ms ease;
}
.player-hero:hover .player-hero__img { transform: scale(1.04); }
.player-hero__overlay {
    position:   absolute;
    inset:      0;
    background: linear-gradient(to top, rgba(0,0,0,.75) 0%, rgba(0,0,0,.2) 50%, transparent 80%);
}
.player-hero__body {
    position:        absolute;
    bottom:          0;
    left:            0;
    right:           0;
    padding:         var(--space-4) var(--space-5);
}
.player-hero__info {
    display:         flex;
    align-items:     flex-end;
    justify-content: space-between;
    gap:             var(--space-3);
    width:           100%;
}
.player-hero__name { font-size: var(--font-size-lg); font-weight: var(--font-weight-bold); color: #ffffff; margin: 0; line-height: var(--line-height-tight); }
.player-hero__meta { font-size: var(--font-size-xs); color: rgba(255,255,255,.75); margin: 0; }
.player-hero__brand-badge {
    width:           32px;
    height:          32px;
    border-radius:   var(--radius-full);
    background:      rgba(255,255,255,.95);
    border:          2px solid rgba(255,255,255,.5);
    display:         flex;
    align-items:     center;
    justify-content: center;
    flex-shrink:     0;
    overflow:        hidden;
}
.player-hero__brand-badge img { width: 24px; height: 24px; object-fit: contain; }

/* players-col */
.players-col__hero {
    display:        flex;
    flex-direction: column;
}

.players-col__hero .player-hero {
    flex:       1;
    width:      100%;
}

.players-col__hero .player-hero .player-hero__img {
    position:   absolute;
    inset:      0;
    width:      100%;
    height:     100%;
    object-fit: cover;
}
.players-col__list  { display: flex; flex-direction: column; gap: var(--space-2); }

/* --------------------------------------------------------------
   Footer
   -------------------------------------------------------------- */
.site-footer {
    background: var(--color-footer-bg);
    color:      var(--color-footer-text);
    margin-top: var(--space-12);
    font-size:  var(--font-size-sm);
}
.site-footer__top {
    padding:       var(--space-8) 0 var(--space-6);
    border-bottom: 1px solid var(--color-footer-border);
}
.site-footer__logo-link        { display: inline-block; margin-bottom: var(--space-4); }
.site-footer__logo-link img    { height: 28px; width: auto; max-width: 160px; display: block; }
.site-footer__bio-row {
    display:     flex;
    align-items: center;
    gap:         var(--space-8);
    margin-bottom: var(--space-5);
}

.site-footer__bio {
    font-size:   var(--font-size-sm);
    color:       var(--color-footer-text);
    line-height: var(--line-height-base);
    margin:      0;
    flex:        1;
    max-width:   480px;
}

.site-footer__social {
    display:     flex;
    gap:         var(--space-4);
    flex-wrap:   wrap;
    flex-shrink: 0;
    align-items: center;
}

.site-footer__social a {
    color:      var(--color-footer-link);
    transition: color var(--transition-fast), transform var(--transition-fast);
    display:    flex;
    align-items: center;
}

.site-footer__social a:hover { color: var(--color-footer-link-hover); transform: translateY(-2px); }

/* Desktop: grote icons */
.site-footer__social a svg { width: 44px; height: 44px; }

/* Mobiel: terug naar klein */
@media (max-width: 767px) {
    .site-footer__bio-row {
        flex-direction: column;
        align-items:    flex-start;
        gap:            var(--space-4);
    }
    .site-footer__social a svg { width: 18px; height: 18px; }
}

.site-footer__nav {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   var(--space-6);
    padding:               var(--space-8) 0;
    border-bottom:         1px solid var(--color-footer-border);
}
.site-footer__nav-title {
    font-size:      var(--font-size-xs);
    font-weight:    var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: .08em;
    color:          var(--color-footer-heading);
    margin-bottom:  var(--space-4);
}
.site-footer__nav-list { display: flex; flex-direction: column; gap: var(--space-2); }
.site-footer__nav-list a { font-size: var(--font-size-sm); color: var(--color-footer-link); transition: color var(--transition-fast); }
.site-footer__nav-list a:hover { color: var(--color-footer-link-hover); }

.site-footer__newsletter-desc  { font-size: var(--font-size-sm); color: var(--color-footer-text); margin-bottom: var(--space-3); line-height: var(--line-height-base); }
.site-footer__newsletter-row   { display: flex; gap: var(--space-2); }
.site-footer__newsletter-input {
    flex: 1; min-width: 0;
    padding:     var(--space-2) var(--space-3);
    font-size:   var(--font-size-sm);
    background:  rgba(255,255,255,.07);
    border:      1px solid var(--color-footer-border);
    border-radius: var(--radius-md);
    color:       var(--color-footer-heading);
    transition:  border-color var(--transition-fast);
    font-family: inherit;
}
.site-footer__newsletter-input::placeholder { color: var(--color-footer-text); }
.site-footer__newsletter-input:focus { outline: none; border-color: var(--color-cta); }
.site-footer__newsletter-btn {
    padding:     var(--space-2) var(--space-4);
    background:  var(--color-cta);
    color:       var(--color-cta-text);
    border:      none;
    border-radius: var(--radius-md);
    font-size:   var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    cursor:      pointer;
    white-space: nowrap;
    transition:  background var(--transition-fast);
    font-family: inherit;
}
.site-footer__newsletter-btn:hover { background: var(--color-cta-dark); }

.site-footer__bottom {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    padding:         var(--space-4) 0;
    font-size:       var(--font-size-xs);
    gap:             var(--space-4);
    flex-wrap:       wrap;
}
.site-footer__copy { margin: 0; color: var(--color-footer-text); }
.site-footer__bottom-links { display: flex; gap: var(--space-4); flex-wrap: wrap; }
.site-footer__bottom-links a { color: var(--color-footer-text); transition: color var(--transition-fast); }
.site-footer__bottom-links a:hover { color: var(--color-footer-link-hover); }
.site-footer__cookie-btn {
    background:  none; border: none; padding: 0;
    font-size:   var(--font-size-xs);
    color:       var(--color-footer-text);
    cursor:      pointer; font-family: inherit;
    transition:  color var(--transition-fast);
}
.site-footer__cookie-btn:hover { color: var(--color-footer-link-hover); }

/* Footer mobile */
@media (max-width: 900px) {
    .site-footer__nav { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .site-footer__logo-link img   { height: 22px; max-width: 50vw; }
    .site-footer__newsletter-row  { flex-direction: column; }
    .site-footer__newsletter-input,
    .site-footer__newsletter-btn  { width: 100%; }
    .site-footer__nav             { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
    .site-footer__bottom          { flex-direction: column; align-items: flex-start; gap: var(--space-2); }
}

/* --------------------------------------------------------------
   Paginastructuur
   -------------------------------------------------------------- */
.container {
    width:     100%;
    max-width: var(--container-max);
    margin:    0 auto;
    padding:   0 var(--container-padding);
}

@media (max-width: 900px) {
    .container { padding: 0 var(--space-4); }
}

@media (max-width: 600px) {
    .container { padding: 0 var(--space-3); }
}
.page-header  { padding: 0 0 var(--space-6); margin-bottom: var(--space-6); }
.page-header__title    { font-size: var(--font-size-3xl); line-height: var(--line-height-tight); margin-bottom: var(--space-2); }
.page-header__subtitle { font-size: var(--font-size-md); color: var(--color-text-secondary); }
.page-content          { padding: var(--space-8) 0 var(--space-16); }

/* --------------------------------------------------------------
   Mobile bottom navigation
   -------------------------------------------------------------- */
.mobile-nav {
    display:       none;
    position:      fixed;
    bottom:        var(--space-4);
    left:          50%;
    transform:     translateX(-50%);
    z-index:       var(--z-header);
    background:    var(--color-bg);
    border:        1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow:    var(--shadow-lg);
    padding:       var(--space-2) var(--space-3);
    transition:    transform 300ms ease, opacity 300ms ease;
    min-width:     280px;
}
.mobile-nav.is-hidden { transform: translateX(-50%) translateY(120%); opacity: 0; pointer-events: none; }
.mobile-nav__list { display: flex; align-items: center; justify-content: space-around; gap: var(--space-1); }
.mobile-nav__item {
    display:        flex;
    flex-direction: column;
    align-items:    center;
    gap:            3px;
    padding:        var(--space-2) var(--space-3);
    border-radius:  var(--radius-md);
    text-decoration:none;
    color:          var(--color-text-secondary);
    cursor:         pointer;
    background:     none;
    border:         none;
    font-family:    inherit;
    transition:     color var(--transition-fast), background var(--transition-fast);
    min-width:      56px;
}
.mobile-nav__item:hover  { color: var(--color-text); background: var(--color-bg-secondary); }
.mobile-nav__item.is-active { color: var(--color-cta); }
.mobile-nav__icon  { width: 22px; height: 22px; flex-shrink: 0; }
.mobile-nav__label { font-size: var(--font-size-xs); font-weight: var(--font-weight-medium); line-height: 1; white-space: nowrap; }

/* Sidebar overlay */
.sidebar-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: calc(var(--z-header) + 10); backdrop-filter: blur(4px); }
.sidebar-overlay.is-open { display: block; }

/* Sidebar */
.mobile-sidebar {
    position:   fixed;
    top:        0;
    left:       -320px;
    width:      300px;
    height:     100vh;
    height:     100dvh;
    background: var(--color-sidebar-bg);
    z-index:    calc(var(--z-header) + 11);
    display:    flex;
    flex-direction: column;
    transition: left 300ms ease;
    overflow-y: auto;
    box-shadow: var(--shadow-lg);
}
.mobile-sidebar.is-open { left: 0; }
.mobile-sidebar__header { display: flex; align-items: center; justify-content: space-between; padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-sidebar-border); flex-shrink: 0; }
.mobile-sidebar__logo img { height: 22px; width: 100px; object-fit: contain; object-position: left center; }
.mobile-sidebar__logo img.logo-light-mode { display: block; }
.mobile-sidebar__logo img.logo-dark-mode  { display: none; }
[data-theme="dark"] .mobile-sidebar__logo img.logo-light-mode { display: none; }
[data-theme="dark"] .mobile-sidebar__logo img.logo-dark-mode  { display: block; }
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .mobile-sidebar__logo img.logo-light-mode { display: none; }
    :root:not([data-theme="light"]) .mobile-sidebar__logo img.logo-dark-mode  { display: block; }
}
.mobile-sidebar__close { width: 32px; height: 32px; border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; color: var(--color-sidebar-text); transition: background var(--transition-fast); cursor: pointer; background: none; border: none; font-family: inherit; }
.mobile-sidebar__close:hover { background: var(--color-sidebar-hover-bg); color: var(--color-sidebar-text-hover); }
.mobile-sidebar__nav { flex: 1; padding: var(--space-2) var(--space-3); display: flex; flex-direction: column; gap: var(--space-2); overflow-y: auto; }
.mobile-sidebar__section { display: flex; flex-direction: column; gap: 2px; }
.mobile-sidebar__link { display: flex; align-items: center; padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); font-size: var(--font-size-base); color: var(--color-sidebar-text); text-decoration: none; transition: color var(--transition-fast), background var(--transition-fast); }
.mobile-sidebar__link:hover { color: var(--color-sidebar-text-hover); background: var(--color-sidebar-hover-bg); }
.mobile-sidebar__link.is-active { color: var(--color-cta); font-weight: var(--font-weight-bold); background: rgba(255,102,0,.15); }
.mobile-sidebar__link--secondary { font-size: var(--font-size-sm); color: var(--color-sidebar-link-secondary); }
.mobile-sidebar__link--secondary:hover { color: var(--color-sidebar-text); }
.mobile-sidebar__footer { padding: var(--space-3) var(--space-4); border-top: 1px solid var(--color-sidebar-border); flex-shrink: 0; }
.mobile-sidebar__socials { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.mobile-sidebar__social { color: var(--color-sidebar-social); transition: color var(--transition-fast); display: flex; align-items: center; }
.mobile-sidebar__social:hover { color: var(--color-sidebar-text-hover); }

@media (max-width: 767px) {
    .mobile-nav { display: flex; }
    body { padding-bottom: 0; }
    main#main-content { padding-bottom: 80px; }
    .site-header { height: var(--header-height-mobile); }
    /* site-header__eredivisie altijd zichtbaar */
    .site-nav { display: none; }
    .site-header__logo img { height: 18px; width: 80px; }
}
@media (min-width: 768px) {
    .mobile-sidebar, .sidebar-overlay { display: none !important; }
}

/* --------------------------------------------------------------
   Consistent grid-systeem
   -------------------------------------------------------------- */
.article-grid {
    display:               grid;
    grid-template-columns: repeat(3, 1fr);
    gap:                   var(--space-5);
}
.article-grid--4 {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   var(--space-5);
}
.article-grid--2 {
    display:               grid;
    grid-template-columns: repeat(2, 1fr);
    gap:                   var(--space-5);
}

/* Home hero: 3+1 */
.home-hero {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   var(--space-5);
    align-items:           start;
}
.home-hero .hero-article { grid-column: 1 / span 3; }
.home-hero .home-hero__sidebar { grid-column: 4; }

/* Kennisbank (3) + CTA (1) */
.section-split {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   var(--space-5);
    align-items:           start;
}
.section-split > :first-child { grid-column: 1 / span 3; }
.section-split > :last-child  { grid-column: 4; }

/* Spelers (2) + Clubs (2) */
.section-players-clubs {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   var(--space-5);
    align-items:           start;
}
.section-players-clubs > :first-child { grid-column: 1 / span 2; }
.section-players-clubs > :last-child  { grid-column: 3 / span 2; }

/* Players col: hero + lijst */
.players-col {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   var(--space-5);
    align-items:           stretch;
}

/* Tablet (≤ 900px) */
@media (max-width: 900px) {
    .article-grid--4 { grid-template-columns: repeat(2, 1fr); }
    .home-hero { grid-template-columns: 1fr; }
    .home-hero .hero-article { grid-column: 1; }
    .home-hero .home-hero__sidebar { grid-column: 1; display: grid; grid-template-columns: repeat(2, 1fr); }
    .home-hero__all-news { grid-column: 1 / -1; }
    .section-split { grid-template-columns: 1fr; }
    .section-split > :first-child,
    .section-split > :last-child { grid-column: 1; }
    .section-players-clubs { grid-template-columns: 1fr; }
    .section-players-clubs > :first-child,
    .section-players-clubs > :last-child { grid-column: 1; }
    .players-col { grid-template-columns: 1fr 1fr; }
}

/* Mobile (≤ 600px) */
@media (max-width: 767px) {
    .section--nieuws .article-grid--4 { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
}

@media (max-width: 600px) {
    .article-grid,
    .article-grid--4,
    .article-grid--2 { grid-template-columns: 1fr; gap: var(--space-3); }
    .home-hero .home-hero__sidebar { display: flex; flex-direction: column; }
    .players-col { grid-template-columns: 1fr; }
}





@media (max-width: 767px) { .site-header__search { display: none; } }

/* Hero-article: tekst bepaalt hoogte op kleine schermen */
@media (max-width: 600px) {
    .hero-article {
        aspect-ratio:  unset !important;
        height:        auto !important;
        display:       grid !important;
        grid-template: 1fr / 1fr;
    }
    .hero-article__img,
    .hero-article__overlay,
    .hero-article__body {
        grid-area: 1 / 1;
    }
    .hero-article__img {
        position:   relative !important;
        inset:      unset !important;
        width:      100%;
        height:     100%;
        object-fit: cover;
        align-self: stretch;
    }
    .hero-article__overlay {
        position: relative !important;
        inset:    unset !important;
        z-index:  1;
    }
    .hero-article__body {
        position:  relative !important;
        inset:     unset !important;
        z-index:   2;
        padding:   var(--space-4) !important;
        align-self: end;
    }
}
