*{margin:0;padding:0;box-sizing:border-box;}

body{
  font-family:sans-serif;background:#0a0a0a;color:white;overflow-x:hidden;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.035'/%3E%3C/svg%3E");
}

/* ── CUSTOM CURSOR ── */
.cursor{
  position:fixed;width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(255,255,255,0.6);
  pointer-events:none;z-index:99999;
  transform:translate(-50%,-50%);
  transition:width .25s,height .25s,border-color .25s,background .25s;
  mix-blend-mode:difference;
}
.cursor-dot{
  position:fixed;width:5px;height:5px;border-radius:50%;
  background:white;pointer-events:none;z-index:99999;
  transform:translate(-50%,-50%);
}
.cursor.hover{width:60px;height:60px;background:rgba(255,255,255,0.08);border-color:white;}
body:not(.has-cursor) .cursor,
body:not(.has-cursor) .cursor-dot{display:none;}

/* ── FILM GRAIN ── */
.grain{position:fixed;inset:0;z-index:9998;width:100%;height:100%;pointer-events:none;opacity:.04;mix-blend-mode:screen;}

/* ── NAVBAR ── */
.navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:22px 6%;transition:background .4s,padding .4s;}
.navbar.scrolled{background:rgba(10,10,10,0.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:14px 6%;border-bottom:0.5px solid rgba(255,255,255,0.07);}
.nav-logo{font-family:"Playfair Display";font-style:italic;font-size:20px;color:white;text-decoration:none;}
.nav-links{list-style:none;display:flex;gap:36px;}
.nav-link{color:rgba(255,255,255,0.65);text-decoration:none;font-size:13px;letter-spacing:.1em;text-transform:uppercase;transition:color .2s;}
.nav-link:hover{color:white;}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;-webkit-tap-highlight-color:transparent;}
.nav-toggle span{display:block;width:24px;height:1.5px;background:white;transition:.3s;}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* ── HERO ── */
.hero{height:100svh;position:relative;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;}
.hero-video iframe{position:absolute;top:50%;left:50%;width:100vw;height:56.25vw;min-height:100%;min-width:177.77vh;transform:translate(-50%,-50%);pointer-events:none;}
.overlay{position:absolute;width:100%;height:100%;background:linear-gradient(to bottom,rgba(0,0,0,0.2),rgba(0,0,0,0.88));}
.hero-content{position:relative;z-index:2;max-width:700px;padding:20px;}
.hero-content h1{font-family:"Playfair Display";font-style:italic;font-size:clamp(42px,10vw,90px);line-height:1.05;margin-bottom:20px;}
.hero-content p{font-size:clamp(14px,3.5vw,18px);line-height:1.65;color:rgba(255,255,255,0.82);max-width:520px;margin:0 auto;}
.buttons{display:flex;gap:16px;justify-content:center;margin-top:32px;flex-wrap:wrap;}

/* ── BUTTONS ── */
.btn-primary{background:white;color:black;padding:14px 36px;text-decoration:none;transition:.3s;display:inline-block;font-size:13px;letter-spacing:.06em;-webkit-tap-highlight-color:transparent;}
.btn-primary:hover{background:#e0e0e0;}
.btn-secondary{border:1px solid rgba(255,255,255,0.6);padding:14px 36px;color:white;text-decoration:none;transition:.3s;display:inline-block;font-size:13px;letter-spacing:.06em;-webkit-tap-highlight-color:transparent;}
.btn-secondary:hover{background:white;color:black;}
.mag-btn{position:relative;will-change:transform;}

/* ── MARQUEE ── */
.marquee-wrap{overflow:hidden;border-top:0.5px solid rgba(255,255,255,0.1);border-bottom:0.5px solid rgba(255,255,255,0.1);padding:16px 0;white-space:nowrap;}
.marquee-track{display:inline-flex;align-items:center;animation:marquee 28s linear infinite;}
.marquee-track span{font-family:"Playfair Display";font-style:italic;font-size:clamp(13px,3vw,18px);color:rgba(255,255,255,0.45);padding:0 24px;letter-spacing:.04em;}
.marquee-track .dot{font-style:normal;padding:0;color:rgba(255,255,255,0.2);font-size:12px;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ── ABOUT ── */
.about-section{padding:120px 8%;}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.about-text{display:flex;flex-direction:column;gap:20px;}
.section-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,0.4);}
.about-text h2{font-family:"Playfair Display";font-size:clamp(32px,5vw,52px);line-height:1.15;font-style:normal;font-weight:600;}
.about-text h2 em{font-style:italic;font-weight:400;}
.about-text p{font-size:15px;line-height:1.75;color:rgba(255,255,255,0.65);}
.about-photo{aspect-ratio:3/4;background:#111;border-radius:4px;overflow:hidden;position:relative;}
.about-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.2);font-size:13px;letter-spacing:.1em;text-transform:uppercase;border:1px dashed rgba(255,255,255,0.1);}

/* ── STATS ── */
.stats-section{padding:60px 8%;border-top:0.5px solid rgba(255,255,255,0.08);border-bottom:0.5px solid rgba(255,255,255,0.08);}
.stats-inner{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap;}
.stat-item{text-align:center;padding:20px 48px;display:flex;flex-direction:column;align-items:center;gap:8px;}
.stat-number{font-family:"Playfair Display";font-style:italic;font-size:clamp(40px,6vw,72px);line-height:1;color:white;}
.stat-plus{font-family:"Playfair Display";font-style:italic;font-size:clamp(24px,4vw,48px);color:rgba(255,255,255,0.5);margin-left:2px;align-self:flex-start;margin-top:6px;}
.stat-label{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,0.38);}
.stat-divider{width:1px;height:60px;background:rgba(255,255,255,0.1);}

/* ── SECTIONS ── */
section.video-section{padding:100px 8%;}
.section-header{display:flex;align-items:baseline;gap:16px;margin-bottom:40px;}
.section-header h2{font-family:"Playfair Display";font-style:italic;font-size:clamp(28px,5vw,50px);margin-bottom:0;}
.video-count{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,0.3);}

/* ── HORIZONTAL VIDEO ROW ── */
.video-row{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;touch-action:pan-x;padding-bottom:12px;cursor:grab;}
.video-row.dragging{cursor:grabbing;}
.video-row::-webkit-scrollbar{display:none;}
.video-item{
  flex:0 0 auto;width:clamp(280px,80vw,600px);aspect-ratio:16/9;
  background-size:cover;background-position:center;
  border-radius:6px;cursor:pointer;scroll-snap-align:start;
  transition:transform .4s;position:relative;overflow:hidden;
  background-color:#111;
}
.video-item::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(0,0,0,0.55) 0%,transparent 50%);
  opacity:0;transition:opacity .3s;
}
.video-item:hover::before{opacity:1;}
.video-item:hover{transform:scale(1.03);}

/* Preview iframe bij hover */
.video-preview{
  position:absolute;inset:0;z-index:0;
  opacity:0;transition:opacity .5s;
  pointer-events:none;
}
.video-preview iframe{width:100%;height:100%;border:none;transform:scale(1.05);}
.video-item:hover .video-preview,
.vertical-video:hover .video-preview{opacity:1;}

/* Shimmer skeleton */
.video-item.loading,.vertical-video.loading{
  background-image:none !important;
  background:linear-gradient(90deg,#111 25%,#1a1a1a 50%,#111 75%) !important;
  background-size:200% 100% !important;
  animation:shimmer 1.4s infinite;
}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}

/* Category label */
.video-label{
  position:absolute;bottom:12px;left:12px;
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,0.75);background:rgba(0,0,0,0.5);
  backdrop-filter:blur(6px);padding:4px 10px;border-radius:2px;
  z-index:2;opacity:0;transform:translateY(4px);
  transition:opacity .3s,transform .3s;pointer-events:none;
}
.video-item:hover .video-label,
.vertical-video:hover .video-label{opacity:1;transform:translateY(0);}

/* ── VERTICAL VIDEO ROW ── */
.vertical-row{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;touch-action:pan-x;padding-bottom:12px;cursor:grab;}
.vertical-row.dragging{cursor:grabbing;}
.vertical-row::-webkit-scrollbar{display:none;}
.vertical-video{
  flex:0 0 auto;width:clamp(140px,55vw,290px);aspect-ratio:9/16;
  background-size:cover;background-position:center;
  border-radius:6px;cursor:pointer;scroll-snap-align:start;
  transition:transform .4s;position:relative;overflow:hidden;
  background-color:#111;-webkit-tap-highlight-color:transparent;
}
.vertical-video::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(0,0,0,0.55) 0%,transparent 50%);
  opacity:0;transition:opacity .3s;
}
.vertical-video:hover::before{opacity:1;}
.vertical-video:hover{transform:scale(1.02);}

/* ── CONTACT ── */
.contact-section{text-align:center;padding:120px 8%;}
.contact-section h2{font-family:"Playfair Display";font-style:italic;font-size:clamp(28px,5vw,50px);margin-bottom:20px;}
.contact-btn{display:flex;justify-content:center;margin-top:30px;}

/* ── FOOTER ── */
.footer{border-top:0.5px solid rgba(255,255,255,0.1);padding:50px 8% 40px;}
.footer-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:30px;margin-bottom:40px;}
.footer-tagline{font-family:"Playfair Display";font-style:italic;font-size:18px;color:rgba(255,255,255,0.45);}
.footer-socials{display:flex;gap:32px;flex-wrap:wrap;}
.social-link{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,0.45);text-decoration:none;font-size:12px;letter-spacing:.1em;text-transform:uppercase;transition:color .3s;-webkit-tap-highlight-color:transparent;}
.social-link:hover{color:white;}
.social-link svg{transition:transform .3s;}
.social-link:hover svg{transform:scale(1.15);}
.footer-bottom{font-size:11px;letter-spacing:.08em;color:rgba(255,255,255,0.2);text-transform:uppercase;}

/* ── MODAL ── */
.video-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.97);opacity:0;pointer-events:none;transition:opacity .3s;z-index:9999;}
.video-modal.active{opacity:1;pointer-events:auto;}
.modal-close{position:fixed;top:20px;right:20px;font-size:28px;background:rgba(0,0,0,0.6);border:1px solid rgba(255,255,255,0.2);color:white;cursor:pointer;z-index:10001;width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1;-webkit-tap-highlight-color:transparent;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .2s;}
.modal-close:hover{background:rgba(255,255,255,0.12);}
.modal-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;}
#modalVideo{background:black;display:block;}
#modalVideo iframe{display:block;border:none;width:100%;height:100%;}

/* ── MOBILE ── */
@media(max-width:768px){
  .grain{display:none;}
  .cursor,.cursor-dot{display:none !important;}
  .nav-toggle{display:flex;}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;
    width:100%;background:rgba(10,10,10,0.97);
    flex-direction:column;gap:0;padding:8px 0;
    border-bottom:0.5px solid rgba(255,255,255,0.08);
  }
  .nav-links.open{display:flex;}
  .nav-links li a{display:block;padding:16px 6%;font-size:14px;border-bottom:0.5px solid rgba(255,255,255,0.05);}
  section.video-section{padding:70px 5% 50px;}
  .about-section{padding:80px 5%;}
  .about-inner{grid-template-columns:1fr;gap:40px;}
  .about-photo{aspect-ratio:4/3;max-height:280px;}
  .stats-section{padding:40px 5%;}
  .stat-item{padding:16px 20px;}
  .stat-divider{height:40px;}
  .hero-content p{font-size:15px;}
  .buttons{flex-direction:column;align-items:center;gap:12px;}
  .btn-primary,.btn-secondary{width:100%;max-width:280px;text-align:center;padding:16px 24px;}
  .video-item{width:82vw;}
  .vertical-video{width:58vw;}
  .modal-close{top:14px;right:14px;width:48px;height:48px;font-size:24px;}
  /* FIX: op mobiel hoogte afhankelijk van video type via JS, CSS als fallback */
  #modalVideo{width:100vw !important;max-height:100svh !important;}
  .footer-top{flex-direction:column;align-items:flex-start;}
  .footer-socials{gap:20px;}
  .contact-section{padding:80px 5%;}
}

@media(max-width:390px){
  .vertical-video{width:72vw;}
  .video-item{width:88vw;}
  .stats-inner{flex-direction:column;gap:0;}
  .stat-divider{width:60px;height:1px;}
}
