/* WijMobiel OV-Pas Formulier v1.6.1 */
.wmpas-wrapper *{box-sizing:border-box;margin:0;padding:0}
.wmpas-wrapper{
  --wm-roze:#E9418F;--wm-paars:#6E368D;--wm-groen:#5B9E34;--wm-rood:#CC2200;
  --wm-roze-l:#FCE4F1;--wm-roze-m:#F4AACD;--wm-paars-l:#EDE0F5;
  --wm-ink:#2D2D2D;--wm-mid:#5A5A5A;--wm-grijs:#9A9A9A;--wm-lijn:#EAD9E5;
  font-family:'Century Gothic','AppleGothic',sans-serif;color:var(--wm-ink);
  max-width:700px;margin:0 auto;
}

/* ── Info blok ── */
.wm-info-blok{background:#fff;border:2px solid var(--wm-lijn);border-radius:16px 16px 0 0;border-bottom:none;padding:1.25rem 1.5rem 1.4rem}
.wm-info-titel{font-size:1rem;font-weight:900;margin-bottom:.3rem}
.wm-info-sub{font-size:.83rem;color:var(--wm-mid);font-weight:700;line-height:1.5;margin-bottom:1rem}
.wm-info-kolommen{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.wm-info-kaart{border-radius:12px;padding:.9rem 1rem;font-size:.8rem;line-height:1.55;color:var(--wm-mid);font-weight:600}
.wm-info-kaart strong{display:flex;align-items:center;gap:.4rem;font-size:.83rem;font-weight:900;color:var(--wm-ink);margin-bottom:.45rem}
.wm-info-kaart-roze{background:var(--wm-roze-l);border:1.5px solid var(--wm-roze-m)}
.wm-info-kaart-paars{background:var(--wm-paars-l);border:1.5px solid #D9CCEE}

/* ── Kaart ── */
.wmpas-kaart{background:#fff;border-radius:0 0 20px 20px;box-shadow:0 8px 40px rgba(110,54,141,.13);overflow:hidden;border:2px solid var(--wm-lijn)}

/* ── Header ── */
.wmpas-form-hoofd{background:var(--wm-roze);padding:1.4rem 2rem;display:flex;align-items:center;gap:1.25rem}
.wmpas-uil-gif{width:68px;animation:wm-bob 3s ease-in-out infinite}
@keyframes wm-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.wmpas-form-hoofd h2{font-size:1.15rem;font-weight:900;color:#fff;margin-bottom:.2rem;font-family:'Century Gothic','AppleGothic',sans-serif}
.wmpas-form-hoofd p{font-size:.8rem;color:rgba(255,255,255,.85);font-weight:700}

/* ── Stappenbalk ── */
.wmpas-stappen{display:flex;align-items:center;padding:.9rem 1.5rem;background:#fdfbfc;border-bottom:2px solid var(--wm-lijn)}
.wm-stap{display:flex;align-items:center;gap:.35rem;flex-shrink:0}
.wm-bal{width:30px;height:30px;border-radius:50%;border:2.5px solid var(--wm-lijn);background:#fff;color:var(--wm-grijs);font-size:.75rem;font-weight:900;display:flex;align-items:center;justify-content:center;transition:all .3s}
.wm-bal.actief{background:var(--wm-roze);border-color:var(--wm-roze);color:#fff;box-shadow:0 0 0 4px var(--wm-roze-l)}
.wm-bal.klaar{background:var(--wm-groen);border-color:var(--wm-groen);color:#fff}
.wm-snaam{font-size:.65rem;font-weight:800;color:var(--wm-grijs);white-space:nowrap}
.wm-snaam.actief{color:var(--wm-roze)}.wm-snaam.klaar{color:var(--wm-groen)}
.wm-slijn{flex:1;height:3px;background:var(--wm-lijn);border-radius:3px;margin:0 .3rem;min-width:8px;transition:background .4s}
.wm-slijn.klaar{background:var(--wm-groen)}
.wm-foto-item{display:none}

/* ── Body & paneelen ── */
.wmpas-form-body{padding:2rem}
.wmpas-paneel{display:none}
.wmpas-paneel.actief{display:block;animation:wm-op .3s ease}
@keyframes wm-op{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ── Titels ── */
.wmpas-paneel-titel{font-size:1.05rem;font-weight:900;margin-bottom:.3rem}
.wmpas-paneel-omschr{font-size:.85rem;color:var(--wm-mid);font-weight:700;line-height:1.5;margin-bottom:1.4rem}

/* ── Gemeente raster ── */
.wmpas-gem-raster{display:grid;grid-template-columns:repeat(3,1fr);gap:.45rem;margin-bottom:1rem}
.wmpas-gem-knop{border:2px solid var(--wm-lijn);border-radius:10px;padding:.55rem .3rem;text-align:center;cursor:pointer;background:#fff;font-family:'Century Gothic','AppleGothic',sans-serif;font-size:.73rem;font-weight:800;color:var(--wm-mid);line-height:1.3;transition:all .15s}
.wmpas-gem-knop:hover{border-color:var(--wm-roze-m);color:var(--wm-roze);background:var(--wm-roze-l)}
.wmpas-gem-knop.aan{border-color:var(--wm-roze);background:var(--wm-roze);color:#fff}
.wmpas-gem-knop .wm-vtag{display:block;font-size:.59rem;margin-top:.2rem;opacity:.75}
.wmpas-gem-knop.aan .wm-vtag{opacity:.9;color:rgba(255,255,255,.9)}

/* ── Info methode kaarten (tussen stap 1 en 2) ── */
.wm-info-methode{display:flex;gap:1rem;background:var(--wm-roze-l);border:1.5px solid var(--wm-roze-m);border-radius:14px;padding:1.1rem 1.2rem;margin-bottom:.85rem}
.wm-info-methode p{font-size:.82rem;color:var(--wm-mid);font-weight:700;line-height:1.6;margin-bottom:0}
.wm-info-methode-paars{background:var(--wm-paars-l);border-color:#D9CCEE}
.wm-info-methode-nr{width:32px;height:32px;border-radius:50%;background:var(--wm-roze);color:#fff;font-weight:900;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.1rem}
.wm-info-methode-nr-paars{background:var(--wm-paars)}
.wm-info-methode-titel{font-weight:900;font-size:.9rem;color:var(--wm-ink);margin-bottom:.45rem}


.wm-voucher-blok{background:var(--wm-paars-l);border:2px solid #D9CCEE;border-radius:14px;padding:1rem 1.2rem;margin-top:.9rem}
.wm-voucher-blok-titel{font-size:.87rem;font-weight:900;color:var(--wm-paars);margin-bottom:.75rem}

/* ── Route kaarten (stap 2) ── */
.wmpas-route-raster{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-bottom:1.2rem}
.wmpas-route-kaart{border:2.5px solid var(--wm-lijn);border-radius:16px;padding:1.4rem 1rem;text-align:center;cursor:pointer;background:#fff;transition:all .2s;position:relative;user-select:none}
.wmpas-route-kaart:hover{border-color:var(--wm-roze-m);transform:translateY(-2px);box-shadow:0 6px 20px rgba(233,65,143,.12)}
.wmpas-route-kaart.aan{border-color:var(--wm-roze);background:var(--wm-roze-l)}
.wmpas-route-kaart.aan::after{content:'';position:absolute;top:.5rem;right:.65rem;width:22px;height:22px;background:var(--wm-roze);border-radius:50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath d='M1 5l3 3 7-7' stroke='white' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:60%}
.wmpas-route-gif{width:100px;height:100px;object-fit:contain;margin:0 auto .75rem;display:block}
.wmpas-route-titel{font-weight:900;font-size:.88rem;margin-bottom:.2rem}
.wmpas-route-info{font-size:.73rem;color:var(--wm-mid);line-height:1.4;font-weight:700}

/* ── Profielbox (voucher) ── */
.wmpas-profiel-box{background:var(--wm-roze-l);border:2px solid var(--wm-roze-m);border-radius:14px;padding:.9rem 1.2rem;margin-bottom:1.3rem;display:flex;align-items:center;gap:.9rem}
.wmpas-profiel-avatar{width:44px;height:44px;background:var(--wm-roze);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:900;color:#fff;flex-shrink:0}
.wmpas-profiel-naam{font-weight:900;font-size:.95rem}
.wmpas-profiel-meta{font-size:.74rem;color:var(--wm-mid);font-weight:700;margin-top:.1rem}

/* ── Velden ── */
.wmpas-veld{margin-bottom:1rem}
.wmpas-veld label{display:block;font-size:.82rem;font-weight:900;margin-bottom:.36rem}
.wmpas-veld .req{color:var(--wm-roze)}
.wmpas-veld .opt{color:var(--wm-grijs);font-weight:600;font-size:.74rem}
.wmpas-veld input,.wmpas-veld select{width:100%;padding:.7rem 1rem;border:2px solid var(--wm-lijn);border-radius:12px;font-family:'Century Gothic','AppleGothic',sans-serif;font-size:.91rem;font-weight:700;color:var(--wm-ink);background:#fdfafb;outline:none;transition:all .2s}
.wmpas-veld input:focus,.wmpas-veld select:focus{border-color:var(--wm-roze);background:#fff;box-shadow:0 0 0 4px var(--wm-roze-l)}
.wmpas-veld input[readonly]{background:#ede8f2!important;cursor:not-allowed;color:var(--wm-mid);border-color:var(--wm-roze-m)!important}
.wmpas-hint{display:block;font-size:.74rem;color:var(--wm-grijs);margin-top:.28rem;font-weight:700}
.wmpas-fout{display:none;font-size:.76rem;color:var(--wm-rood);margin-top:.28rem;font-weight:800}
.wmpas-fout.toon{display:block}
.wmpas-vergrendeld-hint{display:none;font-size:.73rem;color:var(--wm-paars);font-weight:800;margin-top:.25rem}
.wmpas-rij{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.wmpas-lijn{border:none;height:2px;background:#f3ecf0;margin:1.3rem 0}

/* ── Info melding ── */
.wmpas-info-melding{background:#eaf4ff;border:2px solid #b8d8f0;border-radius:12px;padding:.9rem 1.2rem;font-size:.84rem;color:#1a4a6e;font-weight:700;line-height:1.6;margin-bottom:1rem}

/* ── Adres lookup ── */
.wm-postcode-rij{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.wm-adres-laden{background:#EAF4FF;border:2px solid #B8D8F0;border-radius:14px;padding:1rem 1.2rem;font-size:.82rem;color:#1a4a6e;font-weight:700;display:none}
.wm-adres-ok{background:#EAF6E5;border:2px solid #A8D898;border-radius:14px;padding:1rem 1.2rem;display:none}
.wm-adres-ok-header{font-weight:900;font-size:.82rem;color:#2A5C1A;margin-bottom:.55rem}
.wm-adres-ok-straat{font-size:.95rem;font-weight:900;color:var(--wm-ink);margin-bottom:.15rem}
.wm-adres-ok-stad{font-size:.9rem;font-weight:800;color:var(--wm-ink);margin-bottom:.65rem}
.wm-adres-ok-badge{display:inline-block;background:var(--wm-groen);color:#fff;font-size:.78rem;font-weight:900;padding:.3rem .85rem;border-radius:100px}
.wm-adres-err{background:#FFF0EE;border:2px solid #F4BBAA;border-radius:14px;padding:1rem 1.2rem;font-size:.82rem;color:#8B2000;font-weight:700;display:none}

/* ── Foto upload ── */
.wm-foto-zone{border:2.5px dashed var(--wm-roze-m);border-radius:14px;padding:2.2rem 1.5rem;text-align:center;cursor:pointer;position:relative;background:#fdfafb;transition:all .2s}
.wm-foto-zone:hover{border-color:var(--wm-roze);background:var(--wm-roze-l)}
.wm-foto-zone.vol{border-style:solid;border-color:var(--wm-groen);padding:0;overflow:hidden}
.wm-foto-zone input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.wm-foto-zone strong{display:block;font-size:.92rem;font-weight:900;margin-bottom:.3rem}
.wm-foto-zone small{font-size:.77rem;color:var(--wm-grijs);font-weight:700}
.wm-foto-gif{width:80px;height:80px;object-fit:contain;margin:0 auto .65rem;display:block}
.wm-foto-eisen{background:#f7f4fa;border:1.5px solid #d9ccee;border-radius:12px;padding:.9rem 1.1rem;margin-top:.8rem}
.wm-foto-eisen-titel{font-size:.81rem;font-weight:900;color:var(--wm-paars);margin-bottom:.55rem}
.wm-foto-eisen-lijst{list-style:none;display:flex;flex-direction:column;gap:.3rem}
.wm-foto-eisen-lijst li{font-size:.79rem;color:var(--wm-mid);font-weight:600;line-height:1.4;padding-left:1rem;position:relative}
.wm-foto-eisen-lijst li::before{content:'○';color:var(--wm-paars);font-weight:900;position:absolute;left:0}

/* ── Akkoord checkboxen ── */
.wmpas-akkoord{display:flex;align-items:flex-start;gap:.65rem;padding:.7rem .9rem;background:#fdfafb;border:1.5px solid var(--wm-lijn);border-radius:11px;margin-bottom:.75rem}
.wmpas-akkoord input[type=checkbox]{width:17px;height:17px;margin-top:2px;accent-color:var(--wm-roze);flex-shrink:0;cursor:pointer}
.wmpas-akkoord label{font-size:.81rem;color:var(--wm-mid);line-height:1.5;font-weight:700;cursor:pointer}
.wmpas-akkoord label a{color:var(--wm-roze);font-weight:900}

/* ── Knoppen ── */
.wmpas-knop{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.6rem;border:none;border-radius:100px;font-family:'Century Gothic','AppleGothic',sans-serif;font-size:.93rem;font-weight:900;cursor:pointer;transition:all .2s}
.wmpas-knop-hoofd{background:var(--wm-roze);color:#fff;width:100%;box-shadow:0 4px 16px rgba(233,65,143,.32)}
.wmpas-knop-hoofd:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px rgba(233,65,143,.42)}
.wmpas-knop-hoofd:disabled{opacity:.5;cursor:not-allowed;transform:none}
.wmpas-knop-terug{background:#fff;color:var(--wm-roze);border:2px solid var(--wm-roze-m);padding:.75rem 1.2rem;font-size:.87rem}
.wmpas-knop-terug:hover{background:var(--wm-roze-l);border-color:var(--wm-roze)}
.wmpas-knop-rij{display:flex;gap:.7rem;margin-top:1.2rem}
.wm-spin{display:inline-block;width:15px;height:15px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:wm-spin .7s linear infinite}
@keyframes wm-spin{to{transform:rotate(360deg)}}

/* ── Succes paneel ── */
.wmpas-succes-header{text-align:center;margin-bottom:1.4rem}
.wmpas-succes-uil{width:120px;margin:0 auto .7rem;display:block}
.wmpas-succes-header h3{font-size:1.45rem;font-weight:900;margin-bottom:.35rem}
.wmpas-succes-intro{font-size:.88rem;color:var(--wm-mid);font-weight:700;line-height:1.55;margin-bottom:.8rem}
.wmpas-ref-nr{display:inline-block;background:var(--wm-roze-l);border:2px solid var(--wm-roze-m);color:var(--wm-paars);padding:.45rem 1.1rem;border-radius:100px;font-weight:900;font-size:.88rem}
.wmpas-overzicht{background:#fdfafb;border:2px solid var(--wm-lijn);border-radius:12px;overflow:hidden;margin:1rem 0 1.3rem}
.wmpas-ov-rij{display:flex;justify-content:space-between;padding:.6rem 1rem;font-size:.83rem;border-bottom:1px solid #f3ecf0}
.wmpas-ov-rij:last-child{border:none}
.wmpas-ov-rij span:first-child{color:var(--wm-grijs);font-weight:700}
.wmpas-ov-rij span:last-child{font-weight:900}

/* ── Wanneer blok ── */
.wmpas-tk-blok{background:#fdfafb;border:2px solid var(--wm-lijn);border-radius:14px;overflow:hidden;margin-bottom:.7rem}
.wmpas-tk-body{padding:1.2rem 1.4rem}
.wmpas-tk-kop{font-size:.93rem;font-weight:900;margin-bottom:.9rem;padding-bottom:.7rem;border-bottom:2px solid #f0eaf3}
.wmpas-tk-vraag{margin-bottom:.9rem;padding-bottom:.9rem;border-bottom:1.5px dashed #ede6f0}
.wmpas-tk-vraag:last-child{margin-bottom:0;padding-bottom:0;border:none}
.wmpas-tk-vraag>strong{display:block;font-size:.85rem;font-weight:900;margin-bottom:.4rem}
.wmpas-tk-vraag p{font-size:.81rem;color:var(--wm-mid);line-height:1.65;font-weight:600;margin-bottom:.4rem}
.wmpas-tk-vraag p:last-child{margin-bottom:0}
.wmpas-tk-grijs{background:#f7f4fa;border-radius:10px;padding:.8rem .95rem}
.wmpas-tk-contact{background:var(--wm-paars-l);border:2px solid #d9ccee;border-radius:11px;padding:.85rem 1.2rem;font-size:.83rem;color:var(--wm-paars);font-weight:700}
.wmpas-tk-contact strong{display:block;font-weight:900;margin-bottom:.15rem;color:var(--wm-ink)}
.wmpas-tk-contact a{color:var(--wm-roze);font-weight:900}

/* ── Responsive ── */
@media(max-width:540px){
  .wmpas-form-body{padding:1.2rem}
  .wmpas-rij,.wmpas-route-raster,.wm-info-kolommen,.wm-postcode-rij{grid-template-columns:1fr}
  .wmpas-gem-raster{grid-template-columns:repeat(2,1fr)}
  .wm-snaam{display:none}
}
