.zp-kaart-wrapper {
width: 100%;
max-width: 1180px;
margin: 1.5rem auto;
box-sizing: border-box;
}
.zp-kaart-wrapper * {
box-sizing: border-box;
} .zp-kaart-toolbar {
display: flex;
gap: 12px;
align-items: flex-start;
flex-wrap: wrap;
margin-bottom: 12px;
}
.zp-zoekblok {
flex: 1 1 320px;
min-width: 240px;
}
.zp-search {
width: 100%;
max-width: 520px;
padding: 10px 13px;
border: 1px solid #cfcfcf;
border-radius: 9px;
font-size: 15px;
background: #fff;
}
.zp-search:focus {
outline: 2px solid #2f7d4f;
outline-offset: 2px;
} .zp-filter-wrapper {
position: relative;
flex: 0 0 auto;
}
#zp-filter-toggle {
background: #fff;
border: 1px solid #ccc;
border-radius: 9px;
padding: 10px 14px;
cursor: pointer;
font-weight: 700;
}
.zp-filters-panel {
display: none;
position: absolute;
z-index: 9999;
top: 46px;
right: 0;
width: 300px;
padding: 16px;
background: #fff;
border: 1px solid #ddd;
border-radius: 14px;
box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}
.zp-filters-panel.open {
display: block;
}
.zp-filter-group {
margin-bottom: 16px;
}
.zp-filter-group:last-child {
margin-bottom: 0;
}
.zp-filter-group strong {
display: block;
margin-bottom: 8px;
}
.zp-filter-group label {
display: block;
margin-bottom: 6px;
font-size: 14px;
}
.zp-clear-filters {
display: block;
margin-bottom: 10px;
padding: 7px 10px;
background: #f5f5f5;
border: 1px solid #ccc;
border-radius: 7px;
cursor: pointer;
font-size: 13px;
}
.zp-clear-filters:hover {
background: #eaeaea;
} .zp-kaart-layout {
display: flex;
flex-direction: column;
gap: 16px;
align-items: stretch;
width: 100%;
}
.zp-map,
#zp-map {
width: 100% !important;
max-width: none !important;
min-height: 560px;
border-radius: 16px;
overflow: hidden;
border: 1px solid #ddd;
} .zp-info {
width: 100%;
max-width: 100%;
padding: 18px 20px;
background: #fff;
border: 1px solid #ddd;
border-radius: 16px;
box-shadow: 0 4px 18px rgba(0,0,0,0.06);
font-size: 17px;
line-height: 1.65;
}
.zp-info h3 {
margin: 0 0 10px;
font-size: 26px;
line-height: 1.25;
}
.zp-info p {
margin-top: 0;
}
.zp-info-description {
max-width: 860px;
margin-bottom: 16px;
font-size: 17px;
line-height: 1.65;
} .zp-info-iconen {
display: flex;
flex-wrap: wrap;
gap: 10px;
margin-top: 16px;
}
.zp-info-iconen > span {
display: inline-flex;
align-items: center;
gap: 8px;
padding: 11px 14px;
border-radius: 14px;
background: #eef7f0;
border: 1px solid #d7eadb;
font-size: 16px;
font-weight: 700;
}
.zp-info-iconen .zp-icon-symbol {
font-size: 25px;
line-height: 1;
} .zp-tags {
display: flex;
flex-wrap: wrap;
gap: 8px;
margin: 14px 0 0;
}
.zp-tag {
display: inline-flex;
align-items: center;
padding: 6px 11px;
border-radius: 999px;
background: #eef2f3;
color: #444;
font-size: 14px;
line-height: 1.2;
} .zp-info-actions {
margin: 16px 0 4px;
}
.zp-info-button,
.zp-popup-actions a {
display: inline-block;
padding: 11px 16px;
border-radius: 10px;
background: #2f7d4f;
color: #fff !important;
text-decoration: none !important;
font-size: 16px;
font-weight: 700;
line-height: 1.2;
}
.zp-info-button:hover,
.zp-info-button:focus,
.zp-popup-actions a:hover,
.zp-popup-actions a:focus {
background: #245f3d;
color: #fff !important;
} .zp-popup {
font-size: 14px;
}
.zp-popup-title {
display: block;
margin-bottom: 6px;
font-size: 18px;
font-weight: 800;
}
.zp-popup-description {
margin: 0 0 8px;
font-size: 14px;
line-height: 1.4;
}
.zp-popup-iconen {
display: flex;
flex-wrap: wrap;
gap: 6px;
margin: 7px 0 10px;
}
.zp-popup-iconen > span {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 30px;
min-height: 30px;
border: 1px solid #dbe7db;
border-radius: 999px;
background: #eef7f0;
font-size: 15px;
}
.zp-popup-iconen .zp-icon-label {
position: absolute;
width: 1px;
height: 1px;
overflow: hidden;
clip: rect(0 0 0 0);
}
.zp-popup-actions {
display: flex;
flex-wrap: wrap;
gap: 7px;
margin-top: 8px;
}
.zp-popup-actions a {
padding: 9px 12px;
border-radius: 8px;
font-size: 14px;
} .zp-info-section {
margin-top: 16px;
}
.zp-info-chips {
display: flex;
flex-wrap: wrap;
gap: 8px;
margin-top: 8px;
}
.zp-info-chip {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 7px 10px;
border-radius: 999px;
background: #f2f5f2;
border: 1px solid #e1e8e1;
font-size: 14px;
} @media (max-width: 900px) {
.zp-kaart-wrapper {
max-width: 100%;
}
.zp-map,
#zp-map {
min-height: 480px;
}
}
@media (max-width: 520px) {
.zp-kaart-wrapper {
margin: 1rem 0;
}
.zp-kaart-toolbar {
gap: 8px;
}
.zp-zoekblok,
.zp-filter-wrapper,
#zp-filter-toggle {
width: 100%;
}
.zp-search {
max-width: none;
}
.zp-filters-panel {
left: 0;
right: auto;
width: min(300px, 92vw);
}
.zp-map,
#zp-map {
min-height: 420px;
border-radius: 14px;
}
.zp-info {
padding: 16px;
}
.zp-info h3 {
font-size: 23px;
}
.zp-info-description {
font-size: 16px;
}
.zp-info-iconen > span {
font-size: 15px;
}
}
@media (max-width: 520px) {
.zp-popup-actions {
display: block;
margin-top: 8px;
}
.zp-popup-actions a {
display: inline;
padding: 0;
margin-right: 10px;
background: none;
border-radius: 0;
color: #2f7d4f !important;
text-decoration: underline !important;
font-size: 14px;
font-weight: 700;
line-height: 1.5;
}
.zp-popup-actions a:hover,
.zp-popup-actions a:focus {
background: none;
color: #245f3d !important;
text-decoration: underline !important;
}
} .zp-info-iconen .zp-icon-chip,
.zp-popup-iconen .zp-icon-chip {
display: inline-flex;
align-items: center;
justify-content: center;
}
.zp-info-iconen .zp-icon-chip {
gap: 8px;
}
.zp-popup-iconen .zp-icon-chip {
width: 34px;
height: 34px;
min-width: 34px;
min-height: 34px;
padding: 0;
border-radius: 10px;
overflow: hidden;
background: #fff;
}
.zp-icon-symbol {
display: inline-flex;
align-items: center;
justify-content: center;
line-height: 1;
}
.zp-icon-img {
display: block;
width: 32px;
height: 32px;
object-fit: contain;
}
.zp-info-iconen .zp-icon-img {
width: 34px;
height: 34px;
}
.zp-popup-iconen .zp-icon-img {
width: 34px;
height: 34px;
}
.zp-icon-emoji {
display: inline-flex;
align-items: center;
justify-content: center;
width: 30px;
height: 30px;
font-size: 19px;
}
.zp-popup-iconen .zp-icon-label {
position: absolute;
width: 1px;
height: 1px;
overflow: hidden;
clip: rect(0 0 0 0);
white-space: nowrap;
} .zp-lijnen {
display: flex;
flex-wrap: wrap;
gap: 6px;
margin: 8px 0 10px;
}
.zp-lijn-chip {
display: inline-flex;
align-items: center;
padding: 5px 9px;
border-radius: 999px;
background: #eef2f7;
border: 1px solid #d9e2ef;
color: #24384f;
font-size: 13px;
font-weight: 800;
line-height: 1.2;
}
.zp-ov-actions {
display: flex;
flex-wrap: wrap;
gap: 8px;
margin-top: 10px;
}
.zp-ov-button {
display: inline-flex;
align-items: center;
justify-content: center;
padding: 9px 12px;
border-radius: 9px;
background: #2f6f9f;
color: #fff !important;
text-decoration: none !important;
font-size: 14px;
font-weight: 800;
line-height: 1.2;
}
.zp-ov-button:hover,
.zp-ov-button:focus {
background: #245579;
color: #fff !important;
text-decoration: none !important;
}
.zp-ov-actions-info .zp-ov-button {
font-size: 16px;
padding: 11px 15px;
}
@media (max-width: 520px) {
.zp-ov-actions-popup {
display: block;
}
.zp-ov-actions-popup .zp-ov-button {
display: block;
width: 100%;
margin: 7px 0 0;
text-align: center;
}
} .zp-kaart-intro {
display: flex;
flex-direction: column;
gap: 3px;
margin: 0 0 12px;
padding: 13px 16px;
border: 1px solid #d8e5d8;
border-radius: 14px;
background: #f4faf5;
color: #1f3f2c;
line-height: 1.35;
}
.zp-kaart-intro strong {
font-size: 18px;
font-weight: 800;
}
.zp-kaart-intro span {
font-size: 15px;
}
.zp-kaart-toolbar {
align-items: stretch;
}
.zp-zoekblok {
flex: 1 1 420px;
}
.zp-search {
min-height: 48px;
max-width: none;
border-color: #b8cdbd;
color: #17351f;
}
.zp-search::placeholder {
color: #66756a;
opacity: 1;
}
.zp-filter-wrapper {
position: relative;
flex: 0 0 280px;
}
#zp-filter-toggle,
.zp-filter-toggle {
display: grid;
grid-template-columns: 1fr auto;
grid-template-areas:
"title icon"
"subtitle icon";
align-items: center;
width: 100%;
min-height: 48px;
padding: 9px 13px;
border: 1px solid #2f7d4f;
border-radius: 12px;
background: #2f7d4f;
color: #fff !important;
text-align: left;
cursor: pointer;
box-shadow: 0 3px 12px rgba(47, 125, 79, 0.18);
}
.zp-filter-toggle-title {
grid-area: title;
display: block;
font-size: 15px;
font-weight: 800;
line-height: 1.15;
}
.zp-filter-toggle-subtitle {
grid-area: subtitle;
display: block;
margin-top: 2px;
font-size: 12px;
font-weight: 600;
line-height: 1.2;
opacity: 0.92;
}
.zp-filter-toggle-icon {
grid-area: icon;
display: inline-flex;
align-items: center;
justify-content: center;
width: 28px;
height: 28px;
font-size: 19px;
transition: transform 0.18s ease;
}
#zp-filter-toggle[aria-expanded="true"] .zp-filter-toggle-icon {
transform: rotate(180deg);
}
.zp-filters-panel[hidden] {
display: none !important;
}
.zp-filters-panel.open {
display: block;
}
.zp-filter-panel-head {
display: flex;
align-items: center;
justify-content: space-between;
gap: 10px;
margin-bottom: 14px;
padding-bottom: 10px;
border-bottom: 1px solid #e1e8e1;
}
.zp-filter-panel-head strong {
font-size: 18px;
}
.zp-filter-group {
padding: 12px 0;
border-bottom: 1px solid #edf1ed;
}
.zp-filter-group:last-child {
border-bottom: 0;
padding-bottom: 0;
}
.zp-filter-group strong {
margin-bottom: 10px;
color: #1f3f2c;
font-size: 15px;
font-weight: 800;
}
.zp-filter-group label {
display: flex !important;
align-items: center;
gap: 10px;
width: 100%;
margin: 0 0 9px !important;
color: #26382b;
font-size: 15px;
line-height: 1.3;
cursor: pointer;
}
.zp-filter-group input[type="checkbox"] {
position: static !important;
display: inline-block !important;
width: 20px !important;
height: 20px !important;
min-width: 20px !important;
margin: 0 !important;
padding: 0 !important;
opacity: 1 !important;
visibility: visible !important;
appearance: auto !important;
-webkit-appearance: checkbox !important;
accent-color: #2f7d4f;
}
.zp-clear-filters {
margin: 0;
white-space: nowrap;
border-color: #cbd8cb;
background: #f7faf7;
color: #25442f;
font-weight: 700;
}
.zp-active-filters {
flex: 1 1 100%;
display: none;
align-items: center;
flex-wrap: wrap;
gap: 7px;
min-height: 0;
margin-top: 2px;
}
.zp-active-filters.is-visible {
display: flex;
}
.zp-active-filter-summary {
font-size: 14px;
font-weight: 800;
color: #1f3f2c;
}
.zp-active-filter-chip {
display: inline-flex;
align-items: center;
padding: 5px 9px;
border: 1px solid #d7eadb;
border-radius: 999px;
background: #eef7f0;
color: #25442f;
font-size: 13px;
font-weight: 700;
line-height: 1.2;
}
.zp-kaart-layout {
scroll-margin-top: 90px;
}
.leaflet-container {
touch-action: pan-x pan-y;
}
@media (max-width: 700px) {
.zp-kaart-wrapper {
margin: 0.8rem 0;
}
.zp-kaart-intro {
margin-bottom: 10px;
padding: 12px 13px;
border-radius: 12px;
}
.zp-kaart-intro strong {
font-size: 17px;
}
.zp-kaart-intro span {
font-size: 14px;
}
.zp-kaart-toolbar {
gap: 9px;
}
.zp-zoekblok,
.zp-filter-wrapper,
#zp-filter-toggle {
flex: 1 1 100%;
width: 100%;
}
.zp-search {
width: 100%;
min-height: 48px;
font-size: 16px;
}
.zp-filter-wrapper {
position: static;
}
.zp-filters-panel {
position: static;
width: 100%;
max-height: 58vh;
overflow: auto;
margin-top: 8px;
padding: 14px;
border-radius: 14px;
box-shadow: none;
}
.zp-filter-panel-head {
position: sticky;
top: 0;
z-index: 2;
margin: -14px -14px 12px;
padding: 12px 14px;
background: #fff;
}
.zp-filter-group {
padding: 10px 0;
}
.zp-filter-group label {
min-height: 34px;
padding: 3px 0;
}
.zp-map,
#zp-map {
min-height: 360px;
height: 58vh !important;
border-radius: 14px;
}
.leaflet-popup-content {
width: min(260px, 76vw) !important;
margin: 12px 14px;
}
.zp-popup-title {
font-size: 16px;
}
.zp-popup-description {
font-size: 13px;
}
}
@media (max-width: 380px) {
.zp-map,
#zp-map {
min-height: 330px;
height: 55vh !important;
}
.zp-filter-toggle-subtitle {
font-size: 11px;
}
} @media (min-width: 901px) {
.zp-kaart-wrapper {
max-width: 1240px;
}
.zp-kaart-intro {
display: block;
margin-bottom: 14px;
padding: 14px 18px;
}
.zp-kaart-intro strong {
display: block;
margin-bottom: 3px;
font-size: 20px;
line-height: 1.25;
}
.zp-kaart-intro span {
display: block;
font-size: 15px;
line-height: 1.35;
}
.zp-kaart-toolbar {
display: grid;
grid-template-columns: minmax(360px, 1fr) 280px;
gap: 14px;
align-items: stretch;
margin-bottom: 14px;
}
.zp-zoekblok {
min-width: 0;
width: 100%;
}
.zp-search {
width: 100%;
max-width: none;
min-height: 68px;
height: 68px;
padding: 14px 16px;
border-radius: 12px;
font-size: 16px;
}
.zp-filter-wrapper {
width: 280px;
min-width: 280px;
flex: none;
}
#zp-filter-toggle,
.zp-filter-toggle {
min-height: 68px;
height: 68px;
padding: 12px 14px;
border-radius: 12px;
}
.zp-filter-toggle-title {
font-size: 16px;
line-height: 1.2;
text-transform: none;
}
.zp-filter-toggle-subtitle {
font-size: 13px;
line-height: 1.2;
text-transform: none;
}
.zp-filters-panel {
top: calc(100% + 9px);
right: 0;
width: 680px;
max-width: min(680px, calc(100vw - 44px));
padding: 18px;
}
.zp-filters-panel.open {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
column-gap: 20px;
row-gap: 8px;
}
.zp-filter-panel-head {
grid-column: 1 / -1;
margin-bottom: 2px;
}
.zp-filter-group {
min-width: 0;
margin-bottom: 0;
padding: 4px 0 0;
border-bottom: 0;
}
.zp-filter-group strong {
min-height: 38px;
margin-bottom: 8px;
font-size: 15px;
}
.zp-filter-group label {
margin-bottom: 8px !important;
font-size: 14px;
}
.zp-active-filters {
grid-column: 1 / -1;
margin-top: -2px;
padding: 2px 0 0;
}
.zp-map,
#zp-map {
min-height: 620px;
}
}
@media (min-width: 901px) and (max-width: 1100px) {
.zp-kaart-toolbar {
grid-template-columns: minmax(320px, 1fr) 260px;
}
.zp-filter-wrapper {
width: 260px;
min-width: 260px;
}
.zp-filters-panel {
width: 620px;
}
} #zp-filter-toggle,
.zp-filter-toggle {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 10px;
width: auto;
min-height: 48px;
padding: 10px 14px;
border: 1px solid #d6ded8;
border-radius: 12px;
background: #fff;
color: #1f2f24 !important;
text-align: left;
box-shadow: none;
}
#zp-filter-toggle:hover,
#zp-filter-toggle:focus,
.zp-filter-toggle:hover,
.zp-filter-toggle:focus {
border-color: #2f7d4f;
background: #f4faf5;
color: #1f3f2c !important;
}
.zp-filter-toggle-icon {
flex: 0 0 auto;
width: 22px;
height: 22px;
font-size: 0;
transform: none !important;
}
.zp-filter-toggle-svg {
display: block;
width: 22px;
height: 22px;
}
.zp-filter-toggle-svg path {
fill: none;
stroke: currentColor;
stroke-width: 2;
stroke-linecap: round;
stroke-linejoin: round;
}
.zp-filter-toggle-title {
display: inline-flex;
align-items: center;
font-size: 15px;
font-weight: 800;
line-height: 1.15;
text-transform: uppercase;
letter-spacing: 0.01em;
}
.zp-filter-toggle-subtitle {
display: none !important;
}
.zp-filter-toggle-chevron {
flex: 0 0 auto;
display: inline-flex;
align-items: center;
justify-content: center;
width: 18px;
height: 18px;
font-size: 15px;
line-height: 1;
transition: transform 0.18s ease;
}
#zp-filter-toggle[aria-expanded="true"] .zp-filter-toggle-chevron {
transform: rotate(180deg);
}
#zp-filter-toggle[aria-expanded="true"] .zp-filter-toggle-icon {
transform: none !important;
}
@media (min-width: 901px) {
.zp-kaart-toolbar {
grid-template-columns: minmax(360px, 1fr) auto;
}
.zp-filter-wrapper {
width: auto;
min-width: 0;
}
#zp-filter-toggle,
.zp-filter-toggle {
min-height: 54px;
height: 54px;
padding: 11px 16px;
white-space: nowrap;
}
.zp-filter-toggle-title {
font-size: 14px;
}
}
@media (max-width: 700px) {
#zp-filter-toggle,
.zp-filter-toggle {
width: 100%;
justify-content: flex-start;
min-height: 48px;
}
.zp-filter-toggle-title {
font-size: 14px;
}
.zp-filter-toggle-chevron {
margin-left: auto;
}
}