/* Camperkaart - huisstijl #1F5965 (petrol) en #1B2B2E (donker) */
.ck-app, .ck-detail {
    --ck-groen: #1f5965;
    --ck-groen-d: #16434c;
    --ck-donker: #1b2b2e;
    --ck-donker-2: #2a3d40;
    --ck-grijs: #f4f6f5;
    --ck-grijs-2: #e6eae8;
    --ck-rand: #d8dedb;
    --ck-tekst: #293536;
    --ck-tekst-licht: #5c6b6c;
    --ck-wit: #ffffff;
    --ck-radius: 4px;
    --ck-radius-sm: 4px;
    --ck-shadow: 0 4px 20px rgba(41,53,54,.08);
    --ck-shadow-h: 0 8px 28px rgba(41,53,54,.14);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    color: var(--ck-tekst);
    box-sizing: border-box;
}
.ck-app *, .ck-detail * { box-sizing: border-box; }

/* ---------- Platform ---------- */
.ck-app {
    display: flex;
    flex-direction: column;
    height: 82vh;
    min-height: 560px;
    border: 1px solid var(--ck-rand);
    border-radius: var(--ck-radius);
    overflow: hidden;
    background: var(--ck-wit);
    box-shadow: var(--ck-shadow);
    position: relative;
}

.ck-topbar {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    background: var(--ck-donker);
    flex-wrap: wrap;
}
.ck-search {
    display: flex;
    align-items: center;
    flex: 1 1 320px;
    background: var(--ck-wit);
    border-radius: 999px;
    padding: 4px 6px 4px 14px;
    gap: 8px;
}
.ck-search-icon { width: 19px; height: 19px; flex: none; fill: none; stroke: var(--ck-tekst-licht); stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
#ck-search-input {
    border: 0; outline: 0; flex: 1; font-size: 15px; padding: 8px 0; background: transparent; color: var(--ck-tekst);
}
.ck-geo-btn {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--ck-groen); color: #fff; border: 0;
    padding: 8px 14px; border-radius: 999px; font-size: 13px; font-weight: 600; cursor: pointer;
    white-space: nowrap; transition: background .15s;
}
.ck-geo-btn:hover { background: var(--ck-groen-d); }
.ck-geo-btn svg { width: 16px; height: 16px; fill: none; stroke: #fff; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }

.ck-topbar-actions { display: flex; align-items: center; gap: 12px; }
.ck-result-count { color: #cbd5d3; font-size: 13px; }
.ck-filter-toggle {
    display: none; align-items: center; gap: 6px;
    background: var(--ck-donker-2); color: #fff; border: 0;
    padding: 9px 14px; border-radius: var(--ck-radius-sm); font-size: 14px; cursor: pointer;
}
.ck-filter-toggle svg { width: 18px; height: 18px; fill: none; stroke: #fff; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }

.ck-view-switch { display: flex; background: var(--ck-donker-2); border-radius: var(--ck-radius-sm); padding: 3px; }
.ck-view-btn {
    border: 0; background: transparent; color: #cbd5d3; padding: 7px 13px;
    font-size: 13px; cursor: pointer; border-radius: 4px; font-weight: 500; transition: all .15s;
}
.ck-view-btn.is-active { background: var(--ck-groen); color: #fff; }

.ck-layout { display: flex; flex: 1; min-height: 0; }

/* Filters */
.ck-filters {
    width: 280px; flex: none; background: var(--ck-grijs);
    border-right: 1px solid var(--ck-rand); overflow-y: auto; padding: 18px;
}
.ck-filters-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.ck-filters-head h2 { font-size: 17px; margin: 0; }
.ck-link-btn { background: none; border: 0; color: var(--ck-groen); font-weight: 600; cursor: pointer; font-size: 13px; }
.ck-filter-group { padding: 16px 0; border-bottom: 1px solid var(--ck-grijs-2); }
.ck-filter-group:last-child { border-bottom: 0; }
.ck-filter-group h3 { font-size: 13px; text-transform: uppercase; letter-spacing: .04em; color: var(--ck-tekst-licht); margin: 0 0 10px; }
.ck-radio, .ck-check { display: flex; align-items: center; gap: 9px; padding: 6px 0; cursor: pointer; font-size: 14.5px; }
.ck-radio input, .ck-check input { width: 17px; height: 17px; accent-color: var(--ck-groen); cursor: pointer; }
.ck-range-label { display: block; font-size: 13px; color: var(--ck-tekst-licht); margin-top: 12px; }
.ck-range-label strong { color: var(--ck-groen); }
.ck-range { width: 100%; accent-color: var(--ck-groen); margin-top: 6px; }
.ck-select {
    width: 100%; padding: 9px 11px; border: 1px solid var(--ck-rand);
    border-radius: var(--ck-radius-sm); font-size: 14px; background: #fff; color: var(--ck-tekst);
}
.ck-select-sm { width: auto; padding: 7px 10px; font-size: 13px; }

/* Resultaten */
.ck-results { width: 380px; flex: none; display: flex; flex-direction: column; min-height: 0; border-right: 1px solid var(--ck-rand); }
.ck-results-head { padding: 12px 16px; border-bottom: 1px solid var(--ck-grijs-2); display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--ck-tekst-licht); }
.ck-list { overflow-y: auto; padding: 12px; flex: 1; }

.ck-place-card {
    display: block; background: #fff; border: 1px solid var(--ck-rand);
    border-radius: var(--ck-radius-sm); padding: 14px; margin-bottom: 11px; cursor: pointer;
    transition: box-shadow .15s, border-color .15s, transform .1s; text-decoration: none; color: inherit;
}
.ck-place-card:hover, .ck-place-card.is-active { border-color: var(--ck-groen); box-shadow: var(--ck-shadow-h); }
.ck-place-card.is-active { transform: translateY(-1px); }
.ck-pc-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.ck-pc-naam { font-size: 15.5px; font-weight: 700; margin: 0 0 2px; line-height: 1.25; }
.ck-pc-plaats { font-size: 13px; color: var(--ck-tekst-licht); margin: 0; }
.ck-pc-rating { flex: none; background: var(--ck-grijs); color: var(--ck-donker); font-size: 12.5px; font-weight: 700; padding: 4px 8px; border-radius: 4px; white-space: nowrap; }
.ck-pc-meta { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; align-items: center; }
.ck-pc-prijs { font-weight: 700; color: var(--ck-groen); font-size: 14px; }
.ck-pc-prijs.is-gratis { color: var(--ck-groen); }
.ck-chip { background: var(--ck-grijs); color: var(--ck-tekst-licht); font-size: 11.5px; padding: 3px 8px; border-radius: 4px; }
.ck-pc-vz { display: flex; gap: 5px; flex-wrap: wrap; margin-top: 9px; }
.ck-vz-pill { font-size: 11px; background: rgba(31,89,101,.12); color: var(--ck-groen-d); padding: 2px 7px; border-radius: 4px; font-weight: 600; }

.ck-empty { text-align: center; padding: 40px 20px; color: var(--ck-tekst-licht); }
.ck-empty strong { display: block; font-size: 16px; color: var(--ck-tekst); margin-bottom: 4px; }

/* Kaart */
.ck-map-wrap { flex: 1; min-width: 0; position: relative; }
.ck-map { position: absolute; inset: 0; }

/* Marker popup */
.ck-popup { font-family: inherit; min-width: 180px; }
.ck-popup h4 { margin: 0 0 4px; font-size: 14.5px; }
.ck-popup p { margin: 0 0 8px; font-size: 12.5px; color: var(--ck-tekst-licht); }
.ck-popup .ck-popup-btn { display: inline-block; background: var(--ck-groen); color: #fff; padding: 6px 12px; border-radius: 4px; font-size: 13px; font-weight: 600; text-decoration: none; }

.leaflet-marker-icon.ck-pin { background: transparent; border: 0; }
.ck-pin-inner { width: 30px; height: 30px; border-radius: 50% 50% 50% 0; background: var(--ck-groen); transform: rotate(-45deg); border: 2px solid #fff; box-shadow: 0 2px 6px rgba(0,0,0,.3); }
.ck-pin-inner.is-gratis { background: var(--ck-donker); }

/* View-modes */
.ck-layout[data-view="map"] .ck-results { display: none; }
.ck-layout[data-view="list"] .ck-map-wrap { display: none; }
.ck-layout[data-view="list"] .ck-results { width: 100%; flex: 1; border-right: 0; }

.ck-mobile-switch { display: none; }

/* ---------- Detailpagina ---------- */
.ck-detail { max-width: 1080px; margin: 0 auto; }
.ck-breadcrumb { display: flex; gap: 8px; align-items: center; font-size: 13px; color: var(--ck-tekst-licht); margin-bottom: 16px; flex-wrap: wrap; }
.ck-breadcrumb a { color: var(--ck-groen); text-decoration: none; }
.ck-detail-header { margin-bottom: 20px; }
.ck-detail-title h1 { font-size: 28px; margin: 0 0 4px; line-height: 1.2; }
.ck-detail-loc { color: var(--ck-tekst-licht); margin: 0 0 12px; font-size: 15px; }
.ck-detail-labels { display: flex; gap: 8px; flex-wrap: wrap; }
.ck-badge { background: var(--ck-grijs); color: var(--ck-donker); padding: 6px 12px; border-radius: 999px; font-size: 13px; font-weight: 600; }
.ck-badge-rating { background: var(--ck-donker); color: #fff; }
.ck-badge-rating small { font-weight: 400; opacity: .8; }
.ck-badge-prijs { background: var(--ck-groen); color: #fff; }

.ck-detail-grid { display: grid; grid-template-columns: 1fr 320px; gap: 24px; align-items: start; }
.ck-detail-main { min-width: 0; display: flex; flex-direction: column; gap: 18px; }
.ck-detail-map { height: 280px; border-radius: var(--ck-radius); overflow: hidden; border: 1px solid var(--ck-rand); }
.ck-card { background: #fff; border: 1px solid var(--ck-rand); border-radius: var(--ck-radius); padding: 22px; }
.ck-card h2 { font-size: 19px; margin: 0 0 16px; }
.ck-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 24px; margin: 0; }
.ck-info-grid dt { font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--ck-tekst-licht); margin-bottom: 2px; }
.ck-info-grid dd { margin: 0; font-size: 15px; font-weight: 600; }
.ck-voorzieningen { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px; }
.ck-voorzieningen li { display: flex; align-items: center; gap: 9px; font-size: 14.5px; }
.ck-vz-icon { width: 22px; height: 22px; flex: none; background: rgba(31,89,101,.14); color: var(--ck-groen-d); border-radius: 50%; display: grid; place-items: center; }
.ck-vz-icon svg { width: 13px; height: 13px; }
.ck-seo-tekst { font-size: 15.5px; line-height: 1.7; color: var(--ck-tekst); margin: 0; }

/* Affiliate */
.ck-affiliate { background: linear-gradient(135deg, #fff, var(--ck-grijs)); border: 1px solid var(--ck-rand); border-left: 4px solid var(--ck-groen); border-radius: var(--ck-radius); padding: 20px 22px; position: relative; }
.ck-aff-tag { position: absolute; top: 12px; right: 14px; font-size: 10px; text-transform: uppercase; letter-spacing: .06em; color: var(--ck-tekst-licht); }
.ck-affiliate h3 { margin: 0 0 8px; font-size: 17px; }
.ck-affiliate p { margin: 0 0 16px; font-size: 14.5px; color: var(--ck-tekst-licht); line-height: 1.55; }
.ck-aff-cta { display: inline-block; background: var(--ck-groen); color: #fff; padding: 11px 20px; border-radius: var(--ck-radius-sm); font-weight: 700; text-decoration: none; font-size: 14.5px; transition: background .15s; }
.ck-aff-cta:hover { background: var(--ck-groen-d); }
.ck-affiliate-sm { padding: 16px 18px; }
.ck-affiliate-sm h3 { font-size: 15px; }
.ck-affiliate-sm p { font-size: 13px; margin-bottom: 12px; }
.ck-affiliate-sm .ck-aff-cta { padding: 9px 16px; font-size: 13.5px; }

/* Detail zijbalk */
.ck-detail-side { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 20px; }
.ck-side-cta { text-align: center; }
.ck-side-prijs { font-size: 22px; font-weight: 800; color: var(--ck-groen); margin: 0 0 14px; }
.ck-route-btn { display: block; background: var(--ck-donker); color: #fff; padding: 13px; border-radius: var(--ck-radius-sm); font-weight: 700; text-decoration: none; transition: background .15s; }
.ck-route-btn:hover { background: var(--ck-donker-2); }
.ck-side-omgeving { display: flex; gap: 6px; flex-wrap: wrap; justify-content: center; margin: 14px 0 0; }
.ck-tag { background: var(--ck-grijs); color: var(--ck-tekst-licht); font-size: 12px; padding: 4px 10px; border-radius: 999px; }

/* Vergelijkbaar */
.ck-nearby { margin-top: 30px; }
.ck-nearby h2 { font-size: 21px; margin: 0 0 16px; }
.ck-nearby-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.ck-nearby-card { background: #fff; border: 1px solid var(--ck-rand); border-radius: var(--ck-radius); padding: 18px; text-decoration: none; color: inherit; position: relative; transition: box-shadow .15s, border-color .15s; }
.ck-nearby-card:hover { border-color: var(--ck-groen); box-shadow: var(--ck-shadow-h); }
.ck-nearby-rating { position: absolute; top: 14px; right: 14px; font-size: 12.5px; font-weight: 700; background: var(--ck-grijs); padding: 3px 8px; border-radius: 4px; }
.ck-nearby-card h3 { font-size: 16px; margin: 0 24px 4px 0; }
.ck-nearby-card p { font-size: 13px; color: var(--ck-tekst-licht); margin: 0 0 10px; }
.ck-nearby-prijs { font-weight: 700; color: var(--ck-groen); font-size: 14px; }
.ck-detail-empty { padding: 40px; text-align: center; color: var(--ck-tekst-licht); }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
    .ck-filters { position: absolute; left: 0; top: 0; bottom: 0; z-index: 1200; transform: translateX(-100%); transition: transform .25s; box-shadow: 4px 0 24px rgba(0,0,0,.15); }
    .ck-filters.is-open { transform: translateX(0); }
    .ck-filter-toggle { display: inline-flex; }
    .ck-results { width: 320px; }
    .ck-detail-grid { grid-template-columns: 1fr; }
    .ck-detail-side { position: static; }
}
@media (max-width: 720px) {
    .ck-app { height: 86vh; }
    .ck-view-switch { display: none; }
    .ck-results { position: absolute; inset: 0; width: 100%; border-right: 0; z-index: 600; background: #fff; }
    .ck-map-wrap { position: absolute; inset: 0; }
    .ck-layout.show-map .ck-results { display: none; }
    .ck-layout.show-list .ck-map-wrap { display: none; }
    .ck-mobile-switch {
        display: block; position: absolute; bottom: 18px; left: 50%; transform: translateX(-50%);
        z-index: 700; background: var(--ck-donker); color: #fff; border: 0; padding: 12px 22px;
        border-radius: 999px; font-size: 14px; font-weight: 700; cursor: pointer; box-shadow: 0 4px 16px rgba(0,0,0,.25);
    }
    .ck-ms-map { display: none; }
    .ck-layout.show-list .ck-ms-map { display: inline; }
    .ck-layout.show-list .ck-ms-list { display: none; }
    .ck-info-grid { grid-template-columns: 1fr; }
    .ck-detail-title h1 { font-size: 23px; }
}
