/* =========================================
   Calicura — basisstijl (licht, rustig, warm)
   ========================================= */
:root{
  --bg:#f7f8f6;
  --card:#ffffff;
  --ink:#133a33;
  --muted:#5b6f68;
  --line:#e6ece8;
  --brand:#0f5a4e;         /* pine green */
  --brand-2:#1ba39c;       /* turquoise accent */
  --good:#1f8654;
  --focus:#6dd1c7;
  --shadow:0 8px 24px rgb(20 40 40 / 10%);
  --radius:14px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Inter,sans-serif;
  color:var(--ink); background:var(--bg);
  text-rendering:optimizeLegibility; -webkit-font-smoothing:antialiased;
}

/* Wraps */
.wrap{width:min(1200px, 92vw); margin-inline:auto}

/* ===== Topbar ===== */
.topbar{position:sticky; top:0; z-index:50; background:var(--card); border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex; align-items:center; gap:2rem; padding:14px 0}
.brand{font-weight:700; font-size:1.35rem; color:var(--brand); text-decoration:none; letter-spacing:.2px}
.mainnav{display:flex; gap:1rem; margin-left:auto}
.mainnav a{color:var(--muted); text-decoration:none}
.mainnav a:hover{color:var(--ink)}
.quickcall .tel{color:var(--brand); text-decoration:none; font-weight:600}

/* ===== Hero ===== */
.hero{background:linear-gradient(180deg,#f2f6f5,transparent)}
.hero-grid{display:grid; grid-template-columns: 1.1fr .9fr; align-items:center; gap:2rem; padding:48px 0}
.region{color:var(--muted); margin:0 0 6px}
.hero h1{font-size:clamp(1.8rem,3vw,2.6rem); margin:.2rem 0}
.lead{color:var(--muted); margin:.4rem 0 1.1rem}
.hero-art img{width:100%; height:auto; border-radius:var(--radius); box-shadow:var(--shadow)}
.cta-row{display:flex; gap:.75rem; flex-wrap:wrap}

/* Buttons */
.btn{display:inline-block; padding:.9rem 1.1rem; border-radius:12px; text-decoration:none; font-weight:600; border:1px solid transparent}
.btn.primary{background:var(--brand); color:#fff}
.btn.primary:hover{filter:brightness(.95)}
.btn.ghost{background:#fff; border-color:var(--line); color:var(--ink)}
.btn.ghost:hover{border-color:#cfe3de}

/* Trust list */
.trust-list{list-style:none; padding:0; margin:1.2rem 0 0; display:grid; gap:.4rem}
.i{display:inline-block; width:1.1em; height:1.1em; margin-right:.45em; vertical-align:-.2em}
.i-shield{background:conic-gradient(from 180deg at 50% 60%, var(--brand), var(--brand-2))}
.i-map{background:radial-gradient(circle at 40% 40%, var(--brand-2), var(--brand))}
.i-heart{background:radial-gradient(circle at 50% 40%, #f66, #f22); border-radius:50%}

/* ===== Form layout ===== */
.form-area{display:grid; grid-template-columns: 1.3fr .7fr; gap:2rem; margin:40px auto}
.form-card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow)}
.form-title{margin:0; padding:18px 18px 0}
.stepper{display:flex; gap:.5rem; padding:12px 18px; margin:0; list-style:none; border-bottom:1px solid var(--line)}
.stepper li{flex:1 1 auto; text-align:center; font-weight:600; color:var(--muted); padding:.4rem .5rem; border-radius:999px; background:#f2f6f5}
.stepper li.active{background:#e8f6f3; color:var(--brand); outline:2px solid #d8f0eb}

form{padding:18px}
fieldset{border:0; padding:0; margin:0}
legend{position:absolute; left:-9999px}
.step{display:none}
.step.active{display:block}

.grid{display:grid; grid-template-columns:1fr 1fr; gap:12px}
label{display:grid; gap:.35rem; margin:12px 0}
input,select,textarea{
  width:100%; padding:.8rem .9rem; border:1px solid #cfe3de; border-radius:12px; background:#fff; color:var(--ink);
}
textarea{min-height:120px; resize:vertical}
input:focus,select:focus,textarea:focus{outline:3px solid var(--focus); border-color:transparent}
.hint{color:var(--muted); margin:.4rem 0}

.nav-row{display:flex; gap:.6rem; justify-content:flex-end; margin-top:6px}
.btn.next, .btn.prev{min-width:9rem}
.btn.submit{min-width:11rem}

/* Errors */
.is-error{border-color:#d33 !important}
.field-error{color:#b3261e; font-size:.95rem; margin:.2rem 0 0}

/* Honeypot */
.hp{position:absolute; left:-9999px}

/* Side cards */
.side{display:grid; gap:1.2rem}
.card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:16px; box-shadow:var(--shadow)}
.card h3{margin:0 0 .6rem}
.services{list-style:none; padding:0; margin:0; display:grid; grid-template-columns:1fr 1fr; gap:.6rem}
.services li{display:flex; align-items:center}
.i-bandage,.i-leaf,.i-stoma,.i-compress,.i-syringe,.i-vial{
  width:1.1rem; height:1.1rem; margin-right:.5rem; background:var(--brand); border-radius:4px; opacity:.9
}

/* Footer */
.site-footer{margin-top:40px; padding:28px 0; border-top:1px solid var(--line); background:#fafcfb}
.footer-grid{display:grid; grid-template-columns:1fr 1fr 1fr; gap:1.2rem}

/* Sticky CTA (mobiel) */
.sticky-cta{
  position:fixed; inset:auto 0 0 0; display:none; gap:.5rem; padding:.6rem .9rem; background:rgb(255 255 255 / .9); backdrop-filter:saturate(160%) blur(6px); border-top:1px solid var(--line); z-index:60;
}
.sticky-cta .btn{flex:1 1 33%}

/* Screenreader utility */
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr; padding:32px 0}
  .form-area{grid-template-columns:1fr; gap:1.2rem}
  .footer-grid{grid-template-columns:1fr; text-align:center}
  .sticky-cta{display:flex}
}
@media (max-width: 640px){
  .grid{grid-template-columns:1fr}
  .mainnav{display:none}
}
