/* ---------- 0. THEME TOKENS ---------- */
:root{
  --font: "Outfit", system-ui, sans-serif;
  --radius: 1.25rem;

  /* colour scale */
  --bg-outer: #0e1013;
  --bg-inner: #1a1d22;
  --card-glass: hsla(0 0% 100% / .06);
  --card-stroke: hsla(0 0% 100% / .12);

  --accent: #3dd68c;
  --accent-hover: #29c27a;

  --text: #f5f7f8;
  --text-muted: #9ca2a8;
}

/* ---------- 1. GLOBAL RESET ---------- */
*,
*::before,
*::after{ box-sizing:border-box; }

html,body{
  height:100%;
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:
    radial-gradient(120% 100% at 50% -20%, var(--bg-inner) 0%, var(--bg-outer) 80%);
  overflow-x:hidden;
}

/* ---------- 1.1 VIDEO BACKGROUND ---------- */
#bg-video{
  position:fixed;
  top:0;left:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  pointer-events:none;
  opacity:1;
}

/* ---------- 1.2 VIGNETTE OVERLAY ---------- */
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-5;
  background:radial-gradient(circle at center,transparent 60%,rgba(0,0,0,.35));
}

/* ---------- 2. LANGUAGE ---------- */
.lang-switch{
  position:absolute;
  top:1.25rem;
  right:1.5rem;
  display:flex;
  gap:.5rem;
  font-size:.95rem;
  font-weight:500;
  color:var(--text-muted);
  letter-spacing:.02em;
}

/* ---------- 3. LAYOUT ---------- */
main{
  height:100%;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:5vh 0;
}

/* ---------- 4. GLASS CARD ---------- */


.card{
  width:min(90rem,100%);
  padding:clamp(1.75rem,0vw,4rem);
  backdrop-filter:blur(16px) saturate(160%);
  background:var(--card-glass);
  border:1px solid var(--card-stroke);
  border-radius:var(--radius);
  box-shadow:
    0 8px 24px rgba(0,0,0,.45),
    0 0 0 .5px rgba(255,255,255,.08) inset;
  text-align:center;
  position:relative;
  
}

/* top highlight */
.card::before{
  content:"";
  position:absolute;
  top:-1px;left:2px;right:2px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);
}

.card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.2); /* adjust to taste */
  border-radius: var(--radius);
  z-index: -1;
}


/* ---------- 5. TYPOGRAPHY ---------- */
h1{
  margin:0 0 0.75rem;          /* kleiner */
  font-size:clamp(2.1rem,4.5vw,3.5rem);
  line-height:1.13;
  font-weight:600;
}
.accent{ color:var(--accent); }

.lead{
  font-size:clamp(1.05rem,1.7vw,1.25rem);
  margin:0 0 1.25rem;          /* kleiner */
  color:var(--text);
}
.small{
  font-size:.8rem;
  color:var(--text-muted);
  margin-top:1rem;             /* kleiner */
}

/* ---------- 6. FORM ---------- */
form{
  display:grid;
  grid-template-columns:1fr auto;
  gap:1rem;
}
input[type=email]{
  padding:1rem 1.25rem;
  border-radius:9999px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.05);
  color:var(--text);
  font-size:.95rem;
  width:100%;
}
button{
  padding:1rem 1.75rem;
  border-radius:9999px;
  border:none;
  background:var(--accent);
  color:#031d11;
  font-weight:600;
  font-size:.95rem;
  cursor:pointer;
  transition:background .25s;
}
button:hover{ background:var(--accent-hover); }

/* thank-you replacement */
.thanks{
  font-size:1.05rem;
  font-weight:500;
  color:var(--accent);
}

/* ---------- 7. RESPONSIVE ---------- */
@media (max-width:600px){
  form{ grid-template-columns:1fr; }
  button{ width:100%; }
  .mobile-hide{ display:none; }
}

/* ---------- TEXT-BASED LANGUAGE SWITCH ---------- */
.lang-switch{
  position:absolute;
  z-index:20;
  top:1.25rem;
  right:1.5rem;
  display:flex;
  gap:.5rem;
  font-size:.95rem;
  font-weight:500;
  letter-spacing:.02em;
}

.lang{
  text-decoration:none;
  color:var(--text);
  opacity:.9;
  transition:opacity .2s;
}
.lang:hover{ opacity:1; }
.lang[aria-current]{
  opacity:1;
  font-weight:600;
  color:var(--accent);   /* geselecteerde taal = groen */
  cursor:default;
}
.divider{
  opacity:.6;
  color:var(--text);
}

/* ---------- BUTTON LINK ---------- */
.form-button{
  display:inline-block;
  padding:1rem 1.75rem;
  border-radius:9999px;
  background:var(--accent);
  color:#031d11;
  font-weight:600;
  font-size:.95rem;
  text-align:center;
  text-decoration:none;
  cursor:pointer;
  transition:background .25s;
  margin-top:1rem;
}
.form-button:hover{ background:var(--accent-hover); }