/* ============================================================
   Popup / dienst-drawer systeem — schuift in van rechts
   ============================================================ */
.popup-overlay{position:fixed;inset:0;background:rgba(16,40,63,.55);opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s var(--ease);z-index:1000;backdrop-filter:blur(2px)}
.popup-overlay.active{opacity:1;visibility:visible}
.popup-panel{position:fixed;right:0;top:0;height:100%;width:min(460px,100%);background:var(--surface);transform:translateX(100%);transition:transform .38s var(--ease);overflow-y:auto;box-shadow:-20px 0 60px -20px rgba(16,40,63,.4);display:flex;flex-direction:column}
.popup-overlay.active .popup-panel{transform:translateX(0)}
.popup-head{position:sticky;top:0;background:var(--surface);padding:22px 24px 16px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;gap:14px;z-index:2}
.popup-head .ic-wrap{width:50px;height:50px;border-radius:13px;background:linear-gradient(135deg,var(--brand),var(--brand-dark));display:grid;place-items:center;color:#fff;flex:none}
.popup-head .ic-wrap .ic{width:26px;height:26px}
.popup-head h3{margin:0;font-size:1.3rem}
.popup-head .sub{font-size:.85rem;color:var(--muted)}
.popup-close{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:.15s}
.popup-close:hover{background:var(--bg);color:var(--brand)}
.popup-close .ic{width:20px;height:20px}
.popup-body{padding:22px 24px;flex:1}
.popup-body p{color:var(--muted)}
.popup-body h4{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-dark);margin:22px 0 12px;font-family:var(--head)}
.popup-incl{list-style:none;padding:0;margin:0 0 8px}
.popup-incl li{display:flex;gap:11px;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--line);font-size:.96rem}
.popup-incl li .ic{width:20px;height:20px;color:var(--ok);flex:none;margin-top:1px}
.popup-prijs{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px;margin:20px 0;display:flex;align-items:center;justify-content:space-between;gap:10px}
.popup-prijs span{font-size:.85rem;color:var(--muted)}
.popup-prijs b{font-family:var(--head);font-size:1.25rem;color:var(--brand)}
.popup-foot{position:sticky;bottom:0;background:var(--surface);border-top:1px solid var(--line);padding:16px 24px calc(16px + env(safe-area-inset-bottom))}
body.popup-open{overflow:hidden}
@media(max-width:680px){
  .popup-panel{width:100%}
}
