/* Gedeelde 4-stapsflow (bottom-sheet) voor plaats-, gids- en juridische pagina's.
   Zelfde stijl als de flow op de homepage (index-nieuw.html). Kleuren komen uit
   de CSS-variabelen van de pagina (--accent / --accent-deep). */
:root{--accent-soft:color-mix(in srgb,var(--accent,#16b364) 10%,#fff);--spring:cubic-bezier(.34,1.4,.44,1);--sh-l:0 32px 80px -16px rgba(10,15,26,.22)}

.flow{position:fixed;inset:0;z-index:90;background:rgba(10,15,26,.44);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);display:none;align-items:flex-end;justify-content:center}
.flow.open{display:flex}
@media(min-width:640px){.flow{align-items:center;padding:20px}}
.sheet{background:#fff;width:100%;max-width:460px;border-radius:28px 28px 0 0;padding:22px 22px calc(26px + env(safe-area-inset-bottom));box-shadow:var(--sh-l);animation:sheetup .38s cubic-bezier(.3,1.05,.35,1)}
@media(min-width:640px){.sheet{border-radius:28px;padding-bottom:26px;animation:sheetpop .34s cubic-bezier(.3,1.05,.35,1)}}
@keyframes sheetup{from{transform:translateY(70px);opacity:0}}
@keyframes sheetpop{from{transform:scale(.94) translateY(10px);opacity:0}}
.sheet .stop{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.sheet .stop b{font-size:12.5px;color:var(--muted);font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.x{border:0;background:var(--bg);width:32px;height:32px;border-radius:50%;font-size:14px;cursor:pointer;color:var(--muted)}
.prog{height:5px;background:var(--line);border-radius:99px;overflow:hidden;margin-bottom:20px}
.prog i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-deep));border-radius:99px;transition:width .45s cubic-bezier(.3,1,.36,1)}
.pane{display:none;animation:panein .32s ease}
.pane.on{display:block}
@keyframes panein{from{opacity:0;transform:translateX(16px)}}
.pane h3{font-size:19.5px;letter-spacing:-.02em;margin-bottom:14px}
.opt{display:flex;align-items:center;gap:12px;border:1.5px solid var(--line);border-radius:15px;padding:14px 15px;margin-bottom:10px;cursor:pointer;font-weight:600;font-size:15px;transition:border .15s,background .15s,transform .12s}
.opt:active{transform:scale(.98)}
.opt.sel{border-color:var(--accent);background:var(--accent-soft)}
.opt .ico{width:38px;height:38px;border-radius:11px;background:var(--bg);display:grid;place-items:center;font-size:18px;flex:0 0 auto}
.fld{margin-bottom:11px;text-align:left}
.fld label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}
.fld input{width:100%;border:1.5px solid var(--line);border-radius:13px;padding:13px 14px;font-size:16px;font-family:inherit;outline:none;transition:border .15s,box-shadow .15s;background:#fff}
.fld input:focus{border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 13%,transparent)}
.row2{display:grid;grid-template-columns:1.2fr .8fr;gap:10px}
.landsw{position:relative;display:flex;background:var(--bg);border:1.5px solid var(--line);border-radius:14px;padding:3px;margin-bottom:13px}
.landsw .thumb{position:absolute;top:3px;bottom:3px;left:3px;width:calc(50% - 3px);background:#fff;border-radius:11px;box-shadow:0 2px 8px rgba(10,15,26,.10),inset 0 0 0 1.5px color-mix(in srgb,var(--accent) 55%,transparent);transition:transform .38s var(--spring)}
.landsw.be .thumb{transform:translateX(100%)}
.landsw button{flex:1;position:relative;z-index:1;border:0;background:transparent;padding:10px;font-weight:600;font-size:14px;cursor:pointer;color:var(--muted);font-family:inherit;transition:color .25s;display:flex;align-items:center;justify-content:center;gap:7px}
.landsw button.on{color:var(--ink);font-weight:700}
.landsw button .bol{width:7px;height:7px;border-radius:50%;background:var(--line);transition:background .25s,box-shadow .25s}
.landsw button.on .bol{background:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}
.adreswrap{overflow:hidden;transition:height .42s cubic-bezier(.3,1,.36,1)}
.adreswrap>div{animation:panein .3s ease}
.fld input.leeg{border-color:#dc2637;box-shadow:0 0 0 4px rgba(220,38,55,.10)}
.sheet .nav2{display:flex;gap:10px;margin-top:16px}
.sheet .nav2 .btn{flex:1;padding:15px;border-radius:14px}
.btn-terug{background:var(--bg);color:var(--ink);border:1.5px solid var(--line)}
[data-kenteken]{--glyph-height:74.5%;--dash-height:23.6%}
.kenteken.is-empty:not(.is-focus) .kenteken__placeholder{animation:phpuls 3.8s ease-in-out infinite}
@keyframes phpuls{0%,100%{opacity:1}50%{opacity:.45}}
.fplate{position:relative;width:min(320px,86%);margin:0 auto 16px;aspect-ratio:2800/520;filter:drop-shadow(0 5px 9px rgba(60,45,10,.30))}
.fplate img.b{position:absolute;inset:0;width:100%;height:100%;display:block;user-select:none;-webkit-user-drag:none}
.fplate .g{position:absolute;left:11.4%;right:2.4%;top:0;bottom:0;display:flex;align-items:center;justify-content:center;gap:.3%}
.fplate .g img{height:79.4%;width:auto;transform:translateY(1.9%);user-select:none;-webkit-user-drag:none}
.fplate .g img.d{height:25.2%;transform:translateY(-6.6%)}
.rdwbox{background:var(--accent-soft);border-radius:14px;padding:13px 15px;font-size:14.5px;margin-bottom:8px;text-align:left}
.rdwbox small{display:block;color:var(--accent-deep);font-weight:700;margin-top:2px;font-size:12px}
.wijzig{text-align:center;margin:-6px 0 14px}
.wijzig a{color:var(--muted);font-size:13px;font-weight:600;text-decoration:none;border-bottom:1px dashed #c7ccd6;padding-bottom:1px}
.wijzig a:hover{color:var(--accent-deep);border-color:var(--accent)}
.kvbox{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:4px 16px;text-align:left}
.kv2{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.kv2:last-child{border-bottom:0}
.kv2 .k{color:var(--muted)}
.rdwlive{display:inline-flex;align-items:center;gap:7px;color:var(--accent-deep);font-weight:700;font-size:12.5px;margin-top:12px}
.rdwlive .puls{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 55%,transparent);animation:ring 2s infinite}
@keyframes ring{70%{box-shadow:0 0 0 9px transparent}100%{box-shadow:0 0 0 0 transparent}}
.fsub{color:var(--muted);font-size:13.5px;margin:-6px 0 16px;text-align:left}
.adreshint{color:var(--muted);font-size:12.5px;text-align:left;margin-top:-2px}
.telrow{display:flex;gap:8px}
.telrow .pfx{border:1.5px solid var(--line);border-radius:13px;background:var(--bg);padding:0 13px;font-weight:700;font-size:14.5px;display:flex;align-items:center;gap:7px;cursor:pointer;font-family:inherit;white-space:nowrap;transition:border .15s}
.telrow .pfx:hover{border-color:#c9d3df}
.telrow .fld{flex:1;margin-bottom:0}
.consent{display:flex;gap:10px;font-size:12.5px;color:var(--muted);text-align:left;margin-top:8px;align-items:flex-start;cursor:pointer;line-height:1.5}
.consent input{margin-top:2px;width:17px;height:17px;accent-color:var(--accent);flex:0 0 auto}
.consent a{color:var(--accent-deep)}
.consent.leeg span{color:#dc2637}
.f4err{display:none;color:#dc2637;font-size:13px;font-weight:600;margin-top:10px;text-align:left}
.f4err.zicht{display:block}
.done2{text-align:center;padding:14px 0 4px}
.done2 .chk{width:76px;height:76px;border-radius:50%;background:linear-gradient(160deg,var(--accent),var(--accent-deep));margin:0 auto 16px;display:grid;place-items:center;animation:sheetpop .5s cubic-bezier(.3,1.2,.4,1);box-shadow:0 14px 34px -8px color-mix(in srgb,var(--accent) 55%,transparent)}
.done2 .chk svg{width:36px;height:36px;stroke:#fff;stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round}
