/* =========================================================================
   Vacaturedetailpagina — Bredasevacatures huisstijl
   ========================================================================= */

.breadcrumb{display:flex;align-items:center;gap:9px;font-size:.9rem;color:var(--muted);
  padding:22px 0 0;flex-wrap:wrap;}

/* ===================== SOLLICITATIE-MODAL ===================== */
.apply-modal[hidden]{display:none;}
.apply-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-start;
  justify-content:center;padding:40px 18px;overflow-y:auto;}
.apply-backdrop{position:fixed;inset:0;background:rgba(12,40,26,.55);backdrop-filter:blur(3px);}
.apply-dialog{position:relative;z-index:1;background:#fff;border-radius:24px;width:100%;
  max-width:560px;box-shadow:var(--shadow-lg);padding:34px 34px 30px;margin:auto;}
@media (prefers-reduced-motion: no-preference){.apply-dialog{animation:applyIn .3s cubic-bezier(.2,.7,.3,1) both;}}
@keyframes applyIn{from{opacity:0;transform:translateY(18px) scale(.98);}to{opacity:1;transform:none;}}
.apply-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;
  border:0;background:var(--cream-2);color:var(--ink);cursor:pointer;display:flex;
  align-items:center;justify-content:center;transition:.15s;}
.apply-close:hover{background:var(--line);}
.apply-close svg{width:18px;height:18px;}
.apply-head h2{font-size:1.6rem;margin:12px 0 0;}
.apply-sub{color:var(--muted);font-weight:600;margin-top:6px;}
.apply-form{margin-top:24px;display:flex;flex-direction:column;gap:16px;}
.apply-form .af-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.apply-form .af-field{display:flex;flex-direction:column;gap:7px;}
.apply-form label{font-size:.82rem;font-weight:700;color:var(--ink);}
.apply-form input,.apply-form textarea{font:inherit;border:1.5px solid var(--line);border-radius:12px;
  padding:12px 14px;background:#fff;color:var(--ink);transition:.15s;width:100%;resize:vertical;}
.apply-form input:focus,.apply-form textarea:focus{outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px var(--green-tint);}
.apply-form .af-file{display:flex;align-items:center;gap:11px;border:1.5px dashed var(--line);
  border-radius:12px;padding:14px;cursor:pointer;transition:.15s;}
.apply-form .af-file:hover{border-color:var(--primary);background:var(--green-tint);}
.apply-form .af-file.has-file{border-style:solid;border-color:var(--primary);background:var(--green-tint);}
.apply-form .af-file input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;}
.apply-form .af-file svg{width:22px;height:22px;color:var(--primary-strong);flex-shrink:0;}
.apply-form .af-file-text{font-weight:600;color:var(--body);font-size:.9rem;}
.apply-form .af-error{background:#fdecea;color:#a3371f;border-radius:10px;padding:11px 14px;
  font-size:.88rem;font-weight:600;}
.apply-form .af-error[hidden]{display:none;}
.apply-form .af-consent{font-size:.78rem;color:var(--muted);text-align:center;}

/* extra vragen + wettelijke overeenkomsten */
.apply-section{border-top:1px solid var(--line-2);padding-top:18px;display:flex;
  flex-direction:column;gap:12px;}
.apply-qh{font-family:var(--font-head);font-weight:800;color:var(--ink);font-size:1.1rem;}
.apply-qsub{color:var(--muted);font-size:.9rem;margin-top:-8px;}
.apply-yesno{display:flex;gap:10px;}
.apply-yesno .yn{display:flex;align-items:center;gap:8px;border:1.5px solid var(--line);
  border-radius:12px;padding:10px 20px;cursor:pointer;font-weight:600;color:var(--ink);transition:.15s;}
.apply-yesno .yn:hover{border-color:var(--primary);}
.apply-yesno .yn:has(input:checked){border-color:var(--primary);background:var(--green-tint);}
.apply-yesno input{accent-color:var(--primary);width:16px;height:16px;}
.apply-check{display:flex;align-items:flex-start;gap:11px;font-size:.92rem;color:var(--ink);
  cursor:pointer;line-height:1.45;}
.apply-check input{margin-top:2px;width:17px;height:17px;accent-color:var(--primary);flex-shrink:0;}
.apply-check a{color:var(--primary-strong);font-weight:700;text-decoration:underline;}
.apply-submitting{opacity:.7;pointer-events:none;}
.apply-success{text-align:center;padding:30px 10px 8px;}
.apply-success[hidden]{display:none;}
.apply-success .chk{width:70px;height:70px;border-radius:50%;background:var(--green-tint);
  margin:0 auto 22px;display:flex;align-items:center;justify-content:center;}
.apply-success .chk svg{width:36px;height:36px;color:var(--primary-strong);}
.apply-success h2{margin-bottom:10px;}
.apply-success p{color:var(--body);max-width:40ch;margin:0 auto;}
@media(max-width:560px){.apply-dialog{padding:28px 22px;}.apply-form .af-row{grid-template-columns:1fr;}}
.breadcrumb a{color:var(--muted);font-weight:600;}
.breadcrumb a:hover{color:var(--primary-strong);}
.breadcrumb .sep{opacity:.5;}
.breadcrumb .cur{color:var(--ink);font-weight:700;}

/* header */
.vd-hero{padding:26px 0 40px;}
.vd-head{display:flex;gap:22px;align-items:flex-start;}
.vd-logo{width:74px;height:74px;border-radius:18px;display:flex;align-items:center;
  justify-content:center;font-family:var(--font-head);font-weight:800;font-size:1.7rem;
  color:#fff;flex-shrink:0;box-shadow:var(--shadow-sm);}
.vd-head h1{font-size:clamp(1.9rem,3.6vw,2.8rem);line-height:1.12;}
.vd-company-line{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:18px;
  color:var(--body);font-weight:600;}
.vd-company-line .it{display:flex;align-items:center;gap:7px;}
.vd-company-line svg{width:17px;height:17px;color:var(--primary);}
.vd-pills{display:flex;flex-wrap:wrap;gap:9px;margin-top:18px;}

/* layout */
.vd-wrap{display:grid;grid-template-columns:1fr 360px;gap:40px;align-items:start;
  padding-bottom:30px;}
.vd-body{min-width:0;}

/* rich-text from Recruitee */
.vd-rt{color:var(--body);font-size:1.05rem;line-height:1.7;}
.vd-rt > *:first-child{margin-top:0;}
.vd-rt h1,.vd-rt h2,.vd-rt h3,.vd-rt h4{color:var(--ink);margin:34px 0 12px;line-height:1.2;}
.vd-rt h2{font-size:1.5rem;}
.vd-rt h3{font-size:1.2rem;}
.vd-rt p{margin:0 0 16px;}
.vd-rt ul,.vd-rt ol{margin:0 0 18px;padding-left:0;list-style:none;display:flex;
  flex-direction:column;gap:11px;}
.vd-rt ol{counter-reset:li;}
.vd-rt li{position:relative;padding-left:34px;color:var(--ink);}
.vd-rt ul li::before{content:"";position:absolute;left:4px;top:9px;width:9px;height:9px;
  border-radius:50% 50% 50% 0;background:var(--accent);transform:rotate(45deg);}
.vd-rt ol li{counter-increment:li;}
.vd-rt ol li::before{content:counter(li);position:absolute;left:0;top:1px;width:22px;height:22px;
  border-radius:50% 50% 50% 0;background:var(--green-tint);color:var(--primary-strong);
  font-weight:800;font-size:.8rem;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);}
.vd-rt a{color:var(--primary-strong);font-weight:700;text-decoration:underline;
  text-decoration-color:var(--line);text-underline-offset:3px;}
.vd-rt img{border-radius:14px;margin:18px 0;}
.vd-rt strong{color:var(--ink);}

.vd-section-label{font-family:var(--font-head);font-weight:800;color:var(--ink);
  font-size:1.5rem;margin:0 0 16px;}
.vd-divider{height:1px;background:var(--line);margin:38px 0;border:0;}

/* sidebar apply card */
.vd-aside{position:sticky;top:96px;display:flex;flex-direction:column;gap:18px;}
.apply-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-md);overflow:hidden;}
.apply-card .ac-top{background:var(--green-900);color:#fff;padding:22px 24px;}
.apply-card .ac-top .t{font-family:var(--font-head);font-weight:800;font-size:1.18rem;}
.apply-card .ac-top .s{color:#9fccb4;font-size:.88rem;margin-top:3px;}
.apply-card .ac-body{padding:22px 24px 24px;}
.fact{display:flex;justify-content:space-between;gap:14px;padding:11px 0;
  border-bottom:1px solid var(--line-2);font-size:.94rem;}
.fact:first-child{padding-top:0;}
.fact .fk{color:var(--muted);display:flex;align-items:center;gap:8px;}
.fact .fk svg{width:16px;height:16px;color:var(--primary);}
.fact .fv{font-weight:700;color:var(--ink);text-align:right;}
.apply-card .btn{margin-top:20px;}
.btn-wa{background:#25D366;color:#fff;margin-top:10px;}
.btn-wa:hover{background:#1da851;color:#fff;transform:translateY(-2px);}
.btn-wa svg{width:20px;height:20px;}
.ac-note{text-align:center;font-size:.82rem;color:var(--muted);margin-top:11px;}
.ac-powered{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:13px;
  padding-top:14px;border-top:1px solid var(--line-2);font-size:.8rem;color:var(--muted);}

.share-card{background:var(--cream-2);border-radius:var(--radius);padding:20px 24px;}
.share-card .sh-t{font-weight:700;color:var(--ink);font-size:.95rem;margin-bottom:12px;}
.share-row{display:flex;gap:9px;}
.share-row a{width:40px;height:40px;border-radius:11px;background:#fff;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--body);transition:.15s;}
.share-row a:hover{border-color:var(--primary);color:var(--primary-strong);transform:translateY(-2px);}
.share-row svg{width:18px;height:18px;}

/* states */
.vd-state{padding:80px 0;text-align:center;}
.vd-state .si{width:74px;height:74px;border-radius:50% 50% 50% 0;background:var(--green-tint);
  transform:rotate(45deg);margin:0 auto 26px;display:flex;align-items:center;justify-content:center;}
.vd-state .si svg{width:34px;height:34px;color:var(--primary-strong);transform:rotate(-45deg);}
.vd-state h2{margin-bottom:12px;}
.vd-state p{color:var(--muted);max-width:46ch;margin:0 auto 26px;}
.vd-skel-line{height:16px;border-radius:8px;background:linear-gradient(90deg,#eef2ee 25%,#e4ebe5 37%,#eef2ee 63%);
  background-size:400% 100%;margin:0 0 14px;}
@media (prefers-reduced-motion: no-preference){
  .vd-skel-line{animation:skel 1.4s ease infinite;}
}

/* mobile sticky apply bar */
.vd-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:40;background:#fff;
  border-top:1px solid var(--line);box-shadow:0 -6px 24px rgba(20,40,28,.1);
  padding:13px 18px;align-items:center;gap:14px;}
.vd-bar .bt{flex:1;min-width:0;}
.vd-bar .bt .bl{font-size:.76rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.vd-bar .bt .bv{font-family:var(--font-head);font-weight:800;font-size:1.05rem;color:var(--ink);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

@media(max-width:900px){
  .vd-wrap{grid-template-columns:1fr;}
  .vd-aside{position:static;}
  .vd-bar{display:flex;}
  .vd-wrap{padding-bottom:20px;}
}
@media(max-width:600px){
  .vd-head{gap:15px;}
  .vd-logo{width:58px;height:58px;font-size:1.35rem;border-radius:14px;}
}
