html{ scroll-behavior: smooth; }

/* zodat de titel niet onder je sticky nav valt */
:target{ scroll-margin-top: 90px; } /* pas 90px aan naar jouw nav hoogte */

:root{
      --bg:#0b0f14;
      --card:#111826;
      --muted:#93a4b7;
      --text:#eaf0f7;

      /* ✅ REF Registratie brand (blauw/rood) */
      --brandBlue:#0a84ff;
      --brandRed:#ff3b30;

      --line:rgba(255,255,255,.08);
      --shadow: 0 18px 40px rgba(0,0,0,.45);
      --radius:18px;
    }

    *{box-sizing:border-box}
    html, body{ overflow-x:hidden; }

    body{
      margin:0;
      font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
      background: var(--bg);
      color:var(--text);
      line-height:1.55;
    }

	body::before{
      content:"";
      position: fixed;
      inset: 0;
      z-index: -1;
      background:
		radial-gradient(1200px 1600px at 20% 0%, rgba(10,132,255,.22), transparent 60%),
        radial-gradient(1200px 1600px at 80% 80%, rgba(255,59,48,.16), transparent 60%),
        var(--bg)
    }

    a{color:inherit}
    .wrap{max-width:1080px;margin:0 auto;padding:28px 18px 70px}

    /* ========= NAV ========= */
    .nav{
      display:flex;align-items:center;justify-content:space-between;gap:14px;
      padding:14px 16px; border:1px solid var(--line); border-radius:999px;
      background:rgba(17,24,38,.65);
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      box-shadow: var(--shadow);
      position:fixed; 
	  top:12px; 
	  z-index:9999;
      min-width:0;
      flex-direction:row; /* ✅ desktop: alles in 1 rij */
	  width: -webkit-fill-available;
	    /* ✅ zelfde breedte als de pagina-content */
      max-width: 1045px;
      margin: 0 auto;   /* center + ruimte eronder */
	  margin-right: 12px;
    }
    .navTop{
      display:flex;
      align-items:center;
      justify-content:flex-start;
      gap:12px;
      min-width:0;
      flex:1 1 auto; /* ✅ neemt ruimte, zodat links rechts kunnen */
	  max-width: 1045px;
      margin: 0 auto;   /* center + ruimte eronder */
    }

    .brand{display:flex;align-items:center;gap:10px;text-decoration:none;min-width:0}
    .logoRing{
      width:38px;height:38px;border-radius:12px;padding:2px;flex:0 0 auto;
      background: linear-gradient(135deg, var(--brandBlue), var(--brandRed));
      box-shadow: 0 10px 25px rgba(0,0,0,.35);
      display:flex;align-items:center;justify-content:center;
    }
    .logoImg{
      width:34px;height:34px;border-radius:10px;object-fit:cover;display:block;
    }
    .brand span{
      font-weight:800;letter-spacing:.2px;
      white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
      max-width:220px;
    }

    .navlinks{
      display:flex;
      gap:10px;
      flex-wrap:wrap;
      justify-content:flex-end;
      width:auto;      /* ✅ niet 100% (anders wordt het te breed) */
      min-width:0;
    }
    .pill{
      display:inline-flex;align-items:center;gap:8px;
      padding:10px 12px;border-radius:999px;border:1px solid var(--line);
      background:rgba(255,255,255,.04); text-decoration:none; font-weight:700; font-size:14px;
      white-space:nowrap;
    }
    .pill:hover{border-color:rgba(10,132,255,.35); background:rgba(10,132,255,.08)}
    .pill.primary{
      border-color:rgba(10,132,255,.40); background:rgba(10,132,255,.12)
    }

    /* Hamburger (desktop uit) */
    .hamburger{
      display:none;
      border:1px solid var(--line);
      background:rgba(255,255,255,.04);
      border-radius:14px;
      padding:10px 12px;
      font-weight:900;
      cursor:pointer;
      flex:0 0 auto;
	  color: inherit;
    }

    .hamburger:hover{border-color:rgba(10,132,255,.35); background:rgba(10,132,255,.08)}

    /* Mobile dropdown menu */
    .mobileMenu{
      display:none;
      margin-top:10px;
      border:1px solid var(--line);
      border-radius:18px;
      background:rgba(17,24,38,.70);
      backdrop-filter: blur(10px);
      box-shadow: var(--shadow);
      overflow:hidden;
      width:100%;
    }
    .mobileMenu a{
      width:100%;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:10px;
      padding:14px 14px;
      text-decoration:none;
      border-top:1px solid rgba(255,255,255,.06);
      font-weight:800;
      background:transparent;
      color:inherit;
    }
    .mobileMenu a:first-child{border-top:none}
    .mobileMenu .sub{color:var(--muted); font-weight:800; font-size:13px}
    .mobileMenu.open{display:block}

    /* ========= HERO ========= */
    header{
      display:grid;grid-template-columns: 1.2fr .8fr; gap:20px;
      margin-top:75px; align-items:stretch;
    }
    @media (max-width: 880px){ header{grid-template-columns:1fr} }

    .hero{
      border:1px solid var(--line); border-radius:var(--radius);
      padding:26px; background:rgba(17,24,38,.6); backdrop-filter: blur(12px);
      box-shadow: var(--shadow);
      min-width:0;
    }
    h1{margin:0 0 8px;font-size:40px;line-height:1.1}
    @media (max-width: 520px){ h1{font-size:32px} }
    .sub{margin:0;color:var(--muted);font-size:16px}

    .ctaRow{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
    .btn{
      display:inline-flex;align-items:center;justify-content:center;gap:10px;
      padding:12px 14px;border-radius:14px;border:1px solid var(--line);
      background:rgba(255,255,255,.05); text-decoration:none; font-weight:900;
      min-width: 190px;
    }
    .btn:hover{border-color:rgba(255,255,255,.18)}
    .btn.primary{
      background: linear-gradient(135deg, var(--brandBlue), var(--brandRed));
      border-color:transparent; color:#061018;
    }
    .btn.primary:hover{filter:saturate(1.05) brightness(1.05)}
    .btn .tag{font-size:12px;font-weight:900;opacity:.9}
    .mini{font-size:13px;color:var(--muted);margin-top:14px}

    .heroAside{
      border:1px solid var(--line); border-radius:var(--radius);
      padding:22px; background:rgba(17,24,38,.55); backdrop-filter: blur(12px);
      box-shadow: var(--shadow);
      display:flex;flex-direction:column;justify-content:space-between;gap:16px;
      min-width:0;
    }
    .stats{
      display:grid;grid-template-columns:1fr 1fr; gap:12px;
    }
    .stat{
      border:1px solid var(--line); border-radius:16px; padding:14px;
      background:rgba(255,255,255,.03)
    }
    .stat .k{font-size:12px;color:var(--muted);font-weight:800}
    .stat .v{font-size:18px;font-weight:900;margin-top:4px}
    .badge{
      display:inline-flex;align-items:center;gap:8px;
      padding:10px 12px;border-radius:999px;border:1px solid rgba(10,132,255,.35);
      background:rgba(10,132,255,.10); color:#dbeeff; font-weight:900; font-size:13px;
      width:fit-content;
    }

    section{margin-top:26px}
    .grid{
      display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
    }
    @media (max-width: 980px){ .grid{grid-template-columns:1fr 1fr} }
    @media (max-width: 620px){ .grid{grid-template-columns:1fr} }

    .card{
      border:1px solid var(--line); border-radius:var(--radius);
      padding:18px; background:rgba(17,24,38,.55); backdrop-filter: blur(10px);
      box-shadow: 0 14px 34px rgba(0,0,0,.35);
      min-width:0;
    }
    .card h2, .card h3{margin:0 0 8px}
    .card h2{font-size:22px}
    .card h3{font-size:18px}
    .muted{color:var(--muted)}
    ul{margin:10px 0 0; padding-left:18px}
    li{margin:6px 0}
    .hr{height:1px;background:var(--line);margin:16px 0}

    .pricing{
      display:grid;grid-template-columns: repeat(3, 1fr); gap:14px;
    }
    @media (max-width: 980px){ .pricing{grid-template-columns:1fr} }

    .price{
      border:1px solid var(--line); border-radius:var(--radius);
      padding:18px; background:rgba(17,24,38,.60); backdrop-filter: blur(10px);
      box-shadow: 0 14px 34px rgba(0,0,0,.35);
      position:relative; overflow:hidden;
      min-width:0;
    }
    .price.featured{
      border-color: rgba(10,132,255,.45);
      background: linear-gradient(180deg, rgba(10,132,255,.12), rgba(17,24,38,.58));
    }
    .ribbon{
      position:absolute; top:14px; right:-36px; transform: rotate(35deg);
      background: rgba(10,132,255,.25); border:1px solid rgba(10,132,255,.35);
      color:#dbeeff; font-weight:900; font-size:12px;
      padding:6px 40px;
    }
    .pTitle{display:flex;align-items:center;justify-content:space-between;gap:10px}
    .pTitle b{font-size:18px}
    .pPrice{font-size:34px;font-weight:950;margin:10px 0 2px}
    .pNote{color:var(--muted);font-size:13px;margin:0}
    .small{font-size:13px;color:var(--muted)}
    .ok{color:#c9f7d7}
    .warn{color:#ffd7a8}

    .form{
      display:grid; grid-template-columns: 1fr 1fr; gap:12px;
    }
    @media (max-width: 820px){ .form{grid-template-columns:1fr} }

    input, textarea, select{
      width:100%;
      padding:12px 12px;
      border-radius:14px;
      border:1px solid var(--line);
      background:rgba(255,255,255,.04);
      color:var(--text);
      outline:none;
      min-width:0;
    }
    textarea{min-height:120px;resize:vertical}
    label{font-size:13px;color:var(--muted);font-weight:900;display:block;margin:2px 0 8px}
    .formActions{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}
    .btn2{
      cursor:pointer;
      padding:12px 14px;border-radius:14px;border:1px solid var(--line);
      background:rgba(255,255,255,.05); color:var(--text); font-weight:900;
      display:inline-flex;align-items:center;justify-content:center;
      text-decoration:none;
      min-width:190px;
    }
    .btn2.primary{
      background: linear-gradient(135deg, var(--brandBlue), var(--brandRed));
      border-color:transparent; color:#061018;
    }
    .btn2:hover{border-color:rgba(255,255,255,.18)}
    .footer{
      margin-top:26px; padding-top:18px; border-top:1px solid var(--line);
      display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;
      color:var(--muted); font-size:13px;
    }
    .kbd{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono"; font-size:12px}

    /* =========================================================
       ✅ HARD MOBILE OVERRIDES (hamburger dropdown)
       ========================================================= */
    @media (max-width: 700px){
      .wrap{ padding:16px 12px 60px; }

      .nav{
        top:10px;
        padding:10px;
        border-radius:18px;
        gap:10px;
        backdrop-filter: blur(8px);

        flex-direction:column;
        align-items:stretch;
      }

      .navTop{
        width:100%;
        justify-content:space-between;
      }


      /* Desktop navlinks: altijd uit op mobiel */
      .nav .navlinks{
        display:none !important;
      }

      /* Hamburger: altijd aan op mobiel */
      .nav .hamburger{
        display:inline-flex !important;
        align-items:center;
        justify-content:center;
        gap:10px;
      }

      header{ grid-template-columns:1fr; }
      header .hero, header .heroAside{ padding:18px; }

      .ctaRow .btn{ width:100%; min-width:0; }
      .btn2{ width:100%; min-width:0; }
      .card{ padding:16px; }
    }
/* ========= SCREENSHOT SLIDER ========= */
.sliderWrap{
  position:relative;
}

.slider{
  display:flex;
  gap:14px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:6px 6px 10px;
  scrollbar-width:none; /* Firefox */
}
.slider::-webkit-scrollbar{display:none} /* Chrome/Safari */

.slide{
  flex:0 0 auto;
  width:min(330px, 82vw);
  scroll-snap-align:center;
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,255,255,.03);
  overflow:hidden;
  box-shadow: 0 14px 34px rgba(0,0,0,.30);
}

.slide img{
  width:100%;
  height:auto;
  display:block;
}

.slideCap{
  padding:12px 14px 14px;
}

.slideCap b{
  display:block;
  font-size:16px;
  margin-bottom:4px;
}

.slideCap span{
  display:block;
  font-size:13px;
  color:var(--muted);
  font-weight:800;
  line-height:1.35;
}

.sliderHint{
  margin-top:10px;
  color:var(--muted);
  font-size:13px;
  font-weight:900;
}
/* ========= DESKTOP PIJLEN ========= */
.sliderWrap{ position:relative; }

.sliderBtn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:44px;height:44px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(17,24,38,.75);
  color:var(--text);
  font-weight:900;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow: 0 14px 34px rgba(0,0,0,.30);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.sliderBtn:hover{ border-color:rgba(10,132,255,.35); background:rgba(10,132,255,.10); }

.sliderBtn.left{ left:8px; }
.sliderBtn.right{ right:8px; }

/* Alleen tonen op desktop */
@media (max-width: 700px){
  .sliderBtn{ display:none; }
}

/* Geef wat ruimte zodat pijlen niet over tekst heen vallen */
@media (min-width: 701px){
  .slider{ padding-left:60px; padding-right:60px; }
}

/* =========================================================
   ✅ MIJN VERHAAL (quote stijl met brand accent)
   ========================================================= */
.storyGrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:14px;
}
@media (max-width: 880px){
  .storyGrid{ grid-template-columns:1fr; }
}
.storyQuote{
  position:relative;
  padding-left:22px;
}
.storyQuote::before{
  content:"";
  position:absolute;
  left:0;
  top:14px;
  bottom:14px;
  width:4px;
  border-radius:999px;
  background: linear-gradient(180deg, var(--brandBlue), var(--brandRed));
  box-shadow: 0 0 0 1px rgba(255,255,255,.06);
}
.storyQuoteMark{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  margin-bottom:10px;
  font-weight:950;
  letter-spacing:.5px;
}
  


/* =========================================================
   ✅ REF Chatbox (drop-in) — gebruikt jouw brand kleuren
   ========================================================= */
:root{
  --chatAccentA: var(--brandBlue);
  --chatAccentB: var(--brandRed);
  --chatBg: rgba(17,24,38,.72);
  --chatPanel: rgba(17,24,38,.88);
  --chatText: var(--text);
  --chatMuted: var(--muted);
  --chatLine: var(--line);
  --chatShadow: var(--shadow);
}

.refChatFab{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:10000; /* boven jouw navbar (9999) */
  width:56px;
  height:56px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: linear-gradient(135deg, var(--chatAccentA), var(--chatAccentB));
  color:#061018;
  cursor:pointer;
  box-shadow: var(--chatShadow);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  font-weight:900;
}

.refChatBox{
  position:fixed;
  right:18px;
  bottom:86px;
  z-index:10000;
  width:min(390px, calc(100vw - 36px));
  height:540px;
  max-height:72vh;
  border-radius:18px;
  border:1px solid var(--chatLine);
  background: var(--chatPanel);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--chatShadow);
  overflow:hidden;
  display:none;
  flex-direction:column;
}

.refChatBox.open{ display:flex; }

.refChatHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 12px;
  border-bottom:1px solid var(--chatLine);
  background: rgba(255,255,255,.03);
}

.refChatLeft{
  display:flex;
  gap:10px;
  align-items:center;
  min-width:0;
}

.refChatBadge{
  width:34px;
  height:34px;
  border-radius:12px;
  padding:2px;
  background: linear-gradient(135deg, var(--chatAccentA), var(--chatAccentB));
  display:flex;
  align-items:center;
  justify-content:center;
  color:#061018;
  font-weight:950;
}

.refChatMeta{ min-width:0; }
.refChatTitle{
  font-weight:950;
  font-size:14px;
  line-height:1.15;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:240px;
}
.refChatSub{
  font-size:12px;
  color: var(--chatMuted);
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:260px;
}

.refChatClose{
  border:1px solid var(--chatLine);
  background: rgba(255,255,255,.04);
  color: var(--chatText);
  cursor:pointer;
  padding:8px 10px;
  border-radius:12px;
  font-weight:950;
}
.refChatClose:hover{
  border-color: rgba(10,132,255,.35);
  background: rgba(10,132,255,.08);
}

.refChatLog{
  flex:1;
  overflow:auto;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.refMsg{
  max-width:86%;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--chatLine);
  background: rgba(255,255,255,.03);
  color: var(--chatText);
  font-size:13.5px;
  line-height:1.35;
  white-space:pre-wrap;
  word-wrap:break-word;
}

.refMsg.user{
  margin-left:auto;
  background: rgba(10,132,255,.14);
  border-color: rgba(10,132,255,.30);
}

.refMsg.ai{
  margin-right:auto;
}

.refChips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:-4px;
}

.refChip{
  border:1px solid var(--chatLine);
  background: rgba(255,255,255,.03);
  color: var(--chatText);
  padding:7px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
}
.refChip:hover{
  border-color: rgba(10,132,255,.35);
  background: rgba(10,132,255,.08);
}

.refChatFoot{
  border-top:1px solid var(--chatLine);
  padding:10px;
  display:flex;
  gap:10px;
  align-items:center;
  background: rgba(255,255,255,.02);
}

.refChatInput{
  flex:1;
  border-radius:14px;
  border:1px solid var(--chatLine);
  background: rgba(255,255,255,.03);
  color: var(--chatText);
  padding:10px 12px;
  outline:none;
  font-size:13.5px;
}
.refChatInput::placeholder{ color: rgba(147,164,183,.85); }

.refChatSend{
  border:0;
  cursor:pointer;
  border-radius:14px;
  padding:10px 12px;
  font-weight:950;
  background: linear-gradient(135deg, var(--chatAccentA), var(--chatAccentB));
  color:#061018;
}

.refChatNote{
  padding:0 12px 12px;
  color: var(--chatMuted);
  font-size:11.5px;
  font-weight:900;
}

@media (max-width: 420px){
  .refChatBox{ height:78vh; }
}

/* ===== Portal embed (Web Portal) ===== */
.portalCard{
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,255,255,.03);
  overflow:hidden;
  box-shadow: 0 14px 34px rgba(0,0,0,.30);
}
.portalFrame{
  width:100%;
  height:760px;
  border:0;
  display:block;
  background:transparent;
}
@media (max-width:700px){
  .portalFrame{ height:720px; }
}
