.fwa-overlay{position:fixed;inset:0;background:rgba(15,27,45,.6);display:none;align-items:center;justify-content:center;z-index:99999;padding:16px}
.fwa-overlay.is-open{display:flex}
.fwa-modal{background:#fff;border-radius:14px;max-width:420px;width:100%;padding:28px;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.fwa-close{position:absolute;top:12px;right:16px;border:0;background:none;font-size:28px;line-height:1;cursor:pointer;color:#64748b}
.fwa-modal h3{margin:0 0 6px;font-size:20px;color:#0f1b2d}
.fwa-sub{margin:0 0 18px;font-size:14px;color:#64748b;line-height:1.5}

.fwa-field{margin-bottom:14px}
.fwa-field label{display:block;font-size:13px;font-weight:600;color:#334155;margin-bottom:4px}
.fwa-field input{width:100%;padding:11px 12px;border:1px solid #cbd5e1;border-radius:8px;font-size:15px;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}
.fwa-field input:focus{outline:none;border-color:#25d366;box-shadow:0 0 0 3px rgba(37,211,102,.15)}

/* foutstaat per veld */
.fwa-field input.fwa-input-error{border-color:#dc2626}
.fwa-field input.fwa-input-error:focus{border-color:#dc2626;box-shadow:0 0 0 3px rgba(220,38,38,.15)}
.fwa-err{display:block;font-size:12.5px;color:#dc2626;margin-top:5px;min-height:0;line-height:1.4}
.fwa-err:empty{margin-top:0}
.fwa-err-consent{margin-top:-12px;margin-bottom:12px}

.fwa-consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:#475569;line-height:1.45;margin:6px 0 8px;cursor:pointer}
.fwa-consent input{margin-top:2px;flex-shrink:0}
.fwa-privacy-link{color:#0f7a3d;text-decoration:underline;font-weight:600}
.fwa-privacy-link:hover{color:#25d366}

.fwa-submit{width:100%;padding:13px;background:#25d366;color:#fff;border:0;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:background .15s}
.fwa-submit:hover{background:#1eb558}
.fwa-submit:disabled{opacity:.6;cursor:not-allowed}

.fwa-msg{margin:12px 0 0;font-size:14px;color:#0f1b2d;text-align:center;min-height:0}
.fwa-msg:empty{margin:0}
.fwa-msg-error{color:#dc2626}

.fwa-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0}

/* bedankt-scherm */
.fwa-success{text-align:center;padding:8px 4px 4px}
.fwa-success h3{margin:14px 0 8px;font-size:22px;color:#0f1b2d}
.fwa-success-msg{font-size:15px;color:#475569;line-height:1.55;margin:0 0 22px}
.fwa-check{display:flex;justify-content:center;margin-top:8px}
.fwa-check svg{display:block}
.fwa-check circle{stroke-dasharray:151;stroke-dashoffset:151;animation:fwa-circle .5s ease-out forwards}
.fwa-check path{stroke-dasharray:48;stroke-dashoffset:48;animation:fwa-check .35s .45s ease-out forwards}
@keyframes fwa-circle{to{stroke-dashoffset:0}}
@keyframes fwa-check{to{stroke-dashoffset:0}}
.fwa-done{width:100%;padding:12px;background:#0f1b2d;color:#fff;border:0;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer}
.fwa-done:hover{background:#1c2e4a}
@media (prefers-reduced-motion: reduce){
  .fwa-check circle,.fwa-check path{animation:none;stroke-dashoffset:0}
}