/* AutoHalt — luxury automotive design system */
:root{
  --bg:          #0A0A0B;
  --bg-1:        #101114;
  --bg-2:        #16171A;
  --bg-3:        #1C1E22;
  --surface:     #22242A;
  --line:        #2A2D34;
  --line-2:      #383C44;
  --text:        #F6F6F7;
  --text-mute:   #B6B8BD;
  --text-dim:    #767A82;
  --platinum:    #E8E8EA;
  --ice:         oklch(0.82 0.045 230);
  --ice-2:       oklch(0.72 0.05 230);
  --ice-glow:    oklch(0.78 0.05 230 / 0.18);
  --hairline:    rgba(255,255,255,0.08);
  --hairline-2:  rgba(255,255,255,0.14);

  --shadow-1: 0 1px 0 rgba(255,255,255,.04) inset, 0 1px 2px rgba(0,0,0,.4);
  --shadow-2: 0 20px 60px -20px rgba(0,0,0,.6), 0 1px 0 rgba(255,255,255,.05) inset;
  --shadow-card: 0 30px 80px -40px rgba(0,0,0,.8), 0 1px 0 rgba(255,255,255,.05) inset;

  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
  --r-xl: 32px;

  --container: 1360px;

  --t-ease: cubic-bezier(.22,.61,.36,1);
  --t-spring: cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; background:var(--bg); }
body{
  font-family: "Geist", "Helvetica Neue", Helvetica, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 16px;
  line-height: 1.55;
  letter-spacing: -0.01em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }

/* ───────── Typography */
.eyebrow{
  font-family:"Geist Mono", "JetBrains Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--text-dim);
  font-weight: 500;
}
.display{
  font-family:"Geist", "Helvetica Neue", sans-serif;
  font-weight: 500;
  letter-spacing: -0.035em;
  line-height: 1.02;
  text-wrap: balance;
}
.editorial{
  font-family:"Instrument Serif", "Times New Roman", serif;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.01em;
}
.mono{ font-family:"Geist Mono","JetBrains Mono", ui-monospace, monospace; letter-spacing:.02em; }

h1,h2,h3,h4{ margin:0; font-weight:500; letter-spacing:-0.025em; }
h1{ font-size: clamp(48px, 7vw, 104px); line-height: 1.02; letter-spacing:-0.04em; font-weight:500; }
h2{ font-size: clamp(36px, 4.4vw, 64px); line-height: 1.06; letter-spacing:-0.035em; }
h3{ font-size: clamp(22px, 1.8vw, 28px); line-height: 1.2; }
p{ margin:0; }

/* ───────── Layout */
.container{ width:100%; max-width: var(--container); margin:0 auto; padding: 0 32px; }
section{ padding: 120px 0; position:relative; }
@media (max-width: 720px){
  section{ padding: 80px 0; }
  .container{ padding: 0 20px; }
}

.section-head{ display:flex; align-items:end; justify-content:space-between; gap:32px; margin-bottom: 56px; }
.section-head .left{ max-width: 720px; }
.section-head .eyebrow{ margin-bottom: 18px; display:block; }
@media (max-width:720px){ .section-head{ flex-direction:column; align-items:flex-start; } }

.hairline{ height:1px; background: var(--hairline); border:0; }

/* ───────── Header */
.nav{
  position: fixed; top:0; left:0; right:0;
  z-index: 100;
  padding: 18px 0;
  transition: backdrop-filter .3s ease, background .3s ease, padding .3s ease, border-color .3s ease;
  border-bottom: 1px solid transparent;
}
.nav.scrolled{
  background: rgba(10,10,11,0.72);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid var(--hairline);
  padding: 12px 0;
}
.nav-inner{ display:flex; align-items:center; gap: 36px; }
.brand{
  display:flex; align-items:center; gap:10px;
  font-weight: 500; letter-spacing:-0.02em;
  font-size: 18px;
}
.brand-mark{
  width: 32px; height: 32px;
  background-color: var(--text);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 84 84'><rect x='2' y='2' width='80' height='80' rx='8' fill='none' stroke='black' stroke-width='2.4' opacity='0.5'/><path d='M22 22 L22 62 M62 22 L62 62 M22 42 L62 42' stroke='black' stroke-width='5' stroke-linecap='square'/><circle cx='42' cy='42' r='2.8' fill='black'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 84 84'><rect x='2' y='2' width='80' height='80' rx='8' fill='none' stroke='black' stroke-width='2.4' opacity='0.5'/><path d='M22 22 L22 62 M62 22 L62 62 M22 42 L62 42' stroke='black' stroke-width='5' stroke-linecap='square'/><circle cx='42' cy='42' r='2.8' fill='black'/></svg>") center/contain no-repeat;
  transition: transform .35s var(--t-spring);
}
.brand:hover .brand-mark{ transform: scale(1.04); }
.brand-name{ font-weight:500; letter-spacing: -0.025em; }
.brand-name b{ font-weight:700; }

.nav-links{ display:flex; gap:6px; margin-left: 28px; }
.nav-links a{
  font-size: 14px; color: var(--text-mute);
  padding: 8px 14px; border-radius: 999px;
  transition: color .25s var(--t-ease), background .25s var(--t-ease);
}
.nav-links a:hover{ color:var(--text); background: rgba(255,255,255,.04); }
.nav-links a.active{ color: var(--text); }

.nav-cta{ margin-left:auto; display:flex; gap:10px; align-items:center; }
.icon-btn{
  width: 40px; height:40px; border-radius:999px;
  display:inline-grid; place-items:center;
  border: 1px solid var(--hairline-2);
  background: rgba(255,255,255,.02);
  transition: background .25s var(--t-ease), border-color .25s var(--t-ease), transform .25s var(--t-ease);
}
.icon-btn:hover{ background: rgba(255,255,255,.06); border-color: var(--hairline-2); }
.phone{
  font-size:13px; color:var(--text-mute); padding: 0 8px;
  font-variant-numeric: tabular-nums;
}
.phone:hover{ color:var(--text); }

.hamburger{ display:none; }
@media (max-width: 980px){
  .nav-links, .phone{ display:none; }
  .hamburger{ display:inline-grid; }
}

/* ───────── Mobile menu */
.mobile-menu{
  position: fixed; inset: 0; z-index: 200;
  background: var(--bg, #07070a);
  display: flex; flex-direction: column;
  padding: 24px;
  opacity: 0; visibility: hidden;
  transform: translateY(-8px);
  transition: opacity .3s var(--t-ease), transform .3s var(--t-ease), visibility .3s;
  overflow-y: auto;
}
.mobile-menu.open{ opacity: 1; visibility: visible; transform: none; }
.mobile-menu-close{ align-self: flex-end; }
.mobile-menu-links{
  display: flex; flex-direction: column; gap: 4px;
  margin-top: 24px; flex: 1;
}
.mobile-menu-links a{
  font-size: 28px; font-weight: 500; letter-spacing: -0.02em;
  padding: 14px 0; border-bottom: 1px solid var(--hairline);
  color: var(--text);
}
.mobile-menu-links a:active{ color: var(--text-mute); }
.mobile-menu-cta{
  display: flex; flex-direction: column; gap: 16px;
  padding-top: 24px; align-items: stretch;
}
.mobile-menu-cta .phone{ display: inline-block; padding: 0; text-align: center; }
.mobile-menu-cta .btn{ justify-content: center; }
body.menu-open{ overflow: hidden; }

/* ───────── Buttons */
.btn{
  display:inline-flex; align-items:center; gap: 10px;
  height: 48px; padding: 0 22px;
  border-radius: 999px;
  font-size: 14px; font-weight: 500;
  letter-spacing: -0.005em;
  transition: transform .25s var(--t-ease), background .25s var(--t-ease), color .25s var(--t-ease), border-color .25s var(--t-ease), box-shadow .35s var(--t-ease);
  position: relative;
  white-space: nowrap;
}
.btn .arr{ transition: transform .35s var(--t-spring); }
.btn:hover .arr{ transform: translateX(4px); }

.btn-primary{
  background: var(--platinum); color: #0A0A0B;
  box-shadow: 0 1px 0 rgba(255,255,255,.4) inset, 0 10px 30px -10px rgba(232,232,234,.25);
}
.btn-primary:hover{ background: #fff; box-shadow: 0 1px 0 rgba(255,255,255,.4) inset, 0 16px 36px -10px rgba(232,232,234,.35); }

.btn-ghost{
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--hairline-2);
  color: var(--text);
  backdrop-filter: blur(10px);
}
.btn-ghost:hover{ background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.22); }

.btn-ice{
  background: linear-gradient(180deg, oklch(0.85 0.05 230), oklch(0.72 0.06 230));
  color: #0A0A0B;
  box-shadow: 0 10px 30px -10px var(--ice-glow), 0 1px 0 rgba(255,255,255,.4) inset;
}

.btn-wa{
  background: #1FA855; color: #fff;
  box-shadow: 0 10px 30px -10px rgba(31,168,85,.4);
}
.btn-wa:hover{ background: #25C062; }

.btn-sm{ height: 36px; padding: 0 14px; font-size: 13px; }
.btn-lg{ height: 56px; padding: 0 26px; font-size: 15px; }

/* ───────── Hero */
.hero{
  height: 100vh; min-height: 720px;
  position: relative; overflow: hidden;
  padding: 0;
}
.hero-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 40%, #1c1f25 0%, #0a0a0b 65%),
    #0a0a0b;
  will-change: transform;
}
.hero-grid-overlay{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, black 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, black 30%, transparent 80%);
}
.hero-stage{
  position:absolute; inset: 0;
  display:grid; place-items:center;
  pointer-events:none;
}
.hero-fade{
  position:absolute; left:0; right:0; bottom:0; height: 30%;
  background: linear-gradient(180deg, transparent, var(--bg) 90%);
  pointer-events:none;
}
.hero-content{
  position: relative; z-index: 3;
  height: 100%;
  display:flex; flex-direction:column; justify-content: center;
  padding-top: 120px;
}
.hero-eyebrow{ margin-bottom: 28px; opacity:0; transform: translateY(20px); animation: rise .9s var(--t-spring) .2s forwards; }
.hero-title{
  max-width: 16ch;
  opacity:0; transform: translateY(40px);
  animation: rise 1.1s var(--t-spring) .35s forwards;
}
.hero-sub{
  margin-top: 28px; max-width: 540px; color: var(--text-mute);
  font-size: clamp(16px, 1.2vw, 19px); line-height: 1.5;
  opacity:0; transform: translateY(30px); animation: rise 1s var(--t-spring) .6s forwards;
}
.hero-actions{
  margin-top: 44px; display:flex; gap: 12px; flex-wrap:wrap;
  opacity:0; transform: translateY(20px); animation: rise .9s var(--t-spring) .85s forwards;
}
.hero-meta{
  position:absolute; left:32px; right:32px; bottom: 36px;
  display:flex; justify-content: space-between; align-items: flex-end; gap: 32px;
  z-index: 3;
  opacity:0; animation: fade 1s var(--t-ease) 1.1s forwards;
}
.hero-stat{ display:flex; flex-direction:column; gap: 6px; }
.hero-stat .num{ font-size: clamp(28px, 3vw, 44px); font-weight: 500; letter-spacing: -0.03em; }
.hero-stat .lbl{ font-size: 11px; letter-spacing:.2em; text-transform: uppercase; color: var(--text-dim); }
.scroll-cue{
  display:flex; align-items:center; gap:10px; font-size:11px; letter-spacing:.2em;
  text-transform: uppercase; color: var(--text-dim);
}
.scroll-cue .line{ width:1px; height:36px; background: linear-gradient(180deg, transparent, var(--text-dim), transparent); animation: pulse 2.4s var(--t-ease) infinite; }

@keyframes rise{ to{ opacity:1; transform:translateY(0); } }
@keyframes fade{ to{ opacity:1; } }
@keyframes pulse{ 0%,100%{opacity:.3} 50%{opacity:1} }

/* Hero car placeholder */
.hero-video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0;
  animation: heroVideoIn 1.8s var(--t-ease) .2s forwards;
  filter: saturate(1.05) contrast(1.05);
}
@keyframes heroVideoIn{ to{ opacity: 1; } }
.hero-vignette{
  position: absolute; inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(10,10,11,.55) 0%, rgba(10,10,11,.25) 30%, rgba(10,10,11,.4) 60%, var(--bg) 100%),
    linear-gradient(90deg, rgba(10,10,11,.7) 0%, rgba(10,10,11,.25) 45%, rgba(10,10,11,.15) 100%);
  pointer-events: none;
}
/* Hero background gradient sits behind the video so dark edges blend */
.hero .hero-bg{ z-index: -1; opacity: .6; }
.hero .hero-grid-overlay{ z-index: 2; opacity: .5; }
.hero .hero-content{ z-index: 4; }
.hero .hero-meta{ z-index: 4; }

.hero .hero-car{
  position:absolute; left:50%; bottom: 8%;
  transform: translateX(-50%);
  width: min(1100px, 92%);
  aspect-ratio: 16 / 7;
  border-radius: 24px;
  overflow:hidden;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.025) 0 14px, transparent 14px 28px),
    linear-gradient(180deg, #1a1c20, #0e0f12);
  border: 1px solid var(--hairline);
  display:grid; place-items:center;
  opacity:0; transform: translate(-50%, 60px) scale(.96);
  animation: heroCarIn 1.4s var(--t-spring) .5s forwards;
}
@keyframes heroCarIn{ to{ opacity:1; transform: translate(-50%, 0) scale(1); } }
.hero-car::after{
  content:""; position:absolute; inset:0;
  background: radial-gradient(ellipse 60% 80% at 50% 100%, rgba(0,0,0,.5), transparent 60%);
}
.hero-car .ph-label{
  font-family:"Geist Mono", ui-monospace, monospace;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color: var(--text-dim); padding: 6px 12px;
  border: 1px solid var(--hairline-2); border-radius: 999px;
  background: rgba(10,10,11,.6); backdrop-filter: blur(8px);
  position: relative; z-index: 1;
}

/* ───────── Image placeholders */
.ph{
  position:relative;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.03) 0 12px, transparent 12px 24px),
    linear-gradient(180deg, #1a1c20, #0e0f12);
  border: 1px solid var(--hairline);
  overflow: hidden;
  display: grid; place-items: center;
}
.ph::after{
  content:""; position:absolute; inset:0;
  background: radial-gradient(ellipse 60% 80% at 50% 100%, rgba(0,0,0,.4), transparent 60%);
  pointer-events: none;
}
.ph .ph-label{
  font-family:"Geist Mono", ui-monospace, monospace;
  font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color: var(--text-dim); padding: 6px 12px;
  border: 1px solid var(--hairline-2); border-radius: 999px;
  background: rgba(10,10,11,.7); backdrop-filter: blur(8px);
  z-index:1;
}
.ph.light{
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,.04) 0 12px, transparent 12px 24px),
    linear-gradient(180deg, #f0f0f2, #d8d9dc);
  border-color: rgba(0,0,0,.08);
}
.ph.light .ph-label{ color: #555; background: rgba(255,255,255,.6); border-color: rgba(0,0,0,.1); }

/* ───────── Search module */
.search-card{
  background: rgba(22, 23, 26, 0.65);
  backdrop-filter: blur(24px) saturate(160%);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  padding: 10px;
  box-shadow: var(--shadow-card);
  position: relative;
}
.search-grid{
  display: grid;
  grid-template-columns: repeat(7, 1fr) auto;
  gap: 1px;
  background: var(--hairline);
  border-radius: calc(var(--r-lg) - 10px);
  overflow: hidden;
}
.search-field{
  background: var(--bg-1);
  padding: 14px 16px;
  display:flex; flex-direction: column; gap: 4px;
  transition: background .2s ease;
  cursor: pointer;
}
.search-field:hover{ background: var(--bg-2); }
.search-field label{ font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--text-dim); }
.search-field .val{ display:flex; align-items:center; justify-content:space-between; gap: 8px; }
.search-field select, .search-field input{
  appearance:none; -webkit-appearance:none;
  background: transparent; border:0; outline:0;
  color: var(--text); font: inherit; font-size: 14px;
  width: 100%;
  cursor: pointer;
}
.search-field select option{ background: #16171A; color: var(--text); }
.search-submit{
  background: var(--platinum);
  color: #0A0A0B;
  padding: 0 28px;
  display:flex; align-items:center; gap:8px;
  font-weight: 500;
  font-size: 14px;
  cursor: pointer;
  transition: background .2s ease;
}
.search-submit:hover{ background: #fff; }
@media (max-width: 980px){
  .search-grid{ grid-template-columns: repeat(2, 1fr); }
  .search-submit{ grid-column: span 2; padding: 16px; justify-content:center; }
}

/* ───────── Inventory rail / cards */
.rail-wrap{ position: relative; }
.rail{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 380px;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 4px 32px 32px;
  margin: 0 -32px;
  scrollbar-width: none;
}
.rail::-webkit-scrollbar{ display:none; }
.rail.rail-sm{ grid-auto-columns: 300px; }
@media (max-width:720px){
  .rail{ grid-auto-columns: 82vw; }
  .rail.rail-sm{ grid-auto-columns: 78vw; }
}

.car-card{
  scroll-snap-align: start;
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: transform .5s var(--t-spring), border-color .3s var(--t-ease), box-shadow .5s var(--t-spring);
  display: flex; flex-direction: column;
}
.car-card:hover{
  transform: translateY(-6px);
  border-color: var(--hairline-2);
  box-shadow: var(--shadow-card);
}
.car-media{
  aspect-ratio: 16/10;
  position: relative;
  overflow: hidden;
}
.car-media .ph{ width:100%; height:100%; border-radius: 0; border:0; }
.car-media .car-img{
  width:100%; height:100%; object-fit: cover; display:block;
  transition: transform .6s var(--t-spring);
}
.car-card:hover .car-media .car-img{ transform: scale(1.05); }
.car-card.is-sold .car-img{ filter: grayscale(.7) brightness(.7); }
.car-card.is-sold:hover{ transform: translateY(-2px); }
.car-card.is-export .car-img{ filter: brightness(.82); }
.sold-stamp.export-stamp{ background: oklch(0.45 0.06 230 / 0.5); border-color: rgba(255,255,255,.7); }
.sold-stamp{
  position:absolute; top:50%; left:50%; transform: translate(-50%,-50%) rotate(-8deg);
  z-index:3; pointer-events:none;
  font-family:"Geist Mono", ui-monospace, monospace;
  font-size: 22px; font-weight:500; letter-spacing:.18em; text-transform:uppercase;
  color:#fff; padding: 8px 22px;
  border: 2px solid rgba(255,255,255,.85); border-radius: 6px;
  background: rgba(20,10,12,.35); backdrop-filter: blur(2px);
}
.sold-banner{
  background:#2a1316; border:1px solid rgba(220,70,70,.4); color:#ffb3b3;
  border-radius:10px; padding:14px 16px; margin-bottom:18px; font-size:13px; line-height:1.5;
}
.sold-banner a{ color:#fff; text-decoration:underline; }
.detail-sold .gallery-main{ position:relative; }
.car-media::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.5));
  pointer-events:none;
}
.car-tags{
  position:absolute; top: 14px; left: 14px; display:flex; gap: 6px; z-index:2;
}
.tag{
  font-family:"Geist Mono", ui-monospace, monospace;
  font-size: 10px; letter-spacing: .12em; text-transform: uppercase;
  padding: 5px 9px; border-radius: 999px;
  background: rgba(10,10,11,.7); color: var(--text);
  border: 1px solid var(--hairline-2);
  backdrop-filter: blur(8px);
}
.tag.ice{ background: var(--ice-glow); color: var(--ice); border-color: oklch(0.78 0.05 230 / 0.4); }
.tag.new{ background: #fff; color: #0A0A0B; border-color: #fff; }
.tag.sold{ background:#2a1316; color:#ff9a9a; border-color: rgba(220,70,70,.5); }
.tag.export{ background: var(--ice-glow); color: var(--ice); border-color: oklch(0.78 0.05 230 / 0.5); }

.car-body{ padding: 20px; display:flex; flex-direction:column; gap: 14px; flex:1; }
.car-head{ display:flex; justify-content:space-between; align-items:flex-start; gap: 16px; }
.car-title{ font-size: 18px; font-weight: 500; letter-spacing:-0.02em; }
.car-title small{ display:block; color: var(--text-dim); font-size: 13px; font-weight:400; margin-top:2px; letter-spacing: 0;}
.car-price{ font-size: 18px; font-weight: 500; letter-spacing: -0.02em; white-space:nowrap; }
.car-price small{ display:block; font-size: 10px; color: var(--text-dim); text-align:right; letter-spacing:.16em; text-transform:uppercase; font-weight:400; margin-top: 2px; }

.car-specs{
  display:grid; grid-template-columns: repeat(2, 1fr); gap: 6px 16px;
  font-size: 13px; color: var(--text-mute);
  border-top: 1px solid var(--hairline);
  padding-top: 14px;
}
.car-specs span{ display:flex; align-items:center; gap: 8px; }
.car-specs svg{ flex-shrink:0; opacity:.7; }

.car-foot{
  margin-top: auto; padding-top: 4px;
  display:flex; justify-content: space-between; align-items:center; gap: 12px;
}
.car-link{
  font-size: 13px; color: var(--text); font-weight: 500;
  display:inline-flex; align-items:center; gap: 6px;
  padding: 8px 0; transition: gap .25s var(--t-spring);
}
.car-link:hover{ gap: 10px; }
.car-link svg{ transition: transform .25s var(--t-spring); }
.car-card:hover .car-link svg{ transform: translateX(3px); }

.rail-controls{ display:flex; gap: 10px; }
.rail-controls .icon-btn{ width: 44px; height:44px; }

/* ───────── Services grid */
.services{
  display:grid; grid-template-columns: repeat(2, 1fr); gap: 1px;
  background: var(--hairline);
  border-radius: var(--r-xl);
  overflow: hidden;
  border: 1px solid var(--hairline);
}
.service{
  background: var(--bg-1);
  padding: 48px;
  min-height: 360px;
  display:flex; flex-direction: column;
  position: relative; overflow:hidden;
  transition: background .35s var(--t-ease);
}
.service:hover{ background: var(--bg-2); }
.service .num{
  font-family:"Geist Mono", ui-monospace, monospace;
  font-size: 11px; letter-spacing:.22em; color: var(--text-dim);
  margin-bottom: 24px;
}
.service h3{ font-size: clamp(24px, 2vw, 32px); margin-bottom: 14px; max-width: 16ch; }
.service p{ color: var(--text-mute); max-width: 38ch; line-height: 1.55; }
.service-foot{ margin-top: auto; padding-top: 32px; display:flex; justify-content:space-between; align-items:flex-end; gap: 16px; }
.service .arrow{
  width: 48px; height: 48px; border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--hairline-2);
  display:grid; place-items:center;
  transition: background .3s var(--t-ease), transform .3s var(--t-spring);
}
.service:hover .arrow{ background: var(--platinum); color: #0A0A0B; transform: translateX(4px); }
.service:hover .arrow svg{ stroke: #0A0A0B; }
.service .visual{
  position: absolute; right: -40px; top: 40px; bottom: 40px; width: 40%;
  border-radius: var(--r-md);
  opacity: 0.4; transition: opacity .4s var(--t-ease), transform .6s var(--t-spring);
}
.service:hover .visual{ opacity: 0.7; transform: translateX(-10px); }
@media (max-width: 880px){
  .services{ grid-template-columns: 1fr; }
  .service{ padding: 36px; min-height: 280px; }
  .service .visual{ display:none; }
}

/* ───────── Reveal */
.reveal{ opacity:0; transform: translateY(40px); transition: opacity 1s var(--t-ease), transform 1s var(--t-spring); }
.reveal.in{ opacity:1; transform: translateY(0); }
.reveal.d1{ transition-delay: .1s; }
.reveal.d2{ transition-delay: .2s; }
.reveal.d3{ transition-delay: .3s; }
.reveal.d4{ transition-delay: .4s; }

/* ───────── Story strip (sticky storytelling) */
.story{
  position: relative;
  background: #050506;
}
.story-track{
  display:grid; grid-template-columns: 1fr 1fr; gap: 0;
}
.story-media{
  position: sticky; top: 0;
  height: 100vh;
  display:grid; place-items:center;
  background: #0a0a0b;
  overflow: hidden;
}
.story-media .ph{ width:100%; height:100%; border:0; border-radius:0; }
.story-copy{ display:flex; flex-direction: column; }
.story-block{
  min-height: 100vh; display:flex; flex-direction: column; justify-content: center;
  padding: 80px 64px;
  border-top: 1px solid var(--hairline);
}
.story-block:first-child{ border-top: 0; }
.story-block .eyebrow{ margin-bottom: 20px; }
.story-block h2{ margin-bottom: 20px; max-width: 14ch; }
.story-block p{ color: var(--text-mute); max-width: 44ch; font-size: 17px; line-height: 1.55; margin-bottom: 28px; }
.story-bullets{ list-style:none; padding:0; margin: 0; display:grid; gap: 10px; }
.story-bullets li{
  display:flex; gap: 12px; align-items:flex-start;
  font-size: 14px; color: var(--text-mute);
  padding-top: 12px; border-top: 1px solid var(--hairline);
}
.story-bullets li::before{
  content:""; width: 6px; height:6px; border-radius: 50%;
  background: var(--ice); margin-top: 7px; flex-shrink: 0;
}
@media (max-width: 880px){
  .story-track{ grid-template-columns: 1fr; }
  .story-media{ position: relative; height: 60vh; }
  .story-block{ min-height: auto; padding: 60px 24px; }
}

/* ───────── Filters / listing page */
.listing{ padding-top: 140px; }
.listing-grid{ display:grid; grid-template-columns: 280px 1fr; gap: 40px; }
.filter-panel{
  position: sticky; top: 100px;
  background: var(--bg-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  padding: 24px;
  align-self: start;
  height: max-content;
}
.filter-panel h4{ font-size: 13px; letter-spacing:.18em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 16px; font-weight: 500; }
.filter-group{ padding: 18px 0; border-top: 1px solid var(--hairline); }
.filter-group:first-of-type{ border-top: 0; padding-top: 0; }
.filter-group .label{ font-size: 12px; color: var(--text-dim); letter-spacing: .15em; text-transform: uppercase; margin-bottom: 10px; }
.checks{ display:grid; gap: 6px; }
.check{
  display:flex; justify-content: space-between; align-items: center;
  font-size: 14px; padding: 6px 0; color: var(--text-mute);
  cursor: pointer;
  transition: color .2s ease;
}
.check:hover{ color: var(--text); }
.check input{ accent-color: var(--ice); }
.check .count{ font-family:"Geist Mono", ui-monospace, monospace; font-size: 11px; color: var(--text-dim); }

.range-row{ display:flex; gap: 8px; margin-top: 8px; }
.range-row input{
  flex: 1; background: var(--bg-2); border: 1px solid var(--hairline);
  border-radius: 8px; padding: 9px 10px; color: var(--text); font: inherit; font-size: 13px;
  outline: none; transition: border-color .2s ease;
}
.range-row input:focus{ border-color: var(--ice); }

.listing-head{ display:flex; justify-content: space-between; align-items: end; margin-bottom: 24px; }
.listing-toolbar{ display:flex; gap: 12px; }
.cards-grid{
  display:grid; grid-template-columns: repeat(2, 1fr); gap: 24px;
}
@media (max-width: 980px){
  .listing-grid{ grid-template-columns: 1fr; }
  .filter-panel{ position: relative; top:0; }
  .cards-grid{ grid-template-columns: 1fr; }
}

/* ───────── Detail page */
.detail{ padding-top: 100px; }
.detail-gallery{ position: relative; }
.gallery-main{
  aspect-ratio: 16/9; border-radius: var(--r-lg); overflow: hidden;
  background: var(--bg-2); border: 1px solid var(--hairline);
}
.gallery-thumbs{ display:grid; grid-template-columns: repeat(6, 1fr); gap: 10px; margin-top: 12px; }
.thumb{
  aspect-ratio: 16/10; border-radius: 10px; overflow:hidden;
  background: var(--bg-2); border: 1px solid var(--hairline);
  cursor: pointer; transition: border-color .2s ease, transform .2s ease;
  position: relative;
}
.thumb:hover{ border-color: var(--hairline-2); }
.thumb.active{ border-color: var(--ice); }
.thumb .ph{ width:100%; height:100%; border-radius:0; border:0; }

.detail-layout{ display:grid; grid-template-columns: 1fr 380px; gap: 60px; align-items: start; padding-top: 60px; }
.detail-sidebar{ position: sticky; top: 100px; }
.price-card{
  background: var(--bg-1); border: 1px solid var(--hairline);
  border-radius: var(--r-lg); padding: 28px;
}
.price-card .label{ font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--text-dim); }
.price-card .price{ font-size: 36px; font-weight: 500; letter-spacing: -0.03em; margin: 6px 0 4px; }
.price-card .pricesub{ color: var(--text-dim); font-size: 13px; margin-bottom: 24px; }
.cta-stack{ display:grid; gap: 10px; }
.cta-stack .btn{ width:100%; justify-content:center; }
.spec-table{ display:grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid var(--hairline); margin-top: 32px; }
.spec-table div{
  padding: 16px 4px; border-bottom: 1px solid var(--hairline);
  font-size: 14px; display:flex; align-items:center;
}
.spec-table div:nth-child(odd){ color: var(--text-dim); }
.spec-table div:nth-child(even){ justify-content:flex-end; color: var(--text); font-variant-numeric: tabular-nums;}

@media (max-width: 980px){
  .detail-layout{ grid-template-columns: 1fr; }
  .detail-sidebar{ position: relative; top: 0; }
}

/* ───────── Forms */
.form{
  display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px;
}
.form .full{ grid-column: 1 / -1; }
.field{ display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.field label{ font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--text-dim); }
.field input, .field select, .field textarea{
  width: 100%;
  background: var(--bg-1); border: 1px solid var(--hairline);
  border-radius: 10px; padding: 14px 16px;
  color: var(--text); font: inherit; font-size: 15px;
  outline: none;
  transition: border-color .2s ease, background .2s ease;
}
.field input:focus, .field select:focus, .field textarea:focus{ border-color: var(--ice); background: var(--bg-2); }
.field textarea{ min-height: 140px; resize: vertical; }

.upload{
  border: 1.5px dashed var(--hairline-2);
  border-radius: var(--r-md);
  padding: 36px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s ease, background .2s ease;
}
.upload:hover{ border-color: var(--ice); background: rgba(255,255,255,.02); }
.upload .icon{ width: 48px; height: 48px; border-radius: 999px; background: var(--bg-2); display:grid; place-items:center; margin: 0 auto 12px; border: 1px solid var(--hairline); }

@media (max-width: 720px){ .form{ grid-template-columns: 1fr; } }

/* ───────── Footer */
footer.site-foot{
  background: #050506;
  padding: 80px 0 32px;
  border-top: 1px solid var(--hairline);
}
.foot-grid{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 60px;
  padding-bottom: 60px;
  border-bottom: 1px solid var(--hairline);
}
.foot-col h5{ font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: var(--text-dim); margin: 0 0 18px; font-weight: 500;}
.foot-col ul{ list-style: none; padding: 0; margin: 0; display:grid; gap: 10px; }
.foot-col li a{ color: var(--text-mute); font-size: 14px; transition: color .2s ease; }
.foot-col li a:hover{ color: var(--text); }
.foot-brand p{ color: var(--text-mute); font-size: 14px; margin-top: 16px; max-width: 32ch; line-height: 1.55; }
.foot-bottom{
  display:flex; justify-content: space-between; align-items: center;
  padding-top: 32px; flex-wrap: wrap; gap: 16px;
  font-size: 12px; color: var(--text-dim);
  font-family:"Geist Mono", ui-monospace, monospace;
  letter-spacing: .08em;
}
.foot-bottom .legal{ display:flex; gap: 24px; }
@media (max-width:880px){ .foot-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width:560px){ .foot-grid{ grid-template-columns: 1fr; gap: 40px; } }

/* ───────── Mobile bottom bar (sticky CTAs) */
.mobi-cta{
  display: none;
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 90;
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
  background: rgba(10,10,11,.85);
  backdrop-filter: blur(20px);
  border-top: 1px solid var(--hairline);
  gap: 8px;
}
.mobi-cta .btn{ flex:1; justify-content:center; height: 48px; }
@media (max-width: 720px){ .mobi-cta{ display:flex; } body{ padding-bottom: 76px; } }

/* ───────── Misc helpers */
.row{ display:flex; gap: 12px; flex-wrap:wrap; }
.spacer-sm{ height: 24px; } .spacer{ height: 48px; } .spacer-lg{ height: 96px; }
.divider{ height:1px; background: var(--hairline); margin: 80px 0; }
.kbd{
  font-family:"Geist Mono", ui-monospace, monospace; font-size: 11px;
  padding: 3px 8px; border-radius: 6px;
  background: var(--bg-2); border: 1px solid var(--hairline);
  color: var(--text-mute);
}

/* Marquee */
.marquee{
  overflow: hidden;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  padding: 28px 0;
  background: var(--bg);
}
.marquee-track{ display:flex; gap: 64px; width: max-content; animation: scroll 40s linear infinite; }
.marquee-item{
  font-family:"Geist Mono", ui-monospace, monospace;
  font-size: 13px; letter-spacing: .25em; text-transform: uppercase;
  color: var(--text-dim);
  display:flex; align-items:center; gap: 64px;
}
.marquee-item::after{ content:"●"; color: var(--ice); font-size: 8px; }
@keyframes scroll{ to{ transform: translateX(-50%); } }

/* Workshop / Service grid responsive collapse */
.svc-grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); border-radius: var(--r-lg); overflow: hidden; }
@media (max-width: 980px){ .svc-grid-3{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px){ .svc-grid-3{ grid-template-columns: 1fr; } }

.usp-4{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
@media (max-width: 880px){ .usp-4{ grid-template-columns: repeat(2, 1fr); } }

/* Section index numbering */
.sec-num{
  font-family:"Geist Mono", ui-monospace, monospace; font-size: 11px;
  color: var(--text-dim); letter-spacing: .22em; text-transform: uppercase;
}

/* ───────── Form status melding */
.form-status{
  grid-column: 1 / -1;
  margin-top: 18px;
  font-size: 14px;
  line-height: 1.5;
  padding: 0;
}
.form-status.ok{
  padding: 16px 18px;
  border-radius: 12px;
  background: oklch(0.72 0.06 230 / 0.12);
  border: 1px solid oklch(0.78 0.05 230 / 0.4);
  color: var(--ice);
}
.form-status.err{
  padding: 16px 18px;
  border-radius: 12px;
  background: rgba(220, 70, 70, .1);
  border: 1px solid rgba(220, 70, 70, .4);
  color: #ff9a9a;
}

/* ───────── RDW-statusmelding */
.rdw-status{ grid-column:1/-1; font-size:13px; margin-top:8px; min-height:1px; }
.rdw-status.ok{ color: var(--ice); }
.rdw-status.err{ color:#ff9a9a; }

/* ───────── Aanbod-videosectie (homepage) */
.video-feature{
  position: relative; overflow: hidden;
  min-height: 70vh; display: flex; align-items: center;
  padding: 0;
}
.video-feature-media{
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; z-index: 0;
}
.video-feature-overlay{
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(90deg, rgba(10,10,11,.86) 0%, rgba(10,10,11,.55) 45%, rgba(10,10,11,.25) 100%),
    linear-gradient(0deg, rgba(10,10,11,.7), transparent 45%);
}
.video-feature-content{ position: relative; z-index: 2; max-width: 620px; padding-top: 80px; padding-bottom: 80px; }
.video-feature-content .eyebrow{ display:block; margin-bottom: 18px; }
.video-feature-content h2{ font-size: clamp(34px, 4.4vw, 64px); }
.video-feature-content p{ color: var(--text-mute); margin: 22px 0 34px; max-width: 48ch; font-size: 17px; }

/* ───────── Aanbod-videobanner (aanbod-pagina) */
.video-banner{
  position: relative; overflow: hidden;
  border-radius: var(--r-lg);
  aspect-ratio: 21/9; margin-bottom: 48px;
  border: 1px solid var(--hairline);
}
.video-banner-media{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.video-banner-overlay{
  position:absolute; inset:0; z-index:1;
  background: linear-gradient(0deg, rgba(10,10,11,.85), rgba(10,10,11,.15) 70%);
}
.video-banner-content{ position:absolute; z-index:2; left: 0; bottom: 0; padding: 36px 40px; }
.video-banner-content .eyebrow{ display:block; margin-bottom: 12px; }
.video-banner-content h2{ font-size: clamp(24px, 3vw, 40px); max-width: 18ch; }
@media (max-width: 720px){
  .video-banner{ aspect-ratio: 16/10; }
  .video-banner-content{ padding: 24px; }
}

/* ───────── Kopieerbeveiliging (afschrikmiddel) */
body{ -webkit-user-select: none; -moz-user-select: none; user-select: none; }
input, textarea, select, [contenteditable="true"]{ -webkit-user-select: text; -moz-user-select: text; user-select: text; }
img{ -webkit-user-drag: none; user-drag: none; pointer-events: auto; }

/* ───────── Cookiemelding */
.cookie-bar{
  position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 300;
  background: rgba(16,17,20,.96); border: 1px solid var(--hairline-2);
  border-radius: var(--r-md); box-shadow: var(--shadow-2);
  backdrop-filter: blur(12px);
  opacity: 0; transform: translateY(12px);
  transition: opacity .3s var(--t-ease), transform .3s var(--t-ease);
}
.cookie-bar.show{ opacity: 1; transform: none; }
.cookie-inner{
  display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
  padding: 16px 20px; max-width: var(--container); margin: 0 auto;
}
.cookie-text{ flex: 1; min-width: 240px; font-size: 13px; color: var(--text-mute); line-height: 1.5; }
.cookie-text a{ color: var(--ice); text-decoration: underline; }
.cookie-actions{ display: flex; gap: 10px; flex-shrink: 0; }
@media (max-width: 600px){ .cookie-actions{ width: 100%; } .cookie-actions .btn{ flex: 1; justify-content: center; } }
