/* =========================================================
   SkyBytes v2 — assets/site.css (FULL)
   - Dark default + clean light
   - Shared components (nav/hero/cards/steps/contact/faq/footer)
   - Werkwijze: centered taxi-line + alternating phase cards
   - Milestones: centered orb (subtle blink) + label + SVG icons
   ========================================================= */

/* ---------- Theme tokens ---------- */
:root{
  --bg:#0b0b0c;
  --bg2:#070708;
  --panel:#0f0f10;
  --panel2: rgba(255,255,255,.03);

  --text:#f5f7fb;
  --muted:rgba(245,247,251,.72);
  --muted2:rgba(245,247,251,.55);

  --accent:#f6d64a;
  --line:rgba(255,255,255,.10);
  --line2:rgba(255,255,255,.06);

  --shadow:0 10px 30px rgba(0,0,0,.45);

  --r:16px;
  --r2:22px;
  --max:1180px;

  --focus: 0 0 0 4px rgba(246,214,74,.18);
}

html[data-theme="light"]{
  --bg:#fbfbfc;
  --bg2:#f3f4f6;
  --panel:#ffffff;
  --panel2:#ffffff;

  --text:#0f0f10;
  --muted:rgba(15,15,16,.72);
  --muted2:rgba(15,15,16,.55);

  --accent:#b88600;
  --line:rgba(15,15,16,.12);
  --line2:rgba(15,15,16,.08);

  --shadow:0 14px 28px rgba(15,15,16,.10);

  --focus: 0 0 0 4px rgba(184,134,0,.20);
}

/* ---------- Base ---------- */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, Helvetica, sans-serif;
  color:var(--text);
  background:
    radial-gradient(220px 140px at 18% 12%, rgba(246,214,74,.18), transparent 60%),
    radial-gradient(240px 160px at 82% 18%, rgba(246,214,74,.12), transparent 62%),
    linear-gradient(110deg, transparent 0%, rgba(255,255,255,.06) 18%, transparent 28%),
    radial-gradient(1100px 500px at 20% -10%, rgba(246,214,74,.12), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(246,214,74,.08), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg2) 55%, var(--bg2));
}
html[data-theme="light"] body{
  background:
    radial-gradient(900px 520px at 20% -10%, rgba(184,134,0,.06), transparent 60%),
    radial-gradient(900px 520px at 90% 10%, rgba(184,134,0,.04), transparent 60%),
    linear-gradient(180deg, #fbfbfc, #f6f6f8 60%, #f4f4f6);
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; height:auto; display:block; }

.wrap{ max-width:var(--max); margin:0 auto; padding:0 20px; }
main{ padding:34px 0 10px; }
section{ padding:34px 0; scroll-margin-top: 92px; }

/* ---------- Accessibility ---------- */
.skip{
  position:absolute; left:-9999px; top:12px;
  padding:10px 12px; border-radius:12px;
  background:var(--panel); border:1px solid var(--line);
  color:var(--text); z-index:999;
}
.skip:focus{ left:12px; outline:none; box-shadow:var(--focus); }

/* ---------- Topbar / Nav ---------- */
.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background: color-mix(in srgb, var(--bg) 65%, transparent);
  border-bottom:1px solid var(--line2);
}
html[data-theme="light"] .topbar{
  background: color-mix(in srgb, #fbfbfc 82%, transparent);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:14px;
}

.brand{ display:flex; align-items:center; gap:12px; }

/* Always-black logo badge with yellow accent */
.brand-badge{
  display:inline-flex; align-items:center; justify-content:center;
  height:34px; padding:0 12px;
  border-radius:10px;
  background:#0f0f10;
  color:#ffffff;
  border:2px solid var(--accent);
  box-shadow:
    0 0 0 1px rgba(0,0,0,.25) inset,
    0 0 10px rgba(246,214,74,.25);
  font-weight:900;
  letter-spacing:1.2px;
  font-size:14px;
}
html[data-theme="light"] .brand-badge{
  box-shadow:
    0 0 0 1px rgba(0,0,0,.18) inset,
    0 0 6px rgba(184,134,0,.22);
}

.navlinks{
  display:flex; gap:6px;
  color:var(--muted);
  font-size:14px;
  align-items:center;
}
.navlinks a{
  padding:8px 10px;
  border-radius:10px;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.navlinks a:hover{
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color:var(--text);
}
.navlinks a[aria-current="page"]{
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color:var(--text);
  border:1px solid color-mix(in srgb, var(--accent) 35%, transparent);
}

.cta{ display:flex; gap:10px; align-items:center; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 12px; border-radius:12px;
  font-weight:800; font-size:14px;
  border:1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 60%, transparent);
  transition:transform .15s ease, background .2s ease, border .2s ease;
  cursor:pointer;
  user-select:none;
}
html[data-theme="light"] .btn{ background:#ffffff; }

.btn:hover{
  transform:translateY(-1px);
  background: color-mix(in srgb, var(--panel) 78%, transparent);
  border-color: color-mix(in srgb, var(--line) 90%, #000 10%);
}
html[data-theme="light"] .btn:hover{
  background:#ffffff;
  border-color: rgba(15,15,16,.16);
}

.btn:focus{ outline:none; box-shadow:var(--focus); }

.btn-primary{
  background: var(--accent);
  color:#0f0f10;
  border-color: rgba(0,0,0,.15);
}
.btn-primary:hover{
  background: color-mix(in srgb, var(--accent) 82%, #fff 18%);
}

.iconbtn{
  width:40px; height:40px; padding:0;
  border-radius:12px;
  display:inline-flex; align-items:center; justify-content:center;
}
#themeIcon{
  font-size:16px;
  line-height:1;
  color: var(--text);
  opacity:.95;
}

/* Mobile drawer */
.drawer{
  display:none;
  border-top:1px solid var(--line2);
  padding:10px 0 14px;
}
.drawer a{
  display:block;
  padding:10px 10px;
  border-radius:12px;
  color:var(--muted);
}
.drawer a:hover{
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color:var(--text);
}
.drawer a[aria-current="page"]{
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color:var(--text);
}

/* ---------- Shared headings ---------- */
.section-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-end;
  margin-bottom:12px;
}
.section-head h2{ margin:0; font-size:18px; }
.section-head p{
  margin:0;
  color:var(--muted2);
  font-size:13px;
  max-width:70ch;
}

/* ---------- Generic hero ---------- */
.hero{
  display:grid;
  grid-template-columns: 1fr;
  gap:14px;
  align-items:start;
}
.hero-card{
  border-radius: var(--r2);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--panel) 65%, transparent),
    color-mix(in srgb, var(--panel) 40%, transparent)
  );
  border:1px solid var(--line);
  box-shadow: var(--shadow);
  padding:28px;
  position:relative;
  overflow:hidden;
}
html[data-theme="light"] .hero-card{ background:#fff; }
.hero-card::before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(900px 320px at 18% 0%, rgba(246,214,74,.20), transparent 60%);
  pointer-events:none;
}
html[data-theme="light"] .hero-card::before{ opacity:0; }

.kicker{
  display:inline-flex;
  align-items:center;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--accent) 35%, transparent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent);
  font-weight:900;
  letter-spacing:.3px;
  font-size:12px;
  position:relative; z-index:1;
}
.h1{
  margin:14px 0 10px;
  font-size: clamp(32px, 4.2vw, 52px);
  line-height:1.03;
  letter-spacing:-.7px;
  position:relative; z-index:1;
  max-width: 24ch;
}
.lead{
  margin:0 0 18px;
  color: var(--muted);
  font-size:16px;
  line-height:1.65;
  max-width: 78ch;
  position:relative; z-index:1;
}
.actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  position:relative; z-index:1;
}

/* ---------- Cards / grids / tags ---------- */
.grid4{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
}
@media (max-width: 980px){
  .grid4{ grid-template-columns: 1fr; }
}

.card{
  border-radius: var(--r);
  background: var(--panel2);
  border:1px solid var(--line);
  padding:16px;
  transition: transform .15s ease, border .2s ease, background .2s ease;
  min-height: 150px;
}
html[data-theme="light"] .card{ background:#fff; }
.card:hover{
  transform:translateY(-2px);
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
}
html[data-theme="light"] .card:hover{
  background:#fff;
  border-color: rgba(15,15,16,.14);
}

.tag{
  display:inline-block;
  font-size:11px;
  padding:6px 8px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--accent) 35%, transparent);
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  margin-bottom:10px;
  font-weight:900;
  letter-spacing:.3px;
}

/* ---------- Steps (simple 4-up) ---------- */
.steps{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:10px;
  padding:14px;
  border-radius: var(--r2);
  border:1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 55%, transparent);
}
html[data-theme="light"] .steps{ background:#fff; }
@media (max-width: 980px){
  .steps{ grid-template-columns: 1fr; }
}
.step{
  padding:12px;
  border-radius: 14px;
  border:1px solid var(--line2);
  background: color-mix(in srgb, var(--bg) 55%, transparent);
}
html[data-theme="light"] .step{ background:#fff; }
.step b{
  display:block;
  color:var(--accent);
  font-size:12px;
  letter-spacing:.3px;
  text-transform:uppercase;
}
.step span{
  display:block;
  margin-top:6px;
  color:var(--text);
  font-weight:800;
  font-size:13px;
}
.step p{
  margin:6px 0 0;
  color:var(--muted2);
  font-size:12px;
  line-height:1.45;
}

/* ---------- Contact + FAQ ---------- */
.contact{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:14px;
  align-items:start;
}
@media (max-width: 980px){
  .contact{ grid-template-columns: 1fr; }
}

.input{
  width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 65%, transparent);
  color: var(--text);
  outline:none;
  font-size:14px;
}
html[data-theme="light"] .input{ background:#fff; }
.input:focus{
  border-color: color-mix(in srgb, var(--accent) 45%, transparent);
  box-shadow:var(--focus);
}
textarea.input{ min-height:110px; resize:vertical; }

.fine{ font-size:12px; color:var(--muted2); line-height:1.5; }

.aside{
  border-radius: var(--r2);
  border:1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 55%, transparent);
  box-shadow: var(--shadow);
  padding:18px;
}
html[data-theme="light"] .aside{ background:#fff; }
.aside h3{
  margin:0 0 10px;
  font-size:13px;
  letter-spacing:.35px;
  text-transform:uppercase;
  color: var(--accent);
}

.bullets{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.bullets li{
  padding:10px 10px;
  border-radius: 14px;
  border:1px solid var(--line2);
  background: var(--panel2);
}
html[data-theme="light"] .bullets li{ background:#fff; }
.bullets b{ display:block; font-size:13px; }
.bullets span{
  display:block;
  margin-top:2px;
  font-size:12px;
  color: var(--muted2);
  line-height:1.45;
}

.faq{ display:grid; gap:10px; }
details{
  border:1px solid var(--line);
  background: var(--panel2);
  border-radius: 14px;
  padding:12px;
}
html[data-theme="light"] details{ background:#fff; }
summary{
  cursor:pointer;
  font-weight:900;
  color: var(--text);
  list-style:none;
}
summary::-webkit-details-marker{ display:none; }
details p{
  margin:8px 0 0;
  color:var(--muted);
  font-size:13px;
  line-height:1.6;
}

/* ---------- Footer ---------- */
footer{
  padding:28px 0 36px;
  border-top:1px solid var(--line2);
  color: var(--muted2);
  font-size:12px;
}
.foot{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
.foot a{
  color: var(--muted);
  padding:6px 8px;
  border-radius:10px;
}
.foot a:hover{
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--text);
}

/* =========================================================
   Werkwijze: hero + KPI + sticky progress
   ========================================================= */
.w-hero{ padding:18px 0 0; }

.w-heroGrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:14px;
  align-items:stretch;
}
@media (max-width: 980px){
  .w-heroGrid{ grid-template-columns: 1fr; }
}

.w-heroCard{
  border-radius: var(--r2);
  border:1px solid var(--line);
  box-shadow: var(--shadow);
  background:
    radial-gradient(900px 360px at 15% 0%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 60%),
    radial-gradient(720px 420px at 95% 20%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 55%),
    linear-gradient(180deg, color-mix(in srgb, var(--panel) 72%, transparent), color-mix(in srgb, var(--panel) 40%, transparent));
  padding:28px;
  position:relative;
  overflow:hidden;
}
html[data-theme="light"] .w-heroCard{
  background:
    radial-gradient(900px 360px at 15% 0%, rgba(184,134,0,.10), transparent 60%),
    radial-gradient(720px 420px at 95% 20%, rgba(184,134,0,.06), transparent 55%),
    linear-gradient(180deg, #fff, #fff);
}
.w-heroCard::after{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    linear-gradient(120deg, transparent 0%, rgba(255,255,255,.08) 22%, transparent 35%),
    radial-gradient(900px 480px at 50% 120%, rgba(0,0,0,.45), transparent 55%);
  opacity:.55;
  pointer-events:none;
  transform: translateX(var(--shine, 0px));
}
html[data-theme="light"] .w-heroCard::after{
  background: linear-gradient(120deg, transparent 0%, rgba(0,0,0,.05) 22%, transparent 35%);
  opacity:.35;
}

.w-kpiCard{
  border-radius: var(--r2);
  border:1px solid var(--line);
  background: var(--panel2);
  padding:16px;
}
html[data-theme="light"] .w-kpiCard{ background:#fff; }

.kpiGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.kpi{
  border-radius: 16px;
  border:1px solid var(--line2);
  background: color-mix(in srgb, var(--bg) 55%, transparent);
  padding:12px;
}
html[data-theme="light"] .kpi{ background:#fff; }
.kpi b{
  display:block;
  font-size:12px;
  color: var(--muted2);
  letter-spacing:.35px;
  text-transform:uppercase;
}
.kpi span{
  display:block;
  margin-top:6px;
  font-size:15px;
  font-weight:900;
  color: var(--text);
}
.kpi i{
  display:block;
  margin-top:4px;
  font-style:normal;
  font-size:12px;
  color: var(--muted);
  line-height:1.45;
}

/* Sticky progress */
.w-progress{
  position: sticky;
  top: 74px;
  z-index: 60;
  margin: 10px 0 18px;
}
@media (max-width: 980px){
  .w-progress{ top: 70px; }
}

.w-progressInner{
  border-radius: 999px;
  border:1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 70%, transparent);
  padding:10px;
  display:flex;
  align-items:center;
  gap:10px;
  backdrop-filter: blur(10px);
}
html[data-theme="light"] .w-progressInner{ background:#fff; }

.w-track{
  flex:1;
  height:10px;
  border-radius:999px;
  border:1px solid var(--line2);
  background: color-mix(in srgb, var(--bg) 55%, transparent);
  overflow:hidden;
}
html[data-theme="light"] .w-track{ background:#fff; }

.w-fill{
  height:100%;
  width:0%;
  border-radius:999px;
  background: linear-gradient(90deg,
    color-mix(in srgb, var(--accent) 85%, #fff 15%),
    color-mix(in srgb, var(--accent) 60%, #fff 40%)
  );
}

.w-stepLabel{
  min-width: 240px;
  font-size:12px;
  color: var(--muted2);
  line-height:1.25;
}
.w-stepLabel b{ display:block; color: var(--text); font-size:13px; }
@media (max-width: 980px){
  .w-stepLabel{ min-width:auto; }
}

/* =========================================================
   Werkwijze: centered taxi-line + alternating phases
   ========================================================= */

/* taxi container + center line */
.taxi{
  position:relative;
  display:grid;
  gap:22px;
  margin-top: 10px;
  padding-bottom: 10px;
}

/* center vertical line */
.taxi::before{
  content:"";
  position:absolute;
  left:50%;
  transform: translateX(-50%);
  top: 8px;
  bottom: 8px;
  width:2px;
  background: color-mix(in srgb, var(--accent) 35%, transparent);
  opacity:.9;
  border-radius:999px;
}

/* Phase card */
.phase{
  position:relative;
  width: calc(50% - 86px); /* leaves a center "lane" */
  border-radius: var(--r2);
  border:1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 55%, transparent);
  box-shadow: var(--shadow);
  overflow:hidden;
}
html[data-theme="light"] .phase{ background:#fff; }

/* Alternate left/right positioning */
.phase:nth-of-type(odd){ margin-right:auto; }
.phase:nth-of-type(even){ margin-left:auto; }

.phase::after{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(720px 260px at 20% 0%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 60%),
    radial-gradient(720px 320px at 90% 20%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 60%);
  opacity:.9;
  pointer-events:none;
}
html[data-theme="light"] .phase::after{ opacity:.35; }

/* Connector dot ON the center line, aligned to the card */
.phase::before{
  content:"";
  position:absolute;
  top: 34px;
  width: 14px;
  height: 14px;
  border-radius:50%;
  background: var(--accent);
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--accent) 18%, transparent);
}

/* odd = left card, dot to the right (towards center) */
.phase:nth-of-type(odd)::before{
  right: -79px;
}

/* even = right card, dot to the left (towards center) */
.phase:nth-of-type(even)::before{
  left: -79px;
}

/* Phase inner */
.phase-inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns: 1fr 340px;
  gap:14px;
  padding:18px;
}
@media (max-width: 980px){
  .phase-inner{ grid-template-columns: 1fr; }
}

.phase-top{ display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
.phase-left{ display:flex; gap:12px; align-items:flex-start; }

.phase-num{
  width:44px; height:44px;
  border-radius: 14px;
  background: #0f0f10;
  border:2px solid var(--accent);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:1000;
  letter-spacing:.3px;
  flex:0 0 auto;
}

.phase-title{ margin:2px 0 0; font-size:18px; letter-spacing:-.2px; }
.phase-desc{
  margin:8px 0 0;
  color: var(--muted);
  font-size:13px;
  line-height:1.65;
  max-width: 78ch;
}

.phase-tags{ display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius: 999px;
  border:1px solid color-mix(in srgb, var(--accent) 35%, transparent);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent);
  font-size:11px;
  font-weight:900;
  letter-spacing:.25px;
}

/* Right side panel in each phase */
.side{
  border-radius: 18px;
  border:1px solid var(--line2);
  background: var(--panel2);
  padding:14px;
}
html[data-theme="light"] .side{ background:#fff; }
.side h4{
  margin:0 0 10px;
  font-size:12px;
  letter-spacing:.35px;
  text-transform:uppercase;
  color: var(--muted2);
}
.side ul{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.side li{
  border-radius: 14px;
  border:1px solid var(--line2);
  background: color-mix(in srgb, var(--bg) 55%, transparent);
  padding:10px;
}
html[data-theme="light"] .side li{ background:#fff; }
.side b{ display:block; font-size:13px; }
.side span{ display:block; margin-top:2px; font-size:12px; color:var(--muted2); line-height:1.45; }

/* Mobile: phases become full-width, line stays centered */
@media (max-width: 980px){
  .phase{
    width:100%;
    margin:0;
  }
  .phase::before{
    left:50%;
    right:auto;
    transform: translateX(-50%);
  }
}

/* =========================================================
   Milestones: centered orb + label + SVG icons
   ========================================================= */
.milestone{
  position:relative;
  min-height: 160px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 12px 0;
}

/* keep the center line visible "through" milestone area */
.milestone::before{
  content:"";
  position:absolute;
  left:50%;
  transform: translateX(-50%);
  top: 0;
  bottom: 0;
  width:2px;
  background: color-mix(in srgb, var(--accent) 30%, transparent);
  opacity:.8;
  border-radius:999px;
}

/* Big centered orb */
.milestone-orb{
  position:absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 124px;
  height: 124px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, rgba(255,255,255,.35), rgba(255,255,255,0) 40%),
    var(--accent);
  box-shadow:
    0 0 0 10px color-mix(in srgb, var(--accent) 18%, transparent),
    0 26px 70px rgba(0,0,0,.45),
    inset 0 -6px 14px rgba(0,0,0,.25);
  z-index: 2;
  animation: orbPulse 5.5s ease-in-out infinite;
}

/* SVG icon inside orb */
.milestone-ico{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
}
.milestone-ico svg{
  width:34px;
  height:34px;
  display:block;
  fill: none;
  stroke: #0f0f10;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: .95;
}

/* subtle pulse / blink */
@keyframes orbPulse{
  0%{
    box-shadow:
      0 0 0 10px color-mix(in srgb, var(--accent) 18%, transparent),
      0 26px 70px rgba(0,0,0,.45),
      inset 0 -6px 14px rgba(0,0,0,.25);
    transform: translate(-50%, -50%) scale(1);
  }
  45%{
    box-shadow:
      0 0 0 14px color-mix(in srgb, var(--accent) 22%, transparent),
      0 32px 90px rgba(0,0,0,.55),
      inset 0 -8px 18px rgba(0,0,0,.28);
    transform: translate(-50%, -50%) scale(1.04);
  }
  100%{
    box-shadow:
      0 0 0 10px color-mix(in srgb, var(--accent) 18%, transparent),
      0 26px 70px rgba(0,0,0,.45),
      inset 0 -6px 14px rgba(0,0,0,.25);
    transform: translate(-50%, -50%) scale(1);
  }
}

/* Deliverable label below orb */
.milestone-label{
  position:relative;
  margin-top: 150px;
  max-width: 560px;
  padding: 14px 18px;
  border-radius: 16px;
  border:1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 65%, transparent);
  text-align:center;
  box-shadow: var(--shadow);
  z-index: 1;
}
html[data-theme="light"] .milestone-label{ background:#fff; }

.milestone-label small{
  display:block;
  font-size:11px;
  letter-spacing:.35px;
  text-transform:uppercase;
  color: var(--muted2);
}
.milestone-label b{
  display:block;
  margin-top:4px;
  font-size:15px;
  letter-spacing:-.2px;
  color: var(--text);
}
.milestone-label span{
  display:block;
  margin-top:6px;
  font-size:12px;
  color: var(--muted);
  line-height:1.5;
}

/* mobile milestone sizing */
@media (max-width: 980px){
  .milestone{ min-height: 150px; }
  .milestone-orb{ width: 96px; height: 96px; }
  .milestone-ico svg{ width:26px; height:26px; }
  .milestone-label{ margin-top: 120px; padding: 12px 14px; }
}

/* ---------- Reveal support (phases + milestones) ---------- */
.phase.reveal,
.milestone.reveal{
  opacity:0;
  transform: translateY(10px);
  transition: opacity .35s ease, transform .35s ease;
}
.phase.reveal.on,
.milestone.reveal.on{
  opacity:1;
  transform: translateY(0);
}

/* ---------- Responsive nav behavior ---------- */
.menuBtn{ display:none; }
@media (max-width: 980px){
  .navlinks{ display:none; }
  .menuBtn{ display:inline-flex; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .btn, .card{ transition:none; }
  .milestone-orb{ animation:none; }
  .phase.reveal, .milestone.reveal{
    opacity:1;
    transform:none;
    transition:none;
  }
}
/* ===== Readability upgrade for phase cards ===== */
.phase-inner{
  grid-template-columns: 1fr !important; /* side goes below by default */
  gap: 18px !important;
  padding: 22px !important;
}

.phase-title{
  font-size: 20px !important;
  line-height: 1.25 !important;
}

.phase-desc{
  font-size: 14px !important;
  line-height: 1.75 !important;
  max-width: 72ch !important; /* nicer line length */
}

.phase-tags{
  margin-top: 12px !important;
}
/* ===== Move the side panel to the bottom, full width ===== */
.side{
  width: 100% !important;
  border-radius: 18px !important;
  padding: 16px !important;
}

.side ul{
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important; /* 2 kolommen bullets */
  gap: 12px !important;
}

@media (max-width: 980px){
  .side ul{
    grid-template-columns: 1fr !important; /* mobile: 1 kolom */
  }
}
/* ===== More breathing room under the orb ===== */
.milestone{
  min-height: 190px !important; /* extra ruimte voor orb + label */
}

.milestone-label{
  margin-top: 250px !important; /* was 150px */
}

@media (max-width: 980px){
  .milestone{
    min-height: 170px !important;
  }
  .milestone-label{
    margin-top: 135px !important; /* was 120px */
  }
}
