/* ═══════════════════════════════════════════
   TEMPLATE: STUDIO — Portfolio / Creatief
   Masonry, grote foto's, hover overlays, minimal
   ═══════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=DM+Serif+Display&display=swap');

:root {
  --c: #6366f1;
  --c-light: #818cf8;
  --c-dark: #4f46e5;
  --c-10: rgba(99,102,241,.08);
  --accent: #f43f5e;
  --bg: #fafafa;
  --bg-alt: #f3f4f6;
  --card: #ffffff;
  --text: #111827;
  --text-muted: #6b7280;
  --border: #e5e7eb;
  --radius: 12px;
  --ease: cubic-bezier(.22,1,.36,1);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body { font-family:'Space Grotesk',system-ui,sans-serif; background:var(--bg); color:var(--text); line-height:1.65; }
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }

/* Typography */
h1,h2,h3 { font-family:'DM Serif Display',Georgia,serif; font-weight:400; letter-spacing:-.01em; }
.display { font-size:clamp(3rem,8vw,6rem); line-height:.9; letter-spacing:-.04em; }
.h1 { font-size:clamp(2rem,5vw,3.5rem); line-height:1; }
.h2 { font-size:clamp(1.5rem,3vw,2.2rem); line-height:1.1; }
.tag { font-family:'Space Grotesk',sans-serif; font-size:.7rem; font-weight:600; text-transform:uppercase; letter-spacing:.16em; color:var(--c); }
.muted { color:var(--text-muted); }

/* Container */
.w { max-width:1200px; margin:0 auto; padding:0 24px; }
.w-wide { max-width:1400px; margin:0 auto; padding:0 24px; }

/* Nav — ultra minimal */
.nav { position:fixed; top:0; left:0; right:0; z-index:100; padding:20px 28px; display:flex; justify-content:space-between; align-items:center; mix-blend-mode:difference; }
.nav * { color:#fff !important; }
.nav-logo { font-family:'DM Serif Display',serif; font-size:1.4rem; }
.nav-links { display:flex; gap:24px; }
.nav-links a { font-size:.82rem; font-weight:500; letter-spacing:.04em; opacity:.7; transition:opacity .3s; }
.nav-links a:hover { opacity:1; }
.nav-cta { border:1px solid rgba(255,255,255,.3); padding:8px 20px; border-radius:50px; font-size:.78rem; font-weight:600; transition:all .3s; }
.nav-cta:hover { background:#fff; color:#111 !important; mix-blend-mode:normal; }

/* Hero — fullscreen met grote tekst */
.hero { min-height:100vh; display:flex; align-items:flex-end; position:relative; padding:0 0 80px; overflow:hidden; }
.hero-bg { position:absolute; inset:0; }
.hero-bg img { width:100%; height:100%; object-fit:cover; }
.hero-ov { position:absolute; inset:0; background:linear-gradient(0deg, rgba(0,0,0,.7) 0%, rgba(0,0,0,.1) 50%, rgba(0,0,0,.3) 100%); }
.hero .w { position:relative; z-index:2; }
.hero .display { color:#fff; margin-bottom:16px; }
.hero p { color:rgba(255,255,255,.7); font-size:1.1rem; max-width:480px; }
.hero-scroll { position:absolute; bottom:32px; left:50%; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:8px; color:rgba(255,255,255,.5); font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; }
.hero-scroll::after { content:''; width:1px; height:40px; background:rgba(255,255,255,.3); animation:scrollPulse 2s infinite; }
@keyframes scrollPulse { 0%,100%{height:40px;opacity:.3} 50%{height:60px;opacity:.8} }

/* Section */
.sec { padding:clamp(5rem,10vw,8rem) 0; }
.sec-header { margin-bottom:clamp(2rem,5vw,4rem); }

/* Masonry Portfolio Grid */
.masonry { columns:3; column-gap:16px; }
.masonry-item { break-inside:avoid; margin-bottom:16px; position:relative; border-radius:var(--radius); overflow:hidden; cursor:pointer; }
.masonry-item img { width:100%; display:block; transition:transform .6s var(--ease); }
.masonry-item:hover img { transform:scale(1.05); }
.masonry-overlay { position:absolute; inset:0; background:linear-gradient(0deg, rgba(0,0,0,.8) 0%, transparent 60%); opacity:0; transition:opacity .4s; display:flex; flex-direction:column; justify-content:flex-end; padding:24px; }
.masonry-item:hover .masonry-overlay { opacity:1; }
.masonry-overlay h3 { color:#fff; font-size:1.1rem; margin-bottom:4px; }
.masonry-overlay p { color:rgba(255,255,255,.7); font-size:.82rem; }

/* Service Cards — horizontal */
.service-row { display:flex; gap:0; border-top:1px solid var(--border); }
.service-item { flex:1; padding:40px 32px; border-right:1px solid var(--border); transition:background .3s; position:relative; }
.service-item:last-child { border-right:none; }
.service-item:hover { background:var(--c-10); }
.service-num { font-family:'DM Serif Display',serif; font-size:3rem; color:var(--c); opacity:.2; position:absolute; top:20px; right:24px; }
.service-item h3 { font-size:1.2rem; margin-bottom:8px; }
.service-item p { font-size:.86rem; color:var(--text-muted); }

/* Stats — inline */
.stats-row { display:flex; gap:48px; padding:40px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.stat-val { font-family:'DM Serif Display',serif; font-size:2.8rem; color:var(--c); }
.stat-label { font-size:.78rem; color:var(--text-muted); margin-top:4px; text-transform:uppercase; letter-spacing:.08em; }

/* Testimonial — large quote */
.quote-section { background:var(--text); color:#fff; padding:clamp(5rem,10vw,8rem) 0; }
.quote-text { font-family:'DM Serif Display',serif; font-size:clamp(1.6rem,3vw,2.4rem); line-height:1.3; max-width:800px; position:relative; padding-left:40px; }
.quote-text::before { content:'"'; position:absolute; left:0; top:-10px; font-size:4rem; color:var(--c); }
.quote-author { margin-top:24px; padding-left:40px; }
.quote-author strong { display:block; font-size:.9rem; }
.quote-author span { font-size:.78rem; color:rgba(255,255,255,.5); }

/* CTA — minimal */
.cta-minimal { text-align:center; padding:clamp(5rem,10vw,8rem) 0; }
.cta-minimal .h1 { margin-bottom:24px; }
.btn-dark { display:inline-flex; align-items:center; gap:10px; background:var(--text); color:#fff; padding:16px 40px; border-radius:50px; font-weight:600; font-size:.9rem; transition:all .3s var(--ease); }
.btn-dark:hover { background:var(--c); transform:translateY(-3px); box-shadow:0 12px 32px rgba(99,102,241,.25); }
.btn-outline { display:inline-flex; align-items:center; gap:10px; border:1.5px solid var(--border); padding:16px 40px; border-radius:50px; font-weight:600; font-size:.9rem; transition:all .3s; }
.btn-outline:hover { border-color:var(--c); color:var(--c); }

/* Footer — minimal */
.footer { padding:40px 0; border-top:1px solid var(--border); }
.footer-inner { display:flex; justify-content:space-between; align-items:center; }
.footer-logo { font-family:'DM Serif Display',serif; font-size:1.2rem; }
.footer-links { display:flex; gap:24px; }
.footer-links a { font-size:.82rem; color:var(--text-muted); transition:color .2s; }
.footer-links a:hover { color:var(--c); }
.footer-copy { font-size:.72rem; color:var(--text-muted); margin-top:20px; text-align:center; }

/* Reveals */
.reveal { opacity:0; transform:translateY(30px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }
.stagger > *:nth-child(1){transition-delay:0ms} .stagger > *:nth-child(2){transition-delay:100ms} .stagger > *:nth-child(3){transition-delay:200ms} .stagger > *:nth-child(4){transition-delay:300ms} .stagger > *:nth-child(5){transition-delay:400ms} .stagger > *:nth-child(6){transition-delay:500ms}

/* Responsive */
@media(max-width:1024px) {
  .masonry { columns:2; }
  .service-row { flex-direction:column; }
  .service-item { border-right:none; border-bottom:1px solid var(--border); }
  .stats-row { flex-wrap:wrap; gap:32px; }
  .nav-links { display:none; }
}
@media(max-width:640px) {
  .masonry { columns:1; }
  .hero { min-height:80vh; }
  .footer-inner { flex-direction:column; gap:16px; text-align:center; }
}
