/* PADDOCK — industrial / garage */

.pad-body {
  background: oklch(0.14 0.008 55);
  overflow-x: hidden;
}

[data-variant="paddock"] {
  --bg: oklch(0.14 0.008 55);
  --bg-2: oklch(0.17 0.010 55);
  --surface: oklch(0.20 0.012 55);
  --line: oklch(0.30 0.015 55);
  --line-strong: oklch(0.44 0.018 55);
  --font-display: 'Oswald', 'Bebas Neue', 'Impact', sans-serif;
}

/* Russian-friendly display font overrides */
.pad-hero__title,
.pad-hero__cell b,
.pad-section__head h2,
.pad-section__head .num,
.pad-crew__name,
.pad-event__name,
.pad-shop h3,
.pad-footer h5,
.pad-stamp__no,
.pad-sticker,
.pad-crew__specs b {
  font-family: var(--font-display);
  font-weight: 700;
}

/* Hazard strip top */
.pad-strip {
  height: 18px;
  background-image: repeating-linear-gradient(
    135deg,
    var(--accent) 0 22px,
    oklch(0.10 0.01 55) 22px 44px
  );
}

/* Hero */
.pad-hero {
  position: relative;
  padding: 60px 40px 80px;
  max-width: 1440px;
  margin: 0 auto;
  overflow: hidden;
}
.pad-hero__top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 40px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-dim);
}
.pad-hero__top b { color: var(--accent); }

.pad-hero__title {
  font-family: var(--font-head);
  font-size: clamp(80px, 16vw, 260px);
  line-height: 0.82;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  position: relative;
  z-index: 2;
}
.pad-hero__title .line {
  display: block;
  overflow: hidden;
}
.pad-hero__title .line > .fill,
.pad-hero__title .line > .stencil {
  animation: padHeroRise 0.8s var(--ease) both;
}
.pad-hero__title .line:nth-child(2) > span { animation-delay: 0.10s; }
.pad-hero__title .line:nth-child(3) > span { animation-delay: 0.20s; }
@keyframes padHeroRise {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}
[data-motion="off"] .pad-hero__title .line > span { animation: none; }
@media (prefers-reduced-motion: reduce) {
  .pad-hero__title .line > span { animation: none; }
}
.pad-hero__title .stencil {
  display: block;
  color: transparent;
  -webkit-text-stroke: 3px var(--accent);
}
.pad-hero__title .fill {
  display: block;
  color: var(--fg);
}
.pad-hero__title .outlined {
  display: block;
  background:
    linear-gradient(
      transparent calc(50% - 0.08em),
      var(--accent) calc(50% - 0.08em),
      var(--accent) calc(50% + 0.08em),
      transparent calc(50% + 0.08em)
    );
  color: var(--fg);
  background-clip: text;
  -webkit-background-clip: text;
}

/* Warning stamp */
.pad-stamp {
  position: absolute;
  right: 60px;
  top: 120px;
  width: 180px;
  height: 180px;
  border: 3px solid var(--accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  transform: rotate(-8deg);
  color: var(--accent);
  font-family: var(--font-head);
  z-index: 3;
  background: oklch(0.14 0.008 55 / 0.8);
}
.pad-stamp::before, .pad-stamp::after {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px dashed var(--accent);
  border-radius: 50%;
  opacity: 0.6;
}
.pad-stamp__no {
  font-size: 48px;
  line-height: 0.9;
  letter-spacing: 0.01em;
}
.pad-stamp__lbl {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  margin-top: 4px;
}

.pad-hero__bottom {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 40px;
  margin-top: 60px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  position: relative;
  z-index: 2;
}
.pad-hero__cell--poster.has-photo {
  position: relative;
  background-size: cover;
  background-position: center;
  padding: 18px;
  border: 1px solid var(--line);
  min-height: 180px;
}
.pad-hero__cell--poster.has-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0) 60%);
  pointer-events: none;
}
.pad-hero__cell--poster.has-photo > * { position: relative; z-index: 1; }
.pad-hero__cell h4 {
  font-family: var(--font-head);
  font-size: 13px;
  letter-spacing: 0.14em;
  color: var(--accent);
  margin-bottom: 8px;
}
.pad-hero__cell p {
  font-size: 14px;
  color: var(--fg-dim);
  line-height: 1.5;
}
.pad-hero__cell b {
  display: block;
  font-family: var(--font-head);
  font-size: 28px;
  color: var(--fg);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  margin-top: 4px;
}

/* Sticker pack */
.pad-stickers {
  background: oklch(0.18 0.010 55);
  padding: 40px;
  border-top: 2px solid var(--accent);
  border-bottom: 2px solid var(--accent);
  overflow: hidden;
}
.pad-stickers__row {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 1440px;
  margin: 0 auto;
}
.pad-sticker {
  padding: 10px 18px;
  border: 2px solid var(--fg);
  font-family: var(--font-head);
  font-size: 22px;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  transition: transform .15s var(--ease);
}
.pad-sticker:hover { transform: rotate(-2deg) scale(1.05); }
.pad-sticker--accent { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.pad-sticker--rot1 { transform: rotate(-3deg); }
.pad-sticker--rot2 { transform: rotate(2deg); }
.pad-sticker--rot3 { transform: rotate(-1deg); }
.pad-sticker--stencil {
  color: transparent;
  -webkit-text-stroke: 1.5px var(--fg);
  border-color: var(--fg);
}

/* Crew */
.pad-section {
  max-width: 1440px;
  margin: 0 auto;
  padding: 80px 40px;
}
.pad-section__head {
  display: flex;
  align-items: baseline;
  gap: 32px;
  margin-bottom: 32px;
  padding-bottom: 16px;
  border-bottom: 2px dashed var(--line-strong);
}
.pad-section__head .num {
  font-family: var(--font-head);
  font-size: 48px;
  line-height: 1;
  color: var(--accent);
}
.pad-section__head h2 {
  font-family: var(--font-head);
  font-size: 56px;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  flex: 1;
}
.pad-section__head .meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--fg-dim);
  text-transform: uppercase;
  text-align: right;
}

.pad-crew {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 960px) { .pad-crew { grid-template-columns: 1fr; } }
.pad-crew__card {
  background: var(--surface);
  border: 1px solid var(--line);
  position: relative;
  transition: all .2s var(--ease);
}
.pad-crew__card:hover {
  border-color: var(--accent);
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 var(--accent);
}
.pad-crew__img {
  position: relative;
  aspect-ratio: 1/1;
  border-bottom: 1px solid var(--line);
}
.pad-crew__img .ph { position: absolute; inset: 0; }
.pad-crew__tape {
  position: absolute;
  top: 12px; right: -8px;
  background: var(--accent);
  color: var(--accent-ink);
  padding: 6px 14px;
  font-family: var(--font-head);
  font-size: 16px;
  letter-spacing: 0.08em;
  transform: rotate(3deg);
  z-index: 3;
  /* Auto-width: no fixed dimensions, content-driven, no wrap.
     Long labels get clipped with ellipsis at a sane max-width
     instead of overflowing the card. */
  width: auto;
  max-width: calc(100% - 32px);
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
/* Status variants — same shape, different colour anchor.
   Add `data-status="pro|crew|driver"` to the tape to swap. */
.pad-crew__tape[data-status="crew"] {
  background: oklch(0.55 0.01 250);
  color: var(--fg);
}
.pad-crew__tape[data-status="driver"] {
  background: transparent;
  color: var(--fg);
  border: 1px solid var(--fg);
}
/* PRO is the default orange — no override needed. */
.pad-crew__num {
  position: absolute;
  bottom: 10px; left: 12px;
  font-family: var(--font-head);
  font-size: 72px;
  line-height: 0.9;
  color: var(--fg);
  mix-blend-mode: difference;
  z-index: 2;
}
.pad-crew__body {
  padding: 20px;
}
.pad-crew__name {
  font-family: var(--font-head);
  font-size: 32px;
  line-height: 1;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.pad-crew__car {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--accent);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.pad-crew__specs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  padding-top: 14px;
  border-top: 1px dashed var(--line);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--muted);
  text-transform: uppercase;
}
.pad-crew__specs b {
  display: block;
  font-family: var(--font-head);
  font-size: 22px;
  color: var(--fg);
  letter-spacing: 0.02em;
}

/* Calendar / workshop */
.pad-calendar {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
}
@media (max-width: 960px) { .pad-calendar { grid-template-columns: 1fr; } }
.pad-event {
  position: relative;
  padding: 28px;
  background: var(--surface);
  border: 1px solid var(--line);
  overflow: hidden;
  transition: all .2s var(--ease);
  cursor: pointer;
}
.pad-event:hover { background: var(--bg-2); border-color: var(--accent); }
.pad-event::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--accent);
}
.pad-event__date {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--accent);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.pad-event__name {
  font-family: var(--font-head);
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  margin-bottom: 10px;
}
.pad-event__desc {
  font-size: 13px;
  color: var(--fg-dim);
  line-height: 1.5;
  margin-bottom: 16px;
}
.pad-event__foot {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--muted);
  text-transform: uppercase;
}

/* Shop strip */
.pad-shop {
  background:
    linear-gradient(to right, oklch(0.14 0.008 55), transparent 20%),
    linear-gradient(to left, oklch(0.14 0.008 55), transparent 20%),
    repeating-linear-gradient(45deg, oklch(0.22 0.015 55) 0 4px, oklch(0.14 0.008 55) 4px 8px);
  padding: 60px 40px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.pad-shop__inner {
  max-width: 1440px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 40px;
  align-items: end;
}
@media (max-width: 720px) { .pad-shop__inner { grid-template-columns: 1fr; } }
.pad-shop h3 {
  font-family: var(--font-head);
  font-size: 72px;
  line-height: 0.9;
  text-transform: uppercase;
}
.pad-shop h3 span { color: var(--accent); }
.pad-shop p {
  font-size: 15px;
  color: var(--fg-dim);
  line-height: 1.5;
  max-width: 480px;
  margin-bottom: 18px;
}

/* Footer */
.pad-footer {
  padding: 60px 40px 30px;
  background: oklch(0.10 0.008 55);
  border-top: 2px solid var(--accent);
}
.pad-footer__grid {
  max-width: 1440px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr repeat(3, 1fr);
  gap: 40px;
}
.pad-footer h5 {
  font-family: var(--font-head);
  font-size: 14px;
  letter-spacing: 0.14em;
  color: var(--accent);
  margin-bottom: 12px;
}
.pad-footer a {
  display: block;
  padding: 4px 0;
  font-size: 14px;
  color: var(--fg-dim);
}
.pad-footer a:hover { color: var(--fg); }
.pad-footer__mono {
  max-width: 1440px;
  margin: 32px auto 0;
  padding-top: 20px;
  border-top: 1px dashed var(--line-strong);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  display: flex;
  justify-content: space-between;
}

@media (max-width: 720px) {
  .pad-hero__bottom { grid-template-columns: 1fr; gap: 20px; }
  .pad-stamp { display: none; }
  .pad-footer__grid { grid-template-columns: 1fr 1fr; }
}

/* Intro + instructional note */
.pad-intro {
  max-width: 760px;
  font-size: 16px;
  line-height: 1.6;
  color: var(--fg-dim);
  margin-bottom: 32px;
}
.pad-note {
  padding: 28px;
  background: var(--surface);
  border-left: 4px solid var(--accent);
  margin-bottom: 32px;
  font-size: 15px;
  line-height: 1.6;
  color: var(--fg-dim);
}
.pad-note b { color: var(--fg); }

/* Crew card extras for country / titles */
.pad-crew__country {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--fg-dim);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.pad-crew__titles {
  font-size: 12px;
  color: var(--fg-dim);
  line-height: 1.5;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--line);
}

/* Tracks */
.pad-tracks {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
@media (max-width: 720px) { .pad-tracks { grid-template-columns: 1fr; } }
.pad-track {
  position: relative;
  padding: 28px;
  background: var(--surface);
  border: 1px solid var(--line);
  transition: all .2s var(--ease);
}
.pad-track__photo {
  height: 180px;
  margin: -28px -28px 16px;
  background-size: cover;
  background-position: center;
}
.pad-track__photo:not(.has-photo) {
  background-image: repeating-linear-gradient(115deg, oklch(0.22 0.015 250) 0 6px, oklch(0.19 0.015 250) 6px 12px);
  position: relative;
}
.pad-track:hover { border-color: var(--accent); transform: translate(-2px, -2px); box-shadow: 4px 4px 0 var(--accent); }
.pad-track::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--accent);
}
.pad-track__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 10px;
}
.pad-track__name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.01em;
}
.pad-track__lvl {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--accent-ink);
  background: var(--accent);
  padding: 4px 8px;
  text-transform: uppercase;
  white-space: nowrap;
}
.pad-track__loc {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--fg-dim);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.pad-track__desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--fg-dim);
  margin-bottom: 16px;
}
.pad-track__foot {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--muted);
  text-transform: uppercase;
  padding-top: 12px;
  border-top: 1px dashed var(--line);
}
.pad-track__foot a { color: var(--accent); }

/* Services */
.pad-services {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
@media (max-width: 720px) { .pad-services { grid-template-columns: 1fr; } }
.pad-service {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--line);
  padding: 28px;
  transition: all .2s var(--ease);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.pad-service:hover { border-color: var(--accent); box-shadow: 4px 4px 0 var(--accent); transform: translate(-2px, -2px); }
.pad-service__tape {
  position: absolute;
  top: 14px; right: -8px;
  background: var(--accent);
  color: var(--accent-ink);
  padding: 4px 12px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.08em;
  transform: rotate(3deg);
  text-transform: uppercase;
}
.pad-service__name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 30px;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  max-width: 72%;
}
.pad-service__short {
  font-size: 14px;
  color: var(--accent);
  font-weight: 500;
}
.pad-service__long {
  font-size: 13px;
  line-height: 1.55;
  color: var(--fg-dim);
}
.pad-service__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px dashed var(--line);
}
.pad-service__price {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 20px;
  color: var(--fg);
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

/* Mock event card */
.pad-event--mock { opacity: 0.55; border-style: dashed; }
.pad-event--mock::before { background: var(--line-strong); }
.pad-event--mock .pad-event__date::before {
  content: "ПРИМЕР · ";
  color: var(--accent);
  font-weight: 700;
}

/* ============================================================
   PADDOCK — mobile responsive
   ============================================================ */

@media (max-width: 820px) {
  .pad-hero {
    padding: 36px 18px;
    grid-template-columns: 1fr !important;
    gap: 18px;
  }
  .pad-hero__stencil { font-size: clamp(60px, 18vw, 120px); line-height: 0.9; }
  .pad-hero__stamp { font-size: 22px; }
  .pad-hero__cell { padding: 18px; }
  .pad-hero__cell p { font-size: 14px; }

  .pad-hazard { padding: 20px 18px; font-size: 12px; }

  .pad-section { padding: 48px 18px; }
  .pad-section__head {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 24px;
  }
  .pad-section__head h2 { font-size: clamp(36px, 10vw, 56px); }

  .pad-crew,
  .pad-tracks,
  .pad-services {
    grid-template-columns: 1fr !important;
    gap: 12px;
  }

  .pad-events { gap: 12px; }
  .pad-event,
  .pad-event--mock {
    grid-template-columns: auto 1fr !important;
    gap: 12px;
    padding: 16px;
  }
  .pad-event__meta { font-size: 11px; }

  .pad-footer { padding: 36px 18px; }
  .pad-footer__grid { grid-template-columns: 1fr 1fr; gap: 20px; }

  .pad-stickers { display: none; }
}

@media (max-width: 480px) {
  .pad-crew, .pad-tracks, .pad-services { gap: 10px; }
  .pad-footer__grid { grid-template-columns: 1fr; }
}

/* ─── JOIN THE TEAM cta band (paddock variant) ─── */
.pad-cta {
  position: relative;
  padding: clamp(56px, 8vw, 96px) clamp(24px, 5vw, 60px);
  background: var(--accent);
  color: var(--accent-ink);
  text-align: center;
  overflow: hidden;
  margin: 0;
}
.pad-cta::before,
.pad-cta::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 64px;
  background-image: repeating-linear-gradient(
    135deg,
    var(--accent-ink) 0 14px,
    transparent 14px 28px
  );
  opacity: 0.25;
  pointer-events: none;
}
.pad-cta::before { left: 0; }
.pad-cta::after  { right: 0; }
.pad-cta h3 {
  position: relative;
  margin: 0 0 18px;
  font-family: Oswald, 'Bebas Neue', sans-serif;
  font-weight: 700;
  font-size: clamp(48px, 8vw, 120px);
  line-height: 0.92;
  letter-spacing: -0.01em;
  text-transform: uppercase;
}
.pad-cta p {
  position: relative;
  max-width: 56ch;
  margin: 0 auto 28px;
  font-family: Manrope, sans-serif;
  font-weight: 500;
  font-size: clamp(15px, 1.6vw, 18px);
  line-height: 1.55;
}
.pad-cta__btn {
  position: relative;
  display: inline-block;
  padding: 14px 32px;
  background: var(--accent-ink);
  color: var(--accent);
  font-family: Oswald, sans-serif;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  border: 2px solid var(--accent-ink);
  transition: background 120ms ease-out, color 120ms ease-out;
}
.pad-cta__btn:hover {
  background: transparent;
  color: var(--accent-ink);
}

/* ─── Scroll marquee ticker (Jersey-style strip) ─── */
.pad-marquee {
  margin: 0;
  padding: 14px 0;
  background: oklch(0.10 0.005 55);
  border-top: 1px solid oklch(0.30 0.02 60);
  border-bottom: 1px solid oklch(0.30 0.02 60);
  overflow: hidden;
}
.pad-marquee__track {
  display: flex;
  align-items: center;
  gap: 40px;
  white-space: nowrap;
  width: max-content;
  animation: padMarqueeScroll 38s linear infinite;
  font-family: Oswald, 'Bebas Neue', sans-serif;
  font-weight: 700;
  font-size: clamp(20px, 2vw, 28px);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: oklch(0.78 0.012 60);
}
.pad-marquee__track b { color: var(--accent); }
.pad-marquee__track span { display: inline-flex; align-items: center; }
.pad-marquee__track span::after {
  content: "◢";
  margin-left: 40px;
  color: var(--accent);
  font-size: 0.78em;
  line-height: 1;
}
.pad-marquee:hover .pad-marquee__track { animation-play-state: paused; }
[data-motion="off"] .pad-marquee__track,
@media (prefers-reduced-motion: reduce) {
  .pad-marquee__track { animation: none; }
}
@keyframes padMarqueeScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ─── Calendar event card with admin-uploaded photo ─── */
.pad-event.pad-event--mock.has-photo {
  position: relative;
  background-image: var(--bg-img);
  background-size: cover;
  background-position: center;
  border-color: oklch(0.30 0.02 60);
  opacity: 1;
  border-style: solid;
}
.pad-event.pad-event--mock.has-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, oklch(0.10 0.005 55 / 0.55) 0%, oklch(0.10 0.005 55 / 0.92) 80%);
  pointer-events: none;
  z-index: 0;
}
.pad-event.pad-event--mock.has-photo > * { position: relative; z-index: 1; }
.pad-event.pad-event--mock.has-photo .pad-event__date,
.pad-event.pad-event--mock.has-photo .pad-event__name,
.pad-event.pad-event--mock.has-photo .pad-event__desc,
.pad-event.pad-event--mock.has-photo .pad-event__foot { color: oklch(0.94 0.005 60); }

/* NEXT EVENT: when admin uploaded photo, swap SVG → real image */
.pad-next.has-photo img.pad-next__car {
  width: clamp(220px, 28vw, 360px);
  height: auto;
  max-height: 160px;
  object-fit: cover;
  border: 1.5px solid oklch(0.30 0.02 60);
  filter: drop-shadow(0 8px 14px oklch(0 0 0 / 0.45));
}

/* ─── Calendar: kicker on event card date ─── */
.pad-event__date .kicker {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 500;
  font-size: 0.78em;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  opacity: 0.85;
  margin-right: 4px;
}

/* ─── NEXT EVENT countdown hero ─── */
.pad-next {
  position: relative;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto minmax(380px, auto) auto;
  align-items: center;
  gap: clamp(16px, 3vw, 36px);
  margin: 28px 0 36px;
  padding: clamp(18px, 2.5vw, 28px) clamp(20px, 3vw, 36px);
  border: 2px solid var(--accent);
  background: oklch(0.13 0.008 55);
  overflow: hidden;
}
.pad-next::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 80% at 50% 110%, oklch(0.32 0.18 60 / 0.18), transparent 60%);
  pointer-events: none;
}
.pad-next > * { position: relative; }
.pad-next .kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  display: block;
  margin-bottom: 6px;
}
.pad-next h3 {
  font-family: Oswald, sans-serif;
  font-weight: 700;
  font-size: clamp(22px, 2.6vw, 32px);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  margin: 0 0 4px;
  color: oklch(0.96 0.005 60);
}
.pad-next__sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  color: oklch(0.66 0.015 60);
  margin: 0;
  text-transform: uppercase;
}
.pad-next__car {
  width: clamp(180px, 22vw, 280px);
  height: auto;
  filter: drop-shadow(0 8px 14px oklch(0 0 0 / 0.45));
}
.pad-next__count {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.pad-next__count-lab {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: oklch(0.66 0.015 60);
  margin: 0;
}
.pad-next__cells {
  display: grid;
  grid-template-columns: repeat(4, minmax(60px, 70px));
  gap: 14px;
}
.pad-next__cells > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  border-left: 1px solid oklch(0.30 0.02 60);
  padding-left: 14px;
}
.pad-next__cells > div:first-child { border-left: 0; padding-left: 0; }
.pad-next__cells b {
  font-family: Oswald, sans-serif;
  font-weight: 700;
  font-size: clamp(34px, 4vw, 52px);
  line-height: 0.95;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.pad-next__cells span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: oklch(0.66 0.015 60);
  margin-top: 4px;
}
.pad-next__cta {
  border: 1.5px solid var(--accent);
  color: var(--accent);
  font-family: Oswald, sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 12px 22px;
  text-decoration: none;
  white-space: nowrap;
  transition: background 120ms ease-out, color 120ms ease-out;
}
.pad-next__cta:hover { background: var(--accent); color: var(--accent-ink); }

/* ─── EVENT MAP ─── */
.pad-evmap {
  display: grid;
  grid-template-columns: minmax(280px, 360px) 1fr;
  gap: 0;
  margin: 28px 0;
  border: 2px solid oklch(0.30 0.02 60);
  background: oklch(0.13 0.008 55);
  overflow: hidden;
}
.pad-evmap__list {
  padding: 22px 22px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-right: 1px solid oklch(0.22 0.01 55);
}
.pad-evmap__list .kicker {
  font-family: Oswald, sans-serif;
  font-weight: 700;
  font-size: clamp(18px, 1.8vw, 24px);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: oklch(0.96 0.005 60);
  margin-bottom: 0;
}
.pad-evmap__sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: oklch(0.66 0.015 60);
  margin: 0 0 14px;
  text-transform: uppercase;
}
.pad-evmap__row {
  display: grid;
  grid-template-columns: 36px 1fr 16px;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: oklch(0.16 0.010 55);
  text-decoration: none;
  color: inherit;
  transition: background 120ms ease-out;
}
.pad-evmap__row:hover { background: oklch(0.20 0.012 55); }
.pad-evmap__row .num {
  display: inline-grid;
  place-items: center;
  width: 28px; height: 28px;
  background: var(--accent);
  color: var(--accent-ink);
  font-family: Oswald, sans-serif;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.04em;
}
.pad-evmap__row .who {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pad-evmap__row .who b {
  font-family: Oswald, sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: oklch(0.96 0.005 60);
}
.pad-evmap__row .who em {
  font-family: 'JetBrains Mono', monospace;
  font-style: normal;
  font-size: 10px;
  letter-spacing: 0.14em;
  color: oklch(0.62 0.015 60);
  text-transform: uppercase;
}
.pad-evmap__row .arr {
  font-family: Oswald, sans-serif;
  font-size: 18px;
  color: var(--accent);
}
.pad-evmap__all {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  border: 1px solid oklch(0.30 0.02 60);
  text-decoration: none;
  color: oklch(0.96 0.005 60);
  font-family: Oswald, sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.pad-evmap__all:hover { border-color: var(--accent); color: var(--accent); }
.pad-evmap__all span { color: var(--accent); font-size: 16px; }
.pad-evmap__map {
  position: relative;
  margin: 0;
  background: oklch(0.10 0.005 55);
  min-height: 360px;
}
.pad-evmap__map svg {
  display: block;
  width: 100%;
  height: 100%;
}
.pad-evmap__pin { cursor: pointer; }
.pad-evmap__pin circle:nth-of-type(2) {
  transition: r 120ms ease-out, fill 120ms ease-out;
}
.pad-evmap__pin:hover circle:nth-of-type(2) { r: 16; }
.pad-evmap__pop {
  background: oklch(0.13 0.008 55);
  border: 1.5px solid var(--accent);
  padding: 8px 12px;
  font-family: 'JetBrains Mono', monospace;
}
.pad-evmap__pop-name {
  font-family: Oswald, sans-serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: oklch(0.96 0.005 60);
  margin: 0 0 2px;
}
.pad-evmap__pop-date {
  font-size: 9px;
  letter-spacing: 0.12em;
  color: oklch(0.66 0.015 60);
  margin: 0 0 4px;
}
.pad-evmap__pop a {
  font-family: Oswald, sans-serif;
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--accent);
  text-decoration: none;
  text-transform: uppercase;
}
.pad-evmap__zoom {
  position: absolute;
  right: 14px;
  bottom: 14px;
  display: flex;
  flex-direction: column;
  border: 1px solid oklch(0.30 0.02 60);
  background: oklch(0.13 0.008 55);
}
.pad-evmap__zoom button {
  width: 30px; height: 30px;
  background: transparent;
  color: oklch(0.96 0.005 60);
  border: 0;
  font-family: Oswald, sans-serif;
  font-weight: 700;
  font-size: 16px;
  cursor: pointer;
}
.pad-evmap__zoom button:first-child { border-bottom: 1px solid oklch(0.30 0.02 60); }
.pad-evmap__zoom button:hover { color: var(--accent); }

@media (max-width: 1024px) {
  .pad-next {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "left  car"
      "count count"
      "cta   cta";
    gap: 18px;
  }
  .pad-next__left  { grid-area: left; }
  .pad-next__car   { grid-area: car; justify-self: end; }
  .pad-next__count { grid-area: count; }
  .pad-next__cta   { grid-area: cta; justify-self: start; }
  .pad-evmap { grid-template-columns: 1fr; }
  .pad-evmap__list { border-right: 0; border-bottom: 1px solid oklch(0.22 0.01 55); }
  .pad-evmap__map { min-height: 320px; }
}

@media (max-width: 640px) {
  .pad-next__cells { grid-template-columns: repeat(4, 1fr); gap: 8px; }
  .pad-next__cells > div { padding-left: 8px; }
  .pad-evmap__map { min-height: 260px; }
}

/* ─── iPhone-class screens (≤480) — compact paddock layouts ─── */
@media (max-width: 480px) {
  /* Hero title: tighten leading so 3 huge stacked words don't push the page */
  .pad-hero__title {
    font-size: clamp(56px, 18vw, 96px);
    line-height: 0.86;
    letter-spacing: -0.01em;
  }
  .pad-hero__title .stencil { -webkit-text-stroke-width: 2px; }

  /* Hero top meta line wraps to two rows; tighten spacing */
  .pad-hero__top {
    flex-wrap: wrap;
    gap: 8px;
    font-size: 10px;
  }

  /* Section heads stack a bit cleaner */
  .pad-section__head { padding-left: 16px; padding-right: 16px; }
  .pad-section__head .num { font-size: 64px; }

  /* Marquee: smaller text + slower scroll feels nicer on narrow screens */
  .pad-marquee { padding: 10px 0; }
  .pad-marquee__track {
    font-size: 17px;
    gap: 26px;
    animation-duration: 28s;
  }
  .pad-marquee__track span::after { margin-left: 26px; }

  /* NEXT EVENT — fully stacked. Keep countdown horizontal but smaller. */
  .pad-next {
    grid-template-columns: 1fr;
    grid-template-areas:
      "left"
      "car"
      "count"
      "cta";
    gap: 14px;
    padding: 18px 16px;
  }
  .pad-next h3 { font-size: 24px; line-height: 1; }
  .pad-next__sub { font-size: 10px; }
  .pad-next__car { width: 100%; max-width: 320px; justify-self: start; }
  .pad-next.has-photo img.pad-next__car { max-height: 140px; width: 100%; }
  .pad-next__cells { grid-template-columns: repeat(4, 1fr); gap: 6px; }
  .pad-next__cells > div { padding-left: 6px; align-items: flex-start; }
  .pad-next__cells > div:first-child { padding-left: 0; }
  .pad-next__cells b { font-size: 26px; }
  .pad-next__cells span { font-size: 9px; letter-spacing: 0.14em; }
  .pad-next__cta { padding: 10px 18px; font-size: 11px; letter-spacing: 0.14em; }

  /* EVENT MAP — collapse + shorter map */
  .pad-evmap__list { padding: 16px; }
  .pad-evmap__list .kicker { font-size: 18px; }
  .pad-evmap__row { padding: 8px 10px; }
  .pad-evmap__row .num { width: 24px; height: 24px; font-size: 11px; }
  .pad-evmap__row .who b { font-size: 12px; }
  .pad-evmap__map { min-height: 220px; }
  .pad-evmap__zoom { right: 10px; bottom: 10px; }
  .pad-evmap__zoom button { width: 26px; height: 26px; font-size: 14px; }

  /* Calendar event cards: reduce padding so dense kicker line still fits */
  .pad-event { padding: 14px; }
  .pad-event__name { font-size: 22px; line-height: 1.05; }
  .pad-event__date { font-size: 11px; letter-spacing: 0.04em; flex-wrap: wrap; }
  .pad-event__date .kicker { font-size: 9px; letter-spacing: 0.16em; }
  .pad-event__desc { font-size: 13px; line-height: 1.45; }
  .pad-event__foot { font-size: 10px; gap: 6px; }

  /* JOIN THE TEAM CTA: tighten the giant headline + button */
  .pad-cta { padding: 48px 20px; }
  .pad-cta h3 { font-size: clamp(40px, 14vw, 64px); }
  .pad-cta p { font-size: 14px; line-height: 1.5; margin-bottom: 22px; }
  .pad-cta__btn { padding: 12px 22px; font-size: 12px; letter-spacing: 0.14em; }
  /* Hide the diagonal hazard side-strips on narrow phones — they steal width */
  .pad-cta::before, .pad-cta::after { width: 24px; opacity: 0.18; }

  /* Footer: tighter mono row */
  .pad-footer { padding: 18px 16px; }
  .pad-footer__mono { flex-direction: column; gap: 4px; align-items: flex-start; font-size: 10px; }
}

/* ─── Notch + dynamic island safe-area on landscape too ─── */
@supports (padding: max(0px)) {
  .pad-strip { padding-top: max(0px, env(safe-area-inset-top)); }
  .topbar { padding-left: max(16px, env(safe-area-inset-left)); padding-right: max(16px, env(safe-area-inset-right)); }
  .pad-section, .pad-cta, .pad-marquee, .pad-evmap, .pad-next {
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
  }
}
