/* =========================================================
   CAVIARZ - concept · shared styles
   black / white minimal · sparing emphasis
   ========================================================= */
:root{
  --white:#ffffff;
  --black:#0c0c0c;
  --mist:#9c9c9c;
  --line:rgba(12,12,12,.13);
  --line-light:rgba(255,255,255,.16);
  --margin:clamp(18px,3.6vw,52px);
  --gutter:clamp(10px,1.4vw,22px);
  --ease:cubic-bezier(.62,.05,.01,.99);
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:'Archivo',Helvetica,Arial,sans-serif;
  background:var(--white);
  color:var(--black);
  overflow-x:hidden;
  font-weight:400;
  letter-spacing:-.01em;
  line-height:1.4;
}
body.lock{overflow:hidden;height:100vh}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
.wrap{width:100%;padding-left:var(--margin);padding-right:var(--margin)}
.grid{display:grid;grid-template-columns:repeat(12,1fr);column-gap:var(--gutter)}
@media(max-width:900px){.grid{grid-template-columns:repeat(6,1fr)}}
.up{text-transform:uppercase}
.mist{color:var(--mist)}
.tnum{font-variant-numeric:tabular-nums}
.strong{font-weight:600}

/* ---- type scale (lighter by default; emphasis is the exception) ---- */
.t-label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:500}
.t-body{font-size:clamp(15px,1.1vw,17px);line-height:1.5;font-weight:400}
.t-mid{font-size:clamp(20px,2.4vw,32px);line-height:1.2;font-weight:400;letter-spacing:-.02em}
.t-big{font-size:clamp(34px,6vw,88px);line-height:1;font-weight:500;letter-spacing:-.03em}
.t-huge{font-size:clamp(48px,10.5vw,160px);line-height:.9;font-weight:600;letter-spacing:-.04em}

/* ---- media + graceful placeholder ---- */
.media{position:relative;overflow:hidden;background:#16161a}
/* shimmer skeleton while loading */
.media::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(100deg,#141418 28%,#27272e 50%,#141418 72%);
  background-size:220% 100%;animation:shimmer 1.5s linear infinite}
.media.loaded::after,.media.ph::after{display:none}
.media img,.media .ph-fill{position:relative;z-index:1}
.media img{opacity:0;transition:opacity .9s var(--ease)}
.media img.loaded{opacity:1}
@keyframes shimmer{0%{background-position:220% 0}100%{background-position:-220% 0}}
.media .ph-fill{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#1a1a1a,#2c2c2c);color:#cdcdcd;gap:6px;text-align:center;padding:16px}
.media.ph .ph-fill{display:flex;animation:phpulse 2.6s ease-in-out infinite}
.media.ph img{opacity:0!important}
@keyframes phpulse{0%,100%{opacity:.82}50%{opacity:1}}
.ph-fill .ph-name{font-size:11px;letter-spacing:.12em;text-transform:uppercase;opacity:.5}
.ph-fill .ph-lab{font-size:clamp(13px,1.4vw,18px);font-weight:500;letter-spacing:.02em}

/* =========================================================
   PRELOADER (index only)
   ========================================================= */
.loader{position:fixed;inset:0;z-index:9999;background:#000;display:flex;align-items:center;justify-content:center;overflow:hidden}
.loader-video{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:min(78vw,720px);max-height:78vh;height:auto;object-fit:contain;display:none}
@media(max-width:900px){.loader-video{width:min(86vw,520px)}}
.loader-fallback{position:absolute;inset:0;display:none;align-items:center;justify-content:center}
.loader-word{overflow:hidden;color:var(--white)}
.loader-word .lw{display:inline-block;transform:translateY(110%);font-size:clamp(40px,9vw,130px);font-weight:700;letter-spacing:-.04em}
.loader-sub{position:absolute;bottom:var(--margin);left:var(--margin);color:var(--white);overflow:hidden}
.loader-sub .ls{display:block;transform:translateY(110%);font-size:12px;letter-spacing:.06em;text-transform:uppercase;line-height:1.5;opacity:.55}
.loader-count{position:absolute;bottom:var(--margin);right:var(--margin);color:var(--white);font-size:clamp(40px,9vw,120px);font-weight:600;letter-spacing:-.03em;line-height:.8}
.loader-bar{position:absolute;left:0;bottom:0;height:2px;background:var(--white);width:0%}

/* =========================================================
   PAGE TRANSITION (all pages) - staggered columns
   ========================================================= */
.transition{position:fixed;inset:0;z-index:8000;pointer-events:none;display:none}
.transition.show{display:flex}
.transition .col{flex:1;background:var(--black);transform:scaleY(1);transform-origin:top}

/* =========================================================
   HEADER
   ========================================================= */
.header{position:fixed;top:0;left:0;width:100%;z-index:600;mix-blend-mode:difference;color:#fff;
  padding:22px var(--margin);display:flex;align-items:center;justify-content:space-between}
.header .logo{font-size:22px;font-weight:700;letter-spacing:.02em}
.header nav{display:flex;gap:26px;font-size:13px;letter-spacing:.01em}
.header nav a{position:relative}
.header nav a::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.header nav a:hover::after{transform:scaleX(1);transform-origin:left}
.header .meta{display:flex;gap:22px;font-size:12px;letter-spacing:.04em;text-transform:uppercase;align-items:center}
.header .meta .op{opacity:.55}
@media(max-width:900px){.header nav,.header .meta{display:none}}
.burger{display:none;font-size:13px;letter-spacing:.04em;text-transform:uppercase}
@media(max-width:900px){.burger{display:block}}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;height:100vh;width:100%;overflow:hidden;background:var(--black)}
.hero .media{position:absolute;inset:-14% 0;height:128%}
.hero .veil{position:absolute;inset:0;background:rgba(12,12,12,.30)}
.hero .veil2{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.4),rgba(0,0,0,0) 32%,rgba(0,0,0,0) 58%,rgba(0,0,0,.6))}
.hero-inner{position:absolute;inset:0;color:#fff;padding:0 var(--margin) var(--margin);display:flex;flex-direction:column;justify-content:flex-end}
.hero-title{max-width:14ch;margin-bottom:auto;margin-top:23vh}
.hero-title .line{overflow:hidden}
.hero-title .line span{display:inline-block;transform:translateY(105%)}
.hero-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:20px}
.hero-bottom h1{max-width:34ch;font-weight:400;opacity:.92}
.scrolldown{font-size:12px;letter-spacing:.05em;text-transform:uppercase;opacity:.7;display:flex;gap:4px}
.scrolldown .dot{animation:bob 1.6s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}

/* =========================================================
   SECTION SHELL
   ========================================================= */
.sec{position:relative;padding:clamp(80px,11vw,170px) 0}
.subtitle{display:flex;gap:14px;align-items:baseline;font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:500}
.subtitle .n{color:var(--mist)}

/* ---- ABOUT ---- */
.about .sticky-img{position:sticky;top:13vh}
.about .media{aspect-ratio:3/4}
.about .lead{max-width:46ch}
.offset-title{font-weight:500}

/* =========================================================
   AANBOD (work list) - fixed image slot per item
   ========================================================= */
.aanbod-head{display:flex;justify-content:space-between;align-items:flex-end;border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:clamp(40px,6vw,90px)}
.work-list{display:flex;flex-direction:column;gap:clamp(60px,9vw,150px)}
.work-item{display:block}
.work-titlebar{position:relative;display:flex;justify-content:center;align-items:center;gap:18px;margin-bottom:clamp(20px,3vw,46px)}
.work-titlebar .brk{color:var(--mist);transition:transform .55s var(--ease);font-weight:500}
.work-item:hover .brk.l{transform:translateX(-16px)}
.work-item:hover .brk.r{transform:translateX(16px)}
.work-title{text-align:center;font-weight:500;transition:opacity .4s var(--ease)}
.work-item:hover .work-title{opacity:.55}
.work-mediawrap{margin:0 auto;width:min(72%,820px)}
.work-media{position:relative;width:100%;aspect-ratio:16/10;overflow:hidden}
.work-media img{transform:scale(1.18)}
.work-meta{display:flex;justify-content:space-between;font-size:13px;color:var(--mist);margin-top:16px;letter-spacing:.02em}
.work-meta .price{color:var(--black)}
.work-meta .go{color:var(--black);display:inline-flex;gap:6px;align-items:center}
@media(max-width:900px){.work-mediawrap{width:100%}}

/* =========================================================
   HUIDIG AANBOD - pinned scatter (multi-speed)
   ========================================================= */
.inv{position:relative;background:var(--white)}
/* tall scroll zone; the count stays pinned (slowest) while photos fly vertically past */
.inv-pin{position:relative;height:320vh}
.inv-sticky{position:sticky;top:0;height:100vh;overflow:hidden}
.inv-cta{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:6;pointer-events:none}
.inv-cta a{pointer-events:auto;display:flex;gap:14px;align-items:baseline;font-weight:600;color:var(--black)}
.inv-cta sup{font-size:.34em;color:var(--mist)}
.inv-scatter{position:absolute;inset:0}
.inv-card{position:absolute;overflow:hidden;will-change:transform}
.inv-card .media{width:100%;height:100%}

/* =========================================================
   WAAROM - dark, pinned, big horizontal sweep
   ========================================================= */
.why{background:var(--black);color:#fff;position:relative;z-index:2}
.why-pin{height:300vh;position:relative}
.why-sticky{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.why-marquee{position:relative;display:flex;white-space:nowrap;gap:1.1em;font-weight:600;letter-spacing:-.03em;font-size:clamp(36px,7vw,104px);line-height:1;will-change:transform}
.why-marquee .m{opacity:.26;transition:opacity .5s var(--ease)}
.why-marquee .m.on{opacity:1}
.why-row{display:flex;align-items:center;gap:24px;margin:44px var(--margin) 0;font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.why-row .line{flex:1;height:1px;background:var(--line-light)}
.why-content{margin:32px var(--margin) 0;position:relative;min-height:6em}
.why-c{position:absolute;inset:0;max-width:54ch;font-size:clamp(18px,2vw,26px);line-height:1.4;font-weight:400;opacity:0;transform:translateY(14px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.why-c.on{opacity:1;transform:none}
.why-c b{font-weight:600}

/* =========================================================
   IMPORT teaser (homepage) - to the point
   ========================================================= */
.import .media{aspect-ratio:16/10}
.import .panel{display:flex;flex-direction:column;justify-content:center;gap:22px}
.btn{display:inline-flex;gap:10px;align-items:center;align-self:flex-start;border:1px solid var(--black);
  border-radius:40px;padding:12px 22px;font-size:13px;letter-spacing:.04em;text-transform:uppercase;font-weight:500;transition:.4s var(--ease)}
.btn:hover{background:var(--black);color:#fff}
.btn.light{border-color:rgba(255,255,255,.4);color:#fff}
.btn.light:hover{background:#fff;color:var(--black)}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--black);color:#fff;padding:clamp(70px,9vw,130px) 0 0;position:relative;z-index:2}
.footer a:hover{color:var(--mist)}
.footer .cols{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:40px}
@media(max-width:900px){.footer .cols{grid-template-columns:1fr;gap:48px}}
.footer .lead{font-size:clamp(22px,2.4vw,34px);font-weight:400;letter-spacing:-.02em}
.footer .underline{border-bottom:1px solid #fff;padding-bottom:3px}
.foot-list{display:flex;flex-direction:column;gap:8px}
.foot-rows{display:flex;flex-direction:column;gap:14px;font-size:14px}
.foot-rows .r{display:flex;gap:24px}
.foot-rows .k{color:var(--mist);width:14px}
.newsletter{display:flex;justify-content:space-between;border-bottom:1px solid #fff;gap:16px;margin-top:32px;max-width:340px}
.newsletter input{background:none;border:0;outline:0;color:#fff;font-family:inherit;font-size:15px;padding:8px 0;width:100%}
.newsletter input::placeholder{color:rgba(255,255,255,.55)}
.newsletter button{background:none;border:0;color:#fff;cursor:pointer;font-size:18px}
.foot-word{overflow:hidden;margin-top:clamp(60px,8vw,120px);padding:0 var(--margin) 26px}
.foot-word svg{width:100%;height:auto;display:block}
.foot-bar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:22px var(--margin);
  border-top:1px solid var(--line-light);font-size:12px;color:var(--mist);letter-spacing:.03em}
.backtop{cursor:pointer}

/* progress bar */
.prog{position:fixed;top:0;left:0;height:2px;background:#fff;width:0;z-index:700;mix-blend-mode:difference}

/* reveal defaults (set by JS) */
[data-reveal]{opacity:0}

/* =========================================================
   CAR DETAIL PAGE
   ========================================================= */
.car-hero{position:relative;height:92vh;overflow:hidden;background:var(--black)}
.car-hero .media{position:absolute;inset:-12% 0;height:124%}
.car-hero .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,0) 40%,rgba(0,0,0,.55))}
.car-hero .cap{position:absolute;left:var(--margin);right:var(--margin);bottom:var(--margin);color:#fff;display:flex;justify-content:space-between;align-items:flex-end;gap:20px}
.car-hero .cap .name{font-weight:500;letter-spacing:-.03em;line-height:.95}
.car-hero .cap .price{font-weight:400}
.car-back{position:absolute;top:calc(var(--margin) + 40px);left:var(--margin);color:#fff;font-size:13px;letter-spacing:.04em;text-transform:uppercase;z-index:5;mix-blend-mode:difference}
.specs{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gutter);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
@media(max-width:900px){.specs{grid-template-columns:repeat(2,1fr)}}
.spec{padding:30px 0}
.spec .k{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--mist);margin-bottom:10px}
.spec .v{font-size:clamp(24px,3vw,40px);font-weight:500;letter-spacing:-.02em}
.car-gallery{display:flex;flex-direction:column;gap:var(--gutter)}
.car-gallery .row{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--gutter);align-items:center}
.car-gallery .media{overflow:hidden}
.car-gallery .media img{transform:scale(1.14)}
.car-next{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:30px}
.car-next .t-big{font-weight:500}

/* =========================================================
   AANBOD OVERVIEW (grid + filter)
   ========================================================= */
.filter{display:flex;gap:10px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:24px;margin-bottom:clamp(30px,4vw,60px)}
.filter button{font-family:inherit;background:none;border:1px solid var(--line);border-radius:40px;padding:9px 18px;font-size:13px;
  letter-spacing:.02em;cursor:pointer;color:var(--mist);transition:.35s var(--ease)}
.filter button.on,.filter button:hover{background:var(--black);color:#fff;border-color:var(--black)}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter) var(--gutter);row-gap:clamp(36px,5vw,72px)}
@media(max-width:900px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cat-grid{grid-template-columns:1fr}}
.cat-card{display:block}
.cat-card .media{aspect-ratio:4/3;overflow:hidden;margin-bottom:16px}
.cat-card .media img{transform:scale(1.05);transition:transform .8s var(--ease),opacity .9s var(--ease)}
.cat-card:hover .media img{transform:scale(1.1)}
.cat-card .row{display:flex;justify-content:space-between;align-items:baseline}
.cat-card .nm{font-size:clamp(18px,1.5vw,22px);font-weight:500;letter-spacing:-.01em}
.cat-card .pr{font-size:14px}
.cat-card .sub{font-size:13px;color:var(--mist);margin-top:4px}
.cat-card.hide{display:none}

/* =========================================================
   COMING SOON
   ========================================================= */
.cs-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.cs-item{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--gutter);align-items:center;
  padding:clamp(26px,3vw,44px) 0;border-bottom:1px solid var(--line);position:relative}
.cs-item .idx{grid-column:1/2;color:var(--mist);font-size:13px}
.cs-item .nm{grid-column:2/7;font-size:clamp(24px,3.4vw,52px);font-weight:500;letter-spacing:-.03em}
.cs-item .meta{grid-column:7/10;color:var(--mist);font-size:14px}
.cs-item .eta{grid-column:10/13;text-align:right;font-size:13px;text-transform:uppercase;letter-spacing:.06em}
/* coming-soon rows with their own fixed-place thumbnail (no cursor link) */
.cs-item.has-thumb .nm{grid-column:2/8}
.cs-item.has-thumb .eta{grid-column:11/13}
.cs-thumb-inline{grid-column:8/11;aspect-ratio:4/3;overflow:hidden;filter:grayscale(1);align-self:center}
.cs-sub{display:block;font-size:13px;color:var(--mist);margin-top:8px;font-weight:400;letter-spacing:0}
@media(max-width:900px){
  .cs-item .nm{grid-column:1/7}.cs-item .meta{display:none}
  .cs-item.has-thumb .nm{grid-column:1/5}.cs-thumb-inline{grid-column:5/7}.cs-item.has-thumb .eta{display:none}
}

/* page intro headline block (sub pages) */
.page-head{padding:calc(var(--margin) + 90px) 0 clamp(40px,6vw,90px)}
.page-head h1{font-weight:500;letter-spacing:-.03em;max-width:18ch}
.page-head .sub{color:var(--mist);max-width:46ch;margin-top:22px}
