/* ============================================================
   RKFC Matchen - Frontend styles
   ============================================================ */

:root {
    --rkfc-accent:        #005b9a; /* RKFC blauw — pas hier aan om overal te wijzigen */
    --rkfc-accent-dark:   #004576;
    --rkfc-accent-tint:   #e3eff8;
}

/* Lettertype: nergens een eigen font opdringen — altijd het thema volgen */
.rkfc-matchen-grid,
.rkfc-matchen-grid *,
.rkfc-klassement-wrap,
.rkfc-klassement-wrap *,
.rkfc-compact,
.rkfc-compact * {
    font-family: inherit;
}

/* Matchen grid */
.rkfc-matchen-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 20px;
    margin: 24px 0;
}

.rkfc-match-card {
    position: relative;
    background: #ffffff;
    border-radius: 4px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 2px 6px rgba(0,0,0,0.10);
    font-family: inherit;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.rkfc-match-card::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: var(--rkfc-accent);
}

.rkfc-match-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 16px rgba(0,0,0,0.16);
}

.rkfc-match-header {
    padding: 22px 16px 10px;
    text-align: center;
    border-bottom: 1px solid #f0f0f0;
}

.rkfc-match-datum {
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: #1a1a1a;
}

.rkfc-match-competitie {
    font-size: 11px;
    color: #888;
    margin-top: 6px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.rkfc-match-body {
    display: flex;
    align-items: center;
    justify-content: space-around;
    padding: 28px 12px 14px;
    gap: 8px;
    flex: 1;
}

.rkfc-match-club {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 68px;
    height: 68px;
}

.rkfc-club-logo {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}

.rkfc-club-logo-fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    background: var(--rkfc-accent);
    color: #ffffff;
    font-weight: 800;
    border-radius: 50%;
    font-size: 16px;
    letter-spacing: 0.5px;
}

.rkfc-match-result {
    flex: 0 0 auto;
    min-width: 60px;
    text-align: center;
}

.rkfc-score {
    display: inline-block;
    font-size: 26px;
    font-weight: 800;
    color: #ffffff;
    letter-spacing: 1px;
    padding: 4px 10px;
    background: var(--rkfc-accent);
    border-radius: 3px;
    line-height: 1;
}

.rkfc-vs {
    font-size: 16px;
    font-weight: 800;
    color: #888;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.rkfc-match-namen {
    display: flex;
    justify-content: space-between;
    padding: 0 16px 18px;
    font-size: 13px;
    font-weight: 600;
    color: #222;
    gap: 12px;
}

.rkfc-naam-thuis,
.rkfc-naam-uit {
    flex: 1;
    text-align: center;
    line-height: 1.3;
}

.rkfc-match-verslag,
.rkfc-match-tickets {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--rkfc-accent);
    color: #ffffff !important;
    text-decoration: none;
    padding: 14px 18px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    transition: background 0.2s, padding 0.2s;
}

.rkfc-match-verslag span[aria-hidden],
.rkfc-match-tickets span[aria-hidden] {
    color: #ffffff;
    font-size: 16px;
    line-height: 1;
    transition: transform 0.2s ease;
}

.rkfc-match-verslag:hover,
.rkfc-match-tickets:hover {
    background: var(--rkfc-accent-dark);
    color: #ffffff !important;
}

.rkfc-match-verslag:hover span[aria-hidden],
.rkfc-match-tickets:hover span[aria-hidden] {
    transform: translateX(4px);
}

/* Losse tickets-knop (shortcode buiten de match-kaart) */
.rkfc-match-tickets-standalone {
    border-radius: 6px;
}

.rkfc-matchen-empty {
    padding: 20px;
    text-align: center;
    color: #888;
    background: #f7f7f7;
    border-radius: 4px;
}

/* ============================================================
   Klassement
   ============================================================ */

.rkfc-klassement-wrap {
    margin: 24px 0;
    font-family: inherit;
}

.rkfc-klassement-titel {
    font-size: 32px;
    font-weight: 800;
    letter-spacing: -0.5px;
    text-transform: uppercase;
    margin: 0 0 24px;
}

.rkfc-klassement-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    background: #ffffff;
    border-radius: 4px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    /* scroll-hint: subtiele rechter-fade die suggereert dat er meer is */
    background-image: linear-gradient(to right, transparent calc(100% - 24px), rgba(0,0,0,0.06));
    background-repeat: no-repeat;
    background-attachment: local;
}

table.rkfc-klassement {
    width: 100%;
    min-width: 720px;
    border-collapse: collapse !important;
    border-spacing: 0 !important;
    font-size: 14px;
    background: #ffffff;
}

table.rkfc-klassement td,
table.rkfc-klassement th {
    border-left: 0 !important;
    border-right: 0 !important;
}

table.rkfc-klassement thead th {
    text-align: left;
    padding: 22px 14px;
    font-size: 12px;
    letter-spacing: 1.5px;
    color: #888;
    font-weight: 600;
    text-transform: uppercase;
    border-bottom: 1px solid rgba(0,0,0,0.06);
    background: transparent;
}

table.rkfc-klassement tbody td {
    padding: 22px 14px;
    border-bottom: 1px solid rgba(0,0,0,0.06);
    vertical-align: middle;
    color: #222;
}

table.rkfc-klassement tbody tr:last-child td {
    border-bottom: none;
}

.rkfc-col-pos {
    font-weight: 800;
    font-size: 18px;
    width: 70px;
    color: #111;
}

.rkfc-col-ploeg {
    font-weight: 500;
    color: #222;
}

.rkfc-col-trend {
    width: 40px;
    text-align: center;
}

.rkfc-col-punten {
    text-align: right;
    width: 90px;
}

.rkfc-punten-badge {
    display: inline-block;
    font-size: 22px;
    font-weight: 800;
    color: #111;
    line-height: 1;
}

.rkfc-punten-pt {
    font-size: 0.7em;
    margin-left: 1px;
}

/* "Wij" rij highlight — subtiel geel (RKFC clubkleur) */
.rkfc-klassement-wrap table.rkfc-klassement tbody tr.rkfc-rij-ons td {
    background: var(--rkfc-accent-tint) !important;
}
.rkfc-klassement-wrap table.rkfc-klassement tbody tr.rkfc-rij-ons td:first-child {
    box-shadow: inset 4px 0 0 var(--rkfc-accent);
}

/* Trend icoontjes als gevulde driehoekjes / gelijkstreep */
.rkfc-trend {
    display: inline-block;
    width: 14px;
    height: 14px;
    vertical-align: middle;
    line-height: 0;
}
.rkfc-trend-up {
    width: 0; height: 0;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-bottom: 11px solid #2bb673;
}
.rkfc-trend-down {
    width: 0; height: 0;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-top: 11px solid #d73a3a;
}
.rkfc-trend-eq {
    position: relative;
    width: 14px;
    height: 14px;
    background: transparent;
}
.rkfc-trend-eq::before,
.rkfc-trend-eq::after {
    content: "";
    position: absolute;
    left: 1px;
    right: 1px;
    height: 2px;
    background: #999;
    border-radius: 1px;
}
.rkfc-trend-eq::before { top: 4px; }
.rkfc-trend-eq::after  { bottom: 4px; }

/* Admin: highlight van "wij"-rij in het bewerk-formulier */
#rkfc-rijen-tabel tr.rkfc-rij-ons {
    background: #eaf6ee !important;
    box-shadow: inset 3px 0 0 #156138;
}

/* ============================================================
   Mobile responsive
   ============================================================ */

/* Tablet & kleiner */
@media (max-width: 782px) {
    .rkfc-matchen-grid {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 16px;
    }
    table.rkfc-klassement {
        min-width: 640px;
        font-size: 13px;
    }
    table.rkfc-klassement thead th,
    table.rkfc-klassement tbody td {
        padding: 16px 10px;
    }
}

/* Phone */
@media (max-width: 600px) {
    .rkfc-matchen-grid {
        grid-template-columns: 1fr;
        gap: 14px;
    }
    .rkfc-match-header { padding: 18px 14px 8px; }
    .rkfc-match-body   { padding: 22px 10px 10px; gap: 4px; }
    .rkfc-match-club   { width: 56px; height: 56px; }
    .rkfc-match-namen  { padding: 0 12px 14px; font-size: 12px; gap: 8px; }
    .rkfc-match-datum  { font-size: 12px; letter-spacing: 1px; }
    .rkfc-score        { font-size: 22px; padding: 3px 8px; }
    .rkfc-vs           { font-size: 14px; letter-spacing: 1.5px; }
    .rkfc-match-verslag,
    .rkfc-match-tickets {
        padding: 12px 14px;
        font-size: 11px;
        letter-spacing: 1px;
    }

    .rkfc-klassement-titel { font-size: 22px; margin-bottom: 16px; }
    table.rkfc-klassement {
        min-width: 580px;
        font-size: 13px;
    }
    table.rkfc-klassement thead th,
    table.rkfc-klassement tbody td {
        padding: 14px 8px;
    }
    .rkfc-col-pos    { font-size: 15px; width: 50px; }
    .rkfc-col-punten { width: 70px; }
    .rkfc-punten-badge { font-size: 18px; }

    /* Sticky ploeg-naam zodat je context houdt bij horizontaal scrollen */
    table.rkfc-klassement th.rkfc-col-ploeg,
    table.rkfc-klassement td.rkfc-col-ploeg {
        position: sticky;
        left: 0;
        background: #ffffff;
        z-index: 1;
    }
    .rkfc-klassement-wrap table.rkfc-klassement tbody tr.rkfc-rij-ons td.rkfc-col-ploeg {
        background: var(--rkfc-accent-tint) !important;
    }

    /* Compact-shortcode: krappere wrap */
    .rkfc-compact { gap: 0.3em; }
    .rkfc-compact-blok { padding: 0.45em 0.7em; }
}

/* Extra smal (oude/kleine telefoons) */
@media (max-width: 380px) {
    table.rkfc-klassement {
        min-width: 520px;
        font-size: 12px;
    }
    table.rkfc-klassement thead th,
    table.rkfc-klassement tbody td {
        padding: 12px 6px;
    }
    .rkfc-punten-badge { font-size: 16px; }
    .rkfc-match-verslag,
    .rkfc-match-tickets {
        padding: 11px 12px;
        font-size: 10px;
        letter-spacing: 0.8px;
    }
}

/* ============================================================
   Compact "volgende match" (voor header/menu/widget)

   Erft bewust font-family, font-size, line-height en color
   van het omringende thema-element. Wij regelen enkel lay-out.
   ============================================================ */

.rkfc-compact {
    font: inherit;
    color: inherit;
    line-height: inherit;
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    flex-wrap: wrap;
}

.rkfc-compact-blok {
    display: inline-flex;
    padding: 0.5em 0.9em;
    background: rgba(0,0,0,0.04);
    border-radius: 4px;
}

.rkfc-compact-label {
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 0.85em;
    opacity: 0.75;
}

.rkfc-compact-thuis,
.rkfc-compact-uit {
    font-weight: 600;
}

.rkfc-compact-vs {
    opacity: 0.6;
    font-size: 0.9em;
}

.rkfc-compact-datum {
    opacity: 0.75;
    font-size: 0.9em;
}

.rkfc-compact-logo img,
.rkfc-compact-logo .rkfc-club-logo-fallback {
    height: 1.4em;
    width: auto;
    max-width: 1.4em;
    vertical-align: middle;
}

.rkfc-compact-logo .rkfc-club-logo-fallback {
    width: 1.4em;
    height: 1.4em;
    font-size: 0.55em;
}
