/* DOCW Adoptiedieren v7 */
:root {
  --groen: #3a7d44;
  --groen-dark: #2c5f35;
  --groen-light: #eaf5ec;
  --groen-mid: #5fa46a;
  --oranje: #ff6900;
  --oranje-dark: #d95700;
  --oranje-light: #fff3eb;
  --warm: #f8f4ef;
  --warm-d: #e8ddd0;
  --text: #1e2a1e;
  --muted: #6b7c6b;
  --border: #dde8dd;
  --white: #ffffff;
  --wa: #25d366;
  --radius: 14px;
  --radius-sm: 10px;
  --sidebar-w: 240px;
}

/* ── LAYOUT ── */
.docw-layout {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  gap: 32px;
  align-items: start;
  color: var(--text);
}

/* ── SIDEBAR (desktop only) ── */
.docw-sidebar { position: sticky; top: 24px; }

.docw-sidebar-inner {
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}

.docw-sidebar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 16px 12px;
  background: var(--groen);
  color: #fff;
}

.docw-sidebar-title {
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.docw-sidebar-wis {
  font-size: 12px;
  color: rgba(255,255,255,.85) !important;
  text-decoration: none;
  font-weight: 600;
  border: 1px solid rgba(255,255,255,.4);
  padding: 3px 10px;
  border-radius: 20px;
  transition: background .15s;
}
.docw-sidebar-wis:hover { background: rgba(255,255,255,.18); }

.docw-filter-group {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
}
.docw-filter-group:last-child { border-bottom: none; }

.docw-filter-label {
  display: block;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--muted);
  margin-bottom: 8px;
}

.docw-search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--warm);
  border: 1.5px solid var(--warm-d);
  border-radius: 8px;
  padding: 0 10px;
  transition: border-color .2s;
}
.docw-search-wrap:focus-within { border-color: var(--groen); }
.docw-search-ic { color: var(--muted); flex-shrink: 0; }
.docw-search-wrap input {
  border: none !important;
  outline: none !important;
  background: transparent !important;
  font-size: 14px !important;
  padding: 9px 0 !important;
  width: 100% !important;
  color: var(--text) !important;
  font-family: inherit !important;
  box-shadow: none !important;
  -webkit-appearance: none;
  appearance: none;
}
.docw-search-wrap input::placeholder { color: var(--muted); }
.docw-search-clear {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--muted);
  font-size: 18px;
  padding: 0;
  line-height: 1;
  flex-shrink: 0;
}
.docw-search-clear:hover { color: var(--text); }

.docw-radio-list { display: flex; flex-direction: column; gap: 4px; }

.docw-radio {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  padding: 6px 10px;
  border-radius: 8px;
  cursor: pointer;
  transition: background .12s;
}
.docw-radio:hover { background: var(--warm); }
.docw-radio--on { background: var(--groen-light); color: var(--groen-dark); font-weight: 700; }
.docw-radio input[type="radio"] {
  accent-color: var(--groen);
  width: 15px; height: 15px;
  flex-shrink: 0;
  cursor: pointer;
}

/* Mobile filter button — verborgen op desktop */
.docw-mob-filter-btn { display: none; }
/* Mobile filter panel — verborgen op desktop */
.docw-mob-filter-panel { display: none; }

/* ── MAIN AREA ── */
.docw-main { min-width: 0; }

/* ── TOOLBAR ── */
.docw-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  flex-wrap: wrap;
  gap: 10px;
}
.docw-count { font-size: 15px; color: var(--muted); font-weight: 600; }
.docw-sort-select {
  padding: 8px 26px 8px 12px;
  border: 1.5px solid var(--border);
  border-radius: 50px;
  font-size: 13px;
  font-weight: 600;
  background: var(--white);
  color: var(--text);
  cursor: pointer;
  font-family: inherit;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b7c6b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
}
.docw-sort-select:focus { outline: none; border-color: var(--groen); }
.docw-section-label { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .07em; color: var(--muted); margin: 24px 0 12px; }

/* ── BUTTONS ── */
.docw-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 11px 22px;
  border-radius: 50px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  transition: all .18s;
  border: none;
  white-space: nowrap;
  font-family: inherit;
  letter-spacing: .01em;
}
.docw-btn-primary { background: var(--oranje); color: #fff !important; }
.docw-btn-primary:hover { background: var(--oranje-dark); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(255,105,0,.3); }
.docw-btn-outline { background: transparent; color: var(--groen) !important; border: 2px solid var(--groen); }
.docw-btn-outline:hover { background: var(--groen-light); }
.docw-btn-wa { background: var(--wa); color: #fff !important; }
.docw-btn-wa:hover { background: #1ebe5d; transform: translateY(-1px); }
.docw-btn-tel { background: var(--warm); color: var(--text) !important; border: 1.5px solid var(--warm-d); }
.docw-btn-tel:hover { background: var(--warm-d); }
.docw-btn-email { background: var(--warm); color: var(--text) !important; border: 1.5px solid var(--warm-d); }
.docw-btn-email:hover { background: var(--warm-d); }
.docw-btn-block { display: flex; width: 100%; box-sizing: border-box; }

/* ── GRID ── */
.docw-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; margin-bottom: 32px; }

/* ── CARD ── */
.docw-card {
  background: var(--white);
  border-radius: var(--radius);
  border: 1.5px solid var(--border);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .22s, box-shadow .22s;
  position: relative;
  text-decoration: none;
  color: inherit;
}
.docw-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(58,125,68,.14); }
.docw-card--featured { border: 2px solid var(--oranje); }
.docw-ribbon { position: absolute; top: 12px; left: -2px; background: var(--oranje); color: #fff; font-size: 11px; font-weight: 800; padding: 4px 12px 4px 10px; border-radius: 0 6px 6px 0; z-index: 2; letter-spacing: .03em; }
.docw-card-photo { position: relative; aspect-ratio: 4/3; overflow: hidden; background: var(--warm); display: block; }
.docw-card-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .38s; display: block; }
.docw-card:hover .docw-card-photo img { transform: scale(1.05); }
.docw-days-badge { position: absolute; bottom: 10px; left: 10px; background: rgba(20,30,20,.72); color: #fff; font-size: 11px; font-weight: 600; padding: 4px 10px; border-radius: 20px; }
.docw-card-body { padding: 14px 16px 16px; display: flex; flex-direction: column; flex: 1; gap: 0; }
.docw-card-name { margin: 0 0 8px; font-size: 18px; font-weight: 800; line-height: 1.2; color: var(--text); }
.docw-card-name a { text-decoration: none; color: var(--text); transition: color .15s; }
.docw-card-name a:hover { color: var(--groen); }
.docw-card-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 5px; font-size: 13px; color: var(--muted); font-weight: 500; margin: 0 0 8px; line-height: 1.4; }
.docw-meta-gender { font-weight: 700; }
.docw-meta-man { color: #2563eb; }
.docw-meta-vrouw { color: #db2777; }
.docw-meta-dot { color: var(--muted); opacity: .4; }
.docw-meta-loc { display: inline-flex; align-items: center; gap: 3px; color: var(--muted); }
.docw-meta-loc svg { flex-shrink: 0; opacity: .7; }

/* ── EMPTY / PAGINATION ── */
.docw-empty { text-align: center; padding: 60px 20px; color: var(--muted); }
.docw-empty-icon { font-size: 52px; display: block; margin-bottom: 14px; }
.docw-empty h3 { font-size: 20px; color: var(--text); margin-bottom: 8px; }
.docw-pagination { text-align: center; margin-top: 16px; }
.docw-pagination .page-numbers { display: inline-block; padding: 8px 14px; margin: 3px; border-radius: 8px; border: 1.5px solid var(--border); text-decoration: none; font-size: 14px; font-weight: 600; color: var(--text); transition: all .15s; }
.docw-pagination .page-numbers.current,
.docw-pagination .page-numbers:hover { background: var(--groen); color: #fff; border-color: var(--groen); }

/* ── SINGLE PAGINA ── */
.docw-single-page { max-width: 1080px; margin: 0 auto; padding: 24px 20px 70px; }
.docw-bc { font-size: 13px; color: var(--muted); margin-bottom: 20px; }
.docw-bc a { color: var(--muted); text-decoration: none; }
.docw-bc a:hover { color: var(--groen); }
.docw-bc span { margin: 0 6px; }
.docw-geplaatst-banner { background: #ecfdf5; border: 1.5px solid #6ee7b7; border-radius: var(--radius-sm); padding: 14px 20px; margin-bottom: 22px; font-size: 16px; font-weight: 700; color: #065f46; }
.docw-single-hero { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.docw-main-photo-wrap { border-radius: var(--radius); overflow: hidden; aspect-ratio: 4/3; background: var(--warm); position: relative; margin-bottom: 10px; }
.docw-main-photo { width: 100%; height: 100%; object-fit: cover; display: block; }
.docw-foto-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.42); display: flex; align-items: center; justify-content: center; }
.docw-foto-overlay span { background: rgba(255,255,255,.93); padding: 12px 28px; border-radius: 10px; font-size: 18px; font-weight: 800; }
.docw-soort-badge-lg { position: absolute; bottom: 14px; left: 14px; background: rgba(255,255,255,.93); color: var(--groen-dark); font-size: 14px; font-weight: 800; padding: 6px 14px; border-radius: 20px; }
.docw-thumbs-row { display: flex; gap: 8px; flex-wrap: wrap; }
.docw-thumb { width: 76px; height: 76px; object-fit: cover; border-radius: var(--radius-sm); border: 2.5px solid transparent; cursor: pointer; transition: border-color .2s, opacity .2s; opacity: .7; }
.docw-thumb:hover, .docw-thumb--active { border-color: var(--groen); opacity: 1; }
.docw-info-top { margin-bottom: 14px; }
.docw-dier-naam { font-size: 36px; font-weight: 900; margin: 0 0 10px; color: var(--text); line-height: 1.1; }
.docw-days-pill { background: var(--groen-light); color: var(--groen-dark); font-size: 12px; font-weight: 700; padding: 4px 14px; border-radius: 20px; display: inline-block; }
.docw-quick-pills { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 18px; }
.docw-qpill { background: var(--warm); border: 1px solid var(--warm-d); color: var(--muted); font-size: 13px; font-weight: 600; padding: 5px 13px; border-radius: 20px; }
.docw-qpill--check { background: #ecfdf5; border-color: #a7f3d0; color: #065f46; }
.docw-verhaal { font-size: 15px; line-height: 1.8; color: var(--text); margin-bottom: 20px; }

.docw-block { background: var(--warm); border: 1px solid var(--warm-d); border-radius: var(--radius-sm); padding: 16px 18px; margin-bottom: 14px; }
.docw-block--warning { background: #fffbeb; border-color: #fde68a; }
.docw-block-title { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .07em; color: var(--muted); margin: 0 0 14px; }

.docw-kenmerken-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.docw-kenmerk { display: flex; flex-direction: column; padding: 9px 4px; border-bottom: 1px solid var(--warm-d); }
.docw-kenmerk:nth-last-child(-n+2) { border-bottom: none; }
.docw-kenmerk-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); margin-bottom: 2px; }
.docw-kenmerk-val { font-size: 14px; font-weight: 700; color: var(--text); }

.docw-geschikt-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.docw-geschikt { display: flex; align-items: center; gap: 8px; padding: 8px 12px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 600; }
.docw-geschikt--ja { background: #ecfdf5; color: #065f46; }
.docw-geschikt--nee { background: #fef2f2; color: #991b1b; }
.docw-geschikt--onbekend { background: var(--warm); color: var(--muted); }
.docw-g-ic { font-weight: 900; }

.docw-adoptie-block { background: var(--oranje-light); border: 1.5px solid rgba(255,105,0,.25); border-radius: var(--radius-sm); padding: 18px 20px; margin-bottom: 16px; }
.docw-kosten-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; font-size: 14px; color: var(--muted); font-weight: 600; padding-bottom: 14px; border-bottom: 1px solid rgba(255,105,0,.18); }
.docw-kosten-big { font-size: 26px; font-weight: 900; color: var(--oranje-dark); }
.docw-contact-row { display: flex; flex-wrap: wrap; gap: 8px; }
.docw-gf-block { background: var(--warm); border: 1px solid var(--warm-d); border-radius: var(--radius-sm); padding: 20px; margin-top: 16px; }
.docw-kosten-klein { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: #2d6a4f; background: #d8f3dc; border: 1px solid #b7e4c7; border-radius: 20px; padding: 5px 12px; margin: 0 0 14px; font-weight: 600; }
.docw-kosten-klein strong { color: #1b4332; }
.docw-gf-intro { font-size: 14px; color: var(--muted); margin: 0 0 14px; }
.docw-back-row { margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--border); }

/* ════════════════════════════════════════════
   MOBIEL FILTER — uitklapknop (GEEN drawer!)
   ════════════════════════════════════════════ */
@media (max-width: 900px) {

  .docw-layout { grid-template-columns: 1fr; }

  /* Desktop sidebar volledig weg */
  .docw-sidebar { display: none !important; }

  /* — FILTERKNOP — */
  .docw-mob-filter-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    box-sizing: border-box;
    padding: 13px 16px;
    background: var(--white);
    border: 1.5px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    color: var(--text);
    font-family: inherit;
    transition: background .15s, border-color .15s, color .15s;
    margin-bottom: 0;
  }
  .docw-mob-filter-btn:hover {
    background: var(--warm);
    border-color: var(--groen);
  }
  .docw-mob-filter-btn--open {
    background: var(--groen);
    border-color: var(--groen);
    color: #fff;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
  }

  .docw-mob-btn-left {
    display: flex;
    align-items: center;
    gap: 8px;
  }

  /* Oranje stipje als er een filter actief is */
  .docw-mob-active-dot {
    width: 8px; height: 8px;
    background: var(--oranje);
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
  }

  /* Pijltje rechts */
  .docw-mob-chevron {
    width: 18px; height: 18px;
    flex-shrink: 0;
    transition: transform .22s;
    opacity: .65;
  }
  .docw-mob-filter-btn--open .docw-mob-chevron {
    transform: rotate(180deg);
    opacity: 1;
  }

  /* — UITKLAPBLOK — */
  .docw-mob-filter-panel {
    display: block;          /* altijd in DOM */
    overflow: hidden;
    max-height: 0;
    transition: max-height .32s ease;
    background: var(--white);
    border: 1.5px solid var(--groen);
    border-top: none;
    border-radius: 0 0 var(--radius-sm) var(--radius-sm);
    margin-bottom: 16px;
  }
  .docw-mob-filter-panel--open {
    max-height: 2400px;
  }

  /* Wis-link bovenin het uitklapblok */
  .docw-mob-wis-row {
    display: flex;
    justify-content: flex-end;
    padding: 12px 16px 4px;
  }
  .docw-mob-wis {
    font-size: 12px;
    color: var(--muted) !important;
    text-decoration: none;
    font-weight: 600;
    border: 1px solid var(--border);
    padding: 3px 10px;
    border-radius: 20px;
    transition: background .15s;
  }
  .docw-mob-wis:hover { background: var(--warm); }
}

@media (max-width: 820px) {
  .docw-single-hero { grid-template-columns: 1fr; gap: 24px; }
  .docw-dier-naam { font-size: 28px; }
  .docw-geschikt-grid, .docw-kenmerken-grid { grid-template-columns: 1fr; }
  .docw-kenmerk:nth-last-child(-n+2) { border-bottom: 1px solid var(--warm-d); }
  .docw-kenmerk:last-child { border-bottom: none; }
}

@media (max-width: 600px) {
  .docw-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .docw-card-name { font-size: 16px; }
  .docw-card-body { padding: 11px 13px 13px; gap: 8px; }
  /* tablet: keep 2-col grid */
  .docw-single-page { padding: 14px 14px 50px; }
  .docw-contact-row { flex-direction: column; }
  .docw-contact-row .docw-btn { justify-content: center; }
}

@media (max-width: 400px) {
  /* Mobile: horizontal list cards */
  .docw-grid { grid-template-columns: 1fr; gap: 12px; }
  .docw-card {
    flex-direction: row;
    align-items: stretch;
    min-height: 110px;
  }
  .docw-card-photo {
    width: 130px;
    min-width: 130px;
    aspect-ratio: unset;
    height: auto;
    border-radius: 0;
    flex-shrink: 0;
  }
  .docw-card-photo img { height: 100%; object-fit: cover; }
  .docw-card-body {
    padding: 12px 14px;
    justify-content: center;
    gap: 4px;
  }
  .docw-card-name { font-size: 15px; margin: 0 0 4px; }
  .docw-card-meta { font-size: 12px; }
  .docw-days-badge { font-size: 10px; padding: 3px 8px; }
  .docw-ribbon { font-size: 10px; padding: 3px 10px 3px 8px; }
}

/* ── v9: Filter submit knop ── */
.docw-filter-submit { padding: 14px 0 4px; }
.docw-btn-filter-submit {
  display: flex; align-items: center; justify-content: center; gap: 7px;
  width: 100%; padding: 11px 16px;
  background: var(--oranje); color: #fff; border: none; border-radius: var(--radius-sm);
  font-size: 14px; font-weight: 700; cursor: pointer; transition: background .15s;
}
.docw-btn-filter-submit:hover { background: var(--oranje-dark); }

/* ── v9: Buiten/binnen pill op kaartje ── */
.docw-card-buiten { margin: 0 0 10px; }
.docw-meta-buiten {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 700; border-radius: 20px;
  padding: 2px 8px; letter-spacing: .01em; vertical-align: middle;
}
.docw-meta-buiten--ja  { background: #d8f3dc; color: #1b4332; }
.docw-meta-buiten--nee { background: #e8f4fd; color: #1a3c5e; }

/* ════════════════════════════════════════════
   GRAVITY FORMS — stijl passend bij plugin
   ════════════════════════════════════════════ */

/* Verberg sub-labels (Voornaam, Achternaam etc.) */
.docw-gf-block .gform-field-label--type-sub,
.docw-gf-block .gform_wrapper .name_first label,
.docw-gf-block .gform_wrapper .name_last label,
.docw-gf-block .gform_wrapper .ginput_complex label,
.docw-gf-block .gform_wrapper span.name_prefix label,
.docw-gf-block .gform_wrapper span.name_suffix label { display: none !important; }

/* Verberg ook lege prefix/suffix velden */
.docw-gf-block .gform_wrapper .name_prefix,
.docw-gf-block .gform_wrapper .name_suffix,
.docw-gf-block .gform_wrapper .name_middle { display: none !important; }

/* Algemene form layout */
.docw-gf-block .gform_wrapper { font-family: inherit; }
.docw-gf-block .gform_wrapper .gform_fields { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 16px; }
.docw-gf-block .gform_wrapper .gfield { margin: 0 !important; padding: 0 !important; }

/* Labels */
.docw-gf-block .gform_wrapper .gfield_label,
.docw-gf-block .gform_wrapper .gform-field-label {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--muted) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  margin-bottom: 6px !important;
  display: block;
}

/* (Vereist) rode tekst */
.docw-gf-block .gform_wrapper .gfield_required { color: var(--oranje) !important; font-weight: 600 !important; }

/* Input velden */
.docw-gf-block .gform_wrapper input[type=text],
.docw-gf-block .gform_wrapper input[type=email],
.docw-gf-block .gform_wrapper input[type=tel],
.docw-gf-block .gform_wrapper input[type=number],
.docw-gf-block .gform_wrapper input[type=url],
.docw-gf-block .gform_wrapper textarea,
.docw-gf-block .gform_wrapper select {
  width: 100% !important;
  box-sizing: border-box !important;
  padding: 10px 14px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 8px !important;
  font-size: 14px !important;
  font-family: inherit !important;
  color: var(--text) !important;
  background: var(--white) !important;
  transition: border-color .15s, box-shadow .15s !important;
  outline: none !important;
  box-shadow: none !important;
}
.docw-gf-block .gform_wrapper input:focus,
.docw-gf-block .gform_wrapper textarea:focus,
.docw-gf-block .gform_wrapper select:focus {
  border-color: var(--groen) !important;
  box-shadow: 0 0 0 3px rgba(58,125,68,.12) !important;
}

/* Naam veld naast elkaar (voornaam + achternaam) */
.docw-gf-block .gform_wrapper .ginput_complex.ginput_container_name {
  display: flex !important;
  gap: 12px !important;
}
.docw-gf-block .gform_wrapper .ginput_complex.ginput_container_name span {
  flex: 1 !important;
}

/* Textarea hoogte */
.docw-gf-block .gform_wrapper textarea { min-height: 100px !important; resize: vertical !important; }

/* Progress bar */
.docw-gf-block .gf_progressbar_wrapper { margin-bottom: 20px !important; }
.docw-gf-block .gf_progressbar { background: var(--border) !important; border-radius: 20px !important; height: 6px !important; overflow: hidden; }
.docw-gf-block .gf_progressbar_percentage { background: var(--groen) !important; height: 6px !important; border-radius: 20px !important; transition: width .4s !important; }
.docw-gf-block .gf_progressbar_title { font-size: 12px !important; color: var(--muted) !important; font-weight: 600 !important; margin-bottom: 6px !important; }

/* Volgende / Verzenden knop */
.docw-gf-block .gform_wrapper .gform_footer,
.docw-gf-block .gform_wrapper .gform_page_footer { padding: 0 !important; margin-top: 8px !important; }
.docw-gf-block .gform_wrapper input[type=submit],
.docw-gf-block .gform_wrapper button[type=submit],
.docw-gf-block .gform_wrapper .gform_next_button,
.docw-gf-block .gform_wrapper .gform_previous_button {
  background: var(--oranje) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 12px 28px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  font-family: inherit !important;
  cursor: pointer !important;
  transition: background .15s, transform .15s !important;
}
.docw-gf-block .gform_wrapper input[type=submit]:hover,
.docw-gf-block .gform_wrapper button[type=submit]:hover,
.docw-gf-block .gform_wrapper .gform_next_button:hover {
  background: var(--oranje-dark) !important;
  transform: translateY(-1px) !important;
}
.docw-gf-block .gform_wrapper .gform_previous_button {
  background: transparent !important;
  color: var(--muted) !important;
  border: 1.5px solid var(--border) !important;
}
.docw-gf-block .gform_wrapper .gform_previous_button:hover {
  border-color: var(--groen) !important;
  color: var(--groen) !important;
  transform: none !important;
}

/* Validatie errors */
.docw-gf-block .gform_wrapper .gfield_error input,
.docw-gf-block .gform_wrapper .gfield_error textarea,
.docw-gf-block .gform_wrapper .gfield_error select {
  border-color: #e53e3e !important;
}
.docw-gf-block .gform_wrapper .validation_message { font-size: 12px !important; color: #e53e3e !important; margin-top: 4px !important; }
.docw-gf-block .gform_wrapper .gform_submission_error { display: none !important; }

/* Bevestigingsbericht */
.docw-gf-block .gform_confirmation_wrapper {
  background: #d8f3dc;
  border: 1px solid #b7e4c7;
  border-radius: 10px;
  padding: 16px 20px;
  color: #1b4332;
  font-weight: 600;
  font-size: 15px;
}

/* Radio / checkbox stijl */
.docw-gf-block .gform_wrapper .gfield_radio li,
.docw-gf-block .gform_wrapper .gfield_checkbox li {
  margin-bottom: 8px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
