/* ============================================================
   Photobooth Tilburg — site.css
   Productie-stylesheet voor het redesign (Claude Design:
   "Photobooth Tilburg redesign"). Donker neon-thema.
   Fonts: Archivo (display, zwaar/uppercase) + Space Grotesk (tekst).
   Inline-styles in de pagina's verzorgen de fijne styling; deze file
   levert basis, keyframes, hover-states, het design-system, het
   mobiele menu en de responsive breakpoints.
   ============================================================ */

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:#050505;color:#fff;font-family:'Space Grotesk',sans-serif;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;}

/* ---- toegankelijkheid: zichtbare toetsenbordfocus, skip-link, beweging pauzeren ---- */
:focus-visible{outline:3px solid #00e5ff;outline-offset:2px;}
.skip-link{position:absolute;left:12px;top:-72px;z-index:200;background:#fff;color:#050505;font:800 13px/1 'Archivo',sans-serif;text-transform:uppercase;letter-spacing:.04em;padding:12px 18px;border-radius:0 0 12px 12px;transition:top .18s;}
.skip-link:focus{top:0;}
.mq-wrap:hover .mq,.mq-wrap:focus-within .mq{animation-play-state:paused;}

/* ---- keyframes ---- */
@keyframes mq{to{transform:translateX(-50%);}}
@keyframes shim{to{background-position:200% center;}}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(var(--r,0deg));}50%{transform:translateY(-16px) rotate(var(--r,0deg));}}
@keyframes hue{to{filter:hue-rotate(360deg);}}
/* reveal = alleen verschuiven, NIET faden — tekst blijft altijd vol contrast (WCAG) */
@keyframes rise{from{transform:translateY(42px);}to{transform:none;}}

/* ---- scroll-reveal + hover-utilities ---- */
.rise{animation:rise .8s cubic-bezier(.2,.7,.2,1) both;animation-timeline:view();animation-range:entry 0% cover 26%;}
.lift{transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,border-color .35s;}
.lift:hover{transform:translateY(-8px);}
.lift--cyan:hover{border-color:rgba(0,229,255,.45);box-shadow:0 24px 50px rgba(0,229,255,.12);}
.lift--gold:hover{border-color:rgba(232,192,125,.5);box-shadow:0 24px 50px rgba(232,192,125,.12);}
.lift--pink:hover{border-color:rgba(255,46,154,.7);box-shadow:0 24px 50px rgba(255,46,154,.16);}
.lift--purple:hover{border-color:rgba(124,77,255,.5);box-shadow:0 24px 50px rgba(124,77,255,.14);}
.lift--amber:hover{border-color:rgba(255,193,7,.5);box-shadow:0 24px 50px rgba(255,193,7,.12);}

/* ---- page chrome ---- */
.bg-glow{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(circle at 12% 8%,rgba(124,77,255,.22),transparent 34%),
             radial-gradient(circle at 88% 4%,rgba(0,229,255,.18),transparent 36%),
             radial-gradient(circle at 78% 88%,rgba(255,46,154,.18),transparent 38%),
             radial-gradient(circle at 8% 92%,rgba(255,193,7,.12),transparent 36%);
  animation:hue 22s linear infinite;}
.page{position:relative;z-index:1;}
.wrap{max-width:1200px;margin:0 auto;padding-left:40px;padding-right:40px;}

/* ---- type helpers (responsive via clamp) ---- */
.eyebrow{font:700 13px/1 'Archivo',sans-serif;letter-spacing:.16em;text-transform:uppercase;}
.h2{margin:0;font-family:'Archivo',sans-serif;font-weight:900;font-size:clamp(28px,5.2vw,46px);line-height:1.02;text-transform:uppercase;letter-spacing:-.01em;}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(5,5,5,.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.08);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding-top:18px;padding-bottom:18px;gap:16px;}
.nav-logo img{height:30px;width:auto;display:block;}
.nav-links{display:flex;align-items:center;gap:28px;font:700 13px/1 'Archivo',sans-serif;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.72);}
.nv{transition:color .2s;}
.nv:hover,.nv[aria-current="page"]{color:#fff;}
.nav-cta{display:flex;align-items:center;gap:16px;}
.nav-phone{font:700 14px/1 'Archivo',sans-serif;color:#fff;white-space:nowrap;}

/* hamburger (verborgen op desktop) */
.nav-toggle{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;}
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;padding:0 12px;border:1px solid rgba(255,255,255,.18);border-radius:12px;background:rgba(255,255,255,.04);cursor:pointer;}
.nav-burger span{display:block;height:2px;width:100%;background:#fff;border-radius:2px;transition:transform .3s cubic-bezier(.2,.7,.2,1),opacity .2s;}
.nav-toggle:focus-visible ~ header .nav-burger{outline:2px solid #00e5ff;outline-offset:2px;}
.nav-toggle:checked ~ header .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle:checked ~ header .nav-burger span:nth-child(2){opacity:0;}
.nav-toggle:checked ~ header .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* mobiel overlay-menu (alleen actief < 860px) */
.nav-mobile{display:none;}
.nav-mobile__close{position:absolute;top:16px;right:18px;width:46px;height:46px;display:flex;align-items:center;justify-content:center;font-size:30px;line-height:1;color:#fff;cursor:pointer;border-radius:12px;}
.nav-mobile__links{display:flex;flex-direction:column;align-items:center;gap:4px;}
.nav-mobile__links a{font:800 clamp(24px,7vw,32px)/1.5 'Archivo',sans-serif;text-transform:uppercase;letter-spacing:.02em;color:#fff;padding:6px 14px;}
.nav-mobile__links a[aria-current="page"]{background:linear-gradient(90deg,#00e5ff,#7c4dff,#ff2e9a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.nav-mobile__cta{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:30px;}
.nav-mobile__cta .btn-grad{padding:16px 34px;font-size:14px;}
.nav-mobile__phone{font:800 22px/1 'Archivo',sans-serif;color:#fff;}
.nav-mobile__wa{font:600 14px/1 'Space Grotesk',sans-serif;color:rgba(255,255,255,.65);}

/* ---- buttons ---- */
.btn-grad{display:inline-flex;align-items:center;justify-content:center;border-radius:100px;color:#050505;background:linear-gradient(90deg,#00e5ff,#7c4dff,#ff2e9a);background-size:200% auto;animation:shim 4s linear infinite;font-family:'Archivo',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.03em;}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;border-radius:100px;color:#fff;border:1px solid rgba(255,255,255,.25);font-family:'Archivo',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.03em;transition:border-color .2s;}
.btn-ghost:hover{border-color:rgba(255,255,255,.6);}

/* ---- marquee ---- */
.mq-wrap{overflow:hidden;border-bottom:1px solid rgba(255,255,255,.08);padding:11px 0;background:rgba(255,255,255,.02);}
.mq{display:flex;width:max-content;animation:mq 26s linear infinite;font:800 13px/1 'Archivo',sans-serif;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.6);}

/* ---- hero ---- */
.hero{display:grid;grid-template-columns:1.08fr .92fr;gap:40px;align-items:center;padding-top:64px;padding-bottom:56px;}
.hero-title{margin:0 0 20px;font-family:'Archivo',sans-serif;font-weight:900;font-size:clamp(40px,7.6vw,74px);line-height:.94;letter-spacing:-.02em;text-transform:uppercase;}
.hero-stats{display:flex;gap:34px;flex-wrap:wrap;}
.hero-art{position:relative;height:520px;}
.hero-card{position:absolute;border-radius:14px;overflow:hidden;box-shadow:0 26px 60px rgba(0,0,0,.6);border:2px solid rgba(255,255,255,.12);}
.hero-card img{width:100%;height:100%;object-fit:cover;display:block;}
/* crossfade-slideshow binnen elk zwevend kader (zie assets/js/hero.js) */
.hero-slide{position:absolute;inset:0;}
.hero-slide img{position:absolute;inset:0;opacity:0;transition:opacity 1s ease;}
.hero-slide img:first-child{opacity:1;}
.hero-card--a{top:8px;right:24px;width:310px;height:400px;--r:4deg;animation:floaty 7s ease-in-out infinite;}
.hero-card--b{bottom:8px;left:0;width:240px;height:300px;--r:-6deg;animation:floaty 6s ease-in-out infinite;}

/* ---- grids ---- */
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.booth-wide{grid-column:span 2;}
.booth-wide-inner{display:grid;grid-template-columns:.9fr 1.1fr;height:100%;}
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.cta-card{padding:56px 48px;}
.foot{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:40px;}
.fl{transition:color .2s;}
.fl:hover{color:#fff;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .features-grid{grid-template-columns:repeat(2,1fr);}
}

@media(max-width:860px){
  .wrap{padding-left:20px;padding-right:20px;}

  /* nav → hamburger */
  .nav-links{display:none;}
  .nav-cta .nav-phone,.nav-cta .btn-grad{display:none;}
  .nav-burger{display:flex;}

  .nav-mobile{display:flex;position:fixed;inset:0;z-index:60;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;
    background:rgba(5,5,5,.97);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .3s,transform .3s,visibility .3s;}
  .nav-toggle:checked ~ .nav-mobile{opacity:1;visibility:visible;transform:none;}
  html:has(.nav-toggle:checked){overflow:hidden;}

  /* hero stapelt */
  .hero{grid-template-columns:1fr;gap:24px;padding-top:36px;padding-bottom:32px;}
  .hero-art{height:420px;max-width:440px;}
  .hero-card--a{width:62%;height:300px;right:0;}
  .hero-card--b{width:48%;height:230px;left:0;bottom:0;}

  .trust,.grid-3,.reviews-grid{grid-template-columns:1fr;}
  .booth-wide{grid-column:auto;}
  .booth-wide-inner{grid-template-columns:1fr;}
  .foot{grid-template-columns:1fr 1fr;gap:28px;}
  .cta-card{padding:40px 26px;}
}

@media(max-width:560px){
  .features-grid{grid-template-columns:1fr;}
  .foot{grid-template-columns:1fr;}
  .hero-stats{gap:20px;}
  .hero-art{height:340px;}
  .hero-card--a{height:250px;width:66%;}
  .hero-card--b{height:190px;width:54%;}
  .cta-card{padding:32px 20px;}
}

/* respecteer reduced-motion */
@media(prefers-reduced-motion:reduce){
  .rise,.lift,.mq,.btn-grad,.bg-glow,.hero-card{animation:none!important;transition:none!important;}
  .rise{opacity:1;transform:none;}
}
