:root{
	--bg:#070512;
	--bg2:#0b0620;
	--ink:#f4f1ff;
	--muted:rgba(244,241,255,.72);
	--glass:rgba(255,255,255,.06);
	--stroke:rgba(255,255,255,.10);
	--p1:#6d28ff;     /* purple */
	--p2:#b14cff;     /* magenta */
	--p3:#2ee9ff;     /* cyan */
	--shadow: 0 18px 55px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
	margin:0;
	font-family:"Space Grotesk", system-ui, -apple-system, Segoe UI, Roboto, Arial;
	color:var(--ink);
	background: #070512;
	overflow-x:hidden;
}

/* Fixed achtergrondlaag met jouw gradients */
body::before{
	content:"";
	position: fixed;
	inset: 0;
	z-index: 0;
	pointer-events: none;

	background:
			radial-gradient(1200px 700px at 70% 10%, rgba(109,40,255,.30), transparent 60%),
			radial-gradient(900px 600px at 20% 20%, rgba(46,233,255,.16), transparent 55%),
			radial-gradient(900px 700px at 60% 90%, rgba(177,76,255,.14), transparent 60%),
			linear-gradient(180deg, #070512, #0b0620);

	background-repeat: no-repeat;     /* voorkomt “tiles” */
	background-size: cover;           /* vult altijd */
}


/* Subtle animated grid overlay */
.grid-overlay{
	position:fixed; inset:0;
	pointer-events:none;
	opacity:.35;
	background:
			linear-gradient(to right, rgba(255,255,255,.08) 1px, transparent 1px),
			linear-gradient(to bottom, rgba(255,255,255,.06) 1px, transparent 1px);
	background-size: 42px 42px;
	mask-image: radial-gradient(600px 400px at 50% 30%, black 35%, transparent 70%);
	mix-blend-mode: overlay;
	transform: translateZ(0);
}

/* Top progress bar */
.progress{
	position:fixed; top:0; left:0; height:3px; width:100%;
	z-index:999;
	background: rgba(255,255,255,.06);
	backdrop-filter: blur(8px);
}
.progress__bar{
	height:100%;
	width:0%;
	background: linear-gradient(90deg, var(--p3), var(--p1), var(--p2));
	box-shadow: 0 0 18px rgba(109,40,255,.65);
	transform-origin:left center;
}

/* Layout */
.wrap{
	width:min(1120px, 92vw);
	margin:0 auto;
	position:relative;
	z-index:2;
}

header{
	min-height:100vh;
	display:flex;
	align-items:center;
	position:relative;
	padding: 110px 0 70px;
}

nav{
	position:fixed;
	top:18px; left:50%;
	transform:translateX(-50%);
	z-index:1000;
	width:min(1120px, 92vw);
	display:flex;
	justify-content:space-between;
	align-items:center;
	padding: 12px 14px;
	border-radius: 999px;
	background: rgba(6,4,16,.55);
	border: 1px solid rgba(255,255,255,.10);
	backdrop-filter: blur(14px);
	box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
.brand{
	display:flex; gap:10px; align-items:center;
	text-decoration:none; color:var(--ink);
	font-weight:700; letter-spacing:.3px;
}
.brand__dot{
	width:10px; height:10px; border-radius:999px;
	background: linear-gradient(135deg, var(--p3), var(--p1), var(--p2));
	box-shadow: 0 0 22px rgba(46,233,255,.45);
}
.navlinks{display:flex; gap:10px; align-items:center}
.navlinks a{
	color: var(--muted);
	text-decoration:none;
	font-weight:600;
	padding: 10px 12px;
	border-radius: 999px;
	border:1px solid transparent;
	transition: .2s ease;
}
.navlinks a:hover{
	color: var(--ink);
	border-color: rgba(255,255,255,.12);
	background: rgba(255,255,255,.04);
}

.hero{
	display:grid;
	grid-template-columns: 1.2fr .8fr;
	gap: 42px;
	align-items:center;
}

.kicker{
	display:inline-flex;
	gap:10px;
	align-items:center;
	padding: 8px 12px;
	border-radius: 999px;
	border:1px solid rgba(255,255,255,.12);
	background: rgba(255,255,255,.05);
	color: var(--muted);
	width: fit-content;
}
.kicker b{color:var(--ink)}
.hero h1{
	font-size: clamp(2.2rem, 4.2vw, 4rem);
	line-height:1.05;
	margin: 14px 0 14px;
	letter-spacing:-.02em;
}
.grad{
	background: linear-gradient(90deg, var(--p3), var(--p1), var(--p2));
	-webkit-background-clip:text;
	background-clip:text;
	color:transparent;
}
.hero p{
	color: var(--muted);
	font-size: 1.06rem;
	line-height: 1.7;
	max-width: 56ch;
	margin: 0 0 22px;
}
.cta{
	display:flex; flex-wrap:wrap; gap:12px;
	align-items:center;
}
.btn{
	display:inline-flex;
	gap:10px;
	align-items:center;
	text-decoration:none;
	padding: 12px 16px;
	border-radius: 14px;
	font-weight:700;
	letter-spacing:.2px;
	border:1px solid rgba(255,255,255,.12);
	background: rgba(255,255,255,.05);
	color: var(--ink);
	transition: .2s ease;
	box-shadow: 0 10px 26px rgba(0,0,0,.18);
}
.btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,.07); }
.btn--primary{
	border-color: rgba(109,40,255,.35);
	background: linear-gradient(135deg, rgba(109,40,255,.55), rgba(46,233,255,.20));
	box-shadow: 0 16px 45px rgba(109,40,255,.18);
}
.meta{
	display:flex; gap:18px; flex-wrap:wrap;
	margin-top: 18px;
	color: rgba(244,241,255,.62);
	font-weight:600;
	font-size:.92rem;
}
.meta span{
	padding: 8px 10px;
	border-radius: 999px;
	border:1px solid rgba(255,255,255,.10);
	background: rgba(255,255,255,.03);
}

/* Hero orb */
.orb{
	position:relative;
	height: 440px;
	border-radius: 28px;
	overflow:hidden;
	border:1px solid rgba(255,255,255,.10);
	background:
			radial-gradient(260px 260px at 70% 30%, rgba(46,233,255,.35), transparent 55%),
			radial-gradient(320px 320px at 30% 65%, rgba(109,40,255,.55), transparent 60%),
			radial-gradient(260px 260px at 60% 80%, rgba(177,76,255,.35), transparent 65%),
			linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
	box-shadow: var(--shadow);
}
.orb::before{
	content:"";
	position:absolute; inset:-2px;
	background:
			conic-gradient(from 180deg, rgba(46,233,255,.65), rgba(109,40,255,.65), rgba(177,76,255,.65), rgba(46,233,255,.65));
	filter: blur(28px);
	opacity:.55;
	transform: translateZ(0);
}
.orb__inner{
	position:absolute; inset:0;
	display:flex;
	align-items:flex-end;
	justify-content:space-between;
	padding: 18px;
}
.chip{
	border-radius: 16px;
	border:1px solid rgba(255,255,255,.12);
	background: rgba(10,7,26,.55);
	backdrop-filter: blur(12px);
	padding: 12px 14px;
	max-width: 210px;
}
.chip small{color:rgba(244,241,255,.65); font-weight:600}
.chip b{display:block; margin-top:4px}
.pulse{
	width: 12px; height: 12px; border-radius:999px;
	background: var(--p3);
	box-shadow: 0 0 0 0 rgba(46,233,255,.55);
}

/* Sections */
section{
	padding: 80px 0;
	position:relative;
}
.section-title{
	display:flex;
	align-items:flex-end;
	justify-content:space-between;
	gap:16px;
	margin-bottom: 26px;
}
.section-title h2{
	margin:0;
	font-size: clamp(1.6rem, 2.6vw, 2.3rem);
	letter-spacing:-.01em;
}
.section-title p{
	margin:0;
	color: var(--muted);
	max-width: 56ch;
	line-height:1.6;
}

/* Portfolio grid */
.grid{
	display:grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 16px;
}
.card{
	grid-column: span 6;
	border-radius: 22px;
	border:1px solid rgba(255,255,255,.10);
	background: rgba(255,255,255,.04);
	overflow:hidden;
	box-shadow: 0 16px 45px rgba(0,0,0,.28);
	position:relative;
	transform: translateZ(0);
}
.card::after{
	content:"";
	position:absolute; inset:0;
	background: radial-gradient(500px 220px at 20% 0%, rgba(109,40,255,.22), transparent 60%),
	radial-gradient(420px 280px at 90% 10%, rgba(46,233,255,.16), transparent 55%);
	opacity:.9;
	pointer-events:none;
}
.card__media{
	height: 210px;
	position:relative;
	overflow:hidden;
	background:
			linear-gradient(135deg, rgba(109,40,255,.25), rgba(46,233,255,.12)),
			radial-gradient(280px 180px at 70% 30%, rgba(177,76,255,.25), transparent 60%),
			rgba(255,255,255,.03);
}
.card__media img{
	width:100%; height:100%;
	object-fit: cover;
	display:block;
	opacity:.92;
	transform: scale(1.06);
	filter: saturate(1.05) contrast(1.05);
}
.card__body{
	position:relative;
	padding: 16px 16px 18px;
	z-index:1;
}
.tagrow{
	display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px;
}
.tag{
	font-size:.78rem;
	font-weight:700;
	letter-spacing:.3px;
	padding: 6px 10px;
	border-radius: 999px;
	border:1px solid rgba(255,255,255,.12);
	background: rgba(255,255,255,.03);
	color: rgba(244,241,255,.80);
}
.card h3{
	margin: 0 0 8px;
	font-size: 1.25rem;
	letter-spacing:-.01em;
}
.card p{
	margin: 0 0 12px;
	color: rgba(244,241,255,.72);
	line-height:1.65;
}
.card a{
	text-decoration:none;
	color: var(--ink);
	font-weight:800;
	display:inline-flex;
	gap:10px;
	align-items:center;
	padding: 10px 12px;
	border-radius: 14px;
	border:1px solid rgba(255,255,255,.12);
	background: rgba(255,255,255,.03);
	transition:.2s ease;
}
.card a:hover{ transform: translateY(-1px); background: rgba(255,255,255,.06); }

/* About / contact cards */
.split{
	display:grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.panel{
	border-radius: 22px;
	border:1px solid rgba(255,255,255,.10);
	background: rgba(255,255,255,.04);
	padding: 18px;
	box-shadow: 0 16px 45px rgba(0,0,0,.22);
	position:relative;
	overflow:hidden;
}
.panel::after{
	content:"";
	position:absolute; inset:-1px;
	background: radial-gradient(460px 260px at 20% 0%, rgba(177,76,255,.20), transparent 62%),
	radial-gradient(400px 260px at 90% 10%, rgba(46,233,255,.12), transparent 58%);
	pointer-events:none;
	opacity:.9;
}
.panel > *{ position:relative; z-index:1; }
.panel h3{ margin:0 0 10px; font-size: 1.2rem; }
.panel p{ margin:0 0 14px; color: var(--muted); line-height:1.7; }
.contact{
	display:flex; flex-wrap:wrap; gap:10px;
}
.contact a{
	color: var(--ink);
	text-decoration:none;
	font-weight:800;
	padding: 10px 12px;
	border-radius: 14px;
	border:1px solid rgba(255,255,255,.12);
	background: rgba(255,255,255,.03);
	transition:.2s ease;
}
.contact a:hover{ transform: translateY(-1px); background: rgba(255,255,255,.06); }

footer{
	padding: 30px 0 50px;
	color: rgba(244,241,255,.55);
	text-align:center;
}

/* Small screens */
@media (max-width: 900px){
	.hero{ grid-template-columns: 1fr; }
	.orb{ height: 360px; }
	.card{ grid-column: span 12; }
	.split{ grid-template-columns: 1fr; }
	nav{ padding:10px 12px; }
	.navlinks{ gap:6px; }
	.navlinks a{ padding: 9px 10px; font-size:.95rem; }
}

/* reduce motion */
@media (prefers-reduced-motion: reduce){
	*{ scroll-behavior:auto !important; transition:none !important; animation:none !important; }
}

/* Work list (1 per row, image side-by-side) */
.worklist{
	display:flex;
	flex-direction:column;
	gap: 16px;
}

.work-item{
	display:flex;
	gap: 16px;
	border-radius: 22px;
	border:1px solid rgba(255,255,255,.10);
	background: rgba(255,255,255,.04);
	overflow:hidden;
	box-shadow: 0 16px 45px rgba(0,0,0,.22);
	position:relative;
	transform: translateZ(0);
}

.work-item::after{
	content:"";
	position:absolute; inset:0;
	background:
			radial-gradient(560px 260px at 18% 0%, rgba(109,40,255,.18), transparent 62%),
			radial-gradient(520px 260px at 90% 10%, rgba(46,233,255,.12), transparent 58%);
	pointer-events:none;
	opacity:.9;
}

.work-media{
	flex: 0 0 min(420px, 40%);
	position:relative;
	overflow:hidden;
	background:
			linear-gradient(135deg, rgba(109,40,255,.25), rgba(46,233,255,.12)),
			rgba(255,255,255,.03);
	min-height: 240px;
}

.work-media img{
	width:100%;
	height:100%;
	object-fit: cover;
	display:block;
	opacity:.92;
	transform: scale(1.06);
	filter: saturate(1.05) contrast(1.05);
}

.work-body{
	position:relative;
	z-index:1;
	padding: 18px 18px 20px;
	flex: 1;
	min-width: 0;
}

.work-body h3{
	margin: 0 0 10px;
	font-size: 1.35rem;
	letter-spacing:-.01em;
}

.work-body p{
	margin: 0;
	color: rgba(244,241,255,.74);
	line-height: 1.75;
	font-size: 1.02rem;
	max-width: 80ch; /* extra ruimte voor tekst */
}

/* Alternate layout (image right) */
.work-item--flip{
	flex-direction: row-reverse;
}

/* Small screens: stack */
@media (max-width: 900px){
	.work-item,
	.work-item--flip{
		flex-direction: column;
	}
	.work-media{
		flex-basis: auto;
		width: 100%;
		min-height: 220px;
	}
}

/* Work card CTA */
.work-cta{
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-top: 14px;

	padding: 12px 16px;
	border-radius: 14px;

	font-weight: 700;
	font-size: 0.95rem;
	letter-spacing: .2px;
	text-decoration: none;
	color: var(--ink);

	border: 1px solid rgba(255,255,255,.14);
	background:
			linear-gradient(
					135deg,
					rgba(109,40,255,.45),
					rgba(46,233,255,.18)
			);

	box-shadow:
			0 10px 28px rgba(109,40,255,.18),
			inset 0 0 0 1px rgba(255,255,255,.04);

	transition:
			transform .18s ease,
			box-shadow .18s ease,
			background .18s ease;
}

.work-cta .arrow{
	display:inline-block;
	transition: transform .18s ease;
}

/* Hover */
.work-cta:hover{
	transform: translateY(-1px);
	box-shadow:
			0 16px 45px rgba(109,40,255,.28),
			inset 0 0 0 1px rgba(255,255,255,.08);
}

.work-cta:hover .arrow{
	transform: translateX(4px);
}
