/* Brand Tusker — kickass redesign */
@import url('https://fonts.googleapis.com/css2?family=Archivo+Black&family=Space+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;700&family=Boldonse&display=swap');

:root {
  --ink: #0E0B08;
  --ink-2: #18130E;
  --paper: #F4ECDC;
  --paper-2: #EADFC7;
  --tusker: #FF5B1F;
  --neon: #FFD60A;
  --magenta: #FF2D87;
  --line: rgba(244,236,220,0.12);

  --display: 'Boldonse', 'Archivo Black', system-ui, sans-serif;
  --sans: 'Space Grotesk', system-ui, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--neon); color: var(--ink); padding: 12px 18px; font-family: var(--mono); font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em; z-index: 1000; border-radius: 0 0 8px 0; }
.skip-link:focus { left: 0; }
/* overflow-x: clip (not hidden) — `hidden` auto-promotes overflow-y to `auto`,
   which makes body a non-scrolling scroll-container that breaks position:sticky
   for any descendant (the services-pin would never engage). `clip` clips content
   without creating a scroll container, so sticky works AND the horizontal-overflow
   guard against the rotated marquee + 3D parallax remains. */
html, body { background: var(--ink); color: var(--paper); font-family: var(--sans); -webkit-font-smoothing: antialiased; overflow-x: clip; }
body { perspective: 1400px; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }

/* ============ DETAIL OVERLAY ============ */
.detail-overlay {
  position: fixed; inset: 0; z-index: 500;
  display: none; align-items: stretch; justify-content: center;
  opacity: 0; transition: opacity 0.28s ease;
}
.detail-overlay.open { display: flex; opacity: 1; }
.detail-backdrop {
  position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 30%, rgba(255,91,31,0.18), rgba(14,11,8,0.92) 60%);
  backdrop-filter: blur(8px);
}
.detail-panel {
  position: relative; z-index: 1; margin: auto;
  display: grid; grid-template-columns: 1.1fr 1fr;
  width: min(1180px, 94vw); max-height: 92vh;
  background: var(--paper); color: var(--ink);
  border-radius: 28px; overflow: hidden;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,0.6), 0 0 0 1px rgba(14,11,8,0.1);
  transform: translateY(20px) scale(0.98);
  transition: transform 0.32s cubic-bezier(0.2, 0.9, 0.3, 1.1);
  outline: none;
}
.detail-overlay.open .detail-panel { transform: translateY(0) scale(1); }
.detail-close {
  position: absolute; top: 16px; right: 16px; z-index: 5;
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--ink); color: var(--paper);
  display: grid; place-items: center;
  box-shadow: 0 4px 0 0 #000, 0 10px 24px -6px rgba(0,0,0,0.4);
  transition: transform 0.15s ease;
}
.detail-close:hover { transform: translateY(-2px) rotate(90deg); }
.detail-media {
  position: relative; background: var(--ink-2); min-height: 320px;
  overflow: hidden;
}
.detail-media::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,91,31,0.15), transparent 60%);
  z-index: 1; pointer-events: none;
}
.detail-media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.detail-body {
  padding: 44px 44px 38px;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 18px;
}
.detail-eyebrow {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  color: var(--tusker); text-transform: uppercase;
}
.detail-title {
  font-family: var(--display); font-size: clamp(32px, 3.4vw, 48px);
  line-height: 0.95; letter-spacing: -0.02em; color: var(--ink);
}
.detail-lede {
  font-size: 16px; line-height: 1.55; color: rgba(14,11,8,0.78);
  max-width: 46ch;
}
.detail-specs {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px 22px;
  padding: 18px 0; margin-top: 4px;
  border-top: 1px dashed rgba(14,11,8,0.18);
  border-bottom: 1px dashed rgba(14,11,8,0.18);
}
.detail-specs > div { display: flex; flex-direction: column; gap: 4px; }
.detail-specs dt {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em;
  color: rgba(14,11,8,0.55); text-transform: uppercase;
}
.detail-specs dd {
  font-family: var(--display); font-size: 15px; color: var(--ink);
  letter-spacing: -0.01em;
}
.detail-bullets {
  list-style: none; padding: 0; display: flex; flex-direction: column; gap: 10px;
}
.detail-bullets li {
  font-size: 14px; line-height: 1.45; color: var(--ink);
  padding-left: 22px; position: relative;
}
.detail-bullets li::before {
  content: "→"; position: absolute; left: 0; top: 0;
  color: var(--tusker); font-family: var(--mono); font-weight: 700;
}
.detail-cta {
  display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px;
}
.detail-cta .cta {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 22px; border-radius: 14px;
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
  transition: transform 0.15s ease;
}
.detail-cta .cta.primary {
  background: var(--ink); color: var(--paper);
  box-shadow: 0 6px 0 0 #000;
}
.detail-cta .cta.primary:hover { transform: translateY(-2px); box-shadow: 0 8px 0 0 #000; }
.detail-cta .cta.ghost {
  background: transparent; color: var(--ink);
  box-shadow: inset 0 0 0 2px var(--ink);
}
.detail-cta .cta.ghost:hover { background: var(--ink); color: var(--paper); }
body.detail-open { overflow: hidden; }
@media (max-width: 820px) {
  .detail-panel { grid-template-columns: 1fr; max-height: 96vh; }
  .detail-media { min-height: 220px; max-height: 32vh; }
  .detail-body { padding: 28px 24px; }
  .detail-specs { grid-template-columns: 1fr; gap: 12px; }
}

/* Cards that open detail overlays — affordance */
[data-detail] { cursor: pointer; }
[data-detail]:focus-visible { outline: 3px solid var(--tusker); outline-offset: 4px; }

/* Grain overlay */
body::after {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 200;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.07 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode: overlay; opacity: 0.6;
}

/* ============ NAV ============ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 28px; backdrop-filter: blur(10px);
  background: linear-gradient(to bottom, rgba(14,11,8,0.85), rgba(14,11,8,0.4));
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--display); font-size: 18px; letter-spacing: -0.02em; }
.brand .mark {
  width: 36px; height: 36px; border-radius: 10px;
  background: var(--tusker);
  display: grid; place-items: center;
  box-shadow: 0 6px 0 0 #B53A0E, 0 14px 30px -8px rgba(255,91,31,0.6);
  position: relative;
}
.brand .mark svg { width: 22px; height: 22px; }
.brand-name { display: flex; flex-direction: column; line-height: 0.9; }
.brand-name small { font-family: var(--mono); font-size: 9px; opacity: 0.6; letter-spacing: 0.15em; font-weight: 400; margin-top: 4px; }

.nav-links { display: flex; gap: 28px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
.nav-links a { opacity: 0.7; transition: opacity 0.2s; position: relative; }
.nav-links a:hover { opacity: 1; }
.nav-links a::after { content: ""; position: absolute; left: 0; right: 0; bottom: -4px; height: 2px; background: var(--tusker); transform: scaleX(0); transform-origin: left; transition: transform 0.3s; }
.nav-links a:hover::after { transform: scaleX(1); }

.cta {
  font-family: var(--mono); font-weight: 700; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 12px 18px; background: var(--neon); color: var(--ink); border-radius: 999px;
  display: inline-flex; align-items: center; gap: 8px;
  box-shadow: 0 6px 0 0 #BF9F00, 0 14px 30px -10px rgba(255,214,10,0.5);
  transition: transform 0.15s, box-shadow 0.15s;
}
.cta:hover { transform: translateY(2px); box-shadow: 0 4px 0 0 #BF9F00, 0 8px 20px -8px rgba(255,214,10,0.5); }
.cta:active { transform: translateY(6px); box-shadow: 0 0 0 0 #BF9F00; }
.cta.alt { background: var(--tusker); color: var(--paper); box-shadow: 0 6px 0 0 #B53A0E, 0 14px 30px -10px rgba(255,91,31,0.6); }
.cta.alt:hover { box-shadow: 0 4px 0 0 #B53A0E, 0 8px 20px -8px rgba(255,91,31,0.6); }
.cta.alt:active { box-shadow: 0 0 0 0 #B53A0E; }

/* ============ HERO ============ */
.hero {
  min-height: 100vh; position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1.05fr 1fr; align-items: center;
  padding: 120px 60px 60px;
  background:
    radial-gradient(60% 50% at 80% 30%, rgba(255,91,31,0.18), transparent 60%),
    radial-gradient(40% 40% at 10% 80%, rgba(255,45,135,0.12), transparent 60%),
    var(--ink);
}
.hero::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(70% 70% at 50% 50%, black, transparent);
  pointer-events: none;
}

.hero-left { position: relative; z-index: 2; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  padding: 8px 14px; border: 1px solid var(--line); border-radius: 999px;
  background: rgba(244,236,220,0.04);
}
.eyebrow .dot { width: 8px; height: 8px; background: var(--tusker); border-radius: 50%; box-shadow: 0 0 12px var(--tusker); animation: pulse 1.6s ease-in-out infinite; }
@keyframes pulse { 50% { box-shadow: 0 0 24px var(--tusker); transform: scale(1.2); } }

h1.headline {
  font-family: var(--display); font-weight: 400;
  font-size: clamp(56px, 8.4vw, 140px); line-height: 0.86; letter-spacing: -0.04em;
  margin: 24px 0 28px;
}
h1.headline .stroke {
  -webkit-text-stroke: 2px var(--paper); color: transparent;
}
h1.headline .ink-fill { color: var(--tusker); display: inline-block; transform: rotate(-2deg); }
h1.headline .underline {
  position: relative; display: inline-block;
}
h1.headline .underline::after {
  content: ""; position: absolute; left: -6px; right: -6px; bottom: 6px; height: 14px;
  background: var(--neon); z-index: -1; transform: skewX(-12deg);
}

.lede { font-size: 19px; line-height: 1.5; max-width: 520px; opacity: 0.78; margin-bottom: 36px; }
.lede strong { color: var(--neon); font-weight: 500; }

.hero-actions { display: flex; gap: 14px; align-items: center; margin-bottom: 60px; }
.ghost {
  font-family: var(--mono); font-weight: 500; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 12px 18px; border: 1px solid var(--line); border-radius: 999px;
  display: inline-flex; align-items: center; gap: 10px;
}
.ghost:hover { border-color: var(--paper); }

.hero-stats { display: flex; gap: 40px; }
.stat { font-family: var(--display); }
.stat .num { font-size: 38px; line-height: 1; color: var(--paper); }
.stat .num .plus { color: var(--tusker); }
.stat .lbl { font-family: var(--mono); font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; opacity: 0.55; margin-top: 6px; }

/* ===== 3D SCENE ===== */
.scene {
  position: relative; height: 640px;
  transform-style: preserve-3d;
  perspective: 1400px;
}
.scene-inner {
  position: absolute; inset: 0;
  transform-style: preserve-3d;
  transform: rotateY(-18deg) rotateX(8deg);
  transition: transform 0.4s cubic-bezier(0.2, 0.9, 0.3, 1);
}

.card3d {
  position: absolute; transform-style: preserve-3d;
  border-radius: 18px;
  will-change: transform;
}

/* LED Sign card */
.card-led {
  width: 340px; height: 220px; top: 40px; left: 30px;
  transform: translateZ(60px) rotate(-6deg);
  background: linear-gradient(135deg, #2a1a0e, #0E0B08);
  border: 1px solid rgba(255,91,31,0.4);
  box-shadow:
    0 30px 60px -20px rgba(0,0,0,0.8),
    0 0 60px -10px rgba(255,91,31,0.4),
    inset 0 0 0 1px rgba(255,255,255,0.04);
  padding: 22px; overflow: hidden;
}
.card-led::before {
  content: ""; position: absolute; inset: 14px;
  border: 2px dashed rgba(255,91,31,0.3); border-radius: 12px;
}
.card-led .led-text {
  font-family: var(--display); font-size: 42px; line-height: 1;
  color: var(--tusker); text-shadow: 0 0 18px var(--tusker), 0 0 40px rgba(255,91,31,0.6);
  letter-spacing: -0.02em;
  position: relative; z-index: 2;
}
.card-led .led-sub { font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; color: var(--neon); margin-top: 8px; position: relative; z-index: 2; }
.card-led .led-tag { position: absolute; top: 14px; right: 18px; font-family: var(--mono); font-size: 9px; letter-spacing: 0.2em; color: rgba(244,236,220,0.4); }

/* Vinyl sticker — angled */
.card-vinyl {
  width: 260px; height: 260px; top: 220px; right: 0;
  transform: translateZ(140px) rotate(8deg);
  background: var(--neon); color: var(--ink);
  border-radius: 50%;
  box-shadow:
    0 40px 80px -20px rgba(0,0,0,0.7),
    0 0 80px -10px rgba(255,214,10,0.5);
  display: grid; place-items: center;
  font-family: var(--display); text-align: center;
}
.card-vinyl::before {
  content: ""; position: absolute; inset: 12px; border: 2px solid var(--ink); border-radius: 50%;
}
.card-vinyl .v-text { font-size: 32px; line-height: 0.9; letter-spacing: -0.02em; }
.card-vinyl .v-text small { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; margin-top: 8px; }

/* Banner */
.card-banner {
  width: 280px; height: 160px; bottom: 40px; left: 80px;
  transform: translateZ(20px) rotate(4deg);
  background: var(--magenta);
  color: var(--paper);
  box-shadow:
    0 30px 50px -20px rgba(0,0,0,0.8),
    0 0 60px -10px rgba(255,45,135,0.4);
  padding: 22px; overflow: hidden;
}
.card-banner .b-stripe {
  position: absolute; inset: 0;
  background: repeating-linear-gradient(45deg, transparent 0 18px, rgba(255,255,255,0.08) 18px 20px);
}
.card-banner .b-text { font-family: var(--display); font-size: 28px; line-height: 0.9; position: relative; z-index: 2; }
.card-banner .b-meta { position: absolute; bottom: 16px; left: 22px; right: 22px; display: flex; justify-content: space-between; font-family: var(--mono); font-size: 10px; letter-spacing: 0.15em; opacity: 0.8; z-index: 2; }

/* Tusker floating mark */
.tusk-mark {
  position: absolute; top: -10px; right: 50px;
  width: 110px; height: 110px;
  transform: translateZ(180px) rotate(-10deg);
  background: var(--paper); color: var(--ink);
  border-radius: 22px;
  display: grid; place-items: center;
  box-shadow: 0 30px 60px -15px rgba(0,0,0,0.7);
}
.tusk-mark svg { width: 64px; height: 64px; }

/* Ticket */
.card-ticket {
  width: 220px; height: 90px; bottom: 240px; right: 60px;
  transform: translateZ(90px) rotate(-4deg);
  background: var(--paper); color: var(--ink);
  padding: 14px 18px;
  box-shadow: 0 20px 40px -10px rgba(0,0,0,0.6);
  display: flex; flex-direction: column; justify-content: center;
}
.card-ticket::before, .card-ticket::after {
  content: ""; position: absolute; top: 50%; width: 16px; height: 16px;
  background: var(--ink); border-radius: 50%; transform: translateY(-50%);
}
.card-ticket::before { left: -8px; }
.card-ticket::after { right: -8px; }
.card-ticket .t-num { font-family: var(--display); font-size: 22px; letter-spacing: -0.02em; }
.card-ticket .t-lbl { font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; opacity: 0.6; }

/* Floating chips */
.chip3d {
  position: absolute; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em;
  padding: 8px 12px; background: rgba(244,236,220,0.06); border: 1px solid var(--line); border-radius: 999px;
  backdrop-filter: blur(10px);
  text-transform: uppercase;
}
.chip-a { top: 0; right: 30%; transform: translateZ(220px); }
.chip-b { bottom: 160px; left: -10px; transform: translateZ(160px); }

/* ============ MARQUEE ============ */
.marquee {
  background: var(--neon); color: var(--ink);
  padding: 24px 0; overflow: hidden; position: relative; z-index: 3;
  border-top: 2px solid var(--ink); border-bottom: 2px solid var(--ink);
  transform: rotate(-1.5deg) scale(1.04);
  margin: -20px 0;
}
.marquee-track {
  display: flex; gap: 40px; white-space: nowrap;
  animation: scroll 32s linear infinite;
  font-family: var(--display); font-size: 36px; letter-spacing: -0.02em;
  align-items: center;
}
.marquee-track span { display: inline-flex; align-items: center; gap: 40px; }
.marquee-track .sep { width: 16px; height: 16px; background: var(--ink); border-radius: 50%; }
@keyframes scroll { to { transform: translateX(-50%); } }

/* ============ SECTIONS ============ */
section { position: relative; }
.section-head {
  display: flex; justify-content: space-between; align-items: flex-end; gap: 40px;
  padding: 100px 60px 40px;
}
.section-head .label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.55; margin-bottom: 18px; display: flex; align-items: center; gap: 10px; }
.section-head .label::before { content: ""; width: 24px; height: 1px; background: var(--tusker); }
.section-head h2 { font-family: var(--display); font-size: clamp(40px, 5.4vw, 84px); line-height: 0.92; letter-spacing: -0.03em; max-width: 14ch; }
.section-head h2 em { font-style: normal; color: var(--tusker); }
.section-head .head-meta { font-family: var(--mono); font-size: 12px; opacity: 0.6; max-width: 32ch; text-align: right; line-height: 1.6; }
.section-head .head-meta-hint { color: var(--tusker); opacity: 0.95; letter-spacing: 0.06em; }

/* Product strip — horizontal scroll with snap (≈3 cards visible on desktop,
   peek of next card cues "more →"). Right-edge gradient mask reinforces.
   NOTE: at ≥1100px this gets overridden into a JS-driven scroll-pinned
   horizontal track (see media query below + main.js services-pin handler). */
.services-pin-wrap, .services-pin { display: block; }
.services-progress { display: none; }
.product-grid {
  display: flex; gap: 16px;
  padding: 20px 60px 80px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-left: 60px;
  scroll-behavior: smooth;
  /* fade the right edge so the cut-off card reads as "there's more" */
  -webkit-mask-image: linear-gradient(to right, black 0, black calc(100% - 80px), transparent 100%);
          mask-image: linear-gradient(to right, black 0, black calc(100% - 80px), transparent 100%);
  perspective: 1600px;
}
/* hide native scrollbar — discoverability via the visual cue + the
   mono "→ Scroll for all 8" label inside .section-head .head-meta */
.product-grid::-webkit-scrollbar { display: none; }
.product-grid { scrollbar-width: none; }

/* ── Desktop: scroll-pinned horizontal strip ────────────────────────────
   Wrapper provides a 300vh vertical scroll runway. Inner sticky container
   stays at top:0 for the wrap's range. JS in main.js reads scroll progress
   within the wrap and writes a translateX on .product-grid. After the
   wrap's runway ends, normal vertical scroll resumes into the next section.
   Activated at ≥1100px only — mobile/tablet keep the native scroll-snap
   strip above. */
@media (min-width: 1100px) {
  .services-pin-wrap {
    position: relative;
    /* runway = (wrap-height − viewport) of vertical scroll mapped to
       horizontal track travel. 300vh = 200vh of pin-scroll runway. */
    height: 300vh;
  }
  .services-pin {
    position: sticky; top: 0;
    height: 100vh;
    overflow: hidden;
    display: flex; flex-direction: column;
    justify-content: center;
    /* prevent any scroll-chain weirdness during the pin */
    overscroll-behavior: contain;
  }
  /* Override the native-scroll strip: no overflow, no snap, no mask —
     the JS drives translateX instead. */
  .services-pin .product-grid {
    overflow: visible;
    scroll-snap-type: none;
    scroll-behavior: auto;
    -webkit-mask-image: none;
            mask-image: none;
    padding: 20px 60px 40px;
    will-change: transform;
  }
  .services-pin .prod {
    scroll-snap-align: none;
  }
  /* Progress line under the strip — width filled by JS via inline style */
  .services-progress {
    display: block;
    position: relative;
    width: calc(100% - 120px);
    margin: 0 60px 28px;
    height: 2px;
    background: rgba(244, 236, 220, 0.08);
    border-radius: 2px;
    overflow: hidden;
  }
  .services-progress-fill {
    position: absolute; top: 0; left: 0; bottom: 0;
    width: 0;
    background: linear-gradient(90deg, var(--tusker), var(--neon));
    border-radius: 2px;
    transition: width 0.05s linear;
  }
}
.prod {
  flex: 0 0 380px;
  scroll-snap-align: start;
  position: relative; aspect-ratio: 0.95; border-radius: 22px;
  background: var(--ink-2); border: 1px solid var(--line);
  padding: 22px; overflow: hidden;
  transform-style: preserve-3d;
  transition: transform 0.3s cubic-bezier(0.2, 0.9, 0.3, 1), box-shadow 0.3s;
  cursor: pointer; will-change: transform;
}
.prod:hover {
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.7), 0 0 0 1px var(--tusker);
}
.prod .num { font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; opacity: 0.5; transform: translateZ(40px); }
.prod .visual {
  position: absolute; inset: 50px 22px 70px;
  border-radius: 14px; overflow: hidden;
  display: grid; place-items: center;
  transform: translateZ(60px);
  transition: transform 0.3s;
}
.prod .visual img, .showcase-card .visual img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  filter: contrast(1.08) brightness(0.92) saturate(0.55);
  transition: filter 0.4s, transform 0.6s;
}
.prod:hover .visual img, .showcase-card:hover .visual img {
  filter: contrast(1.12) brightness(1) saturate(0.85);
  transform: scale(1.04);
}
.prod .visual::after, .showcase-card .visual::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(140deg, rgba(255,91,31,0.32), rgba(14,11,8,0.55) 70%);
  mix-blend-mode: multiply;
  transition: opacity 0.4s;
}
.prod.led .visual::after { background: linear-gradient(140deg, rgba(255,91,31,0.55), rgba(14,11,8,0.7)); }
.prod.banner .visual::after { background: linear-gradient(140deg, rgba(255,45,135,0.35), rgba(14,11,8,0.5)); }
.prod.flyer .visual::after { background: linear-gradient(140deg, rgba(255,214,10,0.28), rgba(14,11,8,0.4)); }
.prod.standee .visual::after { background: linear-gradient(140deg, rgba(255,214,10,0.42), rgba(14,11,8,0.45)); }
.prod.signage .visual::after { background: linear-gradient(140deg, rgba(255,214,10,0.25), rgba(14,11,8,0.6)); }
.prod.kit .visual::after { background: linear-gradient(140deg, rgba(255,45,135,0.28), rgba(14,11,8,0.5)); }
.prod:hover .visual::after, .showcase-card:hover .visual::after { opacity: 0.75; }
.prod .name { position: absolute; bottom: 22px; left: 22px; font-family: var(--display); font-size: 22px; line-height: 0.95; letter-spacing: -0.02em; transform: translateZ(80px); }
.prod .arrow { position: absolute; bottom: 22px; right: 22px; width: 32px; height: 32px; border-radius: 50%; background: var(--paper); color: var(--ink); display: grid; place-items: center; transform: translateZ(80px); transition: transform 0.3s, background 0.3s; }
.prod:hover .arrow { background: var(--tusker); color: var(--paper); transform: translateZ(80px) rotate(-45deg); }

.prod.vinyl .visual { background: linear-gradient(135deg, var(--tusker), #B53A0E); }
.prod.led .visual { background: #0a0805; border: 1px solid rgba(255,91,31,0.4); }
.prod.led .visual::before { content: "OPEN"; font-family: var(--display); font-size: 52px; color: var(--tusker); text-shadow: 0 0 20px var(--tusker); }
.prod.banner .visual { background: var(--magenta); background-image: repeating-linear-gradient(45deg, transparent 0 14px, rgba(0,0,0,0.1) 14px 16px); }
.prod.flyer .visual { background: var(--paper); }
.prod.flyer .visual::before { content: ""; width: 60%; height: 80%; background: repeating-linear-gradient(transparent 0 6px, var(--ink) 6px 8px); opacity: 0.15; }
.prod.standee .visual { background: linear-gradient(180deg, var(--neon), #BF9F00); }
.prod.standee .visual::before { content: ""; width: 70%; height: 90%; background: var(--ink); border-radius: 6px 6px 0 0; }
.prod.signage .visual { background: var(--ink); border: 2px solid var(--neon); }
.prod.signage .visual::before { content: "BRAND"; font-family: var(--display); font-size: 44px; color: var(--neon); letter-spacing: -0.02em; }
.prod.floor .visual { background: #1a1410; background-image: repeating-linear-gradient(0deg, transparent 0 18px, rgba(244,236,220,0.05) 18px 19px), repeating-linear-gradient(90deg, transparent 0 18px, rgba(244,236,220,0.05) 18px 19px); }
.prod.floor .visual::before { content: "↓ STAND"; font-family: var(--display); font-size: 28px; color: var(--tusker); }
.prod.kit .visual { background: linear-gradient(135deg, var(--paper), var(--paper-2)); display: flex; gap: 6px; padding: 16px; }
.prod.kit .visual::before, .prod.kit .visual::after { content: ""; flex: 1; height: 100%; background: var(--ink); border-radius: 6px; }
.prod.kit .visual::after { background: var(--tusker); }

.prod .glow { position: absolute; inset: 0; background: radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,91,31,0.18), transparent 50%); opacity: 0; transition: opacity 0.3s; pointer-events: none; }
.prod:hover .glow { opacity: 1; }

/* ============ EXTRUDED TYPE / SHOWCASE ============ */
.showcase {
  background: var(--paper); color: var(--ink);
  padding: 120px 60px;
  position: relative; overflow: hidden;
  border-radius: 40px 40px 0 0;
}
.showcase::before {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(14,11,8,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
  pointer-events: none;
}

.tusker-3d {
  font-family: var(--display); font-size: clamp(120px, 22vw, 360px);
  line-height: 0.82; letter-spacing: -0.05em; text-align: center;
  color: var(--ink); position: relative;
  text-shadow:
    1px 1px 0 var(--ink-2),
    2px 2px 0 var(--ink-2),
    3px 3px 0 var(--ink-2),
    4px 4px 0 var(--ink-2),
    5px 5px 0 var(--ink-2),
    6px 6px 0 #B53A0E,
    7px 7px 0 #B53A0E,
    8px 8px 0 var(--tusker),
    9px 9px 0 var(--tusker),
    10px 10px 0 var(--tusker),
    12px 12px 24px rgba(0,0,0,0.2);
  transform: rotate(-1.5deg);
}

.showcase-grid {
  display: grid; grid-template-columns: 1fr 1.4fr 1fr; gap: 24px;
  margin-top: 80px; align-items: end;
}
.showcase-card {
  background: var(--ink); color: var(--paper); padding: 28px;
  border-radius: 20px; aspect-ratio: 0.85;
  position: relative; overflow: hidden;
  transform-style: preserve-3d;
  transition: transform 0.4s cubic-bezier(0.2, 0.9, 0.3, 1);
}
.showcase-card:nth-child(1) { transform: rotate(-3deg) translateY(20px); }
.showcase-card:nth-child(2) { transform: rotate(1deg); aspect-ratio: 0.95; }
.showcase-card:nth-child(3) { transform: rotate(4deg) translateY(30px); }
.showcase-card:hover { transform: rotate(0deg) translateY(0) scale(1.03); z-index: 2; }
.showcase-card .label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.6; }
.showcase-card .title { font-family: var(--display); font-size: 32px; line-height: 0.95; margin-top: 8px; }
.showcase-card .visual { position: absolute; bottom: 24px; left: 24px; right: 24px; height: 50%; border-radius: 12px; }
.showcase-card:nth-child(1) .visual { background: var(--tusker); }
.showcase-card:nth-child(2) .visual { background: var(--magenta); background-image: repeating-linear-gradient(-45deg, transparent 0 14px, rgba(0,0,0,0.1) 14px 16px); }
.showcase-card:nth-child(3) .visual { background: var(--neon); }
.showcase-card .meta { position: absolute; bottom: 8px; left: 24px; right: 24px; display: flex; justify-content: space-between; font-family: var(--mono); font-size: 9px; letter-spacing: 0.15em; opacity: 0.5; }

/* ============ PROCESS ============ */
.process { padding: 120px 60px; background: var(--ink); }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 40px; }
.step {
  position: relative; padding: 32px 28px 28px;
  border: 1px solid var(--line); border-radius: 22px;
  background: var(--ink-2);
  transition: transform 0.3s, background 0.3s;
}
.step:hover { transform: translateY(-6px); background: linear-gradient(180deg, var(--ink-2), rgba(255,91,31,0.06)); }
.step .step-num {
  position: absolute; top: -22px; left: 28px;
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--tusker); color: var(--paper);
  display: grid; place-items: center;
  font-family: var(--display); font-size: 18px;
  box-shadow: 0 6px 0 0 #B53A0E;
}
.step:nth-child(2) .step-num { background: var(--neon); color: var(--ink); box-shadow: 0 6px 0 0 #BF9F00; }
.step:nth-child(3) .step-num { background: var(--magenta); color: var(--paper); box-shadow: 0 6px 0 0 #C71C66; }
.step:nth-child(4) .step-num { background: var(--paper); color: var(--ink); box-shadow: 0 6px 0 0 #A89F8C; }
.step h3 { font-family: var(--display); font-size: 22px; line-height: 1; margin-top: 24px; margin-bottom: 12px; letter-spacing: -0.02em; }
.step p { font-size: 14px; line-height: 1.55; opacity: 0.7; }
.step .meta { font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; opacity: 0.4; margin-top: 20px; text-transform: uppercase; }

/* ============ PARTNERS ============ */
.partners { padding: 80px 60px; background: var(--ink); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.partners-head { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.5; text-align: center; margin-bottom: 40px; }
.partners-row { display: flex; justify-content: space-around; align-items: center; gap: 40px; flex-wrap: wrap; }
.partner-logo {
  font-family: var(--display); font-size: 22px; letter-spacing: -0.02em; opacity: 0.4;
  transition: opacity 0.3s, transform 0.3s;
  padding: 16px 24px; border: 1px solid var(--line); border-radius: 12px;
}
.partner-logo:hover { opacity: 1; transform: translateY(-4px); }

/* ============ BIG CTA ============ */
.bigcta {
  margin: 80px 60px; padding: 80px 60px;
  background: var(--tusker); color: var(--paper);
  border-radius: 36px; position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1.4fr 1fr; align-items: center; gap: 40px;
}
.bigcta::before {
  content: ""; position: absolute; top: -100px; right: -100px;
  width: 400px; height: 400px; border-radius: 50%;
  background: var(--neon); opacity: 0.9;
}
.bigcta::after {
  content: ""; position: absolute; bottom: -120px; left: 30%;
  width: 300px; height: 300px; border-radius: 50%;
  background: var(--magenta);
  mix-blend-mode: multiply;
}
.bigcta h2 { font-family: var(--display); font-size: clamp(40px, 6vw, 88px); line-height: 0.9; letter-spacing: -0.03em; position: relative; z-index: 2; }
.bigcta h2 .stroke { -webkit-text-stroke: 2px var(--paper); color: transparent; }
.bigcta .cta-side { position: relative; z-index: 2; }
.bigcta .cta-side p { font-size: 16px; margin-bottom: 24px; opacity: 0.9; }
.bigcta .bigbutton {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 18px 26px; background: var(--ink); color: var(--paper);
  border-radius: 999px; font-family: var(--mono); font-size: 13px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  box-shadow: 0 8px 0 0 #000;
  transition: transform 0.15s, box-shadow 0.15s;
}
.bigcta .bigbutton:hover { transform: translateY(2px); box-shadow: 0 6px 0 0 #000; }
.bigcta .bigbutton:active { transform: translateY(8px); box-shadow: 0 0 0 0 #000; }
.bigcta .bigbutton .ico { width: 28px; height: 28px; border-radius: 50%; background: var(--tusker); display: grid; place-items: center; }

/* ============ FOOTER ============ */
footer { padding: 60px 60px 30px; background: var(--ink); border-top: 1px solid var(--line); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.2fr; gap: 40px; padding-bottom: 40px; border-bottom: 1px solid var(--line); }
.footer-grid h4 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.5; margin-bottom: 16px; }
.footer-grid ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-grid ul a { font-size: 14px; opacity: 0.85; }
.footer-grid ul a:hover { color: var(--tusker); }
.footer-grid .col-brand p { font-size: 14px; opacity: 0.7; line-height: 1.6; margin-top: 18px; max-width: 38ch; }
.footer-bottom { display: flex; justify-content: space-between; padding-top: 24px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; opacity: 0.5; }

/* ============ TWEAKS PANEL ============ */
.tweaks-panel {
  position: fixed; bottom: 24px; right: 24px; z-index: 300;
  background: var(--ink-2); border: 1px solid var(--line); border-radius: 18px;
  padding: 20px; width: 280px;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.6);
  display: none;
}
.tweaks-panel.open { display: block; }
.tweaks-panel h4 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.6; margin-bottom: 14px; display: flex; justify-content: space-between; align-items: center; }
.tweaks-panel .close { background: var(--line); border-radius: 50%; width: 22px; height: 22px; display: grid; place-items: center; font-size: 14px; }
.swatches { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 16px; }
.swatch { aspect-ratio: 1; border-radius: 10px; cursor: pointer; border: 2px solid transparent; position: relative; transition: transform 0.15s; }
.swatch.active { border-color: var(--paper); }
.swatch:hover { transform: scale(1.08); }
.tweaks-panel label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; opacity: 0.6; display: block; margin-bottom: 8px; }

/* ============ RESPONSIVE ============ */
@media (max-width: 1100px) {
  .hero { grid-template-columns: 1fr; padding: 110px 32px 40px; }
  .scene { height: 500px; margin-top: 40px; }
  .product-grid { padding: 20px 32px 60px; scroll-padding-left: 32px; -webkit-mask-image: linear-gradient(to right, black 0, black calc(100% - 56px), transparent 100%); mask-image: linear-gradient(to right, black 0, black calc(100% - 56px), transparent 100%); }
  .prod { flex: 0 0 min(78vw, 340px); }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .showcase-grid { grid-template-columns: 1fr; }
  .bigcta { grid-template-columns: 1fr; margin: 60px 32px; padding: 60px 36px; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .section-head { flex-direction: column; align-items: flex-start; padding: 80px 32px 30px; }
  .section-head .head-meta { text-align: left; }
  .nav-links { display: none; }
  .showcase { padding: 80px 32px; }
  .process { padding: 80px 32px; }
}


/* ============================================================================
   v3 ADDITIONS — About, Spotlights, Gallery, Lightbox, Testimonials, FAQ, Form
   ============================================================================ */

/* ============ ABOUT ============ */
.about {
  padding: 110px 60px 80px;
  background: var(--ink);
  position: relative;
}
.about-grid {
  display: grid;
  grid-template-columns: 1fr 2.4fr;
  gap: 60px;
  align-items: flex-start;
  max-width: 1480px;
  margin: 0 auto;
}
.about-eyebrow {
  position: sticky; top: 100px;
  display: flex; flex-direction: column; gap: 14px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
}
.about-eyebrow .label {
  color: var(--tusker);
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line);
}
.about-eyebrow .loc { opacity: 0.55; }
.about-h {
  font-family: var(--display);
  font-size: clamp(40px, 5.8vw, 92px);
  line-height: 0.92; letter-spacing: -0.03em;
  margin-bottom: 36px;
}
.about-h em { font-style: normal; color: var(--tusker); }
.about-cols {
  display: grid; grid-template-columns: 1fr 1fr; gap: 30px;
  max-width: 760px;
  margin-bottom: 48px;
}
.about-cols p { font-size: 16px; line-height: 1.6; opacity: 0.78; }
.about-cols strong { color: var(--neon); font-weight: 500; }
.about-marks {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  padding-top: 32px; border-top: 1px dashed var(--line);
}
.mark-tile {
  padding: 18px 20px;
  background: var(--ink-2);
  border-radius: 16px;
  border: 1px solid var(--line);
  transition: transform 0.2s, border-color 0.2s;
}
.mark-tile:hover { transform: translateY(-3px); border-color: var(--tusker); }
.mark-tile .mark-n {
  font-family: var(--display);
  font-size: 36px;
  line-height: 1; letter-spacing: -0.02em;
  color: var(--paper);
}
.mark-tile .mark-n span { color: var(--tusker); }
.mark-tile .mark-l {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  opacity: 0.55; margin-top: 12px; line-height: 1.4;
}

/* ============ SERVICE SPOTLIGHTS ============ */
.spotlights {
  background: var(--ink); padding-bottom: 80px;
}
.spot {
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: 50px;
  align-items: center;
  padding: 90px 60px;
  border-bottom: 1px solid var(--line);
  max-width: 1480px; margin: 0 auto;
}
.spot.reverse { grid-template-columns: 1.05fr 1fr; }
.spot.reverse .spot-art { order: 0; }
.spot.reverse .spot-copy { order: 1; }
.spot:last-of-type { border-bottom: none; }
.spot-copy { max-width: 540px; }
.spot-tag {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--tusker);
  margin-bottom: 18px;
}
.spot h3 {
  font-family: var(--display);
  font-size: clamp(32px, 3.6vw, 56px);
  line-height: 0.94; letter-spacing: -0.025em;
  margin-bottom: 24px;
  text-wrap: balance;
}
.spot h3 em { font-style: normal; color: var(--tusker); }
.spot p {
  font-size: 16px; line-height: 1.6; opacity: 0.78;
  margin-bottom: 22px;
}
.spot-bullets {
  list-style: none; padding: 0; margin: 0 0 28px;
  display: flex; flex-direction: column; gap: 10px;
}
.spot-bullets li {
  font-size: 14px; line-height: 1.45;
  padding-left: 22px; position: relative; opacity: 0.85;
}
.spot-bullets li::before {
  content: "→"; position: absolute; left: 0; top: 0;
  color: var(--tusker); font-family: var(--mono); font-weight: 700;
}

/* Spot art shared */
.spot-art {
  position: relative; aspect-ratio: 1.05;
  border-radius: 24px; overflow: hidden;
  background: var(--ink-2);
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.6);
}

/* Spot LED — glass panel with glow */
.spot-art-led {
  background: radial-gradient(70% 70% at 50% 50%, rgba(255,91,31,0.18), var(--ink-2));
  display: grid; place-items: center;
  padding: 30px;
}
.spot-glass {
  position: relative;
  width: 92%; aspect-ratio: 1.35;
  background: linear-gradient(135deg, #1a0f08, #050402);
  border: 1px solid rgba(255,91,31,0.4);
  border-radius: 16px;
  display: grid; place-items: center; gap: 14px;
  padding: 30px;
  box-shadow: inset 0 0 80px rgba(0,0,0,0.6);
}
.spot-glass::before {
  content: ""; position: absolute; inset: 14px;
  border: 2px dashed rgba(255,91,31,0.25); border-radius: 10px;
  pointer-events: none;
}
.spot-glow {
  position: absolute; inset: 0;
  background: radial-gradient(40% 40% at 50% 60%, rgba(255,91,31,0.45), transparent);
  pointer-events: none;
}
.spot-sign {
  font-family: var(--display);
  font-size: clamp(60px, 7vw, 110px);
  letter-spacing: -0.02em; line-height: 1;
  color: var(--tusker);
  text-shadow: 0 0 24px var(--tusker), 0 0 60px rgba(255,91,31,0.6);
  z-index: 2;
}
.spot-sub {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.25em; color: var(--neon);
  z-index: 2;
}
.spot-meta-strip {
  position: absolute; bottom: 16px; left: 30px; right: 30px;
  display: flex; gap: 18px; justify-content: space-between;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; color: rgba(244,236,220,0.5);
  text-transform: uppercase;
}

/* Spot 3D-printed — layered stack of letters */
.spot-art-printed {
  background: linear-gradient(180deg, var(--ink-2) 0%, var(--ink-2) 70%, #0a0805 100%);
  padding: 40px;
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  gap: 30px;
}
.printed-stack {
  position: relative;
  display: flex; gap: 6px;
  font-family: var(--display);
  font-size: clamp(60px, 9vw, 130px);
  line-height: 1;
}
.printed-stack .layer {
  color: var(--tusker);
  text-shadow:
    1px 1px 0 #b53a0e,
    2px 2px 0 #b53a0e,
    3px 3px 0 #b53a0e,
    4px 4px 0 #b53a0e,
    5px 5px 0 #802a0a,
    6px 6px 0 #802a0a,
    7px 7px 0 #401505,
    9px 9px 30px rgba(0,0,0,0.6);
  transform: translateY(0);
}
.printed-stack .l1 { transform: translateY(-4px); }
.printed-stack .l3 { transform: translateY(4px); color: var(--paper); text-shadow: 1px 1px 0 #888, 2px 2px 0 #666, 3px 3px 0 #444, 4px 4px 0 #222, 6px 6px 24px rgba(0,0,0,0.6); }
.printed-stack .l5 { color: var(--neon); text-shadow: 1px 1px 0 #bf9f00, 2px 2px 0 #bf9f00, 3px 3px 0 #8b7500, 5px 5px 20px rgba(0,0,0,0.6); }
.spot-caption {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.22em; opacity: 0.5;
  text-transform: uppercase;
}

/* Spot Vinyl — sticker + sheet */
.spot-art-vinyl {
  background:
    radial-gradient(50% 50% at 70% 60%, rgba(255,91,31,0.2), transparent),
    var(--ink-2);
  display: grid; place-items: center;
  padding: 40px;
}
.vinyl-circle {
  position: relative;
  width: 60%; aspect-ratio: 1;
  background: var(--neon); color: var(--ink);
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--display);
  text-align: center;
  transform: rotate(8deg);
  box-shadow: 0 30px 60px -10px rgba(0,0,0,0.5), 0 0 80px -10px rgba(255,214,10,0.5);
}
.vinyl-circle::before {
  content: ""; position: absolute; inset: 12px;
  border: 2px solid var(--ink); border-radius: 50%;
}
.vinyl-inner {
  font-size: clamp(20px, 2.2vw, 36px);
  line-height: 0.95; letter-spacing: -0.02em;
}
.vinyl-inner small {
  display: block; font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.22em;
  margin-top: 10px;
}
.vinyl-sheet {
  position: absolute; left: 8%; top: 18%;
  width: 38%; height: 60%;
  background: var(--paper);
  border-radius: 8px;
  padding: 14px;
  transform: rotate(-6deg);
  box-shadow: 0 20px 40px -10px rgba(0,0,0,0.5);
  display: flex; flex-direction: column; gap: 8px;
}
.vinyl-sheet .ribbon {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.3em;
  color: var(--magenta); margin-bottom: 4px;
}
.vinyl-sheet .bar {
  display: block; height: 6px; width: 100%;
  background: var(--ink); border-radius: 3px;
}
.vinyl-sheet .bar.short { width: 60%; }

/* Spot Storefront — full-bleed variant */
.spot.full {
  grid-template-columns: 1fr;
  gap: 0;
  padding: 0;
  position: relative;
  max-width: none;
  margin: 0;
}
.spot.full .spot-bleed {
  position: relative;
  height: 60vh; min-height: 480px;
  background: linear-gradient(180deg, #050402, #0E0B08 70%);
  overflow: hidden;
}
.bleed-windows {
  position: absolute; inset: 0; bottom: 0;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px;
  padding: 50% 80px 0;
}
.bleed-windows .bw {
  background: linear-gradient(180deg, rgba(255,214,10,0.18), rgba(255,91,31,0.08) 40%, var(--ink) 80%);
  border-top: 2px solid var(--tusker);
  box-shadow: inset 0 0 60px rgba(255,91,31,0.15);
}
.bleed-awning {
  position: absolute; left: 60px; right: 60px;
  top: 38%; height: 18px;
  background: repeating-linear-gradient(90deg, var(--magenta) 0 30px, var(--neon) 30px 60px);
  transform: skewX(-2deg);
  box-shadow: 0 6px 0 0 rgba(0,0,0,0.4);
}
.bleed-sign {
  position: absolute; left: 50%; top: 16%;
  transform: translateX(-50%);
  text-align: center;
  z-index: 3;
}
.bleed-sign-letters {
  font-family: var(--display);
  font-size: clamp(48px, 7vw, 110px);
  letter-spacing: -0.02em;
  color: var(--tusker);
  text-shadow: 0 0 30px var(--tusker), 0 0 80px rgba(255,91,31,0.6);
}
.bleed-sign-sub {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.28em; color: var(--neon);
  margin-top: 6px;
}
.spot.full .spot-copy-bleed {
  max-width: 1100px;
  margin: -60px auto 0;
  background: var(--ink-2);
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 48px 56px 52px;
  position: relative; z-index: 4;
  box-shadow: 0 -30px 60px -20px rgba(0,0,0,0.6);
}

/* Spotlight CTA — re-skin */
.spot .cta.alt { background: var(--tusker); color: var(--paper); box-shadow: 0 6px 0 0 #B53A0E; }
.spot .cta.alt:hover { transform: translateY(2px); box-shadow: 0 4px 0 0 #B53A0E; }
.spot .cta.alt:active { transform: translateY(6px); box-shadow: 0 0 0 0 #B53A0E; }

/* ============ GALLERY ============ */
.gallery {
  background: var(--ink);
  padding: 0 60px 100px;
}
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 140px;
  gap: 12px;
  max-width: 1480px;
  margin: 0 auto;
}
.g-tile {
  position: relative;
  background: var(--ink-2);
  border-radius: 18px;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid var(--line);
  padding: 0;
  display: block;
  transition: transform 0.3s cubic-bezier(0.2, 0.9, 0.3, 1), border-color 0.3s, box-shadow 0.3s;
}
.g-tile.g-tall { grid-row: span 3; }
.g-tile.g-wide { grid-column: span 2; grid-row: span 2; }
.g-tile.g-sq   { grid-row: span 2; }
.g-tile img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform 0.7s cubic-bezier(0.2, 0.9, 0.3, 1), filter 0.4s;
  filter: contrast(1.05) saturate(0.95);
}
.g-tile:hover {
  transform: translateY(-4px);
  border-color: var(--tusker);
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.7);
}
.g-tile:hover img { transform: scale(1.05); filter: contrast(1.1) saturate(1.1); }
.g-overlay {
  position: absolute; inset: auto 0 0 0;
  padding: 22px 20px 18px;
  background: linear-gradient(180deg, transparent, rgba(14,11,8,0.92));
  transform: translateY(10px);
  opacity: 0;
  transition: transform 0.3s, opacity 0.3s;
}
.g-tile:hover .g-overlay,
.g-tile:focus-visible .g-overlay { opacity: 1; transform: translateY(0); }
.g-tag {
  font-family: var(--display);
  font-size: 18px; letter-spacing: -0.01em;
  color: var(--paper);
  line-height: 1.1;
}
.g-loc {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--tusker); margin-top: 6px;
}
.g-corner {
  position: absolute; top: 14px; left: 14px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.2em;
  padding: 4px 8px;
  background: rgba(14,11,8,0.6);
  backdrop-filter: blur(6px);
  border-radius: 6px;
  color: var(--paper);
  opacity: 0.75;
}
.g-tile:focus-visible { outline: 3px solid var(--tusker); outline-offset: 4px; }

/* ============ LIGHTBOX ============ */
.lightbox {
  position: fixed; inset: 0; z-index: 600;
  display: none; opacity: 0;
  transition: opacity 0.28s ease;
}
.lightbox.open { display: block; opacity: 1; }
.lb-backdrop {
  position: absolute; inset: 0;
  background: rgba(8,6,4,0.94);
  backdrop-filter: blur(8px);
}
.lb-close, .lb-prev, .lb-next {
  position: absolute; z-index: 2;
  background: rgba(244,236,220,0.06);
  color: var(--paper);
  border: 1px solid var(--line);
  border-radius: 50%;
  width: 48px; height: 48px;
  display: grid; place-items: center;
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
}
.lb-close:hover, .lb-prev:hover, .lb-next:hover {
  background: var(--tusker); border-color: var(--tusker);
}
.lb-close { top: 24px; right: 24px; }
.lb-prev  { left: 24px; top: 50%; transform: translateY(-50%); }
.lb-next  { right: 24px; top: 50%; transform: translateY(-50%); }
.lb-stage {
  position: absolute; inset: 80px 100px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 20px; z-index: 1;
  margin: 0;
}
.lb-img {
  max-width: 100%; max-height: calc(100% - 80px);
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,0.7);
}
.lb-cap {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  text-align: center;
}
.lb-tag {
  font-family: var(--display); font-size: 22px;
  letter-spacing: -0.01em; color: var(--paper);
}
.lb-meta {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--tusker);
}
.lb-count {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.2em; color: rgba(244,236,220,0.5);
  margin-top: 4px;
}
body.lb-open { overflow: hidden; }

/* ============ TESTIMONIALS ============ */
.testimonials {
  background: var(--ink);
  padding-bottom: 80px;
}
.testimonial-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
  padding: 0 60px;
  max-width: 1480px; margin: 0 auto;
}
.testimonial {
  background: var(--ink-2);
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 30px 28px 26px;
  display: flex; flex-direction: column; gap: 22px;
  position: relative;
  transition: transform 0.3s, border-color 0.3s;
  margin: 0;
}
.testimonial:hover { transform: translateY(-4px); border-color: var(--tusker); }
.testimonial.accent {
  background: var(--tusker); color: var(--paper);
  border-color: var(--tusker);
}
.testimonial blockquote {
  font-family: var(--display);
  font-size: 19px; line-height: 1.32; letter-spacing: -0.01em;
  margin: 0;
  text-wrap: pretty;
}
.testimonial.accent blockquote { color: var(--paper); }
.testimonial figcaption {
  display: flex; flex-direction: column; gap: 4px;
  padding-top: 18px;
  border-top: 1px dashed rgba(244,236,220,0.18);
  margin: auto 0 0;
}
.testimonial.accent figcaption { border-top-color: rgba(244,236,220,0.32); }
.t-stars { color: var(--neon); letter-spacing: 4px; font-size: 14px; }
.testimonial.accent .t-stars { color: var(--paper); }
.t-name {
  font-family: var(--display); font-size: 15px;
  letter-spacing: -0.01em; color: var(--paper);
}
.t-meta {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  opacity: 0.6;
}
.testimonial.accent .t-meta { opacity: 0.85; }

/* ============ FAQ ============ */
.faq {
  background: var(--ink);
  padding-bottom: 100px;
}
.faq-list {
  max-width: 980px; margin: 0 auto;
  padding: 0 60px;
  display: flex; flex-direction: column; gap: 8px;
}
.faq-item {
  background: var(--ink-2);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  transition: border-color 0.25s, background 0.25s;
}
.faq-item[open] { border-color: var(--tusker); }
.faq-item summary {
  list-style: none;
  padding: 22px 28px;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  cursor: pointer;
  user-select: none;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-q {
  font-family: var(--display); font-size: 20px;
  line-height: 1.25; letter-spacing: -0.015em;
  flex: 1;
  text-wrap: balance;
}
.faq-toggle {
  width: 32px; height: 32px;
  display: grid; place-items: center;
  background: rgba(255,91,31,0.12);
  color: var(--tusker);
  border-radius: 50%;
  font-family: var(--mono); font-size: 18px;
  transition: transform 0.3s, background 0.25s;
}
.faq-item[open] .faq-toggle {
  transform: rotate(45deg);
  background: var(--tusker); color: var(--paper);
}
.faq-a {
  padding: 0 28px 26px;
  font-size: 15px; line-height: 1.6;
  opacity: 0.78;
  max-width: 76ch;
}

/* ============ QUOTE FORM ============ */
.quote-section {
  background: var(--tusker); color: var(--paper);
  margin: 60px 60px 80px;
  padding: 64px 60px 60px;
  border-radius: 36px;
  position: relative; overflow: hidden;
}
.quote-section::before {
  content: ""; position: absolute; top: -120px; right: -120px;
  width: 440px; height: 440px; border-radius: 50%;
  background: var(--neon); opacity: 0.9; z-index: 0;
}
.quote-section::after {
  content: ""; position: absolute; bottom: -140px; left: -80px;
  width: 360px; height: 360px; border-radius: 50%;
  background: var(--magenta); mix-blend-mode: multiply; z-index: 0;
}
.quote-grid {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 1fr 1.15fr; gap: 60px;
  align-items: flex-start;
}
.quote-pitch .label {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--paper); opacity: 0.85;
  margin-bottom: 18px;
  display: flex; align-items: center; gap: 10px;
}
.quote-pitch .label::before { content: ""; width: 24px; height: 1px; background: var(--paper); }
.quote-pitch h2 {
  font-family: var(--display);
  font-size: clamp(44px, 6vw, 88px);
  line-height: 0.9; letter-spacing: -0.03em;
}
.quote-pitch h2 .stroke { -webkit-text-stroke: 2px var(--paper); color: transparent; }
.quote-lede {
  margin: 24px 0 32px; max-width: 36ch;
  font-size: 17px; line-height: 1.5; opacity: 0.92;
}
.quote-direct {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 12px;
  max-width: 420px;
}
.quote-direct li {
  display: grid; grid-template-columns: 110px 1fr; gap: 16px;
  padding: 12px 0;
  border-bottom: 1px dashed rgba(244,236,220,0.32);
}
.qd-l {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase;
  opacity: 0.75;
}
.qd-v {
  font-family: var(--display); font-size: 15px;
  letter-spacing: -0.01em; color: var(--paper);
}
a.qd-v:hover { color: var(--ink); }

.quote-form {
  background: var(--paper); color: var(--ink);
  border-radius: 28px;
  padding: 32px 32px 28px;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.4);
  display: flex; flex-direction: column; gap: 18px;
}
.qf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.qf-field { display: flex; flex-direction: column; gap: 8px; border: 0; padding: 0; margin: 0; }
.qf-field > span,
.qf-field > legend {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink); opacity: 0.7;
}
.qf-field > span small,
.qf-field > legend small {
  font-family: var(--mono); font-weight: 400;
  text-transform: none; letter-spacing: 0.04em;
  opacity: 0.55; margin-left: 6px;
}
.qf-field input[type="text"],
.qf-field input[type="email"],
.qf-field select,
.qf-field textarea {
  font-family: var(--sans);
  font-size: 15px; line-height: 1.4;
  color: var(--ink);
  background: rgba(14,11,8,0.04);
  border: 1px solid rgba(14,11,8,0.14);
  border-radius: 12px;
  padding: 13px 14px;
  width: 100%;
  transition: border-color 0.2s, background 0.2s;
}
.qf-field input:focus,
.qf-field select:focus,
.qf-field textarea:focus {
  outline: none;
  border-color: var(--tusker);
  background: rgba(255,91,31,0.06);
}
.qf-field textarea { resize: vertical; min-height: 100px; }
.qf-field select {
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8'><path d='M1 1l5 5 5-5' stroke='%230E0B08' stroke-width='2' fill='none' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 38px;
}

.qf-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.qf-chips label,
.qf-radios label {
  position: relative; cursor: pointer;
}
.qf-chips input,
.qf-radios input {
  position: absolute; opacity: 0; pointer-events: none;
}
.qf-chips label span {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
  padding: 9px 14px;
  background: rgba(14,11,8,0.06);
  border: 1px solid rgba(14,11,8,0.14);
  border-radius: 999px;
  color: var(--ink);
  transition: background 0.18s, color 0.18s, border-color 0.18s, transform 0.15s;
}
.qf-chips label:hover span { border-color: var(--ink); transform: translateY(-1px); }
.qf-chips input:checked + span {
  background: var(--ink); color: var(--paper);
  border-color: var(--ink);
}
.qf-chips input:checked + span::before {
  content: "✓"; font-family: var(--display); font-size: 11px;
  color: var(--neon);
}
.qf-chips input:focus-visible + span {
  outline: 3px solid var(--tusker); outline-offset: 2px;
}

.qf-radios { display: flex; gap: 8px; }
.qf-radios label span {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
  padding: 9px 16px;
  background: rgba(14,11,8,0.06);
  border: 1px solid rgba(14,11,8,0.14);
  border-radius: 10px;
  transition: background 0.18s, color 0.18s, border-color 0.18s;
}
.qf-radios input:checked + span {
  background: var(--tusker); color: var(--paper); border-color: var(--tusker);
}
.qf-radios input:focus-visible + span {
  outline: 3px solid var(--neon); outline-offset: 2px;
}

.qf-submit {
  margin-top: 6px;
  display: inline-flex; align-items: center; justify-content: center; gap: 12px;
  padding: 18px 24px;
  background: var(--ink); color: var(--paper);
  border-radius: 14px;
  font-family: var(--mono); font-size: 13px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  box-shadow: 0 8px 0 0 #000;
  transition: transform 0.15s, box-shadow 0.15s, background 0.25s;
  cursor: pointer;
  border: none;
}
.qf-submit:hover { transform: translateY(2px); box-shadow: 0 6px 0 0 #000; }
.qf-submit:active { transform: translateY(8px); box-shadow: 0 0 0 0 #000; }
.qf-submit .ico {
  width: 30px; height: 30px;
  background: var(--tusker); color: var(--paper);
  border-radius: 50%;
  display: grid; place-items: center;
}
.qf-submit.sent { background: #1B5E20; }
.qf-submit.sent .ico { background: var(--neon); color: var(--ink); }
.qf-fine {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.06em; opacity: 0.6;
  line-height: 1.5; text-align: center;
  color: var(--ink);
}

/* ============ RESPONSIVE — v3 additions ============ */
@media (max-width: 1100px) {
  .about { padding: 80px 32px 60px; }
  .about-grid { grid-template-columns: 1fr; gap: 30px; }
  .about-eyebrow { position: static; flex-direction: row; justify-content: space-between; align-items: center; }
  .about-eyebrow .label { border-bottom: none; padding-bottom: 0; }
  .about-cols { grid-template-columns: 1fr; max-width: none; }
  .about-marks { grid-template-columns: repeat(2, 1fr); }

  .spot, .spot.reverse { grid-template-columns: 1fr; gap: 30px; padding: 60px 32px; }
  .spot.reverse .spot-art { order: 1; }
  .spot.reverse .spot-copy { order: 0; }
  .spot.full .spot-bleed { height: 50vh; min-height: 360px; }
  .spot.full .spot-copy-bleed { margin: -40px 24px 0; padding: 36px 28px; }

  .gallery { padding: 0 32px 80px; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 120px; }
  .g-tile.g-wide { grid-column: span 2; }

  .lb-stage { inset: 60px 24px; }
  .lb-prev, .lb-next, .lb-close { width: 40px; height: 40px; }
  .lb-prev { left: 12px; }
  .lb-next { right: 12px; }

  .testimonial-grid { grid-template-columns: 1fr; padding: 0 32px; }
  .faq-list { padding: 0 32px; }

  .quote-section { margin: 40px 32px 60px; padding: 48px 28px 40px; border-radius: 28px; }
  .quote-grid { grid-template-columns: 1fr; gap: 36px; }
  .quote-form { padding: 24px 20px; }
  .qf-row { grid-template-columns: 1fr; }
}

@media (max-width: 700px) {
  .gallery-grid { grid-template-columns: 1fr; grid-auto-rows: 220px; }
  .g-tile.g-wide, .g-tile.g-tall, .g-tile.g-sq { grid-column: span 1; grid-row: span 1; }
  .g-overlay { opacity: 1; transform: translateY(0); }
  .about-marks { grid-template-columns: 1fr 1fr; }
  .qf-radios { flex-wrap: wrap; }
}
