/* ===========================================================
   Mijndomein Verhuisservice — site-layout (marketing)
   Premium, asymmetrisch, editorial. Bouwt op de tokens uit
   mijndomein.css. Vervangt de oude gecentreerde hero + de
   3-kaarten-"zo werkt het"-grid.
   =========================================================== */

/* ----- Header-accent ----- */
.header-right { gap: 18px; }
.header-link { font-size: 14.5px; font-weight: 600; }

/* ===========================================================
   HERO — split / asymmetrisch
   =========================================================== */
.hero2 {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(720px 360px at 88% -10%, rgba(4, 219, 219, .12), transparent 70%),
    var(--grad-band);
  border-bottom: 1px solid var(--border);
}
.hero2-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(540px 320px at 12% 110%, rgba(107, 47, 173, .10), transparent 70%);
  pointer-events: none;
}
.hero2-grid {
  position: relative;
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  align-items: center;
  gap: 40px;
  padding: 72px 24px 80px;
}
.hero2-copy { max-width: 36rem; }
.hero2-copy h1 {
  font-size: clamp(34px, 4.4vw, 56px);
  font-weight: 900;
  letter-spacing: -.028em;
  line-height: 1.04;
}
.hero2-copy h1 em { font-style: normal; color: var(--paars); }
.hero2-sub {
  font-size: clamp(16.5px, 1.5vw, 19px);
  color: var(--text);
  margin-top: 20px;
  max-width: 34rem;
}
.hero2-cta {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-top: 30px;
  flex-wrap: wrap;
}
.hero2-cta .btn svg { width: 19px; height: 19px; }
.hero2-mins {
  font-size: 14px;
  font-weight: 600;
  color: var(--muted);
}
.hero2-signals {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 26px;
  margin: 30px 0 0;
  padding: 0;
  list-style: none;
}
.hero2-signals li {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: 14.5px;
  font-weight: 600;
  color: var(--heading);
}
.hero2-signals svg { width: 17px; height: 17px; color: var(--cyaan-700); }
.hero2-signals li:nth-child(2) svg,
.hero2-signals li:nth-child(3) svg { color: var(--paars); }

/* illustratie */
.hero2-art { position: relative; justify-self: center; width: 100%; max-width: 520px; }
.art-move { width: 100%; height: auto; filter: drop-shadow(0 30px 50px rgba(107, 47, 173, .14)); animation: floaty 7s ease-in-out infinite; }
@keyframes floaty { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@media (prefers-reduced-motion: reduce) { .art-move { animation: none; } }

/* de wizard schuift iets over de hero heen voor diepte */
.wizard-section { padding-top: 0; margin-top: -36px; position: relative; z-index: 2; }

/* ===========================================================
   ZO WERKT HET — editorial, afwisselende rijen
   =========================================================== */
section.steps { padding: 78px 0 30px; }
.steps-head { max-width: 40rem; margin-bottom: 8px; }
.steps-head h2 {
  font-size: clamp(28px, 3.6vw, 40px);
  font-weight: 900;
  letter-spacing: -.025em;
  margin-top: 6px;
}

.step-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 56px;
  padding: 46px 0;
}
.step-row + .step-row { border-top: 1px solid var(--border); }
.step-row.reverse .step-text { order: 2; }
.step-row.reverse .step-art { order: 1; }

.step-text { max-width: 30rem; }
.step-no {
  display: block;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .08em;
  color: var(--cyaan-700);
  margin-bottom: 10px;
}
.step-row:nth-child(odd) .step-no { color: var(--paars); }
.step-text h3 {
  font-size: clamp(21px, 2.4vw, 27px);
  font-weight: 800;
  letter-spacing: -.02em;
  margin-bottom: 12px;
}
.step-text p { font-size: 16.5px; color: var(--text); }

.step-art {
  border-radius: var(--r-card);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  padding: 14px;
}
.step-art svg { width: 100%; height: auto; display: block; }

/* ===========================================================
   REASSURANCE-band
   =========================================================== */
.assure { padding: 26px 0 8px; }
.assure-inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.assure-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 26px 26px;
}
.assure-item + .assure-item { border-left: 1px solid var(--border); }
.assure-item > svg {
  width: 26px; height: 26px;
  color: var(--paars);
  flex: none;
  margin-top: 2px;
}
.assure-item b { display: block; font-size: 15.5px; font-weight: 700; color: var(--heading); }
.assure-item span { display: block; font-size: 13.8px; color: var(--text); margin-top: 4px; line-height: 1.55; }

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width: 920px) {
  .hero2-grid { grid-template-columns: 1fr; gap: 18px; padding: 56px 24px 64px; text-align: left; }
  .hero2-art { max-width: 420px; margin-top: 8px; }
  .step-row { grid-template-columns: 1fr; gap: 26px; padding: 38px 0; }
  .step-row.reverse .step-text { order: 1; }
  .step-row.reverse .step-art { order: 2; }
  .step-art { max-width: 460px; }
  .assure-inner { grid-template-columns: 1fr; }
  .assure-item + .assure-item { border-left: none; border-top: 1px solid var(--border); }
}
@media (max-width: 560px) {
  .header-link { display: none; }
  .hero2-grid { padding: 40px 20px 48px; }
  .hero2-cta { gap: 12px; }
  section.steps { padding: 54px 0 20px; }
}
