/* Venz Motors — Concours d'Elegance × Cinematic Noir */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400&family=Outfit:wght@200;300;400;500;600&family=JetBrains+Mono:wght@300;400;500&display=swap');

:root {
  --ink: #0A0908;
  --ink-2: #14110F;
  --ink-3: #1C1916;
  --ivory: #EFE9DC;
  --ivory-2: #DCD4C2;
  --ivory-dim: rgba(239, 233, 220, 0.62);
  --ivory-faint: rgba(239, 233, 220, 0.38);
  --brass: #A8884A;
  --brass-2: #C9A85C;
  --brass-dim: rgba(168, 136, 74, 0.55);
  --oxblood: #6B1F1A;
  --rule: rgba(239, 233, 220, 0.14);
  --rule-strong: rgba(239, 233, 220, 0.28);

  --display: 'Cormorant Garamond', 'Didot', 'Bodoni 72', serif;
  --sans: 'Outfit', 'Helvetica Neue', sans-serif;
  --mono: 'JetBrains Mono', 'IBM Plex Mono', monospace;
}

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

html, body {
  background: var(--ink);
  color: var(--ivory);
  font-family: var(--sans);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

body {
  position: relative;
  min-height: 100vh;
}

/* Subtle paper grain — quieter than before */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  opacity: 0.025;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; }

/* ── Type system ─────────────────────────────────────── */
.display {
  font-family: var(--display);
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: 0.95;
}
.display-italic {
  font-family: var(--display);
  font-style: italic;
  font-weight: 300;
}
.eyebrow {
  font-family: var(--display);
  font-style: italic;
  font-weight: 400;
  font-size: 18px;
  letter-spacing: 0.01em;
  text-transform: none;
  color: var(--brass-2);
  display: inline-flex;
  align-items: center;
  gap: 18px;
}
.eyebrow-rule {
  display: inline-block;
  width: 40px;
  height: 1px;
  background: var(--brass);
  opacity: 0.7;
}
.meta {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ivory-dim);
}
.body-text {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 15px;
  line-height: 1.7;
  color: var(--ivory-dim);
  letter-spacing: 0.005em;
}

/* ── Layout ─────────────────────────────────────────── */
.container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 56px;
}

@media (max-width: 768px) {
  .container { padding: 0 24px; }
}

.section-rule {
  height: 1px;
  background: var(--rule);
  width: 100%;
}

/* ── Hairline divider with brass dot ─────────────────── */
.crested-rule {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 32px 0;
}
.crested-rule .line {
  flex: 1;
  height: 1px;
  background: var(--rule);
}
.crested-rule .dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--brass);
  box-shadow: 0 0 0 4px rgba(168,136,74,0.12);
}

/* ── Buttons ──────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 16px 32px;
  border: 1px solid var(--rule-strong);
  background: transparent;
  color: var(--ivory);
  font-family: var(--display);
  font-style: italic;
  font-weight: 400;
  font-size: 16px;
  letter-spacing: 0.005em;
  text-transform: none;
  cursor: pointer;
  transition: all 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
  position: relative;
  overflow: hidden;
}
.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--ivory);
  transform: translateY(101%);
  transition: transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
  z-index: -1;
}
.btn:hover {
  color: var(--ink);
  border-color: var(--ivory);
}
.btn:hover::before {
  transform: translateY(0);
}
.btn-brass {
  border-color: var(--brass);
  color: var(--brass-2);
}
.btn-brass::before { background: var(--brass); }
.btn-brass:hover { color: var(--ink); border-color: var(--brass); }

/* ── Image placeholders (atmospheric stand-ins) ─────── */
.placeholder {
  position: relative;
  background:
    repeating-linear-gradient(
      45deg,
      rgba(239,233,220,0.018) 0,
      rgba(239,233,220,0.018) 2px,
      transparent 2px,
      transparent 6px
    ),
    radial-gradient(ellipse at 30% 40%, rgba(168,136,74,0.10), transparent 60%),
    linear-gradient(135deg, var(--ink-3) 0%, var(--ink) 100%);
  border: 1px solid var(--rule);
  overflow: hidden;
}
.placeholder::after {
  content: attr(data-caption);
  position: absolute;
  bottom: 16px;
  left: 18px;
  font-family: var(--display);
  font-style: italic;
  font-weight: 300;
  font-size: 13px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ivory-faint);
}
.placeholder .corner {
  position: absolute;
  width: 14px;
  height: 14px;
  border-color: var(--brass-dim);
  border-style: solid;
}
.placeholder .corner.tl { top: 10px; left: 10px; border-width: 1px 0 0 1px; }
.placeholder .corner.tr { top: 10px; right: 10px; border-width: 1px 1px 0 0; }
.placeholder .corner.bl { bottom: 10px; left: 10px; border-width: 0 0 1px 1px; }
.placeholder .corner.br { bottom: 10px; right: 10px; border-width: 0 1px 1px 0; }

/* Subtle car silhouette using gradient */
.placeholder.car-silhouette::before {
  content: '';
  position: absolute;
  inset: 25% 15% 35% 15%;
  background:
    radial-gradient(ellipse at 50% 80%, rgba(0,0,0,0.5), transparent 65%),
    linear-gradient(180deg, transparent 35%, rgba(168,136,74,0.04) 50%, transparent 70%);
  filter: blur(1px);
}

/* ── Smooth scroll ───────────────────────────────────── */
html { scroll-behavior: smooth; }

/* ── Scroll reveal (init via JS) ────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 1.2s cubic-bezier(0.2, 0.8, 0.2, 1), transform 1.2s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.reveal.in {
  opacity: 1;
  transform: translateY(0);
}

/* Selection */
::selection {
  background: var(--brass);
  color: var(--ink);
}

/* Scrollbar */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--ink); }
::-webkit-scrollbar-thumb { background: var(--ink-3); border-radius: 0; }
::-webkit-scrollbar-thumb:hover { background: var(--brass-dim); }
